@charset "utf-8";
/* CSS Document */

/*niseko.css 556*/
@media screen and (min-width: 768px) {
	#pagetop:hover {
		background-color: #2E4EA0;
		border-color: #2E4EA0;
	}
}
#footer .rnav a > span {
    color: #2E4EA0;
}
#footer .rnav a::before {
	border-top: 1px solid #2E4EA0;
	border-right: 1px solid #2E4EA0;
}
#footer .rnav a > span::before {
	background: url(../images/en/ico-reservation.svg) no-repeat;
}
/*niseko.css 1281*/
.page_title::after {
	content: "";
	display: block;
	width: 40px;
	margin: 30px auto 0;
	border-top: 1px solid #2E4EA0;
	position: absolute;
	left: calc(50% - 20px);
	bottom: 50px;
}

/*niseko.css 1292*/
.page_title h1 {
	padding-top: 60px;
	margin-bottom: 20px;
	font-size: 5rem;
	line-height: 1.3;
	color: #2E4EA0;
}

.page_title h2 {
	margin-bottom: 50px;
	font-size: 3.2rem;
	line-height: 1.3;
	color: #2E4EA0;
}
@media screen and (max-width: 767px) {
	.page_title {
		top: -30px;
		margin-bottom: 0;
	}
	.page_title::after {
		width: 20px;
		margin-top: 20px;
	left: calc(50% - 10px);
	bottom: 18%;
	}
	.page_title h1 {
		padding-top: 30px;
		margin-bottom: 15px;
		font-size: 2.4rem;
	}
	.page_title h1 span {
		display: block;
	}
	.page_title h2 {
		margin-bottom: 24px;
		font-size: 1.6rem;
		line-height: 1.3;
		color: #2E4EA0;
	}
	.page_title p {
		font-size: 1.3rem;
	}
}

/*niseko.css 1299*/
.page_title p {
	font-size: 1.8rem;
	line-height: 1.3;
	letter-spacing: 0.08em;
	font-weight: 300;
	color: #2E4EA0;
}

/*niseko.css 1366*/
.main_block::before {
	background-color: #2E4EA0;
}

/*niseko.css 1379*/
.main_block .text {
	position: relative;
	padding-top: 60px;
	padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
	
	.page_title p {
		font-size: 1.6rem;
		line-height: 1.3;
		letter-spacing: 0.08em;
		font-weight: 300;
		color: #2E4EA0;
	}
	.main_block .text {
		padding-top: 30px;
		padding-bottom: 30px;
	}
}

/*niseko.css 1499*/
.concept_section > header li {
	position: relative;
	width: 100%;
	text-align: center;
}

@media screen and (min-width: 768px), print {
/*niseko.css 1602*/
	.concept_section > header ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		padding-left: max(0px, calc((1240px - 100%) * .4));
		font-size: 3.8rem;
		line-height: 1.2;
		white-space: nowrap;
	}

/*niseko.css 1616*/
	.concept_section > header li + li {
		padding-left: 0px;
		padding-top: 110px;
	}
	.concept_section > header li + li::before,
	.concept_section > header li + li::after {
		top: 40px;
		left: 50%;
		margin-left: -0.5em;
	}
	
/*niseko.css 1749*/
	[lang="en"] .concept_contents p {
		width: 650px;font-family: 'Poppins', sans-serif;
	}
	[lang="en"] .concept_contents p.fzl {
		width: 545px;
		text-align: justify;
		/*margin-bottom: 100px;*/
	}
	[lang="en"] .concept_contents p.fzl.end {
		margin-bottom: 0px;
		width: 100%;
		letter-spacing: 0.018em;
		margin-top: 1.5em;
	}
/*niseko.css 1757*/
	[lang="en"] .concept_contents .hokkaido {
		top: -120px;
	}
}

/*niseko.css 2022*/
.features_section::before {
	content: "";
	position: absolute;
	left: 0;
	top: 200px;
	bottom: 10px;
	width: 82%;
	max-width: calc(50% + 500px);
	background-color: #2E4EA0;
	z-index: -1;
}
@media screen and (max-width: 767px) {
	.features_section::before {
		content: "";
		position: absolute;
		left: 0;
		top: 140px;
		bottom: 10px;
		width: 100%;
		max-width:100%;
		background-color: #2E4EA0;
		z-index: -1;
	}
}

/*niseko.css 2045*/
.features_contents p + p {
	margin-top: 1.5em;
	font-size: 1.8rem;
	letter-spacing: 0.02em;
}

/*niseko.css 2327*/
.plan_section .plan_contents .schedule h4 {
	margin-bottom: 32px;
	font-size: 3.2rem;
	line-height: 1.4;
	white-space: nowrap;
}
.plan_section .plan_contents .schedule h4 .txt_s{
	display: block;
	font-size: 2.0rem;
	line-height: 1.4;
	white-space: nowrap;
	color: #282828;
	letter-spacing: 0.05em;
	padding-top: 0.5em;
}
.plan_section .plan_contents .schedule h4 .txt_s.jp{
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
}
@media screen and (max-width: 767px) {
	.plan_section .plan_contents .schedule h4 {
		margin-bottom: 35px;
		font-size: 2.5rem;
		white-space: normal;
	}
	.plan_section .plan_contents .schedule h4 .txt_s{
		font-size: 1.4rem;
		white-space: normal;
	}
}

.plan_section .plan_contents .schedule ol {
	margin: 0 0 80px;
}
.plan_section .plan_contents .schedule ol .note {padding-left: 8%;margin-top: -32px;display: block;}
/*niseko.css 2332*/
.plan_section .plan_contents .schedule ol.no_line::before {
	content: none;
}

.plan_section .plan_contents .schedule .clock {
	position: absolute;
	top: -5px;
	left: 10px;
	width: 40px;
	height: 40px;
	background-color: #2E4EA0;
	border-radius: 100%;
}
.plan_section .plan_contents .schedule .clock.hour0800::before {
	transform: rotate(240deg);
}
.plan_section .plan_contents .schedule .clock.hour0830::before {
	transform: rotate(255deg);
}
.plan_section .plan_contents .schedule .clock.hour0945::before {
	transform: rotate(293deg);
}
.plan_section .plan_contents .schedule .clock.hour1030::before {
	transform: rotate(295deg);
}
.plan_section .plan_contents .schedule .clock.hour1200::before {
	transform: rotate(360deg);
}
.plan_section .plan_contents .schedule .clock.hour1330::before {
	transform: rotate(45deg);
}
.plan_section .plan_contents .schedule .clock.time45::after {
	transform: rotate(270deg);
}
@media screen and (max-width: 767px) {
	.plan_section .plan_contents .schedule .clock {
		top: 4px;
		left: 0;
		width: 30px;
		height: 30px;
	}
	.plan_section .plan_contents .schedule li {
		margin-bottom: 20px;
	}
	.plan_section .plan_contents .schedule ol .note {padding-left: 15%;margin-top: -16px;display: block;line-height: 1.4;}
}

@media screen and (min-width: 768px), print {
	.plan_section .plan_contents .schedule li.wide {
		padding-right: 0;
		min-height: 2.5em;
		margin-bottom: 24px;
	}
	.plan_section .plan_contents .schedule li.wide .clock{
		top:calc(50% - 20px);
	}
	.plan_section .plan_contents .schedule li.wide dl {align-items: center;}
	
}

/*niseko.css 2841*/
.bnr_section a dd {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100px;
	background-color: #2E4EA0;
	color: #fff;
	font-size: 2.2rem;font-family: 'Poppins', sans-serif;font-weight: 500;
}

/*niseko.css 3130*/
.plan_section {
	position: relative;
	overflow: hidden;
	padding: 140px 0;
	margin-bottom: 140px;
	background-color: #2E4EA0;
}
@media screen and (max-width: 767px) {
	.plan_section {
		margin-bottom: 60px;
		padding: 50px 0 60px 8vw;
	}
	.bnr_section a dd {
		font-size: 1.5rem;
	}
}

/*niseko.css 3145*/
.plan_section .plan_contents .add_box .add_stit {
	font-size: 3.1rem;
	letter-spacing: 0.025em !important;
	color: #2E4EA0;
	margin-top: 46px;
}
@media screen and (max-width: 767px) {
	.plan_section .plan_contents .add_box .add_stit {
		font-size: 1.7rem;
		letter-spacing: 0.025em !important;
		margin-top: 26px;
		text-align: center;
		width: calc(100vw - 8vw);
		margin-left: -8vw;
	}
}

/*niseko.css 3272*/
.plan_section .plan_contents .schedule .plan_txt {
	font-size: 2.4rem;
	color: #2E4EA0;
	font-weight: 500;
	margin-bottom: 0.5rem;
	font-family: 'Poppins', sans-serif;
}
@media screen and (max-width: 767px) {
	.plan_section .plan_contents .schedule .plan_txt {
		font-size: 1.6rem;
	}
}

.ph100 {width: 100%;height: auto;margin-bottom: 40px;}
.ph100.col2 {display: flex;justify-content: space-between;margin-top: 40px;}
.ph100.col2 picture {width: 50%;height: auto;}
.ph100.col2 picture img {width: 100%;height: auto;}
.schedule h2 {font-size: 2.6rem;font-weight: 400;color: #282828;}
.schedule p {letter-spacing: 0.01em;}
@media screen and (max-width: 767px) {
	.schedule h2 {font-size: 4.4vw;font-weight: 500;color: #282828;line-height: 1.5em;margin-bottom: 10px;}
	.schedule p {letter-spacing: 0.01em;margin-bottom: 10%;line-height: calc(70/35);}
}


