@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: 24px;
  color: var(--color04);
  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 p {
  color: var(--color03);
}
.routeWrap h2 {
  font-family: 'Bellefair', serif !important;
  color: var(--color03);
font-weight: normal;
font-size: 36px;
}
.routeWrap h3 {
  font-size: 30px;
  color: var(--color03);
  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;
  color: var(--color03);
}
.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 dt.loc p{
  font-size: 14px;

}
.routeWrap dt.loc p span{
  font-size: 20px;
}
.routeWrap dd {
  margin-top: 10px;
  color: var(--color03) !important;
}
.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: 16px;}
}
@media screen and (max-width: 420px) {
}

a.linkb:link {
  text-decoration: underline;
}
a.linkb:visited {
}
a.linkb:hover {
  text-decoration: none;
}
a.linkb:active {
}


/* taxiSec */
.taxiSec {
	padding: 100px 0;
	background:#ddd; 
  color: var(--color03);
}
.taxiSec p{
  color: var(--color03);
}
.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;
  color: var(--color03);
}
.taxiSec table {
	width: 100%;
	border-collapse: collapse;
  color: var(--color03);
}
.taxiSec table th,
.taxiSec table td {
	padding: 10px;
	border: 1px solid #ddd;
	background: #fff;
  color: var(--color03);

}
.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) {
}

a.linkt:link {
  text-decoration: underline;
	color: var(--color03);
	font-size: 1.26em;
}
a.linkt:visited {
	color: var(--color03);
}
a.linkt:hover {
  text-decoration: none;
}
a.linkt:active {
}


/* -----------------------------------------------------
	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;
	}
}

