@charset "UTF-8";

body{
	background-image: url("../images/bk.webp");
	background-attachment: fixed;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	
	color:#fff;
}


/*==========================
header
===========================*/
header{
	position: fixed;
    top: 0;
    width: 100%;
    z-index: 50;
    transition: .2s;
	background-image: url("../images/bk.webp");
	background-size: cover;
	background-position:center 80%;
	background-repeat: no-repeat;
}

.header_box{
	margin: auto;
	max-width:1200px;
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	position: relative;
	padding:2px 15px;
}

.header_logo{
	display: flex;flex-wrap: wrap;
	padding:3px 0;
}
.header_logo a{
	margin:auto 0;
	display: block;
	line-height: 0;
}
.header_logo a[href*="king"]{max-width:40px;padding:5px 10px 5px 0;}
.header_logo a[href*="top"]{max-width:200px;padding-top:2px;}


.header_nav{margin: auto 0 auto auto;}
.header_nav ul{display:flex;flex-wrap:wrap;gap:1px;}
.header_nav ul li{
	position:relative;
}
.header_nav ul li a{
	display:block;
	padding:2px 16px;
	letter-spacing:0.05em;
	color:#fff;
	font-family: "Noto Serif JP", serif;
	font-weight:700;
	text-decoration: none;
	transition: .2s;
}
@media screen and ( min-width:768px) {
	.header_nav ul li a:hover{
		background-color:rgba(188,142,0,.5);
	}
}

.header_nav ul li::after{
	content:"";
	position:absolute;
	display: block;
	width:1px;
	height:86%;
	top:50%;
	right:0;
	transform:translateY(-50%);
	background-color:#fff;
}
.header_nav ul li:last-child::after{content:none;}

.hamburger_box{
	display: none;
}



/*==========================
MV
===========================*/

.mv_box{
	position:relative;
	background-image: url("../images/mv_bk.webp");
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	padding-top:30px;
}

.mv_box::before,.mv_box::after{
	content:"";
	display:block;
	position:absolute;
	top:0;
	width:200px;
	height:100%;
	background-image: url("../images/mv_side.webp");
	background-size: 100%;
	background-repeat: repeat-y;
	background-position: left top;
}
.mv_box::before{
	left:0;
	
}
.mv_box::after{
	right:0;
	transform: scale(-1,1);
}

.mv_img{
	position:relative;
	z-index: 2;
	margin: auto;
	height:min(96vh,100vw);
	text-align: center;
	padding:8vh 0;
	filter:drop-shadow(0 0 3px rgba(0,0,0,.4));
}
.mv_img img{width:auto;height:100%;}


/*==========================
導入
===========================*/

.intro_box{
	position:relative;
	padding:80px 60px;
}
.intro_box::before,.intro_box::after{
	content:"";
	display:block;
	position:absolute;
	top:20px;
	max-width:400px;
	width:calc(100% - 900px);
	height:auto;
	aspect-ratio:1 / 1;
	background-image: url("../images/shishi.webp");
	background-size:contain;
	background-repeat: no-repeat;
	background-position: -20% top;
	opacity: .5;
}
.intro_box::before{
	left:0;
}

.intro_box::after{
	right:0;
	transform: scale(-1,1);
}

.intro_main{
	text-align:center;
	font-size:24px;
	letter-spacing:.05em;
	line-height:1.8em;
	font-weight:700;
	filter:drop-shadow(0 0 3px rgba(0,0,0,.4));
}
.intro_main p{display:contents;font-weight:700;}

/*==========================
世之介
===========================*/

.profile_box{padding:0 0 80px;}

.profile_h2box{
	text-align: center;
	font-weight:700;
	font-size:46px;
	filter:drop-shadow(0 0 3px rgba(0,0,0,.4));
}
.profile_h2sub{font-size:.5em;}
.profile_h2box h2{font-weight:900;line-height:1em;padding-bottom:.05em;}
.profile_h2ruby{font-size:.4em;letter-spacing:.05em;}

.profile_img{
	margin: auto;
	max-width:900px;
	padding:20px 0;
}

.profile_button{
	display: flex;
	flex-wrap: wrap;
	margin: auto;
	max-width:900px;
	gap:10px;
}
.profile_button a{
	position:relative;
	display:block;
	width:calc((100% - 20px)/ 3);
	border:2px solid #fff;
	padding:2px 0;
	color:#fff;
	text-decoration: none;
	text-align:center;
	font-size:20px;
	letter-spacing:.05em;
	font-weight:900;
	filter:drop-shadow(0 0 3px rgba(0,0,0,.4));
	transition: .2s;
}
.profile_button a::after{
	position: absolute;
    content: "";
    width: 7px;
    height: 7px;
    border-bottom: #fff 2px solid;
    border-right: #fff 2px solid;
    top: 50%;
    right: 5px;
    transform: rotate(-45deg) translateY(-50%);
	transition: .2s;
}
@media screen and ( min-width:768px) {
	.profile_button a:hover{
		background-color:rgba(255,255,255,.85);
		color:#6F4814;
		filter:drop-shadow(0 0 3px rgba(0,0,0,0));
	}
	.profile_button a:hover::after{
		border-color:#6F4814;
	}
}


/*==========================
年表
===========================*/

.timeline_area{
	background:linear-gradient(to bottom,rgba(62,28,0,.55),rgba(62,28,0,.25));
}

.timeline_box{
	position:relative;
	padding:70px 60px 80px;
}
.timeline_box::before{
	content:"";
	display: block;
	position:absolute;
	top:0;
	left:0;
	width:40%;
	height:auto;
	aspect-ratio:1 / 1;
	background-image: url("../images/timeline_top_frame.webp");
	background-repeat: no-repeat;
	background-position: -20px -20px;
	background-size: contain;
}

.timeline_main{
	position:relative;
	z-index: 2;
}

.timeline_h2box{padding-bottom:30px;}
.timeline_h2sub{
	margin: auto;
	max-width:40px;
}
.timeline_h2box h2{
	text-align: center;
    font-weight: 700;
    font-size: 50px;
}
.timeline_h2box h2 span{font-size:.75em;}

.timeline_intro{
	margin: auto;
	max-width:1200px;
	padding-bottom:40px;
}
.timeline_intro_img{
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	padding-bottom:30px;
}

.timeline_intro_img img{position:relative;filter:drop-shadow(0 0 3px rgba(0,0,0,.4));}
.timeline_intro_img img:nth-child(1){width:28%;margin:0 0 auto;}
.timeline_intro_img img:nth-child(2){width:28%;margin:auto 0 -30px -4.2%;}
.timeline_intro_img img:nth-child(3){width:28%;margin:60px 0 auto -4%;z-index:2;}
.timeline_intro_img img:nth-child(4){width:28%;margin-left:-4%;}

.timeline_intro_text{
	font-size:18px;
	padding:40px 0;
}

.timeline_list{
	margin: auto;
	max-width:1200px;
}

.timeline_item{
	position:relative;
	display: flex;
	flex-wrap: wrap;
	gap:15px;
}

.timeline_item::after{
	content:"";
	position:absolute;
	display: block;
	top:0;
	left:9px;
	width:2px;
	height:102%;
	background-color:rgba(255,255,255,.7);
}
.timeline_item:first-child::after{
	top:12px;
	height:calc(100% - 10px);
}
.timeline_item:last-child::after{content:none;}


.timeline_item_circle{
	width:20px;
	height:auto;
	aspect-ratio:1 / 1;
	border-radius:50%;
	background-color:#fff;
	margin:10px 0 auto;
}

.timeline_item_wrap{display:contents;}

.timeline_item_year{
	width:150px;
	font-size:26px;
	font-weight:800;
}
.timeline_item_contents{
	width:calc(100% - 20px - 150px - 30px);
	padding-bottom:60px;
}
.list_only .timeline_item_contents{padding-bottom:10px;}

.timeline_item_contents h3{
	font-size:24px;
	letter-spacing:0.04em;
	font-weight:800;
	line-height:1.3em;
	padding-bottom:20px;
}

.timeline_item_contents .youtube{
	max-width:800px;
	padding-bottom:20px;
	filter:drop-shadow(0 0 3px rgba(0,0,0,.4));
}

.timeline_item-img{display: flex;flex-wrap: wrap;padding-bottom:20px;}
.timeline_item-img img{margin:auto 0;filter:drop-shadow(0 0 3px rgba(0,0,0,.4));}

.timeline_item-img.list01{gap:1.2%;}
.timeline_item-img.list01 img:nth-child(1){width:63.8%;}
.timeline_item-img.list01 img:nth-child(2){width:32%;}

.timeline_item-img.list02-1{padding-bottom:calc(20px + 40px);}
.timeline_item-img.list02-1 img:nth-child(1){width:50%;}
.timeline_item-img.list02-1 img:nth-child(2){width:45%;margin:auto 0 -40px -5%;}

.timeline_item-img.list02-2{padding-top:30px;justify-content:flex-end;}
.timeline_item-img.list02-2 img:nth-child(1){width:57%;}
.timeline_item-img.list02-2 img:nth-child(2){width:42%;margin:-40px 0 auto -5%;}

.timeline_item-img.list03{gap:20px;}
.timeline_item-img.list03 img:nth-child(1){width:calc((100% - 20px)/2);}
.timeline_item-img.list03 img:nth-child(2){width:calc((100% - 20px)/2);}

.timeline_item-img.list04{max-width:800px;}
.timeline_item-img.list04 img{width:100%;}

.timeline_item-img.list06{}
.timeline_item-img.list06 p{width:100%;text-align:center;padding:5px 0 15px;font-size:13px;}
.timeline_item-img.list06 img{width:100%;}

.timeline_item-img.list07{gap:20px;}
.timeline_item-img.list07 img{width:calc((100% - 40px)/ 3);}

.timeline_item-img.list08{max-width:800px;}
.timeline_item-img.list08 img{width:100%;}

.timeline_item-text{
	font-size:18px;
	padding-bottom:20px;
}

.timeline_item-mix{display: flex;flex-wrap: wrap;gap:20px;}
.timeline_item-mix .img{width:30%;filter:drop-shadow(0 0 3px rgba(0,0,0,.4));}
.timeline_item-mix .text{width:calc(70% - 20px);font-size:18px;}

.timeline_item-book{display: flex;flex-wrap: wrap;gap:20px;}
.timeline_item-book .book{width:25%;filter:drop-shadow(0 0 3px rgba(0,0,0,.4));}
.timeline_item-book .text{width:calc(75% - 20px);font-size:18px;}
.timeline_item-book .book_links{padding:20px 0 0;}

.timeline_item-book .book_links a{
	position:relative;
	display: inline-block;
	border:2px solid #fff;
	padding:2px 40px;
	font-size:22px;
	font-weight:700;
	color:#fff;
	text-decoration: none;
	transition: .2s;
}
.timeline_item-book .book_links a::after{
	position: absolute;
    content: "";
    width: 9px;
    height: 9px;
    border-bottom: #fff 2px solid;
    border-right: #fff 2px solid;
    top: 48%;
    right: 10px;
    transform: rotate(-45deg) translateY(-50%);
	transition: .2s;
}
@media screen and ( min-width:768px) {
	.timeline_item-book .book_links a:hover{
		background-color:#fff;
		color: #6F4814;
	}
	.timeline_item-book .book_links a:hover::after{
		border-color: #6F4814;
	}
}

.timeline_item:last-child .timeline_item-img{position:relative;text-align:center;max-width:800px;margin-top:-30px;}
.timeline_item:last-child .timeline_item-img img{max-width:430px;margin:auto;}
.timeline_item:last-child .timeline_item-img::before,.timeline_item:last-child .timeline_item-img::after{
	content:"";
	position:absolute;
	display: block;
	width:200px;
	height:auto;
	aspect-ratio:1 / 1;
	bottom:20px;
	background-image: url("../images/timeline_last.webp");
	background-repeat: no-repeat;
	background-size: contain;
	background-position: left bottom;
}
.timeline_item:last-child .timeline_item-img::before{left:20px;}
.timeline_item:last-child .timeline_item-img::after{right:20px;transform:scale(-1,1);}



/*==========================
特徴
===========================*/

.feature_area{position:relative;}
.feature_areabk{
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
	background-color:rgba(38,31,28,.85);
	mix-blend-mode:multiply;
}
.feature_box{
	position:relative;
	z-index:3;
	background-image: url("../images/feature_bk.webp");
	background-size: contain;
	background-repeat: no-repeat;
	background-position: -10% top;
	padding:80px 60px;
}


.feature_main{
	margin: auto;
	max-width:1200px;
	display:flex;
	flex-wrap: wrap;
	gap:30px;
}
.feature_img{width:53%;}
.feature_text{width:calc(47% - 60px);}

.feature_h2box{
	position:relative;
	font-size:45px;
	font-weight:700;
	padding-left:22px;
}
.feature_h2box::before{
	content:"";
	position:absolute;
	display:block;
	top:51%;
	left:0;
	width:14px;
	height:89%;
	background-color: #fff;
	transform: translateY(-50%);
}
.feature_h2box > div{
	font-size:.6em;
	line-height:1.2em;
}
.feature_h2box h2{
	font-weight:700;
	line-height:1.2em;
}

.feature_textbox{
	padding-top:25px;
}
.feature_textbox p{
	font-size:18px;;
	padding-bottom:20px;
}


/*==========================
広げる
===========================*/

.spread_area{}

.spread_box{
	padding:60px 0;
}

.spread_h2box h2{
	text-align: center;
	font-size: 35px;
	line-height:1.25em;
	font-weight: 700;
	filter: drop-shadow(0 0 3px rgba(0, 0, 0, .4));
	padding-bottom:35px;
}

.spread_sliderwrap{
    display: flex;
    align-items: center;
    overflow: hidden;
}
.spread_slider_imgline{
    display: flex;
    width: min-content;
    animation: 80s linear infinite sliderAnimation;
}
.slider_imgline_inner{
    width: 200px;
    position: relative;
	line-height:0;
}

@keyframes sliderAnimation {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}

.spread_textbox{
	background-color:rgba(53,43,10,.5);
	padding:40px 60px 100px;
}
.spread_text{
	margin: auto;
	max-width:1000px;
}
.spread_text p{
	font-size:18px;
	padding-bottom:10px;
}

.spread_listbox{
	padding: 40px 60px;
}

.spread_listbox h3{
	text-align: center;
	font-size: 30px;
	font-weight: 700;
	filter: drop-shadow(0 0 3px rgba(0, 0, 0, .4));
	padding-bottom:30px;
}

.spread_list{
	margin: auto;
	max-width:1200px;
	display: flex;
	flex-wrap: wrap;
	gap:15px;
}
.spread_item{
	width:calc((100% - (15px * 2))/ 3);
	color:#fff;
	text-decoration: none;
}
.spread_item div:nth-child(1){
	position:relative;
	line-height:0;
	width:100%;
	height:auto;
	aspect-ratio:3 / 2;
	overflow: hidden;
}
.spread_item div:nth-child(1) img{
	position: absolute;
	top:50%;
	left:50%;
	transform: translate(-50%,-50%);
	transition:.2s;
}
.spread_item h4{
	padding:2px 0;
	text-align: center;
	font-size:20px;
	letter-spacing:0.05em;
	font-weight:700;
	background-color:rgba(30,0,0,.75);
}
.spread_item p{
	padding:5px 15px 15px;
	letter-spacing:0.04em;
	font-size:15px;
	line-height:1.4em;
	background-color:rgba(30,0,0,.2);
}

@media screen and ( min-width:768px) {
	.spread_item:hover div:nth-child(1) img{width:110%;}
}



/*==========================
イベント
===========================*/

.event_area{position:relative;}
.event_areabk{
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
	background-color:rgba(124,0,0,.35);
	mix-blend-mode:multiply;
}

.event_box{
	position: relative;
	z-index:3;
	background-image: url("../images/event_bk.webp");
	background-size: 20%;
	background-position: center top;
}

.event_main{
	padding:60px 60px;
}

.event_first{
	text-align: center;
    font-size: 50px;
    font-weight: 800;
    line-height: 1.6em;
    letter-spacing: 0.05em;
    padding-bottom: 30px;
    filter: drop-shadow(2px 2px 5px rgba(0, 0, 0, .35));
}
.event_first span.min{font-size: 80%;}
.event_first span.nar{letter-spacing:-.08em;}
.event_first i {font-family: "游明朝", "Yu Mincho", "游明朝体", "YuMincho", serif;font-style: normal;}

.event_wrap{
	display: flex;
	flex-wrap: wrap;
	margin: auto;
	max-width:1200px;
	gap:20px;
	padding-bottom:20px;
}
.event_titile{width:120px;}
.event_text{width:calc(100% - 120px - 20px);}

.event_h2box{
	width:fit-content;
	display: flex;flex-wrap: wrap;
	gap:7px;
	padding:0 20px;
	background-color:rgba(255,255,0,.16);
}
.event_h2box div{width:40px;margin:auto 0;}
.event_h2box h2{
	font-size:40px;
	font-family: "Noto Serif JP", serif;
	font-weight:900;
}

.event_textbox{padding: 10px 0 0;}
.event_textbox p{
	font-weight: 600;
	font-size:17px;
	padding-bottom:10px;
}
.event_img{padding-top:15px;max-width:800px;}

.event_banner_area{
	margin: auto;
	max-width:1000px;
	padding:60px 0;
}
.event_banner_box h3{
	text-align: center;
	font-size:30px;
	font-weight:700;
	padding-bottom:10px;
}
.event_banner_area a{
	filter: drop-shadow(2px 2px 5px rgba(30, 0, 0, .35));
	transition: .2s;
}
@media screen and ( min-width:768px) {
	.event_banner_area a:hover{
		filter: drop-shadow(2px 2px 5px rgba(30, 0, 0, 0));
		opacity:.7;
	}

}


.event_banner_links{
	display:flex;
	flex-wrap: wrap;
	gap:30px;
	padding:20px 0 0;
}

.event_banner_links > div{
	width:calc((100% - 30px)/ 2);
}

.event_banner_links > div a{
	position: relative;
	display: block;
	text-align: center;
	background-color:#980000;
	padding: 12px 40px;
	font-size: 25px;
	font-weight: 700;
	color: #fff;
	text-decoration: none;
	filter: drop-shadow(2px 2px 5px rgba(30, 0, 0, .35));
	transition: .2s;
}
.event_banner_links > div a::before{
	position: absolute;
	content: "";
	display: block;
	top:4px;
	left:4px;
	width:calc(100% - 12px);
	height:calc(100% - 12px);
	border: 2px solid #fff;
	transition: .2s;
}
.event_banner_links > div a::after{
	position: absolute;
	content: "";
	width: 9px;
	height: 9px;
	border-bottom: #fff 2px solid;
	border-right: #fff 2px solid;
	top: 48%;
	right: 14px;
	transform: rotate(-45deg) translateY(-50%);
	transition: .2s;
}

.event_banner_links > div:nth-child(2) a{
	background-color:rgba(196,10,88,1);
}

@media screen and ( min-width:768px) {
	.event_banner_links > div a:hover{
		background-color:rgba(0,0,0,0);
		filter: drop-shadow(2px 2px 5px rgba(30,0,0,0));
	}
	.event_banner_links > div a:hover::before{
		top:2px;
		left:0;
		width:calc(100% - 4px);
		height:calc(100% - 8px);
	}
	
}

.event_banner_links > div p{
	position:relative;
	margin-top:22px;
	padding:14px 20px;
	font-size:15px;
	line-height:1.3em;
	background-color:rgba(26,0,0,.5);
	border-radius:4px;
}
.event_banner_links > div p::before{
	content:"";
	position:absolute;
	display: block;
	top:-15px;
	left:50%;
	transform:translateX(-50%);
	width:24px;
	height:15px;
	background-color:rgba(26,0,0,.5);
	clip-path:polygon(0 100%, 100% 100%, 50% 0);
}


.event_detail{
	margin:auto;
	max-width:900px;
	padding-bottom:20px;
}

.event_detail_item{
	display:flex;
	flex-wrap:wrap;
	gap:15px;
	padding-bottom:8px;
}
.event_detail_item > div:nth-child(1){
	display:flex;
	flex-wrap: wrap;
	width:140px;
	background-color:rgba(26,0,0,.75);
	color:#fff;
	font-size:30px;
	letter-spacing:.1em;
	font-weight:700;
	padding:5px 0;
}
.event_detail_item > div:nth-child(1) span{margin:auto;}

.event_detail_item > div:nth-child(2){
	width:calc(100% - 15px - 140px);
	padding:10px 0;
}

.event_detail_main.date{font-size:28px;font-weight:700;}
.event_detail_main.date > div:nth-child(1){display:flex;flex-wrap: wrap;}

.event_detail_main.date > div:nth-child(1) div:nth-child(2){
	display:flex;flex-wrap: wrap;
	font-size:.7em;
	margin: auto 0 auto 15px;
}
.event_detail_main.date > div:nth-child(1) div:nth-child(2) span:nth-child(1){
	border:2px solid #fff;
	padding:2px 10px;
	font-size:.8em;
	margin: auto 6px auto 0;
}
.event_detail_main.date > div:nth-child(2){font-size:.8em;line-height:1.2em;}

.event_detail_main.fee{font-size:24px;font-weight:700;}
.event_detail_main.fee > div:nth-child(1){display:flex;flex-wrap: wrap;gap:30px;padding-bottom:10px;}
.event_detail_main.fee > div:nth-child(1) span:nth-child(1)::after{content:":";padding:0 3px;}

.event_detail_main.fee > div:nth-child(2){display:flex;flex-wrap: wrap;}
.event_detail_main.fee > div:nth-child(2) span{display:block;margin:auto 0;}
.event_detail_main.fee > div:nth-child(2) > span{display:contents;}
.event_detail_main.fee > div:nth-child(2) span span:nth-child(1){
	width:1em;
	height:auto;
	aspect-ratio:1 / 1;
	background-image: url("../images/uraume.webp");
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
	margin-right:6px;
}
.event_detail_main.fee > div:nth-child(2) span:nth-child(2){}
.event_detail_main.fee > div:nth-child(2) span span:nth-child(2) i{font-style:normal;font-size:.9em;}
.event_detail_main.fee > div:nth-child(2)  span span:nth-child(2)::after{content:":";padding:0 3px;}

.event_detail_main.fee > div:nth-child(3){font-size:.65em;}
.event_detail_main.fee > div:nth-child(3) a{color:#fff;}
.event_detail_main.fee > div:nth-child(3) a::before{content:"▶︎";}


.event_map{
	max-width:900px;
	margin: auto;
}
.event_map iframe{
	border:0;
	width:100%;
	height:350px;
}




/*==========================
企画
===========================*/

.special_area{position:relative;}
.special_areabk{
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
	background-color:rgba(34,0,0,.7);
	mix-blend-mode:multiply;
}
.special_box{
	position:relative;
	z-index:3;
}
.special_box::before,.special_box::after{
	content:"";
	position:absolute;
	display:block;
	top:0;
	width:min(250px,calc(100% - 600px)/ 2);
	height:100%;
	background-size: contain;
	background-repeat: no-repeat;
}
.special_box::before{
	left:0;
	background-image: url("../images/special_contents_bk_left.webp");
	background-position: top left;
}
.special_box::after{
	right:0;
	background-image: url("../images/special_contents_bk_right.webp");
	background-position: top right;
}

.special_main{
	position:relative;
	z-index:4;
	padding:50px 0 0;
}

.special_h2box{
	text-align: center;
	font-size:30px;
	font-weight:700;
}
.special_h2box h2{margin: auto;max-width:280px;}
.special_h2sub {}
.special_h2title {font-size:1.4em;}



.special_contents{padding:70px 0;}

.special_contents_h3box{
	font-size:30px;
	width:fit-content;
	margin:auto;
	text-align:center;
	padding-bottom: 20px;
}
.special_contents_h3img{max-width:120px;margin:auto;padding-bottom:15px;}
.special_contents_h3sub{font-weight:700;padding-bottom:5px;}

.special_contents_h3box h3{
	position:relative;
	font-size:1.5em;
	font-weight:700;
	text-align:center;
	border:#fff solid 6px;
	padding:4px 1.6em;
}
.special_contents_h3box h3::after{
	content:"";
	position:absolute;
	display:block;
	top:50%;
	left:50%;
	width:calc(100% - 12px);
	height:calc(100% - 12px);
	transform:translate(-50% , -50%);
	border:#fff solid 2px;
}
.special_contents_h3box h3 span{
	position:relative;
	display: block;
}
.special_contents_h3box h3 span::before,
.special_contents_h3box h3 span::after{
	content:"";
	position:absolute;
	display:block;
	top:50%;
	width:auto;
	height:50%;
	aspect-ratio:1 / 1;
	background-image: url("../images/ume.webp");
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	transform:translateY(-50%);
}
.special_contents_h3box h3 span::before{left:-1em;}
.special_contents_h3box h3 span::after{right:-1em;}

.special_contents01_img{
	max-width:700px;
	margin: auto;
}
.special_contents01_img div{
	padding-top:5px;
	text-align:center;
	font-size:14px;
}


.special_contents01_detail{
	margin: auto;
	max-width:1000px;
}

.special_contents01_intro{
	padding:30px 0;
}
.special_contents01_intro p{
	font-size:18px;
	padding-bottom:10px;
}

.special_contents01_fee{
	display: flex;
	flex-wrap: wrap;
	gap:30px;
	background-color:rgba(150,0,15,.75);
	padding:20px;
	font-size: 24px;
	font-weight:700;
	letter-spacing:.05em;
}
.special_contents01_fee-normal{
	display: flex;
	flex-wrap: wrap;
	gap:15px;
	width:calc(((100% - 30px - (30px * 2))/ 8)* 3);
}
.special_contents01_fee-normal > div:nth-child(1){
	display: flex;
	flex-wrap: wrap;
	width:120px;
	border:1px solid #fff;
	border-radius:2px;
	font-size:.9em;
}
.special_contents01_fee-normal div:nth-child(1) span{margin:auto;}

.special_contents01_fee-normal > div:nth-child(2){width:calc(100% - 15px - 120px);margin: auto 0;}
.special_contents01_fee-normal > div:nth-child(2) > div:nth-child(1){line-height:1em;font-size:1.1em;}
.special_contents01_fee-normal > div:nth-child(2) > div:nth-child(2){}

.special_contents01_fee-normal > div:nth-child(2) div:nth-child(3){font-size:.7em;}

.fee-normal_num{display: flex;flex-wrap: wrap;font-family: "Noto Serif JP", serif;}
.fee-normal_num div:nth-child(1){font-size:1.8em;line-height:1em;font-weight:900;}
.fee-normal_num div:nth-child(2) span{display:block;width:100%;}
.fee-normal_num div:nth-child(2) span:nth-child(1){font-size:.6em;}
.fee-normal_num div:nth-child(2) span:nth-child(2){line-height:1em;}


.special_contents01_fee-triangle{
	margin: auto 0;
	width:30px;
	height:auto;
	aspect-ratio:1 / 1;
	background:rgba(255,255,255,.7);
	clip-path: polygon(0 0, 0 100%, 100% 50%);
}

.special_contents01_fee-student{
	display: flex;
	flex-wrap: wrap;
	gap:15px;
	position:relative;
	width:calc(((100% - 30px - (30px * 2))/ 8)* 5);
}
.special_contents01_fee-student > div:nth-child(1){display: flex;flex-wrap: wrap;width:120px;}
.special_contents01_fee-student > div:nth-child(1) img{margin:auto;}

.special_contents01_fee-student > div:nth-child(2){width:calc(100% - 15px - 120px);margin:auto 0;}
.special_contents01_fee-student > div:nth-child(2) > div:nth-child(1){font-size:1.2em;line-height:1em;}
.special_contents01_fee-student > div:nth-child(2) > div:nth-child(3){
	position:absolute;
	width:80px;
	top:0;
	right:0;
}

.fee-student_num{
	display: flex;flex-wrap: wrap;font-family: "Noto Serif JP",serif;width:fit-content;padding-bottom:.2em;
	background:linear-gradient(to bottom,rgba(255,255,255,0) 65%,rgba(255,255,0,.24) 65%)
}
.fee-student_num div:nth-child(1){font-size:3.6em;line-height:.8em;font-weight:900;letter-spacing:-.02em;padding-right:.05em;}
.fee-student_num div:nth-child(2){margin:auto 0 0;font-size:1.3em;}
.fee-student_num div:nth-child(2) span{display:block;width:100%;}
.fee-student_num div:nth-child(2) span:nth-child(1){font-size:.6em;}
.fee-student_num div:nth-child(2) span:nth-child(2){line-height:1em;}


.special_contents01_apply{
	padding:40px 0;
}
.special_contents01_apply a{
	margin: auto;
	position: relative;
	display: flex;
	flex-wrap: wrap;
	width:fit-content;
	text-align: center;
	border: 2px solid #fff;
	padding: 3px 40px;
	font-size: 30px;
	font-weight: 700;
	color: #fff;
	background-color: rgba(30,0,0,.45);
	text-decoration: none;
	transition: .2s;
}
.special_contents01_apply a::after{
	position: absolute;
	content: "";
	width: 9px;
	height: 9px;
	border-bottom: #fff 2px solid;
	border-right: #fff 2px solid;
	top: 48%;
	right: 10px;
	transform: rotate(-45deg) translateY(-50%);
	transition: .2s;
}
.special_contents01_apply a span{
	display: block;
	margin: auto 0;
	padding-left:5px;
}
.special_contents01_apply a img{
	width:1em;
	margin: auto 0;
}

@media screen and ( min-width:768px) {
	.special_contents01_apply a:hover{
		background-color:rgba(30,0,0,0);
		border: 2px solid rgba(255,255,255,0);
	}
	.special_contents01_apply a:hover::after{
		right:0;
	}
}

.special_contents01_note{
	max-width:800px;
	margin: auto;
}


.special_contents01_att{}
.special_contents01_att ul{}
.special_contents01_att ul li{
	font-size:14px;
	padding-bottom:4px;
}
.special_contents01_att ul li::before{
	content:"▶︎";
	padding-right:8px;
}
.special_contents01_att ul li a{
	color:#fff;
}

.special_contents01_flow{
	margin: auto;
	padding:50px 0 0;
}

.special_contents01_flow h4{
	text-align:center;
    font-size: 28px;
    font-weight: 700;
}

.special_contents01_flow ul li{
	display:flex;
	flex-wrap:wrap;
	gap:10px;
	padding-bottom:10px;
}

.special_contents01_flow ul li div:nth-child(1){
	display:flex;
	flex-wrap:wrap;
	width:40px;
	background-color:rgba(255,255,255,.8);
}
.special_contents01_flow ul li div:nth-child(1) span{
	margin: auto;
	color:#222;
	font-weight:700;
	padding:5px;
}
.special_contents01_flow ul li div:nth-child(2){
	width:calc(100% - 50px);
}
.special_contents01_flow ul li div:nth-child(2) h5{font-size:1.2em;font-weight:700;}

.special_contents02_mvarea{
	margin: auto;
	max-width:900px;
}

.special_contents02_intro{
	text-align: center;
	font-size:18px;
	padding-bottom:30px;
}

.special_contents02_mvbox{
	padding-bottom:50px;
}
.special_contents02_mvbox .youtube{
	line-height:0;
}

.special_contents02_mvbox h4{
	text-align: center;
	font-size: 30px;
	font-weight: 700;
	padding:3px 0 5px;
	background-color:rgba(0,0,0,.5);
	margin-bottom:10px;
}
.special_contents02_mvtext{
	
}
.special_contents02_mvtext .open_title{display:none;}
.special_contents02_mvtext .open_box{
	display:contents;
}
.special_contents02_mvtext p{
	padding:0 10px 15px;
}

/*==========================
FAQ
===========================*/

.faq_area{
	background-color:rgba(43,4,5,.2);
}

.faq_box{
	margin: auto;
	padding:50px 60px;
	max-width: 900px;
}

.faq_2hbox{text-align: center;}
.faq_2hbox h2{
	font-size: 34px;
	letter-spacing: 0.08em;
	font-weight:700;
	line-height: 1.4em;
	padding-bottom: 5px;
}

.faq_group{
	padding:15px 0;
}

.faq_group ul *{
	font-family: "Helvetica Neue", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

.faq_group h3{
	position: relative;
	font-size: 20px;
	font-weight:700;
	padding-left:20px;
}
.faq_group h3::before{
	content:"";
	position:absolute;
	bottom:0;
	left:0;
	width:10px;
	height:92%;
	background-color:#fff;
}

.faq_group > ul > li{
	padding-bottom:10px;
}

.faq_group h4{
	position: relative;
	font-weight:700;
	font-size: 16px;
	padding: 10px 55px 10px 60px;
	border-bottom: #fff 1px solid;
	transition: .2s;
}
.faq_group h4::before {
    position: absolute;
    top: 50%;
    left: 20px;
    content: "Ｑ.";
    font-size: 1.3em;
    font-weight: 600;
    transform: translateY(-50%);
}

.faq_group h4 .toggle_icon {
    position: absolute;
    top: 20%;
    right: 20px;
    width: auto;
    height: 60%;
    aspect-ratio: 1 / 1;
}
.faq_group h4 .toggle_icon span{
	display: block;
	height: 2px;
	width:80%;
	border-radius: 10px;
	background-color:#fff;
	transition: .35s;
}
.faq_group h4 .toggle_icon span:nth-child(1){
	margin: 50% 0px 0px;
}
.faq_group h4 .toggle_icon span:nth-child(2){
	margin: -2px 0 0 0;
	transform: rotate(-90deg);
}
.faq_group h4.open .toggle_icon span:nth-child(2){
	margin:0;
	transform: rotate(0deg);
	opacity: 0;
}

.faq_group .open_box{
	position: relative;
	padding: 10px 20px 10px 60px;
}
.faq_group .open_box p{
	font-size: 15px;
    padding-bottom: 12px;
}
.faq_group .open_box p a{
	color:#fff;
}
.faq_group .open_box::before {
    position: absolute;
    top: 5px;
    left: 20px;
    content: "Ａ.";
    font-size: 1.3em;
    font-weight: 600;
}

.faq_group .open_box ul{padding-left:10px;}
.faq_group .open_box ul li{
	position:relative;
	font-size: 15px;
	margin-bottom:5px;
}
.faq_group .open_box ul li::before{
	content:"・";
	position: absolute;
	left:-1em;
	top:0;
}

/*==========================
ディレクター
===========================*/

.director_box{
	padding:50px 60px;
}

.director_wrap{
	background:url("../images/white_bk.webp");
	background-repeat: repeat-y;
	background-size: 100%;
	margin:auto;
	max-width:1200px;
	padding:30px 50px;
	border-radius:15px;
	box-shadow: 1px 1px 10px rgba(0, 0, 0, 0.5);
}

.director_title{
	display:flex;
	flex-wrap: wrap;
	gap:20px;
}
.director_img{width:100px;margin:auto 0;}
.director_name{width:calc(100% - 120px);}
.director_name h2{
	color:#231815;
	line-height: 1em;
    font-size: 20px;
    font-weight: 800;
}
.director_name h2 span{
	font-size:70%;
}

.director_namemain{
	display: flex;
	flex-wrap: wrap;
}

.director_name h3{
	color:#231815;
	line-height: 1em;
    font-size: 36px;
    font-weight: 800;
    padding-bottom: 5px;
}
.director_namesub{
	font-size:15px;color:#231815;
}

.director_namelinks{
	display: flex;
	flex-wrap: wrap;
	gap:20px;
	padding:0 15px;
}
.director_namelinks a{
	display: block;
	margin: 10px 0 auto;
	width:24px;
}

.director_text{padding-top:15px;color:#231815;}
.director_text p{
	padding-bottom: 15px;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.55em;
    letter-spacing: 0.04em;
}
.director_text a{
	color:#222;
}


/*==========================
固定ボタン
===========================*/

.fixed_button{
	position: fixed;
	bottom:60px;
	right:0;
	transition: all .5s ease;
	z-index: 40;
}

.fixed_button div{
	display:flex;
	flex-wrap: wrap;
	padding-bottom:10px;
}

.fixed_button a{
	display: inline-block;
	margin-left: auto;
	background-color:rgba(243,232,223,.85);
	font-family: "Noto Serif JP",serif;
	color:#391505;
	font-size:19px;
	letter-spacing:0.04em;
	font-weight:900;
	text-decoration: none;
	padding:20px 27px 20px 5px;
	border-radius:2px 0 0 2px;
	filter:drop-shadow(0 0 3px rgba(0,0,0,.6));
	transition: .2s;
}
@media screen and ( min-width:768px) {
	
	.fixed_button a{-webkit-writing-mode: vertical-rl; /* Safari用 */ writing-mode: vertical-rl;}
}

.fixed_button a:hover{
	padding:20px 50px 20px 5px;
	background-color:rgba(243,232,223,1);
}




/*==========================
TOP
===========================*/

#page_top {
	opacity: 0;
	position: fixed;
	bottom:20px;
	right:20px;
	transition: all .5s ease;
	z-index: 40;
}

#page_top.show {
    opacity: 1;
 }
#page_top a{
	display: inline-block;
	width:40px;
	text-decoration:none;
	filter:drop-shadow(0 0 3px rgba(0,0,0,.4));
}


/*==========================
footer
===========================*/

footer{
	background-color:rgba(0,0,0,.75);
	text-align:center;
	padding:12px 0 5px;
}

footer a,
footer address{
	font-family: "Helvetica Neue", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	color:#eee;
	text-decoration: none;
}

.footer_box {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
.footer_box a {
    display: block;
    font-size: 12px;
    color: #eee;
    padding: 0 12px;
    border-right: 1px #ccc solid;
}
.footer_box a:last-child{border-right:none;}

.footer_address a{
	margin:auto;
	display:inline-block;
	padding:3px 0;
	font-size:12px;
	letter-spacing:0.05em;
}
