@charset "utf-8";
.nopc {
    display: none!important;
}
.contents {
    font-family: "Yu Gothic Medium", "游ゴシック Medium", "Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
    color: #333;
    font-size: 15px;
    line-height: 1.5em;
}
.contents .inner {
    width: 992px;
    margin: 0 auto;
}

/*------------------------------------------------
	メインビジュアル
--------------------------------------------------*/
#mainvisual {
	width: 100%;
	height: 400px;
	text-align: center;
    background: url("../images/main-bg-pc.png") no-repeat top center;
}
#mainvisual .inner {
    height: 100%;
    position: relative;
}
#mainvisual .title img {margin-top: 40px;}

#mainvisual .lead {
	position: absolute;
	top: 300px;
	right: 0;
	left: 0;
	width: 600px;
	margin: 0 auto;
	font-weight: bold;
	background-color: rgb(255 255 255 / 70%);
	/*font-size: 16px;*/
    line-height: 1.5em;
	color: #000;
	padding: 5px 0;
}
/*------------------------------------------------
	受付インフォメーション
--------------------------------------------------*/
.sc_info {
   background-color: #ffffff;
   padding:30px;
}
.emphasis {
    padding: 25px 0;
    width:992px;
    margin:0 auto;
	text-align: center;
	color: #000;
	font-size: 18px;
    line-height: 1.6em;
	font-weight: bold;
	padding-top:20px;
}

.kikan {
	color:#e7141a;
	font-weight:bold;
	text-align:center;
	font-size:20px;
	/* margin:10px; */
}

.kikan span {
	background: #ffffff;
	padding:10px 100px;
	border:3px solid;
	border-radius:10px;
}
/*------------------------------------------------
	ページナビ
--------------------------------------------------*/
#pageNavi {
    width: 100%;
    background: #e7141a;
    border-top: 1px solid #fff;
}
#pageNavi ul {
	  width: 960px;
	  margin: 0 auto;
	  display: flex;
	  flex-wrap: wrap;
	  background: #e7141a;
	  justify-content: center;
	  padding: 1.2vw 0 0.2vw 0;
}
#pageNavi ul li {
    width: 20%;
    font-size: 1.1em;
    line-height: 1.3em;
    font-weight: bold;
    text-align: center;
    border-left: 1px solid #fff;
}
#pageNavi ul li:first-of-type {
    border-left: none;
}



#pageNavi ul li a {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    padding-bottom: 1.5vw;
    text-decoration: none;
    position: relative;
}
#pageNavi ul li a:after {
    font-family: FontAwesome;
    content: "\f107";
    position: absolute;
    bottom: 0;
}
#pageNavi.fixed {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1000;
    box-shadow: 0px 1px 2px 0px rgb(0 0 0 / 30%);
}
#pageNavi.fixed ul {
    padding: 1vw 0;
}
#pageNavi.fixed ul li {
    height: 5vw;
}
#pageNavi.fixed ul li a:after {
    font-family: FontAwesome;
    content: "\f107";
    position: absolute;
    bottom: -.5vw;
}
@media (orientation: landscape){
    #pageNavi.fixed ul {
        padding: 1.2vw 0;
    }
    #pageNavi.fixed ul li {
        height: 2vw;
        font-size: 1.2vw;
    }  
}
/*------------------------------------------------
	施策
--------------------------------------------------*/
#shisaku { 
    width: 100%;
    background: #fff;
    padding: 30px 20px;
    border: dashed 2px #da0f00;
    text-align: center;
    margin-bottom: 60px;
}
#shisaku .catch {
    font-size: 21px;
    font-weight: bold;
    line-height: 1.4em;
    background: linear-gradient(transparent 60%, #fff100 0%);
    display: inline;
    padding: 0 5px 0 10px;
}
#shisaku .text {
    margin-top: 13px;
    font-size: 18px;
    line-height: 1.5;    
}
/*------------------------------------------------
	商品
--------------------------------------------------*/
#kaigai, #kokunai,#air,#airhtl,#dp {
    margin-bottom: 110px;
}
#tour {
    background: #ffffff;
    padding: 80px 0 10px;
}
#tour h2 {
    text-align: center;
    margin-bottom: 10px;
}
#tour h2 .heading {
    position: relative;
    display: inline-block;
   /* padding-left: 1.3em;*/
    font-size: 40px;
    line-height: 1;
	font-weight: bold;
}
#tour h2 .heading-text {
    font-size: 16px;
    text-align: center;
    margin-bottom: 9px;
    display: block;
    line-height: 1.5em;
	color: #e7141a;
	font-weight: bold;
}
#tour h2 .heading-icon {
    position: absolute;
    display: inline-block;
    width: 38px;
    top: -7px;
    left: -3px;
}
.product__list {
    flex-grow: 1;
    display: flex;
    flex-wrap: wrap;
    width: calc(100% + 10px);
    margin-left: -10px;
    margin-top: -15px;
}
.product__list > li:empty {
    display: none;
}
.product__list > li:hover {
    opacity: 0.7;
    transition: all 0.6s ease;
}
.product__list--item {
    width: 240px;
    margin-left: 10px;
    margin-top: 15px;
    letter-spacing: .5px;
    list-style: none;
    border: 1px solid rgba(0, 0, 0, .23);
    position: relative;
}
.product__list--item:empty{
	display: none;
}
.product__list--data {
    height: 100%;
    display: flex;
    flex-direction: column;
}
/*.product__list--image {
    height: 160px;
    background: #f2f2f2 no-repeat center bottom / cover;    
}*/
.product__list--image-wrapper img{
    width: 100%;
    vertical-align: bottom;
}
.product__list--type {
    font-size: 12px;
    color: #fff;
    background: #191919;
    padding: 4px 4px 3px 4px;
    text-align: center;
}
.product__list--type.port-type::after {
    content: "発着";
}
.product__list--text-wrapper {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    line-height: 1.2;
}
.product__list--title {
    font-size: 15px;
    margin: 8px 0;
    font-weight: bold;
    line-height: 1.3em;
}
.product__list--texts > [class*="product__list--"]:not(.product__list--type) {
    padding: 0 10px;
}
.product__list--detail {
    line-height: 1.5;
}
.product__list--inner {
    background: #fff;
    color: inherit;
    text-decoration: none;
    display: flex;
    font-size: 12px; 
    flex-direction: column;
    height: 100%;    
}
.product__list--inner:hover {
    opacity: 0.7;
    transition: all 0.6s ease; 
}
.product__list--price > :not(.product__list--point):not(.product__list--notes) {
    padding-left: 4px;
}
.product__list--dep {
    font-size: 12px;
    margin-top: 2px;
    letter-spacing: 0.2px;
    color: #333;
}
.product__list--dep .js-split-departure::after,
.product__list--dep span[id*="dep_"]::after{
  content: "出発";
}
.product__list--dep .js-split-departure:empty::after,
.product__list--dep span[id*="dep_"]:empty::after{
  display: none;
}
.product__list--minmax {
    font-size: 18px;
    color: #e90000;
    font-weight: bold;    
}
.product__list--minmax .minmax-new:not(:empty) + .minmax-old,
.product__list--dep .js-split-departure:not(:empty) + span,
.product__list--type .js-split-airport:not(:empty) + span {
    display: none;
}
.product__list--texts {
    display: flex;
    flex-direction: column;
}
.product__list--price {
    padding: 20px 4px 10px;
    margin-top: auto;
}
.product__list--point {
	background-color:#e90000;
	text-align:center;
	color:#fff;
	padding:3px;
	font-weight:bold;
	margin-bottom:5px;
}


/*icon*/
.product__list--label {
    position: absolute;
    top: 0;
    left: 0;
    flex-direction: column;
    min-width: 90px;
}
.product__list--label > [class*="product__list--label--"]:empty {
    display: none;
}
.product__list--label {
    display: flex;
    flex-wrap: wrap;
}
.product__list--label > [class*="product__list--label--"] {
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    z-index: 1;
    height: 25px;
    font-size: 12px;
    font-weight: bold!important;
}
.product__list--label--other {
    background: #f31e1f;
    width: auto;
    padding: 0 8px;
    color: #fff!important;
}

.more-btn{
    width: 800px;
    margin: 40px auto 0;
}
.more-btn a {
	font-size: 15px;
    color: #000;
    font-weight: bold;
	display: block;
	text-decoration: none;
	padding: 10px 20px;
    background-color: #ffe922;
    /*border: solid 1px #ffe922;*/
	text-align: center;
  border-radius: 10px;
  box-shadow: 4px 4px 0 rgba(0 0 0 / 20%);
}
.more-btn  a:hover {
	transition: all 0.6s ease;
	background-color:#ffab00;
    /*border: solid 1px #000;*/
}
.more-btn  a:after {
    font-family: FontAwesome;
    content: "\f105";
	padding-left: 10px;
}
.price_note {
    font-size: 12px;
    margin-top: 30px;
}

.product__list--more--title, .is-sp .media-summary dt {
	display: inline-block;
	line-height: 1.2;
	background: #7d7d7d;
	color: #fff;
	text-align: center;
	
}

.product__list--more, .is-sp .media-summary {
  display: flex;
  align-items: baseline;
}

.product__list--more--title {
	padding: 2px 0 4px;
	width: 72px;
	margin-right: 5px;
	
}

.product__list--more--text {
  width: calc(100% - 72px - 5px);
}

.product__list--more {
    margin-top: 3px;
}

.product__list--tokuten {
	margin: 15px 10px 0;
	font-size: 11px;
	border-top-width: 1px;
}

.media-addList, .product__list--tokuten {
	color: #666;
	border-top: calc(1vw / 7.5) dashed;
	padding: .6em 0 0 !important;
	margin-top: 1em;
}

/*----------------------------------------------
	バナー
------------------------------------------------*/
.bnr-area {
    width: 960px;
    margin: 60px auto 30px;
}
.bnr-area img:hover {
    opacity: .7;
    transition: all 0.6s ease;
}

#banner h3 {

	font-weight:bold;
	font-size:30px;
	text-align:center;

}


.is-bnr {
	width:960px;
	overflow:hidden;
	margin: 35px auto 0;
	padding-bottom: 50px;
}
.is-bnr ul{ 
	width:100%; 
	padding:0 50px; 
	box-sizing: border-box;
}
.is-bnr li img{ 
	width:100%;
}
.is-bnr li img:hover{
	opacity: 0.8;
}
.is-bnr li {
	width: 25%;
    float: left;
    padding: 0 1%;
    box-sizing: border-box;
}

/*------------------------------------------------
	LINEお友達登録ボタン
--------------------------------------------------*/
.line-wrap-detail {
	padding: 0;
	margin-top: 50px;
    background: #fff;
}

.line-inner {
    background: #fff;
    border: solid 1px #d3d3d3;
    width: 992px;
    margin: 0 auto;
	text-align: center;
}
.line-inner .head {
	width: 100%;
    text-align: center;
    background-color: #15c618;
    padding: 6px;
    color: #fff;
    font-size: 20px;
    font-weight: bold;
}

.textarea {
	margin-top:10px;
}
.line-inner .text1 {
    font-size: 17px;
    line-height: 1.4em;
}
.line-inner .text1 span {
	font-weight: bold;
	color: #fb0b0b;
}
.line-inner .text2 {
    font-size: 21px;
    font-weight: bold;
    margin-bottom: -2px;
    background: linear-gradient(transparent 60%, #fff231 0%);
    display: inline-block;
    line-height: 1.7em;
    padding: 0 4px;
}
.line-button {
	width: 340px;
}
.line-button a {
	display: block;
    color: #fff;
    font-size: 20px;
    text-align: center;
    font-weight: bold;
    border-radius: 100px;
    box-shadow: 0px 3px 0px 0 rgba(0, 0, 0, .14);
    background-color: #15c618;
    padding: 14px 10px;
    position: relative;
    text-decoration: none;
}
.line-button a:hover {
	opacity: .8;
	transition: all 0.6s ease;	
}
.line-button a span.small {
	display: block;
	font-size: 14px;
	font-weight: normal;
}
.line-button a span.strong {
	position: relative;
	display: inline-block;
}
.line-button a span.strong::after {
    font-family: "FontAwesome";
    font-weight: 900;
    content: "▶";
	font-size: 20px;
	margin-left: 5px;
}
.btnarea {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;

	width:45%;
}

.box {
		margin:20px 0;
	display:flex;
	flex-wrap: wrap;
	align-items: center;
	text-align: left;
	justify-content:center;
	
}

.btnarea .line-qr {
	width: 43%;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	text-align: left;
}


.btnarea .line-qr:last-of-type {
	flex-wrap: nowrap;
	margin-left: 20px;

}
.btnarea .line-qr {
    display: inline-block;
    width: 80px;
    margin-right: 8px;
}
.btnarea .line-qr img {
	width: 100%;
}

/*----------------------------------------------
	施策案内
------------------------------------------------*/
.shisaku-list {
    position: relative;
    margin: 20px auto 0;
    background: #fff;
    padding: 22px 30px 17px;
    font-size: 16px;
}
.shisaku-list .read {
    font-size: 20px;
    font-weight: bold;
    text-align: center;
    color: #ff0000;
}
.shisaku-list li a {
    text-decoration: none;
    color: #333;
}
.shisaku-list li a:hover {
    text-decoration: underline;
}
.shisaku-list:before {
    content: "";
    position: absolute;
    top: -35px;
    left: 50%;
    margin-left: -20px;
    border: 20px solid transparent;
    border-bottom: 20px solid #fff;
}
.shisaku-list .ttl {
    font-weight: bold;
    display: inline-block;
    padding: 4px 7px 3px;
    margin-bottom: 5px;
    line-height: 1;
}
.shisaku-list .kaigai {
    margin-bottom: 5px;
}
.shisaku-list .kaigai .ttl {
    background: #11a4f7;
    color: #fff;
}
.shisaku-list .kokunai .ttl {
    background: #0abe01;
    color: #fff;
}
.coupon-name {
    font-weight: bold;
}
.shisaku-list .strong {
    color: red;
}
.shisaku-list .catch {
font-weight: bold;
    line-height: 1.4em;
    background: linear-gradient(transparent 55%, #fff100 0%);
    display: flex;
    padding: 0 0 1px 2px;
    width: 260px;
    justify-content: center;
    margin: 9px auto 4px;
    letter-spacing: .1em;
}
.shisaku-list .catch:hover {
    opacity: .7;
    transition: all 0.6s ease;    
}
.shisaku-list .catch a {
    text-decoration: none;
    color: #333;
}
/*----------------------------------------------
	検索ボックス
------------------------------------------------*/
#searchArea {
    padding-top: 50px;
}

/*----------------------------------------------
	終了
------------------------------------------------*/
#close {
    padding: 100px 0;
    background-color: #e7e7e7;
    text-align: center;
    font-size: 18px;
    line-height: 1.8em;
}
/*----------------------------------------------
	完売対応
------------------------------------------------*/
.product__list--item a.kanbai {
    pointer-events: none;
    position: relative;
}
.product__list--item a.kanbai:before {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background: rgba(0,0,0,0.3);
    z-index: 101;
}
.product__list--item a.kanbai .kanbai-text {
    position: absolute;
    top: 70px;
    right: 0;
    left: 0;
    margin: auto;
    font-size: 20px;
    font-weight: bold;
    color: #fff;
    text-align: center;
    z-index: 102;
    width: 160px;
    background-color: #f00;
    padding: 8px 0 5px;
    transform: rotate(-7deg);
}

 .end {
  font-size: 16px;
  line-height: 2em;
	 font-weight:bold;
	 text-align:center;
	 margin-bottom:50px;
}
.end span {
  font-size: 24px;
}

#countdown {
    background: #ffef00;
    padding: 20px　0;
    color: #e7141a;
    text-align: center;
	
	
}
.contents .inner {
    width: 992px;
    margin: 0 auto;
}
#countdown p {
    position: relative;
    padding-top: 20px;
    font-size: 22px;
    font-weight: bold;
    padding-bottom: 5px;
	line-height:2;
}

.count__text_end {
	padding:30px 0 !important;
	font-size:2em !important;
}

#countdown .timer {
    font-size: 42px;
    font-weight: bold;
    line-height: 1;
	padding-bottom:20px;
	
}
#countdown .timer .small {
    font-size: 27px;
    margin-right: -7px;
}
#countdown .timer .large {
    margin-right: 3px;
}
    
    .headfoot-is-sp #countdown .timer{
        font-size:32px;
    }
    .headfoot-is-sp #countdown .timer .small{
        font-size:22px;
    }

/***　特集バナー　****/
.spbn{
	text-align: center;
	filter: drop-shadow(1px 1px 1px rgba(0,0,0,0.3));
    margin: 0 auto;
	}
.spbn img{padding: 10px 0 10px;}
.w43 {width: 545px;}
.w43r{width: 545px; margin-left: 10px;}
.spbn a:hover{
	opacity:0.7;
	filter: alpha(opacity=70);
	-ms-filter: "alpha( opacity=70 )";
	transition: all 0.4s ease;
}
