@charset "utf-8";
/* CSS Document */

/*ヘッダー*/
body {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 1.0em;
}
.mincho {
	font-family: 'Noto Serif JP', serif;
}
.eng {
	font-family: 'Cormorant Garamond', serif;
	font-weight: 400;
}
@media screen and (max-width: 767px) {
	body {
		font-size: 0.875em;
	}
}



/*layout*/
#containar {
	/*max-width: 500px;*/
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	position: relative;
	z-index: 2;
	background: #fff;
	/*box-shadow: 0 0 30px 0px rgb(0 0 0 / 30%);*/
}
.wrap {
	max-width: 1000px;
	margin: 0 auto;
}
.wrapS {
	max-width: 800px;
	margin: 0 auto;
}
.pc { display: block; margin-left: auto; margin-right: auto;}
.sp { display: none;}
@media screen and (max-width: 767px) {
	#containar {
		max-width: inherit;
	}
	.wrap {
		padding: 0 20px;
	}
	.wrapS {
		padding: 0 20px;
	}
	.pc { display: none;}
	.sp { display: block;}
}





#containar {
	color: #000;
	text-align: left;
}
#containar p {
	line-height: 1.7;
	padding: 0.5em 0;
}

table {
	border-collapse:collapse;
}

div.youtube {
	width: 100%;
	aspect-ratio: 16 / 9;
}
div.youtube iframe {
	width: 100%;
	height: 100%;
}
a:hover {
	text-decoration: none;
}

.textCenter {
	text-align: center;
}
.textCenterLeft {
	text-align: center;
}
@media screen and (max-width: 767px) {
	.textCenterLeft {
		text-align: left;
	}
}
.c-red {
	color: #fc0b0b;
}
.cap {
	text-indent: -1em;
	padding-left: 1em;
}
.tit {
	position: relative;
	border-left: 1px solid #1A1311;
	padding-left: 0.5em;
	font-size: 1.4em;
	margin-bottom: 1.0em;
}
.tit span {
	display: block;
	margin-bottom: 0.2em;
	font-weight: 700;
	font-size: 2.0em;
}
.tit strong {
	font-weight: 400;
}





footer {
	background: #f7c8dc;
	text-align: center;
	padding: 40px 0;
}





/*mv*/
#containar .mv {
	position: relative;
}
#containar .mv figure {
	text-align: center;
}
#containar .mv ul {
	margin: 0;
	padding: 0;
	list-style: none;
	position: absolute;
	top: 30px;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 760px;
}
#containar .mv ul li {
	width: 30%;
}
#containar .mv ul li a {
	background: #fff;
	border-radius: 5px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 10px 15px;
	color: #E50044;
	font-weight: bold;
	text-decoration: none;
}
#containar .mv ul li a:hover {
	background: #fcc6d6;
}
#containar .mv ul li a .fas {
	margin-left: 10px;
}
#containar .mv ul li a span {
	display: inline-block;
	width: 20px;
	margin-right: 5px;
}
@media only screen and (max-width: 767px) {
	#containar .mv ul {
		width: 100%;
		top: 7px;
		left: 0;
		transform: translateX(0);
		justify-content: center;
	}
	#containar .mv ul li {
		padding: 0 5px;
		width: auto;
	}
	#containar .mv ul li a {
		padding: 12px 10px;
	}
	#containar .mv ul li a .fas {
		display: none;
	}
	#containar .mv ul li a span {
		display: none;
	}
}






/*secMenu*/
#containar .secMenu {
	background: #ffce00;
	padding: 15px 0;
}
#containar .secMenu.fixed {
	position: fixed;
	top: 0;
	width: 100%;
}
#containar .secMenu ul {
	margin: 0 auto;
	padding: 0;
	list-style: none;
	display: flex;
	justify-content: space-between;
	/*width: 600px;/*中高生の作品掲載時はグレーアウトにする*/
}
#containar .secMenu ul li {
	/*width: 30%;*/
}
#containar .secMenu ul li a {
	background: #fff;
	color: #000;
	text-decoration: none;
	border-radius: 5px;
	padding: 14px 20px;
	padding-left: 30px;
	box-sizing: border-box;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
}
#containar .secMenu ul li a:hover {
	background: #000;
	color: #fff;
}
#containar .secMenu ul li a .fas {
	margin-left: 10px;
}
@media only screen and (max-width: 767px) {
	#containar .secMenu {
		padding: 7px 0;
	}
	#containar .secMenu ul {
		width: 100%;
		flex-wrap: wrap;
		justify-content: center;
		margin: 0;
	}
	#containar .secMenu ul li {
		border: none;
		width: 30%;
		text-align: center;
		padding: 5px 5px;
	}
	#containar .secMenu ul li.large {
		width: 50%;
	}
	#containar .secMenu ul li a {
		font-size: 0.875em;
		padding: 10px 4px;
	}
	#containar .secMenu ul li a:hover {
		background: #fff;
		color: #000;
	}
	#containar .secMenu ul li a .fas {
		display: none;
	}
}






/*sec01*/
#containar .sec01 {
	background: #f7c8dc;
	padding: 75px 0;
}
#containar .sec01 h2 {
	text-align: center;
	margin-bottom: 35px;
}
#containar .sec01 h2 span {
	display: block;
	max-width: 360px;
	margin: 0 auto;
	font-size: 1.3em;
	background: #fff;
	border-radius: 5px;
	padding: 20px 0;
}
#containar .sec01 ul {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	justify-content: space-between;
}
#containar .sec01 ul li {
	width: 33%;
    margin-bottom: 30px;
}
#containar .sec01 ul li h3 {
	text-align: center;
	font-weight: 400;
	line-height: 1.4;
	margin-top: 10px;
}
@media only screen and (max-width: 767px) {
	#containar .sec01 {
		padding: 40px 0;
	}
	#containar .sec01 h2 {
		margin: 0 30px;
		margin-bottom: 15px;
	}
	#containar .sec01 ul {
		flex-wrap: wrap;
	}
	#containar .sec01 ul li {
		width: 90%;
		margin: 15px auto;
	}
	#containar .sec01 ul li h3 {
		margin-top: 5px;
	}
}






/*sec02*/
#containar .sec02 {
	background: #fff;
	padding: 75px 0;
}
#containar .sec02 h2 {
	text-align: center;
	margin-bottom: 35px;
}
#containar .sec02 h2 span {
	display: block;
	max-width: 360px;
	margin: 0 auto;
	font-size: 1.3em;
	background: #ffce00;
	border-radius: 5px;
	padding: 20px 0;
}
#containar .sec02 h3 {
	font-size: 1.3em;
	margin-top: 30px;
	margin-bottom: 10px;
}
#containar .sec02 ol {
	padding-left: 1.0em;
}
#containar .sec02 ol li {
	margin: 0.8em 0;
	line-height: 1.7;
}
#containar .sec02 table {
    border-collapse: collapse;
    border-spacing: 0;
	overflow: auto;
	margin: 0;
	width: 100%;
}
#containar .sec02 table th,
#containar .sec02 table td {
	vertical-align: middle;
	padding: 1.0em 2.0em;
	border-top: 1px solid #b3b3b3;
	border-bottom: 1px solid #b3b3b3;
}
#containar .sec02 table th {
	text-align: center;
	font-weight: bold;
	background: #f2ebeb;
	width: 160px;
}
@media only screen and (max-width: 767px) {
	#containar .sec02 {
		padding: 40px 0;
	}
	#containar .sec02 h2 {
		margin: 0 30px;
		margin-bottom: 25px;
	}
	#containar .sec02 table {
		border-top: 1px solid #b3b3b3;
	}
	#containar .sec02 table th,
	#containar .sec02 table td {
		border-top: none;
		width:auto;
		display:block;
		padding: 1.0em 0.5em;
	}
}





/*sec03*/
#containar .sec03 {
	background: #fff;
	padding: 75px 0;
}
#containar .sec03 h2 {
	text-align: center;
	margin-bottom: 35px;
}
#containar .sec03 h2 span {
	display: block;
	max-width: 360px;
	margin: 0 auto;
	font-size: 1.3em;
	background: #ffce00;
	border-radius: 5px;
	padding: 20px 0;
}
#containar .sec03 ul {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	justify-content: space-between;
}
#containar .sec03 ul li {
	width: 18%;
	/*width: 16%;*/
	border: 1px solid #b3b3b3;
	background: #fff;
	border-radius: 5px;
	overflow: hidden;
	text-align: center;
}
#containar .sec03 ul li h3 {
	background: #f2ebeb;
	text-align: center;
	padding: 1.0em 0.5em;
}
#containar .sec03 ul li figure {
	padding: 1.0em 0.5em;
}
@media only screen and (max-width: 767px) {
	#containar .sec03 {
		padding: 30px 0;
	}
	#containar .sec03 h2 {
		margin: 0 30px;
		margin-bottom: 25px;
	}
	#containar .sec03 ul {
		flex-wrap: wrap;
	}
	#containar .sec03 ul li {
		width: 47%;
		margin: 10px 0;
	}
}







/*sec04*/
#containar .sec04 {
	background: #f2ebeb;
	padding: 75px 0;
}
#containar .sec04 h2 {
	text-align: center;
	margin-bottom: 15px;
}
#containar .sec04 h2 span {
	display: block;
	max-width: 360px;
	margin: 0 auto;
	font-size: 1.3em;
	background: #ffce00;
	border-radius: 5px;
	padding: 20px 0;
}
#containar .sec04 h3 {
	font-size: 1.3em;
	margin-top: 30px;
	margin-bottom: 10px;
}
#containar .sec04 .note {
	font-size: 0.875em;
}
#containar .sec04 ul {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
}
#containar .sec04 ul li {
	margin: 10px 0;
	margin-right: 20px;
}
#containar .sec04 ul li a {
	display: flex;
	align-items: center;
	background: #fff;
	border: 1px solid #000;
	padding: 0.8em 2.5em;
	color: #000;
	font-size: 0.875em;
	text-decoration: none;
}
#containar .sec04 ul li a:hover {
	background: #000;
	color: #fff;
}
#containar .sec04 ul li a .fas {
	margin-left: 0.5em;
}
#containar .sec04 ul li .note {
	text-align: center;
	font-size: 0.75em;
	padding: 0;
}
@media only screen and (max-width: 767px) {
	#containar .sec04 {
		padding: 50px 0;
	}
	#containar .sec04 h2 {
		margin: 0 30px;
		margin-bottom: 25px;
	}
	#containar .sec04 ul li {
		margin: 5px 0;
		margin-right: 15px;
	}
	#containar .sec04 ul li a {
		padding: 0.8em 1.5em;
	}
}






/*sec05*/
#containar .sec05 {
	background: #e6e6e6;
	padding: 75px 0;
}
#containar .sec05 h2 {
	text-align: center;
	font-size: 1.5em;
	line-height: 1.4;
	margin-bottom: 35px;
}
#containar .sec05 ul {
	margin: 0;
	padding: 0;
	list-style: none;
}
#containar .sec05 ul li {
	background: #fff697;
	border-radius: 10px;
	padding: 2.0em 2.0em;
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
}
#containar .sec05 ul li:not(:first-child) {
	margin-top: 30px;
}
#containar .sec05 ul li .text {
	width: 40%;
}
#containar .sec05 ul li .text h3 {
	font-size: 1.3em;
	margin-bottom: 10px;
}
#containar .sec05 ul li .text .note {
	font-size: 0.875em;
}
#containar .sec05 ul li dl.desc {
	width: 52%;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}
#containar .sec05 ul li dl.desc dt {
	box-sizing: border-box;
	width: 20%;
	font-size: 0.875em;
	font-weight: 700;
	background: #e60039;
	color: #fff;
	text-align: center;
	padding: 0.3em 0.5em;
	border-radius: 5px;
}
#containar .sec05 ul li dl.desc dd {
	box-sizing: border-box;
	width: 80%;
	padding: 0.5em 0.5em;
}
@media only screen and (max-width: 767px) {
	#containar .sec05 {
		padding: 50px 0;
	}
	#containar .sec05 h2 {
		margin: 0 30px;
		margin-bottom: 25px;
	}
	#containar .sec05 ul li {
		padding: 1.5em 1.0em;
		flex-direction: column;
	}
	#containar .sec05 ul li:not(:first-child) {
		margin-top: 20px;
	}
	#containar .sec05 ul li .text {
		width: 100%;
		margin-bottom: 15px;
	}
	#containar .sec05 ul li .text h3 {
		font-size: 1.4em;
		margin-bottom: 5px;
	}
	#containar .sec05 ul li dl.desc {
		width: 100%;
	}
	#containar .sec05 ul li dl.desc dt {
		width: 24%;
	}
	#containar .sec05 ul li dl.desc dd {
		width: 76%;
	}
}






/*sec06*/
#containar .sec06 {
	padding: 75px 0;
	padding-bottom: 40px;
}
#containar .sec06 .inner {
	background: #fff697;
	border-radius: 10px;
	padding: 2.0em 2.0em;
}
#containar .sec06 .inner2 {
	background: #fbe6ef;
	border-radius: 10px;
	padding: 2.0em 2.0em;
}
#containar .sec06 h3 {
	font-size: 1.3em;
	text-align: center;
	border-bottom: 1px solid #333;
	padding-bottom: 10px;
	margin-bottom: 15px;
}
#containar .sec06 h3 span {
	font-size: 0.75em;
	margin-top: 8px;
}
#containar .sec06 .note {
	font-size: 0.875em;
}
#containar .sec06 p {
	font-size: 1.2em;
}
#containar .sec06 dl.desc {
	width: 100%;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}
#containar .sec06 dl.desc dt {
	box-sizing: border-box;
	width: 18%;
	font-size: 0.875em;
	font-weight: 700;
	background: #e60039;
	color: #fff;
	text-align: center;
	padding: 0.4em 0.5em;
	border-radius: 5px;
}
#containar .sec06 dl.desc dd {
	box-sizing: border-box;
	width: 82%;
	padding: 0.7em 0.5em;
	padding-left: 1.5em;
}
@media only screen and (max-width: 767px) {
	#containar .sec06 {
		padding: 50px 0;
	}
	#containar .sec06 .inner {
		padding: 1.5em 1.0em;
	}
	#containar .sec06 h3 {
		font-size: 1.2em;
		text-align: left;
		line-height: 1.4;
		margin-bottom: 5px;
	}
	#containar .sec06 dl.desc {
		width: 100%;
	}
	#containar .sec06 dl.desc dt {
		width: 24%;
	}
	#containar .sec06 dl.desc dd {
		width: 76%;
		padding-left: 1.0em;
	}
}




/*secform*/
#containar .secform {
	background: #fff;
	padding: 75px 0;
}
#containar .secform h2 {
	text-align: center;
	margin-bottom: 35px;
}
#containar .secform h2 span {
	display: block;
	max-width: 360px;
	margin: 0 auto;
	font-size: 1.3em;
	background: #ffce00;
	border-radius: 5px;
	padding: 20px 0;
}
#containar .secform h3 {
	text-align: center;
	font-size: 1.3em;
	margin-top: 50px;
	margin-bottom: 10px;
}
#containar .secform dl {
	display: flex;
	align-items: center;
	border-bottom: 1px solid #f2ebeb;
}
#containar .secform dl dt {
	box-sizing: border-box;
	width: 30%;
	padding: 1.5em 0;
	padding-right: 2.0em;
	font-weight: bold;
	line-height: 1.4;
}
#containar .secform dl dd {
	box-sizing: border-box;
	width: 70%;
	padding: 1.5em 0;
	line-height: 1.4;
}
#containar .secform .attach {
	padding: 0;
}
#containar .secform .attach2 {
	padding-bottom: 1.0em;
}
#containar .secform .note {
	font-size: 0.875em;
}
#containar .secform .privacy {
	margin: 20px 0;
	border: 1px solid #f2ebeb;
	padding: 1.0em 1.5em;
	height: 10em;
	overflow-y: scroll;
}
#containar .secform .select_group label {
	display: inline-block;
	margin: 0 15px;
}
@media only screen and (max-width: 767px) {
	#containar .secform {
		padding: 40px 0;
	}
	#containar .secform h2 {
		margin: 0 30px;
		margin-bottom: 10px;
	}
	#containar .secform h3 {
		margin-top: 50px;
		margin-bottom: 5px;
	}
	#containar .secform dl {
		flex-direction: column;
	}
	#containar .secform dl dt {
		width: 100%;
		padding: 1.5em 0;
		padding-bottom: 0.5em;
	}
	#containar .secform dl dd {
		width: 100%;
		padding: 1.5em 0;
		padding-top: 0.5em;
	}
	#containar .secform .privacy {
		margin: 15px 0;
		height: 20em;
	}
}






form input[type=text], form input[type=email], form input[type=search], form input[type=tel], form input[type=password], form input[type=url], form input[type=date], form button[type=submit], form textarea{
	-webkit-appearance: none;
	font-family: 'Noto Sans JP', sans-serif;
	font-size:100%;
	width:100%;
	box-sizing: border-box;
	line-height: 1.5em;
	border: none;
	background: #E8E8E8;
	padding:0.5em;}
form select{
	font-family: 'Noto Sans JP', sans-serif;
	font-size:100%;
	width:100%;
	box-sizing: border-box;
	line-height: 1.5em;
	border: none;
	background: #E8E8E8;
	padding:8px;}
form label{
	display: block;
	margin-bottom: 10px;}
form .field{
	margin-bottom: 15px;}
form input[type=checkbox], form input[type=radio]{
	vertical-align:0;
	margin-right:5px;}
form .submit {
	text-align: center;
	margin: 0 auto;
	border-top: 1px solid #f2ebeb;
	padding: 2.0em 0;}
form .submit input[type=submit] {
	-webkit-appearance: none;
	border-radius: 0;
	display: inline-block;
	cursor: pointer;
	background: #0071bc;
	border: 1px solid #0071bc;
	width: 100%;
	max-width: 500px;
	padding: 20px;
	letter-spacing: 2px;
	color: #fff;}
form .submit input[type=submit]:hover {
	background: #fff;
	color: #000;
	border: 1px solid #0071bc;}

