@charset "utf-8";
/* CSS Document */
:root{
	--font-sans: 'Noto Sans JP', serif;
	--content-width-pc: 1104px;
	--content-width-sp: calc(675vw / 7.5);
	--content-width: min(var(--content-width-sp), var(--content-width-pc));
	--font-size-pc: 16px;
	--font-size-sp: calc(28vw / 7.5);
	--default-color-black: #2C2A29;
	--content-color-red: #dc0e0e;
	--content-color-orange: #fa4b09;
	--content-color-yellow: #f6c531;
	--content-color-green: #4e7c05;
	--content-color-courseA: #a46a14;
	--content-color-courseB: #8c3b3b;
	--bg-color-beige1: #fbf9df;
	--bg-color-beige2: #f5f2c6;
}
.nosp {
    display: none
}
.main {
  font-family: var(--font-sans);
  line-height: 1.5;
  font-size: var(--font-size-sp);
  color: var(--default-color-black);
  & a {
    text-decoration: none;
  }
  & img {
    width: 100%;
  }
  & .inner {
    width: var(--content-width-sp);
    margin: 0 auto;
  }
}

/*------------------------------------------------
	メインビジュアル
--------------------------------------------------*/
#mainvisual {
	width: 100%;
	height: calc(550vw / 7.5);
	background: url("../img/main-bg-sp.jpg") no-repeat top center;
	background-size: 100%;
	position: relative;
	& .inner {
		& .title {
			padding-top: 7vw;
			width: calc(498vw / 7.5);
			margin: 0 auto 7vw;
		}
		& .kikan {
			width: calc(425vw / 7.5);
			margin: 0 auto;
		}
	}
}

/*------------------------------------------------
	発地切り替え
--------------------------------------------------*/
.display_selected{
	width: 24vw;
	height: calc(80vw / 7.5);
	padding: calc(10vw / 7.5);
	background: var(--default-color-black);
	font-size: calc(24vw / 7.5);
	font-weight: 700;
	color: #fff;
	text-align: center;
	position: absolute;
	right: 0;
	top: 0;
	&::after {
		content: "";
		display: inline-block;
		width: 5vw;
		height: 5vw;
		background: url(/cmn/icon/icon_arrow_down_white.svg) no-repeat center center / contain;
		position: absolute;
		right: 0;
		left: 0;
		bottom: 0;
		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;
		font-size: calc(30vw / 7.5);
		padding: calc(20vw / 7.5);
		text-align: center;
		& a {
			color: #fff;
		}
		&.selected {
			background: #fff;
			& a {
				color: var(--default-color-black);
			}
		}
	}
	& .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;
	}
}
/*------------------------------------------------
	導入/共通特典背景
--------------------------------------------------*/
#intro {
	width: 100%;
	background-image: url("../img/intro-bg.jpg");
	padding: calc(80vw / 7.5) 0 calc(140vw / 7.5);
}

/*------------------------------------------------
	導入
--------------------------------------------------*/
#lead {
	background: url("../img/lead-map-sp.png") no-repeat bottom 2vw center / 90%;
	padding-bottom: 72vw;
	& .text {
		font-size: 3.8vw;
		line-height: 1.8;
		padding: 0 4vw;
		text-align: justify;
	}:last-of-type {
    margin-top: 4vw;
  }
}
/*------------------------------------------------
	共通特典
--------------------------------------------------*/
#discount {
  margin-top: 8vw;
  & h2 {
    width: calc(660vw / 7.5);
    margin: 0 auto -6.8vw;
  }  
  & .inner {
    width: 100%;
    height: calc(512vw / 7.5);
    background-image: url("../img/illust-mega.png"),url("../img/illust-coupon.png"),url("../img/discount-bg-sp.jpg");
    background-repeat: no-repeat,no-repeat,no-repeat;
    background-position:top 22vw left 6vw,top 20vw right 5vw,top center;
    background-size: 13vw,13vw,100%;
    padding: 6vw 0 0;
    text-align: center;
    & .title-text {
      display: inline-block;
      font-size: 6.8vw;
      font-weight: 900;
      color: var(--content-color-orange);
      margin-bottom: 3vw;
      & span {
        background: linear-gradient(transparent 70%, var(--content-color-yellow) 0%);
        &:nth-child(1) {
          color: var(--default-color-black);
          font-size: 0.7em;
        }
        &:nth-child(2) {
          display: block;
          line-height: 1.3;
        }
      }
    }
  }
  .coupon {
    text-align: center;
    & .flex-box {
      margin-bottom: 2vw;
      & .sub {
        font-size: 3.8vw;
        font-weight: 700;
      }
      & .point {
        font-size: 8.7vw;
        line-height: 1.3;
        font-weight: 900;
        color: var(--content-color-red);
        & span {
          font-size: 0.4em;
        }
        & mark {
          background: linear-gradient(transparent 70%, #ffe900 0%);
          color: inherit;
          margin-left: 2vw;
          & span {
            font-size: 0.6em;
          }
        }
      }
    }
    & .detail {
      width: 100%;
      font-size: 3.0vw;
      & a {
        color: #1079bb;
      }
    }
  }
}

/*------------------------------------------------
	エリアナビ
--------------------------------------------------*/
#area-navi {
	width: 100%;
	background-color: var(--content-color-green);
	padding: 6vw 0;
	
	& ul {
		width: var(--content-width-sp);
		margin: 0 auto;
		display: flex;
		justify-content: space-between;
		& li {
			width: 32%;
			font-size: 3.8vw;
			line-height: 1.2;
			font-weight: 700;
			text-align: center;
			& a {
				display: flex;
				justify-content: center;
				align-items: center;
				width: 100%;
				height: 100%;
				color: inherit;
				background-color: #fff;
				border-radius: 2vw;
				position: relative;
				padding: 2vw 0 4vw;
				&::after {
					content: "";
					display: inline-block;
					width: 5vw;
					height: 5vw;
					background: url(/cmn/icon/icon_arrow_down.svg) no-repeat center center / contain;
					position: absolute;
					bottom: 0;
					right: 0;
					left: 0;
					margin: 0 auto;
				}
				&:hover {
					background-color: var(--content-color-yellow);
					opacity: 1;
				}
			}
		}
	}
}

/*------------------------------------------------
　ツアー　枠・キャンペーン内容
--------------------------------------------------*/
#tour {
	width: 100%;
	background-color: var(--bg-color-beige1);
	& .area {
		padding: 5vw 0 10vw;
		#yakushima& {
			background-color: var(--bg-color-beige2);
		}
	}
}
#tour #other .area-title {padding-top: 8.2vw;}
#tour .area-title {
	height: calc(290vw / 7.5);
	text-align: center;
	padding-top: 13vw;
	background-repeat: no-repeat;
	background-position: top center;
	background-size: 100%;
	#amami & {background-image: url("../img/tour-amami-bg-sp.png");}
	#yakushima & {background-image: url("../img/tour-yakushima-bg-sp.png");}
	#other & {background-image: url("../img/tour-other-bg-sp.png");}
  & p {
		font-size: 4.0vw;
		font-weight: 700;
		color: var(--content-color-green);
		margin-bottom: 1vw;
	}
	& h2 {
		font-size: 7.6vw;
		line-height: 1.2;
		font-weight: 700;
		letter-spacing: 0.1em;
	}
}
#tour .course-title {
	background-color: var(--content-color-orange);
	color: #fff;
	font-size: 4.8vw;
	line-height: 1.3;
	font-weight: 700;
	text-align: center;
	padding: 2vw 0;
	& span {
		font-size: 1.2em;
	}
  & .tag {
    font-size: .9em;
    background: #fff;
    display: inline-block;
    padding: 0vw 2vw .4vw;
    margin-bottom: 4px;
    color: var(--content-color-orange);
    border-radius: 4px;
  }
}
#tour .area-cpn {
	background-color: #fff;
	padding: 5vw 3vw 8vw;
	& h4 {
		font-size: 5.5vw;
		line-height: 1.2;
		font-weight: 900;
		padding: 0 0 4vw;
		display: flex;
		align-items: center;
		& img {
			width: 16%;
			margin-right: 1%;
		}
		& .text {
			width: 83%;
			& .small {
				font-size: 0.7em;
        vertical-align: .6vw;
			}
			& .color-a {
				color: var(--content-color-courseA);
			}
			& .color-b {
				color: var(--content-color-courseB);
			}
			& .note {
				display: block;
				font-size: 2.7vw;
				margin-top: 1vw;
			}
		}
	}
	& .course-list {
		margin-bottom: 5vw;
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items:flex-start;
    margin-bottom: 4vw;
    /*共通のスタイル*/
    & h5 {
      width: 100%;
      font-size: 4.1vw;
      line-height: 1.3;
      font-weight: 700;
      margin-bottom: 2vw;
      &::before {
        content: "";
        display: inline-block;
        width: 5vw;
        height: 5vw;
        background: url("../img/star.svg") no-repeat center center / contain;
        transform: translateY(0.5vw);
        margin-right: 1vw;
      }
    }
    & img {
    width: 49%;
    margin-bottom: 1vw;
    }
   /* ハーフサイズのスタイル */
    & .half {
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between;
      & p {
        width: 49%;
        font-size: 3.5vw;
      }
    }
    & .icon-or {
      width: 20%;
      margin: 2vw auto 0;
      & img {
        width: 100%;
      }
    }
	}
	& .aori {
		text-align: center;
		font-size: 4.8vw;
		font-weight: 700;
		& mark {
			color: var(--content-color-orange);
			background: linear-gradient(transparent 70%, #ffe900 0%);
		}
	}
}
/*ドットライン*/
.area-cpn .course-list:first-of-type::after {
	content: "";
	display: block;
	width: 100%;
	height: 1vw;
	background: url("../img/dotline.png") no-repeat center center / 150%;
  margin-top: 4vw;
}
#amami .area-cpn ul.course-list:first-of-type::after {
  content: none;
}

/*奄美 共通特典*/
#amami .all {
	background-color: #f1f1f1;
	border-radius: 3vw;
	padding: 4vw 4vw 2vw;
	position: relative;
	margin: 5vw 0;
	& .title {
		font-size: 4.4vw;
		font-weight: 900;
		display: flex;
		align-items: center;
		margin-bottom: 1vw;
		& img {
			width: 15%;
			margin-right: 1vw;
		}
	}
  & .course-list li {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    & h5 {
      font-size: 3.8vw;
      margin-bottom: 1vw;
    }
    & p {
      width: 62%;
      font-size: 3.5vw;
    }
    & img {
      width: 36%;
    }
  }
}

/*その他の離島*/
#other {
  & .course-title {
    padding: 1.4vw 0 2vw;
  }
  & .yoronto {
  margin-bottom: 4vw;
    & .course-list {
      gap: 0;
      margin-bottom: 0;
      & span {
        color: var(--content-color-orange);
        font-size: 0.87em;
      }
    }
    & ::after {
      content: none;
    }
  }
}
/*gift*/
#other .egift {
	display: flex;
	justify-content: space-between;
	padding-bottom: 14vw;
	position: relative;
	& .illust {
		position: absolute;
		top: 20vw;
		right: 5vw;
		width: 20vw;
	}
	& .text {
		width: 65%;
		font-size: 3.5vw;
		font-weight: 700;
		& span {
			display: inline-block;
			font-size: 0.8em;
			line-height: 1.3;
			font-weight: 500;
			margin-top: 2vw;
		}
		& a {
			position: absolute;
			bottom: 0;
			right: 0;
			left: 0;
			margin: 0 auto;
			display: block;
			width: 70vw;
			text-align: center;
			font-size: 3.5vw;
			font-weight: 500;
			background-color: var(--default-color-black);
			color: #fff;
			border-radius: 5vw;
			padding: 2vw 0 2.5vw;
			&::after {
				content: "";
				background: url(/cmn/icon/icon_arrow_right_white.svg) no-repeat center center / contain;
				width: 5vw;
				height: 7vw;
				position: absolute;
				top: 0;
				right: 2vw;
				bottom: 0;
				margin: auto;
			}
		}
	}
	& .ph {
		width: 32%;
	}
}

/*レンタル*/
/*#yakushima .rental {
	background-color: #f1f1f1;
	border-radius: 3vw;
	padding: 8vw 4vw 4vw;
	position: relative;
	margin: 5vw 0;
	& .title {
		position: absolute;
		top: -5vw;
		left: -3vw;
		width: 35vw;
	}
	& dl {
		margin-bottom: 3vw;
		& dt {
			font-size: 4.8vw;
			font-weight: 700;
			color: #607500;
			padding-left: 28vw;
			margin-bottom: 5vw;
		}
		& dd {
			font-size: 3.5vw;
			& span {
				display: block;
				font-size: 0.8em;
				margin-top: 2vw;
			}
		}
	}
}*/

/*------------------------------------------------
　ツアー　商品
--------------------------------------------------*/
.area00{
  display: none;
	&.is-display{
	  display: block;
	}
}
#tour {
	& .product {
		padding: 10vw 0 0;
		& h3 {
			text-align: center;
			margin-bottom: 5vw;
			font-size: 5.6vw;
			font-weight: 900;
		}
		& .outsales-txt {
			text-align: center;
			font-size: 3.6vw;
			margin: 4vw auto;
			&:empty {
				display: none
			}
		}
		& .other-link {
			width: 84vw;
   			margin: 3vw auto 0;

			& a {
				display: block;
				margin: 0 auto;
				font-size: 3.5vw;
				line-height: 1.3;
				color: #fff;
				background: var(--default-color-black);
				text-align: center;
				border-radius: 10vw;
				padding: 2.6vw 7vw 3vw 5vw;
				position: relative;
				&::after {
					content: "";
					background: url(/cmn/icon/icon_arrow_right_white.svg) no-repeat center center / contain;
					width: 7vw;
					height: 7vw;
					position: absolute;
					top: 0;
					right: 2vw;
					bottom: 0;
					margin: auto;
				}
			}
		}
	}
  & .note {
    font-size: 0.8em;
	}
}

/*------------------------------------------------
	商品部分調整・縦積みスタイル・ページ用アイコン
--------------------------------------------------*/
.product-list.card-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.3;
	padding: 0.5vw;
	margin-top: -1px;/*ios用調整*/
}
.product-list.row-style .item-photo__wrapper {
	border-radius: 0;
}
.product-list.row-style .item-txt__title {
	font-size: calc(28vw /(750 / 100))!important;
	line-height: 1.4;
}
.product-list.row-style .item-txt__point {
	line-height: 1.3;
}
.product-list.row-style .item-txt__price {
	margin-top: 1vw;
}
.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 {
	height: 6vw;
	margin-bottom: 1.5vw;
}
#other .item-label {
	height: initial;
	margin-bottom: 0;
}
.item-label::after {
	width: 22vw;
	height: 6vw;
	margin-right: 1vw;
	background-size: 100%;
	background-size: cover;
	line-height: 6vw;
}
.item-label.courseA::after{
	display: block;
	content: "コースA";
	background-color: var(--content-color-courseA);
	font-weight: 700;
	color: #fff;
	text-align: center;
}
.item-label.courseB::after{
	display: block;
	content: "コースB";
	background-color: var(--content-color-courseB);
	font-weight: 700;
	color: #fff;
	text-align: center;
}

/*------------------------------------------------
	関東のみチャーターバナーリンク
--------------------------------------------------*/
#charter .area00 {
	width: 100%;
	background-color: #fffbd4;
	padding: 7vw 0;
	text-align: center;
	& .text-area {
		text-align: center;
		margin-bottom: 2vw;
		& p:nth-child(1){
			font-size: 4.0vw;
			font-weight: 700;
		} 
		& p:nth-child(2){
			font-size: 5.6vw;
			font-weight: 900;
		} 
		& p:nth-child(3){
			font-size: 3.4vw;
		} 
	}
	& .note {
		text-align: left;
		font-size: 3.0vw;
		margin-top: 3vw;
	}
}

/*------------------------------------------------
	観光局リンク
--------------------------------------------------*/
#pr {
	width: 100%;
	background-color: #f4f4f4;
	padding: 7vw 0;
	& a {
		display: block;
		width: 84vw;
		margin: 0 auto;
		text-align: center;
		font-size: 3.6vw;
		background-color: var(--content-color-green);
		color: #fff;
		border-radius: 7vw;
		padding: 2.6vw 0 3vw;
		position: relative;
		&::after {
			content: "";
			background: url(/cmn/icon/icon_launch_white.svg) no-repeat center center / contain;
			width: 5vw;
            height: 5vw;
			position: absolute;
			top: 0;
			right: 4vw;
			bottom: 0;
			margin: auto;
		}
	}
}

/*------------------------------------------------
	おすすめバナー
--------------------------------------------------*/
#recobnr {
	width: 100%;
	background-color: #fff;
	padding: 5vw 0;
	
	& h2 {
		text-align: center;
		font-size: 5.0vw;
		font-weight: 700;
		line-height: 1.0;
		margin-bottom: 5vw;
	}
	
	& .bnr-list {
		width: var(--content-width-sp);
		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;
	}
}

/*------------------------------------------------
	検索ボックス調整
--------------------------------------------------*/
#searchArea .inner {
	width: 100%;
}
@media (orientation: landscape) {
	#searchArea {
		padding: 40px 0;
	}
}
.rn-searchMod__inputField, .rn-searchMod__select {
	font-size: 14px!important;
	color: #222;
}

/*------------------------------------------------
	クーポンコード
--------------------------------------------------*/
.coupon-code-wrapper{
	margin: 4vw auto 0;
	position: relative;
  background: #dcdce5;
  padding: 2vw 0 2.6vw;
  width: 70%;
	}
.coupon-code-txt{
	display: block;
	font-size: 3.5vw;
}
.coupon-code{
	max-width: 86%;
	margin: 0 auto;
	font-size: 3.8vw;
	font-weight: 700;
	text-align: center;
	background: #f2f2f2;
	padding: 1.5vw 5vw 1.5vw 2vw;
	cursor: pointer;
	position: relative;
}
.coupon-code::after {
	content: "";
	background: url("/cmn/icon/icon_copy.svg") no-repeat center center / cover;
	width: 7vw;
	height: 7vw;
	position: absolute;
	top: 1vw;
	right: 1vw;
}
.msgBoard{
	width: 100%;
	font-size: 3.3vw;
	display: none;
	text-align: center;
}

/*----------------------------------------------
	終了
------------------------------------------------*/
#close {
    padding: 20vw 0;
    background-color: #f9f6e3;
    text-align: center;
    font-size: 4.0vw;
    line-height: 1.8;
  & a {
    color: var(--default-color-black);
    text-decoration: underline;
  }  
}

/*----------------------------------------------
ページトップ
------------------------------------------------*/
.goTop {
	position: fixed;
    bottom: 10px;
    right: 10px;
    transform: translateZ(0);
    z-index: 200;
	& a {
		display: flex;
		cursor: pointer;
		align-items: center;
		justify-content: center;
		border-radius: 50%;
		background-color: rgba(105, 113, 128, .5);
		width: 48px;
		height: 48px;
		& img {
				width: 24px;
				height: 24px;
		}
	}
}