@charset "utf-8";

:root{
	--font-sans: 'Noto Sans JP', serif;
	--font-serif: "Noto Serif 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: 3.6vw;
	--default-color-black: #2C2A29;
	--content-color-green: #1c8080;
	--content-color-pink: #f54e5a;
	--content-color-blue: #26b7bc;
	--content-color-brown: #B04A13;
	--content-border_yellow: linear-gradient(transparent 60%, #fff553 50%);
	--bg-color-green: #e6f8f8;
}
.nosp {
    display: none
}
.main {
    font-size: var(--font-size-sp);
    color: var(--default-color-black);
	& a {
		text-decoration: none;
	}
    & img {
        width: 100%;
		vertical-align: bottom;
    }
    & .inner {
        margin: 0 auto;
    }
	& .no-sp{
		display: none;
	}
}

/*------------------------------------------------
	メインビジュアル
--------------------------------------------------*/
#mainvisual {
	width: 100%;
	height: 66.66vw;
	text-align: center;
	position: relative;
	overflow: hidden;
	& .slick-img img {
		height: 66.66vw;
		margin: auto;
		max-height: 66.66vw;
		max-width: 100%;
		object-fit: cover;
		width: 100%;
	}
	& .title {
		position: absolute;
		right: 0;
		left: 0;
		top: 24vw;
		z-index: 2;
		& img {
			width: 60vw;
		}
	}
}

/*------------------------------------------------
	ナビ
--------------------------------------------------*/
#navi {
	width: 100%;
	background-color: #fff;
	position: relative;
	
	& .navi-list {
		width: 100%;
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		gap: 1px;
		
		& li {
			text-align: center;
			color: #fff;
			background-color: var(--content-color-green);
			width: calc((100% - 2px)/3);
			& a {
				display: block;
				color: #fff;
				font-size: 3.6vw;
				padding: 5vw 0;
				position: relative;
				
				&::after {
					content: "";
					display: inline-block;
					width: 4vw;
					height: 4vw;
					background: url(/cmn/icon/icon_arrow_down_white.svg) no-repeat center center / contain;
					position: absolute;
					bottom: 0;
					right: 0;
					left: 0;
					margin: 0 auto;
				}
			}
		}
	}
}

/*発地切り替え*/
.dep-select-nav{
	position: absolute;
	top: -65vw;
	right: 2vw;
	width: 24vw;
	height: calc(80vw / 7.5);
	border-radius: calc(12vw / 7.5);
}
.display_selected{
	width: 100%;
	height: 100%;
	background: #fff;
	font-size: calc(26vw / 7.5);
	font-weight: 500;
	text-align: center;
	padding: calc(10vw / 7.5);
	border-radius: calc(8vw / 7.5);
	position: relative;
	&::after {
		content: "";
		display: inline-block;
		width: 4vw;
		height: 4vw;
		background: url(/cmn/icon/icon_arrow_down.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;
	}
}

/*ナビ固定時*/
.fix-navi:has(.fixed) {
	height: 13vw;
}
#navi.fixed {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 1000;
	padding: 0;
	
	& .navi-list {
		flex-wrap: nowrap;
		width: 85vw;
		height: 13vw;
		& li {
			width: 100%;
			& a {
				display: flex;
				justify-content: center;
				align-items: center;
				width: 100%;
				height: 100%;
				font-size: 2.6vw;
				line-height: 1.2;
				padding: 3vw 1vw 4.5vw;
				&.active {
					background-color: #2d9999;
				}
			}
		}
	}
	& .dep-select-nav{
		top: 0;
		right: 0;
		width: 15vw;
		height: 13vw;
	}
	& .display_selected {
		display: flex;
		justify-content: center;
		align-items: center;
		font-size: 2.8vw;
		line-height: 1.2em;
		background-color: #feffcf;
		padding: 0;
		border-radius: 0;
	}
}

/*------------------------------------------------
	導入
--------------------------------------------------*/
#lead {
	width: 100%;
	padding: 7vw 0;
	
	& .inner {
		width: 86vw;
		text-align: center;
	}
	& dl {
		margin-bottom: 5vw;
		
		& dt {
			font-size: 5.0vw;
			line-height: 1.4;
			font-weight: 700;
			text-align: center;
			margin-bottom: 3vw;
		}
	}
}

/*------------------------------------------------
	共通見出し
--------------------------------------------------*/
.main  {
	& :is(#tour, #event, #asobu, #hotel, #access) h2 {
		text-align: center;
		color: var(--content-color-green);
		margin-bottom: 5vw;
		font-size: 5vw;
		font-weight: 900;
		letter-spacing: 0.05em;
		background: url("../img/bg-titleicon.svg") no-repeat bottom center;
		background-size: 40vw;
		padding-bottom: 2vw;
		&::before {
			content: "";
			display: block;
			width: 8vw;
			height: 8vw;
			margin: 0 auto 2vw;
			background-repeat: no-repeat;
			background-size: contain;
		}
		#tour &::before {background-image: url("../img/icon-plane.svg");}
		#hotel &::before {background-image: url("../img/icon-hotel.svg");}
		#event &::before {background-image: url("../img/icon-snow.svg");}
		#asobu  &::before {background-image: url("../img/icon-snowbord.svg");}
		#access &::before {background-image: url("../img/icon-access.svg");}
	}
}
/*------------------------------------------------
	ホテル特典
--------------------------------------------------*/
#point {
	width: 100%;
	background-color: #ffedee;
	padding: 7vw 0;
	
	& .inner {
		width: 90vw;
	}
	& h2 {
		font-size: 5vw;
		font-weight: 900;
		text-align: center;
		color: var(--content-color-pink);
		margin-bottom: 5vw;
		&::before,&::after {
			content: "";
			display: inline-block;
			width: 5vw;
			height: 5vw;
			background: url("../img/icon-snow-point.svg") no-repeat center center /contain;
			margin: 0 1vw;
			transform: translateY(1vw);
		}
	}
	& h3 {
		margin-bottom: 1vw;
		color: var(--content-color-pink);
		font-size: 4.6vw;
		font-weight: 900;
		text-align: center;
		& span {
			font-size: 0.8em;
			font-weight: 700;
		}
	}
	& .flex-box {
		background-color: #fff;
		border-radius: 3vw;
		padding: 4vw 4vw 5vw;
		margin-bottom: 5vw;
		
		& .gentei {
			margin-bottom: 1vw;
			& span {
				display: inline-block;
				background-color: #fbb3be;
				font-size: 3.0vw;
				font-weight: 500;
				padding: 0.5vw 1vw 0.7vw;
			}
		}
		& .text-area {
			& li {
				&:not(:last-child) {
					margin-bottom: 3vw;
					padding-bottom: 3vw;
					border-bottom: dashed 1px #ccc;
				}
				& .text-l {
					display: block;
					font-size: 4.2vw;
					font-weight: 700;
				}
				& .text-m {
					display: block;
					font-size: 3.6vw;
				}
				& .text-s {
					display: block;
					font-size: 3.3vw;
					margin-top: 1vw;
				}
				& .f-mini {
					font-size: 0.7em;
					font-weight: 500;
				}
				& .kikan {
					display: inline-block;
					background-color: #8c6708;
					color: #fff;
					font-size: 3.3vw;
					font-weight: 500;
					padding: 0 3vw 0.3vw;
					&:nth-of-type(3) {
						margin-top: 2vw;
					}
				}
				& .renpaku {
					display: inline-block;
					background-color: #8c6708;
					color: #fff;
					font-size: 3.3vw;
					font-weight: 500;
					padding: 0 3vw 0.3vw;;
					margin: 2vw 1vw 0 0;
				}
				& mark {
					background: var(--content-border_yellow);
				}
				&.sp-ph {
					display: flex;
					flex-wrap: wrap;
					justify-content: space-between;
					& img {
						width: 42%;
						align-items:flex-start;
					}
					& .text-l {
						width: 55%;
					}
					& .text-s {
						width: 100%;
					}
				}
			}
		}
		& .ph {
			width: 70vw;
			margin: 3vw auto 0;
		}
	}
}

/*------------------------------------------------
	ホテル紹介
--------------------------------------------------*/
#hotel {
	width: 100%;
    background-color: var(--bg-color-green);
	padding: 7vw 0 10vw;
	& .inner {
		width: 90vw;
	}
	& .hotel-name {
		text-align: center;
		font-family: var(--font-serif);
		margin-bottom: 3vw;
		&:nth-of-type(2) {
			margin-top: 10vw;
		}
		& span:first-child {
			display: inline-block;
			font-size: 5vw;
			border-bottom: 1px solid var(--default-color-black);
			padding: 0 1vw 1vw 1vw;
		}
		& span:last-child {
			display: inline-block;
			font-size: 3.2vw;
			padding-top: 1vw;
		}
	}
	& .mainph {
		margin-bottom: 3vw;
		& img {
			width: 100%;
			height: 40vw;
			object-fit: cover;
		}
	}
	& .copy {
		font-size: 3.8vw;
		margin-bottom: 3vw;
	}
	& .hotelinfo {
		width: 100%;
	}
	& .hoteldata {
		width: 100%;
		font-size: 3.0vw;
		background-color: #fff;
		padding-bottom: 2vw;
		margin-bottom: 5vw;
		& dt {
			background-color: var(--default-color-black);
			color: #fff;
			display: inline-block;
			padding: 0.5vw 1vw;
			margin-bottom: 1vw;
		}
		& dd {
			padding: 0 3vw;
		}
	}
	& .hotelimg {
		width: 100%;
		display: flex;
		justify-content: space-between;
		& li {
			width: 32%;
			& img {
				border-radius: 50%;
			}
		}
	}
}

/*------------------------------------------------
	イベント・あそぶ
--------------------------------------------------*/
#event {
	width: 100%;
	padding: 7vw 0 10vw;
    background-color: var(--bg-color-green);
}
#asobu {
	width: 100%;
	padding: 7vw 0 10vw;
}
#event .inner,
#asobu .inner {
	width: 90vw;
}
.conts-box {
	width: 100%;
	border-bottom: dashed 1px #ccc;
	padding-bottom: 5vw;
	margin-bottom: 5vw;
	& .ph {
		margin-bottom: 2vw;
	}
	& .copy-box {
		width: 100%;
	}
	& h3 {
		font-size: 5vw;
		font-weight: 700;
		margin-bottom: 1vw;
	}
	& .copy {
		text-align: justify;
		margin-bottom: 2vw;
	}
}
#event div.conts-box:nth-last-of-type(1),
#asobu div.conts-box:nth-last-of-type(1){
	border-bottom: none;
	padding-bottom: 0;
}

.conts-box .memo, .conts-list .memo {
	font-size: 3.0vw;
	color: var(--content-color-brown);
    padding: 2vw;
    background-color: #fff;
	& .bold {
		font-weight: bold;
	}
	& .red {
		color: #FF0004;
	}
	& a {
		color: inherit;
		text-decoration: underline;
	}
}
#asobu .conts-box .memo {
    background-color: #f5f5f5;
}

/*施設紹介*/
.conts-list-ttl {
    margin: 12vw 0 6vw;
	text-align: center;
	& span {
		display: inline-block;
		font-size: 4.6vw;
		font-weight: 900;
		color: var(--content-color-green);
		position: relative;
		&::before,&::after {
			content: '';
			display: inline-block;
			width: 8vw;
			height: 2px;
			background-color: var(--content-color-green);
			margin: 0 2vw;
			transform: translateY(-1.5vw);
		}
	}
}
.conts-list {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;	
	align-items: flex-start;
	gap: 7vw;
	& li {
		width: 100%;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		& .ph {
			width: 40%;
			& img {
				height: 30vw;
				object-fit: cover;	
			}
		}
		& .copy-box {
			width: 57%;
			& h3 {
				font-weight: 700;
				margin-bottom: 1vw;
				font-size: 4.2vw;
				line-height: 1.3;
				color: var(--content-color-green);	
			}
			& .copy {
				font-size: 3.4vw;				
			}
		}
		& .memo {
			width: 100%;
			padding: 2vw 1vw;
			margin-top: 2vw;
		}
	}
}

#event .note {
	text-align: center;
	margin-top: 5vw;
	& span {
		display: block;
		padding: 1vw 2vw;
		font-size: 3vw;
		border: solid 1px #cacaca;
		line-height: 1.3;
		text-align: left;
	}
}

/*------------------------------------------------
	ホテル特典
--------------------------------------------------*/
#hotelttn {
    width: 100%;
}
#hotelttn .inner {
	width: 100%;
	background: #fff;
    border: solid 1px #2c211c;
	margin-bottom: 14vw;
	padding: 4vw;
}
#hotelttn h3 {
	font-size:	5vw;
    font-weight: 900;
    color: #fff;
    text-align: center;
    background: #2c211c;
    padding: 3vw 0;
}
#hotelttn h3 span {
	position: relative;
	line-height: 1;
	display: inline-block;
}
#hotelttn h3 span::before {
    content: '';
    display: block;
    background-image: url(../img/snow-icon02.png);
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    top: 0;
    left: -6vw;
    width: 5vw;
    height: 5.5vw;
}
#hotelttn h3 span::after {
    content: '';
    display: block;
    background-image: url(../img/snow-icon02.png);
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    top: 0;
    right: -7vw;
    width: 5vw;
    height: 5.5vw;
}
#hotelttn .shiawase-point {
	margin-bottom: 5vw;
}
#hotelttn .shiawase-point .ttl {
	text-align: center;
	margin-bottom: 2vw;
	font-weight: bold;
}
#hotelttn .shiawase-point .ttl span, #omo .shiawase-point .ttl span {
	width: 100%;
    font-size: 3.3vw;
    display: inline-block;
    line-height: 1.3em;
    color: #fff;
    background: #e48488;
    padding: 1vw 0;
}
#hotelttn .hotel-omotenashi .ttl {
	text-align: center;
	margin-bottom: 2vw;
}
#hotelttn .hotel-omotenashi .ttl span {
	font-size: 3.6vw;
	color: #26b7bc;
	position: relative;
    display: inline-block;	
	font-weight: bold;	
}
#hotelttn .hotel-omotenashi .ttl span:before {
    content: '';
    display: block;
    background-image: url("../img/stripe-line.png");
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    top: 0;
	bottom: 0;
	margin: auto;
    left: -15vw;
    width: 14vw;
    height: 1vw;
}
#hotelttn .hotel-omotenashi .ttl span:after {
    content: '';
    display: block;
    background-image: url("../img/stripe-line.png");
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    top: 0;
	bottom: 0;
	margin: auto;
    right: -15vw;
    width: 14vw;
    height: 1vw;
}
#hotelttn .list {
	font-size: 3.8vw;
    font-weight: bold;
    line-height: 1.6em;
}
#hotelttn .list li {
	position: relative;
	line-height: 1.3em;
	margin-bottom: 1vw;
}
#hotelttn .list li:before {
    content: "■";
	color: #333;
	font-size: 80%;
	margin-right: 4px;
    display: inline-block;
	left: 0;
}
#hotelttn .shiawase-point li {
	color: #dd626e;
}
#hotelttn .shiawase-point li .em {
    margin-left: -2vw;
    color: #333;
}
#hotelttn #omo .shiawase-point li.note {
	margin-top: 0;
}
#hotelttn li.note:before {
	content: none;
}
#hotelttn .note {
	font-size: 3vw;
	color: #333;
	margin-left: 1vw;	
}
#hotelttn li.note {
	line-height: 1.5em;
	color: #333;
	margin-left: 0;
}
#hotelttn .hotel-omotenashi .list {
	color: #26b7bc;
}


#hotelttn .list .underline, #omo .omo-list .underline  {
background: linear-gradient(transparent 60%, #fffbc7 0%);
    padding: 0 .5vw;	
}
#hotelttn .shiawase-point .list .underline{background: linear-gradient(transparent 60%, #f5f1b9 0%);}
#omo {
	background: #f8f7ee;
	margin-top: 6vw;
	padding: 4vw 3vw 3vw;
}
#omo .catch {
	font-size: 5vw;
	text-align: center;
	font-weight: bold;
	margin-bottom: 4vw;
}
#omo h5 {
    display: inline-block;
    padding-bottom: 1vw;
    font-size: 3.4vw;
    margin-bottom: 1vw;
    font-weight: bold;
    line-height: 1em;
    border-bottom: dotted 2px #b3b3b3;
    width: 100%;
}
#omo h5 span {
	font-size: 3vw;
}
#omo .omo-list {
	display: flex;
	flex-wrap: wrap;
}
#omo .omo-list li {
	width: 100%;
	background: #fff;
	padding: 1.8vw;
	display: flex;
	justify-content: space-between;
	margin-bottom: 2vw;
}
#omo .omo-list li:last-of-type {
	margin-bottom: 0;
}
#omo .omo-list .ph {
	width: 37%;
}
#omo .omo-list .ph img {
	width: 100%;
	height: 20vw;
	object-fit: cover;	
}
#omo .omo-list .copy-box {
	width: 60%;
}
#omo .omo-list .copy {
    color: #26b7bc;
	font-size: 3.1vw;
	line-height: 1.3em;
	font-weight: bold;
}

/*------------------------------------------------
	アクセス
--------------------------------------------------*/
#access {
	width: 100%;
	background-color: var(--bg-color-green);
	padding: 10vw 0;
	
	& .inner {
		width: 90vw;
	}
	& .map {
		margin-bottom: 1vw;
	}
	& .address {
		margin-bottom: 5vw;
	}
	& .detail {
		background-color: #fff;
		padding: 1vw 2vw;
		
		& h3 {
			font-size: 3.6vw;
			line-height: 1.8;
			font-weight: 700;
		}
		
		& ul {
			font-size: 15px;
			
			& li {
				font-size: 3.4vw;
				
				& i {
					font-size: 1.2em;
					margin-right: 1vw;
				}
				& img {
					padding: 3vw 0;
				}
				& .note {
					font-size: 3.0vw;
					line-height: 1.4;
				}
			}
		}
	}
}

/*------------------------------------------------
	ツアー
--------------------------------------------------*/
.area00{
  display: none;
	&.is-display{
	  display: block;
	}
}
#tour {
	width: 100%;
	padding: 7vw 0 10vw;
	
	& .inner {
		width: 94vw;
	}
	
	& .product-title__dep {
		background-color: var(--content-color-green);
		font-size: 3.8vw;
		padding: 1vw 0;
		color: #fff;
		text-align: center;
		margin-bottom: 3vw;
	}
	
	& .outsales-txt {
		text-align: center;
		font-size: calc(24vw / 7.5);
		&:empty {
			display: none
		}
	}
	& .other-link {
		width: 84vw;
		margin: calc(20vw / (750 / 100)) auto;
		
		& a {
			display: block;
			margin: 0 auto;
			font-size: calc(24vw / 7.5);
			font-weight: 500;
			color: #FFF;
			background: var(--content-color-green);
			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;
			}
		}
	}
}

/*------------------------------------------------
	商品部分調整・縦積みスタイル
--------------------------------------------------*/
.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;
	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;
	}
}
.product-list.row-style>li .product-list__item .item-photo__wrapper .item-txt__port {
	margin-top: -1px;
}

/*------------------------------------------------
	検索ボックス調整
--------------------------------------------------*/
#searchArea .inner {
	width: 100%;
}
@media (orientation: landscape) {
	#searchArea {
		padding: 40px 0;
	}
}
.rn-searchMod__inputField, .rn-searchMod__select {
	font-size: 14px!important;
	color: #222;
}
/*----------------------------------------------
ページトップ
------------------------------------------------*/
.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;
		}
	}
}