@import url("https://fonts.googleapis.com/css2?family=Lexend+Deca:wght@100..900&family=M+PLUS+1p&family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap");

.f_lexend {
  font-family: "Lexend Deca", sans-serif;
}

html {
  font-size: 0.520832vw;
}

@media (max-width: 1200px) and (min-width: 960.5px) {
  html {
    font-size: 0.6vw;
  }
}

@media (max-width: 960px) and (min-width: 767.5px) {
  html {
    font-size: 1.30208vw;
  }
}

@media (max-width: 767px) {
  html {
    font-size: 2.5641vw;
  }
}

*,
:after,
:before {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body {
  font-size: 1.6rem;
  letter-spacing: 0;
  line-height: 175%;
  font-weight: 500;
  font-family: "Noto Sans JP", sans-serif;
}

@media (max-width: 480px) {
  body {
    font-size: 15px;
  }
}

.anchor_fixtop_1,
.anchor_fixtop {
  display: block;
  position: relative;
  top: -15rem;
  width: 100%;
  visibility: hidden;
}

.anchor_fixtop_1 {
  top: -25rem;
}

#page_top {
  position: fixed;
  bottom: 3.7rem;
  right: 7.3rem;
  width: 7.4rem;
  height: 7.4rem;
  opacity: 0;
  border: 0;
  border-radius: 100%;
  z-index: 99 !important;
  background: #004098;
  background-size: cover;
  transition: all 0.35s;
  cursor: pointer;
  outline: none;
  z-index: 50;
}

#page_top::before {
  content: "";
  position: absolute;
  width: 1.1rem;
  height: 3.9rem;
  background: url(../img/common/page-top.png) no-repeat center;
  background-size: contain;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

#page_top.show {
  opacity: 1;
}

@media (max-width: 1200px) and (min-width: 960.5px) {
  #page_top {
    right: 2.3rem;
  }
}

@media (max-width: 960px) {
  #page_top {
    right: 1.5rem;
    bottom: 1.5rem;
    font-size: 1rem;
    padding-top: 1.5rem;
    height: 6rem;
    width: 6rem;
    position: fixed;
  }

  #page_top::before {
    width: .8rem;
    height: 3rem;
  }
}

.wow_custom {
  opacity: 0;
  -webkit-transform: translate(0, 35px);
  transform: translate(0, 35px);
  transition: all 0.5s ease;
}

.wow_custom.show {
  opacity: 1;
  -webkit-transform: none;
  transform: none;
}

p {
  color: #333333;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 175%;
  letter-spacing: 0.06rem;
  font-feature-settings: 'palt';
}

[class*="dflex"] {
  display: flex;
  flex-wrap: wrap;
}

[class*="aic"] {
  align-items: center;
}

[class*="aie"] {
  align-items: flex-end;
}

[class*="ais"] {
  align-items: flex-start;
}

[class*="jcc"] {
  justify-content: center;
}

[class*="jcsb"] {
  justify-content: space-between;
}

[class*="jcfe"] {
  justify-content: flex-end;
}

[class*="fcolumn"] {
  flex-flow: column;
}

a[href^="tel:"] {
  cursor: default;
  pointer-events: none;
}

@media (max-width: 1024px) {
  a[href^="tel:"] {
    cursor: pointer;
    pointer-events: all;
  }
}

[class*="grid"] {
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}

.grid-1710 {
  max-width: 174rem;
}

.grid-1570 {
  max-width: 160rem;
}

.grid-1560 {
  max-width: 159rem;
}

.grid-1450 {
  max-width: 148rem;
}

.grid-1430 {
  max-width: 146rem;
}

.grid-1350 {
  max-width: 138rem;
}

.grid-1240 {
  max-width: 127rem;
}

.grid-1060 {
  max-width: 109rem;
}

.txt-center {
  text-align: center;
}

.txt-right {
  text-align: right;
}

body,
html {
  height: 100%;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: top;
  overflow-clip-margin: inherit;
}

a,
button {
  color: inherit;
  text-decoration: none;
}

input,
textarea,
button,
select {
  outline: none;
  resize: none;
}

.hv-o {
  transition: ease all 0.5s;
}

.hv-o:hover {
  opacity: 0.8;
}

.ho-main,
.os-main {
  overflow: hidden;
}

.os-y-hidden {
  overflow-y: hidden;
}

.os-section {
  position: relative;
}

.os-align-center {
  text-align: center;
}

.u-sp {
  display: none;
}

ul,
ol {
  list-style: none;
}

.is_hidden {
  display: none !important;
}

.no_scroll {
  overflow: hidden;
}

@media (max-width: 960px) {
  [class*="grid"] {
    padding-left: 3rem;
    padding-right: 3rem;
  }

  .u-pc {
    display: none;
  }

  .u-sp {
    display: block;
  }
}

/* Slider */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  -khtml-user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  display: block;
  overflow: hidden;
  margin: 0;
  padding: 0;
}

.slick-list:focus {
  outline: none;
}

.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.slick-track {
  position: relative;
  top: 0;
  left: 0;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.slick-track:before,
.slick-track:after {
  display: table;
  content: '';
}

.slick-track:after {
  clear: both;
}

.slick-loading .slick-track {
  visibility: hidden;
}

.slick-slide {
  display: none;
  float: left;
  height: 100%;
  min-height: 1px;
}

[dir='rtl'] .slick-slide {
  float: right;
}

.slick-slide img {
  display: block;
  margin-left: auto;
  margin-right: 0;
}

.slick-slide.slick-loading img {
  display: none;
}

.slick-slide.dragging img {
  pointer-events: none;
}

.slick-initialized .slick-slide {
  display: block;
}

.slick-loading .slick-slide {
  visibility: hidden;
}

.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
  display: none;
}

.wp-header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 99;
}

.wp-header-gp {
  transition: all 0.35s;
}

.wp-header-logo {
  transition: all 0.35s;
}

.wp-header-logo img {
  width: 48.5rem;
  border-bottom-right-radius: 1.3rem;
}

.wp-header-menu {
  padding-right: 4.8rem;
  padding-top: 2.4rem;
}

.wp-header-menu .menu {
  align-items: center;
  background: #FFFFFF;
  border-radius: 6.5rem;
  padding: 0.75rem;
}

.wp-header-menu .menu li {
  margin-left: 5rem;
}

.wp-header-menu .menu li:first-child {
  margin-left: 0;
}

.wp-header-menu .menu li.contact a {
  font-size: 1.5rem;
  background: #f38f1e url(../img/common/icon-tel-01.png) no-repeat center left 2.7rem;
  background-size: 1.35rem;
  color: #FFFFFF;
  display: flex;
  width: 17rem;
  height: 5rem;
  align-items: center;
  justify-content: center;
  border-radius: 5rem;
  padding-left: 2.3rem;
}

.wp-header-menu .menu li a {
  color: #333333;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 170%;
  letter-spacing: 0;
  display: inline-block;
}

.wp-header-menu .menu li a:hover {
  color: #187bf0;
}

.wp-header-menu .menu li.active a {
  color: #187bf0;
}

.wp-header-menu .menu .top {
  display: none;
}

.wp-header-02 {
  position: fixed;
  top: -6.5rem;
  left: 0;
  width: 100%;
  transition: all 0.35s;
}

.wp-header-02 .wp-header-menu {
  padding-top: 0;
  display: flex;
  justify-content: center;
}

.wp-header-02 .wp-header-menu .menu li.logo {
  margin-left: 3rem;
}

.wp-header-02 .wp-header-menu .menu li.logo img {
  width: 31.3rem;
}

.wp-header.active .wp-header-02 {
  top: 2.4rem;
}

@media (max-width: 960px) {
  header {
    height: 9rem;
  }

  .wp-header {
    position: fixed;
    background: #FFFFFF;
  }

  .wp-header-02 {
    display: none;
  }

  .wp-header-logo {
    display: flex;
    justify-content: space-between;
    width: 100%;
    height: 9rem;
    padding-left: 2.4rem;
    padding-right: 2.7rem;
    align-items: center;
  }

  .wp-header-logo img {
    width: 25.2rem;
    border-bottom-right-radius: 0;
  }

  .wp-header-menu {
    display: none;
    width: 100%;
    padding-right: 0;
    padding-top: 0;
    padding-bottom: 1.5rem;
  }

  .wp-header-menu .menu {
    display: block;
    padding: 0 1.5rem;
  }

  .wp-header-menu .menu .top {
    display: block;
  }

  .wp-header-menu .menu li {
    margin-left: 0;
  }

  .wp-header-menu .menu li a {
    display: block;
    padding: 1rem;
    border-bottom: dashed 1px #CCC;
    font-size: 1.4rem;
    font-weight: 600;
    text-align: center;
  }

  .wp-header-menu .menu li.contact {
    margin-top: 1rem;
  }

  .wp-header-menu .menu li.contact a {
    width: 100%;
    border-bottom: 0;
  }

  #menu {
    display: block;
    position: relative;
    top: .3rem;
  }

  #menu>div {
    width: 3.86rem;
    height: 3.86rem;
    position: relative;
    display: flex;
  }

  #menu span {
    background: #0143be;
    left: 0.7rem;
    -webkit-transform: translateY(-50%) rotate(0deg);
    transform: translateY(-50%) rotate(0deg);
    position: absolute;
    width: 2.41rem;
    height: 4px;
    -webkit-transition: top 0.1s ease 0.3s, background 0.1s ease 0.3s, -webkit-transform 0.3s ease;
    transition: top 0.1s ease 0.3s, background 0.1s ease 0.3s, -webkit-transform 0.3s ease;
    transition: top 0.1s ease 0.3s, transform 0.3s ease, background 0.1s ease 0.3s;
    transition: top 0.1s ease 0.3s, transform 0.3s ease, background 0.1s ease 0.3s, -webkit-transform 0.3s ease;
  }

  #menu span:nth-child(1) {
    top: 1.1rem;
  }

  #menu span:nth-child(2) {
    bottom: 1.2rem;
  }

  #menu .change span {
    -webkit-transition: top 0.1s ease, background 0.1s ease, -webkit-transform 0.3s ease 0.1s;
    transition: top 0.1s ease, background 0.1s ease, -webkit-transform 0.3s ease 0.1s;
    transition: top 0.1s ease, transform 0.3s ease 0.1s, background 0.1s ease;
    transition: top 0.1s ease, transform 0.3s ease 0.1s, background 0.1s ease, -webkit-transform 0.3s ease 0.1s;
  }

  #menu .change span:nth-child(1) {
    top: 50%;
    -webkit-transform: translateY(-50%) rotate(315deg);
    transform: translateY(-50%) rotate(315deg);
  }

  #menu .change span:nth-child(2) {
    top: 50%;
    -webkit-transform: translateY(-50%) rotate(405deg);
    transform: translateY(-50%) rotate(405deg);
  }

  .chane-x {
    display: inline-block;
    position: relative;
    cursor: pointer;
  }
}

.wp-footer-access {
  background: #0071cd;
  padding-top: 7.3rem;
  padding-bottom: 10rem;
}

.wp-footer-access-head {
  margin-bottom: 1.2rem;
}

.wp-footer-access-head img {
  width: 6.15rem;
}

.wp-footer-access-head .title {
  min-width: 10.8rem;
  font-size: 2.4rem;
  letter-spacing: 0;
  line-height: 150%;
  font-weight: 600;
  padding-bottom: 1.3rem;
  color: #FFFFFF;
  margin-left: 2.5rem;
}

.wp-footer-access-head p {
  font-size: 1.6rem;
  color: #FFFFFF;
  padding-top: .9rem;
}

.wp-footer-access-head .head-txt {
  padding-bottom: 1.5rem;
}

.wp-footer-access-gp {
  margin-bottom: 3rem;
}

.wp-footer-access-gp:last-child {
  margin-bottom: 0;
}

.wp-footer-access-item {
  width: calc((100% - 7.001rem) / 2);
  margin-right: 7rem;
}

.wp-footer-access-item:nth-child(2n) {
  margin-right: 0;
}

.wp-footer-access-item img {
  width: 100%;
}

.wp-footer-access-item iframe {
  width: 100%;
  border: 0;
  vertical-align: top;
  height: 35.4rem;
}

.wp-footer-wrap {
  background: #333333;
  padding: 6.2rem 0;
}

.wp-footer-gp {
  max-width: 178rem;
  margin-left: auto;
  margin-right: auto;
  width: calc(100% - 3rem);
}

.wp-footer-item p {
  color: #FFFFFF;
  font-size: 1.3rem;
  font-weight: 500;
  line-height: 170%;
  letter-spacing: 0;
}

.wp-footer-item:first-child {
  width: 65rem;
}

.wp-footer-item:nth-child(2) {
  width: calc(100% - 65rem - 45rem);
}

.wp-footer-item:last-child {
  width: 45rem;
}

.wp-footer-item:last-child p {
  letter-spacing: -0.02rem;
}

.wp-footer-item .menu li {
  margin-left: 5rem;
}

.wp-footer-item .menu li:first-child {
  margin-left: 0;
}

.wp-footer-item .menu li a {
  color: #FFFFFF;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 170%;
  letter-spacing: 0;
}

.wp-footer-logo {
  margin-right: 3.5rem;
}

.wp-footer-logo img {
  width: 30.35rem;
}

@media (max-width: 1200px) and (min-width: 960.5px) {
  .wp-footer-item:first-child {
    width: 62rem;
  }

  .wp-footer-item:nth-child(2) {
    width: calc(100% - 62rem - 45rem);
  }

  .wp-footer-item .menu li {
    margin-left: 3rem;
  }
}

@media (max-width: 960px) {
  .wp-footer-access {
    padding-top: 5rem;
    padding-bottom: 4.5rem;
  }

  .wp-footer-access-head {
    margin-bottom: .5rem;
    padding: 0px 1.2rem;
  }

  .wp-footer-access-head img {
    width: 4.6rem;
  }

  .wp-footer-access-head .title {
    font-size: 1.6rem;
    margin-left: 1.4rem;
  }

  .wp-footer-access-gp {
    margin-bottom: 3.7rem;
  }

  .wp-footer-access-item {
    width: 100%;
    margin-right: 0;
    margin-top: 1.2rem;
  }

  .wp-footer-access-item:last-child {
    margin-top: 0;
  }

  .wp-footer-access-item:first-child {
    order: 1;
  }

  .wp-footer-access-item iframe {
    height: 36.9rem;
  }

  .wp-footer-access .grid-1450 {
    padding-left: 2.5rem;
    padding-right: 2.5rem;
  }

  .wp-footer-logo {
    margin-right: 0;
    margin-bottom: 2rem;
  }

  .wp-footer-logo img {
    width: 27rem;
  }

  .wp-footer-wrap {
    padding: 5.5rem 0 6.2rem;
  }

  .wp-footer-item:first-child {
    width: 100%;
    justify-content: center;
    margin-bottom: 2.8rem;
  }

  .wp-footer-item:nth-child(2) {
    display: none;
  }

  .wp-footer-item:last-child {
    width: 100%;
    text-align: center;
  }

  .wp-footer-item:last-child p {
    font-size: 1.2rem;
  }

  .wp-footer-item p {
    letter-spacing: .08rem;
    font-feature-settings: initial;
  }
}

@media (max-width: 767px) {
  .wp-footer-access-item iframe {
    height: 17.5rem;
  }
}

.title-default-01 {
  position: relative;
  padding-left: 6rem;
  margin-left: 3rem;
}

.title-default-01::before {
  content: "";
  position: absolute;
  width: 1.9rem;
  height: 9.65rem;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  background: url(../img/common/icon-title-01.png) no-repeat center;
  background-size: contain;
}

.title-default-01>span {
  display: block;
  color: #333333;
  font-size: 5.5rem;
  font-weight: 600;
  line-height: 148%;
  letter-spacing: 0;
}

.title-default-01>span:last-child {
  font-size: 1.6rem;
  color: #187bf0;
  font-family: "Lexend Deca", sans-serif;
}

.title-default-01.vs-02::before {
  background-image: url(../img/common/icon-title-01-w.png);
}

.title-default-01.vs-02 span {
  color: #FFFFFF;
}

.title-default-02 {
  display: flex;
  align-items: center;
  margin-bottom: 1.5rem;
}

.title-default-02 .icon img {
  width: 6.3rem;
}

.title-default-02 .txt {
  margin-left: 2.5rem;
  color: #333333;
  font-size: 3rem;
  font-weight: 600;
  line-height: 148%;
  letter-spacing: 0;
}

.title-default-05 {
  color: #FFFFFF;
  font-size: 5rem;
  font-weight: 900;
  line-height: 150%;
  letter-spacing: 0.35rem;
  font-family: "Noto Serif JP", serif;
}

.title-default-06 {
  color: #FFFFFF;
  font-size: 2.3rem;
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0;
  margin-top: 1.2rem;
}

.btn-default-01 a {
  display: flex;
  align-items: center;
  height: 6.2rem;
  width: 100%;
  max-width: 24.7rem;
  background: #eeeeee;
  color: #333333;
  font-size: 2rem;
  font-weight: 600;
  line-height: 170%;
  letter-spacing: 0;
  border-radius: .7rem;
  padding: 0 2.5rem;
  position: relative;
}

.btn-default-01 a::before {
  content: "";
  position: absolute;
  width: 3.5rem;
  height: 0.9rem;
  top: 50%;
  right: 2.5rem;
  transform: translateY(-50%);
  background: url(../img/common/icon-01.png) no-repeat center;
  background-size: contain;
}

.btn-default-02 a {
  display: flex;
  align-items: center;
  width: 19.3rem;
  height: 6.2rem;
  background: #f38f1e url(../img/common/icon-arrow-right-w.png) no-repeat center right 2.5rem;
  background-size: 3.5rem;
  border-radius: .7rem;
  padding: 0 2.5rem;
  color: #FFFFFF;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 150%;
  letter-spacing: 0;
}

.btn-default-02.vs-02 a {
  width: 39rem;
  height: 9.5rem;
  padding: 0 3.2rem;
  background-position: center right 3.8rem;
  margin-left: auto;
  margin-right: auto;
}

.btn-gp-01 .btn-default-01 {
  width: calc((100% - 2.001rem) / 2);
  margin-right: 2rem;
}

.btn-gp-01 .btn-default-01:nth-child(2n) {
  margin-right: 0;
}

.title-gp-01 .title-default-01 {
  width: 46.5rem;
}

.title-gp-01 p {
  margin-top: .6rem;
}

.title-gp-01 .cont {
  width: 71.2rem;
}

.title-gp-01.vs-02 p {
  color: #FFFFFF;
  max-width: 58rem;
  letter-spacing: .18rem;
}

.wp-mv {
  position: relative;
}

.wp-mv-cont {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  transform: translateY(-50%);
}

.wp-mv-cont p {
  color: #FFFFFF;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 165%;
  letter-spacing: 0;
}

.wp-mv-title {
  color: #FFFFFF;
  font-size: 6rem;
  font-weight: 900;
  line-height: 170%;
  letter-spacing: 0.45rem;
  font-family: "Noto Serif JP", serif;
  margin-bottom: 2rem;
}

.wp-mv-slide li {
  position: relative;
}

.wp-mv-slide li::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: #000000;
  opacity: 0.4;
}

.wp-mv-slide .wrap_banner__line {
  bottom: 7.3rem;
  animation-delay: 1s;
}

.wp-mv-slide .wrap_banner__line--mask::before {
  background: linear-gradient(90deg, #187bf0 0%, #94d4f5 25%, #ffffff 50%, #94d4f5 75%, #187bf0 100%);
}

.wp-mv-slide .slick-active .wrap_banner__line {
  animation: _opacity 500ms 1s linear forwards;
}

.wp-mv-slide .slick-active .wrap_banner__line .--mask {
  animation: widthAnimation 900ms 1s linear forwards 1;
}

.wp-mv-slide .slick-active .wrap_banner__line .--glow {
  animation: _mask 1s ease-out 1.85s forwards;
}

.wp-mv-slide .slick-active .wrap_banner__line .--glow::before {
  animation: _mask_bg 1.5s ease-in-out 1.85s forwards 1, _glow_fade_out 300ms linear 3.2s forwards 1;
}

.wp-mv .scroll {
  position: absolute;
  right: 5.3rem;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
}

.wp-mv .scroll .txt {
  color: #FFFFFF;
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 170%;
  letter-spacing: 0;
  margin-right: 2.4rem;
}

.wp-mv .scroll .btn {
  width: 9.1rem;
  height: 9.1rem;
  border-radius: 100%;
  padding: 1.5rem;
  cursor: pointer;
  background: url(../img/top/scroll-down.png) no-repeat center;
  background-size: contain;
}

.wp-mv .scroll .btn .line {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  display: block;
}

.wp-mv .scroll .btn .line::before {
  left: 2.7rem;
  top: 1.2rem;
  animation: hero-scroll-arrow 2s ease-in-out 0s infinite normal both;
  content: "";
  position: absolute;
  width: 1.15rem;
  height: 4.05rem;
  background: url(../img/top/scroll-down-line.png) no-repeat center;
  background-size: contain;
}

@keyframes hero-scroll-arrow {
  0% {
    transform: translateY(0);
  }

  20% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(170%);
  }

  50.01% {
    transform: translateY(-170%);
  }

  90% {
    transform: translateY(0);
  }

  to {
    transform: translateY(0);
  }
}

@keyframes widthAnimation {
  0% {
    width: 0;
    transition: width 1.5s cubic-bezier(0.33, 1, 0.68, 1) 2s;
  }

  100% {
    width: 100%;
    transition: width 1.5s cubic-bezier(0.33, 1, 0.68, 1) 2s;
  }
}

.wp-service {
  padding: 17.7rem 0 18rem;
  overflow: hidden;
}

.wp-service .title-gp-01 {
  margin-bottom: 10rem;
}

.wp-service-gp-box {
  width: calc((100% - 9.501rem) / 2);
  margin-right: 9.5rem;
  position: relative;
}

.wp-service-gp-box:nth-child(2n-1) {
  margin-right: 0;
}

.wp-service-gp-box:last-child {
  margin-bottom: 0;
}

.wp-service-gp-box.vs-01 {
  margin-left: -23.5rem;
  margin-right: -23.5rem;
  width: calc(100% + 47rem);
  margin-bottom: 10rem;
}

.wp-service-gp-box.vs-01 .wp-service-gp-item {
  padding: 13.4rem 10.5rem 12.8rem;
  margin-left: 0;
  margin-top: -4.5rem;
  max-width: 72.6rem;
}

.wp-service-gp-box.vs-01 .wp-service-gp-item p {
  margin-bottom: 3.7rem;
}

.wp-service-gp-box.vs-01 .title-default-02 {
  margin-bottom: 3.7rem;
}

@media (min-width: 960.5px) {
  .wp-service-gp-box.vs-02 .btn-default-01 a {
    position: absolute;
    max-width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: transparent;
    color: transparent;
  }

  .wp-service-gp-box.vs-02 .btn-default-01 a::before {
    top: auto;
    bottom: 3.3rem;
    transform: initial;
  }
}

.wp-service-gp-item {
  margin-top: -12.5rem;
  background: #FFFFFF;
  padding: 5rem 5rem 9.2rem;
  box-shadow: 1px 1px 1rem rgba(224, 224, 224, 0.75);
  max-width: 52.4rem;
  margin-left: auto;
  margin-right: auto;
  font-feature-settings: 'palt';
  border-radius: 1.25rem;
  position: relative;
}

.wp-service-gp-item p {
  letter-spacing: 0.05rem;
}

.wp-service-gp-field {
  width: 50%;
  margin-left: auto;
  margin-right: 0;
  position: absolute;
  top: 0;
  right: 0;
}

.wp-works {
  padding: 16.2rem 0 20.3rem;
  background: linear-gradient(0deg, #004098 0%, #187bf0 53%, #004098 100%);
  position: relative;
  z-index: 0;
  overflow: hidden;
}

.wp-works::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: -1;
  background: url(../img/top/bg-works-01.png) no-repeat center;
  background-size: contain;
}

.wp-works .btn-default-02 {
  margin-top: 7rem;
}

.wp-works .title-gp-01 {
  margin-bottom: 10rem;
}

.wp-works-list {
  overflow: hidden;
  padding: 4rem 0;
}

.wp-works-list ul {
  display: flex;
  animation: slideAnimation 40s linear infinite;
  width: calc(68rem * 8);
}

.wp-works-list ul li {
  flex-shrink: 0;
  width: 63rem;
  height: 100%;
  margin-right: 5rem;
  position: relative;
}

.wp-works-list ul li:nth-child(2n) {
  margin-top: 6.8rem;
}

.wp-works-list ul li img {
  width: 100%;
  box-shadow: 1rem 1rem 3rem rgba(0, 0, 0, 0.38);
}

.wp-works-icon {
  position: absolute;
  opacity: 0.5;
  background-size: cover;
}

.wp-works-icon.icon-01 {
  width: 26.6rem;
  height: 20rem;
  top: 38.5rem;
  left: 7.3rem;
  background-image: url(../img/top/works-icon-01.jpg);
}

.wp-works-icon.icon-02 {
  width: 52.6rem;
  height: 39.5rem;
  left: 76.3rem;
  bottom: 18rem;
  background-image: url(../img/top/works-icon-02.jpg);
}

.wp-works-icon.icon-03 {
  top: 34rem;
  right: 6rem;
  width: 20rem;
  height: 26.6rem;
  background-image: url(../img/top/works-icon-03.jpg);
}

@keyframes slideAnimation {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-100%);
  }
}

.wp-company {
  padding: 18rem 0;
}

.wp-company .title-default-01 {
  margin-left: 0;
  margin-bottom: 2rem;
}

.wp-company-wrap {
  position: relative;
  z-index: 0;
  padding-bottom: 7.5rem;
}

.wp-company-wrap::before {
  content: "";
  position: absolute;
  width: 144.9rem;
  height: calc(100% - 10rem);
  bottom: 0;
  left: 0;
  z-index: -1;
  background: url(../img/top/company-bg-01.jpg) no-repeat center;
  background-size: cover;
}

.wp-company-wrap p {
  margin-bottom: 3.4rem;
}

.wp-company-gp {
  background: #FFFFFF;
  max-width: 100.5rem;
  margin-left: auto;
  box-shadow: 0.125rem 0.125rem 1.253rem rgba(224, 224, 224, 0.75);
  border-radius: 1.3rem;
  padding: 10.7rem 8.2rem 7.5rem 8.5rem;
}

.wp-company-list li {
  width: calc((100% - 2.001rem) / 2);
  margin-right: 2rem;
  margin-bottom: 1.5rem;
}

.wp-company-list li:nth-child(2n) {
  margin-right: 0;
}

.wp-company-list li a {
  display: flex;
  align-items: center;
  width: 100%;
  height: 12.5rem;
  background-size: cover;
  position: relative;
  z-index: 0;
  border-radius: 1rem;
  color: #FFFFFF;
  font-size: 2rem;
  font-weight: 500;
  line-height: 150%;
  letter-spacing: 0;
  padding: 0 5rem;
}

.wp-company-list li a::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: -1;
  border-radius: 1rem;
  background: #000000;
  opacity: 0.4;
  transition: all 0.35s;
}

.wp-company-list li a:hover::before {
  opacity: 0.6;
}

.wp-recruit {
  margin-bottom: 4.2rem;
}

.wp-recruit-wrap {
  margin-top: -35.5rem;
  padding-top: 14rem;
  padding-bottom: 8rem;
  position: relative;
  border-radius: 1.3rem;
  box-shadow: 1rem 1rem 3rem rgba(0, 0, 0, 0.38);
  background: linear-gradient(90deg, #004098 0%, #187bf0 53%, #004098 100%);
}

.wp-recruit-list {
  margin-bottom: 5.3rem;
}

.wp-recruit-list li {
  width: calc((100% - 17rem) / 3);
  margin-right: 8.5rem;
}

.wp-recruit-list li:nth-child(3n) {
  margin-right: 0;
}

.wp-recruit-list li img {
  width: 100%;
  border-radius: 1rem;
}

.wp-recruit .title-gp-01 {
  padding-left: 8rem;
  padding-right: 12rem;
  margin-bottom: 4.6rem;
}

.wp-recruit .title-gp-01 .title-default-01 {
  margin-left: 0;
  width: 33.5rem;
}

.wp-recruit .title-gp-01 p {
  width: calc(100% - 33.5rem);
  color: #FFFFFF;
}

.wrap_contact_us.vs-02 {
  position: relative;
}

.wrap_contact_us.vs-02 .wrap_contact_us--item:last-child {
  margin-top: 23rem;
}

.wrap_contact_us.vs-02 .wrap_banner__line {
  padding: 0;
  top: 11.8rem;
  bottom: auto;
}

.wrap_contact_us.vs-02>div {
  padding-bottom: 18rem;
  background-color: transparent;
}

.wrap_contact_us.vs-02 .title-default-01 {
  margin-bottom: 26rem;
}

.wrap_contact_us.vs-02 .title-default-01::before {
  background-image: url(../img/common/icon-title-01.png);
}

.wrap_contact_us.vs-02 .title-default-01>span {
  color: #333333;
}

.wrap_contact_us.vs-02 p {
  color: #333333;
}

.wrap_contact_us.vs-02 .wrap_tel_fax {
  box-shadow: 0.125rem 0.125rem 1.253rem rgba(224, 224, 224, 0.75);
}

.wrap_banner__line.vs-02 .wrap_banner__line--mask::before {
  background: linear-gradient(90deg, #187bf0 0%, #94d4f5 25%, #ffffff 50%, #94d4f5 75%, #187bf0 100%);
}

.letter {
  display: inline-block;
  -webkit-transform: translateY(100%);
  transform: translateY(100%);
  opacity: 0;
  -webkit-transition: opacity 0.5s, -webkit-transform 0.5s;
  transition: opacity 0.5s, -webkit-transform 0.5s;
  transition: transform 0.5s, opacity 0.5s;
  transition: transform 0.5s, opacity 0.5s, -webkit-transform 0.5s;
}

.letter.show-anime {
  -webkit-transform: translateY(0);
  transform: translateY(0);
  opacity: 1;
}

@media (max-width: 960px) {
  .title-gp-01 .title-default-01 {
    width: 100%;
  }

  .title-default-01 {
    margin-left: 1.4rem;
    padding-left: 4rem;
  }

  .title-default-01::before {
    width: 1.4rem;
    height: 6.7rem;
  }

  .title-default-01>span {
    font-size: 3rem;
  }

  .title-default-02 {
    margin-left: 1.5rem;
    margin-bottom: 2.2rem;
  }

  .title-default-02 .txt {
    margin-left: 2rem;
  }

  .title-default-05 {
    font-size: 3.2rem;
    letter-spacing: .25rem;
    line-height: 130%;
  }

  .btn-default-01 a {
    margin-left: auto;
    margin-right: auto;
    font-size: 1.6rem;
  }

  .btn-default-02 a {
    margin-left: auto;
    margin-right: auto;
    width: 24.7rem;
  }

  .btn-default-02.vs-02 a {
    width: 24.7rem;
    height: 6.2rem;
  }

  .btn-gp-01 .btn-default-01 {
    width: 100%;
    margin-right: 0;
    margin-bottom: 2rem;
  }

  .btn-gp-01 .btn-default-01:last-child {
    margin-bottom: 0;
  }

  .wp-mv-title {
    color: #333333;
    font-size: 3.2rem;
    line-height: 140%;
  }

  .wp-mv-cont {
    position: relative;
    top: 0;
    transform: initial;
    padding-bottom: 18rem;
  }

  .wp-mv-cont p {
    color: #333333;
    font-size: 1.6rem;
    letter-spacing: .1rem;
    font-feature-settings: initial;
    line-height: 190%;
  }

  .wp-mv-cont .wrap_banner__line--mask::before {
    background: linear-gradient(90deg, #187bf0 0%, #94d4f5 25%, #ffffff 50%, #94d4f5 75%, #187bf0 100%);
  }

  .wp-mv-slide {
    margin-bottom: 3.5rem;
  }

  .wp-mv-slide .wrap_banner__line {
    display: none;
  }

  .wp-mv-slide li::before {
    content: none;
  }

  .wp-mv .scroll {
    display: none;
  }

  .title-gp-01 p {
    margin-top: 2.5rem;
  }

  .wp-service {
    padding: 3.4rem 0 6.7rem;
  }

  .wp-service .title-gp-01 {
    margin-bottom: 4.2rem;
  }

  .wp-service-gp-box {
    width: 100%;
    margin-right: 0;
  }

  .wp-service-gp-box.vs-01 {
    margin-left: 0;
    margin-right: 0;
    width: 100%;
    margin-bottom: 5.7rem;
  }

  .wp-service-gp-box.vs-01 .wp-service-gp-item {
    margin-top: 0;
    padding: 0;
  }

  .wp-service-gp-box.vs-01 .wp-service-gp-item p {
    margin-bottom: 4.4rem;
  }

  .wp-service-gp-box.vs-01 .title-default-02 {
    margin-bottom: 1.7rem;
  }

  .wp-service-gp-box .img {
    margin-left: -3rem;
    margin-right: -3rem;
    width: calc(100% + 6rem);
    margin-bottom: 4rem;
  }

  .wp-service-gp-box.vs-02 {
    margin-bottom: 6rem;
  }

  .wp-service-gp-box.vs-02:last-child {
    margin-bottom: 0;
  }

  .wp-service-gp-box.vs-02 .img {
    margin-bottom: 4.5rem;
  }

  .wp-service-gp-box.vs-02 p {
    margin-bottom: 4.4rem;
  }

  .wp-service-gp-item {
    margin-top: 0;
    background: transparent;
    box-shadow: initial;
    padding: 0;
  }

  .wp-service-gp-field {
    width: 100%;
    position: relative;
  }

  .wp-service p {
    font-feature-settings: initial;
    letter-spacing: .1rem;
    line-height: 190%;
  }

  .wp-works {
    padding: 7.2rem 0 7rem;
  }

  .wp-works::before {
    width: 126.6rem;
    height: 70.7rem;
    top: 10.1rem;
    left: -87rem;
    background-image: url(../img/common/bg-works-01-sp.png);
  }

  .wp-works-icon {
    display: none;
  }

  .wp-works-list {
    padding: 3.4rem 0;
  }

  .wp-works-list ul {
    width: calc(39.5rem * 8);
  }

  .wp-works-list ul li {
    width: 36.5rem;
    margin-right: 3rem;
  }

  .wp-works-list ul li:nth-child(2n) {
    margin-top: 0;
  }

  .wp-works .title-default-01 {
    margin-bottom: 4.2rem;
  }

  .wp-works .title-gp-01 {
    margin-bottom: 0;
  }

  .wp-works .title-gp-01 .vs-02 p {
    letter-spacing: .1rem;
    margin-top: 1.7rem;
    font-feature-settings: initial;
  }

  .wp-works .btn-default-02 {
    margin-top: 1.2rem;
  }

  .wp-works .title-gp-01.vs-02 p {
    letter-spacing: .1rem;
    font-feature-settings: initial;
  }

  .wp-company {
    padding: 0;
  }

  .wp-company .title-default-01 {
    margin-bottom: 2.8rem;
    margin-left: 1.4rem;
  }

  .wp-company .btn-default-02 a {
    color: #333333;
    background-color: #eeeeee;
    background-image: url(../img/common/icon-01.png);
  }

  .wp-company-gp {
    background: transparent;
    box-shadow: initial;
    padding: 0;
  }

  .wp-company-wrap {
    padding-top: 31.6rem;
    padding-bottom: 6.2rem;
  }

  .wp-company-wrap::before {
    width: 100%;
    height: 25.7rem;
    bottom: auto;
    top: 0;
  }

  .wp-company-wrap p {
    letter-spacing: .14rem;
    font-feature-settings: initial;
    line-height: 185%;
    margin-bottom: 2.7rem;
  }

  .wp-company-list {
    display: none;
  }

  .wp-recruit {
    margin-bottom: 1.6rem;
  }

  .wp-recruit .title-gp-01 {
    padding-left: 3rem;
    padding-right: 3rem;
    margin-bottom: 4rem;
  }

  .wp-recruit .title-gp-01 .title-default-01 {
    width: 100%;
    margin-bottom: 4.2rem;
    margin-left: 1.5rem;
  }

  .wp-recruit .title-gp-01 p {
    width: 100%;
    line-height: 185%;
    margin-top: 2rem;
    font-feature-settings: initial;
  }

  .wp-recruit .title-default-05 {
    letter-spacing: .1rem;
  }

  .wp-recruit-wrap {
    margin-top: 0;
    border-radius: 0;
    padding-top: 5rem;
    padding-bottom: 7rem;
    box-shadow: initial;
    background: linear-gradient(0deg, #004098 0%, #187bf0 53%, #004098 100%);
  }

  .wp-recruit-list {
    display: none;
  }

  .wp-recruit .grid-1450 {
    padding-left: 0;
    padding-right: 0;
  }

  .wrap_contact_us.vs-02>div {
    padding-left: 0;
    padding-right: 0;
    padding-bottom: 6.5rem;
  }

  .wrap_contact_us.vs-02 .grid-1570 {
    overflow: initial;
  }

  .wrap_contact_us.vs-02 .title-default-01 {
    margin-bottom: 20rem;
  }

  .wrap_contact_us.vs-02 .title-default-01>span:last-child {
    color: #187bf0;
  }

  .wrap_contact_us.vs-02 .wrap_contact_us--item:first-child {
    padding-bottom: 0;
  }

  .wrap_contact_us.vs-02 .wrap_contact_us--item:last-child {
    margin-top: 4rem;
  }
}

@media (max-width: 767px) {
  .wp-mv-cont {
    padding-bottom: 11rem;
  }

  .wrap_contact_us.vs-02 .title-default-01 {
    margin-bottom: 10.5rem;
  }
}

.wrap_service {
  padding-top: 3.6rem;
}

.wrap_service_box {
  margin-bottom: 18rem;
}

.wrap_service_box--item {
  width: 100rem;
}

.wrap_service_box--item:first-child {
  width: calc(100% - 100rem);
  padding-left: 17rem;
}

.wrap_service_box.right {
  flex-direction: row-reverse;
}

.wrap_service_box.right .item--01 {
  padding-left: 0rem;
  padding-right: 17rem;
}

.wrap_service_box.right .right--bg {
  padding: 10rem 16.5rem 10rem 10rem;
}

.wrap_service_box--bg {
  padding: 10rem 10rem 9.5rem 16.5rem;
  background-color: #f2fafe;
}

.wrap_service_box.vs-02 .item--01 {
  padding-top: 5rem;
}

.wrap_service_box.vs-02 .left--bg {
  padding-left: 12.5rem;
  padding-bottom: 10rem;
}

.wrap_service_box.vs-02 .left--bg>div {
  width: 100%;
}

.wrap_service_box .title-default-03 {
  margin-bottom: 2.8rem;
  margin-top: 0;
}

.wrap_service_box .bg-white {
  background-color: #ffffff;
  border-radius: 1.5rem;
  padding: 2.8rem 3rem;
  margin-top: 3.5rem;
  box-shadow: 0.2rem 0.2rem 1rem 0.2rem rgba(0, 0, 0, 0.05);
}

.wrap_service_box .right-before {
  position: relative;
}

.wrap_service_box .right-before img {
  position: relative;
  z-index: 1;
}

.wrap_service_box .right-before::before {
  content: "";
  position: absolute;
  width: calc(100% - 17.5rem);
  height: 100%;
  background-color: #f2fafe;
  left: 0;
  top: 0;
}

.wrap_service_box .list {
  margin-top: 3rem;
}

.wrap_service_box .list li {
  width: 100%;
  background-color: #004098;
  border-radius: 5.6rem;
  padding: 1rem;
  display: flex;
  align-items: center;
}

.wrap_service_box .list li:not(:last-child) {
  margin-bottom: 1.2rem;
}

.wrap_service_box .list li .item {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.9rem;
  height: 3.9rem;
  border-radius: 100%;
  background: linear-gradient(134deg, #1a86ff 21%, #187bf0 30%, #94d4f5 100%);
  color: #ffffff;
  font-size: 2.00001rem;
  font-weight: 500;
  line-height: 100%;
  letter-spacing: 0;
}

.wrap_service_box .list li .txt {
  width: calc(100% - 3.9rem);
  padding-left: 2.3rem;
  color: #ffffff;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 175%;
  letter-spacing: 0.05rem;
  font-feature-settings: 'palt';
  position: relative;
  top: -0.1rem;
}

.wrap_service_box-related {
  margin-bottom: 18rem;
}

.wrap_service_box-related>div {
  background-color: #f2fafe;
  padding: 10rem 7.5rem 6rem 7.5rem;
}

.wrap_service_box-related li {
  width: calc((100% - 7.002rem) / 3);
  margin-right: 3.5rem;
  margin-bottom: 3.3rem;
}

.wrap_service_box-related li:nth-child(3n),
.wrap_service_box-related li:last-child {
  margin-right: 0;
}

.wrap_service_box-related li img {
  margin-bottom: 2.1rem;
}

.wrap_service_box-related li .title-default-03 {
  margin-top: 0;
}

.wrap_service_box-related li .desc {
  font-size: 1.6rem;
  margin-top: 3.2rem;
  letter-spacing: 0.1rem;
}

.wrap_service_box-related li.pl-65 {
  padding-left: 6.5rem;
}

.wrap_service_box-related p {
  font-size: 2.00001rem;
}

@media (max-width: 1200px) and (min-width: 960.5px) {
  .wrap_service_box--item:first-child {
    padding-left: 5rem;
  }

  .wrap_service_box.right .item--01 {
    padding-right: 5rem;
  }

  .wrap_service_box .right-before::before {
    width: calc(100% - 5rem);
  }

  .wrap_service_box--bg {
    padding-left: 5rem !important;
    padding-right: 5rem !important;
  }
}

@media (max-width: 960px) {
  .wrap_service {
    padding-top: 4.8rem;
  }

  .wrap_service_box {
    padding-left: 3rem;
    padding-right: 3rem;
    margin-bottom: 10rem;
    overflow: hidden;
  }

  .wrap_service_box--item {
    width: 100%;
  }

  .wrap_service_box--item:first-child {
    width: 100%;
    padding-left: 0;
  }

  .wrap_service_box--item:first-child img {
    margin-bottom: 2.2rem;
  }

  .wrap_service_box--item:last-child {
    display: none;
  }

  .wrap_service_box--item p {
    text-align: justify;
  }

  .wrap_service_box.right .item--01 {
    padding-right: 0;
  }

  .wrap_service_box.right .right--bg {
    padding: 3.8rem 2rem;
  }

  .wrap_service_box--bg {
    padding: 3.8rem 2rem;
  }

  .wrap_service_box.vs-02 .item--01 {
    padding-top: 0;
  }

  .wrap_service_box.vs-02 .left--bg {
    padding: 3.8rem 2rem;
  }

  .wrap_service_box.vs-02 .left--bg>div {
    width: 100%;
  }

  .wrap_service_box .title-default-03 {
    margin-bottom: 4rem;
    margin-top: 0;
  }

  .wrap_service_box .bg-white {
    padding: 1.8rem 2rem;
    margin-top: 2.5rem;
  }

  .wrap_service_box .list {
    margin-top: 2.5rem;
  }

  .wrap_service_box .list li {
    border-radius: 7rem;
    padding: 1.5rem;
  }

  .wrap_service_box .list li:not(:last-child) {
    margin-bottom: 1.5rem;
  }

  .wrap_service_box .list li .item {
    width: 4rem;
    height: 4rem;
    font-size: 1.8rem;
  }

  .wrap_service_box .list li .txt {
    width: calc(100% - 4rem);
    padding-left: 1.2rem;
    font-size: 1.5rem;
    letter-spacing: 0;
  }

  .wrap_service_box-related {
    margin-bottom: 10rem;
    padding-left: 3rem;
    padding-right: 3rem;
  }

  .wrap_service_box-related>div {
    padding: 3.8rem 2rem 0rem;
  }

  .wrap_service_box-related ul.vs-01 li:nth-child(1) {
    order: 1;
  }

  .wrap_service_box-related ul.vs-01 li:nth-child(2) {
    order: 2;
  }

  .wrap_service_box-related ul.vs-01 li:nth-child(3) {
    order: 0;
  }

  .wrap_service_box-related li {
    width: 100%;
    margin-right: 0;
    margin-bottom: 3.4rem;
  }

  .wrap_service_box-related li img {
    margin-bottom: 1.7rem;
  }

  .wrap_service_box-related li .desc {
    margin-top: 2.2rem;
    letter-spacing: 0.1rem;
  }

  .wrap_service_box-related li.pl-65 {
    padding-left: 0;
    margin-bottom: 3.4rem;
  }

  .wrap_service_box-related p {
    font-size: 1.6rem;
    letter-spacing: .05rem;
  }
}

.wrap_company {
  padding-top: 4.5rem;
}

.wrap_company_box {
  width: 100%;
  position: relative;
  margin-bottom: 18rem;
}

.wrap_company_box--item {
  width: 100%;
  border-radius: 2rem;
  overflow: hidden;
  background-color: #fff;
  border: 1px solid #eeeeee;
  margin-bottom: 10rem;
  padding: 10rem 11rem;
}

.wrap_company-greeting .title-default-04 {
  margin-top: 3.8rem;
}

.wrap_company-greeting .wrap-desc {
  margin-top: 2.9rem;
}

.wrap_company-greeting--item {
  width: 72.1rem;
}

.wrap_company-greeting--item:first-child {
  padding-right: 7rem;
  width: calc(100% - 72.1rem);
}

.wrap_company_profile .title-default-03 {
  margin-top: 0;
}

.wrap_company_profile-table {
  margin-top: 4.5rem;
}

.wrap_company_profile-table--item {
  margin-right: 11.3rem;
  width: calc((100% - 11.302rem) / 2);
}

.wrap_company_profile-table--item:nth-child(2n),
.wrap_company_profile-table--item:last-child {
  margin-right: 0;
}

.wrap_company_history .title-default-03 {
  margin-top: 0;
}

.title-default-03 {
  padding: 0 0 .4rem 2.9rem;
  margin-top: .5rem;
  border-left: .5rem solid #187bf0;
  color: #333333;
  font-size: 3.50001rem;
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0;
}

.title-default-04 {
  font-family: "Noto Serif JP", serif;
  color: #666666;
  font-size: 3.50001rem;
  font-weight: 900;
  line-height: 150%;
  letter-spacing: 0.27rem;
}

.wrap-desc p:not(:last-child) {
  margin-bottom: 3.4rem;
}

.wrap-desc-representative {
  text-align: right;
  margin-top: 3.9rem;
  margin-bottom: -0.5rem;
}

.wrap-desc-representative strong {
  font-size: 2.40001rem;
  font-weight: bold;
  display: inline-block;
  margin-left: 1.8rem;
}

.wrap_table {
  width: 100%;
  position: relative;
  border-spacing: 0;
}

.wrap_table tr:last-child td {
  border-bottom: 1px solid #e2e2e2;
}

.wrap_table td {
  color: #333333;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 175%;
  letter-spacing: 0rem;
  border-top: 1px solid #e2e2e2;
  padding: 1.55rem 0;
  vertical-align: top;
}

.wrap_table td:first-child {
  width: 19.5rem;
}

.wrap_table.vs-02 {
  margin-top: 4.5rem;
  max-width: 89.6rem;
  margin-left: auto;
  margin-right: auto;
}

.wrap_table.vs-02 td {
  vertical-align: middle;
  padding: 3.35rem 0;
}

.wrap_table.vs-02 td:first-child {
  font-size: 7.00002rem;
  font-weight: 500;
  color: #c8c8c8;
  font-family: "Lexend Deca", sans-serif;
  width: 20.5rem;
  line-height: 100%;
  letter-spacing: -0.23rem;
}

.wrap_table.vs-02 td:first-child span {
  font-size: 1.6rem;
  font-family: "Noto Sans JP", serif;
  position: relative;
  margin-left: 1rem;
  top: -1.9rem;
  display: inline-block;
  line-height: 100%;
}

.wrap_table.vs-02 td:last-child span {
  width: 17.5rem;
  display: inline-block;
}

.qualifications {
  margin-top: 4.5rem;
}

.qualifications li {
  width: 100%;
  color: #333333;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 175%;
  letter-spacing: 0rem;
  border-top: 1px solid #e2e2e2;
  padding: 1.55rem 0;
}

.qualifications li:last-child {
  border-bottom: 1px solid #e2e2e2;
}

@media (max-width: 960px) {
  .title-default-03 {
    padding: 0 0 .4rem 1.9rem;
    font-size: 2.5rem;
  }

  .title-default-03 {
    padding: 0 0 .4rem 1.9rem;
    font-size: 2.5rem;
  }

  .title-default-04 {
    font-size: 2.5rem;
  }

  .wrap_company_box {
    margin-bottom: 10rem;
  }

  .wrap_company_box--item {
    margin-bottom: 10rem;
    padding: 4.4rem 2rem 4.5rem;
  }

  .wrap_company-greeting .title-default-03 {
    margin-bottom: 4rem;
  }

  .wrap_company-greeting .title-default-04 {
    margin-top: 3rem;
  }

  .wrap_company-greeting .wrap-desc {
    margin-top: 2.5rem;
  }

  .wrap_company-greeting .wrap-desc p {
    text-align: justify;
  }

  .wrap_company-greeting--item {
    width: 100%;
  }

  .wrap_company-greeting--item:first-child {
    padding-right: 0;
    width: 100%;
  }

  .wrap_company-greeting--item:last-child {
    display: none;
  }

  .wrap_company_profile .title-default-03 {
    margin-top: 0;
  }

  .wrap_company_profile-table {
    margin-top: 4rem;
  }

  .wrap_company_profile-table--item {
    margin-right: 0;
    width: 100%;
  }

  .wrap_company_profile-table--item:last-child table tr:last-child td:last-child {
    padding-bottom: 0;
  }

  .wrap_company_history .title-default-03 {
    margin-top: 0;
  }

  .wrap-desc p:not(:last-child) {
    margin-bottom: 2.1rem;
  }

  .wrap-desc-representative {
    margin-top: 3rem;
    margin-bottom: 0rem;
  }

  .wrap-desc-representative strong {
    font-size: 2rem;
  }

  .wrap_table tr:last-child td {
    border-bottom: 0px solid #e2e2e2;
  }

  .wrap_table td {
    border-top: 0px solid #e2e2e2;
    float: left;
    width: 100%;
  }

  .wrap_table td:first-child {
    width: 100%;
    float: left;
    background-color: #187bf0;
    color: #fff;
    padding: 1.5rem 2rem;
  }

  .wrap_table td:last-child {
    padding-bottom: 2.5rem;
  }

  .wrap_table.vs-02 {
    margin-top: 2.4rem;
    margin-bottom: -2.2rem;
    max-width: 100%;
  }

  .wrap_table.vs-02 td {
    padding: 1rem 0 2rem;
    vertical-align: top;
  }

  .wrap_table.vs-02 td:first-child {
    width: 12rem;
    float: inherit;
    font-size: 4.00002rem;
    background-color: transparent;
  }

  .wrap_table.vs-02 td:first-child span {
    font-size: 1.5rem;
    top: -1rem;
  }

  .wrap_table.vs-02 td:last-child {
    padding-left: 0rem;
    letter-spacing: normal;
    font-size: 1.5rem;
  }

  .wrap_table.vs-02 td:last-child span {
    width: 100%;
    display: block;
  }

  .qualifications {
    margin-top: 3.5rem;
  }
}

.recruit-title-01 {
  color: #FFFFFF;
  font-size: 8.6rem;
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0.6rem;
  font-family: "Noto Serif JP", serif;
  background: url(../img/recruit/bg-boder-title.png) no-repeat center top;
  background-size: contain;
  text-align: center;
  position: relative;
  padding-top: .7rem;
  padding-bottom: 6.1rem;
  margin-bottom: 1.8rem;
}

.recruit-title-02 {
  color: #FFFFFF;
  font-size: 3.5rem;
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0;
  position: relative;
  margin-bottom: 5.5rem;
  z-index: 0;
}

.recruit-title-02::before {
  content: "";
  position: absolute;
  width: 11.7rem;
  height: 11.7rem;
  background: url(../img/recruit/icon-01.png) no-repeat center;
  background-size: cover;
  top: -3.2rem;
  left: -3.8rem;
  z-index: -1;
  animation: title-rec 6s linear infinite;
}

.recruit-title-02.vs-02 {
  color: #004098;
}

.recruit-title-02.vs-02::before {
  background-image: url(../img/recruit/icon-02.png);
}

.recruit-title-03 {
  margin-bottom: 2.5rem;
}

.recruit-title-03 span {
  color: #333333;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0;
}

.recruit-title-03 span:first-child {
  display: inline-block;
  background: #1a86ff;
  color: #FFFFFF;
  font-size: 1.3rem;
  padding: .7rem 1.6rem;
  margin-right: 1.6rem;
}

.recruit-title-04 {
  margin-bottom: 2rem;
}

.recruit-title-04>span {
  color: #0071b8;
  font-size: 4rem;
  font-weight: 900;
  line-height: 165%;
  letter-spacing: 0.37rem;
}

.recruit-title-04>span:first-child {
  font-family: "Lexend Deca", sans-serif;
  display: inline-block;
  font-size: 1.5rem;
  color: #FFFFFF;
  background: #0071b8;
  font-weight: 500;
  letter-spacing: .05rem;
  padding: .4rem 1.35rem;
  border-radius: 3rem;
  margin-bottom: 1.4rem;
}

.recruit-title-04>span.jp {
  font-family: "Noto Serif JP", serif;
  display: block;
}

@media (min-width: 960.5px) {
  .recruit-title-04>span.jp.u-sp {
    display: none;
  }
}

.recruit-title-05 {
  color: #0071b8;
  font-size: 2.1rem;
  font-weight: 700;
  line-height: 165%;
  letter-spacing: 0;
  position: relative;
  padding-left: 11rem;
}

.recruit-title-05::before {
  content: "";
  position: absolute;
  width: 7rem;
  height: 7rem;
  top: 50%;
  left: 0;
  border-radius: 100%;
  transform: translateY(-50%);
  background: url(../img/recruit/icon-03.png) no-repeat center;
  background-size: contain;
}

.recruit-title-06 {
  color: #0071b8;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 215%;
  letter-spacing: 0.2rem;
  position: relative;
  padding-left: 5rem;
  font-family: "Noto Serif JP", serif;
}

.recruit-title-06::before {
  content: "";
  position: absolute;
  width: 0.9rem;
  height: calc(100% - 2.1rem);
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  background: #0071b8;
}

@keyframes title-rec {
  0% {
    transform: rotate(0);
  }

  100% {
    transform: rotate(360deg);
  }
}

.wrap_banner.vs-recruit {
  padding-top: 20rem;
  height: 127.5rem;
  background: #FFFFFF url(../img/recruit/banner.jpg) no-repeat center top;
  background-size: cover;
  overflow: initial;
}

.wrap_banner.vs-recruit .wrap_title--banner {
  padding-bottom: 13.5rem;
}

.wrap_banner.vs-recruit .wrap_banner__line {
  bottom: -5rem;
}

.wrap_banner-recruit p {
  color: #333333;
  font-size: 2rem;
  font-weight: 500;
  line-height: 280%;
  letter-spacing: 0;
  text-align: center;
  font-feature-settings: initial;
}

.recruit-gp-01 {
  margin-top: -21.5rem;
  margin-bottom: 9.2rem;
  padding-top: 34.5rem;
  position: relative;
  background: url(../img/recruit/bg-02.jpg) no-repeat center bottom;
  background-image: url(../img/recruit/bg-02.png);
  background-size: cover;
  padding-bottom: 10rem;
}

.recruit-gp-02 {
  overflow: hidden;
  padding-top: 4rem;
  margin-bottom: 21.7rem;
}

.recruit-gp-03 {
  margin-bottom: 8rem;
}

.recruit-gp-03 .recruit-title-02 {
  margin-bottom: 1.3rem;
}

.recruit-gp-04 {
  padding-top: 12.7rem;
  padding-bottom: 8rem;
  margin-bottom: 13.5rem;
  background: #FFFFFF;
  border-top: #e2e2e2 solid 1px;
  border-bottom: #e2e2e2 solid 1px;
}

.job-gp {
  border-radius: 1.3rem;
  overflow: hidden;
  background: #FFFFFF;
}

.job-gp-item:first-child {
  width: calc(100% - 57.6rem);
  padding: 3rem 10rem 3rem 10.5rem;
  height: 100%;
}

.job-gp-item:first-child p {
  letter-spacing: .1rem;
}

.job-gp-item:last-child {
  width: 57.6rem;
}

.job-gp-item img {
  width: 100%;
}

.recruit-block-gp {
  margin-bottom: 18rem;
}

.recruit-block-gp:last-child {
  margin-bottom: 0;
}

.recruit-block-gp-item {
  position: relative;
}

.recruit-block-gp-item:first-child {
  width: calc(100% - 70rem);
  padding: 9rem 5.5rem 9.7rem 11rem;
  z-index: 0;
}

.recruit-block-gp-item:first-child::before {
  content: "";
  position: absolute;
  width: 163.5rem;
  height: 100%;
  bottom: 0;
  left: -17.5rem;
  z-index: -1;
  background: #FFFFFF;
}

@media (min-width: 960.5px) {
  .recruit-block-gp-item:first-child::before {
    border: #e2e2e2 solid 1px;
  }
}

.recruit-block-gp-item:last-child {
  width: 70rem;
  margin-top: -10rem;
  position: relative;
  z-index: 1;
}

.recruit-block-gp-item p {
  font-feature-settings: initial;
  letter-spacing: .04rem;
  line-height: 185%;
}

.recruit-block-gp:first-child {
  margin-bottom: 28rem;
}

.recruit-block-gp:first-child .recruit-block-gp-item:last-child {
  margin-bottom: -10rem;
}

.recruit-block-gp:nth-child(2n) .recruit-block-gp-item:first-child::before {
  left: auto;
  right: -17.5rem;
}

.recruit-block-gp:nth-child(2n) .recruit-block-gp-item:last-child {
  margin-bottom: 0;
  padding-bottom: 4.8rem;
}

@media (min-width: 960.5px) {
  .recruit-block-gp:nth-child(2n) .recruit-block-gp-item:first-child {
    order: 1;
    padding-left: 6.5rem;
    padding-right: 10rem;
  }

  .recruit-block-gp:nth-child(2n) .recruit-block-gp-item:last-child img {
    border-radius: 2rem;
  }
}

.recruit-list-01 {
  margin-top: 5.2rem;
}

.recruit-list-01 li {
  background: #94d4f5;
  border-left: #0071b8 solid 1.4rem;
  margin-bottom: 2.5rem;
  min-height: 16rem;
  padding-left: 2.5rem;
  display: flex;
  align-items: center;
}

.recruit-list-01 li:last-child {
  margin-bottom: 0;
}

.recruit-list-01 li p {
  color: #0071b8;
  margin-left: 3.6rem;
}

.recruit-voice-gp {
  position: relative;
  z-index: 0;
  padding: 0 9rem 0 11rem;
  max-width: 136.7rem;
  margin-bottom: -2.3rem;
}

.recruit-voice-gp:last-child {
  margin-bottom: 0;
}

.recruit-voice-gp:nth-child(2n-1) {
  margin-left: auto;
}

.recruit-voice-gp::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 32.4rem;
  top: 50%;
  left: 0;
  z-index: -1;
  transform: translateY(-50%);
  background: #FFFFFF;
  border: #e2e2e2 solid 1px;
  border-radius: 2rem;
}

.recruit-voice-gp-item:first-child {
  width: calc(100% - 45.2rem);
}

.recruit-voice-gp-item:last-child {
  width: 45.2rem;
  position: relative;
  top: -3.8rem;
}

.recruit-voice-gp-item p {
  padding-left: 5rem;
}

.recruit-voice-gp.vs-02 {
  padding-left: 19.7rem;
}

.recruit-voice-gp.vs-02 .recruit-voice-gp-item:first-child {
  order: 1;
  padding-left: 11rem;
  width: calc(100% - 29.8rem);
}

.recruit-voice-gp.vs-02 .recruit-voice-gp-item:last-child {
  top: -1rem;
  width: 29.8rem;
}

.recruit-voice-gp.vs-03 {
  padding-right: 23rem;
}

.recruit-voice-gp.vs-03 .recruit-voice-gp-item:first-child {
  width: calc(100% - 37.3rem);
}

.recruit-voice-gp.vs-03 .recruit-voice-gp-item:last-child {
  width: 37.3rem;
}

.recruit-contact {
  max-width: 58rem;
  margin-left: auto;
  margin-right: auto;
}

.recruit-contact .recruit-title-02 {
  margin-right: 10.5rem;
  margin-top: .6rem;
}

.recruit-contact p {
  font-size: 1.8rem;
  line-height: 210%;
}

@media (max-width: 960px) {
  .wrap_banner.vs-recruit {
    height: 75rem;
    padding-top: 5.4rem;
    background-image: url(../img/recruit/banner-sp.jpg);
  }

  .wrap_banner.vs-recruit .dflex-aic {
    display: none;
  }

  .wrap_banner.vs-recruit .wrap_title--banner {
    padding-bottom: 16.3rem;
  }

  .wrap_banner.vs-recruit .wrap_banner-recruit p {
    font-size: 1.6rem;
    line-height: 187%;
    text-align: left;
    padding-right: 2.5rem;
  }

  .wrap_banner.vs-recruit .wrap_banner__line {
    display: none;
  }

  .recruit-title-01 {
    font-size: 3rem;
    margin-left: -1rem;
    margin-right: -1rem;
    letter-spacing: .25rem;
    padding: 1.6rem 4rem 2.9rem;
    line-height: 135%;
    margin-bottom: 3.2rem;
    background-image: url(../img/recruit/bg-boder-title-sp.png);
  }

  .recruit-title-02 {
    font-size: 3rem;
    margin-left: 6rem;
    margin-bottom: 5.8rem;
  }

  .recruit-title-02-vs-02 {
    margin-bottom: 7.3rem;
  }

  .recruit-title-03 {
    margin-bottom: 1.5rem;
  }

  .recruit-title-04 {
    margin-left: 2rem;
  }

  .recruit-title-04>span {
    font-size: 3rem;
    letter-spacing: .25rem;
    line-height: 140%;
  }

  .recruit-title-04>span:first-child {
    margin-bottom: 2.1rem;
  }

  .recruit-title-04>span.jp.u-pc {
    display: none;
  }

  .recruit-title-05 {
    padding-left: 0;
    padding-top: 7.5rem;
    text-align: center;
    margin-bottom: .6rem;
  }

  .recruit-title-05::before {
    top: 0;
    left: 50%;
    transform: translateX(-50%);
  }

  .recruit-title-06 {
    font-size: 2rem;
    padding-left: 0;
    line-height: 180%;
    margin-bottom: 1.2rem;
  }

  .recruit-title-06::before {
    content: none;
  }

  .recruit-gp-01 {
    margin-top: 0;
    padding-top: 9rem;
    padding-bottom: 7.5rem;
    margin-bottom: 0;
    background-image: url(../img/recruit/bg-02-sp.jpg);
  }

  .recruit-gp-02 {
    background: #FFFFFF;
    padding-top: 9.7rem;
    margin-bottom: 0;
  }

  .recruit-gp-03 {
    background: #FFFFFF;
    padding-top: 11rem;
    margin-bottom: 0;
    padding-bottom: 6.8rem;
  }

  .recruit-gp-03 .recruit-title-02 {
    margin-bottom: 9.3rem;
  }

  .recruit-gp-04 {
    background: #0071cd;
    padding-top: 7.7rem;
    padding-bottom: 6rem;
    margin-bottom: 0;
  }

  .job-gp-item:first-child {
    width: 100%;
    padding: 4.5rem 4rem 3.2rem 3rem;
  }

  .job-gp-item:first-child p {
    line-height: 185%;
  }

  .job-gp-item:last-child {
    width: 100%;
  }

  .recruit-block-gp {
    margin-bottom: 6rem;
  }

  .recruit-block-gp-item:first-child {
    width: 100%;
    padding: 0 0 4.5rem;
  }

  .recruit-block-gp-item:last-child {
    margin-top: 0;
    margin-left: -3rem;
    margin-right: -3rem;
    width: calc(100% + 6rem);
  }

  .recruit-block-gp:first-child {
    margin-bottom: 6rem;
  }

  .recruit-block-gp:first-child .recruit-block-gp-item:last-child {
    margin-bottom: 0;
  }

  .recruit-block-gp:last-child .recruit-block-gp-item:last-child {
    padding-bottom: 0;
  }

  .recruit-list-01 {
    margin-top: 3rem;
    margin-bottom: -1rem;
  }

  .recruit-list-01 li {
    border-left: 0;
    flex-wrap: wrap;
    padding-left: 0;
    padding-top: 2.5rem;
    padding-bottom: 3.5rem;
  }

  .recruit-list-01 li div {
    width: 100%;
    text-align: center;
  }

  .recruit-list-01 li p {
    margin-left: 0;
  }

  .recruit-voice-gp {
    padding: 0;
    margin-bottom: 5rem;
  }

  .recruit-voice-gp::before {
    content: none;
  }

  .recruit-voice-gp-item:first-child {
    width: 100%;
    order: 1;
  }

  .recruit-voice-gp-item:last-child {
    width: 22.4rem;
    top: 0;
    margin-left: auto;
    margin-right: auto;
  }

  .recruit-voice-gp-item p {
    padding-left: 0;
  }

  .recruit-voice-gp.vs-02 {
    margin-bottom: 6rem;
    padding-left: 0;
  }

  .recruit-voice-gp.vs-02 .recruit-voice-gp-item:first-child {
    width: 100%;
    padding-left: 0;
  }

  .recruit-voice-gp.vs-02 .recruit-voice-gp-item:last-child {
    top: 0;
    width: 17.1rem;
    margin-bottom: 1rem;
  }

  .recruit-voice-gp.vs-03 {
    padding-right: 0;
  }

  .recruit-voice-gp.vs-03 .recruit-voice-gp-item:first-child {
    width: 100%;
  }

  .recruit-voice-gp.vs-03 .recruit-voice-gp-item:last-child {
    width: 20.8rem;
    margin-bottom: 1.7rem;
  }

  .recruit-contact .recruit-title-02 {
    color: #FFFFFF;
    margin-bottom: 4.8rem;
  }

  .recruit-contact .recruit-title-02::before {
    background-image: url(../img/recruit/icon-01.png);
  }

  .recruit-contact p {
    color: #FFFFFF;
    padding-left: 2.5rem;
  }

  .wrap_contact_us.vs-03 {
    background: #FFFFFF;
    position: relative;
    overflow: hidden;
  }

  .wrap_contact_us.vs-03>div {
    background-color: transparent;
    padding: 6.5rem 0;
    overflow: initial;
  }

  .wrap_contact_us.vs-03 p {
    color: #333333;
  }

  .wrap_contact_us.vs-03 .title-default-01 {
    margin-bottom: 10.5rem;
  }

  .wrap_contact_us.vs-03 .title-default-01::before {
    background-image: url(../img/common/icon-title-01.png);
  }

  .wrap_contact_us.vs-03 .title-default-01 span.jp {
    color: #333333;
  }

  .wrap_contact_us.vs-03 .title-default-01 span.en {
    color: #187bf0;
  }

  .wrap_contact_us.vs-03 .wrap_contact_us--item:first-child {
    padding-bottom: 4rem;
  }

  .wrap_contact_us.vs-03 .wrap_banner__line {
    padding: 0;
    top: 4.5rem;
    bottom: auto;
  }

  .wrap_contact_us.vs-03 .wrap_tel_fax {
    box-shadow: 0.125rem 0.125rem 1.253rem rgba(224, 224, 224, 0.75);
  }

  .wrap_works.vs-02 {
    padding-top: 0;
    padding-bottom: 0;
  }
}

@media (max-width: 767px) {
  .wrap_contact_us.vs-03 .wrap_banner__line {
    top: 13.5rem;
  }
}

.bg_guide {
  width: 100%;
  position: relative;
  background-image: url(../img/common/bg.jpg);
  background-position: center top;
  background-repeat: repeat-y;
  background-attachment: fixed;
  background-size: 192rem;
}

.wrap_banner {
  width: 100%;
  height: 58.2rem;
  position: relative;
  overflow: hidden;
}

.wrap_banner__line {
  width: 100%;
  height: 29.3rem;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 1;
  opacity: 0;
  overflow: hidden;
  pointer-events: none;
}

.wrap_banner__line--mask {
  -webkit-mask-image: url(../img/common/line.png);
  -webkit-mask-position: left;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-clip: fill-box;
  -webkit-mask-size: 100vw;
  mask-image: url(../img/common/line.png);
  mask-position: left;
  mask-repeat: no-repeat;
  mask-clip: fill-box;
  mask-size: 100vw;
  height: 100%;
  position: relative;
  width: 0;
  animation-direction: normal;
  transition-property: width;
  transition-duration: 0s;
  transition-delay: 5s;
  will-change: width;
}

.wrap_banner__line--mask::before {
  display: block;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(90deg, #194fff 0%, #1a86ff 17%, #94d4f5 37%, #94d4f5 62%, #1a86ff 80%, #194fff 100%);
  z-index: 1;
}

.wrap_banner__line--glow {
  -webkit-mask-image: url(../img/common/line.png);
  -webkit-mask-position: left;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-clip: fill-box;
  -webkit-mask-size: 100vw;
  mask-image: url(../img/common/line.png);
  mask-position: left;
  mask-repeat: no-repeat;
  mask-clip: fill-box;
  mask-size: 100vw;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0;
}

.wrap_banner__line--glow::before {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: repeating-linear-gradient(135deg, #194fff 0%, rgba(255, 255, 255, 0.4) 10%, #194fff 16%, rgba(255, 255, 255, 0.4) 24%, #194fff 32%);
  background-size: 300% 300%;
  z-index: 1;
  -webkit-mask-image: linear-gradient(220deg, white 0%, white 10%, rgba(255, 255, 255, 0.5) 50%, rgba(255, 255, 255, 0.5) 100%);
  mask-image: linear-gradient(220deg, white 0%, white 10%, rgba(255, 255, 255, 0.5) 50%, rgba(255, 255, 255, 0.5) 100%);
}

.wrap_banner__line.active {
  animation: _opacity 500ms 0s linear forwards;
}

.wrap_banner__line.active .--mask {
  width: calc(100% + 1rem);
  transition: width 1.5s cubic-bezier(0.33, 1, 0.68, 1) 1.2s;
}

.wrap_banner__line.active .--glow {
  animation: _mask 1s ease-out 1.75s forwards;
}

.wrap_banner__line.active .--glow::before {
  animation: _mask_bg 1.5s ease-in-out 1.75s forwards 1, _glow_fade_out 300ms linear 3s forwards 1;
}

@keyframes _opacity {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

@keyframes _mask {
  50% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

@keyframes _mask_bg {
  0% {
    background-position: 100% 100%;
  }

  100% {
    background-position: 100% 0%;
  }
}

@keyframes _glow_fade_out {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

.wrap_breadcrumb li {
  color: #afafaf;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 170%;
  letter-spacing: 0;
  position: relative;
}

.wrap_breadcrumb li:not(:last-child) {
  padding-right: 2.6rem;
}

.wrap_breadcrumb li:not(:last-child)::before {
  content: "";
  position: absolute;
  width: 1.2rem;
  height: 1.5px;
  background-color: #afafaf;
  right: .7rem;
  top: 50%;
  transform: translateY(-50%);
}

.wrap_breadcrumb a {
  color: #afafaf;
  font-weight: 500;
}

.wrap_title--banner {
  margin-top: 1.8rem;
  padding-bottom: 4.5rem;
  color: #333333;
  font-size: 6.00002rem;
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0;
}

.wrap_title--banner .ja,
.wrap_title--banner .en {
  display: block;
  line-height: 140%;
}

.wrap_title--banner .en {
  font-weight: 500;
  color: #187bf0;
  font-size: 1.6rem;
}

.pd-bottom-100 {
  padding-bottom: 10rem;
}

.wrap_works {
  padding-top: 4.5rem;
}

.wrap_works-list {
  width: 100%;
  position: relative;
}

.wrap_works-list li:not(:last-child) {
  margin-right: 1.4rem;
}

.wrap_works-list a {
  border-radius: 6.3rem;
  padding: 1.6rem 2.58rem 1.8rem;
  background-color: #004098;
  display: block;
  color: #ffffff;
  font-size: 2rem;
  font-weight: 500;
  line-height: 130%;
  letter-spacing: 0;
}

.wrap_works-list--box {
  width: 100%;
  position: relative;
}

.wrap_works-list--box .title {
  width: 100%;
  position: relative;
  text-align: center;
  margin: 10rem 0 5rem;
}

.wrap_works-list--box .title span {
  border-radius: 6.3rem;
  padding: 1.6rem 2.58rem 1.8rem;
  display: inline-block;
  color: #ffffff;
  font-size: 2rem;
  font-weight: 500;
  line-height: 130%;
  letter-spacing: 0;
  background: #194FFF;
  background: linear-gradient(95deg, #194fff 0%, #1a86ff 18%, #1a86ff 80%, #194fff 100%);
}

.wrap_works-list--box .sub-title {
  margin-top: 1.2rem;
  margin-bottom: .7rem;
  color: #333333;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 150%;
  letter-spacing: 0;
}

.wrap_works-list--box .maps {
  padding-top: .5rem;
  padding-bottom: .5rem;
  padding-left: 3rem;
  background-image: url(../img/works/works--19.png);
  background-position: left center;
  background-repeat: no-repeat;
  background-size: 2.15rem;
  color: #333333;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 175%;
  letter-spacing: 0;
}

.wrap_works-list--box_group {
  margin-bottom: 13rem;
}

.wrap_works-list--box_group ul {
  display: flex;
  flex-wrap: wrap;
}

.wrap_works-list--box_group li {
  width: calc((100% - 6.502rem) / 2);
  margin-right: 6.5rem;
  margin-bottom: 4.6rem;
}

.wrap_works-list--box_group li:nth-child(2n),
.wrap_works-list--box_group li:last-child {
  margin-right: 0;
}

.wrap_contact_us {
  width: 100%;
}

.wrap_contact_us .title-default-01 {
  margin-left: 0;
  padding-left: 5.1rem;
  margin-bottom: 4.4rem;
}

.wrap_contact_us .title-default-01::before {
  top: calc(50% + .8rem);
  background-image: url(../img/common/icon-title-01-w.png);
}

.wrap_contact_us .title-default-01>span {
  color: #ffffff;
}

.wrap_contact_us .title-default-01>span:last-child {
  font-size: 2.00001rem;
  padding-left: .5rem;
  margin-top: -0.5rem;
}

.wrap_contact_us p {
  color: #ffffff;
  line-height: 195%;
}

.wrap_contact_us>div {
  background-color: #004098;
  border-radius: 1.2rem;
  overflow: hidden;
  padding: 10rem 9.5rem 10rem 15.3rem;
}

.wrap_contact_us--item {
  width: 79.8rem;
}

.wrap_contact_us--item:first-child {
  padding-bottom: 2.4rem;
  width: calc(100% - 79.8rem);
}

.wrap_contact_us .wrap_tel_fax {
  width: 100%;
  height: 28.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border-radius: 1.2rem;
  background-color: #ffffff;
}

.wrap_contact_us .wrap_tel_fax a {
  padding-left: 5.8rem;
  line-height: 150%;
  font-size: 4.5rem;
  font-weight: 500;
  display: inline-block;
  background-image: url(../img/common/icon-tel.png);
  background-position: left center;
  background-repeat: no-repeat;
  background-size: 4.3rem;
}

.wrap_contact_us .wrap_tel_fax p {
  padding-left: 5.9rem;
  color: #333333;
  font-size: 1.4rem;
  font-weight: 500;
}

.wrap_contact_us .wrap_tel_fax p.mt--10 {
  margin-top: -1rem;
  margin-bottom: .5rem;
  letter-spacing: .16rem;
  font-feature-settings: inherit;
}

.wrap_contact_us .wrap_tel_fax p strong {
  font-weight: 500;
  font-size: 2.40001rem;
  margin-left: -0.1rem;
}

@media (max-width: 960px) {

  .wrap_banner__line--glow,
  .wrap_banner__line--mask {
    -webkit-mask-image: url(../img/common/line-02.png);
    mask-image: url(../img/common/line-02.png);
  }

  .bg_guide {
    background-image: url(../img/common/bg-sp.png);
    background-attachment: inherit;
    background-size: contain;
  }

  .wrap_banner {
    height: 30rem;
  }

  .wrap_banner__line {
    height: 9.1rem;
  }
}

@media (max-width: 960px) and (min-width: 767.5px) {
  .wrap_banner__line {
    height: 18rem;
  }
}

@media (max-width: 960px) {
  .wrap_title--banner {
    margin-top: 1.6rem;
    padding-bottom: 0;
    font-size: 3rem;
  }

  .wrap_title--banner .en {
    margin-top: .8rem;
  }

  .wrap_works {
    padding-top: 4.8rem;
  }

  .wrap_works-list li {
    width: 100%;
  }

  .wrap_works-list li:not(:last-child) {
    margin-right: 0rem;
    margin-bottom: 1.5rem;
  }

  .wrap_works-list a {
    font-size: 1.6rem;
  }

  .wrap_works-list--box {
    margin-top: 10rem;
  }

  .wrap_works-list--box .title {
    margin-top: 0;
    margin-bottom: 4rem;
  }

  .wrap_works-list--box .title span {
    font-size: 1.8rem;
    line-height: 150%;
  }

  .wrap_works-list--box_group {
    margin-bottom: 6rem;
  }

  .wrap_works-list--box_group li {
    width: 100%;
    margin-right: 0;
    margin-bottom: 3.6rem;
  }

  .wrap_contact_us {
    padding-left: 3rem;
    padding-right: 3rem;
  }

  .wrap_contact_us .title-default-01 {
    margin-left: 1.5rem;
    padding-left: 4.1rem;
    margin-bottom: 3rem;
  }

  .wrap_contact_us .title-default-01::before {
    top: 50%;
    width: 1.3rem;
    height: 6.7rem;
  }

  .wrap_contact_us .title-default-01 span.jp {
    font-size: 3rem;
  }

  .wrap_contact_us .title-default-01 span.en {
    font-size: 1.6rem;
    margin-top: 0rem;
    padding-left: 0;
  }

  .wrap_contact_us p {
    color: #ffffff;
    line-height: 195%;
  }

  .wrap_contact_us>div {
    border-radius: 2rem;
    padding: 5rem 2rem;
  }

  .wrap_contact_us--item {
    width: 100%;
  }

  .wrap_contact_us--item:first-child {
    padding-bottom: 3.2rem;
    width: 100%;
  }

  .wrap_contact_us .wrap_tel_fax {
    height: auto;
    padding: 7.2rem 2rem;
    border-radius: 2rem;
  }

  .wrap_contact_us .wrap_tel_fax>div {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-flow: column;
  }

  .wrap_contact_us .wrap_tel_fax a {
    padding-left: 4.8rem;
    font-size: 3rem;
  }

  .wrap_contact_us .wrap_tel_fax p {
    padding-left: 0;
    font-size: 1.3rem;
    letter-spacing: -0.02rem;
  }

  .wrap_contact_us .wrap_tel_fax p.mt--10 {
    margin-top: 0;
    margin-bottom: .6rem;
    letter-spacing: .17rem;
  }

  .wrap_contact_us .wrap_tel_fax p strong {
    font-size: 2.4rem;
  }

  .wrap_contact_us .wrap_banner__line {
    border-radius: 0;
  }
}