@charset "UTF-8";

/**************************************************/
/********************** 768px *********************/
/**************************************************/

@media screen and (max-width: 768px) {
  html, body {
    width: 100%;
  }

  header {
    padding: 0px;
  }

  .headSp {
    overflow: hidden;
    height: 52px;
    padding: 15px 30px;
  }

  .gnav {
    float: none;
    margin-top: 0px;
  }

  .gnav ul {
    list-style: none;
    display: block;
    float: none;
    width: 100%;
  }

  .gnav ul li {
    position: relative;
    display: block;
    height: auto;
    width: 100%;
    font-family: montserrat;
    padding: 20px 0px;
    font-size: 100%;
    border-bottom: 1px solid #efefef;
    font-weight: 600;
    text-align: center;
    letter-spacing: 1px;
    color: #383838;
  }

  .gnav ul li:hover {
    opacity: 1;
  }

  #header .nav_btn {
    width: 44px;
    height: 44px;
    z-index: 300;
    top: 17px;
    right: 20px;
    cursor: pointer;
    position: absolute;
  }

  .hamburger_line {
    transition: all .6s;
    width: 34px;
    height: 3px;
    left: 5px;
    background-color: #fff;
    position: absolute;
  }

  .hamburger_line1 {
    top: 29px;
  }

  .hamburger_line2 {
    top: 18px;
  }

  .tell_black {
    position: relative;
    top: 9px;
    float: right;
    right: 90px;
    padding-right: 30px;
  }

  .tell_black img {
    height: 35px;
  }

  .tell_black:after {
    content: '';
    display: inline-block;
    background: #0d1d62;
    height: 24px;
    width: 1px;
    top: 6px;
    right: -1px;
    position: absolute;
  }

  .nav_bg {
    opacity: 0;
    width: 100vw;
    height: 100vh;
    background: #fff;
    z-index: 100;
    top: 0;
    left: 0;
    visibility: hidden;
    cursor: pointer;
    position: fixed;
  }

  #header #navi {
    overflow-y: auto;
    opacity: 0;
    visibility: hidden;
    width: 100%;
    height: auto;
    z-index: -1;
    background-color: #ffffff;
    position: absolute;
    -webkit-transition: all 0.6s;
    -moz-transition: all 0.6s;
    -ms-transition: all 0.6s;
    transition: all 0.6s;
  }

  .gnav {
    -webkit-transition: all 0.6s;
    -moz-transition: all 0.6s;
    -ms-transition: all 0.6s;
  }

  .gnav ul a {
    display: block;
    color: #383838 !important;
    text-decoration: none;
  }

  .navContactBox {
    font-size: 135%;
    text-decoration: none;
    display: inline-block;
    letter-spacing: 2px;
    font-weight: 600;
    line-height: 1;
    pointer-events: all;
    width: calc(100% - 40px);
    margin: 0 auto;
    color: #009ca7 !important;
    background-color: #fff;
    padding: 15px 0px;
  }

  .navContactBox div {
    display: inline-block;
  }

  .NavListContact:hover div {
    display: inline-block;
    color: #fff;
    background-color: #009ca7;
  }

  #navi svg.mail {
    fill: #009ca7;
    width: 36px;
    float: none;
    height: auto;
    top: 5px;
    position: relative;
  }

  .NavListContact:hover svg.mail {
    fill: #fff !important;
    width: 36px;
    float: none;
    height: auto;
    top: 5px;
    position: relative;
  }

  .nav_open #header #navi {
    display: block;
    opacity: 1;
    visibility: visible;
    z-index: 200;
  }

  .nav_open .nav_bg {
    opacity: 1;
    visibility: visible;
  }

  .nav_open .hamburger_line1 {
    transform: rotate(45deg);
    top: 20px;
    background-color: #383838;
  }

  .nav_open .hamburger_line2 {
    transform: rotate(-45deg);
    top: 20px;
    background-color: #383838;
  }

  .fixed {
    position: fixed;
    width: 100%;
    height: 100%;
  }

  .pc {
    display: none;
  }

  .sp {
    display: block;
  }

  h2 {
    font-size: 320%;
    letter-spacing: 0px;
    margin-top: 10px;
  }

  h3 {
    bottom: 0px;
  }

  .br_pc {
    display: none;
  }

  .splashWrapper {
    max-width: 100%;
    margin: 0 0 0 auto;
    position: relative;
  }

  .splashWrapper .mv {
    height: 420px;
  }

  .splashWrapper p.mvTxt1 {
    font-size: 190%;
    bottom: 29%;
    left: 0px;
  }

  .splashWrapper p.mvTxt2 {
    font-size: 190%;
    left: 0px;
    bottom: 17%;
  }

  .aboutBg::before {
    content: none;
  }

  .serviceBg:before {
    position: relative;
    padding-top: 0px;
    width: 100%;
    margin: 30px auto 0px;
  }

  .companyBg {
    background-image: none;
    width: auto;
    margin-top: 0px;
    height: auto;
    background-color: #ffffff;
    overflow: hidden;
  }

  .companyBg:before {
    content: none;
  }

  .recruitBg {
    background-image: none;
    height: auto;
    background-color: #f9f9f9;
    margin-top: 0px;
    overflow: hidden;
  }

  .recruitBg:before {
    content: none;
  }

  header {
    width: auto;
  }

  .aboutBox {
    width: auto;
    overflow: hidden;
    margin: 0px 20px 0px;
    display: block;
  }

  .serviceBg .servicesBox {
    width: auto;
    padding: 60px 20px;
    margin: 0px auto;
  }

  .splashWrapper h1 img {
    height: 32px;
    margin: 5px 0px 0px 0px;
  }

  .swiper-pagination-fraction, .swiper-pagination-custom, .swiper-container-horizontal > .swiper-pagination-bullets {
    bottom: 3px !important;
  }

  .splash img {
    width: 130%;
  }

  .newsBox {
    width: 90%;
    margin: 0 0 0 auto;
  }

  .news {
    max-width: 510px;
  }

  .news .head:before {
    bottom: -7px;
  }

  .about {
    background-color: #fff;
    margin-bottom: 30px;
  }

  .aboutImg {
    display: none;
  }

  .aboutBox img {
    margin-top: 30px;
  }

  .aboutTxt {
    width: auto;
    float: none;
    text-align: left;
    background-color: #fff;
    margin-left: 0px;
    padding: 17% 0px 0px;
  }

  .aboutTxt p {
    font-size: 100%;
    margin-top: 15px;
  }

  .serviceBg {
    position: relative;
    padding-top: 0px;
    width: 100%;
    margin: 25px auto 0px;
    background-color: #fbfbfb;
  }

  .serviceBg .servicesBox {
    padding: 60px 20px 0px;
  }

  .serviceBg .services {
    display: block;
    margin: 0 auto;
    width: 100%;
    flex-wrap: unset;
  }

  .serviceBg .servicesHeading h3 {
    margin-right: 0px;
  }

  .serviceBg .illust {
    margin: 30px auto;
  }

  .services {
    flex-wrap: wrap;
  }

  .servicesList {
    width: 100%;
    overflow: hidden;
    height: auto;
    margin: 25px auto;
    vertical-align: middle;
    padding: 30px;
    box-sizing: border-box;
    max-width: 460px;
  }

  .servicesList:last-child {
    margin-bottom: 0px;
  }

  .servicesList:first-child {
    margin-top: 0px;
  }

  .companyBox {
    width: calc(100% - 40px);
    margin: 40px auto;
  }

  .companyHeading {
    margin-top: 0px;
    text-align: left;
    margin-bottom: 15px;
  }

  .companyHeading h3:after {
    left: 0px;
    right: auto;
  }

  .companyPic_sp img {
    border: 0;
    width: 100%;
  }

  .companyDescription {
    width: auto;
    box-shadow: none;
    padding-bottom: 30px;
    float: none;
  }

  .companyLeft {
    width: 92%;
    padding: 25px 0px 10px 0px;
    font-size: 100%;
    letter-spacing: 0px;
  }

  .btnWrapper {
    display: table;
    width: auto;
    padding: 15px 8%;
  }

  .recruitBox {
    width: calc(100% - 40px);
    margin: 60px auto;
    padding: 0px 0px 20px;
  }

  .recruitBox .blueBox2 {
    display: none;
  }

  .recruitHeading {
    margin-bottom: 15px;
  }

  .recruitBoxTxt p {
    line-height: 27px;
    font-size: 100%;
  }

  .recruitImgs {
    position: relative;
    margin: 0 0 0 auto;
    display: block;
    max-width: 400px;
    width: 70%;
  }

  .recruitImgsLeft, .recruitImgsRight {
    width: 100%;
    top: 0px;
    right: 0px;
    margin-top: 18px;
  }

  .recruitImgsLeft img, .recruitImgsLeft img {
    width: 100%;
    position: relative;
  }

  .recruitImgsRight img.recruitImg03 {
    width: 100%;
    float: none;
    margin-top: 10px;
  }

  .contactBg {
    top: 0px;
  }

  .contact {
    height: auto;
    padding: 30px 0px;
    text-align: center;
    background-position: center;
    background-size: cover;
    margin: 0px auto;
    width: 100%;
    border-radius: 0px;
    display: block;
    top: 0px;
  }

  .contactLeft, .contactRight {
    width: 100%;
    text-align: center;
  }

  .contact p {
    padding-top: 30px;
    line-height: 1;
  }

  .contact h2 {
    margin-top: 15px;
    margin-bottom: 30px;
    line-height: 1;
  }

  .contact .tel {
    display: block;
    width: calc(100% - 20%);
    margin: 30px auto 0px;
    padding: 10px 0px;
    max-width: 390px;
    font-weight: 600;
  }

  .contact .tel:hover {
    background: #908126;
    transition: all 0.3s;
  }

  .contact div.telnumber {
    text-align: center;
    font-size: 130%;
    display: block;
  }

  .contact .telsvg {
    width: 18px;
    top: 1px;
    left: -7px;
    position: relative;
  }

  .contact a.tellBox {
    width: auto;
  }

  .contact span {
    margin-bottom: 10px;
    top: -11px;
  }

  .btn-hover {
    display: block;
    max-width: 390px;
    width: 100%;
  }

  .contect .btnBox span {
    left: -33px;
  }

  .contect a.tellBox {
    pointer-events: auto;
    padding-bottom: 0px;
  }

  span.privacybr {
    display: block;
  }

  .copyright {
    margin: 0px;
    padding: 20px 0px;
  }

  .copyrightWrapper {
    margin-bottom: 0px;
  }
}

/**************************************************/
/********************** 520px *********************/
/**************************************************/

@media screen and (max-width: 520px) {
  .br {
    display: block;
    margin-left: 14px;
    margin-top: -5px;
  }

  .splashWrapper .mv {
    height: 390px;
  }

  .news {
    display: block;
    align-items: baseline;
    min-height: 70px;
  }

  .news .head {
    border-bottom: 1px solid #efefef;
    width: 100%;
  }

  .news .head span {
    display: initial;
    margin-left: 10px;
  }

  .ticker {
    width: 100%;
  }

  .news ul {
    margin-top: 10px;
  }

  .news ul li b {
    float: none;
    width: 100%;
    display: block;
  }

  .news ul li span {
    float: none;
    display: block;
  }

  .serviceBg {
    margin: 0px auto 0px;
  }

  .servicesList {
    width: calc(80% - 40px);
    padding: 20px;
    min-width: 300px;
  }

  .recruitBoxTxt {
    padding: 20px;
  }

  .recruitTxt {
    padding: 10px 0px 30px;
  }

  .recruitRight h5 {
    font-size: 105%;
    top: 16px;
    margin: 0px 0px 0px 20px;
  }

  .companyLeft {
    font-size: 90%;
    width: 100%;
    min-width: 340px;
  }

  .company-btn {
    width: 100%;
  }

  .btn-hover {
    width: 80%;
  }

  .btn-hover div {
    font-size: 90%;
  }

  .btn-hover svg.mail {
    top: 0px;
  }
}

/**************************************************/
/********************** 375px *********************/
/**************************************************/
@media screen and (max-width: 375px) {
  h2 {
    font-size: 280%;
    letter-spacing: 1px;
  }

  .recruit {
    padding-bottom: 5px;
  }

  .btn-hover {
    width: calc(100% - 10%);
  }

  .content .tel {
    width: calc(100% - 10%);
  }

  .servicesList h4 {
    font-size: 87%;
  }

  .companyName {
    letter-spacing: 0px;
  }

  .companyLeft {
    font-size: 90%;
    width: 100%;
    min-width: 100%;
  }

  .navContactBox {
    font-size: 125%;
  }

  .aboutBox {
    margin: 25px 10px 0px;
  }

  .news {
    margin: 30px 10px;
  }
}

/*********************************************************/
/********************** 769px - 900px*********************/
/*********************************************************/
@media screen and (min-width: 769px) and (max-width: 900px) {
  .gnav ul li {
    padding-right: 15px;
  }

  .splashWrapper p.mvTxt1 {
    font-size: 390%;
    bottom: 197px;
  }

  .splashWrapper p.mvTxt2 {
    font-size: 390%;
    bottom: 120px;
  }

  .contact {
    display: block;
    margin-top: -60px;
  }

  .contactLeft, .contactRight {
    width: 100%;
    text-align: center;
  }

  .services {
    flex-wrap: wrap;
  }
}

/*********************************************************/
/********************** 1300px〜　　　*********************/
/*********************************************************/
@media screen and (min-width: 1300px) {
  .splashWrapper {
    max-width: 90%;
  }

  .headerWrapper {
    border-bottom: none;
  }

  .gnav ul li {
    font-size: 110%;
  }

  .splashWrapper p.mvTxt1 {
    font-size: 620%;
  }

  .splashWrapper p.mvTxt2 {
    font-size: 620%;
  }

  .left {
    margin-left: 0px;
  }

  .content {
    background-position: right 10% bottom 10%;
  }

  .aboutBox {
    width: 98%;
  }

  .aboutTxt {
    padding: 160px 90px 120px 130px;
  }
}

/*********************************************************/
/********************** iphone SE用   *********************/
/*********************************************************/

@media screen and (max-width: 320px) {
  #header .nav_btn {
    width: 44px;
    height: 44px;
    z-index: 300;
    top: 17px;
    right: 10px;
    cursor: pointer;
    position: absolute;
  }

  h1 img {
    margin: 5px 0px 0px 10px;
  }

  h2 {
    font-size: 240%;
    letter-spacing: 0px;
  }

  .servicesBox {
    padding: 30px 10px;
  }

  .companyBox {
    padding: 0px;
    width: auto;
    margin: 0px 10px;
  }

  .recruitBox {
    padding: 0px;
    width: auto;
    margin: 25px 10px 0px;
  }

  .btn-hover div {
    font-size: 88%;
    letter-spacing: 0px;
  }

  .servicesList h4 {
    letter-spacing: 0.2px;
    font-size: 82%;
  }

  .recruitRight h5 {
    font-size: 92%;
    letter-spacing: 1px;
  }

  .tell_black {
    position: relative;
    top: 9px;
    float: right;
    right: 70px;
    padding-right: 20px;
  }
}





