@charset "utf-8";

  #appdeeplink{
    display: none;
  }

/* 
 *	Common Style
 ************************/
article {
    font-family: "游ゴシック", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
    text-align: center;
}
article img {
	width: 100%;
	height: auto;
}
article a {
    color: #000;
}
article a:hover {
    text-decoration: none;
}
.visible-md-block {
    display: none;
}
.card-plan-price span::before {
    font-size: 10px;
}
.card-plan-price span:after {
    font-weight: bold;
    font-size: 11px;
}
/* Icons */
.icon {
    position: relative;
    top: .2em;
}
.icon::before,
.icon::after {
    display: inline-block;
    width: 22px;
    height: 22px;
    content: "";
}
.icon-calendar-gray::before {
    background: url("/static/img/tour/megurip/icon-calendar-gray.webp") center center / contain no-repeat;
}
.icon-calendar-pink::after {
    background: url("/static/img/tour/megurip/icon-calendar-pink.webp") center center / contain no-repeat;
	pointer-events: none;
}
.icon-angle-down::after {
    background: url("/static/img/common/icon/angle-down-solid.png") center center / contain no-repeat;
	pointer-events: none;
	    width: 14px;
    height: 14px;
	top:40%!important;
	right: 24px!important;
}

.icon-pin-gray::before {
    background: url("/static/img/tour/megurip/icon-pin-gray.webp") center center / contain no-repeat;
}
.icon-pin-pink::after {
    background: url("/static/img/common/icon/icon-pin-pink.webp") center center / contain no-repeat;
	pointer-events: none;
}
.icon-bag-gray::before {
    background: url("/static/img/tour/megurip/icon-bag-gray.webp") center center / contain no-repeat;
}
.icon-bag-pink::after {
    background: url("/static/img/common/icon/icon-bag-pink.png") center center / contain no-repeat;
	pointer-events: none;
}
/* Color */
article .pink {
	color: #f53d7e;
}
article .comments {
    font-size: 12px;
}
/* Buttons */
.btn-main-pink {
    display: block;
    min-height: 40px;
    margin: 15px 0;
    padding: 14px 10px;
    background: #f53d7e;
    border-radius: 2px;
    text-align: center;
    font-weight: bold;
    font-size: 14px;
    color: #fff;
    cursor: pointer;
}
.section-search-more {
    margin: 15px 0 10px 0;
}
.btn-more {
    position: relative;
    display: block;
    box-sizing: content-box;
    width: 80%;
    margin: 15px auto 0 auto;
    padding: 15px 25px 15px 15px;
    background: url("/static/img/index/bg-stripe-pink.webp") left top;
    border-radius: 3em;
    font-weight: bold;
    font-size: 14px;
    color: #333;
    text-align: center;
}
.btn-more::after{
    position: absolute;
    right: 20px;
	content: "\f105";
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	color: #f53d7e;
	margin-left: 15px;
}
.btn-more:hover {
    color: #333;
    text-decoration: underline;
}
button:focus {
    outline: none;
}


.departure-bus-select,.departure-price-select{
	position: relative;
}

.bus-select-btn {
	display: flex;
	align-content: center;
	justify-content: space-between;
	height: 50px;

}


.bus-select-btn .btn{
	color: #000!important;
	font-weight: bold!important;	
	margin: 0!important;
	font-size: 16px!important;
	text-align: left!important;
	padding: 13px 14px 13px 20px!important;
	position: relative!important;
	min-height: 50px!important;
	align-items: center!important;	
	vertical-align: middle!important;
	border-radius: 0!important;
	width: 25%!important;
	background-color:transparent;
}

.price-select-btn .btn{
	color: #000!important;
	font-weight: bold!important;	
	margin: 0!important;
	font-size: 16px!important;
	text-align: left!important;
	padding: 13px 14px 13px 20px!important;
	position: relative!important;
	min-height: 50px!important;
	align-items: center!important;	
	vertical-align: middle!important;
	border-radius: 0!important;
	width: 40%!important;
	background-color:transparent;
}






.bus-select-btn .btn input[type=radio]{
	display: none;
}

.price-select-btn .btn input[type=radio]{
	display: none;
}

.bus-select-btn .btn.focus {
    outline: none;
	box-shadow: none!important;

}

.price-select-btn .btn.focus {
    outline: none;
	box-shadow: none!important;

}

.bus-select-btn .btn::before,.price-select-btn .btn::before {
    content: "";
    width: 12px;
    height: 12px;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translate(0, -50%);
    outline: none !important;
    background: #fff;
    border-radius: 100px;
    border: solid 1px #ccc;
}




.bus-select-btn .btn.active,.price-select-btn .btn.active{
  color: #f53d7e!important;
}

.bus-select-btn .btn.active:before,.price-select-btn .btn.active:before {
    border: solid 1px #999!important;
}

.bus-select-btn .btn-default,.price-select-btn .btn-default{
	border: none;
}


.bus-select-btn .btn.active:after,.price-select-btn .btn.active:after{
    content: "";
    width: 8px;
    height: 8px;
    position: absolute!important;
    left: 2px!important;
    top: 50%!important;
    transform: translate(0, -50%)!important;
    outline: none !important;
    background: #F53D7E;
    border-radius: 100px;
}




/* Card */
.card {
    padding: 0;
    border: none;
    border-radius: 4px;
    text-align: left;
    overflow: hidden;
}
.card-plan-01 {
    box-shadow: 0px 0px 6px 0px rgba(231,231,231,1);
}
.card-plan-01 dd {
    padding: 0;
}
.card-body {
    padding: 10px;
    color: #000;
}
.card-title {
    display: block;
    margin-bottom: 10px;
    font-size: 14px;
}
/* Title */
.section-title {
    padding: 40px 0 30px;
    width: 55%;
    max-width: 400px;
}
/* 
 *	Common Style (Tablet)
 ************************/
@media (min-width: 768px) {
    .visible-sm-block {
        display: none;
    }
    .visible-md-block {
        display: block;
    }
    .card-plan-price span::before {
        font-size: 13px;
    }
    .card-plan-price span:after {
        font-size: 19px;
    }
    .section-search-more {
        margin: 60px 0 30px;
    }
    .btn-more {
        display: inline-block;
        width: auto;
        margin-top: 0;
        padding: 20px 50px 20px 25px;
        font-size: 18px;
		width: 100%;
    }
    .card-body {
        padding: 24px;
    }
    .card-title {
        margin-bottom: 20px;
        font-size: 16px;
    }
    /* Title */
    .section-title {
        padding: 60px 0;
        max-width: 300px;
    }
}
/* 
 *	section-main
 ************************/
/*キービジュアル*/
.img-pc{
	display: none;
}
@media(min-width:576px) {
.inner-hero{

}
.inner-hero h1{
	padding: 0 15px;
}
.img-pc{
	display: inline-block !important;
}
.img-sp{
	display: none !important;
}
}
.section-main {
    position: relative;
}
.title-main {
    position: absolute;
    top: 50%;
    left: 50%;
    height: 100%;
    -webkit-transform: translate(-50%,-50%);
    -moz-transform: translate(-50%,-50%);
    -ms-transform: translate(-50%,-50%);
    -o-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
    z-index: 10;
}
.title-main img {
    width: auto;
    height: 100%;
}
.img-main {
    max-width: 1366px;
    margin: 0 auto;
}
.title-main-ribon{
    position: relative;
    height: 100%;
}
.title-main-ribon::before {
    position: absolute;
    right: -67%;
    bottom: -5.8%;
    width: 100%;
    max-width: 541px;
    height: 19%;
    max-height: 108px;
    padding-top: 0;
    background: url("/static/img/tour/megurip/title-main-comments.webp") no-repeat;
    background-size: contain;
    content: "";
}
.title-main-ribon::after {
    position: absolute;
    right: -60%;
    width: 100%;
    padding-top: 1em;
    text-align: right;
    font-size: 12px;
    content: "※路線によっては飛行機のプランも選べます。";
}
.title-main-pc{
	height: 100%;
}
.title-main-pc img{
	height: 90%;
	margin-top: 3%;
}


.card-plan-price {
    text-align: left;
}
.card-plan-price span {
    margin-left: 0;
    font-size: 13px;
}
.card-plan-price strong {
    display: block;
    text-align: left;
}
.card-plan-price .only::after {
    content: "";
}
/* 
 *	section-main (Tablet)
 ************************/
@media (min-width: 768px) {
    .section-main {
        max-height: 550px;
        margin-bottom: 30px;
    }
    .title-main-ribon::after {
        right: -68%;
    }
    .card-plan-price {
        text-align: right;
    }
    .card-plan-price-pref {
        font-size: 11px;
    }
    .card-plan-price span {
        font-size: 19px;
    }
    .card-plan-price strong {
        display: inline;
        white-space: nowrap;
    }
}
/* 
 *	section-search (PC)
 ************************/
@media (min-width: 992px) {
    .card-plan-price-pref {
        margin-right: 5px;
    }

  .bus-select-btn .btn,.price-select-btn .btn{
	color: #000;
	font-weight: bold;	
	margin: 0;
	font-size: 16px;

}

}
/* 
 *	section-nav
 ************************/
.section-nav-ul {
    padding: 0 10px;
    box-sizing: border-box;
	text-align: center;
}
.section-nav-ul li {
    padding: 30px 10px;
}
.section-nav-ul li a {
    display: block;
    padding-bottom: 10px;
    border-bottom: 2px solid #f53d7e;
    font-weight: bold;
    font-size: 12px;
    color: #000000;
}
.section-nav-ul li a .icon {
    display: block;
    margin: 0 0 7px;
}
.section-nav-ul li a .icon::after {
   content: none;
}
/* 
 *	section-nav (Tablet)
 ************************/
@media (min-width: 768px) {
    .section-nav-ul {
        padding: 20px 0;
    }
    .section-nav-ul li {
        padding: 0;   
    }
    .section-nav-ul li a {
        padding: 0;
        border: none;
        font-weight: bold;
        font-size: 16px;
    }
    .section-nav-ul li a .icon {
        display: inline;
        margin-right: 20px;
    }
    .section-nav-ul li a:hover {
        text-decoration: underline;
    }
}
/* 
 *	section-pickup
 ************************/
.section-pickup {
    position: relative;
    padding: 30px 0;
}
.section-pickup h2 {
    text-align: center;
}
.section-title-pickup {
    max-width: 464px;
    padding-bottom: 30px;
}
.badge-pref {
    position: absolute;
    width: 30px;
    top: 6px;
    left: 6px;
}
.badge-pref.badge-castle {
    position: absolute;
    width: 40px;
    top: 5px;
    left: 12px;
}
.card-pickup dt {
    height: 63.5%;
    max-height: 110px;
    overflow: hidden;
}
.card-pickup-text {
    font-size: 12px;
    line-height: 1.6em;
}
.card-pickup .btn-main-pink {
    min-height: auto;
    margin: 0 10px 15px 10px;
    padding: 8px 10px;
    font-weight: normal;
}
/* 
 *	section-pickup (Tablet)
 ************************/
@media (min-width: 768px) {
    .section-pickup {
        position: relative;
        padding: 35px 0 60px 0;
    }
    .section-title-pickup {
        max-width: 464px;
        padding-bottom: 40px;
    }
    .badge-pref {
        width: 48px;
        top: 10px;
        left: 10px;
    }
    .card-pickup-text {
        font-size: 14px;
        line-height: 1.8em;
    }
    .card-pickup .btn-main-pink {
        margin: 0 24px 24px;
    }
    .card-pickup dt {
        max-height: 174px;
    }
}
/* 
 *	section-search
 ************************/
.section-search {
    padding-bottom: 105px;
    background: #fafafa;
}
/* -- Departure */
.card-search {
    box-shadow: 0px 0px 6px 0px rgba(231,231,231,1);
}
.card-search-title {
    padding: 15px;
    background: url("/static/img/tour/megurip/bg-stripe-pink.webp") left top / 5px;
    color: #f53d7e;
    font-weight: bold;
    font-size: 18px;
    text-align: center;
    letter-spacing: .1em;
}
.search-departure-date {
    margin-bottom: 15px;
}
.search-departure-date .card-body {
    padding: 20px 20px 20px;
}
.search-departure-date .card-body li {
    margin-right: 0;
    margin-bottom: 7px;
    padding-left: 70px;
    border: 1px solid #dbdbdb;
    border-radius: 2px;
}
.search-departure-date .card-body li.departure-date-select-ym {
    margin-bottom: 0;
    border-bottom: none;
    border-radius: 2px 2px 0 0 / 2px 2px 0 0;
}
.search-departure-date .card-body li.departure-date-select-d {
    border-radius: 0 0 2px 2px / 0 0 2px 2px;
}

/* ▼ Form Style */
.search-departure-date .form-control {
    width: 100%;
    min-height: 50px;
    padding: 0;
    border: none;
    color: #000!important;
    font-weight: bold;
    font-size: 15px;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
    box-shadow: none;
	background: #fff;
	justify-content: flex-start;

}
.form-control::placeholder {
	color: #000!important;
	opacity: 1!important;
}



.departure-date-select-ym {
    margin-bottom: 2px;
}
.search-departure-date select:focus,
.search-departure-date select:active {
    box-shadow: none;
    outline: none;
}
.departure-date-select::before,
.departure-select::before,
.departure-hotelarea-select::before,
.departure-bus-select::before,
.departure-price-select::before{
    position: absolute;
    top: 15px;
    left: 15px;
    width: auto;
    color: #666;
    font-weight: bold;
    font-size: 14px;
}
.departure-date-select-ym::before {
    content: "出発日";
}
.departure-select::before {
    content: "出発地";
}
.departure-hotelarea-select::before {
    content: "宿泊地";
}
.departure-bus-select::before {
    content: "バス";
	    left: 20px;
}

.departure-price-select::before {
    content: "表示順";
}


.departure-date-select::after,
.departure-select::after,
.departure-hotelarea-select::after,
.departure-bus-select::after{
    position: absolute;
    top: 13px;
    right: 20px;
}

.departure-date-select-d input:disabled {
    color: black;
    background-color: #ccc;
    opacity: 1;
}

/* ▲ Form Style */
.search-departure-date ul li.btn-search-box {
    border: none;
    overflow: hidden;
    margin-bottom: 0;
    padding-left: 0;
}
.btn-search-box .btn-main-pink {
    min-width: 180px;
    margin: 18px auto 20px;
    font-size: 16px;
    letter-spacing: .1em;
}
.card-body .comments {
    display: block;
    color: #666;
    font-size: 12px;
    text-align: center;
}
.search-departure-pref .card-body {
    padding: 20px 10px;
    background: url("/static/img/tour/megurip/bg-map.webp") 80% center no-repeat;
    background-size: 70%;
}
.search-departure-pref dl {
    margin-bottom: 3px;
    padding-left: 65px;
}
.search-departure-pref dt {
    position: absolute;
    left: 10px;
    display: inline-block;
    width: 60px;
    padding: 10px 7px;
    box-sizing: border-box;
    background: #f6f6f6;
    font-size: 10px;
    text-align: center;
    line-height: 1em;
}
.search-departure-pref dd {
    display: inline-block;
    font-weight: bold;
    font-size: 11px;
    line-height: 1em;
}
.search-departure-pref dd a {
    display: block;
    padding: 11px 6px 7px 6px;
    color: #f53d7e;
}
.search-departure-pref dd a:hover{
    background: #feebf2;
    text-decoration: underline;
}
/* 
 *	section-search (Tablet)
 ************************/
@media (min-width: 768px) {
    .section-search {
		padding-top: 20px;
        padding-bottom: 40px;
    }
    .card-search-title {
        padding: 20px 40px;
        background: url("/static/img/tour/megurip/bg-stripe-pink.webp") left top / 11px;
        font-size: 18px;
        text-align: center;
    }
    .search-departure-pref {
        margin-top: 0;
    }
    .search-departure-date .card-body li {
        margin-bottom: 20px;
        padding-left: 80px;
    }

    /* ▼ Form Style */
    .search-departure-date .form-control {
        font-size: 16px;
    }
    .departure-date-select::before,
    .departure-select::before,
    .departure-hotelarea-select::before,
	.departure-bus-select::before,
	.departure-price-select::before{
        left: 20px;
        font-size: 13px;
    }
    /* ▲ Form Style */
    .search-departure-pref dl {
        margin-bottom: 3px;
        padding-left: 30%;
    }
    .search-departure-pref dt{
        left: 20px;
        width: 24.52%;
        margin-right: 10px;
        padding: 10px;
        font-weight: normal;
        font-size: 13px;
    }
    .search-departure-pref dd {
        font-weight: normal;
        font-size: 14px;
    }
    .search-departure-pref dd a {
    padding: 9px 7px;
    }
    .btn-search-box .btn-main-pink {
        float: right;
        min-width:140px;
        margin: 0;
    }
    .card-body .comments {
        display: inline;
        font-size: 14px;
        text-align: left;
    }
    .search-departure-pref .card-body {
        padding: 20px;
        background-size: 266px;
        background-position: 70%;
    }
}
/* 
 *	section-search (PC)
 ************************/
@media (min-width: 992px) {
    /* ▼ Form Style */
    .search-departure-date .card-body li.departure-date-select-ym {
        float: left;
        width: 50%;
        border-bottom: 1px solid #dbdbdb;
        border-radius: 2px 0 0 2px / 2px 0 0 2px;
    }
    .search-departure-date .card-body li.departure-date-select-d {
        float: left;
        width: 50%;
        padding-left: 1em;
        border-left: none;
        border-radius: 0 2px 2px 0 / 0 2px 2px 0;
    }

    .search-departure-date .card-body li.departure-select {
        clear: both;
    }

    /* ▲ Form Style */
    .search-departure-date .card-body {
        padding: 20px 20px 30px;
    }


}



@media only screen and (max-width: 480px){
	.bus-select-btn {
		justify-content: space-between;
	}
	.bus-select-btn .btn{
		width: 35%!important;
		padding: 16px 14px 13px 30px!important;
			font-size: 14px!important;	
	}
	
	.price-select-btn .btn{
		width: 50%!important;
		padding: 16px 14px 13px 18px!important;
		font-size: 14px!important;
	}
	
	
	.radio-text span{
		font-size: 13px;
	}
	.bus-select-btn .btn input[type=radio],.price-select-btn .btn input[type=radio]{
		margin-right: 1px!important;
	}
	.search-departure-date .card-body li.departure-bus-select{
		padding-left: 58px;
		
	}
.bus-select-btn .btn::before{
   left: 12px;

}	
	
.price-select-btn .btn::before {
		   left: 2px;
		
	}	
	
.bus-select-btn .btn.active:after{
		left: 14px!important;
	}
	
.price-select-btn .btn.active:after{
		left: 4px!important;
	}
		
	
	}			

@media only screen and (max-width: 360px){
	.bus-select-btn .btn{
		width: 40%!important;
				font-size: 12px!important;	
	}
	
		.price-select-btn .btn{
		width: 50%!important;
			font-size: 12px!important;
	}
	
		.radio-text span{
		font-size: 11px;
	}
}
/* 
 *	HotelArea
 ************************/
#search-hotelarea{
	text-align: center;
}
.card-search-hotelarea {
    padding: 8px;
}
.card-search-hotelarea .card-info {
    position: relative;
    padding: 10px 5px;
    font-weight: bold;
    color: #333;
}
.card-search-hotelarea .card-info::after {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 1px;
		/* cardの対象出発地削除につきline-dotted.png非表示 */
    /*background: url("/static/img/tour/megurip/line-dotted.png") left center repeat-x;*/
    content: "";
}
.card-search-hotelarea .card-body {
    padding: 10px 5px 5px 5px;
    color: #333;
}
.card-targetarea {
    font-size: 11px;
}
.card-targetarea dt {
    font-weight: bold;
    padding-bottom: 10px;
}
.card-targetarea dd {
    display: inline;
    padding: 0;
    color: #666;
}
/* 
 *	HotelArea (Tablet)
 ************************/
@media (min-width: 768px) {
    .card-search-hotelarea .card-body {
        padding: 24px 10px 10px 10px;
    }
    .card-search-hotelarea {
        padding: 10px;
    }
    .card-search-hotelarea .card-info {
        padding: 20px 0 20px 10px;
    }
    .card-targetarea {
        font-size: 12px;
    }
}






.wrap-sale{
    margin-bottom: 30px;
    border-radius: 4px;
    box-shadow: 0px 0px 6px 0px rgba(231,231,231,1);
    padding: 15px;
    display: block;
    background:#ffe900;
    text-decoration: none !important;
}
.wrap-sale:hover{
    text-decoration: none !important;
}
.sale-title{
    color: #333;
    text-align: center;
    padding: 15px 0 15px 0;
    position: relative;
    font-size: 18px;
    font-weight: bold;

}
.sale-title:after{
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 1px;
    background: url(/static/img/tour/megurip/line-dotted.webp) left center repeat-x;
    content: "";
}
.sale-title:before{
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 1px;
    background: url(/static/img/tour/megurip/line-dotted.webp) left center repeat-x;
    content: "";
}
.sale-label{
    background:red;
    border-radius: 1px;
    margin-right: 10px;
    font-size: 16px;
    padding: 1px 15px;
    font-weight: bold;
    position: relative;
    color: #fff;
    top: -1px;
}
.sale-body{
    padding: 15px 15px 15px 15px;
    background:#fff;
}
.wrap-sale:hover .sale-body{
    background:;
}
.sale-btn{
    display: inline-block;
    margin:15px auto 0 auto;
    background: #f53d7e;
    border-radius: 2px;
    text-align: center;
    padding: 8px 20px;
    color: #fff;
}
.wrap-sale:hover .sale-btn{
    color: #fff;
}
.sale-price{
    font-weight: bold;
}
.sale-price b{
    font-size: 140%;
    color: #f53c7f;
    margin-left: 10px;
}

.sale-deptitle{
    text-align: left;
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 5px;
}
.sale-roomprice{
    font-weight: bold;
    margin-bottom: 10px;
    font-size: 13px;
}
.sale-roomprice b{
    font-size: 140%;
    color: #f53c7f;
    margin-left: 10px;
}
.modal-list-departure + .sale-deptitle{
    margin-top: 25px;
    border-top: 1px dotted #ccc;
    padding-top: 15px;
}


@media (max-width: 768px) {
.sale-title{
    color: #333;
    text-align: center;
    padding: 5px 0 15px 0;
    font-size: 16px;
}
.sale-label{
    border-radius: 2px;
    margin-right: 0px;
    font-size: 14px;
    top: auto;
    display: block;
    margin-bottom: 5px;
}
.sale-price b{
    margin-left: 0px;
}
}




.card-plan-price p.goto-line,
.card-plan-price p.normal-line{
    text-align: right !important;
}
.card-plan-price span.goto_price .num{
    font-size: 19px;
}
.card-plan-price .goto_price span:after {
    font-size: 19px;
}
@media (max-width: 768px) {
.card-plan-price p.goto-line,
.card-plan-price p.normal-line{
    text-align: left !important;
}
.card-plan-price p.goto-line{
    margin-bottom: 6px;
}
.card-plan-price span.goto_price .num,
.card-plan-price span.normal .num{
    font-size: 13px !important;
}
.card-plan-price .goto_price span:after,
.card-plan-price .normal span:after {
    font-size: 13px !important;
}
.card-plan-price span.txt-label{
    display: block;
}

}

.txt-gotoobi{
    /*position: absolute;
    top: 20px;
    left: 5%;*/
    text-align: center;
    margin:0 auto;
}
.txt-gotoobi{
    font-size: 14px;
}
.txt-gotoobi i{
    font-size: 80%;
}
.txt-gotoobi b{
    font-size: 16px;
    font-weight: bold;
    color: #F53D7E;
}

@media (max-width: 768px) {
.txt-gotoobi{
    font-size: 13px;
}
.section-nav-ul + .txt-gotoobi{
    border-top: 1px dotted #ccc;
    margin:0 auto;
    width: 97%;
}
}


 /*	section-about
 ************************/

.section-about{
	padding: 40px 0 20px;
	background: #fafafa;
}

.bnr-timesale{
	width: 86%;
	max-width: 400px;
	margin: 20px auto 0;
}
.about-title{
	width: 60%;
	max-width: 300px;
}

.img-about{
	max-width: 800px;
	margin: 30px auto 0;
}
.guide-box{
		max-width: 800px;
	margin: 10px auto 0;	
}

.btn-guide{
	position: relative;
	text-align: center;
	display: block;
	background: #dd6460;
	color: #fff;
	font-weight: bold;
	width: 200px;
	padding: 8px 8px 8px 0;
	border-radius: 20px;
	
}

.btn-guide:hover{
	color: #fff;	
	
}
.btn-guide::after{
	position: absolute;
	content: "\f24d";
	font-family: "Font Awesome 5 Free";
    font-size: 15px;
    font-weight: 400;
	margin-left: 5px;
	
}

@media (max-width: 768px) {
	
.section-about{
	padding: 20px 0 20px;
}
	.section-about p{
		font-size: 14px;
	}
	.img-about{
		margin-top: 20px;
	}
	
	
}






.acc-box{
  margin:15px auto;
}
.acc-box .card-header{
    padding:5px;
    background: #faf2dc;
    border-bottom:none;
}
.acc-box .card-header .title-acc{
    font-size: 14px;
    font-weight: bold;
    margin:0;
}
.acc-box .card-header .title-acc button{
    background: none;
    text-align: left;
    color: #dc3545;
    padding:5px 0 5px 60px;
    position: relative;
    line-height: 1.4;
    display: block;
    width: 100%;
    font-weight: bold;
}
.acc-box .card-header:first-child{
    border-radius: 0;
}
.acc-box .card{
    border-radius: 0;
    border: 1px solid #efe1bb;
    border-bottom: 1px solid #efe1bb;
}
/*.acc-box .card + .card{
  border-bottom: 1px solid #efe1bb;
}*/
.acc-box .card-body{
    padding:5px 10px;
    background: #fffcf4;
    margin-bottom: 0;
    border-radius: 0;
}
.acc-box .card-body p{
  line-height: 1.6;
    font-size: 14px;
    color: #555;
}
.acc-box .card-header button:after {
    margin-left: 10px;
    content: "\f077";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;

}
.acc-box .card-header button.collapsed:after {
    content: "\f078";
}
.acc-box .label{
    margin-right: 10px;
    position: absolute;
    top: 6px;
    left: 0;
    padding: 3px 4px 2px;
    font-weight: normal;
    background-color: #b9923b;
    color: #fff;
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
    border-radius: .25em;
    display: inline;
    font-size: 75%;
    line-height: 1;
}
.collapse.in{
    display: block;
}
@media (max-width: 767px) {
.acc-box .card-header button:after {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    margin-left: 0;
    right: 0px;
}
.acc-box .card-header .title-acc button{
    padding:0 10px 0 60px;
}
.acc-box .label{
  top: 1px;
}
}

/* TimeSale(水Wバナー)
--------------------------------------------------------- */
.wed-timesale {
	width: 60%;
	margin: 30px 20%;
}
@media (max-width: 767px) {
	.wed-timesale {
		width: 100%;
		margin: 15px 0;
	}
}
/* 一覧サムネイルTabサイズの一部画像のサイズ調整
--------------------------------------------------------- */
@media(min-width : 768px) and (max-width : 991.98px) {
	.img-fluid.edit {
		object-fit: cover;
		height: 163px;
	}
}



/*全国支援誘導パーツ*/
.ryokoshien-box{
    padding: 15px 30px;
    background: #fffdf6;
    border: solid 3px #8ec31f;
    width: 100%;
    max-width: 890px;
    margin: 0 auto;
    border-radius: 4px;
}
.inner-ryokoshien-box{
    display: flex;
    width: 100%;
}
.inner-ryokoshien-box:before{
    content: "";
    display: block;
    width: 100px;
    height: 100px;
    background: url(/static/img/campaign/ryokoshien/logo-goto-w.png) no-repeat;
    background-size: cover;
}
.inner-ryokoshien-box > div{
    width: calc(100% - 120px);
    padding-left: 20px;
}
.ryokoshien-box p{
    font-size: 14px;
    line-height: 1.6;
    margin: 0;
    text-align: left;
}
.title-ryokoshien-box{
    color: #fff;
    font-size: 16px;
    font-weight: bold;
    margin:-15px -32px 10px;
    text-align: center;
    background: #8ec31f;
    padding: 8px;
}
.ryokoshien-box dl{
    display: flex;
    font-size: 14px;
}
.ryokoshien-box dl + dl{
    margin-top: 5px;
}
.ryokoshien-box dt{
    width: 100px;
    text-align: left;
}
.ryokoshien-box dd{
    width: calc(100% - 100px);
    text-align: left;
}
.ryokoshien-box dd small{
    display: block;
    line-height: 1.4;
}
@media(max-width:767px) {
.ryokoshien-box{
    padding: 10px 10px;
}
.title-ryokoshien-box{
    display: flex;
    font-size: 16px;
    text-align: left;
    margin:-12px -12px 10px;
}
.title-ryokoshien-box:before{
    content: "";
    display: block;
    width: 80px;
    height: 80px;
    background: url(/static/img/campaign/ryokoshien/logo-goto-w.png) no-repeat;
    background-size: cover;
}
.title-ryokoshien-box > span{
    width: calc(100% - 80px);
    padding-left: 20px;
}
.inner-ryokoshien-box:before{
    display: none;
}
.inner-ryokoshien-box > div{
    width: 100%;
    padding-left:0px;
}
.ryokoshien-box dl{
    display: block;
}
.ryokoshien-box dt{
    width: 100%;
}
.ryokoshien-box dt:before{
    content: "▼";
    margin-right: 3px;
    color: #da4453;
}
.ryokoshien-box dd{
    width: 100%;
}
}


/* 隠しバス
----------------------------------------------------*/
.hit-img {
  animation: poyon 1.2s infinite;
  width: 25%;
  height: auto;
}
/* 768px以上 */
@media only screen and (min-width: 768px) {
  .hit-img {
    width: 40%;
    height: auto;
  }
}
@keyframes poyon {
  0%   { transform: scale(1.0, 1.0) translate(0%, 0%); }
  15%  { transform: scale(0.9, 0.9) translate(0%, 5%); }
  30%  { transform: scale(1.3, 0.8) translate(0%, 10%); }
  50%  { transform: scale(0.8, 1.3) translate(0%, -10%); }
  70%  { transform: scale(1.1, 0.9) translate(0%, 5%); }
  100% { transform: scale(1.0, 1.0) translate(0%, 0%); }
}

.btn-stripe {
  padding: 15px 25px 15px 15px;
  display: flex;
  justify-content: center;
  background: url(/static/img/index/bg-stripe-pink.png) left top;
  border: 8px solid #fafafa;
  border-radius: 3rem;
  font-weight: bold;
  color: #333;
  font-size: 14px;
  max-width: 86%;
  margin: 0 auto;
}
/* 768px以上 */
@media only screen and (min-width: 768px) {
  .btn-stripe {
    width: 100%;
    max-width: 100%;
    margin-top: 0;
    padding: 20px 50px 20px 25px;
    font-size: 18px;
  }
}
.btn-stripe::after {
  position: absolute;
  right: 20px;
  content: "\f105";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  color: #f53d7e;
  margin-left: 10px;
}

/* #search-area
------------------------------------------*/
#search-area{
	padding-top:30px;
	padding-bottom:0px;
	line-height: 1.2;
}
#search-day{
	float:left;
	width:30%;
	margin-bottom:20px;
}
#search-map{
	float:right;
	width:68%;
	margin-bottom:20px;
}
#search-plan{
	clear:both;
}
.search-box{
	position:relative;
	padding:0 20px 20px;
	background:#fff;
	box-shadow:0 0 4px rgba(0,0,0,0.15);
	border-radius:3px;
	overflow:hidden;
}
.search-box .title-style01{
	margin:0 -20px 20px;
	border-radius:3px 3px 0 0;
}


/* #search-day */
#search-day dt{
	margin:20px 0 5px;
	font-weight:normal;
}
#search-day dt i{
	color:#f8689b;
}
.form-inline{
	margin-bottom: 5px;
}
#search-day .btn-style01{
	margin-top:10px;
}
#search-day select{
	margin:0;
	margin-bottom:5px;
	width: 49%;
	color: #222222;
}
#search-day .btn-select-design-dep-area select,
#search-day .btn-select-design-arriv-area select{
	width: 100%;
}
#search-day select + select{
	margin-left:2%;
}
#search-day .usj_ken{
	width: 100%;
}
#search-day .usj_ken select{
	width: 100%;
}
#search-day .ver-test .usj_ken{
	width: 90%;
}
.detepicker-design{
	display: block;
	width: % !important;
	background: url(/static/img/common/icon/i-nav-day.png) #fff no-repeat 90% 50% !important;
	cursor: pointer;
	margin-bottom: 5px;
}
.ver-test .detepicker-design{
	width: 90% !important;
	background: url(/static/img/common/icon/i-nav-day.png) #fff no-repeat 98% 50% !important;
	margin-left: 0;
}
.text-required{
	font-size: 12px;
	display: inline-block;
	background: #ef3c4d;
	border-radius: 4px;
	padding: 4px 5px 3px;
	line-height: 1;
	color: #fff;
	text-align: center;
	margin: 0 auto;
}
.detepicker-design::placeholder{
	color: #222222;
}
/* #search-map */
.map-img{
	position:absolute;
	top:80px;
	right:10px;
	width:310px;
	height:270px;
	background:url(/tour/campaign/tdr/img/2017/map/all.png) no-repeat center center;
	z-index:1;
}
.map-list{
	position:relative;
	margin:0;
	padding-left:65px;
	font-size:14px;
}
.map-list.kyusyu{ padding-right:320px; }

.map-list:after{
	content:"";
	display:block;
	clear:both;
}
.map-list dt{
	position:absolute;
	top:3px;
	left:0;
	font-weight:normal;
	text-align:center;
}
.map-list dd{
	position:relative;
	float:left;
	margin:0 10px 1px 0;
	padding:2px 0;
	z-index:2;
}
.map-list dt a,
.map-list dd a{
	display:block;
	padding:2px 4px;
	border-radius:5px;
}
.map-list dt a{
	width:52px;
	font-size:13px;
	color:#fff!important;
	text-decoration:none!important;
}
.map-list .on{
	text-decoration:none!important;
	color:#fff!important;
	background:#f8689b;
}
/* color */
.map-list.hokkaido dt a{ background:#007ddb; }
.map-list.tohoku dt a{ background:#4db8f0; }
.map-list.hokushinetsu dt a{ background:#9435b8; }
.map-list.tokai dt a{ background:#ef3c4d; }
.map-list.kansai dt a{ background:#f68732; }
.map-list.chugoku dt a{ background:#9ba61d; }
.map-list.shikoku dt a{ background:#66aa2f; }
.map-list.kyusyu dt a{ background:#f54b6b; }
.map-list.okinawa dt a{ background:#e23be2; }


@media (max-width: 991px) {
	#search-day{
		width:40%;
	}
	#search-map{
		width:57%;
	}
	.map-list dd{
		margin-right:5px;
	}
}
@media (max-width: 767px) {
	#search-day{
		float:none;
		width:100%;
		height:auto;
		margin-bottom: 10px;
	}
	.search-box{
		box-shadow:none;
	    padding: 0;
	    overflow: initial;
	}
	.search-box .title-style01{
		margin:0 0 10px;
	}
	/* #search-day */
	#search-day dt{
		margin:10px 0 5px;
	}
	#search-day .btn-style01{
		margin:10px auto 0;
	}
	#search-day select{
		display: inline-block;
	}
	#search-day .ver-test .usj_ken{
		width: 78%;
	}
	.ver-test .detepicker-design{
		width: 78% !important;
	}
}


.box-timesale{
	display: flex;
	align-items: center;
	padding: 20px;
	font-size: 18px;
	text-align: left;
	background: #fff;
	border: 5px solid #e7d38e;
	width: 90%;
	margin: 10px auto;
}

.box-timesale li:first-child{
width: 25%;
	padding-right: 20px;
}

.box-timesale li:last-child{
	width: 75%;
}


.txt-red{
	color: #BA2425;
	font-weight: bold;
}
.txt-link{
	text-decoration: underline;
	color: #2086D1;
	text-align: right;
	display: block;
}

@media (max-width: 767px) {
	
	
.box-timesale{
	padding: 10px;
	width: 100%;
		border: 4px solid #e7d38e;
	font-size: 13px;
}

.box-timesale li:first-child{
width: 42%;
	padding-right: 10px;
}

.box-timesale li:last-child{
	width: 58%;
}
	
	
	
	
	
}