@charset "UTF-8";
/* CSS Document */
@import url("https://fonts.googleapis.com/css?family=M+PLUS+1p|M+PLUS+Rounded+1c|Noto+Sans+JP|Noto+Serif+JP:400,900");
@media print {
  body{
    width: 1024px;
  }
}
#page-top{
  font-family: Arial, Helvetica, "sans-serif";
  position: fixed;
  bottom: 160px;
  right: 10px;
  font-size: 1.4rem;
  line-height: 60px;
  z-index: 1000;
}
#page-top a{
  background: rgba(23, 31, 74, 0.7);
  text-decoration: none;
  color: #fff;
  width: 60px;
  text-align: center;
  display: block;
  border-radius: 30px;
}
#page-top a:hover{
  text-decoration: none;
  background: rgba(23, 31, 74, 0.5);
}

html{
  font-size: 62.5%;
}

body{
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Segoe UI', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴシック', 'Hiragino Sans', YuGothic,' Yu Gothic', メイリオ, Meiryo, sans-serif;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1;
  font-weight: 400;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  color: #231815;
  overflow-x: hidden;
}

.stuffing {
  font-feature-settings: "palt" 1;
}

.justify{
  text-align: justify;
  text-justify: inter-ideograph;
}

.text_set{
  font-feature-settings: "palt" 1;
  text-align: justify;
  text-justify: inter-ideograph;
}

img{
  width: 100%;
  vertical-align: bottom;
}

a{
  color: #2ea6ff;
  text-decoration: none;
}
a:hover{
  text-decoration: underline;
}

.alpha a {
  opacity: 1;
  transition: all 0.3s linear 0s;
  -webkit-transition: all 0.3s linear 0s;
  -ms-transition: all 0.3s linear 0s;
  -moz-transition: all 0.3s linear 0s;
  -o-transition: all 0.3s linear 0s;
}
.alpha a:hover {
  opacity: 0.8;
}

.anchor_base{
  position: relative;
}
.anchor_base .anchor_point{
  position: absolute;
  left: 0;
  top: -20px;
}

.page_break_before{
  page-break-before: always;
}

.page_break_after{
  page-break-after: always;
}

.header_area{
  background: #000;
}
.header_area .bk_line{
  padding: 5px 0;
  font-size: 0.875em;
  line-height: 1.5;
  color: #fff;
  text-align: center;
}
@media screen and (max-width: 600px) {
  .header_area .bk_line{
    font-size: 0.75em;
  }
}
.header_area .mainvisual{
  height: 172px;
  width: 100%;
  max-width: 1024px;
  margin: auto;
  background : url(hbg.png) left bottom / cover no-repeat scroll padding-box border-box transparent;
  position: relative;
}
@media screen and (max-width: 600px) {
  .header_area .mainvisual{
    height: 340px;
    background : url(hbg_mobile.png) center bottom / contain no-repeat scroll padding-box border-box transparent;
  }
}
@media screen and (max-width: 414px) {
  .header_area .mainvisual{
    height: 220px;
    background : url(hbg_mobile.png) center bottom / contain no-repeat scroll padding-box border-box transparent;
  }
}
.header_area .mainvisual .logoset{
  position: absolute;
  right: 0;
  top: calc(50% - 52.5px);
  width: 430px;
}
@media screen and (max-width: 600px) {
  .header_area .mainvisual .logoset{
    top: 1em;
    left: calc(50% - 215px);
  }
}
@media screen and (max-width: 414px) {
  .header_area .mainvisual .logoset{
    width: 280px;
    top: 0.75em;
    left: calc(50% - 140px);
  }
}

.navi_area{
  width: 100%;
  max-width: 1024px;
  margin: 3px auto 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}
.navi_area a{
  color: #231815;
}
.navi_area a:hover{
  text-decoration: none;
}
.navi_area li{
  font-size: 0.875em;
}
@media screen and (max-width: 960px) {
  .navi_area{
    display: block;
  }
}
@media screen and (max-width: 600px) {
  .navi_area{
    display: none;
  }
}
.navi_area .main_menu {
  width: calc(75% - 0.5px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
@media screen and (max-width: 960px) {
  .navi_area .main_menu{
    width: 100%;
  }
}
.navi_area .main_menu li{
  width: calc(33.333333% - 0.6666666px);
  text-align: center;
  line-height: 2.3;
}
.navi_area .main_menu li:nth-child(-n + 3) a{
  display: block;
  background: rgba(150, 150, 150, 0.2);
}
.navi_area .main_menu li:nth-child(-n + 3) a:hover{
  background: rgba(150, 150, 150, 0.4);
}
.navi_area .main_menu li:nth-child(n + 4){
  margin-top: 1px;
}
.navi_area .main_menu li:nth-child(n + 4) a{
  display: block;
  background: rgba(0, 155, 126, 0.2);
}
.navi_area .main_menu li:nth-child(n + 4) a:hover{
  background: rgba(0, 155, 126, 0.4);
}
.navi_area .sub_menu {
  width: calc(25% - 0.5px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
@media screen and (max-width: 960px) {
  .navi_area .sub_menu{
    width: 100%;
    margin-top: 1px;
  }
}
.navi_area .sub_menu li{
  text-align: center;
  line-height: 2.3;
}
.navi_area .sub_menu li a{
  display: block;
  background: rgba(0, 88, 143, 0.2);
}
.navi_area .sub_menu li a:hover{
  background: rgba(0, 88, 143, 0.4);
}
.navi_area .sub_menu li:nth-child(-n + 2) {
  width: calc(50% - 0.5px);
}
@media screen and (max-width: 960px) {
  .navi_area .sub_menu li:nth-child(-n + 2) {
    width: calc(33.33333333% - 0.66666666px);
  }
}
.navi_area .sub_menu li:nth-child(3){
  margin-top: 1px;
  width: 100%;
}
@media screen and (max-width: 960px) {
  .navi_area .sub_menu li:nth-child(3){
    width: calc(33.33333333% - 0.66666666px);
    margin-top: 0;
  }
}

.footer_bg{
  width: 100%;
}
.footer_bg .footer_area{
  width: 100%;
  background: #1d2087;
  color: #fff;
}
.footer_bg .footer_area footer{
  width: 93.75%;
  max-width: 990px;
  margin: auto;
  padding: 1em 0;
}
.footer_bg .footer_area footer > ul {
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
@media screen and (max-width: 600px) {
  .footer_bg .footer_area footer > ul{
    display: block;
  }
}
.footer_bg .footer_area footer > ul .fmenu{
  width: 55%;
}
@media screen and (max-width: 600px) {
  .footer_bg .footer_area footer > ul .fmenu{
    display: none;
  }
}
.footer_bg .footer_area footer > ul .fmenu ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.footer_bg .footer_area footer > ul .fmenu ul li{
  position: relative;
  font-size: 0.75em;
  line-height: 1.75;
  padding: 0 1em;
}
.footer_bg .footer_area footer > ul .fmenu ul li a{
  color: #fff;
}
.footer_bg .footer_area footer > ul .fmenu ul li::before{
  position: absolute;
  left: 0;
  top: 0;
  content: "|";
}
.footer_bg .footer_area footer > ul .profile{
  text-align: right;
}
@media screen and (max-width: 600px) {
  .footer_bg .footer_area footer > ul .profile{
    text-align: center;
  }
}
.footer_bg .footer_area footer > ul .profile .profile_text{
  display: inline-block;
  text-align: left;
}
.footer_bg .footer_area footer > ul .profile .profile_text .classification{
  font-size: 0.625em;
  line-height: 1.5;
}
.footer_bg .footer_area footer > ul .profile .profile_text .company_name{
  line-height: 1.2;
}
.footer_bg .footer_area footer > ul .profile .profile_text .company_name span{
  font-size: 0.75em;
  vertical-align: 2px;
}
.footer_bg .footer_area footer > ul .profile .profile_text .address{
  font-size: 0.625em;
  line-height: 1.5;
  margin-top: 0.5em;
}
.footer_bg address{
  text-align: center;
  font-size: 0.75em;
  line-height: 1.5;
  margin-top: 1em;
  padding-bottom: 1em;
}

.contents{
  padding: 1em 0;
}
.contents .inner{
  width: 97%;
  max-width: 1024px;
  margin: auto;
}
@media screen and (max-width: 414px) {
  .contents .inner{
    width: 93.75%;
  }
}

.page_title{
  font-size: 1.25em;
  border: solid 1px #ddd;
  -moz-border-radius: 5px;
  /* FF */
  -webkit-border-radius: 5px;
  /* Webkit */
  border-radius: 5px;
  background: #eee;
  background: -webkit-gradient(linear, left top, left bottom, from(#fff), to(#eee));
  background: -moz-linear-gradient(top, #fff, #eee);
  padding: 12px 10px;
  -pie-background: linear-gradient(top, #fff, #eee);
  font-family: 'Noto Sans JP', sans-serif;
  text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.5);
}
@media screen and (max-width: 414px) {
  .page_title{
    font-size: 1.125em;
  }
}
.page_title div{
  border-left: 5px #3cf solid;
  padding-left: 10px;
}
.page_title span{
  font-size: 0.75em;
  vertical-align: 3px;
}
.page_title p{
  text-indent: -0.5em;
}

.inner_box{
  box-sizing: border-box;
  padding: 1.5em;
  border: 1px solid #ddd;
  margin-top: 1.25em;
}
@media screen and (max-width: 414px) {
  .inner_box{
    padding: 1em;
  }
}

.inner_box2{
  box-sizing: border-box;
  padding: 1.5em;
  border: 1px solid #ddd;
  margin-top: 2.5em;
}
@media screen and (max-width: 414px) {
  .inner_box2{
    padding: 1em;
  }
}

.column_mt{
  margin-top: 2em;
}

.column_mt1{
  margin-top: 1em;
}

.position_re{
  position: relative;
}

.go_mails{
  position: absolute;
  right: 0;
  top: -24px;
  font-size: 0.75em;
  background: #09f;
  width: 9em;
  text-align: center;
  border-radius: 3px 3px 0 0;
}
.go_mails:hover{
  background: #6cf;
}
.go_mails a{
  font-weight: 700;
  color: #fff;
  display: block;
  line-height: 2;
}
.go_mails a:hover{
  text-decoration: none;
}

.contact{
  text-align: center;
  font-size: 0.875em;
  margin: 1em 0 0;
}
.contact span{
  font-weight: 700;
}
.contact p{
  display: inline-block;
  text-align: left;
  line-height: 1.5;
}
