@charset "utf-8";

/*共通ブロック*/
.layout-01{
  padding: 60px 0;
}
/*.layout-01 + .layout-01{
  padding-top: 0;
}*/
#Busprice.layout-01{
  padding: 0 0 60px 0;
}
@media(min-width:767px) {
.layout-01{
  padding: 80px 0;
}
/*.layout-01 + .layout-01{
  padding-top: 0;
}*/
}


/* パーツ */
.coler-white{
	color: #fff;
}


/*タイトル・見出しの設定*/
.section-header{
  padding: 0 15px;
  text-align: center;
}
#Campaign .section-header{
	position: relative;
	z-index: 2;
	padding-top: 20px;
}
#Campaign .section-header:before{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	content: "";
	height: 80px;
	background: #E2F5F7;
	z-index: 1;
}
#Busprice .section-header{
  background: #e2f5f7;
  padding-top: 60px;
  padding-bottom: 40px;
}
.title-base-01{
  font-size: 18px;
  font-weight: bold;
}
#Campaign .title-base-01 img{
	zoom: 0.5;
	position: relative;
	z-index: 2;
}
.section-header p{
	text-align: left;
  font-size: 14px;
}
.section-header h2 + p{
  margin-top: 10px;
}
.title-img{
	text-align: center;
	margin-bottom: 10px;
}
.title-img img{
	zoom:0.25;
}
.wrap-1point{
	margin-bottom: 40px;
	width: 100%;
	max-width: 760px;
	margin-left: auto;
	margin-right: auto;
}
.title-point-img{
	text-align: center;
	margin-bottom: -15px;
}
.title-point-img img{
	zoom:0.25;
}
.list-1point{
	background: #fff;
	padding: 30px 20px 20px;
	border-radius: 10px;
}
.list-1point > li{
	position: relative;
	padding-left: 35px;
}
.list-1point > li + li{
	margin-top: 8px;
}
.list-1point > li img{
	width: 25px;
	position: absolute;
	top: -2px;
	left: 0;
}

#Busprice .wrap-departure-arrival {
    width: 100%;
    padding: 0;
    margin: 10px auto 0;
    display: block;
}
#Busprice .wrap-departure-arrival .search-text{
    font-size: 14px;
    font-weight: bold;
}
@media(min-width:767px) {
.section-header{
}
#Busprice .section-header{
	padding-top: 80px;
}
.title-base-01{
  font-size: 26px;
}
.section-header p{
  font-size: 18px;
	text-align: center;
}
.section-header h2 + p{
  margin-top: 15px;
}
.title-point-img{
	margin-bottom: -25px;
}
.list-1point{
	padding: 40px 30px 30px;
}
#Campaign .section-header{
	position: relative;
	z-index: 2;
	padding-top: 40px;
}
#Campaign .section-header:before{
	height: 143px;
}
}



#Hero{
	background: url(/static/img/campaign/summer/bg.jpg) no-repeat center center;
	background-size: cover;
}
#Hero h1{
	text-align: center;
	padding: 10px;
}
@media(min-width:767px) {
#Hero h1{
	padding: 20px 0;
}
#Hero h1 img{
	zoom:0.8;
}
}

/*ページ内リンク*/
#Pagenavi{
	background: #2caad9;
	padding: 30px 0;
}
.lead-pagenavi{
	font-size: 16px;
	color: #fff;
}
.lead-pagenavi b{
	font-size: 110%;
}
.nav-pagenavi{
	display: flex;
	margin-top: 30px;
	flex-wrap: wrap;
	justify-content: center;
}
.nav-pagenavi > li{
	width: 55%;
	padding:5px 0 5px 16px;
}

.nav-pagenavi > li:first-child{
	width: 45%;
	padding-left: 0;
}
.nav-pagenavi > li:last-child{
	width: 50%;
	padding: 5px;
}

.nav-pagenavi > li a{
	display: flex;
	background: #fff;
	color: #2caad9;
	align-items: center;
	justify-content: center;
	border-radius: 100px;
	padding: 15px 20px;
	position: relative;
	font-size: 14px;
	font-weight: bold;
}
.nav-pagenavi > li a:before {
	content: "\f13a";
	font-family: "Font Awesome 5 Free";
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	right: 5px;
	font-weight: bold;
}
.nav-pagenavi > li a:hover{
	text-decoration: none;
	background: #fef24f;
}
@media(min-width:767px) {
#Pagenavi{
	padding: 40px 0;
}
.lead-pagenavi{
	font-size: 18px;
	text-align: center;
}
.nav-pagenavi > li{
	width: 33.333%!important;
	padding: 0 10px;
}
.nav-pagenavi > li a{
	padding: 25px 5px;
	font-size: 18px;
}
.nav-pagenavi > li a:before {
	right: 15px;
}
}



/*最安値*/
#Busprice{
	background: #f8fdfd;
}
.table-responsive{
	width: 100%;
	max-width: 760px;
	margin-left: auto;
	margin-right: auto;
}
.side-price-list thead th{
	border-top: none;
	border-bottom: 2px solid #111;
	text-align: center;
}
.side-price-list thead th.this_month:after,
.side-price-list thead th.next_month:after,
.side-price-list thead th.after_2months:after{
	content: "出発";
}
.side-price-list td, .side-price-list th{
	font-size: 14px;
	vertical-align: middle;
	border-bottom: 1px solid #111;
	text-align: center;
}
.side-price-list td.route_title{
	font-size: 12px;
	text-align: left;
}
.side-price-list td a{
	color: #FF6C6C;
	font-weight: bold;
}
.side-price-list td a:before{
	content: "￥";
	font-size: 80%;
}
.side-price-list td.route_title a{
	color: #111;
	font-weight: normal;
}
.side-price-list td.route_title a:before{
	display: none;
}

.next_month{
	background: #fef24f;
}


@media(min-width:767px) {
.side-price-list td, .side-price-list th{
	font-size: 20px;
}
.side-price-list td.route_title{
	font-size: 16px;
	text-align: center;
}
}




/*テーマから探す*/
#Spot{
	background: #58c7e2;
}
.box-themenavi{
	margin-bottom: 30px;
}
.nav-themenavi{
	display: flex;
	justify-content: center;
	margin-top: 30px;
	flex-wrap: wrap;
}
.nav-themenavi > li{
	width: 50%;
	padding: 5px 5px;
}
.nav-themenavi > li a{
	display: flex;
	background: #fff;
	color: #2caad9;
	align-items: center;
	justify-content: center;
	border-radius: 100px;
	padding: 15px 20px 15px 30px;
	position: relative;
	font-size: 13px;
	font-weight: bold;
}
.nav-themenavi > li a:before {
	content: "\f13a";
	font-family: "Font Awesome 5 Free";
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	right: 5px;
	font-weight: bold;
}
.nav-themenavi > li a:hover{
	text-decoration: none;
	background: #fef24f;
}
.box-theme{
	padding: 30px 0;
}
.title-theme{
	line-height: 1;
	text-align: center;
	margin-bottom: 40px;
}
.title-theme span{
	border-top: 2px solid #fff;
	border-bottom: 2px solid #fff;
	padding: 10px 10px;
	font-size: 18px;
	font-weight: bold;
	display: inline-block;
	color: #fff;
	width: 200px;
}
.title-theme span img{
	width: 100%;
	max-width: 50px;
	margin-right: 10px;
	position: relative;
	top: -5px;
}
@media(min-width:767px) {
#Pickup .box-themenavi{
	margin-bottom: 60px;
	width: 100%;
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
}
.nav-themenavi > li{
	padding: 5px 10px;
}
.nav-themenavi > li a{
	padding: 25px 5px;
	font-size: 18px;
}
.nav-themenavi > li a:before {
	right: 15px;
}
.title-theme span{
	font-size: 20px;
}
}
@media(min-width:1200px) {
#Pickup .box-themenavi{
	margin-bottom: 60px;
	width: 100%;
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
}
.nav-themenavi{
	justify-content: space-between;
	flex-wrap: nowrap;
}
.nav-themenavi > li{
	width: 100%;
	padding: 5px 10px;
}
.nav-themenavi > li a{
	padding: 25px 10px;
	font-size: 16px;
}
}

.slider-box{
  padding: 0 0 0 5px;
}
.slider-container{
  padding-left: 10px;
}
.slider-box-01{
  overflow-x: scroll;
  padding-bottom: 10px;
}
.slider-plan-01{
  width: 277%;/*260px x 4 = 1040 ⇒ 1040/375 =277 */
  display: flex;
  padding-bottom: 5px;
}
.slider-plan-01.ver-1{
  width: 69.3%;/*260px x 1 = 260 ⇒ 520/375 =69.3 */
  display: flex;
  padding-bottom: 5px;
}
.slider-plan-01.ver-2{
  width: 138%;/*260px x 2 = 1040 ⇒ 520/375 =138 */
  display: flex;
  padding-bottom: 5px;
}
.slider-plan-01.ver-3{
  width: 208%;/*260px x 3 = 780 ⇒ 780/375 =208 */
  width: 214%;/*段*/
}
.slider-plan-01.ver-5{
  width: 346%;/*260px x 5 = 1300 ⇒ 1300/375 =346 */
}
.slider-plan-01.ver-6{
  width: 470%;
}
.slider-plan-01.ver-8{
  width: 392.3%;
}
.slider-plan-01 > li{
  padding: 0 5px;
  display: flex;
  width: 25%;/*260px*/
}
.slider-plan-01.ver-1 > li{
  padding: 0 5px;
  display: flex;
  width: 100%;
}
.slider-plan-01.ver-2 > li{
  padding: 0 5px;
  display: flex;
  width: 50%;
}
.slider-plan-01.ver-3 > li{
  padding: 0 5px;
  display: flex;
  width: 33.33%;
}
.slider-plan-01.ver-5 > li{
  padding: 0 5px;
  display: flex;
  width: 20%;
}
.slider-plan-01.ver-6 > li{
  padding: 0 5px;
  display: flex;
  width: 20%;
}
@media(min-width:576px) {
.slider-plan-01{
  width: 155.9%;
}
.slider-plan-01.ver-1{
  width: 100%;
}
.slider-plan-01.ver-2{
  width: 100%;
}
.slider-plan-01.ver-3{
  width: 116.9%;
}
.slider-plan-01.ver-5{
  width: 194.6%;
}
.slider-plan-01.ver-6{
  width: 346.6%;
}
.slider-plan-01.ver-1 > li{
  width: 40%;
}
}
@media(min-width:767px) {
.slider-plan-01{
  width: 100%;
  flex-wrap: wrap;
}
.slider-plan-01.ver-3{
  width: 100%;
  flex-wrap: wrap;
  justify-content: center;
}
.slider-plan-01.ver-5,
 .slider-plan-01.ver-6 {
  width: 100%;
  flex-wrap: wrap;
  justify-content: center;
}
.slider-plan-01 > li,
.slider-plan-01.ver-1 > li,
.slider-plan-01.ver-2 > li,
.slider-plan-01.ver-3 > li,
.slider-plan-01.ver-5 > li,
.slider-plan-01.ver-6 > li{
  width: 50%;/* 205 */
  padding: 5px 5px;
}
}
@media(min-width:992px) {
.slider-box-01{
  overflow-x: initial;
  padding-bottom: 0;
}
.slider-plan-01{
  width: 100%;
  max-width: 860px;
  margin-right: auto;
  margin-left: auto;
  flex-wrap: wrap;
}
.slider-plan-01 > li{
  width: 50%;/* 274 */
  padding: 5px 5px;
}
}




#Willercolle{
	background: #e2f5f7;
}
.slider-willercolle-01{
}
.slider-willercolle-01 > li + li{
	margin-top: 10px;
}
.card-article{
	background: #fff;
	padding: 10px;
	display: flex;
	color: #1c1c1c;
}
.card-article:hover{
  text-decoration: none;
  background: #fff3f7;
	color: #1c1c1c;
}
.card-article img{
	width: 100%;
	max-width: 80px;
}
.article-title{
	width: calc(100% - 80px);
	padding-left: 10px;
	font-size: 14px;
}
@media(min-width:767px) {
.slider-willercolle-01{
  width: 100%;
  display: flex;
  flex-wrap: wrap;
}
.slider-willercolle-01 > li{
  padding: 5px 5px;
  width: 25%;
}
.slider-willercolle-01 > li + li{
	margin-top: 0;
}
.card-article{
	display: block;
}
.card-article img{
	width: 100%;
	max-width: 100%;
}
.article-title{
	width: 100%;
	padding: 10px 10px 0;
}
}


/*プランの掲載*/
.card-plan{
  display: block;
  background: #fff;
  color: #111111;
  padding: 10px;
  overflow: hidden;
  width: 100%;
}
.dl-plan{
  padding: 10px 0;
}
.dt-planname{
  font-size: 14px;
  font-weight: bold;
  margin-bottom: 5px;
}
.dd-plantext{
  font-size: 10px;
}
.plan-price{
  font-size: 13px;
  padding: 10px;
  font-weight: bold;
  background: #fafafa;
	text-align: center;
}
.plan-price b.txt-start{
	border-bottom: #339EB8 3px solid;
	margin-bottom: 10px;
	display: inline-block;
	width: 100px;
}

.modal-body .plan-price{
	padding: 0;
	background: none;
}
.plan-price > b{
  display: block;
  width: 100%;
  font-size: 12px;
}
.list-price{
	background: #fff;
	padding: 10px;
	margin-top: 5px;
}
.list-price > li,
.list-price > li > span {
	font-size: 11px;
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}
.list-price > li > span {
    width: 100%;
}
.list-price > li a:hover{
	color: #FF6C6C;
}
.list-price > li b{
    text-align: left;
}
.plan-price .num{
  color: #FF6C6C;
}
.plan-price .num:after{
  content: "円～";
  font-size: 10px;
}
.plan-price .num.min:after{
  content: "～";
}
.plan-price .num.min.only:after{
  content: "円～";
}
.plan-price .num.max:after{
  content: "円";
}
.nav-reservenavi{
	margin-top: 15px;
}
.nav-reservenavi > li{
	width: 100%;
}
.nav-reservenavi > li + li{
	margin-top: 10px;
}
.nav-reservenavi > li a,
.nav-reservenavi > li button {
	display: block;
	background: #fef24f;
	color: #1c1c1c;
	border:solid 2px #1c1c1c;
	border-radius: 100px;
	padding: 10px 5px;
	text-align: center;
	font-size: 14px;
	position: relative;
	font-weight: bold;
}

.nav-reservenavi > li button {
    display: block;
    width: 100%;
}

.nav-reservenavi > li a:before,
.nav-reservenavi > li button:before {
	content: "\f138";
	font-family: "Font Awesome 5 Free";
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	right: 5px;
	font-weight: bold;
}
.nav-reservenavi > li a.add-window:before{
	content: "\f24d" !important;
	font-weight: normal;
}
.nav-reservenavi > li a:hover,
.nav-reservenavi > li button:hover {
	text-decoration: none;
	background: #1c1c1c;
	color: #fef24f;
}
.nav-reservenavi > li button:focus,
.nav-reservenavi > li button:active {
    background: #000;
    border-color: none;
    color: #fef24f;
}

.nav-reservenavi > li span.btn-end{
	display: block;
	background: #eee;
	color: #1c1c1c;
	border-radius: 100px;
	padding: 10px 5px;
	text-align: center;
	font-size: 14px;
	position: relative;
	font-weight: bold;
}
.link-text{
	font-size: 14px;
	color: #4CA9E8;
}
.link-text:after {
	content: "\f138";
	font-family: "Font Awesome 5 Free";
	margin-left: 3px;
	font-weight: bold;
}

.text-recommend{
	text-align: center;
	font-size: 13px;
	position: relative;
	text-align: center;
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 0;
	margin-bottom: 5px;
	font-weight: 900;
}
.text-recommend span{
    padding: 0 10px;
}
.text-recommend:before,
.text-recommend:after{
    content: "";
    display: inline-block;
    width: 3px;
    height: 16px;
    background: #000;
    border-radius: 2px;
}
.text-recommend:before{
    -webkit-transform: rotate(-30deg);
    -ms-transform: rotate(-30deg);
    transform: rotate(-30deg);
}
.text-recommend:after{
    -webkit-transform: rotate(30deg);
    -ms-transform: rotate(30deg);
    transform: rotate(30deg);
}



@media(min-width:767px) {
.dl-plan{
  padding: 20px 0;
}
.dt-planname{
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 10px;
}
.dd-plantext{
  font-size: 14px;
}
.plan-price{
	width: 100%;
  font-size: 16px;
  margin-top: 10px;
}
.plan-price b{
  display: inline-block;
  width: auto;
  margin-right: 5px;
	font-size: 12px;
}
.list-price > li b{
    text-align: center;
}
.plan-price .num{
  font-size: 16px;
}
.plan-price .num:after{
  font-size: 14px;
}
.nav-reservenavi{
	display: flex;
	justify-content: center;
}
.nav-reservenavi > li a,
.nav-reservenavi > li button {
	font-size: 16px;
}
.nav-reservenavi > li{
	padding: 0 5px;
}
.nav-reservenavi > li + li{
	margin-top:0;
}
}
@media(min-width:991px) {

	.plan-price b{
		font-size: 14px;
	}

}



#Faq{
   background: #fafafa;
}
#faq-accordion{
   width: 100%;
   max-width: 960px;
   margin-left: auto;
   margin-right: auto;
   counter-reset:renban;
}
.card-faq{
   position: relative;
   min-width: 0;
   word-wrap: break-word;
   background-color: #fff;
   background-clip: border-box;
   border-radius: 4px;
   box-shadow: 0px 0px 3px 1px rgb(0 0 0 / 10%);
}
.card-faq + .card-faq{
   margin-top: 10px;
}
.card-faq-header{
   padding: 0;
   margin-bottom: 0;
}
.card-faq-header button{
   display:block;
   padding:15px 70px 15px 80px;
   position: relative;
   color:#333;
   background:#fff;
   border-radius: 4px;
   width: 100%;
   text-align: left;
   cursor: pointer;
}
.card-faq-header button:hover{
   cursor:pointer;
   background:#feebf2;
   opacity:1.0;
   text-decoration:none;
}
.card-faq-header button:after{
   position: absolute;
   top: 50%;
   -webkit-transform: translateY(-50%);
   transform: translateY(-50%);
   right: 20px;
   font-size: 18px;
   content: "\f077";
   font-family: "Font Awesome 5 Free";
   font-weight:900;
   color:#1C1C1C;
   background: #FFD545;
   width: 45px;
   height: 45px;
   display: flex;
   justify-content: center;
   align-items: center;
   line-height: 1;
   border-radius: 100px;
}
.card-faq .card-faq-header button:before{
   counter-increment:renban;
   content:"Q"counter(renban) ;
   color: #fff;
   font-size: 20px;
   font-weight: bold;
   background: #333;
   width: 45px;
   height: 45px;
   display: flex;
   justify-content: center;
   align-items: center;
   line-height: 1;
   border-radius: 100px;
   position: absolute;
   top: 50%;
   -webkit-transform: translateY(-50%);
   transform: translateY(-50%);
   left: 20px;
}
.card-faq-header button.collapsed:after{
   content: "\f078";
}
.card-faq-ttl{
   font-size:14px;
   line-height:1.4;
   display: block;
}
.card-faq-body{
   padding:15px;
}
.card-faq-body p{
   font-size:14px;
   line-height:1.8;
   color:#333;
   margin-left:5px;
}
.card-faq-body p + p{
   margin-top:10px;
}
@media(min-width:767px) {
.card-faq-header button{
   padding:25px 70px 25px 80px;
}
.card-faq-ttl{
   font-size:18px;
}
}



/*ピックアップから探す*/
#Pickup{
	background: #E2F5F7;
}
#Pickup .title-theme span{
    border-top: 2px solid #2caad9;
    border-bottom: 2px solid #2caad9;
    color: #2caad9;
}
.col-pickup + .col-pickup{
	margin-top: 20px;
}
.wrap-plan{
	background: #fff;
	padding: 20px 0;
	border-radius: 10px;
	overflow: hidden;
	border: #1C1C1C solid 4px;
}
.wrap-plan-thum{
	padding: 20px;
}
#usj .wrap-plan-thum,#tdr .wrap-plan-thum{
	padding: 20px 20px 0;
}

.wrap-plan-txt{
	padding: 0 20px;
}

.title-pickupplan{
	font-size: 16px;
	font-weight: bold;
	line-height: 1.6;
	text-align: center;
	background: #339EB8;
	color: #fff;
	padding: 15px 5px 10px 5px;
	width: 100%;
}
.dl-deplist{
	font-size: 13px;
	margin:10px 0;
}
.dl-deplist dt{
	width: 110px;
	color: #fff;
	background: #339EB8;
	text-align: center;
	padding: 4px 0;
	border-radius: 20px;
	margin-bottom: 4px;
}
.dl-deplist dd{
	width: calc(100% - 0);
	line-height: 1.6;
}
#restaurantbus .dl-deplist dt{
	width: 110px;
	color: #339EB8;
}txt-plan
#restaurantbus .dl-deplist dd{
	width: calc(100% - 110px);
	padding-left: 10px;
}
.wrap-corde-plan{
	margin-top: 5px;
	background: #f8fdfd;
	padding: 5px;
	border-radius:4px;
}
/*.wrap-corde-plan img{
	width: 100%;
	max-width: 110px;
}*/
.wrap-corde-plan p{
	font-size: 13px;
	font-weight: bold;
	color: #2caad9;
	margin-bottom: 5px;
}
.list-price.list-dep-pickup{
	padding: 0;
	background: none;
	margin-top: 5px;
}
.list-price.list-dep-pickup > li{
	width: 100%;
	display: block;
}
.list-price.list-dep-pickup > li + li{
	margin-top: 10px;
}
.list-price.list-dep-pickup a,
.list-price.list-dep-pickup button{
	display: flex;
	justify-content: space-between;
	align-items: center;
	background: #fff;
	padding: 15px 35px 15px 20px;
	width: 100%;
	border:solid 2px #333;
	border-radius: 100px;
	position: relative;
	color: #1a1a1a;
	font-size: 13px;
	cursor: pointer;
}
.list-price.list-dep-pickup button{
	font-weight: bold;
}
.list-price.list-dep-pickup a:hover,
.list-price.list-dep-pickup button:hover{
	text-decoration: none;
}
.list-price.list-dep-pickup a:hover b,
.list-price.list-dep-pickup button:hover b{
	color: #1a1a1a;
	text-decoration: none;
}
.list-price.list-dep-pickup a:before,
.list-price.list-dep-pickup button:before{
	content: "\f138";
	font-family: "Font Awesome 5 Free";
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	right: 10px;
	font-weight: bold;
}
.list-price.list-dep-pickup a.add-window:before,
.list-price.list-dep-pickup button.add-window:before{
	content: "\f24d" !important;
	font-weight: normal;
}
.modal-body .list-price.list-dep-pickup a{
	display: block;
	padding: 10px 25px 5px 20px;
}
.modal-body .list-price.list-dep-pickup a .wrap-price{
	display: block;
	margin-top: 0;
	text-align: right;
	font-size: 140%;
}
.modal-footer{
	text-align: center;
	padding: 10px;
}
.modal-footer button{
	display: inline-block;
	padding: 10px 15px;
	background: #333;
	border-radius: 4px;
	cursor: pointer;
    margin: auto;
    background: #eee;
    color: #1c1c1c;
    border: 1px solid #bbb;
}
.wrap-corde{
	background: #f8fdfd;
	padding: 10px;
	margin-top: 20px;
	border-radius: 8px;
}
.title-corde{
	text-align: center;
	margin-bottom: 10px;
	color: #2caad9;
}
.title-restaurant-area{
	width: 100%;
	margin-bottom: 0;
	margin-top: 10px;
	font-weight: bold;
	font-size: 14px;
	color: #FF6C6C;
}
.txt-link-r{
	width: 98%!important;
}

.txt-plan{
	font-size: 1.1em;
	color: #2caad9;
	font-weight: bold;
	
}

@media(min-width:767px) {
.title-pickupplan{
	margin-bottom: 30px;
}
.row-pickup{
/*	display: flex;*/
	width: 100%;
	max-width: 900px;
	margin-left: auto;
	margin-right: auto;
/*	justify-content: space-between;*/
}
.wrap-corde-plan{
	margin-top: 5px;
	background: #f8fdfd;
	padding: 10px;
	border-radius:4px;
	width: 100%;
}
.wrap-corde-plan p{

	text-align: center;
}
.wrap-plan{
	display: flex;
	flex-wrap: wrap;
}
.wrap-plan-thum{
	width: 35%;
	padding:0 0 0 30px;
	
}
.wrap-plan-txt{
	width: 65%;
	padding-left: 20px;
	padding-right: 30px
}
#restaurantbus .wrap-plan-thum{
	width: 35%;
}
#restaurantbus .wrap-plan-txt{
	width: 65%;
}
.wrap-plan .list-price.list-dep-pickup{
	display: flex;
	flex-wrap: wrap;
	margin: 0 auto;
	max-width: 780px;
	
}
.wrap-plan .list-price.list-dep-pickup > li{
	width: 50%;
	display: flex;
	padding: 5px;
}
.wrap-plan .list-price.list-dep-pickup > li button{
	display: flex;
}
.wrap-plan .list-price.list-dep-pickup > li + li{
	margin-top: 0px;
}
.modal-body .list-price.list-dep-pickup a{
	padding: 10px 45px 5px 40px;
}
.title-restaurant-area{
	width: 100%;
}
}

.modal-header{
	background: #339EB8;
}
.title-modal{
	color: #fff;
}

.youtube {
  width: 100%;
  aspect-ratio: 16 / 9;
}
.youtube iframe {
  width: 100%;
  height: 100%;
}



/*キャンペーン用路線*/
#Campaign{
	background: #58C7E2;
	padding-top: 0;
}
.wrap-pickupbus{
	width: 100%;
	max-width: 860px;
	margin:0 auto;
}
.list-rosen{
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	align-items: center;
}
.list-rosen + .list-rosen{
	margin-top: 25px;
}
.li-name{
	width: 50%;
	font-size: 16px;
	font-weight: bold;
}
.li-price{
	width: 50%;
	text-align: right;
	font-size: 20px;
	color: #FF6C6C;
	font-weight: bold;
}
.li-price span:after{
	content: "円～";
	font-size:18px;
}
.li-btn{
	width: 100%;
	margin-top: 5px;
}
.list-btn-reserve{
	display: flex;
}
.list-btn-reserve > li{
	width: 100%;
	padding: 0 5px;
}
.list-btn-reserve > li + li{
	margin-top: 0;
}
.list-btn-reserve > li a{
	display: block;
	background: #fef24f;
	color: #1c1c1c;
	border: solid 2px #1c1c1c;
	border-radius: 100px !important;
	font-size: 14px;
	padding: 10px 25px;
	border-radius: 5px;
	position: relative;
	text-align: center;
	font-weight: bold;
}
.list-btn-reserve > li a:before{
	content: "\f138";
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	position: absolute;
	top: 50%;
	right: 5px;
	transform: translate(0, -50%);
}
.list-btn-reserve > li a:hover{
	text-decoration: none;
	background: #1c1c1c;
	color: #fef24f;
}

@media(min-width:767px) {
#Campaign{
	background: #58C7E2;
	padding-top: 0;
}
#Rosen{
	margin-top: 120px;
}
.list-rosen{
	padding: 15px 10px;
}
.list-rosen + .list-rosen{
	margin-top: 0;
	border-top: 2px dashed #ADADAD;
}
.li-name{
	width: 40%;
	font-size: 20px;
	font-weight: bold;
}
.li-price{
	width: 20%;
	text-align: right;
	font-size: 24px;
	color: #FF6C6C;
	font-weight: bold;
}
.li-price span:after{
	content: "円～";
	font-size:18px;
}
.li-btn{
	width: 40%;
	margin-top:0;
}

.list-btn-reserve > li a{
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1.3;
	padding: 10px 20px;
	border-radius: 100px;
	font-size: 16px;
}
}



.box-campaign{
	background: #fff;
	border:solid 5px #1C1C1C;
	border-radius: 60px;
	padding:30px 20px;
	margin:0 auto;
	width: 100%;
	max-width: 760px;
	position: relative;
	z-index: 2;
	overflow: hidden;
}
.lead-end-campaign{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.7);
	z-index: 5;
	display: flex;
	align-items: center;
	justify-content: center;
}
.lead-end-campaign span{
	font-size: 24px;
	color: #fff;
	font-weight: bold;
	text-align: center;
}
/*.box-campaign:before {
	border: 24px solid transparent;
	border-top: 24px solid #1C1C1C;
	left: 50%;
	content: "";
	display: block;
	bottom: -48px;
	transform: translate(-50%, 0);
	position: absolute;
	z-index: 1;
}
.box-campaign:after {
	border: 24px solid transparent;
	border-top: 24px solid #fff;
	left: 50%;
	content: "";
	display: block;
	bottom: -42px;
	transform: translate(-50%, 0);
	position: absolute;
	z-index: 3;
}*/
.lead-campaign-img{
	text-align: center;
	margin-bottom: 25px;
	position: relative;
	z-index: 3;
}
.lead-campaign-img img{
	zoom:0.3;
	margin:0 auto;
}
.lead-campaign-text{
	text-align: center;
	font-size: 13px;
}
.lead-campaign-text b{
	color: red;
}
.lead-campaign-text + .lead-campaign-text{
	margin-top: 10px;
}
.lead-campaign-text small{
	display: block;
	line-height: 1.4;
}
.dl-campaign{
	display: flex;
	width: 100%;
	max-width: 600px;
	margin:20px auto 0;
	align-items: flex-start;
}
.dl-campaign + .dl-campaign{
	margin-top: 5px;
}
.dl-campaign dt{
	background: #2CAAD9;
	color: #fff;
	border-radius: 100px;
	padding: 8px;
	font-size: 12px;
	line-height: 1;
	width: 110px;
	text-align: center;
}
.dl-campaign dd{
	width: calc(100% - 110px);
	padding-left: 10px;
	font-size: 12px;
}
.bg-kami-left{
	position: absolute;
	top: -5px;
	left: -15px;
}
.bg-kami-left img{
	zoom:0.4;
}
.bg-kami-right{
	position: absolute;
	top: -5px;
	right: -15px;
}
.bg-kami-right img{
	zoom:0.4;
}
@media(min-width:767px) {
.box-campaign{
	padding: 30px;
}
.lead-campaign-img img{
	zoom:0.5;
}
.lead-campaign-text{
	font-size: 14px;
}
.lead-campaign-text + .lead-campaign-text{
	margin-top: 15px;
}
.dl-campaign{
	margin:30px auto 0;
}
.dl-campaign dt{
	background: #2CAAD9;
	color: #fff;
	border-radius: 100px;
	padding: 8px;
	font-size: 14px;
	line-height: 1;
	width: 160px;
	text-align: center;
}
.dl-campaign dd{
	width: calc(100% - 160px);
	padding-left: 15px;
	font-size: 14px;
}
.bg-kami-left{
	position: absolute;
	top: 15px;
	left: 25px;
}
.bg-kami-left img{
	zoom:0.5;
}
.bg-kami-right{
	position: absolute;
	top: 15px;
	right: 25px;
}
.bg-kami-right img{
	zoom:0.5;
}
}

.btn-go-rosen{
	display:block;
	background: #fff;
	border:solid 1px #2caad9;
	color: #2caad9;
	text-align: center;
	border-radius: 100px;
	width: 100%;
	padding: 10px 25px;
	position: relative;
	font-size: 14px;
	margin-top: 8px;
	font-weight: bold;
}
.btn-go-rosen:hover{
	text-decoration: none;
	background: #fef24f;
}
.btn-go-rosen:before {
	content: "\f13a";
	font-family: "Font Awesome 5 Free";
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	right: 5px;
	font-weight: bold;
}



.lead-end-campaign{

}

/* calendar
-------------------------*/
.calendar-box {
  background: #2caad9;
  padding: 80px 32px 30px;
	position: relative;
}


.calendar-box::before{
    content: "";
    position: absolute;
    height: 55px;
    width: 178px;
    clip-path: polygon(50% 100%, 100% 0%, 0% 0%); /* ココ */
    background-color: #e2f5f7;
	margin: 0 auto;
	right: 0;
	left: 0;
    top: 0;
}



.calendar-list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  padding-bottom: 20px;
  margin:0 auto 16px;
	max-width: 700px;
	justify-content: center;
}

.calendar-item {
  width: 18%;
  background: var(--white);
  border-radius: 10px;
  overflow: hidden;
  padding-bottom: 4px;
}

.calendar-item .wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}

/* week */
.calendar-item .week {
  text-align: center;
  padding: 5px 10px;
  width: 100%;
}
.calendar-item .week img{
	height: 18px;
}

.calendar-item.gray .week {
  background: #BCBCBC;
}

.calendar-item.red .week {
  background: #D25252;
}

.calendar-item.blue .week {
  background: #0F5E9C;
}

/* num */
.calendar-item .num {
  text-align: center;
  padding: 8px 16px;
}
.calendar-item .num img{
	height: 40px;
}
/* price */
.calendar-item .price-num {
  display: flex;
  justify-content: center;
  align-items: baseline;
  border-top: 1px solid #eee;
  padding: 3px 0 0;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.4;
  color: #0F5E9C;
}

.calendar-item .price-en {
  font-size: 70%;
}

/* starあり*/
.calendar-item.star .num {
  position: relative;
}

.calendar-item.star .num::before {
  content: "";
  position: absolute;
  z-index: 2;
  top: 5px;
  right: 2px;
  width: 16px;
  height: 16px;
  display: inline-block;
  background: url("/static/img/campaign/summer/img-star.svg") no-repeat center
    center/100%;
}

.calendar-item.star .price-num {
  color: #FF6C6C;
}

@media (max-width: 1024px) {
  .calendar-item {
    width: 18%;
  }
}

@media (max-width: 767px) {
  .calendar-box {
    padding: 70px 22px 20px;
  }
  .calendar-item {
    width: 31%;
  }

  /* price */
  .calendar-item .price-num {
    padding: 6px 0 0;
    font-size: 13px;
  }
	
.calendar-item .week img{
	height: 14px;
}	
	
.calendar-item .num img{
	height: 30px;
}	
}

@media (max-width: 560px) {
  .calendar-item {
    width: 31%;
  }
    
  .price-button {
    width: 80%;
  }
    
  .price-button .button-link {
    padding: 16px;
  }
}

.attention-list {
	width: 420px;
	margin: 0 auto;
}
.attention-list li {
  position: relative;
  padding-left: 16px;
  font-size: 14px;
  color: var(--black);
  margin-bottom: 8px;
}

.attention-list li::before {
  content: "※";
  position: absolute;
  left: 0;
  font-size: 14px;
}

@media (max-width: 767px) {
	.attention-list {
	width: 100%;
	margin: 0;
}
    .attention-list li {
        font-size: 11px;
    }
}

/* price-box */
.price-box {
    margin: 40px auto;
}

@media (max-width: 767px) {
    .price-box {
        width: 100%;
    }
}


/* title-mid */
.title-mid {
  text-align: center;
  margin-bottom: 20px;
}

.title-mid span {
  font-weight: bold;
  font-size: 17px;
  color: #fff;
  position: relative;
}

.title-mid span::before,
.title-mid span::after {
position: relative;
  display: inline-block;
  content: "";
  background: #fff;
  width: 4px;
  height: 1.4em;
  margin: 0 1em;
  margin-top: -.2em;
  vertical-align: middle;
	border-radius: 20px;
}

.title-mid span::before {
transform: rotate(-35deg);
}
.title-mid span::after {
  transform: rotate(35deg);
}


@media (max-width: 767px) {
	.title-mid span {
		  font-size: 16px;
	}
}
/* timesale*/
.timesale{
	position: relative;
}
.timesale::after{
	position: absolute;
	content: ''; /*何も入れない*/
	top:5px;
	left: 15%;
	  width: 65px; /*画像の幅*/
  height:65px; /*画像の高さ*/
  background: url(/static/img/usj/2023/timesale_b.svg) no-repeat;
	background-size: contain;
}


.link-ancker.timesale::after{
  width: 60px; /*画像の幅*/
  height: 60px; /*画像の高さ*/
	left: 0;
	top:-25px;	
	
}

.timesale-label {
    position: absolute;
    top: 8px;
    left: 10px;
    background: #f5df61;
    padding: 5px 10px;
    border: 2px solid #000;
    border-radius: 3px;
    /*color: #d20100;*/
    color: #161616;
    font-size: 15px;
    font-weight: bold;
    text-align: center;
    display: flex;
    justify-content: center;
    width: 95%;
}
.timesale-label::after {
    content: '';
    position: absolute;
    top: -14px;
    right: 79px;
    display: inline-block;
    width: 40px;
    height: 40px;
    background: url(/static/img/campaign/summer/time-watch.svg) no-repeat center center / 100%;
    background-color: #fff;
    border-radius: 100%;
}


@media (max-width: 1020px) {
    .timesale-label::after {
        right: 25px;
    }
}


@media (max-width: 768px) {
    .timesale::after{
        position: absolute;
        content: ''; /*何も入れない*/
        top:-20px;
        left: 5px;
          width: 65px; /*画像の幅*/
      height:65px; /*画像の高さ*/
      background: url(/static/img/usj/2023/timesale_b.svg) no-repeat;
        background-size: contain;
    }
    .link-ancker.timesale::after{
       width: 45px; /*画像の幅*/
       height: 45px; /*画像の高さ*/
        left: -15px;
        top:-16px;	

    }	
}


@media (max-width: 767px) {
    .timesale-label::after {
        right: 27px;
    }
}

@media (max-width: 560px) {
    .timesale-label {
        font-size: 12px;
        padding: 5px 10px 3px;
    }
    .timesale-label::after {
        top: -8px;
        right: 12px;
        width: 30px;
        height: 30px;
    }
}

@media (max-width: 360px) {
	.timesale::after{
	 width: 50px; /*画像の幅*/
     height: 50px; /*画像の高さ*/	
	}
	
}

@media(min-width:992px) {
	.timesale::after{
		left: 22%;
}
 #usj .timesale::after{
		left: 19%;
}
	
}



/* slider*/
.slick-dots{
	bottom:-25px;
}

.txt-limit{
	color: #FF6C6C;
	font-weight: bold;
}

.slick-prev, .slick-next{
	display: none!important;
}

.slick-dots li{
	margin: 0!important;
}

/*
おすすめツアー商品
**********************************/


ul.recommend-tour-list{
	display:flex;
	gap:15px;
	margin:20px 0;
}

ul.recommend-tour-list li{
	width:25%;
}

ul.recommend-tour-list li a{
	display:block;
	padding:10px;
	color:#896A98;
	background: #fdfdf7;
	overflow: hidden;
	box-shadow: 0px 0px 6px #e7e7e7;
	border-radius:4px;
	overflow:hidden;
	text-align: left;
	height: 100%;
}

ul.recommend-tour-list li a:hover{
	text-decoration:none;
}

ul.recommend-tour-list li img{
	display: inline;
	height: 150px;
	object-fit: cover;
	width: 100%;
	margin-bottom:10px !important;
}

.tour-plan-ttl{
	font-size:14px;
	font-weight:bold;
	line-height:1.4;
	margin-bottom:3px;
}

.tour-plan-sub{
	font-size:12px;
	color:#77653c;
	background:#fff;
	padding:3px;
}
.tour-plan-lead{
	font-size:14px;
	font-weight: bold;
	color:#77653c;
	margin-bottom: 5px;
}
.price-text{
	font-size:14px;
	font-weight:normal;
	margin-top:3px;
}

.price-box{
	text-align:right;
}

.goto-price-after,
.goto-price-before{
	position:relative;
}

.goto-price-after{
	margin-top:-5px;
}
.goto-price-after .price{
	font-size: 18px;
	font-weight: bold;
	color: #F53D7D;
	font-family: Verdana, Geneva, sans-serif;
	text-align:right;
	position:relative;
	display:inline-block;
}

.goto-price-after .price .yen{
	font-size: 11px;
	font-weight: bold;
	display: inline-block;
	padding-left:0px;
	color: #F53D7D;
	font-family: initial;
}

.goto-price-before{
	margin-top:-3px;
}

.goto-price-before .price{
	font-size: 14px;
	font-weight: bold;
	color: #666;
	font-family: Verdana, Geneva, sans-serif;
	text-align:right;
	letter-spacing:-0.3px;
	position:relative;
	display:inline-block;
	margin-top:-2px;
}

.goto-price-before .price .yen{
	font-size: 10px;
	font-weight: bold;
	display: inline-block;
	padding-left:0px;
	font-family: initial;
}



.kara{
	font-size: 12px;
	font-family: initial;
}

.goto-price-after .price:before {
    content: "お一人様あたり";
    position: absolute;
    top:5px;
    left: -8px;
    font-size: 13px;
    font-weight:normal;
    color:#333;
}
.goto-price-before .price:before {
    content: "割引前";
    position: absolute;
    top:2px;
    left: -48px;
    font-size: 13px;
    font-weight:normal;
}

.goto-price-before .price:after{
	content:"";
	display:block;
	width:100%;
	height:2px;
	background:#cc0000;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	right: 0;
}

.tab-pane{
	animation: fadeIn 1s ease 0s 0.5 normal;
	-webkit-animation: fadeIn 1s ease 0s 0.5 normal;
}

#recommend-tour .price-box {
    margin: 10px auto;
}

#recommend-tour .plan-price{
	background: none;
}



@keyframes fadeIn {
	0% {opacity: 0}
	100% {opacity: 1}
}

@-webkit-keyframes fadeIn {
	0% {opacity: 0}
	100% {opacity: 1}
}

@media(min-width:992px) {
	.goto-price-after .price{
		padding-top:20px;
	}
}
@media(min-width:992px) and (max-width:1199px){
	.goto-price-after .price:before {
	    top:5px;
	    left:-5px;
	    font-size: 13px;
	}
}

@media(min-width:768px) and (max-width:991px){
	ul.recommend-tour-list{
		display: grid;
		 grid-template-columns: 1fr 1fr;
	}
	ul.recommend-tour-list li{
		width:100%;
	}
	
	.goto-price-after .price:before {
	    left: -100px;
	}
}

@media(min-width:577px) and (max-width:767px){
	ul.recommend-tour-list{
		display: grid;
		 grid-template-columns: 1fr 1fr;
	}
	ul.recommend-tour-list li{
		width:100%;
	}
	
	.goto-price-after .price{
		padding-top:20px;
	}
	
	.goto-price-after .price:before {
	    top:5px;
	    left:-7px;
	    font-size: 13px;
	}
}

@media(max-width:576px){
	#recommend-tour .tab-pane{
		overflow-x:scroll;
		padding-left: 5px;
		padding-right: 5px;
	}
	ul.recommend-tour-list{
		 width:1000px;
	}
	
	ul.recommend-tour-list li{
		width:240px;
	}
	
	.tour-plan-ttl{
		font-size:13px;
		line-height:1.3;
	}
	
	
	.tour-plan-sub{
		font-size:12px;
	}
	
	.goto-price-after .price{
		font-size:16px;
		text-align:right;
	}
	.goto-price-before .price{
		font-size:14px;
		text-align:right;
	}
	.goto-price-after .price:before {
	    top:2px;
	    left:-100px;
	}
	.tour-plan-lead{
	font-size:13px;
	}
}


@media(max-width:374px){

	ul.recommend-tour-list{
		 width:1108px;
	}
	
	ul.recommend-tour-list li{
		width:265px;
	}
	
	.goto-price-after .price:before{
		font-size:12px;
		left:-95px;
	}
	
	.goto-price-after .price{
		font-size:14px;
		letter-spacing:-0.35px;
	}
	
	.goto-price-before .price{
		font-size:13px;
	}

}


.nav-tabs.nav-dep{
  width: 100%;
  justify-content: space-between;
  border-bottom: 3px solid #eee;
}
.nav-tabs .nav-link{
  border: none;
}
.nav-dep > li{
  flex: 1;
  display: flex;
  width: 100%;
}
.nav-dep > li a.nav-link{
  text-align: center;
  padding: 18px 0;
  display: flex;
  width: 100%;
  color: #fff;
  align-items: center;
  justify-content: center;
  background: #fafafa;
  border: solid 2px #fff;
	border-bottom: none;
}
.nav-dep > li a.nav-link:hover,
.nav-dep > li a.nav-link.active{
  border: solid 2px #fff;
	border-bottom: none;
}
.nav-dep > li.nav-item-tokai a.nav-link{
  color: #ef3c4d;
}
.nav-dep > li.nav-item-kansai a.nav-link{
  color: #f68732;
}
.nav-dep > li.nav-item-hokuriku a.nav-link{
  color: #9435b8;
}
.nav-dep > li.nav-item-tohoku a.nav-link{
  color: #4db8f0;
}
.nav-dep > li.nav-item-chugoku a.nav-link{
  color: #9ba61d;
}
.nav-dep > li.nav-item-kyushu a.nav-link{
  color: #f54b6b;
}
.nav-dep > li.nav-item-kanto a.nav-link{
  color: #1a2975;
}
.nav-dep .nav-item.show.nav-item-tokai a.nav-link,
.nav-dep .nav-item-tokai .nav-link.active{
  background: #ef3c4d;
  color: #fff;
}
.nav-dep .nav-item.show.nav-item-kansai a.nav-link,
.nav-dep .nav-item-kansai .nav-link.active{
  background: #f68732;
  color: #fff;
}
.nav-dep .nav-item.show.nav-item-hokuriku a.nav-link,
.nav-dep .nav-item-hokuriku .nav-link.active{
  background: #9435b8;
  color: #fff;
}
.nav-dep .nav-item.show.nav-item-tohoku a.nav-link,
.nav-dep .nav-item-tohoku .nav-link.active{
  background: #4db8f0;
  color: #fff;
}
.nav-dep .nav-item.show.nav-item-chugoku a.nav-link,
.nav-dep .nav-item-chugoku .nav-link.active{
  background: #9ba61d;
  color: #fff;
}
.nav-dep .nav-item.show.nav-item-kyushu a.nav-link,
.nav-dep .nav-item-kyushu .nav-link.active{
  background: #f54b6b;
  color: #fff;
}
.nav-dep .nav-item.show.nav-item-kanto a.nav-link,
.nav-dep .nav-item-kanto .nav-link.active{
  background: #1a2975;
  color: #fff;
}
.tab-deplink{
  padding-top: 12px;
  margin-bottom: 24px;
}
.ul-depselect{
  display: flex;
  /*background: #fafafa;*/
}
.ul-header{
  position: sticky;
  top: 0;
}
.ul-depselect > li{
  padding: 0;
}
.ul-depselect > li a:hover{
  text-decoration: none;
}
.ul-depselect + .ul-depselect{
  border-top: 1px dotted #ccc;
}
.li-dep-name{
  width: 15%;
  display: flex;
}
.li-dep-name a{
  font-weight: bold;
  display: flex;
  align-items: center;
  padding: 12px;
  width: 100%;
}
.li-dep-name a:after{
  content: "\f054";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  font-size: 80%;
  margin-left: 12px;
}
.li-dep-name.list-area-tohoku a{
  color: #4db8f0;
  border-left: 5px solid #4db8f0;
}
.li-dep-name.list-area-hokushinetsu a{
  color: #9435b8;
  border-left: 5px solid #9435b8;
}
.li-dep-name.list-area-tokai a{
  color: #ef3c4d;
  border-left: 5px solid #ef3c4d;
}
.li-dep-name.list-area-kansai a{
  color: #f68732;
  border-left: 5px solid #f68732;
}
.li-dep-name.list-area-chugoku a{
  color: #9ba61d;
  border-left: 5px solid #9ba61d;
}
.li-dep-name.list-area-shikoku a{
  color:#66aa2f;
  border-left: 5px solid #66aa2f;
}
.li-dep-name.list-area-kyushu a{
  color:#f54b6b;
  border-left: 5px solid #f54b6b;
}
.li-dep-name.list-area-kanto a{
  color:#1a2975;
  border-left: 5px solid #1a2975;
}
.li-dep-bus{
  width: 25%;
  text-align: right;
  border-left: dotted 1px #ccc;
}
.li-dep-set{
  width: 30%;
  text-align: right;
  border-left: dotted 1px #ccc;
}
.ul-depselect-inner{
	width: 85%;
}
.ul-depselect-inner > ul{
	margin: 0;
	padding: 0;
	display: flex;
}
.ul-depselect-inner .li-dep-bus{
  width: 25%;
}
.ul-depselect-inner .li-dep-set{
  width: 25%;
}
.li-dep-empty{}

.ul-depselect.ul-header .li-dep-name,
.ul-depselect.ul-header .li-dep-bus,
.ul-depselect.ul-header .li-dep-set{
  background: #333;
  color: #fff;
  text-align: center;
  justify-content: center;
}
.li-dep-bus .wrap-price .num,
.li-dep-set .wrap-price .num {
    font-size: 20px;
    font-weight: bold;
    color: #F14482;
}
.li-dep-bus .wrap-price .num.min:after,
.li-dep-set .wrap-price .num.min:after {
    content: "～";
    font-size: 12px;
    margin-right: 3px;
}
.li-dep-bus .wrap-price .num.onlybus:after,
.li-dep-set .wrap-price .num.onlybus:after {
    content: "円～";
    font-size: 12px;
    margin-right: 3px;
}
.li-dep-bus .wrap-price .num.max:after,
.li-dep-set .wrap-price .num.max:after {
    content: "円";
    font-size: 12px;
}
.li-dep-bus a,
.li-dep-set a,
.li-dep-bus button,
.li-dep-set button{
	padding: 12px 12px 10px 12px;
	display: block;
	background: none;
	width: 100%;
	text-align: right;
}
.li-dep-bus a:hover,
.li-dep-set a:hover,
.li-dep-bus button:hover,
.li-dep-set button:hover{
  color: #fff;
  background: #fff5f9;
}
.li-dep-bus a .wrap-price,
.li-dep-set a .wrap-price,
.li-dep-bus button .wrap-price,
.li-dep-set button .wrap-price{
  display: inline-block;
}
.plan-name{
  display: block;
  text-align: left;
  font-size: 12px;
  color: #333;
  margin-bottom: 0;
}
/*.li-dep-bus a:before,
.li-dep-set a:before,
.li-dep-set.list-pass a:before{
  display: block;
  text-align: left;
}
.li-dep-bus a:before{
  content: "高速バスのみ";
  font-size: 12px;
  color: #333;
}
.li-dep-set a:before{
  content: "高速バス＋ホテル";
  font-size: 12px;
  color: #333;
}
.li-dep-set.list-pass a:before{
  content: "スタジオ・パス付き(日帰り・宿泊)";
  font-size: 12px;
  color: #333;
}
.li-dep-set.bus-katamichi a:before{
  content: "高速バス(片道)＋ホテル";
}
.li-dep-set.list-pass.bus-katamichi a:before{
  content: "スタジオ・パス付き(日帰り・宿泊)";
}*/
.li-dep-bus a:hover:before,
.li-dep-set a:hover:before,
.li-dep-bus button:hover:before,
.li-dep-set button:hover:before{
  color: #fff;
}
@media (max-width: 992px) {
.ul-depselect-inner > ul{
	flex-wrap: wrap;
}
.ul-depselect-inner .li-dep-bus{
  width: 50%;
}
.ul-depselect-inner .li-dep-set{
  width: 50%;
}
}
@media (max-width: 767px) {
.ul-depselect{
  display: block;
  position: relative;
}
.nav-dep > li a.nav-link{
  font-size: 14px;
}
.ul-depselect > li a,
.ul-depselect > li button{
  padding: 6px 24px 6px 6px;
  position: relative;
}
.li-dep-name{
  position: absolute;
  top: 0;
  left: 0;
  width: 80px;
  height: 100%;
  background: none;
  display: block;
}
.li-dep-bus{
  width: calc(100% - 80px) ;
  text-align: right;
  margin: 0 0 0 auto;
  border-left: none;
}
.li-dep-set{
  width: calc(100% - 80px) ;
  text-align: right;
  margin: 0 0 0 auto;
  border-top: 1px dotted #ccc;
  border-left: none;
  border-right: none;
}
.ul-depselect-inner{
	width: calc(100% - 80px) ;
	margin: 0 0 0 auto;
}
.ul-depselect-inner .li-dep-bus,
.ul-depselect-inner .li-dep-set{
	width: 100%;
}

.li-dep-empty{
	display: none;
}
.li-dep-bus.stop + .li-dep-set{
  border-top: none;
}
.li-dep-set + .li-dep-set{
	border-left: none;
}
.ul-depselect + .ul-depselect{
  border-top: none;
  margin-top: 12px;
}
.li-dep-name a:after{
  margin-left: 0;
  position: absolute;
  right: 5px;
}
.ul-depselect > li.li-dep-name a{
  padding: 3px;
  width: 100%;
  height: 100%;
  justify-content: center;
  align-items: center;
  display: flex;
  color: #fff;
  border-radius: 5px 0 0 5px;
  font-size: 14px;
  text-align: center;
}
.li-dep-name.list-area-tohoku a{
  background: #4db8f0;
  border-left: none;
}
.li-dep-name.list-area-hokushinetsu a{
  background: #9435b8;
  border-left: none;
}
.li-dep-name.list-area-tokai a{
  background: #ef3c4d;
  border-left: none;
}
.li-dep-name.list-area-kansai a{
  background: #f68732;
  border-left: none;
}
.li-dep-name.list-area-chugoku a{
  background: #9ba61d;
  border-left: none;
}
.li-dep-name.list-area-shikoku a{
  background:#66aa2f;
  border-left: none;
}
.li-dep-name.list-area-kyushu a{
  background:#f54b6b;
  border-left: none;
}
.li-dep-name.list-area-kanto a{
  background:#1a2975;
  border-left: none;
}
.li-dep-bus a:after,
.li-dep-set a:after,
.li-dep-bus button:after,
.li-dep-set button:after{
  content: "\f054";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  position: absolute;
  top: 50%;
  right: 6px;
  transform: translate(0, -50%);
  color: #F14482;
  font-size: 12px;
}
/*.li-dep-bus a:before{
  content: "高速バスのみ";
  margin-right: 0px;
}
.li-dep-set a:before{
  content: "高速バス＋ホテル";
  margin-right: 0px;
}
.li-dep-set.list-pass a:before{
  content: "スタジオ・パス付き(日帰り・宿泊)";
  margin-right: 0px;
}*/
}


/* 2025 追加 */
/* 高速バス
---------------------------------*/
#Busprice .side-price-list tr.area-search .search-text {
    text-align: left;
}
#Busprice .side-price-list tr.area-search td .prefectures-ul {
    display: flex;
    gap: 1.5%;
    margin-top: 5px;
}
#Busprice .side-price-list tr.area-search td .prefectures-ul li a {
    color: #1c1c1c;
    font-weight: 400;
    font-size: 14px;
}
#Busprice .side-price-list tr.area-search td .prefectures-ul li a:before {
    content: none;
}
#Busprice .side-price-list tr.area-search td .prefectures-ul li a:hover {
    opacity: 0.6;
}
#Busprice .side-price-list tr.area-search td .wrap-arrival {
    margin-top: 16px;
}


@media (min-width: 768px) {
    #Busprice .side-price-list tr.area-search .wrap-departure-arrival {
        display: flex;
        gap: 1.5%;
    }
    #Busprice .side-price-list tr.area-search .wrap-departure,
    #Busprice .side-price-list tr.area-search .wrap-arrival{
        width: 49%;
    }    
    #Busprice .side-price-list tr.area-search td .prefectures-ul {
        gap: inherit;
    }
    #Busprice .side-price-list tr.area-search td .wrap-arrival {
        margin-top: 0;
    }
    #Busprice .side-price-list tr.area-search .search-text {
        font-size: 16px;
    }
    #Busprice .side-price-list tr.area-search td .prefectures-ul li:not(:first-child){
        margin-left: 2%;
    }
}


/* Pick up
----------------------------------*/
#Pickup .card-plan {
    border: #1C1C1C solid 2px;
    border-radius: 5px;
    position: relative;
    overflow: inherit;
}


/* Spot
---------------------------------*/


@media (min-width: 768px) {
   #Spot .nav-reservenavi.num3 {
        flex-wrap: wrap;
   }
   #Spot .nav-reservenavi.num3 li:first-child {
        width: 58%;
    }
   #Spot .nav-reservenavi.num3 li:nth-child(2) {
        width: 42%;
    }
   #Spot .nav-reservenavi.num3 li:nth-child(3) {
        width: 50%;
        margin-top: 10px;
   }
}

@media (min-width: 992px) {
   #Spot .nav-reservenavi.num3 li:first-child {
        width: 54%;
    }
   #Spot .nav-reservenavi.num3 li:nth-child(2) {
        width: 46%;
    }
}



/* modal button link
--------------------------*/
.modal h3 {
    font-size: 16px;
    font-weight: bold;
    color: #fff;
}
.modal-plan-item .button-link {
    position: relative;
    display: block;
    width: 100%;
    padding: 12px 30px;
    font-size: 20px;
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.6;
    color: #1c1c1c;
    transition: 0.3s;
    background: #fdfcf0;
    background: #fff56c;
    border-radius: 50px;
    border: 2px solid #1c1c1c;
}
.modal-plan-item .button-link:hover {
    text-decoration: none;
}
.modal-plan-item .button-link::after {
    content: "\f138";
    font-family: "Font Awesome 5 Free";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 5px;
    font-weight: bold;
}

.modal-plan-item .plan-name {
    font-size: 14px;
    color: #1c1c1c;
}

.modal-plan-item .wrap-price {
    color: #FF6C6C;
}
