@charset "utf-8";

/*//////////////////////////////////////////////////////////////////////////////

	アクセスマップ共通

//////////////////////////////////////////////////////////////////////////////*/


/* キャッチ
------------------------------------------------------------------------------*/

main .text_box {
	padding: 3em 1.5em;
	background-color: rgba(233,237,239,.5);
}

main .site_column > .text_box {
	margin-top: 0;
}

main .text_box p {
	text-align: center;
}


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

main .text_box {
	margin-bottom: 3em;
	padding-top: 2em;
	padding-bottom: 2em;
}

main .text_box p {
	text-align: left;
}

}


/*------------------------------------------------------------------------------

	時刻表

------------------------------------------------------------------------------*/

/* ガイド
------------------------------------------------------------------------------*/

.tab_contents > header {
	position: relative;
}

.tab_contents .guide {
	position: absolute;
	right: 0;
	bottom: 0;
	display: flex;
	margin: 0;
	list-style: none;
}

.tab_contents .guide li,
main .time_table tbody th {
	font-size: .875em;
}

.tab_contents .guide li {
	margin-right: 1.25em;
	line-height: 1;
}

.tab_contents .guide li:last-child {
	margin-right: 0;
}

.tab_contents .guide li span:last-child::before {
	content: "…";
	padding-left: .5em;
}

main .regular,
main .limousine {
	padding: .25em .5em;
	line-height: 1;
	color: #FFF;
}

main .regular {
	background-color: rgba(235,103,113,1);
}

main .limousine {
	background-color: rgba(38,161,214,1);
}

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

.tab_contents .guide {
	position: relative;
	right: auto;
	bottom: auto;
	display: flex;
	justify-content: center;
	margin-bottom: 1.5em;
}

}

/* 表（共通）
------------------------------------------------------------------------------*/

main .time_table thead,
main .fee thead th,
main .fee tbody th,
main .time_table .arrow_guide span {
	width: 20%;
}

main .fee thead td,
main .fee tbody td {
	width: 40%;
}

main .time_table tbody {
	width: 80%;
}

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

main .time_table thead,
main .fee thead th,
main .fee tbody th,
main .time_table .arrow_guide span {
	width: 30%;
}

main .fee thead td,
main .fee tbody td {
	width: 35%;
}

main .time_table tbody {
	width: 70%;
}

}

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

main .time_table thead,
main .time_table .arrow_guide span {
	width: 32%;
}
	
.ru main .time_table thead,
.ru main .time_table .arrow_guide span {
	width: 45%;
}

main .fee thead th,
main .fee tbody th {
	width: 35%;
}

main .fee thead td,
main .fee tbody td {
	width: 32.5%;
}

main .time_table tbody {
	width: 50%;
}

}

/* 表（料金表）
------------------------------------------------------------------------------*/

main .fee td {
	text-align: center;
}

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

main .fee th,
main .fee td {
	font-size: 2.75vw;
}

main .fee tr:not(:first-child) td {
	text-align: left;
}

}


/* 表（時刻表）
------------------------------------------------------------------------------*/

main .time_table table,
main .time_table thead,
main .time_table tbody,
main .time_table tr {
	display: flex;
}

main .time_table th,
main .time_table td {
	border: none;
}

main .time_table thead th:first-child,
main .time_table tbody th {
	padding-top: 1em;
	padding-bottom: 1em;
}

main .time_table thead th:not(:first-child),
main .time_table tbody td {
	margin-bottom: 2px;
	font-size: .875em;
}

main .time_table thead th:last-child,
main .time_table tbody td:last-child {
	margin-bottom: 0;
}

main .time_table {
	margin-bottom: 3.5em;
}

main .time_table tr {
	flex-direction: column;
	display: table-cell;
	width: 100%;
}

main .time_table thead tr,
main .time_table thead th {
	display: block;
	width: 100%;
}

main .time_table tbody th {
	background-color: transparent;
}

main .time_table thead th {
	padding-right: .85em;
	padding-left: .85em;
}

main .time_table thead th:first-child {
	background-color: transparent;
	line-height: 1;
	color: inherit;
}

main .time_table thead th:not(:first-child),
main .time_table tbody td:not(:first-child) {
	min-height: 3.25em;
}

_:-ms-lang(x)::-ms-backdrop, main .time_table thead th:not(:first-child),
_:-ms-lang(x)::-ms-backdrop, main .time_table tbody td:not(:first-child) {
	height: 3.25em;
}

main .time_table thead th:not(:first-child) {
	position: relative;
}

main .time_table thead th:not(:first-child) span {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	width: 90%;
	line-height: 1.2;
}

main .time_table tbody td:not(:first-child) {
	display: flex;
	justify-content: center;
	align-items: center;
}

main .time_table tbody {
	position: relative;
	white-space: nowrap;
	overflow-x: scroll;
}

main .time_table tbody tr {
	border-right: 1px solid #FFF;
	border-left: 1px solid rgba(0,0,0,.12);
}

main .time_table tbody tr:last-child {
	border-right: 1px solid rgba(0,0,0,.1);
}

main .time_table tbody th,
main .time_table tbody td {
	min-width: 6em;
	padding-right: 1.5em;
	padding-left: 1.5em;
	text-align: center;
}

main .time_table tbody th {
	font-weight: normal;
}

main .time_table tbody td {
	background-color: transparent;
}

main .time_table .arrow_guide {
	position: relative;
	font-size: .75em;
}

main .time_table .arrow_guide span {
	position: relative;
	display: block;
}

main .time_table .arrow_guide span::after,
main .time_table .arrow_guide::after {
	content: url(../../common/img/icon_arrow_b.svg);
	position: absolute;
	top: 0;
	width: .5em;
}

main .time_table .arrow_guide span::after {
	right: -1em;
	transform: rotate(180deg) ;
}

main .time_table .arrow_guide::after {
	right: 0;
}

main .inspan .timetable_box {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

main .inspan .timetable_box > section {
	width: 48.5%;
}

main .inspan .timetable_box h4 {
	text-align: center;
}

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

main .time_table tbody th,
main .time_table tbody td {
	min-width: 3.5em;
}

main .time_table thead th:not(:first-child),
main .time_table tbody td {
	font-size: 2.5vw;
}

main .inspan .timetable_box > section {
	width: 100%;
}
	
.en main .time_table tbody th, .en main .time_table thead th:first-child, .ru main .time_table tbody th, .ru main .time_table thead th:first-child {
	font-size: 2.2vw;
}

}

@media screen and (max-width: 480px){
	
.en main .time_table tbody th, .en main .time_table thead th:first-child, .ru main .time_table tbody th, .ru main .time_table thead th:first-child {
	font-size: 2.5vw;
}	
}


/*------------------------------------------------------------------------------

	乗り場・降り場

------------------------------------------------------------------------------*/

.getting_onoff {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}

.getting_onoff .map {
	position: relative;
	width: 48.5%;
	margin-top: 2em;
	padding: 2.375em 3.75em;
	border: 1px solid rgba(0,0,0,.15);
}

.getting_onoff .map:first-child:nth-last-child(2) {
	margin-right: 3%;
}

.getting_onoff .map > span {
	position: absolute;
	top: -1.25em;
	left: 50%;
	transform: translateX(-50%);
	padding: .6em .85em;
	background-color: rgba(47,60,69,1);
	line-height: 1;
	color: #FFF;
}

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

.getting_onoff .map {
	padding: 2em 1.75em;
}

}

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

.getting_onoff .map {
	width: 100%;
	margin-top: 3em;
	padding-right: 1em;
	padding-left: 1em;
}

.getting_onoff .map:first-child:nth-last-child(2) {
	margin-top: 1em;
	margin-right: 0;
}

}


/*------------------------------------------------------------------------------

	インデックスページ

------------------------------------------------------------------------------*/

main .contents .content_list {
	padding: 2.5em;
	background: #FFF;
}


/*------------------------------------------------------------------------------

	高速バス

------------------------------------------------------------------------------*/

/* 高速バス共通
------------------------------------------------------------------------------*/

.red {
	color: rgba(235,103,113,1);
	font-weight: bold;
}

.blue {
	color: rgba(38,161,214,1);
	font-weight: bold;
}

main .inspan tbody th {
	background-color: rgba(47,60,69,.65);
	font-weight: bold;
}

main .inspan thead th:first-child, main .inspan tbody th {
    padding-top: .85em;
    padding-bottom: .85em;
}

#content main .inspan thead th,
#content main .inspan tbody th {
	padding: .85em;
}
#content main .inspan th span {
	position: relative;
	display: inline-block;
	transform:none;
	top: inherit;
	left: inherit;
}

#content main .inspan table tbody th {
	position: relative;
    padding: .85em;
}



#content main .inspan th .attribute {
	position: absolute;
    top: 50%;
    transform: translate(-50%,-50%);
	display: inline-block;
	padding: 0.3em;
	width: auto;
	left: 90%;
	background-color: #FFF;
}


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

#content main .inspan thead,
#content main .inspan tbody th {
	font-size: 2.25vw;
}
	
#content main .inspan tbody {
	width: 80%;
}
	
#content main .inspan tbody th {
	line-height: 1;
}

}


/*------------------------------------------------------------------------------

	お問い合わせ

------------------------------------------------------------------------------*/

/* お問い合わせ共通
------------------------------------------------------------------------------*/

.company {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	margin: 1em 0;
}

.company .operating {
	position: relative;
	width: 48.5%;
	padding: 2em;
	background: rgba(233,237,239,1);
}

.company .operating:first-child:nth-last-child(2) {
	margin-right: 3%;
}

.company .operating a {
	word-wrap: break-word;
}

.company .name {
	margin-bottom: .5em;
	font-weight: bold;
}

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

.company .operating  {
	width: 100%;
	padding-right: 1em;
	padding-left: 1em;
}

.company .operating:first-child:nth-last-child(2) {
	margin-top: 1em;
	margin-right: 0;
}

.company .operating:nth-child(2) {
	margin-top: 1em;
}

}











