@charset "utf-8";
/*==================================================
	設定部
----------------------------------------------------
  WEBフォント指定
--------------------------------------------------*/
#menu, #container h3.sub,
.cmn_btn a,
.mp { font-family: 'M PLUS 1p', sans-serif; }
#service .flow .text li::before,
.serif { font-family: 'Noto Serif JP', serif; }
/*--------------------------------------------------
  フォント色指定
--------------------------------------------------*/
.red { color: #FF0000; }	/* 赤 */
.pick { color: #0200FF; }	/* 注目色 */
.thin { color: #666666; }	/* 薄い色 */
/* リンク */
a:link, a:visited {
	color: #06479D;
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
/*--------------------------------------------------
  タブレット・スマホに適応
--------------------------------------------------*/
@media only screen and (max-width: 768px) {
	/* ハンバーガーメニュー */
	#switchBtnArea #switchBtn { background: #060; }
	#header .contact .for-sp .tel a { background: #060; }
	#header .contact .btn a { background: #060; }
}
/*==================================================
  ヘッダ
--------------------------------------------------*/
#header {
	background-color: #006600;
	height: 50px;
	padding: 15px;
	text-align: left;
	width: 95%;
	/* margin-bottom: 10px; */
}
/* タイトル */
#header h1.title {
	height: 100%;
	/* 縦方向中央揃え */
	display: flex;
	align-items: center;
	justify-content: center;
}
#header h1.title span {
	font-size: 35px;
	font-weight: 600;
	color: #090;
}
@media only screen and (max-width: 640px){
	#header h1.title span {
		display: none;
	}
}

/* お問い合わせ */
#header .contact a {
	display: block;
}

/* PCとスマホとの表示切替 */
#header .contact .for-pc {
	display: block;
	margin-right: 3px;
}
#header .contact .for-sp {
	display: none;
}
/*　上と下とで連携　*/
@media only screen and (max-width: 640px){
	#header .contact .for-pc {
		display: none;
	}
	#header .contact .for-sp {
		display: block;
	}
}
/* ここまで */

#header .contact a img {
	vertical-align: middle;
}
/*--------------------------------------------------
  メニュー
--------------------------------------------------*/
#menu {
	width: 1000px;
	margin: 40px auto;
	background-color: #bafcf4;
	border-radius: 20px;
}
/* #menu ul {
	background: url(../img/menu/line.png) no-repeat right center;
} */

#menu li {
	display: inline-flex;
	/* background-color: #ddd; */
	width: 450px;
	margin-left: 35px;
	margin-bottom: 10px;
}
#menu li a {
	display: block;
	padding: 5px 20px;
	color: #005500;
	font-size: 18px;
	font-family: Georgia, 'Times New Roman', Times, serif;
	line-height: 28px;
	text-align: left;
	text-decoration: none;
	/* background: url(../img/menu/line.png) no-repeat left center; */
	font-weight: 500;
	position: relative;
}

#menu li.on a,
#menu li a:hover {
	color: #22b573;
	filter:alpha(opacity=100);
	-moz-opacity: 1;
	opacity: 1;
}
#menu li.on a:before,
#menu li a:hover:before {
	content: "";
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	bottom: 0;
	width: 80%;
	height: 4px;
	background: #22b573;
}
/*--------------------------------------------------
  ページタイトル
--------------------------------------------------*/
#page_title {
	overflow: hidden;
	position: relative;
	text-align: center;
}
#page_title p {
	text-align: center;
}
#page_title #recruit_ttl {
	background: url("../img/recruit/bg_title.jpg") center / cover no-repeat;
}
#page_title #contact_ttl {
	background: url("../img/contact/bg_title.jpg") center / cover no-repeat;
}
#page_title #service_ttl {
	background: url("../img/service/bg_title.jpg") center / cover no-repeat;
}
#page_title .sub_ttl {
	text-align: right !important;
}


/*--------------------------------------------------
  コンテナ
--------------------------------------------------*/

#container {
	overflow: hidden;
	text-align: left;
	line-height: 1.8;
}
/* 広告 */
#container .ad {
	width: 90%;
	margin: 0 auto;
	margin-top: 10px;
}
#container p {
	margin-bottom: 1em;
}
#container p.nm {
	margin-bottom: 0;
}

#container .main .sub {
	position: relative;
	margin-bottom: 0px;
	padding-bottom: 0px;
	font-size: 23px;
	color: "#006600";
	font-weight: bold;
	text-align: center;
}
#container .main .ing {
	position: relative;
	margin-bottom: 20px;
	padding-bottom: 5px;
	font-size: 20px;
	color: #0033ff;
	text-align: center;
}

/*--------------------------------------------------
  メイン
--------------------------------------------------*/
.main {
	clear: both;
}
/*--------------------------------------------------
  フッタ
--------------------------------------------------*/
#footer {
	clear: both;
	width: 100%;
	color: #FFF;
	font-size: 14px;
	line-height: 1.6;
	/* background: #666; */
	margin: 0 auto;
}
/* #footer .footer_in {
	border-radius: 20px;
	background: url("../img/bg_footer.jpg") no-repeat center /cover;
} */
#footer .footer_in .box_flex {
	padding: 100px 0;
	width: 1100px;
	margin: 0 auto;
}
#footer .footer_in .box_flex .box, #footer .footer_in .box_flex .contact {
	width: 50%;
}
#footer .footer_in .box_flex .box {
	background-color: rgba(256, 256, 256, 0);
	border-radius: 20px;
	color: #fff;
	padding: 30px 0;
}
#footer .footer_in .box_flex .box dt {
	margin-bottom: 3px;
}

#footer .footer_in .box_flex .box dt img {
	border-radius: 30px;
}
#footer .footer_in .box_flex .box dt span {
	font-size: 35px;
	color: #fff;
}
#footer .footer_in .box_flex .box .ing {
	font-size: 30px;
	font-family: 'Times New Roman', Times, serif;
	color: #f9ffcc;
	margin-bottom: 0px;
}
#footer .footer_in .box_flex .box dd p {
	font-size: large;
	text-align: center;
}
/* お問い合わせ */
#footer .contact {
	background-color: rgba(0, 0, 0, 0);
	border-radius: 20px;
	padding: 50px 0;
}
#footer .contact .txt {
	font-size: 25px;
	color: #FFF;
	text-align: center;
	margin-bottom: 15px;
}
#footer .contact .btn {
	text-align: center;
}
#footer .contact .btn a {
	display: inline-block;
	margin-bottom: 5px;
	padding: 7px 25px;
	width: 370px;
	line-height: 72px;
	background: rgba(0, 102, 0, 0.4);
	border-radius: 10px;
	color: #fff;
	font-size: 24px;
	font-weight: bold;
	box-shadow : 2px 2px 0px rgba(0, 0, 0, 0.2);
}
#footer .contact .btn img {
	width: 24px;
	margin-right: 10px;
	vertical-align: middle;
	position: relative;
	top: -2px;
}
#footer .contact .btn a {
	width: 300px;
	line-height: 40px;
}
/* リンク */
#footer .dsp_hp {
	background-color: #666;
	width: 100%;
	margin-top: 10px;
}
#footer ul {
	height: 80px;
	border-bottom: 1px solid #FFF;
	line-height: 30px;
	padding-top: 20px;
	margin: auto;
}
#footer ul li {
	display: inline;
	margin-right: 20px;
	padding-left: 20px;
	list-style: none;
}
#footer ul li a {
	color: #f0f4cc;
	text-decoration: none;
}
/* #footer ul li a:hover {
	text-decoration: underline;
} */
/* コピーライト */
#copyright {
	background-color: #666;
	height: 52px;
	font-size: 16px;
	line-height: 52px;
	color: #FFF;
	text-align: center;
}
/*--------------------------------------------------
  共通
--------------------------------------------------*/
/* パンくずリスト */
#page_navi {
	clear: both;
	margin-bottom: 40px;
	padding-top: 30px;
	color: #999;
	font-size: 12px;
	line-height: 1;
}
#page_navi li { display: inline; }
#page_navi li+li { margin-left: 8px; }
#page_navi li+li:before {
	content: ">";
	margin-right: 8px;
}
#page_navi a { text-decoration: none; color: #888888; }
/* テーブル */
.tbl { width: 100%; }
.tbl th,
.tbl td {
	padding: 10px;
	border: 1px solid #BBBBBB;
}
.tbl th {
	white-space: nowrap;
	background: #EEEEEE;
}
/* 注意書き */
p.attention {
	margin-left: 1em;
	text-indent: -1em;
}
/* 横100％背景 */
/* .bg_wide {
	position: relative;
} */
/* .bg_wide::before {
	position: absolute;
	left: 0;
	top: 0;
	display: block;
	width: 100vw;
	height: 100%;
	margin-left: calc(((100vw - 100%) / 2) * -1);
	margin-right: calc(((100vw - 100%) / 2) * -1);
	content: "";
	z-index: -1;
} */
/* @media only screen and (max-width: 1150px) {
	.bg_wide::before {
		width: calc(100% + 50px);
		margin-left: -25px;
		margin-right: 0;
	}
} */
/* フレックスボックス */
.box_pad {

	padding: 15px;
	box-sizing: border-box;
}
.box_flex_sp {
	display:flex;
	flex-wrap:wrap;
	justify-content: space-between;
}
.box_flex_sp.rev { flex-direction: row-reverse; }
.box_flex_sp.vcen { align-items: center; }
@media print, screen and (min-width: 641px){ /* PC用 */
	.box_pad { padding: 30px; }
	.box_flex {
		display:flex;
		flex-wrap:wrap;
		justify-content: space-between;
	}
	.box_flex.rev { flex-direction: row-reverse; }
	.box_flex.vcen { align-items: center; }
}
.cmn_btn a {
	display: inline-block;
	width: 245px;
	box-sizing: border-box;
	color: #fff;
	text-align: center;
	/*background: url("../img/arrow.png") no-repeat right 10px center, linear-gradient(90deg, rgba(6, 71, 157, 1) 0%, rgba(13, 103, 174, 1) 100%);*/
	background: #006600;
	font-size: 17px;
	letter-spacing : 3.4px;
	box-shadow : 2px 2px 0px rgba(0, 0, 0, 0.2);
	line-height: 25px;
	-webkit-transition: none;
	-moz-transition: none;
	-o-transition: none;
	transition: none;
}
.cmn_btn a:hover {
	filter:alpha(opacity=100);
	-moz-opacity: 1;
	opacity: 1;
	background: url("../img/arrow_on.png") no-repeat right 10px center, #fff;
	border: 3px solid #22b573;
	line-height: 23px;
	color: #22B573;
}
