@charset "UTF-8";


/***************************************************

	character

***************************************************/

main{
	overflow-y: hidden;
}

footer{
	margin-top: 0;
}

#page_header{
	height: 922px;
	margin-bottom: 30px;
	background-repeat: no-repeat;
	background-position: bottom 0 left 0;
	background-size: cover;
	background-image: url('../images/character/character_head_bg.webp');
	position: relative;
    z-index: 2;
}

#page_header::after {
    content: '';
    display: block;
    width: 100%;
    height: 8.888889vw;
    background-repeat: no-repeat;
    background-position: 0 0;
    background-size: cover;
    background-image: url(../images/character/kv_line.png);
    position: absolute;
    bottom: 6.805556vw;
    left: 0;
    z-index: -1;
}

#page_header .text_wrapper {
    width: 100%;
    position: absolute;
    top: 117px;
    left: 0;
    transform: translate(0, 0);
    text-align: center;
}

#page_header .text_wrapper h1{
	width: 845px;
	margin: 0 auto 40px;
}

#page_header .text_wrapper h1 img{
	width: 100%;
	height: auto;
}

#page_header .text_wrapper .head_catch{
	display: inline-block;
	font-size: 64px;
	color: var(--color1);
	font-weight: 700;
	line-height: 1.1;
	margin-bottom: 40px;
	position: relative;
}

#page_header .text_wrapper .head_catch::after{
	content: '';
	display: block;
	width: 100%;
	height: 2px;
	background: linear-gradient(90deg,rgba(179, 157, 80, 1) 0%, rgba(179, 157, 80, 0) 100%);
	position: absolute;
	bottom: -16px;
	left: 0;
}

#page_header .text_wrapper .head_catch span{
	font-weight: 700;
	position: relative;
}

#page_header .text_wrapper .head_caption{
	font-size: 18px;
	color: var(--text_w);
	font-weight: 700;
	line-height: 2.0;
	margin-bottom: 24px;
	position: relative;
}


#page_header .chara_area{
    width: 823px;
    height: 215px;
    margin: 0 auto;
    background-repeat: no-repeat;
    background-position: 0 0;
    background-size: contain;
    background-image: url(../images/character/kv_other_chara.png);
    transform: translate(36px, 3px);
}

.webp #page_header .chara_area{
    background-image: url(../images/character/kv_other_chara.webp);
}

#page_header .chara_area .chara_box{
	position: absolute;
}

#page_header .chara_area .chara_box.ch01{
    width: 129px;
    top: 9px;
    left: 363px;
    z-index: 6;
}

#page_header .chara_area .chara_box.ch02{
	width: 114px;
    top: 0;
    left: 468px;
    z-index: 5;
}

#page_header .chara_area .chara_box.ch03{
    width: 136px;
    top: -6px;
    left: 269px;
    z-index: 5;
}

#page_header .chara_area .chara_box.ch04{
	width: 160px;
    top: 10px;
    left: 167px;
    z-index: 4;
}

#page_header .chara_area .chara_box.ch05{
    width: 118px;
    top: 28px;
    left: 85px;
    z-index: 1;
}

#page_header .chara_area .chara_box.ch06{
	width: 98px;
    top: 56px;
    left: 725px;
    z-index: 2;
}

#page_header .chara_area .chara_box.ch07{
    width: 77px;
    top: 31px;
    left: 48px;
    z-index: 1;
}

#page_header .chara_area .chara_box.ch08{
    width: 108px;
    top: 84px;
    left: 3px;
    z-index: 1;
}

#page_header .chara_area .chara_box.ch09{
    width: 127px;
    top: 21px;
    left: 587px;
    z-index: 2;
}

#page_header .chara_area .chara_box.ch10{
    width: 124px;
    top: 26px;
    left: 524px;
    z-index: 1;
}

#page_header .chara_area .chara_box.ch11{
	width: 138px;
    top: -1px;
    left: 644px;
    z-index: 1;
}



.character_main_wrapper{
	width: 1096px;
	margin: 0 auto 143px;
}

.character_main_wrapper .chara_ul{
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  justify-content: center;
  gap: 20px;
}

/* =========================
  1段目（1〜4）4列
========================= */
.chara_ul li:nth-child(-n + 4) {
  grid-column: span 3;
}

/* =========================
  2段目（5〜7）3列
========================= */
.chara_ul li:nth-child(5) {
  grid-column: 2 / span 3;
}
.chara_ul li:nth-child(6) {
  grid-column: 5 / span 3;
}
.chara_ul li:nth-child(7) {
  grid-column: 8 / span 3;
}

/* =========================
  3段目（8〜11）4列
========================= */
.chara_ul li:nth-child(n + 8):nth-child(-n + 11) {
  grid-column: span 3;
}

.character_main_wrapper .chara_ul li{
	width: 219px;
	margin-bottom: 40px;
}

.character_main_wrapper .chara_ul li:nth-child(11),
.character_main_wrapper .chara_ul li:nth-child(9),
.character_main_wrapper .chara_ul li:nth-child(even){
	margin-top: 40px;
}

.character_main_wrapper .chara_ul li:nth-child(10),
.character_main_wrapper .chara_ul li:nth-child(8){
	margin-top: 0;
}

.character_main_wrapper .chara_ul li:nth-child(even){
	margin-top: 40px;
}

.character_main_wrapper .chara_data{
	position: relative;
}

.character_main_wrapper .chara_data.modal_btn{
	cursor: pointer;
	transition: all 0.2s linear;
	opacity: 1;
}

.character_main_wrapper .chara_data.modal_btn:hover{
	opacity: 0.7;
}

.character_main_wrapper .chara_data .off_image {
  display: block;
}

.character_main_wrapper .chara_data .on_image {
  display: none;
}

.character_main_wrapper .chara_data .view{
	width: 156px;
	margin: 0 auto;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
}



/* ===============================
   モーダル背景
=============================== */
.modal_area {
	position: fixed;
	width: 100vw;
	min-height: -webkit-fill-available;
	height: var(--vh);
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	inset: 0;
	background: linear-gradient(0deg, rgba(0, 0, 0, 0.75) 0%, rgba(0, 0, 0, 0.75) 100%);
	z-index: 1000;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s ease, visibility 0.3s ease;
}

.modal_area.active {
	opacity: 1;
	visibility: visible;
}

/* ===============================
   モーダル本体
=============================== */
.modal_cont {
	width: 1077px;
	height: 600px;
	background-repeat: no-repeat, no-repeat, no-repeat, no-repeat, no-repeat;
	background-position: top 8px left 14px, top 8px right 14px, bottom 8px left 14px, bottom 8px right 14px, 50% 50%;
	background-size: 43px 43px, 43px 43px, 43px 43px, 43px 43px, cover;
	background-image: url('../images/character/modal_frame_tl.png'), url('../images/character/modal_frame_tr.png'), url('../images/character/modal_frame_bl.png'), url('../images/character/modal_frame_br.png'), url('../images/character/modal_bg.webp');
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%) translateY(20px);

	opacity: 0;
	transition: opacity 0.3s ease, transform 0.3s ease;
	pointer-events: none;
}

.modal_cont.active {
	opacity: 1;
	transform: translate(-50%, -50%) translateY(0);
	pointer-events: auto;
}

.modal_cont::before{
	content: '';
	display: inline-block;
	width: 497px;
	height: 600px;
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: 100% 100%;
	background-image: url('../images/character/modal_bg01.webp');
	position: absolute;
	bottom: 0;
	left: 0;
}

.modal_cont.cont02::before{
	width: 495px;
	background-image: url('../images/character/modal_bg02.webp');
}
.modal_cont.cont02 .data_wrapp {
	left: 74%;
	transform: translate(-74%, -50%);
}

.modal_cont.cont03::before{
	background-image: url('../images/character/modal_bg03.webp');
}

.modal_cont.cont04::before{
	width: 504px;
	background-image: url('../images/character/modal_bg04.webp');
}

.modal_cont .close{
	width: 45px;
	position: absolute;
	top: 32px;
	right: 40px;
	text-align: center;
	cursor: pointer;
	z-index: 10;
}

.modal_cont .close p{
	font-size: 14px;
	font-weight: 700;
	color: var(--color3);
	line-height: 1.4;
	white-space: nowrap;
}

.modal_cont .data_wrapp{
	display: flex;
	align-items: center;
	position: absolute;
	top: 50%;
	left: 70%;
	transform: translate(-70%, -50%);
}

.modal_cont .data_wrapp .image_area{
	width: 237px;
	padding-right: 24px;
}

.modal_cont.cont02 .data_wrapp .image_area{
	width: 212px;
	padding-right: 36px;
}

.modal_cont.cont03 .data_wrapp .image_area{
	width: 244px;
	padding-right: 20px;
}

.modal_cont.cont04 .data_wrapp .image_area{
	width: 323px;
	padding-right: 28px;
}

.modal_cont .data_wrapp .text_area{
	width: 458px;
}

.modal_cont .data_wrapp .text_area .name{
	text-align: center;
	margin-bottom: 12px;
	position: relative;
	z-index: 2;
}

.modal_cont .data_wrapp .text_area .name::before{
	content: '';
	display: inline-block;
	width: 477px;
	height: 139px;
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: 100% 100%;
	background-image: url('../images/character/modal_name_bg.png');
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: -1;
}

.modal_cont .data_wrapp .text_area .name strong{
	display: inline-block;
	font-size: 24px;
	font-weight: 700;
	color: var(--color3);
	position: relative;
}

.modal_cont .data_wrapp .text_area .name strong::after,
.modal_cont .data_wrapp .text_area .name strong::before{
	content: '';
	display: inline-block;
	width: 106px;
	height: 2px;
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: 100% 100%;
	background-image: url('../images/character/name_line.png');
	position: absolute;
	top: 50%;
	left: -120px;
	transform: translate(0, -50%);
}

.modal_cont .data_wrapp .text_area .name strong::after{
	left: unset;
	right: -120px;
	transform: translate(0, -50%) scale(-1, -1);
}

.modal_cont .data_wrapp .text_area .chara_caption{
	font-size: 18px;
	font-weight: 700;
	line-height: 2.0;
	color: var(--text2);
	position: relative;
	z-index: 3;
}



.modal_nav {
    width: 64px;
    height: 64px;
	position: fixed;
	top: 50%;
	transform: translateY(-50%);
	cursor: pointer;
}

.modal_nav::after{
    content: '';
    display: inline-block;
    width: 64px;
    height: 64px;
    opacity: 1;
    background-repeat: no-repeat;
    background-position: 0 0;
    background-size: cover;
    background-image: url(../images/common/icon_slider_arrow.png);
    position: absolute;
    top: unset;
    bottom: 0;
    left: 0;
}

.modal_nav.next::after{
    transform: scale(-1, 1);
}

.modal_nav.prev {
	left: 10vw
}

.modal_nav.next {
	right: 10vw
}







/********************************************************************************
	リッキド用 CSS
********************************************************************************/

@media(max-width:1440px){


#page_header{
	height: 64.027778vw;
	margin-bottom: 2.083333vw;
}

#page_header .text_wrapper {
    top: 8.125vw;
}

#page_header .text_wrapper h1{
	width: 58.680556vw;
	margin: 0 auto 2.777778vw;
}

#page_header .text_wrapper .head_catch{
	font-size: 4.444444vw;
	margin-bottom: 2.777778vw;
}

#page_header .text_wrapper .head_catch::after{
	height: 0.138889vw;
	bottom: -1.111111vw;
}

#page_header .text_wrapper .head_caption{
	font-size: 1.250000vw;
	margin-bottom: 1.666667vw;
}


#page_header .chara_area{
    width: 57.152778vw;
    height: 14.930556vw;
    transform: translate(2.5vw, 0.208333vw);
}

#page_header .chara_area .chara_box.ch01{
    width: 8.958333vw;
    top: 0.625vw;
    left: 25.208333vw;
}

#page_header .chara_area .chara_box.ch02{
	width: 7.916667vw;
    top: 0;
    left: 32.5vw;
}

#page_header .chara_area .chara_box.ch03{
    width: 9.444444vw;
    top: -0.416667vw;
    left: 18.680556vw;
}

#page_header .chara_area .chara_box.ch04{
	width: 11.111111vw;
    top: 0.694444vw;
    left: 11.597222vw;
}

#page_header .chara_area .chara_box.ch05{
    width: 8.194444vw;
    top: 1.944444vw;
    left: 5.902778vw;
}

#page_header .chara_area .chara_box.ch06{
	width: 6.805556vw;
    top: 3.888889vw;
    left: 50.347222vw;
}

#page_header .chara_area .chara_box.ch07{
    width: 5.347222vw;
    top: 2.152778vw;
    left: 3.333333vw;
}

#page_header .chara_area .chara_box.ch08{
    width: 7.5vw;
    top: 5.833333vw;
    left: 0.208333vw;
}

#page_header .chara_area .chara_box.ch09{
    width: 8.819444vw;
    top: 1.458333vw;
    left: 40.763889vw;
}

#page_header .chara_area .chara_box.ch10{
    width: 8.611111vw;
    top: 1.805556vw;
    left: 36.388889vw;
}

#page_header .chara_area .chara_box.ch11{
	width: 9.583333vw;
    top: -1px;
    left: 44.722222vw;
}



.character_main_wrapper{
	width: 76.111111vw;
	margin: 0 auto 9.930556vw;
}

.character_main_wrapper .chara_ul{
	gap: 1.388889vw;
}

.character_main_wrapper .chara_ul li{
	width: 15.208333vw;
	margin-bottom: 2.777778vw;
}

.character_main_wrapper .chara_ul li:nth-child(11),
.character_main_wrapper .chara_ul li:nth-child(9),
.character_main_wrapper .chara_ul li:nth-child(even){
	margin-top: 2.777778vw;;
}

.character_main_wrapper .chara_data .view{
	width: 10.833333vw;
}



/* ===============================
   モーダル背景
=============================== */
.modal_area {

}

/* ===============================
   モーダル本体
=============================== */
.modal_cont {
	width: 74.791667vw;
	height: 41.666667vw;
	background-position: top 0.555556vw left 0.972222vw, top 0.555556vw right 0.972222vw, bottom 0.555556vw left 0.972222vw, bottom 0.555556vw right 0.972222vw, 50% 50%;
	background-size: 2.986111vw 2.986111vw, 2.986111vw 2.986111vw, 2.986111vw 2.986111vw, 2.986111vw 2.986111vw, cover;
}

.modal_cont::before{
	width: 34.513889vw;
	height: 41.666667vw;
}

.modal_cont.cont02::before{
	width: 34.375vw;
}

.modal_cont.cont03::before{
}

.modal_cont.cont04::before{
	width: 35vw;
}

.modal_cont .close{
	width: 3.125vw;
	top: 2.222222vw;
	right: 2.777778vw;
}

.modal_cont .close p{
	font-size: 0.972222vw;
}

.modal_cont .data_wrapp .image_area{
	width: 16.458333vw;
	padding-right: 1.666667vw;
}

.modal_cont.cont02 .data_wrapp .image_area{
	width: 14.722222vw;
	padding-right: 2.5vw;
}

.modal_cont.cont03 .data_wrapp .image_area{
	width: 16.944444vw;
	padding-right: 1.388889vw;
}

.modal_cont.cont04 .data_wrapp .image_area{
	width: 22.430556vw;
	padding-right: 1.944444vw;
}

.modal_cont .data_wrapp .text_area{
	width: 31.805556vw;
}

.modal_cont .data_wrapp .text_area .name{
	margin-bottom: 0.833333vw;
}

.modal_cont .data_wrapp .text_area .name::before{
	width: 33.125vw;
	height: 9.652778vw;
}

.modal_cont .data_wrapp .text_area .name strong{
	font-size: 1.666667vw;
}

.modal_cont .data_wrapp .text_area .name strong::after,
.modal_cont .data_wrapp .text_area .name strong::before{
	width: 7.361111vw;
	height: 0.138889vw;
	left: -8.333333vw;
}

.modal_cont .data_wrapp .text_area .name strong::after{
	left: unset;
	right: -8.333333vw;
}

.modal_cont .data_wrapp .text_area .chara_caption{
	font-size: 1.25vw;
}


.modal_nav {
    width: 4.76vw;
    height: 4.76vw;
}

.modal_nav::after{
    width: 4.76vw;
    height: 4.76vw;
}
.modal_nav.prev {
	left: 8vw;
}
.modal_nav.next {
	right: 8vw;
}









}

/********************************************************************************
	スマートフォン用 CSS
********************************************************************************/

@media(max-width:460px){

#page_header{
	height: 133.333333vw;
	margin-bottom: 24vw;
	background-image: url('../images/character/character_head_bg_sp.webp');
}

#page_header::after {
    height: 32.800000vw;
    background-image: url(../images/character/kv_line_sp.png);
    bottom: -5.866667vw;
}

#page_header .text_wrapper {
    top: 28.266667vw;
}

#page_header .text_wrapper h1{
	width: 100%;
	margin: 0 auto 2.133333vw;
}

#page_header .text_wrapper .head_catch{
	font-size: 5.333333vw;
	margin-bottom: 5.333333vw;
}

#page_header .text_wrapper .head_catch::after{
	content: none;
}

#page_header .text_wrapper .head_catch span{
	display: block;
	padding-bottom: 10px;
	margin-bottom: 8px;
}

#page_header .text_wrapper .head_catch span:last-of-type{
	margin-bottom: 0;
}

#page_header .text_wrapper .head_catch span::after{
	content: '';
	display: block;
	width: 100%;
	height: 2px;
	background: linear-gradient(90deg,rgba(179, 157, 80, 1) 0%, rgba(179, 157, 80, 0) 100%);
	position: absolute;
	bottom: 0;
	left: 0;
}

#page_header .text_wrapper .head_caption{
	font-size: 3.733333vw;
	line-height: 1.75;
	margin-bottom: 6.4vw;
}


#page_header .chara_area{
	width: 91.733333vw;
	height: 25.066667vw;
	background-image: url(../images/character/kv_other_chara_sp.png);
	transform: translate(0px, 4.8vw);
}

.webp #page_header .chara_area{
    background-image: url(../images/character/kv_other_chara_sp.webp);
}

#page_header .chara_area .chara_box.ch01{
	width: 14.4vw;
	top: 1.333333vw;
	left: 40vw;
}

#page_header .chara_area .chara_box.ch02{
	width: 12.533333vw;
	top: 0.533333vw;
	left: 51.733333vw;
}

#page_header .chara_area .chara_box.ch03{
	width: 14.933333vw;
	top: 0;
	left: 30.133333vw;
}

#page_header .chara_area .chara_box.ch04{
	width: 17.6vw;
	top: 1.6vw;
	left: 18.666667vw;
}

#page_header .chara_area .chara_box.ch05{
	width: 12.8vw;
	top: 3.733333vw;
	left: 10.133333vw;
}

#page_header .chara_area .chara_box.ch06{
	width: 11.2vw;
	top: 6.666667vw;
	left: 80.266667vw;
}

#page_header .chara_area .chara_box.ch07{
	width: 8.533333vw;
	top: 4vw;
	left: 5.866667vw;
}

#page_header .chara_area .chara_box.ch08{
	width: 12vw;
	top: 9.866667vw;
	left: 0.8vw;
}

#page_header .chara_area .chara_box.ch09{
	width: 14.133333vw;
	top: 2.933333vw;
	left: 65.066667vw;
}

#page_header .chara_area .chara_box.ch10{
	width: 13.6vw;
	top: 3.466667vw;
	left: 58.133333vw;
}

#page_header .chara_area .chara_box.ch11{
	width: 15.2vw;
	top: 0.533333vw;
	left: 71.2vw;
}



.character_main_wrapper{
	width: auto;
	margin: 0 5.333333vw 51.733333vw;
}

.character_main_wrapper .chara_ul{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 0;
}

.character_main_wrapper .chara_ul li{
	width: 41.866667vw;
	margin-bottom: 0;
}

.character_main_wrapper .chara_ul li:nth-child(10),
.character_main_wrapper .chara_ul li:nth-child(8),
.character_main_wrapper .chara_ul li:nth-child(even){
	margin-top: 10.666667vw;
}

.character_main_wrapper .chara_ul li:nth-child(11),
.character_main_wrapper .chara_ul li:nth-child(9){
	margin-top: 0;
}


.character_main_wrapper .chara_data .view{
	width: 100%;
    bottom: -3.733333vw;
}


/* ===============================
   モーダル本体
=============================== */
.modal_cont {
	width: 89.333333vw;
	height: auto;
	min-height: 130.933333vw;
	background-position: top 2.666667vw left 2.666667vw, top 2.666667vw right 2.666667vw, bottom 2.666667vw left 2.666667vw, bottom 2.666667vw right 2.666667vw, 50% 50%;
	background-size: 7.466667vw 7.466667vw, 7.466667vw 7.466667vw, 7.466667vw 7.466667vw, 7.466667vw 7.466667vw, cover;
	background-image: url('../images/character/modal_frame_tl.png'), url('../images/character/modal_frame_tr.png'), url('../images/character/modal_frame_bl.png'), url('../images/character/modal_frame_br.png'), url('../images/character/modal_bg_sp.webp');

	padding: 10.666667vw 5.333333vw;
	box-sizing: border-box;
}

.modal_cont::before{
	width: 43.733333vw;
	height: 82.666667vw;
	background-image: url('../images/character/modal_bg01_sp.webp');
	bottom: unset;
	top: 0;
}

.modal_cont.cont02::before{
	width: 39.466667vw;
	height: 79.466667vw;
	background-image: url('../images/character/modal_bg02_sp.webp');
	top: 2.666667vw;
}
.modal_cont.cont02 .data_wrapp{
	left: 0;
	transform: translate(0, 0);
}

.modal_cont.cont03::before{
	width: 42.133333vw;
	height: 80vw;
	background-image: url('../images/character/modal_bg03_sp.webp');
	top: 2.666667vw;
}

.modal_cont.cont04::before{
	width: 43.466667vw;
	height: 64.8vw;
	background-image: url('../images/character/modal_bg04_sp.webp');
	top: 5.333333vw;
}

.modal_cont .close{
	width: 12vw;
	top: 5.333333vw;
	right: 4.266667vw;
}

.modal_cont .close p{
	font-size: 3.733333vw;
}

.modal_cont .data_wrapp{
	display: block;
	align-items: center;
	position: relative;
	top: 0;
	left: 0;
	transform: translate(0, 0);
}

.modal_cont .data_wrapp .image_area{
	width: 38.4vw;
	padding-right: 0;
	margin: 0 auto 8px;
}

.modal_cont.cont02 .data_wrapp .image_area{
	width: 34.4vw;
	padding-right: 0;
}

.modal_cont.cont03 .data_wrapp .image_area{
	width: 38.4vw;
	padding-right: 0;
}

.modal_cont.cont04 .data_wrapp .image_area{
	width: 46.666667vw;
	padding-right: 0;
}

.modal_cont .data_wrapp .text_area{
	width: auto;
	margin-top: 5.866667vw;
}

.modal_cont .data_wrapp .text_area .name{
	margin-bottom: 2.133333vw;
}

.modal_cont .data_wrapp .text_area .name::before{
	width: 73.6vw;
	height: 21.6vw;
	top: 77%;
}

.modal_cont .data_wrapp .text_area .name strong{
	font-size: 5.333333vw;
}

.modal_cont .data_wrapp .text_area .name strong::after,
.modal_cont .data_wrapp .text_area .name strong::before{
	width: 21.333333vw;
	height: 0.533333vw;
	left: -26.133333vw;
}

.modal_cont .data_wrapp .text_area .name strong::after{
	left: unset;
	right: -26.133333vw;
}

.modal_cont .data_wrapp .text_area .chara_caption{
	font-size: 3.733333vw;
	line-height: 1.75;
}


.modal_nav {
    width: 11.733333vw;
    height: 11.733333vw;
}

.modal_nav::after{
    width: 11.733333vw;
    height: 11.733333vw;
}

.modal_nav.prev {
	left: 1.066667vw;
}

.modal_nav.next {
	right: 1.066667vw;
}






}
