@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) {
  #accessPage .container {
    width: 90%;
  }
  .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: min(2.5vw,30px);
  line-height: 1.75;
  letter-spacing: 0;
  color: #333;
  font-weight: normal;
}
.mapWrap h3 span {
  opacity: .5;
}
@media screen and (max-width: 560px) {
  .mapWrap h3 {
    font-size: 4.7vw;
  }
}
.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 {
  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;
}
.routeWrap figure img {
  padding: 0 10%;
}
@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: 90%;
  }
  .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: min(30px,3vw);
  color: rgba(51, 51, 51, .5);
  font-weight: normal;
}
@media screen and (max-width: 560px) {
  .routeWrap h3 {
    font-size: 6vw;
  }
}
.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: 14px;
}
@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: 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;
  display: flex;
  line-height: 1.75;
}
.taxiSec p.caption small::before {
  content: "※";
}
.taxiSec h2 {
  font-family: "Jost", sans-serif;
	margin-bottom: 50px;
  text-align: center;
  font-size: 48px;
  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;
	}
}

