@charset "utf-8";

/************* MV *************/
.top-mv .container {
    margin: 0 auto 15px auto;
}

.mv-access {
    letter-spacing: .05em;
    background-color: #f1e9dc;
	font-family: "RyuminPro", "GaramondPro", serif;
	font-weight: normal;
}

.mv-access__main {
    padding: 15px 0;
    font-size: 2.4rem;
    border-bottom: 1px solid #d1c7b6;
}

.mv-access__main span {
    font-size: 150%;
}

.mv-access__list {
    padding: 15px 0 30px;
}

.mv-access__list p {
    width: 33.33%;
    font-size: 2rem;
	font-family: "RyuminPro", "GaramondPro", serif;
}

.mv-access__list p span {
    font-size: 120%;
}

.mv-access__list p+p {
    border-left: 1px solid #d1c7b6;
}

@media screen and (max-width: 1400px) {
    .mv-access__main {
        font-size: 1.8vw;
    }
    .mv-access__list p {
        font-size: 1.5vw;
    }
}

@media screen and (max-width: 639px) {
    .mv-access__main {
        font-size: 4.16vw;
    }
    .mv-access__list p {
        width: 100%;
        font-size: 4vw;
    }
    .mv-access__list p+p {
        margin-top: 15px;
        padding-top: 15px;
        border-left: none;
        border-top: 1px solid #d1c7b6;
    }

    /* SP用 MVスライド */
    .top-mv{
        background:#F1E9DC;
    }

    .top-mv__slide .slick-dots li {
        width: 10px;
        height: 10px;
    }

    .top-mv__slide .slick-dots li button {
        width: 100%;
        height: 100%;
        padding: 0;
        border-radius: 50%;
        background-color: #707070;
    }

    .top-mv__slide .slick-dots li.slick-active button {
        background-color: rgba(80, 50, 30, 1);
    }

    .top-mv__slide .slick-dots li button:before {
        display: none;
    }

}


/************* バナースライド *************/

.top-banner {
    padding-top: 50px;
}

.banner-slide {
    margin: 27px -10px 0;
}

.banner-slide .slick-slide {
    margin: 0 14px;
    border: 1px solid #d1c7b6;
    background:#DDD;
}

.banner-slide .slick-slide figure{
        width: 100%;
        height: 100%;
}

.banner-slide .slick-prev {
    left: -50px;
}

.banner-slide .slick-next {
    right: -50px;
}

@media screen and (max-width: 1400px) {
    .banner-slide {
        margin: 27px 25px 0;
    }
    .banner-slide .slick-prev {
        left: -25px;
    }
    .banner-slide .slick-next {
        right: -25px;
    }
}

@media screen and (max-width: 639px) {
    .banner-slide .slick-dots li {
        width: 10px;
        height: 10px;
    }

    .banner-slide .slick-dots li button {
        width: 100%;
        height: 100%;
        padding: 0;
        border-radius: 50%;
        background-color: #707070;
    }

    .banner-slide .slick-dots li.slick-active button {
        background-color: rgba(80, 50, 30, 1);
    }

    .banner-slide .slick-dots li button:before {
        display: none;
    }


    .banner-slide .slick-slide {
        margin: 0;
    }    
    .banner-slide .slick-prev {
        left: -30px;
    }
    .banner-slide .slick-next {
        right: -30px;
    }
    .slick-slide img{
        margin: auto;
    }
}

.top-sec-ttl {
    margin-bottom: 1em;
    text-align: center;
    font-size: 3.6rem;
    font-family: 'GaramondPro';
    letter-spacing: .4em;
}

/************* メリットコピー *************/

#merit {
    width: 100%;
    font-family: 'RyuminPro', serif;
    background-image: url(../images/common/texture01.jpg);
    background-position: center center;
    background-size: cover;%;
}
#merit ul {
    width: 90%;
    max-width: 1300px;
    margin: auto;
    padding: 2vw 0;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
#merit ul li {
    width: 33.3333%;
    padding: 1%;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    font-size: clamp(1.5rem, 1.198rem + 0.48vw, 1.875rem);
    letter-spacing: .1em;
    line-height: 36px;
    color: #fff;
}
#merit ul li span {
    font-size: 150%;
    display: inline-block;
    color: #fff;
}
#merit ul li span.large {
    font-size: 175%;
}
#merit ul li:first-child,
#merit ul li:nth-child(2) {
    border-bottom: 1px solid #fff;
    border-right: 1px solid #fff;
}
#merit ul li:nth-child(3) {
    border-bottom: 1px solid #fff;
}
#merit ul li:nth-child(4),
#merit ul li:nth-child(5) {
    border-right: 1px solid #fff;
}


#merit sup{
    display: inline-block;
    font-size: 40%;
    font-weight: normal;
    transform: translateY(-1.2em);
}
#merit small {
    font-size: 10px;
    display: block;
    line-height: 2em;
}

@media screen and (max-width: 1000px) {
}


@media screen and (max-width: 767px) {

#merit ul {
    display: block;
}
#merit ul li {
    width: 100%;
    font-size: clamp(1rem, 0.92rem + 0.43vw, 1.125rem);
    line-height: 1.25;
    padding: 2%;
}
#merit ul li:first-child,
#merit ul li:nth-child(2),
#merit ul li:nth-child(3),
#merit ul li:nth-child(4),
#merit ul li:nth-child(5) {
    border-right: none;
    border-bottom: 1px solid #000;
}

}


/************* CONTENTS *************/

.contents-link {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-content: flex-start;
    align-items: flex-start;
    flex-wrap: wrap;
    gap:0 20px;
    height: calc(420px * 4);
}

.contents-link a {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    width: calc(50% - 10px);
    height: 400px;
    margin-top: 20px;
}

.contents-link a::before {
    content: '';
    position: absolute;
    left: 20px;
    right: 20px;
    top: 100px;
    bottom: 100px;
    background-color: rgba(255, 255, 255, .8);
    z-index: 1;
}

.contents-link a figure {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.contents-link a figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.contents-link div.ComingSoon{
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    width: calc(50% - 10px);
    margin-top: 20px;
    background: #cdcdcd;
}

.contents-link__ttl {
    position: relative;
    text-align: center;
    z-index: 2;
}

.contents-link__ttl .f-en {
    font-size: 4.8rem;
    color: #615239;
}

.contents-link__ttl h3 {
    position: relative;
    width: 240px;
    margin: 0 auto;
    font-size: 1.8rem;
    font-weight: 300;
    letter-spacing: .13em;
    color: #272624;
}

.contents-link__ttl h3::before {
    content: '';
    position: absolute;
    left: 0;
    top: calc(50% - 4px);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 5px 0 5px 10px;
    border-color: transparent transparent transparent #000000;
}

@media screen and (max-width: 1310px) {

    .contents-link {
        height: calc((20vw + 20px) * 4);
    }
    .contents-link a {
        height: 20vw;
    }
    .contents-link a::before {
        left: 5%;
        right: 5%;
        top: 10%;
        bottom: 10%;
    }
    .contents-link__ttl .f-en {
        font-size: 3vw;
    }
}

@media screen and (max-width: 639px) {
    #contents-sec .container{
        width:84%;
    }
    .contents-link {
        display: block;
        width: 90%;
        height: auto;
        margin: auto;
    }
    .contents-link div.ComingSoon,
    .contents-link a {
        width: 100%;
        height: 40vw;
        margin-top: 4vw;
    }
    .contents-link a::before {
        left: 5%;
        right: 5%;
        top: 10%;
        bottom: 10%;
    }
    .contents-link__ttl .f-en {
        font-size: 5.5vw;
    }
    .contents-link__ttl h3{
        font-size: 3.75vw;
        font-weight: 400;
    }
    .contents-link__ttl h3::before {
    content: none;
    }
}