@charset "utf-8";
/*-----------------------------------------------
 * COMMON
-------------------------------------------------*/
/**
* BG
**/
.contBgWrap {
    width: 100%;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: -2;
}
.contBg {
    width: 100%;
    height: min(100vh, 100%);
    position: sticky;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: url(../img/common/bg/bg_main.jpg) no-repeat center / cover;
}
@supports (background-image: url(../img/common/bg/bg_main.webp)){
    .contBg{
        background-image: url(../img/common/bg/bg_main.webp);
    }
}
/**
* TIT
**/
.cont-titWrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    overflow: hidden;
}
.cont-tit-catch {
    width: min(calc(208 / var(--vw-min) * 100vw),208px);
    height: min(calc(30 / var(--vw-min) * 100vw),30px);
    display: block;
    -webkit-mask: url(../img/common/deco/deco_catchTit.svg)no-repeat center/contain;
    mask: url(../img/common/deco/deco_catchTit.svg)no-repeat center/contain;
    background-color: var(--color-brown6E1);
    margin-bottom: min(calc(35 / var(--vw-min) * 100vw),35px);
}
@media screen and (max-width:768px){
    .cont-tit-catch {
        width: calc(144 / var(--vw-min) * 100vw);
        height: calc(21 / var(--vw-min) * 100vw);
        margin-bottom: calc(16 / var(--vw-min) * 100vw);
    }
}
.cont-tit-en {
    font-size: min(calc(88 / var(--vw-min) * 100vw),88px);
    color: var(--color-brown6E1);
    line-height: 1;
    font-weight: 700;
    margin-bottom: min(calc(20 / var(--vw-min) * 100vw),20px);
}
.cont-tit-en span {
    display: inline-block;
}
@media screen and (max-width:768px){
    .cont-tit-en {
        font-size: calc(42 / var(--vw-min) * 100vw);
        margin-bottom: calc(12 / var(--vw-min) * 100vw);
    }
}
.cont-tit-ja {
    font-size: min(calc(15 / var(--vw-min) * 100vw),15px);
    color: var(--color-brown6E1);
    line-height: 1;
    font-weight: 700;
}
@media screen and (max-width:768px){
    .cont-tit-ja {
        font-size: calc(12 / var(--vw-min) * 100vw);
    }
}

.subDeco {
    width: 100%;
    position: absolute;
    top: 0;
    z-index: 0;
}
.subDeco:before {
    content: "";
    background: url(../img/common/deco/sub_deco_corner_l.png) no-repeat 0 0 / contain;
    width: min(calc(400 / var(--vw-min) * 100vw), 400px);
    height: min(calc(184 / var(--vw-min) * 100vw), 184px);
    position: absolute;
    top: min(calc(18 / var(--vw-min) * 100vw), 18px);
    left: 0;
}
.subDeco:after {
    content: "";
    background: url(../img/common/deco/sub_deco_corner_r.png) no-repeat 0 0 / contain;
    width: min(calc(400 / var(--vw-min) * 100vw), 400px);
    height: min(calc(184 / var(--vw-min) * 100vw), 184px);
    position: absolute;
    top: min(calc(18 / var(--vw-min) * 100vw), 18px);
    right: 0;
}
@media screen and (max-width:768px){
    .subDeco:before {
        width: calc(187 / var(--vw-min) * 100vw);
        height: calc(86 / var(--vw-min) * 100vw);
        top: calc(13 / var(--vw-min) * 100vw);
    }
    .subDeco:after {
        width: calc(187 / var(--vw-min) * 100vw);
        height: calc(86 / var(--vw-min) * 100vw);
        top: calc(13 / var(--vw-min) * 100vw);
    }
}
.subDeco__decoLine {
    background-color: #FF9D00;
    border-top: min(calc(2 / var(--vw-min) * 100vw), 2px) solid #FFC915;
    border-bottom: min(calc(2 / var(--vw-min) * 100vw), 2px) solid #FFC915;
    width: 100%;
    height: min(calc(18 / var(--vw-min) * 100vw),18px);
    position: absolute;
    top: 0;
}
.subDeco__decoLine::before {
    content: "";
    width: 100%;
    height: min(calc(5 / var(--vw-min) * 100vw),5px);
    margin: auto;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    -webkit-mask: url(../img/common/deco/deco_dot.svg)repeat-x left/min(calc(15 / var(--vw-min) * 100vw),15px) min(calc(5 / var(--vw-min) * 100vw),5px);
    mask: url(../img/common/deco/deco_dot.svg)repeat-x left/min(calc(15 / var(--vw-min) * 100vw),15px) min(calc(5 / var(--vw-min) * 100vw),5px);
    background-color: #FFC915;
}
@media screen and (max-width:768px){
    .subDeco__decoLine {
        border-width: calc(2 / var(--vw-min) * 100vw);
        height: calc(13 / var(--vw-min) * 100vw);
    }
    .subDeco__decoLine::before {
        height: calc(4 / var(--vw-min) * 100vw);
        -webkit-mask-size: calc(12 / var(--vw-min) * 100vw) calc(4 / var(--vw-min) * 100vw);
        mask-size: calc(12 / var(--vw-min) * 100vw) calc(4 / var(--vw-min) * 100vw);
    }
}

.deco__nose {
    width: min(calc(236 / var(--vw-min) * 100vw),236px);
    height: min(calc(300 / var(--vw-min) * 100vw),300px);
    position: absolute;
    top: min(calc(265 / var(--vw-min) * 100vw),265px);
    right: 0;
    z-index: -1;
    overflow: hidden;
}
.deco__nose::before {
    content: "";
    width: min(calc(284 / var(--vw-min) * 100vw),284px);
    height: min(calc(294 / var(--vw-min) * 100vw),294px);
    position: absolute;
    bottom: 0;
    left: 0;
    background: url(../img/common/deco/deco_nose.png)no-repeat center/contain;
}
@media screen and (max-width:768px){
    .deco__nose {
        width: calc(41 / var(--vw-min) * 100vw);
        height: calc(146 / var(--vw-min) * 100vw);
        top: calc(180 / var(--vw-min) * 100vw);
    }
    .deco__nose::before {
        width: calc(140 / var(--vw-min) * 100vw);
        height: calc(140 / var(--vw-min) * 100vw);
    }
}

.deco__full1 {
    width: min(calc(240 / var(--vw-min) * 100vw),240px);
    height: min(calc(190 / var(--vw-min) * 100vw),190px);
    position: absolute;
    left: 0;
    top: min(calc(265 / var(--vw-min) * 100vw),265px);
    z-index: 2;
    overflow: hidden;
}
.deco__full1::before {
    content: "";
    width: min(calc(400 / var(--vw-min) * 100vw),400px);
    height: min(calc(190 / var(--vw-min) * 100vw),190px);
    position: absolute;
    top: 0;
    right: 0;
    background: url(../img/common/deco/deco_full.png)no-repeat center/contain;
}
@media screen and (max-width:768px){
    .deco__full1 {
        width: calc(82 / var(--vw-min) * 100vw);
        height: calc(76 / var(--vw-min) * 100vw);
        top: calc(180 / var(--vw-min) * 100vw);
    }
    .deco__full1::before {
        width: calc(160 / var(--vw-min) * 100vw);
        height: calc(76 / var(--vw-min) * 100vw);
    }
}

/*-----------------------------------------------
* loading
-------------------------------------------------*/
.loading {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	z-index: 10000;
}
.loading::before,
.loading::after {
	content: "";
	width: 50%;
	height: 130%;
	position: absolute;
	top: -15%;
	display: block;
	background: linear-gradient(0deg, #FA6A16, #FDDB2A);
	transform-origin: center;
}
.loading::before {
	left: 0;
}
.loading::after {
	right: 0;
}
.loading.--animate::before {
  animation: curtain_l 2s ease forwards;
}
.loading.--animate::after {
  animation: curtain_r 2s ease forwards;
}
@keyframes curtain_l {
	0% {transform: rotate(0deg) translateX(0%);}
	100% {transform: rotate(6deg) translateX(-120%);}
}
@keyframes curtain_r {
	0% {transform: rotate(0deg) translateX(0%);}
	100% {transform: rotate(-6deg) translateX(120%);}
}
.loading__logo {
	width: min(calc(516 / var(--vw-min) * 100vw),516px);
	position: relative;
    transform: scale(0);
    animation: logoIn .3s forwards;
    z-index: 1;
}
.loading__logo.--out {
  animation: logoOut .6s forwards;
}
@media screen and (max-width: 768px) {
    .loading__logo {
		width: calc(258 / var(--vw-min) * 100vw);
	}
}
.loading__logo img {
	width: 100%;
	pointer-events: none;
}
@keyframes logoIn {
  0% {transform: scale(0);opacity: 0;}
  100% {transform: scale(1);opacity: 1;}
}

@keyframes logoOut {
  0% {transform: scale(1);opacity: 1;}
  100% {transform: scale(0);opacity: 0;}
}

/*-----------------------------------------------
 * GALLERY
-------------------------------------------------*/
.character {
    padding-top: min(calc(136 / var(--vw-min) * 100vw),136px);
}
@media screen and (max-width:768px){
    .character {
        padding-top: calc(90 / var(--vw-min) * 100vw);
    }
}
.charaCont {
    padding-top: min(calc(30 / var(--vw-min) * 100vw),30px);
}
@media screen and (max-width:768px){
    .charaCont {
        padding-top: calc(26 / var(--vw-min) * 100vw);
    }
}
.charaContIn {
    position: relative;
    padding: min(calc(18 / var(--vw-min) * 100vw),18px) 0;
}
@media screen and (max-width:768px){
    .charaContIn {
        padding: calc(13 / var(--vw-min) * 100vw) 0;
    }
}
.character__h3 {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-top: min(calc(40 / var(--vw-min) * 100vw), 40px);
}
.character__h3:before {
    content: "";
    background: url(../img/gallery/deco_star.png) no-repeat 0 0 / contain;
    width: min(calc(60 / var(--vw-min) * 100vw), 60px);
    height: min(calc(16 / var(--vw-min) * 100vw), 16px);
    display: block;
    margin-bottom: min(calc(20 / var(--vw-min) * 100vw), 20px);
}
.character__h3 > span {
    background: url(../img/gallery/title_gallery_sub.png) no-repeat 0 0 / contain;
    width: min(calc(394 / var(--vw-min) * 100vw), 394px);
    height: min(calc(81 / var(--vw-min) * 100vw), 81px);
    display: block;
}
@media screen and (max-width:768px){
    .character__h3 {
        margin-top: calc(20 / var(--vw-min) * 100vw);
    }
    .character__h3:before {
        width: calc(41 / var(--vw-min) * 100vw);
        height: calc(10 / var(--vw-min) * 100vw);
        margin-bottom: calc(10 / var(--vw-min) * 100vw);
    }
    .character__h3 > span {
        width: calc(240 / var(--vw-min) * 100vw);
        height: calc(60 / var(--vw-min) * 100vw);
    }
}
.charaSwiperWrap {
    position: relative;
    padding: min(calc(40 / var(--vw-min) * 100vw),40px) 0;
    background-image: radial-gradient(#772228, #370f12);
}
@media screen and (max-width:768px){
    .charaSwiperWrap {
        padding: calc(24 / var(--vw-min) * 100vw) 0;
    }
}
.charaSwiperWrap::before {
    content: "";
    width: 100%;
    height: min(calc(120 / var(--vw-min) * 100vw),120px);
    position: absolute;
    top: 0;
    z-index: 10;
    background-image: linear-gradient(#000, transparent);
    opacity: .5;
    pointer-events: none
}
@media screen and (max-width:768px){
    .charaSwiperWrap::before {
       height: calc(80 / var(--vw-min) * 100vw);
    }
}
.charaSwiper {
    width: 100%;
}
.chara__item {
    width: min(calc(326 / var(--vw-min) * 100vw),326px);
    margin: 0 min(calc(20 / var(--vw-min) * 100vw),20px);
}
@media screen and (max-width:768px){
    .chara__item {
        width: calc(293 / var(--vw-min) * 100vw);
        margin: 0 calc(4 / var(--vw-min) * 100vw);
    }
}
.chara__item.--comingSoon {
    width: min(calc(270 / var(--vw-min) * 100vw),270px);
    opacity: .4;
}
@media screen and (max-width:768px){
    .chara__item.--comingSoon {
        width: calc(242 / var(--vw-min) * 100vw);
    }
}
.chara__link {
    width: 100%;
    height: 100%;
    display: block;
}
.chara__item.--comingSoon .chara__link {
    pointer-events: none;
}
.chara__img {
    width: 100%;
    height: min(calc(468 / var(--vw-min) * 100vw),468px);
    overflow: hidden;
}
@media screen and (max-width:768px){
    .chara__img {
        height: calc(420 / var(--vw-min) * 100vw);
    }
}
.chara__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    pointer-events: none;
    transition: .3s ease;
}
.chara__tit {
    width: min(calc(326 / var(--vw-min) * 100vw),326px);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: min(calc(20 / var(--vw-min) * 100vw),20px) auto 0;
}
@media screen and (max-width:768px){
    .chara__tit {
        width: calc(293 / var(--vw-min) * 100vw);
        margin-top: calc(12 / var(--vw-min) * 100vw);
    }
}
.chara__tit img {
    height: 100%;
    pointer-events: none;
}
@media (hover: hover) and (pointer: fine){
    .chara__item:not(.--comingSoon) .chara__link:hover .chara__img img{
        transform: scale(1.1);
    }
}
@media screen and (max-width:768px){
.chara__item .chara__tit {
    opacity: 0;
    transition: .3s ease;
}
.chara__item.swiper-slide-active .chara__tit {
    opacity: 1;
}
}
/**
* thumb
**/
.chara__thumbLists {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: min(calc(16 / var(--vw-min) * 100vw),16px);
}
@media screen and (max-width:768px){
    .chara__thumbLists {
        margin-bottom: calc(8 / var(--vw-min) * 100vw);
    }
}
.chara__thumbBtn {
    width: min(calc(80 / var(--vw-min) * 100vw),80px);
    height: min(calc(80 / var(--vw-min) * 100vw),80px);
    position: relative;
    margin: 0 min(calc(4 / var(--vw-min) * 100vw),4px);
    cursor: pointer;
}
@media screen and (max-width:768px){
    .chara__thumbBtn {
        width: calc(64 / var(--vw-min) * 100vw);
        height: calc(64 / var(--vw-min) * 100vw);
        margin: 0 calc(2 / var(--vw-min) * 100vw);
    }
}
.chara__thumbBtn::before {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
    inset: 0; 
    background: url(../img/common/deco/deco_thumbBg.svg)no-repeat center/contain;
    pointer-events: none;
}
.chara__thumbImg {
    width: min(calc(64 / var(--vw-min) * 100vw),64px);
    height: min(calc(64 / var(--vw-min) * 100vw),64px);
    border-radius: 50%;
    position: absolute;
    inset: 0;
    margin: auto;
    background-color: var(--color-redAD0);
    overflow: hidden;
}
@media screen and (max-width:768px){
    .chara__thumbImg {
        width: calc(48 / var(--vw-min) * 100vw);
        height: calc(48 / var(--vw-min) * 100vw);
    }
}
.chara__thumbImg img {
    width: 100%;
    pointer-events: none;
}
.chara__thumbImg::after {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
    inset: 0;
    background-color: var(--color-redAD0);
    opacity: 0;
    transition: .3s ease;
}
/**
* active
**/
.chara__thumbBtn.--is-active::before {
    animation: 20s ani_rotate01 linear infinite;
}
.chara__thumbBtn.--is-active .chara__thumbImg::after {
    opacity: .5;
}
@media (hover: hover) and (pointer: fine){
    .chara__thumbBtn:hover .chara__thumbImg::after {
        opacity: .5;
    }
}
/**
* deco line
**/
.chara__decoLine {
    width: 100%;
    height: min(calc(18 / var(--vw-min) * 100vw),18px);
    position: absolute;
}
@media screen and (max-width:768px){
    .chara__decoLine {
        height: calc(13 / var(--vw-min) * 100vw);
    }
}
.chara__decoLine.--top {
    top: 0;
    border-top: min(calc(2 / var(--vw-min) * 100vw),2px) solid var(--color-op70-brown6E1);
}
.chara__decoLine.--bottom {
    bottom: 0;
    border-bottom: min(calc(2 / var(--vw-min) * 100vw),2px) solid var(--color-op70-brown6E1);
}
@media screen and (max-width:768px){
    .chara__decoLine {
        border-width: calc(2 / var(--vw-min) * 100vw);
    }
}
.chara__decoLine::before {
    content: "";
      width: 100%;
    height: min(calc(5 / var(--vw-min) * 100vw),5px);
    position: absolute;
    bottom: min(calc(6 / var(--vw-min) * 100vw),6px);
    -webkit-mask: url(../img/common/deco/deco_dot.svg)repeat-x left/min(calc(15 / var(--vw-min) * 100vw),15px) min(calc(5 / var(--vw-min) * 100vw),5px);
    mask: url(../img/common/deco/deco_dot.svg)repeat-x left/min(calc(15 / var(--vw-min) * 100vw),15px) min(calc(5 / var(--vw-min) * 100vw),5px);
    background-color: var(--color-op70-brown6E1);
}
@media screen and (max-width:768px){
    .chara__decoLine::before {
        height: calc(4 / var(--vw-min) * 100vw);
        bottom: calc(3 / var(--vw-min) * 100vw);
        -webkit-mask-size: calc(12 / var(--vw-min) * 100vw) calc(4 / var(--vw-min) * 100vw);
        mask-size: calc(12 / var(--vw-min) * 100vw) calc(4 / var(--vw-min) * 100vw);
    }
}
/**
* arrow
**/
.swiper__arrowWrap {
    height: min(calc(468 / var(--vw-min) * 100vw),468px);
    top: calc(40 / var(--vw-min) * 100vw);
    bottom: unset;
}
@media screen and (max-width:768px){
    .swiper__arrowWrap {
        height: calc(420 / var(--vw-min) * 100vw);
        top: calc(20 / var(--vw-min) * 100vw);
    }
}