@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=Alfa+Slab+One&family=Noto+Sans+JP:wght@400;500;700;900&family=Noto+Serif+JP:wght@400;500;600;700&family=Oswald&display=swap');

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

  リセット

====================================================================*/
html, body, div, span, object, iframe,h1, h2, h3, h4, h5, h6, p, blockquote, pre,abbr, address, cite, code,del, dfn, em, ins, kbd, q, samp,small, strong, sub, sup, var,b, i,dl, dt, dd, ol, ul, li,fieldset, form, label, legend,table, caption, tbody, tfoot, thead, tr, th, td,article, aside, canvas, details, figcaption, figure, footer, header, hgroup,menu, nav, section, summary,time, mark, audio, video {
    margin:0;
	padding:0;
	border:0;
	outline:0;
	font-size:100%;
	background:transparent;
}
article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section {
	display:block;
}
nav ul {list-style:none;}
blockquote, q {quotes:none;}
blockquote:before,
blockquote:after,
q:before,
q:after {
	content:'';content:none;
}
table {border-collapse:collapse;border-spacing:0;}
input, select {vertical-align:middle;}
*, *:before, *:after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}
h1, h2, h3, h4, h5, h6 {line-height: 150%;}
body {line-height:150%;}
img {vertical-align: bottom;max-width: 100%;height: auto;display: block;margin: 0 auto;}
a {margin:0;padding:0;font-size:100%;vertical-align:baseline;background:transparent;}
caption, th, td {font-weight: normal;}
strong {font-weight:normal;}

/* iOSでのデフォルトスタイルをリセット */
input[type="submit"],
input[type="reset"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration,
input[type="reset"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none;
}
input[type="submit"]::focus,
input[type="reset"]::focus,
input[type="button"]::focus {
  outline-offset: -2px;
}

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

  設定

====================================================================*/
html,body {
	color:#333333;
	font-family: 'Noto Sans JP', -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Noto Sans Japanese", "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, Meiryo, sans-serif;
	-webkit-text-size-adjust: 100%;
	background: #FFFFFF;
}

a:link {color:#0064C8; text-decoration:none;}
a:visited {color:#0064C8; text-decoration:none;}
a:hover {color:#64C8FF; text-decoration:none}

a:hover img {
	opacity: 0.8 ;
	filter: alpha(opacity=80) ;	
	-ms-filter: "alpha(opacity=80)";
	}
a img {
	-webkit-transition: opacity 0.4s ease-out;
	-moz-transition: opacity 0.4s ease-out;
	-ms-transition: opacity 0.4s ease-out;
	transition: opacity 0.4s ease-out;
}
a {-webkit-transition: 0.4s ;transition: 0.4s ;}
p {line-height:180%;}
i {	padding: 0 0.5rem;}

.f_l {float:left;}
.f_r {float:right;}
.clear {clear:both}
.clear_fix:before, .clear_fix:after {content: " ";display: table;}
.clear_fix:after {clear: both;}
.clear_fix {*zoom: 1;}
.ta_c {text-align: center;}

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

 共通CSS

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

html {font-size: 62.5%;}
body {font-size:1.6rem;}

/*===========================================
 レイアウト
===========================================*/
.container {margin: 0 auto;}

section .container  {padding: 8vh 0;}

/*===========================================
 共通項目
===========================================*/
/*----------タイトル----------*/
.tit01 {
	font-family: 'Alfa Slab One', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
	font-size: 6.5rem;
	color: #003264;
	text-align: center;
	border-bottom: 5px solid #003264;
	display: inline-block;
	line-height: 110%;
	margin-bottom: 0.2em;
	letter-spacing: 0.02em;
}
.tit01:first-letter{
	color:#0064C8;
 }
.tit02 {
	text-align: center;
	color: #0064C8;
	font-size: 2.8rem;
	font-family: 'Noto Serif JP', serif;
	margin-bottom: 1em;
	font-weight: 500;
	letter-spacing: 0.1em;
}
.tit03 {
	font-family: 'Alfa Slab One', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
	font-size: 6.5rem;
	color: #FFF;
	text-align: center;
	border-bottom: 5px solid #FFF;
	display: inline-block;
	line-height: 110%;
	margin-bottom: 0.2em;
	letter-spacing: 0.02em;
}
.tit03:first-letter{
	color:#96C8F0;
 }
.tit04 {
	text-align: center;
	color: #96C8F0;
	font-size: 2.8rem;
	font-family: 'Noto Serif JP', serif;
	margin-bottom: 1em;
	font-weight: 500;
	letter-spacing: 0.1em;
}
.tit05 {
	font-size: 3.2rem;
	text-align: center;
	font-weight: 900;
	color: #003264;
	margin-bottom: 1em;
}
.tit06 {
	text-align: center;
	font-size: 2.4rem;
	color: #0064C8;
	font-weight: 800;
	line-height: 130%;
	margin-top: 0.5em;
	margin-bottom: 0.5em;
	padding-bottom: 0.5em;
	border-bottom: 1px solid #003264;
}
.tit07 {
	background: #003264;
	color: #FFF;
	text-align: center;
	font-weight: 600;
	font-size: 2.4rem;
	line-height: 130%;
	padding: 0.3em;
	margin-bottom: 1em;
}
.tit08 {
	text-align: center;
	font-size: 2.8rem;
	font-weight: 700;
	color: #003264;
	margin-bottom: 0.5em;
}
.tit08 span {
	font-size: 80%;
}
.tit09 {
	font-family: 'Alfa Slab One', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
	font-size: 6.5rem;
	color: #FFF;
	text-align: center;
	line-height: 110%;
	margin-bottom: 0em;
	letter-spacing: 0.02em;
}
.tit10 {
	text-align: center;
	color: #64C8FF;
	font-size: 2.8rem;
	font-weight: 700;
	letter-spacing: 0.5em;
	line-height: 110%;
}
.tit11 {
	font-size: 4.2rem;
	text-align: center;
	font-weight: 900;
}
.tit12 {
	color: #0064C8;
	font-size: 1.8rem;
	font-family: 'Oswald', sans-serif;
	text-align: center;
	margin-bottom: 2.5em;
}
.tit13 {
	color: #FFF;
	font-size: 2.8rem;;
	font-weight: 800;
	line-height: 130%;
}
.tit13:after {
	content: "";
	display: block;
	width: 150px;
	height: 1px;
	background: #FFF;
	margin-top: 1em;
	margin-bottom: 0.5em;
}
.tit14 {
	color: #FFF;
	font-size: 3.4rem;;
	font-weight: 700;
	line-height: 130%;
	text-align: center;
	border-bottom: 1px solid #FFF;
	padding-bottom: 0.5em;
	margin-bottom: 1.0em;
}
.tit15 {
	color: #FFF;
	font-weight: 700;
	font-size: 2.8rem;
	background: #003264;
	text-align: center;
	padding: 0.2em;
}
.tit16 {
	color: #FFF;
	font-weight: 700;
	font-size: 3.4rem;
	background: #003264;
	text-align: center;
	padding: 0.2em;
	border-radius: 1em;
	margin-bottom: 1.5em;
}

@media screen and (max-width: 768px) {
	.tit01 {font-size: 4.6rem;}
	.tit02 {font-size: 2.2rem;}
	.tit03 {font-size: 4.6rem;}
	.tit04 {font-size: 2.2rem;}
	.tit05 {font-size: 2.4rem;}
	.tit08 {font-size: 2.4rem;}
	.tit09 {font-size: 4.6rem;}
	.tit10 {font-size: 2.2rem;}
	.tit11 {font-size: 3.6rem;}
	.tit14 {font-size: 2.8rem;}
	.tit15 {font-size: 2.2rem;}
	.tit16 {font-size: 2.2rem;}
}

/*----------p 設定----------*/
.p_01 {
	font-weight: 500;
	font-size: 1.8rem;
	margin-bottom: 2.0em;
}
.p_02 {
	font-weight: 500;
	font-size: 1.8rem;
	color: #FFF;
	text-align: center;
}

/*----------flex 設定----------*/
.flex_wrap {
  	display:-webkit-box;
  	display:-ms-flexbox;
	display: flex;
  	-ms-flex-wrap: wrap;
  	flex-wrap: wrap;
}
.flex_reverse {
  	-webkit-box-orient: horizontal;
  	-webkit-box-direction: reverse;
  	-ms-flex-direction: row-reverse;
  	flex-direction: row-reverse;
}

/*----------テーブル 設定----------*/
/*-- tabl01 --*/
.tbl01 table {
	width: 100%;
	color: #FFF;
	font-size: 1.8rem;
	margin-top: 5vh;
}
.tbl01 th {
	border-bottom: 1px solid #FFF;
	padding: 0.8em;
	width: 30%;
}
.tbl01 td {
	border-bottom: 1px solid #FFF;
	padding: 0.8em;
	width: 70%;
}
.tbl01 td ul li {
	list-style: none;
	padding-left:1.5em;
	text-indent:-1.5em;
	margin-bottom: 0.5em;
}
@media screen and (max-width: 768px) {
	.tbl01 table {
		font-size: 1.6rem;
	}
}
/*-- company tabl01 --*/
.company .tbl01 table {
	color: #333;
}
.company .tbl01 th,
.company .tbl01 td {
	border-bottom: 1px solid #333;
}
/*-- tabl02 --*/
.tbl02 table {
	width: 100%;
	font-size: 1.8rem;
}
.tbl02 th {
	border-bottom: 1px solid #0096F0;
	padding: 0.8em;
	width: 30%;
}
.tbl02 td {
	border-bottom: 1px solid #0096F0;
	padding: 0.8em;
	width: 70%;
}
@media screen and (max-width: 768px) {
	.tbl02 table {
		font-size: 1.6rem;
		border-top: 1px solid #0096F0;
	}
	.tbl02 table th {
		display: block;
		width: 100%;
		text-align: left;
		border-bottom: none;
		padding-bottom: 0;
	}
	.tbl02 table td {
		display: block;
		width: 100%;
		padding-top: 0;
	}
}
/*-- tabl03 --*/
.tbl03 table {
	width: 100%;
}
.tbl03 th {
	border: 1px solid #333;
	padding: 0.8em;
	width: 25%;
}
.tbl03 td {
	border: 1px solid #333;
	padding: 0.8em;
	width: 75%;
}

/*----------ボタン設定----------*/
.btn01 a {
    position: relative;
    font-size: 2.5rem;
	font-weight: 500;
    display: block;
    max-width: 400px;
    padding: 1em;
	border: 1px solid #003264;
	border-radius: 5px;
    color:#FFF;
    text-align: center;
    margin: 0 auto;
	background: -webkit-linear-gradient(bottom, #0050A0 0%, #003264 30%, #003264 70%, #001428 100%);
	background: -o-linear-gradient(bottom, #0050A0 0%, #003264 30%, #003264 70%, #001428 100%);
	background: linear-gradient(to top, #0050A0 0%, #003264 30%, #003264 70%, #001428 100%);
}
.btn01 a:hover {
    background: #001428;
}
.btn01 a:after {
    content: ">";
    position: absolute;
    right: 25px;
	top: 30%;
    -webkit-transition: all 0.4s ease-out;
    transition: all 0.4s ease-out;
}
.btn01 a:hover:after {
    transform: translate(15px,0);
}
@media screen and (max-width: 768px) {
	.btn01 a {
		font-size: 2.2rem;
	}
}

/*----------共通 設定----------*/
.bg_gy {background: #F0F0F0;}
.mb2 {margin-bottom: 2em;}
.mb4 {margin-bottom: 4em;}
.mt2 {margin-top: 2em;}
.mt3 {margin-top: 3em;}
.fc_w {color: #FFF;}
.w750_mrl {max-width: 750px; margin: 0 auto; width: 90%;}
.w1000 {max-width: 1000px; margin: 0 auto;}
.prl5 {padding: 0 5%;}

/*===========================================
 共通 - ヘッダー
===========================================*/
header {
	background-color: rgba(255,255,255,0.9);
    width: 100%;
	border-bottom: 1px solid #F2F2F2;
	height: 100px;
}
header .container {
    position: relative;
	max-width: 1000px;
}
header .logo {
    position: absolute;
    left: 0;
    top: 15px;
}
header .header_tell {
    position: absolute;
    right: 0;
    top: 15px;
}

/*===========================================
 共通 - ナビゲーション
===========================================*/
#g_nav {
	background: linear-gradient(#0064C8, #003264);
}
#g_nav .container {
	max-width: 900px;
}
.Nav {}

.Nav .navbtn {
    display: none;
}
.Nav ul.close {
    display: none;
}
.Nav ul {
	width: 100%;
}
.Nav > ul > li {
    position: relative;
    text-align: center;
    width:calc(100% / 5);
	height: 70px;
    font-weight: 500;
	float: left;
	line-height: 100%;
	border-right: 1px solid #003264;
	border-image: linear-gradient(to top, #003264 0%, #FFF 40%, #FFF 60%, #0064C8 100% );
	border-image-slice: 1;
}
.Nav > ul > li:first-child {
	border-left: 1px solid #003264;
	border-image: linear-gradient(to top, #003264 0%, #FFF 40%, #FFF 60%, #0064C8 100% );
	border-image-slice: 1;
}
.Nav > ul > li a {
    display: block;
    position: relative;
    text-decoration: none;
    width: 100%;
    height: 100%;
    color: #F0F0F0;
    font-size: 1.8rem;
}
.Nav > ul > li a span {
	position: absolute;
	display: block;
	width: 100%;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	letter-spacing: 0.05em;
}
.Nav > ul > li a span i {
	color: #64C8FF;
	display: block;
	font-size: 1.2rem;
	font-style: normal;
	margin-top: 0.9rem;
	font-family: 'Oswald', sans-serif;
}
.Nav > ul > li.parent > a {
    padding-right:20px;
}
.Nav > ul > li.parent > a::before {
    display: block;
    content: "";
    position: absolute;
    top: 50%;
    right: 12px;
    width: 8px;
    height: 8px;
    margin: -8px 0 0 0;
    border-top: solid 2px #1EAA39;
    border-right: solid 2px #1EAA39;
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg);
}
.Nav > ul > li a:hover {
    font-weight: 500;
}
/* 2階層 */
.Nav > ul > li > ul {
    display: none;
    position: absolute;
    top: 45px;
    left: -50%;
    width: auto;
    background-color: #1A1A1A;
    z-index: 9;
}
.Nav > ul > li > ul:before {
	content: "";
	position: absolute;
	top: -20px;
	left: 50%;
	margin-left: -10px;
	border: 10px solid transparent;
	border-bottom: 10px solid #1A1A1A;
}
.Nav > ul > li > ul li {
    white-space: nowrap;
    text-align: left;
	border-bottom: 1px solid #000;
}
.Nav > ul > li > ul li a {
    position: relative;
    padding: 12px 27px 12px 27px;
    color: #FFF;
}
.Nav > ul > li > ul li a::before {
    display: block;
    content: "";
    position: absolute;
    top: 50%;
    left: 10px;
    width: 6px;
    height: 6px;
    margin: -6px 0 0 0;
    border-top: solid 2px #1EAA39;
    border-right: solid 2px #1EAA39;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
.Nav > ul > li > ul li a:hover {
	background:  #000;
}
.Nav > ul > li > ul li ul li a {
    padding-left: 42px;
}
.Nav > ul > li > ul li ul li a::before {
    left: 20px;
}

@media screen and (max-width: 768px) {
	header {
		padding-bottom: 0;
		background-color: rgba(255,255,255,1.0);
		position: fixed;
		z-index: 10;
		height: 60px;
	} 
    header .container {width: 100%;}	
    header .logo_mark {
        position: absolute;
		left: 0px;
        z-index: 10;
    }
    header .logo_type {
        max-width:250px;
			width: 70%;
			margin: 0 auto;
     }
    .Nav {
	}
    .Nav .navbtn {
        display: block;
        position: fixed;
        top: 0;
        right: 0;
		z-index: 10;
    }
    .Nav .navbtn a,
    .Nav .navbtn a.close {
        display: block;
        position: relative;
        width: 60px;
        height: 60px;
        background-color: #0064C8;
    }
    .Nav .navbtn a::before,
    .Nav .navbtn a.close::before {
        position: absolute;
        top:18px;
        left:10px;
        content:"";
        width: 40px;
        height: 2px;
        background-color: #FFF;
        transition: .2s;
    }
    .Nav .navbtn a.open::before {
        top:29px;
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg);
    }
    .Nav .navbtn a::after,
    .Nav .navbtn a.close::after {
        position: absolute;
        bottom:18px;
        left:10px;
        content:"";
        width: 40px;
        height: 2px;
        background-color: #FFF;
        transition: .2s;
    }
    .Nav .navbtn a.open::after {
        bottom:29px;
        -webkit-transform: rotate(-135deg);
        transform: rotate(-135deg);
    }
    .Nav .navbtn a.open {
    }
    .Nav .navbtn a span {
        display: block;
        overflow: hidden;
        width: 1px;
        height: 1px;
    }
    .Nav .navbtn a span::after,
    .Nav .navbtn a.close span::after {
        position: absolute;
        top:29px;
        left:10px;
        content:"";
        width: 40px;
        height: 2px;
        background-color: #FFF;
    }
    .Nav .navbtn a.open span::after {
        display: none;
    }
    .Nav > ul {
        display: none;
        position: fixed;
        top: 60px;
        left: 0;
        right: 0;
        z-index: 9;
        background: linear-gradient(#0064C8, #003264);
		max-width: 100%;
		border-top: 1px solid #FFF;
    }
    .Nav > ul > li {
        text-align: center;
        width: 100%;
        float: none;
        display: block;
        border-bottom: solid 1px #dddddd;
		border-right: 0px;
    }
	.Nav > ul > li:first-child {
		border-left: 0px;
	}
    .Nav .nav_tel {
		height: auto;
	}
	.Nav > ul > li a {
    	padding: 1.3vh 10px;
	}
	.Nav > ul > li > ul {
		max-width: 100%;
	}
	.Nav > ul > li > ul li a {
    	padding: 1.5vh 27px;
	}
	.Nav > ul > li > ul:before {
		display: none;
	}
    .Nav > ul > li.parent.open > a::before {
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg);
    }
    .Nav > ul > li.parent.open {
        border-bottom: none;
    }
    .Nav > ul > li.parent.open > a {
        color: #FFF;
    }
    .Nav > ul > li > ul {
        position: static;
    }
	#mainimg {margin-top: 61px;
	}
	#subimg {margin-top: 61px;
	}
}

/*===========================================
 共通 - footer
===========================================*/
body {
  	display:-webkit-box;
  	display:-ms-flexbox;
  	display:flex;
  	-webkit-box-orient: vertical;
  	-webkit-box-direction: normal;
  	-ms-flex-direction: column;
  	flex-direction: column;
    min-height: 100vh;
}
footer {
    margin-top: auto;
}

#go_top {
	position: fixed;
	bottom: 10px;
	right: 5vw;
}
#copy {
	background: linear-gradient(#0064C8, #003264);
	padding: 2.0em 0;
	text-align: center;
}
small {
	color: #FFF;
	font-size: 1.4rem;
	display: block;
}
@media screen and (max-width: 1000px) {
	#go_top {
		bottom: 13vw;
		right: 10px;
		width: 40px;
		height: 40px;
	}
}

/*===========================================
 トップ - mainimg
===========================================*/
#mainimg {
	background: url("../img/mainimg.jpg")center center #003264;
	background-size: cover;
}
#mainimg .container {
	position: relative;
	max-width: 1000px;
	height: 600px;
}
#mainimg_tit {
	position: absolute;
	display: block;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width: 100%;
}
#mainimg_tit img {
	max-width: 100%;
}
@media screen and (max-width: 768px) {
	#mainimg .container {
		width: 100%;
		height: 500px;
	}
}

/*===========================================
 トップ - メインコンテンツ
===========================================*/
/*----------top_business----------*/
#top_business {}

#top_business .container {
	padding-top: 10vh;
}
.point {
	margin-top: 3vh;
}
.point .point_box {
	width: calc(88% / 3);
	margin: 3% 6% 0 0;
}
.point .point_box:last-child {
	margin: 3% 0 0 0;
}
.point .point_box p {
	color: #003264;
	font-weight: 500;
}
@media screen and (max-width: 768px) {
	.point .point_box {
		width: 100%;
		margin: 3% 0;
	}
}

/*----------top_feature----------*/
#top_feature {
	background-colord: #000010;
	background:url("../img/top/top_feature_bg.jpg") center center;
	background-size: cover;
	text-shadow: 0 0 10px rgba(0, 0, 0, 0.7);
}
@media screen and (max-width: 768px) {
	#top_feature .p_02 {
		text-align: left;
	}
	#top_feature .p_02 br {
		display: none;
	}
}

/*----------image_view----------*/
.image_view{background: #000010;}
.image_view img {width: 100%;}

/*----------bottom_profile----------*/
#bottom_profile {
	background: #003264;
}
.bottom_profile_box {
	color: #003264;
	background: #FFF;
	border-radius: 10px;
	padding: 3%;
	margin: 5% 0 0 0; 
}
.bottom_profile_box .clear_fix {
	margin-bottom: 1em;
}
.bottom_profile_box_l {
	width: 47%;
	float: left;
}
.bottom_profile_box_r {
	width: 50%;
	float: right;
	color: #003264;
}
.bottom_profile_box_r .add {
	font-size: 1.5rem;
	line-height: 130%;
	margin-bottom: 0.5em;
}
.bottom_profile_box_r .box01 {
	text-align: center;
	border-radius: 10px;
	border: 2px solid #003264;
	margin-top: 1.5em;
	position: relative;
	font-weight:700;
	font-size: 1.6rem;
	padding: 1em 0.5em;
 }
.bottom_profile_box_r .box01 .tit {
	background: #FFF;
	position: absolute;
	top: 0;
	left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
	width: 100px;
}
.bottom_profile_box_r .box01 p {
	line-height: 150%;
}
@media screen and (max-width: 768px) {
	.bottom_profile_box_l {
		width: 100%;
		float: none;
		margin-bottom: 1em;
	}
	.bottom_profile_box_r {
		width: 100%;
		float: none;
	}
}

/*===========================================
 サブページ共通
===========================================*/
/*----------subimg----------*/
#subimg {
	height: 400px;
	background-size: cover;
	position: relative;
	background: #003264;
}
#page_business #subimg .container {background: url("../img/business/subimg.jpg")center;background-size: cover;}
#page_profile #subimg .container {background: url("../img/profile/subimg.jpg")center;background-size: cover;}
#page_recruit #subimg .container {background: url("../img/recruit/subimg.jpg")center;background-size: cover;}
#page_contact #subimg .container {background: url("../img/contact/subimg.jpg")center;background-size: cover;}

@media screen and (max-width: 768px) {
	#page_recruit #subimg .container {background-position: right center;}
}

#subimg .container {
	position: relative;
	height: 400px;
	max-width: 1200px;
	width: 100%;
}
#subimg_tit {
	position: absolute;
	display: block;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width: 100%;
	background: -webkit-linear-gradient(left, rgba(0,50,100,0) 0%, rgba(0,50,100,0.4) 30%, rgba(0,50,100,0.4) 70%, rgba(0,50,100,0) 100%);
	background: -o-linear-gradient(left, rgba(0,50,100,0) 0%, rgba(0,50,100,0.4) 30%, rgba(0,50,100,0.4) 70%, rgba(0,50,100,0) 100%);
	background: linear-gradient(to left, rgba(0,50,100,0) 0%, rgba(0,50,100,0.4) 30%, rgba(0,50,100,0.4) 70%, rgba(0,50,100,0) 100%);
	padding: 8px 0;
}
#subimg_tit div {
	background: -webkit-linear-gradient(left, rgba(0,50,100,0) 0%, rgba(0,50,100,0.4) 30%, rgba(0,50,100,0.4) 70%, rgba(0,50,100,0) 100%);
	background: -o-linear-gradient(left, rgba(0,50,100,0) 0%, rgba(0,50,100,0.4) 30%, rgba(0,50,100,0.4) 70%, rgba(0,50,100,0) 100%);
	background: linear-gradient(to left, rgba(0,50,100,0) 0%, rgba(0,50,100,0.4) 30%, rgba(0,50,100,0.4) 70%, rgba(0,50,100,0) 100%);
	padding: 1em 0 1.3em 0;
}
@media screen and (max-width: 768px) {
	#subimg {
		height: 300px;
	}
	#subimg .container {
		height: 300px;
		width: 100%;
	}
	#subimg_tit,
	#subimg_tit div {
		background: -webkit-linear-gradient(left, rgba(0,50,100,0) 0%, rgba(0,50,100,0.4) 30%, rgba(0,50,100,0.4) 70%, rgba(0,50,100,0) 100%);
		background: -o-linear-gradient(left, rgba(0,50,100,0) 0%, rgba(0,50,100,0.4) 30%, rgba(0,50,100,0.4) 70%, rgba(0,50,100,0) 100%);
		background: linear-gradient(to left, rgba(0,50,100,0) 0%, rgba(0,50,100,0.4) 30%, rgba(0,50,100,0.4) 70%, rgba(0,50,100,0) 100%);
	}
}

/*===========================================
 page business
===========================================*/
/*----------sec01----------*/
#page_business .sec01 {
}
#page_business .sec01 .container {
	max-width: 1000px;
	width: 100%;
}
#page_business .sec01 .box01 {
	background-color: #000;
	background: url("../img/business/sec01_bg.jpg")center;
	background-size: cover;
	margin-bottom: 2.0em;
}

/*----------sec02----------*/
#page_business .sec02 {
	background: #003264;
}
#page_business .point_box .img01 {background: url("../img/business/sec02_01.jpg")center;background-size: cover;}
#page_business .point_box .img02 {background: url("../img/business/sec02_02.jpg")center;background-size: cover;}
#page_business .point_box .img03 {background: url("../img/business/sec02_03.jpg")center;background-size: cover;}
#page_business .point_box .img04 {background: url("../img/business/sec02_04.jpg")center;background-size: cover;}
.point_box_img {
	width: 50%;
	min-height: 400px;
}
.point_box_exp {
	width: 50%;
	color: #FFF;
	padding: 5%;
}
@media screen and (max-width: 768px) {
	.point_box_img {
		width: 100%;
		min-height: 300px;
	}
	.point_box_exp {
		width: 100%;
	}
}

/*===========================================
 page business
===========================================*/
/*----------greeting----------*/
.greeting {
	background: #003264;
}
.greeting_box {
	/*background: url("../img/profile/greeting_president.jpg") right center;
	background-size: cover;*/
}
.greeting_box_exp {
	/*width: 60%;
	background: rgba(0,50,100,0.8);*/
	width: 100%;
	background: rgba(0,50,100,1.0);
	color: #FFF;
	font-family: 'Noto Serif JP', -apple-system, BlinkMacSystemFont, "ＭＳ Ｐ明朝", "MS PMincho","ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
}
.greeting_box_exp p {
	margin-bottom: 1.0em;
}
/*@media screen and (max-width: 768px) {
	.greeting_box {
		background: none;
	}
	.greeting_box_exp {
		width: 100%;
		background: rgba(0,50,100,1.0);
		padding: 5% 5% 10% 5%;
	}
}*/

/*----------company----------*/
.company {}

.company_list {
	background: #FFF;
	border-radius: 10px;
	padding: 3%;
	margin: 5% 0 0 0; 
}
.company_list .office {
	margin-bottom: 1.0em;
}
.company_list .add {
	text-align: center;
	font-weight: 500;
	font-size: 1.8rem;
	line-height: 130%;
	margin-bottom: 0.5em;
}
.company_list .tit {
	font-weight: 600;
	color: #003264;
	text-align: center;
	font-size: 2.2rem;
	margin-top: 1em;
	margin-bottom: 0.5em;
    display: flex;
    align-items: center;
}
.company_list .tit:before,
.company_list .tit:after{
    content:"";
    flex-grow: 1;
    border-bottom: 2px solid #003264;
}
.company_list .tit:before{
    margin-right: 10px;
    padding-left: 15px;
}
.company_list .tit:after{
    margin-left: 10px;
    padding-right: 15px;
}
.company_list .exp {
	font-weight: 600;
	color: #003264;
	text-align: center;
	font-size: 2.2rem;
	line-height: 130%;
	margin-bottom: 0.5em;
}
.company_list .map {
	margin-top: 2em;
}
@media screen and (max-width: 768px) {
	.company_list .add {
		font-size: 1.6rem;
	}
	.company_list .tit {
		font-size: 1.8rem;
	}
	.company_list .exp {
		font-size: 1.8rem;
	}
}

/*===========================================
 page contact
===========================================*/
/*----------contact tel----------*/
.contact_tel {
	margin-top: 8vh;
	text-align: center;
}
.contact_tel .tantou {
	font-size: 1.8rem;
	margin-bottom: 2em;
	font-weight: 500;
}
.contact_tel .uketsuke {
	border-top: 1px solid #B4B4B4;
	border-bottom: 1px solid #B4B4B4;
	font-size: 2.2rem;
	font-weight: 500;
	padding: 0.5em;
}

/*----------mailform----------*/
input,
select,
textarea {font-size:16px!important;}

form#mail_form * {
	margin: 0;
	padding: 0;
}
form#mail_form {
	width: 100%;
	line-height: 1.8;
}
form#mail_form dl {
	width: 100%;
	margin: 0 auto;
	overflow: hidden;
	margin-top: 5vh;
}
form#mail_form dl dt {
	padding: 1.5rem 0 0 0;
	text-align: left;
	overflow: hidden;
    font-size: 1.8rem;
	font-weight: 500;
}
form#mail_form dl dd {
	padding: 0.5em 0.5em 1.5rem 0.5em;
}
form#mail_form dl dt .must {
    color: #C80000;
	margin-left: 0.5em;
	font-size: 90%;
}
form#mail_form input[type="text"],
form#mail_form input[type="email"],
form#mail_form input[type="tel"] {
	max-width: 100%;
	padding: 7px 2%;
	border: 1px solid #CCC;
	border-radius: 3px;
	background: #F5F7F9;;
	-webkit-appearance: none;
	font-size: 100%;
	font-family: inherit;
}
form#mail_form input[type="text"]:focus,
form#mail_form input[type="email"]:focus,
form#mail_form input[type="tel"]:focus,
form#mail_form textarea:focus {
	box-shadow: 0px 0px 5px #003264;
	border: 1px solid #003264;
	background: #ffffff;
}
form#mail_form ul li input[type="radio"],
form#mail_form ul li input[type="checkbox"] {
	margin-right: 10px;
    position: relative;
    top: -1px;
}
form#mail_form ul li:first-child input[type="radio"],
form#mail_form ul li:first-child input[type="checkbox"] {
	margin-top: 0px;
}
form#mail_form select {
	font-size: 1.6rem;
    height: 4.2rem;
	padding : 0 2%;
	border : 1px solid #666666;
    width: 50%;
    border-radius: 3px;
}
form#mail_form textarea {
	display: block;
	width: 100%;
	max-width: 100%;
	height: 200px;
	padding: 7px 2%;
	resize: vertical;
	border: 1px solid #CCC;
	border-radius: 3px;
	background: #F5F7F9;;
	-webkit-appearance: none;
	font-size: 100%;
	font-family: inherit;
}
form#mail_form ul {
	list-style-type: none;
}
form#mail_form ul li label:hover {
	cursor: pointer;
}
form#mail_form input#company_name,
form#mail_form input#name,
form#mail_form input#phone,
form#mail_form input#mail_address {
	width: 100%;
}
form#mail_form input#postal + a {
	display: inline-block;
	padding: 5px 15px;
	border: 1px solid #46b8da;
	border-radius: 3px;
	background: #5bc0de;
	font-size: 100%;
	color: #ffffff;
	text-decoration: none;
}
form#mail_form input#postal + a:hover {
	cursor: pointer;
	background: #31b0d5;
	border: 1px solid #269abc;
}
form#mail_form p#form_submit {
	width: 90%;
	margin: 0 auto 3rem auto;
	padding: 15px 0;
}
form#mail_form input[type="submit"] {
	padding: 1.0em 0.5em;
    max-width: 350px;
    width: 100%;
	background: #FFF;
	font-size: 2.0rem!important;
    font-weight: 300;
    color: #003264;
	font-family: inherit;
	-webkit-appearance: none;
    letter-spacing: 0.05em;
    margin: 0 auto;
    display: block;
	border: 1px solid #003264;
}
form#mail_form input[type="submit"]:hover {
	cursor: pointer;
	background: #333;
	color: #FFF;
}

/*===========================================
 page thanks
===========================================*/
#complete {
    text-align: center;
    padding: 5%;
	background: #FFF;
}
#complete p {
	margin-bottom: 1em;
}
#complete .links {
    margin-top: 5%;
}
#complete .links p {
    margin: 1em auto;
}

/*====================================================================
 768px以下 
====================================================================*/
@media screen and (max-width: 768px) {
	.container {width: 90%;}
	.sp_none {display: none;}
}

/*====================================================================
 420px以下 
====================================================================*/
@media screen and (max-width: 420px) {
	html {font-size: 58%;}
}

/*====================================================================
 768px以上 
====================================================================*/
@media screen and (min-width: 769px) {
	.pc_none {display: none;}
	.container {width: 96%;}
	.container {max-width: 750px;}
}
