.txt-a {
  position: relative;
  box-sizing: border-box;
  border: solid 2px #ffffff;
  background: #2D3139;
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 17.4479166667vw;
  height: 4.1666666667vw;
  border-radius: 4.1666666667vw;
  margin: 0 auto;
  gap: 0.8vw;
  transition: 1s;
}
.txt-a svg {
  position: absolute;
  top: 50%;
  right: 1.8229166667vw;
  transform: translateY(-50%);
  display: flex;
  width: 0.8333333333vw;
  height: 0.8333333333vw;
}
.txt-a svg path {
  transition: 1s;
  fill: #3C5DFF;
}
.txt-a:hover {
  background: #ffffff;
  color: #1B1D22;
}

.ttl-box {
  margin-bottom: 4.1666666667vw;
}
.ttl-box .txt-h2 {
  color: #9DAEFF;
  line-height: 1;
}
.ttl-box .txt-h2 .txt-e {
  color: #ffffff;
  display: block;
  line-height: 1;
  margin-bottom: 1.8vw;
}

@media screen and (max-width: 767px) {
  .txt-a {
    width: 100%;
    height: 50px;
    border-radius: 50px;
    gap: 10px;
    margin: 0 auto;
    font-size: 16px;
  }
  .txt-a span {
    font-size: 16px;
  }
  .txt-a svg {
    width: 14px;
    height: 14px;
    right: 20px;
  }
  .txt-a svg path {
    transition: 1s;
  }
  .txt-a:hover {
    background: #ffffff;
    color: #000000;
  }
  .txt-a:hover svg path {
    fill: #000000;
  }
  .ttl-box {
    margin-bottom: 50px;
  }
  .ttl-box .txt-h2 {
    font-size: 14px;
  }
  .ttl-box .txt-h2 .txt-e {
    font-size: 38px;
    margin-bottom: 10px;
  }
}
/*==========================================================================
section#mv_area
========================================================================== */
section#mv_area {
  position: relative;
}
section#mv_area .img-box {
  position: relative;
  width: 100%;
  height: 100svh;
  overflow: hidden;
  z-index: 1;
  transform: scale(1);
}
section#mv_area .img-box::before {
  content: "";
  background: rgba(0, 0, 0, 0.5);
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
}
section#mv_area .txt-box {
  position: absolute;
  z-index: 3;
  box-sizing: border-box;
  left: 5.2083333333vw;
  bottom: 5.2083333333vw;
}
section#mv_area .txt-box .txt-h1 {
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
}
section#mv_area .txt-box .txt-h1 .item {
  display: block;
  color: #ffffff;
}

body:not(.loading) section#mv_area .img-box img {
  -webkit-animation: fadeInScale 1.5s ease-out 0.3s forwards, slowZoom 15s linear 1.8s forwards;
  animation: fadeInScale 1.5s ease-out 0.3s forwards, slowZoom 15s linear 1.8s forwards;
}

@-webkit-keyframes slowZoom {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.1);
  }
}

@keyframes slowZoom {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.1);
  }
}
@-webkit-keyframes fadeInScale {
  from {
    opacity: 0;
    transform: scale(1.1);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes fadeInScale {
  from {
    opacity: 0;
    transform: scale(1.1);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
@media screen and (max-width: 767px) {
  section#mv_area {
    position: relative;
  }
  section#mv_area .img-box {
    position: relative;
    width: 100%;
    height: 90svh;
    overflow: hidden;
    z-index: 1;
  }
  section#mv_area .img-box img {
    -o-object-position: right;
       object-position: right;
  }
  section#mv_area .img-box::before {
    content: "";
    background: rgba(0, 0, 0, 0.5);
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 1;
  }
  section#mv_area .txt-box {
    position: absolute;
    z-index: 3;
    box-sizing: border-box;
    left: 10%;
    bottom: 40%;
    transform: translateY(50%);
  }
  section#mv_area .txt-box .txt-h1 {
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
  }
  section#mv_area .txt-box .txt-h1 .item {
    display: block;
    color: #ffffff;
    font-size: 18px;
  }
  section#mv_area .txt-box .txt-h1 .item.txt-j {
    font-size: 40px;
    margin-bottom: 20px;
  }
}
/*==========================================================================
section#about_area
========================================================================== */
section#about_area {
  position: relative;
  background: #2D3139;
}
section#about_area .inner {
  padding-top: 7.8125vw;
  position: relative;
}
section#about_area .box {
  position: relative;
  justify-content: space-between;
  align-items: flex-end;
}
section#about_area .txt-box {
  position: relative;
  margin-bottom: 5.2083333333vw;
}
section#about_area .txt-box .txt-h3 {
  margin: 0;
  color: #ffffff;
  margin-bottom: 1.5vw;
}
section#about_area .txt-box .txt-p {
  color: #ffffff;
  line-height: 1.8em;
}
section#about_area .txt-box .txt-a {
  margin: 0;
  position: absolute;
  right: 0;
  bottom: 0;
}
section#about_area .img-box {
  width: 100%;
  height: 33vw;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  section#about_area .inner {
    padding-top: 80px;
  }
  section#about_area .box {
    position: relative;
    justify-content: space-between;
    align-items: flex-end;
  }
  section#about_area .txt-box {
    position: relative;
    margin-bottom: 80px;
  }
  section#about_area .txt-box .txt-h3 {
    margin-bottom: 30px;
    font-size: 20px;
  }
  section#about_area .txt-box .txt-p {
    font-size: 14px;
  }
  section#about_area .txt-box .txt-a {
    margin: 0;
    margin-top: 50px;
    position: relative;
    bottom: initial;
    right: initial;
  }
  section#about_area .txt-box .txt-a svg {
    width: 14px;
    height: 14px;
  }
  section#about_area .img-box {
    width: 98%;
    height: 33vw;
    margin: 0 auto;
  }
}
/*==========================================================================
section#service_area
========================================================================== */
section#service_area {
  position: relative;
  background: #2D3139;
}
section#service_area .inner {
  padding: 7.8125vw 0;
}
section#service_area .ttl-box {
  margin: 0 auto;
  margin-bottom: 4.1666666667vw;
}
section#service_area .ttl-box .txt-h2 {
  text-align: center;
}
section#service_area .box {
  position: relative;
}
section#service_area .box::before {
  content: "";
  background: #1B1D22;
  width: 100%;
  height: calc(100% - 6.25vw - 6.25vw);
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: -1;
}
section#service_area .items {
  position: relative;
  box-sizing: border-box;
  padding-top: 2.6041666667vw;
}
section#service_area .items .txt-box {
  background: #ffffff;
  padding: 3.3854166667vw 0;
  box-sizing: border-box;
  min-height: 31.3020833333vw;
  border-radius: 5.2083333333vw;
}
section#service_area .items .txt-box .in {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
section#service_area .items .txt-box .txt-h3 {
  color: #000000;
  margin-bottom: 2.6041666667vw;
}
section#service_area .items .txt-box .txt-h3 .txt-e {
  display: block;
  color: #9DAEFF;
  margin-bottom: 1vw;
}
section#service_area .items .txt-box .txt-p {
  color: #000000;
  line-height: 1.8em;
}
section#service_area .items .txt-box .txt-a {
  margin: 0;
  margin-top: 2.6041666667vw;
  border-color: #2D3139;
}
section#service_area .items .img-box {
  position: absolute;
  left: 0;
  top: 0;
  width: 46.875vw;
  height: 30.5208333333vw;
  z-index: 1;
  overflow: clip;
}
section#service_area .items.top-box {
  margin: 0;
  justify-content: flex-end;
}
section#service_area .items.top-box .txt-box {
  padding-left: 38vw;
  padding-right: 3.90625vw;
}
section#service_area .items.top-box .img-box {
  border-radius: 0 2.6041666667vw 2.6041666667vw 0;
}
section#service_area .items.top-box .img-box img {
  -o-object-position: left;
     object-position: left;
}
section#service_area .items.bot-box {
  margin: 0;
  margin-top: 4.1666666667vw;
  justify-content: flex-start;
}
section#service_area .items.bot-box .txt-box {
  padding-right: 38vw;
  padding-left: 3.90625vw;
}
section#service_area .items.bot-box .img-box {
  left: initial;
  right: 0;
  border-radius: 2.6041666667vw 0 0 2.6041666667vw;
}

@media screen and (max-width: 767px) {
  section#service_area .inner {
    padding: 100px 0;
  }
  section#service_area .ttl-box {
    margin-bottom: 60px;
  }
  section#service_area .items {
    position: relative;
    box-sizing: border-box;
    padding-top: 80px;
  }
  section#service_area .items .txt-box {
    width: 80%;
    padding: 30px 0;
    min-height: initial;
    border-radius: 20px;
    z-index: 2;
    position: relative;
    background: rgba(255, 255, 255, 0.9);
  }
  section#service_area .items .txt-box .txt-h3 {
    font-size: 20px;
    margin-bottom: 20px;
  }
  section#service_area .items .txt-box .txt-h3 .txt-e {
    font-size: 14px;
    margin-bottom: 5px;
  }
  section#service_area .items .txt-box .txt-p {
    font-size: 14px;
  }
  section#service_area .items .txt-box .txt-a {
    margin-top: 30px;
  }
  section#service_area .items .img-box {
    position: absolute;
    left: 0;
    top: 0;
    width: 80%;
    height: calc(100% - 30px);
    z-index: 1;
    overflow: clip;
  }
  section#service_area .items.top-box {
    margin: 0;
    justify-content: flex-end;
  }
  section#service_area .items.top-box .txt-box {
    padding-left: 30px;
    padding-right: 30px;
    margin-right: 0;
    border-radius: 20px 0 0 20px;
  }
  section#service_area .items.top-box .img-box {
    border-radius: 0 20px 20px 0;
  }
  section#service_area .items.bot-box {
    margin: 0;
    margin-top: 80px;
    justify-content: flex-start;
  }
  section#service_area .items.bot-box .txt-box {
    padding-left: 30px;
    padding-right: 30px;
    margin-left: 0;
    border-radius: 0 20px 20px 0;
  }
  section#service_area .items.bot-box .img-box {
    left: initial;
    right: 0;
    border-radius: 20px 0 0 20px;
  }
}
/*==========================================================================
section#recruit_area
========================================================================== */
section#recruit_area {
  position: relative;
}
section#recruit_area .inner {
  position: relative;
  z-index: 1;
  box-sizing: border-box;
  padding: 5.2083333333vw 0;
}
section#recruit_area .ttl-box {
  margin-left: 11.975%;
  margin-bottom: 3.125vw;
}
section#recruit_area .ttl-box .txt-h2 {
  color: #3C5DFF;
}
section#recruit_area .ttl-box .txt-h2 .txt-e {
  color: #3C5DFF;
}
section#recruit_area .img-box {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
section#recruit_area .txt-box .txt-h3 {
  margin-bottom: 1.5625vw;
}
section#recruit_area .txt-box .txt-p {
  line-height: 1.8em;
}
section#recruit_area .txt-box .txt-a {
  margin: 0;
  margin-top: 2.6041666667vw;
  background: #3C5DFF;
  border-color: #3C5DFF;
}
section#recruit_area .txt-box .txt-a svg path {
  fill: #ffffff;
}
section#recruit_area .txt-box .txt-a:hover {
  background: #ffffff;
  color: #3C5DFF;
}
section#recruit_area .txt-box .txt-a:hover svg path {
  fill: #3C5DFF;
}
section#recruit_area .link-box {
  width: 100%;
  margin-top: 3.125vw;
  align-items: center;
  justify-content: center;
  gap: 6.25vw;
}
section#recruit_area .link-box .txt-t {
  color: #ffffff;
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 0.5vw;
  line-height: 1;
  pointer-events: none;
}
section#recruit_area .link-box .txt-t svg {
  display: flex;
  width: 2.7083333333vw;
  height: 2.6041666667vw;
}
section#recruit_area .link-box .txt-t svg path {
  fill: #ffffff;
}
section#recruit_area .link-box .txt-l {
  width: 23.4375vw;
  height: 5.2083333333vw;
  border: solid 2px #ffffff;
  background: #ffffff;
  color: #2D3139;
  border-radius: 5.2083333333vw;
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  transition: 1s;
  gap: 1.05vw;
}
section#recruit_area .link-box .txt-l svg {
  display: flex;
  width: 2.2760416667vw;
  height: 1.4583333333vw;
}
section#recruit_area .link-box .txt-l svg path {
  transition: 1s;
  fill: #1B1D22;
}
section#recruit_area .link-box .txt-l:hover {
  background: #1B1D22;
  color: #ffffff;
}
section#recruit_area .link-box .txt-l:hover svg path {
  fill: #ffffff;
}

@media screen and (max-width: 767px) {
  section#recruit_area {
    position: relative;
  }
  section#recruit_area .inner {
    position: relative;
    z-index: 1;
    box-sizing: border-box;
    padding: 100px 0;
  }
  section#recruit_area .ttl-box {
    margin-bottom: 60px;
    margin-left: 7.5%;
  }
  section#recruit_area .ttl-box .txt-h2 {
    color: #3C5DFF;
  }
  section#recruit_area .ttl-box .txt-h2 .txt-e {
    color: #3C5DFF;
  }
  section#recruit_area .img-box {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
  }
  section#recruit_area .txt-box .txt-h3 {
    font-size: 20px;
    margin-bottom: 30px;
  }
  section#recruit_area .txt-box .txt-p {
    font-size: 14px;
  }
  section#recruit_area .txt-box .txt-a {
    margin-top: 50px;
  }
  section#recruit_area .link-box {
    width: 100%;
    margin-top: 3.125vw;
    align-items: center;
    justify-content: center;
    gap: 6.25vw;
  }
  section#recruit_area .link-box .txt-t {
    color: #ffffff;
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 0.5vw;
    line-height: 1;
    pointer-events: none;
  }
  section#recruit_area .link-box .txt-t svg {
    display: flex;
    width: 2.7083333333vw;
    height: 2.6041666667vw;
  }
  section#recruit_area .link-box .txt-t svg path {
    fill: #ffffff;
  }
  section#recruit_area .link-box .txt-l {
    width: 23.4375vw;
    height: 5.2083333333vw;
    border: solid 2px #ffffff;
    background: #ffffff;
    color: #2D3139;
    border-radius: 5.2083333333vw;
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    transition: 1s;
    gap: 1.05vw;
  }
  section#recruit_area .link-box .txt-l svg {
    display: flex;
    width: 2.2760416667vw;
    height: 1.4583333333vw;
  }
  section#recruit_area .link-box .txt-l svg path {
    transition: 1s;
    fill: #1B1D22;
  }
  section#recruit_area .link-box .txt-l:hover {
    background: #1B1D22;
    color: #ffffff;
  }
  section#recruit_area .link-box .txt-l:hover svg path {
    fill: #ffffff;
  }
}
/*==========================================================================
section#news_area
========================================================================== */
section#news_area {
  background: #2D3139;
}
section#news_area .inner {
  padding: 7.8125vw 0;
}
section#news_area .box {
  align-items: center;
  justify-content: space-between;
  gap: 7.8125vw;
}
section#news_area .ttl-box {
  flex: none;
  margin: 0;
}
section#news_area .ttl-box .txt-a {
  margin-top: 2.6041666667vw;
}
section#news_area .list-box {
  flex: auto;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
}
section#news_area .list-box .txt-d {
  line-height: 1;
  transition: 1s;
  color: #ffffff;
}
section#news_area .list-box .txt-h3 {
  line-height: 1;
  transition: 1s;
  color: #ffffff;
}
section#news_area .list-box svg {
  width: 0.8vw;
  height: 0.8vw;
  transition: 1s;
  position: absolute;
  right: 1.8229166667vw;
  top: 50%;
  transform: translateY(-50%);
}
section#news_area .list-box svg path {
  transition: 1s;
  fill: #9DAEFF;
}
section#news_area .list-box a {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  color: #ffffff;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  padding: 1.5625vw;
  gap: 2.6041666667vw;
  border-bottom: solid 1px #ffffff;
  position: relative;
  line-height: 1;
}
section#news_area .list-box a:hover svg {
  right: 1vw;
}
section#news_area .list-box li {
  width: 100%;
  line-height: 1;
}
section#news_area .list-box li:first-child a {
  border-top: solid 1px #ffffff;
}

@media screen and (max-width: 767px) {
  section#news_area .inner {
    padding: 100px 0;
  }
  section#news_area .box {
    align-items: center;
    justify-content: space-between;
    gap: 7.8125vw;
  }
  section#news_area .ttl-box {
    flex: none;
    margin: 0;
    margin-bottom: 60px;
  }
  section#news_area .ttl-box .txt-a {
    margin-top: 50px;
  }
  section#news_area .list-box {
    flex: auto;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0;
    height: -webkit-fit-content;
    height: -moz-fit-content;
    height: fit-content;
  }
  section#news_area .list-box .txt-d {
    font-size: 10px;
    width: 100%;
  }
  section#news_area .list-box .txt-h3 {
    font-size: 14px;
  }
  section#news_area .list-box svg {
    width: 16px;
    height: 16px;
    right: 20px;
  }
  section#news_area .list-box a {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    color: #ffffff;
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    padding: 35px 20px;
    gap: 10px;
    border-bottom: solid 1px #ffffff;
    position: relative;
    line-height: 1;
  }
  section#news_area .list-box a:hover svg {
    right: 10px;
  }
  section#news_area .list-box li {
    width: 100%;
    line-height: 1;
  }
  section#news_area .list-box li:first-child a {
    border-top: solid 1px #ffffff;
  }
}
/*# sourceMappingURL=top.css.map */