@charset "UTF-8";
/* CSS Document */

html, 
body,
#wrapper {
  height: 100%;
  min-height: 100%;
}

body {
	background:#fff;
	position: relative;
	margin:0;
	padding:0;
	text-align: center;
	font-size: 15px;
	line-height: 1.8;
	color: #404040;
	font-family: '游ゴシック', YuGothic, 'メイリオ', 'Mairyo', sans-serif;
}

a {
	color:#d8d9b6;
	outline:none;
	text-decoration: none;
	-webkit-transition: 0.1s ease-in-out;  
	-moz-transition: 0.1s ease-in-out;  
	-o-transition: 0.1s ease-in-out;  
	transition: 0.1s ease-in-out;
}

a:hover {
	opacity:0.4;
	filter:alpha(opacity=40);
}

a.btn {
	display: block;
	width: 250px;
	height: 50px;
	line-height: 3.3;
	color: #404040;
	border: 1px solid #595959;
	text-align: center;
	background: #fff;
}

a.btn:hover {
	color: #fff;
	background: #595959;
	opacity:1;
	filter:alpha(opacity=100);
}

img {
	border:0;
}

p {
	margin:0;
}

ul {
	margin:0;
	padding:0;
	list-style:none;
}

ul li {
	margin:0;
	padding:0;
}

dl, dl dt, dl dd {
	margin:0;
	padding:0;
}

h1, h2, h3, h4 {
	margin:0;
	padding:0;
	line-height:1;
	font-weight: normal;
}

.mincho {
	font-family: YuMincho, "Yu Mincho", "serif" ;
}

header {
	width: 100%;
	position: fixed;
	z-index: 9999;
	top: 0;
	left: 0;
}

#logo {
	line-height: 0;
	text-align: left;
}

#logo img {
	width: 364px;
	height: auto;
	margin: 0 0 0 30px;
	transition: 0.5s ease;
}
	
nav {	
	width: 100%;
	height: 70px;
	position: relative;
	background: #ffffff;
}
 
.drawer {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: space-between;
	position: relative;
	height: 70px;
}

.menu ul{
	height: auto;
	background: #fff;
}
	
.menu ul li a {
	display:block;
	padding: 2em;
	border-top: 1px dotted #CCC;
	text-decoration:none;
	color: #333;
	letter-spacing: 0.08em;
}

.menu ul li.lang {
	border-top: 1px dotted #CCC;
}

.menu ul li.lang a {
	display:inline-block;
	padding: 2em;
	border-top: none;
	text-decoration:none;
	color: #333;
	letter-spacing: 0.08em;
}
  
.menu ul li a:hover {
	background-color:#e5e5e5;
	opacity:1;
	filter:alpha(opacity=100);
}

.menu {
	width: 100%;
	font-size:13.5px;
	text-align:center;
	transition: 0.5s ease;
	-webkit-transform: translateX(-100%);
	transform: translateX(-100%);
}
 
/*OPEN時の動き*/
.menu.open {
	-webkit-transform: translateX(0%);
	transform: translateX(0%);/*メニューを元の位置へ戻す*/
}
	
/*トグルボタンのスタイルを指定*/
.Toggle {
    display: block;
    position: fixed;    /* bodyに対しての絶対位置指定 */
    width: 40px;
    height: 40px;
    cursor: pointer;
    z-index: 3;
	right:25px;
}
 
.Toggle span {
    display: block;
    position: absolute;
    width: 40px;
    border-bottom: solid 3px #333;
    -webkit-transition: .35s ease-in-out;	/*変化の速度を指定*/
    -moz-transition: .35s ease-in-out;		/*変化の速度を指定*/
    transition: .35s ease-in-out;			/*変化の速度を指定*/
}

.Toggle span:nth-child(1) {
    top:5px;
}

.Toggle span:nth-child(2) {
    top: 18px;
}

.Toggle span:nth-child(3) {
    top: 32px;
}
	
.Toggle.active span:nth-child(1) {
    top: 18px;
/* 1番目のspanをマイナス45度に */
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
 
/* 2番目と3番目のspanを45度に */
.Toggle.active span:nth-child(2),
.Toggle.active span:nth-child(3) {
    top: 18px;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    transform: rotate(45deg);
}	

.floating-banner {
    position: fixed;
    z-index: 99999;
    bottom: 30px;
    right: 30px;
}
.pc-banner {
    width: 200px;
}

.floating-banner a:hover {
	opacity:0.7;
	filter:alpha(opacity=70);
}

.sp-banner {
    display: none;
}

h1 {
	line-height: 0;
}

#concept {
	padding: 100px 0 105px;
	width: 1100px;
	margin: 0 auto;
}

#concept p {
	font-size: 18px;
	color: #4d4d4d;
	line-height: 2.6;
	letter-spacing: 0.2em;
}

#concept p.en {
	font-size: 19px;
	letter-spacing: 0.06em;
}

h2.hl {
	font-family: 'Cormorant Garamond', serif;
	font-size: 90px;
	color: #4d4d4d;
	font-weight: normal;
	line-height: 1;
	margin-bottom: 30px;
}

h2.hl span {
	font-size: 50px;
}

#stay {
	text-align: left;
	position: relative;
	margin-bottom: 60px;
}

#enjoy {
	text-align: right;
	position: relative;
	margin-bottom: 120px;
}

#stay img, #enjoy img {
	width: 60%;
}

#stay div {
	position: absolute;
	z-index: 999;
	top: 25px;
	left: 58%;
	margin-right: 50px;
}

#enjoy div {
	position: absolute;
	z-index: 999;
	top: 25px;
	right: 58%;
	text-align: left;
	margin-left: 50px;
}

#stay div p {
	line-height: 2;
	color: #4d4d4d;
	margin-bottom: 30px;
}

#enjoy div p {
	line-height: 2;
	color: #4d4d4d;
	margin-bottom: 30px;
}

h2.sub {	
	font-family: 'Cormorant Garamond', serif;
	font-size: 32px;
	color: #4d4d4d;
	letter-spacing: 0.05em;
	position: relative;
	margin-bottom: 80px;
}

h2.sub span {
	font-size: 22px;
}

h2.subjp {	
	font-family: "Klee One", serif;
	font-size: 28px;
}

h2.sub::after {
	content: '';
	display: block;
	position: absolute;
	left: 50%;
	transform: translate(-50%);
	bottom: -20px;
	width: 60px;
	height: 3px;
	background-color: #A5A68B;
}

#about {
	padding: 95px 0 100px;
	background: url("../image/about-bg.jpg") center center;
	background-size: cover; 
}

#about h2.sub, #about p {
	color: #e5e5e5;
}

#info {
	padding: 90px 0;
	width: 1100px;
	margin: 0 auto;
}

#info h3 {
	font-size: 18px;
	margin-bottom: 14px;
	letter-spacing: 0.03em;
	color: #727360;
	text-align: left;
}

#info p {
	text-align: left;
}

#info ul li {
	float: left;
	width: 50%;
}

#info dl {
	width: 1100px;
	margin: 5px auto;
	border-top: 1px solid #808080;
}

#info dl dt {
	width: 20%;
	float: left;
	padding: 14px 0;
	border-bottom: 1px solid #808080;
}

#info dl dd {
	width: 20%;
	float: left;
	padding: 14px 0;
	border-bottom: 1px solid #808080;
}

#access {
	padding: 90px 0;
	background: #fff;
}

#access ul {
	width: 1050px;
	margin: 30px auto 0;
}

#access li {
	float: left;
	width: 50%;
	text-align: left;
}

#access p {
	line-height: 1.7;
}

#access h3 {
	font-size: 18px;
	margin-bottom: 14px;
	color: #727360;
}

div.map {
	width: 1100px;
	height: 350px;
	margin: 8px auto;
}


#reservation {
	padding: 70px 0;
	background: #fff;
}

#reservation ul {
	width: 928px;
	margin: 0 auto;
}

#reservation ul li {
	float: left;
	padding: 0 5px 10px;
}

#reservation a.book {
	display: block;
	width: 220px;
	height: 40px;
	line-height: 2.5;
	color: #595959;
	border: 1px solid #595959;
	text-align: center;
}

#reservation a.book:hover {
	color: #fff;
	background: #595959;
	opacity:1;
	filter:alpha(opacity=100);
}

#reservation a.camp {
	display: block;
	width: 916px;
	height: 40px;
	line-height: 2.5;
	color: #fff;
	background: #a5a68b;
	border: 1px solid #999;
	text-align: center;
	margin: 0 auto;
}

#contact {
	padding: 70px 0;
	background: #f1f1f1;
}

#contact p {
	font-size: 20px;
	line-height: 1.6;
}

#contact p span {
	background: linear-gradient(transparent 60%, #fff 0%);
}

#contact p.time {
	font-size: 16px;
}

#contact a {
	color:#A5A68B;
}

.note {
	padding-top: 10px;
	font-size: 14px;
	line-height: 1.6;
}

h2.in {
	font-family: 'Cormorant Garamond', serif;
	font-size: 55px;
	color: #4d4d4d;
	font-weight: normal;
	line-height: 1;
	margin-top: 115px;
	letter-spacing: 0.02em;
}

h2.in span {
	font-size: 35px;
}


#layout {
	padding: 90px 0;
	
}

#layout ul.full {
	width: 1100px;
	margin: 0 auto;
}

#layout ul.full li {
	float: left;
}

#layout ul.full li p {
	text-align: left;
	width: 450px;
}

#layout ul.full li.zumen {
	padding-left: 50px;
}

#layout ul.full li.zumen img {
	width: 600px;
	height: auto;
	margin-top: 15px;
}

#layout ul.full li ul.detail {
	padding: 14px 0 32px;
}

#layout ul.full li ul.detail li {
	float: none;
	text-align: left;
	border-bottom: 1px solid #ccc;
	padding: 12px 0 4px 18px;
	background: url("../image/arrow.png") no-repeat 5px 22px;
	background-size: 7px 8px;
}


#facility {
	padding: 90px 0;
	background: #f1f1f1;
}

#facility h3 {
	font-size: 18px;
	margin: 0 auto 12px;
	letter-spacing: 0.05em;
	color: #727360;
	border-bottom: 1px dotted #ccc;
	width: 1100px;
	padding-bottom: 14px;
}
	
#facility ul {
	width: 1060px;
	margin: 0 auto 36px;
}

#facility ul li {
	float: left;
	width: 25%;
	list-style: disc;
	text-align: left;
}

#facility p {
	width: 1100px;
	margin: 0 auto;
	text-align: left;
}

#facility p span {
	font-size: 13px;
	display: block;
	margin-top: -1px;
	color: #666;
	padding-left: 16px;
}


div.karuizawa {
	background: url("../image/enjoy/main.jpg") center center;
	background-size: cover;
	height: 250px;
	width: 100%;
	margin-top: 80px;
}

p.enjoy-lead {
	padding-top: 40px;
}	


#plan {
	padding: 90px 0 90px;
	width: 1100px;
	margin: 0 auto;
}

#plan h4 {
	font-size: 21px;
	margin-bottom: 30px;
	letter-spacing: 0.02em;
	font-family: "Klee One", serif;
}

#plan ul {
	padding: 50px 0;
	margin: 0 auto;
}

#plan ul.one {
	width: 340px;
}

#plan ul.two {
	width: 680px;
}

#plan ul.three {
	width: 1020px;
}

#plan ul li {
	float: left;
	line-height: 0;
	padding: 0 20px;
}

#plan ul li img {
	width: 300px;
	height: 300px;
}

#plan p.arrow {
  position: relative;
  display: inline-block;
  width: 1px;
  height: 100px;
  margin: 0 9.8px 40px;
  border-radius: 9999px;
  background-color: #404040;
}

.arrow::before,
.arrow::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: calc(50% - 0.5px);
  width: 1px;
  height: 18px;
  border-radius: 9999px;
  background-color: #404040;
  transform-origin: 50% calc(100% - 0.5px);
}

.arrow::before {
  transform: rotate(35deg);
}

.arrow::after {
  transform: rotate(-35deg);
}

.arrow::before {
  transform: rotate(35deg);
}

.arrow::after {
  transform: rotate(-35deg);
}


#funny {
	padding: 90px 0 45px;
	width: 1100px;
	margin: 0 auto;
}

#funny h3 {
	font-size: 40px;
	text-align: left;
	margin-bottom: 24px;
	font-family: 'Cormorant Garamond', serif;
	color: #4d4d4d;
}

#funny p {
	text-align: left;
	padding-bottom: 20px;
}

#funny div {
	padding-bottom: 45px;
}

#funny div img {
	width: 1100px;
}

#around {
	padding: 0 0 45px;
	width: 1100px;
	margin: 0 auto;
}

#around ul {
	padding-bottom: 50px;
}

#around ul li {
	float: left;
}

#around ul li:first-child {
	width: 450px;
	padding-right: 50px;
}

#around ul li h3 {
	font-size: 35px;
	text-align: left;
	margin-bottom: 24px;
	font-family: 'Cormorant Garamond', serif;
}

#around ul li h3 span {
	font-size: 18px;
	color: #b3b3b3;
	display: block;
	padding-top: 8px;
}

#around ul li p {
	text-align: left;
}

#around ul li img {
	width: 600px;
}

#around p a {
	color: #404040;
	text-decoration: underline;
}

#around p span {
	background: url("../image/pin.png") no-repeat top left;
	background-size: 9px 15px;
	padding-left: 15px;
}



#spot {
	width: 1100px;
	margin: 0 auto;
}

#spot ul li {
	padding-bottom: 50px;
	margin-bottom: 50px;
	border-bottom: dotted 1px #ccc;
}

#spot ul li h3 {
	font-size: 32px;
	text-align: left;
	margin-bottom: 24px;
	letter-spacing: 0.02em;
	font-family: "Klee One", serif;
}

#spot ul li h3 span {
	font-size: 18px;
	color: #b3b3b3;
	display: block;
	padding-top: 12px;
	font-family: 'Cormorant Garamond', serif;
}

#spot ul li p {
	text-align: left;
}

#spot p a {
	color: #404040;
	text-decoration: underline;
}

#spot p span {
	background: url("../image/pin.png") no-repeat top left;
	background-size: 9px 15px;
	padding-left: 15px;
}

#spot a.btn {
	margin-top: 8px;
}




footer {
	font-size: 15px;
	padding: 70px 0 20px;
	background: #7f806b;
	color: #fff;	
}

footer h4 {
	text-align: center;
	line-height: 0;
}

footer h4 img {
	width: 240px;
}

footer ul {
	width: 366px;
	margin: 28px auto 60px;
}

footer ul li {
	float: left;
	width: 118px;
	padding-left: 40px;
	line-height: 0;
}

footer ul li:first-child {
	padding-left: 0;
}

footer ul li.htg {
	width: 50px;
}

footer ul li img {
	width: 100%;
}

.copy {
	font-size: 13px;
	text-align: center;
	color: #e5e5e5;
}


.cf:before,
.cf:after {
    content: " ";
    display: table;
}

.cf:after {
    clear: both;
}

.cf {
    zoom: 1;
}






@media screen and (max-width: 750px) {
body {
	font-size: 14px;
}

a.btn {
	margin: 0 auto;
	line-height: 3.4;
}
	
p {
	width: 90%;
	margin: 0 auto;
}
	

#logo img {
	width: 68%;
	height: auto;
	margin: 0 0 0 20px;
}	

.Toggle {
	right:15px;
}		
	
.pc-banner {
	display: none;
}

.sp-banner {
    display: inline-block;
    width: 100%;
}

.floating-banner  {
    bottom: 0;
	right: 0;
	line-height: 0;
}	
	
#concept {
	padding: 55px 0 90px;
	width: 100%;
}

#concept p {
	font-size: 15px;
	color: #666;
	letter-spacing: 0.1em;
	padding-bottom: 0;
}
	
h2.hl {
	font-size: 75px;
	color: #4d4d4d;
	margin-bottom: 0;
	position: absolute;
}

h2.hl span {
	font-size: 45px;
}
	
#stay h2.hl {
	top: -52px;
	right: 10px;
}
	
#enjoy h2.hl {
	top: -52px;
	left: 10px;
}	

#stay {
	text-align: left;
	position: relative;
	margin-bottom: 100px;
}

#enjoy {
	text-align: right;
	position: relative;
	margin-bottom: 110px;
}

#stay img, #enjoy img {
	width: 88%;
}

#stay div {
	position: relative;
	top: 0;
	left: 0;
	margin-right: 0;
	padding-top: 12px;
}

#enjoy div {
	position: relative;
	top: 0;
	right: 0;
	margin-left: 0;
	padding-top: 12px;
}

#stay div p {
	line-height: 2;
	color: #4d4d4d;
	margin-bottom: 30px;
}

#enjoy div p {
	line-height: 2;
	color: #4d4d4d;
	margin-bottom: 30px;
}
	
	
h2.sub {
	margin-bottom: 70px;
}	

#about p {
	text-align: left;
}
	

div.map {
	width: 90%;
	height: 450px;
}

#info {
	width: 100%;
}

#info h3 {
	width: 90%;
	margin: 0 auto 14px;
}

#info ul {
	margin: 0 auto;
}
	
#info ul li {
	float: none;
	width: 100%;
}	
	
#info p.notice, #info p.note {
	text-align: left;
	}
	
#info dl {
	width: 90%;
	font-size: 15px;
	border-top: none;
	border-bottom: 1px solid #808080;
}

#info dl dt {
	width: 100%;
	float: none;
	border: none;
	font-size: 15px;
	color: #fff;
	background: #737373;
	display: inline-block;
	line-height: 1;
}

#info dl dd {
	width: 100%;
	float: none;
	border-bottom: 1px dotted #b3b3b3;
}
	
#info dl dd.bbtm {
	border-bottom: none;
}

div.cp-terms {
	width: 90%;
}
	
#reservation ul {
	width: 95%;
}

#reservation ul li {
	width: 50%;
	float: left;
	padding: 0;
}

#reservation a.book {
	width: 90%;
	margin: 0 5% 5%;
	line-height: 2.7;
}
	
#reservation a.camp {
	width: 90%;
	line-height: 2.7;
	margin: 1% auto 0;
}		
	
#contact p {
	font-size: 18px;
}

#access ul {
	width: 100%;
	margin: 30px auto 0;
}
	
#access li {
	float: none;
	width: 100%;
}	
	
#access h3 {
	width: 90%;
	margin: 0 auto 14px;
}

h2.in {
	font-size: 45px;
	margin-top: 105px;
}

h2.in span {
	font-size: 25px;
}

#layout {
	padding: 110px 0 90px 0;
}	
	
#layout ul.full {
	width: 100%;
}

#layout ul.full li {
	float: none;
}

#layout ul.full li p {
	width: 90%;
}

#layout ul.full li.zumen {
	padding: 45px 0 0 0;
}

#layout ul.full li.zumen img {
	width: 90%;
	height: auto;
	margin-top: 0;
}

#layout ul.full li ul.detail {
	width: 90%;
	margin: 0 auto;
}

#layout ul.full li ul.detail li {
	float: none;
	text-align: left;
	border-bottom: 1px solid #ccc;
	padding: 12px 0 4px 18px;
	background: url("../image/arrow.png") no-repeat 5px 22px;
	background-size: 7px 8px;
}	
	


#facility h3 {
	width: 90%;
}


#facility ul {
	width: 90%;
	margin-left: 10%
}

#facility ul li {
	width: 50%;
}

#facility p {
	width: 90%;
}

#facility p span {
	padding-left: 0;
}	

div.karuizawa {
	height: 150px;
	margin-top: 65px;
}
	
	
p.enjoy-lead {
	text-align: left;
	padding-top: 25px;
}	


	
	
	
#plan {
	width: 90%;
}
	
#plan p {
	width: 95%;
}

#plan ul {
	padding: 50px 0 30px;
}

#plan ul.one {
	width: 100%;
}

#plan ul.two {
	width: 100%;
}

#plan ul.three {
	width: 100%;
}

#plan ul li {
	float: none;
	padding: 0;
}

#plan ul li img {
	width: 85%;
	height: auto;
	margin-bottom: 20px;
}



	

	
#funny h2.sub, #around h2.sub {
	margin-bottom: 75px;
}
	
#funny {
	padding: 70px 0 20px;
	width: 90%;
	margin: 0 auto;
}

#funny h3 {
	font-size: 36px;
	margin-bottom: 16px;
}

#funny div {
	padding-bottom: 50px;
}
	
#funny p {
	width: 100%;
	
}

#funny div img {
	width: 100%;
}

#around {
	width: 90%;
	margin: 0 auto;
	padding: 0 0 30px;
}

#around ul li h3 {
	font-size: 33px;
	margin-bottom: 24px;
	color: #4d4d4d;
}

#around ul li h3 span {
	font-size: 17px;
}

#around ul {
	padding-bottom: 65px;
}
	
#around ul li {
	float: none;
}

#around ul li:first-child {
	width: 100%;
	padding-right: 0;
}

#around ul li p {
	width: 100%;
}

#around ul li img {
	width: 100%;
	margin-bottom: 20px;
}

	
	
#spot {
	width: 90%;
}

#spot ul li h3 {
	line-height: 1.2;
}

#spot ul li h3 span {
	padding-top: 6px;
}

#spot ul li p {
	width: 100%;
}

#spot a.btn {
	margin-top: 20px;
}
	
	
	
	
	
footer {
	padding: 60px 0 75px;	
}
	

footer h4 img {
	width: 200px;
}

	
footer ul {
	width: 321px;
	margin: 25px auto 45px;
}
	
footer ul li {
	width: 113px;
	padding-left: 25px;
}

footer ul li.htg {
	width: 45px;
}	
	
	
.copy {
	font-size: 11px;
}
	
.sp-dn {
    display: none !important; }
}


@media screen and (min-width: 751px) {
  .pc-dn {
    display: none !important; } }



