html{
    font-family: 'Chakra Petch',"M PLUS 1p";
}
body{
    margin: 0;
    color: #eee;
    background: #202020;
}
h1{
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    font-family: 'Chakra Petch',"M PLUS 1p";
    font-size: 70px;
    line-height: 1;
    margin: 0;
    text-align: center;
}
h2{
    font-family: 'Chakra Petch',"M PLUS 1p";
    font-size: 35px;
    margin: 0;
}
p{
    text-align: left;
    font-size: 12px;
}
dl{
    font-size: 12px;
}
img{
    height: 200px;
    width: 300px;
    object-fit:contain ;
}



.scrolldown1{
    position:absolute;
    left:50%;
    bottom:10px;
    height:50px;
}
.scrolldown1 span{
    position: absolute;
    left:-15px;
    top: -15px;
    color: #eee;
    font-size: 0.7rem;
    letter-spacing: 0.05em;
}
.scrolldown1::after{
    content: "";
    position: absolute;
    top: 0;
    width: 1px;
    border-radius: 20px;
    height: 30px;
    background: #eee;
    animation: pathmove 1.4s ease-in-out infinite;
    opacity: 0;
}
@keyframes pathmove{
    0%{
        height:0;
        top:0;
        opacity: 0;
    }
    30%{
        height:30px;
        opacity: 1;
    }
    100%{
        height:0;
        top:50px;
        opacity: 0;
    }
}
#header{
    width:100%;
    height: 100vh;
    position: relative;
} 
#header:before{
    content: '';
    position:fixed;
    top:0;
    left:0;
    z-index:-1;
    width:100%;
    height: 100vh;
    background-image: url(../img/pattern.png);
}
#container{
    position: relative;
    z-index:1;
    background:#000;
    text-align: center;
}
h1.elegantshadow {
    color: #eee;
    letter-spacing: 0.05em;
    text-shadow:0px 0px 0 hsl(0deg 0% 0% / 96%),
                -1px 2px 1px hsl(0deg 0% 1% / 90%),
                -2px 4px 1px hsl(0deg 0% 2% / 84%), 
                -3px 6px 1px hsl(0deg 0% 3% / 78%),
                -4px 8px 1px hsl(0deg 0% 4% / 72%),
                -5px 10px 1px hsl(0deg 0% 5% / 66%),
                -6px 12px 1px hsl(0deg 0% 6% / 60%),
                -7px 14px 1px  hsl(0deg 0% 7% / 54%),
                -8px 16px 1px hsl(0deg 0% 8% / 48%),
                -9px 18px 1px  hsl(0deg 0% 9% / 42%),
                -10px 20px 1px hsl(0deg 0% 10% / 36%),
                -11px 22px 1px hsl(0deg 0% 11% / 30%),
                -12px 24px 1px hsl(0deg 0% 12% / 24%),
                -13px 26px 1px hsl(0deg 0% 13% / 18%),
                -14px 28px 1px hsl(0deg 0% 14% / 12%),
                -15px 30px 1px hsl(0deg 0% 15% / 6%);
}
.footer{
    padding: 40px 5%;
    background: #eee;
}
.footer p{
    text-align: center;
    color: #111;
}
.sns{
    padding: 40px 7.5%;
}
.news{
    padding: 65px 7.5% 0; 
}
.twitter div{
    margin: 0 auto;
}
.home_link.history_link{
    margin: 0;
}
.news_content dd{
    margin-left: 10px;
    width: 55%;
}

.news_content {
    margin: 20px 0;
    padding: 30px 0;
    border-radius: 25px;
}
.news_content{
    background: #fff;
}
.news_btn {
    border: none;
    background: none;
    width: 100%;
}
.news_btn a{
    width: 35%;
    margin: 0 auto;
    padding: 10px 40px;
    border-radius: 25px;
    border-bottom: 5px #696969 solid;
    background: #8b8b8b;
    text-decoration: none;
    color: #eee;
    display: block;
    font-size: 17px;
    font-family: 'Chakra Petch',"M PLUS 1p";
}
.news_btn a:hover{
    border-bottom: 2px #696969 solid;
    margin-top: 3px;
    background: #7a7a7a;
}
.home_link a{
    padding: 10px 40px;
    border-radius: 25px;
    border-bottom: 5px #696969 solid;
    background: #8b8b8b;
    text-decoration: none;
    color: #eee;
    display: block;
    font-size: 17px;
    font-family: 'Chakra Petch',"M PLUS 1p";
    width: 35%;
    margin: 7px auto;
}
.home_link a:hover{
    border-bottom: 2px #696969 solid;
    margin-top: 10px;
    background: #7a7a7a;
}
.home_link{
    width: 100%;
    border: none;
    background:none;
}
.home_link_wrapper{
    margin-bottom: 50px;
}
.copyright p{
    font-family: 'Chakra Petch',"M PLUS 1p";
}


/* ///////////////////////////////////////////////ハンバーガーナビ///////////////////////////////////////////// */

.button{
	z-index:30;
	position:fixed;
    top: 6px;
    right: 5px;
    z-index: 9999;
}
.openbtn{
	position: relative;
	cursor: pointer;
    width: 65px;
    height:60px;
	border-radius: 5px;
}
.openbtn span{
    display: inline-block;
    transition: all .4s;
    position: absolute;
    left: 14px;
    height: 2px;
    border-radius: 15px;
    background: #eee;
    width: 50%;
}
.openbtn span:nth-of-type(1) {
    top:15px; 
}
.openbtn span:nth-of-type(2) {
    top:26px;
}
.openbtn span:nth-of-type(3) {
    top:37px;
}
.openbtn.active span:nth-of-type(1) {
    top: 18px;
    left: 18px;
    transform: translateY(6px) rotate(-45deg);
    width: 50%;
}
.openbtn.active span:nth-of-type(2) {
    display: none;
}
.openbtn.active span:nth-of-type(3){
    top: 30px;
    left: 18px;
    transform: translateY(-6px) rotate(45deg);
    width: 50%;
}

.goods_btn_in.next1{
    margin-bottom: 40px;
    margin-bottom: 15px;
}
.goods_btn_in.next2{
    margin-bottom: 35px;
}



/* ///////////////////////////////////////////////home_link///////////////////////////////////////////// */
/* .home_link{
    padding: 10px 25px;
} */
/* .home_link h2{
    margin: 0;
    font-size: 30px;
}
.home_link a{
    margin: 0 auto;
    width: 250px;
    text-decoration: none;
    color: #656565;
    display: block;
    padding: 10px 0;
    border-radius: 5px;
    text-shadow: -1px -1px 0 #1e1e1ef7, 1px 1px 1px #8a8a8ae7;
    background: #767676;
    border-bottom: #494949 solid 10px;
    border-right: #cacaca solid 8px;
    border-left: #595959 solid 8px;
    border-top: #b5b5b5 solid 5px;
} */

/* .home_link a:hover{
    border-bottom: #494949 solid 5px;  
    background: #696969;
    margin-top: 5px;
} */
/* .home_link_wrapper{
    padding:10px 0 50px;
} */
.nav{
    width: 65vw;
    height: 100vh;
    position: fixed;
    background:#eeee;
    z-index: 99;
    top: 0;
    left: -65vw;
}
.nav ul{
    padding: 0;
    margin: 0;
    margin-top: 50px;
}
.nav ul li{
    list-style: none;
}
.nav ul li a{
    text-decoration: none;
    color: #000;
    padding: 13px 40px;
    display: block;
    font-size: 20px;
    font-family: 'Chakra Petch',"M PLUS 1p";
}
.overlay{
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: #3338;
    display: none;
    z-index: 99;
}

.navi_anime{
    display:block;
    animation:1s navi_anime forwards;
}
.navi_anime_finish{
    display:block;
    animation:1s navi_anime_finish forwards;
}
@keyframes navi_anime{
    0%{
        left: -65vw;
        pointer-events: none;
    }
    100%{
        left: 0;
        pointer-events: inherit;
    }
}
@keyframes navi_anime_finish{
    0%{
        left: 0;
        pointer-events: inherit;
    }
    100%{
        left: -65vw;
        pointer-events: none;

    }
}
.nav ul li a:hover{
    opacity: 0.4;
    background: #333;
    color: #eee;
}





/* ///////////////////////////////////////////////profile///////////////////////////////////////////// */

.project {
    margin: 70px 5% 120px;
}
.kohei {
    margin: 70px 5% 120px;
}
.project h2{
    text-align: center;
}
.project p{
    text-align: center;
}
#other_header{
    width: 100%;
    height: 40vh;
    position: relative;    
}
#other_header:before{
    content: '';
    position:fixed;
    top:0;
    left:0;
    z-index:-1;
    width:100%;
    height: 40vh;
    background-image: url(../img/pattern.png);
}
#other_header h1{
    position: fixed;
    top: 20%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    font-family: 'Chakra Petch',"M PLUS 1p";
    font-size: 70px;
    line-height: 1;
    margin: 0;
    text-align: center;
}
.project_text{
    margin: 50px 0 30px;
}
.pankuzu{
    padding: 25px 10% 20px;
}
.pankuzu a{
    color: rgb(223 85 99);
}
.pankuzu a:hover{
    text-decoration: none;
}

.profile_sns svg{
    width: 30px;
}
.profile_sns a{
    text-decoration: none;
    margin: 0 0px;
}


.TextTyping span {
	display: none;
}
.TextTyping::after {
 	content: "|";
	animation: typinganime .8s ease infinite;
}
@keyframes typinganime{
	from{opacity:0}
	to{opacity:1}
}
.project_text img{
    margin: 0;
    margin-top: 30px;
    background: #fff;
    padding: 15px 0px;
    border-radius: 25px;
}

.profile_sns svg{
    fill: #eee;
}





/* ///////////////////////////////////////////////history///////////////////////////////////////////// */

.history_link{
    margin: 50px 10%;
}
.history_link p,.history_link h3{
    margin: 0;
}
.history_description{
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 20px;
}
.history_description_left{
    width: 40%;
}
.history_description_right{
    width: 55%;
    text-align: left;
}
.history_description_right h3{
    margin: 3px 0;

}
.history_description_left img {
    cursor: pointer;
    height: 140px;
    width: auto;
    object-fit: contain;
}

.history_img{
    position: fixed;
    width: 100%;
    height: 100vh;
    z-index: 999;
    top: 0;
    left: 0;
    display: none;
    pointer-events: none;
}
.history_img img{
    width: 80%;
    height:auto;
    object-fit: contain;
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 999;
    transform: translate(-50% , -50%);
}
.biscuit_img{
    display: none;
}
.db p{
    margin: 5px;
}
.news_db {
    margin: 20px 0;
}
.ikiru_img {
    display: none;
}






/* ///////////////////////////////////////////////contact///////////////////////////////////////////// */

.contact{
    padding: 20px 7% 40px;
    text-align: left;
}

.tab_btn{
    width: 50%;
    background: #eee;
    border: #eee 3px solid;
}
.tab_btn p{
    text-align: center;
    color: #333;
}
.tabs{
    width: 85%;
    margin: 0 auto;
}
input[name="tab_item"] {
    display: none;

}
.tab_item {
    width: calc(96%/2);
    height: 50px;
    margin: 0 1%;
    line-height: 50px;
    font-size: 15px;
    text-align: center;
    color: #565656;
    display: block;
    float: left;
    text-align: center;
    font-weight: bold;
    transition: all 0.2s ease;
    background: #eee;
}
.tab_item:hover {
    opacity: 0.75;
}
#project_btn:checked ~ #project_contact,
#yumino_btn:checked ~ #yumino_contact{
    display: block;
}
.tabs input:checked + .tab_item {
    background: #aaa;
}
.tab_content {
    padding: 20px 0px 40px;
    clear: both;
    overflow: hidden;
}
#yumino_contact,#project_contact{
    display: none;

}
.tab_content h4{
    color: #eee;
    margin-bottom: 0;
}





/* ///////////////////////////////////////////////contact///////////////////////////////////////////// */
.news.news_wrapper{
    padding: 0px 7.5% 50px;
}
.news_wrapper .news_content dl {
    color: #333;
    display: flex;
    width: 270px;
    margin: 0 ;
    padding:0px; 
}
.news_wrapper .news_content{
    padding: 30px 20px;
}
.news_wrapper .news_content p{
    color: #333;
    margin-bottom: 0;
}
.news_main .pankuzu {
    padding: 25px 10% 10px;
}
.news_content dl {
    color: #333;
    display: flex;
    width: 270px;
    margin: 0 0 0 10px;
    padding:5px 0px; 
}
.news_content{
    padding: 30px 20px;  
}
.goods{
    padding-bottom: 50px;
}

.profile_sns img{
    height: 45px;
    width: auto;
}
.yumino_left p{
    text-align: left;

}
.yumino_left {
    padding: 0 10%;
}


.description_link{
    text-decoration: none;
    color: #eee; 
}
.description_link:hover{
    opacity: 0.6;
}
.description_wrapper img{
    width: 100%;
    height: auto;
}
.description_wrapper {
    margin: 10px 7% 50px;
}
.history_description_left:hover{
    opacity: 0.6;
}

.main_performance .pankuzu {
    padding: 25px 10% 1px;
}
.description_wrapper h3{
    margin: 5px 0;
}
.description_wrapper p{
    margin: 8px 0px;
}
.return_img{
    display: none;
}
.main_cast{
    display: flex;
    width: 100%;
    margin-bottom: 20px;
}
.main_cast_figure{
    width: 50%;
    display: block;
    margin: 0;
}
.sub_cast{
    display: flex;
    width: 100%;
    margin-bottom: 10px;
}
.sub_cast_figure{
    width: calc(100% / 4);
    display: block;
    margin: 0;
}
.cast_list figure img{
    width: 18vw;
    height: 19vh;
    object-fit: cover;
}
.cast_list .main_cast_figure img {
    object-fit: cover;
    width: 40vw;
    height: 35vh;
}

.description_wrapper h4{
    margin-top: 40px;
    margin-bottom: 10px;
    position: relative;
}
.description_wrapper h4::before{
    position: absolute;
    top: 50%;
    left: 0;
    width: 35%;
    height: 1px;
    background: #eee;
    content: "";
}
.description_wrapper h4::after{
    position: absolute;
    top: 50%;
    right: 0;
    width: 35%;
    height: 1px;
    background: #eee;
    content: "";
}
.news_content dt{
    width: 25%;
    text-align: left;

}
.news_content dd{
    width: 75%;
    font-weight: bold;
    text-align: left;
}
.bold{
    font-weight: bold;
}
.next {
    padding: 45px 7.5% 0;
}
.next img {
    width: 70%;
    margin: 20px 0;
    height: auto;
}
.next_link:hover{
    opacity: 0.8;
}

.video {
    position: relative;
    height: 0;
    padding: 30px 0 56.25%;
    overflow: hidden;
}
.video iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.home_video{
    padding: 35px 7.5% 0;
}
.sub_cast_figure figcaption{
    font-size: 12px;
}
.red_link{
    color: rgb(223 85 99);
}
.red_link:hover{
    text-decoration: none;
}
.shop_wrapper{
    display: flex;
    justify-content: space-around;
}
.shop_item{
    text-align: left;
    width: calc(90% / 2);
}
.shop_item img{
    width: 100%;
    height: auto;
}
.shop_item h4{
    font-weight: normal;
    margin-bottom: 0px;
    margin-top: 5px;

}
.shop_item p{
    margin-top: 3px;
}
.shop_item_center.shop_item{
    margin: 20px auto;
}
.shop_item a{
    color: white;
    text-decoration: none;
}
.shop_item a:hover{
    opacity: 0.7;
}
.goods_link{
    margin-top: 40px;
    display: block;
}


.goods_inner{
    display: flex;
    justify-content: left;
    flex-wrap: wrap;
    width: 90%;
    margin:30px  auto;
}


.goods h2{
    margin-bottom: 20px;
}
.goods h3{
    font-size: 1.2em;
}

.shop_item {
    width: calc(100% / 2 - 20px);
    height: auto;
    margin:10px;
    object-fit: contain;
}
.next1_back,.goods_wrapper{
    display: none;
}
.next2_back,.goods_wrapper2{
    display: none;
}

.goods_btn_in{
    width: 100%;
    margin: auto;
    cursor: pointer;
}
.goods_btn_in p{
    border-radius: 30px;
    margin: 0 auto;
    padding: 10px 40px;
    border-bottom: 5px rgb(133, 33, 43) solid;
    background: rgb(223 85 99);
    text-decoration: none;
    color: #eee;
    display: block;
    font-family: 'Chakra Petch',"M PLUS 1p";
    text-align: center;
    font-weight: bold;
    white-space: nowrap;
    font-size: 12px;
    width: fit-content;
}
.goods_btn_in.next2 p {
    border-bottom: 5px rgb(78 50 89) solid;
    background: rgb(102 83 110);
}