@charset "utf-8";

.swiper-container:hover {
    cursor: grab;
}
.about ul li:nth-child(1) img,
.onsen ul li:nth-child(2) img {
    width: 110%;
	    position: relative;
    top: 20px;
}
.facility ul li:nth-child(1) img {
	width: 110%;
}
.dinner ul li:nth-child(2) img {
	width: 100%;
}

/* common */
section .ttl {
    text-align: center;
    margin-bottom: 80px;
}
section .ttl h3 {
    font-family: garamond-premier-pro, serif;
    font-weight: 200;
    font-size: 32px;
    letter-spacing: 3px;
    margin-bottom: 15px;
    color: #0f0f0f;
}
section .ttl h3 span.f-size {
    font-size: 20px;
}
section .ttl p {
    font-family: source-han-serif-japanese, serif;
    color: #737373;
    font-size: 14px;
    letter-spacing: 2px;
}
.link-btn {
    width: 100%;
    max-width: 245px;
    margin-left: auto;
    margin-top: 80px;
    overflow: hidden;
    position: relative;
}
.link-btn a {
    color: #711827;
    text-decoration: none;
    font-size: 11px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding-bottom: 20px;
    letter-spacing: 2px;
    font-family: source-han-serif-japanese, serif;
}
.link-btn a:after {
    position: absolute;
    bottom: 0;
    left: 0;
    content: ' ';
    display: block;
    width: 100%;
    height: 1px;
    background-color: #222222;
    -webkit-transform: scale(1, 1);
    -ms-transform: scale(1, 1);
    transform: scale(1, 1);
    -webkit-transform-origin: left top;
    -ms-transform-origin: left top;
    transform-origin: left top;
    -webkit-transition: -webkit-transform .7s;
    transition: -webkit-transform .7s;
    -o-transition: transform .7s;
    transition: transform .7s;
    transition: transform .7s, -webkit-transform .7s;
}
.link-btn a:hover:after {
    /*-webkit-transform: translateX(0%);
    -ms-transform: translateX(0%);
        transform: translateX(0%);*/
    /*transition: -webkit-transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.5s;
    -webkit-transition: -webkit-transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.4s;
    transition: -webkit-transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.4s;
    -o-transition: transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.4s;
    transition: transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.4s;
    transition: transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.4s, -webkit-transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.4s;
    transition: transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.4s, -webkit-transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.5s;*/
        -webkit-transform-origin: right top;
    -ms-transform-origin: right top;
    transform-origin: right top;
    -webkit-transform: scale(0, 1);
    -ms-transform: scale(0, 1);
    transform: scale(0, 1);
}
/*.link-btn a:before {
    position: absolute;
    bottom: 0;
    left: 0;
    content: ' ';
    display: block;
    width: 100%;
    height: 1px;
    background-color: #222222;
    -webkit-transform: translateX(0%);
    -ms-transform: translateX(0%);
        transform: translateX(0%);
    transition: -webkit-transform 0s;
    -webkit-transition: -webkit-transform 0s;
    -o-transition: transform 0s;
    transition: transform 0s;
    transition: transform 0s, -webkit-transform 0s;
}
.link-btn a:hover:before {
    -webkit-transform: translateX(100%);
    -ms-transform: translateX(100%);
        transform: translateX(100%);
    transition: -webkit-transform 0.5s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    -webkit-transition: -webkit-transform 0.5s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    -o-transition: transform 0.5s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    transition: transform 0.5s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    transition: transform 0.5s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s, -webkit-transform 0.5s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
}*/
.link-btn span.arrow {
    margin-left: auto;
    position: relative;
}
.link-btn.white a span.arrow:before {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    content: ' ';
    background: #fff;
    width: 100%;
    height: 100%;
    -webkit-transform: translateX(-101%);
    -ms-transform: translateX(-101%);
        transform: translateX(-101%);
    transition: -webkit-transform 0s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    -webkit-transition: -webkit-transform 0s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    -o-transition: transform 0s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    transition: transform 0s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    transition: transform 0s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s, -webkit-transform 0s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
}
.link-btn.gray a span.arrow-wrap:before {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    content: ' ';
    background: #f5f5f5;
    width: 100%;
    height: 100%;
	    z-index: 100;
    -webkit-transform: translateX(-101%);
    -ms-transform: translateX(-101%);
        transform: translateX(-101%);
    transition: -webkit-transform 0s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    -webkit-transition: -webkit-transform 0s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    -o-transition: transform 0s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    transition: transform 0s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    transition: transform 0s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s, -webkit-transform 0s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
}
.link-btn.white a span.arrow-wrap:before {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    content: ' ';
    background: white;
    width: 100%;
    height: 100%;
	    z-index: 100;
    -webkit-transform: translateX(-101%);
    -ms-transform: translateX(-101%);
        transform: translateX(-101%);
    transition: -webkit-transform 0s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    -webkit-transition: -webkit-transform 0s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    -o-transition: transform 0s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    transition: transform 0s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    transition: transform 0s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s, -webkit-transform 0s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
}
.link-btn.white a:hover span.arrow-wrap:before {
    -webkit-transform: translateX(101%);
    -ms-transform: translateX(101%);
    transform: translateX(101%);
    transition: -webkit-transform 0.8s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    -webkit-transition: -webkit-transform 0.8s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    -o-transition: transform 0.8s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    transition: transform 0.8s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    transition: transform 0.8s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s, -webkit-transform 0.8s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
}
.link-btn.white a span.arrow:before {
	content: none;
}
.link-btn a:hover span.arrow:before {
    -webkit-transform: translateX(101%);
    -ms-transform: translateX(101%);
        transform: translateX(101%);
    transition: -webkit-transform 0.8s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    -webkit-transition: -webkit-transform 0.8s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    -o-transition: transform 0.8s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    transition: transform 0.8s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
    transition: transform 0.8s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s, -webkit-transform 0.8s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
}
.wrap {
    background: #f5f5f5;
    width: 100%;
    overflow: hidden;
}
.parallax-mirror {
    z-index: 0!important;
}
/*.view {
    opacity: 0;
}
.view.active {
    opacity: 1;
    margin-top: -120px;
}*/
.mv__side .lang a {
    text-decoration: none;
    color: #0f0f0f;
}


/* mv */
video {
    width: auto;
    height: 100%;
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
    z-index: 1;
}
.videoContainer {
    background-color: #000;
    position: absolute;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
    width: 100vw;
    height: 100vh;
    z-index: 0;
}
.video-overlay {
    will-change: opacity;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
    width: 100%;
    height: 100%;
    /*background-color: #000;*/
}
.mv {
    height: calc(100vh - 80px);
    max-height: 100vh;
    width: calc(100% - 80px);
    padding: 40px;
    background: white;
    position: relative;
}
.mv__hero img {
    width: 100%;
}
.mv img {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
}
.mv__hero {
    height: 100%;
	width: calc(100% - 80px);
	    margin-left: 80px;
    overflow: hidden;
    position: relative;
}
.mv__side h1,
.mv__side p,
.mv__side .lang {
    margin: 0 auto;
}
.mv__side .lang:hover {
    cursor: pointer;
}
.mv__side p {
    font-family: source-han-serif-japanese, serif;   
}
.mv__hero .ttl {
    position: absolute;
    text-align: center;
    left: 0;
    right: 0;
    top: calc(50% - 80px);
    bottom: 0;
    color: white;
    font-family: source-han-serif-japanese, serif;
}
.mv__hero .ttl h2 {
    width: 300px;
    margin: 0 auto;
}
.mv__hero .ttl h2 img {
    width: 100%!important;
    position: relative;
    margin-bottom: 40px;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
}
.mv__hero .ttl p {
    font-size: 20px;
    letter-spacing: 2.5px;
    color: white;
}
.check-in {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}
.check-in ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    height: 50px;
    padding: 10px;
    background: #f5f5f5;
    margin: 20px 0 0 20px;
    border-radius: 6px;
    font-family: source-han-serif-japanese, serif;
}
.check-in ul li {
    height: 20px;
}
.check-in ul li:first-child {
    font-size: 11px;
    letter-spacing: 1px;
    line-height: 20px;
    padding: 0 10px 0 0;
    position: relative;
    top: 17px;
    border-right: 1px solid #dbdbdb;
}
.check-in ul li:last-child p img {
    width: 14px;
    position: relative;
    top: 2px;
    margin-left: 10px;
    margin-right: 8px;
}
.check-in ul li:last-child {
    position: relative;
    line-height: 20px;
    top: 17px;
}
.check-in ul li:last-child p {
    font-size: 11px;
    letter-spacing: 1px;
}
.check-in {
    position: absolute;
    right: 37px;
    bottom: 40px;
    width: 400px;
    background: white;
}
.search a {
    line-height: 70px;
    color: white;
    font-size: 14px;
    display: block;
    text-decoration: none;
}
.search {
    background: #711827;
    height: 70px;
    margin-top: 20px;
    width: 145px;
    text-align: center;
    margin-left: 13px;
    font-family: source-han-serif-japanese, serif;
    letter-spacing: 2px;
    -webkit-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
    transition: all 0.4s ease-in-out;
}
.search:hover {
    background: #F5F5F3;
}
.search:hover a {
    color: #711827;
}

/* news */
.news {
    background: #f5f5f5;
    padding-top: 120px;
    padding-bottom: 120px;
}
.news .ttl {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    text-align: center;
    margin-bottom: 80px;
}
.news .news-box {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
}
.news .swiper-slide img {
    width: 100%;
	    height: 100%;
}
.news .swiper-slide {
    width: 100%;
    max-width: 270px;
	z-index: 102;
    font-family: source-han-serif-japanese, serif;
}
.news .swiper-slide:not(:last-of-type) {
    margin-right: 40px;
}
.news .swiper-slide time {
    font-size: 11px;
    color: #737373;
    display: block;
    letter-spacing: 2px;
    margin-bottom: 15px;
}
.news .swiper-slide p {
    font-size: 14px;
    line-height: 1.6;
    letter-spacing: 1px;
    /*margin-bottom: 80px;*/
    color: #0f0f0f;
}
.news .swiper-wrapper {
    padding-bottom: 80px;
}
.news .swiper-slide a:hover img {
    -moz-transform: scale(1.05,1.05);
    -webkit-transform: scale(1.05,1.05);
    -o-transform: scale(1.05,1.05);
    -ms-transform: scale(1.05,1.05);
}
.news .img-box img {
    -webkit-transition: all .8s;
    -o-transition: all .8s;
    transition: all .8s;
}
.news .img-box {
    margin-bottom: 40px;
    overflow: hidden;
    font-size: 0;
}
.swiper-container-horizontal>.swiper-scrollbar {
    height: 1px!important;
}
.swiper-scrollbar-drag {
    background: black!important;
}
.news .swiper-slide a {
    text-decoration: none;
}

/* topics */
.topics {
    padding-top: 120px;
    background: white;
}
.topics-box {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding-bottom: 120px;
}
.topics-box ul li {
    overflow: hidden;
}
.topics-box ul li:after {
    -webkit-transition: all .8s;
    -o-transition: all .8s;
    transition: all .8s;
}
.topics-box ul li a {
    display: block;
    height: 100%;
    position: relative;
    z-index: 100;
}
.topics-box ul li:hover:after {
    -moz-transform: scale(1.05,1.05);
    -webkit-transform: scale(1.05,1.05);
    -o-transform: scale(1.05,1.05);
    -ms-transform: scale(1.05,1.05);
}
.topics-box ul:nth-of-type(1) li:first-child {
    width: 800px;
    height: 540px;
    max-width: 800px;
    position: relative;
    background-size: cover;
}
.topics-box ul:nth-of-type(1) li:first-child:after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    z-index: 0;
    /*background: url(../img/top/topic01.png)no-repeat;*/
    background-size: cover;
}
.topics-box ul:nth-of-type(1) li:nth-child(2):after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    z-index: 0;
    /*background: url(../img/top/topic02.png)no-repeat;*/
    background-size: cover;
}
.topics-box ul:nth-of-type(1) li:nth-child(3):after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    z-index: 0;
    /*background: url(../img/top/topic03.png)no-repeat;*/
    background-size: cover;
}
.topics-box ul:nth-of-type(2) li:first-child:after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    z-index: 0;
    /*background: url(../img/top/topic04.png)no-repeat;*/
    background-size: cover;
}
.topics-box ul:nth-of-type(2) li:last-child:after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    z-index: 0;
    /*background: url(../img/top/topic05.png)no-repeat;*/
    background-size: cover;
}
.topics-box ul li:first-child {
    float: left;
}
.topics-box ul li {
    position: relative;
}
.topics-box ul li .item-ttl {
    position: absolute;
    bottom: 40px;
    left: 24px;
    color: white;
    font-size: 24px;
    z-index: 10;
    font-family: source-han-serif-japanese, serif;
}
.topics-box ul li .item-ttl h4 {
    font-weight: 200;
    letter-spacing: 2px;
}
.topics-box ul li .item-ttl span {
    font-size: 11px;
    letter-spacing: 2px;
}
.topics-box ul:after {
    content: "";
    display: block;
    clear: both;
}
.topics-box ul:nth-of-type(1) {
    margin-bottom: 20px;
}
.topics-box ul:nth-of-type(1) li:nth-child(2) {
    height: 260px;
    width: 380px;
    float: right;
    margin-bottom: 20px;
    /*background: url(../img/top/topic02.png)no-repeat;*/
    background-size: cover;
}
.topics-box ul:nth-of-type(1) li:nth-child(3) {
    height: 260px;
    width: 380px;
    float: right;
    /*background: url(../img/top/topic03.png)no-repeat;*/
    background-size: cover;
}
.topics-box ul:nth-of-type(2) {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}
.topics-box ul:nth-of-type(2) li:nth-child(1) {
    height: 380px;
    width: calc(50% - 20px);
    margin-right: 20px;
    /*background: url(../img/top/topic04.png)no-repeat;*/
    background-size: cover;
}
.topics-box ul:nth-of-type(2) li:nth-child(2) {
    height: 380px;
    width: 50%;
    /*background: url(../img/top/topic05.png)no-repeat;*/
    background-size: cover;
}
.topics-box ul:nth-of-type(1) li:nth-child(2):hover:after {
    -moz-transform: scale(1.08,1.08);
    -webkit-transform: scale(1.08,1.08);
    -o-transform: scale(1.08,1.08);
    -ms-transform: scale(1.08,1.08);
}
.topics-box ul:nth-of-type(1) li:nth-child(3):hover:after {
    -moz-transform: scale(1.08,1.08);
    -webkit-transform: scale(1.08,1.08);
    -o-transform: scale(1.08,1.08);
    -ms-transform: scale(1.08,1.08);
}

/* section common */
section .heading p {
    font-size: 11px;
    color: #737373;
}
section .heading p {
    margin-bottom: 25px;
    display: inline-block;
    font-size: 11px!important;
    letter-spacing: 1px!important;
}
section ul li h3 {
    color: #711827;
    line-height: 1.6;
    font-size: 30px;
    letter-spacing: 3.5px;
    font-weight: 200;
    margin-bottom: 80px;
    font-family: source-han-serif-japanese, serif;
}
section ul li:nth-child(2) p {
    font-size: 16px;
    color: #737373;
    letter-spacing: 2px;
    line-height: 2;
    font-family: source-han-serif-japanese, serif;
}
section .heading:after {
    content: "";
    display: inline-block;
    width: 68%;
    margin-left: 5%;
    color: #e3e3e3;
    position: relative;
    bottom: 3px;
    border-bottom: 1px solid;
}

.about ul li:nth-child(1) img {
    width: 135%!important;
    /* right: 200px; */
}

/* about */
.about {
    padding-top: 240px;
}
.about ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}
.about ul li:nth-child(1) {
    width: 55vw;
	    max-height: 1120px;
    margin-top: -120px;
    /*background: url(../img/top/about.jpg)no-repeat;*/
    background-size: cover;
    background-position: bottom;
	overflow: hidden;
}
.about ul li:nth-child(2) {
    background: white;
    padding-left: 80px;
    padding-top: 80px;
	    width: 45vw;
    flex: 1;
    padding-right: calc((100vw - 1200px)/2);
}
.about .link-btn {
    margin-right: auto;
    margin-left: 0;
}
.about ul li:nth-child(2) .link-btn {
    margin-top: 170px;
}

/* onsen */
.onsen {
    padding-top: 360px;
    background: white;
    margin-bottom: 120px;
}
section.onsen .heading:after {
    width: 88%;
}
.onsen ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}
.onsen ul li:nth-child(1) {
    padding-right: 80px;
    padding-bottom: 120px;
    padding-left: calc((100vw - 1200px)/2);
    width: 100%;
    max-width: 450px;
}
.onsen ul li:nth-child(2) {
    width: 55vw;
	    max-height: 945px;
	    flex: 1;
    /*background: url(../img/top/onsen.jpg)no-repeat;*/
    background-size: cover;
    position: relative;
    margin-top: -120px;
	    overflow: hidden;
}
.onsen ul li:nth-child(2):after {
    content: "";
    display: block;
    width: 100%;
    height: 120px;
    background: #f5f5f5;
    position: absolute;
    bottom: 0;
}
.onsen ul li:nth-child(1) p {
    font-size: 16px;
    color: #737373;
    letter-spacing: 2px;
    line-height: 2;
    font-family: source-han-serif-japanese, serif;
}
.onsen ul li:nth-child(1) .link-btn {
    margin-top: 285px;
    margin-right: auto;
    margin-left: 0;
}

/* experience */
.experience {
    background: white;
    padding-top: 120px;
    padding-bottom: 120px;
}
.experience .swiper-container {
    width: 100%;
    max-width: 1200px;
    padding-bottom: 80px;
}
.experience .swiper-slide {
    height: 480px;
    position: relative;
    overflow: hidden;
}
.experience .swiper-slide img {
    width: 100%;
    -webkit-transition: all 0.5s;
    -o-transition: all 0.5s;
    transition: all 0.5s;
}
.experience .swiper-slide:hover img {
    -webkit-transform: scale(1.05);
        -ms-transform: scale(1.05);
            transform: scale(1.05);
}
.experience a.modal span.modal-btn {
    position: absolute;
    background: white;
    height: 45px;
    width: 70px;
    display: block;
    bottom: 0;
    right: 0;
}
.experience a.modal span.modal-btn span:before {
    content: "";
    display: block;
    width: 20px;
    position: absolute;
    top: 25px;
    left: 25px;
    border-bottom: 1px solid #711827;
}
.experience a.modal span.modal-btn span:after {
    content: "";
    display: block;
    height: 13px;
    position: absolute;
    top: 19px;
    left: 35px;
    border-right: 1px solid #711827;
}
.modaal-content-container figure img {
    width: 48%;
}
.modaal-content-container figure {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}
.modaal-content-container {
    padding: 80px!important;
}
.modaal-content-container figure figcaption {
    width: 50%;
    margin-left: 40px!important;
}
.modaal-content-container figure figcaption p {
    font-size: 16px;
    font-family: source-han-serif-japanese, serif;
    letter-spacing: 1px;
    line-height: 1.8;
    color: #737373;
}
.modaal-content-container figure figcaption p.ttl {
    color: #0f0f0f;
    font-size: 22px;
    margin-bottom: 30px;
    font-weight: 500;
    letter-spacing: 2px;
    line-height: 1;
}
button#modaal-close:before,
button#modaal-close:after {
    background: #711827!important;
    border-radius: 0;
    width: 1px;
    top: 0;
    left: 10px;
    height: 100%;
}
button#modaal-close {
    position: absolute;
    right: 33px;
    top: 33px;
    width: 20px;
    height: 22px!important;
}

/* dinner */
.dinner {
    padding-top: 360px;
    background: white;
    margin-bottom: 120px;
}
.dinner ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
	    max-height: 810px;
}
.dinner ul li:nth-child(1) {
    padding-right: 80px;
    padding-bottom: 120px;
    padding-left: calc((100vw - 1200px)/2);
    width: 100%;
    max-width: 450px;
}
section.dinner .heading:after {
    width: 86%;
}
.dinner ul li:nth-child(2) {
    width: 55vw;
	    flex: 1;
    /*background: url(../img/top/dinner.jpg)no-repeat;*/
    background-size: cover;
    position: relative;
    /*right: calc((95vw - 1200px)/-2);*/
    margin-top: -120px;
	overflow: hidden;
}
.dinner ul li:nth-child(2):after {
    content: "";
    display: block;
    width: 100%;
    height: 120px;
    background: #f5f5f5;
    position: absolute;
    bottom: 0;
}
.dinner ul li:nth-child(1) p {
    font-size: 16px;
    color: #737373;
    letter-spacing: 2px;
    line-height: 2;
    font-family: source-han-serif-japanese, serif;
}
.dinner ul li:nth-child(1) .link-btn {
    margin-top: 370px;
margin-right: auto;
    margin-left: 0;
}

/* facility */
.facility {
    padding-top: 240px;
}
section.facility .heading:after {
    width: 81%;
}
.facility ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    background: white;
}
.facility ul li:nth-child(1) {
    width: 55vw;
	    max-height: 900px;
    margin-top: -120px;
    /*background: url(../img/top/facility.jpg)no-repeat;*/
    background-size: cover;
	overflow: hidden;
}
.facility ul li:nth-child(2) {
    background: white;
    padding-left: 80px;
    padding-top: 80px;
    padding-right: calc((100vw - 1200px)/2);
}
.facility .link-btn {
    margin-right: auto;
    margin-left: 0;
}
.facility ul li:nth-child(2) .link-btn {
    margin-top: 310px;
}

/* blog */
.blog {
    padding-bottom: 190px;
    padding-top: 120px;
    background: white;
}
.blog-box {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
}
.blog .swiper-container {
    width: 100%;
    max-width: 1200px;
    padding-bottom: 80px;
    font-family: source-han-serif-japanese, serif;
}
.blog .swiper-slide {
    width: 100%;
    max-width: 360px;
	    position: relative;
    z-index: 102;
}
.blog .swiper-slide time {
    font-size: 11px;
    color: #737373;
    display: block;
    margin-bottom: 15px;
    letter-spacing: 2px;
}
.blog .swiper-slide p {
    font-size: 14px;
    line-height: 1.6;
    letter-spacing: 1px;
    color: #0f0f0f;
}
.blog .swiper-slide:not(:last-of-type) {
    margin-right: 60px;
}
.blog .swiper-slide img {
    width: 100%;
	height: 100%;
}
.blog .swiper-slide a {
    display: block;
    text-decoration: none;
}
.blog .swiper-slide .img-box {
    overflow: hidden;
    margin-bottom: 40px;
    font-size: 0;
	height: 240px;
}
.blog .swiper-slide .img-box img {
    -webkit-transition: all .5s;
    -o-transition: all .5s;
    transition: all .5s;
}
.blog .swiper-slide a:hover img {
    -webkit-transform: scale(1.1);
        -ms-transform: scale(1.1);
            transform: scale(1.1);
}

@media screen and (max-width: 1200px) {
    .news .news-box {
        width: 90%;
    }
    .news .swiper-slide {
        max-width: 19.1vw;
        margin-right: 4.4vw!important;
    }
    .topics-box {
        width: 90%;
    }
    .topics-box ul:nth-of-type(1) li:first-child {
        width: 100%;
        max-width: 65.5vw;
    }
    .topics-box ul:nth-of-type(1) li:nth-child(2) {
        width: 23vw;
    }
    .topics-box ul:nth-of-type(1) li:nth-child(3) {
        width: 23vw;
    }
    .topics-box ul:nth-of-type(1) li:nth-child(2):after,
    .topics-box ul:nth-of-type(1) li:nth-child(3):after {
        background-position: center;
    }
    .about ul li:nth-child(2) {
        background: white;
        padding-left: 5%;
        padding-right: 5%!important;
        padding-top: 80px;
        padding-right: calc((100vw - 1200px)/2);
        width: 35%;
    }
    .onsen ul li:nth-child(1) {
        padding-right: 5%!important;
        padding-left: 5%;
        width: 35%;
    }
    .about ul li:nth-child(1) {
        background-position: bottom right;
    }
    .onsen ul li:nth-child(2) {
        background-position: bottom right;
    }
    .experience .swiper-container {
        width: 90%;
    }
    .experience .swiper-slide {
        width: 30vw!important;
        height: auto;
    }
    .facility ul li:nth-child(2) {
        padding-left: 5%;
        padding-right: 5%;
            width: 35%;
    }
    .facility ul li:nth-child(1) {
        background-position: bottom center;
    }
    .dinner ul li:nth-child(1) {
        padding-right: 5%;
        padding-left: 5%;
        width: 35%;
    }
    .blog-box {
        width: 90%;
    }
    .blog .swiper-slide {
        max-width: 25.5vw;
    }
    footer .footer__sns {
        margin-right: 5%;
    }
    footer .footer__bottom ul li:last-child {
        width: 180px;
    }
    .topics-box ul li .item-ttl h4 {
        font-size: 2vw;
    }
    .mv__hero img {
        width: auto;
        height: 100%;
    }
    .sp.tb {
        display: none;
    }
    .check-in {
        right: 36px;
        bottom: 0;
        padding-bottom: 40px;
    }
    .check-in ul {
        height: 30px;
        padding-bottom: 30px;
    }
    ul.gnav__menu:nth-of-type(1) {
        padding-left: 10%;
    }
}

/* sp */
@media screen and (max-width: 834px) {
    .topics .preparation {
        padding-bottom: 10%!important;
    }
	.mv__hero {
		width: 100%;
		margin-left: 0;
	}
        .mv {
        height: 100vh;
        max-height: 100%;
        width: 100vw;
        padding: 0;
    }
    .mv .mv__hero img {
        display: none;
        -webkit-backface-visibility: hidden;
    }
    .mv .mv__hero .ttl img {
        display: block;
        margin-bottom: 30px;
    }
    .mv__hero {
        /*background: url(../img/top/mv.jpg)no-repeat;*/
        background-size: cover;
        background-position: 30%;
    }
    .mv__hero .ttl p {
        font-size: 17px;
        line-height: 1.8;
        width: 80%;
        margin: 0 auto;
    }
    .search {
        width: 100px;
        height: 50px;
    }
    .search a {
        font-size: 12px;
        line-height: 50px;
    }
    .check-in ul li:last-child {
    line-height: 30px;
            top: 0;
    }
    .check-in ul li:first-child {
        line-height: 18px;
        top: 5px;
    }
    .news .news-box {
        width: 90%;
    }
    .news {
        padding-top: 10%;
        padding-bottom: 10%;
    }
    .news .swiper-slide:not(:last-of-type) {
        margin-right: 0;
    }
	.news .swiper-wrapper {
    padding-bottom: 5%;
}
    .news .swiper-slide img {
        margin-bottom: 0%;
    }
    .news .swiper-slide time {
        margin-bottom: 5%;
    }
    .news .swiper-slide p {
        margin-bottom: 20%;
        font-size: 14px;
    }
    .topics {
        padding-top: 10%;
    }
    .topics-box ul li:first-child {
        float: none;
    }
    .topics-box ul:nth-of-type(1) li:first-child {
        width: 100%;
        max-width: 100%!important;
        height: 250px;
        margin: 0 auto;
        margin-bottom: 3%;
    }
    .topics-box ul:nth-of-type(1) li:first-child .item-ttl {
        left: 20px;
        bottom: 20px;
    }
    .topics-box ul li .item-ttl {
        left: 20px;
        bottom: 20px;
    }
    .topics-box ul li .item-ttl h4 {
        font-size: 18px!important;
        margin-top: 6px;
        line-height: 1;
    }
    .topics-box ul:nth-of-type(1) li:first-child .item-ttl h4 {
        margin-top: 9px;
    }
    .topics-box ul:nth-of-type(1) {
        font-size: 0;
        margin-bottom: 0;
    }
    .topics-box ul:nth-of-type(1) li:nth-child(2),
    .topics-box ul:nth-of-type(1) li:nth-child(3) {
        display: inline-block;
        float: none;
        width: 48.5%!important;
        height: 135px;
        margin-left: 3%;
        vertical-align: top;
    }
    .topics-box ul:nth-of-type(1) li:nth-child(2) {
        margin-left: 0;
    }
    .topics-box ul:nth-of-type(2) {
        margin-left: 0;
    }
    .topics-box ul:nth-of-type(1) li:nth-child(2) .item-ttl, .topics-box ul:nth-of-type(1) li:nth-child(3) .item-ttl {
        left: 20px;
        bottom: 20px;
    }
    .topics-box ul:nth-of-type(2) li {
        width: 49%!important;
        height: 135px!important;
        margin-right: 0!important;
    }
    .topics-box ul:nth-of-type(2) li:nth-child(2) {
        margin-left: 3%;
    }
    .experience .swiper-container .swiper-slide {
        width: 50%!important;
        margin-right: 0!important;
    }
    .topics-box .link-btn {
        margin-right: 0;
    }
    .topics-box {
        padding-bottom: 10%;
    }
.about ul,
.facility ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
}
.about ul li:nth-child(1),
.facility ul li:nth-child(1) {
    width: 90%;
    height: 400px;
    margin: 0 auto;
    margin-bottom: -150px;
    position: relative;
}
.about ul li:nth-child(2),
.facility ul li:nth-child(2) {
    padding: 5%!important;
	    padding-bottom: 0!important;
    width: 90%;
    margin: 0 auto;
    padding-top: 200px!important;
}
.about,
.facility {
    padding-top: 10%;
}
section .heading {
    margin-top: 10%;
    margin-bottom: 5%;
    position: relative;
}
/*section ul li h3 {
    font-size: 20px;
}*/
.heading p {
    margin-bottom: 0!important;
}
section .heading:after {
    width: 60%;
}
section.facility .heading:after {
    width: 88%;
}
section.dinner .heading:after {
    width: 88%!important;
}
section.onsen .heading:after {
    width: 91%!important;
}
section ul li h3 {
    margin-bottom: 10%;
}
section ul li:nth-child(2) p,
.onsen ul li:nth-child(1) p,
.dinner ul li:nth-child(1) p {
    font-size: 16px;
}
.about ul li:nth-child(2) .link-btn,
.facility ul li:nth-child(2) .link-btn {
    margin-top: 10%;
}
.onsen,
.dinner {
    padding-top: 10%;
    margin-bottom: 10%;
}
.onsen ul,
.dinner ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
	    max-height: 100%;
}
.onsen ul li:nth-child(2),
.dinner ul li:nth-child(2) {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    height: 400px;
    right: 0;
    width: 90%;
    margin: 0 auto;
    position: relative;
    z-index: 100;
}
.onsen ul li:nth-child(2):after,
.dinner ul li:nth-child(2):after {
    display: none;
}
.onsen ul li:nth-child(1),
.dinner ul li:nth-child(1) {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    width: 90%;
    margin: 0 auto;
    padding-left: 0;
    padding-right: 0;
}
.onsen ul li:nth-child(1) .link-btn,
.dinner ul li:nth-child(1) .link-btn {
    margin-top: 10%;
    margin-left: auto;
    margin-right: 0;
}
.onsen ul li:nth-child(1),
.dinner ul li:nth-child(1) {
    padding-bottom: 10%;
}
.experience {
    padding-top: 10%;
    padding-bottom: 10%;
}
.experience .swiper-container {
    width: 90%;
        padding-bottom: 10%;
}
.experience .swiper-slide {
    height: 100%;
        overflow: hidden;
}
.modaal-content-container figure {
    display: block;
}
.modaal-content-container figure img {
    width: 100%;
}
.modaal-content-container figure figcaption {
    width: 100%;
    margin-left: 0;
    margin-top: 5%;
    margin-left: 0!important;
    padding-bottom: 5%;
}
.modaal-content-container figure figcaption p.ttl {
    margin-bottom: 5%;
        font-size: 20px;
}
.modaal-content-container figure figcaption p {
    font-size: 14px;
}
.modaal-content-container figure {
    display: block;
    width: 95%;
    margin: 0 auto;
    margin-top: 5%;
}
button#modaal-close {
position: absolute;
    right: 25px;
    top: 25px;
}
.blog .swiper-container {
    width: 90%;
    padding-bottom: 10%;
}
.blog-box {
    width: 100%!important;
}
.blog-box .link-btn {
    margin-right: 5%;
}
.blog {
    padding-top: 10%;
    padding-bottom: 15%;
}
.facility ul li:nth-child(2) .link-btn {
    margin-left: auto;
    margin-right: 0;
}
.about ul li:nth-child(2) .link-btn {
    margin-right: 0;
    margin-left: auto;
}
.mv__hero .ttl h2 {
    width: 300px;
}
.news .swiper-slide {
    max-width: 270px!important;
}
.blog .swiper-slide {
    /*width: 46.2%!important;
    max-width: 46.2%!important;*/
	max-width: 100%;
}
.about .heading:after {
    width: 80%;
    position: absolute;
    right: 0;
    bottom: 9px;
}
.onsen ul li:nth-child(2) {
    background-position: center center;
}
.facility ul li:nth-child(1) {
    background-position: bottom center;
}
.dinner ul li:nth-child(2) {
    background-position: top center;
}
.onsen ul li:nth-child(1) {
    margin-left: 0;
    margin: 0 auto;
    padding-right: 0!important;
}
.onsen ul li:nth-child(1),
.dinner ul li:nth-child(1) {
    max-width: 100%;
}
.facility ul {
    background: none;
}
.about ul li:nth-child(1), .facility ul li:nth-child(1) {
    margin-bottom: -200px;
}
    .news .swiper-slide {
        margin-right: 25px!important;
    }
video {
    width: auto;
    height: 100vh;
}
	.modaal-content-container {
    padding: 40px!important;
}
}

@media screen and (max-width: 480px) {
    .sp.tb {
        display: block;
    }
	.blog .swiper-slide .img-box {
		height: 104px;
	}
    .topics-box ul li .item-ttl span,
     .topics-box ul li .item-ttl h4 {
         text-shadow: 1px 1px #4040408c;
    }
    .check-in {
        position: absolute;
        right: 0;
        bottom: -1px;
        width: 100%!important;
        background: white;
        padding-bottom: 20px;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }
    .check-in ul {
        height: 30px;
        margin: 20px 0 0 0;
        padding-bottom: 10px;
    }
    .mv__hero .ttl p {
        font-size: 14px;
    }
    .mv__hero .ttl h2 {
    width: 236px!important;
}
    .topics-box ul:nth-of-type(1) li:nth-child(2) {
        margin-bottom: 3%;
    }
    .news .swiper-slide img {
        margin-bottom: 10%;
    }
    .news .swiper-slide time {
        margin-bottom: 10%;
    }
    section ul li h3 {
        font-size: 20px;
    }
    section ul li:nth-child(2) p, .onsen ul li:nth-child(1) p, .dinner ul li:nth-child(1) p {
        font-size: 14px;
    }
    .onsen ul li:nth-child(2), .dinner ul li:nth-child(2),
    .about ul li:nth-child(1), .facility ul li:nth-child(1) {
        height: 250px;
    }
    .facility ul {
        background: none;
    }
    .about ul li:nth-child(1), .facility ul li:nth-child(1) {
        margin-bottom: -150px;
    }
    .about ul li:nth-child(2), .facility ul li:nth-child(2) {
        padding-top: 150px!important;
    }
    section.onsen .heading:after {
        width: 86%!important;
    }
    section.facility .heading:after {
        width: 80%!important;
    }
    section.dinner .heading:after {
        width: 84%;
    }
    button#modaal-close {
        position: absolute;
        right: -6px;
        top: -6px;
    }
    .news .img-box {
        margin-bottom: 10%!important;
    }
    .news .swiper-slide p {
        font-size: 12px!important;
    }
    .modaal-content-container figure img {
        margin-bottom: 5%;
    }
}


.topics .preparation {
    text-align: center;
    padding-bottom: 120px;
    letter-spacing: 1px;
}
.news-box figcaption {
    width: 100%!important;
}




/* yahoo */
header nav ul li.reservation a p.cap {
    display: block;
    font-size: 11px;
    opacity: 0.6;
    text-align: center;
    margin-bottom: 20px;
    letter-spacing: 1px;
    position: relative;
    top: -35px;
    font-family: source-han-serif-japanese, serif;
}
header nav ul li.reservation {
    line-height: 55px;
}
header nav ul li.reservation a {
    height: 70px;
}
.search a {
    line-height: initial;
    text-decoration: none;
    display: block;
    font-size: 14px;
}

@keyframes show{
    from{
        opacity: 0;
			left: 20px;
    }
    to{
        opacity: 1;
			left: 80px;
    }
}
@keyframes hide{
    from{
        opacity: 1;
			left: 80px;
    }
    to{
        opacity: 0;
			left: 20px;
    }
}


.mv__side .lang:hover {
    cursor: pointer;
}

.mv__side .lang {
    position: absolute;
    bottom: 40px;
    left: 50px;
    width: 20px;
        background: white;
        color: #0f0f0f;
    padding-bottom: 12px;
    border-bottom: 1px solid;
    font-size: 14px;
    letter-spacing: 1px;
        z-index: 100;
    font-family: garamond-premier-pro, serif;
}
.lang-box.active {
    left: 80px;
    display: block;
    opacity: 1;
    animation: show 0.4s;
}

.lang-box {
    /*display: none;*/
	opacity: 0;
    position: absolute;
    bottom: 40px;
    left: 20px;
    padding-top: 22px;
    width: 100px;
    background: white;
    padding-bottom: 12px;
    font-size: 14px;
    letter-spacing: 1px;
	animation: hide 0.4s;
    font-family: garamond-premier-pro, serif;
}
.lang-box.active {
	left: 80px;
	display: block;
	    opacity: 1;
	animation: show 0.4s;
}
.lang-box a:hover {
    opacity: 1;
}
.lang-box a {
    text-decoration: none;
    padding-bottom: 9px;
    font-size: 14px;
    color: #0f0f0f;
    opacity: 0.4;
    transition: all 0.5s;
}
/*.lang-box {
    display: none;
}*/
.lang-box:before {
    content: "";
    height: 20px;
    display: block;
    border-right: 1px solid #8d4652;
    position: absolute;
    bottom: 10px;
    left: 15px;
	opacity: 0.4;
}







/* yahoo */
header nav ul li.reservation a p.cap {
    display: block;
    font-size: 11px;
	opacity: 0.6;
    text-align: center;
    margin-bottom: 20px;
    letter-spacing: 1px;
    position: relative;
    top: -35px;
    font-family: source-han-serif-japanese, serif;
}
header nav ul li.reservation {
	line-height: 55px;
}
header nav ul li.reservation a {
    height: 70px;
}
.search a {
    line-height: initial;
    text-decoration: none;
    display: block;
    font-size: 14px;
}

@media screen and (max-width: 1300px) {
	.about ul li:nth-child(1) img {
		    width: 120%;
	}
	.onsen ul li:nth-child(2) img {
    width: 120%;
    right: 50px;
}
	.facility ul li:nth-child(1) img {
    width: 120%;
}
	.dinner ul li:nth-child(2) img {
    width: 120%;
}
}

@media screen and (max-width: 834px) {
	.about ul li:nth-child(1) img {
    top: -350px!important;
    width: 100%!important;
    right: 0!important;
	}
	.onsen ul li:nth-child(2) img {
		    top: -200px!important;
		width: 110%!important;
		    right: 0!important;
	}
	.facility ul li:nth-child(1) img {
    position: relative;
    top: -400px!important;
		width: 110%!important;
		    right: 0!important;
}
	.dinner ul li:nth-child(2) img {
    position: relative;
    top: -150px!important;
		width: 110%!important;
		    right: 0!important;
}
	.onsen ul li:nth-child(2),
	.dinner ul li:nth-child(2),
	.facility ul li:nth-child(1) {
		flex: none!important;
	}
}

@media screen and (max-width: 1024px) and (orientation: portrait) {
.about ul li:nth-child(1) img {
    width: 180%;
    top: -120px;
    right: 30%;
}
	.about ul li:nth-child(1) {
		max-height: 990px;
	}
	.onsen ul li:nth-child(2) {
		    max-height: 1000px;
	}
	.onsen ul li:nth-child(2) img {
    width: 170%;
    right: 250px;
    top: -50px;
}
	.facility ul li:nth-child(1) {
    max-height: 930px;
}
	.facility ul li:nth-child(1) img {
    width: 180%;
    position: relative;
    top: -200px;
    right: 200px;
}
	.dinner ul li:nth-child(2) img {
    width: 150%;
    position: relative;
    top: -100px;
}
	section.dinner .heading:after {
    width: 84%;
}
section .heading:after {
	width: 66%;
}
}

@media screen and (max-width: 480px) {
    .sp.tb {
        display: block;
    }
	.topics-box ul li .item-ttl span,
	 .topics-box ul li .item-ttl h4 {
		 text-shadow: 1px 1px #4040408c;
	}
    .check-in {
        position: absolute;
        right: 0;
        bottom: -1px;
        width: 100%!important;
        background: white;
        padding-bottom: 20px;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }
    .check-in ul {
        height: 30px;
        margin: 20px 0 0 0;
        padding-bottom: 10px;
    }
    .mv__hero .ttl p {
        font-size: 14px;
    }
	.mv__hero .ttl h2 {
    width: 236px!important;
}
    .topics-box ul:nth-of-type(1) li:nth-child(2) {
        margin-bottom: 3%;
    }
    .news .swiper-slide img {
        margin-bottom: 10%;
    }
    .news .swiper-slide time {
        margin-bottom: 10%;
    }
    section ul li h3 {
        font-size: 20px;
    }
    section ul li:nth-child(2) p, .onsen ul li:nth-child(1) p, .dinner ul li:nth-child(1) p {
        font-size: 14px;
    }
    .onsen ul li:nth-child(2), .dinner ul li:nth-child(2),
    .about ul li:nth-child(1), .facility ul li:nth-child(1) {
        height: 250px;
    }
    .facility ul {
        background: none;
    }
    .about ul li:nth-child(1), .facility ul li:nth-child(1) {
        margin-bottom: -150px;
    }
    .about ul li:nth-child(2), .facility ul li:nth-child(2) {
        padding-top: 150px!important;
    }
    section.onsen .heading:after {
        width: 86%!important;
    }
    section.facility .heading:after {
        width: 80%!important;
    }
    section.dinner .heading:after {
        width: 84%;
    }
    button#modaal-close {
        position: absolute;
    right: 12px;
    top: 12px;
    }
    .news .img-box {
        margin-bottom: 10%!important;
    }
    .news .swiper-slide p {
        font-size: 12px!important;
    }
    .modaal-content-container figure img {
        margin-bottom: 5%;
    }
	.modaal-content-container {
    padding: 10%!important;
}
.about ul li:nth-child(1) img {
    width: 120%!important;
    top: -200px!important;
    right: 50px!important;
}
	.onsen ul li:nth-child(2) img {
		top: -100px!important;
	}
	.facility ul li:nth-child(1) img {
		top: -150px!important;
	}
	.dinner ul li:nth-child(2) img {
		    right: 5%!important;
	}
}

/* yahoo */
header nav ul li.reservation a p.cap {
    display: block;
    font-size: 11px;
    opacity: 0.6;
    text-align: center;
    margin-bottom: 20px;
    letter-spacing: 1px;
    position: relative;
    top: -35px;
    font-family: source-han-serif-japanese, serif;
}
header nav ul li.reservation {
    /*line-height: 55px;*/
    line-height: 70px;
}
header nav ul li.reservation a {
    height: 70px;
}
.search a {
    line-height: initial;
    text-decoration: none;
    display: block;
    font-size: 14px;
}

@media screen and (max-width: 1300px) {
    .about ul li:nth-child(1) img {
            width: 120%;
    }
    .onsen ul li:nth-child(2) img {
    width: 120%;
    right: 50px;
}
    .facility ul li:nth-child(1) img {
    width: 120%;
}
    .dinner ul li:nth-child(2) img {
    width: 120%;
}
}

@media screen and (max-width: 834px) {
    .about ul li:nth-child(1) img {
    top: -350px!important;
    width: 100%!important;
    right: 0!important;
    }
    .onsen ul li:nth-child(2) img {
            top: -200px!important;
        width: 110%!important;
            right: 0!important;
    }
    .facility ul li:nth-child(1) img {
    position: relative;
    top: -400px!important;
        width: 110%!important;
            right: 0!important;
}
    .dinner ul li:nth-child(2) img {
    position: relative;
    top: -150px!important;
        width: 110%!important;
            right: 0!important;
}
    .onsen ul li:nth-child(2),
    .dinner ul li:nth-child(2),
    .facility ul li:nth-child(1) {
        flex: none!important;
    }
}

@media screen and (max-width: 1024px) and (orientation: portrait) {
.about ul li:nth-child(1) img {
    width: 180%;
    top: -120px;
    right: 30%;
}
    .about ul li:nth-child(1) {
        max-height: 990px;
    }
    .onsen ul li:nth-child(2) {
            max-height: 1000px;
    }
    .onsen ul li:nth-child(2) img {
    width: 170%;
    right: 250px;
    top: -50px;
}
    .facility ul li:nth-child(1) {
    max-height: 930px;
}
    .facility ul li:nth-child(1) img {
    width: 180%;
    position: relative;
    top: -200px;
    right: 200px;
}
    .dinner ul li:nth-child(2) img {
    width: 150%;
    position: relative;
    top: -100px;
}
    section.dinner .heading:after {
    width: 84%;
}
section .heading:after {
    width: 66%;
}
}

@media screen and (max-width: 480px) {
    .sp.tb {
        display: block;
    }
    .topics-box ul li .item-ttl span,
     .topics-box ul li .item-ttl h4 {
         text-shadow: 1px 1px #4040408c;
    }
    .check-in {
        position: absolute;
        right: 0;
        bottom: -1px;
        width: 100%!important;
        background: white;
        padding-bottom: 20px;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }
    .check-in ul {
        height: 30px;
        margin: 20px 0 0 0;
        padding-bottom: 10px;
    }
    .mv__hero .ttl p {
        font-size: 14px;
    }
    .mv__hero .ttl h2 {
    width: 236px!important;
}
    .topics-box ul:nth-of-type(1) li:nth-child(2) {
        margin-bottom: 3%;
    }
    .news .swiper-slide img {
        margin-bottom: 10%;
    }
    .news .swiper-slide time {
        margin-bottom: 10%;
    }
    section ul li h3 {
        font-size: 20px;
    }
    section ul li:nth-child(2) p, .onsen ul li:nth-child(1) p, .dinner ul li:nth-child(1) p {
        font-size: 14px;
    }
    .onsen ul li:nth-child(2), .dinner ul li:nth-child(2),
    .about ul li:nth-child(1), .facility ul li:nth-child(1) {
        height: 250px;
    }
    .facility ul {
        background: none;
    }
    .about ul li:nth-child(1), .facility ul li:nth-child(1) {
        margin-bottom: -150px;
    }
    .about ul li:nth-child(2), .facility ul li:nth-child(2) {
        padding-top: 150px!important;
    }
    section.onsen .heading:after {
        width: 86%!important;
    }
    section.facility .heading:after {
        width: 80%!important;
    }
    section.dinner .heading:after {
     width: 84%!important;
    }
    button#modaal-close {
        position: absolute;
    right: 12px;
    top: 12px;
    }
    .news .img-box {
        margin-bottom: 10%!important;
    }
    .news .swiper-slide p {
        font-size: 12px!important;
    }
    .modaal-content-container figure img {
        margin-bottom: 5%;
    }
    .modaal-content-container {
    padding: 10%!important;
}
.about ul li:nth-child(1) img {
    width: 120%!important;
    top: -200px!important;
    right: 50px!important;
}
    .onsen ul li:nth-child(2) img {
        top: -100px!important;
    }
    .facility ul li:nth-child(1) img {
        top: -150px!important;
    }
    .dinner ul li:nth-child(2) img {
            right: 5%!important;
    }
}


/* English */
.en .mv__hero .ttl p {
    line-height: 1.6;
}
.en .about .heading:after {
    width: 32%;
    position: absolute;
    bottom: 33px;
}
.en .facility .heading:after {
    width: 64%;
    position: absolute;
    bottom: 33px;
}
.en .about ul li:nth-child(1) {
	    max-height: 1525px;
}
.en .about ul li:nth-child(1) img {
	    width: 160%!important;
    position: relative;
    top: 20px;
    right: 200px;
}
.en .onsen .heading:after {
    width: 80%;
}
.en .onsen ul li:nth-child(2) {
    max-height: 1245px;
}
.en .facility ul li:nth-child(2) {
	flex: 1;
}
.en .facility .heading:after {
    width: 64%;
}
p.ttl.en-f {
	line-height: 1.6!important;
    position: relative;
    margin-top: -8px;
}
.en ul.gnav__menu li {
    margin-bottom: 3.8vh;
}
.en ul.gnav__menu li:nth-child(2) {
    line-height: 1.6;
}
.en ul.gnav__menu:nth-of-type(2) li.footer__sns ul li:first-child {
	top: 11px;
}
/*.en ul.gnav__menu li:nth-child(5) {
    line-height: 1.6;
}*/

@media screen and (max-width: 834px) {
	.en .about .heading:after {
    width: 55%;
		    bottom: 9px;
}
	.en .onsen .heading:after {
    width: 85%!important;
    bottom: 2px;
}
	.en .facility .heading:after {
    width: 75%!important;
		    bottom: 9px;
}
	.en .dinner .heading:after {
    width: 90%!important;
		bottom: 3px;
}
	.reservation-btn a {
		letter-spacing: 1px;
	}
        .modaal-content-container {
    padding: 10%!important;
}
    button#modaal-close {
    position: absolute;
    right: 25px;
    top: 25px;
}
}

@media screen and (max-width: 480px) {
	.en .about .heading:after {
		width: 15%;
	}
	.en .onsen .heading:after {
		width: 74%!important;
	}
	.en .facility .heading:after {
		width: 54%!important;
	}
	.en .dinner .heading:after {
		width: 85%!important;
	}
	footer .footer__top ul li {
    margin-bottom: 5%;
    font-size: 14px;
    line-height: 1.6;
}
	footer .footer__top ul:nth-of-type(1) {
		width: 60%;
	}
	footer .footer__top ul:nth-of-type(2) li {
    margin-bottom: 8%!important;
}
	ul.gnav__menu {
		    /*height: 330px!important;*/
	}
        button#modaal-close {
    position: absolute;
    right: 12px;
    top: 14px;
}
	.about .heading:after {
		width: 65%!important;
	}
}

.en section ul li h3,
.en section ul li:nth-child(2) p {
	letter-spacing: 2px;
}
.en .about ul li:nth-child(1) {
    max-height: 1445px;
    overflow: hidden;
}
.en .mv__hero .ttl p {
	letter-spacing: 2px;
}
.en .about ul li:nth-child(2) {
    flex: 1;
}

video.horizontal {
    width: 100%!important;
    height: auto;
}





/* Topics */
.topics-content {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
padding-bottom: 0;
    margin-bottom: 0!important;
}
.topics-content ul li {
    position: relative;
}
.topics-content ul li:first-child {
    max-width: 800px;
    float: left;
    height: 540px;
    position: relative;
   margin-bottom: 20px;
}
.topics-content ul li:first-child .item-ttl {
    color: white;
    position: absolute;
}
.topics-content ul li:first-child .item-ttl h4 {
    font-size: 24px;
    font-family: source-han-serif-japanese, serif;
}
.topics-content ul li:nth-child(2) {
    float: right;
        margin-bottom: 20px;
}
.topics-content ul li:nth-child(2):after {
    content: "";
    display: block;
    clear: both;
}
.topics-content ul li:nth-child(3) {
    float: right;
       margin-bottom: 20px;
}
.topics-content ul li:nth-child(3):after {
    content: "";
    display: block;
    clear: both;
}
.topics-content ul li .item-ttl h4 {
    font-family: source-han-serif-japanese, serif;
    letter-spacing: 2px;
}
.topics-content ul li .item-ttl span {
    letter-spacing: 1px;
    font-size: 11px;
    margin-bottom: 20px;
}
.topics-content ul li .item-ttl h4 {
letter-spacing: 3px;
    font-size: 24px;
    font-weight: 200;
    padding-top: 20px;
}
.topics-content ul li .item-ttl {
    position: absolute;
    bottom: 40px;
    left: 20px;
    color: white;
}
.topics-content ul li:nth-child(5) {
    width: 50%;
    max-width: 590px;
    float: right;
    height: 380px;
}
.topics-content ul li:nth-child(4) {
    width: 50%;
    max-width: 590px;
    margin-right: 20px;
    float: left;
    margin-bottom: 0;
    height: 380px;
}
.topics-content ul li:nth-child(4):before {
    content: "";
    display: block;
    clear: both;
}
div#content img {
    width: 110%;
    height: 100%;
}
.topics-content ul li a {
    text-decoration: none;
    color: #0f0f0f;
    display: block;
}
.topics-content ul li a .img-box img {
    -webkit-transition: all 0.5s;
    -o-transition: all 0.5s;
    transition: all 0.5s;
}
.topics-content ul li a:hover .img-box img {
    -webkit-transform: scale(1.05);
        -ms-transform: scale(1.05);
            transform: scale(1.05);
}
.topics-content ul li a .img-box {
    overflow: hidden;
    font-size: 0;
    margin-bottom: 40px;
}
.topics-content ul li h3 {
    margin-bottom: 40px;
    font-size: 16px;
    letter-spacing: 1px;
    line-height: 1.6;
    font-weight: 500;
}
.topics-content ul li p.time {
    font-size: 11px;
    letter-spacing: 2px;
    padding-bottom: 20px;
    color: #737373;
}
.topics-content ul li {
    width: 100%;
    max-width: 380px;
    height: 260px;
    overflow: hidden;
}
.topics-content ul:after {
    content: "";
    display: block;
    clear: both;
}
@media screen and (max-width: 1200px) {
    .topics-box {
        width: 90%;
    }
    .topics-content ul li {
        max-width: 26.6vw;
    }
    .topics-content ul li:not(:nth-child(3n)) {
        margin-right: 5vw;
    }
}
@media screen and (max-width: 834px) {
        .topics-content ul li:not(:nth-child(2n)) {
        margin-right: 5%!important;
    }
    .topics-content ul li {
        width: 48.5%;
        max-width: 360px;
        margin-bottom: 80px;
        border-bottom: 1px solid #0f0f0f;
    }
        .topics-content ul li {
        margin-bottom: 10%;
    }
    .topics-content ul li:not(:nth-child(3n)) {
        margin-right: 0;
    }
    .topics-content ul li img {
        margin-bottom: 0%;
    }
    .topics-content ul li h3 {
        font-size: 14px;
        margin-bottom: 10%;
    }
    .topics-content ul li:first-child {
    width: 100%;
    height: 100%;
    border-bottom: 0;
    margin-bottom: 0;
}
    .topics-content ul li:nth-child(2), .topics-content ul li:nth-child(3) {
    height: 100%;
    border-bottom: 0;
}
    .topics-content ul li:nth-child(4) {
    height: 100%;
    border-bottom: 0;
}
    .topics-content ul li:nth-child(4) {
    width: 48.5%;
    }
    .topics-content ul li:nth-child(2) .img-box,
    .topics-content ul li:nth-child(3) .img-box {
        margin-bottom: 0;
    }
.topics-content ul li:nth-child(5) {
    margin-right: 0!important;
    height: 100%;
    border-bottom: 0;
    width: 47%;
}
.topics .topics-content ul li:nth-child(5) {
    margin-right: 0!important;
    width: 48.5%;
        margin-bottom: 5%;
}
    .topics-content ul li:nth-child(4) .img-box {
    margin-bottom: 0!important;
}
    .topics-content {
        width: 100%;
    }
        .topics-content ul li {
        max-width: 100%!important;
    }
    .topics-content ul li:not(:nth-child(even)) {
        margin-right: 3%!important;
    }
    .topics-content ul li:not(:nth-child(odd)) {
        margin-right: 0%!important;
    }
    .topics-content ul li a .img-box {
        margin-bottom: 3%;
    }
	.pace-done {
		opacity: 1!important;
	}
	.wrap {
		opacity: 1!important;
	}
	.pace {
		display: none!important;
	}
	.pace-running {
    overflow: visible!important;
	}
	.pace-done .wrap {
		animation-name: none!important;
	}
	#top_swipe.swiper {
	  display: none;
	}
	#top_swipe.swiper-container-initialized {
	  display: block;
	}
}

@media screen and (max-width: 480px) {
        .topics-content ul li .item-ttl span,
    .topics-content ul li .item-ttl h4 {
            text-shadow: 1px 1px #4040408c;
    }
    .topics-content ul li:first-child {
    height: 230px;
    overflow: hidden;
    margin-bottom: 3%;
}
	.topics-box ul:nth-of-type(1) li:nth-child(3) {
    margin-right: 0!important;
}
    .topics-content ul li:first-child .item-ttl {
        bottom: 20px;
    }
        .topics-content ul li:not(:first-child) .item-ttl {
    bottom: 20px;
}
    .topics-content ul li:nth-child(2), .topics-content ul li:nth-child(3) {
        width: 48.5%;
        margin-bottom: 3%;
    }
    .topics-content ul li:nth-child(4) {
     width: 48.5%;
    }
    .topics .topics-content ul li:nth-child(5) {
    width: 48.5%;
}
        .topics-content ul li img {
        width: 130%!important;
    }
    .topics-content ul li:not(:first-child) {
        height: 120px!important;
    }
    .topics-content ul li {
        margin-bottom: 0;
    }
    .topics-content ul li .item-ttl h4 {
    font-size: 18px!important;
    margin-top: 6px;
    line-height: 1.1;
    letter-spacing: 1px;
    padding-top: 0;
}
}

.en .dinner ul {
	max-height: 100%;
}

/*.lang-wrap {
    /*width: 120px;
    height: 120px;*/
    position: absolute;
    bottom: 0;
	    z-index: 100;
	opacity: 1;
	transition: all 0.6s;
}*/
.lang-wrap.active {
    opacity: 0;
	    visibility: hidden;
}
.lang-wrap.active .mv__side .lang {
	opacity: 0;
	visibility: hidden;
}
.lang-box {
    /* display: none; */
    opacity: 0;
    position: absolute;
    bottom: 40px;
    left: 20px;
	    margin-left: -80px;
	    padding-left: 120px;
    padding-top: 30px;
    width: 100px;
    background: white;
    padding-bottom: 12px;
    /* height: 120px; */
    padding-bottom: 52px;
    margin-bottom: -40px;
    font-size: 14px;
    letter-spacing: 1px;
    animation: hide 0.6s;
    font-family: garamond-premier-pro, serif;
}

.lang-wrap {
    /*width: 120px;
    height: 120px;*/
    position: absolute;
    bottom: 0;
	    z-index: 100;
	opacity: 1;
	transition: all 0.7s;
}

.mv__side .lang-wrap:hover .lang.hover {
    opacity: 1;
}
.mv__side .lang.hover {
    opacity: 0;
    transition: all 0.7s;
}