@charset "UFT-8";



.sm{
    display: none;
}

a:hover{
    text-decoration: none;
    color: #d78f2d;
    transition: .5s;
}

.pc{
    display: contents;
}

.flex{
    display: flex;
}

.en{
    font-family: 'Cinzel', serif;
}

#header{
    color: #F4F4F4;
    align-items: center;
    display: flex;
    justify-content: space-between;
    padding: 0 3%;
    position: fixed;
    z-index: 999;
    top: 0;
    left: 0;
    width: 100%;
    box-sizing: border-box;
    font-family: 'Cinzel', serif;
    background-color: rgba(0,0,0,0.8);
    /* display: none; */
    height: 100px;
}


#header.show {
    display: inline-flex;
}


main{
    font-family: 小塚明朝 Pro;
    font-weight: normal;
    color: #F4F4F4;
    overflow: hidden;
}

.logo{
    width: 200px;
    padding: 30px 0px;
}

.tel{
    font-size: 2.5rem;
    margin: 0 35px 0 auto;
}

.nav-btn{
    padding: 0 65px 0 0;
}

.fv{
    width: 100%;
    height: 100vh;
}

.bg {
    position: relative;
}

.bg::before {
    content:"";
    display:block;
    position:fixed;
    top:0;
    left:0;
    z-index:-1;
    width:100%;
    height:100vh;
    background-repeat: no-repeat;
    background-position: center center;
    background-image:url(../img/bg.jpg);
    background-size: cover;
}

.top-swiper{
    position: relative;
}

.logo-fv{
    position: absolute;
    z-index: 1;
    width: 800px;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
}

.top-swiper .swiper-container{
    padding-top: 0px;
}

.swiper2{
    padding-top: 0px;
}

.top-swiper .swiper-slide{
    height: 100vh;
    width: 100%;
}

.about-us{
    width: 100%;
    position: relative;
    margin-top: 65px;
}

.content{
    width: 80%;
    max-width: 1200px;
    margin: 0 auto;
    font-weight: normal;
}

.title{
    font-size: 4rem;
    font-family: 'Cinzel', serif;
    font-weight: normal;
}

.about-us h2{
    font-size: 1.2rem;
    position: relative;
    top: -10px;

}

.sub-title{
    font-size: 1.4rem;
    margin-bottom: 9rem;
}

.text{
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 25rem;
    font-size:min(1.8vw,1.6rem);
    line-height: 2.3461538462;
    letter-spacing: -0.1em;
    text-align: justify;
    width: fit-content;
}

.front-margin{
    margin-bottom: 275px;
}

.text p{
    margin-bottom: 2.3em;
}

.about01{
    top: 5.65625vw;
    left: calc(50% + 23.75vw);
    width: 40.3125vw;
    position: absolute;
}

.about01::before{
    content: "";
    position: absolute;
    top: -13px;
    bottom: 13px;
    left: 13px;
    right: 0;
    border: 1px solid #bea976;
    pointer-events: none;
}

.about01 img{
    width: 100%;
    max-width: 440px;
}

.about02{
    left: calc(50% - 62.5vw);
    top: 36.1458333333vw;
    width: 35.0833333333vw;
    position: absolute;
}

.about02::before{
    content: "";
    position: absolute;
    top: -13px;
    bottom: 13px;
    left: -13px;
    right: 13px;
    border: 1px solid #bea976;
    pointer-events: none;
}

.about02 img{
    width: 100%;
}

.about03{
    left: calc(50% + 27.6470588235vw);
    top: 68.5208333333vw;
    width: 27.5520833333vw;
    position: absolute;
}

.about03::before{
    content: "";
    position: absolute;
    border: 1px solid #bea976;
    pointer-events: none;
    top: -9px;
    bottom: 9px;
    left: 9px;
    right: -9px;
}

.about03 img{
    width: 100%;
    max-width: 348px 
}

.news_ticker1 {
    width: 100%;
    font-size: 20rem;
    overflow: hidden;
    white-space: nowrap;
    font-family: 'Cinzel', serif;
    font-weight: 500;
    height: 345px;
}

@keyframes hscroll {
    0% { transform: translateX(300px); }
    100% { transform: translateX(-100%); }
}

.news_ticker1 ul {
    display: inline-block;
    margin: 0;
    padding: 0;
    animation: hscroll 55s linear infinite; /* ここでdurationを変更 */
}

.news_ticker1 li {
    display: inline-block;
}

.access{
    text-align: center;
    margin-bottom: 30px;
    margin-top: 0px;
}

.gmap{
    width: 90%;
    height: 500px;
}

.access .t2rem{
    margin-top: 0.8em;
}

.access .t1-5rem{
    font-size: 1.3rem;
}

.t2rem{
    font-size: 2rem;
}

.t1-5rem{
    font-size: 1.5rem;
}

.reviews-content {
    padding: 62px 32px 32px 32px;
}

.utility-banners {
    display: flex;
    justify-content: space-between;
    gap: 32px;
    padding-bottom: 32px;
}

.utility-banners li {
    width: 50%;
    padding: 75px 20px;
}

.banner-voice {
    background: no-repeat right/cover url(../img/cast-rct.jpg);
}

.banner-faq {
    background: no-repeat center /cover url(../img/mens-rct.jpg);
}

.label1{
    margin-left: 62%;
}

.label2{
    margin-left: 15%;
}

.reviews-content .label .ja {
    font-weight: normal;
    line-height: .9;
    color: #EDEDED;
    font-size: 26px;
    letter-spacing: .12em;
    display: block;
    margin-bottom: 12px;
}

.reviews-content .label .en {
    font-family: 'Cinzel', serif;
    font-weight: normal;
    color: #9D9E9F;
    font-size: 13px;
    letter-spacing: .20em;
    display: block;
}

.reviews-content .interior {
    text-align: center;
    width: 100%;
    display: inline-block;
    background: #555555;
    padding: 70px 0;
}

.reviews-content .logo{
    width: 40%;
}


.roppongi-img img{
    height: 100vh;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
}

footer{
    padding-top: 30px;
    background-color: #F4F4F4;
    color: black;
}

.footer-info{
    margin: 0px 100px 25px;
}

footer .logo{
    width: 200px;
}

footer .logo img{
    width: 150px;
}

.address{
    margin: auto 0;
}

.footer-navs{
    margin: 0 100px 50px;
}

.footer-navs a{
    margin: auto 35px;
}

.navs{
    font-size: 0.9rem;
}

.copyright{
    text-align: center;
}




@media screen and (max-width: 1480px){
    .text{
        font-size: 1.5vw;
    }
}


@media screen and (max-width: 100em){
    .about02 {
        left: calc(55% - 68.5vw);
    }
}


@media screen and (max-width: 47.9375em){

    .pc{
        display: none;
    }
    
    .sm{
        display: contents;
    }

    .logo{
        width: 130px;
    }

    .tel{
        font-size: 1.5rem;
    }

    .logo-fv{
        width: 400px;
    }

    .about-us {
        z-index: 3;
        padding-top: 130.4492753623vw;
        margin-top: -30px;
    }

    .content{
        width: 86%;
        margin-bottom: 87px;
    }

    .news_ticker1 {
        width: 100%;
        font-size: 14rem;
        height: 250px;
    }

    .about01{
        top: 17.6328502415vw;
        left: calc(50% - 134px);
        width: 87.1980676329vw;
    }

    .about01::before{
        top: -6px;
        bottom: 6px;
        left: 6px;
    }

    .about02{
        position: relative;
        margin-left: -17.8743961353vw;
        margin-bottom: 11.7391304348vw;
        width: 79.2270531401vw;
        top: 25px;
    }

    .about02::before{
        top: -6px;
        bottom: 6px;
        left: 6px;
        right: 6px;
    }

    .about03{
        position: relative;
        width: 63.768115942vw;
        margin-left: auto;
        margin-right: -7.2463768116vw;
        margin-bottom: -19.3236714976vw;
        top: 20px;
        left: 0;
        z-index: 3;
    }

    .about03::before{
        top: -6px;
        bottom: -10px;
        left: 6px;
        right: -6px;
    }

    .title{
        font-size: 3rem;
    }

    .about-us h2{
        font-size: 1rem;
    }

    .sub-title {
        font-size: 1rem;
        margin-bottom: 3rem;
        font-weight: normal;
    }

    .text{
        font-size: 0.9rem;
        line-height: 1.96875;
    }

    .text p br{
        display: none;
    }

    .front-margin {
        margin-bottom: 50px;
    }

    .t2rem{
        font-size: 1.6rem;
    }

    .t1-5rem{
        font-size: 1rem;
        margin: 0 15px;
    }

    .reviews-content {
        padding: 20px 5% 20px;
    }

    .utility-banners {
        display: block;
        padding-bottom: 0;
    }

    .utility-banners li {
        width: auto;
        margin-bottom: 12px;
        padding: 70px 30px;
    }

    .reviews-content .label .ja {
        margin-bottom: 8px;
        font-size: 20px;
    }

    .reviews-content .label .en {
        letter-spacing: .12em;
    }

    .reviews-content .interior {
        padding: 0px 0;
    }

    .banner-voice {
        background: no-repeat center/cover url(../img/cast-rct.jpg);
    }

    .footer-info{
        margin: 0 40px 15px;
    }

    footer .logo{
        width: 200px;
    }

    footer .logo img{
        width: 140px;
    }

    .address{
        width: 70%;
        font-size: 1rem;
    }

    .copyright{
        font-size: 0.8rem;
    }

    .footer-navs{
        margin: 0 2% 30px;
    }

    .footer-navs a{
        margin: auto;
        flex: 1;
    }

    .navs{
        font-size: 0.6rem;
        text-align: center;
        width: 100%;
    }

    .roppongi-img img{
        height: auto;
        width: 140%;
    }

}





#video{
    position: fixed;
    z-index: -1;
    top:0;
    left:0;
    width:100%;
    height:100vh;
    object-fit: cover;
}


.block{
    width: 150px;
}

  .card {
    width: 219px;
    height: 350px;
    box-shadow: 20px 20px 50px rgba(0, 0, 0, 0.5);
    border-radius: 15px;
    background: rgba(255, 255, 255, 0.1); /* 真っ白にして透明度を90%にしている */
    overflow: hidden;
    display: flex;
    justify-content: center;
    align-items: center;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    border-left: 1px solid rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(5px);
    z-index: 1;
  }
  
  .card .content {
    padding: 120px 20px 20px 20px;
    text-align: center;
    transform: translateY(200px); /* あとで */
    opacity: 0; /* あとで */
    transition: 0.5s;
  }
  
  .card:hover .content {
    transform: translateY(0px);
    opacity: 1;
  }
  
  .card .content h2 {
    position: absolute;
    top: 30px;
    right: 0px;
    font-size: 1.5em;
    color: rgba(255, 255, 255, 0.1);
    pointer-events: none;
  }
  
  .card .content h3 {
    font-size: .8em;
    color: #fff;
    text-shadow: 2px 2px 2px rgb(61 70 70);
    z-index: 1;
    display: inline-block;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }

  .card .content p {
    font-size: 0.5em;
    color: #fff;
    text-shadow: 2px 2px 2px rgb(61 70 70);
    font-weight: 300;
    line-height: 1;
  }
  
  .card .content a {
    font-size: 0.3em;
    display: inline-block;
    padding: 8px 20px;
    margin-top: 15px;
    background-color: #fff;
    color: #000;
    border-radius: 20px;
    text-decoration: none;
    font-weight: 500;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5);
  }

.card img{
    width: 100%;
    z-index: -1;
    position: absolute;
}


.area{
    overflow: hidden;
}
.wrap{
    display: flex;
    width: 500% !important;
}
.item{
    height: 100vh;
    width: auto;
    display: flex;
    font-size: 50px;
    color: #fff;
}

.item00{
    width: 37.5%;
}

.item01{
    width: 47.5%;
}


.cast-list{
    width: 30%;
    height: 100vh;
}

.js-item .title{
    counter-increment: number;
    color: #d78f2d;
    margin-bottom: auto;
    margin-right: 10px;
    font-size: 4rem;
    font-family: "Cinzel", serif;
    line-height: 0.8;
    white-space: nowrap;
    writing-mode: vertical-rl;
}

.cast-list img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
}

.item01 .cast{
    margin-top: 140px;
    width: 80%;
}

.item01 .flex{
    align-items: center;
    margin-bottom: 20px;
}

.cast .mr{
    margin: 0 40px;
}

.botton{
    align-items: center;
    border: 1px solid #d78f2d;
    border-radius: 999px;
    display: inline-flex;
    font-size: 1.2rem;
    font-weight: 500;
    line-height: 1;
    padding: 8px 20px 8px 18px;
    margin: 200px 0 0 50px;
}

.botton:hover{
    color: #EDEDED;
    background: #d78f2d;
    transition: .5s ;
}

.item i{
    margin-right: 10px;
}

.item .text{
    margin: auto 40px;
    width: 50%;
}

.item02 .botton{
    position: absolute;
    bottom: 100px;
    right: 240px;
}

.item02 .color{
    color: #d78f2d;
    font-weight: 600;
}

.item02 .t2rem{
    line-height: 1.5;
    margin-bottom: 30px;
}

.item03 .botton{
    position: absolute;
    bottom: 100px;
    right: 480px;
}

.item03 .color{
    color: #d78f2d;
    font-weight: 600;
}

.item03 .t2rem{
    line-height: 1.5;
    margin-bottom: 30px;
}

.item03 .text{
    width: 40%;
}

  
.swiper-container {
    width: 100%;
    padding-top: 150px;
    padding-bottom: 50px;
}

.swiper-slide {
    background-position: top;
    background-size: cover;
    width: 500px;
    height: 500px;
}

.news{
    margin: 150px 5% 100px 5%;
}

.news .flex{
    justify-content: space-around;
}

.news .block{
    width: 20%;
}

.news_title {
    font-size: 4rem;
    font-weight: normal;
}

.home-news__list{
    width: 68%;
    margin-top: 120px;

}

.linklist-news{
    gap: 60px 0;
    font-size: 1.2rem;
    vertical-align: middle;
}

.linklist-news__item{
    display: flex;
    border-top: 1px solid #d5d6d8;
    padding: 35px 20px;
    position: relative;
}

.linklist-news__date{
    margin: auto 0;
}

.linklist-news__link{
    margin-left: 100px;
    width: 100%;
    font-size: 1.2rem;
}

.linklist-news__item .fa-arrow-right{
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 30px;
}

.access h3{
    font-size: 4rem;
    font-weight: normal;
}

.access h2{
    margin-bottom: 20px;
}

@media screen and (max-width: 1300px){
    .wrap {
        display: flex;
        width: 600% !important;
    }

    .item03{
        width: 39% !important;
    }

    .item03 .text {
        width: 30%;
    }

}


@media screen and (max-width: 47.9375em){
    #header {
        height: 80px !important;
    }


    .item-sm{
        margin-top: 70px;
        text-align: center;
    }

    .item00-sm{
        margin-top: 0;
    }

    .cast-list{
        width: 100%;
        height: 100%;
    }
    
    .js-item-sm .title{
        counter-increment: number;
        color: #d78f2d;
        margin-bottom: 4px;
        margin-right: 20px;
        margin-left: 15px;
        font-size: 4.375rem;
        font-family: "Cinzel", serif;
        line-height: 0.8;
        white-space: nowrap;
        writing-mode: vertical-rl;
        letter-spacing: 4px;
    }
    
    .cast-list img {
        width: 100%;
        height: 100%;
        -o-object-fit: cover;
        object-fit: cover;
    }

    .item01-sm{
        margin-top: 180px;
    }
    
    .item01-sm .cast{
        margin-top: 50px;
    }
    
    .item01-sm .flex-cast01{
        display: flex;
        align-items: center;
        margin-bottom: 20px;
        height: 210px;
    }

    .cast .flex{
        width: 100%;
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
    }

    .card{
        width: 150px;
        height: 240px;
    }

    .card .content{
        padding: 200px 0px 10px 0px;
    }

    .card .content h2 {
        top: 100px;
        right: 0px;
        font-size: 3em;
    }

    .card .content h3 {
        font-size: 1.8em;
        position: static;
        transform: translateX(-0%);
    }

    .card .content p {
        font-size: 0.8em;
    }

    .card .content a {
        font-size: 0.8em;
        display: inline-block;
        padding: 3px 10px;
        margin-top: 4px;
    }

    .cast .mr{
        margin: 10px 18px;
    }

    .botton{
        margin: 25px 0 0 0;
    }

    .item-sm i {
        margin-right: 10px;
    }

    .flex-system02{
        display: flex;
        align-items: center;
        margin-bottom: 20px;
        height: 285px;
    }

    .item-sm .text {
        font-size: 1rem;
        line-height: 1.96875;
        margin: 0 30px;
    }

    .item-sm .t2rem{
        font-size: 1rem;
    }

    .item-sm h3{
        font-size: 0.9rem;
        margin-top: 10px;
    }

    .item-sm .color{
        color: #d78f2d;
    }

    .item-sm .big{
        font-size: 1.5rem;
        margin: 0;
    }

    .t1-5rem {
        font-size: 1rem;
        margin: 0px 5px;
    }

    .flex-photo03{
        display: flex;
        align-items: center;
        margin-bottom: 20px;
        height: 270px;
    }

    .news{
        margin: 70px 5% 0px;
    }

    .news_title{
        font-size: 3rem;
    }

    .news .flex{
        display: contents;
    }

    .home-news__list {
        width: 100%;
        margin-top: 30px;
    }

    .news h2 {
        font-size: 1rem;
    }

    .linklist-news__link {
        margin-left: 35px;
        width: 60%;
        font-size: 1rem;
    }

    
    .linklist-news {
        font-size: 1rem;
    }

    .linklist-news__item {
        padding: 30px 15px;
    }

    .access{
        margin-top: 10px;
    }

    .access h3 {
        font-size: 3rem;
        font-weight: normal;
    }

    .access h2{
        font-size: 1rem;
        margin-bottom: 15px;
    }

    .gmap{
        height: 350px;
    }

    .access .t2rem{
        margin-top: 0.5em;
        font-size: 1.4rem;
    }

    .access .t1-5rem{
        margin-top: 0.2em;
        font-size: 1rem;
    }

    .swiper-slide {
        background-position: top;
        background-size: cover;
        width: 200px;
        height: 200px;
    }

    .swiper-container {
        padding-top: 50px;
    }
    

}


h2{
    font-weight: normal;
}

#fv-video{    
    width: 100%;
    height: 100vh;
    object-fit: cover;
    object-position: center;
    margin-top: 100px;
}

#fv-video2{    
    width: 100%;
    height: 100vw;
    object-fit: cover;
    object-position: center;
    margin-top: 80px;
}

.banner-riogroup {
    background: no-repeat center /cover url(../img/riogroup.jpg);
}

.reviews-content h2 {
    font-size: 3.5rem;
    margin-bottom: 36px;
    text-align: center;
}