/***
 * MainReset
 */
html {
	font-size: 62.5%;
	background: #fff;
	box-sizing: border-box;
}
@media (max-width: 795px) {
	html { font-size: calc(0.625em + 4 * (100vw - 795px) / 1000); }
}
*, *:before, *:after {
	box-sizing: inherit;
}
body, div, dl, dt, dd, ul, ol, li, pre, code, 
form, fieldset, legend, input, textarea, figure, 
p, blockquote, th, td {
	font-size: 1.6rem;
	margin: 0;
	padding: 0;
}
h1, h2, h3, h4, h5, h6 {
	font-size: 1.6rem;
	font-weight: normal; /*normal*/
	margin: 0;
	padding: 0;
}
body {
	color: #333;
	/*font-family: YuGothic, 游ゴシック, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, sans-serif;*/
	font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, 游ゴシック体, "ヒラギノ角ゴ Pro W3", メイリオ, sans-serif;
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
}
img {
	/*zoom: .35;*/
	-webkit-backface-visibility: hidden;
	max-width: 100%;
}
input, textarea, select, button {
	font-family: inherit;
	font-size: inherit;
	font-weight: normal;
}
input, select, button {
	vertical-align: middle;
}
article, aside, details, figcaption, figure,
footer, header, hgroup, main, menu, nav, section, summary {
	display: block;
}
address, caption, code, th {
	font-style: normal;
	font-weight: normal;
}
img, fieldset {
	border: 0;
}
ol, ul {
	list-style-type: none;
}

/***
 * SubReset
 */
a {
	color: #000;
	/*color: inherit;*/
	text-decoration: none;
	/*transition: all 0.1s;*/
}
a:active, a:hover {
	color: #419CC0;
	outline: 0;
	text-decoration: none;
}
a:hover img {
	opacity: 0.8;
	filter: alpha(opacity=80);
	transition: all 0.5s;
}
input, select, textarea, button {
	border-radius: 2px;
	border: 1px solid #999;
	margin: 0;
	padding: 5px;
}
input[type=text]:focus,input[type=email]:focus,input[type=tel]:focus, select:focus, textarea:focus {
	outline: none;
	background-color: #FFFFDF;
}
input[type=submit], input[type=button], button {
	cursor: pointer;
	background-color: #F4F4F4;
}
input[type=submit]:hover, input[type=button]:hover, button:hover {
	background-color: #fff;
}
input[type=submit]:active, input[type=button]:active, button:active {
	background-color: #FFFFDF;
}

/* dl.type01 */
dl.type01 {
	padding: 0 2%;
	color: #999;
	font-weight: normal;
	display: inline-block;
	vertical-align: top;
}
dl.type01 dt {
	font-size: 1.6rem;
	text-align: center;
	padding: 20px 0;
	border: 1px solid #999;
}
dl.type01 dd {
	font-size: 1.6rem;
	border: none;
	padding: 0 0 0 120px;
}
/* dl.type05 */
dl.type05 {
	font-weight: normal;
}
dl.type05 dt {
	font-size: 1.5rem;
	font-weight: bold;
	float: none;
	padding: 0;
}
dl.type05 dd {
	border: none;
	padding: 0;
}

/* dl.type06 */
dl.type06 {
	font-weight: normal;
	margin: 20px 0;
}
dl.type06 dt {
	font-size: 1.5rem;
	font-weight: normal;
	float: none;
	padding: 0;
	margin-top: 7px!important;
	margin-bottom: 7px!important;
}
dl.type06 dd {
	border: none;
	padding: 0;
	margin-bottom: 7px!important;
}

/* dl.type04 */
dl.type04 {
	width: 100%;
	font-weight: normal;
}
dl.type04 dt {
	width: 100%;
	font-weight: bold;
	padding: 0 0 2px 0;
	margin-bottom: 10px;
	font-size: 1.5rem;
	border-bottom: 1px dotted #999;
	float: none;
}
dl.type04 dd {
	font-size: 1.5rem;
	border: none;
	float: none;
	padding: 0;
}
/* dl.type02 */
dl.type02 {
	margin-top: 20px;
	font-weight: normal;
}
dl.type02 dt {
	font-size: 1.5rem!important;
	background-color: #fff;
	text-align: center;
	font-weight: normal;
	border: 1px solid #999;
	display: inline-block;
	vertical-align: top;
	width: 21%;
	margin-right: 15px;
	margin-bottom: 20px;
}
dl.type02 dt.dt01 {
	padding: 20px 0;
}
dl.type02 dt.dt02 {
	padding: 10px 0;
}
dl.type02 dt.dt03 {
	padding: 10px 0;
}
dl.type02 dd {
	padding: 0;
	border: none;
	display: inline-block;
	vertical-align: top;
	width: 70%;
	margin-bottom: 20px;
}
/* table */
table {
	border-collapse: collapse;
}
table th {
	padding: 30px 6px;
	min-width: 90px;
	text-align: center;
	background-color: #99C7D9;
	border: 1px solid #419CC0;
}
table td {
	padding: 10px;
	border: 1px solid #419CC0;
}
/* radio, checkbox */
.checkbox {
  display: none;
}
.checkbox + .mwform-checkbox-field-text {
  position: relative;
  vertical-align: middle;
}
.checkbox + .mwform-checkbox-field-text:before {
  content: "\f372";
  font-family: "Ionicons";
  color: #ccc;
  font-size: 22px;
  margin-right: 4px;
  vertical-align: middle;
}
.checkbox:checked + .mwform-checkbox-field-text:before {
  content: "\f374";
  color: #419CC0;
}
/*
input[type=radio] + label,
input[type=checkbox] + label {
	position: relative;
	cursor: pointer;
}
@media (min-width: 1px) {
	input[type=radio],
	input[type=checkbox] {
		visibility: hidden;
		margin: 0;
	}
	input[type=radio] + label,
	input[type=checkbox] + label {
		padding: 0 0 0 20px;
	}
	input[type=radio] + label::before,
	input[type=checkbox] + label::before {
		content: "";
		position: absolute;
		top: 50%;
		left: 0;
		display: block;
		width: 15px;
		height: 15px;
		margin-top: -9px;
		background: #fff;
	}
	input[type=radio] + label::before {
		border: 1px solid #999;
		border-radius: 30px;
	}
	input[type=checkbox] + label::before {
		border: 1px solid #999;
	}
	input[type=radio]:checked + label::after,
	input[type=checkbox]:checked + label::after {
		content: "";
		position: absolute;
		top: 50%;
		display: block;
	}
	input[type=radio]:checked + label::after {
		left: 4px;
		width: 7px;
		height: 7px;
		margin-top: -5px;
		background: #333;
		border-radius: 8px;
	}
	input[type=checkbox]:checked + label::after {
		left: 2px;
		width: 14px;
		height: 7px;
		margin-top: -8px;
		border-left: 3px solid #333;
		border-bottom: 3px solid #333;
		-webkit-transform: rotate(-45deg);
		-ms-transform: rotate(-45deg);
		transform: rotate(-45deg);
	}
}
*/
/* 引用符 */
.mn {
	font-family: '小塚明朝 Pro','Kozuka Mincho Pro',"游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.gs {
	font-family: '小塚ゴシック Pro L','Kozuka Gothic Pro Light','ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,sans-serif;
}
q {
	/*quotes: "「" "」" "『" "』";*/
	quotes: '"' '"' "'" "'";
}
/***
 * Common
 */
.content {
	overflow: hidden;
	width: 100%;
	max-width: 700px;
	margin: 0 auto;
}
.wrap {
	width: 100%;
	margin: 0 auto;
}
p {
	line-height: 180%;
}
.req {
	color: red;
	font-size: 70%;
}
.tac {
	text-align: center;
}
.op8 {
	opacity: 0.8;
	filter: alpha(opacity=80);
	-webkit-opacity: 0.8;
	-moz-opacity:0.8;
	-ms-filter: "alpha(opacity=80)";
}
.op9 {
	opacity: 0.9;
	filter: alpha(opacity=90);
	-webkit-opacity: 0.9;
	-moz-opacity:0.9;
	-ms-filter: "alpha(opacity=90)";
}
.none {
	display: none!important;
	transition: all 0.3s ease;
}
.fixed {
	position: fixed!important;
	top: -100px;
	z-index: 9999;
	box-shadow: 0px 3px 3px rgba(0,0,0,0.3);
	animation: moveimg 1s forwards;
}
@keyframes moveimg {
	100% { top: 0px; }
}
/* 480 */
@media screen and (max-width: 480px){
	.content {
		padding: 0 15px;
	}
}
/*body { background-color: #ccc; }*/

/************************************************************************************************/
html,body { height:100%; }

/***
 * #top -> header
 */
header {
	z-index: 9999;
	position: absolute;
	top: 0;
	width: 100%;
	min-height: 65px;
	max-height: 75px;
	background-color: #419CC0;
	padding-bottom: 0%;
	height: 100%;
}
header .left,
header .right {
	display: inline-block;
	vertical-align: top;
}
header .left {
	width: 45%;
}
header .left h1 {
	line-height: 1.5;
	margin: 12px 0 0 20px;
	font-size: 2.0rem;
}
header .left h1 .genru {
	display: block;
	font-size: 1.4rem;
}
header .left h1 a {
	color: #fff;
}
header .left h1 a:hover,
header .left h1 a:hover .genru {
	opacity: 0.7;
}
header .left h1 img {
	margin-top: 15px;
}
/* right */
header .right {
	height: 100%;
	width: 55%;
	text-align: right;
}
header .right nav,
header .right ul {
	height: 100%;
	width: 100%;
	display: flex;
	justify-content: flex-end;
}
header .right li {
	background-color: #fff;
	display: table;
	width: 15%;
	height: 100%;
}
header .right li a {
	font-size: 12px;
	display: table-cell;
	vertical-align: middle;
	text-align: center;
	width: 100%;
	height: 100%;
}
header .right li span.small {
	display: block;
}
header .right li:hover {
	background: #8fcfe8;
}
header .right li:hover a {
	color: #419CC0;
}
header .right li:hover span.small {
	color: #fff;
}
header .right li.pink {
	background-color: #f0afaf;
	color: #fff;
	width: 100px;
}
header .right li.pink:hover {
	background-color: #ff8585;
}
header .right li.pink a {
	color: #fff;
}
header .right li.pink a:hover {
	opacity: 0.8;
	filter: alpha(opacity=80);
}
header .right li.snavi {
	display: block;
	position: absolute;
	left: 55%;
	top: 85px;
}
header .right li.snavi .sub_ul {
	display: block;
	height: auto;
	width: auto;
}
header .right li.snavi .sub_ul li {
	width: 215px;
	text-align: center;
	padding: 10px 0 10px 20px;
	display: block;
	background-color: #fff;
}
header,
header h1,
header h1 img {
	transition: all 0.3s ease;
}
/* 768 */
@media (max-width: 768px) {
	header {
		max-height: 65px;
		opacity: 1.0!important;
	}
	header .left {
		width: 80%;
	}
	header .right {
		width: 20%;
	}
	header .left h1 img {
		margin-top: 10px;
		min-width: 262px;
		max-width: 262px;
	}
	header .right li {
		font-size: 1.4rem;
	}
	header .right ul {
		display: none;
		position: absolute;
		background-color: #fff;
		top: 65px;
		width: 100%;
		left: 0;
	}
	header .right li {
		padding: 10px 0;
		background-color: #fff;
		display: block;
		text-align: center;
		font-size: 1.8rem;
		width: 100%!important;
	}
	header .right li:last-child {
		box-shadow: 0px 3px 3px rgba(0,0,0,0.3);
	}
	header .right li a {
		display: block;
		text-align: center;
		width: 100%;
		height: 100%;
	}
	/* tab menu button */
	.menu {
		display: block;
		z-index: 9999;
	}
	.menu span {
		transition: all 0.3s;
		transform: rotate(0deg);
	}
	.menu .top {
		transform: translateY(-10px);
	}
	.menu .bottom {
		transform: translateY(10px);
	}
	.menu.is-open .middle {
		background: rgba(255, 255, 255, 0);
	}
	.menu.is-open .top {
		transform: rotate(-45deg) translateY(0px);
	}
	.menu.is-open .bottom {
		transform: rotate(45deg) translateY(0px);
	}
	.icon-ani {
		width: 60px;
		height: 45px;
		display: block;
		background: rgba(255, 255, 255, 0.02);
		position: absolute;
		top: 9px;
		right: 5px;
		cursor: pointer;
	}
	.icon-ani span {
		width: 35px;
		height: 2px;
		display: block;
		background: #fff;
		position: absolute;
		left: 50%;
		top: 50%;
		margin-left: -25px;
	}
}
/***
 * slider
 */
/* top -> slider */
#slider {
	width: 100%;
	height: 624px;
}
.vegas-timer {
	display: none;
}
.top_view {
	position: relative;
	width: 43%;
	min-width: 350px;
	max-width: 605px;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}
.top_view p {
	position: absolute;
	bottom: 10%;
	width: 100%;
	text-align: center;
	font-size: 1.6vw;
	color: #666;
}
#slider .wrap0 {
	text-align: center;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}
#slider .wrap1 {
	text-align: center;
	padding: 2px;
	background-color: rgba(255,255,255,0.6);
	width: 400px;
	margin-bottom: 20px;
	box-shadow: 0px 0px 5px rgba(0,0,0,0.3);
}
#slider .wrap2 {
	background-color: #fff;
	margin: 2px;
	padding: 40px 30px 20px 20px;
	border: #fff 5px solid;
	font-size: 26px;
	border: 4px solid rgba(255,255,255,0.2);
	background-color: rgba(255,255,255,0.5);
}
#slider .wrap0 span.text {
	color: #fff;
	font-size: 20px;
	text-shadow:1px 1px 2px #000000;
}
#slider .wrap2 span {
	display: block;
	font-weight: bold;
}
#slider .wrap2 span.work1 {
	font-size: 32px;
	line-height: 120%;
}
#slider .wrap2 span.work2 {
	font-size: 32px;
	
}
#slider .wrap2 span.work3 {
	font-size: 20px;
}
/* 480 */
@media (max-width: 480px) {
	#slider {
		height: 300px;
		margin-top: 65px;
	}
	#slider .wrap1 {
		width: 300px;
		margin-bottom: 10px;
	}
	#slider .wrap2 {
		padding: 20px 20px 10px 10px;
	}
	#slider .wrap0 span.text {
		font-size: 16px;
	}
	#slider .wrap2 span.work1 {
		font-size: 22px;
		line-height: 120%;
	}
	#slider .wrap2 span.work2 {
		font-size: 22px;
		
	}
	#slider .wrap2 span.work3 {
		font-size: 14px;
	}
}
/* sub => #sub_image */
#sub_image {
	height: 405px;
	margin-bottom: 8%;
	position: relative;
}
#sub_image img {
	width: 100%;
	height: 405px;
	object-fit: cover;
}
#sub_image .title {
	position: absolute;
	top: 58%;
	left: 50%;
	transform: translate(-50%,-50%);
}
#sub_image .title h2 {
	text-align: center;
	font-size: 2.4rem;
}
#sub_image .title h2 .en {
	font-size: 1.8rem;
	display: block;
}
/***
 * #top
 */
/* top -> #s01 */
#top #s01 {
	padding: 8% 0;
}
#top #s01 h2 {
	margin-bottom: 3.5%;
	font-size: 2.3rem;
	text-align: center;
	font-weight: bold;
	margin-bottom: 15%;
}
#top #s01 p {
	line-height: 200%;
}
#top #s01 .left,
#top #s01 .right {
	display: inline-block;
	vertical-align: top;
}
#top #s01 .left {
	width: 30%;
	text-align: center;
	font-weight: bold;
}
#top #s01 .right {
	width: 65%;
	margin-left: 5%;
}
#top #s01 .right h3 {
	border-bottom: 3px solid #419CC0;
	margin-bottom: 20px;
	font-weight: bold;
}
#top #s01 .right p {
	margin-bottom: 40px;
	line-height: 160%;
}
/* 480 */
@media (max-width: 480px) {
	#top #s01 .left,
	#top #s01 .right {
		display: block;
		width: 100%;
		margin: 0;
	}
	#top #s01 .left {
		margin-bottom: 15px;
	}
}
/* top -> #s02 */
#top #s02 {
}
#top #s02 h2 {
	margin-bottom: 3.5%;
	font-size: 2.3rem;
	text-align: center;
	font-weight: bold;
	margin-bottom: 50px;
}
ul.gyoumu {
	margin: 0 auto 15% auto;
	max-width: 500px;
	width: 100%;
	text-align: center;
}
ul.gyoumu li {
	width: 130px;
	height: 130px;
	/*font-weight: bold;*/
	text-align: center;
	margin: 10px;
	display: inline-block;
	vertical-align: top;
}
ul.gyoumu li a {
	display: block;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: #888;
	color: #fff;
}
ul.gyoumu li a:hover {
	background-color: #99C7D9;
	color: #58A8C8;
}
/* 768 */
@media (max-width: 480px) {
	ul.gyoumu li {
		width: 95px;
		height: 95px;
		margin: 4px;
	}
}
/* top -> #s03 */
#top #s03 {
	margin-bottom: 10%;
}
#top #s03 ul {
	text-align: center;
	margin-bottom: 10%;
}
#top #s03 ul li {
	display: inline-block;
	position: relative;
	text-decoration: none;
	width: 550px;
	border-radius: 5px;
	text-align: left;
	vertical-align: middle;
	font-weight: bold;
	padding: 20px 40px 20px 80px;
	font-size: 1.4rem;
	line-height: 140%;
	margin-bottom: 30px;
}
#top #s03 ul li:nth-child(1) {
	background: url(/images/kado01.png) 0 0 no-repeat, linear-gradient(#fff 0%, #fff 50%, #cacaca 100%);
}
#top #s03 ul li:nth-child(2) {
	background: #D7000F;
	color: #fff;
	display: none;
}
#top #s03 ul li:nth-child(3) {
	background: url(/images/kado02.png) 0 0 no-repeat, linear-gradient(#fff 0%, #fff 50%, #cacaca 100%);
}
#top #s03 ul li:nth-child(4) {
	background: url(/images/kado03.png) 0 0 no-repeat, linear-gradient(#fff 0%, #fff 50%, #cacaca 100%);
}
#top #s03 ul li:nth-child(5) {
	background: url(/images/kado04.png) 0 0 no-repeat, linear-gradient(#fff 0%, #fff 50%, #cacaca 100%);
}
#top #s03 .wrap {
	text-align: center;
}
#top #s03 .wrap h3 {
	font-weight: bold;
	font-size: 2.6rem;
}
#top #s03 .wrap .tel {
	font-weight: bold;
	font-size: 4.6rem;
	margin-bottom: 20px;
}
#top #s03 .flow {
	position: relative;
}
.muryou {
	font-size: 1.2rem;
	line-height: 120%;
	background: #D7000F;
	color: #fff;
	text-align: center;
	width: 60px;
	height: 38px;
	padding: 5px 0;
	position: absolute;
	top: 170px;
	left: 0px;
}
.muryou:before {
	content: "";
	position: absolute;
	top: 0px;
	right: -38px;
	border: 19px solid transparent;
	border-left: 19px solid #D7000F;
}
/* 768 */
@media (max-width: 768px) {
	#top #s03 ul li:nth-child(2) {
		display: inline-block;
	}
	.muryou {
		display: none;
	}
}
/* top -> #s04 */
#top #s04 h2 {
	margin-bottom: 3.5%;
	font-size: 2.3rem;
	text-align: center;
	font-weight: bold;
	margin-bottom: 50px;
}
#map iframe {
	display: block;
	height: 350px;
	width: 100%;
}


/***
 * .sub_head
 */
.sub_head {
	position: relative;
}
.sub_title {
	position: absolute;
	top: 58%;
	left: 50%;
	max-width: 230px;
	width: 100%;
	transform: translate(-50%,-50%);
	background-color: #006a94;
	color: #fff;
	opacity: 0.7;
	padding: 10px;
}
.sub_title h2 {
	text-align: center;
	font-size: 2.4rem;
}
.sub_title h2 .jp {
	font-size: 1.6rem;
	display: block;
}
/* 480 */
@media (max-width: 480px) {
	.sub_title {
		top: 50%;
	}
}

/***
 * #sub -> about
 */
#sub_about {
	object-fit: cover;
	height: 400px;
	overflow: hidden;
	background: url(/images/about_head.jpg) center bottom no-repeat;
	background-size: cover;
}
#sub.about #s01 {
    padding: 8% 0 0 0;
}
#sub.about #s01 h2 {
	margin-bottom: 3.5%;
	font-size: 2.3rem;
	text-align: center;
	font-weight: bold;
	margin-bottom: 50px;
}
#sub.about #s01 h3 {
	background-color: #419CC0;
	color: #fff;
	padding: 2px 10px;
	margin-bottom: 7%;
}
#sub.about #s01 table {
	max-width: 500px;
	width: 100%;
	margin: 0 auto 15% auto;
}
#sub.about #s01 table * {
	font-size: 1.4rem;
}
#sub.about #s01 .daihyou {
	text-align: center;
	margin-bottom: 50px;
}
#sub.about #s01 ul {
	width: 87%;
	margin: 0 auto 50px auto;
}
#sub.about #s01 ul li {
	font-size: 1.4rem;
	margin-bottom: 30px;
}
#sub.about #s01 ul li img,
#sub.about #s01 ul li .mid {
	display: inline-block;
	vertical-align: middle;
}
#sub.about #s01 ul li img {
	margin-right: 30px;
}
/* 480 */
@media (max-width: 480px) {
	#sub_about {
		height: 300px;
		margin-top: 65px;
	}
	#sub.about ul.access li {
		text-align: center;
	}
	#sub.about #s01 ul li img {
		display: inline-block;
	}
	#sub.about #s01 ul li .mid {
		width: 100%;
		display: block;
	}
}
/***
 * #sub -> service
 */
#sub_service {
	object-fit: cover;
	height: 400px;
	overflow: hidden;
	background: url(/images/service_head.jpg) center bottom no-repeat;
	background-size: cover;
}
#sub.service #s01 {
    padding: 8% 0 0 0;
}
#sub.service #s01 h2 {
	margin-bottom: 3.5%;
	font-size: 2.3rem;
	text-align: center;
	font-weight: bold;
	margin-bottom: 50px;
}
#sub.service #s01 h3 {
	background-color: #419CC0;
	color: #fff;
	padding: 2px 10px;
	margin-bottom: 7%;
}
#sub.service #s01 .left,
#sub.service #s01 .right {
	display: inline-block;
	vertical-align: top;
	margin-bottom: 15%;
}
#sub.service #s01 .left {
	padding-right: 20px;
	width: 70%;
}
#sub.service #s01 .left p {
	font-size: 1.4rem;
	line-height: 180%;
	margin-bottom: 20px;
}
#sub.service #s01 .right {
	width: 30%;
	text-align: right;
}
#sub.service dl dt,
#sub.service dl dd {
	font-size: 1.4rem;
	font-family: "小塚明朝 Pro", "Kozuka Mincho Pro", 游明朝, YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", HG明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
#sub.service dl dt {
	font-weight: bold;
}
#sub.service dl dd {
	line-height: 180%;
	margin-bottom: 20px;
}
#sub.service dl dd ul li {
	font-size: 1.4rem;
	font-family: "小塚明朝 Pro", "Kozuka Mincho Pro", 游明朝, YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", HG明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
/* 480 */
@media (max-width: 480px) {
	#sub_service {
		height: 300px;
		margin-top: 65px;
	}
	#sub.service #s01 .left,
	#sub.service #s01 .right {
		padding-right: 0px;
		display: block;
		width: 100%;
	}
	#sub.service #s01 .right img {
		width: 60%;
	}
	#sub.service #s01 .left {
		margin-bottom: 10px;
	}
	#sub.service #s01 .right {
		text-align: center;
	}
}
/***
 * #sub -> contact
 */
#sub_contact {
	object-fit: cover;
	height: 400px;
	overflow: hidden;
	background: url(/images/contact_head.jpg) center bottom no-repeat;
	background-size: cover;
}
#sub.contact #s01 {
    padding: 8% 0 0 0;
}
#sub.contact #s01 h2 {
	margin-bottom: 3.5%;
	font-size: 2.3rem;
	text-align: center;
	font-weight: bold;
	margin-bottom: 50px;
}
#sub.contact #s01 h3 {
	background-color: #419CC0;
	color: #fff;
	padding: 2px 10px;
	margin-bottom: 20px;
}
#sub.contact #s01 h3 + p {
	font-size: 1.2rem;
	margin-bottom: 15%;
}
#sub.contact #s01 .wrap {
	border-bottom: 1px solid #419CC0;
}

#sub.contact #s01 .left,
#sub.contact #s01 .right {
	display: inline-block;
	vertical-align: top;
	padding: 30px;
}
#sub.contact #s01 .left {
	position: relative;
	width: 35%;
}
#sub.contact #s01 .right {
	width: 65%;
}
#sub.contact #s01 .left .hissu {
	font-size: 1.4rem;
	padding: 0 10px;
	position: absolute;
	top: 32px;
	right: 0;
	background-color: #419CC0;
	color: #fff;
	display: block;
}
#sub.contact #s01 .left .ninni {
	font-size: 1.4rem;
	padding: 0 10px;
	position: absolute;
	top: 32px;
	right: 0;
	background-color: #ccc;
	color: #000;
	display: block;
}
#sub.contact .sended {
	font-size: 1.4rem!important;
}
#sub.contact .right input[type=text],
#sub.contact .right input[type=email],
#sub.contact .right textarea {
	width: 100%;
}
#sub.contact #s01 .control {
	margin: 8% 0 15% 0;
	text-align: center;
}
#sub.contact #s01 .control input {
	border: 0;
	background-color: #419CC0;
	color: #fff;
	width: 181px;
	height: 46px;
}
#sub.contact #s01 .control input:hover {
	opacity: 0.8;
}
#sub.contact .mwform-checkbox-field {
	width: 47%;
	display: inline-block;
	margin-left: 0px!important;
}
#sub.contact .mwform-tel-field input {
	width: 25%!important;
}
#sub.contact .small {
	font-size: 12px;
}
#sub.contact .mw_wp_form .error {
	color: red;
}
/* 480 */
@media screen and (max-width: 480px){
	#sub_contact {
		height: 300px;
		margin-top: 65px;
	}
	#sub.contact #s01 .left,
	#sub.contact #s01 .right {
		width: 100%;
		display: block;
		padding: 20px 10px;
	}
	#sub.contact #s01 .right {
		padding-top: 0;
	}
	#sub.contact #s01 .left {
		padding-bottom: 5px;
	}
	#sub.contact #s01 .left .hissu,
	#sub.contact #s01 .left .ninni {
		position: initial;
		display: inline;
		margin-left: 5px;
	}
	#sub.contact .mwform-checkbox-field {
		width: 49%;
	}
}

/***
 * #sub->privacy
 */
#sub.privacy {
	margin: 60px 0;
}
#sub.privacy h3 {
	background-color: #419CC0;
	color: #fff;
	padding: 2px 10px;
	margin: 30px 0 10px 0;
}
#sub.privacy .tR {
	text-align: right;
}
#sub.privacy ol {
	margin: 20px 0 0 30px;
}
#sub.privacy ol li {
	list-style: outside decimal;
	margin: 10px 0 0 0;
}
#sub.privacy ol li ul {
	margin-left: 20px;
}
#sub.privacy ol li ul li {
	list-style-type: lower-latin;
}
#sub.privacy ol li ul li ol {
	margin-left: 20px;
}
#sub.privacy ol li ul li ol li {
	list-style-type: lower-roman;
}
/***
 * float-nav
 */
#float-nav {
	display: none;
}
@media (max-width:  768px) {
	#float-nav {
		display: block;
		position: fixed;
		left: 0;
		bottom: 0px;
		z-index: 60;
		width: 100%;
		height: 50px;
		background-color: rgba(255,255,255,0.9);
		box-shadow: 0px 0px 10px rgba(0,0,0,0.54);
		transform: translate(0px, 0px);
		transition: transform 0.2s ease
	}
	#float-nav .nav-list {
		display: table;
		width: 100%;
		height: 100%;
		padding: 4px 0
	}
	#float-nav .nav-list .item {
		display: table-cell;
		width: 33%;
		text-align: center;
		vertical-align: middle
	}
	#float-nav .nav-list .item a {
		display: block
	}
	#float-nav .nav-list .item a * {
		color: #419CC0;
		font-size: 1.4rem!important;
	}
	#float-nav .nav-list .item i {
		font-size: 2.7rem!important;
	}
	#float-nav .nav-list .item .title {
		margin-top: 2px;
		line-height: 1.1;
		font-size: 10px;
	}
	#float-nav.nav-hidden {
		transform: translate(0px, 50px)
	}
}
/***
 * footer
 */
footer {
	padding-top: 10px;
	font-family: '小塚明朝 Pro','Kozuka Mincho Pro',"游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	background-color: #419CC0;
	color: #fff;
	text-align: center;
}
footer address dl dt {
	font-size: 2.0rem;
}
footer address dl dd {
	line-height: 1.2;
}
footer address dl dd:nth-child(3),
footer address dl dd:nth-child(4) {
	display: inline-block;
	padding: 0 6px;
}
footer #copy {
	width: 100%;
	text-align: center;
	font-size: 1.2rem;
	padding: 10px 0 2px 0;
}
footer a {
	color: #fff;
}
footer a:hover {
	color: orange;
}
@media (max-width:  768px) {
	footer {
		padding-bottom: 50px;
	}
}
/***
 * animation
 */
@-webkit-keyframes ani-mouse {
    0% {
    opacity: 1;
    top: 29%;
    }
    15% {
    opacity: 1;
    top: 50%;
    }
    50% {
    opacity: 0;
    top: 50%;
    }
    100% {
    opacity: 0;
    top: 29%;
    }
}
@-moz-keyframes ani-mouse {
    0% {
    opacity: 1;
    top: 29%;
    }
    15% {
    opacity: 1;
    top: 50%;
    }
    50% {
    opacity: 0;
    top: 50%;
    }
    100% {
    opacity: 0;
    top: 29%;
    }
}
@keyframes ani-mouse {
	0% {
		opacity: 1;
		top: 29%;
	}
	15% {
		opacity: 1;
		top: 50%;
	}
	50% {
		opacity: 0;
		top: 50%;
	}
	100% {
		opacity: 0;
		top: 29%;
	}
}
 .scroll-btn {
	display: block;
	position: absolute;
	left: 0;
	right: 0;
	text-align: center;
	top: 85%;
	left: 50%;
	transform: translate(-50%,-50%);
	width: 75px;
}
.scroll-btn > * {
	line-height: 18px;
	font-size: 13px;
	font-weight: normal;
	color: #7f8c8d;
	color: #2c5324;
	font-family: "proxima-nova", "Helvetica Neue", Helvetica, Arial, sans-serif;
	letter-spacing: 2px;
}
.scroll-btn > *:hover,
.scroll-btn > *:focus,
.scroll-btn > *.active {
	color: #2c5324;
}
.scroll-btn > *:hover,
.scroll-btn > *:focus,
.scroll-btn > *:active,
.scroll-btn > *.active {
	opacity: 0.8;
	filter: alpha(opacity=80);
}
.scroll-btn .mouse {
	position: relative;
	display: block;
	width: 22px;
	height: 43px;
	margin: 0 auto 10px;
	box-sizing: border-box;
	border: 2px solid #2c5324;
	border-radius: 23px;
}
.scroll-btn .mouse:hover {
	opacity: 0.7;
}
.scroll-btn .mouse > * {
	position: absolute;
	display: block;
	top: 29%;
	left: 50%;
	width: 8px;
	height: 8px;
	margin: -4px 0 0 -4px;
	background: #2c5324;
	border-radius: 50%;
	animation: ani-mouse 2.5s linear infinite;
}
/* 404 */
.err404 {
	margin: 50px;
	padding: 100px;
	text-align: center;
}
