@charset "utf-8";
.nosp {
    display: none!important;
}
.contents {
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "游ゴシック Medium", "Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "メイリオ", Meiryo, sans-serif;
	color: #333;
	font-size: 3.5vw;
	line-height: 1.5em;
	background: #fef9e8;	
}
.contents .inner {
    width: 96vw;
    margin: 0 auto;
}

/*------------------------------------------------
	メインビジュアル
--------------------------------------------------*/
#mainvisual {
	width: 100%;
	text-align: center;
    background: url("../images/main-sp.png") no-repeat top center;
    background-size: 100%;
	height: 200px;
	position: relative;
}
#mainvisual .inner {
    width: 100%;
}
#mainvisual .title {
}
#mainvisual .title img {
    width: 100%;
}
#mainvisual .lead {
	width: 100%;
	padding: 3vw 2vw;
	font-weight: bold;
	background-color: #fef9e8;
	font-size: 3.3vw;
	line-height: 1.4;
}

/*------------------------------------------------
	受付インフォメーション
--------------------------------------------------
.sc_info {
  padding: 5vw 3vw;
  font-size: 3.3vw;
 background-color: #fef9e8;
}
.emphasis {
    font-weight: bold;
}
*/
/*------------------------------------------------
	ページナビ
--------------------------------------------------*/
#navi {
    width: 100%;
}
#navi .menu {
    display: flex;
    background: #ffc107;
    justify-content: center;
	color: #fff;
}
.navi_subtitle{
	font-size:12px;
}
#navi .menu > li {
    text-align: center;
    font-size: 3.6vw;
	font-weight: bold;
}
#navi .menu > li .subopen {
	display: none;
}
#navi .menu > li:nth-child(1) {
	width: 50%;
}
#navi .menu > li:nth-child(2) {
	width: 50%;
    border-left: 1px solid #fff;
	display: flex;
	justify-content: center;
}
#navi .menu > li .submenu {
	display: flex;
	justify-content:center;
    font-size: 3.6vw;
	font-weight: bold;
}
#navi .menu > li .submenu li {
	width: 100%;
	display: flex;
	justify-content: center;
}
#navi .menu > li .submenu li:first-child {
	border-right: 1px solid #fff;
}
#navi .menu li a {
	display: block;
    color: #fff;
    text-decoration: none;
	padding: 2vw 0;
}
#navi .menu li a:after {
    font-family: FontAwesome;
    content: "\f107";
	margin-left: 1vw;
}
#navi.fixed {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1000;
    box-shadow: 0px 1px 2px 0px rgb(0 0 0 / 30%);
}
#navi.fixed .menu {
	padding: 1vw 0;
}
/*#navi.fixed a.active {
	border-bottom: 3px solid #fff;
}*/
/*------------------------------------------------
	商品
--------------------------------------------------*/
.lead-text{
    font-size: 4.2vw;
    text-align: center;
	margin-bottom: -12vw;
	margin-top:50px;
    color: #F57C00;
    font-weight: bold;
}

#kaigai,#kaigai_corner,#kokunai,#search {
	padding-top: 16vw;
	padding-bottom: 1vw;
}
#tour {
    background: #E8F0F7;
}
#fit {
    background: #fef9e8;
    padding-top: 16vw;
	padding-bottom: 12vw;
}
#searchArea {
    background: #E8F0F7;
    padding-top: 16vw;
	padding-bottom: 12vw;
}
#tour h2,#fit h2,#search h2 {
    text-align: center;
    margin-bottom: 5vw;
}
#tour h2 .heading,
#search h2 .heading,
#fit h2 .heading {
    position: relative;
    display: inline-block;
   /* padding-left: 1.3em;*/
    font-size: 6vw;
    line-height: 1;
	font-weight: bold;
}
#tour h2 .heading-text,
#fit h2 .heading-text{
    font-size: 3.5vw;
    text-align: center;
    margin-bottom: 2vw;
    display: block;
    line-height: 1.4em;
	color: #ff4848;
	font-weight: bold;
}
#tour h2 .heading-icon,
#fit h2 .heading-icon{
    position: absolute;
    display: inline-block;
    width: 8.5vw;
    top: -2vw;
    left: -1vw;
}
#tour h3 {
    padding-top: 13vw;
}
#tour h3 span {
    display: block;
    font-size: 4.5vw;
    line-height: 1.3em;
    color: #fff;
    background-color: #1e2958;
    text-align: center;
    padding: 1vw 0;
}
.product__list {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
}
#kaigai .product__list {
	min-height: 52vw/*レイアウトシフト対策*/;
} 
.product__list > li:empty {
    display: none;
}
.product__list--item {
    width: 49%;
    margin: 0 0.5%;
    margin-bottom: 3vw;
    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: 30vw;
    background: #f2f2f2 no-repeat center bottom / cover;    
}*/
.product__list--image img{
    width: 100%;
    vertical-align: bottom;
}
.product__list--type {
    font-size: 3.0vw;
    color: #fff;
    background: #191919;
    padding: 2px 4px 1px 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: 3.5vw;
    margin: 2vw 0;
    font-weight: bold;
    line-height: 1.4em;
}
.product__list--texts > [class*="product__list--"]:not(.product__list--type) {
    padding: 0 1vw;
}
.product__list--detail {
    font-size: 3.0vw;
    line-height: 1.5;
}
.product__list--inner {
    background: #fff;
    color: inherit;
    text-decoration: none;
    display: flex;
    font-size: 12px; 
    flex-direction: column;
    height: 100%;
	border-radius: 0;
}
.product__list--inner:hover {
    opacity: 0.7;
    transition: all 0.6s ease; 
}
.product__list--dep {
    font-size: 2.3vw;
    letter-spacing: -0.05em;
    margin-top: 1vw;
    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: 3.4vw;
    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: 2vw 1vw;
    margin-top: auto;
}
.product__list--notes {
    font-size: 2.4vw;
    color: #333;
    margin-top: 0.5vw
}
.product__list--point.is-color-gold{
  background: #ff0000;
	padding: calc(5vw / 7.5) 0;
    margin-bottom: calc(5vw / 7.5);
    width: 100%;
    color: #fff;
    text-align: center;
	font-size: 2.6vw;
}
.product__list--point:empty {
    display: none;
}
/*air*/
.is-air .product__list--title {
	padding: 1vw!important;
}
.is-air .product__list--title--tokuten {
	font-size: 3vw;
	display: block;
}
.is-air .product__list--title--text {
	font-size: 4vw;
	line-height: 1.5em;
}
.is-air .product__list--minmax {
	font-size: 4vw;
	line-height: 1;
    padding-bottom: 1vw;
}
.is-air .product__list--minmax .dpt {
	font-size: 0.6em;
	line-height: 1.5em;
	font-weight: normal;
	margin-left: 5px;
}
.is-air .product__list--more {
	margin: 1vw 0 3vw;
	font-size: 2.7vw;
	line-height: 1.5em;
}

/*icon*/
.product__list--label {
    position: absolute;
    top: 0;
    left: 0;
    flex-direction: column;
    /*min-width: 20vw;*/
}
.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;
    font-size: 2.8vw;
    line-height: 1.0em;
    font-weight: bold!important;
}
.product__list--label--other {
    background: #f31e1f;
    width: auto;
    padding: 1.5vw 1vw 1vw;
    color: #fff!important;
}
.price_note {
    font-size: 3.1vw;
    margin-top: 5vw;
}

/*ナビ*/
.area-navi {
    margin-bottom: -5vw;
}
.area-navi ul {
    width: 94vw;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    background-color: #cacaca;
    padding: 2vw 1vw 0;
}
.area-navi ul li {
    width: 48%;
    height: 11vw;
    font-size: 3.3vw;
    line-height: 1.2em;
    font-weight: bold;
    border-radius: 1vw;
    margin: 0 1% 2vw;
    text-align: center;
}
.area-navi ul li a {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: inherit;
    text-decoration: none;
    background-color: #fff;
    border-radius: 1vw;
    padding: 1vw 2vw 1vw 1vw;
    position: relative;
}
.area-navi ul li a:after {
    font-family: FontAwesome;
    content: "\f107";
    position: absolute;
    right: 1vw;
}
.more-btn{
    width: 88%;
    margin: 5vw auto 0;
}
.more-btn a {
	font-size: 3.8vw;
    color: #fff;
    font-weight: bold;
	display: block;
	text-decoration: none;
	padding: 16px 20px;
    background-color:#ff3444;
    /*border: solid 1px #ffe922;*/
	text-align: center;
  border-radius: 28px;
  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;*/
	  opacity: 0.8;
}
.more-btn  a:after {
    font-family: FontAwesome;
    content: "\f105";
	padding-left: 10px;
}
.price_note {
    font-size: 3.0vw;
    margin-top: 2vw;
}
/*----------------------------------------------
	バナー
------------------------------------------------*/
.bnr-area {
    width: 94vw;
    margin: 12vw auto 0;
}
.bnr-area img {
    width: 100%;
}

/*----------------------------------------------
	施策案内
------------------------------------------------*/
.shisaku-list {
    position: relative;
    margin: 5vw auto 0;
    background: #fff;
    padding: 5vw 3vw 3vw 3vw;
    font-size: 3.5vw;
}
.shisaku-list .read {
    font-size: 4vw;
    font-weight: bold;
    text-align: center;
    color: #ff0000;
}
.shisaku-list li a {
    text-decoration: none;
    color: #333;
}
.shisaku-list:before {
    content: "";
    position: absolute;
    top: -35px;
    left: 50%;
    margin-left: -20px;
    border: 6vw solid transparent;
    border-bottom: 20px solid #fff;
}
.shisaku-list .ttl {
    font-weight: bold;
    display: inline-block;
    padding: 1vw 2vw 0.5vw;
    margin-bottom: 1vw;
    line-height: 1;
}
.shisaku-list li {
    line-height: 1.4em;
    margin-bottom: .5vw;
}
.shisaku-list .kaigai {
    margin-bottom: 2vw;
    line-height: 1;    
}
.shisaku-list .kokunai {
    line-height: 1;
}
.shisaku-list .kaigai .ttl {
    background: #11a4f7;
    color: #fff;
}
.shisaku-list .kokunai .ttl {
    background: #0abe01;
    color: #fff;
}
.coupon-name {
    font-weight: bold;
    display: inline-block;
}
.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 2px 2px;
    width: 57vw;
    justify-content: center;
    margin: 0 auto 1vw;
    letter-spacing: .1em;
}
.shisaku-list .catch a {
    text-decoration: none;
    color: #333;
}    
/*----------------------------------------------
	終了
------------------------------------------------*/
#close {
    padding: 20vw 0;
    background-color: #e7e7e7;
    text-align: center;
    font-size: 4.0vw;
    line-height: 1.6em;
}

/*----------------------------------------------
	完売対応
------------------------------------------------*/
.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.4);
    z-index: 101;
}
.product__list--item a.kanbai .kanbai-text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(-7deg);
    margin: auto;
    font-size: 6.0vw;
    font-weight: bold;
    color: #fff;
    text-align: center;
    z-index: 102;
    background-color: #f00;
    width: 40vw;
    padding: 2.8vw 0 1.7vw;
}
/*------------------------------------------------
        スマホ横向き時の余白調整
--------------------------------------------------*/
.breadcrumb {
    width: 100%;
}
/*------------------------------------------------
        LINEお友達登録ボタン
--------------------------------------------------*/
.line-wrap-simple {
    padding: 5vw 0;/*ページによって調整*/
}
.line-wrap-detail {
    padding: 15vw 0;/*ページによって調整*/
    /* background-color: #fff; */
}
.line-inner {
    width: 94vw;
    margin: 0 auto;
    text-align: center;
    letter-spacing: 0.1vw;
    line-height: 1.5;
}
.line-wrap-detail .line-inner {
    background: #fcfff6;/*ページによって調整*/
    border: solid 1px #d3d3d3;
}
.line-inner .fukidashi {
    font-size: 4.1vw;
    font-weight: bold;
    margin-bottom: 2vw;
}
.line-inner .head {
    background-color: #15c618;
    padding: 2vw 0;
    color: #fff;
    font-size: 4.3vw;
    font-weight: bold;
}
.line-inner .textarea {
    padding: 4vw 2vw 2vw;
}
.line-inner .btnarea {
    padding: 2vw 2vw 5vw;
}
.line-inner .text1 {
    font-size: 3.4vw;
    line-height: 1.5em;
    margin-bottom: 1vw;
}
.line-inner .text1 span {
    display: inline-block;
    font-weight: bold;
    color: #fb0b0b;
    background-color: #ffe1e1;
    padding: 0 0.5vw;
}
.line-inner .text2 {
    font-size: 4.1vw;
    font-weight: bold;
    background: linear-gradient(transparent 60%, #fff231 0%);
    line-height: 1.7em;        
    display: inline-block;
}
.line-button {
    margin: 0 auto;
}
.line-wrap-simple .line-button {width: 90vw;}
.line-wrap-detail .line-button {width: 80vw;}

.line-button a {
    display: block;
    color: #fff;
    font-size: 3.5vw;
    font-weight: bold;
    border-radius: 8vw;
    box-shadow: 0px 3px 0px 0 rgba(0, 0, 0, .14);
    background: url(/kansai/images/icon/icon-linekansai.png) no-repeat;
    background-size: 12vw;
    background-position: 3vw;
    background-color: #15c618;
    padding: 2.4vw 4vw 1.8vw 16vw;
    position: relative;
    text-decoration: none;
}
.line-button a span.small {
    display: block;
    font-size: 2.8vw;
    font-weight: normal;
}
.line-button a span.strong {
    display: block;
}
.line-button a span.strong::after {
    font-family: "FontAwesome", "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f138";
    font-size: 4vw;
    margin-left: 1.4vw;
}
.line-button a span.line-friend {
    font-size: 1.3em;
    color: #fff231;
    padding: 0 0.5vw;
}
/*------------------------------------------------
	下部バナー（フェア）
--------------------------------------------------*/
#bnrarea-foot {
	/* background: #fff3cf; */
    padding: 5vw 0 0!important;
}
#bnrarea-foot p span.strong{
	font-size: 5.2vw;
    /*background: linear-gradient(transparent 60%, #fff231 0%);*/
    padding: 0 1vw;
}
/*
#bnrarea-foot .fukidashi {
	display: none;
}
*/
#bnrarea-foot .excl {
	display: inline-block!important;
}