@charset "UTF-8";
/*======================================
    Font / Color
======================================*/
/*======================================
    common
======================================*/
html {
  font-size: 62.5%;
}

body {
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  color: #000;
  background-color: #fff;
}

.main {
  margin-top: 98px;
}

@media screen and (max-width: 768px) {
  .main {
    margin-top: 80px;
  }
}

a {
  text-decoration: none;
  color: inherit;
}

a:hover {
  cursor: pointer;
}

@media (min-width: 768px) {
  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
  }
}

img {
  width: 100%;
}

.btn {
  display: inline-block;
  font-size: clamp(1.4rem, 1.45833vw, 2.1rem);
  font-weight: 700;
  letter-spacing: 0.1em;
  background-color: #0960C8;
  border: 1px solid #0960C8;
  width: clamp(180px, 15.41667vw, 222px);
  max-width: 95%;
  padding: 0.9em 0;
  text-align: center;
  border-radius: 29px;
  color: #fff;
  overflow: hidden;
  position: relative;
  z-index: 1;
  -webkit-transition: color .3s ease;
  transition: color .3s ease;
}

@media screen and (min-width: 1440px) {
  .btn {
    width: max(222 / 1920 * 100vw, 222px);
    font-size: max(21 / 1920 * 100vw, 2.1rem);
  }
}

@media screen and (max-width: 768px) {
  .btn {
    width: 222px;
  }
}

.btn::before {
  content: "";
  position: absolute;
  width: 0;
  height: 100%;
  top: 0;
  right: 0;
  z-index: -1;
  background-color: #fff;
  -webkit-transition: left .3s ease-out, width .3s ease-out;
  transition: left .3s ease-out, width .3s ease-out;
}

.btn:hover {
  color: #0960C8;
  opacity: 1;
}

.btn:hover::before {
  left: 0;
  width: 100%;
}

.btn.-white {
  background-color: #fff;
  color: #0960C8;
  border: 1px solid #fff;
  width: clamp(180px, 16.59722vw, 239px);
}

@media screen and (min-width: 1440px) {
  .btn.-white {
    width: max(239 / 1920 * 100vw, 239px);
  }
}

@media screen and (max-width: 768px) {
  .btn.-white {
    width: 239px;
  }
}

.btn.-white::before {
  background-color: #0960C8;
}

.btn.-white:hover {
  color: #fff;
}

.is-nowrap {
  white-space: nowrap;
}

/*======================================
    section共通
======================================*/
.section__title {
  display: inline-block;
  background-color: #fff;
  font-size: clamp(1.4rem, 1.5625vw, 3rem);
  line-height: 1.76667;
  font-weight: 700;
  padding-left: 0.5em;
}

@media screen and (min-width: 1440px) {
  .section__title {
    font-size: max(30 / 1920 * 100vw, 3rem);
  }
}

.section__title--en {
  display: block;
  font-family: "Gill Sans", "Gill Sans MT", "Calibri", sans-serif;
  color: #0960C8;
  font-weight: 600;
  line-height: 1.07692;
  font-size: 3.9em;
  letter-spacing: 0.0875em;
  margin-left: -0.12em;
  margin-top: 0.1em;
}

@media screen and (max-width: 768px) {
  .section__title--en {
    font-size: calc(30 / 375 * 100vw);
  }
}

.page-mv {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: max(455 / 1920 * 100vw, 300px);
  position: relative;
}

.page-mv::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(9, 96, 200, 0.1);
}

.page-title {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -62%);
          transform: translate(-50%, -62%);
  font-size: clamp(3.2rem, 4.16667vw, 6rem);
  font-weight: 700;
  line-height: 1.25;
  color: #fff;
  text-shadow: 0 0 5px rgba(81, 81, 81, 0.75);
  text-align: center;
  white-space: nowrap;
  z-index: 2;
}

@media screen and (min-width: 1440px) {
  .page-title {
    font-size: max(60 / 1920 * 100vw, 6rem);
  }
}

.page-title span {
  font-family: "Gill Sans", "Gill Sans MT", "Calibri", sans-serif;
  display: block;
  font-size: 0.83em;
  font-weight: 600;
  letter-spacing: 0.1em;
  margin-bottom: 0.1em;
}

/*======================================
    header
======================================*/
.header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 300;
}

.header__inner {
  padding: 0 calc(66 / 1920 * 100vw) 0 calc(116 / 1920 * 100vw);
  height: 98px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #fff;
}

@media screen and (max-width: 768px) {
  .header__inner {
    height: 80px;
  }
}

.header-logo {
  width: 278px;
  -webkit-transform: translateY(10%);
          transform: translateY(10%);
}

@media screen and (max-width: 1199px) {
  .header-logo {
    width: 220px;
  }
}

.header__nav--container {
  margin-left: auto;
}

@media screen and (max-width: 768px) {
  .header__nav--container {
    display: none;
  }
}

.header__nav--links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 2.5rem;
}

@media screen and (max-width: 1439px) {
  .header__nav--links {
    font-size: calc(25 / 1440 * 100vw);
  }
}

.header__nav--link a {
  display: inline-block;
  color: #182986;
  font-weight: bold;
  padding: 0.22em 1.75em;
  letter-spacing: 0.05em;
  -webkit-transition: opacity .3s ease;
  transition: opacity .3s ease;
}

.header__nav--link a:hover {
  opacity: 0.7;
}

.header__nav--link:first-child a {
  padding-right: 2em;
}

.header__nav--link:nth-child(-n + 2) {
  border-right: 1px solid #182986;
}

.header__nav--link.-contact a {
  margin-top: 0.15em;
  margin-left: 1em;
  overflow: hidden;
  background-color: #0960C8;
  color: #fff;
  padding: 0.35em 1.2em;
  letter-spacing: 0.05em;
  border-radius: 23px;
  border: 2px solid #0960C8;
  position: relative;
  z-index: 1;
  -webkit-transition: color .3s ease;
  transition: color .3s ease;
}

.header__nav--link.-contact a::before {
  content: "";
  position: absolute;
  width: 0;
  height: 100%;
  top: 0;
  right: 0;
  z-index: -1;
  background-color: #fff;
  -webkit-transition: left .3s ease-out, width .3s ease-out;
  transition: left .3s ease-out, width .3s ease-out;
}

.header__nav--link.-contact a:hover {
  color: #0960C8;
  opacity: 1;
}

.header__nav--link.-contact a:hover::before {
  left: 0;
  width: 100%;
}

/*======================================
    drawer
======================================*/
.drawer-icon {
  position: fixed;
  top: 40px;
  right: calc(60 / 1080 * 100vw);
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  z-index: 350;
  display: none;
  -webkit-transition: -webkit-transform .5s ease 0s;
  transition: -webkit-transform .5s ease 0s;
  transition: transform .5s ease 0s;
  transition: transform .5s ease 0s, -webkit-transform .5s ease 0s;
}

@media screen and (max-width: 768px) {
  .drawer-icon {
    display: block;
  }
}

.drawer-icon.is-active .drawer-icon-bar1 {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  top: 8px;
}

.drawer-icon.is-active .drawer-icon-bar2 {
  opacity: 0;
}

.drawer-icon.is-active .drawer-icon-bar3 {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  top: 8px;
}

.drawer-icon-bars {
  width: 40px;
  height: 20px;
  position: relative;
}

.drawer-icon-bar1,
.drawer-icon-bar2,
.drawer-icon-bar3 {
  position: absolute;
  width: 40px;
  height: 4px;
  background: #0960C8;
  top: 0;
  left: 0;
  -webkit-transition: top .5s ease, opacity .2s ease, -webkit-transform .5s ease;
  transition: top .5s ease, opacity .2s ease, -webkit-transform .5s ease;
  transition: transform .5s ease, top .5s ease, opacity .2s ease;
  transition: transform .5s ease, top .5s ease, opacity .2s ease, -webkit-transform .5s ease;
}

.drawer-icon-bar1 {
  top: 0;
}

.drawer-icon-bar2 {
  top: 8px;
}

.drawer-icon-bar3 {
  top: 16px;
}

.header__drawer--container {
  position: fixed;
  top: 0;
  right: 0;
  font-size: 1.6rem;
  width: 100%;
  z-index: 299;
  -webkit-transform: translateX(105%);
          transform: translateX(105%);
  opacity: 0;
  -webkit-transition: opacity .5s ease, -webkit-transform .5s ease;
  transition: opacity .5s ease, -webkit-transform .5s ease;
  transition: transform .5s ease, opacity .5s ease;
  transition: transform .5s ease, opacity .5s ease, -webkit-transform .5s ease;
}

.header__drawer--container.is-active {
  opacity: 1;
  -webkit-transform: translateX(0);
          transform: translateX(0);
}

@media screen and (min-width: 1440px) {
  .header__drawer--container {
    display: none;
  }
}

@media screen and (max-width: 1439px) {
  .header__drawer--container {
    display: none;
  }
}

@media screen and (max-width: 768px) {
  .header__drawer--container {
    display: block;
  }
}

.header__drawer--lists {
  padding-top: 80px;
}

.header__drawer--list__link {
  display: block;
  padding: 1.5em 1em 1.5em 2em;
  font-weight: 700;
  -webkit-transition: opacity .3s ease;
  transition: opacity .3s ease;
  border-bottom: 1px solid rgba(9, 96, 200, 0.5);
}

.header__drawer--list__link:hover {
  opacity: 0.7;
}

.header__drawer--sublist__link {
  display: block;
  font-size: 0.75em;
  padding: 0.5em 1em 0.5em 2em;
}

.drawer-background {
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  z-index: 298;
  background-color: #D9E8F6;
  -webkit-transform: translateX(105%);
          transform: translateX(105%);
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  opacity: 0;
  -webkit-transition: opacity .5s ease, -webkit-transform .5s ease;
  transition: opacity .5s ease, -webkit-transform .5s ease;
  transition: transform .5s ease, opacity .5s ease;
  transition: transform .5s ease, opacity .5s ease, -webkit-transform .5s ease;
}

.drawer-background.is-active {
  opacity: 1;
  -webkit-transform: translateX(0);
          transform: translateX(0);
}

.drawer__line--link {
  background-color: #06C755;
  border-radius: 10px;
  padding: 7px 10px;
  display: block;
  -webkit-transition: opacity .3s ease;
  transition: opacity .3s ease;
  width: 80%;
  margin: 20px auto 0;
  transition: opacity .3s ease;
}

.drawer__line--link:hover {
  opacity: 0.7;
}

/*======================================
    TOP
======================================*/
.mv__container {
  position: relative;
  padding-bottom: calc(116 / 1920 * 100vw);
}

.mv__bg--container {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 70%;
  background-color: #0960C8;
}

.mv__contents {
  position: relative;
}

.mv__text {
  position: absolute;
  top: 0;
  right: 50%;
  z-index: 2;
  width: 44.74%;
  color: #fff;
  font-weight: 700;
  font-size: clamp(1.8rem, 4.44444vw, 6rem);
  line-height: 1.74667;
  letter-spacing: 0.2em;
  -webkit-transform: translate(113%, calc(-50% - 2px));
          transform: translate(113%, calc(-50% - 2px));
}

@media screen and (min-width: 1440px) {
  .mv__text {
    font-size: max(70 / 1920 * 100vw, 6rem);
  }
}

@media screen and (max-width: 768px) {
  .mv__text {
    -webkit-transform: translate(110%, calc(-50% - 1px));
            transform: translate(110%, calc(-50% - 1px));
  }
}

.mv__text--line {
  display: block;
  border-bottom: 3px solid #fff;
  padding-left: 0.2em;
  margin-left: -0.2em;
  padding-bottom: 0.1em;
}

@media screen and (max-width: 768px) {
  .mv__text--line {
    border-bottom: 1px solid #fff;
  }
}

.mv__img {
  width: 86.7708%;
  margin: 0 auto;
  background-color: #fff;
  position: relative;
}

.mv__img::before {
  content: "";
  display: block;
  padding-top: calc(814 / 1666 * 100%);
}

.mv__img img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  -webkit-animation: animationZoom2 15s ease-in-out infinite;
          animation: animationZoom2 15s ease-in-out infinite;
  opacity: 0;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.zoom {
  overflow: hidden;
}

@-webkit-keyframes animationZoom2 {
  10% {
    opacity: 1;
  }
  90% {
    opacity: 1;
  }
  100% {
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
  }
}

@keyframes animationZoom2 {
  10% {
    opacity: 1;
  }
  90% {
    opacity: 1;
  }
  100% {
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
  }
}

.mv__lead--container {
  text-align: center;
  padding: 4.55em 1em 5.1em;
  font-size: clamp(1.4rem, 2.43056vw, 3rem);
  background: url(../img/top/mv-lead.jpg) no-repeat center top 55%/cover;
}

@media screen and (min-width: 1440px) {
  .mv__lead--container {
    font-size: max(30 / 1920 * 100vw, 3rem);
  }
}

@media screen and (max-width: 768px) {
  .mv__lead--container {
    padding: 3em 1em;
  }
}

.mv__lead {
  color: #231815;
  font-weight: 700;
  line-height: 2.06667;
  letter-spacing: 0.2em;
}

/*======================================
    TOP-Service
======================================*/
.top-service {
  padding-top: 72px;
}

.top-service__title {
  padding-left: calc(100 / 1920 * 100vw);
}

.top-service__lead {
  margin-top: 0.8em;
  margin-left: 5.2em;
  font-size: clamp(1.4rem, 2.08333vw, 3rem);
  line-height: 1.76667;
  font-weight: 700;
  letter-spacing: 0.1em;
  position: relative;
}

@media screen and (min-width: 1440px) {
  .top-service__lead {
    font-size: max(30 / 1920 * 100vw, 3rem);
  }
}

@media screen and (max-width: 768px) {
  .top-service__lead {
    margin-left: 3em;
  }
}

.top-service__lead::before {
  content: "";
  position: absolute;
  top: 0;
  left: -1.8em;
  width: 1px;
  height: 6.9em;
  background-color: #0960C8;
}

.top-service__container {
  margin-top: calc(30 / 1920 * 100vw);
  padding: calc(152 / 1920 * 100vw) 0 calc(38 / 1920 * 100vw);
  background-image: url(../img/top/service-bg.jpg);
  background-size: calc(139%);
  background-position: 0 33%;
  background-repeat: no-repeat;
}

@media screen and (max-width: 768px) {
  .top-service__container {
    padding-bottom: max(40 / 375 * 100vw, 40px);
    background-size: calc(100%);
    background-position: center center;
    background-size: cover;
  }
}

.top-service__items {
  width: 1642px;
  max-width: 90%;
  margin: 0 auto;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (1fr)[3];
      grid-template-columns: repeat(3, 1fr);
  grid-column-gap: 5%;
}

@media screen and (max-width: 1439px) {
  .top-service__items {
    grid-column-gap: 3%;
  }
}

@media screen and (max-width: 768px) {
  .top-service__items {
    -ms-grid-columns: (minmax(180px, 1fr))[auto-fit];
        grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    grid-row-gap: 40px;
  }
}

.top-service__item {
  -webkit-box-shadow: 3px 3px 8px rgba(104, 104, 104, 0.88);
          box-shadow: 3px 3px 8px rgba(104, 104, 104, 0.88);
}

@media screen and (max-width: 768px) {
  .top-service__item {
    width: 250px;
    max-width: 100%;
    margin: 0 auto;
  }
}

.top-service__item--img {
  position: relative;
}

.top-service__item--img::before {
  content: "";
  display: block;
  padding-top: calc(478 / 493 * 100%);
}

.top-service__item--img img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

.top-service__item--contents {
  background-color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 90px;
  font-size: clamp(1.8rem, 2.77778vw, 4rem);
  font-weight: 700;
  color: #0960C8;
}

@media screen and (min-width: 1440px) {
  .top-service__item--contents {
    font-size: max(40 / 1920 * 100vw, 4rem);
  }
}

@media screen and (max-width: 1439px) {
  .top-service__item--contents {
    height: calc(90 / 1440 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .top-service__item--contents {
    height: unset;
    padding: 1em 0;
  }
}

.top-service__item--number {
  display: inline-block;
  font-family: "Gill Sans", "Gill Sans MT", "Calibri", sans-serif;
  font-size: 1.5em;
  font-weight: 600;
  letter-spacing: 0.075em;
  padding-right: 1.2em;
  position: relative;
}

.top-service__item--number::before {
  content: "";
  position: absolute;
  right: 0.2em;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 0.8em;
  height: 1px;
  background-color: #0960C8;
}

.top-service__link {
  margin-top: 48px;
  text-align: center;
}

/*======================================
    TOP-Recruit
======================================*/
.top-recruit {
  margin-top: max(226 / 1920 * 100vw, 226px);
  position: relative;
}

@media screen and (max-width: 1439px) {
  .top-recruit {
    margin-top: calc(228 / 1440 * 100vw);
  }
}

.top-recruit::before {
  content: "";
  position: absolute;
  top: calc(48 / 1920 * 100vw);
  right: 0;
  width: calc(135 / 1920 * 100vw);
  height: calc(260 / 1920 * 100vw);
  background-color: #0960C8;
}

.top-recruit__subimg--wrap {
  position: absolute;
  bottom: calc(72 / 1920 * 100vw);
  left: 0;
  z-index: 2;
}

@media screen and (max-width: 1199px) {
  .top-recruit__subimg--wrap {
    width: min(120 / 769 * 100vw, 170px);
    height: min(120 / 769 * 100vw, 170px);
  }
}

@media screen and (max-width: 768px) {
  .top-recruit__subimg--wrap {
    display: none;
  }
}

.top-recruit__subimg {
  width: calc(354 / 1920 * 100vw);
  height: calc(354 / 1920 * 100vw);
  background: url(../img/top/recruit2.jpg) no-repeat center center/cover;
}

@media screen and (max-width: 1199px) {
  .top-recruit__subimg {
    width: min(120 / 769 * 100vw, 170px);
    height: min(120 / 769 * 100vw, 170px);
  }
}

.top-recruit__container {
  position: relative;
  width: calc(1113 / 1920 * 100vw);
  border-bottom: 4px solid #0960C8;
  border-right: 4px solid #0960C8;
  border-top: 4px solid #0960C8;
  margin-left: auto;
  margin-right: calc(184 / 1920 * 100vw);
}

@media screen and (max-width: 1199px) {
  .top-recruit__container {
    border-left: 4px solid #0960C8;
    width: 65%;
  }
}

@media screen and (max-width: 768px) {
  .top-recruit__container {
    border: 2px solid #0960C8;
    width: 80%;
    margin: 0 auto;
    background-color: #fff;
  }
}

.top-recruit__container::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: calc(531 / 1920 * 100vw);
  height: calc(664 / 1920 * 100vw);
  background-color: #0960C8;
  -webkit-transform: translate(-101%, 19%);
          transform: translate(-101%, 19%);
}

@media screen and (max-width: 1199px) {
  .top-recruit__container::before {
    -webkit-transform: translate(-100%, 19%);
            transform: translate(-100%, 19%);
  }
}

@media screen and (max-width: 768px) {
  .top-recruit__container::before {
    z-index: -1;
    -webkit-transform: translate(-50%, 30%);
            transform: translate(-50%, 30%);
  }
}

.top-recruit__title--container {
  position: absolute;
  top: 0;
  right: calc(70 / 1920 * 100vw);
  -webkit-transform: translateY(-100%);
          transform: translateY(-100%);
  z-index: -1;
}

.recruit__title--en {
  line-height: 0;
}

@media screen and (min-width: 1440px) {
  .recruit__title--en {
    font-size: calc(117 / 1920 * 100vw);
  }
}

.top-recruit__contents {
  position: relative;
  padding: calc(208 / 1920 * 100vw) 0 calc(124 / 1920 * 100vw) calc(478 / 1920 * 100vw);
}

@media screen and (max-width: 768px) {
  .top-recruit__contents {
    padding: 320px 0 40px;
    width: 366px;
    max-width: 90%;
    margin: 0 auto;
  }
}

.recruit__contents--img__wrap {
  top: calc(-122 / 1920 * 100vw);
  left: 0;
  position: absolute;
  -webkit-transform: translateX(-27%);
          transform: translateX(-27%);
}

@media screen and (max-width: 1199px) {
  .recruit__contents--img__wrap {
    top: 50%;
    -webkit-transform: translate(-27%, -50%);
            transform: translate(-27%, -50%);
  }
}

@media screen and (max-width: 768px) {
  .recruit__contents--img__wrap {
    top: 30px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 100%;
  }
}

.recruit__contents--img {
  width: calc(551 / 1920 * 100vw);
  height: calc(664 / 1920 * 100vw);
  background: url(../img/top/recruit1.jpg) no-repeat center center/cover;
}

@media screen and (max-width: 1199px) {
  .recruit__contents--img {
    width: calc(220 / 769 * 100vw);
    width: min(220 / 769 * 100vw, 300px);
    height: calc(241 / 769 * 100vw);
    height: min(220 / 769 * 100vw, 361px);
  }
}

@media screen and (max-width: 768px) {
  .recruit__contents--img {
    width: 100%;
    height: 200px;
  }
}

.top-recruit__title {
  font-size: clamp(2rem, 2.43056vw, 3.5rem);
  font-weight: 700;
  position: relative;
}

.top-recruit__title::before {
  content: "";
  position: absolute;
  top: 0;
  left: 2.1em;
  width: 1px;
  height: min(126 / 1920 * 100vw, 3.6em);
  background-color: #0960C8;
  -webkit-transform: translateY(-132%);
          transform: translateY(-132%);
}

@media screen and (max-width: 768px) {
  .top-recruit__title::before {
    height: 50px;
  }
}

@media screen and (min-width: 1440px) {
  .top-recruit__title {
    font-size: max(35 / 1920 * 100vw, 3.5rem);
  }
}

.top-recruit__text {
  font-size: clamp(1.6rem, 1.38889vw, 2rem);
  line-height: 1.75;
  margin-top: 2em;
  font-weight: 600;
}

@media screen and (min-width: 1440px) {
  .top-recruit__text {
    font-size: max(20 / 1920 * 100vw, 2rem);
  }
}

.top-recruit__btn {
  margin-top: 76px;
  margin-left: -6px;
}

@media screen and (max-width: 1439px) {
  .top-recruit__btn {
    margin-top: calc(80 / 1440 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .top-recruit__btn {
    text-align: center;
  }
}

/*======================================
    TOP-Service Station
======================================*/
.top-station {
  margin-top: 412px;
}

@media screen and (max-width: 1439px) {
  .top-station {
    margin-top: calc(422 / 1440 * 100vw);
  }
}

.top-station__container {
  padding-bottom: 138px;
  position: relative;
}

@media screen and (max-width: 768px) {
  .top-station__container {
    padding-bottom: min(60 / 375 * 100vw, 100px);
  }
}

.top-station__container::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  bottom: 0;
  width: 80.75%;
  border: 4px solid #0960C8;
  -webkit-transform: translateX(-50.5%);
          transform: translateX(-50.5%);
  z-index: -2;
}

@media screen and (max-width: 768px) {
  .top-station__container::before {
    width: 90%;
  }
}

.top-station__title--container {
  text-align: center;
  -webkit-transform: translateY(-70%);
          transform: translateY(-70%);
  padding: 0 20px 10px;
}

@media screen and (max-width: 768px) {
  .top-station__title--container {
    padding: 0;
  }
}

.top-station__title {
  padding: 0 2em;
  font-size: clamp(1.6rem, 1.82292vw, 3rem);
}

@media screen and (min-width: 1440px) {
  .top-station__title {
    font-size: max(35 / 1920 * 100vw, 3rem);
  }
}

@media screen and (max-width: 768px) {
  .top-station__title {
    padding: 0 0.5em;
    text-align: center;
  }
}

.top-station__title .section__title--en {
  font-size: 2.4286em;
  margin-top: 0.125em;
}

@media screen and (max-width: 768px) {
  .top-station__title .section__title--en {
    font-size: calc(28 / 375 * 100vw);
    white-space: nowrap;
  }
}

.top-station__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 768px) {
  .top-station__item {
    width: 80%;
    margin: 0 auto;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.top-station__item:nth-child(even) {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}

@media screen and (max-width: 768px) {
  .top-station__item:nth-child(even) {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.top-station__item:nth-child(n + 2) {
  margin-top: calc(198 / 1920 * 100vw);
}

@media screen and (max-width: 768px) {
  .top-station__item:nth-child(n + 2) {
    margin-top: calc(60 / 375 * 100vw);
  }
}

.top-station__item:nth-child(odd) > .top-station__item--contents {
  padding-left: calc(60 / 1920 * 100vw);
}

@media screen and (max-width: 768px) {
  .top-station__item:nth-child(odd) > .top-station__item--contents {
    padding-left: 0;
  }
}

.top-station__item--img__container {
  width: 44%;
}

@media screen and (max-width: 768px) {
  .top-station__item--img__container {
    width: 76%;
    margin-top: 10px;
  }
  .top-station__item--img__container.-right {
    margin-left: auto;
  }
}

.top-station__item--img {
  overflow: hidden;
  position: relative;
}

.top-station__item--img::before {
  content: "";
  display: block;
  padding-top: calc(429 / 848 * 100%);
}

.top-station__item--img img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  -o-object-fit: cover;
     object-fit: cover;
  height: 115%;
}

.top-station__item--img.-right img {
  height: 120%;
}

.top-station__item--contents {
  width: calc(100% - 44%);
  padding-left: calc(94 / 1920 * 100vw);
}

@media screen and (max-width: 768px) {
  .top-station__item--contents {
    display: contents;
  }
}

.top-station__item--head {
  display: inline-block;
  font-family: "Gill Sans", "Gill Sans MT", "Calibri", sans-serif;
  font-size: calc(85 / 1920 * 100vw);
  font-weight: 600;
  letter-spacing: 0.1em;
  color: #D9E8F6;
  background-color: #fff;
  margin-top: -50px;
  padding-top: 50px;
  position: relative;
  z-index: -1;
}

@media screen and (max-width: 768px) {
  .top-station__item--head {
    display: block;
    text-align: center;
    -webkit-box-ordinal-group: 0;
        -ms-flex-order: -1;
            order: -1;
    font-size: calc(29 / 375 * 100vw);
    margin-top: 0;
    padding-top: 0;
  }
}

.top-station__item--head span {
  position: absolute;
  bottom: 0;
  right: -0.07em;
  -webkit-transform: translateY(98%);
          transform: translateY(98%);
  font-size: 2em;
  background-color: #fff;
  padding-bottom: 0.5em;
  z-index: -2;
}

.top-station__item--head.-left > span {
  right: unset;
  left: 0;
  padding-bottom: 0.25em;
}

.top-station__item--details.-left {
  margin-top: calc(56 / 1920 * 100vw);
  padding-left: calc(258 / 1920 * 100vw);
}

@media screen and (max-width: 768px) {
  .top-station__item--details.-left {
    padding-left: 0;
  }
}

.top-station__item--details.-right {
  margin-top: calc(40 / 1920 * 100vw);
}

.top-station__item--name {
  font-size: clamp(2rem, 2.43056vw, 3.5rem);
  font-weight: 700;
  padding-bottom: 0.8em;
  padding-left: 1.3em;
  position: relative;
}

@media screen and (min-width: 1440px) {
  .top-station__item--name {
    font-size: max(35 / 1920 * 100vw, 3.5rem);
  }
}

@media screen and (max-width: 768px) {
  .top-station__item--name {
    margin-top: 0.5em;
    font-size: calc(20 / 375 * 100vw);
  }
}

.top-station__item--name::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 3%;
  width: 102%;
  height: 1px;
  background-color: #0960C8;
  z-index: -1;
}

.top-station__item--name.-short {
  padding-bottom: 0.4em;
}

@media screen and (max-width: 768px) {
  .top-station__item--name.-short {
    padding-left: 0;
  }
}

.top-station__item--name.-short::before {
  width: calc(526 / 1920 * 100vw);
  -webkit-transform: translateX(-20%);
          transform: translateX(-20%);
}

@media screen and (max-width: 768px) {
  .top-station__item--name.-short::before {
    width: 85%;
    -webkit-transform: translateX(-8%);
            transform: translateX(-8%);
  }
}

.top-station__item--address {
  margin-top: 2.9em;
  font-size: clamp(1.4rem, 1.73611vw, 2.5rem);
  line-height: 1.76;
  padding-left: 1.85em;
}

@media screen and (min-width: 1440px) {
  .top-station__item--address {
    font-size: max(25 / 1920 * 100vw, 2.5rem);
  }
}

@media screen and (max-width: 768px) {
  .top-station__item--address {
    font-size: min(14 / 375 * 100vw, 3rem);
    margin-top: 1em;
    padding-left: 0;
  }
}

.top-station__item--address span {
  display: inline-block;
  margin-right: 1.3em;
}

.top-station__item--address.-left {
  margin-top: 2em;
  padding-left: 1.3em;
}

.top-station__item--tel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 0.5em;
  font-family: "Gill Sans", "Gill Sans MT", "Calibri", sans-serif;
  font-weight: 600;
  font-size: clamp(2rem, 2.22222vw, 3.2rem);
  letter-spacing: 0.18em;
  color: #0960C8;
  padding-left: 1.7em;
}

@media screen and (min-width: 1440px) {
  .top-station__item--tel {
    font-size: max(32 / 1920 * 100vw, 3.2rem);
  }
}

@media screen and (max-width: 768px) {
  .top-station__item--tel {
    font-size: calc(24 / 375 * 100vw);
    font-size: min(24 / 375 * 100vw, 4rem);
    padding-left: 0;
    margin-top: 0.25em;
  }
}

.top-station__item--tel span {
  display: inline-block;
  background-color: #0960C8;
  color: #fff;
  font-size: 0.7813em;
  padding: 0.3em 0.4em;
  margin-right: 0.8em;
}

.top-station__item--tel.-left {
  padding-left: 1.15em;
}

/*======================================
    TOP-About
======================================*/
.top-about {
  margin-top: 204px;
  overflow: hidden;
}

@media screen and (max-width: 1199px) {
  .top-about {
    margin-top: calc(214 / 1200 * 100vw);
  }
}

.top-about__container {
  width: calc(1680 / 1920 * 100vw);
  max-width: 95%;
  margin: 0 auto;
  position: relative;
}

.top-about__container::before {
  content: "";
  position: absolute;
  top: 3em;
  right: 0;
  width: 100%;
  -webkit-transform: translateX(25%);
          transform: translateX(25%);
  height: 1px;
  background-color: #0960C8;
  z-index: -1;
}

.top-about__title {
  background-color: #fff;
  padding-left: 2.5em;
  font-size: clamp(1.6rem, 1.82292vw, 3rem);
}

@media screen and (min-width: 1440px) {
  .top-about__title {
    font-size: max(35 / 1920 * 100vw, 3rem);
  }
}

@media screen and (max-width: 768px) {
  .top-about__title {
    padding-left: 0.5em;
  }
}

.top-about__title .section__title--en {
  font-size: 2.5714em;
  margin-left: 0;
}

.top-about__contents {
  margin-top: 58px;
  margin-bottom: -1.35%;
  -webkit-transform: translateX(2%);
          transform: translateX(2%);
  padding: 0 calc(80 / 1920 * 100vw) 0 calc(64 / 1920 * 100vw);
  background-color: #0960C8;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1.5fr;
      grid-template-columns: 1fr 1.5fr;
}

@media screen and (max-width: 1439px) {
  .top-about__contents {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    margin-top: calc(82 / 1440 * 100vw);
    padding: 0 calc(50 / 1440 * 100vw);
  }
}

@media screen and (max-width: 1199px) {
  .top-about__contents {
    padding: 0 calc(30 / 1200 * 100vw);
    -ms-grid-columns: 1fr 1.25fr;
        grid-template-columns: 1fr 1.25fr;
  }
}

@media screen and (max-width: 768px) {
  .top-about__contents {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 40px calc(72 / 1920 * 100vw);
  }
}

.top-about__texts {
  color: #fff;
  margin-top: 42px;
  letter-spacing: 0.17em;
}

@media screen and (max-width: 1439px) {
  .top-about__texts {
    margin-top: calc(40 / 1440 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .top-about__texts {
    display: contents;
  }
}

.top-about__text {
  font-size: clamp(1.1rem, 1.38889vw, 2rem);
  font-weight: 700;
  line-height: 2.13636;
}

@media screen and (min-width: 1440px) {
  .top-about__text {
    font-size: max(22 / 1920 * 100vw, 2rem);
  }
}

@media screen and (max-width: 768px) {
  .top-about__text {
    font-size: clamp(1.2rem, 2.60417vw, 2rem);
    text-align: center;
  }
}

.top-about__btn {
  margin-top: 48px;
}

@media screen and (max-width: 1439px) {
  .top-about__btn {
    margin-top: calc(48 / 1440 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .top-about__btn {
    text-align: center;
    margin-top: calc(30 / 375 * 100vw);
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
  }
}

.top-about__imgs {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (1fr)[2];
      grid-template-columns: repeat(2, 1fr);
  grid-gap: 5%;
  -webkit-transform: translateY(-22%);
          transform: translateY(-22%);
}

@media screen and (max-width: 768px) {
  .top-about__imgs {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    margin-top: calc(26 / 375 * 100vw);
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

.top-about__img {
  position: relative;
}

.top-about__img::before {
  content: "";
  display: block;
  margin-top: 100%;
}

.top-about__img img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

/*======================================
    Footer
======================================*/
.footer {
  margin-top: 178px;
}

@media screen and (max-width: 1439px) {
  .footer {
    margin-top: calc(190 / 1440 * 100vw);
  }
}

.footer__container {
  width: 1440px;
  max-width: 90%;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 768px) {
  .footer__container {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 40px;
  }
}

.footer__info {
  width: 420px;
}

@media screen and (max-width: 1439px) {
  .footer__info {
    width: calc(420 / 1440 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .footer__info {
    width: 100%;
    text-align: center;
  }
}

.footer__logo {
  width: 81.5%;
}

@media screen and (max-width: 768px) {
  .footer__logo {
    margin: 0 auto;
  }
}

.footer__address {
  margin-top: 0.7em;
  font-size: 2.3rem;
  font-weight: 700;
  line-height: 1.73913;
}

@media screen and (max-width: 1439px) {
  .footer__address {
    font-size: calc(22 / 1440 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .footer__address {
    font-size: calc(14 / 375 * 100vw);
  }
}

.footer__address span {
  display: inline-block;
  margin-right: 1.1em;
}

.footer__tel {
  display: inline-block;
  margin-top: 0.6em;
  font-size: 3.5rem;
  font-weight: 600;
  font-family: "Gill Sans", "Gill Sans MT", "Calibri", sans-serif;
  letter-spacing: 0.2em;
  color: #0960C8;
  padding-bottom: 0.35em;
  border-bottom: 1px solid #0960C8;
}

@media screen and (max-width: 1439px) {
  .footer__tel {
    font-size: calc(32 / 1440 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .footer__tel {
    display: inline-block;
    font-size: calc(22 / 375 * 100vw);
  }
}

.footer__nav {
  margin-left: auto;
  margin-top: 10px;
}

@media screen and (max-width: 768px) {
  .footer__nav {
    margin: unset;
  }
}

.footer__nav--items {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 768px) {
  .footer__nav--items {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(130px, 1fr))[auto-fit];
        grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
    grid-column-gap: 2%;
    grid-row-gap: 20px;
  }
}

.footer__nav--item:not(:last-child) > .footer__nav--link {
  padding-left: 1.1em;
}

.footer__nav--link {
  display: inline-block;
  color: #0960C8;
  font-size: 2.5rem;
  font-weight: 700;
  padding-right: 2.8em;
  -webkit-transition: opacity .3s ease;
  transition: opacity .3s ease;
}

@media screen and (max-width: 1439px) {
  .footer__nav--link {
    font-size: calc(25 / 1440 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .footer__nav--link {
    font-size: 14px;
  }
}

.footer__nav--link:hover {
  opacity: 0.7;
}

.footer__nav--link.-contact {
  margin-right: 0.8em;
  -webkit-transform: translateY(-25%);
          transform: translateY(-25%);
  overflow: hidden;
  background-color: #0960C8;
  color: #fff;
  letter-spacing: 0.05em;
  padding: 0.3em 1.1em;
  border-radius: 23px;
  border: 2px solid #0960C8;
  text-align: center;
  position: relative;
  z-index: 1;
  -webkit-transition: color .3s ease;
  transition: color .3s ease;
}

.footer__nav--link.-contact::before {
  content: "";
  position: absolute;
  width: 0;
  height: 100%;
  top: 0;
  right: 0;
  z-index: -1;
  background-color: #fff;
  -webkit-transition: left .3s ease-out, width .3s ease-out;
  transition: left .3s ease-out, width .3s ease-out;
}

.footer__nav--link.-contact:hover {
  color: #0960C8;
  opacity: 1;
}

.footer__nav--link.-contact:hover::before {
  left: 0;
  width: 100%;
}

.footer__sub--items {
  font-size: 1.7rem;
  margin-top: 1em;
  margin-left: 1.7647em;
}

@media screen and (max-width: 768px) {
  .footer__sub--items {
    margin-top: 14px;
    margin-left: 10px;
  }
}

.footer__sub--item a {
  display: inline-block;
  font-size: 1.7rem;
  line-height: 1.76471;
  padding-left: 1.5em;
  position: relative;
  -webkit-transition: opacity .3s ease;
  transition: opacity .3s ease;
}

@media screen and (max-width: 1439px) {
  .footer__sub--item a {
    font-size: calc(17 / 1440 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .footer__sub--item a {
    font-size: 1.2rem;
  }
}

.footer__sub--item a::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 1em;
  height: 1px;
  background-color: #000;
  -webkit-transition: left .3s ease;
  transition: left .3s ease;
}

.footer__sub--item a:hover {
  opacity: 0.7;
}

.footer__sub--item a:hover::before {
  left: 3px;
}

.copyright {
  margin-top: 80px;
  text-align: center;
  background-color: #182986;
  color: #fff;
  font-size: 1.8rem;
  letter-spacing: 0.1em;
  padding: 2em 0.5em;
}

@media screen and (max-width: 768px) {
  .copyright {
    font-size: 1.4rem;
    line-height: 1.5;
  }
}

/*======================================
    Page-About
======================================*/
.about-mv {
  background: url(../img/about/about-mv.jpg) no-repeat center bottom 28%/cover;
}

/*======================================
    Policy
======================================*/
.policy {
  margin-top: clamp(40px, 4.30556vw, 62px);
  position: relative;
  padding-left: calc(240 / 1920 * 100vw);
  padding-top: 10px;
  padding-bottom: calc(150 / 1920 * 100vw);
}

@media screen and (max-width: 768px) {
  .policy {
    padding-left: calc(30 / 375 * 100vw);
  }
}

.policy::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 72%;
  background: url(../img/about/policy.jpg) no-repeat center left 14.0625vw/cover;
  background: url(../img/about/policy.jpg) no-repeat top 57% left 17vw/cover;
  z-index: -2;
}

.policy::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  bottom: -10px;
  width: 100%;
  background: -webkit-gradient(linear, left top, right top, color-stop(54%, #fff), color-stop(90%, rgba(255, 255, 255, 0)), to(rgba(255, 255, 255, 0)));
  background: linear-gradient(to right, #fff 54%, rgba(255, 255, 255, 0) 90%, rgba(255, 255, 255, 0) 100%);
  z-index: -1;
}

.policy__title > .section__title--en {
  margin-top: 0;
  margin-left: -0.05em;
}

.policy__text {
  margin-top: 2.55em;
  padding-left: 2.8em;
  font-size: clamp(1.4rem, 2.08333vw, 3rem);
  text-shadow: 0 0 3px rgba(255, 255, 255, 0.5);
  font-weight: 700;
  line-height: 2.48;
  color: #0960C8;
  position: relative;
}

@media screen and (min-width: 1440px) {
  .policy__text {
    font-size: max(30 / 1920 * 100vw, 3rem);
  }
}

.policy__text::before {
  content: "";
  position: absolute;
  top: -0.5em;
  left: 0.5em;
  bottom: -2.6em;
  width: calc(230 / 1920 * 100vw);
  border-left: 4px solid #0960C8;
  border-bottom: 4px solid #0960C8;
}

@media screen and (max-width: 768px) {
  .policy__text::before {
    border-left: 2px solid #0960C8;
    border-bottom: 2px solid #0960C8;
  }
}

/*======================================
    Company Information
======================================*/
.company-info {
  margin-top: clamp(30px, 2.77778vw, 40px);
  margin-top: clamp(200px, 15.9375vw, 306px);
  position: relative;
}

.company-info__title {
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transform: translateY(-58%);
          transform: translateY(-58%);
  padding-left: calc(254 / 1920 * 100vw);
  background: transparent;
}

.company-info__title .section__title--en {
  margin-top: 0;
}

@media screen and (max-width: 768px) {
  .company-info__title {
    padding-left: calc(30 / 375 * 100vw);
  }
}

.company-info__container {
  background: url(../img/about/company-info.jpg) no-repeat center bottom 60%/cover;
  background-color: rgba(246, 246, 246, 0.9);
  background-blend-mode: lighten;
}

.company-info__items {
  padding-top: clamp(100px, 13.88889vw, 200px);
  padding-bottom: clamp(100px, 16.25vw, 234px);
}

@media screen and (max-width: 768px) {
  .company-info__items {
    padding: calc(60 / 375 * 100vw) 0;
  }
}

.company-info__item {
  width: 1143px;
  max-width: 90%;
  margin: 0 auto;
  border-bottom: 1px solid #0960C8;
  background-color: #fff;
}

@media screen and (max-width: 768px) {
  .company-info__item {
    border-bottom: none;
  }
}

.company-info__item:first-child {
  border-top: 1px solid #0960C8;
}

.company-info__dl {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 223px auto;
      grid-template-columns: 223px auto;
  grid-column-gap: min(150 / 1440 * 100vw, 150px);
  font-size: clamp(1.6rem, 1.73611vw, 2.5rem);
  line-height: 1.76;
}

@media screen and (min-width: 1440px) {
  .company-info__dl {
    font-size: 2.5rem;
  }
}

@media screen and (max-width: 768px) {
  .company-info__dl {
    -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
    font-size: calc(16 / 375 * 100vw);
  }
}

.company-info__dl dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-weight: 700;
  background-color: #0960C8;
  color: #fff;
}

.company-info__dl dd {
  padding: 1.3em 0 1.1em;
}

@media screen and (max-width: 768px) {
  .company-info__dl dd {
    padding: 1em 0.5em;
    text-align: center;
  }
}

.info-container > dd:nth-child(n + 2) {
  padding-top: 0;
}

.is-color {
  color: #0960C8;
  font-weight: 700;
}

/*======================================
    History
======================================*/
.history {
  background: url(../img/about/history.jpg) no-repeat center top 10%/cover;
  background-color: rgba(9, 96, 200, 0.4);
  background-blend-mode: darken;
  padding-top: 40px;
  padding-bottom: calc(114 / 1920 * 100vw);
}

.history__title {
  text-align: center;
  color: #fff;
  font-size: clamp(2rem, 2.43056vw, 3.5rem);
  text-shadow: 7px 7px 2px rgba(86, 85, 85, 0.75);
  font-weight: 700;
}

@media screen and (min-width: 1440px) {
  .history__title {
    font-size: max(35 / 1920 * 100vw, 3.5rem);
  }
}

.history__title--en {
  display: block;
  font-family: "Gill Sans", "Gill Sans MT", "Calibri", sans-serif;
  text-shadow: none;
  font-weight: 600;
  font-size: 3.35em;
  letter-spacing: 0.1em;
  padding-bottom: 0.2em;
}

@media screen and (max-width: 768px) {
  .history__title--en {
    font-size: 2.6em;
  }
}

.history__items {
  width: 1349px;
  max-width: 90%;
  margin: 90px auto 0;
}

@media screen and (min-width: 1440px) {
  .history__items {
    -webkit-transform: translateX(1.5%);
            transform: translateX(1.5%);
  }
}

@media screen and (max-width: 1199px) {
  .history__items {
    margin-top: calc(90 / 1200 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .history__items {
    margin: calc(40 / 375 * 100vw) auto 0;
  }
}

.history__item {
  background-color: rgba(255, 255, 255, 0.8);
  position: relative;
  padding-right: 1em;
}

@media screen and (min-width: 1440px) {
  .history__item {
    padding-right: 3em;
  }
}

.history__item:nth-child(n + 2) {
  margin-top: 50px;
}

.history__item:not(:last-child)::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 12.5%;
  -webkit-transform: translateY(75%);
          transform: translateY(75%);
  width: 2px;
  height: 90px;
  background-color: #fff;
  -webkit-box-shadow: 2px 2px 2px rgba(86, 85, 85, 0.75);
          box-shadow: 2px 2px 2px rgba(86, 85, 85, 0.75);
  z-index: 1;
}

@media screen and (max-width: 768px) {
  .history__item:not(:last-child)::before {
    left: 3em;
    bottom: unset;
    top: 50px;
    height: 88%;
    -webkit-transform: translateY(20%);
            transform: translateY(20%);
  }
}

.history__dl {
  font-size: clamp(1.4rem, 1.38889vw, 2rem);
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: calc(506 / 1920 * 100vw) auto;
      grid-template-columns: calc(506 / 1920 * 100vw) auto;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 149px;
}

@media screen and (min-width: 1440px) {
  .history__dl {
    font-size: max(20 / 1920 * 100vw, 2rem);
  }
}

@media screen and (max-width: 768px) {
  .history__dl {
    display: block;
    padding: 40px 20px;
    font-size: calc(14 / 375 * 100vw);
    height: unset;
  }
}

.history__dl dt {
  padding-left: 2.25em;
  font-size: 1.75em;
  font-weight: 700;
  color: #0960C8;
  text-shadow: 2px 2px 5px rgba(86, 85, 85, 0.75);
}

@media screen and (max-width: 768px) {
  .history__dl dt {
    padding-left: 0;
    font-size: 1.25em;
  }
}

.history__dl dt span {
  display: inline-block;
  width: 1.5em;
  text-align: center;
}

.history__dl dd {
  font-weight: 700;
  line-height: 1.75;
}

@media screen and (max-width: 768px) {
  .history__dl dd {
    padding-left: 40px;
    margin-top: 1em;
  }
}

.history__dl dd > .is-color {
  font-size: 1.35em;
  display: block;
}

@media screen and (max-width: 768px) {
  .history__dl dd > .is-color {
    font-size: 1.125em;
  }
}

/*======================================
    Access
======================================*/
.access {
  margin-top: clamp(100px, 17.91667vw, 258px);
}

.access__container {
  border-top: 4px solid #0960C8;
  border-right: 4px solid #0960C8;
  border-bottom: 4px solid #0960C8;
  width: 93%;
  padding-bottom: calc(88 / 1920 * 100vw);
}

.access__title {
  -webkit-transform: translateY(-77%);
          transform: translateY(-77%);
  padding-right: 2.1em;
  padding-left: calc(276 / 1920 * 100vw);
  font-size: clamp(1.6rem, 1.82292vw, 3.5rem);
}

@media screen and (min-width: 1440px) {
  .access__title {
    font-size: max(35 / 1920 * 100vw, 3.5rem);
  }
}

.access__title .section__title--en {
  margin-top: 0;
  font-size: 3.3429em;
}

.access__contents {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 45.7% auto;
      grid-template-columns: 45.7% auto;
  margin-top: -32px;
}

@media screen and (max-width: 768px) {
  .access__contents {
    -ms-grid-columns: 10% auto;
        grid-template-columns: 10% auto;
  }
}

.access__deco {
  background-color: #0960C8;
  height: calc(450 / 1920 * 100vw);
  height: min(450 / 1920 * 100vw, 450px);
}

.access__texts {
  padding-left: calc(256 / 1920 * 100vw);
  padding-top: calc(56 / 1920 * 100vw);
  font-size: clamp(1.6rem, 1.73611vw, 2.5rem);
  line-height: 1.5;
}

@media screen and (min-width: 1440px) {
  .access__texts {
    font-size: max(25 / 1920 * 100vw, 2.5rem);
  }
}

@media screen and (max-width: 768px) {
  .access__texts {
    font-size: calc(16 / 375 * 100vw);
    padding-left: calc(18 / 375 * 100vw);
  }
}

.access__head {
  font-size: 1.4em;
  font-weight: 700;
  position: relative;
}

.access__head::before {
  content: "";
  position: absolute;
  bottom: -0.4em;
  left: 0;
  width: 90%;
  height: 1px;
  background-color: #0960C8;
  -webkit-transform: translateX(-30%);
          transform: translateX(-30%);
}

.access__detail {
  margin-top: 2.64em;
}

.access__detail:nth-child(n + 2) {
  margin-top: 2em;
}

.access__detail.-tel {
  margin-top: 1.5em;
}

.access__detail.-tel .top-station__item--tel {
  padding-left: 0;
}

.access__detail.-tel .top-station__item--tel span {
  padding: 0.1em 0.4em;
}

.access__detail--head {
  display: inline-block;
  background-color: #0960C8;
  color: #fff;
  letter-spacing: 0.1em;
  font-weight: 700;
  padding: 0.1em 0.5em;
  margin-bottom: 0.5em;
}

.access__map {
  width: 1402px;
  max-width: 90%;
  margin: 54px auto 0;
  position: relative;
}

@media screen and (min-width: 1440px) {
  .access__map {
    -webkit-transform: translateX(4%);
            transform: translateX(4%);
  }
}

.access__map::before {
  content: "";
  display: block;
  padding-top: calc(486 / 1401 * 100%);
}

.access__map iframe {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

/*======================================
    Station
======================================*/
.station {
  margin-top: clamp(120px, 20.27778vw, 292px);
  padding-bottom: 30px;
}

.station__container {
  width: 1680px;
  max-width: 90%;
  margin: 0 auto;
  border: 4px solid #0960C8;
  padding-bottom: calc(104 / 1920 * 100vw);
}

.station__items {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (1fr)[2];
      grid-template-columns: repeat(2, 1fr);
}

@media screen and (min-width: 1440px) {
  .station__items {
    margin-top: -30px;
  }
}

@media screen and (max-width: 768px) {
  .station__items {
    -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
    grid-row-gap: calc(40 / 375 * 100vw);
  }
}

.station__item {
  padding: 20px calc(135 / 1920 * 100vw) 40px calc(70 / 1920 * 100vw);
  position: relative;
  font-size: clamp(1.4rem, 1.73611vw, 2.5rem);
}

@media screen and (min-width: 1440px) {
  .station__item {
    font-size: max(25 / 1920 * 100vw, 2.5rem);
  }
}

@media screen and (max-width: 768px) {
  .station__item {
    font-size: calc(16 / 375 * 100vw);
    max-width: 620px;
    margin: 0 auto;
  }
}

.station__item:first-child {
  border-right: 2px solid #0960C8;
  padding: 20px calc(80 / 1920 * 100vw) 40px calc(125 / 1920 * 100vw);
}

@media screen and (max-width: 768px) {
  .station__item:first-child {
    border-right: none;
  }
  .station__item:first-child::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 80%;
    height: 1px;
    background-color: #0960C8;
  }
}

.station__item--img {
  position: relative;
}

.station__item--img::before {
  content: "";
  display: block;
  padding-top: calc(411 / 626 * 100%);
}

.station__item--img::after {
  content: "";
  position: absolute;
  top: -18%;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 66%;
  height: 250%;
  background-color: #D9E8F6;
  z-index: -1;
}

.station__item--img img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  -o-object-fit: cover;
     object-fit: cover;
  height: 100%;
}

.station__item--number {
  font-size: calc(230 / 1920 * 100vw);
  font-weight: 600;
  letter-spacing: 0.05em;
  font-family: "Gill Sans", "Gill Sans MT", "Calibri", sans-serif;
  color: #0960C8;
  position: absolute;
  top: 0;
  z-index: 2;
  -webkit-transform: translateY(-25%);
          transform: translateY(-25%);
}

.station__item--number.-left {
  left: 0;
}

.station__item--number.-right {
  right: 0;
  top: 2%;
}

.station__name {
  font-size: 1.4em;
  font-weight: 700;
  margin-top: 1.3em;
}

.station__item--tel {
  margin-top: 1.1em;
  font-size: 1.28em;
  padding-left: 0;
}

@media screen and (max-width: 768px) {
  .station__item--tel {
    margin-top: 0.5em;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: start;
  }
}

.operation {
  margin-top: 0.75em;
}

.station__item--map {
  margin-top: calc(70 / 1920 * 100vw);
  position: relative;
}

.station__item--map::before {
  content: "";
  display: block;
  padding-top: calc(358 / 626 * 100%);
}

.station__item--map iframe {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

.station__item--address {
  line-height: 1.5;
}

.station__item--address .access__detail {
  margin-top: 0.9em;
}

.station__item--address .access__detail .access__detail--head {
  margin-bottom: 0.8em;
}

/*======================================
    Service
======================================*/
.service-mv {
  background-image: url(../img/service/service-mv.jpg);
  background-size: calc(100% + 135px);
  background-position: -135px 48%;
  background-repeat: no-repeat;
}

.service {
  margin-top: clamp(40px, 5.41667vw, 104px);
  margin-top: 80px;
}

.service__title {
  text-align: center;
  position: relative;
}

.service__title > .section__title {
  background: transparent;
}

.service__title > .section__title .section__title--en {
  margin-top: 0.2em;
}

.service__title::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #D9E8F6;
  height: calc(412 / 1920 * 100vw);
  -webkit-transform: translateY(36%);
          transform: translateY(36%);
  z-index: -1;
}

.service__img--container {
  width: 1400px;
  max-width: 90%;
  margin: calc(70 / 1920 * 100vw) auto 0;
}

.service__img {
  position: relative;
}

.service__img::before {
  content: "";
  display: block;
  padding-top: calc(415 / 1402 * 100%);
}

.service__img img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: 50% 31.5%;
     object-position: 50% 31.5%;
  height: 100%;
}

.service__lead {
  margin-top: 3.8em;
  text-align: center;
  font-size: clamp(1.6rem, 3.05556vw, 4.4rem);
  font-weight: 700;
  line-height: 1.75;
}

@media screen and (min-width: 1440px) {
  .service__lead {
    font-size: max(44 / 1920 * 100vw, 4.4rem);
  }
}

.service__items {
  margin-top: 90px;
}

@media screen and (max-width: 768px) {
  .service__items {
    margin-top: 80px;
  }
}

.service__item {
  overflow: hidden;
  padding: 206px 0 246px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 1439px) {
  .service__item {
    padding: calc(150 / 1440 * 100vw) 0;
  }
}

@media screen and (max-width: 1199px) {
  .service__item {
    padding: calc(100 / 1200 * 100vw) 0;
  }
}

@media screen and (max-width: 768px) {
  .service__item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.service__item::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  opacity: 0.2;
  z-index: -2;
}

.service__item::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(207, 231, 251, 0.3);
  z-index: -1;
}

.service__item:nth-child(n + 2) {
  margin-top: 76px;
}

@media screen and (max-width: 768px) {
  .service__item:nth-child(n + 2) {
    margin-top: 40px;
  }
}

.service__item:nth-child(even) {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  padding: 222px 0 230px;
}

@media screen and (max-width: 1439px) {
  .service__item:nth-child(even) {
    padding: calc(150 / 1440 * 100vw) 0;
  }
}

@media screen and (max-width: 1199px) {
  .service__item:nth-child(even) {
    padding: calc(100 / 1200 * 100vw) 0;
  }
}

@media screen and (max-width: 768px) {
  .service__item:nth-child(even) {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.service__item:nth-child(even) .service__item--contents {
  width: 60%;
  padding-left: calc(230 / 1920 * 100vw);
  padding-bottom: min(90 / 1920 * 100vw, 90px);
}

@media screen and (max-width: 768px) {
  .service__item:nth-child(even) .service__item--contents {
    width: 80%;
    margin: 0 auto;
    padding: 0 calc(20 / 375 * 100vw) 40px;
  }
}

.service__item:nth-child(even) .service__item--contents .service__item--text {
  margin-top: 1em;
}

.service__item:nth-child(even) .service__item--img {
  width: calc(100% - 58%);
}

@media screen and (max-width: 768px) {
  .service__item:nth-child(even) .service__item--img {
    width: 80%;
    margin: 0 auto;
  }
}

.service__item:nth-child(3) {
  padding: 244px 0 198px;
}

@media screen and (max-width: 1439px) {
  .service__item:nth-child(3) {
    padding: calc(150 / 1440 * 100vw) 0;
  }
}

@media screen and (max-width: 1199px) {
  .service__item:nth-child(3) {
    padding: calc(100 / 1200 * 100vw) 0;
  }
}

.service__item:nth-child(3) .service__item--lead {
  margin-top: 2.2em;
}

.service__item:nth-child(3) .service__item--text {
  margin-top: 1.5em;
}

.service__item:nth-child(3) .service__item--contents {
  padding-bottom: 0;
}

@media screen and (max-width: 768px) {
  .service__item:nth-child(3) .service__item--contents {
    padding-bottom: 2em;
  }
}

.service__item:nth-child(1)::before {
  background: url(../img/service/service1-bg.jpg) no-repeat center bottom/cover;
}

.service__item:nth-child(2)::before {
  background: url(../img/service/service2-bg.jpg) no-repeat center 69%/cover;
}

.service__item:nth-child(3)::before {
  background: url(../img/service/service3-bg.jpeg) no-repeat center 10%/cover;
}

.service__item--contents {
  width: 50%;
  background-color: #fff;
  padding-left: calc(256 / 1920 * 100vw);
  padding-bottom: 20px;
  font-size: clamp(1.4rem, 1.30208vw, 2.5rem);
}

@media screen and (min-width: 1440px) {
  .service__item--contents {
    font-size: max(25 / 1920 * 100vw, 2.5rem);
  }
}

@media screen and (max-width: 768px) {
  .service__item--contents {
    width: 80%;
    margin: 0 auto;
    padding: 0 calc(20 / 375 * 100vw) 40px;
  }
}

.service__item--title {
  font-size: 3.4em;
  font-weight: 600;
  font-family: "Gill Sans", "Gill Sans MT", "Calibri", sans-serif;
  letter-spacing: 0.1em;
  color: #0960C8;
  display: inline-block;
  margin-top: 0.1em;
  position: relative;
}

@media screen and (min-width: 1440px) {
  .service__item--title {
    font-size: calc(85 / 1920 * 100vw);
  }
}

@media screen and (max-width: 1199px) {
  .service__item--title {
    font-size: clamp(3.6rem, 4.5vw, 5.4rem);
  }
}

.service__item--title span {
  font-size: 2em;
  position: absolute;
  bottom: 0;
  right: 0;
  -webkit-transform: translate(110%, 10%);
          transform: translate(110%, 10%);
  z-index: 2;
}

.service__item--lead {
  margin-top: 2.65em;
  font-size: 1.4em;
  font-weight: 700;
  color: #0960C8;
  padding-bottom: 0.75em;
  position: relative;
}

@media screen and (max-width: 768px) {
  .service__item--lead {
    margin-top: 2em;
  }
}

.service__item--lead::before {
  content: "";
  position: absolute;
  bottom: 0;
  right: -20%;
  width: 170%;
  height: 1px;
  background-color: #0960C8;
}

@media screen and (max-width: 768px) {
  .service__item--lead::before {
    width: calc(100% + (20 / 375 * 100vw));
    right: unset;
    left: calc(-20 / 375 * 100vw);
  }
}

.service__item--text {
  margin-top: 0.5em;
  line-height: 1.76;
  width: 600px;
  max-width: 95%;
}

@media screen and (min-width: 1440px) {
  .service__item--text {
    width: max(600 / 1920 * 100vw, 600px);
  }
}

@media screen and (max-width: 768px) {
  .service__item--text {
    max-width: 100%;
  }
}

.service__item--img {
  width: 50%;
  position: relative;
}

@media screen and (max-width: 768px) {
  .service__item--img {
    width: 80%;
    margin: 0 auto;
  }
}

.service__item--img::before {
  content: "";
  display: block;
  padding-top: calc(562 / 965 * 100%);
}

.service__item--img img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  -o-object-fit: cover;
     object-fit: cover;
  height: 100%;
}

.service__item--img.-service1, .service__item--img.-service3 {
  -webkit-box-shadow: 1px 1px 4px rgba(153, 154, 154, 0.75);
          box-shadow: 1px 1px 4px rgba(153, 154, 154, 0.75);
  z-index: 1;
}

.service__item--img.-service1::after, .service__item--img.-service3::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: max(525 / 1920 * 100vw, 263px);
  height: max(770 / 1920 * 100vw, 385px);
  background-color: #0960C8;
  z-index: -1;
}

@media screen and (min-width: 1440px) {
  .service__item--img.-service1::after, .service__item--img.-service3::after {
    width: max(525 / 1920 * 100vw, 525px);
    height: max(770 / 1920 * 100vw, 770px);
  }
}

@media screen and (max-width: 768px) {
  .service__item--img.-service1::after, .service__item--img.-service3::after {
    -webkit-transform: translate(10%, -30%);
            transform: translate(10%, -30%);
    width: calc(200 / 375 * 100vw);
    height: calc(150 / 375 * 100vw);
  }
}

.service__item--img.-service2 {
  background-color: #0960C8;
  z-index: 1;
}

@media screen and (max-width: 768px) {
  .service__item--img.-service2::before {
    padding-top: calc(562 / 965 * 100%);
  }
}

.service__item--img.-service2 img {
  display: none;
}

@media screen and (max-width: 768px) {
  .service__item--img.-service2 img {
    display: block;
    -o-object-position: center 90%;
       object-position: center 90%;
  }
}

.service__item--img.-service2::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -1%;
  -webkit-transform: translateY(-54%);
          transform: translateY(-54%);
  width: calc(540 / 1920 * 100vw);
  height: calc(770 / 1920 * 100vw);
  background: url(../img/service/service2.jpg) no-repeat center center/cover;
  -webkit-box-shadow: 1px 1px 4px rgba(153, 154, 154, 0.75);
          box-shadow: 1px 1px 4px rgba(153, 154, 154, 0.75);
}

@media screen and (min-width: 1440px) {
  .service__item--img.-service2::after {
    width: max(540 / 1920 * 100vw, 540px);
    height: max(770 / 1920 * 100vw, 770px);
  }
}

@media screen and (max-width: 768px) {
  .service__item--img.-service2::after {
    background: #0960C8;
    z-index: -1;
    right: unset;
    left: 0;
    -webkit-transform: translate(-10%, -30%);
            transform: translate(-10%, -30%);
    width: calc(200 / 375 * 100vw);
    height: calc(150 / 375 * 100vw);
    -webkit-box-shadow: none;
            box-shadow: none;
  }
}

/*======================================
    Page-Recruit
======================================*/
.recruit-mv {
  background: url(../img/recruit/recruit-mv.jpg) no-repeat center 70%/cover;
}

.recruit__container {
  margin-top: clamp(80px, 8.22917vw, 158px);
  width: 92.3959%;
  margin-left: auto;
  border-top: 4px solid #0960C8;
  border-left: 4px solid #0960C8;
  border-bottom: 4px solid #0960C8;
}

.recruit__wrap {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1.6fr;
      grid-template-columns: 1fr 1.6fr;
  grid-column-gap: calc(90 / 1920 * 100vw);
  margin-left: calc(80 / 1920 * 100vw);
  padding-left: calc(40 / 1920 * 100vw);
  padding-right: calc(50 / 1920 * 100vw);
  padding-bottom: 60px;
  -webkit-transform: translateY(-6%);
          transform: translateY(-6%);
  background-color: #fff;
  position: relative;
}

.recruit__wrap::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: calc(619 / 1920 * 100vw);
  height: calc(479 / 1920 * 100vw);
  -webkit-transform: translateY(18%);
          transform: translateY(18%);
  background-color: #0960C8;
  z-index: -1;
}

@media screen and (max-width: 768px) {
  .recruit__wrap::after {
    -webkit-transform: translateY(30%);
            transform: translateY(30%);
    width: calc(150 / 375 * 100vw);
    height: calc(180 / 375 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .recruit__wrap {
    -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
  }
}

.recruit__contents {
  font-size: clamp(1.4rem, 1.38889vw, 2rem);
  line-height: 1.75;
}

@media screen and (min-width: 1440px) {
  .recruit__contents {
    font-size: max(20 / 1920 * 100vw,, 2rem);
  }
}

.recruit__title .section__title {
  display: block;
}

.recruit__title .section__title .section__title--en {
  margin-top: 0.16em;
}

.recruit__lead {
  font-size: clamp(1.8rem, 2.08333vw, 3rem);
  font-weight: 700;
  margin-top: 4.2em;
  position: relative;
}

@media screen and (min-width: 1440px) {
  .recruit__lead {
    font-size: max(30 / 1920 * 100vw, 3rem);
  }
}

.recruit__lead::before {
  content: "";
  position: absolute;
  top: 0;
  left: 2.4em;
  -webkit-transform: translateY(-150%);
          transform: translateY(-150%);
  width: 1px;
  height: 2.1em;
  background-color: #0960C8;
}

.recruit__text {
  margin-top: 1em;
}

.recruit__img {
  -webkit-transform: translateY(6%);
          transform: translateY(6%);
  padding-top: 10px;
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 768px) {
  .recruit__img {
    margin-top: 20px;
  }
}

.recruit__img img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

@media screen and (max-width: 768px) {
  .recruit__img::before {
    content: "";
    display: block;
    padding-top: calc(539 / 917 * 100%);
    z-index: 2;
  }
}

/*======================================
    Job Description
======================================*/
.job-info {
  margin-top: 146px;
}

.job-info__mv {
  text-align: center;
  background: url(../img/recruit/job-description-mv.jpg) no-repeat center 60%/cover;
  position: relative;
}

.job-info__mv::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(9, 96, 200, 0.4);
}

.job-info__title {
  font-size: clamp(3rem, 3.38542vw, 6.5rem);
  font-weight: 700;
  color: #fff;
  padding: 2.2em 0 2.8em;
  letter-spacing: 0.1em;
  position: relative;
  z-index: 2;
}

.job-info__title span {
  display: block;
  font-size: 0.7692em;
  font-family: "Gill Sans", "Gill Sans MT", "Calibri", sans-serif;
  font-weight: 600;
  margin-bottom: 0.8em;
}

.job-info__items {
  width: 1551px;
  max-width: 90%;
  margin: calc(128 / 1920 * 100vw) auto 0;
}

.job-info__item {
  background-color: rgba(239, 245, 251, 0.78);
  padding: 56px calc(128 / 1920 * 100vw);
}

@media screen and (max-width: 1439px) {
  .job-info__item {
    padding: 56px calc(80 / 1440 * 100vw);
  }
}

.job-info__item:nth-child(n + 2) {
  margin-top: min(130 / 1920 * 100vw, 130px);
}

.job-info__item--title {
  font-size: clamp(2rem, 2.77778vw, 4rem);
  font-weight: 700;
  padding-left: 0.8em;
  line-height: 1.75;
  position: relative;
}

.job-info__item--title::before {
  content: "";
  position: absolute;
  top: 0.25em;
  left: -0.2em;
  width: 0.325em;
  height: 1.23em;
  background-color: #0960C8;
}

.job-info__lists {
  margin-top: min(46 / 1920 * 100vw, 46px);
}

.job-info__list {
  position: relative;
}

.job-info__list::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 8px;
  background-image: radial-gradient(circle farthest-side, #0960C8 20%, transparent 20%, transparent 100%);
  background-size: 8px 8px;
  background-position: 0 0;
  -webkit-transform: translateY(25%);
          transform: translateY(25%);
}

.job-info__dl {
  font-size: clamp(1.6rem, 1.73611vw, 2.5rem);
  line-height: 1.76;
  padding: 1em 0 1em;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 200px auto;
      grid-template-columns: 200px auto;
  grid-column-gap: calc(90 / 1920 * 100vw);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

@media screen and (max-width: 1439px) {
  .job-info__dl {
    -ms-grid-columns: calc(200 / 1440 * 100vw) auto;
        grid-template-columns: calc(200 / 1440 * 100vw) auto;
  }
}

@media screen and (max-width: 768px) {
  .job-info__dl {
    -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
  }
}

.job-info__dl dt {
  font-weight: 700;
  color: #0960C8;
}

@media screen and (max-width: 768px) {
  .job-info__dl dt {
    padding-left: 0;
  }
}

@media screen and (max-width: 768px) {
  .job-info__dl dd {
    padding-left: 1em;
    margin-top: 0.5em;
  }
}

/*======================================
    Join
======================================*/
.join {
  margin-top: clamp(120px, 10.52083vw, 202px);
}

.join__container {
  width: 1555px;
  max-width: 90%;
  margin: 0 auto;
  border: 4px solid #0960C8;
  position: relative;
  padding: calc(54 / 1920 * 100vw) calc(40 / 1920 * 100vw) calc(70 / 1920 * 100vw);
}

@media screen and (min-width: 1440px) {
  .join__container {
    padding: 54px 40px 70px;
  }
}

@media screen and (max-width: 768px) {
  .join__container {
    padding-top: 40px;
  }
}

.join__title--container {
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

@media screen and (max-width: 768px) {
  .join__title--container {
    width: 92%;
    text-align: center;
    -webkit-transform: translate(-50%, -75%);
            transform: translate(-50%, -75%);
  }
}

.join__title {
  display: inline-block;
  background-color: #fff;
  font-size: clamp(2.6rem, 2.84722vw, 4.1rem);
  font-weight: 700;
  line-height: 1.78049;
  padding: 0 calc(90 / 1920 * 100vw);
  white-space: nowrap;
}

@media screen and (max-width: 768px) {
  .join__title {
    white-space: normal;
    font-size: calc(20 / 375 * 100vw);
    font-size: min(20 / 375 * 100vw, 2.6rem);
  }
}

.join__lead {
  font-size: clamp(1.6rem, 2.08333vw, 3rem);
  text-align: center;
  line-height: 1.76667;
}

@media screen and (min-width: 1440px) {
  .join__lead {
    -webkit-transform: translateX(0.5%);
            transform: translateX(0.5%);
  }
}

.join__contact {
  font-size: clamp(1.6rem, 2.08333vw, 3rem);
  text-align: center;
  padding-bottom: 60px;
  font-weight: 700;
  color: #0960C8;
  margin-top: 2.35em;
  position: relative;
}

.join__contact::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 25px 26px 0 26px;
  border-color: #0960C8 transparent transparent transparent;
}

.join__items {
  margin-top: min(68 / 1920 * 100vw, 68px);
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (1fr)[2];
      grid-template-columns: repeat(2, 1fr);
  grid-auto-flow: column;
  -ms-grid-rows: auto 1fr;
      grid-template-rows: auto 1fr;
  grid-column-gap: 5%;
  grid-row-gap: 10px;
}

@media screen and (max-width: 768px) {
  .join__items {
    display: block;
  }
}

.join__item {
  display: contents;
}

@media screen and (max-width: 768px) {
  .join__item {
    display: block;
  }
  .join__item:nth-child(n + 2) {
    margin-top: 40px;
  }
}

.join__item--text {
  text-align: center;
  font-size: clamp(1.6rem, 1.5625vw, 3rem);
  line-height: 1.76667;
  color: #0960C8;
  font-weight: 700;
  -ms-flex-item-align: center;
      -ms-grid-row-align: center;
      align-self: center;
}

.join__item--link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 256px;
  background: url(../img/station-inter.jpg) no-repeat center center/cover;
  background-color: rgba(207, 231, 251, 0.6);
  background-blend-mode: lighten;
  position: relative;
}

@media screen and (max-width: 1199px) {
  .join__item--link {
    height: calc(256 / 1200 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .join__item--link {
    margin-top: 20px;
    height: 256px;
  }
}

.join__item--link::before {
  content: "";
  position: absolute;
  top: 20px;
  left: 50%;
  bottom: 20px;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 91.42%;
  border: 3px solid #0960C8;
}

@media screen and (max-width: 1199px) {
  .join__item--link::before {
    top: 10px;
    bottom: 10px;
  }
}

.join__item--link.-link2 {
  background: url(../img/station-minami.jpg) no-repeat center center/cover;
  background-color: rgba(9, 96, 200, 0.4);
  background-blend-mode: darken;
  color: #fff;
  font-size: clamp(1.8rem, 1.5625vw, 3rem);
  font-weight: 700;
}

.join__item--link.-link2::before {
  border: 3px solid #fff;
}

.join__item--tel {
  display: block;
  font-size: clamp(2.2rem, 2.55208vw, 4.9rem);
  font-family: "Gill Sans", "Gill Sans MT", "Calibri", sans-serif;
  color: #0960C8;
  font-weight: 600;
  letter-spacing: 0.15em;
  -webkit-transform: translateY(-25%);
          transform: translateY(-25%);
}

.join__item--person {
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translate(-50%, calc(-100% - 26px));
          transform: translate(-50%, calc(-100% - 26px));
  display: block;
  margin-top: 58px;
  font-size: clamp(1.2rem, 1.45833vw, 2.8rem);
  font-weight: 700;
  white-space: nowrap;
}

/*======================================
    Page-Contact
======================================*/
.contact-mv {
  background: url(../img/service/service1-bg.jpg) no-repeat center 60%/cover;
}

.contact-mv::before {
  background-color: rgba(9, 96, 200, 0.2);
}

.contact__title {
  margin-top: min(154 / 1440 * 100vw, 142px);
  display: block;
  text-align: center;
}

.contact__message {
  margin-top: min(114 / 1440 * 100vw, 100px);
  font-size: clamp(1.4rem, 1.38889vw, 2rem);
  line-height: 1.75;
  text-align: center;
  letter-spacing: 0.05em;
}

.contact__head--container {
  overflow: hidden;
  text-align: center;
  background: #F6F6F6;
  width: 1486px;
  max-width: 90%;
  margin: 0 auto;
  margin-top: min(140 / 1440 * 100vw, 130px);
  padding: 10px 10px 30px;
  font-size: clamp(1.4rem, 1.38889vw, 2rem);
}

.contact__head--lead {
  font-size: 1.5em;
  font-weight: 700;
  line-height: 1.76667;
}

@media screen and (min-width: 1440px) {
  .contact__head--lead {
    -webkit-transform: translateX(3%);
            transform: translateX(3%);
  }
}

.contact__head--tel {
  padding-top: 10px;
  text-align: center;
}

.contact__head--tel .top-station__item--tel {
  display: block;
  font-size: clamp(2.4rem, 3.40278vw, 4.9rem);
  letter-spacing: 0.2em;
  -webkit-transform: translateX(-1%);
          transform: translateX(-1%);
}

.contact__head--person {
  margin-top: 1em;
  font-weight: 700;
  letter-spacing: 0.1em;
  display: inline-block;
  padding-left: 8em;
}

@media screen and (max-width: 768px) {
  .contact__head--person {
    padding-left: 0;
  }
}

.form__container {
  width: 1486px;
  max-width: 95%;
  margin: 0 auto;
  margin-top: min(220 / 1440 * 100vw, 220px);
  border: 4px solid #0960C8;
  padding: 108px 10px 80px;
  font-size: clamp(1.6rem, 1.38889vw, 2rem);
}

@media screen and (max-width: 1199px) {
  .form__container {
    font-size: clamp(1.4rem, 1.33333vw, 16rem);
    padding: calc(120 / 1200 * 100vw) 10px calc(80 / 1200 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .form__container {
    padding-bottom: max(40 / 375 * 100vw, 40px);
  }
}

.form__title {
  text-align: center;
  font-size: 1.5em;
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .form__title {
    font-size: calc(21 / 375 * 100vw);
    font-size: min(21 / 375 * 100vw, 26px);
  }
}

.form__title span {
  display: block;
  font-family: "Gill Sans", "Gill Sans MT", "Calibri", sans-serif;
  font-weight: 600;
  font-size: 2.4em;
  color: #0960C8;
  letter-spacing: 0.1em;
  padding-bottom: 0.4em;
}

@media screen and (max-width: 768px) {
  .form__title span {
    font-size: calc(30 / 375 * 100vw);
    font-size: min(30 / 375 * 100vw, 50px);
  }
}

.form__message {
  width: 658px;
  max-width: 90%;
  margin: 0 auto;
  margin-top: min(110 / 1440 * 100vw, 110px);
  line-height: 1.75;
}

.form__message .is__required {
  font-size: 1.25em;
  padding: 0;
  line-height: 1;
}

@media screen and (max-width: 768px) {
  .form__message {
    margin-top: calc(50 / 375 * 100vw);
  }
}

.form__wrap {
  width: 1088px;
  max-width: 95%;
  margin: 0 auto;
  margin-top: min(86 / 1440 * 100vw, 86px);
}

.form__list:first-child {
  padding-bottom: 20px;
}

.form__list:nth-child(n + 2) {
  margin-top: min(36 / 1440 * 100vw, 36px);
}

@media screen and (max-width: 768px) {
  .form__list:nth-child(n + 2) {
    margin-top: 30px;
  }
}

.form__dl {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 310px auto;
      grid-template-columns: 310px auto;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
  grid-column-gap: min(54 / 1440 * 100vw, 54px);
}

@media screen and (max-width: 1199px) {
  .form__dl {
    -ms-grid-columns: calc(240 / 769 * 100vw) auto;
        grid-template-columns: calc(240 / 769 * 100vw) auto;
  }
}

@media screen and (max-width: 768px) {
  .form__dl {
    -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
    grid-row-gap: 10px;
  }
}

.form__dl dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  font-size: 2.5rem;
  font-weight: 700;
  padding-top: 1em;
}

@media screen and (max-width: 1199px) {
  .form__dl dt {
    font-size: 20px;
  }
}

@media screen and (max-width: 768px) {
  .form__dl dt {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: start;
    gap: 1em;
    font-size: 1.6rem;
  }
}

.form__dl dd input[type="text"],
.form__dl dd input[type="tel"],
.form__dl dd input[type="email"] {
  -webkit-box-shadow: none;
          box-shadow: none;
  border: none;
  background-color: #D9E8F6;
  padding: 0.75em 0.88em;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border-radius: 0;
  color: inherit;
  font-family: inherit;
  font-size: 25px;
  width: 100%;
}

@media screen and (max-width: 768px) {
  .form__dl dd input[type="text"],
  .form__dl dd input[type="tel"],
  .form__dl dd input[type="email"] {
    font-size: 1.6rem;
  }
}

.form__dl dd input::-webkit-input-placeholder,
.form__dl dd textarea::-webkit-input-placeholder {
  color: #B8B8B9;
  font-size: 25px;
}

.form__dl dd input:-ms-input-placeholder,
.form__dl dd textarea:-ms-input-placeholder {
  color: #B8B8B9;
  font-size: 25px;
}

.form__dl dd input::-ms-input-placeholder,
.form__dl dd textarea::-ms-input-placeholder {
  color: #B8B8B9;
  font-size: 25px;
}

.form__dl dd input::placeholder,
.form__dl dd textarea::placeholder {
  color: #B8B8B9;
  font-size: 25px;
}

@media screen and (max-width: 1199px) {
  .form__dl dd input::-webkit-input-placeholder,
  .form__dl dd textarea::-webkit-input-placeholder {
    font-size: 20px;
  }
  .form__dl dd input:-ms-input-placeholder,
  .form__dl dd textarea:-ms-input-placeholder {
    font-size: 20px;
  }
  .form__dl dd input::-ms-input-placeholder,
  .form__dl dd textarea::-ms-input-placeholder {
    font-size: 20px;
  }
  .form__dl dd input::placeholder,
  .form__dl dd textarea::placeholder {
    font-size: 20px;
  }
}

@media screen and (max-width: 768px) {
  .form__dl dd input::-webkit-input-placeholder,
  .form__dl dd textarea::-webkit-input-placeholder {
    font-size: 1.6rem;
  }
  .form__dl dd input:-ms-input-placeholder,
  .form__dl dd textarea:-ms-input-placeholder {
    font-size: 1.6rem;
  }
  .form__dl dd input::-ms-input-placeholder,
  .form__dl dd textarea::-ms-input-placeholder {
    font-size: 1.6rem;
  }
  .form__dl dd input::placeholder,
  .form__dl dd textarea::placeholder {
    font-size: 1.6rem;
  }
}

.form__dl dd input:focus {
  outline: none;
}

.form__dl dd textarea {
  -webkit-box-shadow: none;
          box-shadow: none;
  border: none;
  background: #D9E8F6;
  padding: 1.03em 0.88em;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border-radius: 0;
  color: inherit;
  font-family: inherit;
  font-size: 20px;
  width: 100%;
  resize: vertical;
  height: 377px;
}

@media screen and (max-width: 768px) {
  .form__dl dd textarea {
    font-size: 1.6rem;
  }
}

.is__required {
  display: inline-block;
  font-weight: 700;
  width: 2.8em;
  text-align: center;
  padding: 0.045em 0;
  background-color: #0960C8;
  color: #fff;
  margin-right: 0.2em;
}

.form__radio {
  font-size: 1.1em;
  display: block;
  margin-left: -2.0909em;
  padding-top: -1.1705em;
}

.form__radio input[type="radio"] {
  display: none;
}

.form__radio [type="radio"]:checked + span::after {
  display: block;
}

.radio__label {
  display: inline-block;
  padding-left: 2.0909em;
  margin-top: 1.1705em;
}

.radio {
  display: inline-block;
  padding-left: 1.9091em;
  position: relative;
}

.radio::before {
  content: "";
  width: 1.2273em;
  height: 1.2273em;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background: #E9E9E9;
}

.radio::after {
  content: "";
  width: 0.6818em;
  height: 0.6818em;
  background: #383838;
  border-radius: 50%;
  position: absolute;
  left: 0.27275em;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  display: none;
}

.form__submit {
  margin-top: clamp(40px, 3.95833vw, 76px);
  text-align: center;
}

.form__submit input[type="submit"] {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  font-family: inherit;
  font-size: 30px;
  border: none;
  background-color: #0960C8;
  font-weight: 700;
  color: #fff;
  padding: 0.35em 0.5em;
  width: 244px;
  max-width: 100%;
  display: inline-block;
  border-radius: 33px;
  -webkit-box-shadow: none;
          box-shadow: none;
  letter-spacing: 0.1em;
  -webkit-transition: opacity .3s ease;
  transition: opacity .3s ease;
}

@media screen and (max-width: 768px) {
  .form__submit input[type="submit"] {
    font-size: 2rem;
  }
}

.form__submit input[type="submit"]:hover {
  opacity: 0.7;
}

.address {
  margin-bottom: min(20 / 1440 * 100vw, 20px);
}

.address input[type="text"] {
  background: url(../img/contact/postcode.svg) no-repeat top 1em left 0.88em/0.9em 0.9em;
  padding-left: 2.5em !important;
}

/*======================================
    animation
======================================*/
.slide {
  overflow: hidden;
}

.slideL,
.slideR {
  overflow: hidden;
  opacity: 0;
  width: 100%;
  height: 100%;
}

.isPlayL {
  -webkit-animation-name: playL;
          animation-name: playL;
  -webkit-animation-duration: .5s;
          animation-duration: .5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  -webkit-animation-timing-function: cubic-bezier(0.8, 0, 0.5, 1);
          animation-timing-function: cubic-bezier(0.8, 0, 0.5, 1);
  position: relative;
  opacity: 1 !important;
}

.isPlayL:after {
  -webkit-animation-name: maskOutL;
          animation-name: maskOutL;
  -webkit-animation-duration: .5s;
          animation-duration: .5s;
  -webkit-animation-delay: .5s;
          animation-delay: .5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  -webkit-animation-timing-function: cubic-bezier(0.8, 0, 0.5, 1);
          animation-timing-function: cubic-bezier(0.8, 0, 0.5, 1);
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-color: #0960C8;
}

@-webkit-keyframes playL {
  from {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  to {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@keyframes playL {
  from {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  to {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@-webkit-keyframes maskOutL {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(101%);
            transform: translateX(101%);
  }
}

@keyframes maskOutL {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(101%);
            transform: translateX(101%);
  }
}

.isPlayR {
  -webkit-animation-name: playR;
          animation-name: playR;
  -webkit-animation-duration: .5s;
          animation-duration: .5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  -webkit-animation-timing-function: cubic-bezier(0.8, 0, 0.5, 1);
          animation-timing-function: cubic-bezier(0.8, 0, 0.5, 1);
  position: relative;
  opacity: 1 !important;
}

.isPlayR:after {
  -webkit-animation-name: maskOutR;
          animation-name: maskOutR;
  -webkit-animation-duration: .5s;
          animation-duration: .5s;
  -webkit-animation-delay: .5s;
          animation-delay: .5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  -webkit-animation-timing-function: cubic-bezier(0.8, 0, 0.5, 1);
          animation-timing-function: cubic-bezier(0.8, 0, 0.5, 1);
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-color: #0960C8;
}

@-webkit-keyframes playR {
  from {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  to {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@keyframes playR {
  from {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  to {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@-webkit-keyframes maskOutR {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-101%);
            transform: translateX(-101%);
  }
}

@keyframes maskOutR {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-101%);
            transform: translateX(-101%);
  }
}

.fadeIn {
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(50px);
          transform: translateY(50px);
  -webkit-transition: opacity 1s, visibility 1s, -webkit-transform 1s;
  transition: opacity 1s, visibility 1s, -webkit-transform 1s;
  transition: opacity 1s, visibility 1s, transform 1s;
  transition: opacity 1s, visibility 1s, transform 1s, -webkit-transform 1s;
  -webkit-transition: opacity 1s ease 0.5s, visibility 1s ease 0.5s, -webkit-transform 1s ease 0.5s;
  transition: opacity 1s ease 0.5s, visibility 1s ease 0.5s, -webkit-transform 1s ease 0.5s;
  transition: opacity 1s ease 0.5s, visibility 1s ease 0.5s, transform 1s ease 0.5s;
  transition: opacity 1s ease 0.5s, visibility 1s ease 0.5s, transform 1s ease 0.5s, -webkit-transform 1s ease 0.5s;
}

.fadeInUp {
  opacity: 1;
  visibility: visible;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
