@charset "utf-8";


body .pc_view{
    display: block !important;
}

body .sp_view{
    display: none !important;
}

@media screen and (max-width: 768px){
    body .pc_view {
        display: none !important;
    }

    body .sp_view {
        display: block !important;
    }
}

.copy{
    user-select:none;
    -webkit-user-select:none;
    -moz-user-select:none;
    -khtml-user-select:none;
    -webkit-user-drag:none;
    -khtml-user-drag:none;
}
  
.box{
    opacity: 0;
}

.fadeUp-y {
    animation-name:fadeUpAnimeY;
    animation-duration:0.5s;
    animation-fill-mode:forwards;
    opacity: 0;
}
@keyframes fadeUpAnimeY{
    from {
    opacity: 0;
    transform: translateY(100px);
    }

    to {
    opacity: 1;
    transform: translateY(0);
    }
}

.fadeUp-x {
    animation-name:fadeUpAnimeX;
    animation-duration:0.4s;
    animation-fill-mode:forwards;
    opacity: 0;
}
@keyframes fadeUpAnimeX{
    from {
    opacity: 0;
    transform: translateX(-200px);
    }

    to {
    opacity: 1;
    transform: translateX(0);
    }
}

img{
    width:100%;
}

a:hover{
    opacity: 0.8;
}

.site-main .orange{
    color:#FF8C46;
}

/* twitter */
.twitter{
    position: relative;
    width: 100%;
    margin: -3% 0 0;
    z-index:1;
}
.twitter p{
    position: absolute;
    top: 44%;
    left: 30%;
    width: 40%;
    text-align: center;
    color:#FFF;
    font-size:1.2vw;
    font-weight: bold;
    line-height: 1.7;
    z-index: 2;
}
@media screen and (max-width: 768px){
    .twitter{
        margin: -9% 0 0;
    }
    .twitter p{
        top: 32%;
        left: 5%;
        width: 90%;
        font-size:4vw;
        line-height: 1.7;
    }
}

/* story */
.story{
    position: relative;
    width: 100%;
    margin: 0;
    z-index:1;
}

.story .ttl_story{
    position: absolute;
    top: 22%;
    left: 21%;
    width: 4.7%;
}
.story .img_story{
    position: absolute;
    top: 27%;
    right: 0;
    width: 70%;
}
.txt_story{
    position: absolute;
    top: 55%;
    left: 32%;
    width: 35%;
}

@media screen and (max-width: 768px){
    .story{
        position: relative;
        width: 100%;
        margin: 0;
    }
    .story .ttl_story{
        top: 11%;
        left: 6%;
        width: 55%;
    }
    .story .img_story{
        top: 23.5%;
        right: 0;
        width: 88%;   
    }
    .txt_story{
        position: absolute;
        top: 53%;
        left: 18.5%;
        width: 73%;
    }
}

/* character */
.character{
    position: relative;
}
.character img{
    width: 100%;
    height: auto;
    vertical-align: bottom;
}

.character .ttl_gallery{
    position: absolute;
    top:0;
    left: 0;
    z-index: 2;
}
.character .gallery{
    margin:0 0 3% 0;
    padding: 12.6% 0 0;
}

.character .gallery img{
    user-select:none;
    -moz-user-select:none;
    -ms-user-select:none;
    -webkit-user-select:none;
    -khtml-user-select:none;
    -webkit-user-drag: none;
    -khtml-user-drag: none;
    -webkit-touch-callout: none;
}

#main .slick-prev, 
#main .slick-next {
    position: absolute;
    z-index: 2;
    top: 83%;
    cursor: pointer;
    outline: none;
    width: 6%;
    height: auto;
}
  
#main .slick-prev {
    left:21%;
}

#main .slick-next {
    left:28%;
}

#main .slick-prev:before,
#main .slick-next:before{
    display: none;
}

.character{
    width:100%;
    margin:0 auto;
    padding: 0 0 4.4%;
}
_::-webkit-full-page-media, _:future, :root .character{
    padding: 0 0 3%;
}
  
.character ul{
    margin:0;
    padding: 0;
    list-style: none;
}

.character .choice-btn{
    width: 35%;
    margin:-8% 0 -1% 20%;
}

.character .slick-track{
    display: flex;
    justify-content: space-between;
}

.character .choice-btn li{
    cursor: pointer;
    outline: none;
    width:18%!important;
}

.character .choice-btn li img{
    opacity: 0.4;
}
  
.character .choice-btn li.slick-current img{
    opacity: 1;
}

.character a{
    color: #333;
}
  
.character a:hover,
.character a:active{
    text-decoration: none;
}

@media screen and (max-width: 768px){
    #main .character .gallery{
        padding: 40.5% 0 0;
    }   
    #main .slick-prev, 
    #main .slick-next {
        position: absolute;
        z-index: 3;
        top: 52%;
        cursor: pointer;
        outline: none;
        width: 8%;
        height: auto;
    }
    
    #main .slick-prev {
        left:0;
    }

    #main .slick-next {
        left:92%;
    }

    .character .choice-btn{
        width: 90%;
        margin: -22% 0 7% 5%;
    }
    #main .character{
        padding: 0;
    }
}
  
/* comics */
.comics{
    position: relative;
    width: 100%;
    margin: 0;
    z-index: 2;
    line-height: 0;
}
.comics .ttl_comics{
    position: absolute;
    top: 14%;
    left: 21%;
    width: 4.7%;
    z-index: 3;
}
.comics .img_comics{
    position: absolute;
    top: 27%;
    right: 0;
    width: 70%;
    z-index: 3;
}
.txt_comics{
    position: absolute;
    top: 55%;
    left: 32%;
    width: 35%;
}
.modal_comics_top{
    position: absolute;
    top: 18%;
    left: 29%;
    width: 50%;
    display: flex;
    justify-content: space-between;
    gap: 2%;
    z-index: 3;
}
.modal_comics_middle{
    position: absolute;
    top: 42%;
    left: 29%;
    width: 50%;
    display: flex;
    justify-content: space-between;
    gap: 2%;
    z-index: 3;
}
.modal_comics_bottom{
    position: absolute;
    top: 67%;
    left: 29%;
    width: 50%;
    display: flex;
    justify-content: space-between;
    gap: 2%;
    z-index: 3;
}
.modal-open{
	margin: auto;
	cursor: pointer;
}
.modal-container{
	position: fixed;
    z-index: 999;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	text-align: center;
	background: rgba(0,0,0,50%);
	padding:0 0 40px;
	overflow: auto;
	opacity: 0;
	visibility: hidden;
	transition: .3s;
    box-sizing: border-box;
}
.modal-container > img{
    position: fixed;
    top:0%;
    left: 0;
    z-index: 1;
}
.modal-container.active{
	opacity: 1;
	visibility: visible;
}
.modal-body{
	position: relative;
	display: inline-block;
	vertical-align: middle;
    margin: 7% 0 0;
}
.modal-close{
    position: fixed;
    display: flex;
    align-items: center;
    justify-content: center;
    top: 2%;
    right: 29%;
    width: 3vw;
    height: 4vh;
    font-size: 60px;
    color: #fff;
    cursor: pointer;
    z-index: 2;
}
.modal-content{
    width: 44vw;
}

@media screen and (max-width: 768px){
    .comics{
        margin:0;
    }
    .comics .ttl_comics{
        top: 6%;
        left: 6%;
        width: 60%;
    }
    .comics .img_comics{
        position: absolute;
        top: 27%;
        right: 0;
        width: 70%;
    }
    .modal_comics_top{
        top: 11%;
        left: 5%;
        width: 90%;
        display: block;
    }
    .modal_comics_middle{
        top: 39%;
        left: 5%;
        width: 90%;
        display: block;
    }
    .modal_comics_bottom{
        top: 67%;
        left: 5%;
        width: 90%;
        display: block;
    }
    .img_modal{
        margin-bottom: 8%;
    }
    .modal-container > img{
        top:55px;
    }
    .modal-content {
        width: 100vw;
        padding:34% 0 0;
    }
    .modal-body{
        margin:0;
    }
    .modal-close {
        width: 44px;
        height: 44px;
        top: 0.4%;
        right: 2%;
        z-index: 2;
    }
}

/* sns */
.sns{
    position: relative;
    width: 100%;
    margin: 0;
    z-index: 1;
}
.sns .ttl_twitter{
    position: absolute;
    top: 11%;
    left: 50%;
    width: 3%;
    z-index: 3;
    transform: translateX(-50%);
}
.sns .timeline{
    position: absolute;
    top: 18%;
    left: 27%;
    width: 46%;
    text-align: center;
    z-index: 3;
}
.sns .timeline iframe{
    height: 330px !important;
}

.sns .btn_sns{
    position: absolute;
    top: 72%;
    left: 40%;
    width: 20%;
    padding: 0 1%;
    background: #FFF;
    z-index: 2;
}

.sns .btn_sns ul{
    display: flex;
    justify-content: space-around;
}

.sns .btn_sns ul li{
    width:17%;
}

.sns .btn_sns ul li:first-child{
    padding: 1% 0 0;
}

@media screen and (max-width: 768px){
    .sns .ttl_twitter{
        position: absolute;
        top: 9%;
        width: 10%;
        z-index: 3;
    }
    .sns .timeline{
        position: absolute;
        top: 15%;
        left: 5%;
        width: 90%;
    }
    .sns .timeline iframe{
        height: 110vw !important;
    }
    .sns .btn_sns{
        top: 68%;
        left: 15%;
        width: 70%;
        padding: 0 1%;
    }
}

/* item */
.item{
    position: relative;
    width: 100%;
    margin: 0;
    z-index: 1;
}

.item .bnr_item{
    position: absolute;
    top: 9%;
    left: 37%;
    width: 26%;
    z-index: 2;
}

.item ul{
    position: absolute;
    display: flex;
    justify-content: space-between;
    width: 60%;
    top: 28%;
    left: 20%;
    z-index: 2;
}
.item ul:nth-child(3) {
    justify-content: center;
    top: 60%;
}
.item ul:nth-child(3) li:nth-child(2) {
    margin-left: 9%;
}
.item ul li{
    width:18%;
    text-align: center;
}

.item ul li img{
    width:86%;
}
  
.item ul li p{
    font-size: 0.7vw;
    line-height: 1.8;
    text-align: left;
    margin: 8% 0;
}
.item ul li:first-child p{
    color:#EA5F01;
}
.item ul li:nth-child(2) p{
    color:#00ACEB;
}
.item ul li:nth-child(3) p{
    color:#A72127;
}
.item ul li:nth-child(4) p{
    color:#89B727;
}
.item ul:nth-child(3) li:nth-child(1) p{
    color:#6C0005;
}
.item ul:nth-child(3) li:nth-child(2) p{
    color:#E89600;
}
.item ul li a{
    display: block;
    width: 6vw;
    margin: 0 auto;
}
.item ul li a img{
    width:100%;
}

.pc_pagetop{
    display:none;
    position: fixed;
    bottom: 5%;
    right: 2%;
    width: 5%;
    z-index: 3;
}
.sp_pagetop{
    display: none;
}

@media screen and (max-width: 768px){
    .item .bnr_item {
        top: 5%;
        left: 10%;
        width: 80%;
    }
    .item .bnr_item a{
        display: block;
    }
    .item ul{
        -webkit-flex-wrap: wrap;/* Safari etc. */
        -ms-flex-wrap    : wrap;/* IE10        */
        flex-wrap        : wrap;
        width: 86%;
        top: 15%;
        left: 7%;
        gap:6%;
    }
    .item ul:nth-child(3) {
        top: 65%;
    }
    .item ul:nth-child(3) li:nth-child(2) {
        margin-left: 0;
    }
    .item ul li{
        width: 47%;
        margin: 0 0 13%;
    }
    .item ul li a{
        width: 60%;
    }
    .item ul li img{
        width:100%;
    }
    .item ul li p {
        font-size: 3.5vw;
        line-height: 1.5;
        text-align: left;
        margin: 7% 0;
    }
    .pc_pagetop{
        display:none;
    }
    .sp_pagetop {
        display: block;
        position: absolute;
        top: 92%;
        left: 39%;
        width: 22%;
    }
}