@charset "UTF-8";
:root {
    --main-font-color: #2b2b2b;
    --white-color: #fff;
    --accent-color: #8A3B2C;
    --yellow01: #D8CBB4;
    --yellow02: #A88B58;
    --yellow03: #b49f7a;
    --blown01: #4B4131;
    --container-narrow: 970px;
    --container-wide: 1210px;
    --container-padding: 16px;
    --trans: all .3s ease;
    --text-shadow: 0px 0px 20px rgba(58, 58, 58, 0.5);
}
/*--------------------------------
 header
---------------------------------*/
.header {
    padding: 20px 4%;
}
.header-link {
    gap: 1em;
}
.header-link .mypage a::before {
    width: 22px;
    height: 22px;
    margin-right: 8px;
}
@media screen and (max-width: 915px) {
    .header-link .mypage {
        display: none;
    }
}
@media screen and (max-width: 800px) {
    .header {
        display: flex;
        align-items: center;
        height: 120px;
    }
    .header-nav {
        order: 3;
    }
    .header .logo.header-logo {
        order: 1;
        margin-right: auto;
    }
    .header-link {
        order: 2;
    }
}
/*--------------------------------
 ハンバーガーメニュー
---------------------------------*/
@media screen and (max-width: 800px) {
    .menu_btn {
        width: 75px;
        width: 55px;
        background: var(--white-color);
        border-radius: 5px;
        margin-left: 10px;
    }
    .menu_btn::after {
        content: none;
    }
    .menu_btn span {
        width: 30px;
        background: var(--main-font-color);
        left: 50%;
    }
    .menu_btn.active span:nth-of-type(1) {
        transform: translateX(-50%) translateY(8px) rotate(35deg);
    }
    .menu_btn.active span:nth-of-type(2) {
        transform: translateX(-50%) translateY(-5px) rotate(-35deg);
    }
}
/*--------------------------------
 ボタン
---------------------------------*/
.btn01 a {
    padding: 12px 22px;
}
@media screen and (max-width: 800px) {
    .btn01 a {
        padding: 9px 18px;
    }
}
/*--------------------------------
 共通
---------------------------------*/
.c-section {
    margin: 130px 0;
}
/*--------------------------------
 table
---------------------------------*/
@media screen and (max-width: 800px) {
    .c-table-row tr {
        display: flex;
        flex-direction: column;
    }
    .c-table-row .c-table-th {
        width: 100%;
    }
    .c-table-row .c-table-td {
        border-bottom: none;
    }
    .c-table-row tr:first-child .c-table-td {
        border-top: none;
    }
    .c-table-row .c-table-th,
    .c-table-row .c-table-td {
        padding: 1em 1em;
    }
    .c-table-row .c-table-th .table-set {
        align-items: center;
    }
    .c-table-row .c-table-th .table-set .en,
    .c-table-row .c-table-th .table-set .jp {
        line-height: 1.2;
    }
    .c-table-row .c-table-th .table-set {
        gap: 0.2em;
    }
    .c-table-row .c-table-th {
        padding: 0.7em 1.5em;
    }
}
/*--------------------------------
 TOP_MV_index.html
---------------------------------*/
.hero-desc {
    /* 35-80 700-999 */
    left: clamp(2.188rem, -4.397rem + 15.05vw, 5rem);
}
.hero-text {
    top: 230px;
    width: 80%;
    padding-right: 0;
    height: 180vh;
}
.scroll {
    /* 130-170 700-999 */
    bottom: clamp(8.125rem, 2.272rem + 13.38vw, 10.625rem);
}
.nav-grid {
    grid-template-columns: 1fr 0.7fr;
}
.nav-grid .info {
    gap: 2em;
}
@media screen and (max-width: 800px) {
    .nav-grid {
        grid-template-columns: 1fr;
    }
    .nav-grid .navi-img {
        display: none;
    }
    .header .nav-grid .logo {
        margin-right: none;
    }
}
/*--------------------------------
 TOP_News
---------------------------------*/
.t-news {
    margin: 180px 0;
}
.t-news .flex {
    gap: 1em;
}
@media screen and (max-width: 760px) {
.t-news .flex {
    flex-direction: column;
}
}
.t-news .calendar-area {
    max-width: 440px;
}
@media screen and (max-width: 850px) {
    .t-news .contents-area {
        flex-direction: column;
    }
    .scroll-box {
        flex: none;
        height: 300px;
    }
    .t-news .calendar-area {
        max-width: 100%;
    }
}

/*--------------------------------
 TOP_About
---------------------------------*/
.t-about {
    min-height: calc(6.8vw * 18);
}
@media screen and (max-width: 870px) {
    .grid-img img:nth-child(1) {
        grid-column: 13 / 21;
    }
    .grid-img img:nth-child(2) {
        grid-row: 5 /9;
        grid-column: 1 / 4;
    }
    .grid-img img:nth-child(3) {
        grid-column: 13 / 18;
        grid-row: 8 /13;
    }
    .grid-img img:nth-child(4) {
        grid-column: 3 / 11;
        grid-row: 11 / 16;
    }
}
@media screen and (max-width: 760px) {
    .t-about {
        display: flex;
        flex-direction: column-reverse;
        gap: 10vw;
    }
    .grid-img {
        position: static;
    }
    .grid-img img:nth-child(1) {
        grid-column: 9 / 21;
        grid-row: 1 / 7;
    }
    .grid-img img:nth-child(2) {
        grid-column: 1 / 6;
        grid-row: 4 /10;
    }
    .grid-img img:nth-child(4) {
        grid-column: 3 / 11;
        grid-row: 13 / 18;
    }
    .grid-img img:nth-child(5) {
        grid-column: 14 / 19;
        grid-row: 17 / 21;
    }
}
/*--------------------------------
 TOP_Rooms
---------------------------------*/
.cards-swiper-btn .swiper-button-prev,
.cards-swiper-btn .swiper-button-next,
.cards-swiper-btn .swiper-button-prev::after,
.cards-swiper-btn .swiper-button-next::after {
    width: 58px;
    height: 58px;
}
.above-img figcaption {
    /* 20-24 700-999 */
    font-size: clamp(1.25rem, 0.665rem + 1.34vw, 1.5rem);
    letter-spacing: 2px;
    bottom: 20px;
}
.bg-brown {
    background-attachment: scroll;
    background-repeat: repeat;
    transform: translateZ(0);
}
/*--------------------------------
 TOP_Service
---------------------------------*/
.t-service .text-set.mb-100 {
    margin-bottom: 60px;
}
@media screen and (max-width: 900px) {
    .t-service .flex-start {
        flex-direction: column;
    }
    .t-service .heading-double.mb-50 {
        margin-bottom: 30px;
    }
    .t-card .c-line-title::after {
        width: 40px;
        height: 40px;
        background-size: 40px 40px;
    }
}
@media screen and (max-width: 850px) {
    .t-grid-container {
        gap: 10px;
    }
}
@media screen and (max-width: 800px) {
    .t-grid-container {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5em;
    }
    .t-grid-container .t-ignore:nth-of-type(3) {
        grid-column: span 2;
    }
    .t-grid-container .t-ignore:nth-of-type(1) .t-card,
    .t-grid-container .t-ignore:nth-of-type(2) .t-card {
        margin-top: 0;
    }
    .t-card {
        gap: 12px;
    }
    .t-card__img img {
        aspect-ratio: 2 / 2;
    }
    .t-grid-container .t-ignore:nth-of-type(1) .t-card__img img,
    .t-grid-container .t-ignore:nth-of-type(2) .t-card__img img {
        object-position: 50% 92%;
    }
    .t-grid-container .t-ignore:nth-of-type(3) .t-card__img img {
        object-position: 50% 68%;
        aspect-ratio: 4 / 2;
    }
    .c-line-title p {
        line-height: 1.5;
    }
}
/*--------------------------------
 TOP_faq
---------------------------------*/
.c-bigsmall {
    gap: 4px;
}
.c-bigsmall p {
    /* 35-50 600-999 */
    font-size: clamp(2.188rem, 0.778rem + 3.76vw, 3.125rem);
}
@media screen and (max-width: 800px) {
    .img-big,
    .img-big img {
        aspect-ratio: 366 / 270;
    }
}
/*--------------------------------
 reservation
---------------------------------*/
.c-reserve .c-bigsmall.mb-80 {
    /* 40-60 600-999 */
    margin-bottom: clamp(2.5rem, 0.62rem + 5.01vw, 3.75rem);
}
.c-reserve .btn-transparent.mb-80 {
    /* 20-30 600-999 */
    margin-bottom: clamp(1.25rem, 0.31rem + 2.51vw, 1.875rem);
}
.c-reserve {
    /* 96-140 600-999 */
    padding: clamp(6rem, 1.865rem + 11.03vw, 8.75rem) 0;
}
/*--------------------------------
 footer
---------------------------------*/
.footer-left {
    width: 43%;
}
.footer-right {
    width: auto;
}
.footer-main {
    column-gap: 14px;
}
footer .c-navlist li .jp {
    padding-left: 65px;
}
footer .logo.mb-80 {
    margin-bottom: 60px;
}
footer .c-navlist li .en {
    width: 96px;
}
.footer-right .footer-item.flex {
    flex-direction: column;
    align-items: flex-start;
}
@media screen and (max-width: 800px) {
    footer .logo.mb-80 {
        /* 30-60 600-800 */
        margin-bottom: clamp(1.875rem, -3.75rem + 15vw, 3.75rem);
    }
    .footer-item {
        margin-bottom: 30px;
    }
    footer .c-navlist li .en {
        width: 93px;
    }
    .footer-left {
        width: 50%;
    }
}
@media screen and (max-width: 700px) {
    footer .c-navlist li .jp {
        padding-left: 55px;
    }
    footer .c-navlist li .en {
        width: 90px;
        font-size: 14px;
    }
    footer .c-navlist li .jp::before {
        width: 35px;
    }
    .footer-item.flex .footer-heading {
        width: auto;
    }
    .footer-left .footer-item:last-child {
        gap: 2em;
    }
}
@media screen and (max-width: 665px) {
    footer {
        padding: 90px 0;
    }
    .footer-main {
        flex-direction: column;
        margin-bottom: 2em;
    }
    .footer-left {
        width: 100%;
        margin-bottom: 2em;
    }
    .footer-left .footer-item:first-child {
        display: flex;
        align-items: flex-start;
    }
    .footer-heading,
    .footer-item.flex .footer-heading,
    .footer-right .footer-item.flex .footer-heading {
        width: 30%;
    }
    .footer-left .footer-item:last-child {
        gap: 0;
    }
    .footer-right .footer-item.flex {
        flex-direction: row;
    }
    .footer-btn,
    footer .sns-list {
        width: 70%;
    }
    footer .c-navlist li .jp {
        padding-left: 62px;
    }
    small.jp {
        display: block;
        text-align: center;
    }
}
/*--------------------------------
 lower_共通
---------------------------------*/
.l-hero {
    height: 400px;
}
/*--------------------------------
 aoubt.html
---------------------------------*/
.l-about-desc {
    min-height: calc(6.5vw * 18);
}
.grid-img.grid-img-about img:nth-child(1) {
    grid-column: 14 / 20;
    grid-row: 1 / 7;
}
.l-about-desc-left .en-text p,
.l-about-desc-right .jp-text p {
    margin-bottom: 1.5em;
}
.l-about-desc-left .en-text,
.l-about-desc-right .jp-text {
    max-width: 430px;
}
.l-about-desc-left {
    margin-bottom: 7vw;
}
@media screen and (max-width: 850px) {
    .grid-img.grid-img-about {
        position: static;
    }
    .l-about-desc {
        display: flex;
        flex-direction: column-reverse;
        align-items: center;
    }
    .l-about-desc-left .en-text,
    .l-about-desc-right .jp-text {
        max-width: 100%;
    }
    .grid-img.grid-img-about img:nth-child(1) {
        grid-column: 12 / 20;
        grid-row: 1 / 9;
    }
    .grid-img.grid-img-about img:nth-child(2) {
        grid-column: 2 / 10;
        grid-row: 9 /14;
    }
    .grid-img.grid-img-about img:nth-child(3) {
        grid-column: 15 / 20;
        grid-row: 14 /19;
    }
    .grid-img.grid-img-about img:nth-child(4) {
        grid-row: 17 / 21;
        grid-column: 5 / 11;
    }
}
/*--------------------------------
 rooms/index.html
---------------------------------*/
@media screen and (max-width: 800px) {
    .l-rooms-anchor .c-anchor-list {
        grid-template-columns: repeat(3, 1fr);
    }
}
@media screen and (max-width: 870px) {
    .rooms-list-item {
        padding: 1em 1.6em;
    }
}
@media screen and (max-width: 800px) {
    .rooms-list {
        flex-direction: column;
        width: 100%;
    }
    .rooms-list-item.en {
        border-right: none;
    }
    .rooms-list-item {
        padding: 1em 2em;
        width: 100%;
    }
    .rooms-item .btn02 {
        margin-right: auto;
    }
    .c-img-flex {
        flex-direction: column-reverse;
        gap: 28px;
    }
}
/*--------------------------------
 rooms/bamboo.html
---------------------------------*/
.single-content {
    /* 90-120 600-999 */
    margin-bottom: clamp(5.625rem, 2.805rem + 7.52vw, 7.5rem);
}
.t-grid-container {
    column-gap: 0.8em;
}
@media screen and (max-width: 800px) {
    .floor-desc .text-set {
        padding: 0;
    }
    .l-rooms-other .t-grid-container .t-ignore:nth-of-type(3) {
        grid-column: auto;
    }
    .l-rooms-other .t-grid-container {
        grid-template-columns: repeat(2, 1fr);
        gap: 2em;
    }
    .l-rooms-other .t-grid-container .t-ignore:nth-of-type(3) .t-card__img img {
        aspect-ratio: 4 / 3;
    }
}
@media screen and (max-width: 700px) {
    .btn-flex {
        gap: 1em;
    }
    .btn-flex .btn-icon .flex {
        gap: 0.5em;
    }
    .btn-flex .btn-icon a {
        padding: 14px 16px;
    }
}
.l-rooms-other .t-grid-container .t-ignore:nth-of-type(1) .t-card__img img,
.l-rooms-other .t-grid-container .t-ignore:nth-of-type(2) .t-card__img img,
.l-rooms-other .t-grid-container .t-ignore:nth-of-type(3) .t-card__img img {
    object-position: 50% 50%;
}
/*--------------------------------
 service.html
---------------------------------*/
.l-service article {
    margin: 90px 0;
}
.l-service-desc {
    min-height: calc(4vw * 18);
}
.l-service-desc-left {
    margin-bottom: 13vw;
}
.grid-img.grid-img-service img:nth-child(1) {
    grid-row: 2 / 7;
}
@media screen and (max-width: 850px) {
    .l-service-desc-left {
        margin-bottom: 9vw;
    }
    .l-service-desc .l-about-desc-left .en-text,
    .l-service-desc .l-about-desc-right .jp-text {
        max-width: 100%;
    }
}
.l-service .desc .mb-100 {
    /* 60-100 600-999 */
    margin-bottom: clamp(3.75rem, -0.009rem + 10.03vw, 6.25rem);
}
.inf-slide {
    width: 320px;
}
.inf-slider-container {
    padding: 20px 0 50px 0;
}
.rickshawtour-accordion .accordion-a {
    margin-left: 1em;
}
@media screen and (max-width: 920px) {
    .bicycle-flex {
        flex-direction: column;
    }
    .bicycle-video {
        width: 100%;
    }
}
@media screen and (max-width: 800px) {
    .service-flex .img-area {
        width: 100%;
    }
    .accordion-flex {
        gap: 0.5em;
    }
    .rickshawtour-figure figcaption {
        font-size: 80%;
        padding: 0.3em 1.2em;
    }
    #morningtour .c-img-flex .text-set {
        width: 100%;
    }
    .morningtour-flex,
    .morningtour-benefits-flex,
    .rickshawtour-flex{
        flex-direction: column;
    }
    .morningtour-benefits-flex .dot-list,
    .morningtour-benefits-flex .benefits-img {
        width: 100%;
    }
    .morningtour-benefits-flex .benefits-img img {
        max-width: 100%;
    }
    .l-access-jr .c-img-flex .text-set {
        width: 100%;
    }
    .rickishawtour-video {
        width: 100%;
    }
}
.l-access-map .c-img-flex {
    gap: 2em
}
@media screen and (max-width: 700px) {
    .l-access-map .c-img-flex {
        flex-direction: column-reverse;
        gap: 4em;
    }
    .l-access-map .c-img-flex .img-area {
        width: 100%;
        text-align: center;
    }
    .l-access-map .c-img-flex .img-area img {
        aspect-ratio: 3 / 3;
        object-fit: cover;
        max-width: 500px;
    }
}
/*--------------------------------
 404.html
---------------------------------*/
.l-hero-notfound .l-hero-title {
    flex-direction: column-reverse;
    gap: 0;
}
/*--------------------------------
 gallery.html
---------------------------------*/
@media screen and (max-width: 800px) {
.insta-list {
    grid-template-columns: repeat(2,1fr);
    gap: 20px;
}
}