@charset "UTF-8";

/* ------------------------
base
------------------------ */
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

html {
  margin: 0;
  padding: 0;
  font-size: 62.5%;
}

body {
  animation: fadeIn 2s ease 0s 1 normal;
  -webkit-animation: fadeIn 2s ease 0s 1 normal;
  color: #221E1F;
  font-size: 16px;
  line-height: 1.5;
  font-family: 'Zen Old Mincho', serif;
  font-weight: 400;
  margin: 0 auto;
  text-align: center;
  position: relative;
  background: #F8F9E3;
}

@keyframes fadeIn {
  0% {opacity: 0}
  100% {opacity: 1}
}
@-webkit-keyframes fadeIn {
  0% {opacity: 0}
  100% {opacity: 1}
}

main {
  overflow: hidden;
}

img {
  max-width: 100%;
  vertical-align: top;
  /* pointer-events: none; */
}

a, a img {
  cursor: pointer;
  opacity: 1;
  transition: 0.3s;
  text-decoration: none;
}
a:hover, a img:hover {
  opacity: .8;
}

h1, h2, h3, h4, h5, h6, p {
  margin: 0;
  padding: 0;
}

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

ul li {
  list-style: none;
}

a {
  color: #000;
}

.flex {
  display: flex;
  display: -webkit-flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}

.note {
  font-size: 12px!important;
  font-weight: 400!important;
  text-indent: -1em;
  padding-left: 1em;
}
.note::before {
  content: "※";
}

.justify {
  text-align: justify!important;
  text-justify: inter-ideograph!important;
}

.full {
  margin: 0 calc(50% - 50vw);
  width: 100vw;
}

section {
  padding: 100px 0;
}

.sec-inner {
  max-width: 1000px;
  width: 100%;
  margin: 0 auto;
}

h2 {
  margin-bottom: 50px;
}

h3 {
  margin-bottom: 50px;
}

.sec-txt {
  font-size: 100%;
  line-height: 1.8;
}

@media screen and (min-width: 768px){
  .sp-only {
    display: none!important;
  }
  a[href^="tel:"] {
    pointer-events: none;
  }
}

@media screen and (max-width: 1024px){
  .sec-inner {
    width: 95%;
  }
}

@media screen and (max-width: 767px){
  body {
    font-size: 14px;
  }
  .pc-only {
    display: none!important;
  }
  a:hover, a img:hover {
    opacity: 1;
  }
  section {
    padding: 50px 0;
  }
  .sec-inner {
    width: 90%;
  }
  h2 {
    margin-bottom: 25px;
  }
  h2 img {
    height: 120px;
  }
  h3 {
    margin-bottom: 25px;
  }
  h3 img {
    height: 70px;
  }
}

@media screen and (max-width: 280px){
  h2 img {
    height: 90px;
  }
}

@media print {
  .sp-only {
    display: none;
  }
}


/* ------------------------
header
------------------------ */
header {
  background-color: #fff;
  position: fixed;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  width: 87.8%;
  max-width: 1200px;
  height: 70px;
  z-index: 999;
  padding-left: 1.7%;
  box-shadow: 0 3px 6px rgba(0,0,0,0.1);
}

header {
  align-items: center;
}

header h1 {
  display: block;
  width: 18.3%;
  height: auto;
}

header h1 img {
  display: block;
}

header ul li {
  font-size: 87.5%;
  font-weight: 700;
  letter-spacing: .1em;
}
header ul li a:hover {
  color: #64b9c8;
}

#nav-input {
  display: none;
}

header .header-tel {
  width: 16.6%;
  height: 100%;
}

header .header-tel-top {
  height: 28px;
  background-color: #4C96A3;
}

header .header-tel-top p {
  color: #fff;
  font-size: 87.5%;
  line-height: 28px;
}

header .header-tel-bottom {
  height: 42px;
  background-color: #64B9C8;
  justify-content: center;
}

header .header-tel-bottom a {
  display: inherit;
  width: 88%;
}

@media screen and (min-width: 768px){
  .header-logo-menu {
    width: 55%;
  }
  .header-logo-menu #nav-content ul {
    display: flex;
    display: -webkit-flex;
    justify-content: space-around;
  }
}

@media screen and (max-width: 1024px){
  header h1 {
    width: 15%;
  }
  .header-logo-menu {
    width: 67%;
  }
  header .header-tel {
    width: 15%;
  }
  header ul li {
    font-size: 80%;
  }
}

@media screen and (max-width: 768px){
  header {
    width: 100%;
  }
}

@media screen and (max-width: 767px){
  header {
    width: 100%;
    position: fixed;
    z-index: 10;
    height: 60px;
    display: block;
  }
  header h1 {
    width: 45%;
    margin-top: 3%;
  }
  header .header-tel {
    width: 35%;
    position: absolute;
    top: 0;
    right: 60px;
  }
  header .header-tel-top {
    height: 25px;
  }
  header .header-tel-top p {
    font-size: 80.5%;
    line-height: 25px;
  }
  header .header-tel-bottom {
    height: 35px;
  }
  /* ハンバーガーメニュー --- */
  #nav-drawer {
    position: relative;
  }
  .nav-unshown {
    display:none;
  }
  .header-logo-menu #nav-open {
    position: fixed;
    top: 0;
    right: 0;
    display: flex;
    display: -webkit-flex;
    height: 60px;
    width: 60px;
    justify-content: center;
    align-items: center;
    z-index: 90;
    background-color: #2F5D65;
  }
  .header-logo-menu #nav-open span,
  .header-logo-menu #nav-open span:before,
  .header-logo-menu #nav-open span:after {
    content: '';
    display: block;
    height: 3px;
    width: 25px;
    border-radius: 3px;
    background-color: #fff;
    position: absolute;
    transition: all 0.3s;
  }
  .header-logo-menu #nav-open span:before {
    bottom: 8px;
  }
  .header-logo-menu #nav-open span:after {
    top: 8px;
  }
  #nav-input:checked ~ #nav-open span {
    background-color: rgba(255, 255, 255, 0);/*メニューオープン時は真ん中の線を透明にする*/
  }
  #nav-input:checked ~ #nav-open span::before {
    bottom: 0;
    transform: rotate(45deg);
  }
  #nav-input:checked ~ #nav-open span::after {
    top: 0;
    transform: rotate(-45deg);
  }
  .header-logo-menu #nav-content {
    width: 100%;
    height: 100vh;
    position: fixed;
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
    top: 59px;
    left: 100%;/*leftの値を変更してメニューを画面外へ*/
    z-index: 80;
    background-color: #2F5D65;
    transition: all 0.5s;
    padding: 40px 20px;
  }
  #nav-input:checked ~ #nav-close {
    display: block;
    opacity: .5;
  }
  #nav-input:checked ~ #nav-content {
    left: 0;/*メニューを画面内へ*/
  }
  header ul li {
    font-size: 100%;
    margin: 0!important;
  }
  header ul li a {
    color: #fff;
    width: 100%;
    display: block;
    padding: 18px 0;
  }
}

@media screen and (max-width: 360px){
}

@media screen and (max-width: 320px){
}


/* ------------------------
Top
------------------------ */
#Top .mv {
  position: relative;
  height: auto;
}
#Top .mv::before {
  content: "";
  position: absolute;
  background: url(../img/slide_l.png) no-repeat center center;
  background-size: cover;
  width: 170px;
  height: 166px;
  bottom: 0;
  left: 0;
  z-index: 2;
  mix-blend-mode: soft-light;
}
#Top .mv::after {
  content: "";
  position: absolute;
  background: url(../img/slide_r.png) no-repeat center center;
  background-size: cover;
  width: 170px;
  height: 166px;
  top: 0;
  right: 0;
  z-index: 2;
  mix-blend-mode: soft-light;
}

#Top .mv .mv-logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
}

/* Slick */
.sliderArea {
  max-width: 100%;
  margin: 0 auto;
  padding: 0;
}
.sliderArea.w300 {
  max-width: 300px;
}
.slick-slide img {
  width: 100%;
  height: auto;
}
.slick-slide {
  transition: all ease-in-out .3s;
  opacity: .2;
}
.slick-active {
  opacity: 1;
}
.slick-current {
  opacity: 1;
}
.thumb {
  margin: 20px 0 0;
}
.thumb .slick-slide {
  cursor: pointer;
}
.thumb .slick-slide:hover {
  opacity: .7;
}
.slick-dots {
  bottom: 30px!important;
}
.slick-dots li {
  width: 5%!important;
  height: 7px!important;
  background-color: #4c96a3;
  border-radius: 2px;
}
.slick-dots li.slick-active {
  background-color: #FFFFFF;
}
.slick-dots li button:before {
  display: none;
}
.slick-dotted.slick-slider {
  margin-bottom: 0!important;
}

/* コンセプトが非表示の際-- */
#Top .news {
  background: #E0EDE3;
}
/* --コンセプトが非表示の際 */

#Top .news ul {
  width: 75.6%;
}

#Top .news ul li {
  background: #fff;
  padding: 20px;
  display: flex;
  display: -webkit-flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  text-align: left;
}
#Top .news ul li:not(:last-child) {
  margin-bottom: 8px;
}

#Top .news ul time {
  width: 18%;
  font-size: 75%;
  color: #64B9C8;
}

#Top .news ul span {
  width: 81%;
  /* text-align: left; */
  font-size: 87.5%;
}

#Top .news ul span a {
  text-decoration: underline;
}
#Top .news ul span a:hover {
  color: #64b9c8;
}

#Top .concept {
  background: #C1DCC7;
  position: relative;
}

#Top .concept .sec-inner {
  position: relative;
  z-index: 2;
}

#Top .concept .bg-l {
  width: 23.6%;
  max-width: 280px;
  position: absolute;
  bottom: 0;
  left: 0;
}
#Top .concept .bg-r {
  width: 23%;
  max-width: 270px;
  position: absolute;
  top: 50px;
  right: 0;
}

#Top .concept .sec-txt {
  text-shadow: 
  #C1DCC7 2px 0px 2px, #C1DCC7 -2px 0px 2px,
  #C1DCC7 0px -2px 2px, #C1DCC7 -2px 0px 2px,
  #C1DCC7 2px 2px 2px, #C1DCC7 -2px 2px 2px,
  #C1DCC7 2px -2px 2px, #C1DCC7 -2px -2px 2px,
  #C1DCC7 1px 2px 2px, #C1DCC7 -1px 2px 2px,
  #C1DCC7 1px -2px 2px, #C1DCC7 -1px -2px 2px,
  #C1DCC7 2px 1px 2px, #C1DCC7 -2px 1px 2px,
  #C1DCC7 2px -1px 2px, #C1DCC7 -2px -1px 2px,
  #C1DCC7 1px 1px 2px, #C1DCC7 -1px 1px 2px,
  #C1DCC7 1px -1px 2px, #C1DCC7 -1px -1px 2px;
}

#Top .room {
  padding-bottom: 0;
}

#Top .room .room-ph02 {
  width: 67.8%;
}
#Top .room .room-ph03 {
  width: 32.2%;
}
#Top .room .room-ph06 {
  width: 39.5%;
}
#Top .room .room-ph07 {
  width: 60.5%;
}

#Top .room .box {
  background: #fff;
  padding: 80px 40px 100px;
}

#Top .room .box .con:not(:last-child) {
  margin-bottom: 90px;
}

#Top .room .box .con .con-child:not(:last-child) {
  margin-bottom: 60px;
}

#Top .room .box h4 {
  text-align: left;
  font-size: 125%;
  font-weight: 900;
  border-bottom: solid 2px #64B9C8;
  padding-bottom: 12px;
  margin-bottom: 40px;
}

#Top .room .box .article-wrap {
  padding: 0 20px;
}

#Top .room .box article {
  margin-bottom: 40px;
}

#Top .room .box h5 {
  text-align: left;
  font-size: 112.5%;
  font-weight: 900;
  border-left: solid 6px #64B9C8;
  padding-left: 8px;
  line-height: 17px;
  margin-bottom: 20px;
}

#Top .room .box table {
  border-collapse:collapse;
  margin-bottom: 20px;
}

#Top .room .box table {
  width: 100%;
}

#Top .room .box table th,
#Top .room .box table td {
  border-top: dotted 1px #AAAAAA;
  padding: 16px 0;
}
#Top .room .box table tr:last-child th,
#Top .room .box table tr:last-child td {
  border-bottom: dotted 1px #AAAAAA;
}

#Top .room .box table th {
  font-weight: 700;
  background: #E0EDE3;
}

#Top .room .box table th span {
  font-size: 87.5%;
}

#Top .room .box article p {
  text-align: left;
}

#Top .room .box article .l-box {
  background: #F4E5A2;
  padding: 5px;
  font-size: 87.5%;
  width: 100%;
  display: block;
  margin-top: 16px;
  text-align: center;
  line-height: 1.3;
}

#Top .room .box .flex article {
  width: 47.7%;
}

#Top .room .box .map img {
  padding: 0 20px;
}

#Top .activity {
  background: #C1DCC7;
  position: relative;
}
#Top .activity::before {
  content: "";
  position: absolute;
  background: url(../img/activity_flag_l.png) no-repeat;
  background-size: cover;
  width: 320px;
  height: 172px;
  top: 0;
  left: 0;
}
#Top .activity::after {
  content: "";
  position: absolute;
  background: url(../img/activity_flag_r.png) no-repeat;
  background-size: cover;
  width: 320px;
  height: 172px;
  top: 0;
  right: 0;
}

#Top .activity h3 {
  justify-content: center;
  position: relative;
}
#Top .activity h3::before {
  content: "";
  position: absolute;
  background: url(../img/activity_copy_img01.png) no-repeat;
  background-size: cover;
  width: 40px;
  height: 40px;
  left: 35px;
  top: -35px;
  z-index: 1;
}
#Top .activity h3::after {
  content: "";
  position: absolute;
  background: url(../img/activity_copy_img02.png) no-repeat;
  background-size: cover;
  width: 93px;
  height: 57px;
  right: -20px;
  bottom: -25px;
  z-index: 1;
}

#Top .activity h3 img {
  margin: 0 5px;
  z-index: 2;
}

#Top .activity .list {
  align-items: stretch;
}

#Top .activity .list .list-child {
  width: 48%;
  background: rgba(255,255,255,.8);
}

#Top .activity .list .list-child:nth-child(-n+2) {
  margin-bottom: 40px;
}

#Top .activity .list .list-child img {
  width: 100%;
  display: block;
}

#Top .activity .list .list-child .box {
  padding: 20px 20px 30px;
  text-align: left;
  position: relative;
}
#Top .activity .list .list-child .box.reserve::after {
  content: "要予約";
  position: absolute;
  top: 0;
  right: 0;
  font-size: 100%;
  color: #fff;
  font-weight: 900;
  background: #B90000;
  padding: 0 5px;
}

#Top .activity .list .list-child .box h4 {
  font-size: 150%;
  font-weight: 900;
  color: #17869C;
}

#Top .activity .list .list-child .box .price-area {
  margin-bottom: 10px;
}

#Top .activity .list .list-child .box .price {
  font-size: 125%;
  font-weight: 900;
  margin-top: 5px;
}

#Top .activity .list .list-child .box .red-txt {
  font-size: 100%;
  font-weight: 700;
  color: #B90000;
  margin-top: 0;
}
#Top .activity .list .list-child .box .red-txt span {
  font-size: 125%;
}

#Top .activity .list .list-child .box .txt span {
  font-weight: 700;
}

#Top .spot {
  background: url(../img/spot_bg.png) no-repeat bottom center;
  background-size: contain;
}

#Top .spot h3 {
  font-size: 250%;
  font-weight: 700;
  background:linear-gradient(transparent 55%, #FEDD45 55%);
  display: inline;
  padding: 0 8px;
  position: relative;
}
#Top .spot h3::after {
  content: "";
  position: absolute;
  width: 1px;
  height: 50px;
  bottom: -85px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  background: #64B9C8;
}

#Top .spot h4 {
  font-size: 150%;
  font-weight: 900;
  margin-top: 110px;
  margin-bottom: 20px;
}

#Top .spot .list {
  margin-top: 60px;
  align-items: stretch;
}

#Top .spot .list .list-child {
  width: 30%;
  text-align: left;
}
#Top .spot .list .list-child:nth-child(-n+3) {
  margin-bottom: 35px;
}

#Top .spot .list .list-child h5 {
  color: #64B9C8;
  font-size: 112.5%;
  font-weight: 900;
  margin: 14px 0 6px;
}

#Top .access {
  background: #fff;
  position: relative;
}
#Top .access::before {
  position: absolute;
  content: "";
  background: url(../img/access_bg_l.png) no-repeat center center;
  background-size: cover;
  width: 368px;
  height: 359px;
  top: 0;
  left: 0;
}
#Top .access::after {
  position: absolute;
  content: "";
  background: url(../img/access_bg_r.png) no-repeat center center;
  background-size: cover;
  width: 368px;
  height: 359px;
  bottom: 0;
  right: 0;
}

#Top .access .sec-inner {
  position: relative;
  z-index: 1;
}

#Top .access .address {
  font-size: 112.5%;
  margin-bottom: 30px;
}

@media screen and (min-width: 768px){
}

@media screen and (max-width: 1024px){
}

@media screen and (max-width: 768px){
  #Top .mv .mv-logo {
    top: 56%;
  }
  #Top .activity h3 img.copy01 {
    margin-bottom: 10px;
  }
  #Top .activity .list .list-child:nth-child(-n+2) {
    margin-bottom: 30px;
  }
}

@media screen and (max-width: 767px){
  main {
    margin-top: 60px;
  }
  .slick-slide img {
    height: 630px;
    object-fit: cover;
  }
  #Top .mv::before,
  #Top .mv::after {
    width: 100px;
    height: 98px;
  }
  #Top .mv .mv-logo {
    width: 90%;
    top: 50%;
  }
  .slick-dots li {
    width: 9%!important;
    height: 3px!important;
  }
  #Top .news ul {
    width: 100%;
  }
  #Top .news ul time {
    width: 100%;
    margin-bottom: 3px;
  }
  #Top .news ul span {
    width: 100%;
  }
  #Top .news ul li {
    padding: 20px;
  }
  #Top .concept .sec-txt {
    text-align: left;
  }
  #Top .room .box {
    padding: 40px 15px 50px;
  }
  #Top .room .box .article-wrap {
    padding: 0 10px;
  }
  #Top .room .box h4 {
    margin-bottom: 20px;
  }
  #Top .room .box h4 span {
    display: inline-block;
  }
  .sc-table {
    overflow-x: scroll;
    white-space: nowrap;
  }
  .sc-table table {
    width: 650px!important;
  }
  #Top .room .box article {
    margin-bottom: 25px;
  }
  #Top .room .box .flex article {
    width: 100%;
  }
  #Top .room .box h5 {
    margin-bottom: 10px;
  }
  #Top .room .box .con .con-child:not(:last-child) {
    margin-bottom: 35px;
  }
  #Top .room .box .con:not(:last-child) {
    margin-bottom: 45px;
  }
  #Top .room .box .map img {
    padding: 0;
  }
  #Top .activity::before,
  #Top .activity::after {
    width: 100px;
    height: 54px;
  }
  #Top .activity h3 img.copy01 {
    width: 55%;
    height: auto;
  }
  #Top .activity h3 img.copy02 {
    width: 100%;
    height: auto;
  }
  #Top .activity h3::before {
    left: 5%;
  }
  #Top .activity h3::after {
    top: -60%;
    right: -10%;
  }
  #Top .activity .list .list-child {
    width: 95%;
    margin: 0 auto;
  }
  #Top .activity .list .list-child .box {
    padding: 15px 15px 20px;
  }
  #Top .activity .list .list-child .box h4 {
    font-size: 120%;
  }
  #Top .activity .list .list-child .box .price {
    font-size: 105%;
  }
  #Top .activity .list .list-child .box .red-txt {
    font-size: 100%;
    line-height: 1.2;
  }
  #Top .activity .list .list-child .box .red-txt span {
    font-size: 120%;
  }
  #Top .activity .list .list-child .box .txt {
    font-size: 92.8%;
  }
  #Top .activity .list .list-child .box.reserve::after {
    font-size: 90%;
  }
  #Top .activity .list .list-child:not(:last-child) {
    margin-bottom: 15px;
  }
  #Top .spot h3 {
    font-size: 200%;
  }
  #Top .spot h3::after {
    height: 30px;
    bottom: -50px;
  }
  #Top .spot h4 {
    font-size: 140%;
    margin-top: 60px;
    margin-bottom: 15px;
  }
  #Top .spot .sec-txt {
    text-align: left;
  }
  #Top .spot .list {
    margin-top: 30px;
  }
  #Top .spot .list .list-child {
    width: 48%;
  }
  #Top .spot .list .list-child:nth-last-of-type(n+3) {
    margin-bottom: 20px!important;
  }
  #Top .access::before,
  #Top .access::after {
    width: 120px;
    height: 117px;
  }
  #Top .access .address {
    margin-bottom: 15px;
  }
  #Top .access .googlemap iframe {
    height: 200px;
  }
}

@media screen and (max-width: 320px){

}


/* ------------------------
footer
------------------------ */
footer {
  padding-top: 80px;
  background: #4C96A3;
  color: #fff;
}

footer .footer-inner {
  max-width: 880px;
  margin: 0 auto;
}

footer .logo {
  max-width: 400px;
}

footer .address {
  font-size: 87.5%;
  font-weight: 700;
  margin: 30px 0 40px;
}

footer .info {
  margin-bottom: 16px;
  padding-bottom: 30px;
  align-items: stretch;
  border-bottom: solid 1px #fff;
}

footer .info .info-child {
  width: 47.7%;
}

footer .info .info-child h6 {
  font-size: 87.5%;
  font-weight: 900;
  background: #64B9C8;
  padding: 10px;
  letter-spacing: .1em;
  margin-bottom: 14px;
}

footer .info .info-child .txt {
  font-size: 87.5%;
  text-align: left;
}

footer .note {
  text-align: left;
}

footer .footer-tel {
  margin: 50px 0 87px;
}

footer .copyright {
  background: #2F5D65;
  padding: 20px 0;
}

@media screen and (max-width: 1024px) {
  footer .footer-inner {
    width: 90%;
  }
}

@media screen and (max-width: 767px) {
  footer {
    padding-top: 50px;
  }
  footer .logo {
    width: 70%;
  }
  footer .address {
    margin: 20px 0 25px;
  }
  footer .info .info-child {
    width: 90%;
    margin: 0 auto;
  }
  footer .info .info-child:first-child {
    margin-bottom: 20px;
  }
  footer .info .info-child h6 {
    padding: 6px;
    margin-bottom: 7px;
  }
  footer .info {
    margin-bottom: 10px;
    padding-bottom: 25px;
  }
  footer .footer-tel {
    margin: 40px 0 30px;
  }
  footer .footer-tel img {
    width: 65%;
  }
  footer .copyright {
    padding: 8px 0;
  }
}