@charset "UTF-8";

/* -------------------------------------
winter_common
------------------------------------- */
*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

article {
  position: relative;
}

.page {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

.fntU {
  font-family: "Unica One", cursive;
}

.img {
  width: 100%;
  height: auto;
  display: block;
}

a {
  color: #333;
  cursor: pointer;
}

.btn {
  display: block;
}

.sptel {
  cursor: default;
  pointer-events: none;
}

.morebtn {
  font-size: 18px;
  font-weight: 500;
  color: #1b4076;
  text-align: center;
  display: block;
  border: 1px solid #1b4076;
  background-color: #fff;
}

.morebtn:hover {
  color: #fff;
  background-color: #1b4076;
}

/* -------------------------------------
route
------------------------------------- */
.route {
  color: #4d4d4d;
}

.route #mv {
  padding-top: 360px;
  min-height: 330px;
  max-width: 1160px;
  margin: 0 auto 38px;
  position: relative;
  overflow: hidden;
}

.route #mv .ttl {
  width: auto;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  margin-bottom: 0;
}

.route #mv .ttl img {
  width: auto;
  height: 100%;
}

.route #mv .ttl .sp {
  display: none;
}

.route #mv .bg {
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
}

.route1 #mv .bg

/* .route2 #mv .bg  */
  {
  left: auto;
  right: 0;
}

.route .sttl {
  font-size: 36px;
  font-family: "Unica One", cursive;
  line-height: 1.2;
  color: #1b4076;
  margin-bottom: 15px;
}

.route .sttl span {
  font-size: 18px;
  font-weight: 500;
  font-family: "Noto Sans Japanese", sans-serif;
  color: #1b4076;
  display: inline-block;
  vertical-align: middle;
}

.route .sttl span:before {
  content: "";
  width: 45px;
  height: 1px;
  margin: 0 8.5px;
  background-color: #1b4076;
  display: inline-block;
  vertical-align: middle;
}

.route #rsv {
  width: 16%;
  max-width: 150px;
  min-width: 125px;
  position: fixed;
  left: auto;
  top: 455px;
  margin: 0 0 0 1035px;
  z-index: 1;
}

.route #rsv a {
  display: block;
}

.route #rsv.rsv_2 {
  top: 305px;
}

.route #rsv.rsv_2 a:first-child {
  margin-bottom: 15px;
}

.route #rsv a:hover {
  opacity: 0.8;
}

.route #rsvsp {
  display: none;
  width: 100%;
  position: fixed;
  bottom: 0;
  z-index: 1;
  background-color: #eab84b;
}

.route #rsvsp a {
  text-align: center;
  padding: 10px 0;
  background-color: #e9d88a;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 49px;
}

.route #rsvsp a:hover {
  background-color: #f9e595;
}

.route #rsvsp p {
  font-size: 18px;
  color: #282828;
  padding-left: 56px;
  position: relative;
}

.route #rsvsp p:before {
  content: "";
  width: 42px;
  padding-top: 33px;
  display: block;
  background: url(../imgs/winter/common/btn_rsv.svg) no-repeat 0 center;
  background-size: contain;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
}

.route #rsvsp.rsv_2 {
  width: 100%;
}

.route #rsvsp.rsv_2 a {
  width: 50%;
  padding: 5px;
}

.route #rsvsp.rsv_2 a:first-child {
  border-right: 1px solid #fff;
}

.route #rsvsp.rsv_2 p {
  font-size: 16px;
  line-height: 1.2;
  text-align: left;
}

.route #rsvsp.rsv_2 p span {
  display: block;
}

/* -------------------------------------
oparation_pd
------------------------------------- */
#oparation_pd {
  margin-bottom: 70px;
}

#oparation_pd p {
  color: #4d4d4d;
  font-size: 18px;
  font-weight: 500;
  padding: 5px 0 5px 1em;
  border-top: 1px solid #e6e6e6;
  border-bottom: 1px solid #e6e6e6;
}

/* #oparation_pd p span {
  display: block;
  padding-left: 3.25em;
} */
#oparation_pd p span {
  display: inline-block;
}

/* -------------------------------------
timetable
------------------------------------- */
.route #timetable {
  padding-bottom: 30px;
}

.route #timetable .t_ttl {
  font-size: 18px;
  font-weight: 500;
  font-family: "Noto Sans Japanese", sans-serif;
  color: #1b4076;
  padding-bottom: 10px;
}

.route #timetable .table1 {
  margin-bottom: 50px;
}

.route #timetable .tbl_blk {
  overflow-x: scroll;
  padding-bottom: 5px;
}

.route #timetable table {
  width: 100%;
  min-width: 942px;
}

.route #timetable th {
  font-size: 16px;
  font-weight: normal;
  color: #fff;
  padding: 10px 10px 15px;
  border: 1px solid #e6e6e6;
  background-color: #274897;
}

.route #timetable th:nth-child(2),
.route #timetable th:nth-child(3) {
  width: 10%;
  min-width: 122px;
}

.route #timetable th:nth-child(4) {
  min-width: 166px;
  width: 14%;
}

.route #timetable th:nth-child(5) {
  min-width: 166px;
  width: 14%;
}

.route #timetable td {
  font-size: 16px;
  color: #4d4d4d;
  text-align: center;
  padding: 8px 10px;
  border: 1px solid #e6e6e6;
}

.route #timetable td:first-child {
  text-align: left;
  padding: 8px 15px;
}

.route #timetable td:nth-child(2),
.route #timetable td:nth-child(3) {
  font-size: 21px;
  font-family: "Unica One", cursive;
}

.route #timetable .on {
  padding-right: 5px;
  border-right: none;
}

.route #timetable .off {
  padding-left: 5px;
  border-left: none;
}

.route #timetable td span {
  font-size: 13px;
  font-weight: 500;
  color: #fff;
  padding: 2px;
  display: inline-block;
  border-radius: 11px;
}

.route #timetable td span.red {
  color: #f4511e;
  font-size: 1em;
  font-weight: normal;
  padding: 0;
}

.route #timetable td span.txt_s {
  color: #4d4d4d;
  display: block;
}

.route #timetable .on span {
  background-color: #3285bb;
  width: 66px;
}

.route #timetable .off span {
  background-color: #f18d45;
  width: 66px;
}

.route #timetable .un span {
  background-color: #ccc;
  width: 66px;
}

.route #timetable .ss span {
  background-color: #00926b;
  width: 141px;
}

.route #timetable .wd span {
  background-color: #ce5888;
  width: 66px;
}

.route #timetable .bk span {
  background-color: #41b8d4;
  width: 141px;
}

.route #timetable .lc span {
  background-color: #ff7284;
  width: 141px;
}

.route #timetable ul {
  padding-left: 3px;
}

.route #timetable ul li {
  font-size: 12px;
  line-height: 1.6;
  color: #000;
  text-indent: -1em;
  padding-left: 1em;
}

.route #timetable .cmnt {
  position: relative;
}

.route #timetable .cmnt p {
  font-size: 14px;
  color: #4d4d4d;
  display: inline-block;
  /*position:absolute;
	right:0;
	top:-4px;*/
}

/* -------------------------------------
map
------------------------------------- */
.route #map {
  padding-bottom: 40px;
}

.route #map #gmap {
  padding-top: 480px;
  position: relative;
  overflow: hidden;
}

.route #map #gmap iframe {
  width: 100%;
  position: absolute;
  top: calc(50% - 2px);
  left: calc(50% - 2px);
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -o-transform: translate(-50%, -50%);
}

/* -------------------------------------
fare
------------------------------------- */
.route #fare {
  padding-bottom: 95px;
}

.route #fare .box {
  margin: 0 auto 50px;
  padding-bottom: 5px;
  overflow-x: scroll;
}

.route #fare .box_3 {
  max-width: 256px;
}

.route #fare .box_4 {
  max-width: 335px;
}

.route #fare .box_5 {
  max-width: 420px;
}

.route #fare .box_6 {
  max-width: 500px;
}

.route #fare .box_7 {
  max-width: 596px;
}

.route #fare .box_9 {
  max-width: 766px;
}

.route #fare .box_10 {
  max-width: 510px;
}

.route #fare .box img {
  margin-bottom: 5px;
}

.route #fare .box p {
  font-size: 12px;
  color: #000;
}

.route #fare .box p span {
  display: inline-block;
}

.route #fare .note {
  max-width: 635px;
  margin: 0 auto;
}

/* -------------------------------------
highlight
------------------------------------- */
.route #highlight {
  padding: 18px 0 82px;
  background-color: #fbf7e8;
  position: relative;
}

.route #highlight:before {
  content: "";
  width: 90%;
  max-width: 446px;
  height: 60px;
  background: #fbf7e8;
  display: block;
  clip-path: polygon(0% 100%, 4% 0%, 96% 0%, 100% 100%);
  position: absolute;
  top: -25px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -o-transform: translateX(-50%);
  z-index: -1;
}

.route #highlight .sttl {
  max-width: 166px;
  margin: 0 auto 5%;
}

.route #highlight .sttl span {
  display: block;
  padding-top: 18px;
  text-align: center;
}

.route #highlight .sttl span:before {
  content: none;
}

.route #highlight .cont .imgbox {
  width: 45%;
  max-width: 519px;
}

.route #highlight .cont .imgbox img {
  max-width: 466px;
}

.route #highlight .cont .txt {
  width: 52%;
  max-width: 578px;
  padding-top: 4.5%;
}

.route #highlight .cont .txt p {
  font-size: 16px;
  line-height: 1.5;
  margin-bottom: 18px;
}

.route #highlight .cont .txt .httl {
  font-size: 28px;
  font-weight: 500;
  color: #1b4076;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid #1b4076;
}

.route #highlight .cont .txt .morebtn {
  width: 223px;
  padding: 8px;
}

/* -------------------------------------
point
------------------------------------- */
.route #point {
  padding: 70px 0 75px;
}

.route #point .sttl {
  margin-bottom: 22px;
}

.route #point ul {
  font-size: 0;
  text-align: center;
}

.route #point ul li {
  text-align: left;
  width: 354px;
  margin-right: calc((100% - 1062px) / 2);
  display: inline-block;
  vertical-align: top;
}

.route #point ul li:last-child {
  margin-right: 0;
}

.route #point ul li .ptimg {
  position: relative;
}

.route #point ul li .ptimg p {
  width: 28%;
  max-width: 97px;
  position: absolute;
  top: 10px;
}

.route #point ul li .ptimg+p {
  font-size: 16px;
  line-height: 1.5;
  padding: 8px 20px;
  border: 1px solid #e6e6e6;
}

/* -------------------------------------
noritoku - route7
------------------------------------- */
.route #noritoku {
  padding-bottom: 110px;
}

.route #noritoku .sttl+p {
  font-size: 14px;
  margin-bottom: 20px;
}

.route #noritoku ul {
  font-size: 0;
  max-width: 933px;
  margin-bottom: 10px;
}

.route #noritoku li {
  width: calc((100% - 32px) / 2);
  display: inline-block;
}

.route #noritoku li:first-child {
  margin-right: 32px;
}

.route #noritoku li .nttl {
  font-size: 14px;
}

.route #noritoku li p {
  padding: 10px;
}

.route #noritoku li .pdf {
  font-size: 14px;
  text-decoration: underline;
  margin-bottom: 10px;
}

#lightbox-container-image-box,
#lightbox-container-image-data-box {
  width: 100% !important;
  max-width: 830px;
  height: auto !important;
}

#jquery-lightbox a img {
  width: 27px;
  margin: 0 auto;
}

#lightbox-image {
  width: 100%;
  height: auto;
}

/* -------------------------------------
request
------------------------------------- */
.route #request {
  padding-bottom: 63px;
}

.route #request .sttl {
  margin-bottom: 18px;
}

.route #request .cont {
  width: 100%;
  margin-bottom: 28px;
  position: relative;
  overflow: hidden;
}

.route #request .cont .line {
  position: absolute;
  top: 2px;
  left: 0;
}

.route #request ul {
  padding-left: 8px;
  position: relative;
  top: 2px;
}

.route #request ul li {
  font-size: 14px;
  line-height: 2.8;
  color: #333;
  text-indent: -1em;
  padding-left: 1em;
}

.route #request .morebtn {
  width: 268px;
  margin: 0 auto;
  padding: 13px;
}

/* -------------------------------------
reserve
------------------------------------- */
.route #reserve {
  padding: 58px 0 103px;
  background-color: #eab84b;
}

.route #reserve .page {
  font-size: 0;
  position: relative;
}

.route #reserve .sttl {
  color: #fff;
  margin-bottom: 20px;
}

.route #reserve .sttl span {
  color: #fff;
}

.route #reserve .sttl span:before {
  background-color: #fff;
}

.route #reserve .rttl {
  font-size: 18px;
  font-weight: 500;
  color: #fff;
  margin-bottom: 5px;
}

.route #reserve .rttl .ilblk {
  display: inline-block;
}

.route #reserve .txt a {
  font-size: 52px;
  color: #fff;
  padding-left: 43px;
  position: relative;
}

.route #reserve .txt a:before {
  content: "";
  width: 8%;
  height: 35px;
  display: block;
  background: url(../imgs/winter/common/ic_tel.svg) no-repeat 90% center;
  background-size: contain;
  position: absolute;
  left: 3px;
  top: 51%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
}

.route #reserve .txt .spmail:before {
  background: url(../imgs/winter/common/ic_mail.svg) no-repeat 90% center;
}

.route #reserve .txt p {
  font-size: 18px;
  font-weight: 500;
  color: #fff;
}

.route #reserve .txt p span {
  display: inline-block;
}

.route #reserve .btnblk {
  text-align: center;
  width: 40%;
  max-width: 488px;
  padding: 3.7% 10px;
  display: block;
  background-color: #e9d88a;
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  display: block;
  position: absolute;
  bottom: 0;
  right: 20px;
}

.route #reserve .btnblk:hover {
  background-color: #f9e595;
}

.route #reserve .btnblk p {
  font-size: 23px;
  font-weight: 500;
  color: #282828;
  padding-left: 22%;
  display: inline-block;
  position: relative;
}

.route #reserve .btnblk p:before {
  content: "";
  width: 26%;
  max-width: 86px;
  padding-top: 19%;
  display: block;
  background: url(../imgs/winter/common/btn_rsv.svg) no-repeat center/ 99% 99%;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
}

.route #reserve .btnblk.sp {
  display: none;
}

/* -------------------------------------
reserve rsrv_z (リンク複数)
------------------------------------- */
.route #reserve.rsrv_z .page,
.route #reserve.rsrv_z .btnblk {
  position: static;
}

.route #reserve.rsrv_z .flex {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.route #reserve.rsrv_z .linkblk ul li {
  margin-bottom: 15px;
}

/* link_2 (リンク2つ) */
.route #reserve.rsrv_z .flex.link_2 {
  align-items: flex-start;
}

.route #reserve.rsrv_z .link_2 .linkblk {
  width: 40%;
  max-width: 488px;
}

.route #reserve.rsrv_z .link_2 .linkblk ul {
  width: 100%;
}

.route #reserve.rsrv_z .link_2 .linkblk ul li .btnblk {
  width: 100%;
  padding: 7% 15px;
}

.route #reserve.rsrv_z .link_2 .linkblk ul li .btnblk p {
  line-height: 1.4;
  text-align: left;
}

/* link_2 (リンク4つ) */
.route #reserve.rsrv_z .link_4 .txtblk {
  width: calc(99% - 576px);
}

.route #reserve.rsrv_z .link_4 .linkblk {
  width: 100%;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.route #reserve.rsrv_z .link_4 .linkblk {
  max-width: 576px;
  padding-top: 15px;
}

.route #reserve.rsrv_z .link_4 .linkblk ul {
  width: 49%;
}

.route #reserve.rsrv_z .link_4 .linkblk ul li .btnblk {
  width: 100%;
  padding: 3.7% 15px;
}

.route #reserve.rsrv_z .link_4 .linkblk ul li .btnblk p {
  font-size: 16px;
  line-height: 1.2;
  text-align: left;
  display: block;
  padding-left: 32%;
}

.route #reserve.rsrv_z .linkblk ul li .btnblk p span {
  display: block;
}

/* -------------------------------------
routelist
------------------------------------- */
.route #routelist {
  padding: 68px 0 157px;
}

.route #routelist ul {
  font-size: 0;
  margin-bottom: 42px;
}

.route #routelist ul li {
  width: calc((100% - 34px) / 3);
  margin-right: 17px;
  margin-bottom: 17px;
  display: inline-block;
}

.route #routelist ul li:nth-child(3n) {
  margin-right: 0;
}

.route #routelist ul li a {
  font-size: 16px;
  line-height: 1.2;
  color: #4d4d4d;
  padding: 5px 45px 5px 17px;
  display: table;
  width: 100%;
  min-height: 57px;
  background: url(../imgs/winter/common/arrow_gr.svg) no-repeat 95% center/ 24px 14px;
  border: 1px solid #e6e6e6;
}

.route #routelist ul li a.notice {
  pointer-events: none;
  background: #a8a3a3 url(../imgs/winter/common/arrow_gr.svg) no-repeat 95% center/24px 14px;
  opacity: 0.7;
}

.route #routelist ul li a.on {
  pointer-events: none;
}

.route #routelist ul li a.on,
.route #routelist ul li a:hover {
  background-color: #e6e6e6;
}

.route #routelist ul li a .tc {
  display: table-cell;
  text-align: left;
  vertical-align: middle;
}

.route #routelist ul li a .tc span {
  display: inline-block;
}

.route #routelist ul li a .tc .num {
  padding-left: 0.5em;
}

.route #routelist .topbtn {
  width: 100%;
  max-width: 430px;
  margin: 0 auto;
  display: block;
}

/* -------------------------------------
video
------------------------------------- */
.route #video {
  padding-bottom: 150px;
}

.route #video .page .in {
  max-width: 780px;
  margin: 0 auto;
}

.route #video .itembox {
  padding-top: 56.3%;
  position: relative;
}

.route #video .itembox iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

@media screen and (max-width: 1400px) {}

@media screen and (max-width: 1320px) {}

@media screen and (max-width: 1215px) {
  .route #rsv {
    margin: auto;
    right: 20px;
  }
}

@media screen and (max-width: 1200px) {
  .route #mv {
    margin-bottom: 3.5%;
  }

  .route #fare {
    padding-bottom: 8%;
  }

  .route #highlight {
    padding-bottom: 7%;
  }

  .route #point {
    padding: 6% 0 6.5%;
  }

  .route #request {
    padding-bottom: 6%;
  }

  .route #reserve {
    padding: 5% 0 9%;
  }

  .route #routelist {
    padding: 6% 0 13%;
  }

  #oparation_pd {
    margin-bottom: 6%;
  }

  .route #noritoku {
    padding-bottom: 9%;
  }

  .route #video {
    padding-bottom: 13%;
  }
}

@media screen and (max-width: 1160px) {
  .route #mv {
    padding-top: 31%;
  }

  /* -------------------------------------
	point
	------------------------------------- */
  .route #point ul li {
    width: calc((100% - 40px) / 3);
    margin-right: 20px;
  }
}

@media screen and (max-width: 1100px) {
  .route #timetable .cmnt p {
    position: static;
  }

  /* -------------------------------------
	reserve
	------------------------------------- */
  .route #reserve .btnblk p {
    font-size: 21px;
  }

  .route #reserve .btnblk.en {
    position: static;
    width: 100%;
    max-width: 380px;
    margin: 0 auto;
    padding: 30px 10px;
  }

  .route #reserve .txt.en {
    text-align: center;
    margin-bottom: 30px;
  }
}

@media screen and (max-width: 1060px) {
  .route #mv .bg {
    width: auto;
    height: 100%;
  }
}

@media screen and (max-width: 1020px) {

  /* -------------------------------------
	reserve
	------------------------------------- */
  /* -------------------------------------
	rsrv_z (リンク複数)
	------------------------------------- */
  .route #reserve.rsrv_z .flex {
    display: block;
  }

  .route #reserve.rsrv_z .txtblk,
  .route #reserve.rsrv_z .link_4 .txtblk {
    width: 100%;
  }

  .route #reserve.rsrv_z .txt {
    text-align: center;
    margin-bottom: 30px;
  }

  .route #reserve.rsrv_z .linkblk {
    margin: 0 auto;
  }

  .route #reserve.rsrv_z .link_2 .linkblk {
    width: 100%;
  }
}

@media screen and (max-width: 1000px) {

  /* -------------------------------------
	reserve
	------------------------------------- */
  .route #reserve .btnblk {
    bottom: -5px;
  }

  .route #reserve .btnblk p {
    font-size: 19px;
  }
}

@media screen and (max-width: 860px) {}

@media screen and (max-width: 820px) {

  /* -------------------------------------
	reserve
	------------------------------------- */
  .route #reserve .txt a {
    font-size: 47px;
  }

  .route #reserve .btnblk p {
    font-size: 17px;
  }
}

@media screen and (max-width: 768px) {
  .route #mv {
    padding-top: 0;
    max-height: initial;
    min-height: initial;
  }

  .route #mv .ttl {
    position: static;
    width: 100%;
    height: auto;
  }

  .route #mv .ttl .pc {
    display: none;
  }

  .route #mv .ttl .sp {
    display: block;
    width: 100%;
    height: auto;
  }

  .route #mv .bg {
    display: none;
  }

  .route #rsv {
    top: 405px;
  }

  #oparation_pd p {
    font-size: 17px;
  }

  /* -------------------------------------
	highlight
	------------------------------------- */
  .route #highlight .cont .imgbox,
  .route #highlight .cont .imgbox img,
  .route #highlight .cont .txt,
  .route #highlight .cont .txt .morebtn {
    float: none;
    width: 100%;
    margin: 0 auto;
  }

  .route #highlight .cont .txt .httl {
    font-size: 26px;
  }

  .route #highlight .cont .txt .morebtn {
    max-width: 223px;
  }

  /* -------------------------------------
	point
	------------------------------------- */
  .route #point ul li {
    width: calc((100% - 20px) / 2);
    margin-right: 20px;
    margin-bottom: 30px;
  }

  .route #point ul li:nth-child(2) {
    margin-right: 0;
  }

  .route #point ul li:last-child {
    margin-bottom: 0;
  }

  /* -------------------------------------
	noritoku - route7
	------------------------------------- */
  .route #noritoku li {
    width: calc((100% - 20px) / 2);
  }

  .route #noritoku li:first-child {
    margin-right: 20px;
  }

  /* -------------------------------------
	reserve
	------------------------------------- */
  .route #reserve .txt {
    text-align: center;
    margin-bottom: 30px;
  }

  .route #reserve .txt a {
    padding-left: 38px;
  }

  .route #reserve .btnblk {
    position: static;
    width: 100%;
    max-width: 380px;
    margin: 0 auto;
    padding: 30px 10px;
  }

  .route #reserve .btnblk.pc {
    display: none;
  }

  .route #reserve .btnblk.sp {
    display: flex;
    justify-content: center;
  }

  /* -------------------------------------
	routelist
	------------------------------------- */
  .route #routelist ul li {
    width: calc((100% - 20px) / 2);
  }

  .route #routelist ul li:nth-child(3n) {
    margin-right: 20px;
  }

  .route #routelist ul li:nth-child(2n) {
    margin-right: 0;
  }
}

@media screen and (max-width: 750px) {}

@media screen and (max-width: 640px) {
  .sptel {
    cursor: pointer;
    pointer-events: auto;
  }

  .route #rsv {
    display: none;
  }

  .route #rsvsp {
    display: block;
  }

  .route #rsvsp.rsv_2 {
    display: flex;
    justify-content: center;
  }

  footer {
    padding-bottom: 52px;
  }

  /* -------------------------------------
	request
	------------------------------------- */
  .route #request .cont .line {
    display: none;
  }

  .route #request .cont {
    overflow: initial;
  }

  .route #request ul {
    padding-left: 0;
  }

  .route #request ul li {
    line-height: 1.6;
    text-indent: -14px;
    padding: 10px 5px 10px 22px;
    border-bottom: 1px solid #e6e6e6;
  }

  /* -------------------------------------
	reserve rsrv_z
	------------------------------------- */
  .route #reserve.rsrv_z .link_4 .linkblk ul li .btnblk p {
    font-size: 14px;
  }
}

@media screen and (max-width: 550px) {

  /* -------------------------------------
	point
	------------------------------------- */
  .route #point ul {
    max-width: 466px;
    margin: 0 auto;
  }

  .route #point ul li {
    width: 100%;
    margin-right: 0;
    display: block;
  }

  /* -------------------------------------
	reserve
	------------------------------------- */
  .route #reserve .rttl .spnon {
    display: none;
  }

  /* -------------------------------------
	reserve rsrv_z
	------------------------------------- */
  .route #reserve.rsrv_z .link_4 .linkblk {
    display: block;
  }

  .route #reserve.rsrv_z .link_4 .linkblk ul {
    width: 100%;
  }

  .route #reserve.rsrv_z .link_4 .linkblk ul li .btnblk p {
    font-size: 15px;
  }

  /* -------------------------------------
	routelist
	------------------------------------- */
  .route #routelist ul {
    max-width: 430px;
    margin: 0 auto 27px;
  }

  .route #routelist ul li {
    width: 100%;
    display: block;
    margin-right: 0;
    margin-bottom: 10px;
  }

  .route #routelist ul li:nth-child(3n) {
    margin-right: 0;
  }

  .route #routelist ul li:nth-child(2n) {
    margin-right: 0;
  }

  .route #routelist ul li a {
    font-size: 14px;
  }
}

@media screen and (max-width: 480px) {

  /* -------------------------------------
	fare
	------------------------------------- */
  .route #fare {
    padding-bottom: 40px;
  }

  /* -------------------------------------
	highlight
	------------------------------------- */
  .route #highlight .cont .txt .httl {
    font-size: 24px;
  }

  #oparation_pd p {
    font-size: 16px;
    padding-left: 0;
  }

  /* -------------------------------------
	noritoku - route7
	------------------------------------- */
  .route #noritoku li {
    width: 100%;
    display: block;
  }

  .route #noritoku li:first-child {
    margin-right: 0;
    margin-bottom: 20px;
  }

  .route #rsvsp.rsv_2 p {
    font-size: 14px;
  }

  .route #rsvsp p {
    font-size: 16px;
  }
}

@media screen and (max-width: 400px) {

  /* -------------------------------------
	reserve
	------------------------------------- */
  .route #reserve .txt a {
    font-size: 40px;
  }

  /* -------------------------------------
	point
	------------------------------------- */
  .route #point ul li .ptimg+p {
    font-size: 14px;
  }

  .route #rsvsp.rsv_2 p {
    padding-left: 50px;
  }
}

@media screen and (max-width: 345px) {

  /* -------------------------------------
	reserve
	------------------------------------- */
  .route #reserve .txt a {
    font-size: 36px;
  }

  .route #reserve .btnblk p {
    padding-left: 62px;
  }

  .route #reserve .btnblk p:before {
    width: 60px;
  }
}