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

/*################ リセットcss #################*/
/* 
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com 
Twitter: @rich_clark
*/

html {
overflow: auto;
}

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,
caption, tbody, tfoot, thead, 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: 14px;
	font-family: "Noto Sans JP","ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
    vertical-align:baseline;
    background:transparent;
    max-height:999999px;/** スマートフォンでフォントサイズがおかしくなるのを防止 **/
}


body{
	padding: 0px;
	margin: 0px;
	letter-spacing: 1.3px;
	color:#333333;
	overflow: hidden;
	background: #f5f7fa;
}

.cf:after {
  content: ".";  /* 新しい要素を作る */
  display: block;  /* ブロックレベル要素に */
  clear: both;
  height: 0;
  visibility: hidden;
}

a {
	color: #333333;
    margin:0;
    padding:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}

p {
	-ms-word-break: break-word;
	word-break: break-all;
}

ol, ul {
    list-style:none;
}

table  {
	border: 2px solid #000000;
	border-collapse: collapse;
}
tr, td, th {
	padding: 5px;
}


/* 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;
  font-family: "Noto Sans JP","ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
}
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;
}





.wrapper {
	width: 100%;
    margin: 0px auto;
    overflow: hidden;
	position: relative;
}




/* 共通ヘッダー */

header {
	position: absolute;
    width: 100%;
    z-index: 10;
	background-color: rgba(21,61,142,0.8);
}

.logo {
	margin-left: 2%;
    width: 28%;
    float: left;
}

.logo a {
	display: inline-block;
	max-width:150px;
	width:100%;
	margin: 10px auto;
	float: left;
}

.logo a:hover {
	opacity: 0.7;
}


.logo a img {
	display: block;
	width:100%;
	margin: 0 auto;
}

.menu_nav ul {
	width: 68%;
    margin-right: 2%;
    float: right;
}

.menu_nav li {
	display: inline-block;
	font-size:0px;
	width: 14.285%;
	-ms-transition: all 0.3s ease;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
}


.menu_nav a {
	color: #ffffff;
    text-decoration: none;
    display: inline-block;
    width: 100%;
    font-size: 16px;
    padding: 32.5px 0px;
    line-height: 1.3;
    text-align: center;
	-ms-transition: all 0.3s ease;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
}

.menu_nav a span.jp {
    display: none;
}

.menu_nav a:hover {
    background-color: rgba(40,85,185,0.6)
}

.menu_nav a:hover span.jp {
    display: inline;
}

.menu_nav a:hover span.eng {
    display: none;
}




/*footer*/

footer .contact {
	background-image: url(./../image/common/contact_bg.jpg);
	position: relative;
    height:auto;
    background-size: cover;
	background-position: center;
	background-repeat:no-repeat;
}

footer .contact .inner {
	padding: 80px 0px;
	display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
	align-items: center;
}

footer .contact .inner .text_area {
    width: 55%;
	margin-right: 5%;
}

footer .contact .inner .text_area h2 {
	margin: 0px auto 30px;
}

footer .contact .inner .text_area p {
    font-size: 16px;
    letter-spacing:4px;
	line-height: 1.8;
	color:#ffffff;
}

footer .contact .inner .btn_area {
	width: 100%;
    max-width: 40%;
}

footer .contact .inner .btn_area a {
	display: inline-block;
	width:calc(100% - 6px);
	background-color: #ffffff;
	padding: 12px 0px;
	font-size: 18px;
	letter-spacing:3px;
	font-weight:bold;
	text-align: center;
	text-decoration: none;
	position: relative;
	border-radius: 50px;
	border: solid 3px #ffffff;
	transition: all 0.3s;
}

footer .contact .inner .btn_area a:last-child {
	margin-top:20px; 
}

footer .contact .inner .btn_area a:first-child:before {
    content: url(./../image/common/icon_tel.png);
    vertical-align: middle;
    display: inline-block;
    width: 30px;
    height: 30px;
	margin-top: -3px;
    margin-right: 10px;
	transition: all 0.3s;
}

footer .contact .inner .btn_area a:last-child:before {
    content: url(./../image/common/icon_mail.png);
    vertical-align: middle;
    display: inline-block;
    width: 30px;
    height: 30px;
	margin-top: -3px;
    margin-right: 10px;
	transition: all 0.3s;
}


footer .contact .inner .btn_area a:hover {
	color:#ffffff;
	background-color: #153d8e;
}


footer .contact .inner .btn_area a:first-child:hover:before {
    content: url(./../image/common/icon_tel_on.png);
}

footer .contact .inner .btn_area a:last-child:hover:before {
    content: url(./../image/common/icon_mail_on.png);
}




footer .info {
	background-color:#153d8e;
	width:100%;
	color:#ffffff;
}

footer .info .inner {
	padding:50px 0px;
}

footer .info .info_cont .company_info {
    text-align: center;
	margin-bottom: 15px;
}

footer .info .info_cont .company_info img {
	display: block;
	margin:0px auto 20px;
}

footer .info .info_cont .company_info p {
    font-size:13px;
	line-height: 1.8;
}


footer .info .info_cont .sns_link a {
    display:block;
	width:35px;
	margin: auto;
}

footer .info .info_cont .sns_link a img {
    display:block;
	width:100%;
}

footer .info .info_cont .sns_link a:hover {
	opacity: 0.7;
}




footer .copyright {
	background-color:#153d8e;
	width:100%;
	padding:20px 0px;
	border-top:solid 1px #ffffff;
}

footer .copyright p {
	text-align: center;
	font-size:12px;
	color:#ffffff;
}


/* ページトップへ戻るボタン */

.pagetop {
    display: none;
    position: fixed;
    bottom:90px;
    right: 30px;
    z-index: 99;
}

.pagetop a {
    background-image: url(./../image/common/page_top.png);
    background-repeat: no-repeat;
    display: block;
    width: 20px;
    height: 100px;
}





@media screen and (max-width: 768px) {


.wrapper {
	width: 100%;
	margin: 0px auto;
}



/* 共通ヘッダー */

header {
	height: 75px;
    background-color: rgba(21,61,142,0.6);
}

.logo {
    width:calc(98% - 70px);
}

.logo a {
    max-width: 110px;
}

.menu_nav {
  position: fixed;
  right: -320px; /* これで隠れる */
  top: 0;
  width: 290px; /* スマホに収まるくらい */
  padding-top: 75px;
  transition: all .6s;
  z-index: 9999;
  background:#153d8e;
}

.menu_nav ul {
    display: inline-block;
	height: auto;
	padding-bottom: 30px;
	width: 100%;
	margin-right: 0%;
}

.menu_nav li {
	display: block;
    margin: 0 auto;
    width: 90%;
    height:auto;
    padding: 0px;
	border-right:none;
	border-bottom:none;
}

.menu_nav li:first-child {
	border-left:none;
}

.menu_nav li:hover a {
    color:#ffffff;
}

.menu_nav_item a {
  display: block;
  width: calc(100% - 40px);
  padding: 10px 20px;
  font-size: 16px;
}

.menu_nav_item a:hover {
	text-decoration:none;
	background-color:#355bba;
}

.menu_nav_item a span {
  font-size: 16px;
}


.menu_nav_item a br {
	display:none;
}

.hamburger {
  position: absolute;
  right: 0px;
  top: 0px;
  width: 70px;
  height: 75px;
  cursor: pointer;
  z-index: 9999;
}

.hamburger:after {
	content: "menu";
	font-size:15px;
	color:#ffffff;
	position: absolute;
	top:43px;
	right:13px;
	letter-spacing: 0.5px;
}

.hamburger_line {
  position: absolute;
  left: 15px;
  width: 40px;
  height: 3px;
  background-color: #ffffff;
  transition: all .6s;
}
.hamburger_line-1 {
  top: 15px;
}

.hamburger_line-2 {
  top: 25px;
}

.hamburger_line-3 {
  top: 35px;
}

.black-bg {
  position: fixed;
  left: 0;
  top: 0;
  width: 100vw;
  height: 100vh;
  z-index: 9998;
  background-color: #000000;
  opacity: 0;
  visibility: hidden;
  cursor: pointer;
}


/* メニューが表示された時用のCSS */
.nav-open .menu_nav {
  right: 0;
  position: absolute;
  width:100%;
}

.nav-open .black-bg {
  opacity: .6;
  visibility: visible;
}
.nav-open .hamburger_line-1 {
  transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
   -moz-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
     -o-transform: rotate(45deg);
  top: 25px;
}
.nav-open .hamburger_line-2 {
  width: 0;
  left: 50%;
}
.nav-open .hamburger_line-3 {
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
   -moz-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
     -o-transform: rotate(-45deg);
  top: 25px;
}






/*footer*/

footer .contact .inner {
	padding: 50px 0px;
}

footer .contact .inner h2 {
	text-align: center;
}

footer .contact .inner .text_area {
    width: 100%;
    margin-right: 0%;
	margin-bottom: 5%;
}

footer .contact .inner .text_area p {
    letter-spacing: 0.5px;
	text-align: center;
}

footer .contact .inner .btn_area {
    margin: auto;
	max-width: 75%;
}

footer .contact .inner .btn_area a {
	padding: 10px 0px;
	font-size: 16px;
}

footer .info .inner {
	padding:30px 0px;
}

footer .info .info_cont .company_info {
    width: 100%;
	margin-right: 0%;
	margin-bottom: 30px;
}


footer .copyright p {
    -webkit-transform: scale(0.8);
    -moz-transform: scale(0.8);
    -ms-transform: scale(0.8);
    -o-transform: scale(0.8);
    transform: scale(0.8);
}

footer .info .info_cont ul li p {
    font-size:12px;
}



/* ページトップへ戻るボタン */

.pagetop {
    right: 15px;
	bottom: 75px;
	z-index: 999;
}

}




@media screen and (max-width: 420px) {

.logo p {
    margin-left: 15px;
    padding: 25px 0px;
	font-size: 12px;
}


footer .contact {
	background-image: url(./../image/common/contact_bg_sp.jpg);
}

footer .contact .inner h2 {
	margin: 0px auto 30px;
	width:60%;
}

footer .contact .inner h2 img {
	display: block;
	width:100%;
}

footer .contact .inner p {
	font-size: 14px;
}

footer .contact .inner .btn_area {
    max-width: 100%;
}


footer .info .info_cont .company_info {
    margin-bottom:20px;
}

footer .info .info_cont .company_info img {
    margin-bottom: 10px;
	width: 120px;
}

footer .info .info_cont .company_info p {
    font-size: 12px;
    line-height: 1.5;
}


}



