@charset "utf-8";
/* ===================================================================
//CSS information

// file name  :  public.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: #006655;
  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
----------------------------------------------------- */
.mapBox {
  max-width: 1270px;
  margin: 0 auto;
/*  display: flex;*/
  flex-flow: row nowrap;
  align-items: center;
 text-align: center;
}
.mapImg {
  width: 62%;
 margin: auto;
}
.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%;
  }
}


/* -----------------------------------------------------
 mapWrap
----------------------------------------------------- */
.mapWrap iframe {
    width: 100%;
    height: 700px;
}
.areamap a {
    display: block;
    width: 600px;
    margin: 30px auto 0;
    padding: 25px;
    font-size: 16px;
    color: #fff;
    background: #333;
    text-align: center;
    box-shadow: 0 0 10px rgba(0,0,0,.1);
    border-radius: 5px;
    transition: .3s all ease-in-out;
}
.areamap a:hover {
    box-shadow: 0 0 0 rgba(0,0,0,.1);
    transform: scale(.97);
}
@media screen and (max-width: 767px) {
    .mapWrap iframe {
        height: 400px;
    }
    .areamap a {
        max-width: 100%;
    }
} 

/* -----------------------------------------------------
 routeWrap
----------------------------------------------------- */
.routeWrap {
  background: #ebe8e5;
  padding: 90px 0;
}
.routeWrap h3 {
  font-size: 30px;
  color: #006655;
  font-weight: normal;
}
.routeWrap .routeBox div:nth-child(-n+3) {
  margin-bottom: 70px;
}
.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 .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;
  }
}

.areamap {
	display: block;
	text-align: center;
}
.areamap a {
  background: #ee8552;
	color: #fff;
	padding: 25px 10px;
}

@media only screen and (min-width: 991px) {
.areamap a {
	padding: 25px 100px;
}
}
@media only screen and (max-width: 991px) {
.areamap a {
	font-size: .86em;
}
}

/* 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) {
}