@charset "utf-8";

body {
    background: #edf1f5;
}

article {
    color: #18295c;
}


#activity {
    color: #18295c;
    overflow: hidden;
    padding-bottom: 0;
}

article {
    background-size: 100%;
    position: relative;
}

#rental .item-tmb img {
    border-radius: 14px;
    margin-bottom: 80px;
    width: 100%;
}

#reserve {
    background: #fffefd;
}

#reserve .inner-mid {
    max-width: 1200px;
    width: 70%;
    margin: auto;
}

.info-table tbody th,
.info-table tbody td {
    line-height: 1.6;
    padding: 18px 15px 16px;
    font-weight: 500;
    border-top: #3d4b73 solid 1px;
}

.sec-title-en {}

#map {
    position: relative;
}

.map-img {
    position: relative;

}

.map-click-linkwrap {
    position: absolute;
    top: 60%;
    left: 10%;
    background: #00c5c7;
    padding: 30px 40px 25px;
    font-size: 14px;
    color: #fff;
    border-radius: 8px;
    transition: .4s;
    z-index: 4;
    opacity: 0;
    pointer-events: none;
}

.selected .map-click-linkwrap {
    transition: .4s;
    opacity: 1;
    pointer-events: auto;
}

.map-close {
    position: absolute;
    width: 100%;
    height: 100%;
    display: none;
    z-index: 3;
}

.selected .map-close {
    display: block;
}

.map-click-linkwrap a {
    color: #fff;
}

.map-click-linkwrap a:hover {
    text-decoration: underline;
}

.map-click {
    position: absolute;
    z-index: 2;
}

.map-click a {
    display: block;
    background: #816fc3;
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    padding: 7px 16px 4px;
    border-radius: 40px;
    z-index: 2;
    line-height: 1.3;
    transition: .4s;
}

.map-click a:hover {
    background: #3b287e;
    color: #fff;
    transition: .4s;
}



.spot11 {
    left: 12%;
    top: 75%;
}

.spot10 {
    left: 22%;
    top: 53%;
}
.spot09 {
    left: 18%;
    top: 37%;
}

.spot08 {
    left: 71%;
    top: 35%;
}
.spot07 {
    left: 57%;
    top: 43%;
}

.spot06 {
    left: 71%;
    top: 48%;
}

.spot05 {
   left: 45%;
   top: 40%;
}

.spot04 {
    left: 54%;
    top: 30%;
}

.spot03 {
    left: 61%;
    top: 52%;
}

.spot02 {
    left: 57%;
    top: 19%;
}

.spot01 {
    top: 18%;
    left: 80%;
}

.spot12 {
    top: 27%;
    left: 51%;
}

.spot15 {
    top: 41%;
    left: 63%;
}

.spot17 {
    left: 45%;
    top: 52%;
}

.spot18 {}

.spot19 {
    left: 53%;
    top: 41%;
}

.spot20 {
    left: 30%;
    top: 41%
}

.spot21 {
   left: 42%;
    top: 15%
}



.other-facilities {
    padding-top: 80px;
}

.anchor {
    padding-top: 24px;
    text-align: center;
    font-size: 16px;
}

.anchor li {
    display: inline-block;
    vertical-align: top;
    letter-spacing: 0.06em;
}

.anchor li:after {
    content: "/";
    color: #838383;
    font-size: 13px;
    margin-left: 10px;
    margin-right: 10px;
}

.anchor li:last-child:after {
    display: none;
}

/*アコーディオン全体*/
.accordion-area {
    list-style: none;
    width: 100%;
    margin: 0 auto;
}

.accordion-area li {
    margin: 0 0 18px 0;
}

.accordion-area section {}


.title {
    position: relative;
    cursor: pointer;
    padding: 25px;
    transition: all .5s ease;
    background: #fff;
    font-size: 19px;
    font-weight: 600;
    line-height: 1em;
    border-radius: 6px;
    box-shadow: rgba(0, 0, 0, 0.04) 0px 3px 5px;
}


.title::before,
.title::after {
    position: absolute;
    content: '';
    width: 22px;
    height: 2px;
    background-color: #303030;

}

.title::before {
    top: 48%;
    right: 25px;
    transform: rotate(0deg);

}

.title::after {
    top: 48%;
    right: 25px;
    transform: rotate(90deg);

}

/*　closeというクラスがついたら形状変化　*/
.title.close::before {
    transform: rotate(45deg);
}

.title.close::after {
    transform: rotate(-45deg);
}

.item.-col2 .item-title-line {
    background: #18295c;
}

.box {
    display: none;
    background: #fbfbfb;
    padding: 4%;
}

.items.panel .item .item-summary {
    padding: 1.8em 1.5em 1.5em;
    min-height: 120px;
}

.c-thin {
    color: #18295c;
}

.c-thin a:link,
.c-thin a:visited {
    color: #18295c;
}

.breadcrumb a:link,
.breadcrumb a:visited {
    color: #18295c;
}

.map-img-inner {
    width: 100%;
    margin: 60px auto 120px;
}

.map-img-inner img {
    border-radius: 10px;
}

dl.data {
    margin-top: 36px;
}

dl.data.btmborder {
    border-bottom: #c0c6da solid 1px;
}

dl.data dt {
    width: 5em;
    float: left;
    font-size: 15px;
    border-top: #c0c6da solid 1px;
    padding: 10px;
}

dl.data dd {
    font-size: 15px;
    border-top: #c0c6da solid 1px;
    padding: 10px 10px 10px 6em;
}

.txt-link {
    padding-top: 15px;
    padding: 15px 10px;
    text-decoration: underline;
    color: #18295c;
    font-size: 15px;
    font-weight: 600;
}

.txt-link a {
    color: #18295c;
}


.col3 .item {
    width: calc(33.333% - 30px);
    margin-bottom: 60px;
    position: relative;
}

.col3 .item .item-tmb img {
    border-radius: 6px;
    margin-bottom: 24px;
}

.col3 .item .item-title {
    font-size: 18px;
    text-align: center;
    padding-bottom: 0.8em;
}

.col3 .item p {
    font-size: 15px;
    line-height: 1.8;
    padding: 0 1em;
}

.col3 dl.data {
    margin-top: 18px;
}

.col3 dl.data dt {
    width: 3em;
    float: left;
    font-size: 13px;
    border-top: #414d70 solid 1px;
    padding: 10px;
    line-height: 1.8;
}

.col3 .item dl.data dd {
    font-size: 13px;
    border-top: #414d70 solid 1px;
    padding: 10px 10px 10px 4em;
    line-height: 1.8;
}

.flex {
    justify-content: space-between;
}

.item.-col2 .item-summary .item-summary-inner.em2 {
    padding: 1.2em 4.5em;
}

#about.l-sec {
    padding: 6em 0;
    background: #18295c;
    color: #f8f8f8;
}

#about .sec-title-wrap {
    padding-bottom: 2em;
}

.powerup {
    position: absolute;
    top: 5%;
    background: #f14173;
    color: #fff;
    font-size: 13px;
    font-weight: 600;
    padding: 3px 16px;
    left: -5%;
}

.new {
    position: absolute;
    top: 5%;
    background: #3bacc2;
    color: #fff;
    font-size: 13px;
    font-weight: 600;
    padding: 3px 16px;
    left: -5%;
}

.hotel-pic {
    width: 40%;
}

.hotel-txt {
    width: 55%;
}

.hotel-name {
    font-size: 20px;
    padding: 20px 0 10px;
    font-weight: 600;
}

.hotel p {
    font-size: 14px;
    line-height: 1.8;
    margin-bottom: 1em;
}

.accomo-btn a {
    display: block;
    background: #ffa938;
    width: 12em;
    text-align: center;
    font-size: 16px;
    font-weight: 600;
    padding: 8px 0;
    color: #fff;
    transition: .4s;
    border-radius: 4px;
}

.accomo-btn a:hover {
    color: #fff;
    background: #18295c;
    transition: .4s;
}

.hotel {
    margin-bottom: 36px;
}

.bestrate-box {
    text-align: center;
    margin: 80px 0;
}

.best-ttl {
    font-size: 22px;
    padding: 14px 0 0;
    font-weight: 900;
}

.hotels {
    padding-bottom: 80px;
}

.sec-title-en {
    text-align: center;
}

#head #accordion dt {
    color: #fff;
    font-size: 16px;
    cursor: pointer;
    border-bottom: 1px solid #ffffff;
    padding-left: 7px;
    padding-right: 7px;
    letter-spacing: .02em;
}

.page-leadcopy {
    font-size: 2.1em;
    letter-spacing: 0.2em;
    font-weight: 500;
}

.sec-title-en {
    font-size: 2.2em;
    font-weight: 500;
}

.items.panel .item {
    background: none;
    border-radius: 0px;
}

.items.panel .item .item-tmb img {
    border-radius: 0px;
}

.items.-col4 .item .item-title {
    font-size: 15px;
    margin-bottom: 0.8em;
    font-weight: 500;
    line-height: 1.5em;
    text-align: center;
    display: inline-block;
    margin: 0 auto;
    padding: 2px 10px;
    border-radius: 4px;
}

.info-table table {
    width: 100%;
    margin: 32px 0;
    border-bottom: #3d4b73 solid 1px;
}

.items.panel .item .item-summary {
    padding: 8px;
    min-height: auto;
    position: absolute;
    z-index: 2;
    bottom: 0;
    left: 0;
    right: 0;
    color: #081028;
    text-align: center;
}

.item.-col2 .item-summary .item-summary-inner {
    padding: 1.2em 4.5em;
}

.swiperroop .swiper-wrapper {
    transition-timing-function: linear;
}

#other .item-tmb:hover {
    opacity: 0.5;
}

.item.-col2 {
    margin-bottom: 8em;
}

.modaal-overlay {
    background-color: #343f62 !important;
    opacity: 0.9 !important;
}

.snow01 {
    position: absolute;
    top: 0;
    left: 0;
    width: 30%;
    opacity: 0.3;
}

.snow02 {
    position: absolute;
    bottom: -25%;
    right: -20%;
    width: 40%;
    opacity: 0.6;
    z-index: -1;
}

.snow03 {
    position: absolute;
    bottom: -25%;
    right: -20%;
    width: 40%;
    opacity: 0.6;
    z-index: -1;
}

.items.-col3 .item {
    width: calc(33.3333% - 24px);
    margin-bottom: 48px;
}

.items.-col3 .item .item-tmb img {
    border-radius: 3px;
}

#other {
    padding-bottom: 100px;
}

.ico-snow {
    width: 88px;
    margin: 0 auto 20px;
}

.sec-title {
    text-align: center;
    padding-top: 2px;
    font-size: 15px;
}

.item {
    margin-top: -100px;
    padding-top: 100px;
}

@media screen and (max-width:1600px) {
    body {
        font-size: 16px;
    }
}

@media screen and (max-width:1200px) {
    body {
        font-size: 16px;
    }

    .map-img-inner {
        width: 100%;
    }
}

@media screen and (max-width:1000px) {
    #rental .items.-col2 .item {
        width: 100%;
    }

    .anchor li:after {
        content: "/";
        color: #838383;
        font-size: 12px;
        margin-left: 8px;
        margin-right: 8px;
    }

    .anchor li {
        font-size: 13px;
    }

    .title {
        font-size: 15px;
    }

    .title::before,
    .title::after {
        position: absolute;
        content: '';
        width: 18px;
        height: 2px;
        background-color: #303030;
    }

    .page-leadcopy {
        padding-bottom: 40px;
    }

    .title {
        padding: 20px;
    }

    .title::after {
        top: 48%;
        right: 15px;
        transform: rotate(90deg);
    }

    .title::before {
        top: 48%;
        right: 15px;
        transform: rotate(0deg);
    }

    .title {
        border-radius: 3px;
    }

    .accordion-area li {
        margin: 0 0 10px 0;
    }

    .col3 .item {
        width: calc(50% - 20px);
        margin-bottom: 60px;
        position: relative;
    }



}

@media screen and (max-width:650px) {

    .page-leadcopy {
        padding-bottom: 0;
    }

    .item.-col2 .item-summary .item-summary-inner.em2 {
        padding: 2em 2em;
    }

    dl.data {
        margin-top: 24px;
    }

    .col3 .item .item-title {
        font-size: 16px;
        text-align: center;
        padding-bottom: 0.5em;
    }

    .col3 .item p {
        font-size: 12px;
        line-height: 1.7;
        padding: 0;
    }

    .col3 dl.data dt {
        width: 3em;
        float: left;
        font-size: 12px;
        border-top: #414d70 solid 1px;
        padding: 8px;
        line-height: 1.6;
    }

    .col3 .item dl.data dd {
        font-size: 12px;
        border-top: #414d70 solid 1px;
        padding: 8px 8px 8px 4em;
        line-height: 1.6;
    }

    .new {
        position: absolute;
        top: 5%;
        background: #3bacc2;
        color: #fff;
        font-size: 11px;
        font-weight: 600;
        padding: 3px 16px;
        left: 0;
        line-height: 2;
    }

    .powerup {
        position: absolute;
        top: 5%;
        background: #f14173;
        color: #fff;
        font-size: 11px;
        font-weight: 600;
        padding: 3px 16px;
        left: 0;
        line-height: 2;
    }

    .col3 .item {
        width: calc(50% - 10px);
        margin-bottom: 60px;
        position: relative;
    }

    .hotel-name {
        font-size: 16px;
        padding: 0px 0 6px;
        font-weight: 600;
    }

    .hotel p {
        font-size: 13px;
        line-height: 1.6;
        margin-bottom: 1em;
    }

    .hotel {
        margin-bottom: 45px;
    }

    .hotel-pic {
        width: 30%;
    }

    .hotel-txt {
        width: 65%;
    }

    .accomo-btn a {
        display: block;
        background: #ffa938;
        width: 12em;
        text-align: center;
        font-size: 13px;
        font-weight: 600;
        padding: 4px 0;
        color: #fff;
    }

    .best-img {
        width: 100px;
        margin: 0 auto;
    }

    .bestrate-box p {
        font-size: 12px;
    }

    .bestrate-box p.best-ttl {
        font-size: 18px;
        padding: 14px 0 0;
        font-weight: 900;
    }

    .hotel-txt {
        width: 90%;
        margin: 20px auto;
    }

    .hotel-name {
        font-size: 15px;
        padding: 0px 0 10px;
        font-weight: 600;
        text-align: center;
    }

    .sec-title-en {
        font-size: 25px;
    }

    .items.-col3 .item {
        width: calc(50% - 8px);
        margin-bottom: 24px;
    }

    .items.-col3 .item .item-summary {
        padding: 1.4em 0;
    }

    .items.-col3 .item .item-title {
        font-size: 13px;
        margin-bottom: 0.8em;
        font-weight: 600;
        line-height: 1.5em;
        text-align: center;
    }

    .items.-col3 .item p {
        font-size: 11px;
        line-height: 1.8;
    }

    #map {
        position: relative;
        overflow: scroll;
    }

    .map-img {
        width: 640px;
    }

    .map-click a {
        display: block;
        background: #816fc3;
        color: #fff;
        font-size: 10px;
        font-weight: 600;
        padding: 5px 10px 3px;
        border-radius: 40px;
        z-index: 2;
        line-height: 1.3;
        transition: .4s;
    }

    .ico-snow {
        width: 64px;
        margin: 0 auto 20px;
    }

    #reserve .inner-mid {
        max-width: 1200px;
        width: 78%;
        margin: auto;
    }

    .sec-title {
        text-align: center;
        padding-top: 2px;
        font-size: 12px;
        line-height: 1.2;
    }
}

@media screen and (max-width:450px) {

    .page-leadcopy {
        padding-bottom: 0;
        font-size: 24px;
    }

    .sec-title-en {
        font-size: 22px;
    }

    .sec-title-wrap {
        padding-bottom: 2em;
    }

    .item.-col2 .item-summary .item-summary-inner.em2 {
        padding: 1em 0.5em;
    }

    .item.-col2 .item-summary .item-summary-inner {
        padding: 1em 0.5em;
    }


    .item.-col2 p {
        font-size: 14px;
        line-height: 1.8;
    }

    dl.data dt {
        width: 5em;
        float: left;
        font-size: 13px;
        border-top: #414d70 solid 1px;
        padding: 8px;
    }

    dl.data dd {
        font-size: 13px;
        border-top: #414d70 solid 1px;
        padding: 8px 8px 8px 6em;
    }

    .col3 .item .item-tmb img {
        border-radius: 4px;
        margin-bottom: 20px;
    }

    .col3 .item p {
        font-size: 11px;
        line-height: 1.7;
        padding: 0;
    }

    .col3 dl.data dt {
        width: 3em;
        float: left;
        font-size: 11px;
        border-top: #414d70 solid 1px;
        padding: 6px 0;
        line-height: 1.6;
    }

    .col3 .item dl.data dd {
        font-size: 11px;
        border-top: #414d70 solid 1px;
        padding: 8px 0px 8px 4em;
        line-height: 1.6;
    }

    .hotel-pic {
        width: 100%;
    }

    .bestrate-box {
        text-align: center;
        margin: 30px 0;
    }

    .accomo-btn a {
        display: block;
        background: #ffa938;
        width: 90%;
        text-align: center;
        font-size: 15px;
        font-weight: 600;
        padding: 8px 0;
        color: #fff;
        margin: 0 auto;
    }

    .hotels {
        padding-bottom: 0;
    }

    #about .sec-title-wrap {
        padding-bottom: 1em;
    }

    .info-table table {
        width: 100%;
        font-size: 0.9em;
        margin: 32px 0 16px;
        border-bottom: #c2c2c2 solid 1px;
    }

    .sup li {
        font-size: 11px;
        line-height: 1.6;
    }

    .sup-wrap {
        padding: 0.5em 0.5em;
    }

    .map-img-inner {
        width: 100%;
        margin: 30px auto 60px;
    }

    .item.-col2 {
        margin-bottom: 4em;
    }

    .modaal-content-container {
        padding: 0px !important;
    }

    .modal-detail {
        padding: 1.5em;
    }

    .modal-detail p {
        font-size: 14px;
        line-height: 2;
    }

    .info-table tbody th,
    .info-table tbody td {
        line-height: 1.6;
        padding: 12px;
        font-weight: 500;
        border-top: #3d4b73 solid 1px;
    }

    .info-table tbody th {
        width: 3.5em;
    }

    #head #accordion dt {
        color: #fff;
        font-size: 12px;
        cursor: pointer;
        border-bottom: 1px solid #ffffff;
        padding-left: 2px;
        padding-right: 2px;
        letter-spacing: .02em;
    }

    .sec-title {
        line-height: 1.2;
    }

    .sec-title-en {
        font-size: 25px;
        line-height: 1.2;
    }

    #other {
        padding-bottom: 30px;
    }

    #about.l-sec {
        padding: 3em 0;
        background: #18295c;
        color: #f8f8f8;
    }

    .accomo-btn a {
        width: 100%;
    }

    .info-table tbody th {
        width: 4em;
    }

    .modal-detail-title {
        text-align: center;
        font-size: 18px;
        padding-bottom: 0.5em;
    }

    dl.data dt {
        line-height: 1.6;
    }

    dl.data dd {
        line-height: 1.6;
    }
}