@charset "utf-8";
/* CSS Document */


/* bootstrap.css基本の打消し（同じclass名での書き換え）
---------------------------------------------------- */
body{ margin:0px; padding:0px;}
h1,h2,h3,h4,h5,h6{ margin:0px; padding:0px; font-weight:normal; clear:both}
p{ margin:0px; padding:0px}

.navbar {
  margin-bottom:0px;
  border:none;
}
.table-striped > tbody > tr:nth-of-type(odd) { background-color: #efefef;}
.table{ margin-bottom:30px}
.table th{ width:30%}

@media (min-width: 768px) {.btn-group-vertical a{ padding-top:15px;padding-bottom:15px}}

img.img-fluid {display: block;}


/* 全体構造
---------------------------------------------------- */
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, dialog, figure, footer, header,
hgroup, menu, nav, section,
time, mark, audio, video {
	margin:0;
	padding:0;
	border:0;
	outline:0;
	font-size:100%;
	vertical-align:baseline;
	background:transparent;
}

.clearfix:after {
  content: ".";  /* 新しい要素を作る */
  display: block;  /* ブロックレベル要素に */
  clear: both;
  height: 0;
  visibility: hidden;
}
.clearfix {
    zoom:1;/*for IE 5.5-7*/
	overflow:hidden;
}
* html .clearfix {
  height: 1px;
  /*\*//*/
  height: auto;
  overflow: hidden;
  /**/
}

.clear{clear:both;}

img{border:0;vertical-align:bottom;}

a {
	outline:none;
	margin:0;
	padding:0;
	border:0;
	font-size:100%;
	vertical-align:baseline;
	background:transparent;
}

hr {
    display:block;
    height:1px;
    border-top:1px dotted #333;
    margin:0;
    padding:0;
	margin-bottom:20px
}

body{
	font-size:85%;/* 基本のフォントサイズ */
	line-height:185%;/* 基本の行間 */
	font-family:FontAwesome, "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	color:#272727;
	letter-spacing: 0.05em;
}

.en{ font-family: 'Julius Sans One', sans-serif;}
.en2{ font-family: 'Roboto', sans-serif;}
sup {font-size: 80%;}

header{
	font-family: 'Noto Sans JP', sans-serif;
}


/* link
---------------------------------------------------- */
a:link,a:visited,a:hover,a:active{text-decoration:none; color:#272727; }
/*.link_kon a:link,a:visited,a:hover,a:active{text-decoration:none; color:#f58599}*/

/* header
---------------------------------------------------- */
header{
	width: 100%;
	top: 0;
	z-index: 100;
	padding-top: 10px;
	padding-bottom: 10px;
	background: #fff;
}

h1 {float: left;}
h1 img{width: 220px;}


.gengo ul{
	display: table;
}
.gengo li{
	display: table-cell;
	vertical-align: middle;
	border-collapse: collapse;
	line-height: 1.4em;
	font-size: 80%;
}
.gengo a:link,
.gengo a:visited{
	padding: 5px;
	background-color: #e0e0e0;
	border-right: 1px solid #ccc;
}
.gengo li:last-child a{
	border-right: none;
}
.gengo a:hover,
.gengo .navi-on a{
	background-color: #313131;
	color: #fff;
}

@media only screen and (max-width: 767px) {
	header{
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
	}
}
@media print, screen and (min-width: 576px) {
}
@media print, screen and (min-width: 768px) {
	header{
		padding-top: 0;
		padding-bottom: 0;
	}
	h1 img{width: 250px; padding-top: 0; margin-top: 25px;}
	.head_right {padding-right: 0;}
	.head_mail{
		width: 130px;
		float: right;
	}
	.head_mail a:link,
	.head_mail a:visited{
		padding: 20px 10px;
		text-align: center;
		background-color: #404040;
		color: #fff;
		display: block;
	}
	.head_mail img{
		display: block;
		margin: 0 auto;
		padding-bottom: 5px;
		max-width: 36px;
		width: 25px;
	}
	
	.head_box{
		float: right;
		margin-right: 20px;
		margin-top: 10px;
	}
	
	.head_time{
		float: right;
		font-size: 70%;
		line-height: 1.4em;
		font-family: 'Roboto', sans-serif;
	}
	.head_time .tel{
		font-size: 120%;
		line-height: 1.4em;
	}
	.head_time .tel .num{
		font-size: 150%;
	}
	
	.gengo{
		float: right;
		margin-left: 10px;
		margin-top: 10px;
	}
}
@media print, screen and (min-width: 992px) {
	h1 img{width: 300px; margin-top: 25px;}
	
	.head_mail a:link,
	.head_mail a:visited{
		padding: 28px 10px;
	}
	.head_mail img{
		width: 30px;
	}
	
	.head_box{
		margin-right: 20px;
		margin-top: 20px;
	}
	
	.head_time{
		font-size: 80%;
	}
	.head_time .tel{
		font-size: 130%;
		line-height: 1.4em;
	}
	.head_time .tel .num{
		font-size: 150%;
	}
	
	.gengo{
		float: right;
		margin-left: 10px;
		margin-top: 10px;
	}
	.gengo li{
		font-size: 90%;
	}
	.gengo a:link,
	.gengo a:visited{
		padding: 5px 10px;
	}
}
@media print, screen and (min-width: 1200px) {
	h1 img{width: 377px;}
	.head_mail img{
		width: 36px;
	}
	.head_mail a:link,
	.head_mail a:visited{
		padding: 33px 10px;
	}
	.head_time{
		float: right;
		font-size: 90%;
	}
	.head_time .tel{
		font-size: 130%;
	}
	.head_time .tel .num{
		font-size: 160%;
	}
}





/* nav
---------------------------------------------------- */
.menu {font-size: 85%;}
.menu > ul > li a {color: #272727!important; text-align: center!important; padding: 15px 5px!important;}
.menu > ul > li a:hover,
.menu li.navi-on a{
	opacity: 1;
	background-color: #efefef;
}
.menu > ul > li { border-bottom: 1px solid #ccc !important; width: 50%!important; float: left!important;}
.menu > ul > li > ul {font-size: 90%;}
.menu > ul > li > ul > li {list-style: none;}
.menu > ul > li > ul > li a {text-align: left!important;}
.menu-container { margin-top: -33px!important;}

@media only screen and (max-width: 767px) {
	.menu-dropdown-icon > a {margin-left: 30px;}
	.menu > ul > li.gengo_sp{
		width: 100%!important; float: none!important;
	}
	.menu > ul > li.gengo_sp .gengo ul{width: 100%!important; table-layout: fixed;}
	.menu > ul > li.gengo_sp .navi-on a{
		background-color: #313131!important;
		color: #fff!important;
	}

}
@media print, screen and (min-width: 576px) {
	.menu {font-size: 100%;}
}
@media print, screen and (min-width: 768px) {
	.menu {float: right; margin-top: 17px; font-size: 88%;}
    .menu-container { margin-top: 0!important;}
	.menu .show-on-mobile {padding-top:10px!important;}
	.menu > ul {width: auto!important; float: right;}
	.menu > ul i {padding-left: 10px;}
	.menu > ul > li {width: auto!important; float: none!important;}
	.menu > ul > li a{
		padding: 0 0 15px 0!important;
		text-align: center!important;
		margin-left: 10px;
	}
	.menu > ul > li a:hover,
	.menu li.navi-on a{
		color: #272727!important;
		background: url(../images/navi-on.png) repeat-x center bottom;
	}
	.menu > ul > li { border-bottom: none !important;}
	.menu > ul > li > ul {font-size: 100%;}
	.menu > ul > li > ul.normal-sub > li {margin: 4px 0!important;}
	
	.menu > ul > li i {vertical-align: middle;}
}
@media print, screen and (min-width: 992px) {
	.menu {font-size: 100%;}
	.menu .show-on-mobile {padding-top: 0!important;}
	.menu-dropdown-icon > a {margin-left: 0;}
	.menu > ul > li a{ margin-left: 15px;}
}
@media print, screen and (min-width: 1200px) {
	.menu {margin-top: 25px;}
	.menu > ul > li a{ margin-left: 22px;}
}
@media print, screen and (min-width: 1600px) {
	.menu {font-size: 110%;}
}

.osu1 {position: relative; z-index: 1;}
.osu2 {position: relative; z-index: 2;}
.osu3 {position: relative; z-index: 3;}

.f-right {float: right;}


/*ナビ固定*/
.cb-header {
	position: fixed; /* ヘッダーバーを固定 */
	top: -145px;
	left: 0;
	width: 100%;
	z-index: 1000;
	background-color: #fff;
	box-shadow: 0px 5px 5px -5px rgba(0,0,0,0.3);
}
@media print, screen and (min-width: 768px) {
	.cb-header .menu {margin-top: 0;}
	.cb-header .menu .otoiawase a:link,
	.cb-header .menu .otoiawase a:visited{
		background-color: #404040;
		color: #fff!important;
		padding: 20px 10px!important;
	}
	.cb-header .menu > ul > li a{
		padding: 0 0 20px 0!important;
	}
	
	.cb-header h1 img{ margin-top: 10px;}
}
@media print, screen and (min-width: 992px) {
	.cb-header .menu .otoiawase a:link,
	.cb-header .menu .otoiawase a:visited{
		padding: 27px 10px!important;
	}
	.cb-header .menu > ul > li a{
		padding: 0 0 27px 0!important;
	}
}
@media print, screen and (min-width: 1200px) {
	.cb-header h1 img{width: 300px;}
}

/* midashi
---------------------------------------------------- */
.fs60 {font-size:60%;}
.fs70 {font-size:70%;}
.fs75 {font-size:75%;}
.fs80 {font-size:80%; line-height: 1.6em;}
.fs85 {font-size:85%;}
.fs90 {font-size:90%;}
.fs110 {font-size:110%; line-height:1.4em;}
.fs120 {font-size:120%;}
.fs140 {font-size:130%; line-height:1.4em;}
.fs160 {font-size:160%;}
.fs180 {font-size:180%;}

.fs100_sm90_md90_lg100 {font-size: 100%;}
@media print, screen and (min-width: 768px) {
	.fs100_sm90_md90_lg100 {font-size: 90%;}
}
@media print, screen and (min-width: 1200px){
	.fs100_sm90_md90_lg100 {font-size: 100%;}
}

@media print, screen and (min-width: 768px){
	.fs90_smmd{ font-size: 90%;}
}
@media print, screen and (min-width: 1200px){
	.fs90_smmd{ font-size: 100%;}
}

.fs60_sm80_md70{font-size: 80%;}
@media print, screen and (min-width: 992px){
	.fs60_sm80_md70{font-size: 70%;}
}
@media print, screen and (min-width: 1200px) {
	.fs60_sm80_md70{font-size: 60%;}
}

.fs160_sp140 {font-size: 140%;}
@media print, screen and (min-width: 768px) {
	.fs160_sp140 {font-size: 160%;}
}

.text_large{font-size: 100%; line-height: 1.8em;}
.text_large2{font-size: 100%; line-height: 1.8em;}
@media print, screen and (min-width: 768px){
	.text_large2{font-size: 110%;line-height: 2.0em;}
}
@media print, screen and (min-width: 992px){
	.text_large{font-size: 105%;line-height: 2.0em;}
	.text_large2{font-size: 130%;}
}
@media print, screen and (min-width: 1200px){
	.text_large{font-size: 120%;}
	.text_large2{font-size: 150%;}
}


#midashi_h2{padding: 60px 0 10px 0; color: #fff; margin-top: 50px; }
#midashi_h2 h2{
	line-height: 1.4em;
	margin-bottom: 30px;
	text-align: center; 
	font-size: 170%;
	font-family: 'Noto Sans JP', sans-serif;
}
#midashi_h2 h2 span{
	display: block;
	font-size: 50%;
	font-family: 'Julius Sans One', sans-serif;
	line-height: 1.4em;
}
#midashi_h2.h2_news{background: url(../images/h2_news.jpg) no-repeat 50% 50% / cover;}
#midashi_h2.h2_service{background: url(../images/h2_service.jpg) no-repeat 50% 50% / cover;}
#midashi_h2.h2_works{background: url(../images/h2_works.jpg) no-repeat 50% 50% / cover;}
#midashi_h2.h2_recruit{background: url(../images/h2_recruit.jpg) no-repeat 50% 50% / cover;}
#midashi_h2.h2_company{background: url(../images/h2_company.jpg) no-repeat 50% 50% / cover;}
#midashi_h2.h2_contact{background: url(../images/h2_contact.jpg) no-repeat 50% 50% / cover;}

.pankuzu{ font-size: 85%;}
.pankuzu a:link,
.pankuzu a:visited{
	text-decoration: underline;
	color: #fff;
}
@media print, screen and (min-width: 576px){
	#midashi_h2 h2{ font-size: 200%;}
}
@media print, screen and (min-width: 768px){
	#midashi_h2{margin-top: 0; padding: 70px 0 10px 0;}
	#midashi_h2 h2{ margin-bottom: 40px; font-size: 250%;}
	.pankuzu{ text-align: right;}
}
@media print, screen and (min-width: 992px){
	#midashi_h2{ padding: 90px 0 10px 0;}
	#midashi_h2 h2{ margin-bottom: 60px; font-size: 300%;}
}
@media print, screen and (min-width: 1200px){
	#midashi_h2{padding: 130px 0 10px 0;}
	#midashi_h2 h2{ margin-bottom: 100px; font-size: 350%;}
}



/*--------------------------*/

.midashi1{
	font-family: 'Julius Sans One', sans-serif;
	/*
	background: url(../images/midashi_sen.png) no-repeat left top;
	padding-top: 20px;
	*/
	font-size: 200%;
	line-height: 1.4em;
}

.midashi1.tac{
	/*background: url(../images/midashi_sen.png) no-repeat center top;*/
}

.midashi2{
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 120%;
	line-height: 1.4em;
}

.midashi3{
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 120%;
	line-height: 1.4em;
	display: flex;
	align-items: center;
	margin-bottom: 10px;
}
.midashi3:after {
	content: "";
	flex-grow: 1;
	height: 1px;
	background: #444;
	display: block;
}
.midashi3:after {
	margin-left: .4em;
}

.midashi4{
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 400;
	font-size: 120%;
	line-height: 1.4em;
	margin-bottom: 10px;
	background: url(../images/midashi_sen2.png) no-repeat left bottom;
	padding-bottom: 10px;
}
.midashi4 .en{
	display: block;
	color: #c2c2c2;
	font-size: 70%;
}
.midashi4.sen_none{
	background: none;
	padding-bottom: 0;
}


.midashi5{
	font-family: 'Noto Sans JP', sans-serif;
	border-collapse: collapse;
	border-left: 4px solid #ccc;
	padding: 2px 0 2px 10px;
	line-height: 1.4em;
	font-size: 110%;
	margin-bottom: 10px;
}

@media print, screen and (min-width: 768px){
	.midashi1{ font-size: 250%;	}
	.midashi2{ font-size: 130%;}
}
@media print, screen and (min-width: 992px){
	.midashi1{ font-size: 300%;	}
	.midashi2{ font-size: 150%;}
}
@media print, screen and (min-width: 1200px){
	.midashi1{ font-size: 350%;	}
	.midashi2{ font-size: 170%;}
}



/*リンク・ボタン関係
---------------------------------------------------- */
a:hover{opacity:0.7;filter: alpha(opacity=70);/*transition: 0.5s;*/}

.btn{ padding-top:10px; padding-bottom:10px;}
@media print, screen and (min-width: 768px) {.btn{ padding:10px 25px;}}

.btn.dsb_sp {display: block;}
@media print, screen and (min-width: 768px) {.btn.dsb_sp {display: inline-block;}}


.btn1{
	font-size: 100%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
}
.btn1:link,
.btn1:visited{
	color:#fff;
	border-collapse: collapse;
	border: 1px solid #fff;
}
.btn1:hover{
	opacity: 1;
	background-color: #444;
}
.btn1 i{margin-left:60px;}
.btn1.btn {border-radius: 0; padding:15px 10px 15px 70px;}



.btn2{
	font-size: 100%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
}
.btn2:link,
.btn2:visited{
	color:#272727;
	text-decoration: underline;
}
.btn2:hover{
	opacity: 1;
	letter-spacing: 0.2em;
}
.btn2 i{margin-right:5px;}
.btn2.btn {border-radius: 0; padding: 0;}




.btn3{
	font-size: 100%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
}
.btn3:link,
.btn3:visited{
	color:#fff;
	background-color: #313131;
}
.btn3:hover{
	opacity: 1;
	background-color: #666;
}
.btn3 i{margin-left:60px;}
.btn3.btn {border-radius: 0; padding:15px 10px 15px 70px;}



.btn4{
	font-size: 100%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
}
.btn4:link,
.btn4:visited{
	color:#fff;
	background-color: #313131;
}
.btn4:hover{
	opacity: 1;
	background-color: #666;
}
.btn4 i{margin-right:10px;}
.btn4.btn {border-radius: 0; padding:15px 50px;}



.btn5{
	font-size: 100%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
}
.btn5:link,
.btn5:visited{
	color:#272727;
	border-collapse: collapse;
	border: 1px solid #272727;
}
.btn5:hover{
	opacity: 1;
	background-color: #444;
	color: #fff;
}
.btn5 i{margin-left:60px;}
.btn5.btn {border-radius: 0; padding:15px 10px 15px 70px;}




.btn6{
	font-size: 100%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
}
.btn6:link,
.btn6:visited{
	color:#272727;
	border-collapse: collapse;
	border: 1px solid #272727;
}
.btn6:hover{
	opacity: 1;
	letter-spacing: 0.2em;
}
.btn6 i{margin-right:5px;}
.btn6.btn {border-radius: 50px; padding: 5px 30px;}




.btn_detail{
	font-size: 80%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	font-family: 'Julius Sans One', sans-serif;
}
.btn_detail:link,
.btn_detail:visited{
	color:#808080;
}
.btn_detail:hover{
	opacity: 1;
	letter-spacing: 0.2em;
}
.btn_detail i{margin-right:5px;}
.btn_detail.btn {border-radius: 0; padding: 0;}






.pdf_list li{
	list-style: none;
	margin-bottom: 3px;
}
.pdf_list li a:link,
.pdf_list li a:visited{
	padding: 10px 15px;
	color: #ba1d5d;
	border-collapse: collapse;
	border: 1px solid #ba1d5d;
	display: block;
}
.pdf_list li i {margin-right: 5px;}
@media print, screen and (min-width: 768px){
	.pdf_list{
		margin-left: -1%;
		margin-right: -1%;
	}
	.pdf_list li{
		width: 31.3%;
		float: left;
		margin: 1%;
	}
}


a.text_link {text-decoration: underline; color: #272727;}
@media only screen and (max-width: 767px) {
	.text_link_sp {text-decoration: underline; color: #272727;}
	.text_link_sp2 {text-decoration: underline!important; color: #fff;}
}

/* リスト
---------------------------------------------------- */
ol.list_ol{
	list-style:decimal;
	margin-left:25px;
}
ul.list_ul{
	list-style:disc;
	margin-left:20px;
}
@media print, screen and (min-width: 768px){
	.list_ul.dib_md{
		display: inline-block;
		margin-right: 20px;
	}
}

/* color
---------------------------------------------------- */
.red{color:#c33;}
.white{color:#fff;}
.black{color:#272727;}


/* hanyo
---------------------------------------------------- */
.large{font-size:130%;line-height:1.7em}
.small{font-size:80%;line-height:1.5em; font-weight:normal}
.lsn{ list-style:none;}
.ln{ line-height:normal}
.dsb{ display:block}
.dsi{ display:inline}

.kome {text-indent:-1em; margin-left:1em;}
.kome_num {text-indent:-2.8em; margin-left:2.8em;}


.tal{ text-align:left}
.tac{ text-align:center}
.tar{ text-align:right}
.bold {font-weight:bold;}

.tar_sptac {text-align:center;}
@media print, screen and (min-width: 768px) {
.tar_sptac {text-align:right;}
}

.tar_spsmtac {text-align:center;}
@media print, screen and (min-width: 992px) {
.tar_spsmtac {text-align:right;}
}

.tar_sptal {text-align:left;}
@media print, screen and (min-width: 768px){
.tar_sptal {text-align:right;}
}

.tal_lgtar {text-align:left;}
@media print, screen and (min-width: 1200px){
.tal_lgtar {text-align:right;}
}

.tal_smtac {text-align:center;}
@media print, screen and (min-width: 576px){
.tal_smtac {text-align:left;}
}

.tal_sptac {text-align:center;}
@media print, screen and (min-width: 768px){
.tal_sptac {text-align:left;}
}

.tal_spsmtac {text-align:center;}
@media print, screen and (min-width: 992px){
.tal_spsmtac {text-align:left;}
}

.tac_smtal {text-align:left;}
@media print, screen and (min-width: 576px){
.tac_smtal {text-align:center;}
}
.tac_sptal {text-align:left;}
@media print, screen and (min-width: 768px){
.tac_sptal {text-align:center;}
}

.img_c img{
	margin: 0 auto;
}

/* dl
---------------------------------------------------- */
/*
.dl_list dt{
	background: url(../images/dl_sen.jpg) no-repeat left center;
	padding: 3px 0 3px 25px;
}
.dl_list dd{
	line-height: 1.8em;
	padding-left: 25px;
}
*/

/* テーブル
---------------------------------------------------- */
table{border-spacing:0;border-collapse:separate;}
table ul.list_ul, table ol.list_ol{margin-left:20px;}

.nw {width:1%; white-space:nowrap;}
@media only screen and (max-width: 767px){
	.nw_sp {width:1%; white-space:nowrap;}
}
@media print, screen and (min-width: 768px){
	.nw_spnone {width:1%; white-space:nowrap;}
}

.table1{
	width:100%;
	border-collapse: collapse;
	border-top: 1px solid #ccc;
}
.table1 th{
	width:100%;
	padding:10px 10px 0 10px;
	display: block;
	color: #666;
}
.table1 td{
	width:100%;
	padding:0 10px 10px 10px;
	display: block;
	border-bottom: 1px solid #ccc;
}
@media print, screen and (min-width: 768px) {
	.table1 th{
		width:27%;
		padding:12px 12px;
		vertical-align:middle;
		text-align:center;
		display:table-cell;
		border-bottom: 1px solid #ccc;
		font-weight: normal;
		color: #272727;
	}
	.table1 td{
		width:100%;
		padding:12px 12px;
		display:table-cell;
		vertical-align: middle;
	}
}
@media print, screen and (min-width: 992px) {
	.table1 th{ width:30%;}
}
@media print, screen and (min-width: 1200px) {
	.table1 th{ width:27%;}
}



/* サイズ指定
---------------------------------------------------- */
.mb05{ margin-bottom:5px}
.mb10{ margin-bottom:10px}
.mb15{ margin-bottom:15px}
.mb20{ margin-bottom:20px}
.mb30{ margin-bottom:30px}
.mb40{ margin-bottom:40px}
.mb50{ margin-bottom:50px}
.mb60{ margin-bottom:60px}
.mb70{ margin-bottom:70px}
.mt10{ margin-top:10px}
.mt20{ margin-top:20px}
.mt40{ margin-top:40px}
.ml20{ margin-left:20px}
.ml05{ margin-left:5px}
.ml10{ margin-left:10px}

.pl40 {padding-left: 40px;}
.mt10{ margin-top:10px}

@media print, screen and (min-width: 768px) {.pr30_sp0 {padding-right: 30px;}}

.mb10_sp {margin-bottom:10px;}
@media print, screen and (min-width: 768px) {.mb10_sp {margin-bottom:0;}}

.mb15_sp {margin-bottom:15px;}
@media print, screen and (min-width: 768px) {.mb15_sp {margin-bottom:0;}}

.mb20_sp {margin-bottom:20px;}
@media print, screen and (min-width: 768px) {.mb20_sp {margin-bottom:0;}}

.mb30_sp {margin-bottom:30px;}
@media print, screen and (min-width: 768px) {.mb30_sp {margin-bottom:0;}}

.mb50_sp {margin-bottom:50px;}
@media print, screen and (min-width: 768px) {.mb50_sp {margin-bottom:0;}}

.mb50_lg0 {margin-bottom:50px;}
@media print, screen and (min-width: 992px) {.mb50_lg0 {margin-bottom:0;}}

.mb50_sp_sm0 {margin-bottom:50px;}
@media print, screen and (min-width: 576px) {.mb50_sp_sm0 {margin-bottom:0;}}

@media print, screen and (min-width: 768px) {.mb30_sp0 {margin-bottom:30px;}}

@media print, screen and (min-width: 992px) {.mb30_spsm0 {margin-bottom:0;}}

.mt10_sm20_md30 {margin-top: 10px;}
@media print, screen and (min-width: 768px) {.mt10_sm20_md30 {margin-top: 20px;}}
@media print, screen and (min-width: 992px) {.mt10_sm20_md30 {margin-top: 30px;}}

.mt20_sm40_md50 {margin-top: 20px;}
@media print, screen and (min-width: 768px) {.mt20_sm40_md50 {margin-top: 40px;}}
@media print, screen and (min-width: 992px) {.mt20_sm40_md50 {margin-top: 50px;}}

.mb10_md0 {margin-bottom: 10px;}
@media print, screen and (min-width: 992px) {.mb10_md0 {margin-bottom: 0;}}

.mb10_lg0 {margin-bottom: 10px;}
@media print, screen and (min-width: 1200px) {.mb10_lg0 {margin-bottom: 0;}}

.mb10_sm30 {margin-bottom: 10px;}
@media print, screen and (min-width: 768px) {.mb10_sm30 {margin-bottom: 30px;}}

.mb10_md20 {margin-bottom: 10px;}
@media print, screen and (min-width: 992px) {.mb10_md20 {margin-bottom: 20px;}}

@media print, screen and (min-width: 768px) {.mb20_sp0 {margin-bottom: 20px;}}

.mb20_md0 {margin-bottom: 20px;}
@media print, screen and (min-width: 992px) {.mb20_md0 {margin-bottom: 0;}}

.mb20_sm30 {margin-bottom: 20px;}
@media print, screen and (min-width: 768px) {.mb20_sm30 {margin-bottom: 30px;}}

.mb20_md30 {margin-bottom: 20px;}
@media print, screen and (min-width: 992px) {.mb20_md30 {margin-bottom: 30px;}}

.mb30_md0 {margin-bottom: 30px;}
@media print, screen and (min-width: 992px) {.mb30_md0 {margin-bottom: 0;}}

.mb30_sm50 {margin-bottom:30px;}
@media print, screen and (min-width: 768px) {.mb30_sm50 {margin-bottom:50px;}}

.mb30_md50 {margin-bottom:30px;}
@media print, screen and (min-width: 992px) {.mb30_md50 {margin-bottom:50px;}}

.mb30_lg40_xl50 {margin-bottom:30px;}
@media print, screen and (min-width: 992px) {.mb30_lg40_xl50 {margin-bottom:40px;}}
@media print, screen and (min-width: 1200px) {.mb30_lg40_xl50 {margin-bottom:50px;}}

.mb40_md50 {margin-bottom:40px;}
@media print, screen and (min-width: 992px) {.mb40_md50 {margin-bottom:50px;}}

.mb30_sm60 {margin-bottom:30px;}
@media print, screen and (min-width: 768px) {.mb30_sm60 {margin-bottom:60px;}}

.mb30_sp10 {margin-bottom:10px;}
@media print, screen and (min-width: 768px) {.mb30_sp10 {margin-bottom:30px;}}

.pl50_sm0 {padding-left: 50px;}
@media print, screen and (min-width: 768px) {.pl50_sm0 {padding-left: 0;}}


@media print, screen and (min-width: 768px) {
	.mt20_sp0 {margin-top: 20px;}
}

@media print, screen and (min-width: 992px) {
	.mt40_sm0 {margin-top: 40px;}
	.mt40_md_20_sm0 {margin-top: 20px;}
}
@media print, screen and (min-width: 1200px) {
	.mt40_md_20_sm0 {margin-top: 40px;}
}

.mb_content {margin-bottom: 50px;}
.mt_content {margin-top: 50px;}
@media print, screen and (min-width: 768px) {
	.mb_content {margin-bottom: 60px;}
	.mt_content {margin-top: 60px;}
}
@media print, screen and (min-width: 992px) {
	.mb_content {margin-bottom: 80px;}
	.mt_content {margin-top: 80px;}
}
@media print, screen and (min-width: 1200px){
	.mb_content {margin-bottom: 100px;}
	.mt_content {margin-top: 100px;}
}


.lh160 {line-height: 160%;}
.lh200 {line-height: 200%;}

/* content
---------------------------------------------------- */
main { line-height: 2.0em; font-size: 105%;}


.content_pd {padding-top: 50px; padding-bottom: 50px;}
.content_pd2 {padding-top: 30px; padding-bottom: 30px;}
.pd20 { padding: 20px;}
.pd30 { padding: 30px;}
@media only screen and (max-width: 767px){
	.content_pd.pt0_sp {padding-top: 0;}
	.content_pd.pb0_sp{padding-bottom: 0;}
}
@media print, screen and (min-width: 768px){
	main {font-size: 100%;}
	.content_pd {padding-top: 60px; padding-bottom: 60px;}
	.content_pd2 {padding-top: 50px; padding-bottom: 50px;}
}
@media print, screen and (min-width: 992px){
	.content_pd {padding-top: 80px; padding-bottom: 80px;}
}
@media print, screen and (min-width: 1200px){
	main {font-size: 110%;}
	.content_pd {padding-top: 100px; padding-bottom: 100px;}
}
.content_pd.pt0{padding-top: 0;}
.content_pd.pb0{padding-bottom: 0;}
.content_pd.pb10{padding-bottom: 10px;}
.content_pd.pb30{padding-bottom: 30px;}




/* mainimage
---------------------------------------------------- */
/* 画面用 */
@media screen {
#main_print { display: none; }
}

/* 印刷用 */
@media print {
#main_print img { margin: 0 auto;}
}


.swiper-wrapper img{
	margin: 0 auto;
}

.swiper-container-horizontal > .swiper-pagination-bullets, .swiper-pagination-custom, .swiper-pagination-fraction{
	bottom: 0px!important;
}
@media print, screen and (min-width: 1200px) {
	.swiper-container-horizontal > .swiper-pagination-bullets, .swiper-pagination-custom, .swiper-pagination-fraction{
		bottom: 10px!important;
	}
}


#mainimage { position: relative; margin-top: 50px;}
#mainimage h2{
	z-index: 1;
    position: absolute;
    bottom: 0;
    left: 0;
}

#mainimage h2 img {
	width: 100%;
	height: auto;
	max-width: 951px;
}

.swiper-button-next, .swiper-button-prev{ z-index: 200!important; position: absolute!important;}
@media print, screen and (min-width: 768px){
	#mainimage {margin-top: 0;}
	#mainimage h2 img { width: 60%;}
}
@media print, screen and (min-width: 992px){
	#mainimage h2 img { width: 60%;}
}
@media print, screen and (min-width: 1500px){
	#mainimage h2 img { width: 100%;}
}


/* ヘッダー固定で上空ける
---------------------------------------------------- */


/* 背景
---------------------------------------------------- */
.bg_naname {background: url(../images/bg_naname.jpg) repeat;}



.bg_naname.akeru{ margin-top: 50px;}
#top02 .midashi1{ margin-top: -80px;}
@media print, screen and (min-width: 768px){
	.bg_naname.akeru{ margin-top: 70px;}
	.bg_naname.akeru .midashi1{ margin-top: -100px;}
}
@media print, screen and (min-width: 992px){
	.bg_naname.akeru{	margin-top: 50px;}
	.bg_naname.akeru .midashi1{margin-top: -120px;}
}
@media print, screen and (min-width: 1200px){
	.bg_naname.akeru .midashi1{ margin-top: -150px;}
}

.bg_black{
	background: url(../images/bg_black.jpg) no-repeat scroll 50% 50% / cover;
	color: #fff;
	
}



/* レイアウト
---------------------------------------------------- */
.layout1{
	background: url(../images/top01_bg_sp.jpg) no-repeat scroll 50% 50% / cover;
	color: #c2c2c2;
}
.layout1 .midashi2 {color: #f7f6f6;}
.layout1 .midashi3 {color: #f7f6f6;}

.layout1.bg_all{
	background: url(../images/top01_bg_sp.jpg) no-repeat scroll 50% 50% / cover;
	color: #c2c2c2;
}

.layout1 .photo2{
	/*width: 70%;*/
	width: 80%;
	margin: 0 auto;
	padding-bottom: 70px;
}
.layout1 .photo2 .name{
	max-width: 350px;
	width: 70%;
	margin: 0 auto;
	padding-top: 15px;
}
@media print, screen and (min-width: 576px){
	.layout1 .photo2{
		width: 50%;
	}
}
@media print, screen and (min-width: 768px){
	.layout1{
		background: url(../images/top01_bg.jpg) no-repeat scroll 50% 50% / cover;
		position: relative;
	}
	.layout1 .photo{
		position: absolute;
		right: 8.333333%;
		top:60px;
		width: 40%;
	}
	.layout1 .photo2{
		position: absolute;
		right: 8.333333%;
		top:60px;
		width: 30%;
		padding-bottom: 0;
	}
	.layout1 .photo img,
	.layout1 .photo2 img{
		width: 100%;
		height: auto;
	}
}
@media print, screen and (min-width: 992px){
	.layout1 .photo{ top:80px;}
}
@media print, screen and (min-width: 1200px){
	.layout1 .photo{ top:100px;}
	.layout1 .photo2{ width: 25%;}
}
@media print, screen and (min-width: 1600px){
	.layout1 .photo2{
		top: 50%;
		right: 15%;
		transform: translateY(-50%);
		-webkit-transform: translateY(-50%);
		-ms-transform: translateY(-50%);
	}
	.layout1 .photo2{ width: 20%;}
}


@media print, screen and (min-width: 768px){
	.layout2{
		position: relative;
	}
	.layout2 .photo{
		position: absolute;
		left: 8.333333%;
		top:60px;
		width: 40%;
	}
	.layout2 .photo img{
		width: 100%;
		height: auto;
	}
}
@media print, screen and (min-width: 992px){
	.layout2 .photo{ top:80px;}
}
@media print, screen and (min-width: 1200px){
	.layout2 .photo{ top:100px;}
}
/* 共通
---------------------------------------------------- */
a:hover img {
	opacity:0.9;
	filter: alpha(opacity=90);
}

.close {
    float: none;
}

/* 縦横比固定 */
.photo-ofi {
	 height: 0;
	 display: block;
	padding-bottom: 75%; /* 高さを指定（ボックスの横幅を基準） */
	/*background-color: #EFEFEF;*/
	overflow: hidden;
	position: relative;
	/*margin-bottom: 10px;*/
}
.photo-ofi img {
	 max-width: inherit;
	 max-height: inherit;
	width: 100%;
	height: 100%;
	 object-fit: scale-down;
	 font-family: 'object-fit: scale-down;';
	 position: absolute;
	 left: 0;
	 top: 0;
}

.object-fit img{
	object-fit: cover;
	font-family: 'object-fit: cover;'; /*IE対策*/
}


div.paging { text-align: center; font-size: 90%; margin-top: 20px; line-height: 1.4em; font-family: 'Julius Sans One', sans-serif;}
div.paging span.current,
div.paging span.paging-text{
	margin:0px 0.5px;
	color:#262626;
	border:1px solid #262626;
	display:inline;
	zoom:1;
	display:inline-block;
	overflow:hidden;
	text-decoration:none;
}
div.paging span.paging-text a{
	padding:5px 8.5px;
	display:block;
	color: #262626;
}
div.paging span.current{
	background: #262626;
	border:1px solid #262626;
	color:#fff;
	zoom:1;
	padding:5px 8.5px;
	text-decoration:none;
	display:inline-block;
	cursor:pointer;
}
div.paging span.paging-text a:hover{
	background: #262626;
	color:#fff;
	text-decoration:none;
	cursor:pointer;
	opacity: 1;
}

/*左右の余白*/
@media print, screen and (min-width: 768px){
	.yohaku{
		margin-left: 8.333333%;
		margin-right: 8.333333%;
	}
	.yohaku2{
		margin-left: 8.333333%;
		margin-right: 8.333333%;
	}
	.yohaku3{
		margin-left: 8.333333%;
		margin-right: 8.333333%;
	}
	.yohaku4{
		margin-left: 15px;
		margin-right: 15px;
	}
}
@media print, screen and (min-width: 1500px){
	.yohaku{
		margin-left: 16.666667%;
		margin-right: 16.666667%;
	}
	.yohaku3{
		margin-left: 13%;
		margin-right: 13%;
	}
	.yohaku4{
		margin-left: 8.333333%;
		margin-right: 8.333333%;
	}
}

/* 01 index
---------------------------------------------------- */
#top01{
	background: url(../images/top01_bg_sp.jpg) no-repeat scroll 50% 50% / cover;
	color: #c2c2c2;
}
#top01 .midashi2 {color: #f7f6f6;}
#top01 .midashi3 {color: #f7f6f6;}
@media print, screen and (min-width: 768px){
	#top01{
		background: url(../images/top01_bg.jpg) no-repeat scroll 50% 50% / cover;
		position: relative;
	}
	#top01 .photo{
		position: absolute;
		right: 8.333333%;
		top:60px;
		width: 40%;
	}
	#top01 .photo img{
		width: 100%;
		height: auto;
	}
}
@media print, screen and (min-width: 992px){
	#top01 .photo{ top:80px;}
}
@media print, screen and (min-width: 1200px){
	#top01 .photo{ top:100px;}
}



#top02{
	margin-top: 50px;
}
#top02 .midashi1{
	margin-top: -80px;
}

#top_searvice .box{
	margin-bottom: 30px;
}
#top_searvice .box .text {
    background-color: #fff;
    padding: 30px;
    position: relative;
    z-index: 1;
	margin-top: -50px;
	width: 90%;
	margin-left: 20px;
}
#top_searvice .box .text::after {
    content: "";
    height: 100%;
    position: absolute;
    width: 100%;
	border-collapse: collapse;
	border: 1px solid #272727;
}
#top_searvice .box .text::after {
    top: -10px;
    left: -10px;
    z-index: -2;
}

#top_searvice a:link,
#top_searvice a:visited{
	display: block;
}
#top_searvice .more{
	text-align: right;
	font-family: 'Julius Sans One', sans-serif;
}
#top_searvice a .more{
	text-decoration: underline;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
}
#top_searvice a:hover .more{
	letter-spacing: 0.1em;
}
@media print, screen and (min-width: 768px){
	#top02{
		margin-top: 70px;
	}
	#top02 .midashi1{
		margin-top: -100px;
	}
	
	#top_searvice{
		margin-left: -1%;
		margin-right: -1%;
	}
	#top_searvice .box{
		width: 48%;
		float: left;
		margin:1%;
	}
}
@media print, screen and (min-width: 992px){
	#top02{
		margin-top: 50px;
	}
	#top02 .midashi1{
		margin-top: -120px;
	}
	
	#top_searvice .box{
		width: 31.3%;
	}
	#top_searvice .box:nth-child(4) { margin-left: 15.5%;}
}
@media print, screen and (min-width: 1200px){
	#top02 .midashi1{
		margin-top: -150px;
	}
	#top_searvice .box .text { margin-left: 0;}
}




#top03 .box {margin-bottom: 10px;}
@media print, screen and (min-width: 768px){
	#top03{
		background: url(../images/top03_bg.jpg) repeat-x center top;
		-moz-background-size:auto 100%;
		background-size:auto 100%; 
		margin-bottom: 30px;
	}
	#top03 .box{
		width: 40%;
		margin: 1% 5%;
		float: left;
	}
}
@media print, screen and (min-width: 1200px){
	#top03{
		background: url(../images/top03_bg.jpg) repeat-x center top;
		-moz-background-size:auto 100%;
		background-size:auto 100%; 
	}
	#top03 .box{
		width: 23%;
		margin: 0 1%;
	}
}


/* ホバーエフェクト
---------------------------------------------------- */
figure.snip1384 {
  position: relative;
  /*float: left;*/
  overflow: hidden;
  /*margin: 10px 1%;*/
  min-width: 100%;
  max-width: auto;
  width: 100%;
  color: #ffffff;
  text-align: left;
  font-size: 16px;
  background-color: #000000;
}
figure.snip1384 * {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all 0.35s ease;
  transition: all 0.35s ease;
}
figure.snip1384 img {
  max-width: 100%;
  backface-visibility: hidden;
  vertical-align: top;
}
figure.snip1384:after,
figure.snip1384 figcaption {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}
figure.snip1384:after {
  content: '';
  background-color: rgba(0, 0, 0, 0.65);
  -webkit-transition: all 0.35s ease;
  transition: all 0.35s ease;
  opacity: 0;
}
figure.snip1384 figcaption {
  z-index: 1;
  padding: 25px;
}
@media (min-width: 1500px) {
	figure.snip1384 figcaption {  padding: 30px;}
}

figure.snip1384 h3,
figure.snip1384 .links {
  width: 100%;
  margin: 5px 0;
  padding: 0;
}
figure.snip1384 h3 {
  line-height: 1.4em;
  font-size: 120%;
  text-transform: uppercase;
  opacity: 0;
	margin-bottom: 20px;
	border-collapse: collapse;
	border-left: 2px solid #fff;
	padding-left: 10px;
}
figure.snip1384 .text {
  line-height: 1.4em;
  font-size: 90%;
  text-transform: uppercase;
  opacity: 0;
	margin-bottom: 20px;
}
@media print, screen and (min-width: 768px){
	figure.snip1384 h3 { font-size: 100%;}
	figure.snip1384 .text { font-size: 80%;}
}
@media print, screen and (min-width: 1500px){
	figure.snip1384 h3 { font-size: 120%;}
	figure.snip1384 .text { font-size: 90%;}
}

figure.snip1384 p {
  font-size: 0.8em;
  font-weight: 300;
  letter-spacing: 1px;
  opacity: 0;
  top: 50%;
  -webkit-transform: translateY(40px);
  transform: translateY(40px);
	border-collapse: collapse;
	border: 1px solid #fff;
	display: inline-block;
	padding: 5px 10px;
}
figure.snip1384 i {
  position: absolute;
  bottom: 10px;
  right: 10px;
  padding: 20px 25px;
  font-size: 34px;
  opacity: 0;
  -webkit-transform: translateX(-10px);
  transform: translateX(-10px);
}
figure.snip1384 a {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1;
}
figure.snip1384:hover img,
figure.snip1384.hover img {
  zoom: 1;
  filter: alpha(opacity=50);
  -webkit-opacity: 0.5;
  opacity: 0.5;
}
figure.snip1384:hover:after,
figure.snip1384.hover:after {
  opacity: 1;
  position: absolute;
  top: 10px;
  bottom: 10px;
  left: 10px;
  right: 10px;
}
figure.snip1384:hover h3,
figure.snip1384.hover h3,
figure.snip1384:hover .text,
figure.snip1384.hover .text,
figure.snip1384:hover p,
figure.snip1384.hover p,
figure.snip1384:hover i,
figure.snip1384.hover i {
  -webkit-transform: translate(0px, 0px);
  transform: translate(0px, 0px);
  opacity: 1;
}




#top04{
	background: url(../images/top04.jpg) no-repeat scroll 50% 50% / cover;
}
/*--------------------------------------
新着情報
--------------------------------------*/
.news_bg{
	background-color: #fff;
	padding: 20px;
	box-shadow : 0px 0px 18.8px 1.2px rgba(157, 157, 157, 0.6) ;
}


.news_box{
	border-bottom: 1px solid #e2e2e2;
}
.new{
	margin-left: 10px;
	font-size: 80%;
	line-height: 1.0em;
	color: #fff;
	font-family: 'Julius Sans One', sans-serif;
	background-color: #272727;
	padding: 2px 5px;
}

.news_box .date{
	font-size: 80%;
	color: #b2b2b2;
	padding: 10px 10px 0 10px;
}
.news_box .text{
	padding: 0 10px 10px 10px;
}
a .news_box{
	text-decoration: none;
}
a:hover .news_box{
	background-color: #efefef;
	opacity: 1;
}

.news_box li{
	list-style: none;
}

.news_box .btn_area {
	text-align: right;
	font-family: 'Julius Sans One', sans-serif;
	font-size: 80%;
	color: #808080;
}
.news_box .btn_area a{
	border: 1px solid #808080;
	padding: 5px 10px;
}
@media print, screen and (min-width: 576px) {
	.news_box{
		display: table;
		width: 100%;
	}
	.news_box li{
		display: table-cell;
		padding: 15px 5px;
		vertical-align: middle;
	}
	.news_box .date{
		padding: 0 0 0 10px;
		width: 160px;
	}	
	
	.news_box .text{
		width: 100%;
		padding: 0 10px 0 0;
	}
	.news_box .btn_area{
		float: right;
		margin-left: 10px;
		font-family: 'Julius Sans One', sans-serif;
		font-size: 80%;
		color: #808080;
	}
	.news_box .moji{
		overflow: hidden;
		zoom:1;
	}
}


#saiyou{
	background-image : linear-gradient(0deg, #272727 0%, rgba(39, 39, 39, 0.8) 48%, rgba(39, 39, 39, 0.88) 67%, #272727 100%) ;
	color: #fff;
	border-collapse: collapse;
	border: 1px solid #000;
	text-align: center;
}
#saiyou .more{
	text-decoration: underline;
	margin-bottom: 50px;
	font-family: 'Julius Sans One', sans-serif;
}

#saiyou a:link,
#saiyou a:visited{
	color: #fff;
	display: block;
	padding: 50px 0 0 0;
}
#saiyou .photo2 {display: none;}
@media print, screen and (min-width: 576px) {
	#saiyou{
		position: relative;
	}
	#saiyou .photo1{
		position: absolute;
		left: 0;
		top: 0;
		height: 100%;
		width: 33%;
		z-index: -1;
	}
	#saiyou .photo2{
		position: absolute;
		right: 0;
		top: 0;
		height: 100%;
		width: 33%;
		z-index: -1;
		display: block;
	}
	#saiyou .photo1 img,
	#saiyou .photo2 img{
		width: 100%;
		height: 100%;
	}
	#saiyou a:link,
	#saiyou a:visited{
		color: #fff;
		display: block;
		padding: 50px 0;
	}
	#saiyou .more{
		margin-bottom: 0;
	}
}


#otoiawase{
	background: url(../images/otoiawase.jpg) no-repeat scroll 50% 50% / cover;
	color: #fff;
}
#otoiawase li{
	list-style: none;
	text-align: center;
	height: 52px;
}

#otoiawase .tel{
	font-size: 100%;
	line-height:1.4em;
	color:#fff;
	border-collapse: collapse;
	border: 1px solid #fff;
	display: block;
	padding: 15px 10px;
	font-family: 'Roboto', sans-serif;
}
#otoiawase .tel .num {font-size: 130%;}
#otoiawase .tel a:link,
#otoiawase .tel a:visited{
	text-decoration: none!important;
	color: #fff;
}

#otoiawase .en2 {margin: 10px 0; font-size: 110%;}


#otoiawase .mail img{
	display: inline-block;
	width: 25px;
	margin-right: 15px;
}
#otoiawase .mail a:link,
#otoiawase .mail a:visited{
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	font-size: 100%;
	line-height:1.4em;
	color:#fff;
	border-collapse: collapse;
	border: 1px solid #fff;
	display: block;
	padding: 15px 20px;
	font-family: 'Julius Sans One', sans-serif;
	height: 52px;
}
#otoiawase .mail a:hover{
	opacity: 1;
	background-color: #444;
}
#otoiawase .mail i{margin-left:60px;}

@media print, screen and (min-width: 768px) {
	#otoiawase ul{
		float: left;
		margin-left: 20px;
		margin-top: 30px;
	}
}
@media print, screen and (min-width: 992px) {
	#otoiawase ul{
		margin-left: 20px;
		width: 45%;
		font-size: 110%;
	}
}

/* news
---------------------------------------------------- */
.news_photo{
	margin-left: -1%;
	margin-right: -1%;
}
.news_photo .photo{
	width: 31.3%;
	float: left;
	margin: 1%;
}

/* 02 service
---------------------------------------------------- */
#service1,
#service2,
#service3,
#service4,
#service5{
	margin-top:-61px;
	padding-top:61px;
}
@media print, screen and (min-width: 992px) {
	#service1,
	#service2,
	#service3,
	#service4,
	#service5{
		margin-top:-75px;
		padding-top:75px;
	}
}


/* 03 works
---------------------------------------------------- */
#cate_head{
	margin-top:-61px;
	padding-top:61px;
}
@media print, screen and (min-width: 992px) {
	#cate_head{
		margin-top:-75px;
		padding-top:75px;
	}
}


.works_box_waku{
	margin-left: -1%;
	margin-right: -1%;
}
.works_box_waku .works_box{
	width: 48%;
	float: left;
	margin: 0 1% 30px 1%;
}
.works_box_waku .works_box h4 {
	margin-top: 10px;
	font-size: 90%;
	line-height: 1.4em;
}
.works_box_waku .works_box:nth-of-type(2n+1) { clear: both;}
@media print, screen and (min-width: 768px) {
	.works_box_waku .works_box{
		width: 31.3%;
		margin: 0 1% 50px 1%;
	}
	.works_box_waku .works_box:nth-of-type(2n+1) { clear: none;}
	.works_box_waku .works_box:nth-of-type(3n+1) { clear: both;}
}
@media print, screen and (min-width: 1200px) {
	.works_box_waku .works_box h4 {
		font-size: 100%;
	}
}


.works_detail_ba{
	margin-left: -2.5%;
	margin-right: -2.5%;
	position: relative;
}

.works_detail_ba .box{
	width: 45%;
	float: left;
	margin: 0 2.5%;
}
.works_detail_ba .box .en{
	text-align: center;
	font-size: 110%;
	margin-bottom: 10px;
}
.works_detail_ba i{
    position: absolute;
    top: 60%;
    left: 50%;
    transform: translate(-60%, -50%);
    -webkit-transform: translate(-60%, -50%);
    -ms-transform: translate(-60%, -50%);
	font-size: 120%;
	line-height: 1.4em;
}
@media print, screen and (min-width: 768px) {
	.works_detail_ba i{
		top: 55%;
		left: 50%;
		transform: translate(-55%, -50%);
		-webkit-transform: translate(-55%, -50%);
		-ms-transform: translate(-55%, -50%);
		font-size: 150%;
	}
}

@media print, screen and (min-width: 1500px) {
	.works_yohaku{ margin: 0 10%;}
}

/* 04 contact
---------------------------------------------------- */
.recruit_list li{
	list-style: none;
	font-size: 120%;
	line-height: 1.4em;
	margin-bottom: 10px;
}
.recruit_list li{ list-style:none;text-indent: -1em; padding-left:1em;}
.recruit_list li:before{
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f56b";
	margin-right: 5px;
}

/* 05 company
---------------------------------------------------- */
.company_touroku{
	display: table;
	
}
.company_touroku li{
	display: table-cell;
}
.company_touroku .title{
	width: 170px;
}

/* 06 contact
---------------------------------------------------- */
#mailform{
	margin-top:-61px;
	padding-top:61px;
}
@media print, screen and (min-width: 992px) {
	#mailform{
		margin-top:-75px;
		padding-top:75px;
	}
}


.contact_tel_box .tel .num {font-size: 130%;}
.contact_tel_box .tel a:link,
.contact_tel_box .tel a:visited{
	text-decoration: none!important;
	color: #fff;
}

.contact_tel_box li{
	list-style: none;
	text-align: center;
	font-size: 100%;
	line-height:1.4em;
	color:#fff;
	border-collapse: collapse;
	border: 1px solid #fff;
	display: block;
	padding: 15px 25px;
	font-family: 'Roboto', sans-serif;
	margin-bottom: 5px;
}

@media print, screen and (min-width: 576px) {
	.contact_tel_box ul{
		display: table;
		margin: 0 auto;
		border-collapse: separate;
		border-spacing: 5px 0;
	}
	.contact_tel_box li{
		display: table-cell;
		vertical-align: middle;
	}
}
@media print, screen and (min-width: 992px) {
	.contact_tel_box ul{
		font-size: 110%;
	}
}
@media print, screen and (min-width: 1200px) {
	.contact_tel_box ul{
		font-size: 120%;
	}
	.contact_tel_box li{
		padding: 20px 40px;
		margin-bottom: 5px;
	}
}

.contact_box{
	border-collapse: collapse;
	border: 1px solid #c8a14f;
	padding: 10px;
}
.contact_box .text{
	margin: 20px 20px 10px 20px;
}
@media print, screen and (min-width: 576px) {
	.contact_box{padding: 30px;}
	.contact_box .image{
		width: 30%;
		float: left;
		margin-right: 30px;
	}
	.contact_box .text{
		overflow: hidden;
		zoom:1;
	}
	.contact_box .text{
		margin: 0;
	}
}

/*フォームのテーブル*/
.table_form{
	width:100%;
	border-collapse:collapse;
	border-top:1px solid #ccc;
}
.table_form th{
	width:100%;
	padding:10px 5px 3px 5px;
	display: block;
	color: #666;
}
.table_form td{
	width:100%;
	border-bottom:1px solid #ccc;
	padding:3px 5px 10px 5px;
	display: block;
}
.table_form th span{/*必須*/
	font-size:70%;
	color:#fff;
	padding:0px 6px;
	float:right;
	border-radius:3px; 
	font-weight: normal;
	background-color: #ff7300;
}
.table_form td.last {border-bottom:none;}


.table_form th.sen_none,
.table_form td.sen_none{
	border:0;
}

@media print, screen and (min-width: 768px) {
	.table_form th{
		width:33%;
		border-bottom:1px solid #ccc;
		padding:15px 20px;
		vertical-align:middle;
		text-align:left;
		display:table-cell;
		color: #272727;
	}
	.table_form td{
		width:100%;
		padding:15px 20px;
		display:table-cell;
	}
	
	.table_form.sen_none .last td{padding-bottom: 10px;}
	.table_form.sen_none th{
		padding:10px 20px 0 20px;
	}
	.table_form.sen_none td{
		padding:10px 25px 0 25px;
	}

}
@media print, screen and (min-width: 992px) {
	.table_form th{width:30%;}
}

/* フォーム関係 */
.required input[type="text"], .required input[type="password"], .required select, .required textarea{border:1px solid #c36;}
input[type="checkbox"], input[type="radio"] {vertical-align:middle; margin:5px 5px 5px 0;}
input{font-size:100%;vertical-align:middle; padding:9px}
input[type="file"]{width: 99%;}
input[type="text"], select{border:1px solid #ccc; border-radius:3px; color: #272727;}
input[type="email"]{color: #272727;}

input:focus[type="text"]{border:1px solid #06c;}
textarea{font-size:100%;border:1px solid #ccc;width:99%; border-radius:3px; }
input,textarea{ 
  /*display: inline-block; 
  font-family: FontAwesome; */
  font-style: normal; 
  font-weight: normal; 
  line-height: 1; 
  -Webkit-font-smoothing: antialiased; 
  -moz-osx-font-smoothing: grayscale;
} 
select {padding: 9px; color: #272727; }

.form-control {color: #272727;}
.form-control.w50 {width:50px; display: inline-block; margin-right: 10px;}
.form-control.w300 {width:200px;}
@media (min-width: 768px) {
.form-control.w300 {width:250px;}
}


.privacy_waku{
	padding:30px 20px;
	border-collapse: collapse;
	border: 1px solid #ccc;
	font-size: 90%;
	background-color: #fff;
}
@media print, screen and (min-width: 992px){
	.privacy_waku{	padding:40px 20px;}
}


.privacy_scroll {
  max-height:200px;
  overflow-y: scroll;
  padding-right:10px;
	z-index: 1;
}
@media print, screen and (min-width: 768px) {
.privacy_scroll {max-height:400px;}
}


.btn-primary{
	border-radius:0;
	font-size: 100%;
}
.btn-primary:hover{
	background-color: #444;
	opacity: 1;
}


.form-control {
    height: 50px;
    padding: 12px 10px;
    font-size: 14px;
    line-height: 1.42857143;
    background-image: none;
    border: 1px solid #cccccc;
    border-radius: 4px;
    -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
    -webkit-transition: border-color ease-in-out .15s, -webkit-box-shadow ease-in-out .15s;
    -o-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
    transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
}



/* footer
---------------------------------------------------- */
footer {
	font-size: 90%;
	line-height: 1.6em;
	background-color: #313131;
	color: #fff;
}
footer .in {padding: 30px 0;}
footer .foot_logo{
	margin-bottom: 20px;
	text-align: center;
}
footer .foot_logo img{
	width: 70%;
	height: auto;
	margin: 0 auto;
	max-width: 398px;
}


footer .address{
	font-size: 100%;
	line-height: 1.6em;
}

footer .address{
	text-align: center;
	margin-bottom: 5px;
	line-height: 1.4em;
}


@media print, screen and (min-width: 576px) {
	footer .foot_logo img{
		width: 40%;
	}
}
@media print, screen and (min-width: 768px) {
	footer .foot_link{
		font-size: 90%;
		text-align: center;
		margin-top: 15px;
	}
	footer .foot_link li {
		list-style: none;
		display: inline-block;
		padding-left: 10px;
	}
	footer .foot_link li a:link,
	footer .foot_link li a:visited{
		color: #fff;
	}
}
@media print, screen and (min-width: 992px) {
	footer .in {padding: 50px 0;}
	footer .foot_logo{
		text-align: left;
	}
	footer .foot_logo img{
		width: 100%;
		margin: 0;
	}
	footer .address {text-align: left;}
	footer .foot_link{
		font-size: 90%;
		text-align: right;
		margin-top: 15px;
	}
}
@media print, screen and (min-width: 1200px) {
	footer {
		font-size: 100%;
	}
	footer .foot_link{
		font-size: 100%;
		margin-top: 0;
	}
}



/*copy*/
.bg_copy{
	background-color: #272727;
	padding: 10px;
	text-align: center;
}

.copy {
	text-align: center;
	font-size: 80%;
	line-height: 1.4em;
}

/* pagetop
---------------------------------------------------- */
#pagetop { position: fixed; bottom:10px; right:10px; z-index: 100;}
#pagetop img {width: 40px; height: auto;}
@media (min-width: 1200px) {
	#pagetop { position: fixed; bottom:20px; right:20px; z-index: 100;}
	#pagetop img {width: 55px; height: auto;}
}

/*20210618*/
@media print, screen and (min-width: 992px) {
	.fotorama__caption{
		font-size: 140%!important;
	}
}
/*2024/3/21追加*/
#midashi_h2.h2_movie {
    background: url(../images/h2_movie.jpg) no-repeat 50% 50% / cover;
}
.movie-text-area {
	max-width: 800px;
	margin: auto;
}
.video-wrap {
	width: 100%;
	max-width: 800px;
	margin: auto;
}

@media print, screen and (min-width: 768px) {
	.menu {
		font-size: 78%;
	}
}
@media print, screen and (min-width: 992px) {
	.menu {
		font-size: 100%;
	}
}
.midashi6 {
	font-size: 3em;
	font-weight: nor;
}

/*
.gengo_sp {display: none!important;}
.gengo {display: none!important;}
*/

.map_img {
	width: 100%;
	height: auto;
}