@charset "UTF-8";
/*
* frame.css
*
*/
/* ------------------------
	Content Block
------------------------ */
.contents-wrap {
	padding: 15px 0;
	margin-bottom: 20px;
}
/* 背景処理 */
.with-bg .contents-wrap {
	background: #fff;
	padding: 15px 20px;
	border-bottom: 1px solid #ccc;
}

/*============
見出し
==============*/
.h2-style {
	padding: 10px 18px;
	border-left: 4px solid #2073db;
	border-bottom: 1px solid #ccc;
	background-color: #fff;
	font-size: 18px;
	font-weight: bold;
	margin-top: 0;
	margin-bottom: 10px;
}
.h3-style {
	margin: 0;
	padding: 0 0 10px 0;
	border-bottom: 2px solid #e5e5e5;
	font-size: 15px;
	font-weight: bold;
}
.h3-style:before {
	content: "";
	border-left: 4px solid #2073db;
	padding-right: 10px;
}
.h3-style.none:before {
	content: none;
}
.h3-style-icon {
	margin: 0;
    padding: 0 0 5px 0;
    border-bottom: 4px solid #e5e5e5;
    font-size: 16px;
    font-weight: bold;
}
.h3-style.outside {
	background: #fff;
    padding: 10px 20px 10px;
}
.h4-style {
	border-bottom: 1px solid #e5e5e5;
	font-weight: bold;
	padding-bottom: 6px;
	font-size: 14px;
	margin: 0;
}
.h5-style {
	font-weight: bold;
	font-size: 13px;
	margin: 0 0 5px;
}
.fomu-title {
	font-size: 16px;
	font-weight: bold;
	border-bottom: 2px solid #ccc;
	padding-bottom: 5px;
	margin-top: 0;
	text-align: left;
}
.fomu-title-sub {
	margin: 18px 0 5px;
	font-size: 14px;
	font-weight: bold;
	color: #000;
	text-align: left;
}
.contents-wrap p {
	margin: 0;
	font-size: 13px;
}
/* タイトル内、コンテンツ */
.into-title {
	position: relative;
}
.into-title .into-title-contents{
	position: absolute;
	top: 50%;
	right: 0;
	/* margin-top: -18px; */
	margin-top: -15px;
}
/* テキストリンク */
.text-link {
	font-size: 14px;
    font-weight: bold;
}
/*　画像リンク　*/
a img:hover {
	opacity: 0.8;
}
/*============
リスト
==============*/
.link-item-list {
	width: 100%;
	margin: 0;
	font-size: 0;
	padding: 0;
}

.link-item-list > li {
	font-size: 13px;
	list-style: none;
}
.link-item-list > li > a,
.link-item-list > li > span {
	display: block;
	/*padding: 9px 0;*/
	border-bottom: 1px solid #e5e5e5;
	font-size: 13px;
	/* color: #1b6bcf; */
	height: 40px;
	display: table;
	width: 100%;
}
.link-item-list > li > a {
	/* display: block;
	border-bottom: 1px solid #e5e5e5;
	font-size: 13px; */
	color: #1b6bcf;
	/* height: 40px;
	display: table;
	width: 100%; */
}
.link-item-list > li > a:hover {
	text-decoration: none;
}
.link-item-list > li > a:hover .text {
	text-decoration: underline;
}
.link-item-list > li > .a-substitute {
	display: block;
	border-bottom: 1px solid #e5e5e5;
	font-size: 13px;
	color: #999;
	height: 40px;
	display: table;
	width: 100%;
}
.link-item-list.col2 li:nth-child(2n),
.link-item-list.col3 li:nth-child(3n),
.link-item-list.col4 li:nth-child(4n),
.link-item-list.col5 li:nth-child(5n) {
	margin-right: 0;
}

/*2列用*/
.link-item-list.col2 > li {
	display: inline-block;
	margin-right: 20px;
	width: calc((100% - 20px) / 2);
}

/*3列用*/
.link-item-list.col3 > li {
	width: calc((100% - 41px) / 3);
	display: inline-block;
	margin-right: 20px;
}

/*4列用*/
.link-item-list.col4 > li {
	display: inline-block;
	margin-right: 15px;
	width: calc((100% - 45px) / 4);
}

/*5列用*/
.link-item-list.col5 > li {
	display: inline-block;
	margin-right: 10px;
	width: calc((100% - 40px) / 5);
}

/*5列用(上にリスト式ボタンあり)*/
.link-item-list.col5.top-line li:nth-child(-n+5) a {
	border-top: 1px solid #e5e5e5;
}
/*4列用(上にリスト式ボタンあり)*/
.link-item-list.col4.top-line li:nth-child(-n+4) a {
	border-top: 1px solid #e5e5e5;
}
/*3列用(上にリスト式ボタンあり)*/
.link-item-list.col3.top-line li:nth-child(-n+3) a {
	border-top: 1px solid #e5e5e5;
}

/*2列用(上にリスト式ボタンあり)*/
.link-item-list.col2.top-line li:nth-child(-n+2) a {
	border-top: 1px solid #e5e5e5;
}
/*1列用(上にリスト式ボタンあり)*/
.link-item-list.ç li:nth-child(-n+1) a {
	border-top: 1px solid #e5e5e5;
}

.link-item-list-wrap .ttl-type06 + .link-item-list.col5.top-line li:nth-child(-n+5) a {
	border-top: none;
}

.link-item-list + .btn-wrap.type06 {
	display: block;
}

/*複数リスト用タイトル*/
.ttl-sub {
	padding: 10px 0 5px;
	font-size: 13px;
	font-weight: bold;
}

.ttl-sub + .link-item-list li:nth-child(-n+1) a {
	border-top: 1px solid #e5e5e5;
}

.ttl-sub + .link-item-list.col2 li:nth-child(-n+2) a {
	border-top: 1px solid #e5e5e5;
}

.ttl-sub + .link-item-list.col3 li:nth-child(-n+3) a {
	border-top: 1px solid #e5e5e5;
}

.ttl-sub + .link-item-list.col4 li:nth-child(-n+4) a {
	border-top: 1px solid #e5e5e5;
}

.ttl-sub + .link-item-list.col5 li:nth-child(-n+5) a {
	border-top: 1px solid #e5e5e5;
}

/*区切り線付きリスト*/
.separator-list-wrap dl {
	display: table;
	width: 100%;
	margin: 0;
	border-bottom: 1px solid #e5e5e5;
	/*padding: 10px 0 5px;*/
	padding: 5px 0 0;
}

.separator-list-wrap dt, .separator-list-wrap dd {
	display: table-cell;
	vertical-align: top;
}
.separator-list-wrap dt {
	font-size: 13px;
}
.separator-list-wrap.type-short-dt dt {
	width: 15%;
}

.separator-list-wrap.type-short-dt dd {
	width: 85%;
}

.separator-list-wrap.type-long-dt dt {
	width: 25%;
}

.separator-list-wrap.type-long-dt dd {
	width: 75%;
}
.separator-list-wrap.type-stripe dl {
	padding: 10px 10px 3px;
	border-bottom: none;
}
.separator-list-wrap.type-stripe dl:nth-of-type(even) {
	background-color: #f7f7f7;
}
.separator-list {
	margin-bottom: 0;
	padding-left: 0;
	font-size: 13px;
	margin-top: 0;
}
.separator-list > li {
	display: inline-block;
	border-right: 1px solid #e5e5e5;
	margin-bottom: 10px;
	line-height: 1;
	/*padding: 0 10px;*/
	padding: 0 10px 0 0;
	margin-right: 7px;
}

.separator-list > li:last-child {
	border: none;
}
/* お知らせ　リスト */
.information-block {
	
}
.information-block .inner-cell {
    padding: 10px 0;	
}
.information-block .link-item-list > li > a,
.information-block .link-item-list > li > span  {
	height: 70px;

}
.info-label {
	font-size: 13px;
    color: #fff;
    font-weight: bold;
    padding: 2px 8px 0;
    vertical-align: middle;
    width: 110px;
    display: inline-block;
	text-align: center;
	margin-right: 10px;
}
.info-label.press {
	background: #D8AB57;
}
.info-label.info {
	background: #8FB8D6;
}
.info-date {
	font-size: 14px;
    color: #333;
    line-height: 20px;
    vertical-align: middle;
}
.info-text {
	display: block;
	margin-top: 3px;
    font-size: 14px;
}
.link-item-list > li > a:hover .info-text {
    text-decoration: underline;
}
/*============
リンクボックス
==============*/
.link-item-box-wrap {

}
.link-item-box {
    padding: 0;
	margin: 0;
	font-size: 0;
}

.link-item-box li {
	list-style: none;
	vertical-align: top;
}
.link-item-box.col2 li {
	display: inline-block;
	width: calc((100% - 15px) / 2);
    display: inline-block;
    margin-right: 15px;
}
.link-item-box.col2 li:nth-child(2n) {
    margin-right: 0;
}
.link-item-box.col3 li {
	display: inline-block;
	width: calc((100% - 30px) / 3);
    display: inline-block;
    margin-right: 15px;
}
.link-item-box.col3 li:nth-child(3n) {
    margin-right: 0;
}
/* Edge 対応 */
@supports (-ms-ime-align: auto) {
	.link-item-box.col2 li {
		width: calc(-10px + 50%);
	}
	.link-item-box.col3 li {
		width: calc(-10px + 33.33%);
	}
}
/* ie11対応 */
@media all and (-ms-high-contrast:none) {
	.link-item-box.col2 li {
		width: calc(-10px + 50%);
	}
	.link-item-box.col3 li {
		width: calc(-10px + 33.33%);
	}	
}
.link-item-box-text {
	border: 1px solid #ccc;
	border-top: none;
	border-radius: 0 0 4px 4px;
	padding: 5px 10px;
}
.link-item-box .title {
	font-size: 14px;
    color: #1B6BCF;
    margin: 0 0 3px;
	font-weight: bold;
	letter-spacing: -0.5px;
}
.link-item-box .text {
	font-size: 12px;
	color: #333;
	letter-spacing: -1px;
    min-height: 3em;
}
/*============
コンテンツボックス
==============*/
.contents-box-wrap {
	font-size: 0;
}
.contents-box {
	font-size: 0;
	margin-bottom: 10px;
	border-bottom: 1px solid #E5E5E5;
	padding-bottom: 10px;
	box-sizing: border-box;
}
.contents-box.col2 {
	
}
.contents-box .title {
	font-size: 14px;
    font-weight: bold;
    margin-bottom: 5px;
}
/* コンテンツボックス内レイアウト */
.contents-box.col2 > .contents-box-inner {
	width: calc(100% / 2 - 7.5px);
	/* display: inline-block; */
    vertical-align: top;
	/* margin-right: 15px; */
	
	padding-right: 15px;
    display: table-cell;
}
.contents-box.col2 > .contents-box-inner:nth-child(2n) {
	margin-right: 0;
	padding-right: 0;
}
/* コンテンツボックス 2列 */
.contents-box-wrap.col2 > .contents-box {
	width: calc(100% / 2 - 10px);
    display: inline-block;
	vertical-align: top;
	margin-right: 20px;
}
.contents-box-wrap.col2 > .contents-box:nth-child(2n) {
    margin-right: 0;
}
/*============
アイコン追加
==============*/

.inner-cell {
	position: relative;
	/*padding-left: 20px;*/
	display: table-cell;
	vertical-align: middle;
}
.inner-cell .text {
	/*margin-right: 5px;*/
}
.travel-icon {
	position: absolute;
	top: 4px;
	left: 0;
	margin-top: -2px;
}

.travel-icon-btn {
	position: absolute;
	top: 7px;
	left: 16px;
	margin-top: -2px;
}

.inner-cell .travel-icon {
	top: 50%;
	margin-top: -7px;
	top: 12px;
	margin-top: 0;
}

.inner-cell .travel-icon + .text {
	padding-left: 20px;
	display: inline-block;
}

a:hover .inner-cell .travel-icon + .text {
	text-decoration: underline;
}

.travel-icon.fe-arrow-line-right {
	content: "\EA06";
	display: inline-block;
	font-family: "myfont";
	margin-top: -6px;
	font-size: 10px;
	vertical-align: baseline;
	top: 18px;
}

.inner-cell .travel-icon.fe-arrow-line-right + .text {
	padding-left: 15px;
	display: inline-block;
}

/*============
リスト式ボタン
==============*/
.select-area.col5 {
	font-size: 0;
	margin: 20px 0 30px;
}

.select-area.col5 li {
	display: inline-block;
	width: calc(100% / 5);
}

.select-area.col5 .btn.btn-md {
	border-left: none;
	display: block;
	float: none;
	width: 100%;
	height: 26px;
	line-height: 26px;
	padding: 0;
}

.select-area.col5 .btn.btn-md:last-of-type {
	width: 100%;
	border-radius: 0;
}

.select-area.col5 li:nth-child(n+6) a.btn.btn-md {
	border-top: none;
}

.select-area.col5 li:nth-child(6) a.btn.btn-md,
.select-area.col5 li:first-of-type a.btn.btn-md {
	border-left: 1px solid #ccc;
}

.select-area.col5 .btn.btn-md.active > .fe-check {
	position: absolute;
	top: 50%;
	left: 25px;
	margin-top: -4px;
}

.select-area.col5 .btn.btn-md.letter-6.active > .fe-check {
	left: 18px;
}

/*======================
リスト式ボタン改良版サンプル
========================*/

.select-btn-list {
	font-size: 0;
	margin: 0 0 15px;
	width: 100%;
	padding-left: 0;
}

h2 + .select-btn-list {
	margin: 10px 0 15px;
}

.select-btn-list li {
	background-color: #fff;
	border: 1px solid #ccc;
	border-left: none;
	display: inline-block;
	cursor: pointer;
	font-size: 13px;
}

.select-btn-list li:first-of-type {
	border-left: 1px solid #ccc;
}

.select-btn-list li a,
.select-btn-list li > span {
	display: block;
	position: relative;
	color: #1b6bcf;
	text-align: center;
	width: 100%;
	outline: none;
	min-width: 4em;
	padding: 4px 0;
}

.select-btn-list li:hover {
	background-color: #d2f0ff;
	color: #1b6bcf;
}

.select-btn-list li:hover a, .select-btn-list li:visited a {
	text-decoration: none;
}

.select-btn-list .fe-check::before {
	/*vertical-align: baseline;*/
}

/*選択状態（5文字・6文字以外は都度作成）*/
.select-btn-list li.active {
	color: #fff;
	font-weight: bold;
	border-color: #2073db;
	background-color: #2073db;
}

.select-btn-list li.active a,
.select-btn-list li.active > span {
	color: #fff;
	font-weight: bold;
}

.select-btn-list li:not(.active) a > .fe.fe-check,
.select-btn-list li:not(.active) > span > .fe.fe-check {
	display: none;
}

.select-btn-list li.active a > .fe.fe-check::before,
.select-btn-list li.active > span > .fe.fe-check::before {
	font-size: 80%;
	margin: 0 3px 0 0;
	/*vertical-align: middle;*/
}

/*4列ボタン（2段対応）*/
.select-btn-list.col4 li {
	width: calc(100% / 4);
}

.select-btn-list.col4 li:nth-child(4n+1) {
	border-left: 1px solid #ccc;
}

.select-btn-list.col4 li:nth-child(n+5) {
	border-top: none;
}

.select-btn-list.col4 li:nth-child(5),
.select-btn-list.col4 li:first-of-type {
	border-left: 1px solid #ccc;
}

/*5列ボタン（2段対応）*/
.select-btn-list.col5 li {
	width: calc(100% / 5);
}

.select-btn-list.col5 li:nth-child(6) aa, .select-btn-list.col5 li:first-of-type {
	border-left: 1px solid #ccc;
}

.select-btn-list.col5 li:nth-child(n+6) {
	border-top: none;
}

.select-btn-list.col5 li:nth-child(6),
.select-btn-list.col5 li:first-of-type {
	border-left: 1px solid #ccc;
}

/*10列ボタン（1段用）*/
.select-btn-list.col10 {
	/*display: table;*/
	display:-webkit-box;
	display:-ms-flexbox;
	display:flex;
}

.select-btn-list.col10 li {
	/*display: table-cell;*/
	/*-webkit-box-flex:1;
	-ms-flex:1 1 0;
	flex:1 1 0;*/
	-webkit-box-flex:1;
	-ms-flex-positive:1;
	flex-grow:1;
	-ms-flex-negative:1;
	flex-shrink:1;
	-ms-flex-preferred-size: 0;
	flex-basis: 0;


}
.select-btn-list.col10 li:last-child {
	-webkit-box-flex:1.5;
	-ms-flex-positive:1.5;
	flex-grow:1.5;
	-ms-flex-negative:1.5;
	flex-shrink:1.5;
	-ms-flex-preferred-size: 0;
	flex-basis: 0;
}



/* リスト　-テーブルスタイル */
.list-table {
	padding-left: 0;
	margin: 0 0 10px;
}
.list-table > li {
	list-style: none;
	display: table;
	width: 100%;
	border-bottom: 1px solid #ccc;
	border-right: 1px solid #ccc;
}
.list-table > li:first-child {
	border-top: 1px solid #ccc;
}
.list-table > li .table-col {
	display: table-cell;
	border-left: 1px solid #ccc;
	padding: 10px;
	font-size: 13px;
}
/* 3列均等 */
.list-table.col3 > li .table-col {
	width: calc(100% / 3);
}
/* ie11対応 */
@media all and (-ms-high-contrast:none) {
	.list-table.col3 > li .table-col {
		width: 33.3%;
	}
}
/* テーブル装飾 */
.list-table > li .table-col a {
	font-weight: 700;
}
.list-table.ht-30 > li .table-col:first-child {
	width: 30%;
}
.list-table.th-color > li .table-col:first-child {
		background: #F7F7F7;
}
.list-table .has-status .icon-base-20 {
	padding-right: 8px;
}

/* 広告枠 -画像(728x90) */
.bnr-wrap {
	margin-bottom: 20px;
}
/* 広告枠 -画像(300x250横並び) */
.bnr-wrap.abreast {
	font-size: 0;
	text-align: center;
}
.bnr-wrap.abreast::after {
	content: "";
	display: block;
	clear: both;
}
.bnr-wrap.abreast .bnr-item {
	display: inline-block;
	max-width: 50%;
}
.bnr-wrap.abreast .bnr-item:nth-child(odd) {	
    float: left;
}
.bnr-wrap.abreast .bnr-item:nth-child(even) {
    float: right;
}
/* 広告枠 -テキスト */
.pr-link-box {
	background-color: #fff;
	border: 2px solid #ccc;
	height: 42px;
	line-height: 38px;
	text-align: center;
	width: 100%;
	margin-bottom: 20px;
}
.pr-link-box a {
	display: block;
}
.pr-link-box a:hover {
	background-color: #d2f0ff;
}
.pr-link-box a img {
	margin-top: -4px;
	margin-right: 5px;
}
.label-wrap {
    vertical-align: middle;
	display: table-cell;
	min-width: 55px;
}
.label-wrap .labeling {
	font-size: 10px;
    color: #fff;
    padding: 0 5px;
    margin-right: 5px;
    vertical-align: top;
}
.label-wrap .labeling.red {
	background: #E52727;
}
.label-wrap .labeling.pink {
	background: #EE3996;
}
.pr-link-box .text {
    vertical-align: middle;
	display: table-cell;
	line-height: 18px;
}
.pr-link-box.in-label-wrap a:hover {
	text-decoration: none;
}
.pr-link-box.in-label-wrap a:hover .text {
	text-decoration: underline;
}
/* 広告枠 -サイドエリア-バナー */
.sidearea-bnr-wrap {
	width: 300px;
}
.sidearea-bnr-wrap .bnr-item {
	margin-bottom: 20px;
}
/*============
バナーラップ
==============*/
.bnr-contents {

}
.bnr-contents + .bnr-contents {
	margin-top: 10px;
}
.bnr-contents h4 {
	margin: 0;
}
.bnr-contents img {
	width: 100%;
}
.bnr-contents .text-link {
	font-weight: bold;
}
.bnr-contents .fe.fe-arrow-line-right {
    font-size: 11px;
}
.bnr-contents a:hover img {
	opacity: 0.8;
}
/*============
運行情報　路線登録
==============*/
.line-registration {
	background: #f7f7f7;
	padding: 15px;
}
.line-registration h4 {
	font-size: 14px;
	font-weight: bold;
	margin-bottom: 5px;
}
.line-registration-text {
	line-height: 26px;
}
.line-registration-text .btn-type {
	vertical-align: baseline;
}
.tippy-btn + .tippy-align {
	margin-top: -33px;
}
/* 運行情報　登録路線　-テーブル表示 */
.list-table.col-registration > li .table-col {
	width: calc(100% / 3 - 100px);
	width: calc((100% - 100px) / 3);
	width: 230px;
}
.list-table.col-registration > li .table-col:nth-child(3) {
	width: 150px;
}
.list-table.col-registration > li .table-col:nth-child(4) {
	width: 90px;
    text-align: center;
    color: #1B6BCF;
}
/* 運行情報　詳細ページ　-路線登録ボタン */
.registration-btn-box {
    text-align: center;
	font-size: 0;
	margin-top: 15px;
}
.registration-btn-wrap {
	display: inline-block;
	vertical-align: top;
}
.registration-btn-wrap + .registration-btn-wrap {
	margin-left: 30px;
}
.registration-btn-wrap .tippy-btn {
    display: block;
    margin: 10px auto 0;
}