@charset "UTF-8";
/* CSS Document */
:root{
	--fontcolor: #333;
	--orangecolor: #FD6D03;
	--bluecolor: #2F3B84;
	--lightbluecolor: #009EFF;
	--detailfont: 19px;
	--defaultfontfamily: "Noto Sans TC","正黑體", "黑體", "微軟正黑體", Helvetica, Arial, "sans-serif";
	--w:min(1, 1.11);
}
body {
	background: #fff center center repeat-y;
	background-size: min(100%, 1600px) auto;
	font-family: "Noto Sans TC","正黑體", "黑體", "微軟正黑體", Helvetica, Arial, "sans-serif";
	font-weight: 400;
	color: var(--fontcolor);
	overflow-x: hidden;
}
.top_bar {
	position: fixed;
	top: 0;
	width: 100%;
	background: rgba(255, 255, 255, 1);
	z-index: 9999;
	-webkit-box-shadow: 0px 3px 3px 0px rgba(0,0,0,0.4);
	-moz-box-shadow: 0px 3px 3px 0px rgba(0,0,0,0.4);
	box-shadow: 0px 3px 3px 0px rgba(0,0,0,0.4);
}
.top_menu {
	position: relative;	
	left: 0;
	right: 0;
	width: 100%;
/*	max-width: 1080px;*/
	overflow-x: hidden;
	margin: auto;
	max-width: 1600px;
}
.navbar-brand {
	width: 15%;
	padding-bottom: 10px;
	max-width: 140px;
	min-width: 100px;
}
.navbar-toggler {
    padding: .20rem 0rem;
    background-color: transparent;
    border: 0px solid transparent;
	display: none !important;
}
.navbar {
	padding: 0 1rem;
}
.navbar-nav {
	display: none !important;
}

.hidden{
	display: none;
}

.desktop{
	display: inline-block;
}
.mobile{
	display: none;
}
.tablet768{
	display: none;
}

a{
	color: var(--fontcolor);
}
a:hover{
	color: var(--lightbluecolor);
	text-decoration: underline;
}
.user-select{
	user-select: none;
	-webkit-user-select: none;
}




.main_kv {
	position: relative;
    width: 100%;
	margin-top: 78px;
	z-index: 1;
	overflow: hidden;
}
.main_kv picture{
	position: relative;
	z-index: 1;
}
/*.main_kv a, .main_kv a:hover, .main_kv a:focus{
	color: white;
	text-decoration: none;
	position: relative;
}*/
.top_banner {
	margin: 0px auto 0px auto;
	position: relative;
	max-width: 1600px;
}


.wrapper {
	position: relative;
    margin: 0 auto;
    padding: 32px;
    width: 100%;
/*    max-width: 1280px;*/
	max-width: 1600px;
}
/*.wrapper img{
	pointer-events: none;
	outline: none;
	user-select: none;
	width: 100%;
	height: auto;
}*/
.wrapper.row{
	flex-direction: column;
	max-width: 90%;
}
.full-width{
/*	max-width: 100% !important;*/
	width: 100% !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
	max-width: 1600px !important;
}

.foot_bg {
	position: relative;
	width: 100%;
	background: #fff;
	border-top: 1px solid #ccc;
}
footer {
	position: relative;
    margin: 0px auto 0 auto;
    padding: 10px;
    width: 100%;
    max-width: 1200px;
    background: #fff;
    font-size: 11px;
    text-align: center;
    
}
footer span {
	white-space: nowrap;
}
.footer01 {
	position: relative;
    float: left;
	margin-right: 3%;
    width: 12%;
    max-width: 141px;
}
.footer02 {
	position: relative;
    float: left;
    padding-top: 12px;
    width: 25%;
    text-align: left;
    font-size: 12px;
    color: #666;
    line-height: 14px;
    font-weight: 300;
}
.footer03 {
	position: relative;
    float: right;
    width: 50%;
    max-width: 590px;
    text-align: right;
}

.m768, .m576{
	display: none;
}

.mt0{
	margin-top: 0 !important;
}
.pb0{
	padding-bottom: 0 !important;
}
.align-left{
	text-align: left !important;
}
.align-center{
	text-align: center !important;
}
.align-right{
	text-align: right !important;
}

/**/
.content_menu{
	width: 480px;
	border-radius: 8px;
	background-color: #fff;
	margin:0 auto;
	font-size: 19px;
	overflow: hidden;
	max-width: 95%;
	border: 1px solid var(--lightbluecolor);
}
.content_menu .title{
	background: var(--lightbluecolor);
    font-weight: normal;
    color: white;
    line-height: 1;
    padding: 10px 28px;
    font-size: 22px;
    letter-spacing: 1px;
}
.content_menu ul{
	list-style: none;
	padding: 20px 30px 10px 35px;
}
.content_menu a{
	color:var(--fontcolor);
/*	text-decoration: underline;*/
/*	line-height: 1.9;*/
	font-weight: 400;
	letter-spacing: .5px;
}
.content_menu li{
	position: relative;
}
.content_menu li.sub{
	font-size: .89em;
	padding-left: 23px;
	background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/ic_pin.png) left 2px no-repeat;
	background-size: 17px auto;
}
.content_menu li:not(:last-child) {
    margin-bottom: 8px;
}
.content_menu li.sub + li.sub + li.sub + li.sub{
	margin-bottom: 10px;
}
.content_menu a:hover, .content_menu a:focus{
	color:var(--highlight-color);
}

.section-title{
	width: 633px;
	height: 91px;
	background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/section_title.png) center center no-repeat;
	background-size: 100% auto;
	font-size: 26px;
	font-weight: bold;
	line-height: 91px;
	color: var(--bluecolor);
	text-align: center;
	margin: 0 auto;
}

h1{
	font-size: 40px;
	text-align: center;
	font-weight: 600;
	line-height: 48px;
	position: relative;
	margin: 0 auto;
}
h1:after{
	content: '';
	height: 30px;
	bottom: 21px;
	position: relative;
	display: block;
	z-index: -1;
	background-color: #F7FB00;
}
h1 + h2{
	font-size: 31px;
	color: var(--bluecolor);
	text-align: center;
	font-weight: 600;
	position: relative;
	margin: 10px auto 0;
	line-height: 42px;
}
/* desc */
.section-desc-box{
	margin: -45px auto 0;
	width: 1063px;
	max-width: 90%;
	background-color: #E2F2FF;
	padding: 58px 50px 38px;
	font-size: 18px;
	text-align: center;
	line-height: 29px;
	z-index: -1;
}

/* feature */
.section-desc-box2{
	margin-top: 7px;
	position: relative;
}
.section-desc-box2:before, .section-desc-box2:after{
	content: '';
	position: absolute;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
}
.section-desc-box2:before{
	top: -5%;
	left: 0;
	background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/f_lt.png) left center no-repeat;
	background-size: 258px auto;
}
.section-desc-box2:after{
	top: 10%;
	right: 0;
	background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/f_rt.png) right center no-repeat;
	background-size: 258px auto;
}
.section-desc-box2 ul{
	list-style: none;
	font-size: 18px;
	line-height: 30px;
	letter-spacing: 1.8px;
	padding: 32px 56px;
}
.section-desc-box2 ul li span{
	padding-right: 6px;
	font-size: 23px;
}
.section-desc-box2 .remark{
	position: absolute;
	color: #0FC3CB;
	font-size: 32px;
	line-height: 42px;
	bottom: 32px;
	right: 30px;
	font-weight: 900;
	letter-spacing: 2px;
	transform: rotate(-2deg);
}
.section-desc-box2 .remark span{
	font-size: 28.6px;
}
.section-desc-box2-wrapper{
  position: relative;
  width: 920px;
  height: 325px;
  margin: 0 auto;
  z-index: 2;
  background-color: #fff;
  min-width: 68%;
  overflow: hidden;
  display: flex;
}
.vert {
  position: absolute;
  left: 35px;
  border-top: 1px solid #979797;
  border-bottom: 1px solid #979797;
  height: 100%;
  width: calc(100% - 70px);
}
.vert:before{
	content: '';
	position: absolute;
	left: -35px;
	top: -15px;
	border-left: 1px solid #979797;
	width: 49.4974px;
	height: 49.4974px;
	transform-origin: left bottom;
	transform: rotate(45deg);
}
.vert:after{
	content: '';
	position: absolute;
	right: -35px;
	top: -15px;
	border-right: 1px solid #979797;
	width: 49.4974px;
	height: 49.4974px;
	transform-origin: right bottom;
	transform: rotate(-45deg);
}
.hori {
  position: absolute;
  top: 35px;
  border-left: 1px solid #979797;
  border-right: 1px solid #979797;
  width: 100%;
  height: calc(100% - 70px);
}
.hori:before{
    content: '';
    position: absolute;
    left: -15px;
    bottom: -15px;
    border-left: 1px solid #979797;
    width: 49.4974px;
    height: 49.4974px;
    transform-origin: right top;
    transform: rotate(-45deg);
}
.hori:after{
	content: '';
	position: absolute;
	right: -15px;
	bottom: -15px;
	border-right: 1px solid #979797;
	width: 49.4974px;
	height: 49.4974px;
	transform-origin: left top;
	transform: rotate(45deg);
}

/* compare-box */
.compare-box{
	width: 100%;
	margin: 18px auto;
	display: flex;
	align-items: center;
	position: relative;
	max-width: 1280px;
}
.compare-box-list-title{
	color: #fff;
	background-color: var(--lightbluecolor);
	z-index: 1;
	position: relative;
	overflow: hidden;
	width: 143px;
	flex: 0 0 143px;
	font-size: 19px;
	font-weight: 500;
	line-height: 22px;
	display: flex;
	flex-direction: column;

	height: 558px;
}
.compare-box-list-title:after{
	content: '';
	position: absolute;
	top: 0;
	left: 100%;
    width: 80px;
    height: 100%;
    background-color: rgba(0, 0, 0, .17);
    transform: rotate(-1.5deg);
    transform-origin: left bottom;
}
.compare-box-list-title .tri{
	position: absolute;
	height: 100%;
}
.compare-box-list-title .tri:before, .compare-box-list-title .tri:after{
	content: '';
	position: absolute;
	width: 0px;
    height: 0px;
    border-style: solid;
}
.compare-box-list-title .tri:before{
    border-width: 28px 28px 0 0;
    top: 0;
    left: 0;
    border-color: #fff transparent transparent transparent;
}
.compare-box-list-title .tri:after{
    border-width: 28px  0 0 28px;
    bottom: 0;
    left: 0;
    border-color: transparent transparent transparent #fff;
}
.compare-box-list-title .name{
	padding: 20px 22px 0;
	display: flex;
}
.compare-box-list-title .name:nth-child(even){
	background-color: #0085D7;
}
.compare-box-list-title .name:nth-child(1){
	flex: 0 0 17%;
	padding-top: 55px;
}
.compare-box-list-title .name:nth-child(2){
	flex: 0 0 21%;
}
.compare-box-list-title .name:nth-child(3){
	flex: 1 0 auto;
}
.compare-box-list-title .name:nth-child(4){
	flex: 0 0 12%;
}
.compare-box-list-title .name:nth-child(5){
	flex: 0 0 15%;
}
.compare-box-list{
	z-index: 2;
	background: white;
	height: 587px;
	flex: 0 1 1138px;

	display: flex;
	width: 100%;
    
    border: 1px solid #ddd;
}

.compare-box-list .compare-box-list-item{
	scroll-snap-align: start;
	flex: 0 0 300px;
	position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 0 28px;
    white-space: wrap;
    border-right: 1px solid #ddd;
}
.compare-box-list:hover{
	overflow: auto;
}
.compare-box-list .compare-box-list-item:nth-child(1){
	flex: 0 0 300px;
}
.compare-box-list .compare-box-list-item:nth-child(2){
	flex: 0 0 266px;
}
.compare-box-list .compare-box-list-item:nth-child(3){
	flex: 0 0 290px;
}
.compare-box-list .compare-box-list-item:nth-child(4){
	flex: 0 0 279px;
	border-right: 0;
}

.compare-box-list-item .title span{
	font-size: 19px;
	color: white;
	padding: 3px 18px 4px;
	background-color: var(--orangecolor);
	border-radius: 50em;
	margin-left: -2px;
	margin-right: -10px;
	display: block;
	margin-top: 58px;
}
.compare-box-list-item .level{
	display: flex;
	padding-top: 15px;
	width: 100%;
}
.compare-box-list-item .level ul{
	font-size: 18px;
	list-style: none;
	line-height: 26px;
	padding: 0;
	flex: 0 0 50%;
}
.compare-box-list-item .level li.label{
	color: var(--orangecolor);
	font-size: 16px;
}
.compare-box-list-item .feature li{
	position: relative;
	padding-left: 20px;
}
.compare-box-list-item .feature li:before{
	content: '';
	position: absolute;
	top: -1px;
	left: 0;
	width: 18px;
	height: 18px;
	background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/ic_star.png) center center no-repeat;
	background-size: 100% auto;
}
.compare-box-list-item .feature{
	padding-top: 18px;
}
.compare-box-list-item .feature ul{
	list-style: none;
	font-size: 15px;
	line-height: 17px;
	padding: 0;
}
.compare-box-list-item .feature li:not(:last-child){
	margin-bottom: 7px;
}
.compare-box-list-item .distance, .compare-box-list-item .hotel{
	font-size: 17px;
	line-height: 22px;
}
.compare-box-list-item div:nth-child(1){
	flex: 0 0 110px;
}
.compare-box-list-item div:nth-child(2){
	flex: 0 0 118px;
}
.compare-box-list-item div:nth-child(3){
	flex: 1 0 auto;
}
.compare-box-list-item div:nth-child(4){
	flex: 0 0 68px;
	display: flex;
    align-items: center;
}
.compare-box-list-item div:nth-child(5){
	flex: 0 0 100px;
	padding-top: 13px;
}

.compare-box-list-item .bg{
	position: absolute;
	width: 100%;
	height: 100%;
	z-index: -1;
	top: 0;
	left: 0;
	background-repeat: no-repeat;
	background-size: 100% auto;
}
.compare-box + .skiman:after{
	content: '';
	position: absolute;
	right: 0;
	bottom: 0;
	width: 206px;
	height: 112px;
	background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/compare_ski.png) center center no-repeat;
	background-size: 100% auto;
	z-index: 3;
}

/* compare-tab */
.compare-tab-box{
	position: relative;
}
.compare-tab-box-tab{
	z-index: 1;
	background-color: #fff;
	border-bottom: 6px solid var(--orangecolor);
}
.compare-tab-box-tab ul{
	display: flex;
	justify-content: center;
	list-style: none;
	padding: 0;
	max-width: 1280px;
	margin: 0 auto;
	text-align: center;
	width: 100%;
}
.compare-tab-box-tab ul li{
	flex: 0 0 25%;
	font-size: 20px;
	line-height: 26px;
	padding: 16px 0;
	font-weight: 500;
	cursor: pointer;
	position: relative;
}
.compare-tab-box-tab a{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
}
.compare-tab-box-tab ul li + li{
	border-left: 1px solid #979797;
}
.compare-tab-box-tab ul li:hover{
	background-color: var(--orangecolor);
	color: #fff;
	font-weight: 600;
}
.compare-tab-box-tab ul li.highlight{
	background-color: var(--orangecolor) !important;
	color: #fff !important;
	font-weight: 600 !important;
}

.compare-tab-box-gallery .img-set,
.info-content-top-wrapper .info-content,
.info-content-bottom-wrapper .info-content-bottom{
	height: 0;
	visibility: hidden;
	margin: 0;
}
.compare-tab-box-gallery .img-set.show,
.info-content-top-wrapper .info-content.show,
.info-content-bottom-wrapper .info-content-bottom.show{
	height: 100%;
	visibility: visible;
}
.compare-tab-box-gallery{
	position: relative;
}
.compare-tab-box-gallery:after{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 470px;
	background-color: #0085D7;
	z-index: -1;
}
.compare-tab-box-gallery .img-sets{
	max-width: 1280px;
	height: 560px;
	margin: 0 auto;
	position: relative;
	width: 100%;
}
.compare-tab-box-gallery .img-set{
	position: relative;
}
.compare-tab-box-gallery .img-set:after{
	content: '';
	position: absolute;
	z-index: 2;
	width: calc(100% + 2px);
	height: 89px;
	background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/gallery_bottom.png) center bottom no-repeat;
	background-size: 100% auto;
	bottom: -1px;
	pointer-events: none;
	margin-left: -1px;
}
.compare-tab-box-gallery .img-set:before{
	content: '';
	position: absolute;
	z-index: 3;
	right: -20px;
	width: 243px;
	height: 192px;
	background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/gallery_right.png) center bottom no-repeat;
	background-size: 100% auto;
	bottom: -5px;
}
.compare-tab-box-gallery .img-set h2{
	position: absolute;
	bottom: 48px;
	left: -15px;
	font-size: 36px;
	line-height: 38px;
	padding:20px 40px;
	font-weight: bold;
	color: white;
	background-color: var(--orangecolor);
	z-index: 3;
}
.img-set .swiper-container{
	z-index: 1;
	position: relative;
	display: block;
	width: 100%;
	height: 100%;
}
.gallery-photo{
	position: absolute;
	width: 100%;
	height: 100%;
	background-size: 100% auto;
	background-repeat: no-repeat;
	background-position: center center;
}
.hotel-thumbnail{
	width: 220px;
}
.btn-prevnext .swiper-button-next,
.btn-prevnext .swiper-button-prev{
	width: 68px;
	height: 68px;
	border-radius: 50em;
	background-color: var(--orangecolor);
}
.btn-prevnext .swiper-button-prev{
	margin-left: -43px;
	margin-top: -70px;
}
.btn-prevnext .swiper-button-next{
	margin-right: -43px;
	margin-top: -70px;
}
.btn-prevnext .swiper-button-next:after,
.btn-prevnext .swiper-button-prev:after{
	width: 49px;
	height: 49px;
	position: absolute;
	top: 50%;
	background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/ic_arrow.png) center center no-repeat;
	background-size: 100% auto;
	content: '';
}
.btn-prevnext .swiper-button-prev:after{
	left: calc(50% - 1px);
	transform: translate(-50%, -50%);
}
.btn-prevnext .swiper-button-next:after{
	left: 50%;
	transform: translate(-50%, -50%) rotate(180deg);
	transform-origin: center center;
}
.img-set .swiper-pagination-bullet{
	width: 33px;
	height: 4px;
	border-radius: 0;
}
.img-set .swiper-pagination-bullets{
	left: 25px !important;
    width: auto !important;
    bottom: 30px !important;
}
.img-set .swiper-pagination-bullet-active{
	background: var(--orangecolor);
}
.info-content-top-wrapper{
	max-width: 1280px;
	margin: 15px auto 0;
	width: 100%;
}
.info-content-bottom-wrapper{
	margin: 51px auto 0;
	max-width: 1280px;
	width: 100%;
}
.info-content-top-wrapper > .title,
.info-content-bottom h3{
	font-size: 19px;
	font-weight: 600;
	border-radius: 11px;
	border: 1px solid #979797;
	display: inline-block;
	color: var(--orangecolor);
	line-height: 33px;
	width: 119px;
	text-align: center;
	margin-bottom: 20px;
}
.info-content.show{
	display: flex;
	align-items: center;
}
.height-info{
	width: 245px;
	height: 148px;
	background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/height_info.png) center center no-repeat;
	background-size: 100% auto;
	font-size: 21px;
	font-weight: bold;
	color: #000;
	position: relative;
}
.height-info .top{
	position: absolute;
	top: -4px;
	right: 57px;
}
.height-info .bottom{
	position: absolute;
	top: 51px;
	right: 8px;
}
.height-info span{
	display: block;
	text-align: right;
}
.height-info span + span{
	font-size: 14px;
	font-weight: 300;
	line-height: 14px;
}
.detail-info{
	font-size: 16px;
	margin:14px 29px;
}
.detail-info div{
	display: flex;
	align-items: center;
	justify-content: space-between;
	line-height: 21px;
}
.detail-info > div + div{
	margin-top: 12px;
}
.detail-info .title{
	flex: 0 0 138px;
}
.detail-info .value{
	flex: 1 1 auto;
	font-size: 21px;
	font-weight: 900;
}
.level-info{
	border-left: 1px solid #D8D8D8;
	border-right: 1px solid #D8D8D8;
	height: 136px;
	padding: 0 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    line-height: 31px;
    font-size: 14px;
    margin-right: 22px;
}
.cable-car-info{
	font-size: 16px;
	flex: 1 1 auto;
}
.cable-car-info .title{
	font-size: 18px;
	line-height: 26px;
	margin-bottom: 15px;
}
.cable-car-1{
	display: flex;
	align-items: center;
	padding-left: 37px;
	background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/car_a.png) left top no-repeat;
	background-size: 30px 30px;
	font-size: 13px;
	height: 30px;
}
.cable-car-1 span{
	font-size: 16px;
	margin-right: 9px;
	margin-left: 2px;
}
.cable-car-other{
	display: flex;
	gap: 2px;
	margin-top: 6px;
}
.cable-car-other div{
	padding-top: 30px;
	background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/car_b.png) left top no-repeat;
	background-size: 30px 30px;
	width: 30px;
	text-align: center;
}
.cable-car-other .cable-car-3{
	background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/car_c.png) left top no-repeat;
	background-size: 30px 30px;
}
.cable-car-other .cable-car-4{
	background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/car_d.png) left top no-repeat;
	background-size: 30px 30px;
}
.cable-car-other .cable-car-5{
	background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/car_e.png) left top no-repeat;
	background-size: 30px 30px;
}
.photo-thumbnail{
	position: relative;
	overflow: hidden;
	width: 230px;
	height: 150px;
	margin-right: 39px;
	cursor: pointer;
}
.map-img{
	position: absolute;
	z-index: 1;
	width: 100%;
	height: 100%;
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center center;
}
.photo-thumbnail .zoom-in{
	width: 43px;
	height: 43px;
	background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/ic_zoom.png) center center no-repeat;
	background-size: 100% auto;
	position: absolute;
	right: 10px;
	bottom: 10px;
	z-index: 2;
	pointer-events: none;
}
.photo-thumbnail:hover{
	opacity: 0.75;
}
.info-content-bottom{
	display: flex;
	justify-content: space-between;
}
.info-content-bottom ul{
	list-style: none;
	padding: 0 0 0 12px;
}
.feature-info{
	font-size: 16px;
	line-height: 23px;
}
.feature-info li{
	position: relative;
	padding-left: 19px;
}
.feature-info li + li{
	margin-top: 10px;
}
.feature-info li:before {
    width: 11px;
    height: 11px;
    position: absolute;
    left: 0;
    top: 7px;
    content: '';
    background-color: var(--orangecolor);
    transform: rotate(45deg);
}
.hotel-info{
	flex: 0 0 690px;
	margin-left: 56px;
	font-size: 16px;
	line-height: 23px;
}
.hotel-content .title{
	font-size: 26px;
	font-weight: bold;
	line-height: 26px;
	margin-bottom: 19px;
}
.hotel-content-wrapper{
	display: flex;
	gap: 45px;
}
.hotel-content-wrapper .hotel-thumbnail{
	flex: 0 0 220px;
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.hotel-thumbnail img{
	width: 100%;
}

.lightbox{
	opacity: 0;
	z-index: 0;
	transform-origin: center center;
	transform: scale(1);
	transition: 0.5s;

	position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, .75);
    pointer-events: none;
}
.lightbox.show{
    z-index: 20;
	opacity: 1;
	transform: scale(1);
	transition: 0.1s;
	pointer-events: initial;
}
.lightbox .img{
	display: none;
}
.lightbox.show .img{
	max-width: 70vw;
    max-height: 70vh;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate3d(-50%, -50%, 0);
    width: 100%;
    height: 100%;
    overflow: hidden; 
}
.lightbox .close-btn{
	position: absolute;
    right: 27px;
    top: 102px;
    color: white;
    font-size: 16px;
    font-weight: 300;
    cursor: pointer;
    opacity: 1;
    padding-left: 23px;
    background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/close.png) left center no-repeat;
    background-size: 20px;
    line-height: 20px;
}
.lightbox.show .img img{
	width: 100%;
    height: 100%;
    object-fit: contain;
}
/* gear */
.gear-showcase .gear-img{
	width: 1246px;
	margin: 11px auto 0;
	display: block;
	max-width: 100%;
}
.gear-showcase + h3{
	margin-top: 43px;
	font-size: 32px;
	font-weight: 600;
	text-align: center;
	color: var(--bluecolor);
}
.gear-showcase + h3 + .desc{
	margin: 16px auto 0;
	width: 812px;
	text-align: center;
	font-size: 20px;
	color: #092A57;
}
.gear-showcase ~ ul.table{
	margin: 36px auto 48px;
	width: 812px;
	list-style: none;
	font-size: 16px;
	padding: 0;
}
.gear-showcase ~ ul.table li{
	display: flex;
	padding: 0 26px 0 0;
}
.gear-showcase ~ ul.table li:not(:last-child){
	margin-bottom: 7px;
}
.gear-showcase ~ ul.table li div:nth-child(1){
	flex: 0 0 192px;
	padding: 0 0 0 24px;
	color: #0085D7;
	font-weight: 600;
}
.gear-showcase ~ ul.table li.other{
	background-color: #E2F2FF;
	padding: 12px 26px 24px 0;
	margin-top: 15px;
}
#course + h3 + .desc{
	width: 776px;
	font-size: 18px;
	text-align: center;
	margin: 20px auto;
}
.ski-compare-table-block{
	width: 850px;
	margin: 22px auto 0;
}
.ski-compare-table-block .big-title{
	text-align: center;
	font-size: 22px;
	color: #092A57;
	font-weight: 500;
}
.ski-compare-table{
	margin: 26px auto;
	border: 1px solid #979797;
}
.ski-compare-table .top td + td{
	background-color: var(--lightbluecolor);
	color: #fff;
	height: 59px;
	font-size: 19px;
	font-weight: 500;
}
.ski-compare-table td:nth-child(1){
	width: 132px;
	border-right: 1px solid #979797;
}
.ski-compare-table td + td{
	padding: 0 20px 0 30px;
	width: 360px;
}
.ski-compare-table td + td + td{
	padding: 0 40px 0 14px;
}
.ski-compare-table tr + tr td{
	padding-top: 11px;
	padding-bottom: 11px;
}
.ski-compare-table tr:last-child td{
	padding-bottom: 24px;
}
.ski-compare-table tr + tr:nth-child(even) td + td{
	background: #f4f4f4;
}
.ski-compare-table tr td:nth-child(1){
	padding-left: 19px;
}
/* faq */
.faq-a ul {
    padding-left: 1.2em;
}
.faq-section-title{
	position: relative;
	font-size: 28px;
	font-weight: bold;
	text-align: center;
	margin: 32px auto 7px;
	line-height: 28px;
}
.faq-section-title:before,.faq-section-title:after{
	content:'';
	position: relative;
	width: 34px;
	height: 46px;
	display: inline-block;
	vertical-align: middle;
}
.faq-section-title:before{
	background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/faq_title.png) center center no-repeat;
	background-size: 100% auto;
	margin-right: 10px;
}
.faq-section-title:after{
	background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/faq_title.png) center center no-repeat;
	background-size: 100% auto;
	margin-left: 10px;
}
.faq-lists{
	max-width: 90%;
	width: 988px;
	margin: 0 auto 20px;
}
.faq-list{
	border-bottom: 1px solid #979797;
	padding: 11px 0;
}
.faq-q{
	font-size: 21px;
	font-weight: bold;
	min-height: 32px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-left: 34px;
	position: relative;
	cursor: pointer;
	letter-spacing: 1px;
}
.faq-q:before{
	width: 11px;
	height: 11px;
	position: absolute;
	left: 0;
	content: '';
	background-color: #4A99D5;
	transform: rotate(45deg);
}
.faq-a:before, .faq-a:after{
    content: '';
    position: relative;
    display: block;
    width: 100%;
    height: 10px;
}
.faq-q:not(.open) + .faq-a:after{
    display: none;
}
.faq-a{
	padding: 0 80px 0 34px;
	font-size: 17px;
	line-height: 24.5px;

	max-height: 0;
    overflow: hidden;
    transition: max-height 0.2s ease-out;
}
.faq-q.open + .faq-a:before{
	height: 10px;
}
.faq-btn{
	position: absolute;
    right: 24px;
    top: -2px;
    width: 34px;
    height: 34px;
    transform: rotate(0);
    background-image: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/ic_arrow_down.png);
    background-size: contain;
}
.faq-q.open .faq-btn {
    transform: rotate(180deg);
}


.products{
/*	background-color: #EEE3D8;*/
	display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 18px;
    margin: 0 auto;
    padding: 33px;
    
    font-family: var(--defaultfontfamily);
    width: 100%;
    max-width: 1137px;
}
.product{
	border: 3px solid var(--lightbluecolor);
	padding: 11px;
	flex: 0 0 calc(33.33% - 12px);
}
.product .thumbnail{
	width: 100%;
	height: 0;
	padding-bottom: 66.87%;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	border: 3px solid var(--lightbluecolor);
}
.product{
	display: flex;
	flex-direction: column;
}
.product .title{
	font-size: 28px;
	font-weight: 600;
	color: var(--lightbluecolor);
	margin-top: 10px;
	line-height: 1.2;
}
.product .desc{
	font-size: 15px;
	line-height: 20px;
	margin-top: 10px;
}
.product .desc ul{
	padding-left: 20px;
}
.product .bottom{
	flex: 1 0 auto;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.product .bottom .date{
	font-weight: 500;
	line-height: 20px;
	font-size: 15px;
}
.product .bottom .price{
	align-self: flex-end;
	color: var(--orangecolor);
	font-size: 37px;
	font-weight: 500;
}
.product .bottom .price span{
	font-size: 25px;
	font-weight: normal;
}
.tour-block .button {
    display: flex;
    justify-content: space-around;
}
.tour-block .button a {
    display: flex;
    border-radius: 7px;
    background-color: var(--orangecolor);
    color: white;
    text-align: center;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    font-size: 13px;
    font-weight: bold;
    padding: 7px;
    flex: 0 0 calc(50% - 7px);
    white-space: nowrap;
}
.tour-block .button a:before {
    position: relative;
    content: '';
    width: 100%;
    height: 19px;
    background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/ic_plane.png) center center no-repeat;
    background-size: auto 100%;
}
.tour-block .button a + a:before {
    background: url(https://www.egltours.com/travel/pages/japan-ski-tour/images/ic_whatsapp.png) center center no-repeat;
    background-size: auto 100%;
}
.compare-box-list::-webkit-scrollbar {
  height: 5px;
}
.compare-box-list::-webkit-scrollbar-button {
  background: transparent;
  border-radius: 3px;
}

.compare-box-list::-webkit-scrollbar-track-piece {
 background: transparent;
}

.compare-box-list::-webkit-scrollbar-thumb {
  border-radius: 3px;
  background-color: rgba(0, 0, 0, .4);
  border: none;
}
.compare-box-list::-webkit-scrollbar-track {
  box-shadow: transparent;
}


@media only screen and (min-width: 1600px){
}
@media only screen and (max-width: 1280px){	
	.compare-box-list-item div:nth-child(5){
		flex: 0 0 95px;
	}
	.compare-box-list:hover .compare-box-list-item div:nth-child(5){
		flex: 0 0 90px;
	}
	.compare-tab-box-gallery .img-sets{
		height: 39.375vw;
		width: 90vw;
	}
	.compare-tab-box-gallery:after{
		height: 32.639vw;
	}
	.btn-prevnext .swiper-button-next, .btn-prevnext .swiper-button-prev{
		width: 50px;
		height: 50px;
	}
	.btn-prevnext .swiper-button-prev{
		margin-left: -35px;
    	margin-top: -65px;
	}
	.btn-prevnext .swiper-button-next{
		margin-right: -35px;
    	margin-top: -65px;
	}
	.btn-prevnext .swiper-button-next:after, .btn-prevnext .swiper-button-prev:after{
		width: 32px;
		height: 32px;
	}
	.compare-tab-box-gallery .img-set h2 {
	    bottom: 48px;
	    left: -15px;
	    font-size: 30px;
	    line-height: 23px;
	    padding: 20px 28px;
	}
	.compare-tab-box-tab ul li {
	    font-size: 18px;
	    line-height: 23px;
	    padding: 14px 0;
	}
	.compare-tab-box-gallery .img-set:before{
		width: 193px;
		height: 162px;
	}
	.info-content-top-wrapper{
		width: 90%;
	}
	.info-content-bottom-wrapper{
		width: 90%;
	}
	.info-content-top-wrapper > .title, .info-content-bottom h3 {
	    font-size: 16px;
	    border-radius: 9px;
	    line-height: 28px;
	    width: 103px;
	    margin-bottom: 12px;
	}
	.photo-thumbnail{
		width: 180px;
		height: 130px;
		margin-right: 29px;
	}
	.photo-thumbnail .zoom-in{
		width: 33px;
		height: 33px;
	}
	.height-info {
	    width: 225px;
	    height: 128px;
	    font-size: 17px;
	}
	.height-info .top{
		right: 47px;
	}
	.height-info .bottom{
		top: 46px;
	}
	.height-info span + span{
		font-size: 12px;
		line-height: 12px;
	}
	.detail-info {
	    font-size: 14px;
	    margin: 14px 19px;
	}
	.level-info {
	    height: 124px;
	    padding: 0px 15px;
	    line-height: 26px;
	    font-size: 12px;
	    margin-right: 16px;
	}
	.info-content-bottom-wrapper{
		margin-top: 33px;
	}
	.feature-info {
	    font-size: 14px;
	    line-height: 20px;
	}
	.feature-info li{
		padding-left: 16px;
	}
	.feature-info li:before{
		width: 8px;
		height: 8px;
	}
	.feature-info li + li {
	    margin-top: 6px;
	}
	.hotel-info {
	    flex: 0 0 600px;
	    margin-left: 46px;
	}
	.hotel-content{
		font-size: 14px;
		line-height: 20px;
	}
	.hotel-content-wrapper{
		gap: 35px;
	}
	.hotel-content .title {
	    font-size: 20px;
	    line-height: 26px;
	    margin-bottom: 11px;
	}
	.hotel-content-wrapper .hotel-thumbnail{
		flex: 0 0 180px;
	}
	.compare-box-list-title{
		margin-left: 50px;
	}
	h1{
		font-size: 30px;
		line-height: 36px;
	}
	h1:after {
	    height: 21px;
	    bottom: 16px;
	}
	h1 + h2{
		font-size: 24px;
		line-height: 35px;
	}
	.section-desc-box{
		font-size: 16px;
		line-height: 26px;
	}
	.img-set .swiper-pagination-bullets{
		left: 10px !important;
	}
	.img-set .swiper-pagination-bullet {
	    width: 28px;
	    height: 3px;
	}
	.cable-car-info .title {
	    font-size: 15px;
	    line-height: 16px;
	    margin-bottom: 13px;
	}
	.cable-car-1 {
	    padding-left: 34px;
	    background-size: 26px 26px;
	    font-size: 12px;
	    height: 26px;
	    line-height: 12px;
	}
	.cable-car-other div{
		background-size: 26px 26px !important;
	    font-size: 12px;
	    height: 26px;
	    width: 26px;
	}
	.cable-car-1 span {
	    font-size: 15px;
	    margin-right: 7px;
	    margin-left: 1px;
	}
	.detail-info .title {
	    flex: 0 0 116px;
	}
	.detail-info .value {
	    font-size: 18px;
	}

}

@media (max-width: 1200px) {
	.footer02 {
		position: relative;
		float: left;
		padding-top: 5px;
		width: 25%;
		text-align: left;
		font-size: 10px;
		color: #666;
		line-height: 12px;
		font-weight: 300;
	}
}
@media (max-width: 1024px) {
	.gear-showcase + h3{
		font-size: 27px;
	}
	.products{
		padding: 33px;
	}
	
	.content_menu li.sub{
		background-size: 14px auto;
	}
	

	.main_kv {
		margin-top: 7.65625vw;
	}
	.wrapper.row{
		padding:32px 0;
	}
	
    .main_kv:after{
    	height: 90px;
    }

	


    .label-faq {
	    position: absolute;
	    right: 56px;
	    top: 65px;
	    width: 86px;
	}
	.tips-lists {
	    margin: 12px auto 24px;
	}
	.tips-title{
		font-size: 18px;
		padding-left: 20px;
	}
	.tips-title:before {
	    width: 15px;
	    height: 28px;
	}
	.tips-btn{
		width: 28px;
		height: 28px;
		right: 20px;
	}
	.tips-list{
		padding:16px 0;
	}
	.tips-text-content{
	    font-size: 15px;
	    line-height: 23px;
	    padding: 0 66px 0 20px;
	}
	.content_menu .title{
		padding: 10px 22px;
    	font-size: 19px;
	}
	.content_menu ul {
	    padding: 18px 25px 18px 28px;
	    margin-bottom: .5em;
	}
	.content_menu li:not(:last-child) {
	    margin-bottom: 4px;
	}
	.content_menu li.sub + li.sub + li.sub {
	    margin-bottom: 7px;
	}
	.content_menu {
        font-size: 17px;
    }
    .content_menu li.sub{
    	padding-left: 21px;
    }

	.product .title{
		font-size: 22px;
	}
	.product .desc{
		font-size: 13px;
	    line-height: 18px;
	}
	.product .desc ul{
		padding-left: 20px;
	}
	.product .bottom .date{
		line-height: 18px;
		font-size: 13px;
	}
	.product .bottom .price{
		font-size: 31px;
	}
	.product .bottom .price span{
		font-size: 20px;
	}

	.section-title{
		font-size: 22px;
		height: 72px;
		line-height: 72px;
		width: 540px;
	}
	.section-desc-box {
        font-size: 14px;
        line-height: 22px;
    }
    .section-desc-box2 ul {
	    font-size: 15px;
	    line-height: 26px;
	    letter-spacing: 1.2px;
	    padding: 27px 46px;
	}
	.section-desc-box2:before,
	.section-desc-box2:after{
		background-size: 168px auto;
	}
	.vert{
		left: 22px;
		width: calc(100% - 44px);
	}
	.hori{
		top: 22px;
		height: calc(100% - 44px);
	}
	.section-desc-box2 .remark{
		font-size: 26px;
    	line-height: 34px;
	}
	.section-desc-box2 .remark span{
		font-size: 24.6px;
	}
	.section-desc-box2-wrapper {
	    width: 780px;
	    height: 295px;
	}
	.compare-box-list-title {
        margin-left: 20px;
        font-size: 15px;
        line-height: 20px;
        flex: 0 0 123px;
        width: 123px;
    }
    .compare-box-list-title .tri:before{
	    border-width: 24px 24px 0 0;
	}
	.compare-box-list-title .tri:after{
	    border-width: 24px 0 0 24px;
	}
	.compare-box-list-item .title span{
		font-size: 16px;
	}
	.compare-box-list-item .level ul {
	    font-size: 15px;
	    line-height: 21px;
	    margin-bottom: 0;
	}
	.compare-box-list-item .feature ul{
		font-size: 13px;
    	line-height: 15px;
	}
	.compare-box-list-item .distance, .compare-box-list-item .hotel {
	    font-size: 15px;
	    line-height: 19px;
	}
	.compare-box-list-item div:nth-child(5){
		flex: 0 0 90px;
	}
	.compare-box-list:hover .compare-box-list-item div:nth-child(5){
		flex: 0 0 85px;
	}
	.compare-box-list-item .feature li:before{
		width: 14px;
		height: 14px;
		top: 1px;
	}
	.compare-box-list-item .feature li{
		padding-left: 17px;
	}
	.compare-box-list-item .feature li:not(:last-child) {
	    margin-bottom: 6px;
	}
	.compare-box-list .compare-box-list-item:nth-child(1) {
	    flex: 0 0 260px;
	}
	.compare-box-list .compare-box-list-item:nth-child(2) {
	    flex: 0 0 236px;
	}
	.compare-box-list .compare-box-list-item:nth-child(3) {
	    flex: 0 0 262px;
	}
	.compare-box-list .compare-box-list-item:nth-child(4) {
	    flex: 0 0 244px;
	}
	.compare-box-list-item .level li.label{
		font-size: 13px;
	}
	.compare-box + .skiman:after{
		width: 156px;
		height: 92px;
	}
	.hotel-info{
		flex: 0 0 530px;
	}
	.height-info {
        width: 205px;
        height: 118px;
        font-size: 15px;
    }
    .height-info .top {
        right: 41px;
        top: -1px;
    }
    .height-info .bottom {
        top: 43px;
    }
    .height-info span + span {
        font-size: 10px;
        line-height: 10px;
    }
    .photo-thumbnail {
        width: 160px;
        height: 118px;
        margin-right: 19px;
    }
    .detail-info {
        font-size: 13px;
        margin: 12px 14px;
    }
    .detail-info .title {
        flex: 0 0 106px;
    }
    .detail-info .value {
        font-size: 16px;
    }
    .faq-section-title{
    	transform: scale(0.9);
    	transform-origin: top center;
    }
    .faq-lists{
    	transform: scale(0.9);
    	transform-origin: top center;
    	margin-bottom: -30px;
    }
}
@media (max-width: 768px) {
	
	.content_menu .title{
		padding: 10px 18px;
    	font-size: 17px;
	}
	.content_menu ul {
	    padding: 15px 23px 16px 25px;
	    margin-bottom: .5rem;
	}
	.content_menu li:not(:last-child) {
	    margin-bottom: 6px;
	}
	.content_menu{
		font-size: 17px;
		width: 440px;
	}

    .desktop{
    	display: none;
    }
    
	
	.wrapper {
		padding: 30px 10px;
	}
	.w970{
		max-width: 100%;
	}
	
	.footer01 {
		display: none;
	}
	.footer02 {
		position: relative;
		float: none;
		padding-top: 12px;
		width: 100%;
		text-align: left;
		font-size: 12px;
		color: #666;
		line-height: 14px;
		font-weight: 300;
		text-align: center;
	}
	.footer03 {
		position: relative;
		float: none;
		width: 100%;
		margin: 0 auto;
		max-width: 590px;
		text-align: center;
	}
	:root{
		--detailfont: 15px;
	}

	.product .title{
		font-size: 18px;
	}
	.product .desc{
		font-size: 12px;
	    line-height: 17px;
	}
	.product .desc ul{
		padding-left: 17px;
	}
	.product .bottom .date{
		line-height: 17px;
		font-size: 12px;
	}
	.product .bottom .price{
		font-size: 27px;
	}
	.product .bottom .price span{
		font-size: 16px;
	}
	.product .thumbnail{
		border-width: 2px;
	}
	.product {
	    border-width: 2px;
	    padding: 8px;
	}
	.products{
		gap: 8px;
        padding: 13px;
    }

    .compare-tab-box-tab ul li, .compare-tab-box-tab ul li:hover{
		background-color: white;
		color: #333;
		font-weight: 500;
	}
    h1 {
        font-size: 23px;
        line-height: 30px;
    }
    h1:after {
        height: 15px;
        bottom: 13px;
    }
    h1 + h2 {
        font-size: 19px;
        line-height: 28px;
    }
    .section-title {
        font-size: 18px;
        height: 62px;
        line-height: 62px;
        width: 440px;
    }
    .section-desc-box{
    	padding: 58px 40px 28px;
    }
    .section-desc-box2 ul {
        font-size: 14px;
        line-height: 22px;
        letter-spacing: 1px;
        padding: 24px 36px;
    }
    .section-desc-box2-wrapper {
        width: 600px;
        height: 255px;
    }
    .section-desc-box2 .remark {
        font-size: 22px;
        line-height: 24px;
    }
    .section-desc-box2 .remark span {
        font-size: 19.6px;
    }
    .compare-box-list-title{
    	height: 518px;
    }
    .compare-box-list{
    	height: 538px;
    }
    .compare-box-list-item div:nth-child(1){
    	flex: 0 0 98px;
    }
    .compare-box-list-item div:nth-child(2) {
	    flex: 0 0 106px;
	}
    .compare-box-list-item .level{
    	padding-top: 18px;
    }
    .compare-box-list-item .feature {
	    padding-top: 23px;
	}
	.compare-box-list-item div:nth-child(5) {
        flex: 0 0 80px;
    }
    .compare-box-list:hover .compare-box-list-item div:nth-child(5){
		flex: 0 0 75px;
	}
    .compare-box-list-item div:nth-child(4) {
	    flex: 0 0 62px;
	}
	.compare-box-list .compare-box-list-item{
		padding: 0 19px;
	}
	.compare-box-list .compare-box-list-item:nth-child(1) {
        flex: 0 0 240px;
    }
    .compare-tab-box-tab ul li {
        font-size: 15px;
        line-height: 20px;
        padding: 12px 0;
    }
    .compare-tab-box-tab{
    	border-width: 4px;
    }
    .compare-tab-box-gallery .img-set h2 {
        bottom: 21px;
        left: -15px;
        font-size: 21px;
        line-height: 20px;
        padding: 14px 21px;
    }
    .btn-prevnext .swiper-button-next, .btn-prevnext .swiper-button-prev {
        width: 40px;
        height: 40px;
    }
    .btn-prevnext .swiper-button-prev {
        margin-left: -29px;
        margin-top: -44px;
    }
    .btn-prevnext .swiper-button-next {
        margin-right: -29px;
        margin-top: -44px;
    }
    .btn-prevnext .swiper-button-next:after, .btn-prevnext .swiper-button-prev:after {
        width: 26px;
        height: 26px;
    }
    .compare-tab-box-gallery .img-set:before {
        width: 103px;
        height: 92px;
    }
    .img-set .swiper-pagination-bullets {
	    left: 3px !important;
	    bottom: 9px !important;
	}
	.img-set .swiper-pagination-bullet {
        width: 18px;
        height: 2px;
    }
    .info-content-top-wrapper > .title, .info-content-bottom h3 {
        font-size: 13px;
        border-radius: 7px;
        line-height: 24px;
        width: 86px;
        margin-bottom: 8px;
    }
    .info-content-top-wrapper,
    .info-content-bottom-wrapper{
        width: 94%;
    }
    .info-content.show{
    	flex-wrap: wrap;
    }
    .photo-thumbnail {
        width: 223px;
        height: 118px;
        margin-right: 29px;
    }
    .height-info .top{
    	top: -3px;
    }
    .detail-info {
        font-size: 14px;
        margin: 12px 24px;
    }
    .detail-info .title {
        flex: 0 0 126px;
    }
    .detail-info .value {
        font-size: 20px;
    }
    .level-info {
        height: 124px;
        padding: 0px 20px;
        line-height: 28px;
        font-size: 14px;
        margin-right: 29px;
    }
    .cable-car-info{
    	margin-top: -10px;
    }
    .cable-car-info .title{
    	margin-bottom: 9px;
    }
    .cable-car-other div{
    	padding-top: 26px;
    }
    .info-content-bottom{
    	flex-wrap: wrap;
    }
    .feature-info, .hotel-content{
        font-size: 13px;
        line-height: 19px;
    }
    .feature-info li:before{
    	top: 5px;
    }
    .hotel-info{
    	flex: 1 1 auto;
    	margin-left: 0;
    	margin-top: 10px;
    }
    .hotel-content-wrapper {
        gap: 30px;
        padding-left: 10px;
        padding-top: 5px;
        padding-right: 10px;
    }
    .info-content-bottom-wrapper {
        margin-top: 20px;
    }
    .gear-showcase + h3 + .desc,
    .gear-showcase ~ ul.table,
    #course + h3 + .desc,
    .ski-compare-table-block{
    	max-width: 90%;
    }
    .gear-showcase + h3 {
	    margin-top: 38px;
	    font-size: 23px;
	}
	.gear-showcase + h3 + .desc{
		font-size: 15px;
	}
	.gear-showcase ~ ul.table{
	    margin: 30px auto 40px;
	    font-size: 14px;
	}
	.gear-showcase ~ ul.table li div:nth-child(1) {
	    flex: 0 0 162px;
	    padding: 0 0 0 18px;
	}
	#course + h3 + .desc{
		font-size: 14px;
	}
	.ski-compare-table-block .big-title{
		font-size: 17px;
	}
	.ski-compare-table .top td + td{
		font-size: 15px;
		height: 49px;
	}
	.ski-compare-table tr td:nth-child(1) {
	    padding-left: 13px;
	    font-size: 15px;
	    font-size: 13px;
	}
	.ski-compare-table td:nth-child(1) {
	    width: 116px;
	}
	.ski-compare-table td + td {
	    padding: 0 10px 0 20px;
	    width: calc((100% - 58px) / 2);
	    font-size: 13px;
	}
	.ski-compare-table tr + tr td {
	    padding-top: 8px;
	    padding-bottom: 8px;
	}
	.faq-section-title{
    	transform: scale(1);
    }
    .faq-lists{
    	transform: scale(1);
    	margin-bottom: 0px;
    }
    .faq-section-title {
	    font-size: 20px;
	    margin: 28px auto 7px;
	    line-height: 20px;
	}
	.faq-section-title:before, .faq-section-title:after{
		width: 25px;
		height: 32px;
	}
	.faq-section-title:before{
		margin-right: 5px;
	}
	.faq-section-title:after{
		margin-left: 5px;
	}
	.faq-q:before {
	    width: 8px;
	    height: 8px;
	}
	.faq-q {
	    font-size: 16px;
	    min-height: 24px;
	    padding-left: 19px;
	}
	.faq-btn {
	    right: 14px;
	    top: -1px;
	    width: 25px;
	    height: 26px;
	}
	.faq-a {
	    padding: 0 60px 0 18px;
	    font-size: 14px;
	    line-height: 18px;
	}
	.faq-a:before, .faq-a:after{
		height: 4px;
	}
	.faq-q.open + .faq-a:before {
	    height: 6px;
	}
	.lightbox.show .img{
		max-width: 85vw;
		max-height: 85vw;
	}
}
@media (max-width: 576px) {
	.map-box{
		max-width: 85%;
		padding: 8px;
        border-radius: 20px;
	}
	h2.border, h3.border {
        font-size: 21px;
        width: 214px;
        height: 62px;
        line-height: 58px;
    }
    .underline:before, .underline:after {
        width: calc(50% - 74px - 29px - 30px);
        height: 2px;
    }
    h2.border span:nth-child(1), h3.border span:nth-child(1) {
        left: -22px;
    }
    h2.border span:nth-child(2), h3.border span:nth-child(2) {
        right: -22px;
    }
    .underline{
    	padding: 14px 25px;
    	margin: 0 22px 10px;
    }
    .hotel .hotel-desc {
        font-size: 12px;
        line-height: 16px;
    }
    .hotel .text-content {
        padding: 10px 14px 18px;
    }
    .hotel {
        border-radius: 14px;
    }
    .tour-block .button a {
        font-size: 13px;
    }
    .tour-block .button a:before {
        height: 19px;
    }
	.top_bar {
		position: fixed;
		width: 100%;
		background: rgba(255, 255, 255, 1);
		z-index: 9999;
		overflow-x: hidden;
	}
	.top_menu {
		width: 100%;
	}
	.navbar-brand {
		width: 19%;
		padding-bottom: 6px;
		max-width: 140px;
		min-width: 70px;
	}	
	.main_kv{
		margin-top: 44px;
	}
	.h576{
		display: none;
	}
	.m576{
		display: inline-block;
	}
	
    .mobile{
    	display: block;
    }
    .desktop{
    	display: none;
    }

	:root{
		--detailfont: 12px;
	}
	
	
    
    .wrapper.row {
        padding: 24px 0;
    }
    .desc-content{
    	max-width: 90%;
    	margin-top: 0;
    	font-size: 14px;
        line-height: 1.5;
    }
    
    .products{
    	display: flex !important;
    }
    .products + .products {
	    padding: 0 18px 12px;
	}
	
    .main_kv:after {
        height: 44px;
        bottom: -18px;
    }
    

    .swiper-button-next{
		right: 10px !important;
	}
	.swiper-button-prev{
		left: 10px !!important;
	}
	
    .content_menu{
    	font-size: 14px;
    	margin-top: -2em;
    	max-width: 100%;
    }		
    .content_menu ul {
        padding: 15px 20px 14px 19px;
    }
    .content_menu li.sub {
        background-size: 11px auto;
        padding-left: 16px;
    }
    .content_menu li:not(:last-child),
    .content_menu li.sub + li.sub + li.sub{
        margin-bottom: 4px;
    }
    .content_menu li.sub + li.sub + li.sub + li.sub {
	    margin-bottom: 6px;
	}
    
    .product{
    	flex:0 0 100%;
    }
    

    .product{
    	padding: 15px;
    }
    .product .title{
		font-size: 23px;
	}
	.product .desc{
		font-size: 15px;
	    line-height: 22px;
	}
	.product .desc ul{
		padding-left: 17px;
	}
	.product .bottom .date{
		line-height: 22px;
		font-size: 15px;
	}
	.product .bottom .price{
		font-size: 37px;
	}
	.product .bottom .price span{
		font-size: 22px;
	}
	
	
    .section-title {
        font-size: 16px;
        height: 51px;
        line-height: 51px;
        width: 370px;
    }
    .section-desc-box{
    	padding: 58px 19px 20px;
    	font-size: 13px;
        line-height: 18px;
        text-align: justify;
    }
    h1 {
        font-size: 20px;
        line-height: 27px;
        max-width: 95%;
    }
    h1:after {
        height: 15px;
        bottom: 13px;
        width: 150px;
        margin: 0 auto;
    }
    h1 + h2 {
        font-size: 14px;
        line-height: 20px;
        max-width: 100%;
    }
    .content_menu a{
    	letter-spacing: 0;
    }
    .section-desc-box2-wrapper {
        width: 380px;
        height: 340px;
        max-width: 93%;
    }
    .section-desc-box2 ul{
        font-size: 13px;
        line-height: 16px;
        letter-spacing: 0px;
        padding: 24px 26px;
    }
    .section-desc-box2 li{
    	display: flex;
    	margin-bottom: 12px;
    }
    .section-desc-box2 ul li span {
	    padding-right: 5px;
	    font-size: 18px;
	}
	.section-desc-box2 ul li:nth-child(6) span{
		margin-top: -2px;
	}
	.compare-box + .skiman:after {
        width: 96px;
        height: 62px;
    }
    .compare-box-list-title {
        margin-left: 9px;
        font-size: 12px;
        line-height: 17px;
        flex: 0 0 68px;
        width: 68px;
    }
    .compare-box-list-title .name {
	    padding: 20px 6px 0;
	    justify-content: center;
	    text-align: right;
	    line-height: 18px;
	}
	.compare-box-list{
		scroll-snap-type: initial;
	}
	.compare-box-list-title:after{
		transform: rotate(-.9deg);
	}
	.compare-box-list-item div:nth-child(5) {
        flex: 0 0 87px;
    }
    .compare-box-list:hover .compare-box-list-item div:nth-child(5){
		flex: 0 0 82px;
	}
    .compare-box-list .compare-box-list-item {
        padding: 0 16px;
    }
    .compare-box-list .compare-box-list-item:nth-child(1) {
        flex: 0 0 220px;
    }
    .compare-box-list .compare-box-list-item:nth-child(2) {
        flex: 0 0 210px;
    }
    .compare-box-list .compare-box-list-item:nth-child(3) {
        flex: 0 0 244px;
    }
    .compare-box-list .compare-box-list-item:nth-child(4) .level{
    	width: 80%;
    }
    .compare-box-list-item div:nth-child(5){
    	padding-top: 22px;
    }
    .compare-tab-box-tab ul li{
    	font-size: 11px;
    	line-height: 15px;
    }
    .compare-tab-name:nth-child(1){
    	flex: 0 0 23%;
    }
    .compare-tab-name:nth-child(2){
    	flex: 0 0 29%;
    }
    .compare-tab-name:nth-child(3){
    	flex: 0 0 26%;
    }
    .compare-tab-name:nth-child(4){
    	flex: 0 0 22%;
    }
    .compare-tab-box-tab ul li + li{
    	border-color: #ddd;
    }
    .compare-tab-box-gallery .img-sets {
        height: 56vw;
    }
    .compare-tab-box-gallery:after {
        height: 51vw;
    }
    .gallery-photo{
    	background-size: cover;
    }
    .compare-tab-box-gallery .img-set:before {
        width: 81px;
        height: 67px;
        right: -18px;
        bottom: -10px;
    }
    .compare-tab-box-gallery .img-set:after{
    	height: 39px;
    }
    .img-set .swiper-pagination-bullet{
    	width: 12px;
    }
    .img-set .swiper-pagination-bullets {
        left: -2px !important;
        bottom: -10px !important;
    }
    .btn-prevnext .swiper-button-next, .btn-prevnext .swiper-button-prev{
    	width: 36px;
    	height: 36px;
    }
    .btn-prevnext .swiper-button-prev {
        margin-left: -27px;
        margin-top: -19px;
    }
    .btn-prevnext .swiper-button-next {
        margin-right: -27px;
        margin-top: -19px;
    }
    .compare-tab-box-gallery .img-set h2 {
        bottom: -3px;
        left: -10px;
        font-size: 14px;
        line-height: 16px;
        padding: 9px 10px;
    }
    .info-content-top-wrapper{
    	margin-top: 23px;
    	width: 95%;
    }
    .photo-thumbnail {
        width: 147px;
        height: 118px;
        margin-right: 12px;
    }
    .lightbox .close-btn{
    	top: 62px;
    	right: 16px;
    }
    .detail-info {
        margin: 19px 14px 19px 1px;
        font-size: 12px;
    }
    .detail-info .title {
        flex: 0 0 98px;
    }
    .detail-info .value {
        font-size: 16px;
    }
    .level-info {
        height: 114px;
        padding: 0px 5px 0 10px;
        line-height: 26px;
        font-size: 13px;
        margin-right: 0;
        border-right: 0;
    }
    .detail-info > div + div{
    	margin-top: 5px;
    }
    .cable-car-info {
        margin-top: 5px;
        display: flex;
    }
    .cable-car-info .title{
    	margin-top: 4px;
    	order: 0;
    	margin-bottom: 0;
    	margin-right: 13px;
    }
    .cable-car-other{
    	margin-top: 0;
    }
    .cable-car-1{
    	order: 2;
    	margin-left: 6px;
    	padding-left: 30px;
    }
    .cable-car-other div {
        padding-top: 24px;
    }
    .info-content-bottom-wrapper {
        margin-top: 32px;
    }
    .info-content-bottom ul{
    	padding-left: 2px;
    }
    .feature-info li + li {
        margin-top: 5px;
    }
    .hotel-content-wrapper {
        gap: 20px;
        padding-left: 2px;
        padding-top: 2px;
        padding-right: 0px;
    }
    .hotel-content .title {
        font-size: 17px;
        margin-bottom: 8px;
    }
    .feature-info, .hotel-content {
        line-height: 18px;
        text-align: justify;
    }
    .hotel-content-wrapper .hotel-thumbnail {
        flex: 0 0 150px;
    }
    .gear-showcase + h3{
    	font-size: 19px;
    }
    .gear-showcase + h3 + .desc{
    	font-size: 14px;
    }
    .gear-showcase ~ ul.table{
    	font-size: 12px;
    	line-height: 17px;
    }
    .gear-showcase ~ ul.table li{
    	padding-right: 10px;
    }
    .gear-showcase ~ ul.table li div:nth-child(1) {
        flex: 0 0 128px;
        padding: 0 0 0 11px;
    }
    .gear-showcase ~ ul.table li.other {
	    padding: 12px 10px 14px 0;
	    margin-top: 12px;
	}
	.ski-compare-table-block .big-title {
        font-size: 13px;
    }
    .ski-compare-table{
    	margin: 16px auto;
    }
    .ski-compare-table tr td:nth-child(1) {
        padding-left: 6px;
        font-size: 12px;
        padding-right: 6px;
        line-height: 16px;
    }
    .ski-compare-table td:nth-child(1){
    	width: 67px;
    }
    .ski-compare-table .top td + td {
        font-size: 12px;
        height: 41px;
        line-height: 17px;
    }
    .ski-compare-table td + td {
        padding: 0 3px 0 9px;
        line-height: 16px;
        font-size: 12px;
    }
    .ski-compare-table td + td + td{
    	padding: 8px 10px;
    }
    .ski-compare-table tr:last-child td {
	    padding-bottom: 14px;
	}
    .faq-q:before{
    	top: 7px;
    }
    .faq-q{
    	font-size: 14px;
    	letter-spacing: 0;
    	padding-left: 16px;
    	min-height: 21px;
    }
    .faq-a{
    	padding: 0 40px 0 16px;
        font-size: 12px;
        line-height: 16px;
    }
    .faq-btn {
        right: 7px;
        top: 0px;
        width: 19px;
        height: 22px;
    }
    .faq-section-title {
        font-size: 17px;
        margin: 28px auto 7px;
        line-height: 17px;
    }
    .faq-section-title:before, .faq-section-title:after {
        width: 20px;
        height: 28px;
    }
    .section-desc-box2 .remark{
    	right: 10px;
    	bottom: 25px;
    }
    .info-content[data-tab="c02"] .level-info,
    .info-content[data-tab="c03"] .level-info,
    .info-content[data-tab="c04"] .level-info{
    	font-size: 11px;
    }
    #course + h3 + .desc {
        font-size: 13px;
    }
    .compare-box-list-item .title span {
        font-size: 14px;
        padding: 3px 12px 4px;
        margin-top: 59px;
    }
    .compare-box-list-item .distance, .compare-box-list-item .hotel {
        font-size: 14px;
        line-height: 17px;
    }
    .compare-box-list{
    	overflow: auto;
    }



    .compare-box-list::-webkit-scrollbar {
	  height: initial;
	}
	.compare-box-list::-webkit-scrollbar-button {
	  background: initial;
	  border-radius: initial;
	}

	.compare-box-list::-webkit-scrollbar-track-piece {
	 background: initial;
	}

	.compare-box-list::-webkit-scrollbar-thumb {
	  border-radius: initial;
	  background-color: initial;
	  border: initial;
	}
	.compare-box-list::-webkit-scrollbar-track {
	  box-shadow: initial;
	}
}
@media (max-width: 375px) {
	.main_kv {
		margin-top: 44.16px;
	}
}
