@charset "utf-8";
/* CSS Document */
/*------------------------------------------------------
                 
				全ページ共通
				
			赤：#c00　リンク色：#f00117　緑：#003300;

			ヒラギノ角ゴ W3 JIS2004 → "sawarabi-gothic" 変更
				 
------------------------------------------------------*/
body{
	text-align:left!important;
	
	font-family: "sawarabi-gothic", sans-serif;
	/* font-weight: bold;*/
	color:#000;
	overflow-x: hidden;
}

@media only screen and (max-width: 767px) {
	body{	
		font-size:14px;
	}
}
@media (min-width: 768px) {
	body{	
		font-size:14px;
	}
}
@media (min-width: 992px) {
	body{	
		font-size:16px;
	}
}
#body{
	/*background-image:url(../img/back4.jpg);*/
	background-repeat:no-repeat;
	background-position:center top;
	/*background-attachment: fixed; */
}
@media only screen and (max-width: 767px) {
	#body{
	/*background-image:url(../img/back_xs.jpg);*/
}
}
a:link,a:visited,a:hover,a:active{
	color:dodgerblue;
}
.wrap{
	 overflow:hidden;
}
.c_b{
	clear:both;
}
.c_r{
	clear:right;
}
.color-black{
	color:#000;
}
.hissu{
	color:#F00;
}
.alert{
	color:#ff0000;
}
.row-eq-height{
	display:flex;
	flex-wrap:wrap;
}

#mainbox2{
	padding-top:80px;
}
.content{
	font-size:1.0em;
}@media only screen and (max-width: 767px) {
	.content{
		font-size:0.9em;
	}	
}
.content ul{
	margin-left:0;
	padding-left:0;
}
.content li{
	margin-left:20px;
	padding-left:0;
}
.kadomaru50{
	border-radius: 50%;        /* CSS3草案 */  
	-webkit-border-radius: 50%;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 50%;   /* Firefox用 */
}
.font-SS{
	font-size:0.7em!important;
}
.image-tate .cover{
  object-fit: cover!important;
  width: 100%!important;
  height: auto!important;
}
.image-yoko .cover{
  object-fit: cover!important;
  width: auto!important;
  height: 100%!important;
}
.object-fit-img {
  object-fit: contain;
}
/*.row{
	margin:0!important;
	
}*/
/*.container{
	margin:0 auto!important;
	text-align:center!important;
}*/
img{
	margin:auto;
	text-align:center;
}
h1{
	color:#000;
	text-decoration:none;
	font-size:1.8em;
	margin-bottom:15px;
	font-weight: bold!important;
}
@media only screen and (max-width: 767px) {
	h1{
		font-size:1.5em;
	}
}
h2,h3,h4,h5,h6{
	/* font-weight: bold;*/
}
table{
	box-shadow: 0px 3px 7px 0px rgba(0, 0, 0, 0.35)!important;
	border:1px solid #fff;
	margin:0;

}
tr,th,td{
	margin:0;
}
dl,dt,dd{
	margin:0;
}
table tr:nth-child(even) {
background: #fff;
}
 
table tr:nth-child(odd) {
background-color:#E5F3FF;
}

.link{
	position:relative;
}
.link a{
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    text-indent:-999px;
}
.center{
	text-align:center!important;
}

.font-S{
	font-size:0.8em!important;

}
.font-L{
	font-size:1.4em;

}
.mb10{
	margin-bottom:10px;
}
.mb20{
	margin-bottom:20px;
}
.mt20{
	margin-top:20px!important;
}
.pt20{
	padding-top:20px!important;
}
.template-none{
	margin:50px auto;
	text-align:center;
}
.setumei{
	font-size:0.8em;
}
#topimgback{
	background-image:url(../img/headback.jpg);
	padding:25px 0;
	background-size: cover;
	max-height:600px;
}
#topimgback img{
	width:100%;
	height:700px;
	object-fit: cover;
}
@media only screen and (max-width: 767px) {
	#topimgback{
		padding:10px 0;
	}
	#topimgback img{
		width:100%;
		height:200px;
		object-fit: cover;
	}
}
@media (min-width: 768px) and (max-width: 991px) {
	#topimgback img{
		width:100%;
		height:350px;
		object-fit: cover;
	}
}
@media (min-width: 992px)and (max-width: 1199px)  {
	#topimgback img{
		width:100%;
		height:400px;
		object-fit: cover;
	}
}
#topimg{
	position:relative;
}
#topimg .topimgtxt{
	max-width:1200px;
	position: absolute;
  top: 60%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%); /* Safari用 */
  transform: translate(-50%, -50%);
	font-family:"a-otf-ryumin-pr6n";
	
	color:#fff;
	text-shadow: 1px 1px 1px #333;

}
#topimg .topimgtxt p{
	padding:0;
	margin:0;
		text-align: center;
	
	/* 2秒待ってからアニメーションする */
	-webkit-animation-duration: 2s;
  animation-delay:2s;
  /* 2回繰り返す */
 /* -webkit-animation-iteration-count: 2;
  animation-iteration-count: 2;*/
}
@media only screen and (max-width: 767px) {
	#topimg .topimgtxt{
	font-size:20px;
	top: 80%;
		min-width:280px;
}
}
@media (min-width: 768px) {
	#topimg .topimgtxt{
	font-size:40px;
}
}
@media (min-width: 992px) {
	#topimg .topimgtxt{
	font-size:50px;
}
}
@media (min-width: 1200px) {
	#topimg .topimgtxt{
	font-size:60px;
}
}


header{
	padding-top:10px;
	padding-bottom:5px;
	border:none;
	width:100%;
	
}
#header{

  background-image: -moz-linear-gradient( 90deg, rgb(231,233,235) 0%, rgb(255,255,255) 15%, rgb(255,255,255) 100%);
  background-image: -webkit-linear-gradient( 90deg, rgb(231,233,235) 0%, rgb(255,255,255) 15%, rgb(255,255,255) 100%);
  background-image: -ms-linear-gradient( 90deg, rgb(231,233,235) 0%, rgb(255,255,255) 15%, rgb(255,255,255) 100%);
 
}

}

}
header p{padding:0;
}
header .stitle{
	font-size:0.7em;
	padding:0;
	margin-top:0;
	margin-bottom:5px;
}
@media only screen and (max-width: 767px) {
	header .stitle{
	font-size:0.4em;
	}
}
header .sitetitlebox{
	padding:0 0 0 15px;
}
header .titlesetumei{
	font-size:0.8em;
	padding:15px 0 0 0;
	/*display:none;*/
}
header .sitesetumei{
	font-size:0.8em;
	padding-top:10px;
}


header .logomark{
	padding:0 5px;
	text-align: right;
}
header .logomark .logo1{
	width:140px;
	margin:15px 5px 5px;
}
header .logomark .logo2{
	width:120px;
	margin:5px;
}
@media only screen and (max-width: 992px) {
	header .logomark{
		padding:10px 5px;
		text-align: left;
	}
	header .logomark .logo1{
		width:70px;
		margin:10px 5px 5px;
		
	}
	header .logomark .logo2{
		width:60px;
		margin-right:60px;
		
	}
}

header address{
	margin:0 0 0;
	text-align:center;
	font-size:1.0em;
}
@media only screen and (max-width: 767px) {
header .bkblue{
	background-color:#06F;	
}
}
.btn_contact{
	margin:0 auto 0;
}
.btn_contact a{
	color:#fff;
	text-decoration:none;
	padding:5px;
	margin-bottom:2px;
	display:block;
	text-align:center;
	border-style: solid;
	border-width: 3px;
	border-color: rgb(36, 187, 16);
	border-radius: 10px;
	-webkit-border-radius: 10px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 10px;   /* Firefox用 */
	background-image: -webkit-linear-gradient(left, rgb(0,153,51) 0%, rgb(0,153,51) 22%, rgb(0,153,51) 48%, rgb(20,177,20) 99%);
	background-image: -o-linear-gradient(left, rgb(0,153,51) 0%, rgb(0,153,51) 22%, rgb(0,153,51) 48%, rgb(20,177,20) 99%);
	background-image: linear-gradient(to right, rgb(0,153,51) 0%, rgb(0,153,51) 22%, rgb(0,153,51) 48%, rgb(20,177,20) 99%);

}
@media only screen and (max-width: 767px) {
	.btn_contact a{
		font-family: "sawarabi-gothic", sans-serif;
		/* font-weight: bold;*/
	}
}
#header-xs .sitesetumei{
	color:#fff;
	padding-top:10px;
	padding-bottom:10px;
}
#header-xs .btn_contact{
	text-align:center;
}
.red{
	color:#E40A2F;
}
#hbtn{
	/*background-color:#fff;*/
	float:right;
	text-align: center;
	padding:0px;
}
#hbtn button{
	color:#fff;
	border-radius: 20%;        /* CSS3草案 */  
	-webkit-border-radius: 20%;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 20%;   /* Firefox用 */
	padding:10px 10px;

  background-image: -moz-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  background-image: -webkit-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  background-image: -ms-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
 

	z-index:1000!important;
	margin:5px;
	font-size:12px;
	width:35px;
	height:35px;
}
.drawer-nav{
	/*background-color:#fff!important;*/
	background-image: -moz-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  background-image: -webkit-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  background-image: -ms-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
	z-index:1000!important;
}
.drawer-menu li{
	border-bottom:1px dotted #fff;
	list-style:none;
	line-height:1.0;
}
.drawer-menu li a{
	text-decoration:none;
	color:#fff;
	font-size:14px;
	display:block;
	padding:20px 0;
	text-align:center;
	position:relative;
}

#menuback{
	margin:0;
	text-align:center;
	/*padding:0!important;*/
	/*padding-bottom:5px;
	box-shadow: 0 2px 2px rgba(0,0,0,0.2);*/	

  background-image: -moz-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  background-image: -webkit-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  background-image: -ms-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  box-shadow: 0px 3px 7px 0px rgba(102, 102, 102, 0.6);
}

#menu.navi{
	/*margin:0 auto!important;
	padding:0 0 5px!important;*/
	text-align:center;
	
}
#menu.navi ul{
	margin:0;
	padding:0;

}


#menu.navi li{
	text-align:center;
	list-style:none;
	border-right:1px solid #fff;
	line-height: 1.0;
	margin:0;
	padding:0;
}
#menu.navi  li:first-child{
	border-left:1px solid #fff;
}
#menu.navi li a{
	text-align:center;
	vertical-align:middle;
	display:block;
	text-decoration:none;
	position:relative;
	color:#fff;
	background-color:transparent;
	border:none;
	padding:10px;
	
margin:0;
}
@media only screen and (max-width: 767px) {
	#menu.navi li a{
		font-size:0.8em;
	}	
}

.pagetop{
	text-align:center;
	padding:0 10px;
	margin:20px auto 10px;
	float:right;
}
.pagetop a{
	padding-top:15px;
	font-size:0.8em;
	margin-bottom:2px;
	border-radius: 50%;        /* CSS3草案 */  
	-webkit-border-radius: 50%;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 50%;   /* Firefox用 */
	background-image: -moz-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  background-image: -webkit-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  background-image: -ms-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
	color:#fff;
	width:70px;
	height:70px;
	display:block;
	text-decoration:none;
}

.pagelink{
	margin-top:20px;
	margin-bottom:20px;
	font-size:0.8em;
	text-align:center;
}

.box-sizing-cb{
	box-sizing:content-box;
}

h3,p{
	text-align:left;
}

h3.title{
	padding:10px 0;
	text-align: center;
	border-bottom:2px solid #1681ec;
	
	background-image: -moz-linear-gradient( 90deg, rgb(248,246,246) 0%, rgb(255,255,255) 100%);
  background-image: -webkit-linear-gradient( 90deg, rgb(248,246,246) 0%, rgb(255,255,255) 100%);
  background-image: -ms-linear-gradient( 90deg, rgb(248,246,246) 0%, rgb(255,255,255) 100%);
  box-shadow: 0px 3px 7px 0px rgba(0, 0, 0, 0.35);
  font-size:1.2em;
	margin-top:30px;
}
@media only screen and (max-width: 767px) {
	h3{
		font-size:1.4em;
	}	
}

#banner{
	/*margin:10px auto 0!important;
	padding:0;*/
	padding:0;
	margin:0;
}
#banner .banner{
	padding:5px;
	margin:0;
}

#main{
	/*background-image:url(../img/back4.jpg);*/
	background-repeat:no-repeat;
	background-position:center top;
	background-color: aliceblue;
}
.pagetitle{
	margin:0;
	padding:100px 0;
	height:100%;
	background-size:cover;
	background-position: center center;

  

}
@media only screen and (max-width: 767px) {
	.pagetitle{
	margin:0;
	padding:50px 0;
	height:100%;
	background-size:cover;
	background-position: center center;
}
}
.pagetitle h2 {
	margin-top:15px;
  padding: 5px;
	color:#fff;
	text-shadow: 1px 1px 1px #000;
/*  background-image: -moz-linear-gradient( 90deg, rgb(0,164,55) 0%, rgb(0,133,103) 100%);
  background-image: -webkit-linear-gradient( 90deg, rgb(0,164,55) 0%, rgb(0,133,103) 100%);
  background-image: -ms-linear-gradient( 90deg, rgb(0,164,55) 0%, rgb(0,133,103) 100%);*/
  font-size:1.4em;
}

.pback01{
	background-image:url(../img/ptitleback01.jpg);
}
.pback02{
	background-image:url(../img/ptitleback02.jpg);
}
.pback03{
	background-image:url(../img/ptitleback03.jpg);
}
.pback04{
	background-image:url(../img/ptitleback04.jpg);
}
.pback05{
	background-image:url(../img/ptitleback05.jpg);
}
.pback06{
	background-image:url(../img/ptitleback06.jpg);
	background-position: center left;
}
.pback07{
	background-image:url(../img/ptitleback07.jpg);
	background-position: center left;
}
.pback08{
	background-image:url(../img/ptitleback08.jpg);
	background-position: center left;
}
/*------------------------------------------------------
                 
			#home（個別テンプレート）
				 
------------------------------------------------------*/
/* home共通 */
#home {
	padding-top:20px;
}
#home .backimg{
	background-image:url(../img/backimg.jpg);
	background-size:cover;
}
#topimg{
	margin:0 auto;
	padding:0;
}
#home .cycle-slideshow{
	display: none;
}
#home #youtubebox{
	width:100%;
	margin:30px auto;
	text-align: center;
}
#home #youtubebox .youtube{
		position: relative;
		padding-top: 56.25%;
		width: 100%;
		margin-top:20px;
		
	}
#home #youtubebox .youtube iframe{
		position: absolute;
		top: 0;
		right: 0;
		width: 100%;
		height: 100%; 
}
/*お知らせ*/
#home #topnews .title{
  background-image: -moz-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  background-image: -webkit-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  background-image: -ms-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  box-shadow: 0px 3px 7px 0px rgba(102, 102, 102, 0.6);	
  padding-top:1px;
	border-bottom:1px solid #fff;
}
#home #topnews h2{
	color:#fff;
	background-image:url(../img/bk_blue.png);
	background-repeat: no-repeat;
	width:100%;
	background-size: 40px;
	padding-left:50px;	
	font-size:1.0em;
	padding-top:10px;
		min-height:30px;
	
}

@media only screen and (max-width: 767px) {
	home #topnews .title{
		background-size: 10px;
		height:20px;
	}
	
	#home #topnews h2{
		font-size:1.0em;
		padding-top:5px;
		min-height:20px;
		background-size: 30px;
		font-family: "sawarabi-gothic", sans-serif;
		/* font-weight: bold;*/
	}
}
#home .topnewsbox{
	background-color: rgb(255, 255, 255);
  opacity: 0.8;

	padding:10px 0 0;
	margin:0 0 15px;
	border-left:2px solid #ddd;
	border-right:2px solid #ddd;
	border-bottom:2px solid #ddd;
}
#home #topnews .icon-play-circle2{
	position:absolute;
	bottom:30%;
	color:#ffb030;
	font-size:1.4em;
}
#home .btn-common{
	display:inline-block;
	margin:10px 0;
	font-size:0.8em;
}

#home .topnewsbox .box{
	padding:10px 0;
	border-bottom:2px dotted #dddddd;
	margin:0;
}
#home .topnewsbox .box time{	
	padding:0 0 2px 15px;
	text-align:left;
	font-size:0.8em;
	display:inline-block;
	height:50%;
	margin:0;
	color:#666;
	color:dodgerblue;
}

#home h3{
	background-image:none;
	border:none;
	text-align: left;
	margin:0;
}
#home .topnewsbox .box h3{
	text-align:left!important;
	font-size:1.0em;
	padding-right:0;
}
@media only screen and (max-width: 767px) {
	#home .topnewsbox .box h3{
		font-size:1.0em;
		font-family: "sawarabi-gothic", sans-serif;
		/* font-weight: bold;*/
	}	
}
@media (min-width: 768px)and (max-width: 991px)  {
	#home .topnewsbox .box h3{
	font-size:1.0em;
	}
}
#home .topnewsbox .box h3 a{
	font-weight:bold;
}
#home .topnewsbox .box  p{
	padding-left:15px;
	padding-right:15px;
	padding-top:10px;
}
@media only screen and (max-width: 767px) {
	#home .topnewsbox .box{
		padding:5px 0;
	}
}
@media only screen and (max-width: 991px) {
	#home .topnewsbox .box time{
		font-size:0.7em;
	}	
}
/*topbtn*/
#home #topbtn .topbtn {
	background-image: -moz-linear-gradient( 90deg, rgb(239,119,139) 0%, rgb(223,42,43) 100%);
  background-image: -webkit-linear-gradient( 90deg, rgb(239,119,139) 0%, rgb(223,42,43) 100%);
  background-image: -ms-linear-gradient( 90deg, rgb(239,119,139) 0%, rgb(223,42,43) 100%);
  box-shadow: 0px 3px 7px 0px rgba(102, 102, 102, 0.6);
	padding:0;
	margin-bottom:15px;
}
#home #topbtn .topbtn .title{  
 color:#fff;
padding-top:1px;
	margin:0;
	border-bottom:1px solid #fff;
	padding-bottom:0;
	max-height:38px;
}

#home #topbtn h2{
	background-image: url(../img/bk_red.png);
	background-repeat: no-repeat;
	background-size: 40px;
	padding-left:50px;
	font-size:1.0em;
	padding-top:10px;
	max-height:30px;
	font-family: "sawarabi-gothic", sans-serif;
	/* font-weight: bold;*/
}
#home #topbtn p{
	font-size:0.7em;
	padding-top:10px;
}
#home #topbtn .staffphoto{
	padding-bottom:10px;
}
@media only screen and (max-width: 767px) {
	#home #topbtn .topbtn .title{ 
	max-height:28px;
	}
	#home #topbtn h2{
		font-size:1.0em;
		max-height:20px;
		background-size:30px;
		padding-top:5px;
		
	}
	#home #topbtn p{
	font-size:0.7em;
	padding-top:5px;
}
}

/* topmap*/
#topmap{
	margin-top:50px;
}
#topmap .title{
  background-image: -moz-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  background-image: -webkit-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  background-image: -ms-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  box-shadow: 0px 3px 7px 0px rgba(102, 102, 102, 0.6);
  color:#fff;
}
#topmap .title h2{
	margin-top:-30px;
}
#topmap .title p{
	padding-top:15px;
}
#topmap .mapbox{
	margin-top:30px;
	margin-bottom:30px;
}
#topmap .mapbox i{
	color:#ffcc00;
}
#topmap h3{
	font-size:1.4em;
	
}
#topmap h3 a{
	color:#000;
}
#topmap address{
	font-size:0.8em;
}
/*------------------------------------------------------
                 
	#newslist #news 共通　(一覧・詳細・個別テンプレート）
				 
------------------------------------------------------*/

/* template01 */
#newslist,#newsdetail{
}
#newslist h3,#newsdetail h3{
	background-image:none;
	border:none;
	text-align: left;
}

#newsbox{
	
}

/*------------------------------------------------------
                 
		#newslist　(一覧・個別テンプレート）
				 
------------------------------------------------------*/
#newslist{
}
#newslist #newsbox{
	border:2px solid #ddd;
	border-radius: 10px;        /* CSS3草案 */  
	-webkit-border-radius: 10px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 10px;   /* Firefox用 */
	background-color:#fff;
	margin-top:30px;
	padding-top:30px;
	
}
#newslist #newsbox img{
	height:250px;
	object-fit: contain;
	margin-bottom: 20px;
}
#newslist #newsbox .textbox{
	padding:0 15px 15px;
}
#newslist #newsbox a{
	text-decoration: none;
}
#newslist #newsbox .textbox p{
	color:#333;
}
#newslist h2{

}
#newslist .box{
	margin:0;
	border-bottom:1px dotted #ccc;
	padding:5px 10px;

}
#newslist .box time{
	color:#999;
	text-align:center;
	font-size:1.0em;
}
@media only screen and (max-width: 767px) {
	#newslist .box time{
		font-size:0.8em;
	}	
}
#newslist .box h3{
	text-align:left!important;
	font-size:1.4em;
	padding:5px 0 5px 0;
	color:dodgerblue;
}
@media only screen and (max-width: 767px) {
	#newslist .box h3{
		font-size:16px;
		font-family: "sawarabi-gothic", sans-serif;
		/* font-weight: bold;*/
	}	
}


/*------------------------------------------------------
                 
				#newsdetail (詳細・個別テンプレート）
				 
------------------------------------------------------*/

#newsdetail h2{

}
#newsdetail .box{
	margin-top:15px;
	border:2px solid #ddd;
	box-shadow: 0px 3px 7px 0px rgba(204, 204, 204, 0.35);
	padding:15px;
	height:100%;
	border-radius: 10px;        /* CSS3草案 */  
	-webkit-border-radius: 10px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 10px;   /* Firefox用 */
	background-color:#fff;
}
#newsdetail h3{
	margin:10px 0!important;
	font-size:1.8em;
	text-align:left;
	padding:0 0 10px 0!important;
	color:dodgerblue;
}
@media only screen and (max-width: 767px) {
	#newsdetail h3{
		font-size:1.4em;
		font-family: "sawarabi-gothic", sans-serif;
		/* font-weight: bold;*/
	}	
}
#newsdetail time{
	margin:0;
	padding:20px 0 20px;
	text-align:right!important;
	font-size:0.8em;
	float:right;
}
#newsdetail .content{
	padding:0;
}
#newsdetail .content p{
	padding:15px 0 0;
	text-align:left;
}
#newsdetail .content img{
	max-width:100%;
	height:auto;
}

/*------------------------------------------------------
                 
				#company（ 個別テンプレート）
				 
------------------------------------------------------*/
#company{
	text-shadow: 1px 1px 1px #fff;
	text-align:left;
	
}
#company h3{
	padding:10px 0;
	text-align: center;
	border-bottom:2px solid #1681ec;
	
	background-image: -moz-linear-gradient( 90deg, rgb(248,246,246) 0%, rgb(255,255,255) 100%);
  background-image: -webkit-linear-gradient( 90deg, rgb(248,246,246) 0%, rgb(255,255,255) 100%);
  background-image: -ms-linear-gradient( 90deg, rgb(248,246,246) 0%, rgb(255,255,255) 100%);
  box-shadow: 0px 3px 7px 0px rgba(0, 0, 0, 0.35);
  font-size:1.2em;
}

#company .setumei{
	padding:10px;
}
#company .box{
	
}
#company .box a{
	color:#FF0;
}

#company .icon-commerical-building{
	color:#ddd;
}
#company .backblue{
	background-color:aliceblue;
	padding-top:10px;
}	
#company #backblue h3{
	margin:0;
}
#company .aisatsu p,#company .enkaku p{
	text-align:left;
}

#company .aisatsu{
	padding:15px;
}
#company .content{
	padding-top:15px;
	
}
#company .cominfo dl{
	padding:0;
	margin:0;
	border-bottom:1px solid #ddd;
}
#company .cominfo dt{
	text-align:center;
	color:#1444a2;
	font-family: "sawarabi-gothic", sans-serif;
	padding:15px 0;
	/* font-weight: bold;*/
}
#company .cominfo dd {
	padding:15px 0;
}
#company .cominfo dd p{
	text-align:center;
	font-size:1.2em;
	padding-bottom:0;
}

@media only screen and (max-width: 767px) {
	#company dd{
	font-size:1.0em;
	}
}

#company figure{
	margin:0 10px 10px 0;
	padding:0;
}
#company .cominfo th,#company .enkaku th{
	width:25%;
}
@media only screen and (max-width: 767px) {
#company .enkaku th{
	width:35%;
}
}
 
/*------------------------------------------------------
                 
				#contact
				 
------------------------------------------------------*/
#contact #contactbox{
	margin-top:10px;
}
#contact #contactbox address{
	margin:20px 0;
	padding:10px;
	margin-top:15px;
	border:2px solid #ddd;
	box-shadow: 0px 3px 7px 0px rgba(204, 204, 204, 0.35);
	padding:15px;
	height:100%;
	border-radius: 10px;        /* CSS3草案 */  
	-webkit-border-radius: 10px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 10px;   /* Firefox用 */
	background-color:#fff;
	text-align: center;
	font-size:1.6em;
}
@media only screen and (max-width: 767px) {
	#contact #contactbox address span{
		font-size:0.8em;
		padding:0 15px;
	}
}
#contact{
	text-align:left!important;
	/*margin:10px;*/

}
#contact h2{
	text-shadow:none;
}
#contact p{
	padding-top:15px;
}
#contact  form{
	margin:20px 0;
	padding:10px;
	margin-top:15px;
	border:2px solid #ddd;
	box-shadow: 0px 3px 7px 0px rgba(204, 204, 204, 0.35);
	padding:15px;
	height:100%;
	border-radius: 10px;        /* CSS3草案 */  
	-webkit-border-radius: 10px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 10px;   /* Firefox用 */
	background-color:#fff;
}
#contact .form-group{
	margin:5px 0;
	padding:0;
}
#contact input{
	width:100%;
	padding:5px;
}
#contact textarea{
	width:100%;
}
#contact .btn_submit{
	text-align:center;
	margin:0 auto;
}
#contact .btn_submit input{

}
#contact .font-s{
	font-size:0.7em;
}
#contact .alert{
	font-size:0.9em;
	padding:0;
}
#contact table{
}
#contact th{
	width:30%;
}
#contact td{
	width:70%;
}
#contact input[type=radio]{
	width: 25px;
    height: 25px;
    vertical-align: middle;
	padding:25px 0;
}
#contact input[name=zipcode]{
	width:40%;
	margin-bottom:2px;
}
#contact input[type=checkbox] {
	width:30px;
	height:30px;
	padding:0;
	margin:10px 0;
	vertical-align: middle;
}
/*------------------------------------------------------
                 
		#service
				 
------------------------------------------------------*/
#service{
}
#service .servicebox{
	border:2px solid #ddd;
	border-radius: 10px;        /* CSS3草案 */  
	-webkit-border-radius: 10px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 10px;   /* Firefox用 */
	background-color:#fff;
	margin-top:50px;
	padding-top:20px;
	padding-bottom: 15px;
	text-align: center;
}
#service .servicebox img{
	height:250px;
	object-fit: contain;
}
#service p{
	padding:15px 15px 0;
}
#service h3{
  	position: relative;
	font-size:1.4rem;
	padding:10px 10px 0;
	border:none;
	color:#000;
	box-shadow: none;
	background-image:none;
	/* font-weight: bold;*/
	color:dodgerblue;
}
/*#service h3::after {
  position: absolute;
  top: .5em;
  left: .2em;
  content: '';
  width: 6px;
  height: -webkit-calc(100% - 1em);
  height: calc(100% - 1em);
  background-color: #3498db;
  border-radius: 4px;
}*/
@media only screen and (max-width: 767px) {
	#service .servicebox{
		margin-top:30px;
	}
}

/*------------------------------------------------------
                 
		#flow
				 
------------------------------------------------------*/
#flow{

}
#flow h2{
	background-color:#3ec771;
}
/* template07 */

#flow .setumei{
	padding:10px;
}
#flow .box{
	background-color: #FFF;
	padding:15px 10px;
	border-bottom:1px solid #dddddd;
}
#flow h3{
	/*margin:0!important;
	padding:15px 15px 15px!important;*/
	font-weight:bold;
	line-height:1.4;
	margin:0 0 0 0;
	border-bottom:0;
	font-size:1.8em;
	color:#c00;
}
@media only screen and (max-width: 767px) {
	#flow h3{
		font-size:1.0em;
	}	
}
#flow .sbox{
	border-bottom:1px dotted #fff;
}
#flow .content{
	margin:0;
	text-align:left;
}

#flow .txt01{
	font-size:0.7em!important;
}
#flow figure{
	margin-bottom:0;
}
/*------------------------------------------------------
                 
		#recruit
				 
------------------------------------------------------*/
#recruit #recruitbtn{
	
}
@media (min-width: 992px){
	#recruit #recruitbtn{
		padding:10px 40px 0;
	}
}
#recruit #recruitbtn a{
	border:1px solid #ddd;
	padding:15px;
	display: block;
	margin-top:15px;
	text-align: center;
	text-decoration: none;
	background-color: #fff;
	border-radius: 15px;
}


#recruit .senpai{
	padding:30px 15px;
}

#recruit .senpai figure{
	padding:15px;
}
#recruit .senpai figcaption{
	text-align: center;
	padding:10px;
}
#recruit .motomeru{
	padding:50px 10px 30px;
	text-align: center;
	margin:auto;
}
#recruit .motomerubox{
	text-align: left;
	border:2px solid #ddd;
	border-radius: 10px;        /* CSS3草案 */  
	-webkit-border-radius: 10px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 10px;   /* Firefox用 */
	background-color:#fff;
	padding-top:10px;
	font-size:1.1rem;
}
#recruit .motomerubox li{
	 padding-top:5px;
}
#recruit .setumeibox{
		padding:20px 0 0;
}
@media (min-width: 992px){
	#recruit .motomeru img{
		width:800px;
		margin:auto;
		
	}
	#recruit .motomerubox{
		width:800px;
		margin:auto;
		font-size:1.8rem;
		padding:15px 50px 15px;
	}
	#recruit .motomerubox li{
	  padding-top:15px;
	}
	#recruit .setumeibox{
		padding:50px 40px 0;
	}
}
	

#recruit .recruitbox{
	padding:30px 50px 0;
}
#recruit .recruitbox-2{
	padding:50px;
}
@media only screen and (max-width: 767px) {
	#recruit .recruitbox{
	padding:10px;
}
}
@media only screen and (max-width: 767px) {
	#recruit .recruitbox-2{
	padding:0;
}
}
#recruit dt,#recruit dd{
	padding:10px;
	border-bottom:1px solid #ccc;
	margin:0;
}
#recruit dt{
	 background-image: -moz-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  background-image: -webkit-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  background-image: -ms-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  box-shadow: 0px 3px 7px 0px rgba(102, 102, 102, 0.6);
	color:#fff;
	font-size:0.8em;
}
@media only screen and (max-width: 767px) {
	#recruit dt{
	padding:5px 10px;
}
}
#recruit dd{
	background-color:#fff;
}
#recruit h4{
	margin-top:15px;
	font-size:1.4em;
}
#recruit table{
	width:100%!important;
	padding:0;
	margin:0 0 15px 0;
}
#recruit table th,#recruit table td{
	border:1px solid #ccc;
	border-collapse: collapse;
	white-space: nowrap;　　/*tableのセル内にある文字の折り返しを禁止*/
	text-align: center;
	font-size:0.9em;
}
#recruit table th{
	position: relative;
  padding: 5px;
	color:#fff;
	text-shadow: 1px 1px 1px #000;

  background-image: -moz-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  background-image: -webkit-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  background-image: -ms-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  box-shadow: 0px 3px 7px 0px rgba(102, 102, 102, 0.6);
	color:#fff;
	min-width:200px;
	font-size:0.8em;
	text-align:center;
}
#recruit table td{
}
@media only screen and (max-width: 767px) {

#recruit table th{
	min-width:100px;
	
}
	
}
#recruit .scroll::-webkit-scrollbar {

  height: 15px;

}

.scroll::-webkit-scrollbar-track {

  border-radius: 5px;

  background: #eee;

}

.scroll::-webkit-scrollbar-thumb {

  border-radius: 5px;

  background:#0099ff;
} 
/*------------------------------------------------------
                 
		#voice
				 
------------------------------------------------------*/
#voice{
	
	

}
#voice .notxt{
	padding:50px 0;
	text-align: center;
}
#voice .sbox{
	padding:10px 10px 0;
}
#voice .voicebox{
	border:2px solid #ddd;
	box-shadow: 0px 3px 7px 0px rgba(204, 204, 204, 0.35);
	padding:15px;
	height:100%;
	background-color:#fff;
	margin-top:15px;
	border-radius: 10px;        /* CSS3草案 */  
	-webkit-border-radius: 10px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 10px;   /* Firefox用 */
	
	
}
#voice .comment{
	border:2px dotted #ddd;
	padding:15px;
	border-radius: 10px;        /* CSS3草案 */  
	-webkit-border-radius: 10px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 10px;   /* Firefox用 */
	background-color:#fff;

}
#voice  img{
	padding-left:0;
	padding-bottom:10px;
}
#voice .comment .fukidashi{
	color:#fff;
  background-color: rgb(14, 94, 225);
	border-radius: 10px;        /* CSS3草案 */  
	-webkit-border-radius: 10px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 10px;   /* Firefox用 */
 	font-size:0.8em;
	display:inline-block;
	padding:5px 10px;
	position:relative;
}
#voice .comment .fukidashi:after{
	content:"";
	position:absolute;
	top:100%;
	left:20px;
	height:0;
	width:0;
	border:10px solid transparent;
	border-top:10px solid #0e5ee1;
}
#voice .message{
	margin:10px;
}
#voice .note {
  font-size: 16px;
  color: #222; 
  padding:2rem 1rem 3rem;
  background-image: linear-gradient( rgba(152,196,255,.3) .1em, transparent .1em );
  background-size: auto 2em;  /*line-heightと一致させる*/
  line-height: 2rem; /*background-sizeと一致させる*/
  overflow: hidden;
}

.note  > p { margin: 0 0 2rem; }

.note  > p:first-letter { margin-left: 1rem; }
/*------------------------------------------------------
                 
		#store
				 
------------------------------------------------------*/
#store .box{
	padding:15px;
}
#store .storebox .shoptitle{
	border-bottom:2px dotted #fcec91;
	margin-bottom:30px;

  background-image: -moz-linear-gradient( 90deg, rgb(248,246,246) 0%, rgb(255,255,255) 100%);
  background-image: -webkit-linear-gradient( 90deg, rgb(248,246,246) 0%, rgb(255,255,255) 100%);
  background-image: -ms-linear-gradient( 90deg, rgb(248,246,246) 0%, rgb(255,255,255) 100%);
  box-shadow: 0px 3px 7px 0px rgba(0, 0, 0, 0.35);
padding:10px 0 0 10px;

}
#store .storebox h3{
	font-size:1.4em;
	
	display:inline-block;
	padding:5px 10px;
	text-align: center;
	
}
#store  .icon-home{
	color:#ff6600;
}
#store .storebox address{
	font-size:0.9em;
	color:#666;
}
@media only screen and (max-width: 767px) {
	#store .storebox h3{
font-size:1.2em;
	
}
	#store .storebox address{
	font-size:0.8em;
}
	
}
#store .storebox{
	border:2px solid #ddd;
	box-shadow: 0px 3px 7px 0px rgba(204, 204, 204, 0.35);
	padding:15px;
	height:100%;
	border-radius: 10px;        /* CSS3草案 */  
	-webkit-border-radius: 10px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 10px;   /* Firefox用 */
	background-color:#fff;
}
#store dl{
	text-align: left;
	margin:0 0 30px;
}
#store dt{
	margin:0;
	border-bottom:1px dotted #fcec91;
	padding:5px 0;
	font-size:0.8em;
	
}
#store dd{
	margin:0;
	border-bottom:1px dotted #fcec91;
	padding:5px 0;
	font-size:0.9em;
}
#store .fukidashi{
	color:#fff;
  background-color: rgb(14, 94, 225);
	border-radius: 10px;        /* CSS3草案 */  
	-webkit-border-radius: 10px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 10px;   /* Firefox用 */
 	font-size:0.8em;
	display:inline-block;
	padding:5px 10px;
	position:relative;
}
#store .fukidashi:after{
	content:"";
	position:absolute;
	top:98%;
	left:20px;
	height:0;
	width:0;
	border:10px solid transparent;
	border-top:10px solid #0e5ee1;
}

#store .fukidashi2{
	color:#fff;
  background-color: #ff6600;
	border-radius: 10px;        /* CSS3草案 */  
	-webkit-border-radius: 10px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 10px;   /* Firefox用 */
 	font-size:0.8em;
	display:inline-block;
	padding:5px 10px;
	position:relative;
}
#store .fukidashi2:after{
	content:"";
	position:absolute;
	top:98%;
	left:20px;
	height:0;
	width:0;
	border:10px solid transparent;
	border-top:10px solid #ff6600;
}
@media only screen and (max-width: 767px) {
	#store .fukidashi2{
		margin-top:15px;
	}
	
}
#store .mapbtn{
	margin-top:15px;
}
/*------------------------------------------------------
                 
		#staff
				 
------------------------------------------------------*/
#staff{

}
#staff h2{
	background-color:#3ec771;
}
#staff .box{
	background-color: #fff;
	margin:10px 0;
	padding:10px;
	border-bottom:1px solid #ddd;
}
#staff h3{
	text-align:center;
	margin:0 0 15px;
	padding:0 0 5px!important;
	font-weight:bold;
	line-height:1.4;
	font-size:1.4em;
	border-bottom:1px dotted #ccc;
}
@media only screen and (max-width: 767px) {
	#staff h3{
		font-size:1.1em;
	}	
}
#staff .setumei{
	padding:10px;
}
#staff .txt01{
	margin:0;
	padding:0 5px;
	font-size:0.8em;
	text-align:center;
}
#staff .box .content{
	text-align:left;
	padding:10px 0;
	font-size:0.9em;
	
}
#staff .box .content p{
/*	margin:0!important;
	padding:0 0 15px!important;*/
	padding:5px 0 0!important;
	font-size:1.2em;
	color:#c00;
}
#staff .box figure{
	padding-left:0;
	padding-right:0;
	margin:0 auto 5px;
}
#staff .box figure img{
	margin:auto;
}
#staff dl{
	margin:0;
}
#staff dt,#staff dd{
	font-size:0.9em;
	margin:0;
}
#staff dt{
	float:left;
	width:20%;
}
#staff dd{
	float:right;
	width:80%;
}
#staff .icon-comment-1{
	font-size:2.0em;
	color:#ddd;
	float:left;
}
/*------------------------------------------------------
                 
		#qa
				 
------------------------------------------------------*/
#qa{

}
#qa h2{
	background-color:#3ec771;
}
/* template07 */

#qa .setumei{
	padding:10px;
}
#qa .box{
	background-color: #fff;
	padding:10px 10px;
	margin-top:15px;
	border-bottom:1px solid #ddd;
}
#qa h3{
	/*margin:0!important;
	padding:15px 15px 15px!important;*/
	font-weight:bold;
	line-height:1.4;
	margin:0 0 0 0;
	border-bottom:0;
	font-size:1.4em;
	color:#c00;
	font-family: "sawarabi-gothic", sans-serif;
}
@media only screen and (max-width: 767px) {
	#qa h3{
		font-size:1.0em;
	}	
}
#qa .sbox{
	border-bottom:1px dotted #fff;
}
#qa .content{
	margin:0;
	text-align:left;
}

#qa .txt01{
	font-size:0.7em!important;
}
#qa figure{
	margin-bottom:0;
}


/*------------------------------------------------------
                 
		.flyer（今日のチラシ）
				 
------------------------------------------------------*/

#flyer{
}

#flyer .flyerbox{
	border:2px solid #ddd;
	border-radius: 10px;        /* CSS3草案 */  
	-webkit-border-radius: 10px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 10px;   /* Firefox用 */
	background-color:#fff;
	padding-top:50px;
	margin:30px auto 0;
}
#flyer .flyerbox img{
	height:250px;
	object-fit: contain;
	margin:0 auto 20px;
}
#flyer .flyerbox .titlebox{
	margin:0 15px 0;
	border-bottom: 1px solid #ddd;
	padding-bottom:15px;
}
#flyer .flyerbox a{
	text-decoration: none;
}
#flyer .flyerbox p{
	color:#333;
}
#flyer .flyerbox .titlebox time{
	color:dodgerblue;
	margin-bottom: 10px;
	padding-bottom:15px;
	font-size:0.9rem;
}
#flyer .flyerbox .titlebox h3{
	color:dodgerblue;
	margin-top: 10px;
}
#flyer .flyerbox .content{
	padding-top:10px;
	margin:0 15px 15px;
}
#flyer .flyerbox .content p{
	padding-top:10px;
	margin-bottom: 0;
}
/*------------------------------------------------------
                 
		.common-template（共通テンプレート）
				 
------------------------------------------------------*/

/* common */
.common h2{
	margin-top:0;
}
.common{
	text-align:left;
	color:#fff;
	background-image:url(../img/contentsback.jpg);
	background-repeat:repeat;
}
.common h3{
	color:#333;
}
.common .table{
	margin:15px 0;
	padding:0;
	/*margin:0!important;
	padding:0!important;*/
}
.txt01{
		font-size:0.9em;
	}
@media only screen and (max-width: 767px) {
	.common .table{
		font-size:0.9em;
	}	
	.txt01{
		font-size:0.8em;
	}
}
.common .table th{

}
/* template01 */
.common-template01 .box{
	margin-top:20px;
	margin-bottom:20px;
	border-bottom:1px dotted #fff;
}
.common-template01 h3{
	text-align:center;
	font-size:1.8em;
	font-weight:bold;
	line-height:1.4;
	color:#fff;
	margin-top:40px;
	margin-bottom:40px;
}
@media only screen and (max-width: 767px) {
	.common-template01 h3{
		font-size:1.2em;
	}	
}
.common-template01 .content{
	/*margin:10px 0;
	padding:0 15px;*/
	text-align:left;
}
.common-template01 figure{
	margin-bottom:15px;
	/*margin:0!important;
	padding:10px 10px 10px!important;*/
}
.common-template01 figure img{
	margin-bottom:2px;
}
.common-template01 figcaption{
	/*margin:0!important;
	padding:10px 0 15px!important;*/
	font-size:0.8em;
	padding-top:10px;
}
.common-template01 p{
	/*margin:0!important;
	padding:0 0 15px!important;*/
	padding-bottom:15px;
}
.common-template01 .txt01{
	text-align:center;
	/*margin:10px 0!important;
	padding:0!important;*/
	margin-top:0;
	padding-bottom:0;
}
.common-template01 time{
	width:100%;
	text-align:center;
	padding-top:10px;
	padding-bottom:15px;
	margin-top:0;
	margin-bottom:10px;
	font-size:0.8em;
}


/* template02 */
.common-template02{
	/*padding:10px 15px;*/
}
.common-template02 .box{
	margin-top:20px;
	margin-bottom:20px;
}
.common-template02 .box h3{
	text-align:center;
	font-weight:bold;
	line-height:1.4;
	margin:30px 0 20px 0;
	font-size:1.8em;
	color:#fff;
}
.common-template02#about .box h3{
	text-align:left;
}
@media only screen and (max-width: 767px) {
	.common-template02 .box h3{
		font-size:1.4em;
	}	
}

.common-template02 .box .content{
	text-align:left;
	padding:0 15px 15px;
	margin-bottom:10px;
}
.common-template02 .box .content p{
/*	margin:0!important;
	padding:0 0 15px!important;*/
	padding:10px 0 0;
}
.common-template02 .box .txt01{
	text-align:center;
	margin:0;
	padding:5px 0 15px!important;
}
.common-template02 .box time{
	text-align:center!important;
	padding-top:10px;
	padding-bottom:10px;
}
.common-template02 .box figure{
	margin:auto;
	padding:10px;
}
.common-template02 .box figure img{
	width:100%;
}
.common-template02 .box .sfigure-box{
	margin-bottom:30px;
}
.common-template02 .box figcaption{
	font-size:0.8em;
}
.common-template02 .box time{
	font-size:0.8em;
}
/* template03 */
.common-template03 .box{

}
.common-template03 h3{
	text-align:center;
	/*margin:0!important;
	padding:15px 15px 15px!important;*/
	font-weight:bold;
	line-height:1.4;
	margin:30px 0 20px 0;
	border-bottom:0;
	color:#fff;
	font-size:1.8em;
}
@media only screen and (max-width: 767px) {
	.common-template03 h3{
		font-size:1.0em;
	}	
}
.common-template03 .sbox{
	/*padding:5px!important;
	margin:0!important;*/
	padding-top:20px;
	padding-bottom:20px;
	margin-top:0;
	border-bottom:1px dotted #fff;
}
.common-template03 .content{
	margin:0;
	text-align:left;
}

.common-template03 time{
	text-align:right;
	padding-top:10px;
	font-size:0.8em;
	padding-right:20px;
}
.common-template03 .txt01{
	font-size:0.7em!important;
}
.common-template03 figure{
	margin:0 5px;
	padding:0;
}
.common-template03 .slider01-6{
	margin:0!important;
	padding:0 -20px!important;
}
.common-template03 .figure-s{
	margin-right:5px;
	margin-left:5px;
	padding:0;
}
.common-template03 .figure-s figcaption{
	font-size:0.8em;
}
/* template04 */
.common-template04 .box{
	padding:15px;
	margin-top:10px;
	border:5px solid #D7FF99;
	
	
}
.common-template04 h3{
	text-align:left;
	margin:10px 0 0;
	padding:0;
	font-size:1.2em;
	background-color:#FFF;
	border-bottom:2px dotted #F99;
	opacity:0.8;
	border-bottom:4px solid #E40A2F;
}
.common-template04 h3 a{
	color:#000;
	display:block;
	padding:10px 10px;
}
.common-template04 h3 a:link{
	text-decoration:none;
}

.common-template04 h3 a:hover{
	color:#C00;
}

@media only screen and (max-width: 767px) {
	.common-template04 h3{
	font-size:1.0em;
	}	
}
.common-template04 .sbox{
	padding:10px 15px!important;
	background-color:#FFF7F7;
	margin-top:10px;
	border-radius: 10px;        /* CSS3草案 */  
	-webkit-border-radius: 10px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 10px;   /* Firefox用 */
	
}
.common-template04 .content{
	text-align:left;
}
.common-template04 figure{
	padding:0 10px 10px;
}
.common-template04 figcaption{
	font-size:0.8em;
	padding-top:5px;
}
.common-template04 time{
	width:100%;
	text-align:right;
	padding-top:10px;
	font-size:0.8em;
}
.common-template04 .txt01{
	font-size:0.8em!important;
	color:#FF0!important;
}
/* template05 */
.common-template05 .box{
	padding:20px 0 20px 0;
	border-bottom:1px dotted #fff;
	
}
.common-template05 h3{
	margin:5px 0 0!important;
	padding:5px 10px 15px!important;
	text-align:center;
	font-weight:bold;
	color:#fff;
}
.common-template05#about h3{
	text-align:left;
	font-size:1.2em;
}
@media only screen and (max-width: 767px) {
	.common-template05 h3{
		font-size:1.4em;
	}	
}

.common-template05 .content{
	margin:10px 0;
	padding:0 10px;
	text-align:left;
}
.common-template05 figure{
	margin:0 auto;
	width:70%;
}
@media only screen and (max-width: 767px) {
	.common-template05 figure{
		width:50%;
	}	
}
.common-template05 figcaption{
	margin:0!important;
	padding:10px 0 15px!important;
	font-size:0.8em;
}
.common-template05 p{
	margin:0!important;
	padding:0 0 15px!important;
	font-size:0.9em;
}
.common-template05 .txt01{
	text-align:center!important;
	margin:0 0!important;
	padding:10px 0 0!important;
}
@media only screen and (max-width: 767px) {
	.common-template05 .txt01{
	font-size:0.8em;
	}	
}
.common-template05 time{
	text-align:center!important;
	padding:10px 0 5px;
	font-size:0.8em;
}
/* template06 */
.common-template06 .box{
	margin:5px 0 15px;
	padding:10px 15px;
	
}
.common-template06 h3{
	text-align:left;
	margin:0!important;
	padding:10px 15px 5px!important;
	font-weight:bold;
	line-height:1.4;
	font-size:1.2em;
	
}
.common-template06#about h3{
	text-align:left;
}
@media only screen and (max-width: 767px) {
	.common-template06 h3{
		font-size:1.1em;
	}	
}
.common-template06 .content{
	margin:0;
	padding:0 0;
	text-align:left;
}
.common-template06 figure{
	margin-right:10px;
	margin-bottom:10px;
	margin-top:10px;
	padding:0;
}
.common-template06 figcaption{
	margin:0!important;
	padding:10px 0 15px!important;
	font-size:0.8em;
}
.common-template06 p{
	margin:0!important;
	padding:0 0 15px!important;
}
.common-template06 .txt01{
	text-align:center;
	margin:10px 0!important;
	padding:0!important;
	font-size:0.8em;
}
.common-template06 time{
	width:100%;
	text-align:right;
	padding-bottom:5px;
	font-size:0.8em;
}


/* template07 */

.common-template07{
	/*padding:10px 15px;*/
}

.common-template07 .box{
	padding:0;
	padding-bottom:30px!important;
	margin:10px -10px 0!important;
	box-sizing:border-box!important;
	
}
.common-template07 h3{
	text-align:left;
	margin:0!important;
	padding:20px 15px 5px!important;
	font-weight:bold;
	line-height:1.4;
	font-size:1.4em;
	border-bottom:4px solid #E40A2F;

}
@media only screen and (max-width: 767px) {
	.common-template07 h3{
		font-size:1.1em;
	}	
}
.common-template07 .txt01{
	text-align:left;
	margin:0;
	padding:0 15px;
	font-size:0.8em;
}
.common-template07 .box .content{
	text-align:left;
	padding:0 30px 15px;
}
.common-template07 .box .content p{
/*	margin:0!important;
	padding:0 0 15px!important;*/
	padding:15px 0 0;
}

.common-template07 .box time{
	padding-top:10px;
	padding-bottom:10px;
	padding-right:30px;
	text-align:right;
	font-size:0.8em;
}
.common-template07 .box figure{
	/*margin:0!important;
	padding:10px 0 10px!important;*/
	padding-left:0;
	padding-right:0;
	margin-bottom:15px;
	padding-top:20px;
	margin:0;
}

/* template08 */

.common-template08 .box{
	margin-top:10px;
	margin-bottom:20px;
	padding:20px 20px 20px;
	
}

.common-template08 h3{
	text-align:center;
	/*margin:0!important;
	padding:15px 15px 15px!important;*/
	font-weight:bold;
	line-height:1.4;
	margin:0 0 10px 0;
	padding-top:0px;
	border-bottom:4px solid #E40A2F;
}
.common-template08#about h3{
	text-align:left;
}
@media only screen and (max-width: 767px) {
	.common-template08 h3{
		font-size:1.1em;
	}	
}
.common-template08 .content{
	/*margin:10px 0;
	padding:0 15px;*/
	text-align:left;
}

.common-template08 p{
	/*margin:0!important;
	padding:0 0 15px!important;*/
	padding-bottom:15px;
}


.common-template08 .txt01{
	text-align:center;
	/*margin:10px 0!important;
	padding:0!important;*/
	margin-top:0;
	padding-bottom:0;
}

.common-template08 time{
	width:100%;
	text-align:center!important;
	padding-top:10px;
	padding-bottom:15px;
	font-size:0.8em;
	margin:0 auto 10px;
	width:100%;
}
.common-template08 .box ul{
	margin:0;
	padding:0;
}
.common-template08 .box li{
	margin:0;
	padding:0;
	list-style:none;
}

.common-template08 .thumbs1{
  width: 100%;
  height: 100%;
  position: relative; 
  margin-bottom:5px;
}
.common-template08 .thumbs1::before{
  content: "";
  display: block;
  padding-top:70%;/*比率*/
}
.common-template08 .thumbs1 a{
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.common-template08 .thumbs1 img{
  width: 100%;
  height: auto;
  line-height: 0;
  position: absolute;
  /*bottom: 0;*/
}
.common-template08 .figcap{
	margin-top:10px;
	font-size:1.0em;
}
.common-template08 .box .figure-s-box{
	margin-top:20px;
}
.common-template08 .thumbs2{
  width: 100%;
  height: 100%;
  position: relative; 
}
.common-template08 .thumbs2::before{
  content: "";
  display: block;
  padding-top:80%;/*比率*/
}
.common-template08 .thumbs2 a{
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.common-template08 .thumbs img{
  width: 100%;
  height: auto;
  line-height: 0;
  position: absolute;
  /*bottom: 0;*/
}

/* template09 */

/* template10 */
/*------------------------------------------------------
                 
				#footer
				 
------------------------------------------------------*/
#footback{	
	padding:20px 0;
	color:#fff;
	font-weight:bold;
	
  
  background-image: -moz-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  background-image: -webkit-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  background-image: -ms-linear-gradient( 90deg, rgb(46,122,236) 0%, rgb(5,87,222) 100%);
  
}

  
}

}
#footback .name{
	text-align:left;
	font-size:1.0em;
}
#footback address{
	text-align:left;
	font-size:0.8em;
}
#footback address a{
	color:#c00;
}
#copyright{
	font-size:0.8em;
	padding:20px 0;
	color:#fff;
	text-align:center;
	background-color:#1545a2;
}
#footerlink{
	margin:0;
	padding:10px 0 10px 0;
	background-color:#FFF;
}
#footerlink ul{
	margin:0;
	padding:0;
}
#footerlink li{
	float:left;	
	list-style:none;
	border-radius: 10px;        /* CSS3草案 */  
	-webkit-border-radius: 10px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 10px;   /* Firefox用 */
	margin:5px;
}
#footerlink li a{
	text-decoration:none;
	font-size:0.8em;
	display:block;
	padding:5px 10px;
	color:#000;
}
#footerlink i{
	color:#ffcc00;
}

#footerlink li a:hover{
	text-decoration:none;
}
/*------------------------------------------------------
                 
				#その他
				 
------------------------------------------------------*/
/* googlemap レスポンシブ*/
.gmap {
position: relative;
padding-bottom: 56.25%;
padding-top: 30px;
height: 0;
overflow: hidden;
}
 
.gmap iframe,
.gmap object,
.gmap embed {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}
/*------------------------------------------------------
                 
		メニューボタンのCSSはここ
				 
------------------------------------------------------*/
/*ボタン*/
a.btn-common{
	display: inline-block;
	position: relative;
	text-decoration: none;
	/* font-weight: bold;*/
	text-align: center;
	-webkit-border-radius: 5px; 
	-moz-border-radius: 5px;
	border-radius: 5px;
	behavior: url(/PIE.htc);
	color:#fff;
	padding:5px 10px;
	font-weight:bold;
	background-color: #c00;
	border:1px solid #fff;
}
a.btn-common:hover {
		background-color:#CC0A2D ;
}
a.btn-common2{
	display: inline-block;
	position: relative;
	text-decoration: none;
	/* font-weight: bold;*/
	text-align: center;
	-webkit-border-radius: 5px; 
	-moz-border-radius: 5px;
	border-radius: 5px;
	behavior: url(/PIE.htc);
	color:#fff;
	padding:5px 10px;
	font-weight:bold;
	background-color: #ee7800;
	border:1px solid #fff;
}
a.btn-common2:hover {
		background-color:#ee7800 ;
}
/*メニューボタン*/
a.menubtn,
a.menubtn:hover,
a.menubtn:visited{
	box-shadow: 0 2px 2px rgba(0,0,0,0.1);
	font-weight:bold;
	border-top:1px solid #eee;
	border-bottom:1px solid #eee;
	background-color: rgba(168,18,42,1.0);
	background-color:#c00;
	color:#fff;
}
a.menubtn:hover {
	background-color:#CC0A2D;
}
.footnavi a.menubtn,
.footnavi a.menubtn:hover,
.footnavi a.menubtn:visited{
	box-shadow: 0 2px 2px rgba(0,0,0,0.1);
	font-weight:bold;
	border-top:1px solid #eee;
	border-bottom:1px solid #eee;
	background-color: rgba(0,51,0,0.5);
	color:#fff;
}
.footnavi a.menubtn:hover {
	background-color: rgba(0,51,0,0.3);
}
/*------------------------------------------------------
                 
		ナビ
				 
------------------------------------------------------*/
#mainNav {
	margin:5px 2px;
	padding:0;
	background-color:#003399;
	font-size:0.8em;
	color:#003399;
}
#mainNav .navbar-toggler {/*スマホ・タブレットの「MENU」ボタンの色*/
    font-size: 12px;
    right: 0;
    padding: 20px 13px;
    text-transform: uppercase;
    color: #fff;
    border: 0;
    background-color: #003399;
}
#mainNav a{
	color:#fff;
	background-color:#003399;
	padding:10px 5px;
	display:block;
}
#mainNav .container {
	background-color:#333;
    padding: 0; }
	
#mainNav .container .navbar-brand:hover, #mainNav .container .navbar-brand:focus, #mainNav .container .navbar-brand:active, #mainNav .container .navbar-brand.active {
        color: #fff; }
		
#mainNav .container .navbar-nav .nav-item .nav-link {
      font-size: 75%;
      font-weight: 400;
      letter-spacing: 1px;
      color: white;
}
@media only screen and (max-width: 767px) {
	#mainNav .container .navbar-nav .nav-item .nav-link{
	font-size: 85%;
	}	
}
#mainNav .container .navbar-nav .nav-item .nav-link:hover, #mainNav .container .navbar-nav .nav-item .nav-link.active {
	      
}
@media only screen and (max-width: 767px) {
	#mainNav .navbar-brand {
	font-size:0.9em;
	}
	#mainNav img{
	width:50px;
}	
}
@media (min-width: 992px) {
	header nav ul{
		width:auto;		
		margin:0;
		padding:0;
		width:100%;
	}
	header nav li{
		float:left;
		position:relative;
		text-align:center;
		width:12.5%;
	}
	header nav li a{
		position:absolute;
		vertical-align:middle;
		margin:0 2px;
		font-size:0.8em;
		color:#fff!important;
		background-color:#003399;
		padding:10px 5px!important;
	}

}

.flexH [class^=col] {
  display: flex;
  flex-direction: column;
}

.flexH [class^=col] div {
  flex-grow: 1
}