@charset "UTF-8";
/*p {*/
/*    font-size: 12px;*/
/*    text-align: left;*/
/*}*/

.inner:after, .clear:after {
    content: ".";
    display: block;
    clear: both;
    visibility: hidden;
    line-height: 0;
    height: 0;
    overflow: hidden;
}

.printBr {
    page-break-before: always;
}

.inner {
    width: 980px;
    margin-left: auto;
    margin-right: auto;
}

.inner1366 {
    max-width: 1366px;
    margin-left: auto;
    margin-right: auto;
}

br.pc1366 {
    display: none;
}

.caption {
    font-size: 12px;

}

.caption0 .caption {
    line-height: 1.5em;
    text-align: left;
    color: white;
}

.caption1 .caption {
    line-height: 1.5em;
    text-align: left;
    color: #000;
}

.caption.colBl {
    color: #000;
}

.caption.colW {
    color: #fff;
    text-shadow: 1px 1px 3px #000;
}

.caption.br {
    position: absolute;
    bottom: 1%;
    right: 1%;
}

.caption.bl {
    position: absolute;
    bottom: 1%;
    left: 1%;
}

.capbl {
    position: absolute;
    bottom: 1%;
    left: 2%;
}

.capbr {
    position: absolute;
    bottom: 1%;
    right: 2%;
}

.bold {
    font-weight: bold;
}

.cTopBtn {
    margin-right: 0;
    margin-left: auto;
    width: 80px;
    font-weight: 600;
}

.cTopBtn img {
    margin-right: auto;
    margin-left: auto;
}

.cTopBtn p {
    text-align: center;
}

.top-anim {
    z-index: 800;
    width: 100%;
    left: 0;
    top: 0;
    padding-top: calc(100% / 1920 * 960);
    overflow: hidden;
    background: #000;
    z-index: 10;
    box-shadow: 0 0 10px #000;
}

.top-anim.slide {
    transition: all 0.8s ease;
    z-index: 800;
    width: 100%;
    left: -100%;
    top: 0;
    overflow: hidden;
    background: #000;
}

.top-anim::after {
    content: "image photo";
    position: absolute;
    bottom: 3px;
    right: 3px;
    line-height: 1em;
    color: #FFF;
    font-size: 10px;
    font-family: sans-serif;
    letter-spacing: 0;
    font-weight: 700;
}

/*@media (max-width: 580px) { .top-anim { padding-top: calc(100vh - 140px); } }*/

.top-anim_inner {
    width: 100%;
    height: 100vh;
    position: absolute;
    top: 0;
    left: 0;
    background: #000;
    z-index: 20;
}

.top-anim_inner.slide {
    width: 100%;
    height: 100vh;
    position: absolute;
    top: 0;
    left: -100%;
    transition: all 0.8s ease;
}

.top-anim_inner img {
    position: absolute;
    top: 0;
    left: 0;
    width: auto;
    min-width: 100%;
    height: 100%;
    max-width: inherit;
    overflow: hidden;
}

/*.top-anim_inner.down { transition: transform 4s ease-out; transform: translateY(-53%); }*/

@media (max-width: 580px) {
    .top-anim_inner {
        height: calc(100vh - 140px);
        padding: 0;
    }

    .top-anim_inner.down {
        transform: none;
    }
}

.top-anim_label {
    width: 389px;
    height: auto;
    position: absolute;
    top: 54%;
    left: 10px;
    opacity: 0;
}

.top-anim_label.show {
    opacity: 1;
    transition: opacity 1s linear;
}

@media (max-width: 580px) {
    .top-anim_label {
        top: 10px;
        left: 0;
        right: 0;
        margin: 0 auto;
        display: none;
    }
}

.top-anim_img {
    width: 100%;
    opacity: 0;
    position: absolute;
    top: auto;
    left: auto;
    right: auto;
    margin: auto;
    display: block;
}

/*-------------------------------------------------*/
._pc {
    display: block;
}

._sp {
    display: none;
}

@media (max-width: 580px) {
    ._pc {
        display: none;
    }

    ._sp {
        display: block;
    }
}

@media (min-width: 1251px) {
    ._max1250 {
        display: none;
    }

    ._min1250 {
    }
}

@media (max-width: 1250px) {
    ._max1250 {
    }

    ._min1250 {
        display: none;
    }
}

.top-anim_img0 {
    opacity: 0;
}

.top-anim_img0.show {
    opacity: 1;
    transition: all 1s linear;
}

.top-anim_img1 {
    opacity: 0;
    transform: scale(1.05);
    filter: blur(5px);
}

.top-anim_img1.show {
    width: 100%;
    transform: scale(1);
    transition: all 3s ease-in;
    height: auto;
    overflow: hidden;
    position: absolute;
    left: 0;
    top: 0;
    filter: blur(0);
    opacity: 1;
    z-index: 100;
}

.top-anim_img2 {
    opacity: 0;
    filter: brightness(125%);
}

.top-anim_img2.show {
    opacity: 1;
    filter: brightness(100%);
    transition: all 2s linear;
    width: 100%;
    height: auto;
    position: absolute;
    top: 0;
    left: 0;
    right: auto;
    margin: auto;
    display: block;
    z-index: 110
}

.top-anim_img3-1, .top-anim_img3-2, .top-anim_img3-3, .top-anim_img3-4, .top-anim_img3-5, .top-anim_img3-6 {
    opacity: 0;
    z-index: 50;
}

.top-anim_img3-1.show, .top-anim_img3-2.show, .top-anim_img3-3.show,
.top-anim_img3-4.show, .top-anim_img3-5.show, .top-anim_img3-6.show {
    opacity: 1;
    transition: all 1s linear;
    width: 100%;
    height: auto;
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    z-index: 50;
}

}

.top-anim_img4 {
    opacity: 0;
    width: 100%;
    z-index: 1500;
    filter: brightness(120%);
}

.top-anim_img4.show {
    opacity: 1;
    filter: brightness(100%);
    transition: all 2s linear;
    width: 100%;
    height: auto;
    position: absolute;
    top: 0;
    left: 0;
    bottom: auto;
    right: auto;
    margin: auto;
    display: block;
    z-index: 1200;
}

.top-anim_img5 {
    opacity: 0;
    z-index: 120;
    filter: brightness(300%);
}

.top-anim_img5.show {
    opacity: 1;
    filter: brightness(100%);
    transition: all 2s linear;
    width: 100%;
    height: auto;
    position: absolute;
    top: 0;
    left: auto;
    right: auto;
    margin: auto;
    display: block;
}

}
@media (max-width: 580px) {
    .top-anim_img5.show {
        opacity: 1;
        filter: brightness(100%);
        transition: all 2s linear;
        width: 100%;
        max-width: 375px;
        height: auto;
        position: absolute;
        top: 40%;
        left: auto;
        right: auto;
        bottom: auto;
        margin: auto;
        display: table-cell;
    }
}

.top-anim_img6 {
    opacity: 0;
    z-index: 150;
}

.top-anim_img6.show {
    opacity: 1;
    transition: all 1s linear;
    width: 100%;
    height: auto;
    position: absolute;
    top: 0;
    left: auto;
    right: auto;
    margin: auto;
    display: block;
}

@media (max-width: 580px) {
    .top-anim_img6.show {
        opacity: 1;
        transition: all 1s linear;
        width: 100%;
        height: auto;
        position: absolute;
        top: auto;
        bottom: 0;
        left: auto;
        right: auto;
        margin: auto;
        display: none;
    }
}

.top-anim_img7 {
    opacity: 0;
}

.top-anim_img7.show {
    opacity: 1;
    transition: opacity 1.5s linear;
    filter: brightness(110%);
}

.top-anim_img8 {
    opacity: 0;
    filter: brightness(400%);
}

.top-anim_img8.show {
    opacity: 1;
    filter: brightness(100%);
    transition: all 2s linear;
}

.top-anim_Wappen {
    width: 30%;
    height: auto;
    position: absolute;
    top: 23%;
    left: 20%;
    opacity: 0;
    z-index: 990;
}

.top-anim_Wappen.show {
    opacity: 1;
    transition: opacity 1s linear;
}

/*@media (max-width: 580px) {
.top-anim_img0 { opacity: 0; }
.top-anim_img0.show { opacity: 1; transition: all 1s linear; }

.top-anim_img1 { opacity: 0; }
.top-anim_img1.show { opacity: 1; transition: all 1s linear; }

.top-anim_img2 { opacity: 0; filter: brightness(400%); }
.top-anim_img2.show { opacity: 1; filter: brightness(100%); transition: all 2s linear; }

.top-anim_img3 { opacity: 0; }
.top-anim_img3.show { opacity: 1; transition: all 1s linear; }

.top-anim_img4 { opacity: 0; }
.top-anim_img4.show { opacity: 1; transition: opacity 1.5s linear;filter: brightness(110%); }

.top-anim_img5 { opacity: 0; filter: brightness(400%); }
.top-anim_img5.show { opacity: 1; filter: brightness(100%); transition: all 2s linear; }

.top-anim_img6 { opacity: 0; }
.top-anim_img6.show { opacity: 1; transition: all 1s linear; }

.top-anim_img7 { opacity: 0; }
.top-anim_img7.show { opacity: 1; transition: opacity 1.5s linear;filter: brightness(110%); }

.top-anim_img8 { opacity: 0; filter: brightness(400%); }
.top-anim_img8.show { opacity: 1; filter: brightness(100%); transition: all 2s linear; }

.top-anim_Wappen { position: absolute; width: 100%; top: 170px; right: 0; left: 0;}
.top-anim_Wappen.show { opacity: 1; transition: opacity 1s linear; }
}*/

.light_wrap {
    width: 100%;
    max-width: inherit;
    height: auto;
    margin: 0 auto;
    position: absolute;
    overflow: hidden;
    left: 0;
    bottom: 0;

    opacity: 0;
    /* アニメーション設定*/
    animation-name: light;
    animation-duration: 2s; /*アニメーション時間*/
    animation-timing-function: ease-out; /*アニメーションさせるイージング*/
    animation-delay: 7.5s; /*アニメーション開始させる時間*/
    animation-iteration-count: 1; /*繰り返し回数*/
    animation-direction: normal; /*往復処理をするかどうか*/
    animation-fill-mode: forwards; /*アニメーション後のスタイルをどうするか*/
    4
}

.light_wrap img {
    width: 100%;
    position: absolute;
    object-fit: cover;
    bottom: 0;
    left: 0;
}

@keyframes light {
    0% {
        opacity: 0;
        width: 100%;
        height: 0
    }
    25% {
        opacity: 0.5;
        width: 100%;
        height: 15%
    }
    75% {
        opacity: 1;
        width: 100%;
    }
    100% {
        opacity: 1;
        width: 100%;
        height: 100%
    }
}

/*@media (max-width: 580px) { .top-anim_img { top: auto; bottom: 0; }
  .top-anim_img4 { display: inline; } }*/

.top-anim_text {
    width: 100%;
    height: 100%;
    background-color: #000;
    position: absolute;
    top: 0;
    left: 0;
}

.top-anim_text.hide {
    transition: opacity 0.75s linear;
    opacity: 0;
}

.top-anim_text_inner {
    width: 100%;
    height: 100%;
    max-height: 100vh;
    position: absolute;
    top: 0;
    left: 0;
    background-color: #000;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
    text-align: center;
}

.top-anim_text_inner.show {
    transition: opacity 0.75s linear;
    opacity: 1;
}

.top-anim_text_p1 {
    font-size: 2.7vw;
    font-weight: bold;
    letter-spacing: 0.05em;
    line-height: 1.5em;
    margin-top: 15%;
    text-shadow: 0 0 5px #000, 0 0 5px #000;
}

.top-anim_text_p1 .ast::after {
    transform: translate3d(-5px, -20px, 0);
}

.top-anim_text_p2 {
    font-size: 3vw;
    letter-spacing: 0em;
    line-height: 1.5em;
}

.top-anim_text_p2 .ast::after {
    transform: translate3d(-5px, -20px, 0);
}

.top-anim_text_p3 {
    font-size: 50px;
    letter-spacing: 0.2em;
    line-height: 1.5em;
}

@media (max-width: 580px) {
    .top-anim_text_p1 {
        font-size: 14px;
        margin-top: 10%;
    }

    .top-anim_text_p1 .ast::after {
        transform: translate3d(-5px, -16px, 0);
    }

    .top-anim_text_p2 {
        font-size: 11px;
    }

    .top-anim_text_p2 .ast::after {
        transform: translate3d(-5px, -16px, 0);
    }

    .top-anim_text_p3 {
        font-size: 11px;
    }
}

.top-anim .enji {
    display: inline-block;
    font-size: 150%;
    color: #B94047;
    vertical-align: baseline;
    transform: translateY(10%);
}

.top-anim .middle {
    font-size: 60%;
    line-height: 1.5em;
}

.skip {
    width: 20%;
    max-width: 140px;
    position: absolute;
    bottom: 25px;
    right: 30px;
    border: none;
    outline: none;
    cursor: pointer;
    z-index: 999;
}

@media (max-width: 580px) {
    .skip {
        position: absolute;
        bottom: 10px;
        right: 10px;
        font-size: 12px;
        width: 120px;
    }
}

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

.info_banner {
    width: 100%;
    background-color: rgba(0, 0, 0, 0.8);
    padding: 0px 10px 10px;
    z-index: 800;
    text-align: center;
}

.info_banner img {
    width: 100px;
    margin: 0 auto;
}

@media (max-width: 580px) {
    .info_banner img {
        width: 80px;
        margin: 0 auto;
    }
}

.top-con {
    width: 100%;
    max-width: 1044px;
    padding: 60px 10px;
    margin-top: 60px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
}

.top-con_text {
    width: 50%;
    transform: translateY(-15%);
    display: flex;
}

.top-con_text_inner {
    width: 80%;
}

.top-con_head_p1 {
    font-size: 22px;
    font-family: "Marcellus", serif;
}

.top-con_head_p1::after {
    content: "";
    width: 80px;
    height: 2px;
    display: block;
    margin-top: 10px;
    margin-bottom: 40px;
    background-color: #cac337;
}

.top-con_head_p2 {
    color: #072e63;
    text-shadow: 2px 2px 2px rgba(7, 46, 99, 0.4);
    margin-bottom: 60px;
}

.top-con_body {
    line-height: 3em;
    margin-bottom: 50px;
}

.top-con_link {
    display: inline-flex;
    width: 180px;
    height: 50px;
    justify-content: center;
    align-items: center;
    font-family: "Marcellus", serif;
    font-size: 18px;
    color: #072e63;
    transform: translateY(50px);
    opacity: 0;
}

.top-con_link.show {
    transition: opacity 1s linear, transform 1s ease-out, background-color 0.3s linear, color 0.3s linear;
    transform: none;
    opacity: 1;
}

.top-con_link.show:hover {
    background-color: #072e63;
    color: #FFF;
}

.top-con_img {
    width: 50%;
}

.top-con_img::before {
    content: "";
    width: 86%;
    height: 130%;
    position: absolute;
    top: -15%;
    background-image: url(../img/top/borders.png);
    transform: scale(0);
    transition: transform 0.5s ease-out 1s;
}

.top-con_img.show::before {
    transform: scale(1);
}

.top-con_img_sp {
    width: 100%;
    margin-bottom: 60px;
    display: none;
}

.top-con_img_sp_inner {
    width: 80%;
}

.top-con_img_sp_inner::before {
    content: "";
    width: 86%;
    height: 130%;
    position: absolute;
    top: -15%;
    background-image: url(../img/top/borders.png);
    transform: scale(0);
    transition: transform 0.5s ease-out 1s;
}

.top-con_img_sp.show .top-con_img_sp_inner::before {
    transform: scale(1);
}

@media (max-width: 768px) {
    .top-con {
        padding: 0 10px;
    }

    .top-con_text {
        width: 100%;
        transform: none;
    }

    .top-con_text_inner {
        width: 100%;
    }

    .top-con_head {
        width: 80%;
    }

    .top-con_head_p2 {
        text-align: center;
        margin-bottom: 80px;
    }

    .top-con_body {
        text-align: center;
    }

    .top-con_link {
        display: flex;
        left: 0;
        right: 0;
        margin: 0 auto;
    }

    .top-con_img {
        display: none;
    }

    .top-con_img_sp {
        display: flex;
    }
}

@media (max-width: 580px) {
    .top-con_body {
        text-align: left;
        line-height: 1.75em;
    }
}

.concept {
    flex-direction: row;
}

.concept .top-con_img::before {
    left: -10%;
    transform-origin: 0% 0%;
}

.concept .top-con_img_sp {
    justify-content: flex-end;
}

.concept .top-con_img_sp_inner::before {
    left: -20%;
    transform-origin: 0% 0%;
}

.concept .top-con_text {
    justify-content: flex-start;
}

.concept .top-con_head_p2 {
    font-size: 40px;
}

@media (max-width: 1024px) {
    .concept .top-con_head_p2 {
        font-size: calc(100vw / 1024 * 36);
    }
}

@media (max-width: 768px) {
    .concept .top-con_head_p2 {
        font-size: 30px;
    }
}

.access {
    flex-direction: row-reverse;
    padding-bottom: 0;
}

.access .top-con_text {
    justify-content: flex-end;
}

.access .top-con_head_p2 {
    font-size: 32px;
    line-height: 1.5em;
}

.access .top-con_img::before {
    right: -10%;
    transform-origin: 100% 0%;
}

.access .top-con_img_sp {
    justify-content: flex-start;
}

.access .top-con_img_sp_inner::before {
    right: -20%;
    transform-origin: 100% 0%;
}

@media (max-width: 1024px) {
    .access .top-con_head_p2 {
        font-size: calc(100vw / 1024 * 30);
    }
}

@media (max-width: 768px) {
    .access .top-con_head_p2 {
        font-size: 24px;
    }
}

.location {
    flex-direction: row-reverse;
    padding-bottom: 0;
}

.location .top-con_text {
    justify-content: flex-end;
}

.location .top-con_head_p2 {
    font-size: 32px;
    line-height: 1.5em;
}

.location .top-con_img::before {
    right: -10%;
    transform-origin: 100% 0%;
}

.location .top-con_img_sp {
    justify-content: flex-start;
}

.location .top-con_img_sp_inner::before {
    right: -20%;
    transform-origin: 100% 0%;
}

@media (max-width: 1024px) {
    .location .top-con_head_p2 {
        font-size: calc(100vw / 1024 * 30);
    }
}

@media (max-width: 768px) {
    .location .top-con_head_p2 {
        font-size: 24px;
    }
}

.info {
    position: fixed;
    z-index: 750;
    width: 170px;
    height: 90px;
    left: 0;
    bottom: 30px;
    display: flex;
    padding-left: 10px;
    color: #072e63;
    font-size: 18px;
    align-items: center;
    background-color: #FFF;
    cursor: pointer;
    border-top: 1px solid rgba(7, 46, 99, 0.5);
    border-bottom: 1px solid rgba(7, 46, 99, 0.5);
}

.info_outer {
    background-color: #f6f6f6;
}

.info_mark {
    width: 30px;
    height: 29px;
    position: absolute;
    top: 50%;
    margin-top: -15px;
    right: 10px;
    cursor: pointer;
}

.info_open {
    position: absolute;
    top: 0;
    left: 0;
}

.info_close {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
}

.info_data {
    position: fixed;
    z-index: 700;
    bottom: 30px;
    left: 0;
    width: 100%;
    max-width: 800px;
    padding-left: 200px;
    height: 90px;
    background-color: #FFF;
    transform: translateX(calc(-100% + 220px));
    transition: transform 0.5s ease-out;
    border: 1px solid rgba(7, 46, 99, 0.5);
}

.info_data div.scroll {
    overflow: scroll;
    overflow-x: hidden;
    height: 88px;
    width: 91%;
}

.info_data dl {
    display: flex;
    margin: 5px 0 0 0;
}

.info_data dl:first-child {
    margin: 7px 0 0 0;
}

/*2行の時非表示*/
/*.info_data dl dt,
.info_data dl dd {
  line-height: 70px;
}*/

.info_data.open {
    transform: none;
}

.info_data.open .info_open {
    opacity: 0;
}

.info_data.open .info_close {
    opacity: 1;
}

.info_data_dt {
    padding-left: 20px;
    height: 100%;
    width: 20%;
}

.info_data_dd {
    padding-left: 20px;
    width: 80%;
    height: 100%;
}

@media (max-width: 580px) {
    .info {
        position: relative;
        height: auto;
        left: auto;
        bottom: auto;
        display: block;
        padding: 10px;
        color: #072e63;
        font-size: 18px;
        text-align: center;
        border: 1px solid #072e63;
    }

    .info_outer {
        padding: 20px;
    }

    .info_data {
        position: relative;
        z-index: 700;
        bottom: auto;
        left: auto;
        width: 100%;
        padding: 10px;
        height: auto;
        display: block;
        background-color: transparent;
        transform: none;
        border: none;
    }

    .info_data div.scroll {
        overflow: auto;
        height: auto;
        width: auto;
    }

    .info_data dl {
        display: block;
    }

    .info_data_dt {
        padding: 0;
        width: 100%;
    }

    .info_data_dd {
        width: 100%;
        padding: 0;
    }

    .info_mark {
        display: none;
    }
}

@media (min-width: 581px) {
    .footer {
        padding-bottom: 120px;
    }
}

.bar-top {
    display: block;
    position: absolute;
    width: 100%;
    height: 2px;
    background-color: #072e63;
    top: 0;
    left: 0;
    transform-origin: 0% 50%;
    transform: scaleX(0);
}

.bar-bottom {
    display: block;
    position: absolute;
    width: 100%;
    height: 2px;
    background-color: #072e63;
    bottom: 0;
    left: 0;
    transform-origin: 100% 50%;
    transform: scaleX(0);
}

.bar-left {
    display: block;
    position: absolute;
    width: 2px;
    height: 100%;
    background-color: #072e63;
    top: 0;
    left: 0;
    transform-origin: 50% 100%;
    transform: scaleY(0);
}

.bar-right {
    display: block;
    position: absolute;
    width: 2px;
    height: 100%;
    background-color: #072e63;
    top: 0;
    right: 0;
    transform-origin: 50% 0%;
    transform: scaleY(0);
}

.show .bar-top {
    transform: scaleX(1);
    transition: transform 0.1s ease-out 1.1s;
}

.show .bar-right {
    transform: scaleY(1);
    transition: transform 0.1s ease-out 1.2s;
}

.show .bar-bottom {
    transform: scaleX(1);
    transition: transform 0.1s ease-out 1.3s;
}

.show .bar-left {
    transform: scaleY(1);
    transition: transform 0.1s ease-out 1.4s;
}

.price_wrap {
    border-bottom: 1px solid #152f59;
}

.price {
    overflow: hidden;
    max-width: 1044px;
    margin: 0 auto;
    padding: 33px 0 26px 0;
}

.price p {
    margin: 0 0 24px;
}

.price li {
    float: left;
    width: 48%;
}

.price li:last-child {
    float: right;
}

.price li a:hover {
    opacity: 0.7;
}

.price li img {
    width: 100%;
    height: auto;
}

@media (max-width: 768px) {
    .price {
        overflow: hidden;
        width: auto;
        margin: 0 auto;
        padding: 15px 0 15px 0;
    }

    .price p {
        margin: 0 5% 15px;
    }

    .price li {
        float: none;
        margin: 0 5% 20px;
        width: auto;
        padding-bottom: 20px;
        border-bottom: 1px solid #072E63;
    }

    .price li:last-child {
        float: none;
        margin: 20px 5% 0;
        border-bottom: none;
    }
}

.plan {
    flex-direction: row;
    margin-bottom: 60px;
}

.plan .top-con_img::before {
    left: -10%;
    transform-origin: 0% 0%;
}

.plan .top-con_img_sp {
    justify-content: flex-end;
}

.plan .top-con_img_sp_inner::before {
    left: -20%;
    transform-origin: 0% 0%;
}

.plan .top-con_text {
    justify-content: flex-start;
}

.plan .top-con_head_p2 {
    font-size: 32px;
    line-height: 1.5em;
}

@media (max-width: 1024px) {
    .plan .top-con_head_p2 {
        font-size: calc(100vw / 1024 * 36);
    }
}

@media (max-width: 768px) {
    .plan .top-con_head_p2 {
        font-size: 30px;
        line-height: 1.5em;
    }
}

.reservation {
    width: 1024px;
    margin: 35px auto 60px;
    text-align: center;
    border: 1px solid #072E63;
    padding: 30px 100px 20px;
    position: relative;

}

.reservation .title {
    font-size: 36px;
    margin: 0 0 45px;
    line-height: 1.3;
    color: #B94047;
}

.reservation .title span {
    font-size: 28px;
    color: #000;
}

.reservation .note {
    font-size: 12px;
}

.gmap {
    display: flex;
    justify-content: center;
    margin-top: 35px;
    margin-bottom: 45px;
}

.gmap a {
    background: #072E63;
    width: 340px;
    height: 70px;
    color: #fff;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    text-decoration: none;
    font-size: 20px;
}

.reservation .btn {
    overflow: hidden;
    margin: 0 0 45px;
}

.reservation .btn li {
    font-size: 0;
    line-height: 0;
    float: left;
}

.reservation .btn li:last-child {
    float: right;
}

.reservation .sub {
    font-size: 24px;
    margin-bottom: 12px;
}

.reservation .sub span {
    font-size: 12px;
    display: block;
}

.reservation table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 10px;
    box-sizing: border-box;
}

.reservation table th,
.reservation table td {
    border: 1px solid #CCCCCC;
}

.reservation table th {
    background: #333;
    color: #fff;
    font-size: 16px;
    font-weight: normal;
    padding: 2px 0;
}

.reservation table.other th.day {
    /*width: 16.6%;
    width: 234px;*/
}

.reservation table th.time,
.reservation table.other th.time {
    width: 120px !important;
}

.reservation table th br {
    display: none;
}

.reservation table td {
    font-size: 20px;
    color: #666666;
    padding: 30px 0;
}

.reservation table .special td {
}

.reservation table td span {
    display: block;
    font-size: 12px;
    color: #B94047;
}

.reservation .triangle {
    font-size: 26px;
    font-weight: bold;
    color: #BCBB79;
}

.reservation .cross {
    font-size: 26px;
    font-weight: bold;
    color: #B94047;
}

.reservation .circle {
    font-size: 26px;
    font-weight: bold;
    color: #072E63;
}

.reservation .txt {
    overflow: hidden;
}

.reservation .txt li {
    float: right;
    font-size: 16px;
    vertical-align: middle;
    margin: 0 0 0 40px;
}

.reservation .txt li span. {
    vertical-align: middle;
}

.reservation .txt li .triangle,
.reservation .txt li .cross,
.reservation .txt li .circle {
    font-size: 23px;
}

.ribbon {
    text-align: center;
    background: #B94047;
    margin-bottom: 20px;
    padding: 10px;
}

.ribbon span {
    margin: 0;
    font-size: 18px;
    color: white;
}

.ribbon span span {
    font-size: 30px;
    font-weight: bold;
}

@media (max-width: 768px) {
    .reservation {
        width: auto;
        margin: 20px 1px 30px;
        padding: 15px;

    }

    .reservation .title {
        font-size: 18px;
        margin-bottom: 25px;
    }

    .reservation .title span {
        font-size: 14px;
    }

    .reservation .note {
        font-size: 12px;
    }

    .gmap {
        margin: 0 0 10px;
    }

    .gmap a {
        font-size: 16px;
        height: 64px;
    }

    .reservation .btn {
        margin: 0 0 20px;
    }

    .reservation .btn li {
        float: none;
        margin-bottom: 10px;
    }

    .reservation .btn li:last-child {
        float: none;
    }

    .reservation .btn li img {
        width: 100%;
        height: auto;
    }

    .reservation .sub {
        font-size: 16px;
        margin-bottom: 12px;
    }

    .reservation table th {
        font-size: 12px;
    }

    .reservation table th.time {
        width: 60px;
    }

    .reservation table th br {
        display: block;
    }

    .reservation table td {
        font-size: 12px;
        padding: 10px 0;
    }

    .reservation table td span {
        font-size: 10px;
        line-height: 1;
    }

    .reservation .triangle,
    .reservation .cross,
    .reservation .circle {
        font-size: 15px;
    }

    .reservation .txt {
        overflow: hidden;
    }

    .reservation .txt li {
        float: right;
        font-size: 12px;
        margin: 0 0 0 20px;
    }

    .reservation .txt li .triangle,
    .reservation .txt li .cross,
    .reservation .txt li .circle {
        font-size: 15px;
    }

    .ribbon {
    }

    .ribbon span {
        font-size: 12px;
    }

    .ribbon span span {
        font-size: 20px;
    }
}

.swiper-slide {
    position: relative;
}

.swiper-slide img {
}

.swiper-slide-active .introduction-card-content {
    display: none;
}

.swiper-slide-active img {
}

.swiper-button-next,
.swiper-button-prev {
    width: 51px;
    height: 51px;
    margin-top: -25px;
    background-size: 100%;
    background-image: url(../img/top/left.png);
}

.swiper-button-next {
    background-image: url(../img/top/right.png);
}

.media-image span {
    display: none;
}

.swiper-slide-active .media-image span {
    position: absolute;
    top: 526px;
    left: 0;
    display: inline-flex;
    width: 180px;
    height: 50px;
    justify-content: center;
    align-items: center;
    font-family: "Marcellus", serif;
    font-size: 18px;
    color: #072e63;
    border: 2px solid #072e63;
    background: #fff;
    transition: all 500ms 0s;
}

.swiper-slide-active .media-image span:hover {
    border: 2px solid #072e63;
    background: #072e63;
    color: #fff;
}

@media (max-width: 768px) {
    .swiper-button-next,
    .swiper-button-prev {
        width: 25px;
        height: 25px;
        margin-top: -13px;
    }

    .swiper-button-prev {
        left: -13px;
    }

    .swiper-button-next {
        right: auto;
        left: 70%;
    }

    .swiper-container-horizontal > .swiper-pagination-bullets,
    .swiper-pagination-custom,
    .swiper-pagination-fraction {
        bottom: 0;
    }
}

p.bnr {
    max-width: 1024px;
    margin: 0 auto 30px;
    position: relative;
}

p.bnr .new {
    position: absolute;
    top: 0;
    right: 0;
    background: #c01a20;
    color: #fff;
    padding: 0 10px;
    font-size: 14px;
    line-height: 1.5;
}

p.bnr .click {
    position: absolute;
    bottom: 5px;
    right: 0;
    text-align: right;
    font-size: 12px;
}

p.bnr_movie {
    position: fixed;
    top: 140px;
    right: 0;
    z-index: 1000;
}

#cboxLoadedContent {
    margin-bottom: 0;
}

@media (max-width: 768px) {
    .movie {
        padding: 20px 0;
        text-align: center;
    }

    .movie-wrap {
        position: relative;
        padding-bottom: 56.25%;
        height: 0;
        overflow: hidden;
    }

    .movie-wrap iframe {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
    }
}

.news_box {
    border-top: 1px solid #999;
    padding: 100px 0;
    margin: 0 auto;
    text-align: left;
    font-size: 1.1em;
    letter-spacing: 0;
    font-family: "YakuhanMin", "Yu Mincho", "YuMincho", "Noto Serif JP", serif;
}

.news_title_box {
    width: 90%;
    max-width: 640px;
    margin: 0 auto;
}

.news_title {
    padding-bottom: 20px;
    text-align: left;
    color: #8b6d28;
    font-size: 25px;
    font-family: 'ＭＳ Ｐ明朝', 'MS PMincho', 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', 'serif'
}

.news_content {
    display: flex;
    width: 90%;
    max-width: 640px;
    margin: 0 auto;
    text-align: left;
}

.news_day {
    width: 30%;
    padding: 20px 20px;
    border-left: 1px #8b6d28 solid;
}

.news_info {
    width: 70%;
    padding: 20px 0;
}

.news_info a {
    text-decoration: underline;
}

@media (max-width: 580px) {
    .news_box {
        font-size: 0.9em !important;
        padding: 50px 0;
    }

    .news_day {
        width: 30%;
        padding: 10px 20px;
        border-left: 1px #8b6d28 solid;
    }

    .news_info {
        width: 70%;
        padding: 10px;
    }
}

.note_box_2 {
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
}

.footer_bnul {
    width: 100%;
    margin: 0 auto;
    padding: 30px;
    display: flex;
}

@media (max-width: 580px) {
    .footer_bnul {
        width: 100%;
        margin: 0 auto;
        padding: 40px 20px;
        display: flex;
        flex-wrap: wrap;
        text-align: center;
    }

    .footer_bnul li {
        margin: 0 auto;
    }
}

.footer_bn_div {
    max-width: 1200px;
    width: 100%;
    position: relative;
    margin: 0 auto;
}

.ref {
    overflow: hidden;
}

.ref::after {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background-image: linear-gradient(-60deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, 0.6) 40%, rgba(255, 255, 255, 0.6) 60%, rgba(255, 255, 255, 0) 90%, rgba(255, 255, 255, 0) 100%);
    animation: kiran 4s infinite;
}

@keyframes kiran {
    0% {
        transform: translateX(-100%);
    }
    20% {
        transform: translateX(100%);
    }
    100% {
        transform: translateX(100%);
    }
}

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

@media (max-width: 580px) {
    .sp_nav {
        width: 100%;
        position: fixed;
        bottom: 0;
    }

    .sp_nav ul {
        width: 100%;
        height: 80px;
        background: #000;
        padding: 10px 0;
        display: flex;
        text-align: center;
    }

    .sp_nav ul li {
        width: 20%;
        height: 60px;
        background: #a69040;
        border-right: 1px solid #8f6f00;
    }

    .sp_nav ul li p {
        font-size: 12px;
        line-height: 18px;
        font-weight: bold;
        font-family: " a-otf-futo-min-a101-pr6n,", "YakuhanMin", "Yu Mincho", "YuMincho", "Noto Serif JP", serif;
        padding-top: 10px;
    }

    .sp_nav ul li span {
        font-size: 10px;
    }
}

/*#section {*/
    /*padding: 10px;*/
/*}*/

/*.content {*/
    /*width: 100%;*/
    /*margin: 150px auto;*/
    /*padding: 0px;*/
/*}*/

@media (max-width: 580px) {
    /*.content {*/
        /*width: 100%;*/
        /*margin: 60px auto 20px;*/
        /*padding: 10px;*/
    /*}*/
}

.content_inner {
    width: 100%;
    padding: 0px;
    margin: 0 auto;
    position: relative;
}

.content_inner1000 {
    width: 100%;
    max-width: 1000px;
    padding: 0px;
    margin: 0 auto;
    position: relative;
}

.content_inner860 {
    width: 100%;
    max-width: 860px;
    padding: 10px;
    margin: 0 auto;
    position: relative;
}

.content_title {
    font-size: 1.8em;
    margin: 10px auto 40px;
}

.content_copy {
    font-size: 1.4em;
    margin: 10px auto 20px;
}

.content_text {
    font-size: 1em;
    margin: 10px auto 20px;
}

.content_title_left {
    font-size: 1.8em;
    margin: 30px auto;
    text-align: left;
    padding-left: 20px;
}

.content_copy_left {
    font-size: 1.4em;
    margin: 20px auto;
    text-align: left;
    padding-left: 20px;
}

.content_text_left {
    font-size: 1em;
    margin: 30px auto;
    text-align: left;
    padding-left: 20px;
}

.content_title_right {
    font-size: 1.8em;
    margin: 30px auto;
    text-align: right;
    padding-right: 20px;
}

.content_copy_right {
    font-size: 1.4em;
    margin: 20px auto;
    text-align: right;
    padding-right: 20px;
}

.content_text_right {
    font-size: 1em;
    margin: 30px auto;
    padding: 0 20px;
    text-align: right;
}

@media (max-width: 584px) {
    .content_title_left {
        font-size: 1.8em;
        margin: 30px auto;
        padding: 0 20px;
        text-align: left;
    }

    .content_copy_left {
        font-size: 1.4em;
        margin: 20px auto;
        padding: 0 20px;
        text-align: left;
    }

    .content_text_left {
        font-size: 1em;
        margin: 30px auto;
        padding: 0 20px;
        text-align: left;
    }

    .content_title_right {
        font-size: 1.8em;
        margin: 30px auto;
        padding: 0 20px;
        text-align: left;
    }

    .content_copy_right {
        font-size: 1.4em;
        margin: 20px auto;
        padding: 0 20px;
        text-align: left;
    }

    .content_text_right {
        font-size: 1em;
        margin: 30px auto;
        padding: 0 20px;
        text-align: left;
    }

    .content_title_big {
        font-size: 3.2em;
        margin: 30px auto;
        padding: 0 20px;
        text-align: left;
    }

    .content_title_big_center {
        font-size: 3.2em;
        line-height: 1.2em;
        margin: 30px auto;
        padding: 0 20px;
        text-align: center;
    }
}

.content_title_line {
    padding: 15px 0;
    width: 180px;
    margin: 50px auto 0;
    border-bottom: 1px solid #fff;
    border-top: 1px solid #fff;
}

.content_title_line span {
    font-size: 1.8em;
    margin: 0px auto;
}

.content_title_big {
    font-size: 3.2em;
    margin: 30px auto;
    text-align: left;
    padding-left: 20px;
}

.content_title_big_center {
    font-size: 3.2em;
    margin: 30px auto;
    text-align: center;
    padding-left: 20px;
}

.cap_right {
    position: absolute;
    right: 5px;
    bottom: 10px;
    font-size: 12px;
    line-height: 1.4em;
    color: #fff;
    text-shadow: 0 0 2px #000, 0 0 2px #000;
}

.cap_left {
    position: absolute;
    left: 5px;
    bottom: 10px;
    font-size: 12px;
    line-height: 1.4em;
    color: #fff;
    text-shadow: 0 0 2px #000, 0 0 2px #000;
}

.image_wrap {
    width: auto;
    display: flex;
}

@media (max-width: 1250px) {
    .image_wrap {
        width: auto;
        display: flex;
    }
}

@media (max-width: 584px) {
    .image_wrap {
        width: auto;
        display: block;
    }
}

.image_box {
    width: 100%;
    padding: 5px;
    position: relative;
}

.image_img {
    position: relative;
    margin-top: 10px;
}

.image_text {
    text-align: center;
    width: 100%;
    max-width: 1000px;
    padding: 0;
    margin: 5px auto 10px;
    left: 0;
    right: 0;
    font-size: 14px;
    line-height: 1.6em;
    color: #fff;
}

.image_text_right {
    text-align: right;
    width: 100%;
    max-width: 1000px;
    padding: 0 20px;
    margin: 10px auto;
    left: 0;
    right: 0;
    font-size: 14px;
    line-height: 1.6em;
    color: #fff;
}

.room_wrap {
    width: auto;
    display: flex;
}

@media (max-width: 584px) {
    .room_wrap {
        width: auto;
        display: block;
    }
}

.room_box {
    width: 100%;
    padding: 40px 20px;
    position: relative;
}

.room_img {
    position: relative;
}

.room_title p {
    width: 100%;
    margin: 0 auto 20px;
    text-align: center;
    padding: 5px 15px;
    background: #b78059;
    text-align: center;
}

.room_img img {
    width: 100%;
    max-width: 270px;
    margin: 0 auto;
}

.room_text {
    text-align: center;
    width: 90%;
    max-width: 1044px;
    padding: 0;
    margin: 10px auto 0;
    left: 0;
    right: 0;
    font-size: 18px;
    line-height: 1.4em;
    color: #fff;
    display: inline-block;
}

.room_text dl {
    border-bottom: 1px solid #b18059;
}

.room_text dl dt {
    display: inline-block;
    text-align: left;
    float: left;
}

.room_text dl dd {
    display: inline-block;
    text-align: right;
    float: right;
}

.room_text_right {
    text-align: right;
    width: 100%;
    max-width: 1044px;
    padding: 0 20px;
    margin: 10px auto;
    left: 0;
    right: 0;
    font-size: 14px;
    line-height: 1.6em;
    color: #fff;
}

.header_wrap {
    position: fixed;
    z-index: 5000;
    width: 100%;
    height: 90px;
    /*background: rgba(0,0,0,0.6);*/
}

.gmenu {
    position: relative;
    text-align: center;
    width: 100%;
    z-index: 70;
    font-size: 0;
    margin: 0px auto 5px;
    padding: 5px 0;
    background: rgba(0, 0, 0, 0.6);
}

.gmenu li {
    display: inline-block;
    box-sizing: border-box;
    position: relative;
    width: auto;
    padding: 0 1.5% 5px;
    border-left: 1px solid #ccc;
}

.gmenu li:last-child {
    border-right: 1px solid #999;
}

.gmenu li::after {
    width: 0;
    height: 2px;
    content: "";
    background-color: #b78059;
    position: absolute;
    left: 50%;
    bottom: 0;
    -webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    -webkit-transition: 0.3s;
    -moz-transition: 0.3s;
    -o-transition: 0.3s;
    transition: 0.3s;
}

.gmenu li a p {
    font-size: 9px;
    color: #fff;
    text-align: center;
    line-height: 2em;
}

.gmenu li a p span {
    font-size: 13px;
    color: #fff;
    display: block;
    font-weight: bold;
}

.gmenu li.active::after,
.gmenu li:hover::after {
    width: 50px;
}

@media (max-width: 1250px) {
    .gmenu {
        display: none;
    }
}

.content_big_wrap {
    position: relative;
    margin-bottom: 300px;
    display: block;
}

.content_big_wrap::after {
    clear: both;
}

.content_big_img {
    width: 55%;
}

.content_big_text {
    width: 50%;
    position: absolute;
    background: #000;
    padding: 30px 60px;
}

@media (max-width: 584px) {
    .content_big_wrap {
        position: relative;
        margin-bottom: 40px;
    }

    .content_big_img {
        width: 100%;
    }

    .content_big_text {
        width: 100%;
        position: static;
        background: #000;
        padding: 20px 20px;
    }

    .content .content_big_wrap:nth-child(odd) div:first-child {
        float: none;
    }

    .content .content_big_wrap:nth-child(even) div:first-child {
        float: none;
    }

    .content .content_big_wrap:nth-child(odd) div:last-child {
        left: 0;
        top: 0;
    }

    .content .content_big_wrap:nth-child(even) div:last-child {
        right: 0;
        top: 0;
    }
}

.big_text_inner {
    width: 100%;
    max-width: 1000px;
}

.big_text_inner .content_title_left {
    border-bottom: 1px #b78059 solid;
}

.content .content_big_wrap:nth-child(odd) div:first-child {
    float: left;
}

.content .content_big_wrap:nth-child(even) div:first-child {
    float: right;
}

.content .content_big_wrap:nth-child(odd) div:last-child {
    left: 50%;
    top: 30%;
}

.content .content_big_wrap:nth-child(even) div:last-child {
    right: 50%;
    top: 30%;
}

.inq_btn {
    width: 100%;
    max-width: 400px;
    margin: 20px auto;
    text-align: center;
    padding: 5px 15px;
    background: #b78059;
    text-align: center;
}

.inq_btn::after {
    content: "‣";
}

/*-----------------------------------------------------------*/
.sp_noflex

@media (max-width: 580px) {
    .sp_noflex {
        display: block !important;
    }
}

.tabs {
    margin-top: 50px;
    padding-bottom: 20px;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
    width: 94%;
    max-width: 1000px;
    margin: 0 auto 0px;
    border: 1px #b78059 solid;
}

/*タブのスタイル*/
.tab_item01, .tab_item02, .tab_item03, .tab_item04 {
    width: calc(100% / 3);
    height: 60px;
    display: block;
    float: left;
    transition: all 0.2s ease;
    position: relative;
}

.tab_item01 p, .tab_item02 p, .tab_item03 p, .tab_item04 p {
    line-height: 24px;
    font-size: 16px;
    text-align: center;
    color: #fff;
    font-weight: bold;
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    margin: auto;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

@media (max-width: 584px) {
    .tab_item01, .tab_item02, .tab_item03, .tab_item04 {
        height: 40px;
        line-height: 14px;
        font-size: 12px;
        position: relative;
        padding-top: 5px;
    }

    .tab_item01 p, .tab_item02 p, .tab_item03 p, .tab_item04 p {
        line-height: 14px;
        font-size: 12px;
    }
}

/*.tab_item:hover {
  opacity: 0.75;
}*/
.tab_item01 {
    border-bottom: 3px solid #b78059;
    border: 1px #b78059 solid;
}

.tab_item02 {
    border-bottom: 3px solid #b78059;
    border: 1px #b78059 solid;
}

.tab_item03 {
    border-bottom: 3px solid #b78059;
    border: 1px #b78059 solid;
}

.tab_item04 {
    border-bottom: 3px solid #b78059;
    border: 1px #b78059 solid;
}

.tab_item01:hover {
    border-bottom: 3px solid #b78059;
    background-color: #b78059;
}

.tab_item02:hover {
    border-bottom: 3px solid #b78059;
    background-color: #b78059;
}

.tab_item03:hover {
    border-bottom: 3px solid #b78059;
    background-color: #b78059;
}

.tab_item04:hover {
    border-bottom: 3px solid #b78059;
    background-color: #b78059;
}

/*ラジオボタンを全て消す*/
input[name="tab_item"] {
    display: none;
}

/*タブ切り替えの中身のスタイル*/
.tab_content {
    display: none;
    padding: 20px 20px 0;
    clear: both;
    overflow: hidden;
}

/*選択されているタブのコンテンツのみを表示*/
#tab_item01:checked ~ #tab_item01_content,
#tab_item02:checked ~ #tab_item02_content,
#tab_item03:checked ~ #tab_item03_content,
#tab_item04:checked ~ #tab_item04_content,
#tab_item05:checked ~ #tab_item05_content {
    display: block;
    transition: all 0.5s;
}

/*選択されているタブのスタイルを変える*/
.tabs input:checked + .tab_item01 {
    background-color: #b78059;
    color: #fff;
}

.tabs input:checked + .tab_item02 {
    background-color: #b78059;
    color: #fff;
}

.tabs input:checked + .tab_item03 {
    background-color: #b78059;
    color: #fff;
}

.tabs input:checked + .tab_item04 {
    background-color: #b78059;
    color: #fff;
}

.tabs input:checked + .tab_item05 {
    background-color: #b78059;
    color: #fff;
}

.tab_content_description {
    display: flex;
}

.lifeinfo_img {
    width: 100%;
    padding: 20px;
}

.lifeinfo_img img {
    width: 100%;
}

.lifeinfo_text {
    width: 35%;
    position: relative;
}

.lifeinfo_text img {
    width: 100%;
}

@media (max-width: 584px) {
    .tab_content_description {
        display: block;
    }

    .lifeinfo_img {
        width: 100%;
    }

    .lifeinfo_img img {
        width: 100%;
    }

    .lifeinfo_text {
        width: 100%;
    }

    .lifeinfo_text img {
        width: 100%;
        padding: 10px 0 0;
    }
}

.service_copy_left {
    font-size: 1.4em;
    padding-bottom: 10px;
    margin: 10px auto 20px;
    text-align: left;
    border-bottom: 1px solid #b78059;
}

.service_copy_small {
    font-size: 1em;
    padding-bottom: 5px;
    margin: 10px auto 20px;
    text-align: left;
    border-bottom: 1px solid #b78059;
}

.service_text {
    font-size: 0.8em;
    padding-bottom: 5px;
    margin: 10px auto 20px;
    text-align: left;
}

.service_item {
    width: 100%;
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
}

.item_list {
    width: 64px;
    font-size: 10px;
    line-height: 1em;
    margin: 5px;
    float: left;
}

.item_list p {
    font-size: 9px;
    line-height: 1.1em;
    margin: 3px auto;
}

@media (max-width: 584px) {
    .service_copy_small {
        font-size: 1.4em;
        padding-bottom: 5px;
        margin: 10px auto 20px;
        text-align: left;
        border-bottom: 1px solid #b78059;
    }

    .service_text {
        font-size: 1.2em;
        padding-bottom: 5px;
        margin: 10px auto 20px;
        text-align: left;
    }
}

/*a #rooms,*/
a #facility, a #restaurant, a #onsen, a #meeting, a #bus, /*a #shopping,*/
a #access {
    margin-top: 120px;
}

@media (max-width: 584px) {
    a #rooms, a #facility, a #restaurant, a #onsen, a #meeting, a #bus, a #shopping, a #access {
        margin-top: 0;
    }
}

.link_btn {
    width: 20%;
    max-width: 131px;
    position: absolute;
    top: 80px;
    right: 30px;
}

@media (max-width: 584px) {
    .link_btn {
        width: 20%;
        max-width: 131px;
        position: absolute;
        top: 10px;
        right: 10px;
    }
}

#info {
    width: 100%;
    margin: 0 auto;
    display: flex;
    border-bottom: 1px solid #979797;
    background: #fff;
}

.info_title {
    display: inline-block;
    width: 20%;
    max-width: 300px;
    vertical-align: top;
    height: 100%;
    line-height: 50px;
    background-color: #000;
    color: #fff;
    font-size: 22px;
}

.infodata {
    width: 80%;
    vertical-align: top;
    height: 100%;
    line-height: 50px;
}

.info_item {
    display: flex;
    background: #fff;
}

.info_date {
    width: 20%;
    text-align: center;
    display: block;
    color: #000;
    padding: 0 20px;
    background-color: #fff;
}

.info_text {
    width: 80%;
    text-align: left;
    padding: 0 20px;
    display: block;
    color: #000;
    background-color: #fff;
}

@media (max-width: 580px) {
    #info {
        width: 100%;
        margin: 0 auto;
        display: block;
        border-bottom: 1px solid #979797;
    }

    .info_title {
        display: block;
        width: 100%;
        max-width: none;
        vertical-align: top;
        height: 100%;
        line-height: 50px;
        background-color: #000;
        color: #fff;
        font-size: 22px;
    }

    .infodata {
        width: 100%;
        vertical-align: top;
        height: 100%;
        line-height: 24px;
        padding: 10px 10px;
    }

    .info_date {
        width: 25%;
        padding: 0px 0px;
    }

    .info_text {
        width: 75%;
    }
}

.box_btn_img {
    position: relative;
    width: 100%;
    padding: 10px;
    cursor: pointer;
}

.box_btn_text {
    position: absolute;
    width: 100%;
    top: 40%;
    left: 50%;
    text-align: center;
    font-size: 18px;
    line-height: 1.5em;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}

.box_left {
    width: 55%;
}

.box_left img {
    height: 100%;
}

.box_right {
    width: 45%;
    padding: 40px 4%;
}

@media (max-width: 580px) {
    .box_left {
        width: 100%;
    }

    .box_right {
        width: 100%;
        padding: 10px 4%;
    }
}

.box_title {
    color: #b78059;
    font-size: 16px;
    margin: 30px auto;
    text-align: center;
}

.box_copy {
    color: #000;
    font-size: 20px;
    line-height: 1.6em;
    text-align: center;
}

.box_text {
    color: #000;
    font-size: 16px;
    margin: 30px auto;
    line-height: 1.6em;
    text-align: left;
}

.popUp1, .popUp2, .popUp3, .popUp4, .popUp5, .popUp6,
input[name="switch"],
#open1 + label ~ label, #open2 + label ~ label, #open3 + label ~ label, #open4 + label ~ label, #open5 + label ~ label, #open6 + label ~ label {
    display: none;
}

#open1 + label, #open2 + label,

,
#open3 + label,

,
#open4 + label,

,
#open5 + label,

,
#open6 + label,
#close-button1 + label, #close-button2 + label, #close-button3 + label, #close-button4 + label, #close-button5 + label, #close-button6 + label {
    cursor: pointer;
}

.popUp1, .popUp2, .popUp3, .popUp4, .popUp5, .popUp6 {
    animation: fadeIn 1s ease 0s 1 normal;
    -webkit-animation: fadeIn 1s ease 0s 1 normal;
}

#open1:checked ~ #close-button1 + label, #open2:checked ~ #close-button2 + label, #open3:checked ~ #close-button3 + label,
#open4:checked ~ #close-button4 + label, #open5:checked ~ #close-button5 + label, #open6:checked ~ #close-button6 + label {
    animation: fadeIn 2s ease 0s 1 normal;
    -webkit-animation: fadeIn 2s ease 0s 1 normal;
}

@keyframes fadeIn {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}

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

#open1:checked + label ~ .popUp1, #open2:checked + label ~ .popUp2, #open3:checked + label ~ .popUp3,
#open4:checked + label ~ .popUp4, #open5:checked + label ~ .popUp5, #open6:checked + label ~ .popUp6 {
    background: #fff;
    display: block;
    width: 80%;
    height: 80%;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    z-index: 9998;
}

#open1:checked + label ~ .popUp1 > .popUp-content1, #open2:checked + label ~ .popUp2 > .popUp-content2, #open3:checked + label ~ .popUp3 > .popUp-content3,
#open4:checked + label ~ .popUp4 > .popUp-content4, #open5:checked + label ~ .popUp5 > .popUp-content5, #open6:checked + label ~ .popUp6 > .popUp-content6 {
    width: calc(100% - 0px);
    height: calc(100% - 0px);
    padding: 20px 20px;
    overflow-y: auto;
    display: flex;
    -webkit-overflow-scrolling: touch;
}

@media (max-width: 580px) {
    #open1:checked + label ~ .popUp1 > .popUp-content1, #open2:checked + label ~ .popUp2 > .popUp-content2, #open3:checked + label ~ .popUp3 > .popUp-content3,
    #open4:checked + label ~ .popUp4 > .popUp-content4, #open5:checked + label ~ .popUp5 > .popUp-content5, #open6:checked + label ~ .popUp6 > .popUp-content6 {
        width: calc(100% - 0px);
        height: calc(100% - 0px);
        padding: 20px 20px;
        overflow-y: auto;
        display: block;
        -webkit-overflow-scrolling: touch;
    }
}

#open1:checked + label + #close-overlay + label, #open2:checked + label + #close-overlay + label, #open3:checked + label + #close-overlay + label,
#open4:checked + label + #close-overlay + label, #open5:checked + label + #close-overlay + label, #open6:checked + label + #close-overlay + label {

    background: rgba(0, 0, 0, 0.70);
    display: block;
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 0;
    overflow: hidden;
    white-space: nowrap;
    text-indent: 100%;
    z-index: 9997;
}

#open1:checked ~ #close-button1 + label, #open2:checked ~ #close-button2 + label, #open3:checked ~ #close-button3 + label,
#open4:checked ~ #close-button4 + label, #open5:checked ~ #close-button5 + label, #open6:checked ~ #close-button6 + label {
    display: block;
    background: #000;
    text-align: center;
    font-size: 25px;
    line-height: 40px;
    width: 40px;
    height: 40px;
    position: fixed;
    top: 10%;
    right: 10%;
    z-index: 9999;
}

#open1:checked ~ #close-button1 + label::before, #open2:checked ~ #close-button2 + label::before, #open3:checked ~ #close-button3 + label::before,
#open4:checked ~ #close-button4 + label::before, #open5:checked ~ #close-button5 + label::before, #open6:checked ~ #close-button6 + label::before {
    content: '×';
}

/*@media (min-width: 768px) {
  #open:checked + label ~ .popUp {
    width: 600px;
    height: 600px;
  }
  #open:checked + label ~ .popUp > .popUp-content {
    height: calc(100% - 20px);
  }
  #open:checked ~ #close-button + label {
    width: 44px;
    height: 44px;
    left: 50%;
    top: 50%;
    margin-left: 240px;
    margin-top: -285px;
    overflow: hidden;
  }
  #open:checked ~ #close-button + label::after {
    display: none;
  }
}*/
#room .caption0  {
    width: 100%;
    max-width: 100%!important;
    background-color: #000;
}
#room .caption0  .secin {
    padding: 10px;
    color: #fff;
}
@media (max-width: 580px) {
    .caption0 .caption {
        box-sizing: border-box;
        padding: 10px;
        color: #fff;
    }
}






