body,
html {
    margin: 0;
    padding: 0;
}

html {
    font-size: 62.5%;
    width: 100%;
}

body {
    background-color: #fff;
    color: #000;
    font-size: 1.6rem;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
    line-height: 1.6em;
    margin: 0 auto;
    position: relative;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-text-size-adjust: 100%;
    width: 750px;
}

a {
    color: #000;
    display: inline-block;
    text-decoration: none;
}

a:hover {
    color: #000;
    opacity: 0.8;
    text-decoration: underline;
    transition: 1s;
}

img {
    max-width: 100%;
    height: auto !important;
}

a img:hover {
    opacity: 0.8;
    filter: alpha(opacity=80);
    -ms-filter: "alpha( opacity=80 )";
}

p { margin: 0;}

table {
    width: 100%;
    border-collapse: collapse;
}

table tr th {
    font-weight: normal;
    text-align: left;
}

* {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
}

a {
    text-decoration: none;
}

a:hover {
    opacity: .8 !important;
    text-decoration: none;
}

button,
input[type="text"],
input[type="password"],
textarea,
select {
    outline: none;
    width: 100%;
}

/*--------------------------------------------------------------------------------

--------------------------------------------------------------------------------*/
.inner-box {
    max-width: 100%;
    margin: 0 auto;
}

.pc-br::before {
    content: "\A";
    white-space: pre;
}

.pc-block {
    display: block;
}

.sp-block {
    display: none;
}

.flex-list {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    flex-direction: row;
    margin: 0 auto;
    padding: 0;
    justify-content: center;
}

.flex-list > li {
    list-style: none;
}

.list {
    font-size: 0;
    margin: 0;
    padding: 0;
}

.list > li {
    list-style: none;
}

/*--------------------------------------------------------------------------------
 共通箇所
--------------------------------------------------------------------------------*/
.wrap-tit {
    color: #49b7c1;
    font-size: 7rem;
    font-family: 'Barlow Condensed', sans-serif;
    letter-spacing: .3em;
    line-height: 1em;
    margin: 0 auto 35px;
    text-align: center;
}

.bg-wrap {
    background-size: 100% auto;
    background-position: center;
    position: relative;
}

.bg-wrap::before {
    background-repeat: no-repeat;
    background-position: top center;
    background-size: 100% auto;
    content: "";
    display: block;
    left: 0;
    position: absolute;
    width: 100%;
}

.bg-wrap::after {
    background-repeat: no-repeat;
    background-position: top center;
    background-size: 100% auto;
    content: "";
    display: block;
    left: 0;
    position: absolute;
    width: 100%;
}

.for-reserve {
    position: fixed;
    bottom: 30px;
    left: 0;
    width: 100%;
    z-index: 999;
}

.for-reserve > a {
    background-color: #ff80aa;
    border-radius: 4px;
    color: #fff;
    display: inline-block;
    font-size: 2.6rem;
    margin: 0 auto;
    min-width: 360px;
    padding: 22px 10px;
    position: absolute;
    bottom: 0;
    left: calc(50% - 356px);
    text-align: center;
}

/*--------------------------------------------------------------------------------
 header
--------------------------------------------------------------------------------*/
.header {
    text-align: center;
}

.header > .inner-box {
    position: relative;
}

.h-tit {
    margin: 0 auto;
    position: absolute;
    bottom: 20%;
    left: 50%;
    -ms-transform: translate(-50%,0%);
    -webkit-transform: translate(-50%,0%);
    transform: translate(-50%,0%);
}

.h-tit > img {
    width: 350px;
}

/*--------------------------------------------------------------------------------
  about-wrap
--------------------------------------------------------------------------------*/
.about-wrap {
    padding: 80px 0;
    position: relative;
}

.fish {
    position: absolute;
}

.fish01 {
    right: 0;
    top: -6%;
}

.about-wrap > .inner-box {
    padding: 0 2.5%;
}

.about-wrap h2 {
    margin: 0 auto 60px;
    text-align: center;
}

.about-wrap h2 > img {
    max-width: 550px;
}

.about-wrap p {
    color: #49b7c1;
    font-size: 2.6rem;
    font-weight: 500;
    letter-spacing: .09em;
    line-height: 1.6em;
    margin: 0 auto 30px;
}

/*--------------------------------------------------------------------------------
  plan-wrap
--------------------------------------------------------------------------------*/
.plan-wrap {
    padding: 0 0 60px;
}

.plan-wrap > .inner-box {
    padding: 0 2.5%;
}

.plan-wrap h2 {
    left: 50%;
    margin: 0 auto 60px;
    position: absolute;
    text-align: center;
    top: -10%;
    width: 100%;
    -ms-transform: translate(-50%,0%);
    -webkit-transform: translate(-50%,0%);
    transform: translate(-50%,0%);
}

.plan-wrap h2 > img {
    max-width: 550px;
}

.p-table-wrap {
    background-image: url(../img/plan-wrap.png);
    margin-bottom: 120px;
    padding: 30px 7%;
}

.p-table-wrap::before {
    background-image: url(../img/plan-wrap-top.png);
    height: 115px;
    top: -50px;
}

.p-table-wrap::after {
    background-image: url(../img/plan-wrap-bottom.png);
    height: 115px;
    bottom: -100px;
}

.plan-table tr th {
    border-bottom: 1px solid #49b7c1;
    color: #5b5b5b;
    font-size: 2.4rem;
    font-weight: 400;
    line-height: 1.6em;
    padding: 24px 0;
    vertical-align: top;
    width: 35%;
}

.plan-table tr td {
    border-bottom: 1px solid #49b7c1;
    color: #5b5b5b;
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 1.6em;
    padding: 24px 0;
    vertical-align: top;
    width: 65%;
}

.cancel-box {
    color: #5b5b5b;
    font-size: 2.6rem;
}

.cancel-box > h3 {
    font-weight: 700;
    margin: 0 auto 40px;
}

.cancel-box > p {
    line-height: 1.6em;
    margin: 30px auto 0;
}

/*--------------------------------------------------------------------------------
  calender-wrap
--------------------------------------------------------------------------------*/
.calender-wrap {
    padding: 0 0 15%;
}

.calender-wrap > .inner-box {
    padding: 0 2.5%;
}

.calender-wrap h2 {
    margin: 0 auto 20px;
    text-align: center;
}

.calender-wrap h2 > img {
    max-width: 550px;
}

/*--------------------------------------------------------------------------------
  other-wrap
--------------------------------------------------------------------------------*/
.other-wrap {
    background-image: url(../img/other-wrap.png);
    margin-bottom: 120px;
    padding: 30px 2.5%;
}

.fish02 {
    left: 0;
    top: -9%;
}

.fish02 > img {
    width: 300px;
}

.fish03 {
    right: 0;
    top: -3%;
}

.fish03 > img {
    width: 100px;
}

.other-wrap > .inner-box {
    padding: 0 2.5%;
}

.other-wrap::before {
    background-image: url(../img/other-wrap-top.png);
    height: 115px;
    top: -50px;
}

.other-wrap::after {
    background-image: url(../img/other-wrap-bottom.png);
    height: 115px;
    bottom: -100px;
}

.o-in-box {
    margin: 0 auto 20px;
}

.o-in-box > p {
    color: #49b7c1;
    font-size: 2.6rem;
    font-weight: 500;
    line-height: 1.5em;
    margin: 5px auto 0;
}

.o-in-img {
    position: relative;
}

.o-in-img > p {
    background-color: #49b7c1;
    color: #fff;
    font-size: 3rem;
    font-weight: 700;
    padding: 17px 20px;
    position: absolute;
    right: 0;
    top: 0;
    text-align: right;
}

.o-in-img > p > span {
    font-size: 2.6rem;
    font-weight: 400;
}

.o-in-img > p > span.s-bold {
    font-size: 2.4rem;
    font-weight: 800;
}
/*--------------------------------------------------------------------------------
  map-wrap
--------------------------------------------------------------------------------*/
.map-wrap {
    padding: 60px 0;
    position: relative;
}

.fish04 {
    left: 0;
    top: -9%;
}

.fish04 > img {
    width: 100px;
}

.fish05 {
    right: 0;
    top: -10%;
}

.fish05 > img {
    width: 360px;
}

.map-wrap > .inner-box {
    padding: 0 2.5%;
}

.for-map {
    margin: 14px auto 0;
    text-align: right;
}

.for-map > a {
    background-color: #4984db;
    border-radius: 4px;
    color: #fff;
    display: inline-block;
    font-size: 2.6rem;
    font-weight: 500;
    min-width: 390px;
    padding: 27px 10px;
    text-align: center;
}

/*--------------------------------------------------------------------------------
  instagram-wrap
--------------------------------------------------------------------------------*/
.instagram-wrap {
    padding: 60px 0 15%;
}

.instagram-wrap > .inner-box {
    padding: 0 2.5%;
}

.for-insta {
    margin: 14px auto 0;
    text-align: right;
}

.for-insta > a {
    border-bottom: 2px solid #49b7c1;
    color: #49b7c1;
    display: inline-block;
    font-size: 3rem;
    font-weight: 700;
    letter-spacing: .3em;
    padding: 2px 0 5px 5px;
}

/*--------------------------------------------------------------------------------
  youtube-wrap
--------------------------------------------------------------------------------*/
.youtube-wrap {
    background-image: url(../img/yt-wrap.png);
    margin-bottom: 120px;
    padding: 30px 2.5% 60px;
}

.movie-list > li {
    display: block;
    width: 100%;
}

#youtube .iframe-responsive {
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 56.25%;
}

#youtube .iframe-responsive > iframe {
    border-radius: 10px;
    position: absolute;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100%;
}

.youtube-wrap .fish02 {
    left: 0;
    top: -13%;
}

.youtube-wrap .fish02 > img {
    width: 270px;
}

.youtube-wrap .fish06 {
    right: 0;
    bottom: -10%;
    z-index: 9;
}

.youtube-wrap .fish06 > img {
    width: 270px;
}

.youtube-wrap::before {
    background-image: url(../img/yt-wrap-top.png);
    height: 115px;
    top: -50px;
}

.youtube-wrap::after {
    background-image: url(../img/yt-wrap-bottom.png);
    height: 115px;
    bottom: -100px;
}

/*--------------------------------------------------------------------------------
  gallery
--------------------------------------------------------------------------------*/
.slick-inner {
    margin: 0 20px;
}

.slick-inner img {
    width: 100%;
}

.slider {
    opacity: 0;
    transition: opacity .25s ease;
}

.slider.slick-initialized {
    opacity: 1;
}

.slick-dots {
    bottom: -40px;
}

.slick-dots li button {
    height: 22px;
    padding: 0;
    width: 22px;
}

.slick-dots li button:before {
    color: rgba(73, 183, 193, 0.2);
    font-size: 22px;
    height: 22px;
    opacity: 1;
    width: 22px;
}

.slick-dots li.slick-active button:before {
    color: #49b7c1;
}

/*--------------------------------------------------------------------------------
  caution-wrap
--------------------------------------------------------------------------------*/
.caution-wrap {
    color: #5b5b5b;
    font-size: 2.6rem;
    line-height: 1.6em;
    padding: 65px 0;
}

.caution-wrap > .inner-box {
    background-color: #f0f6f6;
    padding: 50px 7%;
}

.cau-tit {
    font-weight: 700;
    margin: 0 auto 30px;
}

/*--------------------------------------------------------------------------------
  law-wrap
--------------------------------------------------------------------------------*/
.law-wrap {
    color: #5b5b5b;
    padding: 65px 0 20%;
}

.law-wrap > .inner-box {
    padding: 0 2.5%;
}

.law-tit {
    font-size: 2.6rem;
    font-weight: 700;
    margin: 0 auto;
}

.law-table {
    font-size: 2.6rem;
    line-height: 1.4em;
}

.law-table tr > th {
    border-bottom: 1px solid #49b7c1;
    padding: 24px 0;
    vertical-align: top;
    width: 32%;
}

.law-table tr > td {
    border-bottom: 1px solid #49b7c1;
    padding: 24px 0;
    vertical-align: top;
}

/*--------------------------------------------------------------------------------
 .footer
--------------------------------------------------------------------------------*/
.footer {
    padding: 0 0 50px;
    position: relative;
}

.footer > .foot-wrap > .inner-box {
    position: relative;
    z-index: 99;
}

.foot-icon01 {
    position: absolute;
    left: 0;
    top: 0;
    z-index: 99;
}

.foot-icon02 {
    position: absolute;
    right: 0;
    top: 20%;
}

.foot-wrap {
    background-image: url(../img/foot-wrap.png);
    margin-bottom: 140px;
    padding: 80px 10%;
}

.foot-wrap::before {
    background-image: url(../img/foot-wrap-top.png);
    height: 115px;
    top: -50px;
}

.foot-wrap::after {
    background-image: url(../img/foot-wrap-bottom.png);
    height: 115px;
    bottom: -100px;
}

.foot-logo {
    text-align: center;
}

.foot-logo > img {
    max-width: 350px;
}

.foot-wrap .foot-page-detail {
    color: #fff;
    font-size: 2.6rem;
    font-weight: 400;
    line-height: 2em;
    margin: 50px auto 0;
}

.foot-wrap .foot-page-detail > span {
    display: inline-block;
}

.foot-tel {
    display: inline-block;
    padding: 50px 0 30px;
}

.foot-tel > .tel-inner,
.foot-mail > .mail-inner {
    border-bottom: 1px solid #fff;
    display: inline-block;
    line-height: 2em;
    letter-spacing: .07em;
    padding-bottom: 15px;
}

.tel-time {
    color: #fff;
    font-size: 2.4rem;
    font-weight: 400;
    padding: 10px 0 0;
    text-align: right;
}

.foot-mail {
    padding: 0 0 85px;
}

.tel-inner > span,
.mail-inner > span {
    color: #fff;
    display: inline-block;
    min-width: 100px;
    padding-right: 20px;
    font-size: 3rem;
    vertical-align: middle;
}

.tel-inner > a,
.mail-inner > a {
    color: #fff;
    display: inline-block;
    font-size: 4rem;
    font-weight: 500;
    vertical-align: middle;
}

.sns-share {
    margin: 0 auto 15px;
    text-align: center;
}

.sns-share > img {
    width: 250px;
}

.sns-list > li {
    text-align: center;
    width: 25%;
}

.sns-list > li > a {
    display: block;
}

.sns-list > li > a > img {
    width: 90px;
}

.other-link-wrap {
    max-width: 73.5%;
    margin: 0 auto;
}

.other-link-wrap .list {
    margin-bottom: 50px;
}

.other-link-wrap .list > li {
    margin-bottom: 10px;
}

.other-link-wrap .list > li > a {
    background-color: #d3e1e4;
    border-radius: 4px;
    color: #4e4e4e;
    display: block;
    font-size: 2.4rem;
    font-weight: 500;
    padding: 22px 5px;
    text-align: center;
}

.other-link-wrap .list > li > a > span {
    font-size: 1.8rem;
}

.copy {
    text-align: center;
}

.copy > p {
    color: #49b7c1;
    font-size: 1.8rem;
}

.r2 {
    text-align: center;
    position: relative;
    top: -30px;
}
@media screen and (max-width: 1024px) {

    body {
        width: 100%;
    }
    .for-reserve > a {
        position: static;
    }

    /*--------------------------------------------------------------------------------
      about-wrap
    --------------------------------------------------------------------------------*/
    .about-wrap > .inner-box {
        padding: 0 4%;
    }

    .plan-wrap h2 {
    }

    .plan-wrap h2 > img {
        max-width: 70%;
    }

    .p-table-wrap {
        margin-bottom: 1000px;
    }

    /*--------------------------------------------------------------------------------
      calender-wrap
    --------------------------------------------------------------------------------*/
    .calender-wrap > .inner-box {
        padding: 0 4%;
    }

    /*--------------------------------------------------------------------------------
      other-wrap
    --------------------------------------------------------------------------------*/
    .other-wrap {
        padding: 30px 4%;
    }

    /*--------------------------------------------------------------------------------
      map-wrap
    --------------------------------------------------------------------------------*/
    .map-wrap > .inner-box {
        padding: 30px 4%;
    }

    /*--------------------------------------------------------------------------------
      instagram-wrap
    --------------------------------------------------------------------------------*/
    .instagram-wrap > .inner-box {
        padding: 30px 4%;
    }

    /*--------------------------------------------------------------------------------
      youtube-wrap
    --------------------------------------------------------------------------------*/
    .youtube-wrap {
        padding: 30px 4% 60px;
    }

    /*--------------------------------------------------------------------------------
      law-wrap
    --------------------------------------------------------------------------------*/
    .law-wrap > .inner-box {
        padding: 0 4%;
    }
}


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

    /*--------------------------------------------------------------------------------
      共通
    --------------------------------------------------------------------------------*/
    .wrap-tit {
        font-size: 3.5rem;
        margin: 0 auto 20px;
    }

    .for-reserve {
        left: 4%;
    }

    .for-reserve > a {
        font-size: 1.7rem;
        min-width: 0;
        padding: 15px 20px;
    }

    /*--------------------------------------------------------------------------------
      header
    --------------------------------------------------------------------------------*/
    .h-tit {
        bottom: 25%;
    }

    /*--------------------------------------------------------------------------------
      about-wrap
    --------------------------------------------------------------------------------*/
    .about-wrap {
        padding: 40px 0 60px;
    }

    .fish01 {
        top: -5.5%;
    }

    .fish01 > img {
        width: 130px;
    }

    .about-wrap h2 {
        margin: 0 auto 30px;
    }

    .about-wrap h2 > img {
        max-width: 90%;
    }

    .about-wrap p {
        font-size: 1.3rem;
    }

    /*--------------------------------------------------------------------------------
      plan-wrap
    --------------------------------------------------------------------------------*/
    .p-table-wrap {
        margin-bottom: 80px;
    }

    .plan-wrap h2 {
        margin: 0 auto 30px;
        top: -16%;
    }

    .plan-wrap h2 > img {
        max-width: 90%;
    }

    .plan-wrap > .inner-box {
        padding: 0 4%;
    }

    .p-table-wrap::after {
        height: 50px;
        bottom: -50px;
    }

    .p-table-wrap::before {
        height: 50px;
        top: -30px;
    }

    .plan-table tr th {
        font-size: 1.2rem;
        padding: 12px 0;
    }

    .plan-table tr td {
        font-size: 1.2rem;
        padding: 12px 0;
    }

    /*--------------------------------------------------------------------------------
      cancel-box
    --------------------------------------------------------------------------------*/
    .cancel-box {
        font-size: 1.4rem;
    }

    .cancel-box > h3 {
        margin: 0 auto 20px;
    }

    .calender-wrap h2 > img {
        max-width: 90%;
    }

    /*--------------------------------------------------------------------------------
      other-wrap
    --------------------------------------------------------------------------------*/
    .other-wrap {
        margin-bottom: 30px;
    }

    .fish02 > img {
        width: 140px;
    }

    .fish03 > img {
        width: 50px;
    }

    .other-wrap::before {
        height: 50px;
        top: -30px;
    }

    .o-in-img > p {
        font-size: 1.7rem;
        padding: 5px 10px;
    }

    .o-in-img > p > span.s-bold {
        font-size: 1.7rem;
    }

    .o-in-img > p > span {
        font-size: 1.5rem;
    }

    .o-in-box > p {
        font-size: 1.4rem;
    }

    /*--------------------------------------------------------------------------------
      map-wrap
    --------------------------------------------------------------------------------*/
    .map-wrap {
        padding: 0;
    }

    .fish04 {
        top: 0;
    }

    .fish04 > img {
        width: 50px;
    }

    .fish05 {
        top: -5%;
    }

    .fish05 > img {
        width: 180px;
    }

    .map-box > iframe {
        height: 250px !important;
    }

    .for-map > a {
        font-size: 1.6rem;
        min-width: 200px;
        padding: 10px 20px;
    }

    /*--------------------------------------------------------------------------------
      instagram-wrap
    --------------------------------------------------------------------------------*/
    .instagram-wrap {
        padding: 0 0 7%;
    }

    .for-insta > a {
        font-size: 1.5rem;
    }

    /*--------------------------------------------------------------------------------
      youtube-wrap
    --------------------------------------------------------------------------------*/
    .youtube-wrap {
        margin-bottom: 60px;
    }

    .youtube-wrap::before {
        height: 50px;
        top: -20px;
    }

    .youtube-wrap .fish02 {
        top: -10%;
    }

    .youtube-wrap .fish02 > img {
        width: 135px;
    }

    .youtube-wrap .fish06 {
        bottom: -6%;
    }

    .youtube-wrap .fish06 > img {
        width: 135px;
    }

    /*--------------------------------------------------------------------------------
      gallery-wrap
    --------------------------------------------------------------------------------*/
    .slick-inner {
        margin: 0 10px;
    }

    .slick-dots li button {
        height: 18px;
        width: 18px;
    }

    .slick-dots li button:before {
        font-size: 18px;
        height: 18px;
        width: 18px;
    }

    /*--------------------------------------------------------------------------------
      caution-wrap
    --------------------------------------------------------------------------------*/
    .caution-wrap {
        font-size: 1.4rem;
        padding: 40px 5% 20px;
    }

    .caution-wrap > .inner-box {
        padding: 30px 7%;
    }

    /*--------------------------------------------------------------------------------
      law-wrap
    --------------------------------------------------------------------------------*/
    .law-wrap {
        padding: 30px 0 20%;
    }

    .law-tit {
        font-size: 1.4rem;
    }

    .law-table {
        font-size: 1.4rem;
    }

    .law-table tr > th,
    .law-table tr > td {
        padding: 12px 0;
    }

    /*--------------------------------------------------------------------------------
      footer
    --------------------------------------------------------------------------------*/
    .footer {
        padding: 0 0 25px;
    }

    .foot-wrap {
        margin-bottom: 70px;
        padding: 40px 10%;
    }

    .foot-icon01 > img {
        width: 150px;
    }

    .foot-icon02 {
        top: 15%;
    }

    .foot-icon02 > img {
        width: 225px;
    }

    .foot-wrap::before {
        height: 50px;
        top: -25px;
    }

    .foot-wrap::after {
        height: 50px;
        bottom: -50px;
    }

    .foot-logo > img {
        max-width: 70%;
    }

    .foot-wrap .foot-page-detail {
        font-size: 1.6rem;
        margin: 30px auto 0;
    }

    .tel-inner > span,
    .mail-inner > span {
        font-size: 1.8rem;
        min-width: 60px;
    }

    .tel-inner > a,
    .mail-inner > a {
        font-size: 2.2rem;
    }

    .tel-time {
        font-size: 1.3rem;
        padding: 5px 0 0;
    }

    .foot-tel {
        padding: 25px 0 15px;
    }

    .foot-mail {
        padding: 0 0 40px;
    }

    .other-link-wrap {
        max-width: 85%;
    }

    .other-link-wrap .list {
        margin-bottom: 25px;
    }

    .other-link-wrap .list > li > a {
        font-size: 1.4rem;
        padding: 20px 5px;
    }

    .other-link-wrap .list > li > a > span {
        font-size: 1.2rem;
    }

    .sns-share > img {
        width: 125px;
    }

    .sns-list > li > a > img {
        width: 50px;
    }

    .copy > p {
        font-size: 1.2rem;
    }
}



@media screen and (min-width: 668px) and (max-width: 1024px) and (orientation: landscape) {

    .plan-wrap h2 {
        top: -10%;
    }

    .p-table-wrap::before {
        background-size: 120% auto;
        height: 90px;
        top: -40px;
    }
}
