@charset "utf-8";

/* ==============================================
  header
============================================== */
header li span {
	font-size: 2.6vw;
}

@media screen and (min-width: 1081px) {
	header li span {
		font-size: 2.8rem;
	}
}

@media screen and (max-width: 767px) {
	header li span {
		font-size: 2.67vw;
	}
}

/* ==============================================
  キービジュアル
============================================== */
.kv {
	position: relative;
	background: rgb(6,56,124);
	background: linear-gradient(90deg, rgba(6,56,124,1) 0%, rgba(0,131,223,1) 100%);
}
.kv .inner {
	position: relative;
	padding: 75px 0 45px;
}
.kv h1 {
	text-align: center;
}
.kv .btn_lang {
	position: absolute;
	top: 20px;
	left: 0;
	width: 1080px;
	right: 0;
	margin: auto;
}
.kv .btn_lang a {
	position: relative;
	display: inline-block;
	padding: 0.75em 1em 0.75em 36px;
	font-size: 1.4rem;
	font-weight: 700;
	background: #fff;
}
.kv .btn_lang a::before {
	position: absolute;
	top: 50%;
	left: 10px;
	content: '';
	width: 7px;
	height: 7px;
	border-top: 1px solid #003479;
	border-right: 1px solid #003479;
	-webkit-transform: rotate(45deg) translateY(-50%);
	transform: rotate(45deg) translateY(-50%);
}
.kv .kv_img {
	width: 100%;
}
@media screen and (max-width: 1081px) {
	.kv .btn_lang {
		width: 100%;
		padding: 0 20px;
		box-sizing: border-box;
	}
	.kv h1 {
		width: 100%;
		text-align: left;
	}
	.kv h1 img {
		width: 90%;
		margin-left: 5%;
	}
}
@media screen and (max-width: 767px) {
	.kv {
		position: relative;
	}
	.kv .inner {
		position: static;
		padding: 14vw 4vw 6vw ;
	}
	.kv .btn_lang {
		top: 3.2vw;
		left: 3.2vw;
		padding: 0;
	}
	.kv .btn_lang a {
		padding-left: 5.6vw;
		font-size: 2.67vw;
	}
	.kv .btn_lang a::before {
		left: 0.8vw;
		width: 1.4vw;
		height: 1.4vw;
	}
	.kv h1 img {
		width: 100%;
		margin-left: 0;
	}
}
/* ==============================================
	#abstract
============================================== */
#abstract {
	background: #5986d7;
	padding: 50px 0;
}
.program-table {
	padding: 50px 50px;
	background: #fff;
	color: #003479;
}
.program-table_title {
	font-size: 3.6rem;
	font-weight: 600;
	line-height: 1;
	text-align: center;
}
.program-table_title-small {
	margin-left: 10px;
	font-size: 1.4rem;
}
.program-table_list {
	display: flex;
	flex-wrap: wrap;
	margin-top: 30px;
}
.program-table_time {
	width: 200px;
	font-size: 1.7rem;
	font-weight: 600;
	line-height: 1.5;
}
.program-table_time:nth-of-type(n + 2){
	margin-top: 20px;
}
.program-table_content {
	width: calc(100% - 200px);
	font-size: 1.7rem;
	line-height: 1.5;
}
.program-table_content:nth-of-type(n + 2){
	margin-top: 20px;
}
@media screen and (max-width: 1081px) {
	#abstract {
		padding: 5vw 2vw;
	}
	.program-table_title {
		font-size: 3rem;
	}
}
@media screen and (max-width: 767px) {
	#abstract {
		padding: 5vw 0;
	}
	#abstract .inner {
    padding: 0 4vw;
	}
	.program-table {
		padding: 2em;
		border: 2px solid #003479;
	}
	.program-table_title {
		font-size: 4.8vw;
	}
	.program-table_title-small {
		margin-left: 2.667vw;
		font-size: 3.2vw;
	}
	.program-table_list {
		display: block;
		margin-top: 8vw;
	}
	.program-table_time {
		width: 100%;
		font-size: 3.7vw;
		text-align: center;
		padding: 0 0 0.6em;
		border-bottom: 1px solid #003479;
	}
	.program-table_time:nth-of-type(n + 1){
		margin-top: 8vw;
	}
	.program-table_content:nth-of-type(n + 1) {
		width: 100%;
		font-size: 3.2vw;
		margin-top: 4vw;
	}
}
/* ==============================================
	#movie
============================================== */
#movie {
	background: #87d8fd;
	padding: 50px 0;
	text-align: center;
}
#movie .movie_title {
	color: #003479;
	font-weight: bold;
	font-size: 3.6rem;
}
#movie .movie_title span {
	font-size: 3rem;
}
#movie .video {
	margin-top: 30px;
}
#movie .video video {
	width: 100%;
}
@media screen and (max-width: 767px) {
	#movie {
		padding: 5vw 0;
	}
	#movie .inner {
    padding: 0 4vw;
	}
	#movie .video {
		margin-top: 4vw;
	}
	#movie .movie_title {
		font-size: 4.8vw;
	}
	#movie .movie_title span {
		font-size: 4vw;
	}
}
/* ==============================================
	.scene
============================================== */
.scene {
	padding: 100px 0 0;
}
.scene .scene_title {
	padding-bottom: 18px;
	box-sizing: border-box;
	border-bottom: 1px solid #003479;
	color: #003479;
	font-size: 3rem;
	font-weight: 600;
	line-height: 1.4;
	text-align: center;
}
.scene .scene_text {
	font-size: 1.6rem;
	line-height: 1.8;
	padding-top: 50px;
}
.scene .scene_img span {
	font-size: 1.3rem;
	display: block;
	padding-top: 3px;
}
.scene01 .scene_img01 {
	text-align: center;
	padding-top: 50px;
}
.scene01 .scene_img02 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	padding-top: 30px;
}
.scene01 .scene_img02 li {
	width: 32%;
	margin: 20px 2% 0 0;
}
.scene01 .scene_img02 li:nth-of-type(3n) {
	margin: 20px 0 0 0;
}
.scene02 .scene_img01 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	padding-top: 35px;
}
.scene02 .scene_img01 li {
	width: 32%;
	margin: 20px 2% 0 0;
}
.scene02 .scene_img01 li:nth-of-type(3n) {
	margin: 15px 0 0 0;
}
.scene02 .scene_img01 li img {
	box-shadow: 3px 3px 10px -6px rgba(0,0,0,0.6);
}
.scene02 .scene_img02 {
	text-align: center;
	padding-top: 50px;
}
.scene03 .inner {
	overflow: hidden;
}
.scene03 .scene_text {
	float: left;
	width: 50%;
}
.scene03 .scene_img01 {
	float: right;
	width: 45%;
	padding-top: 30px;
}
.scene03 .scene_img01 img {
	padding-top: 20px;
}
.scene04 {
	padding-bottom: 80px;
}
.scene04 .scene_sec_box {
	overflow: hidden;
}
.scene04 .scene_text01 {
	float: left;
	width: 55%;
}
.scene04 .scene_img01 {
	float: right;
	width: 40%;
	padding-top: 50px;
}
.scene04 .scene_text02 {
	float: right;
	width: 47%;
}
.scene04 .scene_img02 {
	float: left;
	width: 48%;
	padding-top: 50px;
}
.scene04 .scene_text02 span {
	font-size: 1.8rem;
	font-weight: bold;
}
.scene04 .scene_text03 {
	float: left;
	width: 76%;
}
.scene04 .scene_img03 {
	float: right;
	width: 19%;
	padding-top: 50px;
}
@media screen and (max-width: 1081px) {
	.scene .inner {
    padding: 0 2vw;
	}
	.scene .scene_title {
		font-size: 2.6rem;
		line-height: 1.5;
	}
	.scene .scene_title br {
		display: block;
	}
}
@media screen and (max-width: 767px) {
	.scene .inner {
    padding: 0 4vw;
	}
	.scene {
		padding: 10vw 0 0;
	}
	.scene .scene_title {
		padding-bottom: 2.667vw;
		box-sizing: border-box;
		border-bottom: 1px solid #003479;
		font-size: 4.6vw;
		line-height: 1.4;
	}
	.scene .scene_text {
		font-size: 1.4rem;
		padding-top: 5vw;
	}
	.scene .scene_img span {
		font-size: 1.2rem;
	}
	.scene01 .scene_img01 {
		padding-top: 5vw;
	}
	.scene01 .scene_img02 {
		padding-top: 3vw;
	}
	.scene01 .scene_img02 li {
		width: 48%;
		margin: 2vw 4% 0 0;
	}
	.scene01 .scene_img02 li:nth-of-type(3n) {
		margin: 2vw 4% 0 0;
	}
	.scene01 .scene_img02 li:nth-of-type(2n) {
		margin: 2vw 0 0 0;
	}
	.scene02 .scene_img01 {
		padding-top: 3vw;
	}
	.scene02 .scene_img01 li {
		width: 48%;
		margin: 2vw 4% 0 0;
	}
	.scene02 .scene_img01 li:nth-of-type(3n) {
		margin: 2vw 4% 0 0;
	}
	.scene02 .scene_img01 li:nth-of-type(2n) {
		margin: 2vw 0 0 0;
	}
	.scene02 .scene_img02 {
		padding-top: 5vw;
	}
	.scene03 .scene_text {
		float: none;
		width: 100%;
	}
	.scene03 .scene_img01 {
		float: none;
		width: 100%;
		padding-top: 3vw;
	}
	.scene03 .scene_img01 img {
		padding-top: 2vw;
	}
	.scene04 {
		padding-bottom: 10vw;
	}
	.scene04 .scene_text01 {
		float: none;
		width: 100%;
	}
	.scene04 .scene_img01 {
		float: right;
		width: 40%;
		padding-top: 5vw;
		margin: 0 0 2vw 4vw;
	}
	.scene04 .scene_text02 {
		float: none;
		width: 100%;
	}
	.scene04 .scene_img02 {
		float: none;
		width: 100%;
		padding-top: 8vw;
	}
	.scene04 .scene_text02 span {
		font-size: 1.6rem;
	}
	.scene04 .scene_text03 {
		float: none;
		width: 100%;
		padding-top: 8vw;
	}
	.scene04 .scene_img03 {
		float: right;
		width: 35%;
		padding-top: 8vw;
		margin: 0 0 2vw 4vw;
	}
}

/* ==============================================
  comment
============================================== */
.comment {
	padding: 50px 0 80px;
	background: #c5dfff;
}
.comment .comment_title {
	font-size: 3.6rem;
	font-weight: 600;
	line-height: 1;
	text-align: center;
	color: #003479;
	padding-bottom: 30px;
}
.comment .comment_text {
	background: #fff;
	padding: 30px;
	margin-top: 15px;
	border-radius: 5px;
}
@media screen and (max-width: 1081px) {
	.comment {
		padding: 8vw 2vw 10vw;
	}
	.comment .comment_title {
		font-size: 3rem;
	}
}
@media screen and (max-width: 767px) {
	.comment {
		padding: 8vw 0 10vw;
	}
	.comment .comment_title {
		font-size: 4.8vw;
		padding-bottom: 5vw;
	}
	.comment .comment_text {
		padding: 5vw;
		margin-top: 2vw;
	}
}