@charset "utf-8";
.sub .pageTtlWrap{
    margin-bottom: min(calc(80 / var(--vw-min) * 100vw), 80px);
}
@media screen and (max-width:767px) {
    .sub .pageTtlWrap{
        margin: 0 auto calc(60 / var(--vw-min) * 100vw) auto;
        justify-content: center;
    }
}
/*---------------------------------
* CHARACTER
----------------------------------*/
.characterArea__inner{
    width: min(calc(1100 / var(--vw-min) * 100vw), 1100px);
    margin: 0 auto;
}
@media screen and (max-width:767px) {
    .characterArea__inner{
        width: 100%;
        padding: 0 calc(30 / var(--vw-min) * 100vw);
    }
}
.pageTtlWrap{
}
.pageTtl-text {
    color: var(--color-red);
    font-size: min(calc(145 / var(--vw-min) * 100vw), 145px);
    font-family: var(--font-en);
    line-height: 0.7em;
    position: relative;
    padding-right: min(calc(100 / var(--vw-min) * 100vw), 100px);
    padding-bottom: min(calc(20 / var(--vw-min) * 100vw), 20px);
}
.areaTtl__decotxt{
    font-family: "Kolker Brush", cursive;
    font-weight: 400;
    text-shadow: 0 0 min(calc(20 / var(--vw-min) * 100vw), 20px) var(--color-red);
    font-size: min(calc(78 / var(--vw-min) * 100vw), 78px);
    color: rgb(255, 255, 255);
    position: absolute;
    right: 0px;
    bottom: 0px;
    line-height: 1;
}
@media screen and (max-width:767px) {
    .pageTtl-text{
        font-size: calc(120 / var(--vw-min) * 100vw);
        margin-right: 0;
		padding-right: 0;
        letter-spacing: -0.01em;
    }
	.sub .pageTtlWrap{
		width: 100%;
	}
}

.charaLists{
    display: flex;
    gap: min(calc(46 / var(--vw-min) * 100vw), 46px);
    flex-wrap: wrap;
}
@media screen and (max-width:767px) {
    .charaLists{
        flex-direction: row;
        flex-wrap: wrap;
        gap:calc(50 / var(--vw-min) * 100vw);
    }
}
.charaItem{
    width:min(calc(240 / var(--vw-min) * 100vw), 240px);
}
@media screen and (max-width:767px) {
    .charaItem{
        width: calc(307 / var(--vw-min) * 100vw);
    }
}

.charaItem-img{
    mask: url(../img/character/deco/chara_thum_bg.svg) no-repeat center center / contain;
    background: url(../img/character/deco/chara_thum_bg.svg) no-repeat center center / contain;
    display: block;
    position: relative;
    width: 100%;
    height:min(calc(320 / var(--vw-min) * 100vw), 320px);
    overflow: hidden;
    margin-bottom: min(calc(12 / var(--vw-min) * 100vw), 12px);
    /*background: linear-gradient(180deg, #AE0002 0%, #2D0000 100%);*/
    border-radius: min(calc(120 / var(--vw-min) * 100vw), 120px) min(calc(120 / var(--vw-min) * 100vw), 120px) 0 0;
}
.charaItem-img::before{
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background: url(../img/character/deco/chara_thum_frame.png) no-repeat center top;
    background-size: 100% auto;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    pointer-events: none;
    z-index: 1;
    border-bottom: 1px solid rgba(165, 124, 12, 0.4);
}
@media screen and (max-width:767px) {
    .charaItem-img{
        width: 100%;
        height:calc(412 / var(--vw-min) * 100vw);
        margin-bottom:calc(16 / var(--vw-min) * 100vw);
        /*background: linear-gradient(180deg, #AE0002 0%, #2D0000 100%);*/
        border-radius: min(calc(120 / var(--vw-min) * 100vw), 120px) min(calc(120 / var(--vw-min) * 100vw), 120px) 0 0;
    }
}
.charaItem-img img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: all 0.4s ease;
}
@media screen and (hover:hover) and (pointer: fine){
    /*hover*/
    .charaItemLink:hover img{
        transform: scale(1.04);
    }
}

.charaItem-name{
    color: #FFF;
    text-align: center;
    display: block;
    background-image: url(../img/common/deco/deco-gole-l.svg),url(../img/common/deco/deco_gold-r.svg);
    background-repeat: no-repeat,no-repeat;
    background-position: left center,right center ;
    background-size: min(calc(30 / var(--vw-min) * 100vw), 30px) auto;
    font-size: min(calc(16 / var(--vw-min) * 100vw), 16px);
}
@media screen and (max-width:767px) {
    .charaItem-name{
        font-size: calc(20 / var(--vw-min) * 100vw);
        background-size: calc(38 / var(--vw-min) * 100vw)auto;
    }
}


.characteContents{
    border-top:1px solid var(--color-red);
    border-bottom:1px solid var(--color-red);
    margin-bottom: ;
}
.characteContents__inner{
    max-width: min(calc(1366 / var(--vw-min) * 100vw), 1366px);
    position: relative;
    margin: 0 auto;
    padding:0 min(calc(90 / var(--vw-min) * 100vw), 90px);
}
@media screen and (max-width:767px) {
    .characteContents{
        margin-bottom: calc(90 / var(--vw-min) * 100vw);
    }
    .characteContents__inner{
        width:100%;
        padding: 0;
    }
}
.characterDetailBoxWrap{
    margin: 0 auto;
    border-left: 1px solid var(--color-red);
    border-right: 1px solid var(--color-red);
    padding:min(calc(40 / var(--vw-min) * 100vw), 40px) ;
    background: url(../img/character/deco/chara_deco_corner.svg) no-repeat left min(calc(20 / var(--vw-min) * 100vw), 20px) top min(calc(20 / var(--vw-min) * 100vw), 20px);
    background-size:min(calc(140 / var(--vw-min) * 100vw), 140px) auto;
}
@media screen and (max-width:767px) {
    .characterDetailBoxWrap{
        width:100%;
        border-left: unset;
        border-right: unset;
        padding:calc(40 / var(--vw-min) * 100vw);
        background: url(../img/character/deco/chara_deco_corner.svg) no-repeat left min(calc(20 / var(--vw-min) * 100vw), 20px) top min(calc(20 / var(--vw-min) * 100vw), 20px);
        background-size:min(calc(140 / var(--vw-min) * 100vw), 140px) auto;
        position: unset;
    }
}
.characterDetailBox{
    height: min(calc(764 / var(--vw-min) * 100vw), 764px);
    background: linear-gradient(180deg, #AE0002 0%, #2D0000 100%);
    border-radius: min(calc(200 / var(--vw-min) * 100vw), 200px) 0 0 0;
    padding: min(calc(80 / var(--vw-min) * 100vw), 80px);
    position: relative;
}
@media screen and (max-width:767px) {
    .characterDetailBox{
        height: auto;
        border-radius: calc(200 / var(--vw-min) * 100vw) 0 0 0;
        padding: calc(40 / var(--vw-min) * 100vw);
    }
}
.characterDetailBox::before{
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    background: url(../img/character/deco/deco_noise_chara.svg);
    content: "";
    width: 100%;
    height:  100%;
    pointer-events: none;
    opacity: 0.3;
    mix-blend-mode:multiply;
    border-radius: min(calc(200 / var(--vw-min) * 100vw), 200px) 0 0 0;
}
.characterDetailBox::after{
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    background: url(../img/character/deco/chara_frame.svg) no-repeat left top / contain;
    content: "";
    width: min(calc(220 / var(--vw-min) * 100vw), 220px);
    height: min(calc(220 / var(--vw-min) * 100vw), 220px);
    pointer-events: none;
}

.characterDetailBox__inner{
    display: flex;
    height: 100%;
    min-height: min(calc(764 / var(--vw-min) * 100vw), 764px);
    z-index: 1;
}
.characterDetail__left{
    min-height: min(calc(764 / var(--vw-min) * 100vw), 764px);
    width: calc(100% - min(calc(506 / var(--vw-min) * 100vw), 506px));
}
.characterDetail__right{
    width: min(calc(506 / var(--vw-min) * 100vw), 506px);
}
@media screen and (max-width:767px) {
    .characterDetailBox__inner{
        flex-direction: column;
    }
    .characterDetail__left{
        min-height: min(calc(764 / var(--vw-min) * 100vw), 764px);
        width: 100%;
        margin-bottom: calc(64 / var(--vw-min) * 100vw);
        position: relative;
    }
    .characterDetail__right{
        width: 100%;
    }
}

.characterDetail__txt{
    display: flex;
}
 .chara__mainimg{
    position: absolute;
    right: 50%;
    bottom: min(calc(20 / var(--vw-min) * 100vw), 20px);
    width: min(calc(532 / var(--vw-min) * 100vw), 532px);
    height: auto;
    margin-right: min(calc(100 / var(--vw-min) * 100vw), 100px);
    width: min(calc(532 / var(--vw-min) * 100vw), 532px);
    height: auto;
    pointer-events: none;
    opacity: 0;
    transform: translateX(-40px);
    transition: transform .4s ease, opacity .4s ease;
    transition-delay: 0.6s;
    z-index: 1;
}
._chara1 .chara__mainimg{
    bottom: min(calc(80 / var(--vw-min) * 100vw), 80px);
    margin-right: min(calc(150 / var(--vw-min) * 100vw), 150px);
    width: min(calc(532 / var(--vw-min) * 100vw), 532px);
}
._chara3 .chara__mainimg{
    bottom: min(calc(20 / var(--vw-min) * 100vw), 20px);
    margin-right: min(calc(40 / var(--vw-min) * 100vw), 40px);
}
@media screen and (max-width:767px) {
    .chara__mainimg{
        position: relative;
        right:unset;

        bottom: unset;
        width: unset;
        height: auto;
        margin-right:unset;

        transform: translateX(-40px);
        transition: all .4s ease;
        transition-delay: 0.6s;
        z-index: 1;
        margin-left: -20%;
        margin-top: -60%;
        margin-right: unset!important;
        width: 110%;
        bottom: unset!important;
    }
    ._chara1 .chara__mainimg{
        width: 110%;
        margin-left: -30%;
    }
    ._chara2 .chara__mainimg{
        margin-left: -30%;
    }
    ._chara3 .chara__mainimg{
        width: 100%;
        margin-left: -5%;
        margin-top: -50%;
    }
    ._chara4 .chara__mainimg{
        width: 100%;
        margin-top: -50%;
    }
}
.is-ani .chara__mainimg{
    opacity: 1;
    transform: translateX(0);
}
.chara__name-en{
    position: absolute;
    left: 0;
    bottom: min(calc(50 / var(--vw-min) * 100vw), 50px);
    font-size: min(calc(140 / var(--vw-min) * 100vw), 140px);
    color: #FFF;
    text-shadow: 0 0 20px #F00;
    font-family: "Kolker Brush";
    opacity: 0;
    transform: translateY(40px);
    transition: transform .4s ease, opacity .4s ease;
    transition-delay: 0.6s;
    z-index: 2;
    line-height: 0.6;
}
.is-ani .chara__name-en{
    opacity: 1;
    transform: translateX(0);
}
.chara__name-en.-line2{
    text-indent: -0.3em;
    padding-left: 0.3em;
} 
/* chara */
._chara2 .chara__name-en{
    left: max(calc(-20 / var(--vw-min) * 100vw), -20px);
    bottom: min(calc(30 / var(--vw-min) * 100vw), 30px);
}
._chara3 .chara__name-en{
    left: max(calc(-20 / var(--vw-min) * 100vw), -20px);
}
@media screen and (max-width:767px) {
    .chara__name-en{
        position: absolute;
        left: calc(-30 / var(--vw-min) * 100vw);
        bottom: 0;
        font-size: calc(200 / var(--vw-min) * 100vw);
    }
    ._chara2 .chara__name-en{
        left: calc(-70 / var(--vw-min) * 100vw);
        bottom: calc(30 / var(--vw-min) * 100vw);
    }
    ._chara3 .chara__name-en{
        left: calc(-70 / var(--vw-min) * 100vw);
        bottom: 0;
    }
}

.txtBox{
    display: flex;
    margin-bottom:min(calc(20 / var(--vw-min) * 100vw), 20px);
    opacity: 0;
    transform: translateY(40px);
    transition: all .4s ease;
    transition-delay: 0.6s;
}
.is-ani .txtBox{
    opacity: 1;
    transform: translateX(0);
}

.txtBox__ttl{
    width: min(calc(60 / var(--vw-min) * 100vw), 60px);
    border-right: 1px solid #FFF;
    writing-mode: vertical-rl;
    padding-right: min(calc(16 / var(--vw-min) * 100vw), 16px);
}
.txtBox__txt{
    width:  min(calc(428 / var(--vw-min) * 100vw), 428px);
    padding:  min(calc(14 / var(--vw-min) * 100vw), 14px) 0;
    margin-left: min(calc(40 / var(--vw-min) * 100vw), 40px);
}
@media screen and (max-width:767px) {
    .txtBox__ttl{
        width: auto;
        font-size: calc(20 / var(--vw-min) * 100vw);
        padding-right: calc(20 / var(--vw-min) * 100vw);
    }
    .txtBox__txt{
        flex: 1;
        width: auto;
        padding: calc(10 / var(--vw-min) * 100vw) 0;
        margin-left:calc(36 / var(--vw-min) * 100vw);
    }
}

/* chara name */
.chara__name{
    font-size:min(calc(30 / var(--vw-min) * 100vw),30px);
    font-weight: 900;
    display: block;
}
.chara__cv{
    display: inline-block;
    font-size:min(calc(20 / var(--vw-min) * 100vw),20px);
    margin-top: min(calc(12 / var(--vw-min) * 100vw),12px);
}
@media screen and (max-width:767px) {
    .chara__name{
        font-size:calc(40 / var(--vw-min) * 100vw);
    }
    .chara__cv{
        font-size:calc(28 / var(--vw-min) * 100vw);
        margin-top:calc(14 / var(--vw-min) * 100vw);
    }
}

/* chara teams */
.teams__ttl{
    display:inline-block;
    background-color: #000;
    color: var(--color-red);
    font-size: min(calc(18 / var(--vw-min) * 100vw), 18px);
    font-weight: 900;
}
.teams__name{
    display: block;
    margin-top: min(calc(10 / var(--vw-min) * 100vw), 10px);
    font-size: min(calc(18 / var(--vw-min) * 100vw), 18px);
    font-weight: 900;
}
@media screen and (max-width:767px) {
    .teams__ttl{
        font-size: calc(24 / var(--vw-min) * 100vw);
    }
    .teams__name{
        margin-top: calc(26 / var(--vw-min) * 100vw);
        font-size: calc(24 / var(--vw-min) * 100vw);
    }
}

/* chara txt */
.chara__txt{
    margin-top: min(calc(40 / var(--vw-min) * 100vw), 40px);
    font-size: min(calc(15 / var(--vw-min) * 100vw), 15px);
    font-style: normal;
    font-weight: 600;
    line-height: 186.667%
}
@media screen and (max-width:767px) {
    .chara__txt{
        margin-top: calc(44 / var(--vw-min) * 100vw);
        font-size: calc(24 / var(--vw-min) * 100vw);
        line-height: 180%
    }
}

/*controlBlock*/
.controlBlock{
    width: 100%;
    max-width: min(calc(1366 / var(--vw-min) * 100vw), 1366px);
    margin: auto;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    position: absolute;
    display: flex;
    justify-content: center;
    pointer-events: none;
}
@media screen and (max-width:767px) {
    .controlBlock{
        position: absolute;
        max-width:unset;
        top: unset;
        bottom:  calc(-90 / var(--vw-min) * 100vw);
    }
}
/*charaLink*/
.charaLink{
    display: flex;
    width: min(calc(90 / var(--vw-min) * 100vw),90px);
    justify-content: space-between;
    pointer-events: all;
    align-items: center;
}
.charaLink._prev{
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    justify-content: flex-end;
}
.charaLink._next{
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    justify-content: flex-start;
}
@media screen and (max-width:767px) {
    .charaLink._prev,
    .charaLink._next{
        width:calc(142 / var(--vw-min) * 100vw);
        flex-direction: row-reverse;
    }
    .charaLink._prev{
        left:calc(36 / var(--vw-min) * 100vw);

    }
    .charaLink._next{
        right:calc(36 / var(--vw-min) * 100vw);
    }
}

.charaLink-text{
    color: var(--color-red);
    font-family: var(--font-en);
    font-size:min(calc(24 / var(--vw-min) * 100vw),24px);
    transition: all .4s ease;
    writing-mode: vertical-rl;
}
.charaLink._prev .charaLink-text{
    margin-right:min(calc(10 / var(--vw-min) * 100vw),10px);
}
.charaLink._next .charaLink-text{
    margin-left:min(calc(10 / var(--vw-min) * 100vw),10px);
}
@media screen and (max-width:767px) {
    .charaLink-text{
        font-size:calc(28 / var(--vw-min) * 100vw);
        writing-mode: unset;
    }
    .charaLink._prev .charaLink-text{
        margin-right: 0;
        margin-left:min(calc(10 / var(--vw-min) * 100vw),10px);
    }
    .charaLink._next .charaLink-text{
        margin-left: 0;
        margin-right:min(calc(10 / var(--vw-min) * 100vw),10px);
    }
}

.charaLink._next .moreLink-arrow::after {
    right: unset;
    left: -3px;
}
.charaLink._prev .moreLink-arrow::after {
    left: unset;
    right: -3px;
}
@media screen and (max-width:767px) {
    .charaLink._next .moreLink-arrow::after {
        left: unset;
        right: 0;
    }
    .charaLink._prev .moreLink-arrow::after {
        right: unset;
        left: 0;
    }
}

@media screen and (hover:hover) and (pointer: fine){
    /*hover*/
    @media screen and (min-width:768px) {
        .charaLink._prev:hover .moreLink-arrow::after{
            right: 100%;
            left: unset;
        }
        .charaLink._prev:hover .charaLink-text{
            transform: translateX(calc(3 / var(--vw-min) * 100vw));
        }
        .charaLink._next:hover .moreLink-arrow::after{
            left: 100%;
            right: unset;
        }
        .charaLink._next:hover .charaLink-text{
            transform: translateX(calc(-3 / var(--vw-min) * 100vw));
        }
    }
    @media screen and (max-width:767px) {
        .charaLink._prev:hover .charaLink-text,
        .charaLink._next:hover .charaLink-text{
            transform: unset;
        }
    }
}

/*moreLink*/
.moreLink{
    display: flex;
    width: 113px;
    justify-content: space-between;
    pointer-events: all;
    align-items: center;
}
@media screen and (max-width:767px) {
    .moreLink{
        width:calc(139 / var(--vw-min) * 100vw);
    }
}
.moreLink-text{
    color: var(--color-red);
    font-family: var(--font-en);
    font-size:min(calc(24 / var(--vw-min) * 100vw),24px);
    transition: all .4s ease;
    letter-spacing:0;
}
@media screen and (max-width:767px) {
    .moreLink-text{
        font-size:calc(28 / var(--vw-min) * 100vw);
    }
}
.moreLink-arrow{
    position: relative;
    width: min(calc(28 / var(--vw-min) * 100vw),28px);
}
.moreLink-arrow::before{
    content: "";
    position: absolute;
    margin: auto;
    top: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: var(--color-red);
}
.moreLink-arrow::after{
    content: "";
    position: absolute;
    margin: auto;
    top: 0;
    bottom: 0;
    right: 0;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background-color: var(--color-red);
    transition: all .4s ease;
}
@media screen and (max-width:767px) {
    .moreLink-arrow{
        position: relative;
        width: calc(40 / var(--vw-min) * 100vw);
    }
    .moreLink-arrow::after{
        width: calc(9 / var(--vw-min) * 100vw);
        height: calc(9 / var(--vw-min) * 100vw);
    }
}
@media screen and (hover:hover) and (pointer: fine){
    /*hover*/
    .moreLink:hover .moreLink-text{
        transform: translateX(calc(5 / var(--vw-min) * 100vw));
    }
    .moreLink:hover .moreLink-arrow::after{
        right: 100%;
    }
}




/* BACK LINK */
.backLinkWrap{
    width: 100%;
    max-width: min(calc(1180 / var(--vw-min) * 100vw), 1180px);
    margin: 0 auto;
    position: relative;
    margin-top: min(calc(50 / var(--vw-min) * 100vw), 50px);
    display: flex;
}
.moreLink._back{
    width: min(calc(229 / var(--vw-min) * 100vw), 229px);
}
.moreLink._back .moreLink-arrow::after {
    right: unset;
    left: 0;
}
@media screen and (max-width:767px) {
    .backLinkWrap{
        margin-top: calc(150 / var(--vw-min) * 100vw);
        justify-content: center;
    }
    .moreLink._back{
        width: calc(268 / var(--vw-min) * 100vw);
    }
}
@media screen and (hover:hover) and (pointer: fine){
    /*hover*/
    .moreLink._back:hover .moreLink-arrow::after{
        left: 100%;
        right: unset;
    }
    .moreLink._back:hover .moreLink-text{
        transform: translateX(calc(-5 / var(--vw-min) * 100vw));
    }
}
