*,
:after,
:before {
    border: 0 solid;
    box-sizing: border-box
}

:after,
:before {
    --tw-content: ""
}

:host,
html {
    -webkit-text-size-adjust: 100%;
    font-feature-settings: normal;
    -webkit-tap-highlight-color: transparent;
    font-family: ui-sans-serif, system-ui, sans-serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol, Noto Color Emoji;
    font-variation-settings: normal;
    line-height: 1.5;
    -moz-tab-size: 4;
    -o-tab-size: 4;
    tab-size: 4
}

body {
    line-height: inherit;
    margin: 0
}

hr {
    border-top-width: 1px;
    color: inherit;
    height: 0
}

abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-size: inherit;
    font-weight: inherit
}

a {
    color: inherit;
    text-decoration: inherit
}

b,
strong {
    font-weight: 600
}

code,
kbd,
pre,
samp {
    font-feature-settings: normal;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, Liberation Mono, Courier New, monospace;
    font-size: 1em;
    font-variation-settings: normal
}

small {
    font-size: 80%
}

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

table {
    border-collapse: collapse;
    border-color: inherit;
    text-indent: 0
}

button,
input,
optgroup,
select,
textarea {
    font-feature-settings: inherit;
    color: inherit;
    font-family: inherit;
    font-size: 100%;
    font-variation-settings: inherit;
    font-weight: inherit;
    letter-spacing: inherit;
    line-height: inherit;
    margin: 0;
    padding: 0
}

button,
select {
    text-transform: none
}

button,
input:where([type=button]),
input:where([type=reset]),
input:where([type=submit]) {
    -webkit-appearance: button;
    background-color: transparent;
    background-image: none
}

:-moz-focusring {
    outline: auto
}

:-moz-ui-invalid {
    box-shadow: none
}

progress {
    vertical-align: baseline
}

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

summary {
    display: list-item
}

blockquote,
dd,
dl,
figure,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
p,
pre {
    margin: 0
}

fieldset {
    margin: 0
}

fieldset,
legend {
    padding: 0
}

menu,
ol,
ul {
    list-style: none;
    margin: 0;
    padding: 0
}

dialog {
    padding: 0
}

textarea {
    resize: vertical
}

input::-moz-placeholder,
textarea::-moz-placeholder {
    color: #9ca3af;
    opacity: 1
}

input::placeholder,
textarea::placeholder {
    color: #9ca3af;
    opacity: 1
}

[role=button],
button {
    cursor: pointer
}

:disabled {
    cursor: default
}

audio,
canvas,
embed,
iframe,
img,
object,
svg,
video {
    display: block;
    vertical-align: middle
}

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

[hidden] {
    display: none
}

* {
    -webkit-tap-highlight-color: transparent
}

div[style="width: 0; height: 0;"] {
    position: fixed;
    z-index: -9999
}

sup {
    font-size: 32%;
    left: -.5em;
    top: -1.5em
}

sub {
    bottom: 0;
    font-size: 30%;
    left: -.4em;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

html {
    font-size: 10px;
    margin-top: 0 !important
}

@media (min-width:1440px) {
    html {
        font-size: .6944444444444444vw
    }
}

body,
html {
    min-height: 100%;
   /* overscroll-behavior-y: none;*/
    width: 100%
}

button:focus {
    outline: none
}

body {
    -webkit-font-smoothing: antialiased;
    background-color: #fff;
    color: #000;
    font-family: "Aspekta", "Roboto Mono", arial, sans-serif;
    font-kerning: none;
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 1.25;
    margin-right: 0 !important
}

@media (min-width:1440px) {
    body {
        font-size: 1.35rem
    }
}

.custom-icon {
    font-style: normal
}

[style^="--aspect"] {
    aspect-ratio: var(--aspect)
}

main[tabindex="-1"] {
    outline: none
}

[data-lenis-prevent] {
    overscroll-behavior: contain
}

.is-animating,
.is-transitioning {
    cursor: progress !important;
    pointer-events: none !important
}

.h1,
.h2,
.h3,
.h4,
.h5,
.h6,
h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: 400;
    line-height: 1;
    margin-bottom: 3rem
}

.extra-heading {
    font-size: 4rem;
    letter-spacing: -.0125em;
    line-height: .9
}

@media (min-width:768px) {
    .extra-heading {
        font-size: 7rem
    }
}

@media (min-width:1280px) {
    .extra-heading {
        font-size: 12rem
    }
}

.secondary-heading {
    font-size: 4.8rem;
    letter-spacing: -.0125em;
    line-height: .9
}

@media (min-width:768px) {
    .secondary-heading {
        font-size: 3.2rem
    }
}

@media (min-width:1280px) {
    .secondary-heading {
        font-size: 5.2rem
    }
}

.h1,
h1 {
    font-size: 3rem;
    letter-spacing: -.0125em
}

@media (min-width:768px) {

    .h1,
    h1 {
        font-size: 4.2rem
    }
}

@media (min-width:1280px) {

    .h1,
    h1 {
        font-size: 5rem
    }
}

.h2,
h2 {
    font-size: 2.6rem;
    letter-spacing: -.0125em
}

@media (min-width:768px) {

    .h2,
    h2 {
        font-size: 3.6rem
    }
}

@media (min-width:1280px) {

    .h2,
    h2 {
        font-size: 4.6rem
    }
}

.h3,
h3 {
    font-size: 2rem;
    letter-spacing: -.0125em
}

@media (min-width:1280px) {

    .h3,
    h3 {
        font-size: 3.4rem
    }
}

.h4,
h4 {
    font-size: 1.6rem
}

@media (min-width:1280px) {

    .h4,
    h4 {
        font-size: 1.8rem
    }
}

.h5,
.h6,
h5,
h6 {
    font-size: 1.6rem
}

p {
    margin-bottom: 1.25em
}

.reset-last>:last-child {
    margin-bottom: 0
}

cite {
    display: block;
    font-style: normal
}

.multiline-outline-text a,
.multiline-outline-text a mark,
.wysiwyg a,
.wysiwyg a mark {
    text-decoration: underline
}

.multiline-outline-text a mark:hover,
.multiline-outline-text a:hover,
.wysiwyg a mark:hover,
.wysiwyg a:hover {
    text-decoration: none
}

.wysiwyg ol,
.wysiwyg p,
.wysiwyg ul {
    margin-bottom: 1em
}

.wysiwyg img {
    border-radius: 1rem;
    height: auto;
    width: 100%
}

.wysiwyg blockquote p:first-of-type:before {
    content: "“"
}

.wysiwyg blockquote p:last-of-type:after {
    content: "”"
}

.wysiwyg ol {
    list-style: none;
    margin-bottom: 1.25em
}

.wysiwyg ol:last-child {
    margin-bottom: 0
}

.wysiwyg ol li {
    display: block;
    margin-bottom: 1.5em;
    position: relative
}

.wysiwyg ol li:last-child {
    margin-bottom: 0
}

.wysiwyg ol li:before {
    display: block;
    margin-bottom: 1rem
}

@media (min-width:1024px) {
    .wysiwyg ol li:before {
        left: -33.33%;
        position: absolute;
        top: 0;
        width: 33.33%
    }
}

.wysiwyg ol ol {
    margin-top: 1.5rem
}

.wysiwyg ul {
    list-style: none
}

.wysiwyg ul>li {
    padding-left: 2rem;
    position: relative
}

.wysiwyg ul>li:before {
    background: currentColor;
    border: .2rem solid;
    border-radius: 50%;
    content: "";
    height: 1rem;
    left: 0;
    position: absolute;
    top: .25em;
    width: 1rem
}

.wysiwyg ul ol,
.wysiwyg ul ul {
    padding-top: 1em
}

.wysiwyg ul ul>li:before {
    background-color: transparent
}

.wysiwyg ul li {
    margin-bottom: 1em
}

.wysiwyg ul li:last-child {
    margin-bottom: 0
}

.group-hover\:scale-x-100,
.scale-105,
.scale-110,
.scale-x-0,
.scale-y-0,
.transform {
    --tw-translate-x: 0;
    --tw-translate-y: 0;
    --tw-rotate: 0;
    --tw-skew-x: 0;
    --tw-skew-y: 0;
    --tw-scale-x: 1;
    --tw-scale-y: 1
}

.filter,
.grayscale {
    --tw-blur: ;
    --tw-brightness: ;
    --tw-contrast: ;
    --tw-grayscale: ;
    --tw-hue-rotate: ;
    --tw-invert: ;
    --tw-saturate: ;
    --tw-sepia: ;
    --tw-drop-shadow:
}

html {
    box-sizing: border-box
}

*,
:after,
:before {
    box-sizing: inherit
}

@font-face {
  font-family:"Aspekta";
  src:url(../fonts/Aspekta-400.woff2) format("woff2");
  font-weight:400;
  font-style:normal;
  font-display:swap
}
@font-face {
  font-family:"Aspekta";
  src:url(../fonts/Aspekta-600.woff2) format("woff2");
  font-weight:600;
  font-style:normal;
  font-display:swap
}
@font-face {
  font-family:Roboto Mono;
  src:url(../fonts/RobotoMono-Regular.woff2) format("woff2");
  font-weight:400;
  font-style:normal;
  font-display:swap
}


input:-webkit-autofill,
input:-webkit-autofill:focus,
input:-webkit-autofill:hover,
select:-webkit-autofill,
select:-webkit-autofill:focus,
select:-webkit-autofill:hover,
textarea:-webkit-autofill,
textarea:-webkit-autofill:focus,
textarea:-webkit-autofill:hover {
    -webkit-text-fill-color: var(--theme-color) !important;
    -webkit-box-shadow: 0 0 0 20rem var(--theme-bg) inset !important
}

.bg-gray input:-webkit-autofill,
.bg-gray input:-webkit-autofill:focus,
.bg-gray input:-webkit-autofill:hover,
.bg-gray select:-webkit-autofill,
.bg-gray select:-webkit-autofill:focus,
.bg-gray select:-webkit-autofill:hover,
.bg-gray textarea:-webkit-autofill,
.bg-gray textarea:-webkit-autofill:focus,
.bg-gray textarea:-webkit-autofill:hover {
    -webkit-box-shadow: inset 0 0 0 20rem #f1f1f1 !important
}

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

.custom-inline-checkbox .checked-label {
    align-items: center;
    bottom: 0;
    display: flex;
    font-size: 1.2rem;
    opacity: 0;
    position: absolute;
    right: 0;
    top: 0;
    transition: opacity .35s cubic-bezier(.86, 0, .07, 1)
}

.custom-inline-checkbox input[type=checkbox]:checked~.checked-label {
    opacity: 1
}

.custom-inline-checkbox input[type=checkbox]:checked~.checked-label:after {
    content: "Selected"
}

.custom-inline-checkbox:hover .checked-label {
    opacity: 1
}

.custom-inline-checkbox:hover .checked-label:after {
    content: "Select"
}

:root {
    --header: 2.4rem;
    --grey: #92a6b0;
    --light: #b1c5ce;
    --dark: #22282a;
}

::-webkit-scrollbar {
    width: 0
}

body,
html {
    height: 100%;
    overflow: hidden;
    position: fixed
}

.is-changing {
    pointer-events: none !important
}

.theme-animating * {
    transition: none !important
}

[data-scroll-wrapper] {
    height: 100svh;
    overflow-x: hidden;
    overflow-y: auto
}

.lenis.lenis-smooth {
    scroll-behavior: auto
}

.lenis.lenis-smooth [data-lenis-prevent] {
    overscroll-behavior: contain
}

.lenis.lenis-stopped {
    overflow: hidden
}

.lenis.lenis-scrolling iframe {
    pointer-events: none
}

section.bg-orange:not(.ethos-first):first-child:after,
section.bg-orange:not(.ethos-first):first-child:before {
    background: #c44005;
    z-index: 3
}

section.bg-orange:not(.ethos-first):first-child:before {
    content: "";
    display: block;
    height: .1rem;
    margin-left: 3.4rem;
    position: sticky;
    right: 0;
    top: 0
}

section.bg-orange:not(.ethos-first):first-child:after {
    bottom: 0;
    content: "";
    left: 0;
    position: absolute;
    top: 3.4rem;
    width: .1rem
}

[data-component^=lazyload][data-animate] {
    -webkit-clip-path: polygon(0 100%, 100% 100%, 100% 100%, 0 100%);
    clip-path: polygon(0 100%, 100% 100%, 100% 100%, 0 100%);
    transition: -webkit-clip-path 1.3s cubic-bezier(.77, 0, .18, 1);
    transition: clip-path 1.3s cubic-bezier(.77, 0, .18, 1);
    transition: clip-path 1.3s cubic-bezier(.77, 0, .18, 1), -webkit-clip-path 1.3s cubic-bezier(.77, 0, .18, 1)
}

[data-component^=lazyload][data-animate][data-ll-status=loaded] {
    -webkit-clip-path: polygon(0 100%, 100% 100%, 100% 0, 0 0);
    clip-path: polygon(0 100%, 100% 100%, 100% 0, 0 0)
}

@keyframes link {
    0% {
        transform: scaleX(1);
        transform-origin: 100% 100%
    }

    49.9% {
        transform: scaleX(0);
        transform-origin: 100% 100%
    }

    50% {
        transform: scaleX(0);
        transform-origin: 0 0
    }

    to {
        transform: scaleX(1);
        transform-origin: 0 0
    }
}

.cursor {
    -webkit-clip-path: inset(0 100% 0 0);
    clip-path: inset(0 100% 0 0);
    display: none;
    left: 2rem;
    pointer-events: none;
    position: fixed;
    top: 0;
    transform: translate3d(calc(100vw*var(--cursor-x)), calc(100svh*var(--cursor-y)), 0);
    transition: opacity .15s cubic-bezier(.86, 0, .07, 1), color .15s cubic-bezier(.86, 0, .07, 1), -webkit-clip-path .15s cubic-bezier(.86, 0, .07, 1);
    transition: opacity .15s cubic-bezier(.86, 0, .07, 1), clip-path .15s cubic-bezier(.86, 0, .07, 1), color .15s cubic-bezier(.86, 0, .07, 1);
    transition: opacity .15s cubic-bezier(.86, 0, .07, 1), clip-path .15s cubic-bezier(.86, 0, .07, 1), color .15s cubic-bezier(.86, 0, .07, 1), -webkit-clip-path .15s cubic-bezier(.86, 0, .07, 1);
    z-index: 99
}

.cursor-active .cursor {
    -webkit-clip-path: inset(0 0 0 0);
    clip-path: inset(0 0 0 0);
    transition: opacity .3s cubic-bezier(.86, 0, .07, 1), -webkit-clip-path .6s cubic-bezier(.65, .05, .36, 1);
    transition: opacity .3s cubic-bezier(.86, 0, .07, 1), clip-path .6s cubic-bezier(.65, .05, .36, 1);
    transition: opacity .3s cubic-bezier(.86, 0, .07, 1), clip-path .6s cubic-bezier(.65, .05, .36, 1), -webkit-clip-path .6s cubic-bezier(.65, .05, .36, 1)
}

[cursor-theme=light] .cursor {
    color: var(--theme-bg)
}

.line-w {
    margin-bottom: -.15em;
    /*overflow: hidden;*/
    padding-bottom: .15em
}

.underline-multi span {
    background-image: linear-gradient(transparent calc(100% - .1em), currentColor .1em);
    background-repeat: no-repeat;
    background-size: 0 100%;
    transition: background-size .7s cubic-bezier(.86, 0, .07, 1);
    width: 100%
}

.no-touchevents .group:hover .underline-multi span,
.no-touchevents .underline-multi:hover span,
.underline-multi.is-active span {
    background-size: 100% 100%
}

.line {
    will-change: transform
}

.svgi {
    height: 1.4rem;
    -o-object-fit: contain;
    object-fit: contain;
    width: 1.4rem
}

mark {
    background: transparent;
    display: inline-block;
    position: relative;
    z-index: 2
}

mark:before {
    background: #fee09f;
    content: "";
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    transform: scaleY(0);
    transform-origin: bottom;
    transition: transform 1.2s cubic-bezier(.86, 0, .07, 1);
    width: 100%;
    z-index: -1
}

.is-complete mark:before,
.is-started mark:before {
    transform: none;
    transition-delay: .25s
}

mark.marker-blue:before {
    background: #F9B7D0
}
mark.marker-grey:before {
    background:#bcc5ff
}
mark.marker-yellow:before {
    background: #000000
}

.default-section+.default-section {
    border-top: .15rem solid
}

.multiline-outline-text {
    background-repeat: repeat-y;
    background-size: 100% 1.25em;
    overflow: hidden;
    padding-bottom: .2rem
}

.multiline-outline-text--white {
    background-image: linear-gradient(0deg, transparent, transparent calc(1.25em - .1rem), hsla(0, 0%, 100%, .2) 0, hsla(0, 0%, 100%, .2) 1.25em)
}

.multiline-outline-text .line-w {
    margin-bottom: 0;
    padding-bottom: 0
}

.portfolio-row {
    transition: color .2s cubic-bezier(.215, .61, .355, 1)
}

.portfolio-row:nth-last-child(7)~.portfolio-row .portfolio-row__image {
    bottom: 0;
    top: auto
}

.portfolio-row__container:before {
    background: #000000;
    bottom: 0;
    content: "";
    height: 100%;
    left: 0;
    position: absolute;
    transform: scaleY(0);
    transform-origin: bottom;
    transition: transform .2s cubic-bezier(.215, .61, .355, 1);
    width: 100%;
    z-index: -1
}

.portfolio-row__image {
    -webkit-clip-path: polygon(0 100%, 0 100%, 0 0, 0 0);
    clip-path: polygon(0 100%, 0 100%, 0 0, 0 0);
    transition: -webkit-clip-path .3s cubic-bezier(.86, 0, .07, 1);
    transition: clip-path .3s cubic-bezier(.86, 0, .07, 1);
    transition: clip-path .3s cubic-bezier(.86, 0, .07, 1), -webkit-clip-path .3s cubic-bezier(.86, 0, .07, 1)
}

.portfolio-row__image.is-active {
    -webkit-clip-path: polygon(100% 100%, 0 100%, 0 0, 100% 0);
    clip-path: polygon(100% 100%, 0 100%, 0 0, 100% 0);
    transition-delay: .15s
}

.testimonials__overlay {
    transition: transform 1.2s cubic-bezier(.86, 0, .07, 1)
}

.is-started .testimonials__overlay {
    transform: translate(1.2rem, 1.2rem)
}

.team-member__overlay {
    transition: transform 1.2s cubic-bezier(.86, 0, .07, 1)
}

.is-started .team-member__overlay {
    transform: translate(1.2rem, 1.2rem)
}

[data-page-overlay] {
    background: #22282a;
    bottom: 0;
    -webkit-clip-path: polygon(0 0, 0 0, 0 0, 0 0);
    clip-path: polygon(0 0, 0 0, 0 0, 0 0);
    left: 2.4rem;
    pointer-events: none;
    position: fixed;
    right: 0;
    top: 2.4rem;
    z-index: 30
}

.preloader-complete [data-page-overlay] {
    -webkit-clip-path: polygon(0 0, 0 2.4rem, 2.4rem 2.4rem, 2.4rem 0);
    clip-path: polygon(0 0, 0 2.4rem, 2.4rem 2.4rem, 2.4rem 0)
}

.is-transitioning [data-page-overlay] {
    pointer-events: all
}

.section-images-stack {
    --offset: 2.4rem;
    height: calc(var(--count)*100svh)
}

.section-images-stack img {
    -o-object-position: 90% 80%;
    object-position: 90% 80%
}

.stack-panels__panel {
    min-height: 42rem;
    position: sticky
}

.stack-panels__panel:first-child {
    background: #92a6b0;
    top: 2.4rem
}

.stack-panels__panel:nth-child(2) {
    background: #b1c5ce;
    margin-right: 1.2rem;
    top: 6.4rem
}

.stack-panels__panel:nth-child(2) .stack-panel__content {
    margin-right: -2.4rem;
    padding-right: 2.4rem
}

.stack-panels__panel:nth-child(3) {
    background: #22282a;
    margin-right: 2.4rem;
    top: 10.4rem
}

.stack-panels__panel:nth-child(3) .stack-panel__content {
    margin-right: -3.6rem;
    padding-right: 3.6rem
}
.stack-panels__panel:nth-child(4) {
    background: #22282a;
    margin-right: 3.6rem;
    top: 10.4rem
}
.text-decorated {
    font-size: 2rem
}

.text-decorated .svgi {
    display: inline-block;
    height: .75em;
    vertical-align: -.05em;
    width: .75em
}

.text-decorated .line-w {
    margin-right: -.1em;
    padding-right: .1em
}

.text-decorated .line {
    display: flex !important
}

.text-decorated .line>:last-child {
    flex-grow: 1
}

[data-animation=tech-stack] [data-block] {
    transition: background-color .3s cubic-bezier(.65, .05, .36, 1)
}

[data-animation=tech-stack] [data-block].is--active {
    background-color: #f1f1f1
}

[data-animation=tech-stack] .stack-block {
    margin-bottom: -.1rem
}

[data-animation=tech-stack] [data-stack] g.is--active [data-hover-target] {
    fill: #b1c5ce
}

[data-animation=tech-stack] [data-stack] g.is--active [data-hover-background] {
    fill: #fff
}

[data-animation=tech-stack] [data-hover-background] {
    fill: transparent;
    transition: fill .3s cubic-bezier(.65, .05, .36, 1)
}

[data-animation=tech-stack] [data-hover-target] {
    fill: #fff;
    transition: fill .3s cubic-bezier(.65, .05, .36, 1)
}

.no-touchevents [data-accordion-opener]:hover .svgi {
    transform: rotate(90deg)
}

[data-accordion-opener] .svgi {
    height: 1.4rem;
    transition: transform .35s cubic-bezier(.86, 0, .07, 1);
    width: 1.4rem
}

.is-active [data-accordion-opener] .svgi {
    transform: rotate(45deg) !important
}

[data-accordion-content] {
    height: 0;
    overflow: hidden
}

.intro-heading .line-w:first-child {
    text-indent: -.08em
}

.intro-heading .line-w:nth-child(2) {
    text-indent: -.045em
}

[data-transitions-container] {
    position: relative
}

[data-transitions-container]:after {
    background: rgba(0, 0, 0, .3);
    content: "";
    height: 100vh;
    left: 0;
    opacity: 0;
    pointer-events: none;
    position: fixed;
    top: 0;
    transition: opacity .6s cubic-bezier(.65, .05, .36, 1);
    width: 100%
}

.is-animating.is-changing [data-transitions-container]:after,
.menu--opened [data-transitions-container]:after {
    opacity: 1
}

.sr-only {
    clip: rect(0, 0, 0, 0);
    border-width: 0;
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    white-space: nowrap;
    width: 1px
}

.pointer-events-none {
    pointer-events: none
}

.\!pointer-events-auto {
    pointer-events: auto !important
}

.visible {
    visibility: visible
}

.fixed {
    position: fixed
}

.absolute {
    position: absolute
}

.relative {
    position: relative
}

.sticky {
    position: sticky
}

.\!-left-20 {
    left: -2rem !important
}

.\!-right-20 {
    right: -2rem !important
}

.\!left-12 {
    left: 1.2rem !important
}

.-bottom-20 {
    bottom: -2rem
}

.-left-12 {
    left: -1.2rem
}

.bottom-0 {
    bottom: 0
}

.bottom-350 {
    bottom: 35rem
}

.bottom-\[0\.15em\] {
    bottom: .15em
}

.bottom-full {
    bottom: 100%
}

.left-0 {
    left: 0
}

.left-1\/2 {
    left: 50%
}

.left-12 {
    left: 1.2rem
}

.left-140 {
    left: 14rem
}

.left-24 {
    left: 2.4rem
}

.left-\[3\.4rem\] {
    left: 3.4rem
}

.right-0 {
    right: 0
}

.right-12 {
    right: 1.2rem
}

.right-20 {
    right: 2rem
}

.top-0 {
    top: 0
}

.top-1\/2 {
    top: 50%
}

.top-12 {
    top: 1.2rem
}

.top-20 {
    top: 2rem
}

.top-24 {
    top: 2.4rem
}

.top-\[0\.15em\] {
    top: .15em
}

.top-\[3\.4rem\] {
    top: 3.4rem
}

.-z-1 {
    z-index: -1
}

.-z-2 {
    z-index: -2
}

.-z-3 {
    z-index: -3
}

.z-0 {
    z-index: 0
}

.z-1 {
    z-index: 1
}

.z-10 {
    z-index: 10
}

.z-2 {
    z-index: 2
}

.z-20 {
    z-index: 20
}

.z-3 {
    z-index: 3
}

.z-50 {
    z-index: 50
}

.z-\[16\] {
    z-index: 16
}

.z-\[20\] {
    z-index: 20
}

.z-\[48\] {
    z-index: 48
}

.order-last {
    order: 9999
}

.\!m-0 {
    margin: 0 !important
}

.mx-2 {
    margin-left: .2rem;
    margin-right: .2rem
}

.mx-5 {
    margin-left: .5rem;
    margin-right: .5rem
}

.mx-auto {
    margin-left: auto;
    margin-right: auto
}

.my-60 {
    margin-bottom: 6rem;
    margin-top: 6rem
}

.-mb-120 {
    margin-bottom: -12rem
}

.-ml-12 {
    margin-left: -1.2rem
}
.-mr-12 {
    margin-right: -1.2rem
}
.-ml-20 {
    margin-left: -2rem
}
.-mr-20 {
    margin-right: -2rem
}
.-mt-available {
    margin-top: calc(100svh*-1 - var(--header)*-1)
}

.mb-0 {
    margin-bottom: 0
}

.mb-10 {
    margin-bottom: 1rem
}

.mb-12 {
    margin-bottom: 1.2rem
}

.mb-120 {
    margin-bottom: 12rem
}

.mb-15 {
    margin-bottom: 1.5rem
}

.mb-20 {
    margin-bottom: 2rem
}

.mb-25 {
    margin-bottom: 2.5rem
}

.mb-3 {
    margin-bottom: .3rem
}

.mb-30 {
    margin-bottom: 3rem
}

.mb-45 {
    margin-bottom: 4.5rem
}

.mb-5 {
    margin-bottom: .5rem
}

.mb-50 {
    margin-bottom: 5rem
}

.mb-60 {
    margin-bottom: 6rem
}

.mb-80 {
    margin-bottom: 8rem
}

.ml-20 {
    margin-left: 2rem
}

.ml-8 {
    margin-left: .8rem
}

.ml-auto {
    margin-left: auto
}

.mr-10 {
    margin-right: 1rem
}

.mr-8 {
    margin-right: .8rem
}

.mt-10 {
    margin-top: 1rem
}

.mt-20 {
    margin-top: 2rem
}

.mt-25 {
    margin-top: 2.5rem
}

.mt-30 {
    margin-top: 3rem
}

.mt-40 {
    margin-top: 4rem
}

.mt-60 {
    margin-top: 6rem
}
.mt-100 {
    margin-top: 10rem
}

.mt-auto {
    margin-top: auto
}

.\!block {
    display: block !important
}

.block {
    display: block
}

.inline-block {
    display: inline-block
}

.flex {
    display: flex
}

.inline-flex {
    display: inline-flex
}

.grid {
    display: grid
}

.\!hidden {
    display: none !important
}

.hidden {
    display: none
}

.aspect-\[260\/210\] {
    aspect-ratio: 260/210
}

.aspect-\[493\/395\] {
    aspect-ratio: 493/395
}

.aspect-\[670\/400\] {
    aspect-ratio: 670/400
}

.aspect-square {
    aspect-ratio: 1/1
}

.aspect-video {
    aspect-ratio: 16/9
}

.\!h-14 {
    height: 1.4rem !important
}

.\!h-50 {
    height: 5rem !important
}

.\!h-auto {
    height: auto !important
}

.\!h-full {
    height: 100% !important
}

.h-1 {
    height: .1rem
}

.h-10 {
    height: 1rem
}

.h-12 {
    height: 1.2rem
}

.h-120 {
    height: 12rem
}

.h-130 {
    height: 13rem
}

.h-24 {
    height: 2.4rem
}

.h-35 {
    height: 3.5rem
}

.h-6 {
    height: .6rem
}

.h-7 {
    height: .7rem
}

.h-\[25vw\] {
    height: 25vw
}

.h-\[30vw\] {
    height: 30vw
}

.h-\[50vh\] {
    height: 50vh
}

.h-auto {
    height: auto
}

.h-available {
    height: calc(100svh - var(--header))
}

.h-full {
    height: 100%
}

.h-screen {
    height: 100svh
}

.\!max-h-110 {
    max-height: 11rem !important
}

.\!max-h-70 {
    max-height: 7rem !important
}

.min-h-300 {
    min-height: 30rem
}

.min-h-400 {
    min-height: 40rem
}

.min-h-\[26\.5rem\] {
    min-height: 26.5rem
}

.min-h-available {
    min-height: calc(100svh - var(--header))
}

.min-h-full {
    min-height: 100%
}

.min-h-screen {
    min-height: 100svh
}

.\!w-14 {
    width: 1.4rem !important
}

.\!w-50 {
    width: 5rem !important
}

.\!w-auto {
    width: auto !important
}

.\!w-full {
    width: 100% !important
}

.w-1 {
    width: .1rem
}

.w-10 {
    width: 1rem
}

.w-100 {
    width: 10rem
}

.w-12 {
    width: 1.2rem
}

.w-130 {
    width: 13rem
}

.w-24 {
    width: 2.4rem
}

.w-35 {
    width: 3.5rem
}

.w-50 {
    width: 5rem
}

.w-\[24rem\] {
    width: 24rem
}

.w-auto {
    width: auto
}

.w-full {
    width: 100%
}

.w-screen {
    width: 100vw
}

.min-w-\[140rem\] {
    min-width: 140rem
}

.\!max-w-100 {
    max-width: 10rem !important
}

.\!max-w-140 {
    max-width: 14rem !important
}

.max-w-220 {
    max-width: 22rem
}

.max-w-280 {
    max-width: 28rem
}

.max-w-300 {
    max-width: 30rem
}

.max-w-\[29rem\] {
    max-width: 29rem
}

.max-w-\[42rem\] {
    max-width: 42rem
}

.max-w-\[75rem\] {
    max-width: 75rem
}

.max-w-\[87rem\] {
    max-width: 87rem
}

.max-w-none {
    max-width: none
}

.max-w-screen-lg {
    max-width: 1024px
}

.flex-shrink-0 {
    flex-shrink: 0
}

.flex-grow,
.grow {
    flex-grow: 1
}

.origin-bottom {
    transform-origin: bottom
}

.origin-right {
    transform-origin: right
}

.scale-105 {
    --tw-scale-x: 1.05;
    --tw-scale-y: 1.05
}

.scale-105,
.scale-110 {
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.scale-110 {
    --tw-scale-x: 1.1;
    --tw-scale-y: 1.1
}

.scale-x-0 {
    --tw-scale-x: 0
}

.scale-x-0,
.scale-y-0 {
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.scale-y-0 {
    --tw-scale-y: 0
}

.transform {
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.cursor-pointer {
    cursor: pointer
}

.resize {
    resize: both
}

.grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr))
}

.flex-col {
    flex-direction: column
}

.flex-wrap {
    flex-wrap: wrap
}

.items-start {
    align-items: flex-start
}

.items-end {
    align-items: flex-end
}

.\!items-center {
    align-items: center !important
}

.items-center {
    align-items: center
}

.items-baseline {
    align-items: baseline
}

.justify-start {
    justify-content: flex-start
}

.justify-end {
    justify-content: flex-end
}

.\!justify-center {
    justify-content: center !important
}

.justify-center {
    justify-content: center
}

.justify-between {
    justify-content: space-between
}

.gap-x-10 {
    -moz-column-gap: 1rem;
    column-gap: 1rem
}

.gap-x-12 {
    -moz-column-gap: 1.2rem;
    column-gap: 1.2rem
}

.gap-x-20 {
    -moz-column-gap: 2rem;
    column-gap: 2rem
}

.gap-y-18 {
    row-gap: 1.8rem
}

.gap-y-20 {
    row-gap: 2rem
}

.gap-y-30 {
    row-gap: 3rem
}

.gap-y-8 {
    row-gap: .8rem
}

.gap-y-\[1\.25em\] {
    row-gap: 1.25em
}

.overflow-hidden {
    overflow: hidden
}

.overflow-visible {
    overflow: visible
}

.overflow-y-auto {
    overflow-y: auto
}

.truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap
}

.rounded-circle {
    border-radius: 50%
}

.rounded-full {
    border-radius: 9999px
}

.border {
    border-width: .1rem
}

.border-l {
    border-left-width: .1rem
}

.border-t {
    border-top-width: .1rem
}

.border-t-2 {
    border-top-width: .2rem
}

.border-t-\[0\.15rem\] {
    border-top-width: .15rem
}

.border-current {
    border-color: currentColor
}

.border-orange-dark {
    --tw-border-opacity: 1;
    border-color: rgb(196 64 5/var(--tw-border-opacity))
}

.bg-black {
    --tw-bg-opacity: 1;
    background-color: #000;
}
.bg-current {
    background-color: currentColor
}

.bg-gray {
    --tw-bg-opacity: 1;
    background-color: rgb(241 241 241/var(--tw-bg-opacity))
}

.bg-gray-100 {
    --tw-bg-opacity: 1;
    background-color: rgb(222 222 222/var(--tw-bg-opacity))
}

.bg-blue {
    --tw-bg-opacity: 1;
    background-color:#bcc5ff
}

.bg-blue-dark {
    --tw-bg-opacity: 1;
    background-color: #0b00ab
}
.bg-yllw {
    --tw-bg-opacity: 1;
    background-color: #F9B7D0
}
.bg-pink {
    --tw-bg-opacity: 1;
    background-color: #fff
}

.bg-dark {
    --tw-bg-opacity: 1;
    background-color: #0b00ab
}

.bg-teal {
    --tw-bg-opacity: 1;
    background-color: #F9B7D0
}

.bg-white {
    --tw-bg-opacity: 1;
    background-color:#fff;
}

.\!object-contain {
    -o-object-fit: contain !important;
    object-fit: contain !important
}

.object-cover {
    -o-object-fit: cover;
    object-fit: cover
}

.\!object-top {
    -o-object-position: top !important;
    object-position: top !important
}

.\!p-0 {
    padding: 0 !important
}

.p-12 {
    padding: 1.2rem
}

.p-20 {
    padding: 2rem
}

.p-3 {
    padding: .3rem
}

.p-60 {
    padding: 6rem
}

.px-10 {
    padding-left: 1rem;
    padding-right: 1rem
}

.px-12 {
    padding-left: 1.2rem;
    padding-right: 1.2rem
}

.px-20 {
    padding-left: 2rem;
    padding-right: 2rem
}

.px-5 {
    padding-left: .5rem;
    padding-right: .5rem
}

.py-10 {
    padding-bottom: 1rem;
    padding-top: 1rem
}

.py-12 {
    padding-bottom: 1.2rem;
    padding-top: 1.2rem
}

.py-14 {
    padding-bottom: 1.4rem;
    padding-top: 1.4rem
}

.py-20 {
    padding-bottom: 2rem;
    padding-top: 2rem
}

.py-30 {
    padding-bottom: 3rem;
    padding-top: 3rem
}

.py-5 {
    padding-bottom: .5rem;
    padding-top: .5rem
}

.py-6 {
    padding-bottom: .6rem;
    padding-top: .6rem
}

.pb-0 {
    padding-bottom: 0
}

.pb-10 {
    padding-bottom: 1rem
}

.pb-100 {
    padding-bottom: 10rem
}

.pb-12 {
    padding-bottom: 1.2rem
}

.pb-120 {
    padding-bottom: 12rem
}

.pb-20 {
    padding-bottom: 2rem
}

.pb-30 {
    padding-bottom: 3rem
}

.pb-40 {
    padding-bottom: 4rem
}

.pb-5 {
    padding-bottom: .5rem
}

.pb-55 {
    padding-bottom: 5.5rem
}

.pb-60 {
    padding-bottom: 6rem
}

.pb-70 {
    padding-bottom: 7rem
}

.pb-80 {
    padding-bottom: 8rem
}
.ml-5 {
    margin-left: 0.5rem
}

.pl-12 {
    padding-left: 1.2rem
}
.pl-10 {
    padding-left: 0.8rem
}
.pl-20 {
    padding-left: 2rem
}

.pl-24 {
    padding-left: 2.4rem
}

.pl-70 {
    padding-left: 7rem
}

.pr-10 {
    padding-right: 1rem
}

.pr-12 {
    padding-right: 1.2rem
}

.pr-15 {
    padding-right: 1.5rem
}

.pr-20 {
    padding-right: 2rem
}

.pr-30 {
    padding-right: 3rem
}

.pr-50 {
    padding-right: 5rem
}

.pr-60 {
    padding-right: 6rem
}

.pt-10 {
    padding-top: 1rem
}

.pt-12 {
    padding-top: 1.2rem
}

.pt-20 {
    padding-top: 2rem
}

.pt-24 {
    padding-top: 2.4rem
}

.pt-25 {
    padding-top: 2.5rem
}

.pt-30 {
    padding-top: 3rem
}

.pt-50 {
    padding-top: 5rem
}

.pt-\[0\.08em\] {
    padding-top: .08em
}

.text-center {
    text-align: center
}

.text-4xl {
    font-size: 4.8rem
}

.text-6xl {
    font-size: 6.2rem
}

.text-\[0\.8rem\] {
    font-size: .8rem
}

.text-base {
    font-size: 1.4rem
}

.text-md {
    font-size: 1.5rem
}

.text-sm {
    font-size: 1.2rem
}

.text-xl {
    font-size: 2rem
}

.text-xs {
    font-size: 1rem
}

.font-medium {
    font-weight: 400
}

.uppercase {
    text-transform: uppercase
}

.leading-base {
    line-height: 1.25
}

.leading-none {
    line-height: 1
}

.leading-xs {
    line-height: .9
}

.tracking-tight {
    letter-spacing: -.0125em
}

.tracking-tighter {
    letter-spacing: -.015em
}

.tracking-tightest {
    letter-spacing: -.02em
}

.text-black {
    --tw-text-opacity: 1;
    color: #000000
}
.text-dark {
    --tw-text-opacity: 1;
    color: #000
}
.portfolio-row:hover .text-dark {
    color: #fff
}
.text-white {
    --tw-text-opacity: 1;
    color: #fff
}
.text-orange {
    color: #ef5a1e;
    --tw-text-opacity: 1;
}
.antialiased {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

.opacity-0 {
    opacity: 0
}

.opacity-20 {
    opacity: .2
}

.opacity-30 {
    opacity: .3
}

.opacity-50 {
    opacity: .5
}

.grayscale {
    --tw-grayscale: grayscale(100%)
}

.filter,
.grayscale {
    filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)
}

.transition {
    transition-duration: .15s;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, -webkit-backdrop-filter;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter, -webkit-backdrop-filter;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1)
}

.transition-transform {
    transition-duration: .15s;
    transition-property: transform;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1)
}

.duration-500 {
    transition-duration: .5s
}

.container {
    margin-left: auto;
    margin-right: auto;
    padding-left: 1.2rem;
    padding-right: 1.2rem;
    width: 100%
}

@media (min-width:768px) {
    .container {
        padding-left: 2rem;
        padding-right: 2rem
    }
}

.badge {
    border: 1px solid;
    border-radius: .8rem;
    color: currentColor;
    display: inline-flex;
    font-family: "Aspekta", Roboto, sans-serif;
    font-size: 1.4rem;
    font-weight: 400;
    height: 2.6rem;
    justify-content: center;
    letter-spacing: -.01em;
    line-height: 1.2;
    padding: .3rem .5rem;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none
}

.badge,
.btn__content {
    align-items: center;
    position: relative
}

.btn__content {
    display: flex;
    justify-content: space-between;
    width: 100%;
    z-index: 2
}

.btn__icon {
    display: flex;
    gap: .5rem;
    margin-left: 3rem;
    overflow: hidden;
    width: 1em
}

.btn__icon .svgi {
    flex-shrink: 0;
    transform: translateX(-100%) translateX(-.5rem);
    transition: transform .8s;
    transition-timing-function: cubic-bezier(.86, 0, .07, 1)
}

.btn {
    align-items: flex-end;
    -webkit-appearance: none;
    cursor: pointer;
    display: inline-flex;
    font-family: "Aspekta", Roboto, sans-serif;
    font-size: 1.2rem;
    font-weight: 400;
    height: 5rem;
    line-height: 1.2;
    overflow: hidden;
    padding: .5rem .7rem;
    position: relative;
    transition: background-color .45s, color .45s;
    transition-timing-function: cubic-bezier(.86, 0, .07, 1);
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    width: 100%;
    will-change: transform
}

@media (min-width:768px) {
    .btn {
        font-size: 1.5rem;
        height: 6rem;
        max-width: 27rem;
        padding: .8rem 1rem
    }
    .logo {
        left: 0 !important;
        position: absolute;
        max-width: 15rem;
    }
}

.btn:before {
    border-radius: inherit;
    bottom: 0;
    content: "";
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
    transform: scaleY(0);
    transform-origin: 0 0;
    transition: transform .4s;
    transition-timing-function: cubic-bezier(.86, 0, .07, 1);
    z-index: -1
}

.btn .svgi {
    height: 1em;
    width: 1em
}

.btn:disabled {
    opacity: .5;
    pointer-events: none
}

.btn:disabled:before {
    transform: scaleY(0) !important;
    transform-origin: top !important
}

.btn:focus {
    outline: none
}

.no-touchevents .btn.is-active:before,
.no-touchevents .btn:hover:before,
.no-touchevents .group:not(.group--no-events):hover .btn:before {
    transform: scaleY(1);
    transform-origin: 100% 100%
}

.no-touchevents .btn.is-active .svgi,
.no-touchevents .btn:hover .svgi,
.no-touchevents .group:not(.group--no-events):hover .btn .svgi {
    transform: translateX(0)
}

.btn--primary {
    background-color: #000000;
    border-color: #000000;
    color: #fff
}

.btn--primary:before {
    background-color: #000
}

.btn--primary:disabled {
    color: #fff
}

.btn--orange {
    background-color: #b1c5ce;
    border: 0;
    color: #fff
}

.btn--orange:before {
    background-color: #1b1b1b
}

.btn--contacts {
    border: 0;
    height: 100%
}

.btn--contacts:before {
    display: none
}

.btn--white {
    background-color: #fff;
    border: 0;
    color: #1b1b1b
}

.btn--white:before {
    background-color: #1b1b1b
}

.no-touchevents .btn--white.is-active,
.no-touchevents .btn--white:hover,
.no-touchevents .group:not(.group--no-events):hover .btn--white {
    color: #fff
}

.btn--secondary {
    background-color: #f9b7d0;
    border-color: #000000;
    color: #000000
}

.btn--secondary:before {
    background-color: #000000;
    color: #fff
}

.no-touchevents .btn--secondary.is-active,
.no-touchevents .btn--secondary:hover,
.no-touchevents .group:not(.group--no-events):hover .btn--secondary {
    color: #fff
}

.btn--secondary:disabled {
    color: #000 !important
}

.btn--outline {
    background-color: transparent;
    border-color: rgba(0, 0, 0, .2);
    color: #000
}

.btn--outline:before {
    background-color: #1b1b1b
}

.no-touchevents .btn--outline.is-active,
.no-touchevents .btn--outline:hover,
.no-touchevents .group:not(.group--no-events):hover .btn--outline {
    color: #fff
}

.btn--outline:disabled {
    color: #000 !important
}

.link {
    cursor: pointer;
    display: inline-block;
    position: relative;
    vertical-align: top
}

.link:after {
    background: currentColor;
    bottom: .03em;
    content: "";
    height: .06em;
    left: 0;
    pointer-events: none;
    position: absolute;
    right: 0;
    transform: scaleX(0);
    transform-origin: 100% 100%;
    transition-duration: .5s;
    transition-property: transform;
    transition-timing-function: cubic-bezier(.215, .61, .355, 1);
    will-change: transform
}

.link .svgi {
    display: inline-block;
    height: .75em;
    vertical-align: -.05em;
    width: .75em
}

.active .link:after,
.group.is-active .link:after,
.link--underline:after,
.link.is-active:after,
.no-touchevents .group.is-active .link:after,
.no-touchevents .group:hover .link:after,
.no-touchevents .link.is-active:after,
.no-touchevents .link:hover:after {
    transform: scaleX(1);
    transform-origin: 0 0
}

.link--underline:after {
    animation: none
}

.group.is-active .link--underline:after,
.link--underline.is-active:after,
.no-touchevents .group.is-active .link--underline:after,
.no-touchevents .group:hover .link--underline:after,
.no-touchevents .link--underline.is-active:after,
.no-touchevents .link--underline:hover:after {
    animation: link .75s forwards
}

.group.is-active .link--underline-default,
.group:hover .link--underline-default,
.link--underline-default.is-active,
.link--underline-default:hover {
    text-decoration: none
}

.no-touchevents .group.is-active .link--custom .link__hover-text,
.no-touchevents .group:hover .link--custom .link__hover-text,
.no-touchevents .link--custom.is-active .link__hover-text,
.no-touchevents .link--custom:hover .link__hover-text {
    transform: none
}

.no-touchevents .group.is-active .link--custom .link__default-text,
.no-touchevents .group:hover .link--custom .link__default-text,
.no-touchevents .link--custom.is-active .link__default-text,
.no-touchevents .link--custom:hover .link__default-text {
    transform: translateY(-125%)
}

.group.is-active .link--custom .link__hover-text,
.link--custom.is-active .link__hover-text {
    transform: none
}

.group.is-active .link--custom .link__default-text,
.link--custom.is-active .link__default-text {
    transform: translateY(-125%)
}

.link--innactive .splitter-row .link {
    display: inline-block !important;
    vertical-align: top
}

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

input[type=number] {
    -moz-appearance: textfield
}

select {
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    background-blend-mode: difference;
    background-position: 100% 50%;
    background-repeat: no-repeat;
    background-size: 1rem
}

input[type=submit] {
    background-color: #1b1b1b;
    border: 1px solid #1b1b1b;
    color: #fff;
    cursor: pointer;
    font-size: 1.2rem;
    font-weight: 400;
    height: 4rem;
    line-height: 1;
    padding: 1rem 1.5rem;
    text-transform: uppercase;
    transition-duration: .3s;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
    transition-timing-function: cubic-bezier(.19, 1, .22, 1)
}

input[type=submit]:hover {
    background-color: transparent;
    color: #1b1b1b
}

.woocommerce-input-wrapper .choices,
input[type=email],
input[type=password],
input[type=tel],
input[type=text],
textarea {
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    background-color: transparent;
    border-radius: 0;
    border-style: solid;
    border-width: 0 0 1px;
    font-family: "Aspekta", Roboto, sans-serif;
    font-size: 1.4rem;
    height: 4.5rem;
    line-height: 1.25;
    padding: 1rem 0;
    transition-duration: .3s;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
    transition-timing-function: cubic-bezier(.19, 1, .22, 1);
    width: 100%
}

@media (min-width:1024px) {

    .woocommerce-input-wrapper .choices,
    input[type=email],
    input[type=password],
    input[type=tel],
    input[type=text],
    textarea {
        font-size: 2rem
    }
}

[data-theme=dark] .woocommerce-input-wrapper .choices,
[data-theme=dark] input[type=email],
[data-theme=dark] input[type=password],
[data-theme=dark] input[type=tel],
[data-theme=dark] input[type=text],
[data-theme=dark] textarea {
    border-color: hsla(0, 0%, 100%, .4);
    color: hsla(0, 0%, 100%, .4)
}

[data-theme=dark] .woocommerce-input-wrapper .choices:focus,
[data-theme=dark] .woocommerce-input-wrapper .choices:hover,
[data-theme=dark] input[type=email]:focus,
[data-theme=dark] input[type=email]:hover,
[data-theme=dark] input[type=password]:focus,
[data-theme=dark] input[type=password]:hover,
[data-theme=dark] input[type=tel]:focus,
[data-theme=dark] input[type=tel]:hover,
[data-theme=dark] input[type=text]:focus,
[data-theme=dark] input[type=text]:hover,
[data-theme=dark] textarea:focus,
[data-theme=dark] textarea:hover {
    border-color: hsla(0, 0%, 100%, .8)
}

[data-theme=light] .woocommerce-input-wrapper .choices,
[data-theme=light] input[type=email],
[data-theme=light] input[type=password],
[data-theme=light] input[type=tel],
[data-theme=light] input[type=text],
[data-theme=light] textarea {
    border-color: hsla(0, 0%, 4%, .4);
    color: hsla(0, 0%, 4%, .4)
}

[data-theme=light] .woocommerce-input-wrapper .choices:focus,
[data-theme=light] .woocommerce-input-wrapper .choices:hover,
[data-theme=light] input[type=email]:focus,
[data-theme=light] input[type=email]:hover,
[data-theme=light] input[type=password]:focus,
[data-theme=light] input[type=password]:hover,
[data-theme=light] input[type=tel]:focus,
[data-theme=light] input[type=tel]:hover,
[data-theme=light] input[type=text]:focus,
[data-theme=light] input[type=text]:hover,
[data-theme=light] textarea:focus,
[data-theme=light] textarea:hover {
    border-color: hsla(0, 0%, 4%, .8)
}

.woocommerce-input-wrapper .choices:not(:-moz-placeholder-shown),
input[type=email]:not(:-moz-placeholder-shown),
input[type=password]:not(:-moz-placeholder-shown),
input[type=tel]:not(:-moz-placeholder-shown),
input[type=text]:not(:-moz-placeholder-shown),
textarea:not(:-moz-placeholder-shown) {
    color: currentColor;
    outline: none
}

.woocommerce-input-wrapper .choices:focus,
.woocommerce-input-wrapper .choices:hover,
.woocommerce-input-wrapper .choices:not(:placeholder-shown),
input[type=email]:focus,
input[type=email]:hover,
input[type=email]:not(:placeholder-shown),
input[type=password]:focus,
input[type=password]:hover,
input[type=password]:not(:placeholder-shown),
input[type=tel]:focus,
input[type=tel]:hover,
input[type=tel]:not(:placeholder-shown),
input[type=text]:focus,
input[type=text]:hover,
input[type=text]:not(:placeholder-shown),
textarea:focus,
textarea:hover,
textarea:not(:placeholder-shown) {
    color: currentColor;
    outline: none
}

.woocommerce-input-wrapper .choices::-internal-input-suggested,
input[type=email]::-internal-input-suggested,
input[type=password]::-internal-input-suggested,
input[type=tel]::-internal-input-suggested,
input[type=text]::-internal-input-suggested,
textarea::-internal-input-suggested {
    font-family: "Aspekta", Roboto, sans-serif !important;
    font-size: 2rem !important
}

input::-webkit-search-cancel-button {
    -webkit-appearance: none;
    appearance: none
}

input::-moz-placeholder,
textarea::-moz-placeholder {
    color: currentColor;
    transition-duration: .3s;
    -moz-transition-property: opacity;
    transition-property: opacity;
    transition-timing-function: cubic-bezier(.215, .61, .355, 1)
}

input::placeholder,
textarea::placeholder {
    color: currentColor;
    transition-duration: .3s;
    transition-property: opacity;
    transition-timing-function: cubic-bezier(.215, .61, .355, 1)
}

input:hover::-moz-placeholder,
textarea:hover::-moz-placeholder {
    opacity: 1
}

input:hover::placeholder,
textarea:hover::placeholder {
    opacity: 1
}

input:focus::-moz-placeholder,
textarea:focus::-moz-placeholder {
    opacity: 0
}

input:focus::placeholder,
textarea:focus::placeholder {
    opacity: 0
}

input:not(:-moz-placeholder-shown),
textarea:not(:-moz-placeholder-shown) {
    opacity: 1
}

input:not(:placeholder-shown),
textarea:not(:placeholder-shown) {
    opacity: 1
}

.input-group {
    align-items: center;
    display: flex;
    position: relative
}

.input-group:after {
    background: currentColor;
    bottom: 0;
    content: "";
    height: 1px;
    left: 0;
    position: absolute;
    transform: scaleX(0);
    transform-origin: 100% 100%;
    transition-duration: .4s;
    transition-property: transform;
    width: 100%
}

.input-group:focus-within:after,
.input-group:focus-within:before,
.input-group:hover:after,
.input-group:hover:before {
    transform: scaleX(1);
    transform-origin: 0 0
}

.input-group:focus-within .input-group__input:placeholder,
.input-group:hover .input-group__input:placeholder {
    opacity: 1
}

.input-group:not(:first-child):before {
    display: none
}

.input-group:not(:first-child)>input {
    border-top: 0
}

.input-group.has-error:after,
.input-group.is-invalid:after {
    opacity: 1;
    transform: scaleX(1);
    transform-origin: 0 0
}

input[type=checkbox] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-color: transparent;
    border: .1rem solid;
    border-radius: .4rem;
    color: currentColor;
    flex-shrink: 0;
    font: inherit;
    height: 2rem;
    margin: 0 1.5rem 0 0;
    opacity: .8;
    position: relative;
    top: .15em;
    width: 2rem
}

input[type=checkbox]:checked {
    background: currentColor;
    opacity: 1
}

textarea {
    display: flex;
    min-height: 10rem;
    resize: none !important
}

textarea:placeholder {
    bottom: 1rem;
    position: absolute;
    width: 100%
}

hr {
    border-color: currentColor;
    opacity: .15
}

.blur {
    opacity: 0.9;
    backdrop-filter: blur(0.375rem);
}

[data-component=parallax-box],
[data-component=parallax-box]>* {
    will-change: transform
}

.overflow-y-auto {
    -webkit-overflow-scrolling: touch
}

.overflow-y-auto::-webkit-scrollbar {
    background: transparent;
    width: 4px
}

.overflow-y-auto::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, .3)
}

.preloader__layer {
    --m: 1;
    pointer-events: none
}

.preloader__layer:after,
.preloader__layer:before {
    background: var(--bg);
    content: "";
    left: 0;
    position: absolute;
    top: 0;
    z-index: -1
}

.preloader__layer:before {
    height: calc(1.2rem*var(--m));
    width: 100%
}

.preloader__layer:after {
    height: 100%;
    width: calc(1.2rem*var(--m))
}

.preloader__layer:first-child {
    /*--m: 2;
    --bg: #92a6b0;*/
    z-index: -5;
    opacity: 0;
}

.preloader__layer:nth-child(2) {
    /*--bg: #b1c5ce;*/
    z-index: -5;
    opacity: 0;
}

.preloader__layer:nth-child(3) {
    --bg: #000000;
    z-index: 20
}

.preloader__layer:nth-child(3) .preloader__layer-inset {
    display: block;
    height: 20rem;
    width: 20rem
}

.is-loaded .preloader__layer:nth-child(3) .preloader__layer-inset,
.preloader__layer:nth-child(3):after,
.preloader__layer:nth-child(3):before {
    display: none;
}

.preloader__layer-inset {
    background: var(--bg);
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: -1
}

[data-component=preloader] {
    -webkit-clip-path: polygon(0 0, 10rem 0, 10rem 0, 0 0);
    clip-path: polygon(0 0, 10rem 0, 10rem 0, 0 0);
    left: 0;
    position: absolute;
    top: 0;
    transform: translate(50%, 50%) translate(-5rem, -5rem);
    z-index: 15
}

.is-loaded [data-component=preloader] {
    pointer-events: none
}

.preloader-complete [data-component=preloader] {
    -webkit-clip-path: none;
    clip-path: none;
    transform: none
}

.preloader__word,
.preloader__word path:not(:first-child) {
    opacity: 0
}

.is-loading main {
    visibility: hidden
}

[data-page-wrapper] {
    height: 100%;
    padding-top: 2.4rem
}

[data-scroller] {
    padding-left: 2.4rem
}

@font-face {
    font-family: swiper-icons;
    font-style: normal;
    font-weight: 400;
    src: url("data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA") format("woff")
}

:root {
    --swiper-theme-color: #007aff
}

:host {
    display: block;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    z-index: 1
}

.swiper {
    display: block;
    list-style: none;
    margin-left: auto;
    margin-right: auto;
    overflow: hidden;
    padding: 0;
    position: relative;
    z-index: 1
}

.swiper-vertical>.swiper-wrapper {
    flex-direction: column
}

.swiper-wrapper {
    box-sizing: content-box;
    display: flex;
    height: 100%;
    position: relative;
    transition-property: transform;
    transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
    width: 100%;
    z-index: 1
}

.swiper-android .swiper-slide,
.swiper-ios .swiper-slide,
.swiper-wrapper {
    transform: translateZ(0)
}

.swiper-horizontal {
    touch-action: pan-y
}

.swiper-vertical {
    touch-action: pan-x
}

.swiper-slide {
    display: block;
    flex-shrink: 0;
    height: 100%;
    position: relative;
    transition-property: transform;
    width: 100%
}

.swiper-slide-invisible-blank {
    visibility: hidden
}

.swiper-autoheight,
.swiper-autoheight .swiper-slide {
    height: auto
}

.swiper-autoheight .swiper-wrapper {
    align-items: flex-start;
    transition-property: transform, height
}

.swiper-backface-hidden .swiper-slide {
    backface-visibility: hidden;
    transform: translateZ(0)
}

.swiper-3d.swiper-css-mode .swiper-wrapper {
    perspective: 1200px
}

.swiper-3d .swiper-wrapper {
    transform-style: preserve-3d
}

.swiper-3d {
    perspective: 1200px
}

.swiper-3d .swiper-cube-shadow,
.swiper-3d .swiper-slide {
    transform-style: preserve-3d
}

.swiper-css-mode>.swiper-wrapper {
    -ms-overflow-style: none;
    overflow: auto;
    scrollbar-width: none
}

.swiper-css-mode>.swiper-wrapper::-webkit-scrollbar {
    display: none
}

.swiper-css-mode>.swiper-wrapper>.swiper-slide {
    scroll-snap-align: start start
}

.swiper-css-mode.swiper-horizontal>.swiper-wrapper {
    scroll-snap-type: x mandatory
}

.swiper-css-mode.swiper-vertical>.swiper-wrapper {
    scroll-snap-type: y mandatory
}

.swiper-css-mode.swiper-free-mode>.swiper-wrapper {
    scroll-snap-type: none
}

.swiper-css-mode.swiper-free-mode>.swiper-wrapper>.swiper-slide {
    scroll-snap-align: none
}

.swiper-css-mode.swiper-centered>.swiper-wrapper:before {
    content: "";
    flex-shrink: 0;
    order: 9999
}

.swiper-css-mode.swiper-centered>.swiper-wrapper>.swiper-slide {
    scroll-snap-align: center center;
    scroll-snap-stop: always
}

.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper>.swiper-slide:first-child {
    margin-inline-start: var(--swiper-centered-offset-before)
}

.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper:before {
    height: 100%;
    min-height: 1px;
    width: var(--swiper-centered-offset-after)
}

.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper>.swiper-slide:first-child {
    margin-block-start: var(--swiper-centered-offset-before)
}

.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper:before {
    height: var(--swiper-centered-offset-after);
    min-width: 1px;
    width: 100%
}

.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-bottom,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top {
    height: 100%;
    left: 0;
    pointer-events: none;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 10
}

.swiper-3d .swiper-slide-shadow {
    background: rgba(0, 0, 0, .15)
}

.swiper-3d .swiper-slide-shadow-left {
    background-image: linear-gradient(270deg, rgba(0, 0, 0, .5), transparent)
}

.swiper-3d .swiper-slide-shadow-right {
    background-image: linear-gradient(90deg, rgba(0, 0, 0, .5), transparent)
}

.swiper-3d .swiper-slide-shadow-top {
    background-image: linear-gradient(0deg, rgba(0, 0, 0, .5), transparent)
}

.swiper-3d .swiper-slide-shadow-bottom {
    background-image: linear-gradient(180deg, rgba(0, 0, 0, .5), transparent)
}

.swiper-lazy-preloader {
    border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
    border-radius: 50%;
    border-top: 4px solid transparent;
    box-sizing: border-box;
    height: 42px;
    left: 50%;
    margin-left: -21px;
    margin-top: -21px;
    position: absolute;
    top: 50%;
    transform-origin: 50%;
    width: 42px;
    z-index: 10
}

.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader,
.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader {
    animation: swiper-preloader-spin 1s linear infinite
}

.swiper-lazy-preloader-white {
    --swiper-preloader-color: #fff
}

.swiper-lazy-preloader-black {
    --swiper-preloader-color: #000
}

@keyframes swiper-preloader-spin {
    0% {
        transform: rotate(0deg)
    }

    to {
        transform: rotate(1turn)
    }
}

.swiper-fade.swiper-free-mode .swiper-slide {
    transition-timing-function: ease-out
}

.swiper-fade .swiper-slide {
    pointer-events: none;
    transition-property: opacity
}

.swiper-fade .swiper-slide .swiper-slide {
    pointer-events: none
}

.swiper-fade .swiper-slide-active,
.swiper-fade .swiper-slide-active .swiper-slide-active {
    pointer-events: auto
}

.swiper-wrapper {
    box-sizing: border-box
}

.swiper-slide {
    transition-timing-function: cubic-bezier(.65, .05, .36, 1);
    opacity: 0 !important;
}

[data-images-carousel] .swiper-slide:before {
    background: #000;
    content: "";
    height: 100%;
    left: 0;
    opacity: 0;
    position: absolute;
    top: 0;
    transition: opacity 1.1s cubic-bezier(.86, 0, .07, 1);
    width: 100%;
    z-index: 2
}

[data-images-carousel] .swiper-slide.swiper-slide-prev:before {
    opacity: .25
}
.swiper-slide.swiper-slide-active {
    opacity: 1 !important;
}
.header {
    pointer-events: none;
    transform: translateY(-100%)
}

.is-loaded .header {
    pointer-events: all;
    transform: none;
    transition: transform .7s cubic-bezier(.86, 0, .07, 1)
}
.is-loaded .header::before {
    -webkit-backdrop-filter: var(--frosted-backdrop-filter)saturate(4);
    backdrop-filter: var(--frosted-backdrop-filter)saturate(4);
    background-color: var(--popover-bgcolor);
    border-radius: var(--pib-popover-radius);
    pointer-events: none;
    box-shadow: var(--shadow-menu);
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    content: "";
}
.header-line {
    transition: transform 1.4s cubic-bezier(.86, 0, .07, 1);
    z-index: 2
}

.header-line--h {
    transform: scaleX(0)
}

.is-loaded .header-line--h {
    transform: scaleX(1);
    transition-delay: .2s
}

.menu-indicator {
    display: grid;
    gap: .3rem;
    position: relative
}

.menu-indicator:after,
.menu-indicator:before {
    background: currentColor;
    content: "";
    display: block;
    height: 2px;
    transform-origin: right;
    transition: transform .8s cubic-bezier(.86, 0, .07, 1);
    width: 2rem
}

.no-touchevents .group:hover .menu-indicator:after,
.no-touchevents .group:hover .menu-indicator:before {
    transform: scaleX(.5)
}

.menu--opened .menu-indicator:after,
.menu--opened .menu-indicator:before {
    transform: scaleX(0) !important;
    transition-duration: .6s
}

.menu-indicator:after {
    transition-delay: .15s
}

.menu-indicator .svgi {
    bottom: -.1em;
    height: 1.4rem;
    opacity: 0;
    position: absolute;
    right: 0;
    transform: scale(0);
    transition: opacity .5s cubic-bezier(.86, 0, .07, 1), transform .5s cubic-bezier(.86, 0, .07, 1);
    width: 1.4rem
}

.menu--opened .menu-indicator .svgi {
    opacity: 1;
    transform: scale(1);
    transition-delay: .5s
}

[data-menu] {
    -webkit-clip-path: polygon(0 0, 0 0, 0 0, 0 0);
    clip-path: polygon(0 0, 0 0, 0 0, 0 0);
    pointer-events: none;
    transition: -webkit-clip-path .9s cubic-bezier(.86, 0, .07, 1);
    transition: clip-path .9s cubic-bezier(.86, 0, .07, 1);
    transition: clip-path .9s cubic-bezier(.86, 0, .07, 1), -webkit-clip-path .9s cubic-bezier(.86, 0, .07, 1);
    width: calc(100% - 2.4rem)
}

.is-loading [data-menu] {
    display: none
}

.preloader-complete [data-menu] {
    -webkit-clip-path: polygon(100% 0, 100% 0, 100% 0, 100% 0);
    clip-path: polygon(100% 0, 100% 0, 100% 0, 100% 0)
}

.menu--opened [data-menu] {
    -webkit-clip-path: polygon(0 0, 0 100%, 100% 100%, 100% 0) !important;
    clip-path: polygon(0 0, 0 100%, 100% 100%, 100% 0) !important;
    pointer-events: all;
    overflow-y: hidden;
}

.logo {
    left: 0 !important;
    position: absolute;
    max-width: 15.3rem;
}

.fake-logo {
    z-index: 30
}

.preloader-complete .fake-logo {
    pointer-events: all !important
}

.header-nav__link {
    align-items: center;
    display: flex;
    justify-content: space-between;
    position: relative
}

.header-nav__link:after,
.header-nav__link:before {
    background: currentColor;
    bottom: 0;
    content: "";
    height: .1rem;
    left: 0;
    position: absolute;
    transition: transform .3s cubic-bezier(.86, 0, .07, 1);
    width: 100%
}

.header-nav__link:before {
    transform: scaleX(0);
    transform-origin: right
}

.header-nav__link:after {
    transform: scaleX(1);
    transform-origin: left;
    transition-delay: .15s
}

.no-touchevents .header-nav__link:hover:after,
.no-touchevents .header-nav__link:hover:before {
    transition-duration: .6s
}

.no-touchevents .header-nav__link:hover:before {
    transform: scaleX(1);
    transform-origin: left;
    transition-delay: .15s
}

.no-touchevents .header-nav__link:hover:after {
    transform: scaleX(0);
    transform-origin: right;
    transition-delay: 0s
}

.no-touchevents .header-nav__link:hover .svgi {
    opacity: 1;
    transform: none;
    transition-duration: .7s
}

.header-nav__link .svgi {
    height: .75em;
    opacity: 0;
    position: absolute;
    right: 0;
    transform: translateX(-50%);
    transition: opacity .7s cubic-bezier(.86, 0, .07, 1), transform .7s cubic-bezier(.86, 0, .07, 1);
    width: .75em
}

.header-nav__link.is-active {
    opacity: 1;
   /* color: #22282a;*/
}
.header-nav__link:hover {
  color: #0b00ab;
}

[data-component=popup] {
    pointer-events: none;
    transform: translateX(100%);
    transition: transform .8s cubic-bezier(.86, 0, .07, 1)
}

[data-component=popup].is-active {
    pointer-events: all;
    transform: none;
    transition-duration: 1.3s
}

[data-popup-overlay] {
    opacity: 0;
    transition: opacity .7s cubic-bezier(.86, 0, .07, 1)
}

.popup--is-active [data-popup-overlay] {
    opacity: .8;
    pointer-events: all;
    transition-delay: 0s;
    transition-duration: 1.2s
}

@media screen and (min-width:375px) {
    .text-decorated {
        font-size: calc(2rem + 6.76056vw - 25.35211px)
    }
}

@media screen and (min-width:768px) {
    :root {
        --header: 5rem
    }

    section.bg-orange:not(.ethos-first):first-child:before {
        margin-left: 6rem
    }

    section.bg-orange:not(.ethos-first):first-child:after {
        top: 6rem
    }

    .default-section+.default-section {
        border-top-width: .3rem
    }

    .is-started .testimonials__overlay {
        transform: translate(2rem, 2rem)
    }

    [data-page-overlay] {
        left: 5rem;
        top: 5rem
    }

    .preloader-complete [data-page-overlay] {
        -webkit-clip-path: polygon(0 0, 0 5rem, 5rem 5rem, 5rem 0);
        clip-path: polygon(0 0, 0 5rem, 5rem 5rem, 5rem 0)
    }

    .section-images-stack {
        --offset: 5rem
    }

    .section-images-stack img {
        -o-object-position: center;
        object-position: center
    }

    .stack-panels__panel {
        min-height: 66rem
    }

    .stack-panels__panel:first-child {
        top: 5rem
    }

    .stack-panels__panel:nth-child(2) {
        margin-right: 2.5rem;
        top: 16rem
    }

    .stack-panels__panel:nth-child(2) .stack-panel__content {
        margin-right: -4.5rem;
        padding-right: 2.5rem
    }

    .stack-panels__panel:nth-child(3) {
        margin-right: 5rem;
        top: 27rem
    }

    .stack-panels__panel:nth-child(3) .stack-panel__content {
        margin-right: -7rem;
        padding-right: 2.5rem
    }



    .stack-panels__panel:nth-child(4) {
        margin-right: 7.5rem;
        top: 38rem
    }

    .stack-panels__panel:nth-child(4) .stack-panel__content {
        margin-right: -9.5rem;
        padding-right: 2.5rem
    }



    .preloader__layer:before {
        height: calc(2.5rem*var(--m))
    }

    .preloader__layer:after {
        width: calc(2.5rem*var(--m))
    }

    [data-component=preloader] {
        -webkit-clip-path: polygon(0 0, 10rem 0, 10rem 0, 0 0);
        clip-path: polygon(0 0, 10rem 0, 10rem 0, 0 0);
        transform: translate(50%, 50%) translate(-5rem, -5rem)
    }

    [data-page-wrapper] {
        padding-top: 0rem
    }

    [data-scroller] {
        padding-left: 0;
        padding-right: 0;
    }

    .menu-indicator {
        gap: .4rem
    }

    .menu-indicator:after,
    .menu-indicator:before {
        width: 3.3rem
    }

    [data-menu] {
        width: calc(100% - 5rem)
    }

    .header-nav__link:after,
    .header-nav__link:before {
        height: .2rem
    }

    [data-component=popup] {
        width: 50rem
    }

    [data-popup-close] {
        transform: none;
        transition: transform .6s cubic-bezier(.86, 0, .07, 1)
    }

    .is-active [data-popup-close] {
        transform: translateX(-100%);
        transition-duration: 1.2s
    }

    .is-active [data-popup-close]:hover {
        transform: translateX(-80%);
        transition-delay: 0s;
        transition-duration: .4s;
        transition-timing-function: cubic-bezier(.65, .05, .36, 1)
    }
}

@media screen and (min-width:1024px) {
    .custom-inline-checkbox .checked-label {
        font-size: 1.4rem
    }
}

@media screen and (min-width:1280px) {
    .cursor {
        display: block
    }

    .portfolio-row:hover {
        color: #fff
    }

    .group:hover .portfolio-row__container:before {
        transform: none;
        transform-origin: top
    }

    .is-started .team-member__overlay {
        transform: translate(2rem, 2rem)
    }

    [data-component=popup].popup--wide {
        max-width: 74.5rem;
        width: 100%
    }
}

@media screen and (min-width:1440px) {
    .text-decorated {
        font-size: 9.2rem
    }
}

@media (min-width:768px) {
    .md\:container {
        margin-left: auto;
        margin-right: auto;
        padding-left: 1.2rem;
        padding-right: 1.2rem;
        width: 100%
    }

    @media (min-width:768px) {
        .md\:container {
            padding-left: 2rem;
            padding-right: 0
        }
    }
}

@media (min-width:1024px) {
    .lg\:container {
        margin-left: auto;
        margin-right: auto;
        padding-left: 1.2rem;
        padding-right: 0;
        width: 100%
    }

    @media (min-width:768px) {
        .lg\:container {
            padding-left: 2rem;
            padding-right: 0
        }
    }
}

.group:hover .group-hover\:origin-left {
    transform-origin: left
}

.group:hover .group-hover\:scale-x-100 {
    --tw-scale-x: 1;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

@media (min-width:768px) {
    .md\:not-sr-only {
        clip: auto;
        height: auto;
        margin: 0;
        overflow: visible;
        padding: 0;
        white-space: normal;
        width: auto
    }

    .md\:not-sr-only,
    .md\:static {
        position: static
    }

    .md\:absolute {
        position: absolute
    }

    .md\:relative {
        position: relative
    }

    .md\:sticky {
        position: sticky
    }

    .md\:\!left-0 {
        left: 0 !important
    }

    .md\:\!left-20 {
        left: 2rem !important
    }

    .md\:-left-20 {
        left: -2rem
    }

    .md\:-right-20 {
        right: -2rem
    }

    .md\:bottom-auto {
        bottom: auto
    }

    .md\:bottom-full {
        bottom: 100%
    }

    .md\:left-0 {
        left: 0
    }

    .md\:left-25 {
        left: 2.5rem
    }

    .md\:left-50 {
        left: 5rem
    }

    .md\:left-60 {
        left: 6rem
    }

    .md\:left-auto {
        left: auto
    }

    .md\:right-0 {
        right: 0
    }

    .md\:right-20 {
        right: 2rem
    }

    .md\:right-auto {
        right: auto
    }

    .md\:top-0 {
        top: 0
    }

    .md\:top-25 {
        top: 2.5rem
    }

    .md\:top-50 {
        top: 5rem
    }

    .md\:top-60 {
        top: 6rem
    }

    .md\:-z-1 {
        z-index: -1
    }

    .md\:order-first {
        order: -9999
    }

    .md\:order-last {
        order: 9999
    }

    .md\:col-span-1 {
        grid-column: span 1/span 1
    }

    .md\:col-span-12 {
        grid-column: span 12/span 12
    }

    .md\:col-span-2 {
        grid-column: span 2/span 2
    }

    .md\:col-span-3 {
        grid-column: span 3/span 3
    }

    .md\:col-span-4 {
        grid-column: span 4/span 4
    }

    .md\:col-span-5 {
        grid-column: span 5/span 5
    }

    .md\:col-span-6 {
        grid-column: span 6/span 6
    }

    .md\:col-span-7 {
        grid-column: span 7/span 7
    }

    .md\:col-span-9 {
        grid-column: span 9/span 9
    }
    .md\:col-span-10 {
        grid-column: span 10/span 10
    }
    .md\:col-start-2 {
        grid-column-start: 2
    }

    .md\:col-start-4 {
        grid-column-start: 3
    }

    .md\:row-start-1 {
        grid-row-start: 1
    }

    .md\:row-end-5 {
        grid-row-end: 5
    }

    .md\:-mx-20 {
        margin-right: -2rem
    }

    .md\:-ml-20,
    .md\:-mx-20 {
        margin-left: -2rem
    }

    .md\:-ml-25 {
        margin-left: -2.5rem
    }
    .md\:-mr-25 {
        margin-right: -2.5rem
    }
    .md\:-mr-10 {
        margin-right: -1rem
    }

    .md\:-mr-20 {
        margin-right: -2rem
    }

    .md\:-mt-350 {
        margin-top: -35rem
    }

    .md\:mb-0 {
        margin-bottom: 0
    }

    .md\:mb-10 {
        margin-bottom: 1rem
    }

    .md\:mb-140 {
        margin-bottom: 14rem
    }

    .md\:mb-180 {
        margin-bottom: 18rem
    }

    .md\:mb-20 {
        margin-bottom: 2rem
    }

    .md\:mb-40 {
        margin-bottom: 4rem
    }

    .md\:mb-60 {
        margin-bottom: 6rem
    }

    .md\:mt-0 {
        margin-top: 0
    }

    .md\:mt-150 {
        margin-top: 15rem
    }

    .md\:mt-50 {
        margin-top: 5rem
    }

    .md\:mt-60 {
        margin-top: 6rem
    }

    .md\:mt-80 {
        margin-top: 8rem
    }

    .md\:mt-auto {
        margin-top: auto
    }

    .md\:block {
        display: block
    }

    .md\:\!flex {
        display: flex !important
    }

    .md\:flex {
        display: flex
    }

    .md\:grid {
        display: grid
    }

    .md\:hidden {
        display: none
    }

    .md\:aspect-\[343\/477\] {
        aspect-ratio: 343/477
    }

    .md\:h-13 {
        height: 1.3rem
    }

    .md\:h-14 {
        height: 1.4rem
    }

    .md\:h-140 {
        height: 14rem
    }

    .md\:h-15 {
        height: 1.5rem
    }

    .md\:h-25 {
        height: 2.5rem
    }

    .md\:h-50 {
        height: 5rem
    }

    .md\:w-140 {
        width: 14rem
    }

    .md\:w-25 {
        width: 2.5rem
    }

    .md\:w-50 {
        width: 10rem
    }

    .md\:w-\[13\.4rem\] {
        width: 13.4rem
    }

    .md\:w-\[13\.5rem\] {
        width: 13.5rem
    }

    .md\:w-auto {
        width: auto
    }

    .md\:max-w-\[27rem\] {
        max-width: 27rem
    }

    .md\:max-w-none {
        max-width: none
    }

    .md\:flex-shrink-0 {
        flex-shrink: 0
    }

    .md\:flex-grow {
        flex-grow: 1
    }

    .md\:grid-cols-12 {
        grid-template-columns: repeat(12, minmax(0, 1fr))
    }

    .md\:grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr))
    }

    .md\:grid-cols-9 {
        grid-template-columns: repeat(9, minmax(0, 1fr))
    }

    .md\:flex-col {
        flex-direction: column
    }

    .md\:flex-col-reverse {
        flex-direction: column-reverse
    }

    .md\:items-start {
        align-items: flex-start
    }

    .md\:items-end {
        align-items: flex-end
    }

    .md\:justify-start {
        justify-content: flex-start
    }

    .md\:justify-end {
        justify-content: flex-end
    }

    .md\:gap-x-20 {
        -moz-column-gap: 2rem;
        column-gap: 2rem
    }

    .md\:gap-y-10 {
        row-gap: 1rem
    }

    .md\:gap-y-60 {
        row-gap: 6rem
    }

    .md\:border-t-\[0\.3rem\] {
        border-top-width: .3rem
    }

    .md\:\!object-cover {
        -o-object-fit: cover !important;
        object-fit: cover !important
    }

    .md\:p-20 {
        padding: 2rem
    }

    .md\:p-6 {
        padding: .6rem
    }

    .md\:px-0 {
        padding-left: 0;
        padding-right: 0
    }

    .md\:px-10 {
        padding-left: 1rem;
        padding-right: 1rem
    }

    .md\:px-20 {
        padding-left: 2rem;
        padding-right: 2rem
    }

    .md\:px-25 {
        padding-left: 2.5rem;
        padding-right: 2.5rem
    }

    .md\:py-12 {
        padding-bottom: 1.2rem;
        padding-top: 1.2rem
    }

    .md\:py-15 {
        padding-bottom: 1.5rem;
        padding-top: 1.5rem
    }

    .md\:py-20 {
        padding-bottom: 2rem;
        padding-top: 2rem
    }

    .md\:pb-0 {
        padding-bottom: 0
    }

    .md\:pb-10 {
        padding-bottom: 1rem
    }

    .md\:pb-160 {
        padding-bottom: 16rem
    }

    .md\:pb-180 {
        padding-bottom: 18rem
    }

    .md\:pb-260 {
        padding-bottom: 26rem
    }

    .md\:pb-30 {
        padding-bottom: 3rem
    }

    .md\:pb-80 {
        padding-bottom: 8rem
    }

    .md\:pb-100 {
        padding-bottom: 10rem
    }
    .md\:pl-0 {
        padding-left: 0
    }

    .md\:pl-20 {
        padding-left: 2rem
    }

    .md\:pr-0 {
        padding-right: 0
    }

    .md\:pr-1\/10 {
        padding-right: 10%
    }

    .md\:pr-10 {
        padding-right: 1rem
    }

    .md\:pr-20 {
        padding-right: 2rem
    }

    .md\:pr-40 {
        padding-right: 4rem
    }

    .md\:pt-15 {
        padding-top: 1.5rem
    }

    .md\:pt-20 {
        padding-top: 2rem
    }

    .md\:pt-25 {
        padding-top: 2.5rem
    }

    .md\:pt-60 {
        padding-top: 6rem
    }

    .md\:text-9xl {
        font-size: 6.2rem
    }

    .md\:text-base {
        font-size: 1.4rem
    }

    .md\:text-md {
        font-size: 1.5rem
    }

    .md\:text-sm {
        font-size: 1.2rem
    }

    .md\:text-xl {
        font-size: 2rem
    }
}

@media (min-width:1024px) {
    .lg\:\!left-0 {
        left: 0 !important
    }

    .lg\:order-first {
        order: -9999
    }

    .lg\:col-span-3 {
        grid-column: span 3/span 3
    }

    .lg\:col-span-6 {
        grid-column: span 6/span 6
    }

    .lg\:col-span-9 {
        grid-column: span 9/span 9
    }
    .lg\:col-start-3 {
        grid-column-start: 3
    }
    .lg\:col-start-4 {
        grid-column-start: 4
    }

    .lg\:col-start-7 {
        grid-column-start: 7
    }

    .lg\:-mr-20 {
        margin-right: -2rem
    }

    .lg\:mb-70 {
        margin-bottom: 7rem
    }

    .lg\:block {
        display: block
    }

    .lg\:grid {
        display: grid
    }

    .lg\:hidden {
        display: none
    }

    .lg\:grid-cols-12 {
        grid-template-columns: repeat(12, minmax(0, 1fr))
    }

    .lg\:grid-cols-9 {
        grid-template-columns: repeat(9, minmax(0, 1fr))
    }

    .lg\:gap-x-20 {
        -moz-column-gap: 2rem;
        column-gap: 2rem
    }

    .lg\:px-0 {
        padding-left: 0;
        padding-right: 0
    }

    .lg\:pb-20 {
        padding-bottom: 2rem
    }

    .lg\:pl-20 {
        padding-left: 2rem
    }

    .lg\:text-3xl {
        font-size: 3.8rem
    }

    .lg\:text-xl {
        font-size: 2rem
    }
}

@media (min-width:1280px) {
    .laptop\:-left-20 {
        left: -2rem
    }

    .laptop\:right-0 {
        right: 0
    }

    .laptop\:top-20 {
        top: 2rem
    }

    .laptop\:col-span-2 {
        grid-column: span 2/span 2
    }

    .laptop\:col-span-3 {
        grid-column: span 3/span 3
    }

    .laptop\:col-span-6 {
        grid-column: span 6/span 6
    }

    .laptop\:col-span-7 {
        grid-column: span 7/span 7
    }

    .laptop\:col-start-4 {
        grid-column-start: 4
    }

    .laptop\:row-start-auto {
        grid-row-start: auto
    }

    .laptop\:row-end-auto {
        grid-row-end: auto
    }

    .laptop\:m-0 {
        margin: 0
    }

    .laptop\:block {
        display: block
    }

    .laptop\:flex {
        display: flex
    }

    .laptop\:grid {
        display: grid
    }

    .laptop\:hidden {
        display: none
    }

    .laptop\:\!h-20 {
        height: 2rem !important
    }

    .laptop\:\!h-70 {
        height: 7rem !important
    }

    .laptop\:h-260 {
        height: 26rem
    }

    .laptop\:h-60 {
        height: 6rem
    }

    .laptop\:h-available {
        height: calc(100svh - var(--header))
    }

    .laptop\:min-h-400 {
        min-height: 40rem
    }

    .laptop\:min-h-available {
        min-height: calc(100svh - var(--header))
    }

    .laptop\:\!w-20 {
        width: 2rem !important
    }

    .laptop\:\!w-70 {
        width: 7rem !important
    }

    .laptop\:w-150 {
        width: 15rem
    }

    .laptop\:w-60 {
        width: 6rem
    }

    .laptop\:w-\[32rem\] {
        width: 32rem
    }

    .laptop\:w-auto {
        width: auto
    }

    .laptop\:grid-cols-9 {
        grid-template-columns: repeat(9, minmax(0, 1fr))
    }

    .laptop\:gap-x-20 {
        -moz-column-gap: 2rem;
        column-gap: 2rem
    }

    .laptop\:px-0 {
        padding-left: 0;
        padding-right: 0
    }

    .laptop\:px-20 {
        padding-left: 2rem;
        padding-right: 2rem;
    }

    .laptop\:pb-20 {
        padding-bottom: 2rem
    }

    .laptop\:pb-280 {
        padding-bottom: 28rem
    }

    .laptop\:pb-\[45rem\] {
        padding-bottom: 45rem
    }

    .laptop\:pl-40 {
        padding-left: 4rem
    }

    .laptop\:pr-30 {
        padding-right: 3rem
    }

    .laptop\:pr-60 {
        padding-right: 6rem
    }

    .laptop\:pt-40 {
        padding-top: 4rem
    }

    .laptop\:text-9xl {
        font-size: 9.2rem
    }

    .laptop\:text-md {
        font-size: 1.5rem
    }

    .laptop\:text-xl {
        font-size: 1.6rem
    }

    .laptop\:leading-tight {
        line-height: 1.1
    }
}

/* === audit additions: graceful asset fallback & svgi defaults === */
img { color: transparent; }                      /* hide broken-image alt glyph */
img[alt=""] { color: transparent; }
[data-component="lazyload"]:not([src]) { visibility: hidden; }
.svgi { color: inherit; overflow: visible; }
.svgi use { fill: currentColor; }
