@charset "utf-8";

.sec-intro .inner {
    padding: 85px 0 60px;
    display: flex;
    align-items: flex-start;
    gap: 5%;
    justify-content: flex-end;
}

.sec-intro .sec-img {
    max-width: 1021px;
    width: 50%;
}

.sec-intro .main {
    font-family: var(--font-serif);
    font-weight: 700;
    font-size: clamp(1.25rem, 1.189rem + 0.26vw, 1.5rem);
    letter-spacing: 0.2em;
    line-height: 2;
    color: #000;
    margin-bottom: 64px;
}

.sec-image {
    width: 100%;
    overflow: hidden;
    margin-top: -15%;
}

.sec-image .scroll-area {
    display: inline-flex;
    gap: 57px;
    width: max-content;
    animation: scrollLoop 50s linear infinite;
    animation-delay: 0.1s;
    animation-fill-mode: both;
}

.sec-image .scroll-area img {
    height: clamp(14.063rem, 8.738rem + 22.72vw, 36rem);
    width: auto;
    flex-shrink: 0;
}

@keyframes scrollLoop {
    0% {
        transform: translateX(0);
    }

    100% {
        transform: translateX(-50%);
    }
}

.feature .inner {
    padding: 120px 0 80px;
}

.feature .sec-title {
    margin-bottom: 80px;
}

.feature .sec-body {
    display: flex;
    flex-direction: column;
    gap: 120px;
}

.feature .item-head {
    display: grid;
    grid-template-columns: 39% 1fr;
    gap: 4%;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 56px;
}



.feature .item-head .item-tit {
    display: flex;
    gap: 2%;
    align-items: center;
}

.feature .item-head .item-tit .num {
    width: clamp(2.25rem, 1.476rem + 3.3vw, 5.438rem);
    height: auto;
}

.feature .item-head .item-tit .title {
    display: flex;
    gap: 8px;
    align-items: flex-end;
}

.feature .item-head .item-tit .main {
    font-family: var(--font-serif);
    font-weight: 700;
    font-size: clamp(1.5rem, 1.379rem + 0.52vw, 2rem);
    color: #000;
}

.feature .item-head .item-tit .sub {
    font-family: var(--font-serif);
    font-weight: 700;
    font-size: clamp(0.875rem, 0.814rem + 0.26vw, 1.125rem);
    color: #000;
}

.feature .item-body {
    height: 305px;
}

.feature .item-body img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.t_service .inner {
    padding: 80px 0 100px;
}

.t_service .sec-title {
    margin-bottom: 56px;
}

.t_service .mainimg {
    position: relative;
    margin-bottom: 40px;
}

.t_service .mainimg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.t_service .main-tit {
    font-family: var(--font-serif);
    font-weight: 700;
    font-size: clamp(3.313rem, 2.751rem + 2.39vw, 5.625rem);
    letter-spacing: 0.1em;
    color: #fff;
    position: absolute;
}

.service-main {
    margin-bottom: 80px;
}

.service-main .column {
    display: grid;
    grid-template-columns: 30% 1fr;
}

.service-main .title {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.t_service .title .main {
    font-family: var(--font-serif);
    font-weight: 700;
    font-size: clamp(1.5rem, 1.379rem + 0.52vw, 2rem);
    letter-spacing: 0.2em;
    color: #000;
}

.t_service .title .sub {
    font-family: var(--font-serif);
    font-weight: 700;
    font-size: clamp(0.875rem, 0.814rem + 0.26vw, 1.125rem);
    letter-spacing: 0.2em;
    color: #000;
}

.service-main .main-tit {
    left: 20px;
    bottom: 20px;
}

.service-sub .main-tit {
    font-size: clamp(3.313rem, 3.13rem + 0.78vw, 4.063rem);
}

.s02 .main-tit {
    top: 11px;
    right: 14px;
}

.s03 .main-tit {
    left: 26px;
    bottom: 22px;
}

.s04 .main-tit {
    top: 24px;
    left: 13px;
    writing-mode: vertical-lr;
}

.service-main .desc {
    margin-bottom: 32px;
}

.service-main .morebtn {
    margin-right: auto;
    margin-left: 0;
}

.t_service .item-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 4%;
}

.service-sub .title {
    display: flex;
    align-items: flex-end;
    margin-bottom: 20px;
}

.service-sub .title .main {
    font-size: 24px;
}

.service-sub .title .sub {
    font-size: clamp(0.875rem, 0.845rem + 0.13vw, 1rem);
}

.service-sub .desc02 {
    margin-bottom: 20px;
}

@media (max-width: 1366px) {
    .feature .item-head {
        grid-template-columns: 45% 1fr;
    }
}


@media (max-width: 1200px) {
    .feature .item-head .item-tit {
        width: 100%;
    }

    .feature .item-head {
        display: flex;
        flex-direction: column;
        gap: 24px;
        margin-bottom: 24px;
    }

    .feature .sec-body {
        gap: 80px;
    }

    .t_service .item-list {
        display: flex;
        flex-direction: column;
        gap: 80px;
    }

    .t_service .mainimg {
        height: 248px;
    }

    .service-main .column {
        display: flex;
        flex-direction: column;
        gap: 24px;
    }

    .sec-image {
        margin-top: -10%;
    }

    .pc-hidden {
        display: block;
    }

    .sp-hidden {
        display: none;
    }
}

@media (max-width: 1023px) {
    .sec-intro .sec-img {
        margin-left: -12%;
        z-index: -1;
    }

    .sec-intro .inner {
        justify-content: space-between;
    }

    .sec-intro .main {
        margin-bottom: 32px;
    }
}

@media (max-width: 767px) {
    .sec-intro .inner {
        flex-direction: column;
        padding-top: 40px;
    }

    .sec-intro .sec-img {
        max-width: 396px;
        width: 100%;
        margin-top: -36px;
        margin-left: -104px;
    }

    .sec-image {
        margin-top: -188px;
    }

    .service-main .column {
        width: 100%;
    }

    .service-sub .morebtn {
        margin-right: auto;
        margin-left: 0;
    }

    .feature .inner {
        padding: 120px 0 60px;
    }

    .t_service .inner {
        padding: 60px 0 80px;
    }

    .feature .item-body {
        height: 206px;
    }



    .feature .item-head .item-tit .main,
    .feature .item-head .item-tit .sub {
        white-space: nowrap;
    }

    .sec-title.has-line {
        margin-bottom: 40px;
    }


}