@charset "utf-8";

/* ====================================================
	page header
==================================================== */
.page-header {
    height: min(400px, 62vw);
    position: relative;
    background-color: #111;
    z-index: 0;
}

.page-header .bg {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    opacity: .8;
}

.page-header .bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.page-header .title {
    width: 100%;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translate(0, -50%);
    z-index: 10;
    color: #fff;
    text-align: center;
    font-weight: normal;
    text-shadow: 0px 0px 2px rgba(0, 0, 0, .8), 0px 0px 7px rgba(0, 0, 0, .3);
    /* display: inline-block;
    width: fit-content;
    height: fit-content;
    white-space: nowrap;
    writing-mode: vertical-rl;
    position: absolute;
    top: unset;
    bottom: 7%;
    right: 7%; */

    /* letter-spacing: .1em;
    font-feature-settings: "palt";
    padding: 1em .75em;
    background: rgba(255, 255, 255, .7);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px); */
}

.page-header .title-jp {
    font-size: min(2.2em, 6vw);
}

/* .rentalspace .page-header .title-jp {
    font-size: min(1.7em, 6vw);
} */

/* .stay .page-header .title-jp {
    font-size: min(2.1em, 6vw);
    letter-spacing: .15em;
} */


.page-header .title-description {
    margin-top: 1em;
    font-size: min(1.3em, 4.5vw);
}

/* ====================================================
	about
==================================================== */
.about-wrp .about-title {
    margin-bottom: 2em;
    font-size: min(1.7em, 5.2vw);
    font-weight: normal;
    letter-spacing: 0.05em;
    text-align: center;
}

@media screen and (max-width:640px) {
    .about-wrp p {
        margin: 1.5em auto;
        font-size: .95em;
    }
}

/* concept */
.about-wrp .concept-wrp {
    padding: min(80px, 15vw) 0;
}

.about-wrp .concept-wrp p {
    margin: 0 auto 1.5em;
    font-size: 1.05em;
    line-height: 2.4em;
    letter-spacing: 0.04em;
    color: var(--gold);
}

.about-wrp .concept-wrp p.gold {
    width: 90%;
    text-align: center;
}

/* interview */
.about-wrp .interview-wrp {
    background-color: #f9f9f9;
    padding: 6em 1em;
}

.about-wrp .interview-wrp .interview-inner {
    width: min(740px, 100%);
    margin: 0 auto;
}

.about-wrp .interview-wrp .interview-inner p {
    line-height: 2;
    margin-bottom: 1em;
}

.about-wrp .interview-wrp .interview-inner .dush {
    display: inline-block;
    width: 4em;
    height: 1px;
    background-color: #333;
    vertical-align: middle;
    margin-right: 1em;
}

.about-wrp .interview-wrp .interview-inner .sml {
    font-size: .8em;
    margin-top: 1em;
}

.about-wrp .interview-wrp .interview-inner .interview .q {
    text-align: left;
    margin-top: 3em;
    margin-bottom: 1em;
    font-size: 1.1em;
    line-height: 1.5;
}

/* profile */
.about-wrp .profile {
    width: min(740px, 90%);
    margin: min(80px, 10vw) auto 0;
    align-items: center;
}

.about-wrp .profile figure {
    width: min(400px, 50%);
}

.about-wrp .profile figure img {
    width: 100%;
    height: auto;
}

.about-wrp .profile .text {
    width: min(300px, 45%);
}

.about-wrp .profile .name {
    display: inline-block;
    font-size: 1.1em;
    border-bottom: solid 1px #b71b22;
    margin-bottom: 1em;
}

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

    .about-wrp .profile {
        flex-wrap: wrap;
    }

    .about-wrp .profile figure {
        width: 100%;
    }

    .about-wrp .profile .text {
        width: 100%;
    }

    .about-wrp .profile .text p {
        margin: 1em auto 0;
        font-size: .9em;
    }
}


/* ====================================================
	rentalspace
==================================================== */
.rentalspace-wrp section {
    padding: 60px 0;
}

.rentalspace-wrp .rental-title {
    margin: 0 auto;
    padding-bottom: 1.2em;
    font-size: 1.4em;
    font-weight: normal;
    text-align: center;
}

.rentalspace-wrp .about-space p {
    margin: 0 auto 1em;
    font-size: min(1em, 3.8vw);
    line-height: 1.8em;
    text-align: center;
}

.rentalspace-wrp .about-space p.rental-lead {
    font-size: min(1.1em, 4.2vw);
    color: var(--gold);
    line-height: 2.2em;
}

.rentalspace-wrp .about-space .tel-wrp {
    font-size: 1.25em;
    color: var(--gold);
}

@media (max-width: 767px) {
    .rentalspace-wrp .about-space .tel-wrp {
        font-size: min(1.7em, 5.8vw);
        color: var(--gold);
    }
}

.rentalspace-wrp .about-space .tel-wrp .tel-list {
    margin: min(40px, 5vw) auto;

}

.rentalspace-wrp .about-space .tel-wrp .tel-list .ttl {
    font-size: min(.55em, 3.3vw);

}

/* example */
.rentalspace-wrp .example-title {
    margin: 2.5em auto 2em;
    font-weight: normal;
    text-align: center;
}

.rentalspace-wrp .example-title span {
    display: inline-block;
    padding: .5em 1em;
    margin-bottom: .8em;
    text-align: center;
    border: solid 1px #666;
}

.rentalspace-wrp .example {
    width: min(760px, 92%);
    margin: 0 auto;
    flex-wrap: wrap;
}

.rentalspace-wrp .example li {
    width: 25%;
    margin-bottom: 1em;
}

.rentalspace-wrp .example li:last-child {
    width: 50%;
}

@media (max-width: 660px) {
    .rentalspace-wrp .example li {
        width: 50%;
    }

    .rentalspace-wrp .example li:last-child {
        width: 100%;
    }
}

.rental-snslink {
    width: 100%;
    display: block;
    text-align: center;
    padding: .5em;
    margin-top: 2em;
}

.rental-snslink a {
    display: block;
    color: #b71b22;
    text-decoration: underline;
    font-size: min(1.3em, 5vw);
    margin-top: .5em;
}

/* price table */
.rentalspace-wrp .price-table {
    width: min(760px, 92%);
    border-collapse: collapse;
    border: 1px solid #ccc;
    margin: 2em auto 1.5em;
}

.rentalspace-wrp .price-table thead th {
    padding: 1em 0;
    background-color: #efebe4;
}

.rentalspace-wrp .price-table th,
.rentalspace-wrp .price-table td {
    padding: 1.5em .5em;
    font-weight: normal;
    border: 1px solid #ccc;
    text-align: center;
    line-height: 1.4;
    vertical-align: middle;
}

.rentalspace-wrp .price-table th {
    width: 33%;
}

.rentalspace-wrp .price-table td {
    width: 66%;
}

/* floorguide */
.rentalspace-wrp .floorguide {
    background-color: #efebe4;
}

.rentalspace-wrp .floorguide figure {
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
    padding: 0 20px;
}

.rentalspace-wrp .floorguide figure img {
    width: 100%;
    height: auto;
}

/* archives */
.rentalspace-wrp .archives {
    background-color: #f3f3f1;
}

.rentalspace-wrp .archives .event-archive-list {
    width: min(1200px, 92%);
    margin: 3em auto 0;
}

.rentalspace-wrp .archives .event-archive-list .post-entry {
    --item-width: 280px;
    gap: min(2.5em, 4vw) min(2.5em, 3vw);
}

.rentalspace-wrp .archives .event-archive-list .entry {
    width: auto;
}

.rentalspace-wrp .archives .event-archive-list .entry a {
    display: block;
    padding: min(40px, 4vw);
    border: 1px solid #ddd;
    background-color: #fff;
}

.rentalspace-wrp .archives .event-archive-list .entry .thumb {
    display: block;
    width: 100%;
    aspect-ratio: 1/1;
    margin-bottom: 1.2em;
}

.rentalspace-wrp .archives .event-archive-list .entry .thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.rentalspace-wrp .archives .event-archive-list .entry .meta-wrp {
    font-size: 0.8em;
    line-height: 1.5em;
}

.rentalspace-wrp .archives .event-archive-list .entry .meta-wrp p {
    display: none;
}


/* ====================================================
	access
==================================================== */

/* access */
.access-wrp section {
    padding: 60px 0;
    text-align: center;
}

.access-wrp .access-title {
    margin-bottom: 40px;
    font-size: 1.2em;
    font-weight: normal;
    letter-spacing: 0.05em;
    text-align: center;
}

.access-wrp .access-title span {
    display: block;
    margin-bottom: 20px;
    color: #8b774c;
    font-size: 36px;
}

#access .access-navi-wrp {
    width: 100%;
    padding: 20px;
    margin: 0 auto;
}

#access .access-navi-wrp #mapCanvas {
    width: 100%;
    max-width: 980px;
    height: 500px;
    background-color: #ccc;
    margin: 2em auto 1em;
}

#access .root {
    width: 100%;
    max-width: 840px;
    text-align: left;
    padding: 40px 0;
    box-sizing: border-box;
    margin: 0 auto;
}

#access .root .flex {
    width: 100%;
    min-width: 100%;
    margin: 50px auto 0;
    padding-bottom: 20px;
    border-bottom: 1px solid #ccc;
}

#access .root .title-wrp {
    width: 10%;
    margin-right: 2em;
}

#access .root .title-wrp h3 {
    margin-bottom: 1em;
    display: block;
    font-size: 1em;
    text-align: center;
    border: 1px solid #999;
    padding: .5em;
}

#access .root ul {
    display: block;
    width: 85%;
}

#access .root li {
    display: block;
    width: 100%;
}

#access .root h4 {
    margin-bottom: .75em;
    font-weight: normal;
}

#access .root p {
    display: block;
    text-align: left;
    position: relative;
    margin-left: 1.5em;
    margin-bottom: 1.5em;
}

#access .root p::before {
    content: '';
    display: block;
    width: 0;
    height: 0;
    border: solid 5px transparent;
    border-left: solid 8px #1e1e1e;
    position: absolute;
    left: -1.2em;
    top: 0.5em;
}

#access .root p a {
    text-decoration: underline;
    color: #8b774c;
}

@media screen and (max-width:640px) {
    #access .root .title-wrp {
        width: 100%;
        margin-right: 0;
    }

    #access .root ul {
        width: 100%;
        margin-bottom: 0;
    }

    #access .root p {
        font-size: .86em;
    }
}

/* location */
#location {
    background: url(https://storage.googleapis.com/tsukito/2020/11/6ed7a845-image-1536x688.jpeg) no-repeat center top;
    background-size: cover;
    color: #fff;
}

#location .access-title,
#location .access-title span,
#location .access-title+p {
    color: #fff;
}

#location .location-list {
    margin: 50px auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 2em;
}

@media screen and (max-width:70em) {
    #location .location-list {
        width: 40em;
    }

    @media screen and (max-width:36em) {
        #location .location-list {
            width: 94%;
            gap: 1em;
            font-size: min(1em, 3vw);
        }
    }
}

#location .location-list li {
    width: 8.2em;
    height: 8.2em;
    background-color: rgba(255, 255, 255, 0.9);
    border-radius: 50%;
    color: #8b774c;
    display: grid;
    place-items: center;
}

#location .location-list.en li {
    width: 9em;
    height: 9em;
    padding: 10px;
}

#location .location-list li p {
    line-height: 1.4em;
}

#location .location-list.en li p {
    font-size: 0.86em;
    line-height: 1.4em;
}

/* ====================================================
	stay
==================================================== */
.stay-wrp section {
    padding: 60px 0;
    text-align: center;
    overflow: hidden;
}

.stay-wrp .stay-title {
    margin: 0 auto;
    padding-bottom: 1.2em;
    font-size: 1.4em;
    font-weight: normal;
    text-align: center;
}

.stay-wrp p.stay-lead {
    margin: 0 auto 2em;
    font-size: min(1.1em, 4vw);
    color: var(--gold);
    line-height: 2em;
    transform: translateX(.5em);
}

.stay-wrp .gallery {
    background-color: #f9f9f9;
}

.stay-wrp .wp-block-gallery {
    width: min(1200px, calc(100% - 4em));
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(var(--item-width, min(380px, 100%)), 1fr));
    gap: 5px;
}

.wp-block-gallery.has-nested-images.columns-default figure.wp-block-image:not(#individual-image) {
    width: 100% !important;
}

/* ====================================================
	salon
==================================================== */

/* .salon-wrp {
    padding: min(80px, 10vw) min(30px, 5vw);
    background-color: #efebe4;
}

.salon-wrp .box{
    width: min(980px, 100%);
    margin: 0 auto;
    padding: 1.5em;
    background-color: #fff;
}

@media screen and (max-width:640px) {
    .salon-wrp .box{
        width: 100%;
        flex-direction: column;
    }
}

.salon-wrp .box:not(:last-child){
    margin: 0 auto 3em;
}

.salon-wrp .box .txt {
    width: 30%;
}

@media screen and (max-width:640px) {
    .salon-wrp .box .txt{
        width: 100%;
        margin: 0 auto 5vw;
    }
}

.salon-wrp .box .txt .salon-title {
    display: block;
    margin-bottom: 1em;
    padding: .5em 0 1em;
    letter-spacing: .05em;
    font-weight: normal;
    text-align: center;
    font-size: 1.1em;
    border-bottom: 1px solid #ccc;
}

.salon-wrp .box .txt p {
    width: 100%;
}

.salon-wrp .box .thumb {
    width: 67%;
    display: flex;
    justify-content: space-between;
}

@media screen and (max-width:640px) {
    .salon-wrp .box .thumb{
        width: 100%;
        margin: 0 auto;
        display: block ;
    }
}

.salon-wrp .cafe .thumb figure {
    width: 32%;
}

.salon-wrp .antique .thumb figure {
    width: 49%;
}

@media screen and (max-width:640px) {
    .salon-wrp .box .thumb figure{
        width: 100%;
        margin: 5px auto 0;
    }
}

.salon-wrp .box .thumb img {
    width: 100%;
    height: 200px;
    object-fit: cover;
} */