@charset "UTF-8";

/*//////////////////// SWIPER ////////////////////////*/

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

.swiper-button-prev,
.swiper-button-next {
    position: absolute;
    top: 50%;
    width: 30px;
    height: 30px;
    border-radius: 50%;
}

.swiper-pagination-bullet-active {
    background: var(--color-basic);
}

.swiper-button-next {
    background: var(--color-basic) url('../../content/images/icon_arrowRs.svg') no-repeat center / 16px;
    right: 25px;
}

.swiper-button-prev {
    background: var(--color-basic) url('../../content/images/icon_arrowLs.svg') no-repeat center / 16px;
    left: 25px;
}


/*//////////////////// SWIPER basic ////////////////////////*/

.basic {
    width: 100%;
    margin: 0 auto;
}

.basic .swiper-slide {
    opacity: 0.4;
    overflow: hidden;
    transition: .7s;
}

.basic .swiper-slide-active {
    opacity: 1;
    z-index: 1;
    transform: scale(1);
}

.basic .slide-wrap {
    display: flex;
    justify-content: center;
    align-items: center;
    max-width: 100%;
    height: 80vh;
    margin: auto;
    background: linear-gradient(0deg, rgba(0, 0, 0, .6) 0%, rgba(0, 0, 0, 0) 40%, rgba(0, 0, 0, 0) 60%, rgba(0, 0, 0, .6)) 100%;
}

@media (min-width: 821px) {

    .basic .slide-wrap {
        height: 100vh;
    }

    .basic .swiper-slide-active {
        transform: scale(1.2);
    }

    .head-block .basic .slide-wrap {
        height: 80vh;
    }

}

/*//////////////////// SWIPER mv ////////////////////////*/

.mv {
    display: block;
    position: relative;
    top: 0;
    width: 100%;
    margin: 0 auto;
}

.mv .swiper-slide::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    background: rgba(32, 32, 32, 0.3);
    width: 100%;
    height: 100%;
    z-index: 3;
}

.mv .swiper-slide::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background: linear-gradient(0deg, rgba(0, 0, 0, 0) 40%, rgba(0, 0, 0, 0.2) 60%, rgba(0, 0, 0, .9)) 100%;
    width: 100%;
    height: 100%;
    z-index: 2;
}

.mv .swiper-slide {
    overflow: hidden;
    transition: .7s;
}

.mv .swiper-slide-active {
    z-index: 1;
}

.mv .slide-wrap .button {
    background: none;
    border: 1px solid var(--color-non);
    font-family: var(--font-family-en);
}

@media (min-width: 821px) {

    .mv .slide-wrap {
        align-items: end;
        height: calc(100vh - 60px);
        min-height: 600px;
    }

}

.mv .swiper .swiper-wrapper .swiper-slide {
    position: relative;
    overflow: hidden;
    width: 100%;
    height: 100vh;
}

.mv .slide-wrap {
    display: flex;
    justify-content: center;
    align-items: center;
    max-width: 100%;
    height: 80svh;
    min-height: 500px;
    margin: auto;
    position: relative;
    overflow: hidden;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0) 40%, rgba(0, 0, 0, 0.2) 60%, rgba(0, 0, 0, .9)) 100%;
}

.mv .swiper .swiper-wrapper .swiper-slide video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: absolute;
    top: 0;
    left: 0;
}

@media (min-width: 821px) {

    .mv .slide-wrap {
        align-items: end;
        min-height: 600px;
    }

}

/*//////////////////// SWIPER loop ////////////////////////*/

.loop .swiper {
    overflow: visible;
    padding: 0 3.2rem;
}

.topics .loop .swiper {
    overflow: hidden;
}

.loop .swiper-slide {
    overflow: hidden;
    box-sizing: border-box;
    height: auto;
    -webkit-transition: var(--transition), opacity 1s;
    transition: var(--transition), opacity 1s;
}

.loop .swiper-slide:not(.swiper-slide-visible) .slide-wrap {
    pointer-events: none;
}

.loop .loop-inner {
    position: relative;
    -webkit-box-sizing: content-box;
    box-sizing: content-box;
    margin: 0 auto;
}

.swiper-pagination {
    bottom: -40px !important;
}

@media (min-width: 821px) {

    .loop .loop-inner {
        padding: 2rem 0;
    }

}

.loop .contents-img {
    position: relative;
    height: 300px;
}

.loop .contents-img img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    border-radius: 10px;
    -o-object-fit: cover;
    object-fit: cover;
    height: 100%;
}

@media (min-width: 1025px) {

    .loop .slide-wrap img {
        -webkit-transition: var(--transition);
        transition: var(--transition);
    }

    .loop .slide-wrap:hover img {
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }

}

.loop .contents-text {
    padding: 1rem 0;
}

.loop h3 {
    font-family: var(--font-family-ja-min);
    font-size: 1.5rem;
    justify-content: center;
    padding: 0;
    margin: 0;
}

.e1 .loop h3 {
    font-family: var(--font-family-ja);
    font-size: 1.4rem;
    justify-content: center;
    padding: 0;
    margin: 0;
}

.loop .swiper-slide .slide-wrap .date {
    position: absolute;
    bottom: 10%;
    right: 0;
    transition: .2s;
    z-index: 2;
    font-family: var(--font-family-en);
    background: rgba(0, 0, 0, .5);
    color: var(--color-non);
    width: 60%;
    text-align: right;
    padding: .5rem 1rem;
    font-size: 1.2rem;
    letter-spacing: 0.1rem;
}

/*//////////////////// SWIPER modal ////////////////////////*/

.modal .swiper-slide .slide-inner {
    max-height: 50vh;
    overflow-y: auto;
    scrollbar-color: var(--color-60) var(--color-dark);
    scrollbar-width: thin;
}

@media (min-width: 821px) {

    .modal .swiper-slide .slide-inner {
        width: 100%;
    }

    .modal .swiper-slide .slide-inner .inner-contents {
        width: 80%;
        margin: 4rem auto;
    }

    .modal .swiper-slide dt {
        width: 26%;
        padding: 2%;
    }

    .modal .swiper-slide dd {
        width: 66%;
        padding: 2%;
    }

}

/*//////////////////// SWIPER fromLR ////////////////////////*/

.fromL .swiper-wrapper,
.fromL .swiper-wrapper {
    transition-timing-function: linear;
}

.fromL .swiper-slide img,
.fromL .swiper-slide img {
    height: auto;
    width: 100%;
}

/*//////////////////// SWIPER half ////////////////////////*/

.half .swiper {
    position: initial;
}

.half .contents-text .cursive {
    font-size: 6rem;
    color: var(--color-light);
    margin: 4rem 0 1rem;
}

.half .swiper {
    display: grid;
}

.half .swiper .swiper-slide {
    display: grid;
    background: var(--color-non);
}

.half .swiper .swiper-slide .slide-wrap {
    display: grid;
    grid-template-rows: 1fr auto 1fr;
    height: auto !important;
}

.half .swiper .swiper-slide h3 {
    display: flex;
    justify-content: flex-end;
    align-items: flex-end;
    text-align: right;
    font-size: 1.5rem;
    line-height: 1.4;
    padding: 1rem;
}

.half .swiper .swiper-slide h3 span {
    position: absolute;
    top: 0;
    left: 0;
    font-family: var(--font-family-en);
    font-size: 1.3rem;
    padding: 2rem 1rem 0 2rem;
}

.half .swiper .swiper-slide p {
    font-size: 1.3rem;
    line-height: 1.8;
    padding: 2rem 1.6rem 3rem;
    margin: 0;
}

.half .swiper .swiper-slide .contents-img img {
    object-fit: cover;
    height: 220px;
}

.half .swiper .swiper-slide .contents-img::after {
    content: "SERVICE";
    position: absolute;
    bottom: 0;
    left: 0;
    width: calc(100% - 20px);
    background-color: rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.1);
    font-family: var(--font-family-en);
    font-size: 1.3rem;
    letter-spacing: .1rem;
    color: var(--color-non);
    text-align: right;
    padding: 1rem;

}

@media (min-width: 821px) {

    .half .swiper {
        padding: 2rem 0;
        /*margin: 0 4rem;*/
    }

    .half .contents-wrap>.contents-img {
        display: block;
        width: 70%;
    }

    .half .contents-wrap>.contents-text {
        flex: initial;
        width: 30%;
    }

    .half .contents-text .contents-inner {
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
    }

}

/*//////////////////// SWIPER img ////////////////////////*/

.slide_01 {
    background: url(/content/images/slider/01s.jpg) no-repeat center/cover;
}

.slide_02 {
    background: url(/content/images/slider/02s.jpg) no-repeat center/cover;
}

.slide_03 {
    background: url(/content/images/slider/03s.jpg) no-repeat center/cover;
}

.slide_04 {
    background: url(/content/images/slider/04s.jpg) no-repeat center/cover;
}

.slide_05 {
    background: url(/content/images/slider/05s.jpg) no-repeat center/cover;
}


@media (min-width: 821px) {

    .slide_01 {
        background: url(/content/images/slider/01.jpg) no-repeat center/cover;
    }

    .slide_02 {
        background: url(/content/images/slider/02.jpg) no-repeat center/cover;
    }

    .slide_03 {
        background: url(/content/images/slider/03.jpg) no-repeat center/cover;
    }

    .slide_04 {
        background: url(/content/images/slider/04.jpg) no-repeat center/cover;
    }

    .slide_05 {
        background: url(/content/images/slider/05.jpg) no-repeat center/cover;
    }

}