@charset "UTF-8";

@media (max-width: 768px) {
  .page_ttl {
    margin: 0 auto 25px;
    padding: 0;
    background: transparent;
  }
}
/*  header
---------------------------------------------------------- */
header.top {
  background: transparent;
  box-shadow: none;
}
header.top .header {
  justify-content: flex-end;
  margin: 0;
  max-width: none;
}
header.top .logo,
header.top nav ul li a:after {
  display: none;
}
header.top nav ul li a {  color: #fff;}
header.top nav ul li a:hover {color: #ccc;}

.main_img,
.main_img img {
  width: 100%;
}

main {
  padding: 50px 0 0;
}


@media (max-width: 768px) {
  header.top .header {
    justify-content: space-between;
    align-items: center;
  }

  header.top .logo {
    display: block;
    width: 157px;
    height: 33.5px;
    padding: 0;
    margin: 15px 10px;
    background: url(../img/top/sp_logo.png) no-repeat;
    background-size: cover;
  }
  header.top .logo img,
  header.top .sp_nav .tel {  display: none;}
  header.top .sp_nav .menu {background: transparent;}

  .main_img {
    position: relative;
    height: 100%;
  }
  .main_img img{
    width: 100vw;
    height: 100vh;
    object-fit: cover;
    object-position:50% 0;
  }
  .main_img:before {
    position: absolute;
    left: 50%;
    bottom: 5%;
    content: "";
    display: block;
    width:95vw;
    height: 50vw;
    margin-left: -47.5vw;
    background: url(../img/top/sp_txt_copy.png) no-repeat center;
    background-size:contain;
    z-index: 20;
  }

  main {padding: 30px 0 0;}
}


/*  service
---------------------------------------------------------- */
.service_block {
  display: flex;
  width: 1180px;
  margin: 20px auto 50px;
  justify-content: space-between;
  align-items: center;
}
.service_block .box {
  width: calc(100% - 700px);
}
.service_block h2 {
  text-align: left;
  font-size:3.0rem;
}

/*.service {
  margin: 50px auto;
  flex-wrap: wrap;
  justify-content: space-between;
}
.service li {
  position: relative;
  width: calc(33.33% - 20px);
  margin-bottom: 30px;
  transition: .5s;
}
.service h3 {
  display: flex;
  align-items: center;
  padding: 30px 0 30px 15px;
  background:#11244F url(../img/arw_btn_03.png) no-repeat right 20px center;
  background-size: 8px 12px ;
  color: #fff;
  font-size: 1.8rem;
  font-weight: bold;
}
.service h3 img {
  width: 24px;
  height: 24px;
  margin-right: 10px;
}

.service li a {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  font-size: 0;
}
.service li:hover {opacity: .8;}*/


@media (max-width: 768px) {

  .service_block,
  .service_block .box {
    width: 100%;
    display: block;
  }
  .service_block h2 {
    margin: 0 3% 25px;
  }

  .service {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: stretch;
    margin: 25px auto;
  }
  .service li {
    position: relative;
    width: calc(50% - 5px);
    margin-bottom: 10px;
    background:#11244F;
  }
  .service li h3 {
    display: flex;
    align-items: center;
    flex-direction: column;
    width: 100%;
    background:#11244F;
    padding: 20px 10px 10px;
    color: #fff;
    font-size: 1.6rem;
    font-weight: bold;
    box-sizing: border-box;
  }
  .service h3 img {
    margin: 0 0 20px;
    width: 32px;
    height: 32px;
  }.service li a {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    font-size: 0;
  }
}


/*  results
---------------------------------------------------------- */
.results {
  flex-wrap: wrap;
  justify-content: space-between;
  align-items:flex-start;
}
.results li {
  position: relative;
  width: calc(33.33% - 30px);
  margin-bottom: 30px;
  font-weight: bold;
}


.results li a {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  font-size: 0;
}
.results li img {margin-bottom: 10px;}
.results .cate {
  color: #2B00BA;
  font-size: 1.4rem;
}
.results .ttl {  font-size: 2.0rem;}


@media (max-width: 768px) {
  .results li {
    width: 49%;
    margin-bottom: 4%;
  }
  .results li img{margin-bottom: 5px;}

  .results li .cate {
    font-size: 1.0rem;
    letter-spacing: 0.1em;
  }
  .results li .ttl {
    font-size: 1.3rem;
  }
}


/*  about
---------------------------------------------------------- */
.about_block {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.about_block .box,
.about_block figure{
  width: 50%;
  box-sizing: border-box;
}
.about_block figure {align-self: stretch;}
.about_block figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.about_block .box {
  max-width: 44em;
  padding: 2%;
  margin: 0 auto;
}
.about_block .box p {
  margin-bottom: 20px;
  line-height: 1.75em;
  font-size: 1.6rem;
}
.about_block .btn { margin:40px 0 0;}


@media (max-width: 768px) {
  .about_block {  flex-direction: column-reverse;}
  .about_block.recruit {flex-direction: column;}

  .about_block figure{width: 100%;}

  .about_block .box {
    width: 94%;
    max-width: none;
    padding: 5% 0 10%;
  }
  .about_block .box p {
    margin-bottom: 10px;
    line-height: 1.5em;
    font-size: 1.4rem;
  }
  .about_block .btn {margin: 20px 0 0;}
}

/* ---------- 2023/10追加分 ---------- */
/* ----- English ----- */
/* nav-menu */
.top .menu-en-link .icon-en{
  display: none;
}
.top .menu-en-link .icon-en2{
  display: block;
}

/* top-img */
#en-container .en_top_img{
  max-width: 660px;
}

/* ----- レスポンシブ ----- */
/* SPでのFVの高さ調整 */
@media (max-width: 768px) {
 .main_img {
  height: calc(100vh - 64px) !important;
 }
 .main_img img.sp{
  height: calc(100vh - 64px);
 }
}