@charset "utf-8";
/* CSS Document */
@import url('https://fonts.googleapis.com/css?family=Sawarabi+Mincho&display=swap&subset=japanese');
@import url('https://fonts.googleapis.com/css?family=Montserrat:400,700&display=swap');
body{
	font-family: "Sawarabi Mincho", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	line-height: 1.618;
	font-size: 16px;
	color:#404040;
	background-color: #ffffff;
	-webkit-text-size-adjust:100%;
	-webkit-font-smoothing:antialiased;
	min-height: 100vh;
}
.fontGothic {
	font-family: "Montserrat","游ゴシック",YuGothic,"ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","メイリオ",Meiryo,sans-serif;
}
/* Scroll Trigger */
.invisible{
 transition: opacity 0.5s ease;
 opacity: 0.0;
 }
.pcOnly {
	display: block;
}
.spOnly {
	display: none;
}
/*  */
#wrapper{
	position:relative;
	margin: 0 auto;
	width: 100%;
	/*max-width: 1440px;*/
}
header {
	height: 84px;
	width: 100%;
	position: relative;
}
header img {
	height: 36px;
	width: auto;
	position: absolute;
     top: 0;
     left: 0;
     right: 0;
     bottom: 0;
     margin: auto;
}
h1 {
	-webkit-transform: translate3d(0,0,0);
	transform: translate3d(0,0,0);
 	position: fixed;
	width: 57%;
    margin: auto;
    text-align: center;
    left: 16%;
    right: 0;
    top: 28%;
}
section {
	position: relative;
	overflow: hidden;
	min-height: 100vh;
	background-position: top center;
	background-color: transparent;
	padding: 1.6rem 1.6rem 2.4rem;
}
section h2 {
	color: #505050;
	margin: 1.6rem 0;
    font-size: 2.5rem;
    text-align: center;
	background-color: #b5caeb;
	font-weight: normal;
}
section h2 {
	background: linear-gradient(135deg, #f8f6c4, #d6f3ff, #e3fcc8);
    background-size: 500% 100%;
	-webkit-animation: AnimationName 4s ease infinite;
	-moz-animation: AnimationName 4s ease infinite;
	animation: AnimationName 4s ease infinite;
}
@-webkit-keyframes AnimationName {
    0%{background-position:90% 0%}
    50%{background-position:11% 100%}
    100%{background-position:90% 0%}
}
@-moz-keyframes AnimationName {
    0%{background-position:90% 0%}
    50%{background-position:11% 100%}
    100%{background-position:90% 0%}
}
@keyframes AnimationName {
    0%{background-position:90% 0%}
    50%{background-position:11% 100%}
    100%{background-position:90% 0%}
}

#section01 {
	min-height: 100vh;
	padding: 0;
	/*background-image: url(../images/bg/bg_image00.jpg);
    background-size: cover;*/
}
#sec01Bg {
	width: 100vw;
	height: 100vh;
	/*height: calc(100vh - 54px);*/
	position: fixed;
}
#section01 .sec01Title {
	position: absolute;
	right: 10vw;
	top: 0;
	z-index: 10;
}
#section01 .sec01Title img {
	height: 100vh;
	width: auto;
}
#section01 .sec01Footer {
	position: absolute;
	bottom: 0;
	width: 100%;
	height: 54px;
	background-color: #ffffff;
}
#section01 .sec01Footer a {
	display: inline-block;
	width: calc(100vw - 10%);
	text-align: center;
	font-size: 2.2rem;
	text-decoration: none;
	color: #13677c;
}
#section02 {
	background-color: #dcefe9;
	padding: 0 1.6rem 0;
}
#section02 h2 {
	text-align: center;
	font-size: 3.2em;
	padding: 2.4rem 0;
	border: none;
	background-color: inherit;
}
.delay10 {
	-webkit-animation-duration: 0.7s;
	animation-delay: 0.4s;
}
.delay20 {
	-webkit-animation-duration: 0.7s;
	animation-delay: 0.8s;
}
.delay30 {
	-webkit-animation-duration: 0.7s;
	animation-delay: 1.2s;
}
.delay40 {
	-webkit-animation-duration: 0.7s;
	animation-delay: 1.6s;
}
#section02 .sec02Cont {
	position: relative;
	padding: 1.0rem 1.6rem 3.2rem;
}
#section02 .sec02Cont > ul {
	text-align: center;
	padding: 2.0rem 1.6rem;
	background-color: #ffffff;
	border-radius: 7px;
}
#section02 .sec02Cont > ul li {
	padding: 1.0rem 1.0rem 1.6rem;
	font-size: 1.4rem;
}
#section03 {
	padding: 0 0 2.4rem;
	background-color: #dcefe9;
	/*min-height: 100vh;*/
}
#section03 .sec03Head {
    text-align: center;
}
#section03  h2 {
	text-align: center;
    font-size: 3.2em;
    margin: 0 0 2.4rem;
    padding: 2.4rem 0 3.6rem;
    border: none;
    background-color: #fbfda4;
}
#section03  .sec03Cont {
	width: 640px;
    margin: 1.6rem auto;
    padding: 1.6rem;
	background-color: #ffffff;
	border-radius: 7px;
}
#section03  .sec03Cont li {
	line-height: 2.0;
}
#section03  .sec03Ttl {
	text-align: center;
	font-size: 2.0rem;
	color: #1f78a0;
	border-bottom: 4px solid;
    margin: 0 auto 1.6rem;
}
#section03 .sec03ItemTtl {
	font-size: 1.2rem;
	color: #27614e;
	margin-top: 0.6rem;
}
#section03 .sec03Item {
	padding-left: 2.4rem;
	margin-bottom: 2.4rem;
}
#section03 .sec03Img {
	width: 480px;
	margin: 1.0rem auto;
}
#section03 .sec03Img img{
	border-radius: 7px;
}
#section04 {
	padding: 0;
	background-image: url("../images/cont_bg.png");
	background-position: center center;
	background-size: cover;
}
#section04 h2 {
	text-align: center;
	font-size: 3.2em;
	margin: 0 0 2.4rem;
	padding: 2.4rem 0 3.6rem;
	border: none;
	background-color: #fbfda4;
}

#section04 .sec04Cont {
	width: 640px;
	margin: 0 auto 3.6rem;
	padding: 1.0rem 1.6rem 3.2rem;
	background-color: #ffffff;
	border-radius: 8px;
}
#section04 .sec04Ttl {
	font-size: 2.0rem;
    text-align: center;
	color: #3a5a8c;
}
#section04 .sec04Theme {
	font-size: 1.2rem;
    text-align: center;
}
#section04 .sec04Rep {
	margin-top: 2.4rem;
}
#section05 {
	padding: 0;
	background-color: #ffffff;
}
#section05 h2 {
	margin: 0;
    font-size: 3.2em;
    padding: 2.4rem 0;
    background-color: #fbfda4;
}
#section05 h3 {
	text-align: center;
    margin: 3.2rem auto;
	color: #395a8b;
	font-size: 2.0rem;
}
#section05 h3 img {
	width: 36px;
	margin-top: 4px;
	margin-right: 8px;
}
#section05 .sec05Cont {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
    -ms-flex-align: start;
    align-items: flex-start;
	-webkit-justify-content: space-around;
    -ms-flex-pack: distribute;
    justify-content: space-around;
	padding: 1.0rem 1.6rem 3.2rem;
	flex-wrap: wrap;
}
#section05 .sec05Cont > div {
	width: 45%;
	margin-bottom: 2.4rem;
}
#section05 .CompBlock {
	max-width: 600px;
	margin: 0.6rem auto 3.2rem;
	padding: 1.6rem 1.6rem 0;
}
#section05 .CompBlock .compNote a {
	display: inline-block;
	font-size: 0.9rem;
	margin-bottom: 1.0rem;
	text-decoration: none;
}
#section05 .CompBlock .compNote a:hover {
	font-weight: bold;
}
#section05 .CompBlock .compTheme {
	font-weight: bold;
	font-size: 1.1rem;
}
#section05 .CompBlock .compItem {
	margin-left: 1.3rem;
	margin-bottom: 1.0rem;
}
#section06 {
	padding: 0;
	background-color: #dcefe9;
}
#section06 h2 {
	text-align: center;
    font-size: 3.2em;
    margin: 0 0 2.4rem;
    padding: 2.4rem 0 3.6rem;
    border: none;
    background-color: #fbfda4;
}
#section06 .sec06Head {
    text-align: center;
    padding: 1.6rem 0;
    font-weight: bold;
    border-bottom: 4px solid #ffc3d9;
}
#section06  h2 {
	margin: 0;
	padding: 2.4rem 0;
}
#section06  .sec06Ttl {
	text-align: center;
	margin-top: 3.2rem;
	font-size: 1.4rem;
}
#section06  .sec08Cont {
	width: 420px;
    margin: 4.2rem auto;
    padding: 2.4rem 1.0rem 1.0rem;
	text-align: center;
    border-radius: 7px;
	font-size: 1.3rem;
}
#section06  .sec06Cont li {
	margin-bottom: 1.0rem;
}
#section06 .sec06Gallery {
	margin: 2.4rem 0;
}
#section06 .shikiGallery li {
	text-align: center;
	margin-bottom: 4.2rem;
}
#section06 .shikiGallery span {
	padding-left: 1.0rem;
}
#section06 .shikiGallery img {
	width: auto;
	height: auto;
	max-height: 320px;
	max-width: 320px;
}
#section06 .shikiGallery a {
	display: inline-block;
	margin-bottom: 0.6rem;
}
#section06 .shikiGallery p {
	font-size: 0.85rem;
}
#section10 {
	padding: 1.6rem 1.6rem 0;
	min-height: 70vh;
}
#section10 .sec10Cont {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
    -ms-flex-align: start;
    align-items: flex-start;
	-webkit-justify-content: space-around;
    -ms-flex-pack: distribute;
    justify-content: space-around;
	padding: 1.0rem 1.6rem 3.2rem;
}
#section10 .sec10Cont > div {
	width: 45%;
	text-align: center;
}
#section10 .sec10Cont img {
	width: 80%;
    margin-bottom: 1.0rem;
}
#section10 .sec10Cont > ul {
	width: 45%;
}
#section10 .sec10Cont li img {
	width: 100%;
	margin-bottom: 3.2rem;
}
#section10 .sec10Cont > ul > li > ul {
	background-color: #ffffff;
    border-radius: 5px;
	border: 2px solid #99cccc;
    padding: 1.0rem 1.6rem;
}
#section10 .sec10Cont .sep{
	text-align: center;
    font-size: 2.4rem;
    font-weight: bold;
}
#section11 {
	padding: 0;
	min-height: 70vh;
}
#section11 h2 {
	border: none;
	margin: 0;
}
#section11 .sec11Cont div {
	padding-top: 45vh;
}
.footMes {
	display: block;
	width: 100%;
}
.footMes.m_fixed {
	left: 0;
	position: fixed;
	top: 0;
}
#section12 {
    padding: 0;
	/*background-color: #2c7287;*/
    min-height: inherit;
}
#section12 .sec12Foot .copy {
	background-color: rgba(255, 255, 255, 0.85);
	padding: 1.6rem 1.6rem 1.6rem;
	font-size: 0.8rem;
}
#section12 .sec12Foot .footCredit {
	background-color: rgba(44, 114, 135, 0.85);
	color: #ffffff;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
	padding: 1.6rem 1.2rem 0.6rem;
}
#section12 .footBan {
	background-color: #ffffff;
	padding: 0.6rem;
    padding-right: 72px;
}
#section12 .footQR {
    height: 100px;
    width: 100px;
	padding: 0 0.4rem;
}
.footCopy {
	background-color: #2c7287;
	font-size: 0.75rem;
    text-align: right;
    color: #ffffff;
    padding: 0.4rem 0.8rem 0.6rem 0.6rem;
}
.footLink {
	text-align: center;
    margin-bottom: 4.2rem;
}
.footLink a {
	padding: 1.0rem;
    background-color: #45b0b3;
    text-decoration: none;
    font-weight: bold;
    font-size: 1.2rem;
    border-radius: 16px;
    border: 2px solid #2d9295;
	color: #ffffff;
}
.footLink a:hover {
	background-color: #ecebc8;
	border: 2px solid #fffee0;
}
/* 応募要項 */
#section06 a {
	color: #d82773;
}
footer {
	background-color: #2c7287;
	z-index: 10;
}
.gFooter_pagetop {
	position: fixed;
	bottom: 2.4rem;
	right: 0.8rem;
	width: 3.6rem;
	height: 3.6rem;
	background-color: rgba(255, 238, 66, 0.8);
	color: #0c556b;
	text-align: center;
	border-radius: 7px;
	border: 1px solid #054153;
	text-decoration: none;
}
.footTop {
	font-size: 2.2rem;
    line-height: 0.9;
    margin-top: 0.3rem;
}
.footTop2 {
	margin-top: -0.4rem;
    font-size: 1.0rem;
}
/* */
.btn {
	text-align: center;
}
.btn a {
	margin-bottom: 1.0rem;
	display: inline-block;
    padding: 0.8rem 1.0rem;
    background-color: #45b0b4;
    color: #ffffff;
    font-size: 1.1rem;
    letter-spacing: 0.1rem;
    border-radius: 5px;
    border: 2px solid #2d9295;
	text-decoration: none;
} 
.btn a:hover {
    background-color: #80d6d9;
    border: 2px solid #80d6d9;
} 
.contBlock {
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
	padding: 2.0rem 2.4rem;
}
.colLogo {
	width: 40%;
	margin: 3.6rem auto;
}
.copyright{
	display:block;
	font-size: 0.85rem;
	text-align: right;
	margin: 2.6rem 1.0rem 1.0rem 0;
}
#page-top i {
	position: relative;
	padding-top: 2px;
	transition: .2s;
}
#page-top:hover i {
	animation: page-top-animation .1s ease 0s infinite alternate;
}
@keyframes page-top-animation {
	0% {padding-top: 0px; }
	100% {padding-top: 3px; }
}

@media(max-width:768px) {
	html,body,div,span,object,iframe,h1,h2,h3,h4,h5,h6,
	p,blockquote,pre,abbr,address,cite,code,del,dfn,em,
	img,ins,kbd,q,samp,small,strong,sub,sup,var,b,i,
	dl,dt,dd,ol,ul,li,fieldset,form,label,legend,
	table,caption,
	tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,figcaption,figure,
	footer,header,hgroup,menu,nav,section,summary,time,mark,audio,video,
	input,textarea{
		font-size:0.95rem;
	}
	html,body {
		min-width:100%;
	}
	header {
		height: 64px;
	}
	header img {
		width: 84%;
		height: auto;
	}
	.pcOnly {
		display: none;
	}
	.spOnly {
		display: block;
	}
	section {
		background-attachment: scroll
	}
	section h2 {
    	margin: 1.6rem 0;
    	font-size: 1.72rem;
	}
	#section01 {
		padding: 0 0 1.0rem 0;
	}
	#section01 .sec01Img {
		display: block;
		padding-top: 0;
		margin: 1.0rem auto 2.4rem;
		text-align: center;
		width: 96%;
	}
	#section01 .sec01Btn {
		position: absolute;
		text-align: center;
		left: 10vw;
		bottom: 4px;
	}
	#section01 .sec01Btn a {
		display: inline-block;
		padding: 0.4rem 0.6rem;
		background-color: #2c7287;
		border-radius: 5px;
		line-height: 1.0;
		letter-spacing: 0.1rem;
		font-size: 1.1rem;
		border: 2px solid;
		color: #ffffff;
		text-decoration: none;
	}
	#section01 .sec01Footer {
		height: 72px;
	}
	#section01 .sec01Footer a {
		display: inline;
		width: inherit;
	}
	#section02 h2 {
    	font-size: 1.5rem;
		margin: 0;
		padding: 2.6rem 0 1.6rem;;
	}
	#section02 {
		min-height: 72vh;
    	padding: 0 0 1.6rem;
	}
	#section02 h3 {
		font-size: 1.8rem;
		padding-top: 2.0rem;
	}
	#section02 .sec02Cont {
		display: block;
		padding: 2.4rem 1.0rem 3.2rem;
	}
	#section02 .sec02Cont > div {
		width: 100%;
		text-align: center;
	}
	#section02 .sec02Cont > ul {
		width: 100%;
		padding: 1.0rem 0;
	}
	#section02 .sec02Cont > ul li {
		padding: 0.9rem 0.6rem 0.8rem;
		line-height: 1.5;
		font-size: 1.15rem;
	}
	#section03 {
    	padding: 0 0 1.6rem;
	}
	#section03 h2 {
		line-height: 1.0;
    	padding: 2.4rem 0;
		font-size: 1.8rem;
	}
	#section03 .sec03Cont {
		width: 92%;
		max-width: 480px;
   		margin: 2.4rem auto;
    	padding: 1.0rem 0 0;
	}
	#section03  .sec03Cont li {
		margin-bottom: 1.0rem;
		padding: 0 1.0rem;
	}
	#section03  .sec03Ttl {
		width: 90%;
    	margin: 0 auto 1.0rem;
	}
	#section03 .sec03Img {
		width: 64%;
		max-width: 420px;
	}
	#section03 .sec03Item {
    	padding-left: 1.6rem;
	}
	#section04 {
    	padding: 0 0 1.6rem;
	}
	#section04 h2 {
		font-size: 1.8rem;
		padding: 1.6rem 0;
	}
	#section04 .sec04Cont {
		width:inherit;
		margin: 0 0.8rem 3.2rem;
		padding: 0.6rem 0.6rem 2.4rem;
	}
	#section04 .sec04Cont > div {
    	width: auto;
	}
	#section04 .sec04Cont > ul {
    	width: auto;
    	margin-top: 1.6rem;
	}
	#section04 .sec04Theme {
		font-size: 1.2rem;
	}
	#section04 .sec04Cont li img {
    	/*width: 100%;
		max-width: inherit;*/
 	}
	#section04 .sec04ThemeTtl {
    	margin-top: 0;
	}
	#section04 .sec04Ttl {
		font-size: 1.6rem;
    	margin-bottom: 0;
	}
	#section05 h2 {
		font-size: 1.8rem;
	}
	#section05 h3 {
		font-weight: normal;
		font-size: 1.8rem;
	}
	#section05 .sec05Cont {
		display: block;
	}
	#section05 .sec05Cont > div {
    	width: 100%;
    	margin-bottom: 1.6rem;
	}
	#section05 .CompBlock {
    	width: 100%;
    	padding: 1.0rem 1.0rem 0;
	}
	#section05 .CompBlock .compTheme {
    	border-bottom: 1px solid #c49781;
    	border-left: 6px solid #c49781;
    	padding: 0.2rem 0 0 0.6rem;
    	margin: 0.4rem 0;
	}
	#section06  h2 {
		font-size: 1.8rem;
		padding: 1.6rem 0;
	}
	#section06 .shikiGallery img {
    	width: 50%;
	}
	#section08 {
    	padding: 2.4rem 0 1.6rem;
	}
	#section08 .sec08Cont {
		width: 100%;
   		margin: 2.4rem auto;
    	padding: 1.0rem 0 0;
	}
	#section08  .sec08Cont li {
		margin-bottom: 1.0rem;
		padding: 0 1.0rem;
	}
	#section08 .sec08Gallery {
		margin: 1.0rem 0;
	}
	#section08 .shikiGallery {
		display: block;
		padding: 01.0rem;
	}
	#section08 .shikiGallery li {
		width: 100%;
		text-align: center;
	}
	#section08 .shikiGallery li img {
		width: 100%;
    	max-width: 320px;
	}
	#section08 .shikiGallery .vtcl {
		width: 62%;
	}
	#section10 {
		padding: 1.6rem 0 0;
	}
	#section10 .sec10Cont {
		display: block;
		padding: 1.0rem 1.0rem 3.2rem;
	}
	#section10 .sec10Cont > div {
		width: 100%;
	}
	#section10 .sec10Cont img {
    	width: 50%;
    	max-width: 320px;
	}
	#section10 .sec10Cont > ul {
		width: 100%;
		margin-top: 1.6rem;
	}
	#section10 .sec10Cont > ul > li > ul {
    	padding: 1.0rem;
	}
	#section11 {
		height: 80vh;
		padding: 0;
	}
	#section11 span {
		display: inline;
	}
	#section11 .sec11Cont {
		display: block;
	}
	#section11 .sec11Cont div {
		text-align: center;
		padding-top: 36vh;
	}
	#section12 .sec12Foot .copy {
		padding: 1.0rem;
		font-size: 0.85rem;
 	}
	#section12 .sec12Foot .footCredit {
		padding: 1.0rem 1.2rem 1.4rem;
	}
	.footLink a {
    	font-size: 1.1rem;
	}
	.copyright{
		font-size: 0.8rem;
	}
	.btn a {
		padding: 0.8rem 1.0rem;
	}
}

@media(max-width:360px) {
	#section02 .sec02Cont > ul li {
		font-size: 1.0rem;
	}
}

/* Common Css */
.txtBold {
	font-weight: bold;
}
.txt08 {
	font-size: 0.8rem;
}
.txt09 {
	font-size: 0.9rem;
}
.txt10 {
	font-size: 1.0rem;
}
.txt11 {
	font-size: 1.1rem;
}
.txt12 {
	font-size: 1.2rem;
}
.txt14 {
	font-size: 1.4rem;
}
.txt16 {
	font-size: 1.6rem;
}
.txt20 {
	font-size: 2.0rem;
}
.txt24 {
	font-size: 2.4rem;
}
.bottom10 {
	margin-bottom: 1.0rem
}
.bottom16 {
	margin-bottom: 1.6rem
}
.bottom24 {
	margin-bottom: 2.4rem
}
.bottom32 {
	margin-bottom: 3.2rem
}
.top10 {
	margin-top: 1.0rem
}
.top16 {
	margin-top: 1.6rem
}
.top24 {
	margin-top: 2.4rem
}
.top32 {
	margin-top: 3.2rem
}
.left10 {
	margin-left: 1.0rem;
}
.txtSpace10 {
	letter-spacing: 1px;
}
.txtCenter {
	text-align: center;
}
