@charset "utf-8";

/*Googlefonts*/
@import url('https://fonts.googleapis.com/css?family=Noto+Sans+JP:500,700&display=swap&subset=japanese');
@import url('https://fonts.googleapis.com/css?family=Roboto:500,700&display=swap');



body {
	margin: 0px;
	padding: 0px;
	font-family: "Arial", Lato, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	color: #333;
	-webkit-text-size-adjust: 100%;
	/* スマホで文字サイズが大きくなるのを防ぐ */
	font-size: 15px;
	max-width: 1920px;
	margin: 0 auto;
	background-color: #fff;
	border-top: 3px solid #0070C0;
}

html {
	-ms-overflow-style: scrollbar;
}

.serif {
	font-family: "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}

ul {
	padding: 0;
}

li {
	list-style: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	margin: 0px;
	padding: 0px;
	font-weight: normal;
	font-size: 100%
}

a {
	transition-property: all;
	transition: 0.2s linear;
	text-decoration: none;
}

_:-ms-lang(x)::-ms-backdrop,
a {
	transition: 0s;
}

/*IE11*/

a:focus,
*:focus {
	outline: none;
}

p {
	margin: 0px;
	padding: 0px
}

.clearfix:after {
	content: " ";
	/* 新しい要素を作る */
	display: block;
	/* ブロックレベル要素に */
	clear: both;
	height: 0;
	visibility: hidden;
}

.clearfix {
	min-height: 1px;
}

* html .clearfix {
	height: 1px;
	/*\*/
	/*/
height: auto;
overflow: hidden;
/**/
}

/*
	a:hover img {
		opacity: 0.8;
	}
*/

.moa {
	margin: 0 auto;
}

.tac {
	text-align: center;
}

.tal {
	text-align: left
}

@media (min-width: 992px) {
	.tal {
		text-align: center
	}
}

.left {
	float: left;
}

.right {
	float: right;
}

.mb0 {
	margin-bottom: 0px !important;
}

.mb5 {
	margin-bottom: 5px !important;
}

.mb10 {
	margin-bottom: 10px !important;
}

.mb15 {
	margin-bottom: 15px !important;
}

.mb20 {
	margin-bottom: 20px !important;
}

.mb25 {
	margin-bottom: 25px !important;
}

.mb30 {
	margin-bottom: 30px !important;
}

.mb35 {
	margin-bottom: 35px !important;
}

.mb40 {
	margin-bottom: 40px !important;
}

.mb45 {
	margin-bottom: 45px !important;
}

.mb50 {
	margin-bottom: 50px !important;
}

.mb55 {
	margin-bottom: 55px !important;
}

.mb60 {
	margin-bottom: 60px !important;
}

.mb65 {
	margin-bottom: 65px !important;
}

.mb70 {
	margin-bottom: 70px !important;
}

.mb75 {
	margin-bottom: 75px !important;
}

.mb80 {
	margin-bottom: 80px !important;
}

.mb85 {
	margin-bottom: 85px !important;
}

.mb90 {
	margin-bottom: 90px !important;
}

.mb95 {
	margin-bottom: 95px !important;
}

.mb100 {
	margin-bottom: 100px !important;
}

.fwb {
	font-weight: bold;
}

@media (max-width: 767px) {
	.lh2 {
		line-height: 1.8 !important;
	}

	.lh22 {
		line-height: 1.8 !important;
	}
}

@media (min-width: 768px) {
	.lh2 {
		line-height: 1.8 !important;
	}

	.lh22 {
		line-height: 2 !important;
	}
}

@media (min-width: 992px) {
	.lh2 {
		line-height: 2 !important;
	}

	.lh22 {
		line-height: 2.2 !important;
	}
}

.s11 {
	font-size: 11px !important;
	line-height: 1.6;
}

.s12 {
	font-size: 12px !important;
	line-height: 1.6;
}

.s13 {
	font-size: 13px !important;
	line-height: 1.6;
}

.s14 {
	font-size: 14px !important;
	line-height: 1.6;
}

.s14_c {
	font-size: 14px !important;
	line-height: 1.6;
	text-align: center;
}

@media (max-width: 767px) {
	.s15 {
		font-size: 14px !important;
		line-height: 1.7;
	}

	.s16 {
		font-size: 14px !important;
		line-height: 1.7;
	}

	.s15_c {
		font-size: 14px !important;
		line-height: 1.7;
		text-align: left;
	}

	.s16_c {
		font-size: 14px !important;
		line-height: 1.7;
		text-align: left;
	}
}

@media (min-width: 768px) {
	.s15 {
		font-size: 14px !important;
		line-height: 1.8;
	}

	.s16 {
		font-size: 15px !important;
		line-height: 1.8;
	}

	.s15_c {
		font-size: 14px !important;
		line-height: 1.8;
		text-align: center;
	}

	.s16_c {
		font-size: 15px !important;
		line-height: 1.8;
		text-align: center;
	}
}

@media (min-width: 992px) {
	.s15 {
		font-size: 15px !important;
		line-height: 1.8;
	}

	.s16 {
		font-size: 16px !important;
		line-height: 1.8;
	}

	.s15_c {
		font-size: 15px !important;
		line-height: 1.8;
		text-align: center;
	}

	.s16_c {
		font-size: 16px !important;
		line-height: 1.8;
		text-align: center;
	}
}

@media (min-width: 1200px) {
	.s15 {
		font-size: 15px !important;
		line-height: 1.8;
	}

	.s16 {
		font-size: 16px !important;
		line-height: 1.8;
	}

	.s15_c {
		font-size: 15px !important;
		line-height: 1.8;
		text-align: center;
	}

	.s16_c {
		font-size: 16px !important;
		line-height: 1.8;
		text-align: center;
	}
}


.s17 {
	font-size: 17px !important;
	line-height: 1.7;
}

.s18 {
	font-size: 18px !important;
	line-height: 1.7;
}

.s19 {
	font-size: 19px !important;
	line-height: 1.7;
}

.s20 {
	font-size: 20px !important;
	line-height: 1.7;
}

.s21 {
	font-size: 21px !important;
	line-height: 1.7;
}

.s22 {
	font-size: 22px !important;
	line-height: 1.7;
}

.s23 {
	font-size: 23px !important;
	line-height: 1.7;
}

.s24 {
	font-size: 24px !important;
	line-height: 1.7;
}

.s25 {
	font-size: 25px !important;
	line-height: 1.7;
}

.s26 {
	font-size: 26px !important;
	line-height: 1.7;
}

.s27 {
	font-size: 27px !important;
	line-height: 1.7;
}

.s28 {
	font-size: 28px !important;
	line-height: 1.7;
}

.s29 {
	font-size: 29px !important;
	line-height: 1.7;
}

.s30 {
	font-size: 30px !important;
	line-height: 1.7;
}

.br10 img {
	border-radius: 10px;
}

.br20 img {
	border-radius: 20px;
}

.br30 img {
	border-radius: 30px;
}

img.br10 {
	border-radius: 10px;
}

img.br20 {
	border-radius: 20px;
}

img.br30 {
	border-radius: 30px;
}

a.underline {
	text-decoration: underline;
}

a:hover {
	text-decoration: none;
	filter: alpha(opacity=70);
	-moz-opacity: 0.70;
	opacity: 0.70;
}

.pos {
	position: relative;
}

@media (max-width: 767px) {
	.flex_b {
		display: flex;
		flex-direction: column;
		justify-content: space-between;
	}

	.reverse_sp {
		flex-direction: column-reverse !important;
	}
}

@media (min-width: 768px) {
	.flex_b {
		display: flex;
		flex-direction: row;
		justify-content: space-between;
	}
}

@media (max-width: 767px) {
	.flex_c {
		display: flex;
		flex-direction: column;
		justify-content: center;
	}
}

@media (min-width: 768px) {
	.flex_c {
		display: flex;
		flex-direction: row;
		justify-content: center;
	}
}

@media (max-width: 767px) {
	.flex_s {
		display: flex;
		flex-direction: column;
		justify-content: flex-start;
	}
}

@media (min-width: 768px) {
	.flex_s {
		display: flex;
		flex-direction: row;
		justify-content: flex-start;
	}
}

@media (max-width: 767px) {
	.flex_e {
		display: flex;
		flex-direction: column;
	}
}

@media (min-width: 768px) {
	.flex_e {
		display: flex;
		flex-direction: row;
		justify-content: flex-end;
	}
}

.stretch {
	align-items: stretch;
}

.center {
	align-items: center;
}

.start {
	align-items: flex-start;
}

.end {
	align-items: flex-end;
}

.baseline {
	align-items: baseline;
}

.wrap {
	flex-wrap: wrap;
}


@media (max-width: 767px) {
	.cont20 {
		width: 100%;
	}

	.cont21 {
		width: 100%;
	}

	.cont22 {
		width: 100%;
	}

	.cont23 {
		width: 100%;
	}

	.cont24 {
		width: 100%;
	}

	.cont25 {
		width: 100%;
	}

	.cont26 {
		width: 100%;
	}

	.cont27 {
		width: 100%;
	}

	.cont28 {
		width: 100%;
	}

	.cont29 {
		width: 100%;
	}

	.cont30 {
		width: 100%;
	}

	.cont31 {
		width: 100%;
	}

	.cont32 {
		width: 100%;
	}

	.cont33 {
		width: 100%;
	}

	.cont34 {
		width: 100%;
	}

	.cont35 {
		width: 100%;
	}

	.cont36 {
		width: 100%;
	}

	.cont37 {
		width: 100%;
	}

	.cont38 {
		width: 100%;
	}

	.cont39 {
		width: 100%;
	}

	.cont40 {
		width: 100%;
	}

	.cont41 {
		width: 100%;
	}

	.cont42 {
		width: 100%;
	}

	.cont43 {
		width: 100%;
	}

	.cont44 {
		width: 100%;
	}

	.cont45 {
		width: 100%;
	}

	.cont46 {
		width: 100%;
	}

	.cont47 {
		width: 100%;
	}

	.cont48 {
		width: 100%;
	}

	.cont49 {
		width: 100%;
	}

	.cont50 {
		width: 100%;
	}

	.cont51 {
		width: 100%;
	}

	.cont52 {
		width: 100%;
	}

	.cont53 {
		width: 100%;
	}

	.cont54 {
		width: 100%;
	}

	.cont55 {
		width: 100%;
	}

	.cont56 {
		width: 100%;
	}

	.cont57 {
		width: 100%;
	}

	.cont58 {
		width: 100%;
	}

	.cont59 {
		width: 100%;
	}

	.cont60 {
		width: 100%;
	}

	.cont61 {
		width: 100%;
	}

	.cont62 {
		width: 100%;
	}

	.cont63 {
		width: 100%;
	}

	.cont64 {
		width: 100%;
	}

	.cont65 {
		width: 100%;
	}

	.cont66 {
		width: 100%;
	}

	.cont67 {
		width: 100%;
	}

	.cont68 {
		width: 100%;
	}

	.cont69 {
		width: 100%;
	}

	.cont70 {
		width: 100%;
	}

	.cont71 {
		width: 100%;
	}

	.cont72 {
		width: 100%;
	}

	.cont73 {
		width: 100%;
	}

	.cont74 {
		width: 100%;
	}

	.cont75 {
		width: 100%;
	}

	.cont76 {
		width: 100%;
	}

	.cont77 {
		width: 100%;
	}

	.cont78 {
		width: 100%;
	}

	.cont79 {
		width: 100%;
	}

	.cont80 {
		width: 100%;
	}
}

@media (min-width: 768px) {
	.cont20 {
		width: 20%;
	}

	.cont21 {
		width: 21%;
	}

	.cont22 {
		width: 22%;
	}

	.cont23 {
		width: 23%;
	}

	.cont24 {
		width: 24%;
	}

	.cont25 {
		width: 25%;
	}

	.cont26 {
		width: 26%;
	}

	.cont27 {
		width: 27%;
	}

	.cont28 {
		width: 28%;
	}

	.cont29 {
		width: 29%;
	}

	.cont30 {
		width: 30%;
	}

	.cont31 {
		width: 31%;
	}

	.cont32 {
		width: 32%;
	}

	.cont33 {
		width: 33%;
	}

	.cont34 {
		width: 34%;
	}

	.cont35 {
		width: 35%;
	}

	.cont36 {
		width: 36%;
	}

	.cont37 {
		width: 37%;
	}

	.cont38 {
		width: 38%;
	}

	.cont39 {
		width: 39%;
	}

	.cont40 {
		width: 40%;
	}

	.cont41 {
		width: 41%;
	}

	.cont42 {
		width: 42%;
	}

	.cont43 {
		width: 43%;
	}

	.cont44 {
		width: 44%;
	}

	.cont45 {
		width: 45%;
	}

	.cont46 {
		width: 46%;
	}

	.cont47 {
		width: 47%;
	}

	.cont48 {
		width: 48%;
	}

	.cont49 {
		width: 49%;
	}

	.cont50 {
		width: 50%;
	}

	.cont51 {
		width: 51%;
	}

	.cont52 {
		width: 52%;
	}

	.cont53 {
		width: 53%;
	}

	.cont54 {
		width: 54%;
	}

	.cont55 {
		width: 55%;
	}

	.cont56 {
		width: 56%;
	}

	.cont57 {
		width: 57%;
	}

	.cont58 {
		width: 58%;
	}

	.cont59 {
		width: 59%;
	}

	.cont60 {
		width: 60%;
	}

	.cont61 {
		width: 61%;
	}

	.cont62 {
		width: 62%;
	}

	.cont63 {
		width: 63%;
	}

	.cont64 {
		width: 64%;
	}

	.cont65 {
		width: 65%;
	}

	.cont66 {
		width: 66%;
	}

	.cont67 {
		width: 67%;
	}

	.cont68 {
		width: 68%;
	}

	.cont69 {
		width: 69%;
	}

	.cont70 {
		width: 70%;
	}

	.cont71 {
		width: 71%;
	}

	.cont72 {
		width: 72%;
	}

	.cont73 {
		width: 73%;
	}

	.cont74 {
		width: 74%;
	}

	.cont75 {
		width: 75%;
	}

	.cont76 {
		width: 76%;
	}

	.cont77 {
		width: 77%;
	}

	.cont78 {
		width: 78%;
	}

	.cont79 {
		width: 79%;
	}

	.cont80 {
		width: 80%;
	}
}

.img-responsive {}

@media (max-width: 420px) {
	.mb_mainimg {
		margin-bottom: 30px !important;
	}

	.mb_cont {
		margin-bottom: 40px !important;
	}

	.mb_cont2 {
		margin-bottom: 40px !important;
	}

	.mb_cont3 {
		margin-bottom: 20px !important;
	}

	.mb_cont4 {
		margin-bottom: 15px !important;
	}

	.mb_cont5 {
		margin-bottom: 10px !important;
	}
}

@media (min-width: 421px) {

	.mb_mainimg {
		margin-bottom: 40px !important;
	}

	.mb_cont {
		margin-bottom: 40px !important;
	}

	.mb_cont2 {
		margin-bottom: 40px !important;
	}

	.mb_cont3 {
		margin-bottom: 30px !important;
	}

	.mb_cont4 {
		margin-bottom: 20px !important;
	}

	.mb_cont5 {
		margin-bottom: 10px !important;
	}
}

@media (min-width: 768px) {

	.mb_mainimg {
		margin-bottom: 40px !important;
	}

	.mb_cont {
		margin-bottom: 50px !important;
	}

	.mb_cont2 {
		margin-bottom: 40px !important;
	}

	.mb_cont3 {
		margin-bottom: 30px !important;
	}

	.mb_cont4 {
		margin-bottom: 25px !important;
	}

	.mb_cont5 {
		margin-bottom: 15px !important;
	}
}

@media (min-width: 992px) {

	.mb_mainimg {
		margin-bottom: 50px !important;
	}

	.mb_cont {
		margin-bottom: 70px !important;
	}

	.mb_cont2 {
		margin-bottom: 50px !important;
	}

	.mb_cont3 {
		margin-bottom: 40px !important;
	}

	.mb_cont4 {
		margin-bottom: 30px !important;
	}

	.mb_cont5 {
		margin-bottom: 20px !important;
	}
}

.dn {
	display: none;
}

span.tel_link {
	color: #333;
}

span.tel_link_white {
	color: #fff;
}


/* header
=========================================================================== */

.inner_body {
	max-width: 1920px;
	margin: 0 auto;
	overflow: hidden;
}

@media (min-width: 992px) {
	header {
		width: 95.5%;
		height: 70px;
		background-color: #fff;
		max-width: 1834px;
		position: absolute;
		top: 30px;
		right: 50%;
		left:inherit;
		transform: translateY(0) translateX(50%);
		z-index: 99;
}

.flex_h {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: space-between;
	max-width: 1920px;
}

.flex_right {
	width: auto;
	display: flex;
	flex-direction: row;
	align-items: flex-end;
}

	.container-fluid {
		padding: 0;
	}
}

@media (min-width: 1200px) {
	header {
		width: 95.5%;
		height: 80px;
		background-color: #fff;
		max-width: 1834px;
		position: absolute;
		top: 30px;
		right: 50%;
		left:inherit;
		transform: translateY(0) translateX(50%);
		z-index: 99;
}

.flex_h {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: space-between;
	max-width: 1920px;
}

.flex_right {
	width: auto;
	display: flex;
	flex-direction: row;
	align-items: flex-end;
}

	.container-fluid {
		padding: 0;
	}
}




@media (max-width: 991px) {
	.info_h {
		display: none;
	}
}

@media (min-width: 992px) {
	.info_h {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: flex-end;
		margin-left: 30px;
	}

p.btn_h01 a {
	width: 100px;
	height: 70px;
	background-color: #0495FF;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-size: 15px;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
	letter-spacing: 0;
	flex-shrink: 0;
}

p.btn_h01 a:before {
content: '';
display: block;
background: url(../images/icon_h01.png) 0 0 /contain no-repeat;
width: 24px;
height: 26px;
margin-bottom: 3px;
}

p.btn_h01 a:hover {
	opacity: 1;
	background-color: #33a9fd;
}

p.btn_h02 a {
	width: 110px;
	height: 70px;
	background-color: #0070C0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-size: 15px;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
	letter-spacing: 0.05em;
	flex-shrink: 0;
}

p.btn_h02 a:before {
content: '';
display: block;
background: url(../images/icon_h02.png) 0 0 /contain no-repeat;
width: 24px;
height: 24px;
margin-bottom: 3px;
}

p.btn_h02 a:hover {
	opacity: 1;
	background-color: #1a8ddf;
}
}

@media (min-width: 1200px) {
	.info_h {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: flex-end;
		margin-left: 45px;
	}

p.btn_h01 a {
	width: 120px;
	height: 80px;
	background-color: #0495FF;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-size: 15px;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
	letter-spacing: 0.05em;
}

p.btn_h01 a:before {
content: '';
display: block;
background: url(../images/icon_h01.png) 0 0 /contain no-repeat;
width: 30px;
height: 32px;
margin-bottom: 3px;
}

p.btn_h01 a:hover {
	opacity: 1;
	background-color: #33a9fd;
}

p.btn_h02 a {
	width: 140px;
	height: 80px;
	background-color: #0070C0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-size: 15px;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
	letter-spacing: 0.05em;
}

p.btn_h02 a:before {
content: '';
display: block;
background: url(../images/icon_h02.png) 0 0 /contain no-repeat;
width: 30px;
height: 30px;
margin-bottom: 3px;
}

p.btn_h02 a:hover {
	opacity: 1;
	background-color: #1a8ddf;
}

}













/* navigation
=========================================================================== */

/*navbar ナビゲーション全体*/

.navbar {
	margin-bottom: 0;
	/*	デフォルトのマージンを消す*/
	border: none;
	/*	透明1px線を消す*/
	border-radius: 0;
	max-width: 1920px;
	margin: 0 auto;
}

.navbar-default {
	background-color: transparent;
	/*デフォルトの背景色を消す*/
}

/*
.clearfix:before,
.clearfix:after,
*/
.dl-horizontal dd:before,
.dl-horizontal dd:after,
.container:before,
.container:after,
.container-fluid:before,
.container-fluid:after,
.row:before,
.row:after,
/*
.form-horizontal .form-group:before,
.form-horizontal .form-group:after,
*/
.btn-toolbar:before,
.btn-toolbar:after,
.btn-group-vertical > .btn-group:before,
.btn-group-vertical > .btn-group:after,
.nav:before,
.nav:after,
.navbar:before,
.navbar:after,
.navbar-header:before,
.navbar-header:after,
.navbar-collapse:before,
.navbar-collapse:after,
.pager:before,
.pager:after,
.panel-body:before,
.panel-body:after,
.modal-header:before,
.modal-header:after,
.modal-footer:before,
.modal-footer:after {
	display: none;
	/*	自動で生成される疑似要素を消す　flex-boxでカウントされてしまう*/
}

.navbar-brand {
	padding: 0;
	/*	デフォルトのパディングを消す*/
}

/* navbar collapse for iPad (bootstrap) タブレットでもスマホ用ナビゲーションを使う*/
@media (max-width: 991px) {
	.navbar-header {
		float: none;
	}

	.navbar-toggle {
		display: block;
		margin-right: 5px;
	}

	.navbar-collapse {
		border-top: 1px solid transparent;
		box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1);
		margin-right: 0 !important;
		margin-left: 0 !important;
	}

	.navbar-collapse.collapse {
		display: none !important;
	}

	.navbar-nav {
		float: none !important;
		margin: 7.5px -15px;
	}

	.navbar-nav > li {
		float: none;
	}

	.navbar-nav > li > a {
		padding-top: 10px;
		padding-bottom: 10px;
	}

	.navbar-text {
		float: none;
		margin: 15px 0;
	}

	.navbar-collapse.collapse.in {
		display: block !important;
	}

	.collapsing {
		overflow: hidden !important;
	}
}

.navbar-default .navbar-toggle {
	border-color: transparent;
	/*	ハンバーガーメニューの背景色を消す*/
}

.navbar-default .navbar-toggle:hover,
.navbar-default .navbar-toggle:focus {
	background-color: transparent;
}

@media (min-width: 768px) {

	.navbar > .container .navbar-brand,
	.navbar > .container-fluid .navbar-brand {
		margin-left: 0;
	}
}

.navbar-brand a {
	display: block;
}

@media (max-width: 380px) {
	.navbar-brand {
		width: 80%;
		height: auto;
	}
}

@media (min-width: 381px) {
	.navbar-brand {
		width: 280px;
		height: auto;
	}
}

@media (min-width: 768px) {
	.navbar-brand {
		width: 360px;
		height: auto;
	}
}

@media (min-width: 992px) {
	.navbar-brand {
		width: 420px;
	}
}

@media (min-width: 1200px) {
	.navbar-brand {
		width: 480px;
	}
}

.navbar-brand a:hover {
	opacity: 0.85;
}

@media (max-width: 991px) {
	.navbar-nav > li > a {
		padding: 15px;
		font-size: 15px;
		font-weight: bold;
		color: #333;
		margin: 10px;
		border-radius: 2px;
		text-align: left;
		box-shadow: 0px 1px 3px 0px #ccc inset;
		text-decoration: none;
	}

	.navbar-nav > li {
		margin-bottom: 0px;
	}

	.navbar-nav > li > span {
		color: #999999;
		font-size: 10px;
		font-weight: normal;
		float: right;
		letter-spacing: 1px;
	}
}

@media (min-width: 992px) {

	.navbar-collapse {
		display: flex !important;
		align-items: center;
		width: auto;
		padding: 0;
	}

	.navbar-nav {
		background: none;
		float: none;
	}

	.navbar-nav > li {
		display: inline-block;
		font-size: 15px;
		margin-left: 10px;
	}

	.navbar-nav > li > a {
		font-size: 15px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.05em;
		color: #333 !important;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		height: 70px;
		padding: 0 10px;
	}

	.navbar-nav > li > a:hover {
		color: #0070C0 !important;
		opacity: 1;
		background-color: transparent !important;
	}

	.navbar-nav > li.active > a {
		color: #0070C0 !important;
		background-color: transparent !important;
	}

	.navbar-nav > li > a:after {
		position: absolute;
		bottom: 0;
		left: 0;
		content: '';
		width: 100%;
		height: 5px;
		background-color: #0070C0;
		transform: scale(0, 1);
		transform-origin: center top;
		transition: .3s;
	}

	.navbar-nav > li > a:hover:after {
		width: 100%;
		opacity: 1;
		transform: scale(1, 1);
	}

	.navbar-nav > li.active > a:after {
		width: 100%;
		opacity: 1;
		transform: scale(1, 1);
	}
}

@media (min-width: 1200px) {

	.navbar-collapse {
		display: flex !important;
		align-items: center;
		width: auto;
		padding: 0;
	}

	.navbar-nav {
		background: none;
		float: none;
	}

	.navbar-nav > li {
		display: inline-block;
		font-size: 15px;
		margin-left: 30px;
	}

	.navbar-nav > li > a {
		font-size: 15px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.05em;
		color: #333 !important;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		height: 70px;
		padding: 0 10px;
	}

	.navbar-nav > li > a:hover {
		color: #0070C0 !important;
		opacity: 1;
		background-color: transparent !important;
	}

	.navbar-nav > li.active > a {
		color: #0070C0 !important;
		background-color: transparent !important;
	}

	.navbar-nav > li > a:after {
		position: absolute;
		bottom: 0;
		left: 0;
		content: '';
		width: 100%;
		height: 5px;
		background-color: #0070C0;
		transform: scale(0, 1);
		transform-origin: center top;
		transition: .3s;
	}

	.navbar-nav > li > a:hover:after {
		width: 100%;
		opacity: 1;
		transform: scale(1, 1);
	}

	.navbar-nav > li.active > a:after {
		width: 100%;
		opacity: 1;
		transform: scale(1, 1);
	}
}


/*スマホグローバルナビ*/
@media (max-width: 767px) {
	.sp_fix {
		display: flex;
		justify-content: space-between;
		align-items: center;
		margin-right: 0 !important;
		margin-left: 0 !important;
		padding: 12px 0;
	}

	nav.navbar {
		background-color: #fff;
		box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.1);
		z-index: 999;
		position: fixed;
		top: 0;
		width: 100%;
	}

	.navbar-toggle {
		position: relative;
		width: 30px;
		height: 20px;
		border: none;
		background-color: transparent;
	}

	.navbar-toggle,
	.navbar-toggle > span {
		display: inline-block;
		/*transition: all .4s;*/
	}

	.navbar-toggle > span {
		position: absolute;
		right: 0;
		width: 100%;
		height: 2px;
		background-color: #333;
	}

	.navbar-toggle > span:nth-of-type(1) {
		top: 0;
	}

	.navbar-toggle > span:nth-of-type(2) {
		top: 9px;
	}

	.navbar-toggle > span:nth-of-type(3) {
		bottom: 0;
	}

	.navbar-toggle.active > span:nth-of-type(1) {
		-webkit-transform: translateY(9px) rotate(-45deg);
		transform: translateY(9px) rotate(-45deg);
	}

	.navbar-toggle.active > span:nth-of-type(2) {
		opacity: 0;
		-webkit-animation: active-menu-bar02 .8s forwards;
		animation: active-menu-bar02 .8s forwards;
	}

	.navbar-toggle.active > span:nth-of-type(3) {
		-webkit-transform: translateY(-9px) rotate(45deg);
		transform: translateY(-9px) rotate(45deg);
	}

	#gnav {
		overflow-y: scroll;
		width: 100%;
		background-color: #0070c0;
		position: relative;
		-webkit-overflow-scrolling: touch;
		padding-bottom: 1px;
		margin-bottom: 10px;
	}

	.navbar-nav > li > a {
		padding: 15px 15px;
		background-color: #fff;
		font-size: 14px;
		font-weight: bold;
		color: #333 !important;
		margin: 5px 10px;
		border-radius: 2px;
		text-align: left;
		text-decoration: none;
	}

	.navbar-nav > li.active > a {
		background-color: #cbe1f7 !important;
		color: #004690 !important;
	}

	.navbar-nav > li a > span {
		color: #7C9BEB;
		font-size: 10px;
		font-weight: normal;
		float: right;
		letter-spacing: 1px;
		display: none;
	}

	.navbar-nav > li > a:hover,
	.navbar-nav > li > a:focus {
		color: #004690 !important;
		background-color: #cbe1f7 !important;
		opacity: 1;
	}

	.navbar-nav > li > a:hover > span {
		color: #004690 !important;
	}
}

/*タブレットグローバルナビ*/
@media (min-width: 768px) and (max-width:991px) {
	.sp_fix {
		display: flex;
		justify-content: space-between;
		align-items: center;
		margin-right: 0 !important;
		margin-left: 0 !important;
		padding: 15px 0;
	}

	nav.navbar {
		background-color: #fff;
		box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.1);
		z-index: 999;
		position: fixed;
		top: 0;
		width: 100%;
	}

	.navbar-toggle {
		position: relative;
		width: 30px;
		height: 20px;
		border: none;
		background-color: transparent;
	}

	.navbar-toggle,
	.navbar-toggle > span {
		display: inline-block;
		/*transition: all .4s;*/
	}

	.navbar-toggle > span {
		position: absolute;
		right: 0;
		width: 100%;
		height: 2px;
		background-color: #333;
	}

	.navbar-toggle > span:nth-of-type(1) {
		top: 0;
	}

	.navbar-toggle > span:nth-of-type(2) {
		top: 9px;
	}

	.navbar-toggle > span:nth-of-type(3) {
		bottom: 0;
	}

	.navbar-toggle.active > span:nth-of-type(1) {
		-webkit-transform: translateY(9px) rotate(-45deg);
		transform: translateY(9px) rotate(-45deg);
	}

	.navbar-toggle.active > span:nth-of-type(2) {
		opacity: 0;
		-webkit-animation: active-menu-bar02 .8s forwards;
		animation: active-menu-bar02 .8s forwards;
	}

	.navbar-toggle.active > span:nth-of-type(3) {
		-webkit-transform: translateY(-9px) rotate(45deg);
		transform: translateY(-9px) rotate(45deg);
	}

	#gnav {
		overflow-y: scroll;
		width: 100%;
		background-color: #0070c0;
		position: relative;
		-webkit-overflow-scrolling: touch;
		padding-bottom: 1px;
		margin-bottom: 10px;
	}

	.navbar-nav > li > a {
		padding: 15px 15px;
		background-color: #fff;
		font-size: 14px;
		font-weight: bold;
		color: #333 !important;
		margin: 5px 10px;
		border-radius: 2px;
		text-align: left;
		text-decoration: none;
	}

	.navbar-nav > li.active > a {
		background-color: #cbe1f7 !important;
		color: #004690 !important;
	}

	.navbar-nav > li a > span {
		color: #7C9BEB;
		font-size: 10px;
		font-weight: normal;
		float: right;
		letter-spacing: 1px;
		display: none;
	}

	.navbar-nav > li > a:hover,
	.navbar-nav > li > a:focus {
		color: #004690 !important;
		background-color: #cbe1f7 !important;
		opacity: 1;
	}

	.navbar-nav > li > a:hover > span {
		color: #004690 !important;
	}
}


/* メインイメージ
=========================================================================== */

.inner_mainimg {
	width: 100%;
	position: relative;
	max-width: 1920px;
}

@media (max-width: 767px) {
	.bg_mainimg {
		position: relative;
		width: 100%;
		margin-top: 55px;
	}
}

@media (min-width: 768px) {
	.bg_mainimg {
		position: relative;
		width: 100%;
		margin-top: 60px;
	}
}

@media (min-width: 992px) {
	.bg_mainimg {
		position: relative;
		width: 100%;
		margin-top: 0;
	}
}

.swiper-container {
	overflow: visible !important;
}

.swiper-slide img {
	width: 100%;
	height: auto;
	/*	border-radius: 50px;*/
}

.swiper-slide {
	display: flex;
	flex-direction: row;
	align-items: center;
	flex-direction: row-reverse;
	overflow: hidden;
}

@media (max-width: 767px) {

	.swiper-button-next,
	.swiper-button-prev {
		display: none;
	}
}

@keyframes zoomUp {
	0% {
		transform: scale(1);
	}

	100% {
		transform: scale(1.15);
	}
}

.swiper-slide-active .slide-img,
.swiper-slide-duplicate-active .slide-img,
.swiper-slide-prev .slide-img {
	animation: zoomUp 10s linear 0s 1 normal both;
}

.slide-img img {
	display: block;
}

/*ページネーション　カスタム*/

@media (max-width: 991px) {
	.swiper-pagination-bullets {
		display: none;
	}
}

@media (min-width: 992px) {
	.swiper-pagination-bullets {
		right: 35px !important;
		top: 20% !important;
		left: inherit !important;
		display: flex;
		flex-direction: column;
		align-items: flex-end;
	}

	.swiper-pagination-bullet {
		border-radius: inherit;
		margin: 0 0 10px 0 !important;
		width: 100px;
		height: 5px;
	}

	.swiper-pagination-bullet {
		width: 8px !important;
		height: 8px !important;
		border-radius: 0 !important;
		background: #fff !important;
		opacity: 0.8 !important;
	}

	.swiper-pagination-bullet-active {
		background: #0495FF !important;
		opacity: 1 !important;
	}
}

@media (min-width: 1200px) {
	.swiper-pagination-bullets {
		position: absolute;
		bottom: 3%!important;
		left: 50%!important;
		transform: translateY(-50%) translateX(-50%)!important;
		/* left: inherit !important; */
		top:inherit!important;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
	}

	.swiper-pagination-bullet {
		border-radius: inherit;
		margin: 0 0 15px 0 !important;
		width: 100px;
		height: 5px;
	}

	.swiper-pagination-bullet {
		width: 10px !important;
		height: 10px !important;
		border-radius: 0 !important;
		background: #fff !important;
		opacity: 0.8 !important;
		margin-right: 15px!important;
	}

	.swiper-pagination-bullet-active {
		background: #0495FF !important;
		opacity: 1 !important;
	}
}

@media (max-width: 767px) {
	.catch_mainimg {
		width:94%;
		max-width:500px;
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translateY(-50%) translateX(-50%);
		z-index: 99;
	}
}

@media (min-width: 768px) {
	.catch_mainimg {
		width:70%;
		max-width: 1100px;
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translateY(-50%) translateX(-50%);
		z-index: 99;
	}
}

@media (min-width: 992px) {
	.catch_mainimg {
		width: 64%;
		max-width: 1100px;
		position: absolute;
		top: 56%;
		left: 50%;
		transform: translateY(-50%) translateX(-50%);
		z-index: 99;
	}
}

@media (min-width: 1200px) {
	.catch_mainimg {
		width: 57.29%;
		max-width: 1100px;
		position: absolute;
		top: 54%;
		left: 50%;
		transform: translateY(-50%) translateX(-50%);
		z-index: 99;
	}
}



/* スクロール */

@media (max-width: 991px) {
	.top_scroll {
		display: none;
	}
}

@media (min-width: 992px) {
	.top_scroll {
		position: absolute;
		right: 40px;
		bottom: 0;
		display: flex;
		flex-direction: column;
		z-index: 9999;
	}
}

p.ttl_scroll {
	font-size: 18px;
	color: #fff;
	font-family: 'Teko', sans-serif;
	transform: rotate(90deg);
	transform-origin: left top;
	letter-spacing: 0.2em;
	position: absolute;
	top: -80px;
	left: 12px;
	/*	text-shadow: 2px 2px 3px #085197;*/
}

.moveline {
	content: '';
	display: block;
	width: 1px;
	height: 120px;
	background-color: rgba(255, 255, 255, 0.3);
}

.moveline:before {
	content: '';
	display: block;
	z-index: 999999;
	animation-name: anime1;
	animation-duration: 2.7s;
	animation-timing-function: ease-out;
	animation-iteration-count: infinite;
}

@keyframes anime1 {
	0% {
		width: 1px;
		height: 0;
		background-color: #fff;
	}

	25% {
		width: 1px;
		height: 120px;
		background-color: #fff;
	}

	45% {
		width: 1px;
		height: 120px;
		background-color: transparent;
	}

	100% {
		width: 1px;
		height: 120px;
		background-color: transparent;
	}
}


/* index.html
=========================================================================== */

@media (max-width: 767px) {

	.bg_top01 {
		padding: 30px 0;
	}
	.cont_top01 {
		width: 96%;
		margin: 0 auto 30px;
	}
	
	.pic_top01 {
		width: 96%;
		position: relative;
		padding: 0 0 20px;
		overflow: hidden;
		flex-shrink: 0;
		margin: 0 auto;
	}
	
	.pic_top01:after {
		content: '';
		display: block;
		width: 90%;
		height: 100px;
		background-color: #0070C0;
		position: absolute;
		left:5%;
		bottom: 0;
		z-index: -1;
	}
	
	.cont_top01 p.icon {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		margin-bottom: 5px;
	}

	.cont_top01 p.icon img {
		width: 30px;
	}

	.bg_top01 > .flex_e {
		margin-bottom: 40px!important;
	}

	.bg_top01 > .flex_s p.icon img {
		width: 38px;
	}
	
	.cont_top01 p.icon:after {
		content: '';
		display: block;
		background: url(../images/bdr_top01.png) 0 0 /contain no-repeat;
		width: 100px;
		height: 3px;
		margin: 10px auto 0;
	}
	
	p.en_top01 {
		font-size: 24px;
		color: #B3DFFF;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		margin-bottom: 10px;
		text-align: center;
	}
	
	p.en_top01 span {
		font-size: 36px;
		color: #0070BF;
	}
	
	p.en_yoko {
	display: none;
	}
	
	.cont_top01 h2 {
		font-size: 20px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
		margin-bottom: 15px;
		text-align: center;
	}
	
	.cont_top01 p.text {
		font-size: 15px;
		line-height: 1.8;
		padding: 0 15px;
	}

	p.btn_top a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		font-size: 14px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.05em;
		color: #0070C0;
		width: 180px;
		height: 46px;
		border: 2px solid #0070C0;
		border-radius: 30px;
		position: relative;
		margin: 15px auto 0;
	}
	
	p.btn_top a:after {
		content: '';
		display: block;
		background: url(../images/icon_btn_top01.png) 0 0 /contain no-repeat;
		width: 24px;
		height: 6px;
		position: absolute;
		top: 50%;
		right: 13px;
		transform: translateY(-50%) translateX(0);
	}
	
	p.btn_top a:hover {
		opacity: 1;
		background-color: #0070C0;
		color: #fff;
	}
	
	p.btn_top a:hover:after {
		background: url(../images/icon_btn_top01_hover.png) 0 0 /contain no-repeat;
	}
}

@media (min-width: 768px) and (max-width:991px) {
	.cont_top01 {
		width: 53%;
		margin-right: 3%;
	}
	
	.pic_top01 {
		width: 41%;
		position: relative;
		padding: 120px 0 120px;
		overflow: hidden;
		flex-shrink: 0;
	}
	
	.pic_top01:after {
		content: '';
		display: block;
		width: 150%;
		height: 200%;
		background-color: #0070C0;
		position: absolute;
		right:-80%;
		top: -200px;
		z-index: -1;
		transform: rotate(20deg);
	}
	
	.bg_top01 .flex_s .pic_top01:after {
		content: '';
		display: block;
		width: 150%;
		height: 200%;
		background-color: #0070C0;
		position: absolute;
		left:-80%;
		top: -200px;
		z-index: -1;
		transform: rotate(-20deg);
	}
	
	.cont_top01 p.icon {
		display: flex;
		flex-direction: row;
		align-items: baseline;
		margin-bottom: 5px;
	}

	.cont_top01 p.icon img {
		width: 30px;
	}

	.bg_top01 > .flex_s p.icon img {
		width: 38px;
	}
	
	.cont_top01 p.icon:after {
		content: '';
		display: block;
		background: url(../images/bdr_top01.png) 0 0 /contain no-repeat;
		width: 100px;
		height: 3px;
		margin-left: 15px;
	}
	
	p.en_top01 {
		font-size: 34px;
		color: #B3DFFF;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		margin-bottom: 20px;
		margin-left: -10px;
	}
	
	p.en_top01 span {
		font-size: 50px;
		color: #0070BF;
	}
	
	p.en_yoko {
		font-size: 11px;
		color: #0070C0;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		-webkit-writing-mode: vertical-rl;
		-ms-writing-mode: tb-rl;
		writing-mode: vertical-rl;
		margin-right: 30px;
		margin-bottom: 15px;
	}
	
	.cont_top01 h2 {
		font-size: 23px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
	}
	
	.cont_top01 h2:after {
		content: '';
		display: block;
		width: 50px;
		height: 2px;
		background-color: #0070C0;
		margin: 20px 0 0;
	}
	
	.cont_top01 p.text {
		font-size: 15px;
		line-height: 1.8;
	}

	p.btn_top a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		font-size: 15px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.05em;
		color: #0070C0;
		width: 200px;
		height: 46px;
		border: 2px solid #0070C0;
		border-radius: 30px;
		position: relative;
		margin-top: 15px;
	}
	
	p.btn_top a:after {
		content: '';
		display: block;
		background: url(../images/icon_btn_top01.png) 0 0 /contain no-repeat;
		width: 24px;
		height: 6px;
		position: absolute;
		top: 50%;
		right: 20px;
		transform: translateY(-50%) translateX(0);
	}
	
	p.btn_top a:hover {
		opacity: 1;
		background-color: #0070C0;
		color: #fff;
	}
	
	p.btn_top a:hover:after {
		background: url(../images/icon_btn_top01_hover.png) 0 0 /contain no-repeat;
	}
	
	.bg_top01 .flex_s .cont_top01 {
		margin-right: 0;
		margin-left: 5%;
	}
}

@media (min-width: 992px) and (max-width: 1199px)  {
	.cont_top01 {
		width: 53%;
		margin-right: 3%;
	}
	
	.pic_top01 {
		width: 41%;
		position: relative;
		padding: 100px 0 100px;
		overflow: hidden;
		flex-shrink: 0;
	}
	
	.pic_top01:before {
		content: '';
		display: block;
		border-top: 80px solid #fff;
		border-right: 85px solid transparent;
		position: absolute;
		left:0;
		top:90px;
	}
	
	.pic_top01:after {
		content: '';
		display: block;
		width: 150%;
		height: 200%;
		background-color: #0070C0;
		position: absolute;
		right:-80%;
		top: -200px;
		z-index: -1;
		transform: rotate(22deg);
	}
	
	.bg_top01 .flex_s .pic_top01:before {
		content: '';
		display: block;
		border-top: 60px solid #fff;
		border-left: 65px solid transparent;
		border-right:none;
		position: absolute;
		left:inherit;
		right:0;
		top:60px;
	}
	
	.bg_top01 .flex_s .pic_top01:after {
		content: '';
		display: block;
		width: 150%;
		height: 200%;
		background-color: #0070C0;
		position: absolute;
		left:-80%;
		top: -200px;
		z-index: -1;
		transform: rotate(-22deg);
	}
	
	.cont_top01 p.icon {
		display: flex;
		flex-direction: row;
		align-items: baseline;
		margin-bottom: 5px;
	}

	.cont_top01 p.icon img {
		width: 30px;
	}

	.bg_top01 > .flex_s p.icon img {
		width: 38px;
	}
	
	.cont_top01 p.icon:after {
		content: '';
		display: block;
		background: url(../images/bdr_top01.png) 0 0 /contain no-repeat;
		width: 120px;
		height: 3px;
		margin-left: 25px;
	}
	
	p.en_top01 {
		font-size: 60px;
		color: #B3DFFF;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		margin-bottom: 20px;
		margin-left: -10px;
	}
	
	p.en_top01 span {
		font-size: 70px;
		color: #0070BF;
	}
	
	p.en_yoko {
		font-size: 15px;
		color: #0070C0;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		-webkit-writing-mode: vertical-rl;
		-ms-writing-mode: tb-rl;
		writing-mode: vertical-rl;
		margin-right: 40px;
		margin-bottom: 15px;
	}
	
	.cont_top01 h2 {
		font-size: 25px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
	}
	
	.cont_top01 h2:after {
		content: '';
		display: block;
		width: 50px;
		height: 2px;
		background-color: #0070C0;
		margin: 30px 0 0;
	}
	
	.cont_top01 p.text {
		font-size: 15px;
		line-height: 1.8;
	}

	p.btn_top a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		font-size: 16px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.05em;
		color: #0070C0;
		width: 220px;
		height: 46px;
		border: 2px solid #0070C0;
		border-radius: 30px;
		position: relative;
		margin-top: 30px;
	}
	
	p.btn_top a:after {
		content: '';
		display: block;
		background: url(../images/icon_btn_top01.png) 0 0 /contain no-repeat;
		width: 24px;
		height: 6px;
		position: absolute;
		top: 50%;
		right: 20px;
		transform: translateY(-50%) translateX(0);
	}
	
	p.btn_top a:hover {
		opacity: 1;
		background-color: #0070C0;
		color: #fff;
	}
	
	p.btn_top a:hover:after {
		background: url(../images/icon_btn_top01_hover.png) 0 0 /contain no-repeat;
	}
	
	.bg_top01 .flex_s .cont_top01 {
		margin-right: 0;
		margin-left: 5%;
	}
}

@media (min-width: 1200px) and (max-width:1499px) {
	.cont_top01 {
		width: 53%;
		margin-right: 3%;
	}
	
	.pic_top01 {
		width: 41%;
		position: relative;
		padding: 100px 0 100px;
		overflow: hidden;
		flex-shrink: 0;
	}
	
	.pic_top01:before {
		content: '';
		display: block;
		border-top: 80px solid #fff;
		border-right: 85px solid transparent;
		position: absolute;
		left:0;
		top:90px;
	}
	
	.pic_top01:after {
		content: '';
		display: block;
		width: 150%;
		height: 200%;
		background-color: #0070C0;
		position: absolute;
		right:-80%;
		top: -200px;
		z-index: -1;
		transform: rotate(25deg);
	}
	
	.bg_top01 .flex_s .pic_top01:before {
		content: '';
		display: block;
		border-top: 80px solid #fff;
		border-left: 85px solid transparent;
		border-right:none;
		position: absolute;
		left:inherit;
		right:0;
		top:90px;
	}
	
	.bg_top01 .flex_s .pic_top01:after {
		content: '';
		display: block;
		width: 150%;
		height: 200%;
		background-color: #0070C0;
		position: absolute;
		left:-80%;
		top: -200px;
		z-index: -1;
		transform: rotate(-25deg);
	}
	
	.cont_top01 p.icon {
		display: flex;
		flex-direction: row;
		align-items: baseline;
		margin-bottom: 5px;
	}

	.cont_top01 p.icon img {
		width: 40px;
	}

	.bg_top01 > .flex_s p.icon img {
		width: 48px;
	}
	
	.cont_top01 p.icon:after {
		content: '';
		display: block;
		background: url(../images/bdr_top01.png) 0 0 /contain no-repeat;
		width: 120px;
		height: 3px;
		margin-left: 25px;
	}
	
	p.en_top01 {
		font-size: 70px;
		color: #B3DFFF;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		margin-bottom: 30px;
		margin-left: -10px;
	}
	
	p.en_top01 span {
		font-size: 90px;
		color: #0070BF;
	}
	
	p.en_yoko {
		font-size: 16px;
		color: #0070C0;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		-webkit-writing-mode: vertical-rl;
		-ms-writing-mode: tb-rl;
		writing-mode: vertical-rl;
		margin-right: 40px;
		margin-bottom: 20px;
	}
	
	.cont_top01 h2 {
		font-size: 27px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
	}
	
	.cont_top01 h2:after {
		content: '';
		display: block;
		width: 50px;
		height: 2px;
		background-color: #0070C0;
		margin: 30px 0 0;
	}
	
	.cont_top01 p.text {
		font-size: 15px;
		line-height: 2;
	}

	p.btn_top a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		font-size: 16px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.05em;
		color: #0070C0;
		width: 220px;
		height: 50px;
		border: 2px solid #0070C0;
		border-radius: 30px;
		position: relative;
		margin-top: 30px;
	}
	
	p.btn_top a:after {
		content: '';
		display: block;
		background: url(../images/icon_btn_top01.png) 0 0 /contain no-repeat;
		width: 24px;
		height: 6px;
		position: absolute;
		top: 50%;
		right: 20px;
		transform: translateY(-50%) translateX(0);
	}
	
	p.btn_top a:hover {
		opacity: 1;
		background-color: #0070C0;
		color: #fff;
	}
	
	p.btn_top a:hover:after {
		background: url(../images/icon_btn_top01_hover.png) 0 0 /contain no-repeat;
	}
	
	.bg_top01 .flex_s .cont_top01 {
		margin-right: 0;
		margin-left: 5%;
	}
}


@media (min-width: 1500px) {
	.cont_top01 {
		width: 46%;
		margin-right: 3%;
	}
	
	.pic_top01 {
		width: 41%;
		position: relative;
		padding: 90px 0 90px;
		overflow: hidden;
		flex-shrink: 0;
	}
	
	.pic_top01:before {
		content: '';
		display: block;
		border-top: 80px solid #fff;
		border-right: 85px solid transparent;
		position: absolute;
		left:0;
		top:90px;
	}
	
	.pic_top01:after {
		content: '';
		display: block;
		width: 150%;
		height: 200%;
		background-color: #0070C0;
		position: absolute;
		right:-80%;
		top: -200px;
		z-index: -1;
		transform: rotate(30deg);
	}
	
	.bg_top01 .flex_s .pic_top01:before {
		content: '';
		display: block;
		border-top: 80px solid #fff;
		border-left: 85px solid transparent;
		border-right:none;
		position: absolute;
		left:inherit;
		right:0;
		top:90px;
	}
	
	.bg_top01 .flex_s .pic_top01:after {
		content: '';
		display: block;
		width: 150%;
		height: 200%;
		background-color: #0070C0;
		position: absolute;
		left:-80%;
		top: -200px;
		z-index: -1;
		transform: rotate(-30deg);
	}
	
	.cont_top01 p.icon {
		display: flex;
		flex-direction: row;
		align-items: baseline;
		margin-bottom: 5px;
	}
	
	.cont_top01 p.icon:after {
		content: '';
		display: block;
		background: url(../images/bdr_top01.png) 0 0 /contain no-repeat;
		width: 120px;
		height: 3px;
		margin-left: 25px;
	}
	
	p.en_top01 {
		font-size: 102px;
		color: #B3DFFF;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		margin-bottom: 30px;
		margin-left: -10px;
	}
	
	p.en_top01 span {
		font-size: 130px;
		color: #0070BF;
	}
	
	p.en_yoko {
		font-size: 18px;
		color: #0070C0;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		-webkit-writing-mode: vertical-rl;
		-ms-writing-mode: tb-rl;
		writing-mode: vertical-rl;
		margin-right: 50px;
		margin-bottom: 25px;
	}
	
	.cont_top01 h2 {
		font-size: 29px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
	}
	
	.cont_top01 h2:after {
		content: '';
		display: block;
		width: 50px;
		height: 2px;
		background-color: #0070C0;
		margin: 30px 0 0;
	}
	
	.cont_top01 p.text {
		font-size: 16px;
		line-height: 2;
	}

	p.btn_top a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		font-size: 17px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.05em;
		color: #0070C0;
		width: 280px;
		height: 54px;
		border: 2px solid #0070C0;
		border-radius: 30px;
		position: relative;
		margin-top: 30px;
	}
	
	p.btn_top a:after {
		content: '';
		display: block;
		background: url(../images/icon_btn_top01.png) 0 0 /contain no-repeat;
		width: 30px;
		height: 8px;
		position: absolute;
		top: 50%;
		right: 30px;
		transform: translateY(-50%) translateX(0);
	}
	
	p.btn_top a:hover {
		opacity: 1;
		background-color: #0070C0;
		color: #fff;
	}
	
	p.btn_top a:hover:after {
		background: url(../images/icon_btn_top01_hover.png) 0 0 /contain no-repeat;
	}
	
	.bg_top01 .flex_s .cont_top01 {
		margin-right: 0;
		margin-left: 5%;
	}
}

@media (min-width: 1700px) {
	.cont_top01 {
		width: 36%;
		margin-right: 3%;
	}
	
	.pic_top01 {
		width: 41%;
		position: relative;
		padding: 90px 0 90px;
		overflow: hidden;
		flex-shrink: 0;
	}
	
	.pic_top01:before {
		content: '';
		display: block;
		border-top: 80px solid #fff;
		border-right: 85px solid transparent;
		position: absolute;
		left:0;
		top:90px;
	}
	
	.pic_top01:after {
		content: '';
		display: block;
		width: 150%;
		height: 200%;
		background-color: #0070C0;
		position: absolute;
		right:-80%;
		top: -200px;
		z-index: -1;
		transform: rotate(30deg);
	}
	
	.bg_top01 .flex_s .pic_top01:before {
		content: '';
		display: block;
		border-top: 80px solid #fff;
		border-left: 85px solid transparent;
		border-right:none;
		position: absolute;
		left:inherit;
		right:0;
		top:90px;
	}
	
	.bg_top01 .flex_s .pic_top01:after {
		content: '';
		display: block;
		width: 150%;
		height: 200%;
		background-color: #0070C0;
		position: absolute;
		left:-80%;
		top: -200px;
		z-index: -1;
		transform: rotate(-30deg);
	}
	
	.cont_top01 p.icon {
		display: flex;
		flex-direction: row;
		align-items: baseline;
		margin-bottom: 5px;
	}
	
	.cont_top01 p.icon:after {
		content: '';
		display: block;
		background: url(../images/bdr_top01.png) 0 0 /contain no-repeat;
		width: 120px;
		height: 3px;
		margin-left: 25px;
	}
	
	p.en_top01 {
		font-size: 102px;
		color: #B3DFFF;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		margin-bottom: 30px;
		margin-left: -10px;
	}
	
	p.en_top01 span {
		font-size: 130px;
		color: #0070BF;
	}
	
	p.en_yoko {
		font-size: 18px;
		color: #0070C0;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		-webkit-writing-mode: vertical-rl;
		-ms-writing-mode: tb-rl;
		writing-mode: vertical-rl;
		margin-right: 50px;
		margin-bottom: 25px;
	}
	
	.cont_top01 h2 {
		font-size: 29px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
	}
	
	.cont_top01 h2:after {
		content: '';
		display: block;
		width: 50px;
		height: 2px;
		background-color: #0070C0;
		margin: 30px 0 0;
	}
	
	.cont_top01 p.text {
		font-size: 16px;
		line-height: 2;
	}

	p.btn_top a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		font-size: 17px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.05em;
		color: #0070C0;
		width: 280px;
		height: 54px;
		border: 2px solid #0070C0;
		border-radius: 30px;
		position: relative;
		margin-top: 30px;
	}
	
	p.btn_top a:after {
		content: '';
		display: block;
		background: url(../images/icon_btn_top01.png) 0 0 /contain no-repeat;
		width: 30px;
		height: 8px;
		position: absolute;
		top: 50%;
		right: 30px;
		transform: translateY(-50%) translateX(0);
	}
	
	p.btn_top a:hover {
		opacity: 1;
		background-color: #0070C0;
		color: #fff;
	}
	
	p.btn_top a:hover:after {
		background: url(../images/icon_btn_top01_hover.png) 0 0 /contain no-repeat;
	}
	
	.bg_top01 .flex_s .cont_top01 {
		margin-right: 0;
		margin-left: 5%;
	}
}


@media (max-width: 767px) {
	#top02 {
		margin: 0 0 40px;
	}
	
	#top02 .cont42 p img {
		border-radius: 20px;
	}
	
	p.en_top02 {
		font-size: 24px;
		color: #ddd;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		text-align: center;
		margin-bottom: 10px;
	}
	
	p.en_top02 span {
		font-size: 36px;
		color: #545454;
	}
	
	h2.top02 {
		font-size: 20px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		text-align: center;
	}
	
	h2.top02:after {
		content: '';
		display: block;
		background: url(../images/bdr_top02.png) 0 0 /contain no-repeat;
		width: 100px;
		height: 3px;
		margin: 20px auto;
	}
	
	#top02 p.text {
		font-size: 15px;
		line-height: 1.8;
	}
	
	#top02 p.btn_top a {
		border: 2px solid #333;
		color: #333;
		width: 230px;
		margin: 15px auto 30px;
	}
	
	#top02 p.btn_top a:after {
		background: url(../images/icon_btn_top02.png) 0 0 /contain no-repeat;
	}
	
	#top02 p.btn_top a:hover {
		opacity: 1;
		background-color: #333;
		color: #fff;
	}
	
	#top02 p.btn_top a:hover:after {
		background: url(../images/icon_btn_top01_hover.png) 0 0 /contain no-repeat;
	}
}

@media (min-width: 768px) {
	#top02 {
		margin: 50px 0 60px;
	}
	
	#top02 .cont42 p img {
		border-radius: 30px;
	}
	
	p.en_top02 {
		font-size: 34px;
		color: #ddd;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		margin-bottom: 20px;
		margin-left: -10px;
	}
	
	p.en_top02 span {
		font-size: 50px;
		color: #545454;
	}
	
	h2.top02 {
		font-size: 23px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
	}
	
	h2.top02:after {
		content: '';
		display: block;
		background: url(../images/bdr_top02.png) 0 0 /contain no-repeat;
		width: 100px;
		height: 3px;
		margin: 25px 0;
	}
	
	#top02 p.text {
		font-size: 15px;
		line-height: 1.8;
	}
	
	#top02 p.btn_top a {
		border: 2px solid #333;
		color: #333;
		width: 250px;
		margin-right: 50px;
	}
	
	#top02 p.btn_top a:after {
		background: url(../images/icon_btn_top02.png) 0 0 /contain no-repeat;
	}
	
	#top02 p.btn_top a:hover {
		opacity: 1;
		background-color: #333;
		color: #fff;
	}
	
	#top02 p.btn_top a:hover:after {
		background: url(../images/icon_btn_top01_hover.png) 0 0 /contain no-repeat;
	}
}

@media (min-width: 992px) {
	#top02 {
		margin: 50px 0 70px;
	}
	
	#top02 .cont42 p img {
		border-radius: 30px;
	}
	
	p.en_top02 {
		font-size: 60px;
		color: #ddd;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		margin-bottom: 30px;
		margin-left: -10px;
	}
	
	p.en_top02 span {
		font-size: 70px;
		color: #545454;
	}
	
	h2.top02 {
		font-size: 25px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
	}
	
	h2.top02:after {
		content: '';
		display: block;
		background: url(../images/bdr_top02.png) 0 0 /contain no-repeat;
		width: 120px;
		height: 3px;
		margin: 30px 0;
	}
	
	#top02 p.text {
		font-size: 15px;
		line-height: 2;
	}
	
	#top02 p.btn_top a {
		border: 2px solid #333;
		color: #333;
		width: 270px;
		margin-right: 50px;
	}
	
	#top02 p.btn_top a:after {
		background: url(../images/icon_btn_top02.png) 0 0 /contain no-repeat;
	}
	
	#top02 p.btn_top a:hover {
		opacity: 1;
		background-color: #333;
		color: #fff;
	}
	
	#top02 p.btn_top a:hover:after {
		background: url(../images/icon_btn_top01_hover.png) 0 0 /contain no-repeat;
	}
}

@media (min-width: 1200px) {
	#top02 {
		margin: 70px 0 90px;
	}
	
	#top02 .cont42 p img {
		border-radius: 30px;
	}
	
	p.en_top02 {
		font-size: 70px;
		color: #ddd;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		margin-bottom: 30px;
		margin-left: -10px;
	}
	
	p.en_top02 span {
		font-size: 90px;
		color: #545454;
	}
	
	h2.top02 {
		font-size: 27px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
	}
	
	h2.top02:after {
		content: '';
		display: block;
		background: url(../images/bdr_top02.png) 0 0 /contain no-repeat;
		width: 120px;
		height: 3px;
		margin: 30px 0;
	}
	
	#top02 p.text {
		font-size: 15px;
		line-height: 2;
	}
	
	#top02 p.btn_top a {
		border: 2px solid #333;
		color: #333;
		width: 300px;
		margin-right: 50px;
	}
	
	#top02 p.btn_top a:after {
		background: url(../images/icon_btn_top02.png) 0 0 /contain no-repeat;
	}
	
	#top02 p.btn_top a:hover {
		opacity: 1;
		background-color: #333;
		color: #fff;
	}
	
	#top02 p.btn_top a:hover:after {
		background: url(../images/icon_btn_top01_hover.png) 0 0 /contain no-repeat;
	}
}

@media (min-width: 1500px) {
	#top02 {
		margin: 70px 0 90px;
	}
	
	#top02 .cont42 p img {
		border-radius: 30px;
	}
	
	p.en_top02 {
		font-size: 102px;
		color: #ddd;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		margin-bottom: 30px;
		margin-left: -10px;
	}
	
	p.en_top02 span {
		font-size: 130px;
		color: #545454;
	}
	
	h2.top02 {
		font-size: 32px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
	}
	
	h2.top02:after {
		content: '';
		display: block;
		background: url(../images/bdr_top02.png) 0 0 /contain no-repeat;
		width: 120px;
		height: 3px;
		margin: 30px 0;
	}
	
	#top02 p.text {
		font-size: 15px;
		line-height: 2;
	}
	
	#top02 p.btn_top a {
		border: 2px solid #333;
		color: #333;
		width: 300px;
		margin-right: 50px;
	}
	
	#top02 p.btn_top a:after {
		background: url(../images/icon_btn_top02.png) 0 0 /contain no-repeat;
	}
	
	#top02 p.btn_top a:hover {
		opacity: 1;
		background-color: #333;
		color: #fff;
	}
	
	#top02 p.btn_top a:hover:after {
		background: url(../images/icon_btn_top01_hover.png) 0 0 /contain no-repeat;
	}
}

@media (max-width: 767px) {
	.bg_top03 {
		width: 100%;
		padding: 40px 0 40px;
		background: url(../images/bg_top03.jpg) center center /cover no-repeat;
		color: #fff;
	}
	
	p.en_top03 {
		font-size: 24px;
		color: #fff;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		text-align: center;
		line-height: 1;
	}
	
	p.en_top03 span {
		color: #0070BF;
		font-size: 36px;
	}
	
	h2.top03 {
		font-size: 20px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		text-align: center;
		margin: 15px 0 30px;
	}
	
	p.text_top03 {
		font-size: 15px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		text-align: center;
		letter-spacing: 0.05em;
		margin-bottom: 30px;
		line-height: 1.6;
	}
	
	p.tel_top03 {
		font-size: 24px;
		font-family: 'Roboto', sans-serif;
		font-weight: 700;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		letter-spacing: 0.03em;
		margin-bottom: 10px;
	}
	
	p.tel_top03 span.tel_link {
		color: #fff;
	}
	
	p.tel_top03:before {
		content: '';
		display: block;
		background: url(../images/icon_top03_1.png) 0 0 /contain no-repeat;
		width: 12px;
		height: 20px;
		margin-right: 5px;
	}
	
	p.btn_top03 a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		width: 240px;
		height: 50px;
		border: 1px solid #fff;
		border-radius: 10px;
		color: #fff;
		font-size: 15px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.05em;
		margin: 0 auto;
	}
	
	p.btn_top03 a:before {
		content: '';
		display: block;
		background: url(../images/icon_top03_2.png) 0 0 /contain no-repeat;
		width: 20px;
		height: 20px;
		margin-right: 5px;
	}
	
	p.btn_top03 a:hover {
		opacity: 1;
		background-color: #fff;
		color: #333;
	}
	
	p.btn_top03 a:hover:before {
		background: url(../images/icon_top03_2_hover.png) 0 0 /contain no-repeat;
	}
}

@media (min-width: 768px) {
	.bg_top03 {
		width: 100%;
		padding: 50px 0 50px;
		background: url(../images/bg_top03.jpg) center center /cover no-repeat;
		color: #fff;
	}
	
	p.en_top03 {
		font-size: 34px;
		color: #fff;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		text-align: center;
		line-height: 1;
	}
	
	p.en_top03 span {
		color: #0070BF;
		font-size: 50px;
	}
	
	h2.top03 {
		font-size: 23px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		text-align: center;
		margin: 15px 0 40px;
	}
	
	p.text_top03 {
		font-size: 16px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		text-align: center;
		letter-spacing: 0.05em;
		margin-bottom: 40px;
	}
	
	p.tel_top03 {
		font-size: 26px;
		font-family: 'Roboto', sans-serif;
		font-weight: 700;
		display: flex;
		flex-direction: row;
		align-items: center;
		letter-spacing: 0.03em;
		margin-right: 50px;
	}
	
	p.tel_top03 span.tel_link {
		color: #fff;
	}
	
	p.tel_top03:before {
		content: '';
		display: block;
		background: url(../images/icon_top03_1.png) 0 0 /contain no-repeat;
		width: 16px;
		height: 24px;
		margin-right: 5px;
	}
	
	p.btn_top03 a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		width: 280px;
		height: 54px;
		border: 1px solid #fff;
		border-radius: 10px;
		color: #fff;
		font-size: 16px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.05em;
	}
	
	p.btn_top03 a:before {
		content: '';
		display: block;
		background: url(../images/icon_top03_2.png) 0 0 /contain no-repeat;
		width: 24px;
		height: 24px;
		margin-right: 7px;
	}
	
	p.btn_top03 a:hover {
		opacity: 1;
		background-color: #fff;
		color: #333;
	}
	
	p.btn_top03 a:hover:before {
		background: url(../images/icon_top03_2_hover.png) 0 0 /contain no-repeat;
	}
}

@media (min-width: 992px) {
	.bg_top03 {
		width: 100%;
		padding: 60px 0 60px;
		background: url(../images/bg_top03.jpg) center center /cover no-repeat;
		color: #fff;
	}
	
	p.en_top03 {
		font-size: 60px;
		color: #fff;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		text-align: center;
		line-height: 1;
	}
	
	p.en_top03 span {
		color: #0070BF;
		font-size: 70px;
	}
	
	h2.top03 {
		font-size: 25px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		text-align: center;
		margin: 15px 0 40px;
	}
	
	p.text_top03 {
		font-size: 18px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		text-align: center;
		letter-spacing: 0.05em;
		margin-bottom: 40px;
	}
	
	p.tel_top03 {
		font-size: 31px;
		font-family: 'Roboto', sans-serif;
		font-weight: 700;
		display: flex;
		flex-direction: row;
		align-items: center;
		letter-spacing: 0.03em;
		margin-right: 70px;
	}
	
	p.tel_top03 span.tel_link {
		color: #fff;
	}
	
	p.tel_top03:before {
		content: '';
		display: block;
		background: url(../images/icon_top03_1.png) 0 0 /contain no-repeat;
		width: 20px;
		height: 30px;
		margin-right: 5px;
	}
	
	p.btn_top03 a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		width: 330px;
		height: 60px;
		border: 1px solid #fff;
		border-radius: 10px;
		color: #fff;
		font-size: 18px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.05em;
	}
	
	p.btn_top03 a:before {
		content: '';
		display: block;
		background: url(../images/icon_top03_2.png) 0 0 /contain no-repeat;
		width: 30px;
		height: 30px;
		margin-right: 7px;
	}
	
	p.btn_top03 a:hover {
		opacity: 1;
		background-color: #fff;
		color: #333;
	}
	
	p.btn_top03 a:hover:before {
		background: url(../images/icon_top03_2_hover.png) 0 0 /contain no-repeat;
	}
}

@media (min-width: 1200px) {
	.bg_top03 {
		width: 100%;
		padding: 80px 0 80px;
		background: url(../images/bg_top03.jpg) center center /cover no-repeat;
		color: #fff;
	}
	
	p.en_top03 {
		font-size: 70px;
		color: #fff;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		text-align: center;
		line-height: 1;
	}
	
	p.en_top03 span {
		color: #0070BF;
		font-size: 90px;
	}
	
	h2.top03 {
		font-size: 26px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		text-align: center;
		margin: 15px 0 40px;
	}
	
	p.text_top03 {
		font-size: 20px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		text-align: center;
		letter-spacing: 0.05em;
		margin-bottom: 50px;
	}
	
	p.tel_top03 {
		font-size: 31px;
		font-family: 'Roboto', sans-serif;
		font-weight: 700;
		display: flex;
		flex-direction: row;
		align-items: center;
		letter-spacing: 0.03em;
		margin-right: 70px;
	}
	
	p.tel_top03 span.tel_link {
		color: #fff;
	}
	
	p.tel_top03:before {
		content: '';
		display: block;
		background: url(../images/icon_top03_1.png) 0 0 /contain no-repeat;
		width: 20px;
		height: 30px;
		margin-right: 5px;
	}
	
	p.btn_top03 a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		width: 330px;
		height: 60px;
		border: 1px solid #fff;
		border-radius: 10px;
		color: #fff;
		font-size: 18px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.05em;
	}
	
	p.btn_top03 a:before {
		content: '';
		display: block;
		background: url(../images/icon_top03_2.png) 0 0 /contain no-repeat;
		width: 30px;
		height: 30px;
		margin-right: 7px;
	}
	
	p.btn_top03 a:hover {
		opacity: 1;
		background-color: #fff;
		color: #333;
	}
	
	p.btn_top03 a:hover:before {
		background: url(../images/icon_top03_2_hover.png) 0 0 /contain no-repeat;
	}
}

@media (min-width: 1500px) {
	.bg_top03 {
		width: 100%;
		padding: 100px 0 90px;
		background: url(../images/bg_top03.jpg) center center /cover no-repeat;
		color: #fff;
	}
	
	p.en_top03 {
		font-size: 86px;
		color: #fff;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		text-align: center;
		line-height: 1;
	}
	
	p.en_top03 span {
		color: #0070BF;
	}
	
	h2.top03 {
		font-size: 26px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		text-align: center;
		margin: 15px 0 40px;
	}
	
	p.text_top03 {
		font-size: 22px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		text-align: center;
		letter-spacing: 0.05em;
		margin-bottom: 50px;
	}
	
	p.tel_top03 {
		font-size: 31px;
		font-family: 'Roboto', sans-serif;
		font-weight: 700;
		display: flex;
		flex-direction: row;
		align-items: center;
		letter-spacing: 0.03em;
		margin-right: 70px;
	}
	
	p.tel_top03 span.tel_link {
		color: #fff;
	}
	
	p.tel_top03:before {
		content: '';
		display: block;
		background: url(../images/icon_top03_1.png) 0 0 /contain no-repeat;
		width: 20px;
		height: 30px;
		margin-right: 5px;
	}
	
	p.btn_top03 a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		width: 330px;
		height: 60px;
		border: 1px solid #fff;
		border-radius: 10px;
		color: #fff;
		font-size: 18px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.05em;
	}
	
	p.btn_top03 a:before {
		content: '';
		display: block;
		background: url(../images/icon_top03_2.png) 0 0 /contain no-repeat;
		width: 30px;
		height: 30px;
		margin-right: 7px;
	}
	
	p.btn_top03 a:hover {
		opacity: 1;
		background-color: #fff;
		color: #333;
	}
	
	p.btn_top03 a:hover:before {
		background: url(../images/icon_top03_2_hover.png) 0 0 /contain no-repeat;
	}
}


/* フッター
=========================================================================== */

@media (max-width: 767px) {
	footer {
		padding: 40px 0 0;
	}
	
	.footer_l {
		width: 100%;
	}
	
	.footer_r {
		width: 100%;
	}
	
	p.logo_f {
		width: 270px;
		margin: 0 auto 25px;
	}
	
	p.logo_f a {
		display: block;
	}
	
	p.text_f {
		font-size: 15px;
		text-align: center;
		margin-bottom: 20px;
		letter-spacing: 0.05em;
	}
	
	p.tel_f {
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		color: #0070BF;
		font-size: 16px;
		text-align: center;
		line-height: 1;
		margin-bottom: 12px;
	}
	
	p.tel_f span.tel_link {
		color: #0070BF;
	}
	
	ul.fnav {
		width: 100%;
		display: flex;
		flex-direction: column;
		align-items: center;
		background-color: #ecf5fb;
		padding: 15px 5px;
		max-width: 200px;
		margin: 15px auto 30px;
		border-radius: 10px;
	}
	
	ul.fnav li {
		margin-bottom: 7px;
	}
	
	ul.fnav li a {
		font-size: 14px;
		color: #0070C0;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.05em;
		display: flex;
		flex-direction: row;
		align-items: center;
	}
	
	ul.fnav li a:before {
		content: "\f0da";
	font-family: 'Font Awesome\ 5 Free';
	font-weight: 900;
	margin-right: 6px;
	color: #7FB7DF;
	}
	
	p.copyright {
		width: 100%;
		height: 30px;
		background-color: #0070C0;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		font-size: 10px;
		color: #fff;
	}
}

@media (min-width: 768px) {
	footer {
		padding: 60px 0 0;
	}
	
	.footer_l {
		width: 49%;
	}
	
	.footer_r {
		width: 49%;
	}
	
	p.logo_f {
		width: 330px;
		margin-bottom: 25px;
	}
	
	p.logo_f a {
		display: block;
	}
	
	p.text_f {
		font-size: 15px;
		margin-bottom: 20px;
		letter-spacing: 0.05em;
	}
	
	p.tel_f {
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		color: #0070BF;
		font-size: 16px;
	}
	
	p.tel_f span.tel_link {
		color: #0070BF;
	}
	
	ul.fnav {
		width: 100%;
		display: flex;
		flex-wrap: wrap;
		flex-direction: row;
		justify-content: flex-end;
		margin-bottom: 0;
		padding-top: 5px;
	}
	
	ul.fnav li {
		margin-left: 30px;
		margin-bottom: 15px;
	}
	
	ul.fnav li a {
		font-size: 15px;
		color: #0070C0;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.05em;
		display: flex;
		flex-direction: row;
		align-items: center;
	}
	
	ul.fnav li a:before {
		content: "\f0da";
	font-family: 'Font Awesome\ 5 Free';
	font-weight: 900;
	margin-right: 6px;
	color: #7FB7DF;
	}
	
	p.copyright {
		width: 100%;
		height: 36px;
		background-color: #0070C0;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		font-size: 12px;
		color: #fff;
		margin-top: 90px;
	}
}

@media (min-width: 992px) {
	footer {
		padding: 80px 0 0;
	}
	
	.footer_l {
		width: 40%;
	}
	
	.footer_r {
		width: 60%;
	}
	
	p.logo_f {
		width: 380px;
		margin-bottom: 25px;
	}
	
	p.logo_f a {
		display: block;
	}
	
	p.text_f {
		font-size: 15px;
		margin-bottom: 20px;
		letter-spacing: 0.05em;
	}
	
	p.tel_f {
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		color: #0070BF;
		font-size: 18px;
	}
	
	p.tel_f span.tel_link {
		color: #0070BF;
	}
	
	ul.fnav {
		width: 100%;
		display: flex;
		flex-direction: row;
		justify-content: flex-end;
		margin-bottom: 0;
		padding-top: 5px;
	}
	
	ul.fnav li {
		margin-left: 25px;
	}
	
	ul.fnav li a {
		font-size: 15px;
		color: #0070C0;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.05em;
		display: flex;
		flex-direction: row;
		align-items: center;
	}
	
	ul.fnav li a:before {
		content: "\f0da";
	font-family: 'Font Awesome\ 5 Free';
	font-weight: 900;
	margin-right: 6px;
	color: #7FB7DF;
	}
	
	p.copyright {
		width: 100%;
		height: 36px;
		background-color: #0070C0;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		font-size: 12px;
		color: #fff;
		margin-top: 90px;
	}
}

@media (min-width: 1200px) {
	footer {
		padding: 90px 0 0;
	}
	
	.footer_l {
		width: 45%;
	}
	
	.footer_r {
		width: 54%;
	}
	
	p.logo_f {
		width: 440px;
		margin-bottom: 25px;
	}
	
	p.logo_f a {
		display: block;
	}
	
	p.text_f {
		font-size: 15px;
		margin-bottom: 20px;
		letter-spacing: 0.05em;
	}
	
	p.tel_f {
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		color: #0070BF;
		font-size: 18px;
	}
	
	p.tel_f span.tel_link {
		color: #0070BF;
	}
	
	ul.fnav {
		width: 100%;
		display: flex;
		flex-direction: row;
		justify-content: flex-end;
		margin-bottom: 0;
		padding-top: 5px;
	}
	
	ul.fnav li {
		margin-left: 35px;
	}
	
	ul.fnav li a {
		font-size: 15px;
		color: #0070C0;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.05em;
		display: flex;
		flex-direction: row;
		align-items: center;
	}
	
	ul.fnav li a:before {
		content: "\f0da";
	font-family: 'Font Awesome\ 5 Free';
	font-weight: 900;
	margin-right: 6px;
	color: #7FB7DF;
	}
	
	p.copyright {
		width: 100%;
		height: 36px;
		background-color: #0070C0;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		font-size: 12px;
		color: #fff;
		margin-top: 90px;
	}
}

@media (max-width: 767px) {
	p.pagetop a {
		position: fixed;
		bottom: 45px;
		right: 15px;
		width: 30px;
		height: 30px;
		z-index: 999;
	}

	p.pagetop a img {
		width: 30px;
		height: 30px;
	}
}

@media (min-width: 768px) {
	p.pagetop a {
		position: fixed;
		bottom: 70px;
		right: 25px;
		width: 40px;
		height: 40px;
		z-index: 999;
	}

	p.pagetop a img {
		width: 40px;
		height: 40px;
	}
}

@media (min-width: 1921px) {
	p.pagetop a {
		position: fixed;
		bottom: 70px;
		right: calc(50% - 920px);
		width: 40px;
		height: 40px;
		z-index: 99;
	}

	p.pagetop a img {
		width: 40px;
		height: 40px;
	}
}


/* サブページ共通
=========================================================================== */

@media (max-width: 767px) {
	.bg_sub {
		width: 100%;
		height: 160px;
		border-bottom: 2px solid #0070C0;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		position: relative;
		margin-top: 55px;
	}
	
	h2.sub {
		color: #fff;
		font-size: 21px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
		text-align: center;
	}
	
	.bg_sub p.en {
		font-size: 13px;
		color: #fff;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		text-align: center;
		letter-spacing: 0.05em;
		line-height: 1;
		margin-top: 5px;
		background-color: #0070C0;
		padding: 0.3em;
	}
	
	.bg_sub p.en02 {
		font-size: 45px;
		line-height: 1;
		font-family: 'Roboto', sans-serif;
		word-break: keep-all;
		font-weight: 500;
		position: absolute;
		bottom: 130px;
		left: 50%;
		transform: translateY(0) translateX(-50%);
		color: #fff;
		opacity: 0.3;
		width: 100%;
		text-align: center;
	}
}

@media (min-width: 768px) {
	.bg_sub {
		width: 100%;
		height: 240px;
		border-bottom: 3px solid #0070C0;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		position: relative;
		margin-top: 65px;
	}
	
	.bg_sub .inner {
		padding: 15px 40px 10px;
		background-color: #fff;
		position: absolute;
		bottom: -3px;
		left: 50%;
		transform: translateY(0) translateX(-50%);
		border-top: 3px solid #0070C0;
		border-left: 3px solid #0070C0;
		border-right: 3px solid #0070C0;
	}
	
	h2.sub {
		color: #0070C0;
		font-size: 22px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
		text-align: center;
	}
	
	.bg_sub p.en {
		font-size: 16px;
		color: #B2DFFF;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		text-align: center;
		letter-spacing: 0.05em;
		line-height: 1;
		margin-top: 10px;
	}
	
	.bg_sub p.en::first-letter {
		color: #0070C0;
	}
	
	.bg_sub p.en02 {
		font-size: 45px;
		line-height: 1;
		font-family: 'Roboto', sans-serif;
		word-break: keep-all;
		font-weight: 500;
		position: absolute;
		bottom: 130px;
		left: 50%;
		transform: translateY(0) translateX(-50%);
		color: #fff;
		opacity: 0.3;
		width: 100%;
		text-align: center;
	}
}

@media (min-width: 992px) {
	.bg_sub {
		width: 100%;
		height: 330px;
		border-bottom: 3px solid #0070C0;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		position: relative;
		margin-top: 0;
	}
	
	.bg_sub .inner {
		padding: 15px 50px 10px;
		background-color: #fff;
		position: absolute;
		bottom: -3px;
		left: 50%;
		transform: translateY(0) translateX(-50%);
		border-top: 3px solid #0070C0;
		border-left: 3px solid #0070C0;
		border-right: 3px solid #0070C0;
	}
	
	h2.sub {
		color: #0070C0;
		font-size: 24px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
		text-align: center;
	}
	
	.bg_sub p.en {
		font-size: 16px;
		color: #B2DFFF;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		text-align: center;
		letter-spacing: 0.05em;
		line-height: 1;
		margin-top: 10px;
	}
	
	.bg_sub p.en::first-letter {
		color: #0070C0;
	}
	
	.bg_sub p.en02 {
		font-size: 45px;
		line-height: 1;
		font-family: 'Roboto', sans-serif;
		word-break: keep-all;
		font-weight: 500;
		position: absolute;
		bottom: 130px;
		left: 50%;
		transform: translateY(0) translateX(-50%);
		color: #fff;
		opacity: 0.3;
		width: 100%;
		text-align: center;
	}
}

@media (min-width: 1200px) {
	.bg_sub {
		width: 100%;
		height: 360px;
		border-bottom: 4px solid #0070C0;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		position: relative;
	}
	
	.bg_sub .inner {
		padding: 20px 50px 15px;
		background-color: #fff;
		position: absolute;
		bottom: -4px;
		left: 50%;
		transform: translateY(0) translateX(-50%);
		border-top: 4px solid #0070C0;
		border-left: 4px solid #0070C0;
		border-right: 4px solid #0070C0;
	}
	
	h2.sub {
		color: #0070C0;
		font-size: 30px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
		text-align: center;
	}
	
	.bg_sub p.en {
		font-size: 20px;
		color: #B2DFFF;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		text-align: center;
		letter-spacing: 0.05em;
		line-height: 1;
		margin-top: 10px;
	}
	
	.bg_sub p.en::first-letter {
		color: #0070C0;
	}
	
	.bg_sub p.en02 {
		font-size: 45px;
		line-height: 1;
		font-family: 'Roboto', sans-serif;
		word-break: keep-all;
		font-weight: 500;
		position: absolute;
		bottom: 130px;
		left: 50%;
		transform: translateY(0) translateX(-50%);
		color: #fff;
		opacity: 0.3;
		width: 100%;
		text-align: center;
	}
}

@media (max-width: 767px) {
	.bg_business {
		background: url(../images/bg_business_sp.jpg) center center /cover no-repeat;
	}
	
	.bg_company {
		background: url(../images/bg_company_sp.jpg) center center /cover no-repeat;
	}
	
	.bg_recruit {
		background: url(../images/bg_recruit_sp.jpg) center center /cover no-repeat;
	}
	
	.bg_contact {
		background: url(../images/bg_contact_sp.jpg) center center /cover no-repeat;
	}
}

@media (min-width: 768px) {
	.bg_business {
		background: url(../images/bg_business.jpg) center center /cover no-repeat;
	}
	
	.bg_company {
		background: url(../images/bg_company.jpg) center center /cover no-repeat;
	}
	
	.bg_recruit {
		background: url(../images/bg_recruit.jpg) center center /cover no-repeat;
	}
	
	.bg_contact {
		background: url(../images/bg_contact.jpg) center center /cover no-repeat;
	}
}


/* business.html　事業内容
=========================================================================== */

@media (max-width: 991px) {
	#business01,#business02 {
		margin-top: -80px;
		padding-top: 80px;
	}
}

@media (min-width: 992px) {
	#business01,#business02 {
		margin-top: -30px;
		padding-top: 30px;
	}
}

@media (max-width: 767px) {
	p.intro_sub {
		font-size: 14px;
		line-height: 1.8;
		margin-bottom: 25px;
	}
	
	ul.nav_sub {
		width: 100%;
		display: flex;
		flex-direction: row;
		flex-wrap: wrap;
		align-items: center;
		margin-left: 5px;
	}
	
	ul.nav_sub li {
		margin: 0 10px 10px 0;
		flex: auto;
	
	}
	
	ul.nav_sub li a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		border: 1px solid #0070C0;
		font-size: 15px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.1em;
		padding: 0.5em 0.5em;
	}
	
	p.en_business {
		color: #B2DFFF;
		font-size: 16px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		margin-bottom: 10px;
	}
	
	p.en_business b {
		color: #0070BF;
	}
	
	h3.business {
		font-size: 23px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
	}
	
	h3.business:after {
		content: '';
		display: block;
		width: 30px;
		height: 2px;
		background-color: #0070C0;
		margin: 15px 0 15px;
	}

	#business01 p.pic,#business02 p.pic {
		margin-top: 15px;
	}
	
	.bg_blue {
		width: 100%;
		background-color: #f2f9ff;
		padding: 40px 0;
	}
	
	h4.business {
	color: #0070BF;
	font-size: 18px;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	letter-spacing: 0.1em;
	word-break: keep-all;
	margin-bottom: 15px;
	border-bottom: 1px solid #0070BF;
	padding-bottom: 10px;
	}
	
	h5.business {
		font-size: 16px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.05em;
		display: flex;
		flex-direction: row;
		align-items: center;
		margin-bottom: 8px;
		line-height: 1.4;
	}
	
	h5.business span {
		width: 24px;
		height: 24px;
		background-color: #45AAC7;
		border-radius: 50%;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		color: #fff;
		font-size: 13px;
		margin-right: 7px;
		flex-shrink: 0;
	}
	
	.inner_business02 {
		border: 1px solid #0070BF;
		padding: 15px 10px;
		margin-top: 15px;
		background-color: #fff;
	}

	.inner_business02 dl {
		margin-bottom: 10px;
		display: flex;
		flex-direction: column;
	}

	.inner_business02 dl:last-of-type {
		margin-bottom: 0;
	}

	.inner_business02 dt {
		margin-bottom: 4px;
	}

	.inner_business02 dd {
		padding-left: 0.5em;
	}
}

@media (min-width: 768px) {
	p.intro_sub {
		text-align: center;
		font-size: 15px;
		letter-spacing: 0.07em;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		line-height: 1.8;
		margin-bottom: 30px;
	}
	
	ul.nav_sub {
		width: 100%;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
	}
	
	ul.nav_sub li {
		margin: 0 1% 0 0;
		flex: auto;
	
	}
	
	ul.nav_sub li:last-child {
		margin-right: 0;
	}
	
	ul.nav_sub li a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		border: 1px solid #0070C0;
		font-size: 16px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.1em;
		padding: 0.5em 1em;
	}
	
	p.en_business {
		color: #B2DFFF;
		font-size: 20px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		margin-bottom: 15px;
	}
	
	p.en_business b {
		color: #0070BF;
	}
	
	h3.business {
		font-size: 28px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
	}
	
	h3.business:after {
		content: '';
		display: block;
		width: 50px;
		height: 2px;
		background-color: #0070C0;
		margin: 25px 0 20px;
	}
	
	.bg_blue {
		width: 100%;
		background-color: #f2f9ff;
		padding: 40px 0;
	}
	
	h4.business {
	color: #0070BF;
	font-size: 21px;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	letter-spacing: 0.1em;
	word-break: keep-all;
	margin-bottom: 20px;
	border-bottom: 1px solid #0070BF;
	padding-bottom: 10px;
	}
	
	h5.business {
		font-size: 19px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.05em;
		display: flex;
		flex-direction: row;
		align-items: center;
		margin-bottom: 8px;
	}
	
	h5.business span {
		width: 30px;
		height: 30px;
		background-color: #45AAC7;
		border-radius: 50%;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		color: #fff;
		font-size: 15px;
		margin-right: 15px;
	}
	
	.inner_business02 {
		border: 1px solid #0070BF;
		padding: 15px;
		margin-top: 15px;
		background-color: #fff;
	}

	.inner_business02 dl {
		margin-bottom: 10px;
		display: flex;
		flex-direction: row;
	}

	.inner_business02 dl:last-of-type {
		margin-bottom: 0;
	}
}

@media (min-width: 992px) {
	p.intro_sub {
		text-align: center;
		font-size: 16px;
		letter-spacing: 0.07em;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		line-height: 2;
		margin-bottom: 40px;
	}
	
	ul.nav_sub {
		width: 100%;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
	}
	
	ul.nav_sub li {
		margin: 0 1% 0 0;
		flex: auto;
	
	}
	
	ul.nav_sub li:last-child {
		margin-right: 0;
	}
	
	ul.nav_sub li a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		border: 1px solid #0070C0;
		font-size: 18px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.1em;
		padding: 0.5em 1em;
	}
	
	p.en_business {
		color: #B2DFFF;
		font-size: 30px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		margin-bottom: 20px;
	}
	
	p.en_business b {
		color: #0070BF;
	}
	
	h3.business {
		font-size: 36px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
	}
	
	h3.business:after {
		content: '';
		display: block;
		width: 50px;
		height: 2px;
		background-color: #0070C0;
		margin: 25px 0;
	}
	
	.bg_blue {
		width: 100%;
		background-color: #f2f9ff;
		padding: 60px 0;
	}
	
	h4.business {
	color: #0070BF;
	font-size: 24px;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	letter-spacing: 0.1em;
	word-break: keep-all;
	margin-bottom: 20px;
	border-bottom: 1px solid #0070BF;
	padding-bottom: 10px;
	}
	
	h5.business {
		font-size: 20px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.05em;
		display: flex;
		flex-direction: row;
		align-items: center;
		margin-bottom: 10px;
	}
	
	h5.business span {
		width: 36px;
		height: 36px;
		background-color: #45AAC7;
		border-radius: 50%;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		color: #fff;
		font-size: 18px;
		margin-right: 15px;
	}
	
	.inner_business02 {
		border: 1px solid #0070BF;
		padding: 15px;
		margin-top: 15px;
		background-color: #fff;
	}

	.inner_business02 dl {
		margin-bottom: 10px;
		display: flex;
		flex-direction: row;
	}

	.inner_business02 dl:last-of-type {
		margin-bottom: 0;
	}
}


/* company.html　会社案内
=========================================================================== */

@media (max-width: 991px) {
	#company01,#company02,#company03 {
		margin-top: -80px;
		padding-top: 80px;
	}
}

@media (min-width: 992px) {
	#company01,#company02,#company03 {
		margin-top: -30px;
		padding-top: 30px;
	}
}

@media (max-width: 767px) {
	h3.company {
		display: flex;
		flex-direction: column;
		align-items: center;
		font-size: 20px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		margin-bottom: 25px;
		word-break: keep-all;
	}
	
	h3.company span {
		color: #B2DFFF;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		font-size: 22px;
		display: block;
		margin-bottom: 5px;
	}
	
	h3.company:after {
		content: '';
		display: block;
		width: 50px;
		height: 1px;
		border-bottom: 1px solid #4196d3;
		margin: 15px auto 0;
	}
	
	h3.company span b {
		color: #0070BF;
		font-size: 26px;
	}
	
	table.company {
		width: 100%;
		border-top: 1px solid #95a6b3;
	}
	
	table.company th {
		width: 100%;
		display: block;
		background-color: #e0ecf7;
		font-size: 14px;
		padding: 7px 10px 7px 10px;
		border-bottom: 1px solid #95a6b3;
	}
	
	table.company td {
		width: 100%;
		display: block;
		font-size: 14px;
		line-height: 1.8;
		padding: 10px 10px 10px 10px;
		border-bottom: 1px solid #95a6b3;
		background-color: #fff;
	}
}

@media (min-width: 768px) {
	h3.company {
		display: flex;
		flex-direction: row;
		align-items: baseline;
		font-size: 21px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		margin-bottom: 25px;
		word-break: keep-all;
	}
	
	h3.company span {
		color: #B2DFFF;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		font-size: 26px;
		display: inline-block;
		margin-right: 25px;
	}
	
	h3.company:after {
		content: '';
		display: block;
		width: 100%;
		height: 1px;
		border-bottom: 1px solid #4196d3;
		margin-left: 40px;
	}
	
	h3.company span b {
		color: #0070BF;
		font-size: 35px;
	}
	
	table.company {
		width: 100%;
		border-top: 1px solid #aaa;
	}
	
	table.company th {
		width: 220px;
		background-color: #e0ecf7;
		font-size: 15px;
		padding: 20px 15px 20px 25px;
		border-bottom: 1px solid #aaa;
	}
	
	table.company td {
		font-size: 15px;
		line-height: 1.8;
		padding: 20px 15px 20px 30px;
		border-bottom: 1px solid #aaa;
		background-color: #fff;
	}
}

@media (min-width: 992px) {
	h3.company {
		display: flex;
		flex-direction: row;
		align-items: baseline;
		font-size: 22px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		margin-bottom: 25px;
		word-break: keep-all;
	}
	
	h3.company span {
		color: #B2DFFF;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		font-size: 27px;
		display: inline-block;
		margin-right: 25px;
	}
	
	h3.company:after {
		content: '';
		display: block;
		width: 100%;
		height: 1px;
		border-bottom: 1px solid #74bbee;
		margin-left: 40px;
	}
	
	h3.company span b {
		color: #0070BF;
		font-size: 36px;
	}
	
	table.company {
		width: 100%;
		border-top: 1px solid #aaa;
	}
	
	table.company th {
		width: 240px;
		background-color: #e0ecf7;
		font-size: 15px;
		padding: 20px 15px 20px 30px;
		border-bottom: 1px solid #aaa;
	}
	
	table.company td {
		font-size: 15px;
		line-height: 1.8;
		padding: 20px 15px 20px 30px;
		border-bottom: 1px solid #aaa;
		background-color: #fff;
	}
}

@media (min-width: 1200px) {
	h3.company {
		display: flex;
		flex-direction: row;
		align-items: baseline;
		font-size: 24px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		margin-bottom: 25px;
		word-break: keep-all;
	}
	
	h3.company span {
		color: #B2DFFF;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		font-size: 30px;
		display: inline-block;
		margin-right: 25px;
	}
	
	h3.company:after {
		content: '';
		display: block;
		width: 100%;
		height: 1px;
		border-bottom: 1px solid #74bbee;
		margin-left: 40px;
	}
	
	h3.company span b {
		color: #0070BF;
		font-size: 40px;
	}
	
	table.company {
		width: 100%;
		border-top: 1px solid #aaa;
	}
	
	table.company th {
		width: 280px;
		background-color: #e0ecf7;
		font-size: 16px;
		padding: 20px 15px 20px 40px;
		border-bottom: 1px solid #aaa;
	}
	
	table.company td {
		font-size: 16px;
		line-height: 1.8;
		padding: 20px 15px 20px 40px;
		border-bottom: 1px solid #aaa;
		background-color: #fff;
	}
}

@media (max-width: 767px) {
	.access_map iframe {
		width: 100%;
		height: 300px;
	}
}

@media (min-width: 768px) {
	.access_map iframe {
		width: 100%;
		height: 380px;
	}
}

@media (min-width: 992px) {
	.access_map iframe {
		width: 100%;
		height: 460px;
	}
}

@media (max-width: 767px) {
	p.btn_map a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		width: 160px;
		height: 40px;
		border: 1px solid #195897;
		font-size: 14px;
		margin: 20px auto 0;
	}

	p.btn_map a:before {
		content: "\f3c5";
		font-family: 'Font Awesome\ 5 Free';
		font-weight: 900;
		margin-right: 8px;
	}
}

@media (min-width: 768px) {
	p.btn_map a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		width: 200px;
		height: 46px;
		border: 1px solid #195897;
		font-size: 14px;
		margin: 20px auto 0;
	}

	p.btn_map a:before {
		content: "\f3c5";
		font-family: 'Font Awesome\ 5 Free';
		font-weight: 900;
		margin-right: 8px;
	}
}


/* recruit.html　採用情報
=========================================================================== */

@media (max-width: 991px) {
	#recruit01,#recruit02,#recruit03,#recruit04,#recruit05 {
		margin-top: -80px;
		padding-top: 80px;
	}
}

@media (min-width: 992px) {
	#recruit01,#recruit02,#recruit03,#recruit04,#recruit05 {
		margin-top: -30px;
		padding-top: 30px;
	}
}

@media (max-width: 767px) {
	h3.recruit {
		font-size: 18px;
		color: #0070BF;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.07em;
		display: flex;
		flex-direction: column;
		align-items: center;
		margin-bottom: 20px;
	}
	
	h3.recruit span {
		font-size: 23px;
		color: #333;
		display: block;
		letter-spacing: 0.03em;
		margin-bottom: 5px;
	}
	
	.inner_recruit01_1 {
		width: 100%;
		padding: 15px 20px 10px 20px;
		background-color: #DDEFF4;
		display: flex;
		flex-direction: column;
		align-items: center;
		margin-bottom: 50px;
	}
	
	.inner_recruit01_1 .cont {
		width:100%;
	}
	
	.inner_recruit01_1 .cont p.text {
		font-size: 15px;
		line-height: 1.8;
	}
	
	.inner_recruit01_1 .pic {
		width: 100%;
		max-width: 140px;
		margin-top: 20px;
	}
	
	.inner_recruit01_2 {
		width: 100%;
		border: 1px solid #0070BF;
		padding: 20px 20px 20px;
		font-size: 16px;
		line-height: 1.8;
		position: relative;
	}

	.inner_recruit01_2 p.text {
		font-size: 15px;
	}
	
	.inner_recruit01_2 h4 {
		font-size: 16px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		color: #0070BF;
		margin-bottom: 10px;
		line-height: 1.5;
	}
}

@media (min-width: 768px) {
	h3.recruit {
		font-size: 20px;
		color: #0070BF;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.07em;
		display: flex;
		flex-direction: row;
		align-items: baseline;
		margin-bottom: 20px;
	}
	
	h3.recruit span {
		font-size: 26px;
		color: #333;
		display: inline-block;
		margin-right: 25px;
		letter-spacing: 0.03em;
	}
	
	.inner_recruit01_1 {
		width: 100%;
		padding: 20px 30px 20px 30px;
		background-color: #DDEFF4;
		display: flex;
		flex-direction: row;
		align-items: center;
		position: relative;
		margin-bottom: 50px;
	}
	
	.inner_recruit01_1 .cont {
		width: 64%;
	}
	
	.inner_recruit01_1 .cont p.text {
		font-size: 15px;
		line-height: 1.8;
	}
	
	.inner_recruit01_1 .pic {
		width: 26%;
		position: absolute;
		right: 40px;
		bottom:5px;
	}
	
	.inner_recruit01_2 {
		width: 100%;
		border: 1px solid #0070BF;
		padding: 30px 30px 20px;
		font-size: 16px;
		line-height: 1.8;
		position: relative;
	}
	
	.inner_recruit01_2 h4 {
		position: absolute;
		left:40px;
		top: -18px;
		font-size: 18px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		color: #0070BF;
		background-color: #fff;
		padding: 0.5em 2em;
	}
}

@media (min-width: 992px) {
	h3.recruit {
		font-size: 23px;
		color: #0070BF;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.07em;
		display: flex;
		flex-direction: row;
		align-items: baseline;
		margin-bottom: 30px;
	}
	
	h3.recruit span {
		font-size: 34px;
		color: #333;
		display: inline-block;
		margin-right: 25px;
		letter-spacing: 0.03em;
	}
	
	.inner_recruit01_1 {
		width: 100%;
		padding: 40px 60px;
		background-color: #DDEFF4;
		display: flex;
		flex-direction: row;
		align-items: center;
		position: relative;
		margin-bottom: 70px;
	}
	
	.inner_recruit01_1 .cont {
		width: 64%;
	}
	
	.inner_recruit01_1 .cont p.text {
		font-size: 17px;
		line-height: 2;
	}
	
	.inner_recruit01_1 .pic {
		width: 26%;
		position: absolute;
		right: 70px;
		bottom:5px;
	}
	
	.inner_recruit01_2 {
		width: 100%;
		border: 1px solid #0070BF;
		padding: 35px 50px 30px;
		font-size: 16px;
		line-height: 2;
		position: relative;
	}
	
	.inner_recruit01_2 h4 {
		position: absolute;
		left:40px;
		top: -25px;
		font-size: 20px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		color: #0070BF;
		background-color: #fff;
		padding: 0.5em 2em;
	}
}

@media (max-width: 767px) {
	ul.recruit02 {
		width: 100%;
		display: flex;
		flex-direction: row;
		flex-wrap: wrap;
	}
	
	ul.recruit02 li {
		width: 48%;
		background-color: #CCE8F0;
		border-radius: 20px;
		padding: 15px 10px;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		margin-right: 2%;
		margin-bottom: 7px;
		font-size: 14px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.1em;
		text-align: center;
		line-height: 1.4;
	}
	
	ul.recruit02 li:before {
		content: '';
		display: block;
		background: url(../images/icon_recruit02_1.png) 0 0 /contain no-repeat;
		width: 62px;
		height: 62px;
		margin-bottom: 10px;
	}
	
	ul.recruit02 li:nth-of-type(2):before {
		background: url(../images/icon_recruit02_2.png) 0 0 /contain no-repeat;
	}
	
	ul.recruit02 li:nth-of-type(3):before {
		background: url(../images/icon_recruit02_3.png) 0 0 /contain no-repeat;
	}
	
	ul.recruit02 li:nth-of-type(4):before {
		background: url(../images/icon_recruit02_4.png) 0 0 /contain no-repeat;
	}
	
	ul.recruit02 li:nth-of-type(5):before {
		background: url(../images/icon_recruit02_5.png) 0 0 /contain no-repeat;
	}
	
	ul.recruit02 li:nth-of-type(6):before {
		background: url(../images/icon_recruit02_6.png) 0 0 /contain no-repeat;
	}
	
	ul.recruit02 li:nth-of-type(2n) {
		margin-right: 0;
	}
	
	ul.recruit02 li:nth-of-type(2) ,ul.recruit02 li:nth-of-type(3) ,ul.recruit02 li:nth-of-type(6) {
		background-color: #EBF6F9;
	}
}

@media (min-width: 768px) and (max-width:991px) {
	ul.recruit02 {
		width: 100%;
		display: flex;
		flex-direction: row;
		flex-wrap: wrap;
	}
	
	ul.recruit02 li {
		width: 48%;
		background-color: #CCE8F0;
		border-radius: 20px;
		padding: 20px 10px;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		margin-right: 2%;
		margin-bottom: 20px;
		font-size: 16px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.1em;
		text-align: center;
		line-height: 1.6;
	}
	
	ul.recruit02 li:before {
		content: '';
		display: block;
		background: url(../images/icon_recruit02_1.png) 0 0 /contain no-repeat;
		width: 62px;
		height: 62px;
		margin-bottom: 10px;
	}
	
	ul.recruit02 li:nth-of-type(2):before {
		background: url(../images/icon_recruit02_2.png) 0 0 /contain no-repeat;
	}
	
	ul.recruit02 li:nth-of-type(3):before {
		background: url(../images/icon_recruit02_3.png) 0 0 /contain no-repeat;
	}
	
	ul.recruit02 li:nth-of-type(4):before {
		background: url(../images/icon_recruit02_4.png) 0 0 /contain no-repeat;
	}
	
	ul.recruit02 li:nth-of-type(5):before {
		background: url(../images/icon_recruit02_5.png) 0 0 /contain no-repeat;
	}
	
	ul.recruit02 li:nth-of-type(6):before {
		background: url(../images/icon_recruit02_6.png) 0 0 /contain no-repeat;
	}
	
	ul.recruit02 li:nth-of-type(2n) {
		margin-right: 0;
	}
	
	ul.recruit02 li:nth-of-type(2) ,ul.recruit02 li:nth-of-type(3) ,ul.recruit02 li:nth-of-type(6) {
		background-color: #EBF6F9;
	}
}

@media (min-width: 992px) {
	ul.recruit02 {
		width: 100%;
		display: flex;
		flex-direction: row;
		flex-wrap: wrap;
	}
	
	ul.recruit02 li {
		width: 32%;
		background-color: #CCE8F0;
		border-radius: 20px;
		padding: 20px 10px;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		margin-right: 2%;
		margin-bottom: 20px;
		font-size: 17px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		letter-spacing: 0.1em;
		text-align: center;
		line-height: 1.6;
	}
	
	ul.recruit02 li:before {
		content: '';
		display: block;
		background: url(../images/icon_recruit02_1.png) 0 0 /contain no-repeat;
		width: 62px;
		height: 62px;
		margin-bottom: 10px;
	}
	
	ul.recruit02 li:nth-of-type(2):before {
		background: url(../images/icon_recruit02_2.png) 0 0 /contain no-repeat;
	}
	
	ul.recruit02 li:nth-of-type(3):before {
		background: url(../images/icon_recruit02_3.png) 0 0 /contain no-repeat;
	}
	
	ul.recruit02 li:nth-of-type(4):before {
		background: url(../images/icon_recruit02_4.png) 0 0 /contain no-repeat;
	}
	
	ul.recruit02 li:nth-of-type(5):before {
		background: url(../images/icon_recruit02_5.png) 0 0 /contain no-repeat;
	}
	
	ul.recruit02 li:nth-of-type(6):before {
		background: url(../images/icon_recruit02_6.png) 0 0 /contain no-repeat;
	}
	
	ul.recruit02 li:nth-of-type(3n) {
		margin-right: 0;
	}
	
	ul.recruit02 li:nth-of-type(even) {
		background-color: #EBF6F9;
	}
}

@media (max-width: 767px) {
	.cont_recruit04 {
		width: 100%;
		max-width: 420px;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		border: 2px solid #0070C0;
		position: relative;
		padding: 20px 10px;
		margin: 0 auto 40px;
	}

	.cont_recruit04:last-child {
		margin-bottom: 10px;
	}
	
	.cont_recruit04 p.icon {
		margin-bottom: 10px;
	}
	
	.cont_recruit04:after {
		content: "\f0d7";
	font-family: 'Font Awesome\ 5 Free';
	font-weight: 900;
	font-size: 24px;
	color: #0070C0;
	position: absolute;
	bottom: -37px;
	left: 50%;
	transform: translateY(0) translateX(-50%);
	}
	
	.cont_recruit04:last-child:after {
		content: '';
	}
	
	#recruit04 p.text {
		text-align: center;
		font-size: 15px;
		margin-top: 10px;
	}
	
	.cont_recruit04 h4 {
		color: #3A91CD;
		font-size: 21px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
	}
}

@media (min-width: 768px) {
	.cont_recruit04 {
		width: 29%;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		border: 2px solid #0070C0;
		position: relative;
		padding: 25px 10px;
	}
	
	.cont_recruit04 p.icon {
		margin-bottom: 10px;
	}
	
	
	.cont_recruit04:after {
		content: "\f0da";
	font-family: 'Font Awesome\ 5 Free';
	font-weight: 900;
	font-size: 24px;
	color: #0070C0;
	position: absolute;
	top: 50%;
	right: -38px;
	transform: translateY(-50%) translateX(0);
	}
	
	.cont_recruit04:last-child:after {
		content: '';
	}
	
	#recruit04 p.text {
		text-align: center;
		font-size: 15px;
		margin-top: 10px;
	}
	
	.cont_recruit04 h4 {
		color: #3A91CD;
		font-size: 24px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
	}
}

@media (min-width: 992px) {
	.cont_recruit04 {
		width: 29%;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		border: 2px solid #0070C0;
		position: relative;
		padding: 25px 10px;
	}
	
	.cont_recruit04 p.icon {
		margin-bottom: 10px;
	}
	
	
	.cont_recruit04:after {
		content: "\f0da";
	font-family: 'Font Awesome\ 5 Free';
	font-weight: 900;
	font-size: 24px;
	color: #0070C0;
	position: absolute;
	top: 50%;
	right: -38px;
	transform: translateY(-50%) translateX(0);
	}
	
	.cont_recruit04:last-child:after {
		content: '';
	}
	
	#recruit04 p.text {
		text-align: center;
		font-size: 15px;
		margin-top: 10px;
	}
	
	.cont_recruit04 h4 {
		color: #3A91CD;
		font-size: 24px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
	}
}

@media (min-width: 1200px) {
	.cont_recruit04 {
		width: 29%;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		border: 2px solid #0070C0;
		position: relative;
		padding: 25px 10px;
	}
	
	.cont_recruit04 p.icon {
		margin-bottom: 10px;
	}
	
	
	.cont_recruit04:after {
		content: "\f0da";
	font-family: 'Font Awesome\ 5 Free';
	font-weight: 900;
	font-size: 30px;
	color: #0070C0;
	position: absolute;
	top: 50%;
	right: -46px;
	transform: translateY(-50%) translateX(0);
	}
	
	.cont_recruit04:last-child:after {
		content: '';
	}

	#recruit04 p.text {
		text-align: center;
		font-size: 15px;
		margin-top: 10px;
	}
	
	.cont_recruit04 h4 {
		color: #3A91CD;
		font-size: 27px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
	}
}

@media (max-width: 767px) {
	.inner_recruit05 {
		border: 2px solid #0070C0;
		width: 100%;
		padding: 25px 25px;
		max-width: 420px;
		margin: 0 auto;
	}
	
	.inner_recruit05 p.s16 {
		line-height: 1.8;
		margin-bottom: 20px;
	}
	
	p.tel_recruit05 {
		font-size: 24px;
		font-family: 'Roboto', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		display: flex;
		flex-direction: row;
		align-items: center;
		margin-bottom: 15px;
	}
	
	p.tel_recruit05:before {
		content: '';
		display: block;
		background: url(../images/icon_recruit05_1.png) 0 0 /contain no-repeat;
		width: 26px;
		height: 26px;
		margin-right: 7px;
		flex-shrink: 0;
	}
	
	p.tel_recruit05 span.tel_link {
		color: #0070C0;
	}
	
	p.btn_recruit05 a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		width: 240px;
		height: 50px;
		border: 1px solid #0070C0;
		color: #0070C0;
		font-size: 16px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
	}
	
	p.btn_recruit05 a:before {
		content: '';
		display: block;
		background: url(../images/icon_recruit05_2.png) 0 0 /contain no-repeat;
		width: 20px;
		height: 14px;
		margin-right: 5px;
		flex-shrink: 0;
	}
}

@media (min-width: 768px) {
	.inner_recruit05 {
		border: 2px solid #0070C0;
		width: 100%;
		padding: 25px 50px;
	}
	
	.inner_recruit05 p.s16 {
		line-height: 1.8;
		margin-bottom: 20px;
	}
	
	p.tel_recruit05 {
		font-size: 26px;
		font-family: 'Roboto', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		display: flex;
		flex-direction: row;
		align-items: center;
		margin-right: 50px;
	}
	
	p.tel_recruit05:before {
		content: '';
		display: block;
		background: url(../images/icon_recruit05_1.png) 0 0 /contain no-repeat;
		width: 26px;
		height: 26px;
		margin-right: 7px;
	}
	
	p.tel_recruit05 span.tel_link {
		color: #0070C0;
	}
	
	p.btn_recruit05 a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		width: 260px;
		height: 54px;
		border: 1px solid #0070C0;
		color: #0070C0;
		font-size: 18px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
	}
	
	p.btn_recruit05 a:before {
		content: '';
		display: block;
		background: url(../images/icon_recruit05_2.png) 0 0 /contain no-repeat;
		width: 24px;
		height: 18px;
		margin-right: 7px;
	}
}

@media (min-width: 992px) {
	.inner_recruit05 {
		border: 2px solid #0070C0;
		width: 100%;
		padding: 30px 50px;
	}
	
	.inner_recruit05 p.s16 {
		line-height: 1.8;
		margin-bottom: 20px;
	}
	
	p.tel_recruit05 {
		font-size: 30px;
		font-family: 'Roboto', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		display: flex;
		flex-direction: row;
		align-items: center;
		margin-right: 50px;
	}
	
	p.tel_recruit05:before {
		content: '';
		display: block;
		background: url(../images/icon_recruit05_1.png) 0 0 /contain no-repeat;
		width: 30px;
		height: 30px;
		margin-right: 7px;
	}
	
	p.tel_recruit05 span.tel_link {
		color: #0070C0;
	}
	
	p.btn_recruit05 a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		width: 330px;
		height: 54px;
		border: 1px solid #0070C0;
		color: #0070C0;
		font-size: 18px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
	}
	
	p.btn_recruit05 a:before {
		content: '';
		display: block;
		background: url(../images/icon_recruit05_2.png) 0 0 /contain no-repeat;
		width: 24px;
		height: 18px;
		margin-right: 7px;
	}
}

#recruit03 table th {
	background-color: #e8f2f5;
}


/* contact.html　お問い合わせ
=========================================================================== */

@media (max-width: 767px) {
	#contact01 .flex_c .info:first-child {
		margin-bottom: 15px;
	}
	
		h3.contact {
			font-size: 17px;
			font-family: 'Noto Sans JP', sans-serif;
			font-weight: 500;
			letter-spacing: 0.05em;
			text-align: center;
			border-bottom: 2px solid #0070C0;
			padding-bottom: 10px;
			margin-bottom: 10px;
		}
	
		p.tel_contact01 {
			font-family: 'Roboto', sans-serif;
			font-weight: 700;
			font-size: 24px;
			color: #0070BF;
			display: flex;
			flex-direction: row;
			align-items: center;
			justify-content: center;
			letter-spacing: 0.02em;
		}
	
		p.tel_contact01:before {
			content: '';
			display: block;
			background: url(../images/icon_contact01_1.png) 0 0 /contain no-repeat;
			width: 14px;
			height: 22px;
			margin-right: 5px;
			margin-bottom: 2px;
		}
	
		p.tel_contact01 span.tel_link {
			color: #0070BF;
		}
	
		p.fax_contact01 {
			font-family: 'Roboto', sans-serif;
			font-weight: 700;
			font-size: 24px;
			color: #0070BF;
			display: flex;
			flex-direction: row;
			align-items: center;
			justify-content: center;
			letter-spacing: 0.02em;
		}
	
		p.fax_contact01:before {
			content: '';
			display: block;
			background: url(../images/icon_contact01_2.png) 0 0 /contain no-repeat;
			width: 22px;
			height: 26px;
			margin-right: 6px;
		}
	
		#contact01 .info p.text {
			text-align: center;
			font-size: 14px;
		}
}

@media (min-width: 768px) {
	#contact01 .flex_c .info:first-child {
		margin-right: 70px;
	}
	
		h3.contact {
			font-size: 20px;
			font-family: 'Noto Sans JP', sans-serif;
			font-weight: 500;
			letter-spacing: 0.05em;
			text-align: center;
			border-bottom: 2px solid #0070C0;
			padding-bottom: 12px;
			margin-bottom: 15px;
		}
	
		p.tel_contact01 {
			font-family: 'Roboto', sans-serif;
			font-weight: 700;
			font-size: 26px;
			color: #0070BF;
			display: flex;
			flex-direction: row;
			align-items: center;
			justify-content: center;
			letter-spacing: 0.02em;
		}
	
		p.tel_contact01:before {
			content: '';
			display: block;
			background: url(../images/icon_contact01_1.png) 0 0 /contain no-repeat;
			width: 15px;
			height: 24px;
			margin-right: 5px;
			margin-bottom: 2px;
		}
	
		p.tel_contact01 span.tel_link {
			color: #0070BF;
		}
	
		p.fax_contact01 {
			font-family: 'Roboto', sans-serif;
			font-weight: 700;
			font-size: 26px;
			color: #0070BF;
			display: flex;
			flex-direction: row;
			align-items: center;
			justify-content: center;
			letter-spacing: 0.02em;
		}
	
		p.fax_contact01:before {
			content: '';
			display: block;
			background: url(../images/icon_contact01_2.png) 0 0 /contain no-repeat;
			width: 26px;
			height: 30px;
			margin-right: 8px;
		}
	
		#contact01 .info p.text {
			text-align: center;
		}
}

@media (min-width: 992px) {
	#contact01 .flex_c .info:first-child {
		margin-right: 70px;
	}
	
		h3.contact {
			font-size: 22px;
			font-family: 'Noto Sans JP', sans-serif;
			font-weight: 500;
			letter-spacing: 0.05em;
			text-align: center;
			border-bottom: 2px solid #0070C0;
			padding-bottom: 17px;
			margin-bottom: 20px;
		}
	
		p.tel_contact01 {
			font-family: 'Roboto', sans-serif;
			font-weight: 700;
			font-size: 31px;
			color: #0070BF;
			display: flex;
			flex-direction: row;
			align-items: center;
			justify-content: center;
			letter-spacing: 0.02em;
		}
	
		p.tel_contact01:before {
			content: '';
			display: block;
			background: url(../images/icon_contact01_1.png) 0 0 /contain no-repeat;
			width: 18px;
			height: 27px;
			margin-right: 5px;
			margin-bottom: 2px;
		}
	
		p.tel_contact01 span.tel_link {
			color: #0070BF;
		}
	
		p.fax_contact01 {
			font-family: 'Roboto', sans-serif;
			font-weight: 700;
			font-size: 31px;
			color: #0070BF;
			display: flex;
			flex-direction: row;
			align-items: center;
			justify-content: center;
			letter-spacing: 0.02em;
		}
	
		p.fax_contact01:before {
			content: '';
			display: block;
			background: url(../images/icon_contact01_2.png) 0 0 /contain no-repeat;
			width: 30px;
			height: 34px;
			margin-right: 8px;
		}
	
		#contact01 .info p.text {
			text-align: center;
		}
}

span.red {
	color: #ff0000;
}

@media (max-width: 767px) {
	table.contact {
		width: 100%;
	}

	table.contact th {
		display: block;
		width: 100%;
		margin-bottom: 10px;
		font-size: 15px;
	}

	table.contact td {
		display: block;
		margin-bottom: 15px;
		font-size: 15px;
	}
}

@media (min-width: 768px) and (max-width:991px) {
	.bg_contact02 {
		background-color: #f2f9ff;
		padding: 10px 10px;
	}

	table.contact {
		width: 100%;
	}

	table.contact th {
		width: 28%;
		padding: 10px 5px 10px 0;
		font-size: 15px;
	}

	table.contact td {
		padding: 10px 10px 10px 10px;
		background-color: #fff;
		font-size: 15px;
	}

	table.contact td.bgc {
		width: 130px;
	}
}

@media (min-width: 992px) {
	.bg_contact02 {
		background-color: #f2f9ff;
		padding: 10px 10px;
	}

	table.contact {
		width: 100%;
		padding: 10px 0;
	}

	table.contact th {
		width: 27%;
		padding: 10px;
		background-color: #f2f9ff;
		font-size: 15px;
	}

	table.contact td {
		padding: 10px 10px 10px 10px;
		background-color: #fff;
		font-size: 15px;
	}

	table.contact td.bgc {
		width: 130px;
	}
}

@media (min-width: 1200px) {
	table.contact {
		width: 100%;
	}

	table.contact th {
		width: 22%;
		padding: 10px;
		background-color: #f2f9ff;
	}

	table.contact td {
		padding: 10px 10px 10px 10px;
		background-color: #fff;
	}

	table.contact td.bgc {
		width: 130px;
	}
}

@media (max-width: 767px) {
	table.contact th.must:after {
		content: '必須';
		display: inline-block;
		width: 32px;
		height: 16px;
		background-color: #ff0000;
		text-align: center;
		color: #fff;
		font-size: 10px;
		line-height: 16px;
		margin-left: 10px;
		float: right;
		margin-right: 5px;
	}
}

@media (min-width: 768px) {
	table.contact th.must:after {
		content: '必須';
		display: inline-block;
		width: 36px;
		height: 16px;
		background-color: #ff0000;
		text-align: center;
		color: #fff;
		font-size: 10px;
		line-height: 16px;
		margin-left: 15px;
		float: right;
		margin-right: 5px;
	}
}

/*
table.contact th.any:after {
content: '任意';
display: inline-block;
width: 36px;
height: 16px;
background-color: #ececec;
text-align: center;
color: #777;
font-size: 10px;
line-height: 16px;
margin-left: 15px;
float: right;
}
*/

@media (max-width: 767px) {
	table.contact td input.write {
		padding: 0.5em 0.5em;
		width: 100%;
		border-radius: 4px;
		border: 1px solid #ddd;
	}
}

@media (min-width: 768px) {
	table.contact td input.write {
		padding: 0.4em 0.5em;
		width: 100%;
		border: 1px solid #ddd;
		background-color: #fff;
		border-radius: 4px;
	}
}

table.contact td input.form50 {
	width: 50px !important;
}

table.contact td input.form100 {
	width: 100px !important;
}

table.contact td input.form150 {
	width: 150px !important;
}

select {
	padding: 0.3em 0.5em;
}

@media (max-width: 767px) {
	textarea {
		width: 100%;
		padding: 0.2em 0.5em;
		border: 1px solid #ddd;
		background-color: #fff;
	}
}

@media (min-width: 768px) {
	textarea {
		width: 100%;
		padding: 0.2em 0.5em;
		border: 1px solid #ddd;
		background-color: #fff;
	}
}

p.icon01 {
	font-size: 13px;
	color: #fff;
	background-color: #63a11f;
	width: 50px;
	height: 24px;
	text-align: center;
	line-height: 24px;
	border-radius: 10px;
}

p.icon02 {
	font-size: 13px;
	color: #333;
	background-color: #eee;
	border: 1px solid #777;
	width: 50px;
	height: 24px;
	text-align: center;
	line-height: 24px;
	border-radius: 10px;
}


@media (max-width: 767px) {
	h4.privacy {
		font-size: 14px;
		font-weight: bold;
		margin-bottom: 5px;
		line-height: 1.6;
		margin-top: 10px;
	}

	.inner_privacy {
		height: 160px;
		overflow: auto;
		overflow-y: scroll;
		font-size: 13px;
		line-height: normal;
		padding: 15px 15px 10px;
		border: solid 1px #ccc;
		border-radius: 4px;
		background-color: #fff;
		margin-bottom: 20px;
	}

	.inner_privacy h5 {
		font-size: 13px;
		font-weight: bold;
		padding-bottom: 10px;
		border-bottom: 1px dotted #aaa;
		margin-bottom: 10px;
	}

	p.ttl_privacy {
		font-size: 13px;
		font-weight: bold;
		margin-bottom: 5px;
	}

	.inner_privacy p.text {
		font-size: 13px;
		line-height: 1.6;
		margin-bottom: 15px;
	}

	.inner_privacy p.text span.tel_link {
		border-bottom: 1px solid #333;
	}

	ul.privacy li {
		list-style-type: decimal;
		margin-left: 20px;
		margin-bottom: 5px;
		font-size: 13px;
	}
}

@media (min-width: 768px) {
	h4.privacy {
		font-size: 15px;
		font-weight: bold;
		margin-bottom: 5px;
		line-height: 1.6;
		margin-top: 30px;
	}

	.inner_privacy {
		height: 200px;
		overflow: auto;
		overflow-y: scroll;
		font-size: 14px;
		line-height: normal;
		padding: 20px;
		border: solid 1px #ccc;
		border-radius: 4px;
		background-color: #fff;
		margin-bottom: 25px;
	}

	.inner_privacy h5 {
		font-size: 15px;
		font-weight: bold;
		padding-bottom: 10px;
		border-bottom: 1px dotted #aaa;
		margin-bottom: 10px;
	}

	p.ttl_privacy {
		font-size: 14px;
		font-weight: bold;
		margin-bottom: 5px;
	}

	.inner_privacy p.text {
		font-size: 14px;
		line-height: 1.6;
		margin-bottom: 15px;
	}

	ul.privacy li {
		list-style-type: decimal;
		margin-left: 20px;
		margin-bottom: 5px;
		font-size: 13px;
	}
}

@media (max-width: 767px) {
	button.comfirm {
		width: 100%;
		max-width: 240px;
		height: 42px;
		text-align: center;
		background-color: #0C87C6;
		color: #ffffff;
		outline: none;
		border: none;
		cursor: pointer;
		font-weight: bolder;
		font-size: 13px;
		line-height: 42px;
		padding: 0 !important;
	}

	button.comfirm:hover {
		background-color: #0d98df;
	}

	.btn_space {
		width: 100%;
		max-width: 240px;
		margin: 0 auto;
		display: flex;
		flex-direction: row;
		justify-content: space-between;
	}

	button.back {
		width: 47%;
		height: 42px;
		text-align: center;
		background-color: #999;
		color: #ffffff;
		outline: none;
		border: none;
		cursor: pointer;
		font-weight: bolder;
		font-size: 15px;
		line-height: 42px;
		padding: 0 !important;
		display: inline-block;
		margin-right: 4%;
	}

	button.back:hover {
		background-color: #a7a7a7;
	}

	button.send {
		width: 47%;
		height: 42px;
		text-align: center;
		background-color: #0C87C6;
		color: #ffffff;
		outline: none;
		border: none;
		cursor: pointer;
		font-weight: bolder;
		font-size: 15px;
		line-height: 42px;
		padding: 0 !important;
		display: inline-block;
	}

	button.send:hover {
		background-color: #0d98df;
	}
}

@media (min-width: 768px) {
	button.comfirm {
		width: 400px;
		height: 46px;
		text-align: center;
		background-color: #0C87C6;
		color: #ffffff;
		outline: none;
		border: none;
		cursor: pointer;
		font-weight: bolder;
		font-size: 15px;
		line-height: 46px;
		padding: 0 !important;
	}

	button.comfirm:hover {
		background-color: #0d98df;
	}

	.btn_space {
		width: 400px;
		margin: 0 auto;
		display: flex;
		flex-direction: row;
		justify-content: space-between;
	}

	button.back {
		width: 180px;
		height: 46px;
		text-align: center;
		background-color: #999;
		color: #ffffff;
		outline: none;
		border: none;
		cursor: pointer;
		font-weight: bolder;
		font-size: 15px;
		line-height: 46px;
		padding: 0 !important;
		display: inline-block;
		margin-right: 30px;
	}

	button.back:hover {
		background-color: #a7a7a7;
	}

	button.send {
		width: 180px;
		height: 46px;
		text-align: center;
		background-color: #0C87C6;
		color: #ffffff;
		outline: none;
		border: none;
		cursor: pointer;
		font-weight: bolder;
		font-size: 15px;
		line-height: 46px;
		padding: 0 !important;
		display: inline-block;
	}

	button.send:hover {
		background-color: #0d98df;
	}
}

select {
	border: 1px solid #ccc;
}

@media (max-width: 767px) {
	table.contact label {
		font-weight: normal;
	}
}

@media (max-width: 767px) {
	.agreebox label {
		font-size: 13px;
	}
}

@media (max-width: 767px) {
	::-webkit-input-placeholder {
		/* WebKit, Blink, Edge */
		color: #aaa;
		font-size: 15px;
	}

	:-ms-input-placeholder {
		/* Internet Explorer 10-11 */
		color: #aaa;
		font-size: 15px;
	}

	::placeholder {
		/* Others */
		color: #aaa;
		font-size: 15px;
	}

	p.tbl_hosoku {
		font-size: 15px;
		margin-top: 5px;
		color: #555;
	}
}

@media (min-width: 768px) {
	::-webkit-input-placeholder {
		/* WebKit, Blink, Edge */
		color: #aaa;
		font-size: 15px;
	}

	:-ms-input-placeholder {
		/* Internet Explorer 10-11 */
		color: #aaa;
		font-size: 15px;
	}

	::placeholder {
		/* Others */
		color: #aaa;
		font-size: 15px;
	}

	p.tbl_hosoku {
		font-size: 15px;
		margin-top: 5px;
		color: #555;
	}
}

@media (min-width: 992px) {
	::-webkit-input-placeholder {
		/* WebKit, Blink, Edge */
		color: #aaa;
		font-size: 15px;
	}

	:-ms-input-placeholder {
		/* Internet Explorer 10-11 */
		color: #aaa;
		font-size: 15px;
	}

	::placeholder {
		/* Others */
		color: #aaa;
		font-size: 15px;
	}

	p.tbl_hosoku {
		font-size: 14px;
		margin-top: 5px;
		color: #555;
	}
}













/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
