@charset "utf-8";
/* ===================================================================
//CSS information

// file name  :  access.css
// style info :  スタイル指定
=================================================================== */

/* -----------------------------------------------------
 mainWrap
----------------------------------------------------- */
.mainWrap {
  position: relative;
}

.mainImg {
  width: 50%;
  position: absolute;
  top: 0;
  right: 0;
  z-index: -1;
}

.mainTxt {
  display: flex;
  align-items: center;
}

.mainTxtBox {
  padding-right: 70px;
}

.mainTxt p.lede {
  color: #35a067;
  font-size: 30px;
  line-height: 1.7;
}

.mainTxt p+p {
  line-height: 2;
}

@media only screen and (max-width: 1300px) {
  .mainTxt p.lede {
    font-size: 2vw;
  }

  .mainTxtBox {
    padding-right: 30px;
  }
}

@media only screen and (max-width: 991px) {
  .mainTxt p.lede {
    font-size: 30px;
  }

  .mainImg {
    width: 100%;
    max-width: 710px;
    margin: 40px auto;
    padding: 0 15px;
    position: relative;
    top: auto;
    right: auto;
    z-index: 0;
  }

  .mainTxtBox {
    padding-right: 0;
  }
}

@media screen and (max-width: 767px) {
  .mainTxt p.lede {
    font-size: 5vw;
  }
}

@media screen and (max-width: 420px) {
  .mainTxt p.lede {
    font-size: 20px;
  }

  .mainTxt p.lede br {
    display: none;
  }
}

/* -----------------------------------------------------
 mapWrap
----------------------------------------------------- */
.mapWrap h3 {
  font-size: 30px;
  color: #4e617a;
  font-weight: normal;
}

.mapBox {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-flow: row nowrap;
  align-items: center;
}

.mapImg {
  width: 100%;
}

.mapImg iframe {
  width: 100%;
  min-height: 700px;
}

.mapTxt {
  padding: 0 15px;
}

.mapTxt dl+dl {
  margin-top: 30px;
}

.mapTxt dt p {
  font-size: 18px;
}

.mapTxt dd {
  padding: 20px 0 30px 30px;
  border-bottom: #e5e5e5 1px solid;
}

.mapTxt dt p::before {
  font-family: YakuHanMP, "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  font-size: 18px;
  width: 27px;
  height: 27px;
  margin-right: 10px;
  border-radius: 50%;
}

.mapTxt dt p.a::before {
  content: "A";
  background: #f8c700;
}

.mapTxt dt p.b::before {
  content: "B";
  background: #de528f;
}

.mapTxt dt p.c::before {
  content: "C";
  background: #00a4e4;
}

.mapTxt dt p.d::before {
  content: "D";
  background: #45aa34;
}

.mapTxt dt p.e::before {
  content: "E";
  background: #e67610;
}

.mapTxt dt p.f::before {
  content: "F";
  background: #9675ae;
}

@media only screen and (max-width: 1200px) {
  .mapBox {
    display: block;
    width: 100%;
    max-width: 1080px;
    margin: inherit auto;
    padding: 0 15px;
  }

  .mapImg {
    width: 100%;
  }

  .mapTxt {
    display: flex;
    justify-content: space-between;
    flex-flow: row wrap;
  }

  .mapTxt dl {
    margin-top: 30px;
    width: calc(50% - 15px);
  }
}

@media only screen and (max-width: 1099px) {
  .mapBox {
    max-width: 945px;
  }
}

@media only screen and (max-width: 991px) {
  .mapBox {
    max-width: 710px;
  }

  .mapTxt {
    padding: 0;
  }
}

@media screen and (max-width: 767px) {
  .mapBox {
    max-width: 100%;
    padding: 0 15px;
  }

  .mapTxt dl {
    width: 100%;
  }

  .mapImg iframe {
    min-height: 400px;
  }
}

/* -----------------------------------------------------
 routeWrap
----------------------------------------------------- */
.routeWrap {
  background: #efefef;
  padding: 90px 0;
}

.routeWrap h3 {
  font-size: 28px;
  color: #a49455;
  font-weight: normal;
}

.routeWrap .routeBox div:nth-child(-n+6) {
  margin-bottom: 50px;
}

.routeWrap dt {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  border-bottom: #ddd 1px solid;
}

.routeWrap dt .st {
  font-size: 30px;
}

.routeWrap dt .st.long {
  font-size: 22px;
}

.routeWrap dt .num {
  font-size: 36px;
  font-family: 'Bellefair', serif !important;
}

.routeWrap dd {
  margin-top: 10px;
}

.routeWrap dd p {
  font-size: 11px;
}

@media only screen and (max-width: 1200px) {
  .routeWrap .routeBox div {
    margin-bottom: 50px !important;
  }

  .routeWrap .routeBox div:last-child {
    margin-bottom: 0 !important;
  }
}

@media only screen and (max-width: 991px) {
  .routeWrap {
    padding: 60px 0;
  }
}

@media screen and (max-width: 767px) {

  .mapWrap h3,
  .routeWrap h3 {
    font-size: 15px;
  }

  .routeWrap dt.block {
    display: block;
  }
}

@media screen and (min-width: 767px) {
  .p_none {
    display: none;
  }
}

@media screen and (max-width: 1200px) {}

@media screen and (max-width: 991px) {}

@media screen and (max-width: 767px) {}

@media screen and (max-width: 420px) {}


/* taxiSec */
.taxiSec {
  padding: 100px 0;
  background: #ddd;
}

.taxiSec.busSec {
  background: #eee;
}

.taxiSec p.caption {
  margin: 10px 0;
  line-height: 1.3;
}

.taxiSec p.caption small {
  font-size: 11px;
}

.taxiSec h2 {
  margin-bottom: 50px;
  text-align: center;
  font-size: 48px;
  /*  font-family: 'Roboto', sans-serif;*/
  font-weight: 300;
}

.taxiSec table {
  width: 100%;
  border-collapse: collapse;
}

.taxiSec table th,
.taxiSec table td {
  padding: 10px;
  border: 1px solid #ddd;
  background: #fff;

}

.taxiSec table th {
  font-weight: normal;
  text-align: center;
  background: #ccc;
}

.taxiSec.busSec table {
  display: block;
  overflow-x: scroll;
  white-space: nowrap;
  -webkit-overflow-scrolling: touch;
}

@media only screen and (max-width: 767px) {

  .taxiSec table th,
  .taxiSec table td {
    padding: 7px;
    font-size: 12px;
  }
}

@media screen and (max-width: 1200px) {}

@media screen and (max-width: 991px) {}

@media screen and (max-width: 767px) {}

@media screen and (max-width: 420px) {}


/* -----------------------------------------------------
	Bus
----------------------------------------------------- */
.busTable {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 15px;
}

.busTable th,
.busTable td {
  padding: 10px;
  border: 1px solid #888;
  background: #fff;
  font-family: YakuHanMP, 'Noto Serif JP', "貂ｸ譏取悃", YuMincho, "HG譏取悃B", "繝偵Λ繧ｮ繝取�譛� ProN W3", "Hiragino Mincho ProN", "�ｭ�ｳ 譏取悃", serif;
}

.busTable th {
  font-weight: normal;
  text-align: center;
  background: #D1C4AF;
}

.busTable .small {
  font-size: 0.8em;
}

@media only screen and (max-width: 991px) {
  .busTable {
    display: block;
    overflow-x: scroll;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
  }
}