html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
font,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
figure {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    font-weight: normal;
    vertical-align: baseline;
    background: transparent
}

a {
    text-decoration: none
}

a:active {
    outline: none
}

input,
textarea,
submit {
    -webkit-appearance: none;
    border-radius: 0
}

body {
    line-height: 1
}

ol,
ul {
    list-style: none
}

blockquote,
q {
    quotes: none
}

blockquote:before,
blockquote:after,
q:before,
q:after {
    content: '';
    content: none
}

:focus {
    outline: 0;
    -moz-outline-style: none
}

ins {
    text-decoration: none
}

del {
    text-decoration: line-through
}

table {
    border-collapse: collapse;
    border-spacing: 0
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
    display: block
}

#breadcrumbs {
    padding: 20px 0
}

@media screen and (max-width: 1000px) {
    #breadcrumbs {
        padding: 20px 0
    }
}

#breadcrumbs:not(.bg-blue) {
    border-bottom: 1px solid #e3d9d1
}

#breadcrumbs.bg-blue {
    border-top: 1px solid rgba(255, 255, 255, 0.2)
}

#breadcrumbs.bg-blue:not(.m-bottom-no) {
    margin-bottom: 5vw
}

@media screen and (max-width: 1000px) {
    #breadcrumbs.bg-blue:not(.m-bottom-no) {
        margin-bottom: 10vw
    }
}

#breadcrumbs.bg-blue .container a {
    color: rgba(255, 255, 255, 0.5)
}

#breadcrumbs .container a {
    color: #121730;
    display: inline-block;
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    padding: 5px 5px 5px 0
}

@media (hover:hover) and (pointer:fine) {
    #breadcrumbs .container a {
        transition: padding .35s ease-in-out;
        -moz-transition: padding .35s ease-in-out;
        -o-transition: padding .35s ease-in-out;
        -webkit-transition: padding .35s ease-in-out
    }
    #breadcrumbs .container a:hover {
        padding: 5px 0
    }
    #breadcrumbs .container a:hover svg {
        margin-right: 10px
    }
    #breadcrumbs .container a svg {
        transition: margin .35s ease-in-out;
        -moz-transition: margin .35s ease-in-out;
        -o-transition: margin .35s ease-in-out;
        -webkit-transition: margin .35s ease-in-out
    }
}

#breadcrumbs .container a svg {
    height: 12px;
    margin-right: 5px;
    -webkit-transform: scaleY(-1);
    transform: scaleY(-1);
    width: 25px
}

#breadcrumbs .container a svg path {
    fill: #e6af79
}

ul.btns {
    display: block;
    margin-bottom: 0 !important;
    position: relative;
    left: -15px
}

@media screen and (max-width: 800px) {
    ul.btns {
        left: 15px
    }
}

ul.btns:before {
    border: 2px solid #e6af79;
    border-radius: 8px;
    content: '';
    display: block;
    height: 8px;
    left: -15px;
    position: absolute;
    top: 13px;
    width: 8px
}

@media (hover:hover) and (pointer:fine) {
    ul.btns:before {
        transition: border .25s ease-in-out, background .25s ease-in-out;
        -moz-transition: border .25s ease-in-out, background .25s ease-in-out;
        -o-transition: border .25s ease-in-out, background .25s ease-in-out;
        -webkit-transition: border .25s ease-in-out, background .25s ease-in-out
    }
}

ul.btns li {
    display: inline-block;
    margin: 0 10px 20px 0;
    padding: 0 !important
}

ul.btns li:last-of-type {
    margin-right: 0
}

ul.btns li a {
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: .66rem;
    letter-spacing: .2em;
    padding: 15px;
    text-transform: uppercase
}

@media screen and (max-width: 800px) {
    ul.btns li a {
        font-size: .6rem
    }
}

@media (hover:hover) and (pointer:fine) {
    ul.btns:hover:before {
        background-color: #cacfe4;
        border-color: #cacfe4
    }
    ul.btns.light li a,
    ul.btns.dark li a {
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out
    }
    ul.btns.light li a:hover,
    ul.btns.dark li a:hover {
        padding-right: 10px;
        padding-left: 20px
    }
    ul.btns.light li a:hover {
        color: #e6af79
    }
    ul.btns.dark li a:hover {
        color: rgba(18, 23, 48, 0.5)
    }
}

ul.btns.light li a {
    color: #fff
}

ul.btns.dark li a {
    color: #121730
}

a.btn {
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: .66rem;
    letter-spacing: .2em;
    padding: 15px;
    text-transform: uppercase
}

@media screen and (max-width: 800px) {
    a.btn {
        font-size: .6rem
    }
}

#paginate {
    border-top: 1px solid #e9e2dc;
    margin-top: 5vw
}

@media screen and (max-width: 800px) {
    #paginate {
        margin-top: 10vw
    }
}

#paginate.no-margin {
    margin-top: 0
}

#paginate ul:after {
    clear: both;
    content: "";
    display: block
}

@media screen and (min-width: 1001px) {
    #paginate ul {
        padding: 2vw 5vw
    }
}

@media screen and (min-width: 800px) and (max-width: 1000px) {
    #paginate ul {
        padding: 0 10vw 5vw
    }
}

@media screen and (max-width: 800px) {
    #paginate ul {
        padding: 0 10vw 5vw
    }
}

#paginate ul li {
    display: inline;
    float: left;
    min-height: 1px;
    width: 50%
}

#paginate ul li:nth-of-type(1) a {
    padding: 20px 20px 20px 0
}

@media (hover:hover) and (pointer:fine) {
    #paginate ul li:nth-of-type(1) a:hover {
        padding: 20px 10px 20px 10px
    }
}

#paginate ul li:nth-of-type(2) a {
    padding: 20px 0 20px 20px;
    text-align: right
}

@media (hover:hover) and (pointer:fine) {
    #paginate ul li:nth-of-type(2) a:hover {
        padding: 20px 10px 20px 10px
    }
}

#paginate ul li a {
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    color: #474747;
    display: block;
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: .5625rem;
    letter-spacing: .2em;
    text-overflow: ellipsis;
    text-transform: uppercase;
    white-space: nowrap;
    width: 100%
}

@media (hover:hover) and (pointer:fine) {
    #paginate ul li a {
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out
    }
}

.ui-corner-all,
.ui-corner-top,
.ui-corner-bottom,
.ui-corner-left,
.ui-corner-right,
.ui-corner-tl,
.ui-corner-tr,
.ui-corner-bl,
.ui-corner-br {
    border-radius: 0 !important;
    -moz-border-radius: 0 !important;
    -webkit-border-radius: 0 !important
}

.ui-state-default,
.ui-widget-content .ui-state-default,
.ui-widget-header .ui-state-default {
    background-image: none !important
}

.accordions {
    clear: both;
    display: block;
    margin: 1px 0 30px
}

.accordions .accordion {
    border: 1px solid rgba(18, 23, 48, 0.2) !important;
    border-radius: 10px;
    -moz-border-radius: 10px;
    -webkit-border-radius: 10px;
    overflow: hidden
}

.accordions .accordion+.accordion {
    margin-top: 1rem
}

.accordions h3.ui-accordion-header {
    color: #121730 !important;
    cursor: pointer;
    line-height: 1.4;
    letter-spacing: normal !important;
    margin: 0 !important;
    padding: 20px 25px 20px 50px;
    position: relative;
    text-transform: none !important;
    transition: all .35s ease-in-out;
    -moz-transition: all .35s ease-in-out;
    -o-transition: all .35s ease-in-out;
    -webkit-transition: all .35s ease-in-out
}

@media screen and (max-width: 800px) {
    .accordions h3.ui-accordion-header {
        font-size: .85rem !important
    }
}

.accordions h3.ui-accordion-header.ui-state-active {
    background: #121730 !important;
    border-bottom: 4px solid #e6af79 !important;
    border-left: 0 solid #121730;
    color: #fff !important
}

.accordions h3.ui-accordion-header.ui-state-active span {
    border-top-color: #fff;
    border-left-color: #fff;
    rotate: 45deg;
    top: 31px
}

@media screen and (max-width: 800px) {
    .accordions h3.ui-accordion-header.ui-state-active span {
        top: 27px
    }
}

.accordions h3.ui-accordion-header span {
    border-top: 2px solid #121730;
    border-left: 2px solid #121730;
    height: 10px;
    left: 22px;
    position: absolute;
    rotate: 225deg;
    top: 26px;
    transition: rotate .25s ease-in-out, top .25s ease-in-out;
    width: 10px
}

@media screen and (max-width: 800px) {
    .accordions h3.ui-accordion-header span {
        top: 22px
    }
}

@media screen and (min-width: 1001px) {
    .accordions h3.ui-accordion-header:hover {
        background: #121730 !important;
        color: #fff !important
    }
    .accordions h3.ui-accordion-header:hover span {
        border-top-color: #e6af79;
        border-left-color: #e6af79
    }
}

.accordions .ui-accordion-content {
    background-color: #f9f7f6;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding: 2rem;
    top: 0 !important
}

.accordions .ui-accordion-content>*:last-child {
    margin-bottom: 0
}

body .gform_wrapper.gravity-theme {
    min-width: 100%
}

body .gform_wrapper.gravity-theme form[data-active-form="true"] {
    opacity: .5
}

body .gform_wrapper.gravity-theme form[data-active-form="true"] .gform_footer input.button,
body .gform_wrapper.gravity-theme form[data-active-form="true"] .gform_footer input[type="submit"] {
    pointer-events: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

body .gform_wrapper.gravity-theme .gform-loader {
    position: fixed !important;
    top: 50% !important;
    left: 50% !important;
    z-index: 1000000 !important;
    margin: -10px 0 0 -8px !important
}

body .gform_wrapper.gravity-theme input[type="text"],
body .gform_wrapper.gravity-theme input[type="email"],
body .gform_wrapper.gravity-theme input[type="tel"],
body .gform_wrapper.gravity-theme textarea {
    border: 1px solid #e2e2e2;
    border-radius: 6px;
    -moz-border-radius: 6px;
    -webkit-border-radius: 6px;
    font-family: "roc-grotesk", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1em;
    padding: 15px !important;
    width: 100% !important
}

body .gform_wrapper.gravity-theme input[type="text"]:focus,
body .gform_wrapper.gravity-theme input[type="email"]:focus,
body .gform_wrapper.gravity-theme input[type="tel"]:focus,
body .gform_wrapper.gravity-theme textarea:focus {
    border-color: #121730
}

body .gform_wrapper.gravity-theme select {
    background-color: #fff;
    background-image: linear-gradient(45deg, transparent 50%, #121730 50%), linear-gradient(135deg, #121730 50%, transparent 50%), linear-gradient(to right, #e2e2e2, #e2e2e2);
    background-position: calc(100% - 20px) calc(1.25em + 4px), calc(100% - 15px) calc(1.25em + 4px), calc(100% - 2.5em) 1em;
    background-size: 5px 5px, 5px 5px, 1px 1.5em;
    background-repeat: no-repeat;
    border: 1px solid #e2e2e2;
    border-radius: 6px;
    -moz-border-radius: 6px;
    -webkit-border-radius: 6px;
    color: #2e1f15;
    padding: 18px 15px 20px !important;
    -webkit-appearance: none;
    -moz-appearance: none
}

body .gform_wrapper.gravity-theme select:focus {
    border-color: #121730
}

body .gform_wrapper.gravity-theme .gfield {
    padding-bottom: .5rem !important
}

body .gform_wrapper.gravity-theme .gsection {
    border-bottom-color: #e9e2dc !important;
    padding: 3rem 0 0 !important;
    margin-bottom: 1rem
}

body .gform_wrapper.gravity-theme .gsection h3 {
    margin-bottom: 10px
}

body .gform_wrapper.gravity-theme .gfield_description {
    font-size: .7rem !important
}

body .gform_wrapper.gravity-theme .gfield_description:not(.validation_message) {
    padding-top: 0 !important
}

body .gform_wrapper.gravity-theme ul.gform_fields li.gfield {
    padding-right: 0
}

body .gform_wrapper.gravity-theme input[type="checkbox"] {
    appearance: checkbox;
    -moz-appearance: checkbox;
    -webkit-appearance: checkbox;
    margin-left: 5px !important;
    position: relative;
    top: 1px;
    vertical-align: top
}

body .gform_wrapper.gravity-theme input[type="radio"] {
    appearance: radio-button;
    -moz-appearance: radio;
    -webkit-appearance: radio;
    margin-left: 5px !important;
    position: relative;
    top: 3px;
    vertical-align: top
}

body .gform_wrapper.gravity-theme li {
    margin-bottom: 10px;
    padding-left: 0
}

body .gform_wrapper.gravity-theme .gfield.col {
    display: inline;
    width: 50%
}

body .gform_wrapper.gravity-theme .gfield.col.col-left {
    float: left;
    padding-right: 8px !important
}

body .gform_wrapper.gravity-theme .gfield.col.col-right {
    clear: none;
    float: right;
    padding-left: 8px !important
}

body .gform_wrapper.gravity-theme .top_label .gfield_label {
    font-size: 16px;
    font-weight: bold
}

body .gform_wrapper.gravity-theme .ginput_complex label {
    color: #757575;
    font-size: .7rem;
    margin-bottom: 0
}

body .gform_wrapper.gravity-theme .ginput_complex span {
    display: inline-block;
    margin-bottom: 6px
}

body .gform_wrapper.gravity-theme .ginput_full {
    width: 100%
}

body .gform_wrapper.gravity-theme .ginput_left {
    clear: left
}

body .gform_wrapper.gravity-theme .gfield_html {
    background-color: rgba(227, 217, 209, 0.35);
    border: 1px solid rgba(227, 217, 209, 0.7);
    border-radius: 10px;
    font-size: .8rem;
    margin: 1.5rem 0;
    padding: 35px
}

body .gform_wrapper.gravity-theme .gform_footer {
    margin: 30px 0 0;
    padding: 0
}

body .gform_wrapper.gravity-theme .gform_footer input.button,
body .gform_wrapper.gravity-theme .gform_footer input[type="submit"] {
    background: #121730;
    border: none;
    border-radius: 6px;
    -moz-border-radius: 6px;
    -webkit-border-radius: 6px;
    color: #ffffff;
    cursor: pointer;
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: .8rem;
    letter-spacing: .2em;
    margin: 0;
    padding: 30px;
    text-transform: uppercase;
    transition: all .35s ease-in-out;
    -moz-transition: all .35s ease-in-out;
    -o-transition: all .35s ease-in-out;
    -webkit-transition: all .35s ease-in-out;
    width: 100%
}

body .gform_wrapper.gravity-theme .gform_footer input.button:hover,
body .gform_wrapper.gravity-theme .gform_footer input[type="submit"]:hover {
    background: #e6af79
}

body .gform_confirmation_wrapper {
    border: 3px solid #e6af79;
    border-radius: 20px;
    -moz-border-radius: 20px;
    -webkit-border-radius: 20px;
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: 1.5rem;
    padding: 1.5rem;
    text-align: center
}

body .gform_confirmation_wrapper .gform_confirmation_message {
    margin: auto;
    max-width: 800px
}

.lity-active body {
    overflow: hidden
}

.lity-inline .lity-content>* {
    max-height: none !important
}

.lity-inline .lity-wrap {
    overflow: auto
}

.lity-inline .lity-content {
    margin: 20px 0
}

.lity {
    z-index: 9990;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    white-space: nowrap;
    background: #121730;
    outline: none !important;
    opacity: 0;
    transition: opacity .3s ease
}

.lity.lity-opened {
    opacity: 1
}

.lity.lity-closed {
    opacity: 0
}

.lity * {
    box-sizing: border-box
}

.lity-wrap {
    z-index: 9990;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    text-align: center;
    outline: none !important
}

.lity-wrap:before {
    content: '';
    display: inline-block;
    height: 100%;
    vertical-align: middle;
    margin-right: -0.25em
}

.lity-loader {
    z-index: 9991;
    color: #fff;
    position: absolute;
    top: 50%;
    margin-top: -0.8em;
    width: 100%;
    text-align: center;
    font-size: 14px;
    font-family: Arial, Helvetica, sans-serif;
    opacity: 0;
    transition: opacity .3s ease
}

.lity-loading .lity-loader {
    opacity: 1
}

.lity-container {
    z-index: 9992;
    position: relative;
    text-align: left;
    vertical-align: middle;
    display: inline-block;
    white-space: normal;
    max-width: 100%;
    max-height: 100%;
    outline: none !important
}

.lity-content {
    z-index: 9993;
    width: 100%;
    opacity: 1;
    padding: 5vw 0;
    position: relative;
    top: 0;
    transition: opacity .3s ease, top .3s ease
}

.lity-loading .lity-content,
.lity-closed .lity-content {
    opacity: 0;
    top: 50px
}

.lity-content:after {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    display: block;
    right: 0;
    width: auto;
    height: auto;
    z-index: -1
}

.lity-close {
    z-index: 9994;
    width: 35px;
    height: 35px;
    position: fixed;
    right: 0;
    top: 0;
    -webkit-appearance: none;
    cursor: pointer;
    text-decoration: none;
    text-align: center;
    padding: 0;
    color: #fff;
    font-style: normal;
    font-size: 35px;
    font-family: Arial, Baskerville, monospace;
    line-height: 35px;
    border: 0;
    background: none;
    outline: none;
    box-shadow: none
}

.lity-close::-moz-focus-inner {
    border: 0;
    padding: 0
}

.lity-close:hover,
.lity-close:focus,
.lity-close:active,
.lity-close:visited {
    text-decoration: none;
    text-align: center;
    padding: 0;
    color: #fff;
    font-style: normal;
    font-size: 35px;
    font-family: Arial, Baskerville, monospace;
    line-height: 35px;
    border: 0;
    background: none;
    outline: none;
    box-shadow: none
}

.lity-close:active {
    top: 1px
}

.lity-content .basic-content {
    color: #fff;
    max-width: 960px;
    padding: 0 10vw
}

.lity-content .basic-content .p-top {
    padding-top: 6vw !important
}

@media screen and (max-width: 800px) {
    .lity-content .basic-content .p-top {
        padding-top: 16vw !important
    }
}

.lity-image img {
    max-width: 100%;
    display: block;
    line-height: 0;
    border: 0
}

.lity-iframe .lity-container,
.lity-youtube .lity-container,
.lity-vimeo .lity-container,
.lity-facebookvideo .lity-container,
.lity-googlemaps .lity-container {
    width: 100%;
    max-width: 964px
}

.lity-iframe-container {
    width: 100%;
    height: 0;
    padding-top: 9/16 * 100%;
    overflow: auto;
    pointer-events: auto;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    -webkit-overflow-scrolling: touch
}

.lity-iframe-container iframe {
    position: absolute;
    display: block;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #000
}

.lity-hide {
    display: none
}

.splide__track {
    height: 100%
}

.splide__track ul {
    height: 100%
}

.splide__track ul li {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    height: 100%
}

.title.title-pre {
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: .72rem;
    letter-spacing: .2em;
    margin-bottom: 1rem;
    text-transform: uppercase
}

@media screen and (max-width: 800px) {
    .title.title-pre {
        font-size: .6em
    }
}

.title.title-large {
    font-family: "roc-grotesk", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 4.166rem;
    line-height: 1
}

@media screen and (max-width: 800px) {
    .title.title-large {
        font-size: 2.2rem
    }
}

.title.title-medium {
    font-family: "roc-grotesk", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 3rem;
    line-height: 1
}

@media screen and (max-width: 1000px) {
    .title.title-medium {
        line-height: 1.25
    }
}

@media screen and (max-width: 800px) {
    .title.title-medium {
        font-size: 2rem
    }
}

.title.title-main {
    font-family: "roc-grotesk", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1.66rem;
    line-height: 1.5;
    margin-bottom: 1rem
}

@media screen and (max-width: 800px) {
    .title.title-main {
        font-size: 1.4rem
    }
}

.title.m-b {
    margin-bottom: 5vw
}

.title.m-basic {
    margin-bottom: 2rem
}

.numbered-group {
    padding: 40px 0 0 60px
}

@media screen and (max-width: 800px) {
    .numbered-group {
        padding-left: 50px
    }
}

.numbered-group .numbered {
    font-family: "roc-grotesk", sans-serif !important;
    font-weight: 600 !important;
    font-style: normal !important;
    font-size: 1.1rem !important;
    margin-bottom: 10px !important;
    position: relative
}

.numbered-group .numbered:first-of-type {
    padding-top: 10px
}

.numbered-group .numbered:not(:first-of-type) {
    border-top: 1px solid rgba(26, 32, 63, 0.15);
    padding-top: 40px
}

.numbered-group .numbered:not(:first-of-type) strong {
    top: 36px
}

.numbered-group .numbered strong {
    background-color: rgba(26, 32, 63, 0.5);
    border-radius: 50%;
    color: #fff;
    font-size: .65rem;
    height: 36px;
    left: -60px;
    line-height: 36px;
    position: absolute;
    text-align: center;
    top: 6px;
    width: 36px
}

@media screen and (max-width: 800px) {
    .numbered-group .numbered strong {
        left: -50px
    }
}

.c-o {
    color: #e6af79
}

.c-w {
    color: #fff
}

.c-b5 {
    color: #121730;
    opacity: .5
}

.para-medium {
    font-size: 1.4rem;
    line-height: 1.4;
    max-width: 80ch
}

@media screen and (max-width: 800px) {
    .para-medium {
        font-size: 1.25rem
    }
}

.para-large {
    font-size: 1.66rem;
    line-height: 1.5;
    max-width: 60ch
}

@media screen and (max-width: 800px) {
    .para-large {
        font-size: 1.3rem
    }
}

.para-medium,
.para-large {
    font-family: "roc-grotesk", sans-serif;
    font-weight: 400;
    font-style: normal
}

.para-medium a,
.para-large a {
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    position: relative;
    white-space: nowrap
}

@media (hover:hover) and (pointer:fine) {
    .para-medium a,
    .para-large a {
        transition: color .35s ease-in-out;
        -moz-transition: color .35s ease-in-out;
        -o-transition: color .35s ease-in-out;
        -webkit-transition: color .35s ease-in-out
    }
}

@media (hover:hover) and (pointer:fine) and (hover:hover) and (pointer:fine) {
    .para-medium a:hover span svg,
    .para-large a:hover span svg {
        left: -10px
    }
}

.para-medium a span,
.para-large a span {
    bottom: -15px;
    height: 20px;
    left: 0;
    line-height: 0;
    overflow: hidden;
    position: absolute;
    width: 100%
}

.para-medium a span svg,
.para-large a span svg {
    height: 20px;
    left: 0;
    position: relative;
    width: 400px
}

@media (hover:hover) and (pointer:fine) {
    .para-medium a span svg,
    .para-large a span svg {
        transition: left .25s ease-in-out;
        -moz-transition: left .25s ease-in-out;
        -o-transition: left .25s ease-in-out;
        -webkit-transition: left .25s ease-in-out
    }
}

.content {
    font-family: "soleil", sans-serif;
    font-weight: 400;
    font-style: normal;
    position: relative
}

.content a,
.content strong {
    font-weight: 700
}

.content h1:not(.title) {
    font-family: "roc-grotesk", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 2.5rem;
    line-height: 1.4;
    margin-bottom: 20px
}

@media screen and (max-width: 800px) {
    .content h1:not(.title) {
        font-size: 1.8rem
    }
}

.content h2:not(.title) {
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: 1.35rem;
    line-height: 1.4;
    margin-bottom: 20px
}

.content h3:not(.title) {
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: 1.2rem;
    line-height: 1.4;
    margin-bottom: 20px
}

.content p {
    line-height: 1.8;
    margin-bottom: 24px
}

.content p a {
    transition: all .35s ease-in-out;
    -moz-transition: all .35s ease-in-out;
    -o-transition: all .35s ease-in-out;
    -webkit-transition: all .35s ease-in-out
}

@media screen and (max-width: 800px) {
    .content p {
        font-size: .8rem
    }
}

.content ol {
    margin-bottom: 24px
}

.content ol a {
    transition: all .35s ease-in-out;
    -moz-transition: all .35s ease-in-out;
    -o-transition: all .35s ease-in-out;
    -webkit-transition: all .35s ease-in-out
}

.content ol li {
    font-family: "roc-grotesk", sans-serif;
    font-weight: 400;
    font-style: normal;
    line-height: 1.8;
    list-style: decimal;
    margin-left: 30px;
    padding: 0 0 15px 30px;
    position: relative
}

@media screen and (max-width: 800px) {
    .content ol li {
        font-size: .8rem
    }
}

.content ol ol {
    margin-bottom: 5px
}

.content ul {
    margin-bottom: 24px
}

.content ul a {
    transition: all .35s ease-in-out;
    -moz-transition: all .35s ease-in-out;
    -o-transition: all .35s ease-in-out;
    -webkit-transition: all .35s ease-in-out
}

.content ul li {
    line-height: 1.8;
    padding: 0 0 15px 30px;
    position: relative
}

.content ul li:last-of-type {
    padding-bottom: 0
}

.content ul li:before {
    content: "- ";
    left: 0;
    position: absolute
}

@media screen and (max-width: 800px) {
    .content ul li {
        font-size: .8rem
    }
}

.content ul li ul {
    margin-bottom: 0;
    padding-top: 15px
}

.content ul li ul li:before {
    content: "○ "
}

@media screen and (min-width: 1001px) {
    .content ul.btns li a:hover {
        opacity: 1
    }
}

.content blockquote {
    position: relative
}

.content blockquote p {
    line-height: 1.6;
    opacity: .8
}

.content blockquote footer {
    letter-spacing: .3em;
    text-transform: uppercase
}

.content blockquote footer:before {
    background: #e6af79;
    content: "";
    display: inline-block;
    height: 1px;
    margin-right: 10px;
    position: relative;
    top: -1px;
    width: 30px;
    vertical-align: middle
}

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

.content img.alignleft {
    display: inline;
    float: left;
    margin: 7px 20px 6px 0;
    width: 35%
}

.content img.alignright {
    display: inline;
    float: right;
    margin: 7px 0 6px 20px;
    width: 35%
}

.content ul.btns li {
    padding-left: 0
}

.content ul.btns li:before {
    display: none
}

.content form ul li {
    padding-left: 0
}

.content form ul li:before {
    display: none
}

.content.basic a {
    color: #e49c54
}

.content.basic a:hover {
    color: #121730
}

.content.dark a {
    color: #e49c54
}

.content.dark a:hover {
    color: #121730
}

.content.light a {
    color: #e49c54
}

.content.light a:hover {
    color: #fff
}

:root,
:host {
    --fa-style-family-brands: 'Font Awesome 6 Brands';
    --fa-font-brands: normal 400 1em/1 'Font Awesome 6 Brands'
}

@font-face {
    font-family: "Font Awesome 6 Brands";
    font-style: normal;
    font-weight: 400;
    font-display: block;
    src: url(../webfonts/fa-brands-400.woff2) format("woff2"), url(../webfonts/fa-brands-400.ttf) format("truetype")
}

.fab,
.fa-brands {
    font-family: "Font Awesome 6 Brands";
    font-style: normal;
    font-weight: 400
}

.fa-facebook-f:before {
    content: "\f39e"
}

.fa-google:before {
    content: "\f1a0"
}

.fa-instagram:before {
    content: "\f16d"
}

.fa-linkedin-in:before {
    content: "\f0e1"
}

.fa-twitter:before {
    content: "\f099"
}

footer#footer {
    padding: 0 15px
}

footer#footer .container {
    background-color: #121730;
    border-radius: 20px 20px 0 0;
    color: #fff;
    padding: 10vw
}

@media screen and (max-width: 800px) {
    footer#footer .container {
        padding: 14vw
    }
}

footer#footer .container .inner {
    position: relative
}

@media screen and (max-width: 800px) {
    footer#footer .container .inner {
        padding-top: 70px
    }
}

footer#footer .container .inner svg {
    height: 53px;
    position: absolute;
    top: 6px;
    width: 37px
}

@media screen and (min-width: 800px) {
    footer#footer .container .inner svg {
        right: 0
    }
}

@media screen and (max-width: 800px) {
    footer#footer .container .inner svg {
        left: 0
    }
}

footer#footer .container .inner .top {
    padding-bottom: 10vw;
    padding-bottom: clamp(50px, 10vw, 100px)
}

@media screen and (min-width: 800px) {
    footer#footer .container .inner .footer-nav {
        display: flex;
        gap: 10vw
    }
}

@media screen and (max-width: 800px) {
    footer#footer .container .inner .footer-nav>ul:nth-of-type(1) li,
    footer#footer .container .inner .footer-nav>ul:nth-of-type(2) li {
        display: inline;
        float: left;
        width: 50%
    }
}

@media screen and (max-width: 800px) {
    footer#footer .container .inner .footer-nav>ul:nth-of-type(2) li:last-of-type {
        margin-bottom: 10vw
    }
}

@media screen and (max-width: 800px) {
    footer#footer .container .inner .footer-nav>ul:nth-of-type(3) {
        clear: both
    }
}

footer#footer .container .inner .footer-nav>ul li a {
    color: #fff;
    display: block;
    font-family: "roc-grotesk", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1.1rem;
    left: 0;
    padding: 2px 3px 2px 0;
    position: relative
}

@media (hover:hover) and (pointer:fine) {
    footer#footer .container .inner .footer-nav>ul li a {
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out
    }
    footer#footer .container .inner .footer-nav>ul li a:hover {
        color: #e6af79;
        padding-right: 0;
        padding-left: 3px
    }
}

footer#footer .container .inner .footer-nav>ul li ul li a {
    font-family: "soleil", sans-serif;
    font-weight: 400;
    font-size: .83rem;
    font-style: normal
}

footer#footer .container .inner .footer-nav>ul li ul li a a,
footer#footer .container .inner .footer-nav>ul li ul li a strong {
    font-weight: 700
}

footer#footer .container .inner .bottom {
    margin: 0 -10px;
    padding-top: 10vw;
    padding-top: clamp(50px, 10vw, 180px)
}

@media screen and (min-width: 800px) {
    footer#footer .container .inner .bottom {
        align-items: center;
        display: flex;
        justify-content: space-between
    }
}

footer#footer .container .inner .bottom ul {
    display: flex
}

footer#footer .container .inner .bottom ul a {
    color: #fff;
    display: block;
    padding: 10px
}

footer#footer .container .inner .bottom ul.social li+li {
    margin-left: 5px
}

footer#footer .container .inner .bottom ul.social li a {
    font-size: 1.12rem
}

@media (hover:hover) and (pointer:fine) {
    footer#footer .container .inner .bottom ul.social li a {
        transition: color .35s ease-in-out;
        -moz-transition: color .35s ease-in-out;
        -o-transition: color .35s ease-in-out;
        -webkit-transition: color .35s ease-in-out
    }
    footer#footer .container .inner .bottom ul.social li a:hover,
    footer#footer .container .inner .bottom ul.social li a:focus {
        color: #e6af79;
        text-decoration: none
    }
}

footer#footer .container .inner .bottom ul:not(.social) li span,
footer#footer .container .inner .bottom ul:not(.social) li a {
    font-size: .66rem
}

@media screen and (max-width: 800px) {
    footer#footer .container .inner .bottom ul:not(.social) li span,
    footer#footer .container .inner .bottom ul:not(.social) li a {
        padding: 10px 7px
    }
}

footer#footer .container .inner .bottom ul:not(.social) li span {
    display: block;
    padding: 10px
}

footer#footer .container .inner .bottom ul:not(.social) li a:hover {
    text-decoration: underline
}

a.skip-link {
    display: none
}

::-moz-selection {
    background: #e6af79;
    color: #fff
}

::selection {
    background: #e6af79;
    color: #fff
}

::-moz-selection {
    background: #e6af79;
    color: #fff
}

a:focus {
    text-decoration: underline
}

.clearboth {
    clear: both;
    height: 0
}

article,
section {
    clear: both
}

a.link {
    display: block;
    height: 100%;
    left: 0;
    opacity: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 2
}

.wow {
    visibility: hidden
}

.video-container {
    position: relative;
    padding-bottom: 56.25%;
    padding-top: 30px;
    margin-bottom: 30px;
    height: 0;
    overflow: hidden
}

.video-container iframe,
.video-container object,
.video-container embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.video-bg {
    height: 100%;
    overflow: hidden;
    position: absolute;
    right: 0;
    top: 0;
    width: 100%;
    z-index: 1
}

.video-bg video {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover
}

@media screen and (min-width: 1100px) {
    .page-load-complete #header #nav ul.nav>li a {
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out
    }
}

body.in {
    overflow: hidden
}

body.in #container {
    overflow: hidden
}

body.in #container #header #logo path#logo-name {
    opacity: 0
}

body.in #container #header #nav.subs-in-play ul.top {
    opacity: 0
}

body.in #container #header #nav.subs-in-play .bg {
    opacity: .1
}

body.in #container #header #nav .bg {
    opacity: .3;
    scale: 1
}

@media screen and (max-width: 1100px) {
    body.in #container #header #nav .bg {
        pointer-events: initial
    }
}

body.out #container {
    overflow: hidden
}

body.out #container #header #nav .bg {
    opacity: 0;
    scale: 1.2;
    transition: all .35s ease-in-out;
    -moz-transition: all .35s ease-in-out;
    -o-transition: all .35s ease-in-out;
    -webkit-transition: all .35s ease-in-out
}

#header {
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    position: relative;
    width: 100%;
    z-index: 10
}

#header:after {
    clear: both;
    content: "";
    display: block
}

#header.absolute {
    left: 0;
    position: absolute;
    top: 0
}

#header:not(.absolute) {
    background-color: #121730
}

@media screen and (min-width: 1100px) {
    #header {
        padding: 5vw
    }
}

@media screen and (min-width: 1001px) and (max-width: 1100px) {
    #header {
        padding: 7vw
    }
}

@media screen and (max-width: 1000px) {
    #header {
        line-height: 0;
        padding: 50px 7vw
    }
}

@media screen and (max-width: 800px) {
    #header {
        padding: 8vw 10vw
    }
}

#header a#logo {
    line-height: 0;
    position: relative;
    z-index: 11
}

@media screen and (min-width: 1001px) {
    #header a#logo {
        display: inline-block;
        float: left
    }
}

@media screen and (max-width: 1000px) {
    #header a#logo {
        display: inline-block;
        line-height: 0;
        position: relative
    }
}

@media screen and (min-width: 800px) {
    #header a#logo svg {
        height: 47px;
        width: 190px
    }
}

@media screen and (max-width: 800px) {
    #header a#logo svg {
        height: 56px;
        width: 173.6px
    }
}

#header a#logo svg path#logo-name {
    transition: opacity .35s ease-in-out;
    -moz-transition: opacity .35s ease-in-out;
    -o-transition: opacity .35s ease-in-out;
    -webkit-transition: opacity .35s ease-in-out
}

#header a#nav-btn {
    color: #fff;
    font-size: .8rem;
    height: 50px;
    letter-spacing: .2em;
    line-height: 50px;
    padding: 0 0 0 40px;
    position: absolute;
    text-transform: uppercase;
    z-index: 3
}

@media screen and (min-width: 1100px) {
    #header a#nav-btn {
        display: none
    }
}

@media screen and (max-width: 1100px) {
    #header a#nav-btn {
        display: block;
        right: 7vw;
        top: 7vw
    }
}

@media screen and (max-width: 1000px) {
    #header a#nav-btn {
        display: block;
        right: 7vw;
        top: 7vw
    }
}

@media screen and (max-width: 800px) {
    #header a#nav-btn {
        right: 10vw;
        top: 6vw
    }
}

#header a#nav-btn span {
    display: block;
    height: 40px;
    left: 0;
    position: absolute;
    top: 0;
    width: 30px
}

@media screen and (max-width: 800px) {
    #header a#nav-btn span {
        width: 100%
    }
}

#header a#nav-btn span:before,
#header a#nav-btn span:after {
    background-color: #e6af79;
    border-radius: 3px;
    -moz-border-radius: 3px;
    -webkit-border-radius: 3px;
    content: '';
    height: 2px;
    position: absolute
}

#header a#nav-btn span:before {
    left: 0;
    top: 19px;
    width: 100%
}

#header a#nav-btn span:after {
    right: 0;
    bottom: 11px;
    width: 86%
}

#header a#nav-btn div {
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal
}

@media screen and (max-width: 800px) {
    #header a#nav-btn div {
        display: none
    }
}

@media (hover:hover) and (pointer:fine) {
    #header a#nav-btn span:before,
    #header a#nav-btn span:after {
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out
    }
    #header a#nav-btn:hover span:before,
    #header a#nav-btn:hover span:after {
        background-color: #cacfe4
    }
    #header a#nav-btn:hover span:after {
        width: 100%
    }
}

#header #nav {
    position: relative;
    z-index: 1
}

@media screen and (min-width: 1100px) {
    #header #nav {
        float: right
    }
    #header #nav:after {
        clear: both;
        content: "";
        display: block
    }
}

@media screen and (max-width: 1100px) {
    #header #nav {
        background-color: #121730;
        box-sizing: border-box;
        -moz-box-sizing: border-box;
        -o-box-sizing: border-box;
        -webkit-box-sizing: border-box;
        display: table;
        left: 0;
        height: 100%;
        margin: 0;
        min-height: 500px;
        min-width: inherit;
        opacity: 0;
        padding: 7vw;
        pointer-events: none;
        position: fixed;
        top: 0;
        width: 100%;
        z-index: 10;
        transition: opacity .35s ease-in-out;
        -moz-transition: opacity .35s ease-in-out;
        -o-transition: opacity .35s ease-in-out;
        -webkit-transition: opacity .35s ease-in-out
    }
    #header #nav.in {
        opacity: 1;
        pointer-events: inherit
    }
    #header #nav.out {
        opacity: 0;
        pointer-events: none
    }
}

#header #nav ul.top {
    margin-right: -10px;
    position: absolute;
    right: 7vw;
    top: 7vw;
    z-index: 11
}

@media screen and (min-width: 1100px) {
    #header #nav ul.top {
        display: none
    }
}

@media screen and (max-width: 1100px) {
    #header #nav ul.top {
        display: flex;
        transition: opacity .35s ease-in-out;
        -moz-transition: opacity .35s ease-in-out;
        -o-transition: opacity .35s ease-in-out;
        -webkit-transition: opacity .35s ease-in-out
    }
}

@media screen and (max-width: 800px) {
    #header #nav ul.top {
        right: 10vw;
        top: 6vw
    }
}

#header #nav ul.top li a {
    color: #fff;
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: .8rem;
    letter-spacing: .2em;
    line-height: 50px;
    padding: 10px;
    position: relative;
    text-transform: uppercase
}

#header #nav ul.top li a.pull {
    padding-left: 34px
}

#header #nav ul.top li a.pull span {
    background-color: #cacfe4;
    border-radius: 3px;
    -moz-border-radius: 3px;
    -webkit-border-radius: 3px;
    content: '';
    height: 2px;
    left: 0;
    position: absolute;
    top: 18px;
    width: 24px
}

#header #nav .bg {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    height: 100vh;
    left: 0;
    opacity: 0;
    position: fixed;
    scale: 1.1;
    top: 0;
    transition: scale 2s ease-in-out, opacity 2s ease-in-out;
    -moz-transition: scale 2s ease-in-out, opacity 2s ease-in-out;
    -o-transition: scale 2s ease-in-out, opacity 2s ease-in-out;
    -webkit-transition: scale 2s ease-in-out, opacity 2s ease-in-out;
    transition-delay: .5s;
    -webkit-transition-delay: .5s;
    width: 100vw;
    z-index: 4
}

@media screen and (min-width: 1100px) {
    #header #nav .bg {
        display: none
    }
}

@media screen and (max-width: 1100px) {
    #header #nav .bg {
        pointer-events: none
    }
}

#header #nav ul.nav {
    position: relative
}

@media screen and (max-width: 1100px) {
    #header #nav ul.nav {
        border-radius: 20px;
        -moz-border-radius: 20px;
        -webkit-border-radius: 20px;
        box-sizing: border-box;
        -moz-box-sizing: border-box;
        -o-box-sizing: border-box;
        -webkit-box-sizing: border-box;
        bottom: 10vw;
        left: 10vw;
        overflow: hidden;
        position: absolute;
        width: 80vw;
        z-index: 5
    }
}

#header #nav ul.nav:before {
    content: '';
    pointer-events: none;
    position: fixed
}

@media screen and (min-width: 1100px) {
    #header #nav ul.nav:before {
        background: linear-gradient(190deg, #121730 0%, #080a16 100%);
        height: 100vh;
        left: 0;
        opacity: 0;
        top: 0;
        transition: opacity .35s ease-in-out;
        -moz-transition: opacity .35s ease-in-out;
        -o-transition: opacity .35s ease-in-out;
        -webkit-transition: opacity .35s ease-in-out;
        width: 100vw;
        z-index: 0
    }
}

@media screen and (min-width: 1100px) {
    #header #nav ul.nav:hover:before {
        opacity: .8
    }
}

@media (hover:none) {
    #header #nav ul.nav:hover:before {
        opacity: 0
    }
}

@media screen and (min-width: 1001px) and (max-width: 1100px) {
    #header #nav ul.nav.show-sub {
        height: 560px
    }
}

@media screen and (min-width: 800px) and (max-width: 1000px) {
    #header #nav ul.nav.show-sub {
        height: 560px
    }
}

@media screen and (max-width: 800px) {
    #header #nav ul.nav.show-sub {
        height: 420px
    }
}

@media screen and (max-width: 1100px) {
    #header #nav ul.nav.show-sub>li.in {
        opacity: 0;
        pointer-events: none;
        position: initial
    }
    #header #nav ul.nav.show-sub>li.in.active {
        opacity: 1
    }
    #header #nav ul.nav.show-sub>li.in.active .parent {
        transition: opacity .35s ease-in-out;
        -moz-transition: opacity .35s ease-in-out;
        -o-transition: opacity .35s ease-in-out;
        -webkit-transition: opacity .35s ease-in-out
    }
    #header #nav ul.nav.show-sub>li.in.active>a {
        opacity: 0;
        pointer-events: none
    }
    #header #nav ul.nav.show-sub>li.in.active>ul {
        left: 0;
        opacity: 1;
        pointer-events: initial;
        top: 80px
    }
    #header #nav ul.nav.show-sub>li.in.active>ul li {
        opacity: 1;
        pointer-events: initial
    }
}

@media screen and (min-width: 1100px) {
    #header #nav ul.nav>li {
        display: inline;
        float: left;
        text-align: center
    }
}

@media screen and (max-width: 1100px) {
    #header #nav ul.nav>li {
        display: block;
        height: 80px;
        opacity: 0;
        pointer-events: none;
        position: relative;
        top: 0;
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out;
        width: 100%;
        z-index: 2
    }
}

@media screen and (min-width: 1001px) and (max-width: 1100px) {
    #header #nav ul.nav>li {
        height: 80px
    }
}

@media screen and (min-width: 800px) and (max-width: 1000px) {
    #header #nav ul.nav>li {
        height: 80px
    }
}

@media screen and (max-width: 800px) {
    #header #nav ul.nav>li {
        height: 60px
    }
}

#header #nav ul.nav>li#nav-home {
    display: none
}

@media screen and (max-width: 1100px) {
    #header #nav ul.nav>li#nav-maintain .parent:before {
        content: 'Maintain';
        display: block
    }
}

@media screen and (min-width: 1100px) {
    #header #nav ul.nav>li#nav-ps {
        display: flex
    }
}

#header #nav ul.nav>li#nav-ps:before {
    align-self: flex-end;
    background-color: #cacfe4;
    border-radius: 5px;
    content: '';
    display: block;
    height: 25px;
    margin: 0 10px 0 8px;
    opacity: .7;
    position: relative;
    top: 4px;
    width: 1px
}

@media screen and (max-width: 1100px) {
    #header #nav ul.nav>li#nav-ps:before {
        display: none
    }
}

@media screen and (max-width: 1100px) {
    #header #nav ul.nav>li#nav-ps .parent:before {
        content: 'Pools & Spas';
        display: block
    }
}

@media screen and (max-width: 1100px) {
    #header #nav ul.nav>li#nav-learn .parent:before {
        content: 'Learn';
        display: block
    }
}

@media (hover:hover) and (pointer:fine) {
    #header #nav ul.nav>li#nav-contact svg {
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out
    }
    #header #nav ul.nav>li#nav-contact svg path {
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out
    }
}

@media screen and (min-width: 1200px) {
    #header #nav ul.nav>li#nav-contact:hover a {
        padding-left: 20px
    }
}

@media screen and (min-width: 1100px) {
    #header #nav ul.nav>li#nav-contact:hover svg {
        left: 3px;
        margin-left: 6px
    }
    #header #nav ul.nav>li#nav-contact:hover svg path {
        fill: #fff
    }
}

#header #nav ul.nav>li#nav-contact svg {
    height: 12px;
    left: 0;
    margin-left: 13px;
    position: relative;
    top: 2px;
    width: 54px
}

@media screen and (min-width: 1001px) and (max-width: 1200px) {
    #header #nav ul.nav>li#nav-contact svg {
        display: none
    }
}

@media screen and (max-width: 1100px) {
    #header #nav ul.nav>li#nav-contact svg {
        display: none
    }
}

#header #nav ul.nav>li#nav-contact svg path {
    fill: #e6af79
}

#header #nav ul.nav>li.in {
    opacity: 1;
    pointer-events: inherit
}

#header #nav ul.nav>li.out {
    opacity: 0;
    pointer-events: none
}

#header #nav ul.nav>li>a {
    color: #fff;
    display: block;
    position: relative
}

@media screen and (min-width: 1100px) {
    #header #nav ul.nav>li>a:after {
        background-color: #e6af79;
        border-radius: 5px;
        content: '';
        display: block;
        height: 5px;
        opacity: 0;
        position: relative;
        top: -25px;
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out;
        width: 0
    }
}

@media screen and (min-width: 1100px) {
    #header #nav ul.nav>li>a {
        font-family: "roc-grotesk", sans-serif;
        font-weight: 600;
        font-style: normal;
        font-size: .66rem;
        height: 50px;
        letter-spacing: .2em;
        line-height: 86px;
        padding: 0 13px;
        text-transform: uppercase;
        z-index: 2
    }
    #header #nav ul.nav>li>a:hover:after {
        opacity: 1;
        width: 100%
    }
}

@media screen and (max-width: 1100px) {
    #header #nav ul.nav>li>a {
        display: block;
        font-family: "roc-grotesk", sans-serif;
        font-weight: 400;
        font-style: normal;
        font-size: 4vw;
        line-height: 80px
    }
}

@media screen and (min-width: 1001px) and (max-width: 1200px) {
    #header #nav ul.nav>li>a {
        padding: 0 10px
    }
}

@media screen and (min-width: 1001px) and (max-width: 1100px) {
    #header #nav ul.nav>li>a {
        line-height: 80px
    }
}

@media screen and (min-width: 800px) and (max-width: 1000px) {
    #header #nav ul.nav>li>a {
        line-height: 80px
    }
}

@media screen and (max-width: 800px) {
    #header #nav ul.nav>li>a {
        font-size: 7vw;
        line-height: 60px
    }
}

#header #nav ul.nav>li>a.current {
    color: #e6af79
}

@media screen and (max-width: 1100px) {
    #header #nav ul.nav>li>a span {
        display: inline-flex;
        position: relative;
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out
    }
}

@media screen and (min-width: 1001px) and (max-width: 1100px) {
    #header #nav ul.nav>li>a span {
        height: 20px;
        margin-left: 20px;
        top: -2px;
        width: 20px
    }
}

@media screen and (min-width: 800px) and (max-width: 1000px) {
    #header #nav ul.nav>li>a span {
        height: 20px;
        margin-left: 20px;
        top: -2px;
        width: 20px
    }
}

@media screen and (max-width: 800px) {
    #header #nav ul.nav>li>a span {
        height: 17px;
        margin-left: 12px;
        top: 0;
        width: 17px
    }
}

@media screen and (max-width: 1100px) {
    #header #nav ul.nav>li>a span:before,
    #header #nav ul.nav>li>a span:after {
        background-color: #e6af79;
        border-radius: 3px;
        content: '';
        position: absolute
    }
    #header #nav ul.nav>li>a span:before {
        height: 100%;
        left: 50%;
        top: 0;
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%);
        width: 3px
    }
    #header #nav ul.nav>li>a span:after {
        height: 3px;
        left: 0;
        top: 50%;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
        transition: opacity .35s ease-in-out;
        -moz-transition: opacity .35s ease-in-out;
        -o-transition: opacity .35s ease-in-out;
        -webkit-transition: opacity .35s ease-in-out;
        width: 100%
    }
}

@media screen and (min-width: 1100px) {
    #header #nav ul.nav>li>a.current:after {
        background-color: #cacfe4;
        opacity: .25;
        width: 100%
    }
}

@media screen and (max-width: 800px) {
    #header #nav ul.nav>li>a.current {
        opacity: 0
    }
}

@media screen and (min-width: 1100px) {
    #header #nav ul.nav>li.has-children {
        position: relative
    }
}

@media screen and (max-width: 1100px) {
    #header #nav ul.nav>li.has-children {
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out
    }
    #header #nav ul.nav>li.has-children:after {
        background-color: #e6af79;
        display: inline-flex;
        height: 20px;
        width: 20px
    }
}

@media screen and (min-width: 1100px) {
    #header #nav ul.nav>li.has-children:hover a,
    #header #nav ul.nav>li.has-children:focus a {
        touch-action: auto;
        z-index: 2
    }
}

@media screen and (min-width: 1100px) {
    #header #nav ul.nav>li.has-children:hover>ul,
    #header #nav ul.nav>li.has-children:focus>ul {
        opacity: 1;
        pointer-events: initial;
        top: 120%
    }
    #header #nav ul.nav>li.has-children:hover>ul li,
    #header #nav ul.nav>li.has-children:focus>ul li {
        pointer-events: initial
    }
}

#header #nav ul.nav>li.has-children.parent-active .parent {
    left: 0
}

#header #nav ul.nav>li.has-children.parent-active .parent:before {
    color: #e6af79
}

#header #nav ul.nav>li.has-children.parent-active.active .parent div:before {
    opacity: 0
}

#header #nav ul.nav>li.has-children .parent {
    align-items: center;
    color: #fff;
    display: flex;
    font-family: "roc-grotesk", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 4vw;
    left: 0;
    line-height: 80px;
    opacity: 0;
    pointer-events: none;
    position: absolute;
    top: 0;
    transition: all .35s ease-in-out;
    -moz-transition: all .35s ease-in-out;
    -o-transition: all .35s ease-in-out;
    -webkit-transition: all .35s ease-in-out;
    transition-delay: .5s;
    -webkit-transition-delay: .5s;
    z-index: 1
}

@media screen and (max-width: 800px) {
    #header #nav ul.nav>li.has-children .parent {
        font-size: 7vw;
        line-height: 60px
    }
}

#header #nav ul.nav>li.has-children .parent div {
    background-color: #e6af79;
    border-radius: 3px;
    display: inline-flex;
    height: 3px;
    left: 0;
    margin-top: 2px;
    margin-left: 20px;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 20px
}

@media screen and (max-width: 800px) {
    #header #nav ul.nav>li.has-children .parent div {
        margin-left: 12px;
        width: 17px
    }
}

#header #nav ul.nav>li.has-children .parent div:before {
    background-color: #e6af79;
    border-radius: 3px;
    -moz-border-radius: 3px;
    -webkit-border-radius: 3px;
    content: '';
    height: 20px;
    left: 8px;
    position: absolute;
    top: -9px;
    transition: opacity .35s ease-in-out;
    -moz-transition: opacity .35s ease-in-out;
    -o-transition: opacity .35s ease-in-out;
    -webkit-transition: opacity .35s ease-in-out;
    width: 3px
}

@media screen and (max-width: 800px) {
    #header #nav ul.nav>li.has-children .parent div:before {
        left: 7px;
        height: 17px;
        top: -7px
    }
}

#header #nav ul.nav>li.has-children .nav-click {
    height: 80px;
    position: absolute;
    left: 0;
    text-align: right;
    top: 0;
    transition: all .35s ease-in-out;
    -moz-transition: all .35s ease-in-out;
    -o-transition: all .35s ease-in-out;
    -webkit-transition: all .35s ease-in-out;
    width: 100%;
    z-index: 2
}

@media screen and (max-width: 800px) {
    #header #nav ul.nav>li.has-children .nav-click {
        height: 60px
    }
}

#header #nav ul.nav>li.has-children.current>a {
    color: #e6af79
}

#header #nav ul.nav>li.has-children.current>a:before {
    opacity: 0
}

#header #nav ul.nav>li.has-children.active .parent {
    left: 0;
    padding-left: 0;
    opacity: 1;
    transition: initial
}

#header #nav ul.nav>li.has-children.active .parent div:before {
    opacity: 0
}

#header #nav ul.nav>li.has-children.active .nav-click {
    pointer-events: initial
}

#header #nav ul.nav>li.has-children.active>ul {
    left: 0;
    position: absolute;
    top: 0
}

#header #nav ul.nav>li.has-children.active>ul>a span {
    rotate: 90deg
}

#header #nav ul.nav>li.has-children.active>ul>a span:after {
    opacity: 0
}

#header #nav ul.nav>li.has-children.active>ul>a>ul {
    left: 0
}

@media screen and (min-width: 1100px) {
    #header #nav ul.nav>li.has-children>ul {
        background-color: #fff;
        border-radius: 10px;
        -moz-border-radius: 10px;
        -webkit-border-radius: 10px;
        box-shadow: 0 1px 4px rgba(0, 0, 0, 0.15);
        left: 50%;
        margin: 0;
        opacity: 0;
        padding: 5px;
        pointer-events: none;
        position: absolute;
        top: 90%;
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%);
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out;
        width: 250px;
        z-index: 3
    }
    #header #nav ul.nav>li.has-children>ul:before {
        border-right: 5px solid transparent;
        border-bottom: 5px solid #fff;
        border-left: 5px solid transparent;
        content: "";
        display: block;
        height: 0;
        left: 50%;
        margin-left: -5px;
        position: absolute;
        top: -5px;
        width: 0
    }
}

@media screen and (max-width: 1100px) {
    #header #nav ul.nav>li.has-children>ul {
        left: -5vw;
        opacity: 0;
        pointer-events: none;
        position: absolute;
        top: 80px;
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out;
        transition-delay: .5s;
        -webkit-transition-delay: .5s;
        width: 100%
    }
}

@media screen and (min-width: 1100px) {
    #header #nav ul.nav>li.has-children>ul li+li {
        border-top: 1px solid rgba(0, 0, 0, 0.1);
        margin-top: 4px;
        padding-top: 4px
    }
}

@media screen and (max-width: 1100px) {
    #header #nav ul.nav>li.has-children>ul li {
        display: block;
        opacity: 0;
        pointer-events: none;
        transition: opacity .35s ease-in-out;
        -moz-transition: opacity .35s ease-in-out;
        -o-transition: opacity .35s ease-in-out;
        -webkit-transition: opacity .35s ease-in-out
    }
}

#header #nav ul.nav>li.has-children>ul li.in {
    opacity: 1;
    pointer-events: inherit
}

#header #nav ul.nav>li.has-children>ul li.out {
    opacity: 0;
    pointer-events: none
}

#header #nav ul.nav>li.has-children>ul li.current_page_item a {
    color: #e6af79
}

@media screen and (max-width: 800px) {
    #header #nav ul.nav>li.has-children>ul li.current_page_item a {
        color: #e6af79;
        font-weight: 400;
        left: 15px;
        position: relative
    }
}

#header #nav ul.nav>li.has-children>ul li a {
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    line-height: 1;
    text-align: left
}

@media screen and (min-width: 1100px) {
    #header #nav ul.nav>li.has-children>ul li a {
        border-radius: 10px;
        -moz-border-radius: 10px;
        -webkit-border-radius: 10px;
        color: #121730;
        display: block;
        font-size: .8rem;
        height: auto;
        letter-spacing: normal;
        padding: 15px 20px;
        text-transform: none
    }
}

@media screen and (max-width: 1100px) {
    #header #nav ul.nav>li.has-children>ul li a {
        color: #e6af79;
        display: block;
        font-size: 1.2rem;
        padding: 15px 0
    }
}

@media screen and (max-width: 800px) {
    #header #nav ul.nav>li.has-children>ul li a {
        color: #fff
    }
}

@media screen and (min-width: 1100px) {
    #header #nav ul.nav>li.has-children>ul li a:hover {
        background-color: #e6af79;
        color: #fff
    }
}

#hero-project.error {
    background-color: #121730;
    margin-bottom: 5vw;
    position: relative
}

@media screen and (max-width: 1000px) {
    #hero-project.error {
        margin-bottom: 10vw
    }
}

#hero-project.error #hero-project-top {
    position: relative;
    z-index: 1
}

#hero-project.error #hero-project-top .container {
    position: relative;
    z-index: 2
}

@media screen and (min-width: 1001px) {
    #hero-project.error #hero-project-top .container {
        padding: 50vh 10vw 15vw 10vw
    }
}

@media screen and (max-width: 1000px) {
    #hero-project.error #hero-project-top .container {
        padding: 40vh 10vw 10vw
    }
}

@media screen and (max-width: 800px) {
    #hero-project.error #hero-project-top .container {
        padding: 45vh 10vw 20vw
    }
}

#hero-project.error #hero-project-top .container h1 {
    margin-bottom: 2rem
}

#hero-project.error #hero-project-top #hero-fade {
    height: 100%;
    left: 0;
    opacity: .25;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1
}

#hero-project.error #hero-project-top #hero-fade:before {
    background: linear-gradient(0deg, rgba(18, 23, 48, 0.75) 0%, rgba(18, 23, 48, 0.25) 80%);
    content: '';
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 2
}

@media screen and (min-width: 800px) {
    #hero-project.error #hero-project-top #hero-fade.img {
        padding: 15px
    }
}

@media screen and (min-width: 800px) {
    #hero-project.error #hero-project-top #hero-fade.video {
        border-bottom: 15px solid #121730
    }
}

#hero-project.error #hero-project-top #hero-fade.img>div {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    position: absolute
}

@media screen and (min-width: 800px) {
    #hero-project.error #hero-project-top #hero-fade.img>div {
        height: calc(100% - 30px);
        height: -webkit-calc(100% - 30px);
        left: 15px;
        top: 15px;
        width: calc(100% - 30px);
        width: -webkit-calc(100% - 30px)
    }
}

@media screen and (max-width: 800px) {
    #hero-project.error #hero-project-top #hero-fade.img>div {
        left: 0;
        height: 100%;
        top: 0;
        width: 100%
    }
}

.page-id-26 #hero-full {
    margin-bottom: 0
}

#timeline {
    margin: auto;
    max-width: 1800px;
    position: relative;
    z-index: 2
}

@media screen and (min-width: 1001px) {
    #timeline {
        padding: 15px 10vw 5vw
    }
}

@media screen and (max-width: 1000px) {
    #timeline {
        padding: 0 10vw 10vw
    }
}

#timeline:before {
    background-color: #cacfe4;
    content: '';
    display: block;
    height: 1px;
    margin-bottom: 5vw;
    opacity: .25;
    width: 100%
}

@media screen and (max-width: 1000px) {
    #timeline:before {
        margin-bottom: 10vw
    }
}

#timeline .timeline {
    box-sizing: initial;
    padding-bottom: 10vw;
    transition: height .35s ease-in-out;
    -moz-transition: height .35s ease-in-out;
    -o-transition: height .35s ease-in-out;
    -webkit-transition: height .35s ease-in-out
}

@media screen and (max-width: 800px) {
    #timeline .timeline {
        padding-bottom: 20vw
    }
}

#timeline .timeline .splide__arrows .splide__arrow {
    background: transparent;
    border: none;
    bottom: 0;
    cursor: pointer;
    height: 50px;
    position: absolute;
    width: 50px;
    z-index: 2
}

@media (hover:hover) and (pointer:fine) {
    #timeline .timeline .splide__arrows .splide__arrow:hover svg path {
        fill: #fff
    }
}

#timeline .timeline .splide__arrows .splide__arrow.splide__arrow--prev {
    left: -18px;
    -webkit-transform: scaleX(-1);
    transform: scaleX(-1)
}

#timeline .timeline .splide__arrows .splide__arrow.splide__arrow--next {
    right: -18px
}

#timeline .timeline .splide__arrows .splide__arrow svg {
    height: 16px;
    width: 25px
}

#timeline .timeline .splide__arrows .splide__arrow svg path {
    fill: #e6af79
}

@media (hover:hover) and (pointer:fine) {
    #timeline .timeline .splide__arrows .splide__arrow svg path {
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out
    }
}

#timeline .timeline .splide__arrows .splide__arrow:disabled {
    pointer-events: none
}

#timeline .timeline .splide__arrows .splide__arrow:disabled svg path {
    fill: rgba(255, 255, 255, 0.3)
}

#timeline .timeline .splide__track {
    cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='74px' height='30px' viewBox='0 0 90.27 35.16'%3E%3Cpath d='M0 0h84.55c3.16 0 5.73 2.57 5.73 5.73v29.44H5.73C2.57 35.17 0 32.6 0 29.44V0Z' style='fill:rgba(230,175,121,.8'/%3E%3Cpath d='M23.26 13.72h-4.17v8.18h4.53c3.46 0 4.77-1.47 4.77-4.09 0-2.31-1.29-4.09-5.14-4.09Zm.29 6.42h-2.06v-4.65h1.9c1.93 0 2.62 1.03 2.62 2.33 0 1.5-.7 2.32-2.46 2.32Zm18.61-3.99c0-1.47-.95-2.42-3.98-2.42h-5.15v8.18h2.39v-2.95h2.96c1.02 0 1.34.39 1.34 1.23v1.72h2.39v-1.72c0-.86-.14-1.77-1.43-2.06v-.02c1.13-.34 1.48-1.13 1.48-1.95Zm-3.87 1.42h-2.87v-2.08h2.66c1.38 0 1.82.42 1.82 1.01 0 .63-.42 1.07-1.6 1.07Zm12.74-3.84-4.45 8.18h2.46l.85-1.67h4.81l.85 1.67h2.77l-4.45-8.18h-2.83Zm-.45 5.12 1.69-3.33h.01l1.7 3.33h-3.41Zm16.32-1.17v1.27h2.64v.04c0 .58-.65 1.49-2.35 1.49-2 0-2.75-1.16-2.75-2.54 0-1.47.91-2.6 2.79-2.6s2.45.8 2.45 1.43v.09h2.13c.01-.09.01-.14.01-.17 0-1.53-1.08-3.11-4.66-3.11S62 15.57 62 17.93c0 2.15 1.31 4.13 4.8 4.13 2.04 0 3.02-.75 3.29-1.8h.02c0 .6-.01 1.29-.02 1.65h1.84v-4.23h-5.02Z' style='fill:%23121830'/%3E%3C/svg%3E"), grab
}

#timeline .timeline .splide__track ul.splide__list {
    align-items: flex-start !important;
    height: auto !important
}

#timeline .timeline .splide__track ul.splide__list li.splide__slide {
    color: #fff;
    padding-right: 4vw;
    transition: opacity .35s ease-in-out;
    -moz-transition: opacity .35s ease-in-out;
    -o-transition: opacity .35s ease-in-out;
    -webkit-transition: opacity .35s ease-in-out
}

#timeline .timeline .splide__track ul.splide__list li.splide__slide:not(.is-active,
.is-next) {
    height: 0 !important;
    opacity: .5
}

#timeline .timeline .splide__track ul.splide__list li.splide__slide strong {
    display: block;
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: .66rem;
    letter-spacing: .2em;
    margin-bottom: 1em;
    text-transform: uppercase
}

#timeline .timeline .splide__track ul.splide__list li.splide__slide h3 {
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1.5rem;
    line-height: 1.2;
    margin-bottom: 1.5em
}

#timeline .timeline .splide__track ul.splide__list li.splide__slide p {
    font-size: .8rem
}

#timeline .timeline .timeline-progress {
    background-color: rgba(202, 207, 228, 0.25);
    border-radius: 3px;
    height: 6px;
    margin-left: 40px;
    overflow: hidden;
    pointer-events: none;
    position: relative;
    top: calc(10vw - 30px);
    top: -webkit-calc(10vw - 30px);
    width: calc(100% - 80px);
    width: -webkit-calc(100% - 80px)
}

@media screen and (max-width: 800px) {
    #timeline .timeline .timeline-progress {
        top: calc(20vw - 30px);
        top: -webkit-calc(20vw - 30px)
    }
}

#timeline .timeline .timeline-progress .timeline-progress-bar {
    background-color: #e6af79;
    border-radius: 3px;
    left: 0;
    height: 100%;
    position: absolute;
    top: 0;
    transition: width .35s ease-in-out;
    -moz-transition: width .35s ease-in-out;
    -o-transition: width .35s ease-in-out;
    -webkit-transition: width .35s ease-in-out;
    width: 10%
}

#team {
    background-color: #121730;
    color: #fff
}

@media screen and (min-width: 1001px) {
    #team {
        padding-bottom: 5vw
    }
}

@media screen and (max-width: 1000px) {
    #team {
        padding-bottom: 10vw
    }
}

#team>div #headshots {
    display: grid;
    grid-column-gap: 5vw;
    grid-row-gap: 5vw;
    padding: 7vw 0 0
}

@media screen and (min-width: 1001px) {
    #team>div #headshots {
        grid-template-columns: repeat(3, minmax(0, 1fr))
    }
}

@media screen and (min-width: 800px) and (max-width: 1000px) {
    #team>div #headshots {
        grid-template-columns: repeat(2, minmax(0, 1fr))
    }
}

@media screen and (max-width: 1000px) {
    #team>div #headshots {
        padding: 12vw 0 0
    }
}

@media screen and (max-width: 800px) {
    #team>div #headshots {
        grid-row-gap: 8vw
    }
}

#team>div #headshots>div a {
    display: block
}

#team>div #headshots>div a:focus {
    -webkit-text-decoration-color: #e6af79;
    text-decoration-color: #e6af79
}

@media (hover:hover) and (pointer:fine) {
    #team>div #headshots>div a:hover span:before {
        left: 10px;
        opacity: 1;
        top: 10px
    }
    #team>div #headshots>div a:hover div {
        left: 5px
    }
}

#team>div #headshots>div a span {
    display: block;
    line-height: 0;
    position: relative
}

#team>div #headshots>div a span:before {
    background-color: #e6af79;
    border-radius: 20px;
    -moz-border-radius: 20px;
    -webkit-border-radius: 20px;
    content: '';
    height: 100%;
    left: 0;
    opacity: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1
}

@media screen and (min-width: 1001px) {
    #team>div #headshots>div a span:before {
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out
    }
}

#team>div #headshots>div a span img {
    border-radius: 20px;
    -moz-border-radius: 20px;
    -webkit-border-radius: 20px;
    height: auto;
    position: relative;
    width: 100%;
    z-index: 2
}

#team>div #headshots>div a>div {
    left: 0;
    margin-top: 1.5rem;
    position: relative
}

@media screen and (min-width: 1001px) {
    #team>div #headshots>div a>div {
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out
    }
}

#team>div #headshots>div a>div h2 {
    color: #fff;
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1.3rem
}

#team>div #headshots>div a>div strong {
    color: #cacfe4;
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: .85rem;
    position: relative;
    top: -5px
}

.page-id-26 .lity-container .popup#family .container {
    max-width: 1500px
}

.page-id-26 .lity-container .popup .container {
    max-width: 1200px;
    min-width: auto
}

@media screen and (min-width: 1001px) {
    .page-id-26 .lity-container .popup .container.bio {
        align-items: start;
        display: flex;
        gap: 5vw;
        max-width: 80vw;
        padding: 5vw 0
    }
    .page-id-26 .lity-container .popup .container.bio:after {
        display: none
    }
}

.page-id-26 .lity-container .popup .container.bio img {
    border-radius: 20px;
    -moz-border-radius: 20px;
    -webkit-border-radius: 20px;
    height: auto;
    margin-bottom: 10px;
    width: 300px
}

@media screen and (max-width: 800px) {
    .page-id-26 .lity-container .popup .container.bio img {
        width: 100%
    }
}

.page-id-26 .lity-container .lity-close {
    margin-top: 0;
    right: 0
}

#cr {
    background-color: #121730;
    margin-bottom: 5vw;
    padding: 35vh 0;
    position: relative
}

@media screen and (max-width: 800px) {
    #cr {
        padding: 40vh 0 10vw;
        margin-bottom: 10vw
    }
}

#cr:before {
    background: linear-gradient(90deg, #121730 30%, rgba(18, 23, 48, 0) 80%);
    content: '';
    height: 100%;
    left: 0;
    opacity: .8;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 2
}

@media screen and (max-width: 800px) {
    #cr:before {
        background: linear-gradient(0deg, #121730 10%, rgba(18, 23, 48, 0) 40%);
        height: 51vh;
        opacity: 1
    }
}

#cr>.container {
    z-index: 3
}

#cr>.container>div {
    color: #fff
}

@media screen and (min-width: 1001px) {
    #cr>.container>div {
        padding-left: 5vw
    }
}

@media screen and (min-width: 800px) {
    #cr>.container>div {
        margin-right: 50%
    }
}

#cr>.container>div p {
    margin: 2rem 0 24px;
    max-width: 60ch
}

#cr>.bg {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1
}

@media screen and (max-width: 800px) {
    #cr>.bg {
        height: 50vh
    }
}

@media screen and (min-width: 1001px) {
    .lity-content #family .container .bg {
        background-position: center center;
        background-repeat: no-repeat;
        background-size: cover;
        height: 100%;
        left: 0;
        position: fixed;
        top: 0;
        width: 50%
    }
}

@media screen and (max-width: 1000px) {
    .lity-content #family .container .bg {
        background-image: none !important
    }
}

@media screen and (min-width: 1001px) {
    .lity-content #family .container .bg img {
        height: auto;
        opacity: 0;
        width: 10%
    }
}

@media screen and (max-width: 1000px) {
    .lity-content #family .container .bg img {
        border-radius: 20px;
        -moz-border-radius: 20px;
        -webkit-border-radius: 20px;
        margin-bottom: 7vw
    }
}

@media screen and (min-width: 1001px) {
    .lity-content #family .container>div:not(.bg) {
        padding-left: 60%
    }
}

.lity-content #family .container>div:not(.bg) span {
    display: block
}

.lity-content #family .container>div:not(.bg) span.title-medium {
    margin-bottom: 2rem
}

#blog {
    padding: 5vw 0 0
}

@media screen and (max-width: 1000px) {
    #blog {
        padding: 10vw 0 0
    }
}

#blog .articles {
    display: flex;
    flex-wrap: wrap;
    gap: 5vw;
    padding-top: 5vw
}

@media screen and (max-width: 800px) {
    #blog .articles {
        gap: 10vw;
        padding-top: 10vw
    }
}

#blog .articles:after {
    display: none
}

#blog .articles .post {
    position: relative
}

@media screen and (min-width: 1001px) {
    #blog .articles .post {
        width: 26vw
    }
}

@media screen and (max-width: 1000px) {
    #blog .articles .post {
        width: 37.5vw
    }
}

@media screen and (max-width: 800px) {
    #blog .articles .post {
        width: 100%
    }
}

@media (hover:hover) and (pointer:fine) {
    #blog .articles .post .img {
        transition: border-radius .25s ease-in-out;
        -moz-transition: border-radius .25s ease-in-out;
        -o-transition: border-radius .25s ease-in-out;
        -webkit-transition: border-radius .25s ease-in-out
    }
    #blog .articles .post:hover .img {
        border-radius: 20px
    }
    #blog .articles .post:hover .img:before {
        opacity: .25
    }
}

#blog .articles .post .img {
    background-color: #121730;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    border-radius: 0 20px 20px;
    margin-bottom: 20px;
    overflow: hidden;
    padding-bottom: 60%;
    position: relative;
    width: 100%
}

#blog .articles .post .img a {
    z-index: 3
}

#blog .articles .post .img:before {
    background-color: #121730;
    content: '';
    height: 100%;
    left: 0;
    opacity: 0;
    position: absolute;
    top: 0;
    transition: opacity .35s ease-in-out;
    -moz-transition: opacity .35s ease-in-out;
    -o-transition: opacity .35s ease-in-out;
    -webkit-transition: opacity .35s ease-in-out;
    width: 100%;
    z-index: 2
}

#blog .articles .post h2 a {
    color: #121730;
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: 1.3rem;
    line-height: 1.5
}

@media (hover:hover) and (pointer:fine) {
    #blog .articles .post h2 a {
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out;
        text-decoration: underline;
        -webkit-text-decoration-color: #e9e2dc;
        text-decoration-color: #e9e2dc
    }
    #blog .articles .post h2 a:hover {
        color: #e6af79;
        -webkit-text-decoration-color: #121730;
        text-decoration-color: #121730
    }
}

#post {
    position: relative
}

#post:before {
    background-color: #121730;
    content: '';
    height: 100px;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1
}

#post article {
    position: relative;
    z-index: 2
}

#post article figure#featured>div {
    border-radius: 20px 20px 0 0;
    height: 50vh;
    overflow: hidden
}

#post article figure#featured>div img {
    height: 100%;
    max-height: 100%;
    max-width: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    position: relative;
    width: 100%
}

#post article figure#featured figcaption {
    border-bottom: 1px solid #e9e2dc;
    margin-bottom: 2rem;
    padding: 1rem .5rem
}

#post article figure#featured figcaption p {
    font-size: .7rem
}

#post article figure#featured figcaption p strong {
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal
}

#post article #article-title {
    border-bottom: 1px solid #e9e2dc;
    position: relative
}

@media screen and (min-width: 1001px) {
    #post article #article-title {
        padding: 2vw 0
    }
}

@media screen and (max-width: 1000px) {
    #post article #article-title {
        padding: 5vw 0
    }
}

#post article #article-title .post-categories a {
    background-color: #121730;
    border-radius: 15px;
    color: #fff;
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    display: inline-block;
    font-size: .7rem;
    height: 26px;
    line-height: 26px;
    padding: 0 15px
}

@media (hover:hover) and (pointer:fine) {
    #post article #article-title .post-categories a {
        transition: background .35s ease-in-out;
        -moz-transition: background .35s ease-in-out;
        -o-transition: background .35s ease-in-out;
        -webkit-transition: background .35s ease-in-out
    }
    #post article #article-title .post-categories a:hover,
    #post article #article-title .post-categories a:focus {
        background-color: #e6af79
    }
}

#post article #article-title h1 {
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: 1.75rem;
    line-height: 1.25;
    padding-top: 20px
}

@media screen and (max-width: 800px) {
    #post article #article-title h1 {
        font-size: 1.5rem
    }
}

#post article #article-title h2 {
    font-family: "roc-grotesk", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1.35rem;
    line-height: 1.5;
    margin: .5rem 0 1rem;
    opacity: .7
}

@media screen and (max-width: 800px) {
    #post article #article-title h2 {
        font-size: 1.2rem
    }
}

#post article #article-title time {
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: .9rem
}

#post article #article {
    margin: 5vw auto;
    max-width: 1200px
}

#post article #article:after {
    clear: both;
    content: "";
    display: block
}

@media screen and (min-width: 800px) {
    #post article #article #share {
        border-right: 1px solid #e9e2dc;
        float: left;
        position: sticky;
        top: 50px;
        width: 150px
    }
}

@media screen and (max-width: 800px) {
    #post article #article #share {
        border-top: 1px solid #e9e2dc;
        margin-top: 2rem;
        padding: 2rem 0
    }
}

#post article #article #share strong {
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: .5rem;
    letter-spacing: .2em;
    padding-bottom: 20px;
    text-transform: uppercase
}

#post article #article #share ul {
    display: flex;
    left: -15px;
    position: relative
}

#post article #article #share ul li a {
    color: #121730;
    display: block;
    font-size: 1.12rem;
    padding: 15px
}

@media (hover:hover) and (pointer:fine) {
    #post article #article #share ul li a {
        transition: color .35s ease-in-out;
        -moz-transition: color .35s ease-in-out;
        -o-transition: color .35s ease-in-out;
        -webkit-transition: color .35s ease-in-out
    }
    #post article #article #share ul li a:hover,
    #post article #article #share ul li a:focus {
        color: #e6af79;
        text-decoration: none
    }
}

@media screen and (min-width: 800px) {
    #post article #article .content {
        display: inline;
        float: right;
        width: calc(100% - 200px);
        width: -webkit-calc(100% - 200px)
    }
}

#post article #article .content a {
    color: #121730;
    text-decoration: underline;
    -webkit-text-decoration-color: #e6af79;
    text-decoration-color: #e6af79
}

#post article #article .content a:hover {
    color: #e6af79
}

#post article #article .content sup {
    display: inline-flex;
    position: relative;
    top: -8px
}

#post article #article .content sup a {
    background-color: #e6af79;
    border-radius: 50%;
    display: block;
    font-size: .5em;
    height: 20px;
    line-height: 20px;
    text-align: center;
    width: 20px
}

#post article #article .content sup a:hover {
    background-color: #121730;
    color: #fff
}

#post article #article .content img {
    border-radius: 5px
}

#post article #article .content figure {
    background-color: #fff;
    border-radius: 5px;
    line-height: 0;
    margin-bottom: 2rem;
    overflow: hidden
}

#post article #article .content figure img {
    border-radius: 5px;
    height: auto;
    width: 100%
}

#post article #article .content figure .two-col {
    padding: 10px 10px 0
}

@media screen and (min-width: 800px) {
    #post article #article .content figure .two-col {
        display: flex
    }
}

@media screen and (min-width: 800px) {
    #post article #article .content figure .two-col .col {
        width: calc(50% - 5px);
        width: -webkit-calc(50% - 5px)
    }
    #post article #article .content figure .two-col .col+.col {
        margin-left: 10px
    }
}

@media screen and (max-width: 800px) {
    #post article #article .content figure .two-col .col+.col {
        margin-top: 10px
    }
}

#post article #article .content figure figcaption {
    font-size: .75rem;
    line-height: 1.6;
    padding: 20px
}

#post article #article .content footer.references {
    border-top: 1px solid #e9e2dc;
    margin-top: 40px;
    padding-top: 40px
}

#post article #article .content footer.references ol li {
    font-size: .8rem
}

#contact-info {
    border-bottom: 1px solid #e3d9d1;
    padding: 10px 0
}

@media screen and (max-width: 1000px) {
    #contact-info {
        padding: 10px 0
    }
}

@media screen and (min-width: 800px) {
    #contact-info.location .container .col {
        margin: 1.5rem 0;
        padding: 0
    }
}

@media screen and (min-width: 800px) {
    #contact-info.location .container .col.blank {
        border-right: 1px solid #e6af79
    }
}

@media screen and (max-width: 800px) {
    #contact-info.location .container .col.blank {
        border-bottom: 1px solid #e6af79;
        margin-bottom: .5rem
    }
}

@media screen and (min-width: 800px) {
    #contact-info .container {
        display: flex;
        gap: 10px;
        justify-content: space-between;
        padding: 10px 10vw
    }
}

@media screen and (max-width: 800px) {
    #contact-info .container {
        padding-top: 1.5rem;
        padding-bottom: 1.5rem
    }
}

@media screen and (min-width: 800px) {
    #contact-info .container .col {
        padding: 1.5rem 0
    }
}

@media screen and (max-width: 800px) {
    #contact-info .container .col+.col {
        padding-top: 1.5rem
    }
}

#contact-info .container .col strong {
    display: block;
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: .72rem;
    letter-spacing: .2em;
    text-transform: uppercase
}

#contact-info .container .col a {
    color: #121730;
    display: block;
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal
}

#home-hero {
    background-color: #121730;
    position: relative
}

#home-hero .container {
    background: linear-gradient(200deg, rgba(18, 23, 48, 0.5) 10%, rgba(18, 23, 48, 0) 40%);
    position: relative;
    z-index: 2
}

@media screen and (min-width: 1001px) {
    #home-hero .container {
        padding: 70vh 30vw 10vw 10vw
    }
}

@media screen and (max-width: 1000px) {
    #home-hero .container {
        padding: 70vh 10vw 10vw
    }
}

@media screen and (max-width: 800px) {
    #home-hero .container {
        padding: 65vh 10vw 20vw
    }
}

#home-hero .container h1 {
    max-width: 17ch
}

#home-hero #hero-fade {
    height: 100%;
    left: 0;
    opacity: .5;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1
}

@media screen and (min-width: 800px) {
    #home-hero #hero-fade.splide {
        padding: 15px
    }
    #home-hero #hero-fade.video {
        border-top: 15px solid #121730;
        border-right: 15px solid #121730;
        border-left: 15px solid #121730
    }
}

#home-hero #hero-fade .splide__track {
    height: 100%
}

#home-hero #hero-fade .splide__track ul {
    background-color: #2e1f15;
    height: 100%
}

#home-hero #hero-fade .splide__track ul li {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    height: 100%
}

#map {
    position: relative
}

#map a.directions {
    display: block;
    height: 60px;
    left: 50%;
    margin: -14px 0 0 4px;
    position: absolute;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 50px;
    z-index: 2
}

@media (hover:hover) and (pointer:fine) {
    #map a.directions {
        transition: top .25s ease-in-out;
        -moz-transition: top .25s ease-in-out;
        -o-transition: top .25s ease-in-out;
        -webkit-transition: top .25s ease-in-out
    }
}

@media screen and (min-width: 1001px) {
    #map a.directions:hover {
        top: calc(50% + 6px);
        top: -webkit-calc(50% + 6px)
    }
}

#map a.directions img {
    height: 60px;
    width: 50px
}

#map .acf-map {
    border: none;
    position: relative;
    width: 100%
}

@media screen and (min-width: 1001px) {
    #map .acf-map {
        height: 50vh;
        max-height: 450px;
        min-height: 350px
    }
}

@media screen and (max-width: 1000px) {
    #map .acf-map {
        height: 45vh;
        min-height: 400px
    }
}

@media screen and (max-width: 800px) {
    #map .acf-map {
        height: 50vh;
        min-height: 350px
    }
}

#map .acf-map .gm-style * {
    cursor: initial
}

#map .acf-map .gm-style * a {
    cursor: pointer
}

#map .acf-map .gm-style * a img {
    cursor: pointer
}

#map .acf-map img {
    max-width: inherit !important
}

#main-container {
    margin: auto;
    max-width: 1600px;
    padding: 5vw 10vw
}

@media screen and (max-width: 1000px) {
    #main-container {
        padding: 10vw
    }
}

.modules {
    padding-bottom: 5vw
}

@media screen and (max-width: 1000px) {
    .modules {
        padding-bottom: 10vw
    }
}

.modules.p-top-force {
    padding-top: 5vw
}

@media screen and (max-width: 1000px) {
    .modules.p-top-force {
        padding-top: 10vw
    }
}

.modules section+section:not(.m-top-no) {
    margin-top: 10vw
}

@media screen and (max-width: 1000px) {
    .modules section+section:not(.m-top-no) {
        margin-top: 15vw
    }
}

.modules .container.basic .row {
    margin: auto;
    max-width: 800px
}

.modules .container.basic .row.width-full {
    max-width: initial
}

@media (hover:hover) and (pointer:fine) {
    .page-load-complete #projects .projects .project .bg {
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out
    }
}

#projects {
    padding: 5vw 0
}

@media screen and (max-width: 1000px) {
    #projects {
        padding: 10vw 0
    }
}

#projects .projects {
    display: flex;
    flex-wrap: wrap;
    gap: 5vw;
    padding-top: 5vw
}

@media screen and (max-width: 800px) {
    #projects .projects {
        gap: 10vw;
        padding-top: 10vw
    }
}

#projects .projects:after {
    display: none
}

#projects .projects .project {
    border-radius: 0 20px 20px;
    color: #fff;
    overflow: hidden;
    padding-bottom: 34%;
    position: relative
}

@media screen and (min-width: 1001px) {
    #projects .projects .project {
        width: 26.666vw
    }
}

@media screen and (max-width: 1000px) {
    #projects .projects .project {
        width: 37.5vw
    }
}

@media screen and (max-width: 800px) {
    #projects .projects .project {
        width: 100%
    }
}

@media (hover:hover) and (pointer:fine) {
    #projects .projects .project {
        transition: border-radius .25s ease-in-out;
        -moz-transition: border-radius .25s ease-in-out;
        -o-transition: border-radius .25s ease-in-out;
        -webkit-transition: border-radius .25s ease-in-out
    }
    #projects .projects .project:hover {
        border-radius: 20px
    }
    #projects .projects .project:hover .top,
    #projects .projects .project:hover .bottom {
        opacity: 1
    }
    #projects .projects .project:hover .bottom svg {
        left: 0
    }
    #projects .projects .project:hover .bg {
        height: 100%;
        width: 100%
    }
    #projects .projects .project:hover .bg:before {
        opacity: .5
    }
}

@media screen and (max-width: 1000px) {
    #projects .projects .project {
        padding-bottom: 60%
    }
}

@media screen and (max-width: 800px) {
    #projects .projects .project {
        border-radius: 0 20px 20px 0;
        padding-bottom: 120%
    }
}

#projects .projects .project>a {
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 3
}

@media (hover:hover) and (pointer:fine) {
    #projects .projects .project .top,
    #projects .projects .project .bottom {
        opacity: 0;
        transition: opacity .35s ease-in-out;
        -moz-transition: opacity .35s ease-in-out;
        -o-transition: opacity .35s ease-in-out;
        -webkit-transition: opacity .35s ease-in-out
    }
}

#projects .projects .project .top {
    left: 0;
    padding: 3vw;
    position: absolute;
    top: 0;
    z-index: 2
}

@media screen and (max-width: 1000px) {
    #projects .projects .project .top {
        padding: 6vw
    }
}

@media screen and (max-width: 800px) {
    #projects .projects .project .top {
        padding: 10vw
    }
}

#projects .projects .project .top h3 a {
    color: #fff;
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: 1.5rem
}

#projects .projects .project .top ul:after {
    clear: both;
    content: "";
    display: block
}

#projects .projects .project .top ul li {
    display: inline-block;
    font-size: .66rem;
    font-weight: bold
}

#projects .projects .project .top ul li+li:before {
    content: '• '
}

#projects .projects .project .bottom {
    bottom: 0;
    display: flex;
    left: 0;
    justify-content: space-between;
    padding: 3vw;
    position: absolute;
    transition-delay: .2s;
    width: 100%;
    z-index: 2
}

@media screen and (max-width: 1000px) {
    #projects .projects .project .bottom {
        padding: 6vw
    }
}

@media screen and (max-width: 800px) {
    #projects .projects .project .bottom {
        padding: 10vw
    }
}

#projects .projects .project .bottom span {
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: .722rem;
    letter-spacing: .2em;
    text-transform: uppercase
}

#projects .projects .project .bottom svg {
    height: 15px;
    position: relative;
    top: 1px;
    width: 54px
}

@media screen and (min-width: 800px) {
    #projects .projects .project .bottom svg {
        left: -100px
    }
}

@media screen and (max-width: 800px) {
    #projects .projects .project .bottom svg {
        right: 0
    }
}

@media (hover:none) {
    #projects .projects .project .bottom svg {
        left: 0
    }
}

@media (hover:hover) and (pointer:fine) {
    #projects .projects .project .bottom svg {
        transition: left .25s ease-in-out;
        -moz-transition: left .25s ease-out;
        -o-transition: left .25s ease-out;
        -webkit-transition: left .25s ease-out;
        transition-delay: .1s
    }
}

#projects .projects .project .bottom svg path {
    fill: #e6af79
}

#projects .projects .project .bg {
    background-color: #121730;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    height: 106%;
    left: 50%;
    position: absolute;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 106%
}

#projects .projects .project .bg:before {
    background-color: #121730;
    content: '';
    height: 100%;
    left: 0;
    opacity: 0;
    position: absolute;
    top: 0;
    transition: opacity .35s ease-in-out;
    -moz-transition: opacity .35s ease-in-out;
    -o-transition: opacity .35s ease-in-out;
    -webkit-transition: opacity .35s ease-in-out;
    width: 100%
}

@media (hover:none) {
    #projects .projects .project .bg:before {
        opacity: .5
    }
}

@media screen and (max-width: 800px) {
    #projects .projects .project .bg:before {
        opacity: .5
    }
}

#hero-project {
    background-color: #121730;
    position: relative
}

#hero-project #hero-project-top {
    position: relative;
    z-index: 1
}

#hero-project #hero-project-top .container {
    position: relative;
    z-index: 2
}

@media screen and (min-width: 1001px) {
    #hero-project #hero-project-top .container {
        padding: 70vh 30vw 20vw 10vw
    }
}

@media screen and (max-width: 1000px) {
    #hero-project #hero-project-top .container {
        padding: 70vh 10vw 10vw
    }
}

@media screen and (max-width: 800px) {
    #hero-project #hero-project-top .container {
        padding: 65vh 10vw 20vw
    }
}

#hero-project #hero-project-top #hero-fade {
    height: calc(100% + 10vw);
    height: -webkit-calc(100% + 10vw);
    left: 0;
    opacity: .5;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1
}

#hero-project #hero-project-top #hero-fade:before {
    background: linear-gradient(0deg, #121730 0%, rgba(18, 23, 48, 0) 60%);
    content: '';
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 2
}

@media screen and (min-width: 800px) {
    #hero-project #hero-project-top #hero-fade.img {
        padding: 15px
    }
    #hero-project #hero-project-top #hero-fade.video {
        border-top: 15px solid #121730;
        border-right: 15px solid #121730;
        border-left: 15px solid #121730
    }
}

#hero-project #hero-project-top #hero-fade.img>div {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    position: absolute
}

@media screen and (min-width: 800px) {
    #hero-project #hero-project-top #hero-fade.img>div {
        height: calc(100% - 30px);
        height: -webkit-calc(100% - 30px);
        left: 15px;
        top: 15px;
        width: calc(100% - 30px);
        width: -webkit-calc(100% - 30px)
    }
}

@media screen and (max-width: 800px) {
    #hero-project #hero-project-top #hero-fade.img>div {
        left: 0;
        height: 100%;
        top: 0;
        width: 100%
    }
}

#hero-project #hero-overview {
    position: relative;
    z-index: 2
}

@media screen and (min-width: 1001px) {
    #hero-project #hero-overview {
        padding: 15px 10vw 5vw
    }
}

@media screen and (max-width: 1000px) {
    #hero-project #hero-overview {
        padding: 0 10vw 10vw
    }
}

#hero-project #hero-overview:before {
    background-color: #cacfe4;
    content: '';
    display: block;
    height: 1px;
    margin-bottom: 5vw;
    opacity: .25;
    width: 100%
}

@media screen and (max-width: 1000px) {
    #hero-project #hero-overview:before {
        margin-bottom: 10vw
    }
}

#hero-project #hero-overview p {
    color: #fff;
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1.2rem
}

@media screen and (min-width: 1001px) {
    #hero-project #hero-overview p {
        margin: auto;
        max-width: 700px;
        text-align: center
    }
}

@media screen and (max-width: 1000px) {
    #hero-project #hero-overview p {
        font-size: 1rem
    }
}

@media screen and (max-width: 800px) {
    #hero-project #hero-overview p {
        font-size: .9rem
    }
}

#hero-project #hero-overview #team {
    border-top: 1px solid rgba(202, 207, 228, 0.25);
    -webkit-column-gap: 5vw;
    -moz-column-gap: 5vw;
    column-gap: 5vw;
    display: flex;
    font-size: .8rem;
    margin-top: 5vw;
    padding-top: 5vw;
    position: relative
}

@media screen and (min-width: 1001px) {
    #hero-project #hero-overview #team {
        justify-content: center
    }
}

@media screen and (min-width: 800px) and (max-width: 1000px) {
    #hero-project #hero-overview #team {
        flex-wrap: wrap;
        gap: 5vw
    }
    #hero-project #hero-overview #team>div {
        width: 40%
    }
}

@media screen and (max-width: 800px) {
    #hero-project #hero-overview #team {
        flex-wrap: wrap;
        margin-top: 10vw;
        padding-top: 10vw
    }
}

#hero-project #hero-overview #team>div {
    color: #fff
}

@media screen and (max-width: 800px) {
    #hero-project #hero-overview #team>div {
        width: 100%
    }
    #hero-project #hero-overview #team>div+div {
        padding-top: 5vw
    }
}

#hero-project #hero-overview #team>div strong {
    display: block;
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: .6rem;
    line-height: 1.2;
    margin-bottom: 5px
}

#hero-project #hero-overview #team>div span {
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal
}

#hero-project #hero-overview #team>div a {
    color: #fff;
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    text-decoration: underline;
    -webkit-text-decoration-color: #e6af79;
    text-decoration-color: #e6af79
}

@media screen and (min-width: 1001px) {
    #hero-project #hero-overview #team>div a {
        transition: color .35s ease-in-out;
        -moz-transition: color .35s ease-in-out;
        -o-transition: color .35s ease-in-out;
        -webkit-transition: color .35s ease-in-out
    }
    #hero-project #hero-overview #team>div a:hover {
        color: #cacfe4
    }
}

#project #project-content {
    padding: 55vh 10vw 10vw;
    position: relative
}

@media screen and (max-width: 1000px) {
    #project #project-content {
        padding-bottom: 15vw
    }
}

@media screen and (max-width: 800px) {
    #project #project-content {
        padding-top: 45vh
    }
}

#project #project-content .img {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    height: 60vh;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1
}

@media screen and (max-width: 800px) {
    #project #project-content .img {
        height: 50vh
    }
}

#project #project-content .img:before {
    background: linear-gradient(0deg, #f9f7f6 0%, rgba(249, 247, 246, 0) 35%);
    content: '';
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%
}

#project #project-content .project-content {
    margin: auto;
    max-width: 1300px;
    position: relative;
    z-index: 2
}

@media screen and (min-width: 1001px) {
    #project #project-content .project-content {
        display: flex;
        justify-content: space-between
    }
}

@media screen and (min-width: 1001px) {
    #project #project-content .project-content .content {
        width: 55%
    }
}

@media screen and (max-width: 1000px) {
    #project #project-content .project-content .content {
        border-bottom: 1px solid #e9e2dc;
        margin-bottom: 7vw;
        padding-bottom: calc(7vw - 24px);
        padding-bottom: -webkit-calc(7vw - 24px)
    }
}

#project #project-content .project-content .content a {
    color: #121730;
    text-decoration: underline;
    -webkit-text-decoration-color: #e6af79;
    text-decoration-color: #e6af79
}

#project #project-content .project-content .content a:hover {
    color: #e6af79
}

#project #project-content .project-content .highlights {
    position: relative
}

@media screen and (min-width: 1001px) {
    #project #project-content .project-content .highlights {
        width: 35%
    }
}

@media screen and (min-width: 800px) and (max-width: 1000px) {
    #project #project-content .project-content .highlights>ul {
        -webkit-column-count: 2;
        -moz-column-count: 2;
        column-count: 2;
        -webkit-column-gap: 5vw;
        -moz-column-gap: 5vw;
        column-gap: 5vw
    }
}

#project #project-content .project-content .highlights ul li {
    font-size: .75rem;
    line-height: 1.5;
    padding: 0 0 15px 26px;
    position: relative
}

#project #project-content .project-content .highlights ul li:before {
    color: #cacfe4;
    content: "• ";
    left: 0;
    position: absolute
}

#project #project-content .project-content .highlights ul li ul li {
    padding: 15px 0 0 0
}

#project #project-content .project-content .highlights ul li ul li:before {
    left: -26px
}

#project #project-content .project-content .highlights .highlight-preview {
    overflow: hidden;
    padding: 0 2px;
    position: relative
}

@media screen and (max-width: 1000px) {
    #project #project-content .project-content .highlights .highlight-preview {
        height: 280px
    }
}

#project #project-content .project-content .highlights .highlight-preview:before {
    background: linear-gradient(0deg, #f9f7f6 0%, rgba(249, 247, 246, 0) 60%);
    content: '';
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1
}

#project #project-content .project-content .highlights ul.btns {
    left: 14px;
    position: relative
}

#project #project-gallery-contain {
    position: relative
}

@media screen and (min-width: 800px) {
    #project #project-gallery-contain {
        padding: 0 10vw
    }
}

#project #project-gallery-contain:before {
    background-color: #fff;
    bottom: 0;
    content: '';
    height: 50%;
    left: 0;
    position: absolute;
    width: 100%
}

#project #project-gallery-contain #project-gallery {
    margin: auto;
    max-width: 1300px;
    position: relative;
    z-index: 2
}

#project #project-gallery-contain #project-gallery .splide__arrows {
    background-color: #121730;
    border-radius: 10px;
    -moz-border-radius: 10px;
    -webkit-border-radius: 10px;
    left: 5vw;
    padding: 0 15px;
    position: absolute;
    top: -25px;
    z-index: 2
}

@media screen and (max-width: 800px) {
    #project #project-gallery-contain #project-gallery .splide__arrows {
        bottom: -25px;
        left: 10vw;
        top: initial
    }
}

#project #project-gallery-contain #project-gallery .splide__arrows .splide__arrow {
    background: transparent;
    border: none;
    cursor: pointer;
    height: 50px
}

@media (hover:hover) and (pointer:fine) {
    #project #project-gallery-contain #project-gallery .splide__arrows .splide__arrow:hover svg {
        width: 35px
    }
    #project #project-gallery-contain #project-gallery .splide__arrows .splide__arrow:hover svg path {
        fill: #fff
    }
}

#project #project-gallery-contain #project-gallery .splide__arrows .splide__arrow svg {
    height: 12px;
    width: 25px
}

@media (hover:hover) and (pointer:fine) {
    #project #project-gallery-contain #project-gallery .splide__arrows .splide__arrow svg {
        transition: width .35s ease-in-out;
        -moz-transition: width .35s ease-in-out;
        -o-transition: width .35s ease-in-out;
        -webkit-transition: width .35s ease-in-out
    }
}

#project #project-gallery-contain #project-gallery .splide__arrows .splide__arrow svg path {
    fill: #e6af79
}

#project #project-gallery-contain #project-gallery .splide__track {
    cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='74px' height='30px' viewBox='0 0 90.27 35.16'%3E%3Cpath d='M0 0h84.55c3.16 0 5.73 2.57 5.73 5.73v29.44H5.73C2.57 35.17 0 32.6 0 29.44V0Z' style='fill:rgba(230,175,121,.8'/%3E%3Cpath d='M23.26 13.72h-4.17v8.18h4.53c3.46 0 4.77-1.47 4.77-4.09 0-2.31-1.29-4.09-5.14-4.09Zm.29 6.42h-2.06v-4.65h1.9c1.93 0 2.62 1.03 2.62 2.33 0 1.5-.7 2.32-2.46 2.32Zm18.61-3.99c0-1.47-.95-2.42-3.98-2.42h-5.15v8.18h2.39v-2.95h2.96c1.02 0 1.34.39 1.34 1.23v1.72h2.39v-1.72c0-.86-.14-1.77-1.43-2.06v-.02c1.13-.34 1.48-1.13 1.48-1.95Zm-3.87 1.42h-2.87v-2.08h2.66c1.38 0 1.82.42 1.82 1.01 0 .63-.42 1.07-1.6 1.07Zm12.74-3.84-4.45 8.18h2.46l.85-1.67h4.81l.85 1.67h2.77l-4.45-8.18h-2.83Zm-.45 5.12 1.69-3.33h.01l1.7 3.33h-3.41Zm16.32-1.17v1.27h2.64v.04c0 .58-.65 1.49-2.35 1.49-2 0-2.75-1.16-2.75-2.54 0-1.47.91-2.6 2.79-2.6s2.45.8 2.45 1.43v.09h2.13c.01-.09.01-.14.01-.17 0-1.53-1.08-3.11-4.66-3.11S62 15.57 62 17.93c0 2.15 1.31 4.13 4.8 4.13 2.04 0 3.02-.75 3.29-1.8h.02c0 .6-.01 1.29-.02 1.65h1.84v-4.23h-5.02Z' style='fill:%23121830'/%3E%3C/svg%3E"), grab;
    position: relative;
    z-index: 1
}

@media screen and (min-width: 800px) {
    #project #project-gallery-contain #project-gallery .splide__track {
        border-radius: 20px;
        -moz-border-radius: 20px;
        -webkit-border-radius: 20px
    }
}

#project #project-gallery-contain #project-gallery .splide__track ul.splide__list {
    transition: height .35s ease-in-out;
    -moz-transition: height .35s ease-in-out;
    -o-transition: height .35s ease-in-out;
    -webkit-transition: height .35s ease-in-out
}

#project #project-gallery-contain #project-gallery .splide__track ul.splide__list li.splide__slide {
    position: relative;
    width: 100%
}

@media screen and (min-width: 800px) {
    #project #project-gallery-contain #project-gallery .splide__track ul.splide__list li.splide__slide {
        border-radius: 20px;
        -moz-border-radius: 20px;
        -webkit-border-radius: 20px
    }
}

#project #project-gallery-contain #project-gallery .splide__track ul.splide__list li.splide__slide.is-visible .description {
    opacity: 1
}

#project #project-gallery-contain #project-gallery .splide__track ul.splide__list li.splide__slide img {
    display: block;
    margin: auto;
    max-height: 90vh;
    max-width: 100%
}

@media screen and (min-width: 800px) {
    #project #project-gallery-contain #project-gallery .splide__track ul.splide__list li.splide__slide img {
        border-radius: 20px;
        -moz-border-radius: 20px;
        -webkit-border-radius: 20px
    }
}

#big-cta {
    background-color: #121730
}

#big-cta.light {
    background-color: #fff
}

@media screen and (min-width: 800px) {
    #big-cta {
        padding: 5vw 0
    }
}

@media screen and (min-width: 1001px) {
    #big-cta.big-para .container .big-cta .promo {
        padding-right: 30%
    }
}

@media screen and (max-width: 1000px) {
    #big-cta.big-para .container .big-cta .promo {
        padding: 40vh 10vw 10vw
    }
}

#big-cta.big-para .container .big-cta .promo p.para-large a {
    color: #cacfe4
}

#big-cta.big-para .container .big-cta .promo p.para-large a span svg path {
    stroke: #e6af79
}

@media screen and (max-width: 1000px) {
    #big-cta.big-para .container .big-cta .media,
    #big-cta.big-para .container .big-cta .img {
        height: 50vh;
        opacity: .8
    }
}

#big-cta.big-para .container .big-cta .media .video-bg,
#big-cta.big-para .container .big-cta .img .video-bg {
    z-index: 1
}

@media screen and (max-width: 1000px) {
    #big-cta.big-para .container .big-cta .media .video-bg:before,
    #big-cta.big-para .container .big-cta .img .video-bg:before {
        background: linear-gradient(0deg, #121730 0%, rgba(18, 23, 48, 0) 40%);
        content: '';
        height: 100%;
        left: 0;
        position: absolute;
        top: 0;
        width: 100%;
        z-index: 2
    }
}

@media screen and (max-width: 800px) {
    #big-cta .container {
        padding: 15px
    }
}

#big-cta .container .big-cta {
    background-color: #121730;
    border-radius: 20px;
    -moz-border-radius: 20px;
    -webkit-border-radius: 20px;
    overflow: hidden;
    position: relative
}

@media (hover:hover) and (pointer:fine) {
    #big-cta .container .big-cta:hover .img {
        opacity: .4;
        scale: 1.025
    }
}

#big-cta .container .big-cta .promo {
    color: #fff;
    position: relative;
    z-index: 2
}

@media screen and (min-width: 1001px) {
    #big-cta .container .big-cta .promo {
        padding: 10vw 50% 10vw 10vw
    }
}

@media screen and (max-width: 1000px) {
    #big-cta .container .big-cta .promo {
        padding: 10vw
    }
}

#big-cta .container .big-cta .promo h3 {
    color: #fff;
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    line-height: 1.2
}

#big-cta .container .big-cta .promo p {
    line-height: 1.8;
    margin-bottom: 24px
}

#big-cta .container .big-cta .promo figure {
    font-family: "roc-grotesk", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1.25rem;
    margin-bottom: 2rem
}

@media screen and (max-width: 800px) {
    #big-cta .container .big-cta .promo figure {
        font-size: 1.05rem
    }
}

#big-cta .container .big-cta .promo figure figcaption {
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: .72rem;
    letter-spacing: .2em;
    margin-top: 1rem;
    text-transform: uppercase
}

@media screen and (max-width: 800px) {
    #big-cta .container .big-cta .promo figure figcaption {
        font-size: .6em
    }
}

#big-cta .container .big-cta .media,
#big-cta .container .big-cta .img {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    left: 0;
    height: 100%;
    opacity: .25;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1
}

@media (hover:hover) and (pointer:fine) {
    #big-cta .container .big-cta .media,
    #big-cta .container .big-cta .img {
        transition: opacity .5s ease-in-out, scale .75s ease-out;
        -moz-transition: opacity .5s ease-in-out, scale .75s ease-out;
        -o-transition: opacity .5s ease-in-out, scale .75s ease-out;
        -webkit-transition: opacity .5s ease-in-out, scale .75s ease-out
    }
}

#big-hero {
    background-color: #121730;
    color: #fff;
    padding: 10vw 5vw;
    position: relative
}

@media screen and (max-width: 800px) {
    #big-hero {
        padding: 40vw 0vw 10vw
    }
}

#big-hero .container {
    z-index: 2
}

#big-hero .container .content {
    max-width: 60ch
}

#big-hero .bg {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    border-radius: 20px 0 0 0;
    -moz-border-radius: 20px 0 0 0;
    -webkit-border-radius: 20px 0 0 0;
    bottom: 0;
    height: 100%;
    opacity: .5;
    overflow: hidden;
    position: absolute;
    right: 0;
    width: 70%;
    z-index: 1
}

#blog-excerpt {
    padding: 10vw 0
}

@media screen and (min-width: 1001px) {
    #blog-excerpt .container h2 {
        left: 50%;
        margin-left: 2.5vw;
        position: absolute;
        top: 100px
    }
}

@media screen and (min-width: 1001px) {
    #blog-excerpt .container .blog-excerpt {
        display: flex;
        gap: 5vw
    }
}

#blog-excerpt .container .blog-excerpt .latest {
    background-color: #121730;
    border-radius: 20px;
    -moz-border-radius: 20px;
    -webkit-border-radius: 20px;
    overflow: hidden;
    position: relative
}

@media screen and (min-width: 1001px) {
    #blog-excerpt .container .blog-excerpt .latest {
        flex: 1
    }
}

@media (hover:hover) and (pointer:fine) {
    #blog-excerpt .container .blog-excerpt .latest:hover h3 {
        left: 0;
        opacity: 1
    }
    #blog-excerpt .container .blog-excerpt .latest:hover .img {
        opacity: .5;
        scale: 1.1
    }
}

#blog-excerpt .container .blog-excerpt .latest a.link {
    z-index: 3
}

#blog-excerpt .container .blog-excerpt .latest:before {
    border: 2px solid #e6af79;
    border-radius: 8px;
    content: '';
    display: block;
    height: 8px;
    position: absolute;
    width: 8px;
    z-index: 2
}

@media screen and (min-width: 1001px) {
    #blog-excerpt .container .blog-excerpt .latest:before {
        left: 2rem;
        bottom: 2rem
    }
}

@media screen and (max-width: 1000px) {
    #blog-excerpt .container .blog-excerpt .latest:before {
        left: 5vw;
        bottom: 5vw
    }
}

@media screen and (max-width: 800px) {
    #blog-excerpt .container .blog-excerpt .latest:before {
        left: 10vw;
        bottom: 10vw
    }
}

#blog-excerpt .container .blog-excerpt .latest h3 {
    color: #fff;
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    line-height: 1.2;
    z-index: 2
}

@media screen and (min-width: 1001px) {
    #blog-excerpt .container .blog-excerpt .latest h3 {
        bottom: 3rem;
        font-size: 1.35rem;
        left: -15px;
        opacity: 0;
        padding: 0 2rem;
        position: absolute;
        width: 100%
    }
}

@media screen and (max-width: 1000px) {
    #blog-excerpt .container .blog-excerpt .latest h3 {
        padding: 35vh 5vw 10vw;
        position: relative
    }
}

@media screen and (max-width: 800px) {
    #blog-excerpt .container .blog-excerpt .latest h3 {
        padding: 35vh 10vw 15vw
    }
}

@media (hover:none) {
    #blog-excerpt .container .blog-excerpt .latest h3 {
        left: 0;
        opacity: 1
    }
}

@media (hover:hover) and (pointer:fine) {
    #blog-excerpt .container .blog-excerpt .latest h3 {
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out
    }
}

#blog-excerpt .container .blog-excerpt .latest .img {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    left: 0;
    height: 100%;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1
}

@media screen and (max-width: 1000px) {
    #blog-excerpt .container .blog-excerpt .latest .img {
        opacity: .5
    }
}

@media (hover:none) {
    #blog-excerpt .container .blog-excerpt .latest .img {
        opacity: .5
    }
}

@media (hover:hover) and (pointer:fine) {
    #blog-excerpt .container .blog-excerpt .latest .img {
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out
    }
}

@media screen and (min-width: 1001px) {
    #blog-excerpt .container .blog-excerpt .more {
        flex: 1;
        padding: 150px 0 120px
    }
}

#blog-excerpt .container .blog-excerpt .more ul:not(.btns) {
    margin-bottom: 2rem
}

@media screen and (max-width: 1000px) {
    #blog-excerpt .container .blog-excerpt .more ul:not(.btns) {
        margin: 1.25rem 0
    }
}

#blog-excerpt .container .blog-excerpt .more ul:not(.btns) li+li {
    border-top: 1px solid #e3d9d1
}

#blog-excerpt .container .blog-excerpt .more ul:not(.btns) li a {
    color: #121730;
    display: block;
    padding: 10px 30px 10px 0
}

@media (hover:hover) and (pointer:fine) {
    #blog-excerpt .container .blog-excerpt .more ul:not(.btns) li a:hover span {
        left: 10px
    }
}

#blog-excerpt .container .blog-excerpt .more ul:not(.btns) li a span {
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    left: 0;
    position: relative
}

@media (hover:hover) and (pointer:fine) {
    #blog-excerpt .container .blog-excerpt .more ul:not(.btns) li a span {
        transition: left .25s ease-in-out;
        -moz-transition: left .25s ease-in-out;
        -o-transition: left .25s ease-in-out;
        -webkit-transition: left .25s ease-in-out
    }
}

.carousel-group {
    overflow: hidden;
    position: relative
}

.carousel-group .container {
    z-index: 2
}

@media screen and (min-width: 1001px) {
    .carousel-group .container .content {
        padding: 10vw 10vw 5vw
    }
}

@media screen and (max-width: 1000px) {
    .carousel-group .container .content {
        padding: 10vw 0 5vw
    }
}

@media screen and (max-width: 800px) {
    .carousel-group .container .content {
        padding: 10vw 0
    }
}

.carousel-group .container .content h1 {
    max-width: 25ch
}

.carousel-group .carousel {
    position: relative;
    z-index: 2
}

@media screen and (min-width: 800px) {
    .carousel-group .carousel {
        left: -5vw
    }
}

@media screen and (max-width: 800px) {
    .carousel-group .carousel {
        width: 90%
    }
}

.carousel-group .carousel * {
    cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='74px' height='30px' viewBox='0 0 90.27 35.16'%3E%3Cpath d='M0 0h84.55c3.16 0 5.73 2.57 5.73 5.73v29.44H5.73C2.57 35.17 0 32.6 0 29.44V0Z' style='fill:rgba(230,175,121,.8'/%3E%3Cpath d='M23.26 13.72h-4.17v8.18h4.53c3.46 0 4.77-1.47 4.77-4.09 0-2.31-1.29-4.09-5.14-4.09Zm.29 6.42h-2.06v-4.65h1.9c1.93 0 2.62 1.03 2.62 2.33 0 1.5-.7 2.32-2.46 2.32Zm18.61-3.99c0-1.47-.95-2.42-3.98-2.42h-5.15v8.18h2.39v-2.95h2.96c1.02 0 1.34.39 1.34 1.23v1.72h2.39v-1.72c0-.86-.14-1.77-1.43-2.06v-.02c1.13-.34 1.48-1.13 1.48-1.95Zm-3.87 1.42h-2.87v-2.08h2.66c1.38 0 1.82.42 1.82 1.01 0 .63-.42 1.07-1.6 1.07Zm12.74-3.84-4.45 8.18h2.46l.85-1.67h4.81l.85 1.67h2.77l-4.45-8.18h-2.83Zm-.45 5.12 1.69-3.33h.01l1.7 3.33h-3.41Zm16.32-1.17v1.27h2.64v.04c0 .58-.65 1.49-2.35 1.49-2 0-2.75-1.16-2.75-2.54 0-1.47.91-2.6 2.79-2.6s2.45.8 2.45 1.43v.09h2.13c.01-.09.01-.14.01-.17 0-1.53-1.08-3.11-4.66-3.11S62 15.57 62 17.93c0 2.15 1.31 4.13 4.8 4.13 2.04 0 3.02-.75 3.29-1.8h.02c0 .6-.01 1.29-.02 1.65h1.84v-4.23h-5.02Z' style='fill:%23121830'/%3E%3C/svg%3E"), grab
}

.carousel-group .carousel .splide__track {
    border-radius: 0 20px 20px;
    overflow: hidden
}

@media screen and (max-width: 800px) {
    .carousel-group .carousel .splide__track {
        border-radius: 0 20px 20px 0
    }
}

.carousel-group .carousel .splide__track ul.splide__list li.splide__slide {
    border-radius: 0 20px 20px;
    color: #fff;
    overflow: hidden;
    padding-bottom: 34%;
    position: relative
}

@media screen and (max-width: 1000px) {
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide {
        padding-bottom: 60%
    }
}

@media screen and (max-width: 800px) {
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide {
        border-radius: 0 20px 20px 0;
        padding-bottom: 120%
    }
}

.carousel-group .carousel .splide__track ul.splide__list li.splide__slide>a {
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 3
}

@media (hover:hover) and (pointer:fine) {
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide .top,
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide .bottom {
        opacity: 0;
        transition: opacity .35s ease-in-out;
        -moz-transition: opacity .35s ease-in-out;
        -o-transition: opacity .35s ease-in-out;
        -webkit-transition: opacity .35s ease-in-out
    }
}

.carousel-group .carousel .splide__track ul.splide__list li.splide__slide .top {
    left: 0;
    padding: 3vw;
    position: absolute;
    top: 0;
    z-index: 2
}

@media screen and (max-width: 1000px) {
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide .top {
        padding: 6vw
    }
}

@media screen and (max-width: 800px) {
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide .top {
        padding: 10vw
    }
}

.carousel-group .carousel .splide__track ul.splide__list li.splide__slide .top h3 a {
    color: #fff;
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: 1.5rem
}

.carousel-group .carousel .splide__track ul.splide__list li.splide__slide .top ul:after {
    clear: both;
    content: "";
    display: block
}

.carousel-group .carousel .splide__track ul.splide__list li.splide__slide .top ul li {
    display: inline-block;
    font-size: .66rem;
    font-weight: bold
}

.carousel-group .carousel .splide__track ul.splide__list li.splide__slide .top ul li+li:before {
    content: '• '
}

.carousel-group .carousel .splide__track ul.splide__list li.splide__slide .bottom {
    bottom: 0;
    display: flex;
    left: 0;
    justify-content: space-between;
    padding: 3vw;
    position: absolute;
    transition-delay: .2s;
    width: 100%;
    z-index: 2
}

@media screen and (max-width: 1000px) {
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide .bottom {
        padding: 6vw
    }
}

@media screen and (max-width: 800px) {
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide .bottom {
        padding: 10vw
    }
}

.carousel-group .carousel .splide__track ul.splide__list li.splide__slide .bottom span {
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: .722rem;
    letter-spacing: .2em;
    text-transform: uppercase
}

.carousel-group .carousel .splide__track ul.splide__list li.splide__slide .bottom svg {
    height: 15px;
    position: relative;
    top: 1px;
    width: 54px
}

@media screen and (min-width: 800px) {
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide .bottom svg {
        left: -100px
    }
}

@media screen and (max-width: 800px) {
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide .bottom svg {
        right: 0
    }
}

@media (hover:none) {
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide .bottom svg {
        left: 0
    }
}

@media (hover:hover) and (pointer:fine) {
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide .bottom svg {
        transition: left .25s ease-in-out;
        -moz-transition: left .25s ease-out;
        -o-transition: left .25s ease-out;
        -webkit-transition: left .25s ease-out;
        transition-delay: .1s
    }
}

.carousel-group .carousel .splide__track ul.splide__list li.splide__slide .bottom svg path {
    fill: #e6af79
}

.carousel-group .carousel .splide__track ul.splide__list li.splide__slide .bg {
    background-color: #121730;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    height: 106%;
    left: 50%;
    position: absolute;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 106%
}

@media (hover:hover) and (pointer:fine) {
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide .bg {
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out
    }
}

.carousel-group .carousel .splide__track ul.splide__list li.splide__slide .bg:before {
    background-color: #121730;
    content: '';
    height: 100%;
    left: 0;
    opacity: 0;
    position: absolute;
    top: 0;
    transition: opacity .35s ease-in-out;
    -moz-transition: opacity .35s ease-in-out;
    -o-transition: opacity .35s ease-in-out;
    -webkit-transition: opacity .35s ease-in-out;
    width: 100%
}

@media (hover:none) {
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide .bg:before {
        opacity: .5
    }
}

@media screen and (max-width: 800px) {
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide .bg:before {
        opacity: .5
    }
}

@media (hover:hover) and (pointer:fine) {
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide.is-visible:not(.is-active) {
        transition: border-radius .25s ease-in-out;
        -moz-transition: border-radius .25s ease-in-out;
        -o-transition: border-radius .25s ease-in-out;
        -webkit-transition: border-radius .25s ease-in-out
    }
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide.is-visible:not(.is-active):hover {
        border-radius: 20px
    }
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide.is-visible:not(.is-active):hover .top,
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide.is-visible:not(.is-active):hover .bottom {
        opacity: 1
    }
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide.is-visible:not(.is-active):hover .bottom svg {
        left: 0
    }
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide.is-visible:not(.is-active):hover .bg {
        height: 100%;
        width: 100%
    }
    .carousel-group .carousel .splide__track ul.splide__list li.splide__slide.is-visible:not(.is-active):hover .bg:before {
        opacity: .5
    }
}

.carousel-group .bg {
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1
}

#child-hero {
    background-color: #121730;
    color: #fff;
    padding: 35vh 5vw 5vw;
    position: relative
}

@media screen and (max-width: 800px) {
    #child-hero {
        padding: 40vw 0vw 5vw
    }
}

#child-hero .container {
    z-index: 2
}

#child-hero .container .content {
    max-width: 80ch
}

#child-hero .bg {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    bottom: 0;
    height: 100%;
    opacity: .35;
    overflow: hidden;
    position: absolute;
    right: 0;
    width: 100%;
    z-index: 1
}

#child-hero .bg:before {
    background: linear-gradient(0deg, #121730 0%, rgba(18, 23, 48, 0) 60%);
    content: '';
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%
}

#children {
    background-color: #121730;
    padding: 7vw 0
}

@media screen and (max-width: 1000px) {
    #children {
        padding: 10vw 0
    }
}

#children h1 {
    margin-bottom: 3vw;
    text-align: center
}

#children .children {
    display: flex;
    flex-wrap: wrap;
    gap: 5vw;
    justify-content: center
}

@media screen and (max-width: 800px) {
    #children .children {
        gap: 10vw
    }
}

#children .children:after {
    display: none
}

#children .children .child {
    position: relative
}

@media screen and (min-width: 1001px) {
    #children .children .child {
        width: 26.666vw
    }
}

@media screen and (max-width: 1000px) {
    #children .children .child {
        width: 37.5vw
    }
}

@media screen and (max-width: 800px) {
    #children .children .child {
        width: 100%
    }
}

@media (hover:hover) and (pointer:fine) {
    #children .children .child .img {
        transition: border-radius .25s ease-in-out;
        -moz-transition: border-radius .25s ease-in-out;
        -o-transition: border-radius .25s ease-in-out;
        -webkit-transition: border-radius .25s ease-in-out
    }
    #children .children .child:hover .img {
        border-radius: 20px
    }
    #children .children .child:hover .img:before {
        opacity: .25
    }
}

#children .children .child .img {
    background-color: #121730;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    border-radius: 0 20px 20px;
    margin-bottom: 20px;
    overflow: hidden;
    padding-bottom: 60%;
    position: relative;
    width: 100%
}

#children .children .child .img a {
    z-index: 3
}

#children .children .child .img:before {
    background-color: #121730;
    content: '';
    height: 100%;
    left: 0;
    opacity: 0;
    position: absolute;
    top: 0;
    transition: opacity .35s ease-in-out;
    -moz-transition: opacity .35s ease-in-out;
    -o-transition: opacity .35s ease-in-out;
    -webkit-transition: opacity .35s ease-in-out;
    width: 100%;
    z-index: 2
}

#children .children .child h2 a {
    color: #fff;
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: 1.3rem;
    line-height: 1.5
}

@media (hover:hover) and (pointer:fine) {
    #children .children .child h2 a {
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out;
        text-decoration: underline;
        -webkit-text-decoration-color: #e9e2dc;
        text-decoration-color: #e9e2dc
    }
    #children .children .child h2 a:hover {
        color: #e6af79;
        -webkit-text-decoration-color: #fff;
        text-decoration-color: #fff
    }
}

.cta-pages .container {
    display: flex;
    flex-wrap: wrap;
    gap: 5vw;
    padding-top: 5vw
}

@media screen and (max-width: 800px) {
    .cta-pages .container {
        gap: 10vw;
        padding-top: 10vw
    }
}

.cta-pages .container:after {
    display: none
}

.cta-pages .container .item {
    border-radius: 0 20px 20px;
    color: #fff;
    overflow: hidden;
    padding-bottom: 34%;
    position: relative
}

@media screen and (min-width: 1001px) {
    .cta-pages .container .item {
        width: 26.666vw
    }
}

@media screen and (max-width: 1000px) {
    .cta-pages .container .item {
        width: 37.5vw
    }
}

@media screen and (max-width: 800px) {
    .cta-pages .container .item {
        width: 100%
    }
}

@media (hover:hover) and (pointer:fine) {
    .cta-pages .container .item {
        transition: border-radius .25s ease-in-out;
        -moz-transition: border-radius .25s ease-in-out;
        -o-transition: border-radius .25s ease-in-out;
        -webkit-transition: border-radius .25s ease-in-out
    }
    .cta-pages .container .item:hover {
        border-radius: 20px
    }
    .cta-pages .container .item:hover .top,
    .cta-pages .container .item:hover .bottom {
        opacity: 1
    }
    .cta-pages .container .item:hover .bottom svg {
        left: 0
    }
    .cta-pages .container .item:hover .bg {
        height: 100%;
        width: 100%
    }
    .cta-pages .container .item:hover .bg:before {
        opacity: .5
    }
}

@media screen and (max-width: 1000px) {
    .cta-pages .container .item {
        padding-bottom: 60%
    }
}

@media screen and (max-width: 800px) {
    .cta-pages .container .item {
        border-radius: 0 20px 20px 0;
        padding-bottom: 120%
    }
}

.cta-pages .container .item>a {
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 3
}

@media (hover:hover) and (pointer:fine) {
    .cta-pages .container .item .top,
    .cta-pages .container .item .bottom {
        opacity: 0;
        transition: opacity .35s ease-in-out;
        -moz-transition: opacity .35s ease-in-out;
        -o-transition: opacity .35s ease-in-out;
        -webkit-transition: opacity .35s ease-in-out
    }
}

.cta-pages .container .item .top {
    left: 0;
    padding: 3vw;
    position: absolute;
    top: 0;
    z-index: 2
}

@media screen and (max-width: 1000px) {
    .cta-pages .container .item .top {
        padding: 6vw
    }
}

@media screen and (max-width: 800px) {
    .cta-pages .container .item .top {
        padding: 10vw
    }
}

.cta-pages .container .item .top h3 a {
    color: #fff;
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: 1.5rem
}

.cta-pages .container .item .top ul:after {
    clear: both;
    content: "";
    display: block
}

.cta-pages .container .item .top ul li {
    display: inline-block;
    font-size: .66rem;
    font-weight: bold
}

.cta-pages .container .item .top ul li+li:before {
    content: '• '
}

.cta-pages .container .item .bottom {
    bottom: 0;
    display: flex;
    left: 0;
    justify-content: space-between;
    padding: 3vw;
    position: absolute;
    transition-delay: .2s;
    width: 100%;
    z-index: 2
}

@media screen and (max-width: 1000px) {
    .cta-pages .container .item .bottom {
        padding: 6vw
    }
}

@media screen and (max-width: 800px) {
    .cta-pages .container .item .bottom {
        padding: 10vw
    }
}

.cta-pages .container .item .bottom span {
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: .722rem;
    letter-spacing: .2em;
    text-transform: uppercase
}

.cta-pages .container .item .bottom svg {
    height: 15px;
    position: relative;
    top: 1px;
    width: 54px
}

@media screen and (min-width: 800px) {
    .cta-pages .container .item .bottom svg {
        left: -100px
    }
}

@media screen and (max-width: 800px) {
    .cta-pages .container .item .bottom svg {
        right: 0
    }
}

@media (hover:none) {
    .cta-pages .container .item .bottom svg {
        left: 0
    }
}

@media (hover:hover) and (pointer:fine) {
    .cta-pages .container .item .bottom svg {
        transition: left .25s ease-in-out;
        -moz-transition: left .25s ease-out;
        -o-transition: left .25s ease-out;
        -webkit-transition: left .25s ease-out;
        transition-delay: .1s
    }
}

.cta-pages .container .item .bottom svg path {
    fill: #e6af79
}

.cta-pages .container .item .bg {
    background-color: #121730;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    height: 106%;
    left: 50%;
    position: absolute;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    transition: all .35s ease-in-out;
    -moz-transition: all .35s ease-in-out;
    -o-transition: all .35s ease-in-out;
    -webkit-transition: all .35s ease-in-out;
    width: 106%
}

.cta-pages .container .item .bg:before {
    background-color: #121730;
    content: '';
    height: 100%;
    left: 0;
    opacity: 0;
    position: absolute;
    top: 0;
    transition: opacity .35s ease-in-out;
    -moz-transition: opacity .35s ease-in-out;
    -o-transition: opacity .35s ease-in-out;
    -webkit-transition: opacity .35s ease-in-out;
    width: 100%
}

@media (hover:none) {
    .cta-pages .container .item .bg:before {
        opacity: .5
    }
}

@media screen and (max-width: 800px) {
    .cta-pages .container .item .bg:before {
        opacity: .5
    }
}

@media screen and (min-width: 800px) {
    .columns .container {
        display: grid;
        grid-auto-flow: column;
        grid-auto-columns: 1fr;
        gap: 5vw
    }
}

.columns .container:after {
    display: none
}

.columns .container .col {
    background-color: #fff;
    border-radius: 20px;
    -moz-border-radius: 20px;
    -webkit-border-radius: 20px;
    position: relative;
    overflow: hidden
}

.columns .container .col .img {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    padding-bottom: 60%;
    width: 100%
}

.columns .container .col .content {
    padding: 30px
}

.columns .container .col .content h2 {
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: 1.2rem
}

.content-faded {
    background-color: #fff;
    position: relative
}

@media screen and (min-width: 800px) {
    .content-faded {
        padding: 10vw 0
    }
}

@media screen and (max-width: 800px) {
    .content-faded {
        padding-bottom: 10vw
    }
}

@media screen and (min-width: 800px) {
    .content-faded.left .img {
        left: 0
    }
}

@media screen and (min-width: 800px) {
    .content-faded.left .content {
        padding-left: 54%
    }
}

@media screen and (min-width: 800px) {
    .content-faded.right .img {
        right: 0
    }
}

@media screen and (min-width: 800px) {
    .content-faded.right .content {
        padding-right: 54%
    }
}

.content-faded .img {
    position: absolute;
    overflow: hidden;
    top: 0;
    z-index: 1
}

@media screen and (min-width: 800px) {
    .content-faded .img {
        height: 100%;
        width: 60%
    }
}

@media screen and (max-width: 800px) {
    .content-faded .img {
        height: 50vh;
        left: 0;
        width: 100%
    }
}

.content-faded .img:before {
    background: linear-gradient(90deg, rgba(255, 255, 255, 0) 50%, #fff 95%);
    content: '';
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 2
}

@media screen and (max-width: 800px) {
    .content-faded .img:before {
        background: linear-gradient(0deg, rgba(255, 255, 255, 0) 60%, #fff 92%)
    }
}

.content-faded .img img {
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    position: relative;
    width: 100%;
    z-index: 1
}

.content-faded .content {
    position: relative;
    z-index: 3
}

@media screen and (max-width: 800px) {
    .content-faded .content {
        padding-top: 45vh
    }
}

.content-faded .content h1,
.content-faded .content h2,
.content-faded .content h3,
.content-faded .content p {
    max-width: 80ch
}

.content-faded .content a {
    color: #121730;
    text-decoration: underline;
    -webkit-text-decoration-color: #e6af79;
    text-decoration-color: #e6af79
}

.content-faded .content a:hover {
    color: #e6af79
}

@media screen and (min-width: 800px) {
    .content-img {
        display: flex;
        gap: 5vw
    }
}

@media screen and (min-width: 800px) {
    .content-img.right .img {
        order: 2
    }
}

@media screen and (min-width: 800px) {
    .content-img.right .content {
        order: 1
    }
}

.content-img .img {
    border-radius: 0 20px 20px 20px;
    -moz-border-radius: 0 20px 20px 20px;
    -webkit-border-radius: 0 20px 20px 20px;
    line-height: 0;
    overflow: hidden
}

@media screen and (min-width: 800px) {
    .content-img .img {
        width: calc(50% - 2.5vw);
        width: -webkit-calc(50% - 2.5vw)
    }
}

@media screen and (max-width: 800px) {
    .content-img .img {
        margin-bottom: 6vw
    }
}

@media screen and (min-width: 800px) {
    .content-img .img img {
        height: 100%;
        -o-object-fit: cover;
        object-fit: cover;
        width: 100%
    }
}

@media screen and (max-width: 800px) {
    .content-img .img img {
        height: auto;
        width: 100%
    }
}

@media screen and (min-width: 800px) {
    .content-img .content {
        align-self: center;
        width: calc(50% - 2.5vw);
        width: -webkit-calc(50% - 2.5vw)
    }
}

.content-img .content h1,
.content-img .content h2,
.content-img .content h3,
.content-img .content p {
    max-width: 80ch
}

.content-img .content a {
    color: #121730
}

.content-img .content a:not(.no-underline) {
    text-decoration: underline;
    -webkit-text-decoration-color: #e6af79;
    text-decoration-color: #e6af79
}

.content-img .content a:hover {
    color: #e6af79
}

@media screen and (min-width: 1001px) {
    .content-tabs {
        padding: 0 5vw
    }
}

@media screen and (min-width: 800px) {
    .content-tabs:not(.big-tabs) .tabs {
        display: flex;
        flex-direction: row-reverse;
        justify-content: space-between;
        padding-top: 5vw
    }
}

@media screen and (max-width: 800px) {
    .content-tabs:not(.big-tabs) .tabs {
        padding-top: 10vw
    }
}

.content-tabs:not(.big-tabs) .tabs ul.tab-titles {
    margin-top: 10px;
    width: 30%
}

@media screen and (max-width: 800px) {
    .content-tabs:not(.big-tabs) .tabs ul.tab-titles {
        display: none
    }
}

.content-tabs:not(.big-tabs) .tabs ul.tab-titles li a {
    border-top: 1px solid #121730;
    color: #121730;
    cursor: pointer;
    display: block;
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: 1.3rem;
    line-height: 1.2;
    margin-top: 1px;
    padding: 20px;
    transition: all .35s ease-in-out;
    -moz-transition: all .35s ease-in-out;
    -o-transition: all .35s ease-in-out;
    -webkit-transition: all .35s ease-in-out
}

@media (hover:hover) and (pointer:fine) {
    .content-tabs:not(.big-tabs) .tabs ul.tab-titles li a:hover {
        color: #e6af79
    }
}

.content-tabs:not(.big-tabs) .tabs ul.tab-titles li a.active {
    border-top-color: #e6af79;
    border-top-width: 2px;
    color: #e6af79;
    margin-top: 0
}

@media screen and (min-width: 800px) {
    .content-tabs:not(.big-tabs) .tabs .tab-content {
        width: 60%
    }
}

.content-tabs:not(.big-tabs) .tabs .tab-content a {
    color: #121730
}

.content-tabs:not(.big-tabs) .tabs .tab-content a:not(.no-underline) {
    text-decoration: underline;
    -webkit-text-decoration-color: #e6af79;
    text-decoration-color: #e6af79
}

.content-tabs:not(.big-tabs) .tabs .tab-content a:hover {
    color: #e6af79
}

.content-tabs:not(.big-tabs) .tabs .tab-content .tab-pane {
    display: none
}

@media screen and (max-width: 800px) {
    .content-tabs:not(.big-tabs) .tabs .tab-content .tab-pane {
        display: block
    }
    .content-tabs:not(.big-tabs) .tabs .tab-content .tab-pane+.tab-pane {
        border-top: 1px solid #e9e2dc;
        margin-top: 8vw;
        padding-top: 8vw
    }
}

.content-tabs:not(.big-tabs) .tabs .tab-content .tab-pane h2 {
    display: none;
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: 1.3rem;
    line-height: 1.2
}

@media screen and (max-width: 800px) {
    .content-tabs:not(.big-tabs) .tabs .tab-content .tab-pane h2 {
        display: block
    }
}

.content-tabs.big-tabs .tabs ul.tab-titles {
    display: flex;
    gap: 1px
}

@media screen and (min-width: 1001px) {
    .content-tabs.big-tabs .tabs ul.tab-titles {
        margin-bottom: 5vw
    }
}

@media screen and (max-width: 1000px) {
    .content-tabs.big-tabs .tabs ul.tab-titles {
        margin-bottom: 7vw
    }
}

@media screen and (max-width: 800px) {
    .content-tabs.big-tabs .tabs ul.tab-titles {
        display: none
    }
}

.content-tabs.big-tabs .tabs ul.tab-titles li {
    flex: 1
}

.content-tabs.big-tabs .tabs ul.tab-titles li a {
    border-top: 2px solid rgba(18, 23, 48, 0.5);
    background-color: rgba(18, 23, 48, 0.25);
    color: #fff;
    cursor: pointer;
    display: block;
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: 1.3rem;
    line-height: 1.2;
    margin-top: 1px;
    padding: 20px;
    text-align: center;
    transition: all .35s ease-in-out;
    -moz-transition: all .35s ease-in-out;
    -o-transition: all .35s ease-in-out;
    -webkit-transition: all .35s ease-in-out
}

.content-tabs.big-tabs .tabs ul.tab-titles li a:focus {
    text-decoration: none
}

@media (hover:hover) and (pointer:fine) {
    .content-tabs.big-tabs .tabs ul.tab-titles li a:hover:not(.active) {
        color: #121730
    }
}

.content-tabs.big-tabs .tabs ul.tab-titles li a.active {
    background-color: transparent;
    border-top-color: #e6af79;
    border-top-width: 2px;
    color: #e6af79;
    margin-top: 0
}

.content-tabs.big-tabs .tabs .tab-content a {
    color: #121730;
    transition: all .35s ease-in-out;
    -moz-transition: all .35s ease-in-out;
    -o-transition: all .35s ease-in-out;
    -webkit-transition: all .35s ease-in-out
}

.content-tabs.big-tabs .tabs .tab-content a:not(.no-underline) {
    text-decoration: underline;
    -webkit-text-decoration-color: #e6af79;
    text-decoration-color: #e6af79
}

@media (hover:hover) and (pointer:fine) {
    .content-tabs.big-tabs .tabs .tab-content a:hover {
        color: #e6af79
    }
}

.content-tabs.big-tabs .tabs .tab-content .tab-pane {
    display: none
}

@media screen and (max-width: 800px) {
    .content-tabs.big-tabs .tabs .tab-content .tab-pane {
        display: block
    }
    .content-tabs.big-tabs .tabs .tab-content .tab-pane+.tab-pane {
        border-top: 1px solid #e9e2dc;
        margin-top: 8vw;
        padding-top: 8vw
    }
}

.content-tabs.big-tabs .tabs .tab-content .tab-pane h2 {
    display: none;
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: .72rem;
    letter-spacing: .2em;
    margin-bottom: 2rem;
    text-transform: uppercase
}

@media screen and (max-width: 800px) {
    .content-tabs.big-tabs .tabs .tab-content .tab-pane h2 {
        display: block
    }
}

.content-tabs.big-tabs .tabs .tab-content .tab-pane>div {
    display: flex;
    gap: 5%
}

.content-tabs.big-tabs .tabs .tab-content .tab-pane>div+div {
    border-top: 1px solid #e3d9d1;
    margin-top: 2.5rem;
    padding-top: 2.5rem
}

@media screen and (max-width: 800px) {
    .content-tabs.big-tabs .tabs .tab-content .tab-pane>div {
        flex-wrap: wrap
    }
}

.content-tabs.big-tabs .tabs .tab-content .tab-pane>div .logo {
    width: 25%
}

@media screen and (max-width: 800px) {
    .content-tabs.big-tabs .tabs .tab-content .tab-pane>div .logo {
        padding-bottom: 5vw;
        width: 40%
    }
}

.content-tabs.big-tabs .tabs .tab-content .tab-pane>div .logo img {
    max-height: 70px;
    max-width: 200px
}

@media screen and (min-width: 800px) {
    .content-tabs.big-tabs .tabs .tab-content .tab-pane>div div:not(.logo) {
        width: 75%
    }
}

@media screen and (max-width: 800px) {
    .content-tabs.big-tabs .tabs .tab-content .tab-pane>div div:not(.logo) {
        width: 100%
    }
}

.faqs {
    border-radius: 20px;
    -moz-border-radius: 20px;
    -webkit-border-radius: 20px;
    margin: 15px;
    position: relative
}

.faqs .container {
    z-index: 2
}

@media screen and (min-width: 1001px) {
    .faqs .container .content {
        margin: auto;
        max-width: 1000px;
        padding: 5vw
    }
}

@media screen and (max-width: 1000px) {
    .faqs .container .content {
        padding: 10vw 0
    }
}

@media screen and (max-width: 800px) {
    .faqs .container .content {
        padding: 10vw 0
    }
}

.faqs .container .content .accordions {
    margin: 2rem 0 0
}

.features {
    position: relative
}

@media screen and (max-width: 800px) {
    .features {
        border-top: 1px solid rgba(255, 255, 255, 0.1);
        padding-top: 10vw
    }
}

.features .container {
    z-index: 2
}

@media screen and (min-width: 1001px) {
    .features .container .content {
        max-width: 100ch;
        padding: 10vw 5vw 5vw
    }
}

@media screen and (max-width: 1000px) {
    .features .container .content {
        padding: 10vw 0 5vw
    }
}

@media screen and (min-width: 1001px) {
    .features .container .content.no-media {
        padding: 10vw 5vw
    }
}

@media screen and (max-width: 1000px) {
    .features .container .content.no-media {
        padding: 10vw 0
    }
}

.features .container .content.video-only {
    position: relative;
    top: 5vw;
    z-index: 2
}

@media screen and (min-width: 1001px) {
    .features .container .content.video-only {
        padding: 5vw 5vw 0
    }
}

@media screen and (max-width: 1000px) {
    .features .container .content.video-only {
        padding: 8vw 0 0
    }
}

@media screen and (max-width: 800px) {
    .features .container .content {
        padding: 10vw 0
    }
}

.features .container .simple-gallery {
    display: grid;
    gap: 5vw;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding-top: 10vw
}

@media screen and (max-width: 800px) {
    .features .container .simple-gallery {
        gap: 10vw;
        grid-template-columns: repeat(1, minmax(0, 1fr))
    }
}

.features .container .simple-gallery figure .splide__arrows {
    bottom: calc(-1*(42px + 1.5rem));
    bottom: -webkit-calc(-1*(42px + 1.5rem));
    right: 0;
    position: absolute;
    z-index: 2
}

@media screen and (min-width: 1001px) {
    .features .container .simple-gallery figure .splide__arrows {
        padding: 0 15px
    }
}

.features .container .simple-gallery figure .splide__arrows .splide__arrow {
    background: transparent;
    border: none;
    cursor: pointer;
    height: 50px;
    transition: opacity .35s ease-in-out;
    -moz-transition: opacity .35s ease-in-out;
    -o-transition: opacity .35s ease-in-out;
    -webkit-transition: opacity .35s ease-in-out
}

.features .container .simple-gallery figure .splide__arrows .splide__arrow:disabled {
    opacity: .2
}

@media (hover:hover) and (pointer:fine) {
    .features .container .simple-gallery figure .splide__arrows .splide__arrow:hover svg {
        width: 35px
    }
    .features .container .simple-gallery figure .splide__arrows .splide__arrow:hover svg path {
        fill: #fff
    }
}

.features .container .simple-gallery figure .splide__arrows .splide__arrow svg {
    height: 12px;
    width: 25px
}

@media (hover:hover) and (pointer:fine) {
    .features .container .simple-gallery figure .splide__arrows .splide__arrow svg {
        transition: width .35s ease-in-out;
        -moz-transition: width .35s ease-in-out;
        -o-transition: width .35s ease-in-out;
        -webkit-transition: width .35s ease-in-out
    }
}

.features .container .simple-gallery figure .splide__arrows .splide__arrow svg path {
    fill: #e6af79
}

.features .container .simple-gallery figure .splide__track .splide__list .splide__slide {
    border-radius: 0 20px 20px 20px;
    -moz-border-radius: 0 20px 20px 20px;
    -webkit-border-radius: 0 20px 20px 20px;
    margin-right: 30px;
    overflow: hidden;
    position: relative
}

@media (hover:hover) and (pointer:fine) {
    .features .container .simple-gallery figure .splide__track .splide__list .splide__slide:hover>span {
        opacity: 0
    }
    .features .container .simple-gallery figure .splide__track .splide__list .splide__slide:hover>div {
        opacity: 1
    }
}

.features .container .simple-gallery figure .splide__track .splide__list .splide__slide>span {
    background-color: #e6af79;
    border-radius: 50%;
    color: #fff;
    font-family: Arial, Helvetica, sans-serif;
    font-size: .8rem;
    font-weight: bold;
    height: 30px;
    line-height: 30px;
    text-align: center;
    text-shadow: 0 0 5px rgba(0, 0, 0, 0.2);
    width: 30px
}

@media (hover:hover) and (pointer:fine) {
    .features .container .simple-gallery figure .splide__track .splide__list .splide__slide>span {
        bottom: 25px;
        left: 25px;
        position: absolute;
        transition: opacity .35s ease-in-out;
        -moz-transition: opacity .35s ease-in-out;
        -o-transition: opacity .35s ease-in-out;
        -webkit-transition: opacity .35s ease-in-out;
        z-index: 2
    }
}

@media (hover:none) or (pointer:coarse) {
    .features .container .simple-gallery figure .splide__track .splide__list .splide__slide>span {
        display: none
    }
}

.features .container .simple-gallery figure .splide__track .splide__list .splide__slide>div {
    bottom: 0;
    left: 0;
    padding: 25px;
    position: absolute;
    transition: opacity .35s ease-in-out;
    -moz-transition: opacity .35s ease-in-out;
    -o-transition: opacity .35s ease-in-out;
    -webkit-transition: opacity .35s ease-in-out;
    width: 100%;
    z-index: 2
}

@media (hover:hover) and (pointer:fine) {
    .features .container .simple-gallery figure .splide__track .splide__list .splide__slide>div {
        opacity: 0
    }
}

@media (hover:none) or (pointer:coarse) {
    .features .container .simple-gallery figure .splide__track .splide__list .splide__slide>div {
        opacity: 1
    }
}

@media screen and (max-width: 800px) {
    .features .container .simple-gallery figure .splide__track .splide__list .splide__slide>div {
        padding: 0
    }
}

.features .container .simple-gallery figure .splide__track .splide__list .splide__slide>div p {
    background-color: #121730;
    border-radius: 10px;
    font-size: .8rem;
    line-height: 1.5;
    padding: 4px 15px 5px
}

@media screen and (min-width: 800px) {
    .features .container .simple-gallery figure .splide__track .splide__list .splide__slide>div p {
        display: inline-flex
    }
}

@media screen and (max-width: 800px) {
    .features .container .simple-gallery figure .splide__track .splide__list .splide__slide>div p {
        background: rgba(18, 23, 48, 0.65);
        border-radius: 0 0 20px 20px;
        font-size: .7rem;
        padding: 12px 18px 15px
    }
}

.features .container .simple-gallery figure .splide__track .splide__list .splide__slide img {
    height: auto;
    position: relative;
    width: 100%;
    z-index: 1
}

.features .container .simple-gallery figure figcaption {
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    padding: 1.5rem 100px 1.5rem 0
}

.features .features-gallery {
    padding: 0 0 5vw 5vw
}

@media screen and (max-width: 800px) {
    .features .features-gallery {
        padding: 0 0 10vw 10vw
    }
}

.features .features-gallery * {
    cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='74px' height='30px' viewBox='0 0 90.27 35.16'%3E%3Cpath d='M0 0h84.55c3.16 0 5.73 2.57 5.73 5.73v29.44H5.73C2.57 35.17 0 32.6 0 29.44V0Z' style='fill:rgba(230,175,121,.8'/%3E%3Cpath d='M23.26 13.72h-4.17v8.18h4.53c3.46 0 4.77-1.47 4.77-4.09 0-2.31-1.29-4.09-5.14-4.09Zm.29 6.42h-2.06v-4.65h1.9c1.93 0 2.62 1.03 2.62 2.33 0 1.5-.7 2.32-2.46 2.32Zm18.61-3.99c0-1.47-.95-2.42-3.98-2.42h-5.15v8.18h2.39v-2.95h2.96c1.02 0 1.34.39 1.34 1.23v1.72h2.39v-1.72c0-.86-.14-1.77-1.43-2.06v-.02c1.13-.34 1.48-1.13 1.48-1.95Zm-3.87 1.42h-2.87v-2.08h2.66c1.38 0 1.82.42 1.82 1.01 0 .63-.42 1.07-1.6 1.07Zm12.74-3.84-4.45 8.18h2.46l.85-1.67h4.81l.85 1.67h2.77l-4.45-8.18h-2.83Zm-.45 5.12 1.69-3.33h.01l1.7 3.33h-3.41Zm16.32-1.17v1.27h2.64v.04c0 .58-.65 1.49-2.35 1.49-2 0-2.75-1.16-2.75-2.54 0-1.47.91-2.6 2.79-2.6s2.45.8 2.45 1.43v.09h2.13c.01-.09.01-.14.01-.17 0-1.53-1.08-3.11-4.66-3.11S62 15.57 62 17.93c0 2.15 1.31 4.13 4.8 4.13 2.04 0 3.02-.75 3.29-1.8h.02c0 .6-.01 1.29-.02 1.65h1.84v-4.23h-5.02Z' style='fill:%23121830'/%3E%3C/svg%3E"), grab
}

.features .features-gallery .splide__track .splide__list .splide__slide {
    position: relative
}

@media (hover:hover) and (pointer:fine) {
    .features .features-gallery .splide__track .splide__list .splide__slide:hover .img-group {
        border-radius: 20px;
        -moz-border-radius: 20px;
        -webkit-border-radius: 20px
    }
    .features .features-gallery .splide__track .splide__list .splide__slide:hover .img-group .img {
        opacity: .8;
        scale: 1.1
    }
    .features .features-gallery .splide__track .splide__list .splide__slide:hover .img-group .img span {
        opacity: 1
    }
}

.features .features-gallery .splide__track .splide__list .splide__slide .img-group {
    border-radius: 0 20px 20px 20px;
    -moz-border-radius: 0 20px 20px 20px;
    -webkit-border-radius: 0 20px 20px 20px;
    overflow: hidden;
    margin-bottom: 1rem;
    padding-bottom: 100%;
    position: relative;
    top: 0
}

@media (hover:hover) and (pointer:fine) {
    .features .features-gallery .splide__track .splide__list .splide__slide .img-group {
        transition: border-radius .25s ease-in-out;
        -moz-transition: border-radius .25s ease-out;
        -o-transition: border-radius .25s ease-out;
        -webkit-transition: border-radius .25s ease-out
    }
}

.features .features-gallery .splide__track .splide__list .splide__slide .img-group .img {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%
}

@media (hover:hover) and (pointer:fine) {
    .features .features-gallery .splide__track .splide__list .splide__slide .img-group .img {
        transition: scale .25s ease-in-out, opacity .25s ease-in-out;
        -moz-transition: scale .25s ease-out, opacity .25s ease-in-out;
        -o-transition: scale .25s ease-out, opacity .25s ease-in-out;
        -webkit-transition: scale .25s ease-out, opacity .25s ease-in-out
    }
}

.features .features-gallery .splide__track .splide__list .splide__slide .img-group .img span {
    background-color: #121730;
    border-radius: 25px;
    -moz-border-radius: 25px;
    -webkit-border-radius: 25px;
    height: 50px;
    left: 50%;
    line-height: 50px;
    opacity: 0;
    position: absolute;
    text-align: center;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    top: 50%;
    width: 50px
}

@media (hover:hover) and (pointer:fine) {
    .features .features-gallery .splide__track .splide__list .splide__slide .img-group .img span {
        transition: opacity .35s ease-in-out;
        -moz-transition: opacity .35s ease-in-out;
        -o-transition: opacity .35s ease-in-out;
        -webkit-transition: opacity .35s ease-in-out
    }
}

.features .features-gallery .splide__track .splide__list .splide__slide .img-group .img span svg {
    height: 20px;
    width: 35px
}

.features .features-gallery .splide__track .splide__list .splide__slide .img-group .img span svg path {
    fill: #fff
}

.features .features-gallery .splide__track .splide__list .splide__slide h2 {
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal
}

@media screen and (max-width: 800px) {
    .features .features-gallery .splide__track .splide__list .splide__slide h2 {
        font-size: .85rem
    }
}

.features #video-fade {
    height: 80vh;
    position: relative;
    width: 100%;
    z-index: 1
}

.features #video-fade:before {
    background: linear-gradient(180deg, #121730 0%, rgba(18, 23, 48, 0) 60%);
    content: '';
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 2
}

.features #video-fade .video-bg {
    z-index: 1
}

#page-project .lity-container .lity-close {
    margin: 0;
    top: 0
}

.lity-container .lity-close {
    background-color: #121730;
    border-radius: 4px;
    -moz-border-radius: 4px;
    -webkit-border-radius: 4px;
    margin: 40px 20px 20px;
    position: absolute;
    right: 10vw;
    top: 5vw
}

.lity-container .popup .container {
    color: #fff;
    min-width: 70vw;
    padding: 0 10vw
}

.lity-container .popup .container .img {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    border-radius: 20px;
    -moz-border-radius: 20px;
    -webkit-border-radius: 20px;
    margin-bottom: 2rem;
    padding-bottom: clamp(300px, 50%, 50vh)
}

.lity-container .popup .container h3 {
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: 1.5rem;
    margin-bottom: 1rem
}

@media screen and (max-width: 800px) {
    .lity-container .popup .container p {
        font-size: .8rem
    }
}

@media screen and (max-width: 800px) {
    .lity-container .popup p {
        font-size: .8rem
    }
}

.lity-container .popup p a {
    color: #cacfe4;
    font-family: "roc-grotesk", sans-serif;
    font-weight: 600;
    font-style: normal
}

@media (hover:hover) and (pointer:fine) {
    .lity-container .popup p a {
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out;
        text-decoration: underline;
        -webkit-text-decoration-color: #e6af79;
        text-decoration-color: #e6af79
    }
    .lity-container .popup p a:hover {
        color: #e6af79;
        -webkit-text-decoration-color: #e9e2dc;
        text-decoration-color: #e9e2dc
    }
}

#hero-full {
    background-color: #121730;
    margin-bottom: 5vw;
    position: relative
}

#hero-full #hero-full-top {
    position: relative;
    z-index: 1
}

#hero-full #hero-full-top .container {
    position: relative;
    z-index: 2
}

@media screen and (min-width: 1001px) {
    #hero-full #hero-full-top .container {
        padding: 60vh 45vw 20vw 10vw
    }
}

@media screen and (max-width: 1000px) {
    #hero-full #hero-full-top .container {
        padding: 70vh 10vw 10vw
    }
}

@media screen and (max-width: 800px) {
    #hero-full #hero-full-top .container {
        padding: 65vh 10vw 20vw
    }
}

#hero-full #hero-full-top .container p {
    color: #fff;
    font-size: 1.2rem;
    margin-top: 2rem
}

@media screen and (max-width: 1000px) {
    #hero-full #hero-full-top .container p {
        font-size: 1rem
    }
}

@media screen and (max-width: 800px) {
    #hero-full #hero-full-top .container p {
        font-size: .9rem
    }
}

#hero-full #hero-full-top #hero-fade {
    height: calc(100% + 10vw);
    height: -webkit-calc(100% + 10vw);
    left: 0;
    opacity: .5;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1
}

#hero-full #hero-full-top #hero-fade:before {
    background: linear-gradient(0deg, #121730 0%, rgba(18, 23, 48, 0) 60%);
    content: '';
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 2
}

@media screen and (min-width: 800px) {
    #hero-full #hero-full-top #hero-fade.img {
        padding: 15px
    }
    #hero-full #hero-full-top #hero-fade.video {
        border-top: 15px solid #121730;
        border-right: 15px solid #121730;
        border-left: 15px solid #121730
    }
}

#hero-full #hero-full-top #hero-fade.img>div {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    position: absolute
}

@media screen and (min-width: 800px) {
    #hero-full #hero-full-top #hero-fade.img>div {
        height: calc(100% - 30px);
        height: -webkit-calc(100% - 30px);
        left: 15px;
        top: 15px;
        width: calc(100% - 30px);
        width: -webkit-calc(100% - 30px)
    }
}

@media screen and (max-width: 800px) {
    #hero-full #hero-full-top #hero-fade.img>div {
        left: 0;
        height: 100%;
        top: 0;
        width: 100%
    }
}

.intro-group .container .card-gallery {
    cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='74px' height='30px' viewBox='0 0 90.27 35.16'%3E%3Cpath d='M0 0h84.55c3.16 0 5.73 2.57 5.73 5.73v29.44H5.73C2.57 35.17 0 32.6 0 29.44V0Z' style='fill:rgba(230,175,121,.8'/%3E%3Cpath d='M23.26 13.72h-4.17v8.18h4.53c3.46 0 4.77-1.47 4.77-4.09 0-2.31-1.29-4.09-5.14-4.09Zm.29 6.42h-2.06v-4.65h1.9c1.93 0 2.62 1.03 2.62 2.33 0 1.5-.7 2.32-2.46 2.32Zm18.61-3.99c0-1.47-.95-2.42-3.98-2.42h-5.15v8.18h2.39v-2.95h2.96c1.02 0 1.34.39 1.34 1.23v1.72h2.39v-1.72c0-.86-.14-1.77-1.43-2.06v-.02c1.13-.34 1.48-1.13 1.48-1.95Zm-3.87 1.42h-2.87v-2.08h2.66c1.38 0 1.82.42 1.82 1.01 0 .63-.42 1.07-1.6 1.07Zm12.74-3.84-4.45 8.18h2.46l.85-1.67h4.81l.85 1.67h2.77l-4.45-8.18h-2.83Zm-.45 5.12 1.69-3.33h.01l1.7 3.33h-3.41Zm16.32-1.17v1.27h2.64v.04c0 .58-.65 1.49-2.35 1.49-2 0-2.75-1.16-2.75-2.54 0-1.47.91-2.6 2.79-2.6s2.45.8 2.45 1.43v.09h2.13c.01-.09.01-.14.01-.17 0-1.53-1.08-3.11-4.66-3.11S62 15.57 62 17.93c0 2.15 1.31 4.13 4.8 4.13 2.04 0 3.02-.75 3.29-1.8h.02c0 .6-.01 1.29-.02 1.65h1.84v-4.23h-5.02Z' style='fill:%23121830'/%3E%3C/svg%3E"), grab;
    border-radius: 20px;
    -moz-border-radius: 20px;
    -webkit-border-radius: 20px;
    top: -5vw;
    z-index: 2
}

@media screen and (min-width: 1001px) {
    .intro-group .container .card-gallery {
        height: 100%;
        overflow: hidden;
        position: absolute;
        right: 10vw;
        width: 30vw
    }
}

@media screen and (max-width: 1000px) {
    .intro-group .container .card-gallery {
        height: 300px;
        width: 80vw
    }
}

.intro-group .container .card-gallery ul li {
    border-radius: 20px;
    -moz-border-radius: 20px;
    -webkit-border-radius: 20px;
    overflow: hidden
}

.intro-group .container .content {
    position: relative;
    z-index: 1
}

@media screen and (min-width: 1001px) {
    .intro-group .container .content {
        padding: 10vw 40vw 10vw 5vw
    }
}

@media screen and (max-width: 1000px) {
    .intro-group .container .content {
        padding: 5vw 0 10vw
    }
}

@media screen and (min-width: 1001px) {
    .logomark {
        padding: 5vw
    }
}

@media screen and (max-width: 1000px) {
    .logomark {
        padding: 10vw 0
    }
}

@media screen and (min-width: 1100px) {
    .logomark .container .content {
        padding: 5vw 0 5vw 50%
    }
}

@media screen and (min-width: 1001px) and (max-width: 1100px) {
    .logomark .container .content {
        padding: 5vw 0 5vw 60%
    }
}

@media screen and (min-width: 800px) and (max-width: 1000px) {
    .logomark .container .content {
        padding: 0 0 0 40%
    }
}

@media screen and (min-width: 1100px) {
    .logomark .container .mask {
        width: 35%
    }
}

@media screen and (min-width: 1001px) and (max-width: 1100px) {
    .logomark .container .mask {
        width: 40%
    }
}

@media screen and (min-width: 1001px) {
    .logomark .container .mask {
        left: 5vw
    }
}

@media screen and (min-width: 800px) and (max-width: 1000px) {
    .logomark .container .mask {
        left: 10vw;
        width: 25%
    }
}

@media screen and (min-width: 800px) {
    .logomark .container .mask {
        height: 100%;
        position: absolute;
        top: 0
    }
}

@media screen and (max-width: 800px) {
    .logomark .container .mask {
        display: none
    }
}

.logomark .container .mask img {
    -webkit-clip-path: url(#logomark);
    clip-path: url(#logomark);
    -o-object-fit: cover;
    object-fit: cover
}

.media-images {
    padding: 5vw
}

@media screen and (max-width: 1000px) {
    .media-images {
        padding: 10vw
    }
}

.media-images.padding-top-no {
    padding-top: 0
}

.media-images.padding-bottom-no {
    padding-bottom: 0
}

.media-images img {
    border-radius: 20px;
    -moz-border-radius: 20px;
    -webkit-border-radius: 20px;
    max-width: 100%
}

.media-images .row+.row {
    padding-top: 5vw
}

@media screen and (min-width: 800px) {
    .media-images .row .two-col {
        display: flex
    }
}

@media screen and (min-width: 800px) {
    .media-images .row .two-col .col {
        width: calc(50% - 2.5vw);
        width: -webkit-calc(50% - 2.5vw)
    }
    .media-images .row .two-col .col+.col {
        margin-left: 5vw
    }
}

@media screen and (max-width: 800px) {
    .media-images .row .two-col .col+.col {
        margin-top: 5vw
    }
}

.media-video {
    padding: 5vw
}

@media screen and (max-width: 1000px) {
    .media-video {
        padding: 10vw
    }
}

.media-video.padding-top-no {
    padding-top: 0
}

.media-video.padding-bottom-no {
    padding-bottom: 0
}

.media-video .video {
    border-radius: 20px;
    -moz-border-radius: 20px;
    -webkit-border-radius: 20px;
    height: 80vh;
    overflow: hidden;
    position: relative
}

#page-title p {
    max-width: 740px
}

#small-cta {
    padding-bottom: 5vw
}

#small-cta.p-top {
    padding-top: 5vw
}

@media screen and (max-width: 1000px) {
    #small-cta.p-top {
        padding-top: 10vw
    }
}

@media screen and (min-width: 800px) {
    #small-cta.core .container .flex {
        margin-right: 0;
        margin-left: 0
    }
}

@media screen and (max-width: 1000px) {
    #small-cta {
        padding-bottom: 10vw
    }
}

@media screen and (max-width: 800px) {
    #small-cta .container {
        padding: 0 15px
    }
}

#small-cta .container .flex {
    align-items: center;
    background-color: #121730;
    border-radius: 20px;
    -moz-border-radius: 20px;
    -webkit-border-radius: 20px;
    padding: 3vw 5vw
}

@media screen and (max-width: 1000px) {
    #small-cta .container .flex {
        padding: 5vw 8vw
    }
}

@media screen and (min-width: 800px) {
    #small-cta .container .flex {
        display: flex;
        justify-content: space-between;
        margin-right: -15px;
        margin-left: -15px
    }
}

@media screen and (max-width: 800px) {
    #small-cta .container .flex {
        padding-top: 10vw;
        padding-right: 10vw;
        padding-bottom: 10vw;
        padding-left: calc(10vw + 15px);
        padding-left: -webkit-calc(10vw + 15px)
    }
}

#small-cta .container .flex>div h3 {
    color: #fff
}

@media screen and (min-width: 800px) {
    #small-cta .container .flex>div h3 {
        margin-bottom: 0
    }
}

@media screen and (max-width: 800px) {
    #small-cta .container .flex>div h3 {
        margin-bottom: 1rem
    }
}

#small-cta .container .flex ul.btns li {
    margin: 0
}

.support-group {
    position: relative
}

.support-group .container {
    z-index: 2
}

@media screen and (min-width: 1001px) {
    .support-group .container .content {
        max-width: 100ch;
        padding: 10vw 5vw 5vw
    }
}

@media screen and (max-width: 1000px) {
    .support-group .container .content {
        padding: 10vw 0 5vw
    }
}

@media screen and (min-width: 1001px) {
    .support-group .container .content.no-media {
        padding: 10vw 5vw
    }
}

@media screen and (max-width: 1000px) {
    .support-group .container .content.no-media {
        padding: 10vw 0
    }
}

@media screen and (min-width: 1001px) {
    .support-group .container .content.single {
        max-width: none;
        padding: 10vw 5vw
    }
}

@media screen and (max-width: 1000px) {
    .support-group .container .content.single {
        padding: 10vw 0
    }
}

.support-group .container .content.single .push-img {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    border-radius: 20px;
    -moz-border-radius: 20px;
    -webkit-border-radius: 20px
}

@media screen and (min-width: 1001px) {
    .support-group .container .content.single .push-img {
        height: calc(100% - 20vw);
        height: -webkit-calc(100% - 20vw);
        right: 5vw;
        position: absolute;
        top: 10vw;
        width: 30%
    }
}

@media screen and (max-width: 1000px) {
    .support-group .container .content.single .push-img {
        height: 40vh;
        margin-bottom: 5vw;
        position: relative;
        width: 100%
    }
}

@media screen and (max-width: 800px) {
    .support-group .container .content.single .push-img {
        margin-bottom: 10vw
    }
}

@media screen and (min-width: 1001px) {
    .support-group .container .content.single .push {
        margin-right: 40%
    }
}

@media screen and (max-width: 800px) {
    .support-group .container .content {
        padding: 10vw 0
    }
}

.support-group .featured {
    position: relative;
    z-index: 2
}

@media screen and (max-width: 800px) {
    .support-group .featured {
        padding-bottom: 5vw
    }
}

.support-group .featured:before {
    background-color: #121730;
    bottom: 0;
    content: '';
    height: 50%;
    left: 0;
    position: absolute;
    z-index: 1;
    width: 100%
}

.support-group .featured .splide__arrows {
    background-color: #121730;
    border-radius: 10px;
    -moz-border-radius: 10px;
    -webkit-border-radius: 10px;
    left: 10vw;
    padding: 0 15px;
    position: absolute;
    top: -25px;
    z-index: 2
}

@media screen and (max-width: 800px) {
    .support-group .featured .splide__arrows {
        margin-left: 15px
    }
}

.support-group .featured .splide__arrows .splide__arrow {
    background: transparent;
    border: none;
    cursor: pointer;
    height: 50px
}

@media (hover:hover) and (pointer:fine) {
    .support-group .featured .splide__arrows .splide__arrow:hover svg {
        width: 35px
    }
    .support-group .featured .splide__arrows .splide__arrow:hover svg path {
        fill: #fff
    }
}

.support-group .featured .splide__arrows .splide__arrow svg {
    height: 12px;
    width: 25px
}

@media (hover:hover) and (pointer:fine) {
    .support-group .featured .splide__arrows .splide__arrow svg {
        transition: width .35s ease-in-out;
        -moz-transition: width .35s ease-in-out;
        -o-transition: width .35s ease-in-out;
        -webkit-transition: width .35s ease-in-out
    }
}

.support-group .featured .splide__arrows .splide__arrow svg path {
    fill: #e6af79
}

.support-group .featured .splide__track {
    cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='74px' height='30px' viewBox='0 0 90.27 35.16'%3E%3Cpath d='M0 0h84.55c3.16 0 5.73 2.57 5.73 5.73v29.44H5.73C2.57 35.17 0 32.6 0 29.44V0Z' style='fill:rgba(230,175,121,.8'/%3E%3Cpath d='M23.26 13.72h-4.17v8.18h4.53c3.46 0 4.77-1.47 4.77-4.09 0-2.31-1.29-4.09-5.14-4.09Zm.29 6.42h-2.06v-4.65h1.9c1.93 0 2.62 1.03 2.62 2.33 0 1.5-.7 2.32-2.46 2.32Zm18.61-3.99c0-1.47-.95-2.42-3.98-2.42h-5.15v8.18h2.39v-2.95h2.96c1.02 0 1.34.39 1.34 1.23v1.72h2.39v-1.72c0-.86-.14-1.77-1.43-2.06v-.02c1.13-.34 1.48-1.13 1.48-1.95Zm-3.87 1.42h-2.87v-2.08h2.66c1.38 0 1.82.42 1.82 1.01 0 .63-.42 1.07-1.6 1.07Zm12.74-3.84-4.45 8.18h2.46l.85-1.67h4.81l.85 1.67h2.77l-4.45-8.18h-2.83Zm-.45 5.12 1.69-3.33h.01l1.7 3.33h-3.41Zm16.32-1.17v1.27h2.64v.04c0 .58-.65 1.49-2.35 1.49-2 0-2.75-1.16-2.75-2.54 0-1.47.91-2.6 2.79-2.6s2.45.8 2.45 1.43v.09h2.13c.01-.09.01-.14.01-.17 0-1.53-1.08-3.11-4.66-3.11S62 15.57 62 17.93c0 2.15 1.31 4.13 4.8 4.13 2.04 0 3.02-.75 3.29-1.8h.02c0 .6-.01 1.29-.02 1.65h1.84v-4.23h-5.02Z' style='fill:%23121830'/%3E%3C/svg%3E"), grab;
    position: relative;
    z-index: 1
}

.support-group .featured .splide__track ul.splide__list li.splide__slide {
    border-radius: 20px;
    -moz-border-radius: 20px;
    -webkit-border-radius: 20px;
    position: relative;
    width: 100%
}

.support-group .featured .splide__track ul.splide__list li.splide__slide.is-active .description {
    opacity: 1
}

.support-group .featured .splide__track ul.splide__list li.splide__slide .img {
    padding-bottom: 40%;
    position: relative;
    width: 100%;
    z-index: 2
}

@media screen and (max-width: 800px) {
    .support-group .featured .splide__track ul.splide__list li.splide__slide .img {
        padding-bottom: 80%
    }
}

.support-group .featured .splide__track ul.splide__list li.splide__slide .img:before {
    background-color: #121730;
    bottom: 0;
    content: '';
    height: 50%;
    left: 0;
    position: absolute;
    z-index: 1;
    width: 100vw
}

.support-group .featured .splide__track ul.splide__list li.splide__slide .img>div {
    border-radius: 20px;
    -moz-border-radius: 20px;
    -webkit-border-radius: 20px;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 2
}

.support-group .featured .splide__track ul.splide__list li.splide__slide .description {
    color: #fff;
    opacity: 0;
    padding: 2rem 5vw;
    position: relative;
    transition: opacity .35s ease-in-out;
    -moz-transition: opacity .35s ease-in-out;
    -o-transition: opacity .35s ease-in-out;
    -webkit-transition: opacity .35s ease-in-out;
    transition-delay: .5s;
    z-index: 2
}

.support-group .featured .splide__track ul.splide__list li.splide__slide .description p {
    padding-left: 40px;
    position: relative
}

@media screen and (max-width: 800px) {
    .support-group .featured .splide__track ul.splide__list li.splide__slide .description p {
        font-size: .8rem
    }
}

.support-group .featured .splide__track ul.splide__list li.splide__slide .description p span {
    height: 20px;
    left: 0;
    line-height: 0;
    overflow: hidden;
    position: absolute;
    top: 5px;
    width: 24px
}

.support-group .featured .splide__track ul.splide__list li.splide__slide .description p span svg {
    height: 20px;
    left: 0;
    position: relative;
    width: 100px
}

.support-group .featured .splide__track ul.splide__list li.splide__slide .description p span svg path {
    stroke: #e6af79
}

.support-group .bg {
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1
}

.testimonials {
    background-color: #fff;
    padding: 5vw;
    position: relative
}

@media screen and (min-width: 800px) {
    .testimonials {
        text-align: center
    }
}

@media screen and (max-width: 800px) {
    .testimonials {
        padding: 10vw 0
    }
}

.testimonials.gradient {
    background: linear-gradient(0deg, #fff 50%, rgba(255, 255, 255, 0) 100%)
}

.testimonials #quote,
.testimonials #quotes {
    margin: auto;
    max-width: 820px
}

.testimonials #quote figure,
.testimonials #quotes figure {
    padding: 5vw 0;
    position: relative;
    z-index: 1
}

@media screen and (max-width: 1000px) {
    .testimonials #quote figure,
    .testimonials #quotes figure {
        padding: 8vw 0
    }
}

.testimonials #quote figure blockquote,
.testimonials #quotes figure blockquote {
    font-family: "roc-grotesk", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1.25rem
}

@media screen and (max-width: 800px) {
    .testimonials #quote figure blockquote,
    .testimonials #quotes figure blockquote {
        font-size: 1.05rem
    }
}

.testimonials #quote figure blockquote figcaption,
.testimonials #quotes figure blockquote figcaption {
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: .72rem;
    letter-spacing: .2em;
    margin-top: 1rem;
    text-transform: uppercase
}

@media screen and (max-width: 800px) {
    .testimonials #quote figure blockquote figcaption,
    .testimonials #quotes figure blockquote figcaption {
        font-size: .6em
    }
}

.testimonials #quote .splide__arrows,
.testimonials #quotes .splide__arrows {
    background-color: #121730;
    border-radius: 10px;
    -moz-border-radius: 10px;
    -webkit-border-radius: 10px;
    display: inline-flex;
    padding: 0 15px
}

@media screen and (max-width: 800px) {
    .testimonials #quote .splide__arrows,
    .testimonials #quotes .splide__arrows {
        position: relative;
        top: -50px
    }
}

.testimonials #quote .splide__arrows .splide__arrow,
.testimonials #quotes .splide__arrows .splide__arrow {
    background: transparent;
    border: none;
    cursor: pointer;
    height: 50px
}

@media (hover:hover) and (pointer:fine) {
    .testimonials #quote .splide__arrows .splide__arrow:hover svg,
    .testimonials #quotes .splide__arrows .splide__arrow:hover svg {
        width: 35px
    }
    .testimonials #quote .splide__arrows .splide__arrow:hover svg path,
    .testimonials #quotes .splide__arrows .splide__arrow:hover svg path {
        fill: #fff
    }
}

.testimonials #quote .splide__arrows .splide__arrow svg,
.testimonials #quotes .splide__arrows .splide__arrow svg {
    height: 12px;
    width: 25px
}

@media (hover:hover) and (pointer:fine) {
    .testimonials #quote .splide__arrows .splide__arrow svg,
    .testimonials #quotes .splide__arrows .splide__arrow svg {
        transition: width .35s ease-in-out;
        -moz-transition: width .35s ease-in-out;
        -o-transition: width .35s ease-in-out;
        -webkit-transition: width .35s ease-in-out
    }
}

.testimonials #quote .splide__arrows .splide__arrow svg path,
.testimonials #quotes .splide__arrows .splide__arrow svg path {
    fill: #e6af79
}

.testimonials #quote .splide__track .splide__list .splide__slide,
.testimonials #quotes .splide__track .splide__list .splide__slide {
    position: relative
}

@media (hover:hover) and (pointer:fine) {
    .testimonials #quote .splide__track .splide__list .splide__slide:hover a.full-review,
    .testimonials #quotes .splide__track .splide__list .splide__slide:hover a.full-review {
        margin-top: 0;
        opacity: 1
    }
}

@media screen and (max-width: 800px) {
    .testimonials #quote .splide__track .splide__list .splide__slide,
    .testimonials #quotes .splide__track .splide__list .splide__slide {
        padding-bottom: 50px
    }
}

.testimonials #quote .splide__track .splide__list .splide__slide a.full-review,
.testimonials #quotes .splide__track .splide__list .splide__slide a.full-review {
    background-color: #e6af79;
    color: #121730;
    font-size: .6rem;
    font-family: "roc-grotesk-wide", sans-serif;
    font-weight: 600;
    font-style: normal;
    letter-spacing: .2em;
    position: absolute;
    text-transform: uppercase;
    z-index: 2
}

@media screen and (min-width: 1001px) {
    .testimonials #quote .splide__track .splide__list .splide__slide a.full-review,
    .testimonials #quotes .splide__track .splide__list .splide__slide a.full-review {
        transition: all .35s ease-in-out;
        -moz-transition: all .35s ease-in-out;
        -o-transition: all .35s ease-in-out;
        -webkit-transition: all .35s ease-in-out
    }
}

@media screen and (min-width: 800px) {
    .testimonials #quote .splide__track .splide__list .splide__slide a.full-review,
    .testimonials #quotes .splide__track .splide__list .splide__slide a.full-review {
        border-radius: 50px;
        display: flex;
        flex-wrap: wrap;
        height: 100px;
        left: 50%;
        line-height: 1.2;
        margin-top: 10px;
        opacity: 0;
        text-align: center;
        top: 50%;
        -webkit-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
        width: 100px
    }
}

@media screen and (max-width: 800px) {
    .testimonials #quote .splide__track .splide__list .splide__slide a.full-review,
    .testimonials #quotes .splide__track .splide__list .splide__slide a.full-review {
        align-items: center;
        border-radius: 10px;
        -moz-border-radius: 10px;
        -webkit-border-radius: 10px;
        bottom: 0;
        display: inline-flex;
        height: 50px;
        padding: 0 15px;
        right: 0
    }
}

.testimonials #quote .splide__track .splide__list .splide__slide a.full-review svg,
.testimonials #quotes .splide__track .splide__list .splide__slide a.full-review svg {
    height: 16px;
    width: 16px
}

@media screen and (min-width: 800px) {
    .testimonials #quote .splide__track .splide__list .splide__slide a.full-review svg,
    .testimonials #quotes .splide__track .splide__list .splide__slide a.full-review svg {
        display: block;
        margin: auto auto 5px
    }
}

@media screen and (max-width: 800px) {
    .testimonials #quote .splide__track .splide__list .splide__slide a.full-review svg,
    .testimonials #quotes .splide__track .splide__list .splide__slide a.full-review svg {
        padding-right: 5px
    }
}

.testimonials #quote .splide__track .splide__list .splide__slide a.full-review svg path,
.testimonials #quotes .splide__track .splide__list .splide__slide a.full-review svg path {
    fill: #fff
}

@media screen and (min-width: 800px) {
    .testimonials #quote .splide__track .splide__list .splide__slide a.full-review span,
    .testimonials #quotes .splide__track .splide__list .splide__slide a.full-review span {
        margin-bottom: 10px
    }
}

html,
body {
    background-color: #121730;
    color: #474747;
    font-family: "soleil", sans-serif;
    font-size: 18px;
    height: 100%;
    line-height: 1.8;
    scroll-behavior: smooth;
    width: 100%
}

html *,
body * {
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -webkit-box-sizing: border-box
}

#container {
    background-color: #f9f7f6;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    margin: auto;
    max-width: 2000px;
    position: relative;
    width: 100%
}

#container:after {
    clear: both;
    content: "";
    display: block
}

.container {
    position: relative
}

.container:after {
    clear: both;
    content: "";
    display: block
}

@media screen and (min-width: 1001px) {
    .container {
        padding: 0 5vw
    }
}

@media screen and (max-width: 1000px) {
    .container {
        padding: 0 10vw
    }
}

@media screen and (min-width: 800px) {
    .container .inner {
        margin-right: -15px;
        margin-left: -15px
    }
}

.container.max {
    margin: auto;
    max-width: 1600px
}

.container.flex:after {
    display: none
}

.container.dark-container {
    background-color: #121730;
    color: #fff
}

.container.dark-container.max {
    max-width: initial
}

.container.dark-container.basic {
    padding: 5vw 0
}

@media screen and (max-width: 1000px) {
    .container.dark-container.basic {
        padding: 10vw 0
    }
}

.bg-white {
    background-color: #fff
}

.bg-tan {
    background-color: #f9f7f6
}

.bg-tan a {
    color: #121730
}

@media (hover:hover) and (pointer:fine) {
    .bg-tan a:hover {
        color: #e6af79
    }
}

.bg-tan .para-large a span svg path {
    stroke: #e6af79
}

.bg-tan.pattern .pattern-bg {
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1
}

.bg-tan.pattern .pattern-bg svg {
    opacity: .75;
    z-index: 1
}

.bg-tan.pattern .pattern-bg svg path {
    stroke: #e2d9d1
}

.bg-tan.pattern .pattern-bg:before,
.bg-tan.pattern .pattern-bg:after {
    content: '';
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 2
}

.bg-tan.pattern .pattern-bg:before {
    background: linear-gradient(0deg, #f9f7f6 0%, rgba(249, 247, 246, 0) 60%)
}

.bg-tan.pattern .pattern-bg:after {
    background: linear-gradient(90deg, #f9f7f6 0%, rgba(249, 247, 246, 0) 60%)
}

.bg-blue {
    background-color: #121730;
    color: #fff
}

.bg-blue a {
    color: #cacfe4
}

@media (hover:hover) and (pointer:fine) {
    .bg-blue a:hover {
        color: #fff
    }
}

.bg-blue p:not(.para-large) a {
    text-decoration: underline;
    -webkit-text-decoration-color: #e6af79;
    text-decoration-color: #e6af79
}

.bg-blue .para-large a span svg path {
    stroke: #e6af79
}

.bg-brown {
    background-color: #e3d9d1
}

.bg-light-blue {
    background-color: #e4e7f6
}

.bg-light-blue.pattern .pattern-bg {
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1
}

.bg-light-blue.pattern .pattern-bg svg {
    z-index: 1
}

.bg-light-blue.pattern .pattern-bg:before,
.bg-light-blue.pattern .pattern-bg:after {
    content: '';
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 2
}

.bg-light-blue.pattern .pattern-bg:before {
    background: linear-gradient(0deg, #e4e7f6 0%, rgba(228, 231, 246, 0) 60%)
}

.bg-light-blue.pattern .pattern-bg:after {
    background: linear-gradient(90deg, #e4e7f6 0%, rgba(228, 231, 246, 0) 60%)
}

.m-top {
    margin-top: 5vw
}

@media screen and (max-width: 1000px) {
    .m-top {
        margin-top: 7vw
    }
}

@media screen and (max-width: 800px) {
    .m-top {
        margin-top: 10vw
    }
}