@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@500;700;900&display=swap');
/* CSS Document */
:root{
  --content-color-red: #dc0e0e;
  --content-color-orange: #ff4302;
  --content-color-yellow: #fff03b;
  --content-color-green: #258002;
  --content-color-blue: #187a80;
  --bg-color-green: #ebfae5;
  --bg-color-blue: #d4f9fa;
}
.breadcrumb {
	max-width: 100%;
}
.contents {
	font-family: 'Noto Sans JP', sans-serif;
    font-size: 3.6vw;
    line-height: 1.5em;
	color: #222;
	
	& a {
		text-decoration: none;
		color: inherit;
	}
	& .inner {
		margin: 0 auto;
	}
	& img{
		width: 100%;
		vertical-align: bottom;
	}
}

/*tour_style_pc.cssとバッティングするため別名*/
.no-sp{
	display: none;
}

/*------------------------------------------------
	メインビジュアル
--------------------------------------------------*/
#mainvisual {
	width: 100%;
	height: calc(600vw / 7.5);
	background: url("../img/main-bg-sp.jpg") no-repeat top center;
	background-size: 100%;
	
	& .inner {
		position: relative;
	}
	& .title {
		padding-top: 10vw;
		width: calc(560vw / 7.5);
		margin: 0 auto;
	}
}

/*発地切り替え*/
.display_selected{
	width: 24vw;
	height: calc(80vw / 7.5);
	padding: calc(10vw / 7.5);
	background: #ff4302;
	font-size: calc(24vw / 7.5);
	font-weight: 700;
	color: #fff;
	text-align: center;
	position: absolute;
	right: 0;
	top: 0;
}
.display_selected::after{
	font-family: "Font Awesome 5 Free";
	font-weight: bold;
	content: "\f107";
	position: absolute;
	right: 0;
	left: 0;
	bottom: 0;
	line-height: 1.0em;
	margin: auto;
}
.dep-select-zone{
	display: none;
	width: 100vw;      
	height: 100vh;      
	position: fixed;      
	top: 0;      
	left: 0;
	transition: all .5s;       
	z-index: 50;
	background: rgba(0 0 0 / 80%);
	padding: calc(100vw / 7.5) calc(80vw / 7.5); 
}
.dep-select li{
	cursor: default;
	padding: calc(20vw / 7.5);
	font-size: calc(30vw / 7.5);
	color: #FFF;
	text-align: center;
}
.dep-select li:hover,
.dep-select li.selected{
	background: #fff;
	color: #000;
}
.close-button{
	margin: calc(40vw / 7.5) auto;
	width: 5em;
	padding: calc(10vw / 7.5);
	border: solid 1px #fff;
	font-size: calc(30vw / 7.5);
	color: #FFF;
	text-align: center;
}
.area00{
	display: none
}
.area00.is-display{
	display: block
}
/*------------------------------------------------
	導入
--------------------------------------------------*/
#lead {
	width: 100%;
	background: url("../img/lead-bg.jpg");
	background-size: 150px;
	padding: 10vw 0 25vw;
	position: relative;
	
	& .inner {
		width: 90vw;
	}
	& .text {
		font-size: 3.7vw;
		font-weight: 500;
		line-height: 1.4em;
		& .marker {
			background: linear-gradient(transparent 60%, var(--content-color-yellow) 0%);
		}
	}
	& .map {
		position: absolute;
		bottom: 3vw;
		right: 2vw;
		width: 54vw;
	}
}

/*------------------------------------------------
	共通特典
--------------------------------------------------*/
#cpn {
	width: 100%;
	background-image: url("../img/bg-wave.png"),url("../img/bg-dot.png");
	background-repeat: no-repeat,repeat;
	background-position: bottom center,top left;
	background-size: auto 30px,4px;
	padding: 0 0 15vw 0;
	
	& .inner {
		width: 94vw;
	}
}
#cpn h2 {
	background-color: #000;
	font-size: 5.8vw;
	font-weight: 900;
	line-height: 1.6em;
	letter-spacing: 0.05em;
	color: #fff;
	padding: 2vw 0;
	text-align: center;
	vertical-align: middle;
	margin-bottom: 5vw;
	
	&:before,
	&:after {
		content: "";
		display: inline-block;
		width: 10vw;
		height: 10vw;
		background: url("../img/icon-star.svg") no-repeat;
		background-size: contain;
		margin: 0 1vw;
		vertical-align: middle;
	}
	&:after {
		transform: scaleX(-1);
	}
}
#cpn h3 {
	text-align: center;
	margin-bottom: 5vw;
	font-size: 6.8vw;
	line-height: 1.4em;
	font-weight: 900;
	background-image: url("../img/illust-coupon.png"),url("../img/illust-hotel.png");
	background-repeat: no-repeat,no-repeat;
	background-position: left top 5vw,right top 5vw;
	background-size: 15vw,13vw;
	
	& .fuki {
		font-size: 0.8em;
	}
	& .marker {
		color: var(--content-color-orange);
		background: linear-gradient(transparent 70%, var(--content-color-yellow) 0%);
	}

}
#cpn .ttn {
	width: 100%;
	border: solid 2px var(--content-color-red);
	background-color: #fff;
	text-align: center;
	margin-bottom: 2vw;
	
	& h4 {
		width: 100%;
		background-color: var(--content-color-red);
		color: #fff;
		font-size: 5vw;
		line-height: 1.0em;
		font-weight: 700;
		padding: 1vw 0 2vw;
	}
}

/*クーポンテーブル*/
#cpn .table {
	width: 940px;
	text-align: center;
	border-collapse: collapse;
	background-color: #fff;
	
	& th,& td {
		font-size: 14px;
		border-left: 1px solid #ccc;
		border-top: 1px solid #ccc;
		padding: 3px 0;
	}
	& th {
		background-color: #fefde9;
	}
	& tr:last-child th,& tr:last-child td{
		border-bottom: 1px solid #ccc;
	}
	& th:first-child {
		border-left: none;
	}
	& tr:first-child th {
		border-top: none;
	}
	& .dpt th {
		&:nth-child(1) {width: 16%;}
		&:nth-child(2) {width: 28%;}
		&:nth-child(3) {width: 28%;}
		&:nth-child(4) {width: 28%;}
	}
}
#cpn .coupon .point {
	font-size: 22px;
	font-weight: 900;
	line-height: 1.0em;
	color: var(--content-color-red);
	
	& .person {
		display: block;
		font-weight: 700;
		font-size: 0.6em;
		line-height: 1.4em;
	}
	& .small {
		font-size: 0.8em;
	}
}
#cpn .detail {
	width: 100%;
	font-size: 13px;
	line-height: 1.5em;
	font-weight: 500;
	padding: 2vw 0;
	
	& a {
		color: #2381E4;
	}
}

#cpn .hotel {
	padding-bottom: 2vw;
	
	& .point {
		font-size: 7.0vw;
		font-weight: 900;
		line-height: 1.6em;
		color: var(--content-color-red);
		padding-top: 4vw;
		
		& .sub {
			display: block;
			font-size: 0.6em;
			font-weight: 700;
			line-height: 1.0em;
			color: #222;
		}
	}
	& .note {
		font-size: 3.3vw;
		line-height: 1.5em;
	}

}

/*------------------------------------------------
	ツアーナビ
--------------------------------------------------*/
#tour-navi {
	width: 100%;
	background-color: #000;
	padding: 3vw 0;
	
	& ul {
		width: 96vw;
		margin: 0 auto;
		display: flex;
		justify-content: center;
		& li {
			margin: 0 1vw;
			& a {
				display: block;
			}
		}
	}
}

/*------------------------------------------------
	ツアー
--------------------------------------------------*/
#tour .inner {
	width: 94vw;
}
#tour #hondo {
	width: 100%;
	background-color: var(--bg-color-green);
	padding: 8vw 0;
	
	& .inner {
		background: url("../img/illust-food.png") no-repeat right top 10vw / 20vw;
	}
}
#tour #rito {
	width: 100%;
	background-color: var(--bg-color-blue);
	padding: 8vw 0;
	
	& .inner {
		background-image: url("../img/illust-ship.png"),url("../img/illust-hat.png");
		background-repeat: no-repeat,no-repeat;
		background-position: left top 10vw,right top 10vw;
		background-size: 20vw,18vw;
	}
}
#tour h2 {
	height: 21vw;
	font-size: 4.6vw;
	line-height: 1.6em;
	color: #000;
	font-weight: 700;
	text-align: center;
	background: url("../img/tour-fukidashi-bg.png") no-repeat top center / contain;
	padding-top: 8.5vw;
	margin-bottom: 2vw;
}
#tour h3.point {
	font-size: 6.8vw;
	line-height: 1.3em;
	font-weight: 900;
	padding: 5vw 0 0 19vw;
	margin-bottom: 3vw;
	position: relative;
	
	& .marker {
		color: var(--content-color-orange);
		background: linear-gradient(transparent 70%, var(--content-color-yellow) 0%);
	}
	& .note {
		font-size: 3.8vw;
		font-weight: 700;
		padding-left: 2vw;
	}
	& .small {
		display: inline-block;
		font-size: 4.0vw;
		line-height: 1.0em;
	}
	&:before {
		content: "";
		display: inline-block;
		width: 19vw;
		height: 20vw;
		background-repeat: no-repeat;
		background-size: contain;
		position: absolute;
	}
	&.no01:before {background-image: url("../img/tour-point01.png");left: 0;bottom: 1vw;}
	&.no02:before {background-image: url("../img/tour-point02.png");left: 0;bottom: 5vw;}
	
	&.rito {
		text-align: center;
		margin-bottom: 5vw;
		padding: 3vw 0 0 0;
	}
}

#tour .product {
	padding: 10vw 0 0;
	
	& h3 {
		text-align: center;
		margin-bottom: 3vw;
		font-size: 6.7vw;
		line-height: 1.3em;
		letter-spacing: 0.02em;
		font-weight: 900;
		color: var(--content-color-yellow);
		text-shadow: 1px 1px 0 #000, -1px -1px 0 #000, -1px 1px 0 #000, 1px -1px 0 #000, 0px 1px 0 #000, 0 -1px 0 #000, -1px 0 0 #000, 1px 0 0 #000;
		
		&:before {
			content: "";
			display: block;
			height: 10vw;
			background: url("../img/icon-tour.png") no-repeat top center;
			background-size: contain;
		}
	}
}

/*遷移ボタン/ 販売商品なし*/
#tour .outsales-txt {
    text-align: center;
    font-size: calc(22vw / 7.5);
    margin: calc(30vw / 7.5) auto;
	
	&:empty {
		display: none
	}
}
#tour .other-link {
    width: 84vw;
    margin: calc(20vw / (750 / 100)) auto 0;
	
	& a {
		display: block;
		margin: 0 auto;
		font-size: calc(22vw / 7.5);
		font-weight: 500;
		color: #FFF;
		text-align: center;
		border-radius: 7vw;
		position: relative;
		padding: 10px 20px;
		
		&::after {
			content: "";
			background: url(/cmn/icon/icon_arrow_right_white.svg) no-repeat center center / cover;
			width: 8px;
			height: 25px;
			position: absolute;
			top: 0;
			right: 2vw;
			bottom: 0;
			margin: auto;
		}
	}
}
#tour .other-link + .other-link {
	margin-top: calc(13vw / (750 / 100));
}
#tour #hondo .other-link a {background-color: var(--content-color-green);}
#tour #rito .other-link a {background-color: var(--content-color-blue);}

/*------------------------------------------------
	商品部分調整・縦積みスタイル
--------------------------------------------------*/
.product-list.row-style>li .product-list__item .item-photo__wrapper .item-txt__port {
	position: static;
	padding: calc(3vw /(750 / 100));
	font-size: calc(20vw /(750 / 100));
	font-weight: normal;
	line-height: 1.3em;
	background: rgba(0 0 0 / 100%);
}
.product-list.row-style .item-photo__wrapper {
	border-radius: 0;
}
.product-list.row-style .item-photo__wrapper img {
	border-radius: 0;
}
.item-txt__title {
	font-size: calc(28vw /(750 / 100)) !important;
}
.item-txt__point {
	line-height: 1.4em;
}
.item-txt__price {
	margin-top: 1vw;
}
.product-list.row-style>li {
	box-shadow: 0 2px 4px rgb(0 0 0 / 25%);
}
.product-list.row-style .label__wrapper.nosp {
	display: none;
}
.product-list.row-style .label__wrapper {
	display: flex;
	flex-direction: row;
	width: 100%;
	position: static;
}
.item-label::after {
	margin-right: 1vw;
	margin-bottom: 1vw;
	background-size: 100%;
}
.item-label.line::after {
	font-size: calc(25vw / 7.5);
}
@media (orientation: landscape){
	.item-label::after {
		width: auto;
        height: auto;
        padding: 0 5px;
	}
}
/*------------------------------------------------
	FIT
--------------------------------------------------*/
#fit {
	width: 100%;
	background-color: #fffde1;
	padding: 7vw 0 10vw;
	text-align: center;
	& .inner {
		width: 94vw;
	}
	& h2 {
		font-size: 4.0vw;
		line-height: 1.3em;
		font-weight: 700;
		margin-bottom: 2vw;
		& span {
			color: #ed2828;
		}
	}
	& .note {
		font-size: 3.0vw;
		text-align: left;
		margin-top: 3vw;
	}
}

/*------------------------------------------------
	おすすめバナー
--------------------------------------------------*/
#recobnr {
	width: 100%;
	background-image: url("../img/bg-wave.png"),url("../img/bg-dot.png");
	background-repeat: no-repeat,repeat;
	background-position: bottom center,top left;
	background-size: auto 30px,4px;
	padding: 5vw 0 15vw 0;
	
	& h2 {
		text-align: center;
		font-size: 5.0vw;
		font-weight: 700;
		line-height: 1.0em;
		margin-bottom: 5vw;
	}
	
	& .bnr-list {
		width: 92vw;
		margin: 0 auto;
		display: flex;
		flex-wrap: wrap;
		
		& li {
			width: 46%;
			margin: 0 2% 3.5vw;
			& img {
				width: 100%;
			}
			&:empty {
				display: none;
			}
		}
	}
	&:has(.area00.is-display ul li:nth-child(1):empty) {
		display: none;
	}
}
/*------------------------------------------------
	クーポンコード
--------------------------------------------------*/
.coupon-code-wrapper{
	margin: 5px auto;
	position: relative;
	}
.coupon-code-txt{
	display: block;
	font-size: 12px;
	line-height: 1.7;
}
.coupon-code{
	max-width: 92%;
	margin: 0 auto;
	font-size: 15px;
	font-weight: 700;
	text-align: center;
	background: #f2f2f2;
	padding: 5px 30px 5px 5px;
	cursor: pointer;
	position: relative;
}
.coupon-code::after {
	content: "";
	background: url("/cmn/icon/icon_copy.svg") no-repeat center center / cover;
	width: 24px;
	height: 24px;
	position: absolute;
	top: 3px;
	right: 3px;
}
.msgBoard{
	width: 100%;
	font-size: 13px;
	display: none;
	text-align: center;
}

/*---------------------------------------------
ios用調整
----------------------------------------------*/
.product-list.row-style>li .product-list__item .item-photo__wrapper .item-txt__port {
	margin-top: -1px;
}
/*----------------------------------------------
	終了
------------------------------------------------*/
#close {
    padding: 20vw 0;
    background-color: #f9f6e3;
    text-align: center;
    font-size: 4.0vw;
    line-height: 1.6em;
}