@charset "UTF-8";

a {
  color: #1133A2;
}

/* 基本的にすべて仮プロパティ */
body {
  margin: 0;
  width: 100%;
  animation: fadeIn 3s ease 0s 1 normal;
  -webkit-animation: fadeIn 3s ease 0s 1 normal;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Noto Sans", "Noto Sans CJK JP","メイリオ","Meiryo","ＭＳ Ｐゴシック", "MS P Gothic","Osaka", Verdana, Arial, Helvetica, sans-serif;
}

.pc { display: block !important; }
.sp { display: none !important; }

@keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}

@-webkit-keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}

@font-face {
  font-family:"Ostrich Sans Black";
  src:url("../assets/fonts/ostrich-black.eot?") format("eot"),
      url("../assets/fonts/ostrich-black.woff") format("woff"),
      url("../assets/fonts/ostrich-black.ttf") format("truetype"),
      url("../assets/fonts/ostrich-black.svg#OstrichSans-Black") format("svg");
      font-weight:normal;
      font-style:normal;
}

.index-header {
  background-color: transparent;
}

.index-header .header-nav-item > a:before {
  background: #1133A2;
}

h1 {
  font-family: "Ostrich Sans Black";
  font-size: 59px;
  font-weight: lighter;
  letter-spacing: 0.1em;
  margin-top: 0;
  margin-bottom: 36px;
  line-height: 1.15;
}

.onetap {
  padding: 0.22em 0.11em 0.01em 0.22em;
  background: #1133A2;
}

h2 {
  text-align: center;
  letter-spacing: 0.05em;
}

.btn {
  display: inline-block;
  padding: 16.5px 0;
  width: 250px;
  text-decoration: none;
  font-size: 15px;
  line-height: 15px;
  border-radius: 25px;
  transition: .4s;
  font-weight: 600;
}

.top {
  background-image: url("../assets/images/pc/index_mv_pc_bg.jpg");
  background-size: cover;
  max-height: 751px;
}

.vision-box {
  width: 727px;
  color: #ffffff;
  padding: 120px 0 240px 0;
  margin: 0 auto;
}

.vision-box > p {
  font-size: 21px;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Noto Sans", "Noto Sans CJK JP","メイリオ","Meiryo","ＭＳ Ｐゴシック", "MS P Gothic","Osaka", Verdana, Arial, Helvetica, sans-serif;
  font-weight: 300;
  text-shadow: 0 3px 6px #999999;
  line-height: 1.8;
  letter-spacing: 0.24em;
  margin: 0;
}

.service-box {
  margin-bottom: -0.67%;
}

.service-flex {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

.service-flex div {
  width: 400px;
}

.service-introduction {
  order: 1;
  margin-top: 20.4px;
  margin-bottom: 10.4px;
}

.service-introduction > h2 {
  text-align: center;
  font-weight: lighter;
  font-size: 17.6px;
  margin-bottom: 0;
  line-height: 1.6;
}

.service-emphasis {
    padding: 0.0em 0;
    background-repeat: repeat-x;
    background-size: 1em 0.2em;
    background-position: top left;
    background-image: -webkit-gradient(radial,center center,0,center center,1.5,from(#000000),color-stop(0.5,#000000),color-stop(0.9,transparent),to(transparent));
    background-image: -webkit-radial-gradient(center center, 0.1em 0.1em, #000000, #000000 95%, transparent 95%, transparent);
    background-image: radial-gradient(0.1em 0.1em at center center, #000000, #000000 95%, transparent);
}

.sticky-img {
  position: fixed;
  bottom: 10px;
  left: 20px;
  box-shadow: 0 3px 6px rgba(0,0,0,.16), 0 3px 6px rgba(0,0,0,.23);
  height: 170px;
  z-index: 1;
}


.service-logo {
  text-align: center;
  margin-top: 5px;
  margin-bottom: 0px;
}

.service-logo > img {
  width: 300px;
}

.service-btn {
  text-align: center;
  margin-top: 0px;
  width: 100%;
}
.detail-btn{
  display: inline-block;
  padding: 12.5px 0;
  width: 220px;
  text-decoration: none;
  color: #ffffff;
  font-size: 15px;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Noto Sans", "Noto Sans CJK JP","メイリオ","Meiryo","ＭＳ Ｐゴシック", "MS P Gothic","Osaka", Verdana, Arial, Helvetica, sans-serif;
  line-height: 15px;
  background-color: #1133A2;
  border: solid 1px #1133A2;
  border-radius: 25px;
  transition: .4s;
}

.detail-btn:hover {
  background-color: #ffffff;
  color: #1133A2;
}

.service-image {
  order: 2;
  vertical-align: bottom;
  margin-top: 26px;
  z-index: -1;
}

.service-image > img {
  height: 200px;
  margin-bottom: 22px;
  margin-top: 30px;
}

.recruit-bg {
  margin: 0 auto;
  text-align: center;
  background: url("../assets/images/pc/img_pc_recruit@2x.png");
  -webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover;
  -o-background-size: cover;
}

.recruit-box {
  background-color: rgba(31, 61, 148, 0.4);
  padding-top: 55px;
  color: #FFFFFF;
  margin-top: 10px;
}

#recruit {
  margin-top: 0;
  font-size: 36px;
  margin-bottom: 65px;
  line-height: 43px;
  font-family: 'Helvetica Neue';
}

.recruit-box > p {
  font-size: 16px;
  line-height: 17px;
  margin-bottom: 60px;
}

.recruit-btn {
  color: #1133A2;
  background-color: #FFFFFF;
  border: solid 1px #FFFFFF;
  margin-bottom: 65px;
}

.recruit-btn:hover {
  color: #ffffff;
  background: rgba(255, 255, 255, 0.3);
}

.value-box {
  margin: 0 auto;
  text-align: center;
}

#value {
  color: #1133A2;
  font-size: 36px;
  line-height: 43px;
  margin-top: 55px;
  margin-bottom: 50px;
  font-family: 'Helvetica Neue';
}

.value-flex {
  display: flex;
  justify-content: space-evenly;
  margin: 0 16.80% 0 16.88%;
}

.value-img {
  width: 100px;
  height: 100px;
}
.value-inner-box {
  text-align: center;
  width: 26.49%;
}

.value-subject {
  color: #5A5F62;
  font-size: 25px;
  line-height: 25px;
  margin-bottom: 28px;
}

.value-description {
  color: #5A5F62;
  font-size: 13px;
}

.value-recruit-btn {
  margin: 60px 0 65px;
  color: #FFFFFF;
  background-color: #1133A2;
  border: solid 1px #1133A2;
}

.value-recruit-btn:hover {
  background-color: #ffffff;
  color: #1133A2;
}

.contact-box {
  margin: 0 auto;
  text-align: center;
  background-color: #F2F8FF;
  padding-top: 55px;
}

#contact {
  color: #1133A2;
  font-size: 36px;
  margin-top: 0;
  line-height: 43px;
  margin-bottom: 50px;
  font-family: 'Helvetica Neue';
}

.contact-box > p {
  color: #5A5F62;
  line-height: 18px;
  margin-top: 0;
  margin-bottom: 60px;
}

.contact-btn {
  color: #ffffff;
  background-color: #1133A2;
  border: solid 1px #1133A2;
  margin-bottom: 63px;
}

.contact-btn:hover {
  background-color: #ffffff;
  color: #1133A2;
}

#about {
  color: #1133A2;
  font-size: 36px;
  margin: 55px 0 50px;
  line-height: 43px;
  font-family: 'Helvetica Neue';
}

.about-corp {
  margin: 0 auto;
  margin-bottom: 120px;
  border: 1px #CECECE solid;
  border-collapse: collapse;
  width: 694px;
}

tr {
  border-bottom: solid 1px #CECECE;
}

.table-subject {
  width: 23.41%;
  padding: 19px 0 18px 4.34%;
  color: #1133A2;
}

.table-content {
  padding-left: 6.50%;
  color: #5A5F62;
}

.hansya-box {
  padding-top: 85px;
  margin: 0 23.78% 110px;
  max-width: 635px;
  margin: 0 auto;
}

.news-item-title {
  margin-top: 0.5em;
  margin-bottom: 2em;
}

.news-item-date {
  font-size: 15px;
}

.hansya-box > p {
  margin-bottom: 40px;
}

.hansya-box > ol {
  padding-left: 2.28%;
  line-height: 1.9;
}

/* スマホ用 */
@media screen and ( max-width: 651px ) {
  .pc { display: none !important; }
  .sp { display: block !important; }

  .btn {
    border-radius: 25px;
  }

  .hansya-box {
    margin: 0 4% 90px 8%;
    line-height: 1.75;
  }

  .top {
    background-image: url("../assets/images/mobile/index_mv_mobile_bg.webp");
    height: auto;
  }
  .vision-box {
    padding: 74px 0 0 0;
    width: 100%;
  }

  .vision-box > h1 {
    margin-right: 8%;
    margin-left: 4%;
    font-size: 60px;
    text-align: left;
    line-height: 1.14;
  }

  .vision-box > p {
    margin-right: 3.47%;
    margin-left: 4%;
    padding-bottom: 146px;
    font-size: 23px;
    letter-spacing: 0;
    line-height: 1.62;
  }

  .service-box {
    margin: 0 4%;
  }
  .service-flex div {
    width: 100%;
  }

  .service-introduction {
    margin-top: 45px;
  }

  .service-introduction > h2 {
    margin: 0;
    line-height: 1.8;
  }


  .sticky-img {
    display: none;
  }

  .service-logo {
    margin-bottom: 0;
  }

  .service-logo > img {
    width: 100%;
  }

  .service-image {
    height: auto;
    margin-top: 0;
    text-align: center;
    z-index: 0;
  }

  .service-image > img {
    width: 86.67vw;
    height: 55.87vw;
    margin-top: auto;
  }

  .service-btn {
    margin-top: 30px;
    margin-bottom: 56px;
  }

  .detail-btn {
    padding: 17px 0 18px;
    width: 99.42%;
    letter-spacing: 0;
    border-radius: 25px;
  }

  .recruit-box {
    height: 307px;
  }

  .recruit-bg {
    background: url("../assets/images/mobile/img_mb_recruit.webp");
    background-size: cover;
    height: 362px;
  }

  .recruit-box > p {
    margin: 50px 8.27% 60px 8.53%;
    font-size: 14px;
    line-height: 1.45;
  }

  .recruit-btn {
    margin: 0 4% 65px;
    padding: 17px 0 18px;
    width: 91.45%;
  }

  .value-flex {
    flex-wrap: wrap;
    margin-right: 8.27vw;
    margin-left: 8.53vw;
  }

  .value-flex .value-inner-box {
    width: 100%;
    margin-bottom: 60px;
  }

  .value-img {
    width: 80px;
    height: 80px;
  }

  .value-subject {
    font-size: 22px;
  }

  .value-description {
    font-size: 14px;
    line-height: 1.55;
  }

  .value-recruit-btn {
    padding: 17px 0 18px;
    width: 91.45%;
    margin: 10px 4% 65px;
  }

  .recruit-box {
    width: 100%;
  }

  .contact-box {
    width: 100%;
  }

  .contact-box > p {
    margin-right: 8.27vw;
    margin-left: 8.53vw;
    font-size: 14px;
    line-height: 1.75;
  }

  .contact-btn {
    padding: 17px 0 18px;
    width: 91.45%;
    margin: 0 4% 65px;

  }

  .about-box {
    width: 100%;
  }

  .about-corp {
    width: 92%;
    margin: 0 4%;
    font-size: 14px;
    margin-bottom: 90px;
  }

  .table-subject {
    width: 25%;
    padding: 10px 0 9px 4.34%;
  }

  .table-content {
    padding-left: 10%;
    line-height: 2.3;
  }

  .service-emphasis {
      padding: 0.2em 0;
      background-repeat: repeat-x;
      background-size: 1em 0.2em;
      background-position: top left;
      background-image: -webkit-gradient(radial,center center,0,center center,1.5,from(#000000),color-stop(0.5,#000000),color-stop(0.9,transparent),to(transparent));
      background-image: -webkit-radial-gradient(center center, 0.1em 0.1em, #000000, #000000 95%, transparent 95%, transparent);
      background-image: radial-gradient(0.1em 0.1em at center center, #000000, #000000 95%, transparent);
  }

}

/* タブレット用 */
@media only screen and (max-width: 1024px) and (min-width: 652px) {
  .top {
    height: 600px;
  }
  .vision-box {
    width: 652px;
  }
  .vision-box > h1 {
    font-size: 57px;
  }

  .vision-box > p {
    font-size: 19px;
  }

  .service-box {
    margin-right: 3%;
    margin-left: 3%;
    margin-bottom: -0.87%;
  }

  .service-flex div {
    width: 300px;
  }

  .service-introduction > h2 {
    font-size: 16px;
  }

  .service-logo > img {
    width: 260px;
  }

  .service-image > img {
    width: 260px;
    height: 180px;
    margin-top: 30px;
  }

  .service-btn {
    margin-top: 25px;
  }

  .value-flex {
    margin-left: 3%;
    margin-right: 3%;
    margin: 0 auto;
  }

  .value-inner-box {
    width: 205px;
  }

  .about-corp {
    width: 92%
  }
}
