﻿@charset "UTF-8";

/***** common *****/

html, body, img, p, a, div, ul, li, h1, h2, h3 {
	margin: 0;
	padding: 0;
	list-style: none;}
body,img {width:100%;margin:0 auto;padding:0;vertical-align:bottom;font-size:14px;}

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, a, main, input {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;}
* {font-family: 'Comfortaa', cursive;}
a {
	text-decoration: none;
	color: #47515f;}
a:hover,
a.active {color: #2e98e5;}
body {
	width: 100%;
	color: #47515f;
	font-size: 13px;
	font-weight: 400;
	word-wrap: break-word;
	overflow-wrap: break-word;
	background: #fff;
	border-bottom: solid 3px #2668fc;}
.red { color: #ff0000;}

header {
	text-align: center;
	border-top: solid 3px #2668fc;
	background: #ffffff;
	position: fixed;
	font-size: 12px;
	padding: 10px 100px;
	font-family: roboto;
	width: 100%;
	letter-spacing: 0.12em;
	z-index: 10;
	min-width: 960px;
	left: 50%;
	pointer-events: none;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);}
header div#tp {
	position: relative;
	max-width: 1600px;
	margin-left: auto;
	margin-right: auto;
	transition: transform 0.5s ease-out;
	-webkit-transition: -webkit-transform 0.5s ease-out;}
header div#tp div {
	float: left;
	position: relative;
	pointer-events: auto;
	transform-origin: left center;
	-webkit-transform-origin: left center;
	width: 130px;}
header div#tp div a { display: block;}
header div#tp div a img {
	width: 130px;
	height: auto;
	vertical-align: middle;}
header div#tp nav { position: relative;}
header div#tp ul {
	position: absolute;
	right: 0px;margin-right: 1px;
	left: auto;}
header li {
	float: left;
	margin-right: 32px;
	pointer-events: auto;
	padding: 15px 0;}
main {
	margin: 0 auto;
	overflow: hidden;}
main div#mv {
	width: 100%;
	height: 0;
	padding-top: 47.5%;
	background: url(../img/main.png) center 0 no-repeat;
	background-size: cover;
	background-color: #fff;
	position: relative;}
main div#mv p {
	position: absolute;
	top: 58%;
	left: 50%;
	-webkit-transform: translate(-50%,-50%);
	-moz-transform: translate(-50%,-50%);
	-ms-transform: translate(-50%,-50%);
	-o-transform: translate(-50%,-50%);
	transform: translate(-50%,-50%);
	width: 62.5%;
	text-align: center;
	font-size: 4vw;
	color: #ffffff;
	font-family: 'Noto Serif JP', sans-serif;}
article#wrap {
	padding-left: 100px;
	padding-right: 100px;}
section {
	border-left: dotted 1px #CCC;
	border-right: dotted 1px #CCC;
	background: #ffffff;
	width: 100%;
	position: relative;
	padding: 0 0 100px;}
/*
section div.inr {
	width: 90%;
	margin: 100px 5%;
	padding: 0 0 0;
	background: #fff;
	display: block;
	position: relative;}
*/
div.mv img {
	width: 130%;
	margin-top: 0%;
	margin-left: -10%;
	opacity: 0.7;}
div.inr div.sctTTL {
	padding: 150px 0 80px;
	text-align: center;}
div.inr div.sctTTL h1 {
	font-size: 46px;
	margin: 0 auto 30px;}
div.inr div.sctTTL h2 {
	font-size: 16px;
	color: #666666;}
section#sct01 div.inr div.inrCTS {
	padding-left: 30%;
	padding-right: 30%;
	font-family: 'Kosugi Maru', sans-serif;}
div.inr div.inrCTS p {
	letter-spacing: 0.08em;
	font-family: 'Kosugi Maru', sans-serif;
	line-height: 2.142;
	font-size: 14px;}
section#sct02 div.inr div.inrCTS {
	padding-left: 5%;
	padding-right: 5%;
	font-family: 'Kosugi Maru', sans-serif !important;}
section#sct02 div.inr div.inrCTS ul { font-size: 0;}
section#sct02 div.inr div.inrCTS ul li {
    display: inline-block;
    text-align: center;
    width: calc(88% / 3);
    padding: 0%;
    margin: 0 2% 2%;
    vertical-align: top;
    font-size: 14px;}
section#sct02 div.inr div.inrCTS ul li:last-child { margin: 0;}
section#sct02 div.inr div.inrCTS ul li h3 {
	text-align: center;
	font-family: 'Comfortaa', cursive !important;
	margin-bottom: 10px;}
section#sct02 div.inr div.inrCTS ul li img {
	width: 90%;
	margin: 0 0 20px;
	padding: 0 10%;}
section#sct02 div.inr div.inrCTS ul li p { text-align: left;}
section#sct03 div.inr div.inrCTS dl {
	margin: 0 auto;
	padding-left: 20%;
	padding-right: 20%;}
section#sct03 div.inr div.inrCTS dl dt {
	float: left;
	clear: left;
	width: 30%;
	padding: 0 0 20px;
	vertical-align: top;
 	margin: 10px 0 0;}
section#sct03 div.inr div.inrCTS dl dd {
	float:left;
	width: 70%;
	vertical-align: top;
	margin: 10px 0;}
section#sct03 div.inr div.inrCTS dl:after {
	content: "";
	display: block;
	height: 0;
	font-size: 0;
	clear: both;
	visibility: hidden;}
section#sct04 div.inr div.inrCTS { text-align: center;}
section#sct04 div.inr div.inrCTS a {
	text-align: center;
	background: #5889ff;
	padding: 2% 5%;
	border-radius: 5px;
	font-size: 14px;
	color: #fff;}
section#sct04 div.inr div.inrCTS a:hover { background: #8595bd;}
footer {text-align: center;
	border-top: solid 1px #ddd;}
footer div.toHome {
	margin: 0 auto;
	position: absolute;
	top: -50px;
	text-align: right;
	width: 70%;
	left: 15%;}
footer div.toHome a.back-to-top {
	position: fixed;
	right: 10px;
	bottom: 10px;
	color: #fff;
	width: 40px;
	height: 40px;
	z-index: 2;
	display: none;}
footer div.toHome a.back-to-top:before {
	content: "";
	display: block;
	width: 40px;
	height: 40px;
	border-radius: 20px;
	position: absolute;
	left: 0;
	top: 0;
	background: #000000;}
footer div.toHome a.back-to-top:after {
	content: "↑";
	display: block;
	text-align: center;
	width: 40px;
	height: 40px;
	line-height: 40px;
	position: absolute;
	left: 0;
	top: 0;}
footer img {
	width: 130px;
	display: block;
	margin: 10px auto;}
section#sct02 div.inr div.inrCTS ul li p a {
    font-size: 12px;
    background: rgba(0,94,20,1);
    color: #ffffff;
    padding: 3px 0;
    width: 100%;
    display: block;
    text-align: center;
    border-radius: 5px;
}
section#sct02 div.inr div.inrCTS ul li p a:hover {
    background: rgba(0,94,20,0.6);}

.FontR { font-family: 'Comfortaa', cursive !important;}
.FontM { font-family: 'Sawarabi Mincho', sans-serif !important;}
.FontN { font-family: 'Noto Serif JP', sans-serif !important;}
.FontK { font-family: 'Kosugi Maru', sans-serif !important;}

@media screen and (max-width: 1215px) {
	div.mv img { margin-left: -15%;}
}
@media screen and (max-width: 880px) {
	div.mv img { width: 140%;}
	div.mv img { margin-left: -20%;}
}
@media screen and (max-width: 799px) {
	header {
		min-width: 599px;
		max-width: 799px;
		left: unset;
		pointer-events: none;
		transform: unset;
		-webkit-transform: unset;
		padding: 10px 10px;}
	div.mv img {
		margin-left: -40%;
		width: 170%;}
	div.inr div.sctTTL { padding: 100px 0 50px;}
	section#sct01 div.inr div.inrCTS {
		padding-left: 20%;
		padding-right: 20%;}
	section#sct02 div.inr div.inrCTS ul li {
		width: 46%;
		margin: 0 5% 5% 0%;}
	section#sct02 div.inr div.inrCTS ul li:nth-child(2),
	section#sct02 div.inr div.inrCTS ul li:nth-child(4) { margin: 0;}
	section#sct03 div.inr div.inrCTS dl {
		padding-left: 10%;
		padding-right: 10%;}
	section#sct04 div.inr div.inrCTS a { padding: 4% 10%;}
}

@media screen and (max-width: 599px) {
	header, section, footer { width: 99.5%;}
	section#sct01 div.inr div.inrCTS {
		padding-left: 13%;
		padding-right: 13%;}
}
@media screen and (max-width: 540px) {
	div.inr div.sctTTL h1 { font-size: 36px;}
	article#wrap {
		padding-left: 10px;
		padding-right: 10px;}
	header {
		font-size: 10px;
		max-width: 100%;
		min-width: 100%;
		padding: 10px 5px;}
	header div#tp div { width: 80px;}
	header div#tp div a img { width: 80px;}
	header li {
		margin-right: 5px;
		padding: 10px 0;}
	header div#tp { max-width: 100%;}
}
