
.plan-your-trip .media01 .img_wrapper {
  height: auto;
}
.plan-your-trip .media01 {
  margin-top: 10.5rem;
}
.plan-your-trip .media02 {
  margin-top: 13rem;
}
.plan-your-trip .media03 {
  margin-top: 13rem;
}
.plan-your-trip .media04 {
  margin-top: 13rem;
}


@media screen and (max-width: 959.98px) {
  .kv_ttl-wrapper .icn {
    width: 6rem;
  }
  .routes-schedule .kv.lower .content_ttl span img {
    width: 4.4rem;
  }
}


#grid_slider .sub_ttl {
  font-size: 3.2rem;
  font-weight: 600;
  color: #002952;
  font-family: "Inter", sans-serif;
  margin-top: 4rem;
}
@media screen and (max-width: 959.98px) {
  #grid_slider .sub_ttl {
    font-size: 4.6rem;
    margin-top: 2rem;
  }
}

#grid_slider .grid_slider_content .ttl_txt_btn_wrapper .heading_txt {
  margin-top: 6rem;
}
@media screen and (max-width: 959.98px) {
  #grid_slider .grid_slider_content .ttl_txt_btn_wrapper .heading_txt {
    margin-top: 2rem;
  }
}
#grid_slider .g_slider {
  margin-top: 0;
}
@media screen and (max-width: 959.98px) {
  #grid_slider .g_slider {
    margin-top: 6rem;
  }
}

.grid_slider_content .btn_wrapper {
  margin-left: 0;
}

.grid_slider_content .g-swiper-pagenation-btn-wrapper {
  margin-top: 5rem;
}

.faq {
  margin-top: 13rem;
  position: relative;
}
.faq .bg_faq {
  height: 100%;
}
.faq .bg_faq img {
  min-height: 36.6rem;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 959.98px) {
  .faq .bg_faq img {
    min-height: inherit;
  }
}

.faq_content {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  right: 0;
  margin: 0 auto;
  z-index: 10;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 4rem 6rem;
  border-radius: 1.6rem;
  background-color: #fff;
  text-align: center;
}
@media screen and (max-width: 959.98px) {
  .faq_content {
    width: calc(100% - 9.6rem);
    padding: 6rem 1rem;
  }
}
.faq_content .icn {
  display: inline-block;
  margin-bottom: 2rem;
}
@media screen and (max-width: 959.98px) {
  .faq_content .icn {
    width: 9rem;
    height: 9rem;
  }
}
.faq_content .ttl {
  font-family: "Inter", sans-serif;
  font-size: 2.6rem;
  font-weight: 600;
  color: #002952;
}
@media screen and (max-width: 959.98px) {
  .faq_content .ttl {
    font-size: 4.8rem;
  }
}
@media screen and (max-width: 959.98px) {
  .faq_content .icn_arrow {
    margin-top: 2rem;
    padding-right: 8rem;
  }
  .faq_content .icn_arrow::before {
    width: 6rem;
    height: 6rem;
  }
  .faq_content .icn_arrow::after {
    border-width: 1px;
    right: 2.8rem;
    width: 1.4rem;
    height: 1.4rem;
  }
}

#travel-support {
  margin-top: 13rem;
}

.travel-support_content {
  background-color: #ebf2f7;
  max-width: 110rem;
  margin: 0 auto;
  padding: 6rem;
  box-sizing: content-box;
  border-radius: 1.6rem;
}
@media screen and (max-width: 959.98px) {
  .travel-support_content {
    border-radius: 0;
    padding: 8rem 6rem;
  }
}

.travel-support_upper {
  display: flex;
  justify-content: space-between;
  padding-bottom: 5.8rem;
}
@media screen and (max-width: 959.98px) {
  .travel-support_upper {
    display: block;
  }
}
.travel-support_upper .img_wrapper {
  max-width: 45.9rem;
  flex-shrink: 0;
}
@media screen and (max-width: 959.98px) {
  .travel-support_upper .img_wrapper {
    max-width: inherit;
    margin-top: 6rem;
  }
  .travel-support_upper .img_wrapper img {
    width: 100%;
  }
}
.travel-support_upper .txt_wrapper {
  display: flex;
  flex-direction: column;
  max-width: 56.3rem;
}
.travel-support_upper .txt_wrapper .heading_txt {
  font-size: 2.2rem;
  line-height: 1.6363636364;
  margin-top: 4rem;
  margin-bottom: 2rem;
  color: #000;
}
@media screen and (max-width: 959.98px) {
  .travel-support_upper .txt_wrapper .heading_txt {
    font-size: 3.2rem;
  }
}
.travel-support_upper .txt_wrapper .btn_wrapper {
  margin-top: auto;
}
@media screen and (max-width: 959.98px) {
  .travel-support_upper .txt_wrapper .btn_wrapper {
    margin: 2rem 0 0;
  }
}

.travel-support_bottom {
  border-top: 1px solid #9aa9ba;
  padding-top: 4rem;
}
.travel-support_bottom .ttl {
  font-family: "Inter", sans-serif;
  font-size: 3.2rem;
  font-weight: 600;
  color: #002952;
}
@media screen and (max-width: 959.98px) {
  .travel-support_bottom .ttl {
    font-size: 4.6rem;
  }
}

.support_list {
  margin-top: 4rem;
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: repeat(3, 1fr);
  gap: 4rem 1rem;
}
@media screen and (max-width: 959.98px) {
  .support_list {
    margin-top: 3rem;
    display: block;
  }
}

.support_item {
  font-size: 2rem;
  line-height: 1.8;
  display: flex;
  align-items: center;
  color: #000;
}
@media screen and (max-width: 959.98px) {
  .support_item {
    font-size: 3rem;
  }
  .support_item + .support_item {
    margin-top: 4rem;
  }
}
.support_item:nth-of-type(1) {
  grid-column: 1;
  grid-row: 1;
}
.support_item:nth-of-type(2) {
  grid-column: 1;
  grid-row: 2;
}
.support_item:nth-of-type(3) {
  grid-column: 1;
  grid-row: 3;
}
.support_item:nth-of-type(4) {
  grid-column: 2;
  grid-row: 1;
}
.support_item:nth-of-type(5) {
  grid-column: 2;
  grid-row: 2;
}
.support_item:nth-of-type(6) {
  grid-column: 2;
  grid-row: 3;
}
.support_item .icn {
  width: 8rem;
  height: 8rem;
  display: inline-block;
  margin-right: 2.2rem;
  flex-shrink: 0;
}
@media screen and (max-width: 959.98px) {
  .support_item .icn {
    width: 14rem;
    height: 14rem;
  }
}
.support_item a {
  text-decoration: none;
  color: currentColor;
  position: relative;
  transition: 0.3s color;
  display: inline-block;
  padding-right: 2.3rem;
}
@media (any-hover: hover) {
  .support_item a:hover {
    color: #0066bf;
  }
  .support_item a:hover::after {
    border-color: #0066bf;
  }
}
.support_item a::after {
  position: absolute;
  content: "";
  width: 0.7rem;
  height: 0.7rem;
  border-top: 1.5px solid #000;
  border-right: 1.5px solid #000;
  transform: rotate(45deg);
  bottom: 1.2rem;
  margin-left: 1rem;
  transition: 0.3s border-color;
}
@media screen and (max-width: 959.98px) {
  .support_item a::after {
    width: 1.4rem;
    height: 1.4rem;
    bottom: 1.7rem;
  }
}

/* ----------------------------------------------------------------------------------------------------
*	#trafficinfo
* --------------------------------------------------------------------------------------------------*/
#trafficinfo {
  padding-top: 8rem;
  padding-bottom: 4rem;
}
#trafficinfo .txt {
  font-size: 1.6rem;
  line-height: 1.75;
}
@media screen and (max-width: 959.98px) {
  #trafficinfo .txt {
    font-size: 3rem;
    line-height: 1.8;
  }
}
#trafficinfo .txt_btn_wrapper {
  display: flex;
  gap: 0 4rem;
  margin: 4rem auto 0;
  justify-content: space-between;
}
#trafficinfo .txt_btn_wrapper .txt {
  max-width: 80rem;
}
@media screen and (max-width: 959.98px) {
  #trafficinfo .txt_btn_wrapper {
    margin-top: 5rem;
    display: block;
    max-width: inherit;
  }
}
#trafficinfo .btn_wrapper {
  flex-shrink: 0;
}
@media screen and (max-width: 959.98px) {
  #trafficinfo .btn_wrapper {
    margin: 5rem auto 0;
  }
}
#trafficinfo .btn[target=_blank] {
  display: flex;
  align-items: center;
}
@media (any-hover: hover) {
  #trafficinfo .btn[target=_blank]:hover .icn {
    fill: #002952;
  }
}
#trafficinfo .btn[target=_blank] .icn {
  width: 1.2rem;
  height: 1.2rem;
  flex-shrink: 0;
  margin-left: 0.6rem;
  display: inline-block;
  fill: #fff;
  transition: 0.3s fill;
}
@media screen and (max-width: 959.98px) {
  #trafficinfo .btn[target=_blank] .icn {
    width: 2.4rem;
    height: 2.4rem;
    margin-left: 1.2rem;
  }
}
.win #trafficinfo .btn[target=_blank] .icn {
  position: relative;
  top: -0.1rem;
}
#trafficinfo .block_title {
  display: none;
}
#trafficinfo .block_state {
  margin-top: 4rem;
  background-color: #ebf2f7;
  border-radius: 2rem;
}
@media screen and (max-width: 959.98px) {
  #trafficinfo .block_state {
    margin-top: 5rem;
  }
}
#trafficinfo .list_area ul {
  display: flex;
  padding: 1rem 5rem;
}
@media screen and (max-width: 959.98px) {
  #trafficinfo .list_area ul {
    flex-wrap: wrap;
    padding: 2rem 1rem;
  }
}
#trafficinfo .list_area ul li {
  flex-grow: 1;
  position: relative;
}
@media screen and (max-width: 959.98px) {
  #trafficinfo .list_area ul li {
    width: 50%;
  }
}
#trafficinfo .list_area ul li .md {
  display: none;
}
#trafficinfo .list_area ul li:last-of-type::after {
  display: none;
}
#trafficinfo .list_area ul li::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 1px;
  background-color: #000;
  height: 2rem;
  right: 0;
  transform: translateY(-50%);
}
@media screen and (max-width: 959.98px) {
  #trafficinfo .list_area ul li::after {
    display: none;
  }
}
#trafficinfo .list_area ul .trans {
  padding: 1rem 0;
  border-bottom: none;
  min-width: inherit;
}
#trafficinfo .out_service {
  display: none;
}
#trafficinfo .txt_wrapper {
  margin: 4rem auto 0;
}
@media screen and (max-width: 959.98px) {
  #trafficinfo .txt_wrapper {
    margin-top: 5rem;
  }
}

/* ----------------------------------------------------------------------------------------------------
*	Simplified route map
* --------------------------------------------------------------------------------------------------*/
#route-map {
  padding-top: 10rem;
}
#route-map .txt {
  margin-top: 4rem;
  font-size: 2.2rem;
  line-height: 1.6363636364;
}
@media screen and (max-width: 959.98px) {
  #route-map .txt {
    font-size: 3rem;
    line-height: 1.8;
  }
}
#route-map .img_wrapper {
  margin-top: 4rem;
}

#search {
  margin-top: 13rem;
}
@media screen and (max-width: 959.98px) {
  #search {
    margin-top: 0;
    padding-top: 7rem;
  }
}

.search_content {
  background-color: transparent;
  max-width: 108.4rem;
  padding: 0;
}
.search_content .box_search {
  background-color: #ebf2f7;
  padding: 3rem 5rem;
  border-radius: 1.6rem;
  margin-top: 4rem;
}
@media screen and (max-width: 959.98px) {
  .search_content .box_search {
    padding: 3rem;
  }
}
.search_content .box_search .panel-body {
  margin-top: 0;
}

.routes-schedule .media01 {
  margin-top: 13rem;
}
.routes-schedule .media02 {
  margin-top: 13rem;
}
.routes-schedule .media03 {
  margin-top: 13rem;
}
.routes-schedule .media04 {
  margin-top: 13rem;
}

.maps_block {
  padding-top: 13rem;
}
@media screen and (max-width: 959.98px) {
  .maps_block {
    padding-top: 10rem;
  }
}
.maps_block .section_ttl {
  margin-bottom: 4rem;
}
.maps_block .block {
  margin-top: 4rem;
  padding-top: 4rem;
  border-top: 1px solid #002952;
}
@media screen and (max-width: 959.98px) {
  .maps_block .block {
    margin-top: 7rem;
    padding-top: 6rem;
  }
}
.maps_block .block .ttl {
  font-size: 3.2rem;
  font-weight: 600;
  color: #002952;
  font-family: "Inter", sans-serif;
}
@media screen and (max-width: 959.98px) {
  .maps_block .block .ttl {
    font-size: 5rem;
  }
}
.maps_block .block .txt {
  font-size: 1.6rem;
  line-height: 1.625;
  margin-bottom: 4rem;
}
@media screen and (max-width: 959.98px) {
  .maps_block .block .txt {
    font-size: 3rem;
    margin-bottom: 5rem;
  }
}
.maps_block .note_list {
  font-size: 1.6rem;
  line-height: 1.625;
  margin-bottom: 2rem;
}
@media screen and (max-width: 959.98px) {
  .maps_block .note_list {
    font-size: 3rem;
    margin-bottom: 4rem;
  }
}
.maps_block .note_item {
  padding-left: 0.8em;
  text-indent: -0.8em;
}

.maps_list {
  display: grid;
  margin-top: 2rem;
}
@media screen and (max-width: 959.98px) {
  .maps_list {
    margin-top: 4rem;
    display: block;
  }
  .maps_list .maps_item + .maps_item {
    margin-top: 4rem;
  }
}
.maps_list.col--1 {
  display: block;
}
.maps_list.col--1 .maps_item + .maps_item {
  margin-top: 2.5rem;
}
.maps_list.col--2 {
  gap: 2.4rem 1rem;
  grid-template-columns: repeat(2, 1fr);
}
.maps_list.col--2.row--2 .maps_item:first-of-type {
  grid-column: 1;
  grid-row: 1;
}
.maps_list.col--2.row--2 .maps_item:nth-of-type(2) {
  grid-column: 1;
  grid-row: 2;
}
.maps_list.col--2.row--2 .maps_item:nth-of-type(3) {
  grid-column: 2;
  grid-row: 1;
}
.maps_list.col--2.row--2 .maps_item:nth-of-type(4) {
  grid-column: 2;
  grid-row: 2;
}
.maps_list.col--2.row--2.row--4 .maps_item:first-of-type {
  grid-column: 1;
  grid-row: 1;
}
.maps_list.col--2.row--2.row--4 .maps_item:nth-of-type(2) {
  grid-column: 1;
  grid-row: 2;
}
.maps_list.col--2.row--2.row--4 .maps_item:nth-of-type(3) {
  grid-column: 1;
  grid-row: 3;
}
.maps_list.col--2.row--2.row--4 .maps_item:nth-of-type(4) {
  grid-column: 1;
  grid-row: 4;
}
.maps_list.col--2.row--2.row--4 .maps_item:nth-of-type(5) {
  grid-column: 2;
  grid-row: 1;
}
.maps_list.col--2.row--2.row--4 .maps_item:nth-of-type(6) {
  grid-column: 2;
  grid-row: 2;
}
.maps_list.col--2.row--2.row--4 .maps_item:nth-of-type(7) {
  grid-column: 2;
  grid-row: 3;
}
.maps_list.col--2.row--2.row--4 .maps_item:nth-of-type(8) {
  grid-column: 2;
  grid-row: 4;
}

.maps_item {
  font-size: 2rem;
  display: flex;
  align-items: flex-start;
  line-height: 1.3;
  color: #000;
}
@media screen and (max-width: 959.98px) {
  .maps_item {
    font-size: 3rem;
  }
}
.maps_item .icn {
  width: 2.7rem;
  height: 2.7rem;
  display: inline-block;
  margin-right: 1.2rem;
  position: relative;
  top: 0.1rem;
}
@media screen and (max-width: 959.98px) {
  .maps_item .icn {
    width: 4rem;
    height: 4rem;
  }
}
.maps_item .icn img {
  width: 100%;
}
.maps_item a {
  text-decoration: none;
  color: currentColor;
  transition: 0.3s color;
  padding-right: 3rem;
  position: relative;
  display: inline-block;
}
@media screen and (max-width: 959.98px) {
  .maps_item a {
    padding-right: 5rem;
  }
}
.maps_item a::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 1rem;
  width: 0.8rem;
  height: 0.8rem;
  border-top: 1.5px solid #002952;
  border-right: 1.5px solid #002952;
  transform: translateY(-50%) rotate(45deg);
}
@media screen and (max-width: 959.98px) {
  .maps_item a::after {
    width: 1.2rem;
    height: 1.2rem;
  }
}
@media (any-hover: hover) {
  .maps_item a:hover {
    color: #0066bf;
  }
}
.maps_item a.pdf::after {
  content: "";
  border: none;
  position: absolute;
  top: auto;
  right: 0;
  bottom: 0.4rem;
  width: 1.8rem;
  height: 1.8rem;
  background: url(/travel-information/assets/img/common/icn_pdf.svg) no-repeat center center/100% 100%;
  transform: translate(0) rotate(0);
}
@media screen and (max-width: 959.98px) {
  .maps_item a.pdf::after {
    width: 3.6rem;
    height: 3.6rem;
  }
}
.maps_item a.blank::after {
  border: none;
  top: auto;
  content: "";
  position: absolute;
  right: 0;
  bottom: 0.4rem;
  width: 1.8rem;
  height: 1.8rem;
  background: url(/travel-information/assets/img/common/icn_blank.svg) no-repeat center center/100% 100%;
  transform: translate(0) rotate(0);
}
@media screen and (max-width: 959.98px) {
  .maps_item a.blank::after {
    width: 3.2rem;
    height: 3.2rem;
  }
}

.station-maps {
  padding-top: 13rem;
}
/*# sourceMappingURL=plan-your-trip.css.map */