.contact_area .contact_area_title {
  margin-bottom: 75px;
}

.contact_area .contact_area_inner {
  width: 100%;
  padding: 100px 0;
  background-image: url(../img/contact/contact_sec_bg.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  position: relative;
}

.contact_area .contact_area_inner:before {
  content: '';
  display: block;
  width: 1px;
  height: 42px;
  background-color: #333333;
  position: absolute;
  left: 0;
  right: 0;
  top: -42px;
  margin: auto;
}

.contact_area .contact_area_inner:after {
  content: '';
  display: block;
  width: 1px;
  height: 42px;
  background-color: #fff;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  margin: auto;
}

.contact_area .contact_area_inner_text {
  text-align: center;
  margin-bottom: 70px;
}

.contact_area .contact_area_inner_text p {
  font-size: 20px;
  font-weight: 600;
  color: #fff;
  letter-spacing: 0.06em;
}

.contact_area .contact_area_banner {
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.contact_area .contact_area_banner_item {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 48%;
          flex: 0 0 48%;
  background-color: #fff;
  position: relative;
}

.contact_area .contact_area_banner_item:first-child img {
  width: 100%;
  max-width: 66px;
  margin: 0 auto;
}

.contact_area .contact_area_banner_item:last-child img {
  width: 100%;
  max-width: 68px;
  margin: 0 auto;
}

.contact_area .contact_area_banner_item:after {
  content: '';
  display: block;
  background-image: url(../img/other/banner_arrow01.png);
  background-repeat: no-repeat;
  background-size: contain;
  width: 12px;
  height: 12px;
  position: absolute;
  right: 10px;
  bottom: 10px;
}

.contact_area .contact_area_banner_item p {
  font-size: 20px;
  font-weight: 600;
  text-align: center;
}

.contact_area .contact_area_banner_item a {
  display: block;
  padding-bottom: 55px;
}

.contact_area .contact_area_banner_item_img {
  height: 130px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media (min-width: 1px) and (max-width: 1200px) {
  .contact_area .contact_area_banner {
    width: 95%;
  }
}

@media (min-width: 1px) and (max-width: 767px) {
  .contact_area .contact_area_inner {
    background-image: url(../img/contact/contact_sec_bg_sp.jpg);
    padding: 65px 0 90px 0;
  }
  .contact_area .contact_area_inner_text {
    margin-bottom: 40px;
  }
  .contact_area .contact_area_inner_text p {
    font-size: 18px;
    line-height: 1.7;
  }
  .contact_area .contact_area_banner {
    width: 92%;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-flow: column;
            flex-flow: column;
  }
  .contact_area .contact_area_banner_item {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 100%;
            flex: 0 0 100%;
    width: 100%;
  }
  .contact_area .contact_area_banner_item a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding-bottom: 0;
    height: 120px;
  }
  .contact_area .contact_area_banner_item p {
    font-size: 18px;
  }
  .contact_area .contact_area_banner_item .contact_area_banner_item_img {
    height: auto;
    margin-right: 10px;
  }
  .contact_area .contact_area_banner_item:first-child {
    margin-bottom: 20px;
  }
  .contact_area .contact_area_banner_item:first-child img {
    max-width: 46px;
    position: relative;
    bottom: 8px;
  }
  .contact_area .contact_area_banner_item:last-child img {
    max-width: 48px;
  }
}

.access_area {
  width: 100%;
  height: 680px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.access_area .access_map {
  width: 50%;
  height: 100%;
}

.access_area .access_map iframe {
  width: 100%;
  height: 100%;
}

.access_area .address {
  padding-left: 10%;
}

.access_area .address_company_logo {
  margin-bottom: 50px;
}

.access_area .address_company_logo p {
  font-size: 56px;
  font-family: 'font-grotesk-bold';
  font-weight: 600;
  line-height: 1.1;
}

.access_area .address_company_logo span {
  color: #4adae7;
}

.access_area .address_company_text p {
  font-size: 15px;
}

@media (min-width: 1px) and (max-width: 767px) {
  .access_area {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-flow: column;
            flex-flow: column;
    height: auto;
  }
  .access_area .access_map {
    width: 100%;
    height: 265px;
  }
  .access_area .address {
    width: 88%;
    padding: 65px 0 55px 0;
  }
  .access_area .address_company_logo {
    margin-bottom: 25px;
  }
}

.side_banner {
  position: fixed;
  top: 25%;
  right: 0;
}

.side_banner .side_banner_item {
  width: 80px;
  height: 150px;
  background-color: #4adae7;
  padding: 20px 0;
  position: relative;
}

.side_banner .side_banner_item:after {
  content: '';
  display: block;
  border-top: 25px solid #369bad;
  border-right: 50px solid #369bad;
  border-bottom: 25px solid transparent;
  border-left: 50px solid transparent;
  position: absolute;
  bottom: -50px;
}

.side_banner .side_banner_item p {
  font-size: 14px;
  font-weight: 600;
  color: #fff;
  -ms-writing-mode: tb-rl;
  -webkit-writing-mode: vertical-rl;
          writing-mode: vertical-rl;
  line-height: 1.2;
  margin: 0 auto;
}

.side_banner .form_banner {
  margin-bottom: 30px;
}

.side_banner .form_banner img {
  width: 100%;
  max-width: 30px;
  margin: 0 auto 10px auto;
  position: relative;
  left: 3px;
}

.side_banner .online_banner img {
  width: 100%;
  max-width: 32px;
  margin: 0 auto 10px auto;
}

@media (min-width: 1px) and (max-width: 767px) {
  .side_banner {
    display: none;
  }
}

.section_title {
  text-align: center;
}

.section_title--left {
  text-align: left;
}

.section_title .section_title_text--first-letter-lightblue:first-letter {
  color: #4ad5e2;
}

.section_title .eng {
  font-size: 56px;
  font-weight: 600;
  font-family: 'font-grotesk-bold';
  line-height: 1;
  margin-bottom: 10px;
}

.section_title .ja {
  font-size: 20px;
  font-weight: 600;
}

@media (min-width: 1px) and (max-width: 767px) {
  .section_title .eng {
    font-size: 40px;
    margin-bottom: 5px;
  }
  .section_title .ja {
    font-size: 15px;
  }
}

.page_first_view .page_first_view_inner {
  width: 100%;
  max-width: 740px;
  height: 340px;
  margin: 0 auto;
  background-color: #4ad5e2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
}

.page_first_view .page_first_view_inner:before {
  content: '';
  display: block;
  width: 1px;
  height: 42px;
  background-color: #333333;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}

.page_first_view .page_first_view_inner:after {
  content: '';
  display: block;
  width: 1px;
  height: 42px;
  background-color: #4ad5e2;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -42px;
  margin: auto;
}

.page_first_view .page_first_view_title {
  text-align: center;
}

.page_first_view .page_first_view_title .eng {
  font-size: 75px;
  font-weight: 600;
  font-family: 'font-grotesk-bold';
  color: #fff;
  line-height: 1.2;
}

.page_first_view .page_first_view_title .ja {
  font-size: 20px;
  font-weight: 600;
  color: #fff;
}

@media (min-width: 1px) and (max-width: 767px) {
  .page_first_view .page_first_view_inner {
    width: 92%;
    height: 200px;
  }
  .page_first_view .page_first_view_title .eng {
    font-size: 40px;
  }
  .page_first_view .page_first_view_title .ja {
    font-size: 13px;
  }
}
/*# sourceMappingURL=common_section.css.map */