@charset "utf-8";

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&family=Oswald:wght@200..700&display=swap');

/*---------------------------------
	pc(tablet)・sp　切り替え
----------------------------------*/
/* sp */
@media (max-width: 767px) {
  .pc-on {
    display: none;
  }
  .tab-on {
    display: none;
  }
  .sp-on {
    display: block;
  }
  
  .t-left-sp {
    text-align: left!important;
  }
}

/*pc・tablet*/ 
@media (min-width: 768px) {
  .pc-on {
    display: block;
  }
  .tab-on {
    display: none;
  }
  .sp-on {
    display: none;
  }
}

/* tablet only */
@media (min-width: 768px) and (max-width: 991px) {
  .tab-on {
    display: block;
  }
}


/*---------------------------------
	共通　PCファースト
----------------------------------*/
body{
/*	font-family: "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3","Yu Gothic", "Yu Gothic medium", "Arial", "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;*/
	font-family: "Noto Sans JP", sans-serif,"Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3","Yu Gothic", "Yu Gothic medium", "Arial", "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;
	overflow-x: hidden;
	color: #2B2B2B;
	max-width: 1920px;
	margin: 0 auto;
}

img {
	max-width: 100%;
	height: auto;
}

a{	
	text-decoration: none;
	color: inherit;
}
a:hover{
	color: inherit;
}
a:link, a:visited, a:hover, a:active, a:focus{
	text-decoration: none;
}

h1,
h2,
h3,
h4,
ul,
ol,
dl,
dt,
dd,
p,
figure{
	margin:0;
	padding:0;
}

ul,
ol{
	margin:0;
	padding:0;
	list-style-type: none;
}

button:focus {
	outline: none;
}
		
/*
article p{
	font-size:16px;
}
*/

/*共通*/
.red{
	color: #B80E0B;
}

/*リスト*/
.dot-list li{
	position: relative;
	padding-left: 15px;
}

/*リストの「・」*/
.dot-list li:before{
	content: "・";
	position: absolute;
/*	top: 0;*/
	left: 0;
}

/*ドットなし・字下げ*/
.dot-list li.indent{
	padding-left: 0;
}
.dot-list li.indent:before{
	display: none;
}


/*  見出し
-------------------------------*/
.title-h2{
	position: relative;
	text-align: center;
	font-weight: 900;
	font-size: 40px;
	margin: 0 auto 60px;
}

.title-h2 .sub{
	letter-spacing: 0;
	font-size: 26px;
}

.title-h3{
	text-align: center;
	font-weight: 900;
	font-size: 28px;
	margin: 0 auto 30px;
}
.title-h4{
	text-align: center;
	font-weight: 900;
	font-size: 20px;
}

.title-h2 span,
.title-h3 span{
	display: block;
	font-weight: 900;
	line-height: 1.5;
}


@media (max-width:767px) {
	.title-h2{
		font-size: 28px;
		margin: 0 auto 30px;
	}
	.title-h2 .sub{
		font-size: 22px;
	}
	.title-h3{
		font-size: 22px;
	}
	.title-h4{
		font-size: 18px;
	}
}



/*  ボタン
-------------------------------*/
.link-btn {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    font-weight: bold;
    font-size: 20px;
    color: #fff;
    background: #B80E0B;
    border-radius: 5px;
    width: 100%;
	max-width: 268px;
    padding: 18px 30px 18px 30px;
    margin: 20px auto;
	transition: 0.2s;
}
.link-btn:hover {
    color: #fff;
	opacity: 0.8;
	text-decoration: none;
}

/*矢印アイコン*/
.link-btn:before {
    content: "\f105";
    font-family: "Font Awesome 5 Free";
    position: absolute;
	top: calc(50% - 10px);
    right: 0.7em;
    font-weight: bold;
    z-index: 2;
    color: #fff;
    width: 20px;
	font-size: 15px;
    transform: scale(1);
}

/*各ボタン*/
/*背景色：黒*/
.link-btn.bg-black{
	background: #232323;
	border: none;
}

/*アイコン：外部タブ*/
.link-btn.other-tab:before{
	content: "\f35d";
	right: 1em;
}

.link-btn.other-tab2:before{
	content: "\f24d";
	transform: scale(1.3);
}

@media (max-width: 767px) {
	.link-btn {
		font-size: 18px;
	}
}

/*---------------------------------
	ヘッダー
----------------------------------*/
/*ナビ非表示*/
.header{
	display: none;
}

/*ロゴ無し　mv１枚画像の場合*/
/*
.header{
	display: flex;
	justify-content: space-between;
	align-items: center;
	z-index: 3;
	position: relative;
	top: 4vw;
	width: 100%;
	height: 0;
	background: #BDE4F3;
	padding: 0 20px;
}

.header-inner {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: right;
}


@media (min-width: 992px) {
	.navbtn {
		display: none;
	}
	
	.header .nav-wrap{
		width: 100%;
		max-width: 580px;
	}

	.header ul.list-nav{
		display: flex;
		align-items: center;
		justify-content: center;
		list-style: none;
		background: #fff;
		border-radius: 50px;
		margin: 0;
	}
	.header .btn-item{
		margin-right: 10px;
	}
	.header .btn-item:last-of-type{
		margin-right: 0;
	}

	.header .btn-item a{
		display: flex;
		align-items: center;
		justify-content: center;
		width: 100%;
		max-width: 160px;
		padding: 13px 8px;
		font-weight: bold;
		font-size: 19px;
		color: #232323;
		transition: 0.2s;
	}
	.header .btn-item a:hover{
		color: #B80E0B;
	}
}


@media (max-width: 991px) {
	.navbtn {
		padding: 0;
		outline: none;
		border: none;
		background: transparent;
		cursor: pointer;
		color: #97857e;
		font-size: 30px;
		display: block;
		position: fixed;
        top: 10px;
        right: 20px;
		z-index: 100;
	}

	.hamburger-inner, .hamburger-inner::before, .hamburger-inner::after{
		background-color: #000 !important;
	}

	.open .navbtn {
		z-index: 110;
		position: fixed;
		right: 20px;
	}

	.open .hamburger-inner, .open .hamburger-inner::before, .open .hamburger-inner::after{
		background-color: #fff !important;
	}

	.hamburger-inner,
	.hamburger-inner::before,
	.hamburger-inner::after,
	.hamburger.is-active .hamburger-inner,
	.hamburger.is-active .hamburger-inner::before,
	.hamburger.is-active .hamburger-inner::after {
		background-color: currentColor;
	}

    .header-nav {
        position: fixed;
        inset: 0 -100% 0 100%;
        z-index: 100;
        background-color: rgba(60, 176, 219, 0.9);
        transition: 0.3s;
		color: #fff;
    }

    .open .header-nav {
        transform: translate(-100%, 0);
    }

    .header-nav ul {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        height: 100%;
        gap: 40px;
        color: #fff;
		font-size: 18px;
    }
}
*/


/*　MV 
-------------------------------*/
.mv-area {
	width: 100%;
	text-align: center;
	padding: 40px 0 0;
	background: #BDE4F3;
}

/*ロゴ無し　mv1枚画像の場合*/
.mv-area {
	padding: 0;
}

.mv-area img {
	max-width: 100%;
	object-fit: cover;
	object-position: top center;
	margin: auto;
}

/* タブレット以下 */
@media (max-width: 787px) {
	.mv-area {
		padding: 0;
	}
}


/*---------------------------------
	section　Area
----------------------------------*/
.Area{
	background: url(/static/img/maas/mobi/kr001/bg-repeat.png) top left; 
	padding: 80px 0 80px;
}

/*各地図記事*/
.area-item {
    padding: 0 5px 10px;
    max-width: 755px;
	margin: auto;
}

/*カードデザイン*/
.area-item .card-wrap{
	background: #fff;
	border: solid 1px #D7D7D7;
	padding: 0 20px;
}

/*見出し*/
.area-item .title-wrap{
    display: flex;
    justify-content: center;
    align-items: center;
	flex-wrap: wrap;
	min-height: 90px;
}


/*グーグルマップ*/
.wrap-map{
	position: relative;
    overflow: hidden;
    padding-bottom: 56.25%;
	text-align: center;
	margin: 0 auto 15px;
	min-height: 300px;
}

.wrap-map iframe {
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 100%;
}

/*
.area-item .card-wrap .wrap-map img{
	width: 100%;
	max-width: 640px;
    max-height: 516px;
}
*/

/*運行時間*/
.time-wrap{
	text-align: center;
}

/*横並びの時*/
.time-wrap.two-line dl{
	display: flex;
	justify-content: center;
	align-items: center;
}

/* ※注意テキスト */
.area-item .card-wrap .attention-text{
    margin: 10px auto 50px;
	text-align: center;
/*	color: #B80E0B;*/
	font-size: 14px;
}

/*時刻表リンク*/
.wrap-timetable li{
	padding: 0 15px 5px;
}

a.link-time-table{
	position: relative;
	text-decoration: underline;
}
/*アイコン　色反転*/
/*
.fa-clone:before {
    content: "\f24d";
    right: -1.1em;
    top: 2px;
    position: absolute;
	transform: scaleX(-1);
	color: #2b2b2b;
}
*/

/*アイコン：外部タブ*/
.link-time-table:after{
    content: "\f24d";
	font-family: "Font Awesome 5 Free";
    z-index: 2;
    width: 20px;
	font-size: 15px;
    transform: scale(1);
}


@media (max-width: 767px) {
	.Area{
		padding: 60px 0 30px;
	}

	/*各地図記事*/
	.area-item{
		padding: 0 10px 25px;
	}
	/*横並びの時*/
	.time-wrap.two-line dl{
		display: block;
	}
}

@media (max-width: 372px) {
	/*カードデザイン*/
	.area-item .card-wrap{
		padding: 0 5px;
	}
}




/*---------------------------------
	section　Fare
----------------------------------*/
.Fare{
	padding: 50px 0 100px;
}

.Fare .section-body{
	width: 100%;
    max-width: 947px;
    margin: 0 auto;
}

/*テーブル2列の時　筑波山、下妻*/
.Fare .section-body.table-two-rows{
    max-width: 563px;
}

/*テーブル2列・結合の時　牛久*/
.Fare .section-body.table-colspan{
    max-width: 474px;
}

.Fare .section-body .table-title{
	font-size: 20px;
	font-weight: bold;
}


/*テーブル*/
.fare-table {
	border-collapse: collapse;/*セル分離しない*/
    width: 100%;
	text-align: center;
}

.fare-table tr{
	height: 80px;
}
.fare-table td,
.fare-table th {
	padding: 0 10px;
	font-weight: bold;
}

/*奇数行*/
.fare-table tr:nth-of-type(odd){
	background: #F9F9F9;
}

/*偶数行*/
.fare-table tr:nth-of-type(even){
	background: #F1F1F1;
}

/*左端 1列目*/
.fare-table tr th:nth-of-type(1){
	width: 25%;
}
/*テーブル2列の時*/
.table-two-rows .fare-table tr th:nth-of-type(1) {
	width: 35%;
}
/*テーブル2列・結合の時*/
.table-colspan .fare-table tr th:nth-of-type(1) {
	width: 40%;
	border-right: solid 1px #A4A4A4;
}

/*2列目,3列目*/
.fare-table .price{
	font-size: 34px;
	font-weight: 900;
	font-family: "Oswald", sans-serif;
}
.fare-table .big-text{
	font-size: 26px;
	font-weight: 900;
}

.Fare .wrap-attention{
	font-size: 14px;
	margin: 15px 0 15px 15px;
}


@media (max-width: 767px) {
	.Fare{
		padding: 60px 0 60px;
	}
	/*左端 1列目*/
	.fare-table tr th:nth-of-type(1) {
		width: 32%;
	}
}


/*---------------------------------
	section　About
----------------------------------*/
#About{
	background: url(/static/img/maas/mobi/kr001/bg-repeat.png) top left; 
	padding: 80px 0 80px;
}

#About .intro-text {
	font-size: 28px;
	font-weight: 900;
}

#About .wrap-about {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	max-width: 947px;
	margin: 30px auto 0;
}

/*各item*/
#About .about-item{
	background: #fff;
	border-radius: 20px;
	width: calc((100% - 13px) / 2);
	min-height: 311px;
	padding: 20px 45px;
}

#About .about-item:nth-of-type(1){
	border: solid 3px #D11D22;
	margin-right: 13px;
}
#About .about-item:nth-of-type(2){
	border: solid 3px #1D5FD1;
}

/*見出し*/
#About .about-item .item-title{
	font-size: 20px;
	font-weight: bold;
	text-align: center;
}

#About .about-item .attention-text{
	font-size: 16px;
	text-align: center;
	margin: 10px 0 20px;
}

/*リスト*/
#About .wrap-about .attention-list li{
	position: relative;
	padding-left: 15px;
	font-size: 14px;
	line-height: 1.8;
}

/*リストの「・」*/
#About .wrap-about .attention-list li:before{
	content: "・";
	position: absolute;
	top: 0;
	left: 0;
}

/*画像*/
#About .wrap-img{
	width: 100%;
	max-width: 947px;
	margin: 40px auto 0;
	text-align: center;
    background: #fff;
    border-radius: 15px;
    padding: 23px;
}
#About .wrap-img .attention-text{
	text-align: left;
	margin: 5px 5px 0;
	font-size: 14px;
}


@media (max-width: 767px) {
	#About{
		padding: 60px 0;
	}
	#About .intro-text {
		font-size: 24px;
	}
	
	#About .wrap-about {
		flex-wrap: wrap;
	}
	#About .about-item{
		width: 100%;
	}
	#About .about-item:nth-of-type(1){
		margin: 0 0 20px;
	}
	
	/*画像*/
	#About .wrap-img{
		padding: 15px 0 15px 15px;
		overflow: hidden;
		width: calc(100% - 15px);
		margin-left: 15px;
		border-radius: 15px 0 0 15px;
	}
	#About .wrap-inner-img{
		overflow-x: scroll;
		padding: 0 15px 5px 0;
	}
	#About .wrap-inner-img img{
		max-width: 750px;
	}
}

@media (max-width: 991px) {
	/*各item*/
	#About .about-item{
		padding: 20px 10px;
	}
	#About .wrap-img{
		max-width: 720px;
	}
}


/*---------------------------------
	section　Use
----------------------------------*/
#Use{
	padding: 80px 0 0;
}

/*※乗車予定日時は～*/
#Use .about-ridetime{
	max-width: 978px;
	margin: 0 auto 80px;
}


/*自宅登録
-----------------------------*/
.wrap-home-registration{
	padding: 0 15px;
}

.wrap-home-registration .wrap-inner{
	border-radius: 20px;
	border: solid 3px #D7D7D7;
	max-width: 947px;
	width: 100%;
	text-align: center;
	margin: 0 auto 120px;
	padding: 40px 20px 30px;
}

.wrap-home-registration .wrap-target-area{
	font-weight: bold;
	font-size: 18px;
	margin: 0 0 30px;
}

/*リスト*/
.wrap-home-registration .wrap-list{
    max-width: 520px;
	width: 100%;
    margin: auto;
    text-align: left;
    font-size: 14px;
}

/*ドット*/
.wrap-home-registration .wrap-list li{
	position: relative;
	padding-left: 15px;
}
.wrap-home-registration .wrap-list li:before{
	content: "・";
	position: absolute;
    top: 0;
	left: 0;
}

/*ドットなし・字下げ*/
.wrap-home-registration .wrap-list li.indent{
	padding-left: 15px;
}
.wrap-home-registration .wrap-list li.indent:before{
	display: none;
}


@media (max-width: 767px) {
	#Use{
		padding: 80px 0 0;
	}
	
	/*※乗車予定日時は～*/
	#Use .about-ridetime{
		margin: 50px auto 0;
		padding: 0 20px;
	}
	
	.wrap-home-registration .wrap-inner{
		margin: 50px auto 30px;
		padding: 40px 20px 30px;
	}
}


/*01・02 共通
-----------------------------*/
/*各アイテム*/
.wrap-use-item{
	text-align: center;
}

/*見出し*/
.wrap-use-item h3{
	width: 263px;
	font-size: 20px;
	position: relative;
}
/*下線*/
.wrap-use-item h3:before{
	content: "";
	position: absolute;
	bottom: -10px;
	left: 0;
	background: #232323;
	width: 100%;
    height: 2px;
}

/*数字画像*/
.wrap-use-item h3 span{
	position: relative;
	width: fit-content;
    margin: auto;
	padding-left: 1.9em;
}
.wrap-use-item h3 span:before{
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	display: block;
	width: 35px;
    height: 35px;
	background: url(/static/img/maas/mobi/kr001/lower-common/use-01.svg) no-repeat center / 100%;
	padding-left: 35px;
}

/*01 WEBアプリにアクセス
-----------------------------*/
/*QRコード*/
.use-item01 .wrap-img {
    max-width: 371px;
    border: solid 1px #D7D7D7;
    padding: 25px;
    margin: 80px auto 0;
}


/*02 WEBアプリで予約
-----------------------------*/
.use-item02{
	margin: 150px auto 0;
}
/*見出し*/
.use-item02 h3 span{
	padding-left: 2.2em;
}
/*数字画像*/
.use-item02 h3 span:before{
	background: url(/static/img/maas/mobi/kr001/lower-common/use-02.svg) no-repeat center / 100%;
	width: 42px;
    height: 35px;
}


/*ステップ全体---------*/
.use-item02 .wrap-step{
	display: flex;
	flex-wrap: wrap;
	max-width: 978px;
	width: 100%;
	margin: 50px auto 0;
}

/*各ステップ*/
.use-item02 .wrap-step .step-item{
	width: calc(82% / 3);
	margin-bottom: 100px;
}
.use-item02 .wrap-step .step-item:nth-child(3n+2){
	margin-right: 9%;
	margin-left: 9%;
}
.use-item02 .wrap-step .step-item:last-of-type{
	margin-bottom: 0;
}

/*見出し*/
.use-item02 .wrap-step .step-item .title-h4 {
    font-size: 18px;
    min-height: 65px;
    display: flex;
    justify-content: center;
    align-items: center;
}

/*画像*/
.use-item02 .wrap-step .step-item img{
	margin: 0 auto 20px;
}


@media (max-width: 767px) {
	.use-item01 .wrap-img {
		margin: 60px auto 0;
	}
	
	.use-item02{
		margin: 90px auto 0;
	}
	
	/*各ステップ*/
	.use-item02 .wrap-step .step-item{
		width: 100%;
		margin-bottom: 50px;
	}
	.use-item02 .wrap-step .step-item:nth-child(3n+2){
		margin-right: 0;
		margin-left: 0;
	}
	/*画像*/
	.use-item02 .wrap-step .step-item img{
		max-width: 80%;
	}
}


/*---------------------------------
	section　Flow
----------------------------------*/
#Flow{
	padding: 0 0 100px;
}

/*サービス利用の流れ*/
#Flow .wrap-flow{
	max-width: 926px;
	margin: auto;
}

/*ボタン全体*/
.wrap-flow-btn{
	margin: 50px 0 0;
}

.wrap-flow-btn a{
padding: 18px 30px 18px 10px;
}
.wrap-flow-btn ul{
	display: flex;
	justify-content: center;
	align-items: center;
	max-width: 947px;
	width: 100%;
	margin: auto;
}
.wrap-flow-btn ul li{
	max-width: 190px;
	width: 100%;
	margin-right: 13px;
}

/*最後の要素*/
.wrap-flow-btn ul li:last-of-type{
	max-width: 290px;
	margin-right: 0;
}
.wrap-flow-btn ul li:last-of-type a{
	max-width: 290px;
}
/*最後のから2番目*/
.wrap-flow-btn ul li:nth-last-child(2){
	max-width: 290px;
	margin-right: 13px;	
}
.wrap-flow-btn ul li:nth-last-child(2) a{
	max-width: 290px;
}

/*各ボタン*/
.wrap-flow-btn .link-btn{
	border-radius: 10px;
}

/*利用上の注意*/
.wrap-use-attention{
	margin: 100px 0 0 ;
}

.wrap-use-attention .attention-item .attention-title{
	font-weight: bold;
	font-size: 18px;
}
.inner-attention{
	height: 400px;
	padding: 40px;
	overflow-y: scroll;
	border:1px solid #ccc;
}
@media (max-width: 992px) {
	.wrap-flow-btn a{
		font-size: 14px;
	}	
	.inner-attention{
	padding: 20px;
}	
}

/*
#Flow .wrap-flow ul{
	display: flex;
}
#Flow .wrap-flow li{
	position: relative;
	margin-right: 33px;
}
#Flow .wrap-flow li:before{
	content: "";
	display: block;
	width: 17px;
    height: 42px;
	background: url(/static/img/maas/mobi/kr001/flow-triangle.png) no-repeat center center /100%;
	position: absolute;
	top: calc(50% - 21px);
	right: -26px;
}

#Flow .wrap-flow li:last-of-type{
	margin-right: 0;
}
#Flow .wrap-flow li:last-of-type:before{
	display: none;
}
*/


@media (max-width: 767px) {
	#Flow {
		padding: 60px 0 50px;
	}
	
	/*サービス利用の流れ*/
	#Flow .wrap-flow{
		margin: 40px auto 0;
	}
	
	/*利用上の注意*/
	.wrap-use-attention{
		margin: 80px 0 0 ;
	}
	
	/*各ボタン*/
	.wrap-flow-btn ul{
		flex-wrap: wrap;
	}
	.wrap-flow-btn ul li{
		margin-right: 0px!important;
		max-width: 268px!important;
	}
	.wrap-flow-btn .link-btn{
		padding: 18px 20px 18px 5px;
		margin: 10px auto;
	}
	.wrap-flow-btn ul li a{
		max-width: 268px!important;
	}
	.wrap-flow-btn li:last-of-type .link-btn:before{
		transform: scale(1);
	}
}

	
/*---------------------------------
	section　Contact
----------------------------------*/
.Contact{
	background: url(/static/img/maas/mobi/kr001/bg-repeat.png) top left; 
	padding: 110px 0 170px;
}

/*TEL番号
------------------------------*/
.contact-tel{
	margin: 20px 0 0;
	font-weight: bold;
}
.contact-tel a{
    display: block;
    position: relative;
    font-size: 34px;
    font-weight: bold;
    max-width: 347px;
    width: fit-content;
    padding: 10px 20px 10px 50px;
    border: solid 2px #232323;
    border-radius: 10px;
    background: #fff;
    margin: 20px auto;
}
.contact-tel a span{
    position: relative;
}

.contact-tel a span:before {
    content: "";
    position: absolute;
    background: url(/static/img/maas/mobi/kr001/icon-tel.png) no-repeat center / 100%; 
    top: calc(50% - 15px);
    left: -30px;
    width: 25px;
    height: 35px;
}


@media (max-width: 767px) {
	.Contact{
		padding: 60px 0 120px;
	}
	
	/*TEL番号*/
	.contact-tel a{
		font-size: 30px;
	}
}


/* STEP 共通（電話申し込みあり・なし）
-------------------------------------*/
.wrap-contact-step{
	max-width: 755px;
	width: 100%;
	margin: 80px auto 80px;
}

/*見出し*/
.wrap-contact-step .title-h3{
	font-size: 22px;
	border-bottom: solid 2px #232323;
	width: fit-content;
	padding: 0 15px 10px;
}

/*各ステップ*/
.wrap-contact-step > ul > li{
	position: relative;
	background: #fff;
	text-align: left;
	font-weight: bold;
	font-size: 20px;
	min-height: 80px;
	padding: 24px 20px 24px 120px;
	margin-bottom: 20px;
}
.wrap-contact-step li .small{
	font-size: 16px;
}

.wrap-contact-step > ul > li:before{
	content: "";
	display: block;
	width: 91px;
	height: 31px;
	position: absolute;
	top: 28px;
	left: 0;
	background: url(/static/img/maas/mobi/kr001/lower-common/icon-step01.svg) no-repeat center / 100%; 
}
.wrap-contact-step > ul > li:nth-of-type(2):before{
	background: url(/static/img/maas/mobi/kr001/lower-common/icon-step02.svg) no-repeat center / 100%; 
}
.wrap-contact-step > ul > li:nth-of-type(3):before{
	background: url(/static/img/maas/mobi/kr001/lower-common/icon-step03.svg) no-repeat center / 100%; 
}
.wrap-contact-step > ul > li:nth-of-type(4):before{
	background: url(/static/img/maas/mobi/kr001/lower-common/icon-step04.svg) no-repeat center / 100%; 
}
.wrap-contact-step > ul > li:nth-of-type(5):before{
	background: url(/static/img/maas/mobi/kr001/lower-common/icon-step05.svg) no-repeat center / 100%; 
}
.wrap-contact-step > ul > li:nth-of-type(6):before{
	background: url(/static/img/maas/mobi/kr001/lower-common/icon-step06.svg) no-repeat center / 100%; 
}
/*最後の要素*/
.wrap-contact-step > ul > li:last-of-type{
	margin-bottom: 0;
}


@media (max-width: 767px) {
	.wrap-contact-step{
		margin: 60px auto 60px;
	}
	
	/*見出し*/
	.wrap-contact-step .title-h3{
		font-size: 20px;
		padding: 0 10px 10px;
	}
	/*数字画像*/
	.tel-application-available .wrap-contact-step .title-h3 span{
		text-align: left;
		padding-left: 2.5em;
	}
	
	/*各ステップ*/
	.wrap-contact-step > ul > li{
		min-height: 70px;
		padding: 20px 20px 20px 80px;
		margin-bottom: 20px;
		font-size: 18px;
	}
	.wrap-contact-step > ul > li:before{
		width: 70px;
		top: 20px;
	}
}



/* STEP 共通（電話申し込みありの場合のみ）
-------------------------------------*/
/*見出し　数字画像*/
.tel-application-available .wrap-contact-step .title-h3 span{
	position: relative;
	width: fit-content;
    margin: auto;
	padding-left: 2em;
}
.tel-application-available .wrap-contact-step .title-h3 span:before{
	content: "";
	position: absolute;
	bottom: 0;
	left: -5px;
	display: block;
	width: 35px;
    height: 35px;
	padding-left: 35px;
}

/*01 見出しの数字画像*/
.tel-application-available .wrap-tel-application .title-h3 span:before{
	background: url(/static/img/maas/mobi/kr001/lower-common/use-01.svg) no-repeat center / 100%;
}

/*02 見出しの数字画像*/
.tel-application-available .wrap-service-contact .title-h3 span:before{
	width: 42px;
    height: 35px;
	background: url(/static/img/maas/mobi/kr001/lower-common/use-02.svg) no-repeat center / 100%;
}

@media (max-width: 767px) {
	/*大見出し*/
	.tel-application-available .title-h2{
		font-size: 24px;
	}
}


/* 01 電話申込
-------------------------------------*/
/*liの中に、さらにulがある場合*/
.wrap-contact-step ul.inner-list li{
	font-size: 16px;
	font-weight: normal;
}


/* 02 サービスに関するお問い合わせをご希望の方
-------------------------------------------*/
/*注意テキスト*/
.wrap-contact-step .attention-text{
	margin: 20px 0 0;
}

/*ボタン*/
.Contact .link-btn{
	max-width: 563px;
	font-size: 22px;
	padding: 26px;
	border: solid 2px #E45458;
	border-radius: 10px;
	margin-bottom: 50px;
}
.Contact .link-btn:before{
	display: none;
}

/*黒*/
.Contact .link-btn.bg-black{
	border: none;
	padding: 27px 16px;
}
.Contact .link-btn.bg-black:before{
	display: block;
}

/*お客様お問い合わせ/領収書発行のお問い合わせ*/
.Contact .wrap-btn .wrap-inner{
	display: flex;
	justify-content: center;
	align-items: center;
}

.Contact .wrap-btn .wrap-inner a:first-of-type{
	margin-right: 15px;
}


/*利用規約*/
.Contact .link-btn.other-tab2{
    max-width: 371px;
    font-size: 16px;
    padding: 20px;
	background: #fff;
	color: #232323;
	border: solid 3px #232323;
}
.Contact .link-btn.other-tab2:before {
    color: #232323;
	right: 1em;
}

@media (max-width: 767px) {
	.Contact .link-btn{
		font-size: 18px;
		padding: 10px;
		margin-bottom: 30px;
	}
	.Contact .link-btn.bg-black{
		padding: 10px 30px;
	}
	/*お客様お問い合わせ/領収書発行のお問い合わせ*/
	.Contact .wrap-btn .wrap-inner{
		display: block;
	}
	/*利用規約*/
	.Contact .link-btn.other-tab2{
		border: solid 2px #232323;
	}
}


/*---------------------------------
	固定ボタン
----------------------------------*/
.fixed-btn{
	position: fixed;
	right: 0;
	bottom: 0;
	z-index: 2;
	background: rgba(255,255,255,0.7);
	padding: 20px 30px;
	text-align: center;
	width: 100%;
}

.fixed-btn .link-btn{
	max-width: 304px;
	font-size: 20px;
	padding: 29px 30px 30px 29px;
	margin: 0 0 0 auto;
}

.fixed-btn .link-btn:before{
	display: none;
}


@media (max-width: 767px) {
	.fixed-btn{
		left:0;
		margin: auto;
	}
	.fixed-btn .link-btn{
		font-size: 18px;
		padding: 10px;
		margin: 0 auto;
	}
}




/*------------------------------------------------
  タブ切り替え（オンデマンド運行/定時定路線）　下妻エリア
-------------------------------------------------*/
/* ナビより上の部分
-------------------------------------*/
#TabWrap > .wrap-inner{
	background: url(/static/img/maas/mobi/kr001/bg-repeat.png) top left; 
	padding: 65px 0 0;
}

#TabWrap > .wrap-inner .wrap-intro{
	margin: auto;
	text-align: center;
	font-weight: bold;
}

#TabWrap > .wrap-inner .intro-text{
	font-size: 18px;
}

#TabWrap > .wrap-inner .wrap-time{
	background: #fff;
	border: solid 2px #232323;
	max-width: 563px;
	width: 100%;
	padding: 20px;
	margin: 30px auto 40px;
}

@media(max-width:767px) {
	#TabWrap > .wrap-inner{
		padding: 40px 0 0;
	}
	
	#TabWrap > .wrap-inner .intro-text{
		font-size: 16px;
	}
	
	#TabWrap > .wrap-inner .wrap-time{
		margin: 20px auto 30px;
	}
}



/* ナビ以下
-------------------------------------*/
/*ナビ全体*/
.tab-nav-wrap { 
	max-width: 755px;
	margin: 0 auto;
	padding: 0 15px;
} 
/*ナビ*/
ul.nav-area{
	width: 100%;
	border: none;
	border-radius: 10px;
	background: #232323;
	padding: 10px 0;
}
/*各ナビ*/
li.nav-item{
	display: flex;
	flex: 1;/*幅　均等割り当て*/
	width: 100%;
    max-width: 380px;
	text-align: center;
}
/*中央の線*/
li.nav-item:nth-of-type(1){
	border-right: solid 1px #fff;
}

/*選択外のナビのデザイン*/
.nav-area a.nav-link,
.nav-area > li.nav-item a.nav-link:hover{
	display: flex;
	justify-content: center;
	align-items: center;
	font-weight: bold;
    border-radius: 10px;
	width: 100%;
	color: #fff;
    background: transparent;
	border: none;
	font-size: 20px;
	padding: 15px;
	opacity: 1;
	margin: 0 10px;
}

/*アクティブ(選択中)のナビ*/
.nav-area > li.nav-item a.nav-link.active{
	background: #fff;
	color: #232323;
	border: none;
}


@media(max-width:767px) {
	/*ナビのデザイン*/
	.nav-area a.nav-link,
	.nav-area > li.nav-item a.nav-link:hover,
	.nav-area > li.nav-item a.nav-link.active{
		font-size: 15px;
		padding: 10px 7px;
	}
}


/* タブ内　定時定路線
-------------------------------------*/
/*定時定路線運行時*/
#Area02 .Area .area-item .time-wrap{
	padding-bottom: 40px;
}

/*車両について*/
#Area02 .Area .wrap-about-car{
	margin-top: 60px;
}


/*運賃表*/
#Area02 .Fare .wrap-btn {
	display: flex;
	justify-content: center;
}
#Area02 .Fare .wrap-btn .link-btn{
	font-size: 20px;
	padding-right: 40px;
}

@media(max-width:767px) {
	#Area02 .Area .wrap-about-car img{
		max-width: 90%;
	}
	
	#Area02 .Fare .wrap-btn .link-btn{
		padding: 14px 30px 14px 10px;
		margin-right: 5px;
		font-size: 14px;
	}
	#Area02 .Fare .wrap-btn .link-btn:last-of-type{
		margin-right: 0px;
	}
}


/*定時定路線利用方法*/
#Area02 .Contact .wrap-contact-step{
	margin: 0 auto;
}

#Area02 .Contact .wrap-attention {
	text-align: left;
	margin: 20px 0 0;
}



/*------------------------------------------------
  バナー　乗車モニター募集（つくば）
-------------------------------------------------*/
.wrap-bnr-monitor{
	text-align: center;
	margin: 0 auto 40px;
	padding: 0 25px;
}
.wrap-bnr-monitor a:hover{
	opacity: 0.8;
	transition: 0.3s;
}


/*------------------------------------------------
  一時的にクローズ対応
-------------------------------------------------*/
/*20250114公開までクローズ　
※公開時は以下css消すだけでOK（リンク等もcssで無効化中）
------------------------------------------------*/
/*
.display-off-0114on{
	position: relative;
	margin-top: 100px;
}
*/

/*注意書き*/
/*
.display-off-0114on:after{
	content: "※1/14からお問い合わせ開始";
	display: block;
	font-size: 18px;
	font-weight: bold;
	color: #B80E0B;
	position: absolute;
	top: -50px;
	left: 0;
	right: 0;
	margin: auto;
	text-align: center;
}
*/

/*下妻と牛久のみ　「自宅登録方法はこちら」ボタン*/
/*
.wrap-home-registration .display-off-0114on:after{
	content: "※1/14から開始";
}
*/


/*クリック無効*/
/*
.display-off-0114on a{
	pointer-events: none!important;
	filter: brightness(0.5);!important;
	margin-top: 100px;
}
*/



/*20250127公開までクローズ　
※公開時は以下css消すだけでOK（リンク等もcssで無効化中）
------------------------------------------------*/

/*共通
------------------------*/
/*a.display-off-0127on{
	pointer-events: none!important;
	filter: brightness(0.5);!important;
	position: relative;
}*/

/*注意書きテキスト*/
/*.wrap-flow-btn:after,
.wrap-appbtn:before,
a.display-off-0127on:after{
	content: "1月20日～26日はシステム上、WEB申込可能ですが、\A試験運行中のため、ご利用いただけません。";
	white-space: pre;
	display: block;
	font-size: 14px;
	font-weight: bold;
	position: absolute;
	bottom: -37px;
	left: 0;
	right: 0;
	margin: auto;
	color: #999;
	line-height: 1.2;
}*/


/*QR画像非表示・comingsoonテキスト
------------------------*/
.display-off-0127on-qr{
	position: relative;
	border: none!important;
	margin: 80px auto 110px!important;
}
.display-off-0127on-qr:after{
	content: "coming soon";
	display: block;
	font-size: 18px;
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
}
.display-off-0127on-qr img{
	display: none;
}

/*アプリ
------------------------*/
.wrap-appbtn{
	position: relative;
}
.wrap-appbtn:before{
	font-size: 16px;
	top: -55px;
	color: #2B2B2B;
}
/*ボタン下の文言は削除*/
.wrap-appbtn a.display-off-0127on:after{
	content: "";
}


/*サービス利用の流れ
------------------------*/
.wrap-flow-btn{
	position: relative;
}
.wrap-flow-btn:after{
	color: #2B2B2B;
	text-align: center;
	font-size: 16px;
}
/*ボタン下の文言は削除*/
.wrap-flow-btn a.display-off-0127on:after{
	content: "";
}


/*固定ボタン
------------------------*/
.fixed-btn{
	padding: 20px 30px 40px;
}
/*固定ボタンはテキスト内容別*/
/*
.fixed-btn a.display-off-0127on:after{
	content: "※2025年1月27日より本格運行\A(1月20日よりWEB申込開始)";
}
*/


@media (max-width: 767px) {
	a.display-off-0127on:after{
		font-size: 11px;
		bottom: -32px;
	}
	
	.wrap-appbtn:before{
		font-size: 14px;
	}
	
	.wrap-flow-btn:after{
		font-size: 13px;
	}
}

/*NEWS
------------------------*/
.news-box {
    padding: 20px 30px;
    background: #fffdf6;
    border: solid 3px #da4453;
	margin: -40px auto 40px;
}
.news-box p {
    font-size: 18px;
    line-height: 1.6;
    margin: 0;
    color: #da4453;
}
.news-box p .label-news {
    background: #da4453;
    color: #fff;
    font-size: 105%;
    display: inline-block;
    padding:  6px 8px;
    border-radius: 4px;
    position: relative;
    top: -2px;
	font-weight: bold;
	margin-bottom: 8px;

}

@media (max-width: 767px) {
	.news-box {
	margin: -20px auto 40px;
	    padding: 20px;	
	}
	.news-box p {
	font-size: 16px;
	}
}

/*btn
------------------------*/

.btn-recruit {
    max-width: 450px;
    margin: 10px auto 20px;
    text-align: center;
    padding: 16px 12px;
    text-decoration: none;
    border: 2px solid #634c0b;
    display: block;
    transition: 0.3s;
    position: relative;
    background: #ffd43b;
    color: #1c1c1c;
    border-radius: 50px;
    box-shadow: 0px 3px #634c0b;
    font-size: 18px;
    font-weight: 700;
    animation: anim 2s 
ease-out infinite;
}
@keyframes anim {
  0%, 40%, 60%, 80% {
    transform: scale(1.0);
  }
  50%, 70% {
    transform: scale(0.95);
  }
}
.btn-recruit::after {
    content: "\f24d";
    position: absolute;
    font-family: "font awesome 5 free";
    top: 18px;
    right: 16px;
}

@media (max-width: 560px) {
 .btn-recruit {
        max-width: 330px;
        font-size: 14px;
        padding: 12px 10px;
    }
	.btn-recruit::after {
    top: 12px;
    right: 12px;		
}
}


/*oshirase-modal
------------------------*/

.oshirase-modal .modal-header{
	background: #232323;
	color: #fff;
	font-weight: bold;
	font-size: 18px;
}

.oshirase-modal .btn-close{
	border-radius: 6px;
	padding: 6px 16px;
	font-size: 14px;
	border: 1px solid #AAA;
	color:#222;
}

