﻿@charset "utf-8";
/* CSS Document */
/* design10 css */
html{font-size:100%;}
#main_img{
	width: 100%;
	height: 100vh;
}
#fakeloader{
	z-index: 9999;
}
#fakeloader .fl{
	position: absolute!important;
	top: 50%!important;
	left: 50%!important;
	transform: translate(-50%,-50%)!important;
	width: 50%!important;
	max-width: 300px!important;
}
#fakeloader .fl{
animation-name: loader;
animation-duration: 3s;
animation-timing-function: ease;
animation-iteration-count: infinite;
}
@keyframes loader {
0% {opacity: 0;}
100% {opacity: 1;}
}

/* --all page-- */
.logo{
	text-align: center;
}
.logo h1{
	max-width: 200px;
}
#menu_wrap{
	overflow: scroll;
	width: 100%;
	top: -150%;
	box-sizing: border-box;
	z-index: 9997;
}
#menu_bt{}
#menu_bt .bar{
	display: block;
	width: 40px;
	height: 5px;
	background-color: #fff;
	transition: all 0.3s;
}
#menu_bt .bar::before,#menu_bt .bar::after{
	content: "";
	display: block;
	width: 40px;
	height: 5px;
	background-color: #fff;
	transition: all 0.3s;
	position: absolute;
}
#menu_bt .bar::before{
	top: -10px;
}
#menu_bt .bar::after{
	bottom: -10px;
}
#menu_bt.close_bt .bar{
	background-color: transparent;
}
#menu_bt.close_bt .bar::before{
	top: 0;
	transform: rotate(45deg);
}
#menu_bt.close_bt .bar::after{
	bottom: 0;
	transform: rotate(-45deg);
}
footer #map{
	width: 100%;
	height: 500px;
}
footer #map iframe{
	width: 100%;
	height: 500px;
}
footer .logo #logo2{
	max-width: 300px;
}
/* index */
.index{
	box-sizing: border-box;
}
header{
	top: 0;
	z-index: 9998;
	position: fixed;
	width: 100%;
}
.index header #header{
	box-shadow: 0 5px 10px rgba(0,0,0,0.3);
}
.index #main_nav{
	box-shadow: 0 -5px 10px rgba(0,0,0,0.3);
}
/*.index #main_nav::after{
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 30px 30px 0 30px;
	content: "";
	display: block;
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translate(-30px,0);
}*/
.index header.fix{
	position: fixed;
	top: 0;
	width: 100%;
}
.index .fix #header{
	margin-bottom: 0!important;
}
#contents .square_box{
	box-sizing:border-box;
}
#contents figure:hover{
	box-shadow: 0 0 0 rgba(0,0,0,0);
}
#top_cms .more{
	width: 90px;
	height: 90px;
}
#top_cms .more a{
	width: 80px;
	height: 80px;
}
/* page title*/
#page_title::after{
	content: "";
	display: block;
	top: 0;
	left: 0;
	position: absolute;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.5);
	z-index: 0;
}
#page_title div{
	z-index: 1;
}
/* pager */
.pager{}
.pager li a::after{
	content: "";
	position: absolute;
	width: 100%;
	height: 1px;
	left: -100%;
	bottom: 0;
	transition: all 0.3s;
	background-color: #000;
}
.pager li a:hover::after{
	left: 0;
}
/* cate list */
.cate_list{}
.cate_list li:last-of-type{
	border-right: none!important;
}
#page-top{
	position: fixed;
	right: 10px;
}
#page-top a{
	display: block;
	width: 40px;
	height: 40px;
	position: relative;
}
.cate img,.cate_box img{
	box-shadow: 0 2px 4px rgba(0,0,0,0.15);
}
/* page7 */
#page7{}
#page7 .box_wrap .box{}
#page7 .box_wrap .box .box_title h3::before,#page7 .box_wrap .box .box_title h3::after{
	content: "";
	position: absolute;
	width: 10px;
	height: 10px;
}
#page7 .box_wrap .box .box_title h3::before{
	top: 0;
	left: 0;
	border-top: 2px solid;
	border-left: 2px solid;
}
#page7 .box_wrap .box .box_title h3::after{
	bottom: 0;
	right: 0;
	border-bottom: 2px solid;
	border-right: 2px solid;
}
/* page8 */
#page8 #form_box .box input::-webkit-input-placeholder,#page8 #form_box .box textarea::-webkit-input-placeholder{
	font-family: "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic",  sans-serif;
	font-size: 14px;
	opacity: 0.8;
}
#page8 #form_box .box input:-moz-placeholder,#page8 #form_box .box textarea:-moz-placeholder{
	font-family: "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic",  sans-serif;
	font-size: 14px;
	opacity: 0.8;
}
#page8 #form_box .box input::-moz-placeholder,#page8 #form_box .box textarea::-moz-placeholder{
	font-family: "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic",  sans-serif;
	font-size: 14px;
	opacity: 0.8;
}
#page8 #form_box .box input:-ms-input-placeholder,#page8 #form_box .box textarea:-ms-input-placeholder {
	font-family: "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic",  sans-serif;
	font-size: 14px;
	opacity: 0.8;
}
#page8 #form_box #form_bt div{
	display: inline-block;
	height: 50px;
	position: relative;
	-ms-transition: all 0.5s;
	-webkit-transition: all 0.5s;
	transition: all 0.5s;
}
#page8 #form_box #form_bt div input{
	width: 100%;
	height: 100%;
	position: absolute;
	z-index: 99;
	top: 0;
	left: 0;
	padding: 15px;
	border: none;
	background-color: transparent;
	-webkit-appearance: none;
}
#page8 #form_box #form_bt #reset input,#page8 #form_box #form_bt .bt_on input{
	cursor: pointer;
}
#page8 #form_box #form_bt #reset:hover,#page8 #form_box #form_bt .bt_on:hover{
	transform: translate(0,-5px);
	box-shadow: 0 2px 4px rgba(0,0,0,0.5);
}
.g-recaptcha > div{
	margin: 0 auto 30px;
	overflow: hidden;
}
#page8 #form_box #form_bt div::after{
	display: block;
	position: absolute;
	width: auto;
	height: 18px;
	letter-spacing: 3px;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	line-height: 1;
	z-index: 98
}
#page8 #form_box #form_bt #submit::after{
	content: "送信";
}
#page8 #form_box #form_bt #reset::after{
	content: "クリア";
}
/* page10 */
#page10 ul li{
	position: relative;
	padding: 10px 0;
}
#page10 ul li::before,#page10 ul li::after{
	content: "";
	width: 100%;
	height: 2px;
	position: absolute;
	transition: all 0.5s;
}
#page10 ul li::before{
	left: -100%;
	top: 0;
}
#page10 ul li::after{
	left: 100%;
	bottom: 0;
}
#page10 ul li:hover::after{
	left: 0;
}
#page10 ul li:hover::before{
	left: 0;
}
#page10 ul li:hover span:last-of-type{
	opacity: 0.5;
}
/* ---------- タブレット ---------- */
@media screen and (max-width: 768px){
header #header{
margin-bottom:0!important;
}
#top_cms{
	padding-bottom: 100px;
}
#top_cms .more{
	width: 70px;
	height: 70px;
}
#top_cms .more a{
	width: 60px;
	height: 60px;
}
#top_cms .top_cms_box:last-of-type{
	margin-bottom: 0;	
}
/* page10 */
#page10 ul li::after{
	left: 0;
}
#page10 ul li::before{
	left: 0;
}
#page10 ul li span:last-of-type{
	opacity: 0.5;
}
}

/* ---------- スマートフォン ---------- */
@media screen and (max-width: 667px){
	.logo h1{
	max-width: 180px;
}

}

/* ---------- IE ---------- */
@media all and (-ms-high-contrast:none){
	#header{padding: 15px 20px 15px;}
	#header .tel{padding: 8px 0 0 20px;}
	#header .logo{padding: 8px 0 0 0;}
	#main_nav ul li a{padding: 13px 10px 8px;}
	#bottom_menu nav{padding: 13px 10px 8px;}
	#copyright{padding: 13px 0 8px;}
	#top_cms .more a{padding: 8px 5px 2px;}
	#page_title div{padding: calc(5% + 3px) 5% calc(5% - 3px);}
	#page7 .box_wrap .box .box_title h3{padding: 15px 20px 8px;}
	#page8 #mail_contact input{padding-top: 10px;}
	#page8 #form_box #form_bt div::after{top: 56%;}
	.box_wrap .box p{padding-top: 15px;}/*#page09*/
	.box_wrap .box p a{padding-top: 15px;}/*#page09*/
	#page10 ul li {padding-top: 15px;}
}