@charset "UTF-8";
/*==================================================================================================

       hero

===================================================================================================*/

.hero-wrap {
        position: relative;
        box-sizing: border-box;
        margin-top:80px;
        z-index: 6;
        }
        
        @media screen and (max-width:1024px) {
        .hero-wrap { margin-top:96px; }
        }
        @media screen and (max-width:767px) {
        .hero-wrap { margin-top:96px; }
        }

/*==================================================================================================

       Movie

===================================================================================================*/

.movie-wrap {
        position: relative;
        box-sizing: border-box;
        height: auto;
        overflow: hidden;
        z-index: 0;
        }
        .movie {
        position: relative;
        width: 100%;
        height: auto;
        text-align: center;
        overflow: hidden;
        }
        .video-js {
        height: 100% !important;
        }
        .video-js .vjs-tech { 
        top: 50% !important;
        left: 50% !important;
        transform: translate(-50%,-50%);
        }

        /*=================================================
        すべてアスペクト比固定の場合（movieサイズのまま）　top-movie付与
        ==================================================*/

        .movie_inner {
        position: relative;
        width: 100%;
		height: auto;
        overflow: hidden;
        z-index: 0;
        top: 0;
        }
        .movie_inner video { object-fit: cover; }
		.top-movie{ max-height:calc(100vh - 80px); }

        .movie_inner { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); min-height:0; height:100%; }
        .movie.top-movie:before { content:""; display: block; position: relative; top:0; left:0;
        padding-top:56.25%;
        }

        @media screen and (max-width: 1024px) {
        .movie.top-movie:before { padding-top:75%; }
        .top-movie{ max-height:100vh; }
        }
        @media screen and (max-width: 767px) {
        .movie.top-movie:before { padding-top:75%; }
        }

/*==================================================================================================

       背景

===================================================================================================*/

.border-box {
        border:6px solid #707070;
        padding:6%;
        box-sizing: border-box;
        border-radius: 40px;
        }
        .border-box-m {
        border:6px solid #C6BBA8;
        border-radius: 10px;
        padding:8%;
        box-sizing: border-box;
        background: rgb(255 255 255 / .5);
        }
        .border-box-s {
        border:2px solid rgb(59 55 48 / .7);
        padding:6%;
        box-sizing: border-box;
        border-radius: 6px;
        background: rgb(255 255 255 / .3);
        }

.bg-sea {
        position: relative;
        background:#2A9FB1 url("../images/parts/sea.jpg") bottom center repeat-x;
        z-index: 1;
        }
        .wave-top:after {
        content:"";
        display: block;
        position: absolute;
        top:-70px;
        left:0;
        width:100%;
        height:70px;
        background: url("../images/parts/wave-3.png") bottom center repeat-x;
        z-index: -1;
        }

.bg-light { background:#E9F5F7; }

.white-box {
        background: #FFF;
        padding:4.5%;
        box-sizing: border-box;
        border-radius: 40px;
        }

        @media screen and (max-width:1350px) {
        .border-box  { border-radius: 30px; }
        .white-box { border-radius: 30px; }
        }
        @media screen and (max-width:1024px) {
        .border-box  { border-radius: 25px; }
        .border-box-m { padding:2.5rem; }
        .border-box-s { padding:8%; }
        .white-box { border-radius: 25px; }
        }
        @media screen and (max-width:767px) {
        .border-box  { padding:9.5%; border-radius: 20px; }
        .border-box-m { padding:2rem 1.5rem; }
        .border-box-s { padding:9.5%; }
        .wave-top:after { top:-35px; height:35px; background: url("../images/parts/wave-3-sp.png") bottom center repeat-x; }
        .white-box { border-radius: 20px; padding:8.5%; }
        }

/*==================================================================================================

        タイトル / テキスト

===================================================================================================*/

.white { color:#F9F6F0 !important; }
.white .en { color:#F9F6F0; }
.red { color:#B9151B;}
.blue { color:#2A9FB1; }
.gray { color:#A8A194; }


.mark {background:linear-gradient(transparent 60%, #F29E84 60%);}
.mark-w {background:linear-gradient(transparent 60%, rgb(144 131 55 / 1) 60%);}

.under-title {
        padding-bottom:.15rem;
        border-bottom:2px solid #888F95;
        }
.under-bar {
        position: relative;
        padding-bottom:15px;
        }
        .under-bar:after {
        content:"";
        display: block;
        position: absolute;
        bottom:0;
        left:50%;
        translate:-50%;
        width:46px;
        height:1px;
        background:#F6F6F6;
        }
.bar-title {
        position: relative;
        padding-top:18px;
        }
        .bar-title:after {
        content:"";
        display: block;
        position: absolute;
        top:0;
        left:0;
        width:46px;
        height:2px;
        background:#404040;
        }
        .center.bar-title:after {
        left:50%;
        translate:-50%;
        }
        .bg-banner .bar-title:after { background: #FFF; }
        @media screen and (max-width:1024px) {
        .bar-title { padding-top:15px; }
        }
        @media screen and (max-width:767px) {
        .bar-title { padding-top:10px; }
        .bar-title.bar-sp-center:after { left:50%; translate:-50%; }
        }
        
.dotted-title {
        padding-bottom:.15rem;
        border-bottom:2px dotted #857A6B;
        display:block;
        }

.lead {
        position: relative;
        width:100%;
        overflow: hidden;
        z-index: 0;
        }
        .lead:after {
        content:"";
        position: absolute;
        display: inline-block;
        bottom:.75em;
        width:100%;
        height:1px;
        background: #2A9FB1;
        margin-left:1rem;
        z-index: -1;
        }
.half-lead {
        position: relative;
        width:100%;
        overflow: hidden;
        line-height: 200%;
        z-index: 0;
        }
        .half-lead:after {
        content:"";
        position: absolute;
        display: inline-block;
        bottom:1em;
        width:90px;
        height:1px;
        background:#AAA;
        margin-left:1rem;
        z-index: -1;
        }
.center-lead {
        position: relative;
        display:block;
        overflow: hidden;
        width:100%;
        text-align: center;
        z-index: 0;
        }
        .center-lead:before,
        .center-lead:after {
        content:"";
        display: inline-block;
        position: absolute;
        bottom:.75em;
        width:50%;
        height:1px;
        background:#2A9FB1;
        }
        .center-lead:before { right:50%; margin-right:4em; }
        .center-lead:after { left:50%; margin-left:4em; }

.tate-lead-before {
        position: relative;
        width:100%;
        overflow: hidden;
        padding-top:30px;
        z-index: 0;
        }
        .tate-lead-before:after {
        content:"";
        position: absolute;
        display: block;
        top:0;
        left:40%;
        width:1px;
        height:20px;
        background:#9A9DA0;
        z-index: -1;
        }
        @media screen and (max-width:767px) {
        .sp-yokogaki .tate-lead-before { padding-top:0; padding-left:30px; }
        .sp-yokogaki .tate-lead-before:after { left:0; top:50%;  width:20px; height:1px;}
        }
.tate-lead-after {
        position: relative;
        line-height: 150%;
        z-index: 0;
        }
        .tate-lead-after:after {
        content:"";
        position: absolute;
        display: inline-block;
        left:50%;
        width:1px;
        height:40px;
        background:#89611A;
        margin-top:1rem;
        opacity:.5;
        z-index: -1;
        }
        @media screen and (max-width:767px) {
        .sp-yokogaki .tate-lead-after:after { left:auto; top:50%; margin-top:0; margin-left:1rem; width:40px; height:1px;}
        }
.short-lead {
        position: relative;
        display: inline-block;
        padding:0 3em 0;
        text-align: center;
        line-height: 200%;
        z-index: 0;
        }
        .short-lead:before,
        .short-lead:after {
        content:"";
        display: inline-block;
        position: absolute;
        bottom:1em;
        width:2em;
        height:1px;
        background:#FFF;
        }
        .short-lead:before { left:0; }
        .short-lead:after { right:0; }

.label-title-s {
        background: #0B4E88;
        color:#FFF;
        line-height: 180%;
        padding:.5rem 1.2em;
        box-sizing: border-box;
        border-radius: 6px;
        }
.label-title-m {
        background: url("../images/parts/sea.jpg") bottom center repeat-x;
        color:#FFF;
        line-height:180%;
        padding:.75em 1.2em;
        box-sizing: border-box;
        border-radius: 15px;
        }
.tag-label {
        background: #2A9FB1;
        display: inline-block;
        padding:0 1em;
        border-radius: 6px;
        color:#FFF;
        }






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

        }
        @media screen and (max-width:1024px) {
        .label-title-m { border-radius: 10px; }
        }
        @media screen and (max-width:767px) {
        .half-lead:after { width:2.5em; }
        .short-lead { padding:0 2.5em 0; }
        .short-lead:before, .short-lead:after { width:1.5em; }
        .short-lead.sp-lead-none { padding:0; }
        .short-lead.sp-lead-none:before, .short-lead.sp-lead-none:after { display: none; }
        .label-title-m { border-radius: 6px; }
        }

/*==================================================================================================

       トップページ

===================================================================================================*/

        /*=================================================
                News
        ==================================================*/

        .news-wrap {
        position: relative;
        min-height: 190px;
        z-index: 8;
        }
        .top-news-list li {
        position: relative;
        font-size:1rem;
        line-height: 170%;
        padding: .5rem 0;
        border-bottom:1px dotted rgb(255 255 255 / .45);
        }
        .top-news-list li:last-child { border-bottom:none; }
        .top-news-list li a {
        position: relative;
        font-weight:400;
        color:#FFF;
        box-sizing: border-box;
        transition: all 0.3s ease;
        cursor: pointer;
        }
        .top-news-list li .date {
        font-size:12px;
        margin-right:30px;
        color:#FFF;
        opacity:1;
        }
        .top-news-list li a:hover { opacity:1; text-decoration: underline; }
        .top-news-list li a:hover:after { left: 0; width: 100%; }

        .top-news-list .catName {
        display: inline-block;
        padding: 7px 8px 8px;
        color: #333;
        background: #FFF;
        border-radius: 3px;
        font-size: 12px;
        font-weight: 500;
        line-height: 100%;
        margin: 0 12px 0 0 ;
        }
        @media screen and (max-width:767px) {
        .top-news-list .post-title { display: block; padding-top: 5px; margin-left: 0; }
        .top-news-list .catName { padding: 4px 8px 5px; }
        .top-news-list li .date { margin-right:15px; }
        }

        /*=================================================
                GREETING
        ==================================================*/

        .greeting-section {
        position: relative;
        padding-bottom:180px;
        z-index: 0;
        }
        .greeting-section:after {
        content:"";
        dislplay:block;
        position: absolute;
        bottom:0;
        left:0;
        width:100%;
        height:240px;
        background: url("../images/parts/wave-blue.jpg") center center repeat-x;
        z-index: -1;
        }
        .greeting-img img {
        width:100%;
        border-radius:0 0 0 4.5vw;
        }
        .greeting-text {
        width:78%;
        max-width:500px;
        margin-inline:auto;
        }
        .greeting-sub-wrap {
        padding-top:5%;
        }
        .greeting-sub {
        position: relative;
        z-index: 0;
        }
        .greeting-sub figure:nth-child(1) {
        position: relative;
        box-sizing: border-box;
        padding:0 45% 8% 5%;
        margin-top:-20%;
        }
        .greeting-sub figure:nth-child(2) {
        position: absolute;
        bottom:0;
        right:0;
        width:36%;
        }
        .sub-text {
        width:86%;
        max-width:620px;
        padding-bottom:3rem;
        }
        
        @media screen and (max-width:1800px) {
        .greeting-img img { height:670px; }
        }
        @media screen and (max-width:1350px) {
        .greeting-img img { height:600px; }
        }
        @media screen and (max-width:1024px) {
        .greeting-img img { height:540px; border-radius:0 0 0 25px; }
        }
        @media screen and (max-width:767px) {
        .greeting-img { padding-left:8%; padding-bottom:3rem; box-sizing: border-box; }
        .greeting-img img { height:100%; border-radius:0 0 0 20px; }
        .greeting-section { padding-bottom:150px; }
        .greeting-section:after { height:150px; background: url("../images/parts/wave-blue-sp.jpg") center center repeat-x; }
        .greeting-sub-wrap { padding-top:3rem; }
        .greeting-sub figure:nth-child(1) { margin-top:0; }
        .greeting-sub figure:nth-child(2) { right:5%; }
        .sub-text { width:82%; margin-inline:auto; }
        }

        /*=================================================
                Attraction
        ==================================================*/

        .att-wrap {
        padding-bottom:4%;
        }
        .att-title {
        position: relative;
        margin-top:-40px;
        z-index: 1;
        }
        .shift-01 { margin-top:10%; }
        .shift-02 { margin-top:20%; }

        @media screen and (max-width:1350px) {
        .att-title { margin-top:-34px; }
        }
        @media screen and (max-width:1024px) {
        .att-title { margin-top:-30px; }
        }
        @media screen and (max-width:767px) {
        .att-wrap { padding-bottom:12%; }
        .att-title { margin-top:-24px; }
        .shift-01 { margin-top:0; }
        .shift-02 { margin-top:0; }
        }

        /*=================================================
                Banner
        ==================================================*/

        .banner-wrap {
        width:100%;
        position: relative;
        overflow: hidden;
        z-index: 1;
        }
        .banner-wrap a {
        display: block;
        overflow: hidden;
        color:#FFF;
        }
        .banner-img {
        background: url("../images/parts/banner-bg.jpg") center center / cover;
        width:100%;
        height:450px;
        box-sizing: border-box;
        position: relative;
        z-index: 0;
        }
        .banner-text {
        position: absolute;
        top:50%;
        left:50%;
        translate:-50% -50%;
        width:80%;
        max-width:900px;
        text-align: center;
        box-sizing: border-box;
        z-index: 1;
        }
        .more-reservation {
        width:100%;
        height:90px;
        line-height:90px;
        text-align: center;
        color:#FFF;
        background: #E1BD2D;
        background: linear-gradient(135deg, rgba(225, 189, 45, 1) 0%, rgba(199, 147, 25, 1) 100%);
        border-radius:10px;
        box-sizing: border-box;
        overflow: hidden;
        font-size:21px;
        white-space: nowrap;
        text-decoration:none !important;
        position: relative;
        z-index: 1;
        letter-spacing: 0em;
        display: inline-block;
        -webkit-transition: all 0.3s ease;
        transition: all 0.3s ease;
        box-shadow: 0 5px 15px rgb(0 0 0 / .3);
        }
        .more-reservation:after {
        position: absolute;
        content: "";
        width: 0;
        height:100%;
        bottom:0;
        right: 0;
        z-index: -1;
        border-radius:1px;
        -webkit-transition: all 0.3s ease;
        transition: all 0.3s ease;
        background:rgb(255 255 255 / .3);
        }      
        .banner-wrap a:hover .more-reservation { opacity:1; }
        .banner-wrap a:hover .more-reservation:after { left:0; width:100%; }


        @media screen and (max-width: 1350px) {
        .banner-img { height:420px; }
        .banner-text { max-width:750px; }
        .more-reservation { height:72px; line-height:72px; font-size:18px; }
        }

        @media screen and (max-width:1024px) {
        .banner-img { height:340px; }
        .banner-text { max-width:700px; }
        .more-reservation { height:64px; line-height:64px; }
        }
        @media screen and (max-width:767px) {
        .banner-img { height:300px; }
        .banner-text { width:86%; max-width:450px; }
        .more-reservation { height:54px; line-height:54px; font-size:16px;  }
        }

/*==================================================================================================

       下層 ヘッダー

===================================================================================================*/

.page-header-wrap {
        position: relative;
        box-sizing: border-box;
        height: auto;
        overflow: hidden;
        z-index: 0;
        }

        /*=================================================
                ノーマルヘッダー
        ==================================================*/

        .page-header {
        position: relative;
        width: 100%;
        height:100%;
        max-height:80vh;
        overflow: hidden;
        z-index: 0;
        }
        .page-header:before {
        content: "";
        display: block;
        padding-bottom:45%;
        height:0;
        width:100%;
        }
        .page-header.short:before {
        content: "";
        display: block;
        height:0;
        padding-bottom:45%;
        width:100%;
        }

        .facilities   { background: url("../images/img/facilities/header.jpg") center center / cover; }
        .cuisine      { background: url("../images/img/cuisine/header.jpg") center center / cover; }
        .access       { background: url("../images/img/access/header.jpg") center center / cover; }
        .faq          { background: url("../images/img/faq/header.jpg") center center / cover; }
        .news         { background: url("../images/img/news/header.jpg") center center / cover; }


        @media screen and (max-width: 1024px) {
        .page-header:before { padding-bottom:75%; height:0; }
        .page-header.short:before { padding-bottom:75%; height:0; }
        }
        @media screen and (max-width:767px) {
        .page-header:before { padding-bottom:75%; height:0; }
        .page-header.short:before { padding-bottom:75%; height:0; }
        }

.page-title {
        position: absolute;
        bottom: 0;
        left:0;
        padding:0px 24px 30px;
        color:#FFF;
        width:100%;
        background:  url("../images/parts/sea.jpg") top center repeat-x;
        box-sizing: border-box;
        z-index:1;
        }
        .page-title:after {
        content:"";
        display: block;
        position: absolute;
        top:-70px;
        left:0;
        width:100%;
        height: 70px;
        background: url("../images/parts/wave-3.png") bottom right repeat-x;
        z-index: 0;
        }
        .page-title h1 {
        position: relative;
        text-align: center;
        line-height:110%;
        font-weight:500;
        color:#FFF;
        z-index: 2;
        }
        @media screen and (max-width:1024px) {
        .page-title { position: relative;  }
        }
        @media screen and (max-width:767px) {
        .page-title { padding:10px 24px 20px; }
        .page-title:after { top:-35px; height: 35px; background: url("../images/parts/wave-3-sp.png") bottom right repeat-x; }
        }

.memo {
        padding:.5rem 0;
        box-sizing: border-box;
        line-height: 180%;
        border-top: 1px solid rgb(0 0 0 / .6);
        border-bottom: 1px solid rgb(0 0 0 / .6);
        }
        .memo-w {
        padding:.5rem 0;
        border-top:1px solid rgba(255,255,255,.5);
        border-bottom:1px solid rgba(255,255,255,.5);
        }

figure {
        position: relative;
        z-index: 0;
        }
.figure-caption {
        position: absolute;
        display: inline-block;
        bottom:0;
        left:0;
        padding: 5px 13px;
        margin: 0;
        color: #fff;
        background: rgb(0 0 0 / .7);
        font-size: 13px;
        line-height: 120%;
        z-index: 1;
        }
        .figure-caption.top { bottom:auto; top:0; }

        @media screen and (max-width:767px) {
        .figure-caption { font-size:11px; }
        }

/*==================================================================================================

       下層

===================================================================================================*/

        /*=================================================
                ACCESS
        ==================================================*/

        .area-img img { height:600px; }
        @media screen and (max-width:1080px) {
        .area-img img { height:100%; }
        }

        /*=================================================
                FAQ
        ==================================================*/

        .faq-q {
        position: relative;
        font-size: 1rem;
        line-height: 180%;
        background: #EFEFEF;
        box-sizing: border-box;
        border-radius: 10px;
        color:#404040;
        padding: 1.25rem 1.5rem 1.25rem 4rem;
        /* アコーディオンのみ
        cursor: pointer;
        */
        }
        .faq-q:before {
        content: "Q";
        font-family: "Ubuntu Condensed", sans-serif;
        font-weight: 400;
        position: absolute;
        color:#404040;
        top: 1.1rem;
        left: 1.25rem;
        line-height: 100%;
        font-size: 1.8rem;
        }
        /* アコーディオンのみ
        .faq-q h3 { padding-right:1.5rem; }
        */
        .faq-a {
        position: relative;
        font-size: 1rem;
        line-height: 180%;
        box-sizing: border-box;
        padding: 1.25rem 1.5rem 1.25rem 4rem;
        }
        .faq-a:before {
        content: "A";
        font-family: "Ubuntu Condensed", sans-serif;
        font-weight: 400;
        position: absolute;
        color:#42403B;
        top: 1.1rem;
        left: 1.25rem;
        line-height: 100%;
        font-size: 1.8rem;
        }

        @media screen and (max-width:767px) {
        .faq-q { padding:0.75rem 1.5rem; }
        .faq-q:before { font-size: 1.25rem; left:1rem; top:.85rem; opacity:.6; }
        .faq-q h3 { padding-left:1.5rem; }
        .faq-a { padding: 0.75rem 0 .75rem 0; }
        .faq-a:before { display: none; }
        .faq-a p { padding-left:0; }
        }





























