@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&display=swap";* {
    box-sizing: border-box;
    -webkit-user-select: none;
    user-select: none;
    -webkit-user-drag: none;
    overscroll-behavior: none
}

html,body {
    font-family: DM Sans,sans-serif;
    font-optical-sizing: auto;
    line-height: 1.5;
    font-weight: 400;
    color-scheme: light dark;
    color: #ffffffde;
    padding: 0;
    margin: 0;
    -webkit-user-select: none;
    user-select: none;
    overflow: hidden;
    box-sizing: border-box;
    font-synthesis: none;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-text-size-adjust: 100%;
    height: 100%;
    width: 100%
}

body {
    position: fixed;
    background-color: #101010;
    background: radial-gradient(circle at bottom center,#291642,#221236 80%)
}

#root {
    height: 100%;
    width: 100%
}

canvas {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.caption {
    pointer-events: none;
    position: fixed;
    top: 0;
    right: 0;
    margin: 80px;
    color: #fff;
    font-size: 8em;
    font-weight: 100;
    line-height: 1em;
    font-variant-numeric: tabular-nums;
    -webkit-font-smoothing: auto
}

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

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

.lenis.lenis-stopped {
    overflow: hidden
}

.btn-model-logo {
    position: relative;
    width: 100px;
    height: 100px;
    border-radius: 50%;
    border: 1px solid #fff;
    transition: all .4s ease-in-out;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer
}

.btn-model-logo svg {
    transform: rotate(-60deg)
}

.btn-model-logo:hover {
    transform: scale(1.2)
}

.btn-model-text {
    position: relative;
    top: 20px;
    left: -140px;
    width: 200px;
    padding: 10px 20px;
    background-color: #101010;
    border-radius: 30px;
    border: 1px solid #fff;
    font-size: 18px;
    transition: all .4s ease-in-out;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    border: none;
    cursor: pointer;
    z-index: 1
}

.btn-model-text:focus-visible {
    outline: none
}

.btn,.btn-primary {
    position: relative;
    display: inline-block;
    border-radius: 999em;
    color: #fff;
    font-size: 14px;
    letter-spacing: .075em;
    text-transform: uppercase;
    display: flex;
    pointer-events: all;
    cursor: pointer
}

.btn__inner,.btn-primary__inner {
    background-color: #874ad5;
    padding: 1px;
    position: relative;
    z-index: 2;
    display: block;
    overflow: hidden;
    border-radius: inherit
}

.btn__inner:before,.btn-primary__inner:before {
    position: absolute;
    top: 4px;
    right: 4px;
    bottom: 4px;
    left: 4px;
    z-index: 1;
    display: block;
    animation: btn-glow 5s infinite linear;
    background: linear-gradient(20deg,#874ad5,#ffbd1e20 16.5%,#fe848f,#fe848f20,#874ad5 66%,#00f8f160 85.5%,#ffbd1e) 0 100%/100% 200%;
    border-radius: inherit;
    filter: blur(5px);
    mix-blend-mode: overlay;
    opacity: 0;
    transition: opacity .2s linear .1s;
    content: ""
}

.btn__label,.btn-primary__label {
    position: relative;
    display: block;
    overflow: hidden;
    padding: .95em 2em .9em;
    border-radius: inherit;
    color: transparent;
    white-space: nowrap;
    text-align: center
}

.btn__label:before,.btn__label:after,.btn-primary__label:before,.btn-primary__label:after {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
    display: block;
    padding: inherit;
    width: -webkit-fill-available;
    height: 100%;
    color: #fff;
    white-space: nowrap;
    transition: transform .3s cubic-bezier(1,0,0,1) 0s
}

.btn__label:before,.btn-primary__label:before {
    transform: translateZ(0);
    content: attr(data-label)
}

.btn__label:after,.btn-primary__label:after {
    transform: translate3d(0,-100%,0);
    content: attr(data-hover)
}

.btn__label__background,.btn-primary__label__background {
    position: absolute;
    top: -100px;
    right: -100px;
    bottom: -100px;
    left: -100px;
    display: block
}

.btn__background,.btn-primary__background {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    display: block;
    width: fit-content;
    height: 100%;
    border-radius: inherit
}

.btn__background:before,.btn__background:after,.btn-primary__background:before,.btn-primary__background:after {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    display: block;
    border-radius: inherit;
    content: ""
}

.btn__background:after,.btn-primary__background:after {
    animation: btn-glow 5s infinite linear;
    background: linear-gradient(-20deg,#874ad5,#874ad520 16.5%,#874ad5,#874ad510,#874ad5 66%,#874ad500 85.5%,#874ad5) 0 100%/100% 200%;
    filter: blur(5px);
    opacity: 0;
    transition: opacity 0s linear 0s
}

.btn:hover .btn__background:before,.btn-primary:hover .btn__background:before {
    background: #874ad5;
    transition: background .07s linear
}

.btn:hover .btn__background:after,.btn-primary:hover .btn__background:after {
    opacity: 1;
    transition: opacity .4s cubic-bezier(.55,.085,.68,.53) 0s
}

.btn:hover .btn__inner:before,.btn-primary:hover .btn__inner:before {
    opacity: 1
}

.btn:hover .btn__label:before,.btn:hover .btn__label:after,.btn-primary:hover .btn__label:before,.btn-primary:hover .btn__label:after {
    transition-duration: .6s;
    transition-timing-function: cubic-bezier(1,-.6,0,1.6)
}

.btn:hover .btn__label:before,.btn-primary:hover .btn__label:before {
    transform: translate3d(0,100%,0)
}

.btn:hover .btn__label:after,.btn-primary:hover .btn__label:after {
    transform: translateZ(0)
}

@keyframes noise-background {
    0% {
        transform: translateZ(0)
    }

    20% {
        transform: translate3d(50px,30px,0)
    }

    40% {
        transform: translate3d(10px,50px,0)
    }

    60% {
        transform: translate3d(30px,20px,0)
    }

    80% {
        transform: translate3d(50px,0,0)
    }

    to {
        transform: translate3d(100px,0,0)
    }
}

@keyframes btn-glow {
    0% {
        background-position: 0 100%
    }

    to {
        background-position: 0 300%
    }
}

@media only screen and (max-width: 1000px) {
    .caption {
        font-size:4em
    }
}

@media only screen and (max-width: 800px) {
    .caption {
        font-size:3em
    }

    .dot>h1 {
        font-size: 3em
    }
}

@media only screen and (max-width: 700px) {
    .caption {
        font-size:2em
    }

    .dot>h1 {
        font-size: 3em
    }
}

@media only screen and (max-width: 600px) {
    .caption {
        font-size:1em
    }

    .dot>h1 {
        font-size: 3em
    }
}

.cursor {
    position: fixed;
    width: 20px;
    height: 20px;
    background-color: #000;
    border-radius: 50%;
    pointer-events: none;
    transform: translate(-50%,-50%);
    z-index: 9999
}

.wrapper-overlay {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    overflow-y: auto
}

.wrapper-overlay .scroll-content {
    position: relative;
    height: 100dvh;
    width: 100%
}

.wrapper-overlay .scroll-content .section {
    pointer-events: none;
    height: 100%;
    width: 100%;
    padding: 60px 6%
}

@media screen and (max-width: 1024px) {
    .wrapper-overlay .scroll-content .section {
        padding:15px 6%
    }
}

#possibilities {
    overflow: hidden
}

@media screen and (max-width: 780px) {
    #possibilities {
        height:auto
    }
}

.possibilities {
    position: relative;
    align-items: flex-start;
    justify-content: flex-start;
    flex-direction: column;
    overflow: hidden;
    padding: 105px 6%!important
}

.possibilities .description {
    text-align: justify;
    font-size: 18px
}

.possibilities .wrapperRollingText {
    white-space: nowrap;
    margin-top: calc(20dvh - 120px)
}

@media screen and (max-width: 780px) {
    .possibilities .wrapperRollingText {
        margin-top:calc(40dvh - 250px)
    }
}

.possibilities .wrapperRollingText .rollingText {
    position: relative;
    font-size: clamp(2rem,6vw,6rem);
    display: inline-block;
    padding-left: 10px
}

.possibilities .wrapperRollingText .divider {
    position: relative
}

.possibilities .wrapperRollingText .divider:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    width: .5em;
    height: .2em;
    background-color: #874ad5;
    border-radius: 2em
}

.possibilities .title {
    width: 80%
}

@media screen and (max-width: 780px) {
    .possibilities .title {
        height:auto;
        line-height: 150%
    }
}

.possibilities .title span {
    font-size: clamp(2rem,6vw,3rem)
}

.possibilities .title:first-child {
    text-align: start
}

.possibilities .title:last-child {
    text-align: end
}

.possibilities .horizontal,.possibilities .vertical {
    height: auto;
    gap: 30px;
    margin-top: 40px;
    display: flex
}

@media screen and (max-width: 780px) {
    .possibilities .horizontal,.possibilities .vertical {
        display:none
    }
}

.possibilities .horizontal.mobile,.possibilities .vertical.mobile {
    display: none
}

@media screen and (max-width: 780px) {
    .possibilities .horizontal.mobile,.possibilities .vertical.mobile {
        display:flex
    }
}

.possibilities .horizontal .card,.possibilities .vertical .card {
    align-items: center;
    width: 540px;
    height: auto;
    padding: 30px;
    background: #232323;
    border-radius: 38px;
    color: #f6f2e8;
    gap: 25px
}

.possibilities .horizontal .card .icon,.possibilities .vertical .card .icon {
    border-radius: 50%;
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #874ad5
}

.possibilities .horizontal .card .icon img,.possibilities .vertical .card .icon img {
    transform: scale(1.5)
}

.possibilities .horizontal>div,.possibilities .vertical>div {
    display: grid;
    grid-template-columns: .5fr 3fr;
    flex-shrink: 0;
    padding: 0 5px
}

.possibilities .vertical {
    flex-direction: column
}

.possibilities .vertical .card {
    width: auto;
    padding: 0 30px
}

.possibilities .vertical .card h2 {
    font-size: 16px
}

:root {
    --cover-timing: .5s;
    --cover-ease: cubic-bezier(.66, .08, .19, .97);
    --cover-stagger: .15s;
    --text-timing: .75s;
    --text-stagger: 15ms;
    --text-ease: cubic-bezier(.38, .26, .05, 1.07);
    --title-stagger: .05s;
    --highlight: white
}

#discover {
    position: relative;
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    flex-direction: column;
    height: 500vh
}

@media screen and (max-width: 1440px) {
    #discover {
        height:600vh
    }
}

@media screen and (max-width: 1024px) {
    #discover {
        height:100vh
    }
}

#discover .title {
    text-align: start;
    position: relative;
    overflow: hidden;
    width: 100%;
    height: 60px;
    -webkit-font-smoothing: auto;
    pointer-events: none;
    color: #fff;
    margin: 0
}

@media screen and (max-width: 780px) {
    #discover .title {
        height:15%
    }
}

@media screen and (min-width: 1920px) {
    #discover .title {
        height:60px
    }
}

#discover .title span {
    position: absolute;
    left: 0;
    width: 100%;
    font-size: clamp(2rem,6vw,3rem);
    line-height: 130%;
    font-weight: 400
}

#discover .description {
    font-size: 18px;
    margin: 0
}

#discover .discover_desktop_list {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    grid-gap: 20px;
    margin-top: 40px;
    z-index: 1001
}

#discover .discover_desktop_list .discover_desktop_card {
    position: relative;
    height: calc(50vh - 100px);
    width: 100%;
    background-size: cover;
    background-position: center;
    cursor: pointer;
    pointer-events: all;
    overflow: hidden;
    border-radius: 7px;
    box-shadow: #ffffff4d 0 5vw 6vw -8vw,#fff0 0 4.5vw 5vw -6vw,#32325080 0 4vw 8vw -2vw,#000c 0 4vw 5vw -3vw;
    transition: box-shadow 1s var(--cover-ease)
}

#discover .discover_desktop_list .discover_desktop_card:before,#discover .discover_desktop_list .discover_desktop_card:after {
    content: "";
    width: 100%;
    height: 50%;
    top: 0;
    left: 0;
    background: #00000080;
    position: absolute;
    transform-origin: left;
    transform: scaleX(0);
    transition: all var(--cover-timing) var(--cover-ease);
    z-index: 1
}

#discover .discover_desktop_list .discover_desktop_card:after {
    transition-delay: var(--cover-stagger);
    top: 50%
}

#discover .discover_desktop_list .discover_desktop_card:hover,#discover .discover_desktop_list .discover_desktop_card:focus {
    box-shadow: #fff 0 5vw 6vw -9vw,var(--highlight) 0 5.5vw 5vw -7.5vw,#32325080 0 4vw 8vw -2vw,#000c 0 4vw 5vw -3vw
}

#discover .discover_desktop_list .discover_desktop_card:hover:before,#discover .discover_desktop_list .discover_desktop_card:hover:after,#discover .discover_desktop_list .discover_desktop_card:focus:before,#discover .discover_desktop_list .discover_desktop_card:focus:after {
    transform: scaleX(1)
}

#discover .discover_desktop_list .discover_desktop_card:hover .discover_desktop_card__overlay h2,#discover .discover_desktop_list .discover_desktop_card:hover .discover_desktop_card__overlay p,#discover .discover_desktop_list .discover_desktop_card:focus .discover_desktop_card__overlay h2,#discover .discover_desktop_list .discover_desktop_card:focus .discover_desktop_card__overlay p {
    opacity: 1;
    transform: translateY(0);
    color: inherit
}

#discover .discover_desktop_list .discover_desktop_card:hover .discover_desktop_card__overlay h2,#discover .discover_desktop_list .discover_desktop_card:focus .discover_desktop_card__overlay h2 {
    transition-delay: calc(.1s + var(--char-index) * var(--title-stagger))
}

#discover .discover_desktop_list .discover_desktop_card:hover .discover_desktop_card__overlay p,#discover .discover_desktop_list .discover_desktop_card:focus .discover_desktop_card__overlay p {
    transition-delay: calc(.1s + var(--word-index) * var(--text-stagger))
}

#discover .discover_desktop_list .discover_desktop_card:hover img,#discover .discover_desktop_list .discover_desktop_card:focus img {
    transform: scale(1.1)
}

#discover .discover_desktop_list .discover_desktop_card img {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 7px;
    z-index: 0;
    transition: all .8s cubic-bezier(.66,.08,.19,.97)
}

#discover .discover_desktop_list .discover_desktop_card .discover_desktop_card__overlay {
    position: absolute;
    right: 20px;
    bottom: 20px;
    left: 20px;
    top: auto;
    color: #dfdfdf;
    z-index: 2
}

#discover .discover_desktop_list .discover_desktop_card .discover_desktop_card__overlay h2 {
    font-size: 30px;
    font-weight: 800;
    margin-bottom: 10px;
    line-height: 1
}

#discover .discover_desktop_list .discover_desktop_card .discover_desktop_card__overlay p {
    font-size: 18px;
    line-height: 1.2;
    text-align: justify;
    margin-top: .2em;
    margin-bottom: 0
}

#discover .discover_desktop_list .discover_desktop_card .discover_desktop_card__overlay h2,#discover .discover_desktop_list .discover_desktop_card .discover_desktop_card__overlay p {
    color: var(--highlight);
    display: inline-block;
    opacity: 0;
    position: relative;
    transform: translateY(20px);
    transition-property: transform,opacity,color;
    transition-timing-function: var(--text-ease);
    transition-duration: var(--text-timing),var(--text-timing),calc(var(--text-timing) * 2)
}

#discover .slider-section {
    height: 14vh;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    transform: scale(5);
    z-index: 1001
}

#discover .wheel__card {
    display: block;
    position: relative;
    width: 100%;
    height: calc(50vw + 190px);
    border-radius: 5px;
    pointer-events: all;
    z-index: 1001
}

#discover .wheel__card:focus-visible {
    outline: none;
    border: none
}

#discover .wheel__card .wheel__card__overlay_image {
    width: 100%;
    height: 100%;
    z-index: 1000
}

#discover .wheel__card .wheel__card__overlay_image:focus-visible {
    outline: none;
    border: none
}

#discover .wheel__card .wheel__card__overlay {
    position: absolute;
    left: 0;
    bottom: 0;
    display: flex;
    align-items: flex-start;
    justify-content: flex-end;
    flex-direction: column;
    height: 100%;
    width: 100%;
    padding: 15px;
    z-index: 1000
}

#discover .wheel__card .wheel__card__overlay:focus-visible {
    outline: none;
    border: none
}

#discover .wheel__card .wheel__card__overlay h2 {
    margin: 0;
    color: #fff
}

#discover .wheel__card .wheel__card__overlay p {
    line-height: 150%;
    margin: 0;
    color: #fff
}

#discover img {
    width: 100%;
    pointer-events: none;
    z-index: 999;
    position: relative;
    will-change: transform;
    object-fit: cover;
    height: 100%
}

#discover img:focus-visible {
    outline: none;
    border: none
}

#discover .swiper-slide {
    height: calc(50vh + 170px)
}

@media screen and (max-width: 780px) {
    #discover .swiper-slide {
        height:calc(50vh + 120px)
    }
}

#discover .swiper-button-prev,#discover .swiper-button-next {
    background: #ededed;
    border: 0;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    transition: all .4s ease-in-out;
    cursor: pointer;
    pointer-events: all;
    top: var(--swiper-navigation-top-offset, 90%)
}

#discover .swiper-button-prev:hover,#discover .swiper-button-next:hover {
    background: #874ad5
}

#discover .swiper-button-prev:hover:after,#discover .swiper-button-next:hover:after {
    color: #fff
}

#discover .swiper-button-prev:after,#discover .swiper-button-next:after {
    font-size: 18px;
    color: #874ad5
}

#discover .swiper-button-prev {
    left: var(--swiper-navigation-sides-offset, 80px)
}

#discover .swiper-button-next {
    right: var(--swiper-navigation-sides-offset, 80px)
}

:root {
    --swiper-navigation-size: 44px
}

.swiper-button-prev,.swiper-button-next {
    position: absolute;
    top: var(--swiper-navigation-top-offset, 50%);
    width: calc(var(--swiper-navigation-size) / 44 * 27);
    height: var(--swiper-navigation-size);
    margin-top: calc(0px - (var(--swiper-navigation-size) / 2));
    z-index: 10;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--swiper-navigation-color, var(--swiper-theme-color))
}

.swiper-button-prev.swiper-button-disabled,.swiper-button-next.swiper-button-disabled {
    opacity: .35;
    cursor: auto;
    pointer-events: none
}

.swiper-button-prev.swiper-button-hidden,.swiper-button-next.swiper-button-hidden {
    opacity: 0;
    cursor: auto;
    pointer-events: none
}

.swiper-navigation-disabled .swiper-button-prev,.swiper-navigation-disabled .swiper-button-next {
    display: none!important
}

.swiper-button-prev svg,.swiper-button-next svg {
    width: 100%;
    height: 100%;
    object-fit: contain;
    transform-origin: center
}

.swiper-rtl .swiper-button-prev svg,.swiper-rtl .swiper-button-next svg {
    transform: rotate(180deg)
}

.swiper-button-prev,.swiper-rtl .swiper-button-next {
    left: var(--swiper-navigation-sides-offset, 10px);
    right: auto
}

.swiper-button-lock {
    display: none
}

.swiper-button-prev:after,.swiper-button-next:after {
    font-family: swiper-icons;
    font-size: var(--swiper-navigation-size);
    text-transform: none!important;
    letter-spacing: 0;
    font-variant: initial;
    line-height: 1
}

.swiper-button-prev:after,.swiper-rtl .swiper-button-next:after {
    content: "prev"
}

.swiper-button-next,.swiper-rtl .swiper-button-prev {
    right: var(--swiper-navigation-sides-offset, 10px);
    left: auto
}

.swiper-button-next:after,.swiper-rtl .swiper-button-prev:after {
    content: "next"
}

@font-face {
    font-family: swiper-icons;
    src: url(data:application/font-woff;charset=utf-8;base64,\ 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);
    font-weight: 400;
    font-style: normal
}

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

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

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

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

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

.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 {
    flex-shrink: 0;
    width: 100%;
    height: 100%;
    position: relative;
    transition-property: transform;
    display: block
}

.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 {
    transform: translateZ(0);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden
}

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

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

.swiper-3d {
    perspective: 1200px
}

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

.swiper-css-mode>.swiper-wrapper {
    overflow: auto;
    scrollbar-width: none;
    -ms-overflow-style: 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 {
    width:100%;
    min-width: 1px;
    height: var(--swiper-centered-offset-after)
}

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

.swiper-3d .swiper-slide-shadow {
    background: #00000026
}

.swiper-3d .swiper-slide-shadow-left {
    background-image: linear-gradient(to left,#00000080,#0000)
}

.swiper-3d .swiper-slide-shadow-right {
    background-image: linear-gradient(to right,#00000080,#0000)
}

.swiper-3d .swiper-slide-shadow-top {
    background-image: linear-gradient(to top,#00000080,#0000)
}

.swiper-3d .swiper-slide-shadow-bottom {
    background-image: linear-gradient(to bottom,#00000080,#0000)
}

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

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

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

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

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

    to {
        transform: rotate(360deg)
    }
}

#contact {
    position: relative
}

#contact .footer {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 2fr 1fr;
    padding: 40px 6%;
    z-index: 1000;
    pointer-events: all
}

@media screen and (max-width: 800px) {
    #contact .footer {
        grid-template-columns:1fr;
        grid-template-rows: auto 1fr auto
    }
}

@media screen and (max-width: 780px) {
    #contact .footer {
        padding:20px;
        flex-direction: column;
        justify-content: center;
        gap: 15px
    }
}

#contact .footer .copyright {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 10px
}

@media screen and (max-width: 780px) {
    #contact .footer .copyright {
        flex-direction:row
    }
}

#contact .footer .copyright span {
    margin-top: 3px
}

#contact .footer .content-phone {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    flex-direction: column
}

#contact .footer .content-phone a {
    text-decoration: none;
    color: inherit;
    transition: all .4s ease-in-out
}

#contact .footer .content-phone a:hover {
    color: #874ad5
}

#contact .footer .social-media {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 20px
}

#contact .footer .social-media .linkedin path {
    transition: all .4s ease-in-out
}

#contact .footer .social-media .linkedin:hover path {
    fill: #874ad5
}

#contact .footer .social-media .instagram path {
    transition: all .4s ease-in-out
}

#contact .footer .social-media .instagram:hover path {
    stroke: #874ad5
}

.header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100px;
    z-index: 1000;
    padding: 30px 8%;
    display: grid;
    grid-template-columns: 1fr 2fr 1fr;
    opacity: 0
}

@media screen and (max-width: 800px) {
    .header {
        grid-template-columns:1fr 1fr
    }
}

.header .buttons {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 20px
}

.header a:focus-visible,.header a:focus-within,.header a:focus {
    outline: none
}

.header a:nth-child(2) {
    display: flex;
    align-items: center;
    justify-content: center
}

@media screen and (max-width: 800px) {
    .header a:nth-child(2) {
        display:none!important
    }
}

.header a:nth-child(3) {
    display: flex;
    align-items: center;
    justify-content: flex-end
}

.header .logo img {
    height: 40px;
    width: 40px
}

.header .touch {
    text-decoration: none;
    cursor: auto
}

.banner {
    height: 100%;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    padding: 60px 6%;
    text-align: center;
    pointer-events: none
}

.banner .container-btn {
    margin-top: 30px
}

.banner .title {
    position: relative;
    overflow: hidden;
    width: 100%;
    height: 7vw;
    -webkit-font-smoothing: auto;
    pointer-events: none;
    margin: 0
}

@media screen and (max-width: 1366px) {
    .banner .title {
        height:110px
    }
}

@media screen and (max-width: 780px) {
    .banner .title {
        height:85px
    }
}

.banner .title span {
    position: absolute;
    left: 0;
    font-size: clamp(2rem,6vw,6rem);
    line-height: 130%;
    color: #fff;
    width: 100%
}

.banner .scroll-down {
    position: absolute;
    bottom: 40px;
    left: 50%;
    transform: translate(-50%);
    cursor: pointer;
    pointer-events: all
}

.banner .scroll-down #mouse_body {
    border-style: solid;
    border-width: 2px;
    border-color: #fff;
    border-radius: 32px;
    margin-top: 150px!important;
    height: 43px;
    width: 23px;
    margin: 0 auto
}

.banner .scroll-down #mouse_wheel {
    border-style: solid;
    border-width: 2px;
    border-color: #fff;
    border-radius: 8px;
    background-color: #fff;
    position: relative;
    height: 3px;
    width: 3px;
    margin: 0 auto;
    animation: wheel_animation 1.5s linear infinite
}

@keyframes wheel_animation {
    0% {
        opacity: 0;
        top: 2px
    }

    50% {
        opacity: 1;
        top: 50%
    }

    to {
        opacity: 0;
        top: 33px
    }
}

.about {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column
}

.about .title {
    width: -webkit-fill-available;
    text-align: center
}

@media screen and (min-width: 1920px) {
    .about .title {
        height:220px!important
    }
}

.about .title span {
    font-size: clamp(2rem,6vw,3rem)
}

@media screen and (min-width: 1920px) {
    .about .title span {
        font-size:clamp(2rem,6vw,4rem)!important
    }
}

.about .content {
    margin-top: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column
}

.about .content a {
    pointer-events: all
}
