.introSect__cont {
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .introSect__cont {
    max-width: 1000px;
  }
}
@media print, screen and (min-width: 768px) and (max-width: 1000px) {
  .introSect__cont {
    width: 100%;
  }
}
.introSect__cont .touchFigure__capOut {
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .introSect__cont .touchFigure--swipe {
    height: 300px;
    margin-left: 0;
    width: calc(100vw - 24px);
  }
}
@media screen and (min-width: 768px) {
  .introSect__head + .introSect__cont {
    margin-top: 80px;
  }
}
@media screen and (max-width: 768px) {
  .introSect__head + .introSect__cont {
    margin-top: 60px;
  }
}
@media screen and (min-width: 768px) {
  .introSect__bottom {
    margin-top: 80px;
  }
}
@media screen and (max-width: 768px) {
  .introSect__bottom {
    margin-top: 60px;
  }
}
.introSect__bottom .usableList__inner {
  flex-wrap: wrap;
}
@media screen and (min-width: 768px) {
  .introSect__bottom .usableList__inner {
    gap: 40px;
  }
}
@media print, screen and (min-width: 768px) and (max-width: 1208px) {
  .introSect__bottom .usableList__inner {
    justify-content: center;
  }
}
@media screen and (max-width: 768px) {
  .introSect__bottom .usableList__inner {
    gap: 20px 10px;
  }
}
@media screen and (min-width: 768px) {
  .introSect__bottom .usableList__item {
    min-width: 272px;
    width: calc((100% - 120px) / 4);
  }
}
@media screen and (max-width: 768px) {
  .introSect__bottom .usableList__item {
    width: calc(50% - 5px);
  }
}
.introSect__bottom .usableList__note {
  text-align: left;
}
@media screen and (max-width: 768px) {
  .accessCard {
    align-items: center;
    display: flex;
    flex-direction: column;
    height: 100%;
    justify-content: space-between;
  }
}
.accessCard__ttl {
  align-items: center;
  color: #82877D;
  display: flex;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .accessCard__ttl {
    gap: 20px;
    justify-content: center;
  }
}
@media screen and (max-width: 768px) {
  .accessCard__ttl {
    gap: 10px;
    justify-content: space-between;
  }
}
.accessCard__ttl .place {
  display: inline-block;
  text-align: justify;
  -moz-text-align-last: justify;
       text-align-last: justify;
  white-space: nowrap;
  width: 65px;
  line-height: 1.6;
}
.accessCard__ttl .place:before {
  content: "";
  margin-top: calc((1 - 1.6) * 0.5em);
}
.accessCard__ttl .place:after {
  margin-bottom: calc((1 - 1.6) * 0.5em);
}
.accessCard__ttl .place:before, .accessCard__ttl .place:after {
  content: "";
  display: block;
  height: 0;
  width: 0;
}
@media screen and (min-width: 768px) {
  .accessCard__ttl .place {
    font-size: 20px;
  }
}
@media screen and (max-width: 768px) {
  .accessCard__ttl .place {
    font-size: 18px;
  }
}
.accessCard__ttl .unit {
  display: inline-block;
  font-size: 14px;
  letter-spacing: 0.08em;
  line-height: 1.6;
}
.accessCard__ttl .unit:before {
  content: "";
  margin-top: calc((1 - 1.6) * 0.5em);
}
.accessCard__ttl .unit:after {
  margin-bottom: calc((1 - 1.6) * 0.5em);
}
.accessCard__ttl .unit:before, .accessCard__ttl .unit:after {
  content: "";
  display: block;
  height: 0;
  width: 0;
}
.accessCard__ttl .unit {
  position: relative;
}
.accessCard__ttl .num {
  display: inline-block;
  letter-spacing: 0.08em;
  line-height: 0.8;
}
@media screen and (min-width: 768px) {
  .accessCard__ttl .num {
    font-size: 40px;
  }
}
@media screen and (max-width: 768px) {
  .accessCard__ttl .num {
    font-size: 36px;
  }
}
.accessCard__ttl .dayTime {
  bottom: 10px;
  color: rgba(130, 135, 125, 0.7);
  display: block;
  letter-spacing: 0.01em;
  position: absolute;
}
@media screen and (min-width: 768px) {
  .accessCard__ttl .dayTime {
    font-size: 14px;
    right: -15px;
  }
}
@media screen and (max-width: 768px) {
  .accessCard__ttl .dayTime {
    font-size: 12px;
    right: -10px;
  }
}
.accessCard__ttl .dayTime .small {
  font-size: 10px;
}
.accessCard__note {
  letter-spacing: 0.08em;
  text-align: center;
  line-height: 1.6;
}
.accessCard__note:before {
  content: "";
  margin-top: calc((1 - 1.6) * 0.5em);
}
.accessCard__note:after {
  margin-bottom: calc((1 - 1.6) * 0.5em);
}
.accessCard__note:before, .accessCard__note:after {
  content: "";
  display: block;
  height: 0;
  width: 0;
}
@media screen and (min-width: 768px) {
  .accessCard__note {
    font-size: 12px;
  }
}
@media screen and (max-width: 768px) {
  .accessCard__note {
    font-size: 10px;
  }
}
.accessCard__ttl + .accessCard__note {
  margin-top: 16px;
}
.accessCard__head + .accessCard__body {
  margin-top: 12px;
}
.expressSect {
  background-color: #697369;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .expressSect {
    max-width: 1000px;
  }
}
@media print, screen and (min-width: 768px) and (max-width: 1000px) {
  .expressSect {
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .expressSect {
    display: grid;
    grid-gap: 40px;
    gap: 40px;
    grid-template-columns: repeat(2, 1fr);
    padding: 80px;
  }
}
@media screen and (max-width: 768px) {
  .expressSect {
    padding: 40px;
  }
}
@media screen and (max-width: 768px) {
  .expressSect > * + * {
    margin-top: 40px;
  }
}
.expressSect__body {
  color: #fff;
}
@media screen and (min-width: 768px) {
  .expressSect__body {
    grid-column: 1/2;
    grid-row: 1/2;
    width: 400px;
  }
}
.expressSect__body .headingCombi .heading,
.expressSect__body .headingCombi .txt {
  color: #fff;
}
@media screen and (max-width: 768px) {
  .expressSect__body .headingCombi .heading {
    font-size: 22px;
    white-space: nowrap;
  }
}
.expressSect__body .headingCombi + .photo {
  margin-top: 40px;
}
.expressSect__tags {
  display: flex;
  margin: 40px auto 0;
  width: -moz-fit-content;
  width: fit-content;
}
.expressSect__tag {
  align-items: center;
  background-color: #82877D;
  display: flex;
  font-size: 18px;
  justify-content: center;
  letter-spacing: 0.08em;
  padding: 16px;
}
.expressSect__tag .inner {
  display: block;
  line-height: 1.6;
}
.expressSect__tag .inner:before {
  content: "";
  margin-top: calc((1 - 1.6) * 0.5em);
}
.expressSect__tag .inner:after {
  margin-bottom: calc((1 - 1.6) * 0.5em);
}
.expressSect__tag .inner:before, .expressSect__tag .inner:after {
  content: "";
  display: block;
  height: 0;
  width: 0;
}
.expressSect__tag--plus {
  background-color: #697369;
}
.expressSect__note {
  color: #fff;
  display: flex;
  font-size: 12px;
  gap: 0.5em;
  letter-spacing: 0.08em;
  line-height: 1.6;
}
.expressSect__note .solid,
.expressSect__note .data {
  display: inline-block;
}
.expressSect__note .data {
  flex: 1;
}
* + .expressSect__note {
  margin-top: 14px;
}
@media screen and (min-width: 768px) {
  .expressSect__visual {
    width: 400px;
  }
}
.expressSect__visual .photo__image {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .expressSect__visual:first-child {
    grid-column: 2/3;
  }
}
.expressSect__image {
  align-items: center;
  display: flex;
  justify-content: center;
}
@media screen and (min-width: 768px) {
  .expressSect__image {
    border: 1px solid rgba(255, 255, 255, 0.1);
    height: 225px;
    padding: 10px;
  }
}
.trainSect__cont {
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .trainSect__cont {
    max-width: 1000px;
  }
}
@media print, screen and (min-width: 768px) and (max-width: 1000px) {
  .trainSect__cont {
    width: 100%;
  }
}
.trainSect__cont .touchFigure__capOut {
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .trainSect__cont .touchFigure--swipe {
    height: 300px;
    margin-left: 0;
    width: calc(100vw - 24px);
  }
}
@media screen and (min-width: 768px) {
  .trainSect__head + .trainSect__cont {
    margin-top: 80px;
  }
}
@media screen and (max-width: 768px) {
  .trainSect__head + .trainSect__cont {
    margin-top: 60px;
  }
}
.simulationSect {
  color: #fff;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .simulationSect {
    padding: 120px 0;
  }
}
@media screen and (max-width: 768px) {
  .simulationSect {
    padding: 80px 0;
  }
}
.simulationSect .heading,
.simulationSect .txt {
  color: #fff;
}
.simulationSect__head {
  position: relative;
  z-index: 2;
}
.simulationSect__cont {
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .simulationSect__cont {
    max-width: 1000px;
  }
}
@media print, screen and (min-width: 768px) and (max-width: 1000px) {
  .simulationSect__cont {
    width: 100%;
  }
}
.simulationSect__cont .touchFigure__capOut {
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .simulationSect__cont .touchFigure--swipe {
    height: 500px;
    margin-left: 0;
    width: calc(100vw - 24px);
  }
}
@media screen and (min-width: 768px) {
  .simulationSect__head + .simulationSect__cont {
    margin-top: 80px;
  }
}
@media screen and (max-width: 768px) {
  .simulationSect__head + .simulationSect__cont {
    margin-top: 60px;
  }
}
.simulationSect__bg {
  height: 100%;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 100vw;
  z-index: -1;
}
.simulationSect__bg .photo {
  height: 100%;
  width: 100%;
}
.simulationSect__bg .photo__pic, .simulationSect__bg .photo__image {
  height: 100%;
  width: 100%;
}
.simulationSect__bg .photo__image {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: top center;
     object-position: top center;
}
@media screen and (min-width: 768px) {
  .busSect__head .heading--large + .txt {
    max-width: 700px;
  }
}
.busSect__cont {
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .busSect__cont {
    max-width: 1000px;
  }
}
@media print, screen and (min-width: 768px) and (max-width: 1000px) {
  .busSect__cont {
    width: 100%;
  }
}
.busSect__cont .touchFigure__capOut {
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .busSect__cont .touchFigure--swipe {
    height: 300px;
    margin-left: 0;
    width: calc(100vw - 24px);
  }
}
@media screen and (min-width: 768px) {
  .busSect__head + .busSect__cont {
    margin-top: 80px;
  }
}
@media screen and (max-width: 768px) {
  .busSect__head + .busSect__cont {
    margin-top: 60px;
  }
}
.highwaySect {
  color: #fff;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .highwaySect {
    padding: 120px 0;
  }
}
@media screen and (max-width: 768px) {
  .highwaySect {
    padding: 80px 0;
  }
}
.highwaySect .heading,
.highwaySect .txt,
.highwaySect .accessCard__ttl {
  color: #fff;
}
.highwaySect .enTtl {
  color: #c9bc9c;
}
@media screen and (min-width: 768px) {
  .highwaySect__cont .usableList__inner {
    align-items: flex-start;
    gap: 40px;
  }
}
@media print, screen and (min-width: 768px) and (max-width: 1208px) {
  .highwaySect__cont .usableList__inner {
    justify-content: center;
  }
}
@media screen and (max-width: 768px) {
  .highwaySect__cont .usableList__inner {
    gap: 20px 10px;
  }
}
@media screen and (min-width: 768px) {
  .highwaySect__cont .usableList__item {
    min-width: 272px;
    width: calc((100% - 120px) / 4);
  }
}
@media screen and (max-width: 768px) {
  .highwaySect__cont .usableList__item {
    width: calc(50% - 5px);
  }
}
@media screen and (min-width: 768px) {
  .highwaySect__head + .highwaySect__cont {
    margin-top: 80px;
  }
}
@media screen and (max-width: 768px) {
  .highwaySect__head + .highwaySect__cont {
    margin-top: 60px;
  }
}
@media screen and (min-width: 768px) {
  .highwaySect__cont + .highwaySect__map {
    margin-top: 80px;
  }
}
@media screen and (max-width: 768px) {
  .highwaySect__cont + .highwaySect__map {
    margin-top: 60px;
  }
}
@media screen and (min-width: 768px) {
  .highwaySect__map .touchFigure {
    margin-left: auto;
    margin-right: auto;
    width: 890px;
  }
}
@media screen and (max-width: 768px) {
  .highwaySect__map .touchFigure__inner {
    padding-left: 26px;
  }
}
.highwaySect__bg {
  height: 100%;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 100vw;
  z-index: -1;
}
.highwaySect__bg .photo {
  height: 100%;
  width: 100%;
}
.highwaySect__bg .photo__pic, .highwaySect__bg .photo__image {
  height: 100%;
  width: 100%;
}
.highwaySect__bg .photo__image {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: top center;
     object-position: top center;
}
@media screen and (min-width: 768px) {
  .access-introduction {
    padding: 120px 0;
  }
}
@media screen and (max-width: 768px) {
  .access-introduction {
    padding: 80px 0;
  }
}
@media screen and (min-width: 768px) {
  .access-train {
    padding: 120px 0;
  }
}
@media screen and (max-width: 768px) {
  .access-train {
    padding: 80px 0;
  }
}
@media screen and (min-width: 768px) {
  .access-bus {
    padding: 120px 0;
  }
}
@media screen and (max-width: 768px) {
  .access-bus {
    padding: 80px 0;
  }
}
/*# sourceMappingURL=style.css.map */
