:root {
    --header-height: 104px;
    --header-height-sm: 67px;
}
@media screen and (max-width: 991.98px) {
    .home-banner1 {
        padding: 116px 0;
    }
}
@media screen and (min-width: 992px) {
    .home-banner1 {
        display: flex;
        padding-block: 118px;
        align-items: center;
        position: relative;
        height: calc(100vh - 104px);
        /* min-height: 660px; */
    }
}
@media screen and (min-width: 1400px) {
    .home-banner1 {
        align-items: center;
    }
}
.home-banner1 .mob-content {
    max-width: 252px;
    margin: 0 auto;
    font-size: 17px;
    text-align: center;
    letter-spacing: 0.35rem;
    line-height: 1.4;
}
@media screen and (min-width: 992px) {
    .home-banner1 .mob-content {
        letter-spacing: 0.313rem;
        display: none;
    }
}
.home-banner1-hd {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    display: flex;
    flex-direction: column;
}
@media screen and (max-width: 991.92px) {
    .home-banner1-hd {
        justify-content: center;
    }
}
@media screen and (min-width: 992px) {
    .home-banner1-hd {
        justify-content: center;
    }
}
.home-banner1-hd .h1 {
    width: 100%;
    font-size: 41px;
    position: relative;
    z-index: 1;
    text-align: center;
    margin: 0 auto;
    font-weight: 400;
    line-height: 1.1;
}
@media screen and (min-width: 992px) {
    .home-banner1-hd .h1 {
        max-width: 1243px;
        font-size: 7.75rem;
        letter-spacing: 0.1rem;
    }
}
@media screen and (min-width: 1600px) {
    .home-banner1-hd .h1 {
        margin-bottom: 10.375rem;
    }
}
.home-banner1-hd p {
    width: 1000px;
    margin: 0 auto;
    letter-spacing: 0.313rem;
}
@media screen and (max-width: 991.98px) {
    .home-banner1-hd p {
        display: none;
        font-size: 17px;
    }
}
.home-banner1 .word-carousel {
    position: relative;
    overflow-y: hidden;
    overflow-x: visible !important;
    overflow: visible;
    opacity: 0.2;
}
.home-banner1 .word-carousel__wrapper {
    display: flex;
    position: relative;
    white-space: nowrap;
    padding: 0;
    will-change: transform;
}
.home-banner1 .word-carousel__slide {
    margin: 0px 23px;
}
.home-banner1 .word-carousel__slide:nth-child(3n-1) {
    transform: translateY(-70px);
}
.home-banner1 .word-carousel__slide:nth-child(3n) {
    transform: translateY(70px);
}
.home-banner1 .word-carousel-wrapper {
    width: 100%;
}
.home-banner1 .word-carousel__img {
    min-width: 235px;
    width: 100%;
}
@media screen and (min-width: 992px) {
    .home-banner1 .word-carousel__img {
        min-width: 443px;
    }
}
.home-banner1-wrap {
    display: flex;
    position: relative;
}
@media screen and (max-width: 991.98px) {
    .home-banner1-wrap {
        margin-bottom: 68px;
    }
}
@media screen and (min-width: 992px) {
    .home-banner1-wrap {
        position: unset;
        min-height: 580px;
    }
}
@media screen and (min-width: 1400px) {
    .home-banner1-wrap {
        align-items: center;
    }
}
@media screen and (min-width: 992px) {
    h1 .split-lines {
        clip-path: polygon(100% 0, 100% 100%, 0 100%, 0 80%);
        transform: translateY(-50px);
        opacity: 0;
        animation-name: titleAnimation;
        animation-fill-mode: forwards;
        -webkit-animation-fill-mode: forwards;
        animation-timing-function: ease;
        animation-duration: 3s;
        will-change: transform, opacity;
    }
    h1 .split-lines {
        animation-delay: 0.6s;
    }
    h1 .split-lines:first-child {
        animation-delay: 0.7s;
    }
    h1 .split-lines:last-child {
        animation-delay: 0.5s;
    }
    @keyframes titleAnimation {
        0% {
            transform: translateY(-70px);
            opacity: 0;
            clip-path: polygon(100% 0, 100% 100%, 0 100%, 0 80%);
        }
        20% {
            transform: translateY(0);
            opacity: 1;
            clip-path: polygon(100% 0, 100% 100%, 0 100%, 0 0%);
        }
        80% {
            transform: translateY(0);
            opacity: 1;
            clip-path: polygon(100% 0, 100% 100%, 0 100%, 0 0%);
        }
        to {
            transform: translateY(0px);
            opacity: 1;
            clip-path: polygon(100% 0, 100% 100%, 0 100%, 0 0%);
        }
    }
    .split-line {
        will-change: transform, opacity;
    }
}
