/*==========================================================================

   mixin

===========================================================================*/
/*--------------------------------------------------------------------------
   overwrite
---------------------------------------------------------------------------*/
.g-header .gnav__item--04 a {
  color: #0B8943;
}

.page-access .l-page-wrapper {
  overflow: hidden;
}

.m-intro__obj-slide {
  height: 111px;
}

/*--------------------------------------------------------------------------
   common
---------------------------------------------------------------------------*/
/* section
-----------------------------------------------------------------*/
/*--------------------------------------------------------------------------
   sec-walk
---------------------------------------------------------------------------*/
.sec-walk {
  position: relative;
}
.sec-walk__content {
  position: relative;
  max-width: 991px;
  width: 100%;
  padding: 0 20px;
  margin: 0 auto;
}
.sec-walk__info {
  position: relative;
}
.sec-walk__hdg {
  position: absolute;
  top: -0.8em;
  left: 50%;
  padding: 0 40px;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  border-bottom: 1px solid #000;
  font-family: "Heebo", sans-serif;
  font-size: 30px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-align: center;
  white-space: nowrap;
}
.sec-walk__time {
  text-align: center;
}
.sec-walk__time img {
  max-width: 100%;
  height: auto;
}
.sec-walk__station {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 46px;
}
.sec-walk__img {
  position: relative;
  max-width: 450px;
  width: 47.3%;
}
.sec-walk__img img {
  width: 100%;
  height: auto;
}
.sec-walk__img figcaption {
  position: absolute;
  right: 0;
  bottom: 0;
}

/*--------------------------------------------------------------------------
   sec-train
---------------------------------------------------------------------------*/
.sec-train {
  position: relative;
  margin-top: 155px;
  background-color: #fff;
}
.sec-train__content {
  position: relative;
  max-width: 990px;
  width: 100%;
  padding: 140px 20px 106px;
  margin: 0 auto;
}
.sec-train__catch {
  position: absolute;
  top: -0.35em;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  font-family: "Heebo", sans-serif;
  font-size: 150px;
  font-weight: 400;
  color: #eee;
  line-height: 1;
  letter-spacing: 0.05em;
  white-space: nowrap;
}
.sec-train__lead {
  font-family: "Noto Serif JP", serif, sans-serif;
  font-size: 30px;
  text-align: center;
}
.sec-train__txt {
  margin-top: 30px;
  font-family: "Noto Serif JP", serif, sans-serif;
  font-size: 18px;
  text-align: center;
  line-height: 2.22;
}
.sec-train__body {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 100px;
}
.sec-train__trainmap {
  max-width: 371px;
}
.sec-train__trainmap img {
  width: 100%;
  height: auto;
}
.sec-train__info {
  position: relative;
  margin-top: 30px;
}
.sec-train__hdg {
  position: absolute;
  top: -0.8em;
  left: 50%;
  padding: 0 40px;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  border-bottom: 1px solid #000;
  font-family: "Heebo", sans-serif;
  font-size: 30px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-align: center;
  white-space: nowrap;
}
.sec-train__time {
  text-align: center;
}
.sec-train__time img {
  max-width: 100%;
  height: auto;
}
.sec-train__place-list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
.sec-train__place-item {
  position: relative;
  z-index: 0;
}
.sec-train__place-item .name {
  position: absolute;
  top: 35px;
  left: 30px;
  z-index: 2;
  color: #fff;
}
.sec-train__place-item .name__hdg {
  font-family: "League Spartan", sans-serif;
  text-shadow: 2px 2px 10px rgba(0, 0, 0, .5);
  line-height: 1;
}
.sec-train__place-item .name__time {
  position: relative;
  top: -10px;
  text-shadow: 2px 2px 10px rgba(0, 0, 0, .5);
}
.sec-train__place-item .name__time span {
  font-family: "League Spartan", sans-serif;
  line-height: 1;
}
.sec-train__place-item .img {
  position: relative;
}
.sec-train__place-item .img img {
  width: 100%;
  height: auto;
}
.sec-train__place-item .img figcaption {
  position: absolute;
  right: 0;
  bottom: 0;
}
.sec-train__place-list--main .sec-train__place-item {
  width: 50%;
}
.sec-train__place-list--main .name {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  top: 50px;
}
.sec-train__place-list--main .name__hdg {
  font-size: 64px;
}
.sec-train__place-list--main .name__time {
  top: -38px;
  left: 15px;
  font-size: 64px;
}
.sec-train__place-list--main .name__time span {
  font-size: 96px;
}
.sec-train__place-list--sub .sec-train__place-item {
  width: 33.3333333333%;
}
.sec-train__place-list--sub .name__hdg {
  font-size: 48px;
}
.sec-train__place-list--sub .name__time {
  font-size: 48px;
}
.sec-train__place-list--sub .name__time span {
  font-size: 64px;
}

/*--------------------------------------------------------------------------
   custom animation
---------------------------------------------------------------------------*/

@media screen and (min-width: 768px) and (max-width: 991px) {
  .sec-walk__hdg {
    font-size: 3.02vw;
  }
}

@media only screen and (max-width: 767px) {
  .sec-walk__hdg {
    padding: 0 10px;
    font-size: 20px;
    letter-spacing: 0.05em;
  }
  .sec-walk__time img {
    max-width: none;
    width: 100%;
  }
  .sec-walk__station {
    display: block;
  }
  .sec-walk__img {
    max-width: none;
    width: auto;
    margin-bottom: 10px;
  }
  .sec-train {
    margin-top: 80px;
  }
  .sec-train__content {
    padding: 100px 20px 50px;
  }
  .sec-train__catch {
    font-size: 70px;
    left: 18px;
    -webkit-transform: none;
            transform: none;
  }
  .sec-train__lead {
    font-size: 20px;
    text-align: left;
    line-height: 1.8;
  }
  .sec-train__txt {
    margin-top: 20px;
    font-size: 14px;
    text-align: left;
    line-height: 2;
  }
  .sec-train__body {
    display: block;
    margin-top: 48px;
  }
  .sec-train__trainmap {
    max-width: none;
  }
  .sec-train__info {
    margin-top: 90px;
  }
  .sec-train__hdg {
    padding: 0 10px;
    font-size: 20px;
    letter-spacing: 0.05em;
  }
  .sec-train__time img {
    max-width: none;
    width: 100%;
  }
  .sec-train__place-list {
    display: block;
  }
  .sec-train__place-item .name {
    top: 25px;
    left: 20px;
  }
  .sec-train__place-list--main .sec-train__place-item {
    width: 100%;
  }
  .sec-train__place-list--main .name {
    display: block;
  }
  .sec-train__place-list--main .name__hdg {
    font-size: 36px;
  }
  .sec-train__place-list--main .name__time {
    top: -10px;
    left: 0;
    font-size: 36px;
  }
  .sec-train__place-list--main .name__time span {
    font-size: 48px;
  }
  .sec-train__place-list--sub .sec-train__place-item {
    width: 100%;
  }
  .sec-train__place-list--sub .name__hdg {
    font-size: 36px;
  }
  .sec-train__place-list--sub .name__time {
    font-size: 36px;
  }
  .sec-train__place-list--sub .name__time span {
    font-size: 48px;
  }
}

@media screen and (min-width: 768px) and (max-width: 1440px) {
  .sec-train__content {
    padding: 9.72vw 1.38vw 7.36vw;
  }
  .sec-train__catch {
    font-size: 10.4vw;
  }
  .sec-train__place-list--main .name__hdg {
    font-size: 4.44vw;
  }
  .sec-train__place-list--main .name__time {
    top: -2.63vw;
    font-size: 4.44vw;
  }
  .sec-train__place-list--main .name__time span {
    font-size: 6.66vw;
  }
  .sec-train__place-list--sub .name__hdg {
    font-size: 3.33vw;
  }
  .sec-train__place-list--sub .name__time {
    font-size: 3.33vw;
  }
  .sec-train__place-list--sub .name__time span {
    font-size: 4.44vw;
  }
}

@media screen and (min-width: 768px) and (max-width: 950px) {
  .sec-train__trainmap {
    width: 39vw;
  }
  .sec-train__info {
    width: 53.68vw;
  }
  .sec-train__hdg {
    font-size: 3.15vw;
  }
  .sec-train__place-item .name {
    left: 3.15vw;
  }
}
/*# sourceMappingURL=../maps/access/style.css.map */
