@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/css2?family=Kosugi+Maru&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Fjalla+One&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Anton&display=swap');
@import url('https://fonts.googleapis.com/css?family=Roboto:700&display=swap');

body {
	margin: 0px;
	padding: 0px;
	font-family:  "Kosugi Maru", "Noto Sans JP", "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;
}

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.7;
	}

	.s16 {
		font-size: 15px !important;
		line-height: 1.7;
	}

	.s15_c {
		font-size: 14px !important;
		line-height: 1.7;
		text-align: center;
	}

	.s16_c {
		font-size: 15px !important;
		line-height: 1.7;
		text-align: center;
	}
}

@media (min-width: 992px) {
	.s15 {
		font-size: 15px !important;
		line-height: 1.7;
	}

	.s16 {
		font-size: 16px !important;
		line-height: 1.7;
	}

	.s15_c {
		font-size: 15px !important;
		line-height: 1.7;
		text-align: center;
	}

	.s16_c {
		font-size: 16px !important;
		line-height: 1.7;
		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;
	}
}

@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;
	}
}

@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;
	}
}

@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;
	}
}

.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 (max-width: 991px) {
	.info_h {
		display: none;
	}
}

@media (min-width: 992px) {
	header {
		width: 100%;
		max-width: 1920px;
		position: absolute;
	    top: 0;
	    left: 0;
	    right: 0;
	    margin: 0 auto;
	    transition: background 0.4s ease, box-shadow 0.4s ease, color 0.4s ease, transform 0.4s ease;
	    transform: translateY(0);
		z-index: 999;
	}

	header.h_fixed {
	    position: fixed !important;
	    top: 0;
	    left: 0 !important;
	    right: 0 !important;
	    width: 100% !important;
	    margin: 0 auto;
	    transform: translateY(0) !important;
	    background: rgba(5,113,171,0.8);
	    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
	    backdrop-filter: blur(6px);
	    z-index: 9999;
	}

	.flex_h {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
		max-width: 1920px;
		height: 115px;
	}

	header.h_fixed .flex_h {		
		height: 85px!important;
	}

	.flex_right {
		width: auto;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
	}

	.container-fluid {
		padding: 0 10px 0 10px;
	}

	.info_h {
		margin-left: 10px;
	}

	p.btn_contact_h a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		width: 150px;
		height: 60px;
		background-color: #0571AB;
		border-radius: 30px;
		color: #fff;
		font-size: 16px;
	}

	p.btn_contact_h a:after {
		content: '';
		display: block;
		background: url(../images/icon_h.png) 0 0 /contain no-repeat;
		width: 24px;
		height: 15px;
		margin-left: 5px;
	}

	p.btn_contact_h a:hover {
		opacity: 1;
		background-color: #0983c5;
	}
}

@media (min-width: 1200px) {
	header {
		width: 100%;
		max-width: 1920px;
		position: absolute;
	    top: 0;
	    left: 0;
	    right: 0;
	    margin: 0 auto;
	    transition: background 0.4s ease, box-shadow 0.4s ease, color 0.4s ease, transform 0.4s ease;
	    transform: translateY(0);
		z-index: 999;
	}

	header.h_fixed {
	    position: fixed !important;
	    top: 0;
	    left: 0 !important;
	    right: 0 !important;
	    margin: 0 auto;
	    background: rgba(5,113,171,0.8);
	    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
	    backdrop-filter: blur(6px);
	    color: #ff0;
	    transform: translateY(-100%);
	    z-index: 9999;
	}

	.flex_h {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
		max-width: 1920px;
		height: 115px;
	}

	header.h_fixed .flex_h {		
		height: 85px!important;
	}

	.flex_right {
		width: auto;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
	}

	.container-fluid {
		padding: 0 10px 0 10px;
	}

	.info_h {
		margin-left: 0;
	}

	p.btn_contact_h a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		width: 200px;
		height: 60px;
		background-color: #0571AB;
		border-radius: 30px;
		color: #fff;
		font-size: 18px;
	}

	p.btn_contact_h a:after {
		content: '';
		display: block;
		background: url(../images/icon_h.png) 0 0 /contain no-repeat;
		width: 30px;
		height: 19px;
		margin-left: 10px;
	}

	p.btn_contact_h a:hover {
		opacity: 1;
		background-color: #0983c5;
	}
}

@media (min-width: 1500px) {
	header {
		width: 100%;
		max-width: 1920px;
		position: absolute;
	    top: 0;
	    left: 0;
	    right: 0;
	    margin: 0 auto;
	    transition: background 0.4s ease, box-shadow 0.4s ease, color 0.4s ease, transform 0.4s ease;
	    transform: translateY(0);
		z-index: 999;
	}

	header.h_fixed {
	    position: fixed !important;
	    top: 0;
	    left: 0 !important;
	    right: 0 !important;
	    margin: 0 auto;
	    background: rgba(5,113,171,0.8);
	    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
	    backdrop-filter: blur(6px);
	    color: #ff0;
	    transform: translateY(-100%);
	    z-index: 9999;
	}

	.flex_h {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
		max-width: 1920px;
		height: 115px;
	}

	header.h_fixed .flex_h {		
		height: 85px!important;
	}

	.flex_right {
		width: auto;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
	}

	.container-fluid {
		padding: 0 40px 0 40px;
	}

	.info_h {
		margin-left: 30px;
	}

	p.btn_contact_h a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		width: 240px;
		height: 60px;
		background-color: #0571AB;
		border-radius: 30px;
		color: #fff;
		font-size: 21px;
	}

	p.btn_contact_h a:after {
		content: '';
		display: block;
		background: url(../images/icon_h.png) 0 0 /contain no-repeat;
		width: 36px;
		height: 24px;
		margin-left: 10px;
	}

	p.btn_contact_h a:hover {
		opacity: 1;
		background-color: #0983c5;
	}
}


/* navigation
=========================================================================== */

/*
.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でカウントされてしまう*/
}

@media (min-width: 768px) {

	.navbar > .container .navbar-brand,
	.navbar > .container-fluid .navbar-brand {
		margin-left: 0;
	}
}

.navbar-brand {
	padding: 0;
	/*	デフォルトのパディングを消す*/
}

.navbar-brand a {
	display: block;
}

@media (max-width: 360px) {
	.navbar-brand {
		width: 75%;
		height: auto;
	}
}

@media (min-width: 361px) {
	.navbar-brand {
		width: 270px;
		height: auto;
	}
	.h_fixed .navbar-brand {
		width: 270px;
	}	
}

@media (min-width: 992px) {
	.navbar-brand {
		width: 280px;
	}
	.h_fixed .navbar-brand {
		width: 200px;
	}	
}

@media (min-width: 1200px) {
	.navbar-brand {
		width: 320px;
	}
	.h_fixed .navbar-brand {
		width: 220px;
	}
}

@media (min-width: 1500px) {
	.navbar-brand {
		width: 390px;
	}

	.h_fixed .navbar-brand {
		width: 290px;
	}
}

@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: 16px;
		margin-right: 15px;
	}

	.navbar-nav > li > a {
		font-size: 16px;
		font-family: 'Noto Sans JP', sans-serif;
		color: #fff !important;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		padding: 15px 5px;
	}

	.navbar-nav > li > a:hover {
		color: #fff !important;
		opacity: 1;
		background-color: transparent !important;
	}

	.navbar-nav > li.active > a {
		color: #fff !important;
		background-color: transparent !important;
	}

	.navbar-nav > li > a:after {
		position: absolute;
		bottom: -3px;
		left: 0;
		content: '';
		width: 100%;
		height: 2px;
		background-color: #fff;
		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: 17px;
		margin-right: 25px;
	}

	.navbar-nav > li > a {
		font-size: 17px;
		font-family: 'Noto Sans JP', sans-serif;
		color: #fff !important;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		padding: 15px 10px;
	}

	.navbar-nav > li > a:hover {
		color: #fff !important;
		opacity: 1;
		background-color: transparent !important;
	}

	.navbar-nav > li.active > a {
		color: #fff !important;
		background-color: transparent !important;
	}

	.navbar-nav > li > a:after {
		position: absolute;
		bottom: -3px;
		left: 0;
		content: '';
		width: 100%;
		height: 2px;
		background-color: #fff;
		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: 1500px) {

	.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: 19px;
		margin-right: 35px;
	}

	.navbar-nav > li > a {
		font-size: 19px;
		font-family: 'Noto Sans JP', sans-serif;
		color: #fff !important;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		padding: 15px 10px;
	}

	.navbar-nav > li > a:hover {
		color: #fff !important;
		opacity: 1;
		background-color: transparent !important;
	}

	.navbar-nav > li.active > a {
		color: #fff !important;
		background-color: transparent !important;
	}

	.navbar-nav > li > a:after {
		position: absolute;
		bottom: -3px;
		left: 0;
		content: '';
		width: 100%;
		height: 2px;
		background-color: #fff;
		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);
	}
}

/*navbar ナビゲーション全体*/

.navbar {
	margin-bottom: 0;
	/*	デフォルトのマージンを消す*/
	border: none;
	/*	透明1px線を消す*/
	border-radius: 0;
	max-width: 1920px;
	margin: 0 auto;
}

.navbar-default {
	background-color: transparent;
	/*デフォルトの背景色を消す*/
}

/* 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 (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 (max-width: 767px) {
	.sp_fix {
		display: flex;
		justify-content: space-between;
		align-items: center;
		margin-right: 0 !important;
		margin-left: 0 !important;
		padding: 10px 0;
	}

	nav.navbar {
		background-color: #0571AB;
		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: #fff;
	}

	.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: #1183c0;
		position: relative;
		-webkit-overflow-scrolling: touch;
		padding-bottom: 1px;
		margin-bottom: 10px;
	}

	.navbar-nav > li > a {
		padding: 10px 15px;
		background-color: #fff;
		font-size: 16px;
		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: 10px 0;
	}

	nav.navbar {
		background-color: #0571AB;
		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: #fff;
	}

	.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: #1183c0;
		position: relative;
		-webkit-overflow-scrolling: touch;
		padding-bottom: 1px;
		margin-bottom: 10px;
	}

	.navbar-nav > li > a {
		padding: 10px 15px;
		background-color: #fff;
		font-size: 18px;
		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 {
		width: 100%;
		position: relative;
		margin-top: 60px;
	}
}

@media (min-width: 768px) {
	.bg_mainimg {
		width: 100%;
		position: relative;
		margin-top: 65px;
	}
}

@media (min-width: 992px) {
	.bg_mainimg {
		width: 100%;
		position: relative;
		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;
	position: relative;
}

@media (max-width: 767px) {

	.swiper-button-next,
	.swiper-button-prev {
		display: none;
	}
}

@keyframes zoomUp {
	0% {
	 transform: scale(1);
	}
   
	100% {
	 transform: scale(1.06);
	}
   }
   
   .swiper-slide-active .slide-img,
   .swiper-slide-duplicate-active .slide-img,
   .swiper-slide-prev .slide-img {
	animation: zoomUp 5s ease-out 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: 23% !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: 9px !important;
		height: 9px !important;
		border-radius: 50% !important;
		background: #fff !important;
		opacity: 0.8 !important;
	}

	.swiper-pagination-bullet-active {
		background: #0581C2 !important;
		opacity: 1 !important;
	}
}

@media (min-width: 1200px) {
	.swiper-pagination-bullets {
		right: 35px !important;
		top: 33% !important;
		bottom: inherit!important;
		left: inherit !important;
		display: flex;
		flex-direction: column;
		align-items: flex-end;
	}

	.swiper-pagination-bullet {
		border-radius: inherit;
		margin: 0 0 15px 0 !important;
		width: 100px;
		height: 5px;
	}

	.swiper-pagination-bullet {
		width: 12px !important;
		height: 12px !important;
		border-radius: 50% !important;
		background: #fff !important;
		opacity: 0.8 !important;
	}

	.swiper-pagination-bullet-active {
		background: #0581C2 !important;
		opacity: 1 !important;
	}
}

@media (max-width: 767px) {
	.bg_mainimg .inner {
		position: absolute;
		bottom: 7%;
		left: 2%;
		z-index: 22;
		width:90%;
		max-width: 500px;
	}
}

@media (min-width: 768px) {
	.bg_mainimg .inner {
		position: absolute;
		bottom: 5%;
		left: 2%;
		z-index: 22;
		width:64%;
		max-width: 920px;
	}
}

@media (min-width: 992px) {
	.bg_mainimg .inner {
		position: absolute;
		bottom: 7%;
		left: 3%;
		z-index: 22;
		width:58%;
		max-width: 920px;
	}
}

@media (min-width: 1200px) {
	.bg_mainimg .inner {
		position: absolute;
		bottom: 7%;
		left: 3%;
		z-index: 22;
		width:54%;
		max-width: 920px;
	}
}

@media (min-width: 1500px) {
	.bg_mainimg .inner {
		position: absolute;
		bottom: 12%;
		left: 5%;
		z-index: 22;
		width:49.916%;
		max-width: 920px;
	}
}

/* スクロール */

@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: 999;
	}
}

p.ttl_scroll {
	font-size: 13px;
	color: #fff;
	font-family: 'Noto Sans JP', sans-serif;
	transform: rotate(90deg);
	transform-origin: left top;
	letter-spacing: 0.2em;
	position: absolute;
	top: -80px;
	left: 12px;
}

.moveline {
	content: '';
	display: block;
	width: 2px;
	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: 2px;
		height: 0;
		background-color: #fff;
	}

	25% {
		width: 2px;
		height: 120px;
		background-color: #fff;
	}

	45% {
		width: 2px;
		height: 120px;
		background-color: transparent;
	}

	100% {
		width: 2px;
		height: 120px;
		background-color: transparent;
	}
}


/* index.html
=========================================================================== */

@media (max-width: 767px) {
	.bg_top01_1 {
		width: 100%;
		background: url(../images/bg_top01_1.jpg) center bottom /cover no-repeat;
		padding: 20px 0 10px;
	}
	
	.bg_top01_2 {
		width: 100%;
		background: url(../images/bg_top01_2.jpg) center top /cover no-repeat;
		padding: 10px 0 40px;
	}
	
	.cont_top01 {
		width: 90%;
		margin: 0 20px 0 20px;
		flex-shrink: 0;
		position: relative;
		z-index: 2;
	}
	
	.bg_top01_1 .cont_top01 {
		height: 260px;
		background: url(../images/deco_top01.png) center center /contain no-repeat;
		display: flex;
		flex-direction: row;
		align-items: center;
	}
	
	.bg_top01_2 .cont_top01 {
		margin: 10px 15px 0 15px;
	}
	
	.pic_top01 {
		width: 90%;
		margin: 0 auto;
	}
	
	.bg_top01_2 .pic_top01 {
		margin-bottom: 10px;
	}
	
	h2.top01 {
		font-size: 22px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		margin-bottom: 15px;
	}
	
	h2.top01 span {
		display: block;
	font-size: 21px;
	color: #0581C2;
	font-family: 'Fjalla One', sans-serif;
	font-weight: normal;
	margin-bottom: 7px;
	}
	
	.cont_top01 p.text {
		font-size: 15px;
		letter-spacing: 0.02em;
		line-height: 1.8;
	}
	
	p.btn_top a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		width: 180px;
		height: 46px;
		background-color: #1D5C7E;
		color: #fff;
		font-size: 18px;
		font-family: 'Anton', sans-serif;
		position: relative;
		margin: 0 auto;
		border-radius: 30px;
	}
	
	p.btn_top a:after {
		content: '';
		display: block;
		background: url(../images/icon_btn_top.png) 0 0 /cover no-repeat;
		width: 24px;
		height: 8px;
		position: absolute;
		top: 50%;
		right: 15px;
		transform: translateY(-50%) translateX(0);
		transition: 0.2s;
	}
	
	p.btn_top a:hover {
		opacity: 1;
		background-color: #2978a3;
	}
	
	p.btn_top a:hover:after {
		right: 10px;
	}
	
	.bg_top01_2 p.btn_top a {
		margin-top: 25px;
	}

	.bg_top04 p.btn_top a {
		background-color: #333;
		font-size: 18px;
		font-family: 'Kosugi Maru', sans-serif;
		width: 260px;
	}
}

@media (min-width: 768px) and (max-width:991px) {
	.bg_top01_1 {
		width: 100%;
		background: url(../images/bg_top01_1.jpg) center bottom /cover no-repeat;
		padding: 20px 0 10px;
	}
	
	.bg_top01_2 {
		width: 100%;
		background: url(../images/bg_top01_2.jpg) center top /cover no-repeat;
		padding: 10px 0 40px;
	}
	
	.cont_top01 {
		width: 360px;
		margin: 0 20px 0 20px;
		flex-shrink: 0;
		position: relative;
		z-index: 2;
	}
	
	.bg_top01_1 .cont_top01 {
		height: 280px;
		background: url(../images/deco_top01.png) center center /contain no-repeat;
		display: flex;
		flex-direction: row;
		align-items: center;
	}
	
	.bg_top01_2 .cont_top01 {
		margin: 0 20px 0 20px;
	}
	
	.pic_top01 {
		width: 360px;
		margin-right: 15px;
	}
	
	.bg_top01_2 .pic_top01 {
		margin-left: 15px;
		margin-right: inherit;
	}
	
	h2.top01 {
		font-size: 22px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		margin-bottom: 25px;
	}
	
	h2.top01 span {
		display: block;
	font-size: 24px;
	color: #0581C2;
	font-family: 'Fjalla One', sans-serif;
	font-weight: normal;
	margin-bottom: 15px;
	}
	
	.cont_top01 p.text {
		font-size: 16px;
		letter-spacing: 0.02em;
		line-height: 1.8;
	}
	
	p.btn_top a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		width: 200px;
		height: 50px;
		background-color: #1D5C7E;
		color: #fff;
		font-size: 18px;
		font-family: 'Anton', sans-serif;
		position: relative;
		border-radius: 30px;
	}
	
	p.btn_top a:after {
		content: '';
		display: block;
		background: url(../images/icon_btn_top.png) 0 0 /cover no-repeat;
		width: 27px;
		height: 9px;
		position: absolute;
		top: 50%;
		right: 20px;
		transform: translateY(-50%) translateX(0);
		transition: 0.2s;
	}
	
	p.btn_top a:hover {
		opacity: 1;
		background-color: #2978a3;
	}
	
	p.btn_top a:hover:after {
		right: 10px;
	}
	
	.bg_top01_2 p.btn_top a {
		margin-top: 25px;
	}

	.bg_top04 p.btn_top a {
		background-color: #333;
		font-size: 18px;
		font-family: 'Kosugi Maru', sans-serif;
		width: 260px;
	}
}

@media (min-width: 992px) {
	.bg_top01_1 {
		width: 100%;
		background: url(../images/bg_top01_1.jpg) center bottom /cover no-repeat;
		padding: 40px 0 15px;
	}
	
	.bg_top01_2 {
		width: 100%;
		background: url(../images/bg_top01_2.jpg) center top /cover no-repeat;
		padding: 15px 0 60px;
	}
	
	.cont_top01 {
		width: 400px;
		margin: 0 60px 0 30px;
		flex-shrink: 0;
		position: relative;
		z-index: 2;
	}
	
	.bg_top01_1 .cont_top01 {
		height: 300px;
		background: url(../images/deco_top01.png) center center /contain no-repeat;
		display: flex;
		flex-direction: row;
		align-items: center;
	}
	
	.bg_top01_2 .cont_top01 {
		margin: 0 30px 0 60px;
	}
	
	.pic_top01 {
		width: 460px;
		margin-right: 25px;
	}
	
	.bg_top01_2 .pic_top01 {
		margin-left: 25px;
		margin-right: inherit;
	}
	
	h2.top01 {
		font-size: 24px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		margin-bottom: 25px;
	}
	
	h2.top01 span {
		display: block;
	font-size: 30px;
	color: #0581C2;
	font-family: 'Fjalla One', sans-serif;
	font-weight: normal;
	margin-bottom: 15px;
	}
	
	.cont_top01 p.text {
		font-size: 16px;
		letter-spacing: 0.05em;
		line-height: 2;
	}
	
	p.btn_top a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		width: 240px;
		height: 50px;
		background-color: #1D5C7E;
		color: #fff;
		font-size: 20px;
		font-family: 'Anton', sans-serif;
		position: relative;
		border-radius: 30px;
	}
	
	p.btn_top a:after {
		content: '';
		display: block;
		background: url(../images/icon_btn_top.png) 0 0 /cover no-repeat;
		width: 26px;
		height: 9px;
		position: absolute;
		top: 50%;
		right: 25px;
		transform: translateY(-50%) translateX(0);
		transition: 0.2s;
	}
	
	p.btn_top a:hover {
		opacity: 1;
		background-color: #2978a3;
	}
	
	p.btn_top a:hover:after {
		right: 15px;
	}
	
	.bg_top01_2 p.btn_top a {
		margin-top: 25px;
	}

	.bg_top04 p.btn_top a {
		background-color: #333;
		font-size: 18px;
		font-family: 'Kosugi Maru', sans-serif;
	}
}

@media (min-width: 1200px) {
	.bg_top01_1 {
		width: 100%;
		background: url(../images/bg_top01_1.jpg) center bottom /cover no-repeat;
		padding: 50px 0 30px;
	}
	
	.bg_top01_2 {
		width: 100%;
		background: url(../images/bg_top01_2.jpg) center top /cover no-repeat;
		padding: 30px 0 70px;
	}
	
	.cont_top01 {
		width: 440px;
		margin: 0 60px 0 30px;
		flex-shrink: 0;
		position: relative;
		z-index: 2;
	}
	
	.bg_top01_1 .cont_top01 {
		height: 370px;
		background: url(../images/deco_top01.png) center center /contain no-repeat;
		display: flex;
		flex-direction: row;
		align-items: center;
	}
	
	.bg_top01_2 .cont_top01 {
		margin: 0 30px 0 60px;
	}
	
	.pic_top01 {
		width: 700px;
		margin-right: 35px;
	}
	
	.bg_top01_2 .pic_top01 {
		margin-left: 35px;
		margin-right: inherit;
	}
	
	h2.top01 {
		font-size: 27px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		margin-bottom: 25px;
	}
	
	h2.top01 span {
		display: block;
	font-size: 45px;
	color: #0581C2;
	font-family: 'Fjalla One', sans-serif;
	font-weight: normal;
	margin-bottom: 15px;
	}
	
	.cont_top01 p.text {
		font-size: 18px;
		letter-spacing: 0.05em;
		line-height: 2;
	}
	
	p.btn_top a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		width: 260px;
		height: 56px;
		background-color: #0581C2;
		color: #fff;
		font-size: 18px;
		position: relative;
		border-radius: 30px;
	}
	
	p.btn_top a:after {
		content: '';
		display: block;
		background: url(../images/icon_btn_top.png) 0 0 /cover no-repeat;
		width: 26px;
		height: 9px;
		position: absolute;
		top: 50%;
		right: 25px;
		transform: translateY(-50%) translateX(0);
		transition: 0.2s;
	}
	
	p.btn_top a:hover {
		opacity: 1;
		background-color: #2978a3;
	}
	
	p.btn_top a:hover:after {
		right: 15px;
	}
	
	.bg_top01_2 p.btn_top a {
		margin-top: 30px;
	}

	.bg_top04 p.btn_top a {
		background-color: #333;
		font-size: 18px;
		font-family: 'Kosugi Maru', sans-serif;
	}
}

@media (min-width: 1500px) {
	.bg_top01_1 {
		width: 100%;
		background: url(../images/bg_top01_1.jpg) center top /cover no-repeat;
		padding: 100px 0 60px;
	}
	
	.bg_top01_2 {
		width: 100%;
		background: url(../images/bg_top01_2.jpg) center top /cover no-repeat;
		padding: 60px 0 100px;
	}
	
	.cont_top01 {
		width: 540px;
		margin: 0 70px 0 30px;
		flex-shrink: 0;
		position: relative;
		z-index: 2;
	}
	
	.bg_top01_1 .cont_top01 {
		height: 540px;
		background: url(../images/deco_top01.png) center center /contain no-repeat;
		display: flex;
		flex-direction: row;
		align-items: center;
	}
	
	.bg_top01_2 .cont_top01 {
		margin: 0 30px 0 80px;
	}
	
	.pic_top01 {
		width: 1024px;
		margin-right: 85px;
	}
	
	.bg_top01_2 .pic_top01 {
		margin-left: 85px;
		margin-right: inherit;
	}
	
	h2.top01 {
		font-size: 29px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		margin-bottom: 40px;
	}
	
	h2.top01 span {
		display: block;
	font-size: 63px;
	color: #0581C2;
	font-family: 'Fjalla One', sans-serif;
	font-weight: normal;
	margin-bottom: 20px;
	}
	
	.cont_top01 p.text {
		font-size: 20px;
		letter-spacing: 0.05em;
		line-height: 2;
	}
	
	p.btn_top a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		width: 280px;
		height: 56px;
		background-color: #1D5C7E;
		color: #fff;
		font-size: 24px;
		font-family: 'Anton', sans-serif;
		position: relative;
	}
	
	p.btn_top a:after {
		content: '';
		display: block;
		background: url(../images/icon_btn_top.png) 0 0 /cover no-repeat;
		width: 30px;
		height: 11px;
		position: absolute;
		top: 50%;
		right: 25px;
		transform: translateY(-50%) translateX(0);
		transition: 0.2s;
	}
	
	p.btn_top a:hover {
		opacity: 1;
		background-color: #2978a3;
	}
	
	p.btn_top a:hover:after {
		right: 15px;
	}
	
	.bg_top01_2 p.btn_top a {
		margin-top: 40px;
	}

	.bg_top04 p.btn_top a {
		background-color: #333;
		font-size: 18px;
		font-family: 'Kosugi Maru', sans-serif;
	}
}

@media (max-width: 1499px) {
	.br1500 {
		display: none !important;
	}
}

@media (min-width: 1500px) {
	.br1500 {
		display: block;
	}
}







@media (max-width: 767px) {
	.bg_top02 {
		width: 100%;
		background: url(../images/bg_top02.jpg) 20% 0 /cover no-repeat;
		padding: 30px 0 50px;
		color: #fff;
	}
	
	h2.top02 {
		font-size: 21px;
		font-family: 'Noto Sans JP', sans-serif;;
		font-weight: 700;
		letter-spacing: 0.05em;
		line-height: 1;
		text-align: center;
		position: relative;
		margin-bottom: 20px;
	}
	
	h2.top02 span {
		display: block;
		font-family: 'Fjalla One', sans-serif;
		font-weight: normal;
		font-size: 24px;
		letter-spacing: 0;
		margin-bottom: 10px;
	}
	
	h2.top02:after {
		content: '';
		display: block;
		width: 50px;
		height: 2px;
		margin: 20px auto 20px;
		background-color: #fff;
	}
	
	p.text_top02 {
		font-size: 15px;
		letter-spacing: 0.02em;
		line-height: 1.8;
		margin-bottom: 30px;
	}
	
	.cont_top02 {
		width: 100%;
		margin-bottom: 15px;
	}
	
	.cont_top02 a {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		width: 100%;
		height: 120px;
		background-color: #fff;
		border-radius: 10px;
		position: relative;
		padding: 10px;
	}
	
	.cont_top02 a:hover {
		opacity: 1;
		background-color: #81c4eb;
	}
	
	h3.top02 {
		font-size: 18px;
		color: #333;
		line-height: 1;
		margin-top: 15px;
	}

	.cont_top02 p.icon {
		width: 50px;
	}
	
	.cont_top02 a .inner {
	border: 1px solid #000;
	width: 100%;
	height: 100%;
	display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		position: relative;
	}
	
	.cont_top02 a .inner:before {
		content: '';
		display: block;
		width: 3px;
		height: calc(100% - 40px);
		background-color: #fff;
		position: absolute;
		left:-1px;
		top:20px;
		z-index: 2;
	}
	
	.cont_top02 a .inner:after {
		content: '';
		display: block;
		width: 3px;
		height: calc(100% - 40px);
		background-color: #fff;
		position: absolute;
		right:-1px;
		top:20px;
		z-index: 2;
	}
	
	.cont_top02 a:before {
		content: '';
		display: block;
		width: calc(100% - 60px);
		height: 3px;
		background-color: #fff;
		position: absolute;
		top:10px;
		left:30px;
		z-index: 2;
	}
	
	.cont_top02 a:after {
		content: '';
		display: block;
		width: calc(100% - 60px);
		height: 3px;
		background-color: #fff;
		position: absolute;
		bottom:10px;
		left:30px;
		z-index: 2;
	}
	
	.bg_top02 p.btn_top a {
		margin: 15px auto 0;
		background-color: #333;
	}
	
	.bg_top02 p.btn_top a:hover {
		background-color: #81c4eb;
	}
}

@media (min-width: 768px) {
	.bg_top02 {
		width: 100%;
		background: url(../images/bg_top02.jpg) 0 0 /cover no-repeat;
		padding: 60px 0 50px;
		color: #fff;
	}
	
	h2.top02 {
		font-size: 22px;
		font-family: 'Noto Sans JP', sans-serif;;
		font-weight: 700;
		letter-spacing: 0.05em;
		line-height: 1;
		text-align: center;
		position: relative;
		margin-bottom: 30px;
	}
	
	h2.top02 span {
		display: block;
		font-family: 'Fjalla One', sans-serif;
		font-weight: normal;
		font-size: 36px;
		letter-spacing: 0;
		margin-bottom: 10px;
	}
	
	h2.top02:before {
		content: '';
		display: block;
		width: 200px;
		height: 2px;
		background-color: #fff;
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%) translateX(0);
	}
	
	h2.top02:after {
		content: '';
		display: block;
		width: 200px;
		height: 2px;
		background-color: #fff;
		position: absolute;
		top: 50%;
		right: 0;
		transform: translateY(-50%) translateX(0);
	}
	
	p.text_top02 {
		text-align: center;
		font-size: 16px;
		letter-spacing: 0.05em;
		line-height: 2;
		margin-bottom: 30px;
	}
	
	.cont_top02 {
		width: 31%;
	}
	
	.cont_top02 a {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		width: 100%;
		height: 200px;
		background-color: #fff;
		border-radius: 10px;
		position: relative;
		padding: 10px;
	}
	
	.cont_top02 a:hover {
		opacity: 1;
		background-color: #81c4eb;
	}
	
	h3.top02 {
		font-size: 19px;
		color: #333;
		line-height: 1;
		margin-top: 20px;
	}

	.cont_top02 p.icon {
		width: 70px;
	}
	
	.cont_top02 a .inner {
	border: 1px solid #000;
	width: 100%;
	height: 100%;
	display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		position: relative;
	}
	
	.cont_top02 a .inner:before {
		content: '';
		display: block;
		width: 3px;
		height: calc(100% - 40px);
		background-color: #fff;
		position: absolute;
		left:-1px;
		top:20px;
		z-index: 2;
	}
	
	.cont_top02 a .inner:after {
		content: '';
		display: block;
		width: 3px;
		height: calc(100% - 40px);
		background-color: #fff;
		position: absolute;
		right:-1px;
		top:20px;
		z-index: 2;
	}
	
	.cont_top02 a:before {
		content: '';
		display: block;
		width: calc(100% - 60px);
		height: 3px;
		background-color: #fff;
		position: absolute;
		top:10px;
		left:30px;
		z-index: 2;
	}
	
	.cont_top02 a:after {
		content: '';
		display: block;
		width: calc(100% - 60px);
		height: 3px;
		background-color: #fff;
		position: absolute;
		bottom:10px;
		left:30px;
		z-index: 2;
	}
	
	.bg_top02 p.btn_top a {
		margin: 35px auto 0;
		background-color: #333;
	}
	
	.bg_top02 p.btn_top a:hover {
		background-color: #81c4eb;
	}
}

@media (min-width: 992px) {
	.bg_top02 {
		width: 100%;
		background: url(../images/bg_top02.jpg) 0 0 /cover no-repeat;
		padding: 70px 0 55px;
		color: #fff;
	}
	
	h2.top02 {
		font-size: 24px;
		font-family: 'Noto Sans JP', sans-serif;;
		font-weight: 700;
		letter-spacing: 0.05em;
		line-height: 1;
		text-align: center;
		position: relative;
		margin-bottom: 40px;
	}
	
	h2.top02 span {
		display: block;
		font-family: 'Fjalla One', sans-serif;
		font-weight: normal;
		font-size: 46px;
		letter-spacing: 0;
		margin-bottom: 10px;
	}
	
	h2.top02:before {
		content: '';
		display: block;
		width: 280px;
		height: 2px;
		background-color: #fff;
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%) translateX(0);
	}
	
	h2.top02:after {
		content: '';
		display: block;
		width: 280px;
		height: 2px;
		background-color: #fff;
		position: absolute;
		top: 50%;
		right: 0;
		transform: translateY(-50%) translateX(0);
	}
	
	p.text_top02 {
		text-align: center;
		font-size: 18px;
		letter-spacing: 0.05em;
		line-height: 2;
		margin-bottom: 40px;
	}
	
	.cont_top02 {
		width: 31%;
	}
	
	.cont_top02 a {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		width: 100%;
		height: 240px;
		background-color: #fff;
		border-radius: 10px;
		position: relative;
		padding: 10px;
	}
	
	.cont_top02 a:hover {
		opacity: 1;
		background-color: #81c4eb;
	}
	
	h3.top02 {
		font-size: 22px;
		color: #333;
		line-height: 1;
		margin-top: 20px;
	}

	.cont_top02 p.icon {
		width: 80px;
	}
	
	.cont_top02 a .inner {
	border: 1px solid #000;
	width: 100%;
	height: 100%;
	display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		position: relative;
	}
	
	.cont_top02 a .inner:before {
		content: '';
		display: block;
		width: 3px;
		height: calc(100% - 40px);
		background-color: #fff;
		position: absolute;
		left:-1px;
		top:20px;
		z-index: 2;
	}
	
	.cont_top02 a .inner:after {
		content: '';
		display: block;
		width: 3px;
		height: calc(100% - 40px);
		background-color: #fff;
		position: absolute;
		right:-1px;
		top:20px;
		z-index: 2;
	}
	
	.cont_top02 a:before {
		content: '';
		display: block;
		width: calc(100% - 60px);
		height: 3px;
		background-color: #fff;
		position: absolute;
		top:10px;
		left:30px;
		z-index: 2;
	}
	
	.cont_top02 a:after {
		content: '';
		display: block;
		width: calc(100% - 60px);
		height: 3px;
		background-color: #fff;
		position: absolute;
		bottom:10px;
		left:30px;
		z-index: 2;
	}
	
	.bg_top02 p.btn_top a {
		margin: 50px auto 0;
		background-color: #333;
	}
	
	.bg_top02 p.btn_top a:hover {
		background-color: #81c4eb;
	}
}

@media (min-width: 1200px) {
	.bg_top02 {
		width: 100%;
		background: url(../images/bg_top02.jpg) 0 0 /cover no-repeat;
		padding: 100px 0 75px;
		color: #fff;
	}
	
	h2.top02 {
		font-size: 33px;
		font-family: 'Noto Sans JP', sans-serif;;
		font-weight: 700;
		letter-spacing: 0.05em;
		line-height: 1;
		text-align: center;
		position: relative;
		margin-bottom: 70px;
	}
	
	h2.top02 span {
		display: block;
		font-family: 'Fjalla One', sans-serif;
		font-weight: normal;
		font-size: 80px;
		letter-spacing: 0;
		margin-bottom: 10px;
	}
	
	h2.top02:before {
		content: '';
		display: block;
		width: 360px;
		height: 2px;
		background-color: #fff;
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%) translateX(0);
	}
	
	h2.top02:after {
		content: '';
		display: block;
		width: 360px;
		height: 2px;
		background-color: #fff;
		position: absolute;
		top: 50%;
		right: 0;
		transform: translateY(-50%) translateX(0);
	}
	
	p.text_top02 {
		text-align: center;
		font-size: 20px;
		letter-spacing: 0.08em;
		line-height: 2.2;
		margin-bottom: 70px;
	}
	
	.cont_top02 {
		width: 31%;
	}
	
	.cont_top02 a {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		width: 100%;
		height: 300px;
		background-color: #fff;
		border-radius: 10px;
		position: relative;
		padding: 10px;
	}
	
	.cont_top02 a:hover {
		opacity: 1;
		background-color: #81c4eb;
	}
	
	h3.top02 {
		font-size: 25px;
		color: #333;
		line-height: 1;
		margin-top: 20px;
	}

	.cont_top02 p.icon {
		width: 100px;
	}
	
	.cont_top02 a .inner {
	border: 1px solid #000;
	width: 100%;
	height: 100%;
	display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		position: relative;
	}
	
	.cont_top02 a .inner:before {
		content: '';
		display: block;
		width: 3px;
		height: calc(100% - 40px);
		background-color: #fff;
		position: absolute;
		left:-1px;
		top:20px;
		z-index: 2;
	}
	
	.cont_top02 a .inner:after {
		content: '';
		display: block;
		width: 3px;
		height: calc(100% - 40px);
		background-color: #fff;
		position: absolute;
		right:-1px;
		top:20px;
		z-index: 2;
	}
	
	.cont_top02 a:before {
		content: '';
		display: block;
		width: calc(100% - 60px);
		height: 3px;
		background-color: #fff;
		position: absolute;
		top:10px;
		left:30px;
		z-index: 2;
	}
	
	.cont_top02 a:after {
		content: '';
		display: block;
		width: calc(100% - 60px);
		height: 3px;
		background-color: #fff;
		position: absolute;
		bottom:10px;
		left:30px;
		z-index: 2;
	}
	
	.bg_top02 p.btn_top a {
		margin: 60px auto 0;
		background-color: #333;
	}
	
	.bg_top02 p.btn_top a:hover {
		background-color: #81c4eb;
	}
}







@media (max-width: 767px) {
	.cont_top03 {
		width: 100%;
	}
	
	.cont_top03 a {
		display: flex;
		flex-direction: column;
		justify-content: flex-end;
		width: 100%;
		height: 200px;
		background: url(../images/pic_top03_1.jpg) 0 0 /cover no-repeat;
		padding: 30px 15px;
		color: #fff;
	}
	
	.cont_top03:nth-of-type(2) a {
		background: url(../images/pic_top03_2.jpg) 0 0 /cover no-repeat;
	}
	
	.cont_top03 a:hover {
		opacity: 1;
	}
	
	.cont_top03 a .inner {
		display: flex;
		flex-direction: row;
		justify-content: space-between;
		align-items: flex-end;
		border-bottom: 2px solid #fff;
		padding-bottom: 20px;
		position: relative;
	}
	
	.cont_top03 a .inner:before {
		content: '';
		display: block;
		width: 120px;
		height: 2px;
		background-color: #3E91B9;
		position: absolute;
		bottom: -2px;
		left:0;
		z-index: 2;
		transition: 0.3s;
	}
	
	.cont_top03 a:hover .inner:before {
		width: 100%;
		background-color: #3E91B9;
	}
	
	.cont_top03 p.en {
		font-size: 24px;
		font-family: 'Fjalla One', sans-serif;
		line-height: 1;
		margin-bottom: 15px;
	}
	
	.cont_top03 p.en span {
		font-size: 34px;
		color: #3E91B8;
	}
	
	h2.top03 {
		font-size: 21px;
		line-height: 1;
	}
	
	.cont_top03 p.btn {
		font-family: 'Anton', sans-serif;
		font-size: 17px;
		line-height: 1;
		display: flex;
		flex-direction: row;
		align-items: center;
		margin-bottom: -10px;
		transition: 0.3s;
	}
	
	.cont_top03 p.btn:before {
		content: '';
		display: block;
		background: url(../images/icon_top03.png) 0 0 /contain no-repeat;
		width: 14px;
		height: 15px;
		margin-right: 5px;
	}
	
	.cont_top03 a:hover p.btn {
		color: #fff;
		margin-right: -10px;
	}
}

@media (min-width: 768px) {
	.cont_top03 {
		width: 50%;
	}
	
	.cont_top03 a {
		display: flex;
		flex-direction: column;
		justify-content: flex-end;
		width: 100%;
		height: 280px;
		background: url(../images/pic_top03_1.jpg) 0 0 /cover no-repeat;
		padding: 30px 30px;
		color: #fff;
	}
	
	.cont_top03:nth-of-type(2) a {
		background: url(../images/pic_top03_2.jpg) 0 0 /cover no-repeat;
	}
	
	.cont_top03 a:hover {
		opacity: 1;
	}
	
	.cont_top03 a .inner {
		display: flex;
		flex-direction: row;
		justify-content: space-between;
		align-items: flex-end;
		border-bottom: 2px solid #fff;
		padding-bottom: 20px;
		position: relative;
	}
	
	.cont_top03 a .inner:before {
		content: '';
		display: block;
		width: 120px;
		height: 2px;
		background-color: #3E91B9;
		position: absolute;
		bottom: -2px;
		left:0;
		z-index: 2;
		transition: 0.3s;
	}
	
	.cont_top03 a:hover .inner:before {
		width: 100%;
		background-color: #3E91B9;
	}
	
	.cont_top03 p.en {
		font-size: 40px;
		font-family: 'Fjalla One', sans-serif;
		line-height: 1;
		margin-bottom: 20px;
	}
	
	.cont_top03 p.en span {
		font-size: 54px;
		color: #3E91B8;
	}
	
	h2.top03 {
		font-size: 22px;
		line-height: 1;
	}
	
	.cont_top03 p.btn {
		font-family: 'Anton', sans-serif;
		font-size: 19px;
		line-height: 1;
		display: flex;
		flex-direction: row;
		align-items: center;
		margin-bottom: -10px;
		transition: 0.3s;
	}
	
	.cont_top03 p.btn:before {
		content: '';
		display: block;
		background: url(../images/icon_top03.png) 0 0 /contain no-repeat;
		width: 17px;
		height: 18px;
		margin-right: 5px;
	}
	
	.cont_top03 a:hover p.btn {
		color: #fff;
		margin-right: -10px;
	}
}

@media (min-width: 992px) {
	.cont_top03 {
		width: 50%;
	}
	
	.cont_top03 a {
		display: flex;
		flex-direction: column;
		justify-content: flex-end;
		width: 100%;
		height: 360px;
		background: url(../images/pic_top03_1.jpg) 0 0 /cover no-repeat;
		padding: 30px 40px;
		color: #fff;
	}
	
	.cont_top03:nth-of-type(2) a {
		background: url(../images/pic_top03_2.jpg) 0 0 /cover no-repeat;
	}
	
	.cont_top03 a:hover {
		opacity: 1;
	}
	
	.cont_top03 a .inner {
		display: flex;
		flex-direction: row;
		justify-content: space-between;
		align-items: flex-end;
		border-bottom: 2px solid #fff;
		padding-bottom: 25px;
		position: relative;
	}
	
	.cont_top03 a .inner:before {
		content: '';
		display: block;
		width: 210px;
		height: 2px;
		background-color: #3E91B9;
		position: absolute;
		bottom: -2px;
		left:0;
		z-index: 2;
		transition: 0.3s;
	}
	
	.cont_top03 a:hover .inner:before {
		width: 100%;
		background-color: #3E91B9;
	}
	
	.cont_top03 p.en {
		font-size: 50px;
		font-family: 'Fjalla One', sans-serif;
		line-height: 1;
		margin-bottom: 20px;
	}
	
	.cont_top03 p.en span {
		font-size: 64px;
		color: #3E91B8;
	}
	
	h2.top03 {
		font-size: 24px;
		line-height: 1;
	}
	
	.cont_top03 p.btn {
		font-family: 'Anton', sans-serif;
		font-size: 21px;
		line-height: 1;
		display: flex;
		flex-direction: row;
		align-items: center;
		margin-bottom: -10px;
		transition: 0.3s;
	}
	
	.cont_top03 p.btn:before {
		content: '';
		display: block;
		background: url(../images/icon_top03.png) 0 0 /contain no-repeat;
		width: 20px;
		height: 21px;
		margin-right: 5px;
	}
	
	.cont_top03 a:hover p.btn {
		color: #fff;
		margin-right: -10px;
	}
}

@media (min-width: 1200px) {
	.cont_top03 {
		width: 50%;
	}
	
	.cont_top03 a {
		display: flex;
		flex-direction: column;
		justify-content: flex-end;
		width: 100%;
		height: 500px;
		background: url(../images/pic_top03_1.jpg) 0 0 /cover no-repeat;
		padding: 40px 50px;
		color: #fff;
	}
	
	.cont_top03:nth-of-type(2) a {
		background: url(../images/pic_top03_2.jpg) 0 0 /cover no-repeat;
	}
	
	.cont_top03 a:hover {
		opacity: 1;
	}
	
	.cont_top03 a .inner {
		display: flex;
		flex-direction: row;
		justify-content: space-between;
		align-items: flex-end;
		border-bottom: 2px solid #fff;
		padding-bottom: 25px;
		position: relative;
	}
	
	.cont_top03 a .inner:before {
		content: '';
		display: block;
		width: 250px;
		height: 2px;
		background-color: #3E91B9;
		position: absolute;
		bottom: -2px;
		left:0;
		z-index: 2;
		transition: 0.3s;
	}
	
	.cont_top03 a:hover .inner:before {
		width: 100%;
		background-color: #3E91B9;
	}
	
	.cont_top03 p.en {
		font-size: 64px;
		font-family: 'Fjalla One', sans-serif;
		line-height: 1;
		margin-bottom: 20px;
	}
	
	.cont_top03 p.en span {
		font-size: 84px;
		color: #3E91B8;
	}
	
	h2.top03 {
		font-size: 28px;
		line-height: 1;
	}
	
	.cont_top03 p.btn {
		font-family: 'Anton', sans-serif;
		font-size: 25px;
		line-height: 1;
		display: flex;
		flex-direction: row;
		align-items: center;
		margin-bottom: -10px;
		transition: 0.3s;
	}
	
	.cont_top03 p.btn:before {
		content: '';
		display: block;
		background: url(../images/icon_top03.png) 0 0 /contain no-repeat;
		width: 20px;
		height: 21px;
		margin-right: 5px;
	}
	
	.cont_top03 a:hover p.btn {
		color: #fff;
		margin-right: -10px;
	}
}









@media (max-width: 767px) {
	.bg_top04 {
		padding: 50px 0 40px;
	}

	.cont_top04 {
		width: 100%;
		margin-bottom: 20px;
	}

	.cont_top04:nth-of-type(3n) {
		margin-right: 0;
	}

	.photo_top04 {
		height: 0;
		display: block;
		padding-bottom: 100%;
		background-color: #eff4f7;
		overflow: hidden;
		position: relative;
		margin-bottom: 15px;
	}

	.photo_top04 img {
		max-width: inherit;
		max-height: inherit;
		width: 100%;
		height: 100%;
		object-fit: scale-down;
		font-family: 'object-fit: scale-down;';
		position: absolute;
		left: 0;
		top: 0;
	}

	.cont_top04 .flex_s {
		flex-direction: row;
	}

	p.news_date {
		font-size: 15px;
		font-family: 'Roboto', sans-serif;
		font-weight: 700;
	}

	p.news_icon {
		color: #fff;
		background-color: #FF5C26;
		line-height: 1;
		font-size: 11px;
		margin-left: 10px;
		padding: 0.3em 0.5em;
	}

	.news_ttl {
		font-size: 15px;
		line-height: 1.4;
		padding-bottom: 10px;
		margin-top: 5px;
	}

	p.btn_top04 a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		color: #fff;
		font-size: 14px;
		font-weight: 700;
		font-family: 'Roboto', sans-serif;
		padding: 5px 0;
		text-align: center;
		background-color: #0581C2;
		border-radius: 30px;
	}

	p.btn_top04 a:after {
		content: '';
		display: block;
		background: url(../images/icon_btn_news.png) 0 0 /contain no-repeat;
		width: 12px;
		height: 12px;
		margin-left: 5px;
	}
}

@media (min-width: 768px) {
	.bg_top04 {
		padding: 50px 0 70px;
	}

	.cont_top04 {
		width: 31.5%;
		margin-right: 2.75%;
	}

	.cont_top04:nth-of-type(3n) {
		margin-right: 0;
	}

	.photo_top04 {
		height: 0;
		display: block;
		padding-bottom: 100%;
		background-color: #eff4f7;
		overflow: hidden;
		position: relative;
		margin-bottom: 15px;
	}

	.photo_top04 img {
		max-width: inherit;
		max-height: inherit;
		width: 100%;
		height: 100%;
		object-fit: scale-down;
		font-family: 'object-fit: scale-down;';
		position: absolute;
		left: 0;
		top: 0;
	}

	p.news_date {
		font-size: 15px;
		font-family: 'Roboto', sans-serif;
		font-weight: 700;
	}

	p.news_icon {
		color: #fff;
		background-color: #FF5C26;
		line-height: 1;
		font-size: 11px;
		margin-left: 10px;
		padding: 0.3em 0.5em;
	}

	.news_ttl {
		font-size: 16px;
		line-height: 1.4;
		padding-bottom: 15px;
		margin-top: 5px;
	}

	p.btn_top04 a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		color: #fff;
		font-size: 14px;
		font-weight: 700;
		font-family: 'Roboto', sans-serif;
		padding: 5px 0;
		text-align: center;
		width: 100%;
		background-color: #0581C2;
		border-radius: 30px;
	}

	p.btn_top04 a:after {
		content: '';
		display: block;
		background: url(../images/icon_btn_news.png) 0 0 /contain no-repeat;
		width: 12px;
		height: 12px;
		margin-left: 5px;
	}
}

@media (min-width: 992px) {
	.bg_top04 {
		padding: 80px 0 80px;
	}

	.cont_top04 {
		width: 31.5%;
		margin-right: 2.75%;
	}

	.cont_top04:nth-of-type(3n) {
		margin-right: 0;
	}

	.photo_top04 {
		height: 0;
		display: block;
		padding-bottom: 100%;
		background-color: #eff4f7;
		overflow: hidden;
		position: relative;
		margin-bottom: 15px;
	}

	.photo_top04 img {
		max-width: inherit;
		max-height: inherit;
		width: 100%;
		height: 100%;
		object-fit: scale-down;
		font-family: 'object-fit: scale-down;';
		position: absolute;
		left: 0;
		top: 0;
	}

	p.news_date {
		font-size: 16px;
		font-family: 'Roboto', sans-serif;
		font-weight: 700;
	}

	p.news_icon {
		color: #fff;
		background-color: #FF5C26;
		line-height: 1;
		font-size: 11px;
		margin-left: 10px;
		padding: 0.3em 0.5em;
	}

	.news_ttl {
		font-size: 16px;
		line-height: 1.4;
		padding-bottom: 15px;
		margin-top: 5px;
	}

	p.btn_top04 a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		color: #fff;
		font-size: 15px;
		font-weight: 700;
		font-family: 'Roboto', sans-serif;
		padding: 5px 0;
		text-align: center;
		width: 100%;
		background-color: #0581C2;
		border-radius: 30px;
	}

	p.btn_top04 a:after {
		content: '';
		display: block;
		background: url(../images/icon_btn_news.png) 0 0 /contain no-repeat;
		width: 12px;
		height: 12px;
		margin-left: 5px;
	}
}

@media (min-width: 1200px) {
	.bg_top04 {
		padding: 80px 0 90px;
	}

	.bg_top04 h2 {
		text-align: center;
	}

	.bg_top04 h2 span {
		font-size: 56px;
		margin-bottom: 10px;
	}

	.cont_top04 {
		width: 31.5%;
		margin-right: 2.75%;
	}

	.cont_top04:nth-of-type(3n) {
		margin-right: 0;
	}

	.photo_top04 {
		height: 0;
		display: block;
		padding-bottom: 100%;
		background-color: #eff4f7;
		overflow: hidden;
		position: relative;
		margin-bottom: 15px;
	}

	.photo_top04 img {
		max-width: inherit;
		max-height: inherit;
		width: 100%;
		height: 100%;
		object-fit: scale-down;
		font-family: 'object-fit: scale-down;';
		position: absolute;
		left: 0;
		top: 0;
	}

	p.news_date {
		font-size: 16px;
		font-family: 'Roboto', sans-serif;
		font-weight: 700;
	}

	p.news_icon {
		color: #fff;
		background-color: #FF5C26;
		line-height: 1;
		font-size: 11px;
		margin-left: 10px;
		padding: 0.3em 0.5em;
	}

	.news_ttl {
		font-size: 16px;
		line-height: 1.4;
		padding-bottom: 15px;
		margin-top: 5px;
	}

	p.btn_top04 a {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		color: #fff;
		font-size: 15px;
		font-weight: 700;
		font-family: 'Roboto', sans-serif;
		padding: 5px 0;
		text-align: center;
		width: 100%;
		background-color: #0581C2;
		border-radius: 30px;
	}

	p.btn_top04 a:after {
		content: '';
		display: block;
		background: url(../images/icon_btn_news.png) 0 0 /contain no-repeat;
		width: 12px;
		height: 12px;
		margin-left: 5px;
	}
}

.cont_top04 p.pic a:hover {
	opacity: 0.85;
}





/* フッター
=========================================================================== */

@media (max-width: 767px) {
	footer {
		padding: 50px 0 0;
		background: url(../images/bg_footer.jpg) 20% 0 /cover no-repeat;
		color: #fff;
	}
	
	.footer_l {
		width: 100%;
	}
	
	.footer_r {
		width: 100%;
	}
	
	p.logo_f {
		width: 240px;
		margin: 0 auto 15px;
	}
	
	p.text_f {
		font-size: 15px;
		letter-spacing: 0.05em;
		margin-bottom: 10px;
		text-align: center;
		line-height: 1.6;
	}
	
	span.btn_map_f a {
		display: inline-block;
		margin-left: 5px;
	}
	
	span.btn_map_f a img {
		width: 16px;
	}
	
	p.tel_f {
		font-family: 'Fjalla One', sans-serif;
		font-size: 22px;
		letter-spacing: 0.05em;
		margin-top: 10px;
		text-align: center;
	}
	
	p.tel_f span.tel_link {
		color: #fff;
	}
	
	ul.fnav {
		width: 100%;
		display: flex;
		flex-direction: row;
		justify-content: center;
		padding-top: 25px;
	}
	
	ul.fnav li {
		margin-left: 15px;
	}
	
	ul.fnav li:first-child {
		margin-left: 0;
	}
	
	ul.fnav li a {
		width: 20px;
		font-size: 16px;
		letter-spacing: 0.1em;
		color: #fff;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		-webkit-writing-mode: vertical-rl;
		-ms-writing-mode: tb-rl;
		writing-mode: vertical-rl;
	}
	
	ul.fnav li a:before {
		content: '';
		display: block;
		width: 7px;
		height: 7px;
		background-color: #8FCFF1;
		border-radius: 50%;
		flex-shrink: 0;
		margin-bottom: 8px;
	}
	
	p.copyright {
		font-size: 12px;
		color: #fff;
		width: 100%;
		letter-spacing: 0.1em;
		text-align: center;
		margin-top: 30px;
		padding-bottom: 20px;
	}
}

@media (min-width: 768px) and (max-width:991px) {
	footer {
		padding: 100px 0 0;
		background: url(../images/bg_footer.jpg) 0 0 /cover no-repeat;
		color: #fff;
	}
	
	.footer_l {
		width: 54%;
	}
	
	.footer_r {
		width: 44%;
	}
	
	p.logo_f {
		width: 300px;
		margin-bottom: 20px;
	}
	
	p.text_f {
		font-size: 16px;
		letter-spacing: 0.05em;
		margin-bottom: 10px;
	}
	
	span.btn_map_f a {
		display: inline-block;
		margin-left: 10px;
	}
	
	span.btn_map_f a img {
		width: 18px;
	}
	
	p.tel_f {
		font-family: 'Fjalla One', sans-serif;
		font-size: 24px;
		letter-spacing: 0.05em;
		margin-top: 20px;
	}
	
	p.tel_f span.tel_link {
		color: #fff;
	}
	
	ul.fnav {
		width: 100%;
		display: flex;
		flex-direction: row;
		justify-content: flex-end;
		padding-top: 15px;
	}
	
	ul.fnav li {
		margin-left: 30px;
	}
	
	ul.fnav li:first-child {
		margin-left: 0;
	}
	
	ul.fnav li a {
		width: 20px;
		font-size: 16px;
		letter-spacing: 0.1em;
		color: #fff;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		-webkit-writing-mode: vertical-rl;
		-ms-writing-mode: tb-rl;
		writing-mode: vertical-rl;
	}
	
	ul.fnav li a:before {
		content: '';
		display: block;
		width: 7px;
		height: 7px;
		background-color: #8FCFF1;
		border-radius: 50%;
		flex-shrink: 0;
		margin-bottom: 8px;
	}
	
	p.copyright {
		font-size: 13px;
		color: #fff;
		width: 100%;
		letter-spacing: 0.1em;
		text-align: center;
		margin-top: 100px;
		padding-bottom: 25px;
	}
}

@media (min-width: 992px) and (max-width:1199px) {
	footer {
		padding: 100px 0 0;
		background: url(../images/bg_footer.jpg) 0 0 /cover no-repeat;
		color: #fff;
	}
	
	.footer_l {
		width: 48%;
	}
	
	.footer_r {
		width: 48%;
	}
	
	p.logo_f {
		width: 300px;
		margin-bottom: 25px;
	}
	
	p.text_f {
		font-size: 16px;
		letter-spacing: 0.05em;
		margin-bottom: 10px;
	}
	
	span.btn_map_f a {
		display: inline-block;
		margin-left: 10px;
	}
	
	span.btn_map_f a img {
		width: 18px;
	}
	
	p.tel_f {
		font-family: 'Fjalla One', sans-serif;
		font-size: 24px;
		letter-spacing: 0.05em;
		margin-top: 25px;
	}
	
	p.tel_f span.tel_link {
		color: #fff;
	}
	
	ul.fnav {
		width: 100%;
		display: flex;
		flex-direction: row;
		justify-content: flex-end;
		padding-top: 15px;
	}
	
	ul.fnav li {
		margin-left: 30px;
	}
	
	ul.fnav li:first-child {
		margin-left: 0;
	}
	
	ul.fnav li a {
		width: 20px;
		font-size: 16px;
		letter-spacing: 0.1em;
		color: #fff;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		-webkit-writing-mode: vertical-rl;
		-ms-writing-mode: tb-rl;
		writing-mode: vertical-rl;
	}
	
	ul.fnav li a:before {
		content: '';
		display: block;
		width: 7px;
		height: 7px;
		background-color: #8FCFF1;
		border-radius: 50%;
		flex-shrink: 0;
		margin-bottom: 8px;
	}
	
	p.copyright {
		font-size: 13px;
		color: #fff;
		width: 100%;
		letter-spacing: 0.1em;
		text-align: center;
		margin-top: 100px;
		padding-bottom: 25px;
	}
}

@media (min-width: 1200px) {
	footer {
		padding: 120px 0 0;
		background: url(../images/bg_footer.jpg) 0 0 /cover no-repeat;
		color: #fff;
	}
	
	.footer_l {
		width: 40%;
	}
	
	.footer_r {
		width: 60%;
	}
	
	p.logo_f {
		width: 330px;
		margin-bottom: 25px;
	}
	
	p.text_f {
		font-size: 16px;
		letter-spacing: 0.05em;
		margin-bottom: 10px;
	}
	
	span.btn_map_f a {
		display: inline-block;
		margin-left: 10px;
	}
	
	span.btn_map_f a img {
		width: 18px;
	}
	
	p.tel_f {
		font-family: 'Fjalla One', sans-serif;
		font-size: 26px;
		letter-spacing: 0.05em;
		margin-top: 25px;
	}
	
	p.tel_f span.tel_link {
		color: #fff;
	}
	
	ul.fnav {
		width: 100%;
		display: flex;
		flex-direction: row;
		justify-content: flex-end;
		padding-top: 15px;
	}
	
	ul.fnav li {
		margin-left: 30px;
	}
	
	ul.fnav li:first-child {
		margin-left: 0;
	}
	
	ul.fnav li a {
		font-size: 16px;
		color: #fff;
		display: flex;
		flex-direction: row;
		align-items: center;
	}
	
	ul.fnav li a:before {
		content: '';
		display: block;
		width: 7px;
		height: 7px;
		background-color: #8FCFF1;
		border-radius: 50%;
		flex-shrink: 0;
		margin-right: 8px;
	}
	
	p.copyright {
		font-size: 14px;
		color: #fff;
		width: 100%;
		letter-spacing: 0.1em;
		text-align: center;
		margin-top: 100px;
		padding-bottom: 25px;
	}
}

@media (min-width: 1300px) {
	footer {
		padding: 150px 0 0;
		background: url(../images/bg_footer.jpg) 0 0 /cover no-repeat;
		color: #fff;
	}
	
	footer .container {
		width: 1240px;
	}
	
	.footer_l {
		width: 40%;
	}
	
	.footer_r {
		width: 60%;
	}
	
	p.logo_f {
		width: 350px;
		margin-bottom: 25px;
	}
	
	p.text_f {
		font-size: 17px;
		letter-spacing: 0.05em;
		margin-bottom: 10px;
	}
	
	span.btn_map_f a {
		display: inline-block;
		margin-left: 10px;
	}
	
	span.btn_map_f a img {
		width: 18px;
	}
	
	p.tel_f {
		font-family: 'Fjalla One', sans-serif;
		font-size: 26px;
		letter-spacing: 0.05em;
		margin-top: 25px;
	}
	
	p.tel_f span.tel_link {
		color: #fff;
	}
	
	ul.fnav {
		width: 100%;
		display: flex;
		flex-direction: row;
		justify-content: flex-end;
		padding-top: 15px;
	}
	
	ul.fnav li {
		margin-left: 35px;
	}
	
	ul.fnav li:first-child {
		margin-left: 0;
	}
	
	ul.fnav li a {
		font-size: 17px;
		color: #fff;
		display: flex;
		flex-direction: row;
		align-items: center;
	}
	
	ul.fnav li a:before {
		content: '';
		display: block;
		width: 7px;
		height: 7px;
		background-color: #8FCFF1;
		border-radius: 50%;
		flex-shrink: 0;
		margin-right: 8px;
	}
	
	p.copyright {
		font-size: 14px;
		color: #fff;
		width: 100%;
		letter-spacing: 0.1em;
		text-align: center;
		margin-top: 100px;
		padding-bottom: 25px;
	}
}


@media (max-width: 767px) {
	p.pagetop a {
		position: fixed;
		bottom: 30px;
		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: 40px;
		right: 35px;
		width: 42px;
		height: 42px;
		z-index: 999;
	}

	p.pagetop a img {
		width: 42px;
		height: 42px;
	}
}

@media (min-width: 1921px) {
	p.pagetop a {
		position: fixed;
		bottom: 40px;
		right: calc(50% - 920px);
		width: 42px;
		height: 42px;
		z-index: 99;
	}

	p.pagetop a img {
		width: 42px;
		height: 42px;
	}
}



/* サブページ共通
=========================================================================== */

@media (max-width: 767px) {
	.bg_sub {
		width: 100%;
		height: 220px;
		position: relative;
		margin-top: 60px;
	}
	
	.bg_sub .inner {
		height: 220px;
		position: relative;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
	}
	
	h2.sub {
		font-size: 24px;
		color: #fff;
		text-align: center;
		line-height: 1;
		margin-top: 0;
		letter-spacing: 0.05em;
	}
	
	h2.sub span {
		display: block;
		color:#abe2ff;
		opacity: 0.8;
		font-family: 'Fjalla One', sans-serif;
		font-size: 26px;
		margin-bottom: 10px;
		letter-spacing: 0;
	}
}

@media (min-width: 768px) {
	.bg_sub {
		width: 100%;
		height: 300px;
		position: relative;
		margin-top: 65px;
	}
	
	.bg_sub .inner {
		height: 300px;
		position: relative;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
	}
	
	h2.sub {
		font-size: 28px;
		color: #fff;
		text-align: center;
		line-height: 1;
		margin-top: 0;
		letter-spacing: 0.05em;
	}
	
	h2.sub span {
		display: block;
		color:#8ed1f5;
		opacity: 0.8;
		font-family: 'Fjalla One', sans-serif;
		font-size: 30px;
		margin-bottom: 10px;
		letter-spacing: 0;
	}
}

@media (min-width: 992px) {
	.bg_sub {
		width: 100%;
		height: 400px;
		position: relative;
		margin-top: 0;
	}
	
	.bg_sub .inner {
		height: 400px;
		position: relative;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
	}
	
	h2.sub {
		font-size: 33px;
		color: #fff;
		text-align: center;
		line-height: 1;
		margin-top: 80px;
		letter-spacing: 0.05em;
	}
	
	h2.sub span {
		display: block;
		color:#8ed1f5;
		opacity: 0.8;
		font-family: 'Fjalla One', sans-serif;
		font-size: 40px;
		margin-bottom: 10px;
		letter-spacing: 0;
	}
}

@media (min-width: 1200px) {
	.bg_sub {
		width: 100%;
		height: 460px;
	}

	.bg_sub .inner {
			height: 460px;
			position: relative;
			display: flex;
			flex-direction: column;
			align-items: center;
			justify-content: center;
		}
		
		h2.sub {
			font-size: 33px;
			color: #fff;
			text-align: center;
			line-height: 1;
			margin-top: 80px;
			letter-spacing: 0.05em;
		}
		
		h2.sub span {
			display: block;
			color:#8ed1f5;
			opacity: 0.8;
			font-family: 'Fjalla One', sans-serif;
			font-size: 40px;
			margin-bottom: 10px;
			letter-spacing: 0;
		}
	
	h2.sub {
		font-size: 39px;
		color: #fff;
		text-align: center;
		line-height: 1;
		margin-top: 100px;
		letter-spacing: 0.05em;
	}
	
	h2.sub span {
		display: block;
		color:#8ed1f5;
		opacity: 0.8;
		font-family: 'Fjalla One', sans-serif;
		font-size: 51px;
		margin-bottom: 10px;
		letter-spacing: 0;
	}
}


@media (max-width: 767px) {
	.bg_about {
		background: url(../images/bg_about_sp.jpg) 0 0 /cover no-repeat;
	}
	
	.bg_recruit {
		background: url(../images/bg_recruit_sp.jpg) 0 0 /cover no-repeat;
	}
	
	.bg_company {
		background: url(../images/bg_company_sp.jpg) 0 0 /cover no-repeat;
	}
	
	.bg_entry {
		background: url(../images/bg_entry_sp.jpg) 0 0 /cover no-repeat;
	}

	.bg_news {
		background: url(../images/bg_news_sp.jpg) 0 0 /cover no-repeat;
	}
}

@media (min-width: 768px) {
	.bg_about {
		background: url(../images/bg_about.jpg) 0 0 /cover no-repeat;
	}
	
	.bg_recruit {
		background: url(../images/bg_recruit.jpg) 0 0 /cover no-repeat;
	}
	
	.bg_company {
		background: url(../images/bg_company.jpg) 0 0 /cover no-repeat;
	}
	
	.bg_entry {
		background: url(../images/bg_entry.jpg) 0 0 /cover no-repeat;
	}
	
	.bg_news {
		background: url(../images/bg_news.jpg) 0 0 /cover no-repeat;
	}
}


/* news.html　新着情報
=========================================================================== */

@media (max-width: 767px) {
	ul.nav_news {
		display: flex;
		flex-direction: row;
		flex-wrap: wrap;
		align-items: center;
		margin-bottom: 20px;
	}

	ul.nav_news li {
		margin-right: 10px;
		margin-bottom: 10px;
	}

	ul.nav_news li 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;
		color: #333;
		padding: 0.5em 1em;
		border-radius: 16px;
		border: 1px solid #2E86C9;
	}

	ul.nav_news li a {
		transition: 0.1s;
	}

	ul.nav_news li.active a {
		background-color: #2E86C9;
		color: #fff;
	}

	ul.nav_news li:hover a {
		background-color: #2E86C9;
		color: #fff;
		opacity: 1;
	}
}

@media (min-width: 768px) {
	ul.nav_news {
		display: flex;
		flex-direction: row;
		flex-wrap: wrap;
		align-items: center;
		margin-bottom: 20px;
	}

	ul.nav_news li {
		margin-right: 15px;
		margin-bottom: 15px;
	}

	ul.nav_news li 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;
		color: #333;
		padding: 0.5em 2em;
		border-radius: 30px;
		border: 1px solid #2E86C9;
	}

	ul.nav_news li a {
		transition: 0.1s;
	}

	ul.nav_news li.active a {
		background-color: #2E86C9;
		color: #fff;
	}

	ul.nav_news li:hover a {
		background-color: #2E86C9;
		color: #fff;
		opacity: 1;
	}
}

@media (min-width: 992px) {
	ul.nav_news {
		display: flex;
		flex-direction: row;
		flex-wrap: wrap;
		align-items: center;
		margin-bottom: 20px;
	}

	ul.nav_news li {
		margin-right: 15px;
		margin-bottom: 15px;
	}

	ul.nav_news li 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;
		color: #333;
		padding: 0.5em 2em;
		border-radius: 30px;
		border: 1px solid #2E86C9;
	}

	ul.nav_news li a {
		transition: 0.1s;
	}

	ul.nav_news li.active a {
		background-color: #2E86C9;
		color: #fff;
	}

	ul.nav_news li:hover a {
		background-color: #2E86C9;
		color: #fff;
		opacity: 1;
	}
}

@media (max-width: 767px) {
	#news .cont_top04 {
		margin-bottom: 30px;
	}
}

@media (min-width: 768px) {
	#news .cont_top04 {
		margin-bottom: 40px;
	}
}

@media (min-width: 992px) {
	#news .cont_top04 {
		margin-bottom: 50px;
	}
}

@media (max-width: 359px) {
	div.paging {
		text-align: center;
	}

	div.paging span.current,
	div.paging span.paging-text {
		margin: 0px 0px;
		color: #1192d8;
		border: 1px solid #1192d8;
		display: inline;
		zoom: 1;
		display: inline-block;
		overflow: hidden;
		text-decoration: none;
		border-radius: 3px;
	}

	div.paging span.paging-text a {
		padding: 3px 5px;
		display: block;
		color: #1192d8;
		background-color: #fff;
	}

	div.paging span.current {
		background: #1192d8;
		border: 1px solid #1192d8;
		color: #fff;
		display: inline;
		zoom: 1;
		padding: 3px 5px;
		text-decoration: none;
		display: inline-block;
		cursor: pointer;
	}

	div.paging span.paging-text a:hover {
		background: #1192d8;
		color: #fff;
		text-decoration: none;
		cursor: pointer;
		opacity: 0.8;
	}
}

@media (min-width: 360px) {
	div.paging {
		text-align: center;
	}

	div.paging span.current,
	div.paging span.paging-text {
		margin: 0px 2px;
		color: #1192d8;
		border: 1px solid #1192d8;
		display: inline;
		zoom: 1;
		display: inline-block;
		overflow: hidden;
		text-decoration: none;
		border-radius: 5px;
	}

	div.paging span.paging-text a {
		padding: 4px 8px;
		display: block;
		color: #1192d8;
		background-color: #fff;
	}

	div.paging span.current {
		background: #1192d8;
		border: 1px solid #1192d8;
		color: #fff;
		display: inline;
		zoom: 1;
		padding: 4px 8px;
		text-decoration: none;
		display: inline-block;
		cursor: pointer;
	}

	div.paging span.paging-text a:hover {
		background: #1192d8;
		color: #fff;
		text-decoration: none;
		cursor: pointer;
		opacity: 0.8;
	}
}

@media (min-width: 768px) {
	div.paging {
		text-align: center;
	}

	div.paging span.current,
	div.paging span.paging-text {
		margin: 0px 2px;
		color: #1192d8;
		border: 1px solid #1192d8;
		display: inline;
		zoom: 1;
		display: inline-block;
		overflow: hidden;
		text-decoration: none;
		border-radius: 5px;
	}

	div.paging span.paging-text a {
		padding: 5px 13px;
		display: block;
		color: #1192d8;
		background-color: #fff;
	}

	div.paging span.current {
		background: #1192d8;
		border: 1px solid #1192d8;
		color: #fff;
		display: inline;
		zoom: 1;
		padding: 5px 13px;
		text-decoration: none;
		display: inline-block;
		cursor: pointer;
	}

	div.paging span.paging-text a:hover {
		background: #1192d8;
		color: #fff;
		text-decoration: none;
		cursor: pointer;
		opacity: 0.8;
	}
}









/* news.html　新着情報詳細
=========================================================================== */




@media (max-width: 767px) {
	.info_view {
		display: flex;
		flex-direction: row;
		align-items: center;
		margin-bottom: 15px;
	}
	
	#view p.news_date {
		font-family: 'Roboto', sans-serif;
		font-size: 15px;
	}
	
	#view p.news_icon {
		font-size: 11px;
		color: #fff;
		background-color: #FF5C26;
		font-family: 'Roboto', sans-serif;
		font-weight: 700;
	}
	
	h3.view {
		color: #0571AB;
		font-size: 17px;
		font-weight: 500;
		padding-bottom: 10px;
		border-bottom: 2px solid #0571AB;
		margin-bottom: 15px;
		line-height: 1.4;
	}
	
	.cont_view {
		margin: 25px 0;
		font-size: 15px;
		letter-spacing: 0.03em;
		line-height: normal;
	}
	
	ul.pic_view {
		width: 100%;
		display: flex;
		flex-direction: column;
		margin: 25px 0;
	}
	
	ul.pic_view li {
		width: 100%;
		margin-bottom: 15px;
	}
	
	ul.pic_view li a {
		position: relative;
		display: block;
	}

	.photo_view {
		height: 0;
		display: block;
		padding-bottom: 65%;
		background-color: #f7f7f7;
		overflow: hidden;
		position: relative;
		margin-bottom: 10px;
	}
	
	.photo_view img {
		max-width: inherit;
		max-height: inherit;
		width: 100%;
		height: 100%;
		object-fit: scale-down;
		font-family: 'object-fit: scale-down;';
		position: absolute;
		left: 0;
		top: 0;
	}
	
	ul.file_view {
		display: flex;
		flex-direction: column;
		margin: 20px 0;
	}
	
	ul.file_view li {
		margin-bottom: 15px;
	}
	
	ul.file_view li a {
		display: flex;
		flex-direction: row;
		align-items: center;
		color: #0571AB;
		font-size: 15px;
		border: 2px solid #0571AB;
		padding: 0.7em 2em 0.7em 3.4em;
		position: relative;
		border-radius: 10px;
	}
	
	ul.file_view li a:before {
		content: '';
		display: block;
		background: url(../images/icon_file.png) 0 0 /contain no-repeat;
		width: 24px;
		height: 22px;
		position: absolute;
		top: 50%;
		left: 15px;
		transform: translateY(-50%) translateX(0);
		flex-shrink: 0;
	}
	
	p.btn_back a {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		width: 80px;
		height: 80px;
		background-color: #ddd;
		border-radius: 50%;
		color: #333;
		font-size: 14px;
		font-weight: 500;
		margin: 30px auto 0;
		text-align: center;
		line-height: 1.2;
	}
	
	p.btn_back a:before {
		content: '';
		display: block;
		background: url(../images/icon_back.png) 0 0 /contain no-repeat;
		width: 36px;
		height: 20px;
		margin: 0 auto 8px;
		flex-shrink: 0;
	}
}

@media (min-width: 768px) {
	.info_view {
		display: flex;
		flex-direction: row;
		align-items: center;
		margin-bottom: 15px;
	}
	
	#view p.news_date {
		font-family: 'Roboto', sans-serif;
		font-size: 16px;
	}
	
	#view p.news_icon {
		font-size: 12px;
		color: #fff;
		background-color: #FF5C26;
		font-family: 'Roboto', sans-serif;
		font-weight: 700;
	}
	
	h3.view {
		color: #0571AB;
		font-size: 19px;
		font-weight: 500;
		padding-bottom: 12px;
		border-bottom: 2px solid #0571AB;
		margin-bottom: 20px;
		line-height: 1.4;
	}
	
	.cont_view {
		margin: 25px 0;
		font-size: 16px;
		line-height: normal;
		letter-spacing: 0.03em;
	}
	
	ul.pic_view {
		width: 100%;
		display: flex;
		flex-direction: row;
		flex-wrap: wrap;
		align-items: center;
		margin: 25px 0;
	}
	
	ul.pic_view li {
		width: 32%;
		margin-right: 2%;
		margin-bottom: 15px;
	}
	
	ul.pic_view li:nth-of-type(3n) {
		margin-right: 0;
	}
	
	ul.pic_view li a {
		position: relative;
		display: block;
	}
	
	ul.pic_view li a:before {
		content: "\f00e";
		font-family: 'Font Awesome\ 5 Free';
		font-weight: 900;
		position: absolute;
		right: 15px;
		bottom: 10px;
		color: #fff;
		font-size: 20px;
		text-shadow: 5px 2px 5px rgba(0, 0, 0, 0.2);
		z-index: 22;
	}
	
	.photo_view {
		height: 0;
		display: block;
		padding-bottom: 80%;
		background-color: #f7f7f7;
		overflow: hidden;
		position: relative;
		margin-bottom: 10px;
	}
	
	.photo_view img {
		max-width: inherit;
		max-height: inherit;
		width: 100%;
		height: 100%;
		object-fit: scale-down;
		font-family: 'object-fit: scale-down;';
		position: absolute;
		left: 0;
		top: 0;
	}
	
	ul.file_view {
		display: flex;
		flex-direction: row;
		margin: 20px 0;
	}
	
	ul.file_view li {
		margin-right: 20px;
	}
	
	ul.file_view li a {
		display: flex;
		flex-direction: row;
		align-items: center;
		color: #0571AB;
		font-size: 15px;
		border: 2px solid #0571AB;
		padding: 0.7em 2em 0.7em 3.4em;
		position: relative;
		border-radius: 10px;
	}
	
	ul.file_view li a:before {
		content: '';
		display: block;
		background: url(../images/icon_file.png) 0 0 /contain no-repeat;
		width: 24px;
		height: 22px;
		position: absolute;
		top: 50%;
		left: 15px;
		transform: translateY(-50%) translateX(0);
		flex-shrink: 0;
	}
	
	p.btn_back a {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		width: 90px;
		height: 90px;
		background-color: #ddd;
		border-radius: 50%;
		color: #333;
		font-size: 14px;
		font-weight: 500;
		margin: 30px auto 0;
		text-align: center;
		line-height: 1.2;
	}
	
	p.btn_back a:before {
		content: '';
		display: block;
		background: url(../images/icon_back.png) 0 0 /contain no-repeat;
		width: 36px;
		height: 20px;
		margin: 0 auto 8px;
		flex-shrink: 0;
	}
}

@media (min-width: 992px) {
	.info_view {
		display: flex;
		flex-direction: row;
		align-items: center;
		margin-bottom: 15px;
	}
	
	#view p.news_date {
		font-family: 'Roboto', sans-serif;
		font-size: 18px;
	}
	
	#view p.news_icon {
		font-size: 13px;
		color: #fff;
		background-color: #FF5C26;
		font-family: 'Roboto', sans-serif;
		font-weight: 700;
	}
	
	h3.view {
		color: #0571AB;
		font-size: 21px;
		font-weight: 500;
		padding-bottom: 12px;
		border-bottom: 3px solid #0571AB;
		margin-bottom: 30px;
		line-height: 1.4;
	}
	
	.cont_view {
		margin: 25px 0;
		font-size: 16px;
		line-height: normal;
	}
	
	ul.pic_view {
		width: 100%;
		display: flex;
		flex-direction: row;
		align-items: center;
		flex-wrap: wrap;
		margin: 25px 0;
	}
	
	ul.pic_view li {
		width: 32%;
		margin-right: 2%;
		margin-bottom: 15px;
	}
	
	ul.pic_view li:nth-of-type(3n) {
		margin-right: 0;
	}
	
	ul.pic_view li a {
		display: block;
		position: relative;
	}
	
	ul.pic_view li a:before {
		content: "\f00e";
		font-family: 'Font Awesome\ 5 Free';
		font-weight: 900;
		position: absolute;
		right: 15px;
		bottom: 10px;
		color: #fff;
		font-size: 20px;
		text-shadow: 5px 2px 5px rgba(0, 0, 0, 0.2);
		z-index: 22;
	}
	
	.photo_view {
		height: 0;
		display: block;
		padding-bottom: 80%;
		background-color: #f7f7f7;
		overflow: hidden;
		position: relative;
		margin-bottom: 10px;
	}
	
	.photo_view img {
		max-width: inherit;
		max-height: inherit;
		width: 100%;
		height: 100%;
		object-fit: scale-down;
		font-family: 'object-fit: scale-down;';
		position: absolute;
		left: 0;
		top: 0;
	}
	
	ul.file_view {
		display: flex;
		flex-direction: row;
		margin: 20px 0;
	}
	
	ul.file_view li {
		margin-right: 20px;
	}
	
	ul.file_view li a {
		display: flex;
		flex-direction: row;
		align-items: center;
		color: #0571AB;
		font-size: 15px;
		border: 2px solid #0571AB;
		padding: 0.7em 2em 0.7em 3.4em;
		position: relative;
		border-radius: 10px;
	}
	
	ul.file_view li a:before {
		content: '';
		display: block;
		background: url(../images/icon_file.png) 0 0 /contain no-repeat;
		width: 24px;
		height: 22px;
		position: absolute;
		top: 50%;
		left: 15px;
		transform: translateY(-50%) translateX(0);
		flex-shrink: 0;
	}
	
	p.btn_back a {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		width: 100px;
		height: 100px;
		background-color: #ddd;
		border-radius: 50%;
		color: #333;
		font-size: 15px;
		font-weight: 500;
		margin: 30px auto 0;
		text-align: center;
		line-height: 1.2;
	}
	
	p.btn_back a:before {
		content: '';
		display: block;
		background: url(../images/icon_back.png) 0 0 /contain no-repeat;
		width: 40px;
		height: 22px;
		margin: 0 auto 8px;
		flex-shrink: 0;
	}
}


/* about.html　田中興発を知る
=========================================================================== */


@media (max-width: 767px) {
	.bg_about01 {
		padding: 30px 0;
	}

	.bg_about01 .container > .mb_cont {
		margin-bottom: 50px!important;
	}
	
	.ttl_about {
		margin-bottom: 30px;
	}
	
	.ttl_about p.en {
	font-size: 50px;
	color: #E4F5FE;
	font-family: 'Fjalla One', sans-serif;
	text-align: center;
	line-height: 1;
	}
	
	.ttl_about h3 {
		text-align: center;
		font-size: 24px;
		color: #0571AB;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		letter-spacing: 0.1em;
		margin-top: -1.2em;
	}
	
	.pic_about {
		width: 100%;
		margin-top: 15px;
	}
	
	.pic_about img {
		border: 3px solid #0571AB;
		border-radius: 20px;
	}

	.bg_about01 .flex_b:nth-of-type(even) img {
		border: 3px solid #FFDE33
	}

	.pic_about p.ttl img {
		border: none!important;
		border-radius: 0;
	}
	
	.cont_about {
		width: 100%;
	}
	
	.en_ttl_about {
		position: relative;
	}
	
	.en_ttl_about p {
		width: 100%;
		background-color: #0571AB;
		transform: skewX(-18deg);
		font-size: 16px;
		font-family: 'Fjalla One', sans-serif;
		letter-spacing: 0.03em;
		position: relative;
		z-index: 2;
		line-height: 1;
		color: #fff;
		padding: 0.5em 1em 0.4em 1em;
	}
	
	.en_ttl_about p span {
		display: block;
		transform: skewX(18deg);
		position: relative;
	}
	
	.en_ttl_about:before {
		content: '';
		display: block;
		width: 40px;
		height: 40px;
		background: linear-gradient(to bottom,#fff,#FFDE33);
		border-radius: 50%;
		position: absolute;
		left:-10px;
		top: -20px;
		z-index: 1;
	}
	
	h4.about {
		font-size: 21px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.05em;
		margin: 10px 0 10px 0;
	}
	
	h4.about span {
		font-size: 16px;
	}

	h4.about01 {
		font-size: 20px!important;
	}
	
	.cont_about p.text {
		font-size: 16px;
		letter-spacing: 0.05em;
		line-height: 1.8;
	}
	
	.bg_about01 .flex_b:nth-of-type(odd) .en_ttl_about p {
		background-color: #f5d325;
		color: #333;
	}
	
	.bg_about01 .flex_b:nth-of-type(odd) .en_ttl_about:before {
		background: linear-gradient(to bottom,#fff,#4D9AC3);
	}
}

@media (min-width: 768px) {
	.bg_about01 {
		padding: 30px 0;
	}
	
	.ttl_about {
		margin-bottom: 60px;
	}
	
	.ttl_about p.en {
	font-size: 70px;
	color: #E4F5FE;
	font-family: 'Fjalla One', sans-serif;
	text-align: center;
	line-height: 1;
	}
	
	.ttl_about h3 {
		text-align: center;
		font-size: 28px;
		color: #0571AB;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		letter-spacing: 0.1em;
		margin-top: -1.2em;
	}
	
	.pic_about {
		width: 48%;
	}
	
	.pic_about img {
		border: 3px solid #0571AB;
		border-radius: 20px;
	}
	
	.bg_about01 .flex_b:nth-of-type(even) img {
		border: 3px solid #FFDE33
	}

	.pic_about p.ttl img {
		border: none!important;
		border-radius: 0;
	}
	
	.cont_about {
		width: 48%;
	}
	
	.en_ttl_about {
		position: relative;
	}
	
	.en_ttl_about p {
		width: 100%;
		background-color: #0571AB;
		transform: skewX(-18deg);
		font-size: 18px;
		font-family: 'Fjalla One', sans-serif;
		letter-spacing: 0.03em;
		position: relative;
		z-index: 2;
		line-height: 1;
		color: #fff;
		padding: 0.5em 1em 0.4em 1em;
	}
	
	.en_ttl_about p span {
		display: block;
		transform: skewX(18deg);
		position: relative;
	}
	
	.en_ttl_about:before {
		content: '';
		display: block;
		width: 50px;
		height: 50px;
		background: linear-gradient(to bottom,#fff,#FFDE33);
		border-radius: 50%;
		position: absolute;
		left:-15px;
		top: -30px;
		z-index: 1;
	}
	
	h4.about {
		font-size: 24px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
		margin: 15px 0 12px 0;
	}
	
	h4.about span {
		font-size: 19px;
	}
	
	.cont_about p.text {
		font-size: 16px;
		letter-spacing: 0.05em;
		line-height: 1.8;
	}
	
	.bg_about01 .flex_b:nth-of-type(odd) .en_ttl_about p {
		background-color: #f5d325;
		color: #333;
	}
	
	.bg_about01 .flex_b:nth-of-type(odd) .en_ttl_about:before {
		background: linear-gradient(to bottom,#fff,#4D9AC3);
	}
}

@media (min-width: 992px) {
	.bg_about01 {
		padding: 40px 0;
	}
	
	.ttl_about {
		margin-bottom: 60px;
	}
	
	.ttl_about p.en {
	font-size: 70px;
	color: #E4F5FE;
	font-family: 'Fjalla One', sans-serif;
	text-align: center;
	line-height: 1;
	}
	
	.ttl_about h3 {
		text-align: center;
		font-size: 30px;
		color: #0571AB;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		letter-spacing: 0.1em;
		margin-top: -1.2em;
	}
	
	.pic_about {
		width: 48%;
	}
	
	.pic_about img {
		border: 3px solid #0571AB;
		border-radius: 20px;
	}
	
	.bg_about01 .flex_b:nth-of-type(even) img {
		border: 3px solid #FFDE33
	}

	.pic_about p.ttl img {
		border: none!important;
		border-radius: 0;
	}
	
	.cont_about {
		width: 48%;
	}
	
	.en_ttl_about {
		position: relative;
	}
	
	.en_ttl_about p {
		width: 100%;
		background-color: #0571AB;
		transform: skewX(-18deg);
		font-size: 21px;
		font-family: 'Fjalla One', sans-serif;
		letter-spacing: 0.03em;
		position: relative;
		z-index: 2;
		line-height: 1;
		color: #fff;
		padding: 0.5em 1em 0.4em 1em;
	}
	
	.en_ttl_about p span {
		display: block;
		transform: skewX(18deg);
		position: relative;
	}
	
	.en_ttl_about:before {
		content: '';
		display: block;
		width: 60px;
		height: 60px;
		background: linear-gradient(to bottom,#fff,#FFDE33);
		border-radius: 50%;
		position: absolute;
		left:-20px;
		top: -40px;
		z-index: 1;
	}
	
	h4.about {
		font-size: 28px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
		margin: 20px 0 15px 0;
	}
	
	h4.about span {
		font-size: 20px;
	}
	
	.cont_about p.text {
		font-size: 17px;
		letter-spacing: 0.05em;
		line-height: 1.8;
	}
	
	.bg_about01 .flex_b:nth-of-type(odd) .en_ttl_about p {
		background-color: #f5d325;
		color: #333;
	}
	
	.bg_about01 .flex_b:nth-of-type(odd) .en_ttl_about:before {
		background: linear-gradient(to bottom,#fff,#4D9AC3);
	}
}

@media (min-width: 1200px) {
	.bg_about01 {
		padding: 50px 0;
	}
	
	.ttl_about {
		margin-bottom: 70px;
	}
	
	.ttl_about p.en {
	font-size: 90px;
	color: #E4F5FE;
	font-family: 'Fjalla One', sans-serif;
	text-align: center;
	line-height: 1;
	}
	
	.ttl_about h3 {
		text-align: center;
		font-size: 36px;
		color: #0571AB;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		line-height: 1;
		letter-spacing: 0.1em;
		margin-top: -1.2em;
	}
	
	.pic_about {
		width: 47%;
	}
	
	.pic_about img {
		border: 3px solid #0571AB;
		border-radius: 20px;
	}
	
	.bg_about01 .flex_b:nth-of-type(even) img {
		border: 3px solid #FFDE33
	}

	.pic_about p.ttl img {
		border: none!important;
		border-radius: 0;
	}
	
	.cont_about {
		width: 47%;
	}
	
	.en_ttl_about {
		position: relative;
	}
	
	.en_ttl_about p {
		width: 100%;
		background-color: #0571AB;
		transform: skewX(-18deg);
		font-size: 23px;
		font-family: 'Fjalla One', sans-serif;
		letter-spacing: 0.03em;
		position: relative;
		z-index: 2;
		line-height: 1;
		color: #fff;
		padding: 0.6em 1em 0.5em 1em;
	}
	
	.en_ttl_about p span {
		display: block;
		transform: skewX(18deg);
		position: relative;
	}
	
	.en_ttl_about:before {
		content: '';
		display: block;
		width: 80px;
		height: 80px;
		background: linear-gradient(to bottom,#fff,#FFDE33);
		border-radius: 50%;
		position: absolute;
		left:-30px;
		top: -50px;
		z-index: 1;
	}
	
	h4.about {
		font-size: 32px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		letter-spacing: 0.1em;
		margin: 30px 0 25px 0;
	}
	
	h4.about span {
		font-size: 23px;
	}
	
	.cont_about p.text {
		font-size: 18px;
		letter-spacing: 0.05em;
		line-height: 1.9;
	}
	
	.bg_about01 .flex_b:nth-of-type(odd) .en_ttl_about p {
		background-color: #f5d325;
		color: #333;
	}
	
	.bg_about01 .flex_b:nth-of-type(odd) .en_ttl_about:before {
		background: linear-gradient(to bottom,#fff,#4D9AC3);
	}
}

@media (min-width: 1560px) {
	.bg_about01 .container {
		width: 1500px;
	}

	.br1560_h {
		display: none!important;
	}

	.br1560 {
		display: block!important;
	}

	.ttl_about p.en {
		font-size: 105px;
		}
}

@media (max-width: 1559px) {
	.br1560_h {
		display: block !important;
	}

	.br1560 {
		display: none !important;
	}
}





/* recruit.html　採用情報
=========================================================================== */

@media (max-width: 767px) {
	ul.nav_sub {
		width: 100%;
		display: flex;
		flex-direction: row;
		flex-wrap: wrap;
		margin-bottom: 30px;
	}
	
	ul.nav_sub li {
		width: 49%;
		text-align: center;
		margin-right: 2%;
	}
	
	ul.nav_sub li a {
		display: block;
		width: 100%;
	font-size: 14px;
	letter-spacing: 0.05em;
	color: #333;
	padding-top: 10px;
	padding-bottom: 10px;
	position: relative;
background-color: #dfeff8;
margin-bottom: 8px;
border: 1px solid #77b8db;
	}

	ul.nav_sub li:nth-of-type(2n) {
		margin-right: 0;
	}
	
	ul.nav_sub li a:hover {
		opacity: 0.8;
		color: #333;
		background-color: #dfeff8;
	}

	#recruit ul.nav_sub li{
		width: 100%;
		margin-right: 0;
	}
}

@media (min-width: 768px) and (max-width:991px) {
	ul.nav_sub {
		width: 100%;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
		border-bottom: 1px solid #000;
		margin-bottom: 40px;
	}
	
	ul.nav_sub li {
		width: 100%;
		text-align: center;
	}
	
	ul.nav_sub li a {
		display: block;
		width: 100%;
	font-size: 17px;
	letter-spacing: 0.05em;
	color: #333;
	padding-top: 10px;
	padding-bottom: 10px;
	position: relative;
	}
	
	ul.nav_sub li a:hover {
		opacity: 1;
		color: #333;
		background-color: #dfeff8;
	}
	
	ul.nav_sub li a:hover:after {
		content: '';
		display: block;
		width: 100%;
		height: 2px;
		background-color: #3F97C7;
		position: absolute;
		left: 0;
		bottom:-1px;
	}

	#company ul.nav_sub li:nth-of-type(4) a  {
		width: 180px!important;
	}
}

@media (min-width: 992px) and (max-width: 1199px) {
	ul.nav_sub {
		width: 100%;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
		border-bottom: 1px solid #000;
		margin-bottom: 50px;
	}
	
	ul.nav_sub li {
		width: 100%;
		text-align: center;
	}
	
	ul.nav_sub li a {
		display: block;
		width: 100%;
	font-size: 18px;
	letter-spacing: 0.05em;
	color: #333;
	padding-top: 10px;
	padding-bottom: 10px;
	position: relative;
	}
	
	ul.nav_sub li a:hover {
		opacity: 1;
		color: #333;
		background-color: #dfeff8;
	}
	
	ul.nav_sub li a:hover:after {
		content: '';
		display: block;
		width: 100%;
		height: 2px;
		background-color: #3F97C7;
		position: absolute;
		left: 0;
		bottom:-1px;
	}
	
	ul.nav_sub li a:hover:before {
		content: "\f061";
	font-family: 'Font Awesome\ 5 Free';
	font-weight: 900;
	font-size: 14px;
	color: #3F97C7;
	position: absolute;
	top: 50%;
	left: 15px;
	transform: translateY(-50%) translateX(0);
	}

	#company ul.nav_sub li:nth-of-type(1) a  {
		width: 160px!important;
	}

	#company ul.nav_sub li:nth-of-type(2) a  {
		width: 110px!important;
	}

	#company ul.nav_sub li:nth-of-type(4) a  {
		width: 220px!important;
	}
}

@media (min-width: 1200px) {
	ul.nav_sub {
		width: 100%;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
		border-bottom: 1px solid #000;
		margin-bottom: 50px;
	}
	
	ul.nav_sub li {
		width: 100%;
		text-align: center;
	}
	
	ul.nav_sub li a {
		display: block;
		width: 100%;
	font-size: 18px;
	letter-spacing: 0.05em;
	color: #333;
	padding-top: 10px;
	padding-bottom: 10px;
	position: relative;
	}
	
	ul.nav_sub li a:hover {
		opacity: 1;
		color: #333;
		background-color: #dfeff8;
	}
	
	ul.nav_sub li a:hover:after {
		content: '';
		display: block;
		width: 100%;
		height: 2px;
		background-color: #3F97C7;
		position: absolute;
		left: 0;
		bottom:-1px;
	}
	
	ul.nav_sub li a:hover:before {
		content: "\f061";
	font-family: 'Font Awesome\ 5 Free';
	font-weight: 900;
	font-size: 14px;
	color: #3F97C7;
	position: absolute;
	top: 50%;
	left: 10px;
	transform: translateY(-50%) translateX(0);
	}

	#company ul.nav_sub li:nth-of-type(4) a  {
		width: 240px!important;
	}
}












@media (max-width: 991px) {
	#recruit01,#recruit02,#recruit03 {
		margin-top: -80px;
		padding-top: 80px;
	}
}

@media (min-width: 992px) {
	#recruit01,#recruit02,#recruit03 {
		margin-top: -30px;
		padding-top: 30px;
	}
}


@media (max-width: 767px) {
	.ttl_recruit {
		background-color: #EAF3F9;
		padding: 20px;
		position: relative;
		margin-bottom: 30px;
		}
	
		.ttl_recruit .bdr {
			border: 1px solid #000;
			width: 100%;
			height: 100%;
		}
	
		.ttl_recruit .inner {
			position: relative;
			display: flex;
			flex-direction: column;
			align-items: center;
			justify-content: center;
			padding: 10px 20px;
		}
		
		.ttl_recruit:before {
			content: '';
			display: block;
			width: 3px;
			height: calc(100% - 80px);
			background-color: #EAF3F9;
			position: absolute;
			left:19px;
			top:40px;
			z-index: 2;
		}
		
		.ttl_recruit:after {
			content: '';
			display: block;
			width: 3px;
			height: calc(100% - 80px);
			background-color: #EAF3F9;
			position: absolute;
			right:19px;
			top:40px;
			z-index: 2;
		}
		
		.ttl_recruit .inner:before {
			content: '';
			display: block;
			width: calc(100% - 40px);
			height: 3px;
			background-color: #EAF3F9;
			position: absolute;
			top:-2px;
			left:20px;
			z-index: 2;
		}
		
		.ttl_recruit .inner:after {
			content: '';
			display: block;
			width: calc(100% - 40px);
			height: 3px;
			background-color: #EAF3F9;
			position: absolute;
			bottom:-2px;
			left:20px;
			z-index: 2;
		}
	
		h3.recruit {
			font-size: 22px;
			color: #3F97C6;
			font-family: 'Noto Sans JP', sans-serif;
			font-weight: 700;
			letter-spacing: 0.1em;
			margin-bottom: 15px;
			text-align: center;
			line-height: 1.4;
		}

		.ttl_recruit p.icon {
			width: 50px;
		}
	
		.pic_recruit {
			position: relative;
		}
	
		.info_recruit {
			background-color: #fff;
			position: relative;
			margin: 10px auto 0;
			padding: 0 0 0;
		}
	
		.info_recruit p.text {
			font-size: 15px;
			line-height: 1.8;
			letter-spacing: 0.03em;
			margin-bottom: 30px;
		}
}

@media (min-width: 768px) {
	.ttl_recruit {
		background-color: #EAF3F9;
		padding: 20px;
		position: relative;
		margin-bottom: 30px;
		}
	
		.ttl_recruit .bdr {
			border: 1px solid #000;
			width: 100%;
			height: 100%;
		}
	
		.ttl_recruit .inner {
			position: relative;
			display: flex;
			flex-direction: column;
			align-items: center;
			justify-content: center;
			padding: 10px 20px;
		}
		
		.ttl_recruit:before {
			content: '';
			display: block;
			width: 3px;
			height: calc(100% - 80px);
			background-color: #EAF3F9;
			position: absolute;
			left:19px;
			top:40px;
			z-index: 2;
		}
		
		.ttl_recruit:after {
			content: '';
			display: block;
			width: 3px;
			height: calc(100% - 80px);
			background-color: #EAF3F9;
			position: absolute;
			right:19px;
			top:40px;
			z-index: 2;
		}
		
		.ttl_recruit .inner:before {
			content: '';
			display: block;
			width: calc(100% - 40px);
			height: 3px;
			background-color: #EAF3F9;
			position: absolute;
			top:-2px;
			left:20px;
			z-index: 2;
		}
		
		.ttl_recruit .inner:after {
			content: '';
			display: block;
			width: calc(100% - 40px);
			height: 3px;
			background-color: #EAF3F9;
			position: absolute;
			bottom:-2px;
			left:20px;
			z-index: 2;
		}
	
		h3.recruit {
			font-size: 24px;
			color: #3F97C6;
			font-family: 'Noto Sans JP', sans-serif;
			font-weight: 700;
			letter-spacing: 0.1em;
			margin-bottom: 15px;
		}

		.ttl_recruit p.icon {
			width: 60px;
		}
	
		.pic_recruit {
			position: relative;
		}
	
		.info_recruit {
			width: 660px;
			background-color: #fff;
			position: relative;
			margin: -70px auto 0;
			padding: 20px 30px 0;
			border-top: 4px solid #0571AB;
		}
	
		.info_recruit p.text {
			font-size: 16px;
			line-height: 1.8;
			letter-spacing: 0.03em;
		}
}

@media (min-width: 992px) {
	.ttl_recruit {
		background-color: #EAF3F9;
		padding: 20px;
		position: relative;
		margin-bottom: 30px;
		}
	
		.ttl_recruit .bdr {
			border: 1px solid #000;
			width: 100%;
			height: 100%;
		}
	
		.ttl_recruit .inner {
			position: relative;
			display: flex;
			flex-direction: column;
			align-items: center;
			justify-content: center;
			padding: 10px 20px;
		}
		
		.ttl_recruit:before {
			content: '';
			display: block;
			width: 3px;
			height: calc(100% - 80px);
			background-color: #EAF3F9;
			position: absolute;
			left:19px;
			top:40px;
			z-index: 2;
		}
		
		.ttl_recruit:after {
			content: '';
			display: block;
			width: 3px;
			height: calc(100% - 80px);
			background-color: #EAF3F9;
			position: absolute;
			right:19px;
			top:40px;
			z-index: 2;
		}
		
		.ttl_recruit .inner:before {
			content: '';
			display: block;
			width: calc(100% - 40px);
			height: 3px;
			background-color: #EAF3F9;
			position: absolute;
			top:-2px;
			left:20px;
			z-index: 2;
		}
		
		.ttl_recruit .inner:after {
			content: '';
			display: block;
			width: calc(100% - 40px);
			height: 3px;
			background-color: #EAF3F9;
			position: absolute;
			bottom:-2px;
			left:20px;
			z-index: 2;
		}
	
		h3.recruit {
			font-size: 27px;
			color: #3F97C6;
			font-family: 'Noto Sans JP', sans-serif;
			font-weight: 700;
			letter-spacing: 0.1em;
			margin-bottom: 15px;
		}

		.ttl_recruit p.icon {
			width: 70px;
		}
	
		.pic_recruit {
			position: relative;
		}
	
		.info_recruit {
			width: 760px;
			background-color: #fff;
			position: relative;
			margin: -70px auto 0;
			padding: 20px 30px 0;
			border-top: 4px solid #0571AB;
		}
	
		.info_recruit p.text {
			font-size: 16px;
			line-height: 1.8;
			letter-spacing: 0.03em;
		}
}

@media (min-width: 1200px) {
	.ttl_recruit {
		background-color: #EAF3F9;
		padding: 20px;
		position: relative;
		margin-bottom: 30px;
		}
	
		.ttl_recruit .bdr {
			border: 1px solid #000;
			width: 100%;
			height: 100%;
		}
	
		.ttl_recruit .inner {
			position: relative;
			display: flex;
			flex-direction: column;
			align-items: center;
			justify-content: center;
			padding: 20px 20px;
		}
		
		.ttl_recruit:before {
			content: '';
			display: block;
			width: 3px;
			height: calc(100% - 80px);
			background-color: #EAF3F9;
			position: absolute;
			left:19px;
			top:40px;
			z-index: 2;
		}
		
		.ttl_recruit:after {
			content: '';
			display: block;
			width: 3px;
			height: calc(100% - 80px);
			background-color: #EAF3F9;
			position: absolute;
			right:19px;
			top:40px;
			z-index: 2;
		}
		
		.ttl_recruit .inner:before {
			content: '';
			display: block;
			width: calc(100% - 40px);
			height: 3px;
			background-color: #EAF3F9;
			position: absolute;
			top:-2px;
			left:20px;
			z-index: 2;
		}
		
		.ttl_recruit .inner:after {
			content: '';
			display: block;
			width: calc(100% - 40px);
			height: 3px;
			background-color: #EAF3F9;
			position: absolute;
			bottom:-2px;
			left:20px;
			z-index: 2;
		}
	
		h3.recruit {
			font-size: 32px;
			color: #3F97C6;
			font-family: 'Noto Sans JP', sans-serif;
			font-weight: 700;
			letter-spacing: 0.1em;
			margin-bottom: 15px;
		}

		.ttl_recruit p.icon {
			width: 100px;
		}
	
		.pic_recruit {
			position: relative;
		}
	
		.info_recruit {
			width: 960px;
			background-color: #fff;
			position: relative;
			margin: -70px auto 0;
			padding: 25px 40px;
			border-top: 5px solid #0571AB;
		}
	
		.info_recruit p.text {
			font-size: 17px;
			line-height: 2;
			letter-spacing: 0.03em;
		}
}


@media (max-width: 767px) {
	#recruit02 .mb_cont > .mb20 {
		margin-bottom: 0!important;
	} 
	.pic_recruit02 {
		width: 100%;
		flex-shrink: 0;
		max-width: 360px;
		margin: 0 auto;
	}

	.reverse_sp .pic_recruit02 {
		margin-bottom: 20px;
	}

	p.name_staff {
		font-size: 18px;
		text-align: center;
		margin-top: 10px;
		letter-spacing: 0.05em;
		margin-bottom: 15px;
	}

	p.name_staff span {
		display: inline-block;
		font-size: 14px;
		margin-right: 10px;
	}

	.cont_recruit02 {
		width: 100%;
	}

	.faq {
		padding-bottom: 15px;
		margin-bottom: 15px;
		border-bottom: 1px dashed #6DACDA;
	}

	.question {
		display: flex;
		flex-direction: row;
		align-items: center;
		margin-bottom: 8px;
	}

	.question p.icon {
		font-size: 20px;
		color: #6DACDA;
		margin-right: 10px;
	}

	.question p.ttl {
		font-size: 16px;
		letter-spacing: 0.05em;
		line-height: 1.4;
	}

	.answer {
		display: flex;
		flex-direction: row;
		align-items: center;
	}

	.answer p.icon {
		font-size: 20px;
		color: #f1cc0f;
		margin-right: 10px;
	}

	.answer p.text {
		font-size: 15px;
		letter-spacing: 0.05em;
		line-height: 1.4;
	}
}

@media (min-width: 768px) {
	.pic_recruit02 {
		width: 48%;
		flex-shrink: 0;
	}

	p.name_staff {
		font-size: 19px;
		text-align: center;
		margin-top: 10px;
		letter-spacing: 0.05em;
	}

	p.name_staff span {
		display: inline-block;
		font-size: 15px;
		margin-right: 10px;
	}

	.cont_recruit02 {
		width: 48%;
	}

	.faq {
		padding-bottom: 15px;
		margin-bottom: 15px;
		border-bottom: 1px dashed #6DACDA;
	}

	.question {
		display: flex;
		flex-direction: row;
		align-items: center;
		margin-bottom: 10px;
	}

	.question p.icon {
		font-size: 22px;
		color: #6DACDA;
		margin-right: 10px;
	}

	.question p.ttl {
		font-size: 17px;
		letter-spacing: 0.05em;
		line-height: 1.4;
	}

	.answer {
		display: flex;
		flex-direction: row;
		align-items: center;
	}

	.answer p.icon {
		font-size: 22px;
		color: #f1cc0f;
		margin-right: 10px;
	}

	.answer p.text {
		font-size: 16px;
		letter-spacing: 0.05em;
		line-height: 1.4;
	}
}

@media (min-width: 992px) {
	.pic_recruit02 {
		width: 48%;
	}

	p.name_staff {
		font-size: 23px;
		text-align: center;
		margin-top: 10px;
		letter-spacing: 0.05em;
	}

	p.name_staff span {
		display: inline-block;
		font-size: 18px;
		margin-right: 15px;
	}

	.cont_recruit02 {
		width: 48%;
	}

	.faq {
		padding-bottom: 15px;
		margin-bottom: 15px;
		border-bottom: 1px dashed #6DACDA;
	}

	.question {
		display: flex;
		flex-direction: row;
		align-items: center;
		margin-bottom: 5px;
	}

	.question p.icon {
		font-size: 24px;
		color: #6DACDA;
		margin-right: 10px;
	}

	.question p.ttl {
		font-size: 18px;
		letter-spacing: 0.05em;
		line-height: 1.4;
	}

	.answer {
		display: flex;
		flex-direction: row;
		align-items: center;
	}

	.answer p.icon {
		font-size: 24px;
		color: #f1cc0f;
		margin-right: 10px;
	}

	.answer p.text {
		font-size: 17px;
		letter-spacing: 0.05em;
		line-height: 1.4;
	}
}






/* company.html　会社案内
=========================================================================== */

@media (max-width: 991px) {
	#company01,#company02,#company03,#company04,#company05,#company06 {
		margin-top: -80px;
		padding-top: 80px;
	}
}

@media (min-width: 992px) {
	#company01,#company02,#company03,#company04,#company05,#company06 {
		margin-top: -30px;
		padding-top: 30px;
	}
}


@media (max-width: 767px) {
	.ttl_company {
		position: relative;
		background-color: #0571AB;
	}
	
	h3.company {
		font-size: 18px;
		letter-spacing: 0.05em;
		color: #fff;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		padding: 0.4em 1em;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		margin-bottom: 15px;
	}
	
	h3.company span {
		display: block;
		font-family: 'Fjalla One', sans-serif;
		font-size: 12px;
		color: #60b1dd;
		letter-spacing: 0;
		line-height: 1;
		margin-top: 5px;
	}

	#company01 .cont56 .mb20 {
		margin-bottom: 10px!important;
	}

	.pic_company01_sp {
		margin: 15px auto 0;
		max-width: 400px;
	}
	
	#company01 p.text {
		font-size: 15px;
		line-height: 1.8;
	}
	
	#company01 .info {
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		margin-top: 10px;
	}
	
	#company01 .info p.ttl {
		font-size: 15px;
		letter-spacing: 0.05em;
	}
	
	#company01 .info p.name {
		font-size: 19px;
		letter-spacing: 0.05em;
	}
	
	#company01 .info p.name span {
		font-size: 17px;
		display: inline-block;
		margin-right: 15px;
	}
}

@media (min-width: 768px) and (max-width:991px) {
	.ttl_company {
		background-color: #0571AB;
		position: relative;
	}
	
	h3.company {
		font-size: 24px;
		letter-spacing: 0.05em;
		color: #fff;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		padding: 0.4em 1em;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		margin-bottom: 25px;
		width: 100%;
	}
	
	h3.company span {
		display: block;
		font-family: 'Fjalla One', sans-serif;
		font-size: 16px;
		color: #60b1dd;
		letter-spacing: 0;
		line-height: 1;
		margin-left: 15px;
	}
	
	#company01 p.text {
		font-size: 16px;
		line-height: 2;
	}
	
	#company01 .cont41 {
		width: 48%;
		margin-bottom: 15px;
	}

		#company01 .cont56 {
		width: 48%;
	}
	
	#company01 p.text {
		font-size: 16px;
		line-height: 2;
	}
	
	#company01 .info {
		display: flex;
		flex-direction: column;
		justify-content: flex-end;
		align-items: flex-end;
		margin-top: 10px;
	}
	
	#company01 .info p.ttl {
		font-size: 15px;
		letter-spacing: 0.05em;
	}
	
	#company01 .info p.name {
		font-size: 20px;
		letter-spacing: 0.05em;
	}
	
	#company01 .info p.name span {
		font-size: 18px;
		display: inline-block;
		margin-right: 15px;
	}
}

@media (min-width: 992px) {
	.ttl_company {
		background-color: #0571AB;
		position: relative;
	}
	
	h3.company {
		font-size: 28px;
		letter-spacing: 0.05em;
		color: #fff;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		padding: 0.5em 1em;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		margin-bottom: 35px;
	}
	
	h3.company span {
		display: block;
		font-family: 'Fjalla One', sans-serif;
		font-size: 18px;
		color: #60b1dd;
		letter-spacing: 0;
		line-height: 1;
		margin-left: 15px;
	}
	
	#company01 p.text {
		font-size: 16px;
		line-height: 2;
	}
	
	#company01 .info {
		display: flex;
		flex-direction: column;
		justify-content: flex-end;
		align-items: flex-end;
		margin-top: 15px;
	}
	
	#company01 .info p.ttl {
		font-size: 16px;
		letter-spacing: 0.05em;
		margin-bottom: 5px;
	}
	
	#company01 .info p.name {
		font-size: 22px;
		letter-spacing: 0.05em;
	}
	
	#company01 .info p.name span {
		font-size: 17px;
		display: inline-block;
		margin-right: 15px;
	}
}

@media (min-width: 1200px) {
	.ttl_company {
		background-color: #0571AB;
		position: relative;
	}
	
	h3.company {
		font-size: 28px;
		letter-spacing: 0.05em;
		color: #fff;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		padding: 0.5em 1em;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		margin-bottom: 35px;
	}
	
	h3.company span {
		display: block;
		font-family: 'Fjalla One', sans-serif;
		font-size: 18px;
		color: #60b1dd;
		letter-spacing: 0;
		line-height: 1;
		margin-left: 15px;
	}
	
	#company01 p.text {
		font-size: 18px;
		line-height: 2;
	}
	
	#company01 .info {
		display: flex;
		flex-direction: column;
		justify-content: flex-end;
		align-items: flex-end;
		margin-top: 15px;
	}
	
	#company01 .info p.ttl {
		font-size: 17px;
		letter-spacing: 0.05em;
		margin-bottom: 5px;
	}
	
	#company01 .info p.name {
		font-size: 24px;
		letter-spacing: 0.05em;
	}
	
	#company01 .info p.name span {
		font-size: 18px;
		display: inline-block;
		margin-right: 15px;
	}
}



@media (max-width: 767px) {
	table.sub {
		width: 100%;
	}

	table.sub th {
		display: block;
		width: 100%;
		background-color: #d2e2eb;
		font-size: 14px;
		color: #333;
		letter-spacing: 0.05em;
		padding: 6px 10px;
	}

	table.sub td {
		display: block;
		width: 100%;
		font-size: 14px;
		letter-spacing: 0.05em;
		padding: 6px 10px 18px;
		line-height: 1.7;
	}

	table.sub .flex_b {
		flex-direction: column;
		align-items: flex-start;
		border-bottom: 1px dotted #aaa;
		padding-bottom: 25px;
	}
}


@media (min-width: 768px) {
	table.sub {
		width: 100%;
	}

	table.sub th {
		color: #0571AB;
		font-size: 16px;
		letter-spacing: 0.05em;
		width: 200px;
		padding: 15px 30px 15px 0;
		border-bottom: 1px solid #aaa;
		font-weight: normal;
	}

	table.sub td {
		font-size: 16px;
		letter-spacing: 0.05em;
		padding: 15px 0 15px 0;
		border-bottom: 1px solid #aaa;
		line-height: 1.8;
	}
}

@media (min-width: 992px) {
	table.sub {
		width: 100%;
		margin-top: -15px;
	}

	table.sub th {
		color: #0571AB;
		font-size: 16px;
		letter-spacing: 0.05em;
		width: 200px;
		padding: 25px 30px 25px 0;
		border-bottom: 1px solid #aaa;
		font-weight: normal;
	}

	table.sub td {
		font-size: 16px;
		letter-spacing: 0.05em;
		padding: 25px 0 25px 0;
		border-bottom: 1px solid #aaa;
		line-height: 1.8;
	}
}

@media (min-width: 1200px) {
	table.sub {
		width: 100%;
		margin-top: -20px;
	}

	table.sub th {
		color: #0571AB;
		font-size: 18px;
		letter-spacing: 0.05em;
		width: 260px;
		padding: 20px 30px 20px 20px;
		border-bottom: 1px solid #aaa;
		font-weight: normal;
	}

	table.sub td {
		font-size: 18px;
		letter-spacing: 0.05em;
		padding: 20px 30px 20px 20px;
		border-bottom: 1px solid #aaa;
		line-height: 1.8;
	}
}



@media (max-width: 767px) {
	#company04 .flex_c {
		flex-direction: row;
	}

	#company04 .cont30 {
		width: 47%;
		margin-right: 6%;
		margin-bottom: 15px;
	}
	
	#company04 .cont30:nth-of-type(2n) {
		margin-right: 0;
	}
	
	#company04 .cont45 {
		width: 47%;
		margin-right: 6%;
		margin-bottom: 15px;
	}
	
	#company04 .cont45:nth-of-type(2n) {
		margin-right: 0;
	}

	#company05 .flex_c {
		flex-direction: row;
	}
	
	#company05 .cont22 {
		width: 47%;
		margin-right: 6%;
		margin-bottom: 15px;
	}
	
	#company05 .cont22:nth-of-type(2n) {
		margin-right: 0;
	}
}

@media (min-width: 768px) {
	#company04 .cont30 {
		margin-right: 5%;
		margin-bottom: 70px;
	}
	
	#company04 .cont30:nth-of-type(3n) {
		margin-right: 0;
	}
	
	#company04 .cont45 {
		margin-right: 5%;
		margin-bottom: 30px;
	}
	
	#company04 .cont45:nth-of-type(2n) {
		margin-right: 0;
	}
	
	#company05 .cont23 {
		margin-right: 2.666666%;
		margin-bottom: 30px;
	}
	
	#company05 .cont23:nth-of-type(4n) {
		margin-right: 0;
	}
}




@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: 17px;
		margin: 20px auto 0;
		letter-spacing: 0.03em;
	}

	p.btn_map a:before {
		content: "\f3c5";
		font-family: 'Font Awesome\ 5 Free';
		font-weight: 900;
		margin-right: 5px;
	}
}

/* entry.html　エントリーフォーム
=========================================================================== */

@media (max-width: 767px) {
	.bg_entry01 {
		background-color: #bddced;
		padding: 30px 0;
	}
	
		.inner_entry01 {
			background-color: #E7F5FE;
			padding: 10px 0;
			border-radius: 100px;
		}
	
		p.tel_entry01 {
			font-size: 27px;
			color: #0571AB;
			font-family: 'Roboto', sans-serif;
			font-weight: 700;
			display: flex;
			flex-direction: row;
			align-items: center;
			justify-content: center;
		}
		
		p.tel_entry01:before {
			content: '';
			display: block;
			background: url(../images/icon_entry01.png) 0 0 /contain no-repeat;
			width: 15px;
			height: 26px;
			margin-right: 4px;
			margin-top: 5px;
		}
		
		p.tel_entry01 span.tel_link {
			color: #0571AB;
		}
		
		h3.entry {
			font-size: 21px;
			color: #0571AB;
			font-weight: 700;
			text-align: center;
			padding-bottom: 10px;
			border-bottom: 2px solid #0571AB;
			margin-bottom: 15px;
		}
	
		.bg_entry02 {
			background-color: #E7F5FE;
			padding: 30px 0 50px;
		}
	
		.bg_entry02 p.text {
			font-size: 15px;
			line-height: 1.8;
			margin-bottom: 15px;
			letter-spacing: 0.03em;
		}
	
		.bg_entry02 p.text span.hissu {
			background-color: #ff0000;
			color: #fff;
			display: inline-block;
			line-height: 1;
			padding: 0.2em 0.5em;
			font-size: 12px;
			margin-right: 5px;
		}
	
		.inner_entry02 .inner {
			padding: 15px;
			background-color: #fff;
		}
}

@media (min-width: 768px) {
	.bg_entry01 {
		background-color: #bddced;
		padding: 40px 0;
	}
	
		.inner_entry01 {
			background-color: #E7F5FE;
			padding: 15px 0;
			border-radius: 100px;
		}
	
		p.tel_entry01 {
			font-size: 33px;
			color: #0571AB;
			font-family: 'Roboto', sans-serif;
			font-weight: 700;
			display: flex;
			flex-direction: row;
			align-items: center;
			justify-content: center;
		}
		
		p.tel_entry01:before {
			content: '';
			display: block;
			background: url(../images/icon_entry01.png) 0 0 /contain no-repeat;
			width: 17px;
			height: 29px;
			margin-right: 6px;
			margin-top: 5px;
		}
		
		p.tel_entry01 span.tel_link {
			color: #0571AB;
		}
		
		h3.entry {
			font-size: 25px;
			color: #0571AB;
			font-weight: 700;
			text-align: center;
			padding-bottom: 15px;
			border-bottom: 2px solid #0571AB;
			margin-bottom: 20px;
		}
	
		.bg_entry02 {
			background-color: #E7F5FE;
			padding: 50px 0 50px;
		}
	
		.bg_entry02 p.text {
			font-size: 16px;
			line-height: 1.8;
			margin-bottom: 15px;
			letter-spacing: 0.03em;
		}
	
		.bg_entry02 p.text span.hissu {
			background-color: #ff0000;
			color: #fff;
			display: inline-block;
			line-height: 1;
			padding: 0.2em 0.5em;
			font-size: 12px;
			margin-right: 5px;
		}
	
		.inner_entry02 {
			background-color: #dbedf7;
			padding: 10px;
		}
	
		.inner_entry02 .inner {
			padding: 15px;
			background-color: #fff;
		}
}

@media (min-width: 992px) {
	.bg_entry01 {
		background-color: #bddced;
		padding: 50px 0;
	}
	
		.inner_entry01 {
			background-color: #E7F5FE;
			padding: 15px 0;
			border-radius: 100px;
		}
	
		p.tel_entry01 {
			font-size: 39px;
			color: #0571AB;
			font-family: 'Roboto', sans-serif;
			font-weight: 700;
			display: flex;
			flex-direction: row;
			align-items: center;
			justify-content: center;
		}
		
		p.tel_entry01:before {
			content: '';
			display: block;
			background: url(../images/icon_entry01.png) 0 0 /contain no-repeat;
			width: 20px;
			height: 33px;
			margin-right: 8px;
			margin-top: 5px;
		}
		
		p.tel_entry01 span.tel_link {
			color: #0571AB;
		}
		
		h3.entry {
			font-size: 28px;
			color: #0571AB;
			font-weight: 700;
			text-align: center;
			padding-bottom: 15px;
			border-bottom: 3px solid #0571AB;
			margin-bottom: 20px;
		}
	
		.bg_entry02 {
			background-color: #E7F5FE;
			padding: 70px 0 70px;
		}
	
		.bg_entry02 p.text {
			font-size: 16px;
			line-height: 1.8;
			margin-bottom: 20px;
			letter-spacing: 0.03em;
		}
	
		.bg_entry02 p.text span.hissu {
			background-color: #ff0000;
			color: #fff;
			display: inline-block;
			line-height: 1;
			padding: 0.2em 0.5em;
			font-size: 12px;
			margin-right: 5px;
		}
	
		.inner_entry02 {
			background-color: #dbedf7;
			padding: 15px;
		}
	
		.inner_entry02 .inner {
			padding: 15px;
			background-color: #fff;
		}
}



span.red {
	color: #ff0000;
}

@media (max-width: 767px) {
	table.contact {
		width: 100%;
	}

	table.contact th {
		display: block;
		width: 100%;
		margin-bottom: 5px;
		font-size: 15px;
	}

	table.contact td {
		display: block;
		margin-bottom: 15px;
		font-size: 15px;
	}
}

@media (min-width: 768px) and (max-width:991px) {
	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;
	}
}

@media (min-width: 992px) {
	table.contact {
		width: 100%;
		padding: 10px 0;
	}

	table.contact th {
		width: 27%;
		padding: 10px;
		font-size: 15px;
	}

	table.contact td {
		padding: 10px 10px 10px 10px;
		background-color: #fff;
		font-size: 15px;
	}
}

@media (min-width: 1200px) {
	table.contact {
		width: 100%;
	}

	table.contact th {
		width: 25%;
		padding: 10px 15px;
		font-size: 17px;
		border-bottom: 1px solid #ccc;
		background-color: #fff;
	}

	table.contact td {
		padding: 10px 15px 10px 15px;
		background-color: #fff;
		margin: 0 15px;
		font-size: 17px;
		border-bottom: 1px solid #ccc;
	}
}

@media (max-width: 767px) {
	dl.address {
		display: flex;
		flex-direction: column;
		margin-bottom: 10px;
	}
	
	dl.address dt {
		flex-shrink: 0;
		font-weight: normal;
		margin-bottom: 5px;
	}
	
	dl.address dd {
		width: 100%;
	}
	
	dl.address:last-child {
		margin-bottom: 0;
	}
}

@media (min-width: 768px) {
	dl.address {
		display: flex;
		flex-direction: row;
		align-items: center;
		margin-bottom: 10px;
	}
	
	dl.address dt {
		width: 100px;
		flex-shrink: 0;
	}
	
	dl.address dd {
		width: 100%;
	}
	
	dl.address:last-child {
		margin-bottom: 0;
	}
}

@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;
	}
}

@media (max-width: 767px) {
	table.contact td input.write {
		padding: 0.4em 0.5em;
		width: 100%;
		border-radius: 4px;
		border: 1px solid #ddd;
	}
}

@media (min-width: 768px) {
	table.contact td input.write {
		padding: 0.4em 0.8em;
		width: 100%;
		border: 1px solid #ddd;
		background-color: #fff;
		border-radius: 4px;
		font-size: 17px;
	}
}

@media (max-width: 767px) {
	table.contact td input.form50 {
		width: 50px !important;
	}
	
	table.contact td input.form100 {
		width: 100px !important;
	}
	
	table.contact td input.form130 {
		width: 130px !important;
	}
	
	table.contact td input.form150 {
		width: 150px !important;
	}
	
	table.contact td input.form250 {
		width: 250px !important;
	}
	
	select {
		padding: 0.3em 0.2em;
		font-size: 16px;
	}
	
	table.contact label {
		font-size: 16px;
		font-weight: normal;
	}
	
	table.contact ::placeholder {
		color: #bbb;
		font-size: 16px;
	  }
	
	  .place_mini ::placeholder {
		color: #fff!important;
	  }

	  table.contact .place_mini input.form130 {
		width: 50px!important;
		margin-bottom: 5px;
		padding: 0.2em 0.5em!important;
	  }
}

@media (min-width: 768px) {
	table.contact td input.form50 {
		width: 50px !important;
	}
	
	table.contact td input.form100 {
		width: 100px !important;
	}
	
	table.contact td input.form130 {
		width: 130px !important;
	}
	
	table.contact td input.form150 {
		width: 150px !important;
	}
	
	table.contact td input.form250 {
		width: 250px !important;
	}
	
	select {
		padding: 0.5em 0.5em;
		font-size: 16px;
	}
	
	table.contact label {
		font-size: 18px;
		font-weight: normal;
	}
	
	table.contact ::placeholder {
		color: #bbb;
		font-size: 17px;
	  }
	
	  .place_mini ::placeholder {
		font-size: 14px!important;
	  }
}

@media (max-width: 500px) {
	select {
		max-width: 250px;
	}
}

@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;
		font-size: 18px;
	}
}

@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: 18px;
		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: 15px 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: 7px;
	}

	.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: 3px;
		font-size: 14px;
		line-height: 1.4;
	}
}

@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;
		border-radius: 10px;
	}

	button.comfirm:hover {
		background-color: #2b98ce;
	}

	.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%;
		border-radius: 10px;
	}

	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;
		border-radius: 10px;
	}

	button.send:hover {
		background-color: #2b98ce;
	}
}

@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;
		border-radius: 10px;
	}

	button.comfirm:hover {
		background-color: #2b98ce;
	}

	.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;
		border-radius: 10px;
	}

	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;
		border-radius: 10px;
	}

	button.send:hover {
		background-color: #2b98ce;
	}
}

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;
	}
}

.f-bnr{
	text-align: center;
	margin-top: 20px;
}
@media (min-width: 768px) {
	.f-bnr{
		text-align: right;
		margin-top: 40px;
	}
}

/*2023/8/30追加*/
@media (max-width: 767px) {
	.torikumi-link {
		display: flex !important;
		justify-content: center !important;
	}
}

/*2024/1/25追加*/
.policy_text{
font-size: 19px;
width: 960px;
max-width: 100%;
margin: 0 auto 70px;
text-align: center;
}
.sp_br{
	display: block;
}
.policy_box{
	width: 960px;
	margin: 0 auto 120px;
	max-width: 100%;
}
.policy_box2{
	width: 960px;
	margin: 0 auto;
	max-width: 100%;
}
.policy_box2_title{
	width: 100%;
    background-color: #0571AB;
    transform: skewX(-18deg);
    font-size: 23px;
    letter-spacing: 0.03em;
    position: relative;
    z-index: 2;
    line-height: 1;
    color: #fff;
    padding: 0.6em 1em 0.5em 1em;
	margin-bottom: 25px;
}
.policy_box2_title span{
	display: block;
    transform: skewX(18deg);
    position: relative;
}

.policy_box2_title_p{
font-size: 19px;
}
.policy_box2{
	position: relative;
}
.policy_box2:before{
	content: '';
    display: block;
    width: 80px;
    height: 80px;
    background: linear-gradient(to bottom,#fff,#FFDE33);
    border-radius: 50%;
    position: absolute;
    left: -30px;
    top: -50px;
    z-index: -1;
}

.policy_box3{
	width: 960px;
	margin: 0 auto;
	max-width: 100%;
	display: flex;
	justify-content: flex-end;
}

@media (max-width: 991px){
	.policy_text{
		text-align: left;
	}
	.sp_br{
		display: none;
	}
	.policy_box{
		margin-bottom: 50px;
	}
	.policy_box2:before{
		content: '';
    display: block;
    width: 50px;
    height: 50px;
    background: linear-gradient(to bottom,#fff,#FFDE33);
    border-radius: 50%;
    position: absolute;
	left: -15px;
    top: -30px;
		z-index: -1;
	}
}
@media (max-width: 767px){
	.policy_text{
		font-size: 16px;
		margin-bottom: 30px;
		}
		.policy_box2_title{
			font-size: 18px;
		}
		.policy_box2_title_p{
			font-size: 16px;
			}

			.policy_box2:before{
				content: '';
				display: block;
				width: 40px;
				height: 40px;
				background: linear-gradient(to bottom,#fff,#FFDE33);
				border-radius: 50%;
				position: absolute;
				left: -10px;
				top: -20px;
				z-index: -1;
			}
}








/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
/* = */
