/*
! tailwindcss v3.2.4 | MIT License | https://tailwindcss.com
*/
*,
:after,
:before {
    border: 0 solid
}

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

html {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    -moz-tab-size: 4;
    -o-tab-size: 4;
    tab-size: 4;
    font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Helvetica Neue, Arial, Noto Sans, sans-serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol, Noto Color Emoji;
    font-feature-settings: normal
}

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

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

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: bolder
}

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

small {
    font-size: 80%
}

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

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

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

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

button,
select {
    text-transform: none
}

[type=button],
[type=reset],
[type=submit],
button {
    -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
}

textarea {
    resize: vertical
}

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

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

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

:disabled {
    cursor: default
}

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

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

[hidden] {
    display: none
}

*,
:after,
:before {
    --tw-border-spacing-x: 0;
    --tw-border-spacing-y: 0;
    --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;
    --tw-pan-x: ;
    --tw-pan-y: ;
    --tw-pinch-zoom: ;
    --tw-scroll-snap-strictness: proximity;
    --tw-ordinal: ;
    --tw-slashed-zero: ;
    --tw-numeric-figure: ;
    --tw-numeric-spacing: ;
    --tw-numeric-fraction: ;
    --tw-ring-inset: ;
    --tw-ring-offset-width: 0px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: rgba(59, 130, 246, .5);
    --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    --tw-blur: ;
    --tw-brightness: ;
    --tw-contrast: ;
    --tw-grayscale: ;
    --tw-hue-rotate: ;
    --tw-invert: ;
    --tw-saturate: ;
    --tw-sepia: ;
    --tw-drop-shadow: ;
    --tw-backdrop-blur: ;
    --tw-backdrop-brightness: ;
    --tw-backdrop-contrast: ;
    --tw-backdrop-grayscale: ;
    --tw-backdrop-hue-rotate: ;
    --tw-backdrop-invert: ;
    --tw-backdrop-opacity: ;
    --tw-backdrop-saturate: ;
    --tw-backdrop-sepia:
}

::backdrop {
    --tw-border-spacing-x: 0;
    --tw-border-spacing-y: 0;
    --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;
    --tw-pan-x: ;
    --tw-pan-y: ;
    --tw-pinch-zoom: ;
    --tw-scroll-snap-strictness: proximity;
    --tw-ordinal: ;
    --tw-slashed-zero: ;
    --tw-numeric-figure: ;
    --tw-numeric-spacing: ;
    --tw-numeric-fraction: ;
    --tw-ring-inset: ;
    --tw-ring-offset-width: 0px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: rgba(59, 130, 246, .5);
    --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    --tw-blur: ;
    --tw-brightness: ;
    --tw-contrast: ;
    --tw-grayscale: ;
    --tw-hue-rotate: ;
    --tw-invert: ;
    --tw-saturate: ;
    --tw-sepia: ;
    --tw-drop-shadow: ;
    --tw-backdrop-blur: ;
    --tw-backdrop-brightness: ;
    --tw-backdrop-contrast: ;
    --tw-backdrop-grayscale: ;
    --tw-backdrop-hue-rotate: ;
    --tw-backdrop-invert: ;
    --tw-backdrop-opacity: ;
    --tw-backdrop-saturate: ;
    --tw-backdrop-sepia:
}

.container {
    width: 100%
}

@media (min-width:640px) {
    .container {
        max-width: 640px
    }
}

@media (min-width:768px) {
    .container {
        max-width: 768px
    }
}

@media (min-width:1024px) {
    .container {
        max-width: 1024px
    }
}

@media (min-width:1280px) {
    .container {
        max-width: 1280px
    }
}

@media (min-width:1536px) {
    .container {
        max-width: 1536px
    }
}

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

.visible {
    visibility: visible
}

.invisible {
    visibility: hidden
}

.fixed {
    position: fixed
}

.absolute {
    position: absolute
}

.relative {
    position: relative
}

.sticky {
    position: sticky
}

.inset-0 {
    top: 0;
    right: 0;
    bottom: 0;
    left: 0
}

.bottom-2 {
    bottom: 16px
}

.right-2 {
    right: 16px
}

.top-3 {
    top: 24px
}

.left-3 {
    left: 24px
}

.bottom-3 {
    bottom: 24px
}

.right-3 {
    right: 24px
}

.top-0 {
    top: 0
}

.left-0 {
    left: 0
}

.right-0 {
    right: 0
}

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

.bottom-0 {
    bottom: 0
}

.left-\[-90px\] {
    left: -90px
}

.top-\[-62px\] {
    top: -62px
}

.left-full {
    left: 100%
}

.bottom-4 {
    bottom: 32px
}

.z-20 {
    z-index: 20
}

.z-10 {
    z-index: 10
}

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

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

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

.z-50 {
    z-index: 50
}

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

.z-30 {
    z-index: 30
}

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

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

.\!z-\[-1\] {
    z-index: -1 !important
}

.m-auto {
    margin: auto
}

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

.-mx-2 {
    margin-left: -16px;
    margin-right: -16px
}

.my-2 {
    margin-top: 16px;
    margin-bottom: 16px
}

.mb-6 {
    margin-bottom: 64px
}

.mb-3 {
    margin-bottom: 24px
}

.mb-4 {
    margin-bottom: 32px
}

.mb-7 {
    margin-bottom: 72px
}

.mb-5 {
    margin-bottom: 48px
}

.mb-0 {
    margin-bottom: 0
}

.mt-5 {
    margin-top: 48px
}

.mt-4 {
    margin-top: 32px
}

.mt-3 {
    margin-top: 24px
}

.ml-auto {
    margin-left: auto
}

.mb-2 {
    margin-bottom: 16px
}

.block {
    display: block
}

.inline-block {
    display: inline-block
}

.flex {
    display: flex
}

.inline-flex {
    display: inline-flex
}

.table {
    display: table
}

.grid {
    display: grid
}

.contents {
    display: contents
}

.hidden {
    display: none
}

.aspect-\[4\/3\] {
    aspect-ratio: 4/3
}

.h-screen {
    height: 100vh
}

.h-full {
    height: 100%
}

.h-3 {
    height: 24px
}

.h-\[500px\] {
    height: 500px
}

.max-h-\[500px\] {
    max-height: 500px
}

.min-h-0 {
    min-height: 0
}

.w-full {
    width: 100%
}

.w-5 {
    width: 48px
}

.w-3\/5 {
    width: 60%
}

.w-2\/5 {
    width: 40%
}

.w-3 {
    width: 24px
}

.w-6 {
    width: 64px
}

.w-4\/6 {
    width: 66.666667%
}

.w-1\/3 {
    width: 33.333333%
}

.w-\[20\%\] {
    width: 20%
}

.w-max {
    width: -moz-max-content;
    width: max-content
}

.w-1\/2 {
    width: 50%
}

.max-w-\[90\%\] {
    max-width: 90%
}

.max-w-\[30px\] {
    max-width: 30px
}

.flex-1 {
    flex: 1 1 0%
}

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

.flex-grow {
    flex-grow: 1
}

.origin-top {
    transform-origin: top
}

.origin-left {
    transform-origin: left
}

.-translate-y-1\/2 {
    --tw-translate-y: -50%
}

.-translate-y-1\/2,
.translate-y-full {
    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))
}

.translate-y-full {
    --tw-translate-y: 100%
}

.rotate-90 {
    --tw-rotate: 90deg;
    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-text {
    cursor: text
}

.resize {
    resize: both
}

.flex-col {
    flex-direction: column
}

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

.flex-wrap {
    flex-wrap: wrap
}

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

.items-center {
    align-items: center
}

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

.justify-center {
    justify-content: center
}

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

.gap-3 {
    gap: 24px
}

.gap-4 {
    gap: 32px
}

.gap-1 {
    gap: 8px
}

.gap-2 {
    gap: 16px
}

.gap-x-3 {
    -moz-column-gap: 24px;
    column-gap: 24px
}

.overflow-auto {
    overflow: auto
}

.overflow-hidden {
    overflow: hidden
}

.\!overflow-visible {
    overflow: visible !important
}

.whitespace-nowrap {
    white-space: nowrap
}

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

.border-y {
    border-top-width: 1px;
    border-bottom-width: 1px
}

.border-x {
    border-right-width: 1px
}

.border-l,
.border-x {
    border-left-width: 1px
}

.border-b {
    border-bottom-width: 1px
}

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

.border-y-black {
    --tw-border-opacity: 1;
    border-top-color: rgb(0 0 0/var(--tw-border-opacity));
    border-bottom-color: rgb(0 0 0/var(--tw-border-opacity))
}

.border-x-black {
    border-right-color: rgb(0 0 0/var(--tw-border-opacity))
}

.border-l-black,
.border-x-black {
    --tw-border-opacity: 1;
    border-left-color: rgb(0 0 0/var(--tw-border-opacity))
}

.border-b-black {
    --tw-border-opacity: 1;
    border-bottom-color: rgb(0 0 0/var(--tw-border-opacity))
}

.border-t-black {
    --tw-border-opacity: 1;
    border-top-color: rgb(0 0 0/var(--tw-border-opacity))
}

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

.bg-\[\#111\] {
    --tw-bg-opacity: 1;
    background-color: rgb(17 17 17/var(--tw-bg-opacity))
}

.bg-\[\#EBE9E4\] {
    --tw-bg-opacity: 1;
    background-color: rgb(235 233 228/var(--tw-bg-opacity))
}

.bg-green {
    --tw-bg-opacity: 1;
    background-color: #6f1124;
}

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

.bg-\[\#101010\] {
    --tw-bg-opacity: 1;
    background-color: rgb(16 16 16/var(--tw-bg-opacity))
}

.fill-white {
    fill: #fff
}

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

.object-left {
    -o-object-position: left;
    object-position: left
}

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

.p-3 {
    padding: 24px
}

.p-4 {
    padding: 32px
}

.p-0 {
    padding: 0
}

.p-2 {
    padding: 16px
}

.py-2 {
    padding-top: 16px;
    padding-bottom: 16px
}

.py-7 {
    padding-top: 72px;
    padding-bottom: 72px
}

.px-2 {
    padding-left: 16px;
    padding-right: 16px
}

.py-4 {
    padding-top: 32px;
    padding-bottom: 32px
}

.py-5 {
    padding-top: 48px;
    padding-bottom: 48px
}

.py-\[12px\] {
    padding-top: 12px;
    padding-bottom: 12px
}

.py-1 {
    padding-top: 8px;
    padding-bottom: 8px
}

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

.py-3 {
    padding-top: 24px;
    padding-bottom: 24px
}

.px-3 {
    padding-left: 24px;
    padding-right: 24px
}

.pt-\[15vh\] {
    padding-top: 15vh
}

.pb-6 {
    padding-bottom: 64px
}

.\!pt-0 {
    padding-top: 0 !important
}

.pb-7 {
    padding-bottom: 72px
}

.pb-0 {
    padding-bottom: 0
}

.pt-4 {
    padding-top: 32px
}

.\!pt-5 {
    padding-top: 48px !important
}

.pt-5 {
    padding-top: 48px
}

.pt-3 {
    padding-top: 24px
}

.text-left {
    text-align: left
}

.text-center {
    text-align: center
}

.text-right {
    text-align: right
}

.text-20 {
    font-size: 20px
}

.text-12 {
    font-size: 12px
}

.text-32 {
    font-size: 32px
}

.text-16 {
    font-size: 16px
}

.text-24 {
    font-size: 24px
}

.text-48 {
    font-size: 48px
}

.text-14 {
    font-size: 14px
}

.text-72 {
    font-size: 72px
}

.text-18 {
    font-size: 18px
}

.text-96 {
    font-size: 96px
}

.font-medium {
    font-weight: 500
}

.font-semibold {
    font-weight: 600
}

.uppercase {
    text-transform: uppercase
}

.leading-none {
    line-height: 1
}

.leading-\[100\%\] {
    line-height: 100%
}

.leading-\[80\%\] {
    line-height: 80%
}

.leading-\[120\%\] {
    line-height: 120%
}

.tracking-\[2px\] {
    letter-spacing: 2px
}

.text-white {
    --tw-text-opacity: 1;
    color: rgb(255 255 255/var(--tw-text-opacity))
}

.text-green {
    --tw-text-opacity: 1;
    color: #6f1124
}

.text-\[\#F07B48\] {
    --tw-text-opacity: 1;
    color: rgb(240 123 72/var(--tw-text-opacity))
}

.\!text-white {
    --tw-text-opacity: 1 !important;
    color: rgb(255 255 255/var(--tw-text-opacity)) !important
}

.text-black {
    --tw-text-opacity: 1;
    color: rgb(0 0 0/var(--tw-text-opacity))
}

.underline {
    text-decoration-line: underline
}

.opacity-0 {
    opacity: 0
}

.\!opacity-0 {
    opacity: 0 !important
}

.\!opacity-100 {
    opacity: 1 !important
}

.opacity-100 {
    opacity: 1
}

.mix-blend-exclusion {
    mix-blend-mode: exclusion
}

.blur-0 {
    --tw-blur: blur(0)
}

.blur-0,
.blur-2xl {
    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)
}

.blur-2xl {
    --tw-blur: blur(40px)
}

.invert {
    --tw-invert: invert(100%);
    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-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-duration: .15s
}

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

.duration-300 {
    transition-duration: .3s
}

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

.ease-out {
    transition-timing-function: cubic-bezier(0, 0, .2, 1)
}

.tns-outer {
    padding: 0 !important;
    position: relative;
    overflow: visible
}

.tns-outer [hidden] {
    display: none !important
}

.tns-outer [aria-controls],
.tns-outer [data-action] {
    cursor: pointer
}

.tns-slider {
    transition: all 0s;
    display: flex
}

.tns-slider>.tns-item {
    box-sizing: border-box
}

.equal-height .tns-item {
    min-height: 100%
}

.equal-height .tns-item>div {
    height: 100%
}

.slider-overflow-visible .tns-ovh {
    overflow: visible
}

.tns-horizontal.tns-subpixel {
    white-space: nowrap
}

.tns-horizontal.tns-subpixel>.tns-item {
    display: inline-block;
    vertical-align: middle;
    white-space: normal
}

.tns-horizontal.tns-no-subpixel:after {
    content: "";
    display: table;
    clear: both
}

.tns-horizontal.tns-no-subpixel>.tns-item {
    float: left
}

.tns-horizontal.tns-carousel.tns-no-subpixel>.tns-item {
    margin-right: -100%
}

.tns-gallery,
.tns-no-calc {
    position: relative;
    left: 0
}

.tns-gallery {
    min-height: 1px
}

.tns-gallery>.tns-item {
    position: absolute;
    left: -100%;
    transition: transform 0s, opacity 0s
}

.tns-gallery>.tns-slide-active {
    position: relative;
    left: auto !important
}

.tns-gallery>.tns-moving {
    transition: all .25s
}

.tns-autowidth {
    display: inline-block
}

.tns-lazy-img {
    transition: opacity .6s;
    opacity: .6
}

.tns-lazy-img.tns-complete {
    opacity: 1
}

.tns-ah {
    transition: height 0s
}

.tns-ovh {
    overflow: hidden
}

.tns-visually-hidden {
    position: absolute;
    left: -10000em
}

.tns-transparent {
    opacity: 0;
    visibility: hidden
}

.tns-fadeIn {
    opacity: 1;
    filter: alpha(opacity=100);
    z-index: 0
}

.tns-fadeOut,
.tns-normal {
    opacity: 0;
    filter: alpha(opacity=0);
    z-index: -1
}

.tns-vpfix {
    white-space: nowrap
}

.tns-vpfix>div,
.tns-vpfix>li {
    display: inline-block
}

.tns-t-subp2 {
    margin: 0 auto;
    width: 310px;
    position: relative;
    height: 10px;
    overflow: hidden
}

.tns-t-ct {
    width: 2333.3333333333%;
    width: calc(100% * 70 / 3);
    position: absolute;
    right: 0
}

.tns-t-ct:after {
    content: "";
    display: table;
    clear: both
}

.tns-t-ct>div {
    width: 1.4285714286%;
    width: calc(100% / 70);
    height: 10px;
    float: left
}

.tns-controls {
    display: flex;
    gap: 15px
}

.tns-controls button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    background-color: transparent;
    border: 1px solid aqua;
    line-height: 0;
    font-size: 0;
    cursor: pointer;
    color: transparent;
    padding: 0;
    outline: none;
    z-index: 99;
    border-radius: 50%
}

.tns-controls button:focus {
    outline: none
}

.tns-controls button:disabled {
    opacity: .4;
    pointer-events: none
}

.tns-controls button:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(4 179 0/var(--tw-bg-opacity))
}

.tns-controls button:hover svg path {
    stroke: #000
}

.tns-nav {
    position: absolute;
    bottom: -140px;
    right: -72px;
    display: flex;
    gap: 8px;
    justify-content: flex-end
}

.tns-nav button {
    width: 10px;
    height: 10px;
    background-color: #fff;
    border-radius: 50%
}

.tns-nav .tns-nav-active {
    background-color: aqua
}

@media(max-width:767px) {
    .tns-nav {
        bottom: -60px;
        right: 0;
        left: 0;
        justify-content: center
    }
}

@media(max-width:990px) {
    .tns-arrows-mobile .tns-controls {
        display: flex;
        justify-content: center
    }

    .tns-arrows-mobile .tns-controls button {
        left: 0;
        right: 0;
        position: relative;
        margin: 0 8px
    }
}

.black-controls .tns-controls button {
    border: 1px solid #000
}

.black-controls .tns-controls button svg path {
    stroke: #000;
    transition: .4s ease-out
}

.black-controls .tns-controls button:hover {
    background-color: #000
}

.black-controls .tns-controls button:hover svg path {
    stroke: #fff
}

.controls-center .tns-controls {
    margin: 50px;
    justify-content: center
}

.header-main:before {
    position: absolute;
    left: 0;
    bottom: 0;
    height: 1px;
    width: 100%;
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255/var(--tw-bg-opacity));
    content: ""
}

.nav-main .nav-menu-wrapper a {
    color: #fff
}

@media(max-width:1200px) {
    .nav-main .nav-menu-wrapper {
        position: fixed;
        right: 0;
        top: 0;
        bottom: 0;
        background-color: #000;
        width: 100%;
        max-width: 150px;
        padding: 80px 0 0;
        transition: .4s ease-out;
        transform: translateX(100%);
        display: flex;
        flex-direction: column
    }

    .nav-main .nav-menu-wrapper .nav-links {
        flex: 1;
        gap: 72px;
        flex-direction: column;
        align-items: center
    }

    .nav-main .nav-menu-wrapper a {
        writing-mode: vertical-lr
    }
}

.nav-main.nav-active .nav-menu-wrapper {
    transform: translateX(0)
}

.hamburger {
    text-align: right;
    width: 100px
}

.hamburger .hamburger-text span {
    display: inline-flex;
    align-items: center;
    gap: 8px
}

.hamburger .hamburger-text span:nth-child(2) {
    position: absolute;
    inset: 0;
    transform: translateY(100%) skewY(18deg);
    transform-origin: left center;
    transition: .4s ease-out
}

.hamburger .hamburger-text span:first-child {
    transform: translateY(0) skew(0);
    transition: .4s ease-out
}

.hamburger .hamburger-text svg {
    transition: .4s ease-out
}

.hamburger.active .hamburger-text span:nth-child(2) {
    transform: translateY(0) skewY(0)
}

.hamburger.active .hamburger-text span:first-child {
    transform: translateY(-100%) skew(-18deg);
    transition: .4s ease-out
}

@font-face {
    font-family: Neue Montreal;
    src: url(../../../fonts/NeueMontreal-Bold.woff2) format("woff2"), url(../../../fonts/NeueMontreal-Bold.woff) format("woff");
    font-weight: 700;
    font-style: normal;
    font-display: swap
}

@font-face {
    font-family: Neue Montreal;
    src: url(../../../fonts/NeueMontreal-Regular.woff2) format("woff2"), url(../../../fonts/NeueMontreal-Regular.woff) format("woff");
    font-weight: 400;
    font-style: normal;
    font-display: swap
}

@font-face {
    font-family: Neue Montreal;
    src: url(../../../fonts/NeueMontreal-Medium.woff2) format("woff2"), url(../../../fonts/NeueMontreal-Medium.woff) format("woff");
    font-weight: 500;
    font-style: normal;
    font-display: swap
}

*,
:after,
:before {
    box-sizing: border-box;
    -webkit-overflow-scrolling: touch;
    outline: none
}

html {
    background: #fff
}

body,
html {
    margin: 0;
    padding: 0;
    font-family: sans-serif
}

body {
    font-family: Neue Montreal;
    font-size: 14px;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255/var(--tw-bg-opacity));
    --tw-text-opacity: 1;
    color: rgb(0 0 0/var(--tw-text-opacity));
    line-height: 1.4;
    letter-spacing: .6px
}

body,
body * {
    cursor: none
}

ol,
ul {
    padding: 0
}

a {
    transition: all .2s
}

a,
a:active,
a:focus,
a:hover {
    text-decoration: none
}

p {
    margin-bottom: 25px;
    font-size: .9722222222vw
}

@media(max-width:1200px) {
    p {
        font-size: 14px
    }
}

button {
    font-family: Neue Montreal;
    transition: .3s ease
}

main {
    max-width: 100vw
}

.container {
    max-width: 1290px;
    padding: 0 15px;
    margin: 0 auto
}

@media(min-width:1800px) {
    .container {
        max-width: 1600px
    }
}

@media(min-width:2200px) {
    .container {
        max-width: 2000px
    }
}

.arrow-container {
    width: calc((100vw - 1070px)/2)
}

@media(min-width:1800px) {
    .arrow-container {
        width: calc((100vw - 1370px)/2)
    }
}

@media(min-width:2200px) {
    .arrow-container {
        width: calc((100vw - 1775px)/2)
    }
}

.small-container {
    max-width: 994px;
    padding: 0 15px;
    margin: 0 auto
}

.button {
    line-height: 22px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 500;
    --tw-text-opacity: 1;
    color: rgb(0 0 0/var(--tw-text-opacity));
    transition: .4s ease-out;
    gap: 10px
}

.button div .button-content-hover {
    position: absolute;
    inset: 0;
    transform: translateY(100%) skewY(18deg);
    transform-origin: left center;
    transition: .4s ease-out
}

.button div .button-content {
    transform: translateY(0) skew(0);
    transition: .4s ease-out;
    display: inline-block
}

.button svg {
    transition: .4s ease-out
}

.button:hover div .button-content-hover {
    transform: translateY(0) skewY(0)
}

.button:hover div .button-content {
    transform: translateY(-100%) skew(-18deg);
    transition: .4s ease-out
}

.button:hover svg {
    transform: translateX(10px)
}

.button svg path {
    transition: .4s ease-out
}

.button:hover {
    --tw-text-opacity: 1;
    color: #6f1124;
}

.button.button-secondary {
    background-color: transparent;
    --tw-text-opacity: 1;
    color: rgb(255 255 255/var(--tw-text-opacity))
}

.button.button-secondary:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(4 179 0/var(--tw-bg-opacity));
    --tw-text-opacity: 1;
    color: rgb(255 255 255/var(--tw-text-opacity))
}

.button.button-black {
    border-color: rgb(0 0 0/var(--tw-border-opacity));
    background-color: rgb(0 0 0/var(--tw-bg-opacity))
}

.button.button-black,
.button.button-black:hover {
    --tw-border-opacity: 1;
    --tw-bg-opacity: 1;
    --tw-text-opacity: 1;
    color: rgb(255 255 255/var(--tw-text-opacity))
}

.button.button-black:hover {
    border-color: rgb(4 179 0/var(--tw-border-opacity));
    background-color: rgb(4 179 0/var(--tw-bg-opacity))
}

.button.button-small {
    padding: 12px 24px
}

@media(max-width:990px) {
    .button {
        font-size: 14px
    }
}

.line-button {
    padding-bottom: 5px;
    position: relative
}

.line-button:after,
.line-button:before {
    position: absolute;
    bottom: 0;
    width: 100%;
    height: 1px;
    content: "";
    background-color: #fff;
    left: 0;
    transition: .4s ease-out;
    transform-origin: right
}

.line-button:after {
    transform-origin: left;
    transform: scaleX(0)
}

.line-button.animating:after {
    animation: scale-x-up .4s ease-out 1 forwards;
    animation-delay: .5s
}

.line-button.animating:before {
    animation: scale-x-down .4s ease-out 1 forwards
}

@media(max-width:767px) {
    .line-button {
        font-size: 14px
    }
}

.section-pad {
    padding-top: 120px;
    padding-bottom: 120px
}

@media(max-width:767px) {
    .section-pad {
        padding-top: 64px;
        padding-bottom: 64px
    }
}

@keyframes scale-x-up {
    0% {
        transform: scaleX(0)
    }

    to {
        transform: scaleX(1)
    }
}

@keyframes scale-x-down {
    0% {
        transform: scaleX(1)
    }

    to {
        transform: scaleX(0)
    }
}

.heading {
    font-size: 48px;
    font-weight: 700;
    line-height: 130%
}

@media(max-width:1200px) {
    .heading {
        font-size: 32px
    }
}

@keyframes fadein {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

.fadein {
    animation: fadein .4s ease-out 1 forwards
}

.single-section {
    width: 100%;
    overflow: hidden;
    height: 100vh;
    background-color: #fff;
    padding-top: 56px
}

@media(max-width:1200px) {
    .single-section {
        height: auto;
        padding: 0;
        margin-bottom: 64px
    }
}

.vertical-orientation-text {
    writing-mode: vertical-rl;
    text-orientation: mixed
}

.vertical-orientation-text-2 {
    writing-mode: vertical-lr
}

.social-links a {
    position: relative
}

.social-links a:not(:last-child):after {
    position: absolute;
    right: -8px;
    top: 0;
    content: "|"
}

.social-links.social-link-alt a:not(:last-child):after {
    right: -16px
}

@media(max-width:767px) {
    .social-links.social-link-alt a:not(:last-child):after {
        position: absolute;
        right: -16px;
        top: 0;
        content: "|"
    }
}

.vertical-text-wrapper {
    max-height: calc(100vh - 91px)
}

.extended-borders-right:after {
    position: absolute;
    width: calc((100vw - 1260px)/2);
    left: 100%;
    content: "";
    top: -1px;
    height: calc(100% + 2px);
    border-top: 1px solid #000;
    border-bottom: 1px solid #000
}

.accordion-answer {
    grid-template-rows: 0fr;
    transition: grid-template-rows .5s
}

.accordion-answer.active {
    grid-template-rows: 1fr
}

.anchor-animation div:nth-child(2) {
    position: absolute;
    inset: 0;
    transform: translateY(100%) skewY(18deg);
    transform-origin: left center;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: .4s ease-out
}

.anchor-animation div:first-child {
    transform: translateY(0) skew(0);
    transition: .4s ease-out;
    display: inline-block
}

.anchor-animation svg {
    transition: .4s ease-out
}

.anchor-animation:hover div:nth-child(2) {
    transform: translateY(0) skewY(0)
}

.anchor-animation:hover div:first-child {
    transform: translateY(-100%) skew(-18deg);
    transition: .4s ease-out
}

.anchor-animation:hover svg {
    transform: translateX(10px)
}

.single-project-block button {
    position: relative;
    overflow: hidden
}

.single-project-block button:before {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    height: 100%;
    width: 100%;
    --tw-bg-opacity: 1;
    background-color: rgb(0 0 0/var(--tw-bg-opacity));
    content: "";
    transition: .3s ease-out;
    transform: translateY(-100%);
    animation: dropdown2 .3s ease-out 1 forwards
}

@media(hover:hover) {
    .single-project-block button:hover:before {
        animation: dropdown .3s ease-out 1 forwards
    }

    .single-project-block button:hover * {
        color: #fff
    }
}

@keyframes dropdown {
    0% {
        transform: translateY(-105%)
    }

    to {
        transform: translateY(0)
    }
}

@keyframes dropdown2 {
    0% {
        transform: translateY(0)
    }

    to {
        transform: translateY(105%)
    }
}

.cursor {
    width: 20px;
    height: 20px;
    position: fixed;
    pointer-events: none;
    transition: background .2s, width .2s, height .2s, box-shadow .2s;
    transform: translate(-7px, -3px);
    left: -10px;
    top: -8px
}

.cursor,
.cursor .cursor-inner {
    border-radius: 50%;
    display: flex
}

.cursor .cursor-inner {
    width: 100%;
    height: 100%;
    background-color: #fff;
    transition: .2s ease-out;
    align-items: center;
    justify-content: center;
    font-weight: 500;
    line-height: 100%;
    text-transform: uppercase
}

@media(max-width:1200px) {
    .cursor {
        display: none
    }
}

.expand .cursor-inner {
    transform: scale(4)
}

.expand .cursor-inner span {
    transform: scale(.3);
    display: block
}

.loader-text-wrapper .loader-text {
    font-size: 90px;
    text-align: center
}

.loader-text-wrapper .loader-text:not(:first-child) {
    position: absolute;
    left: 0;
    right: 0;
    top: 0
}

@media(max-width:767px) {
    .loader-text-wrapper .loader-text {
        font-size: 48px
    }
}

.loader-curtain {
    transform: scaleX(0)
}

.loader-curtain.animating {
    animation: loader-curtain 2s ease-out 1 forwards
}

@keyframes loader-curtain {
    0% {
        transform: scaleX(0)
    }

    40% {
        transform: scaleX(1)
    }

    50% {
        transform: scaleX(1);
        transform: scaleY(1)
    }

    to {
        transform: scaleY(0)
    }
}

@media(min-width:991px) {
    .cs-project-name {
        writing-mode: sideways-lr
    }
}

.cs-table td {
    padding: 24px 0;
    border-bottom: 1px solid #111;
    vertical-align: text-top
}

.cs-table td:first-child {
    width: 25%;
    padding-right: 16px
}

.cs-table tr:last-child td {
    border: none
}

.cs-small-overview {
    position: relative
}

.cs-small-overview:before {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    width: 100%;
    height: 50%;
    content: "";
    background-color: var(--tooltip-color);
    z-index: 0
}

.marquee-left,
.marquee-right {
    animation: marquee-left 20s linear infinite forwards
}

.marquee-right {
    transform: translateX(50%);
    animation-direction: reverse
}

@keyframes marquee-left {
    0% {
        transform: translateX(0)
    }

    to {
        transform: translateX(-50%)
    }
}

.loader-curtain {
    transition: all .8s cubic-bezier(.985, .115, .04, .87)
}

.pseudo-bottom-border:after {
    bottom: 0;
    transition: width .6s cubic-bezier(.65, 0, .35, 1)
}

.pseudo-bottom-border:after,
.pseudo-top-border:after {
    position: absolute;
    left: 0;
    height: 1px;
    width: 0;
    --tw-bg-opacity: 1;
    background-color: rgb(0 0 0/var(--tw-bg-opacity));
    --tw-content: "";
    content: var(--tw-content)
}

.pseudo-top-border:after {
    top: 0;
    transition: width .6s cubic-bezier(.65, 0, .35, 1)
}

.pseudo-left-border:after {
    position: absolute;
    left: 0;
    bottom: 0;
    top: 0;
    height: 0;
    width: 1px;
    --tw-bg-opacity: 1;
    background-color: rgb(0 0 0/var(--tw-bg-opacity));
    --tw-content: "";
    content: var(--tw-content);
    transition: height .6s cubic-bezier(.65, 0, .35, 1)
}

.loaded .pseudo-bottom-border:after,
.loaded .pseudo-top-border:after {
    width: 100%
}

.loaded .pseudo-left-border:after {
    height: 100%
}

html.lenis {
    height: 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
}

.hover\:bg-black:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(0 0 0/var(--tw-bg-opacity))
}

.group:hover .group-hover\:-translate-y-full {
    --tw-translate-y: -100%
}

.group:hover .group-hover\:-translate-y-full,
.group:hover .group-hover\:translate-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))
}

.group:hover .group-hover\:translate-y-0 {
    --tw-translate-y: 0px
}

@media (min-width:768px) {
    .md\:absolute {
        position: absolute
    }

    .md\:right-6 {
        right: 64px
    }

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

    .md\:ml-\[10\%\] {
        margin-left: 10%
    }

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

    .md\:ml-\[45\%\] {
        margin-left: 45%
    }

    .md\:mb-\[150px\] {
        margin-bottom: 150px
    }

    .md\:mb-\[94px\] {
        margin-bottom: 94px
    }

    .md\:block {
        display: block
    }

    .md\:inline {
        display: inline
    }

    .md\:flex {
        display: flex
    }

    .md\:h-full {
        height: 100%
    }

    .md\:w-1\/2 {
        width: 50%
    }

    .md\:w-1\/3 {
        width: 33.333333%
    }

    .md\:w-2\/5 {
        width: 40%
    }

    .md\:w-3\/5 {
        width: 60%
    }

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

    .md\:w-1\/4 {
        width: 25%
    }

    .md\:w-full {
        width: 100%
    }

    .md\:w-\[7\%\] {
        width: 7%
    }

    .md\:w-\[48\%\] {
        width: 48%
    }

    .md\:w-\[44\%\] {
        width: 44%
    }

    .md\:w-3\/4 {
        width: 75%
    }

    .md\:w-2\/3 {
        width: 66.666667%
    }

    .md\:max-w-\[80\%\] {
        max-width: 80%
    }

    .md\:max-w-\[92\%\] {
        max-width: 92%
    }

    .md\:max-w-\[70\%\] {
        max-width: 70%
    }

    .md\:max-w-\[60\%\] {
        max-width: 60%
    }

    .md\:max-w-\[50\%\] {
        max-width: 50%
    }

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

    .md\:max-w-\[65\%\] {
        max-width: 65%
    }

    .md\:flex-1 {
        flex: 1 1 0%
    }

    .md\:rotate-0 {
        --tw-rotate: 0deg;
        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))
    }

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

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

    .md\:flex-nowrap {
        flex-wrap: nowrap
    }

    .md\:justify-center {
        justify-content: center
    }

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

    .md\:gap-4 {
        gap: 32px
    }

    .md\:whitespace-nowrap {
        white-space: nowrap
    }

    .md\:border-b {
        border-bottom-width: 1px
    }

    .md\:border-b-white {
        --tw-border-opacity: 1;
        border-bottom-color: rgb(255 255 255/var(--tw-border-opacity))
    }

    .md\:bg-white {
        --tw-bg-opacity: 1;
        background-color: rgb(255 255 255/var(--tw-bg-opacity))
    }

    .md\:fill-black {
        fill: #000
    }

    .md\:p-4 {
        padding: 32px
    }

    .md\:py-0 {
        padding-top: 0;
        padding-bottom: 0
    }

    .md\:py-7 {
        padding-top: 72px;
        padding-bottom: 72px
    }

    .md\:\!px-2 {
        padding-left: 16px !important;
        padding-right: 16px !important
    }

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

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

    .md\:py-6 {
        padding-top: 64px;
        padding-bottom: 64px
    }

    .md\:py-5 {
        padding-top: 48px;
        padding-bottom: 48px
    }

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

    .md\:pt-6 {
        padding-top: 64px
    }

    .md\:pl-\[10\%\] {
        padding-left: 10%
    }

    .md\:pb-6 {
        padding-bottom: 64px
    }

    .md\:pl-3 {
        padding-left: 24px
    }

    .md\:pl-8 {
        padding-left: 96px
    }

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

    .md\:text-left {
        text-align: left
    }

    .md\:text-right {
        text-align: right
    }

    .md\:text-16 {
        font-size: 16px
    }

    .md\:text-\[54px\] {
        font-size: 54px
    }

    .md\:text-48 {
        font-size: 48px
    }

    .md\:text-\[200px\] {
        font-size: 200px
    }

    .md\:text-20 {
        font-size: 20px
    }

    .md\:text-\[148px\] {
        font-size: 148px
    }

    .md\:text-14 {
        font-size: 14px
    }

    .md\:text-32 {
        font-size: 32px
    }

    .md\:text-\[calc\(\(150\)\/1440\*100vw\)\] {
        font-size: calc((150) / 1440 * 100vw)
    }

    .md\:text-64 {
        font-size: 64px
    }

    .md\:text-24 {
        font-size: 24px
    }

    .md\:text-\[calc\(\(90\)\/1440\*100vw\)\] {
        font-size: calc((90) / 1440 * 100vw)
    }

    .md\:leading-\[72px\] {
        line-height: 72px
    }

    .md\:text-white {
        --tw-text-opacity: 1;
        color: rgb(255 255 255/var(--tw-text-opacity))
    }

    .md\:text-black {
        --tw-text-opacity: 1;
        color: rgb(0 0 0/var(--tw-text-opacity))
    }

    .md\:mix-blend-exclusion {
        mix-blend-mode: exclusion
    }
}

@media (min-width:1024px) {
    .lg\:mb-0 {
        margin-bottom: 0
    }

    .lg\:ml-\[25\%\] {
        margin-left: 25%
    }

    .lg\:w-2\/5 {
        width: 40%
    }

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

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

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

    .lg\:self-end {
        align-self: flex-end
    }

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

    .lg\:text-right {
        text-align: right
    }
}

@media (min-width:1280px) {
    .xl\:fixed {
        position: fixed
    }

    .xl\:ml-8 {
        margin-left: 96px
    }

    .xl\:block {
        display: block
    }

    .xl\:flex {
        display: flex
    }

    .xl\:hidden {
        display: none
    }

    .xl\:w-\[600\%\] {
        width: 600%
    }

    .xl\:max-w-\[60\%\] {
        max-width: 60%
    }

    .xl\:items-center {
        align-items: center
    }

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

    .xl\:border-t-0 {
        border-top-width: 0
    }

    .xl\:bg-transparent {
        background-color: transparent
    }

    .xl\:px-4 {
        padding-right: 32px
    }

    .xl\:pl-4,
    .xl\:px-4 {
        padding-left: 32px
    }

    .xl\:text-32 {
        font-size: 32px
    }

    .xl\:text-para {
        font-size: calc((14) / 1440 * 100vw)
    }

    .xl\:mix-blend-exclusion {
        mix-blend-mode: exclusion
    }
}

.upgrade-now {
    background-repeat: no-repeat;
    background-position: 100% 0;
    background-size: auto 100%
}

@media(max-width:767px) {
    .upgrade-now {
        height: auto;
        background-size: contain;
        background-position: bottom
    }
}

.sticky-section-main .design-elements-main .design-element:first-child {
    transform: scaleX(-1);
    top: 160px;
    right: 0
}

.sticky-section-main .sticky-scoll-imgs {
    display: flex;
    min-height: 420px
}

.sticky-section-main .sticky-scoll-imgs img {
    position: absolute;
    transition: all .5s ease-out;
    opacity: 1;
    top: 0
}

@media(min-width:768px) {
    .sticky-section-main .sticky-scoll-imgs img {
        opacity: 0
    }
}

.sticky-section-main .sticky-scoll-imgs img.active {
    opacity: 1
}

.sticky-section-main .sticky-scroll-content .single-scroll-content {
    padding: 60px 0 0
}

.sticky-section-main .sticky-scroll-content .single-scroll-content:last-child {
    padding-bottom: 0
}

@media(min-width:767px) {
    .sticky-section-main .sticky-scroll-content .single-scroll-content:last-child {
        padding-bottom: 60px
    }
}

@media(max-width:767px) {
    .sticky-section-main .sticky-scroll-content .single-scroll-content {
        padding: 0 0 50px;
        opacity: 1 !important
    }

    .sticky-section-main {
        overflow: hidden
    }
}

.slider-section .tns-item {
    cursor: grab
}