@charset "utf-8";

/* reset */
#page {
    font-family: unset;
    line-height: unset;
    overflow: unset;
    width: unset;
    min-width: unset;
    color: unset;
    font-weight: unset;
}
/* /reset */

/* all */
:root {
    --sp-fs10: 2.6667vw;
    --sp-fs11: 2.9334vw;
    --sp-fs12: 3.2vw;
    --sp-fs13: 3.4667vw;
    --sp-fs14: 3.7334vw;
    --sp-fs15: 4vw;
    --sp-fs16: 4.2667vw;
    --sp-fs17: 4.5334vw;
    --sp-fs18: 4.8vw;
    --sp-fs19: 5.0667vw;
    --sp-fs20: 5.3334vw;
    --sp-fs21: 5.6vw;
    --sp-fs22: 5.8667vw;
    --sp-fs23: 6.1334vw;
    --sp-fs24: 6.4vw;
}
* { box-sizing: border-box;}

#page { color: #404040;}

#page a {
    opacity: 1;
	transition: opacity .25s ease-in-out;
    text-decoration: none;
}
#page a:hover {
    opacity: .65;
    text-decoration: none;
}
img { width: 100%;}

figure,
picture {
    display: block;
}

#lux {
    font-family: m-plus-1p, sans-serif;
    padding-top: 34px;
}
#lux .heading {
    font-family: あおぞら明朝, serif;
    font-size: 26px;
    text-align: center;
    font-weight: 400;
    letter-spacing: .04em;
    padding-block: 59px 25px;
}
#lux .subheading {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 22px;
    font-weight: 500;
    margin-bottom: 24px;
    transform: rotate(0.05deg);/*m-plus-1pのジャギー対策*/
}
#lux .subheading::before,
#lux .subheading::after {
    content: "";
    display: block;
    width: 50px;
    height: 1px;
    margin-inline: 24px;
    background-color: #404040;
}
#lux .sp-only {
    display: none;
}
@media screen and (max-width: 700px) {
    #lux .heading {
        font-size: var(--sp-fs22);
        padding-block: 11% 6.5%;
    }
    #lux .subheading {
        font-size: var(--sp-fs18);
        margin-bottom: 5.9%;
    }
    #lux .pc-only {
        display: none;
    }
    #lux .sp-only {
        display: block;
    }
}
/* /all */

/* KV */
#lux h1 {
    font-size: 18px;
    text-align: center;
    font-weight: 400;
    padding-block: 19px;
    transform: rotate(0.05deg);/*m-plus-1pのジャギー対策*/
}
#lux .contents-lead {
    font-size: 16px;
    text-align: center;
    line-height: 1.8;
    padding-bottom: 80px;
    transform: rotate(0.05deg);/*m-plus-1pのジャギー対策*/
}

#lux .logo { margin-inline: auto;}
#lux .logo.suirankyoto { width: 87px;}
#lux .logo.shisuinara { width: 72px;}
#lux .logo.iraphsui-okinawamiyako { width: 70px;}

#lux .kv_wrapper {
    max-width: 1020px;
    margin: 0 auto;
}

@font-face {
    font-family: "あおぞら明朝";
    src: url(../font/AozoraMinchoMedium.ttf) format("truetype");
    font-weight: 300;
    font-style: normal;
}
@media screen and (max-width: 700px) {
    #lux { padding-top: 6%;}
    #lux .logo.suirankyoto { width: 19.625%;}
    #lux .logo.shisuinara { width: 16.295%;}

    #lux h1 {
        font-size: var(--sp-fs15);
        text-align: center;
        padding-block: 4.5% 4.3%;
    }
    #lux .contents-lead {
        font-size: var(--sp-fs15);
        padding-inline: 6%;
        padding-bottom: 13%;
        line-height: 1.6;
        text-align: left;
    }
}
/* /KV */

/* infinite-slider */
#lux .swiper {
    max-width: 1440px;
    margin-inline: auto;
}
#lux .infinite-slider {
	padding: 0;
}

#lux .infinite-slider .swiper-wrapper {
	transition-timing-function: linear;
}

#lux .infinite-slider .swiper-slide {
    width: 360px;
    height: 280px;
    margin-inline: 5px;
}
@media screen and (max-width:700px) {
    #lux .infinite-slider .swiper-slide {
        width: 63.2%;
        height: auto;
        margin-inline: 1%;
    }
}
/* /infinite-slider */

/* about_benefit */
#lux .about_benefit .heading {
    padding-block: 84px 59px;
}
#lux .plan_wrapper {
    padding-inline: 20px;
    padding-bottom: 80px;
}
#lux .gray-box {
    max-width: 780px;
    margin-inline: auto;
    background-color: #f8f8f8;
    padding-block: 30px;
}
#lux .gray-box .flex-box {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding-inline: 40px;
    padding-bottom: 18px;
}
#lux .gray-box .flex-box figure {
    width: 340px;
}
#lux .plan_text {
    padding-top: 10px;
}
#lux .plan_text p {
    font-size: 18px;
    line-height: 1.6;
    color: #404040;
    margin-bottom: 21px;
    transform: rotate(0.05deg);/*m-plus-1pのジャギー対策*/
}
#lux .plan_text p small {
    display: block;
    font-size: 15px;
}
#lux .plan_text .period small {
    font-size: 13px;
    margin-top: -4px;
}
#lux .gray-box .btn_reserve {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-inline: auto;
    width: 260px;
    height: 50px;
    background-color: #FFF;
    font-size: 16px;
    color: #444444;
    border: 1px solid currentColor;
}
#lux .gray-box .btn_reserve span {
    transform: rotate(0.05deg);/*m-plus-1pのジャギー対策*/
}
#lux .annotation {
    font-size: 13px;
    line-height: 1.6;
    color: #7a7a7a;
    text-align: center;
    transform: rotate(0.05deg);/*m-plus-1pのジャギー対策*/
    padding-top: 25px;
}
@media screen and (max-width:800px) {
    #lux .gray-box .flex-box {
        flex-direction: column;
        justify-content: flex-start;
        align-items: center;
    }
}
@media screen and (max-width:700px) {
    #lux .about_benefit .heading {
        padding-block: 13.4% 9.8%;
        line-height: 1.6;
    }
    #lux .subheading::before,
    #lux .subheading::after {
        width: 12.69%;
        margin-inline: 5.5%;
    }
    #lux .plan_wrapper {
        padding-inline: 5.3334%;
        padding-bottom: 12.6%;
    }
    #lux .gray-box {
        padding-block: 6% 7.3%;
    }
    #lux .gray-box .flex-box {
        padding-inline: 5.9702%;
        padding-bottom: 3.5%;
    }
    #lux .gray-box .flex-box figure {
        width: 100%;
    }
    #lux .plan_text {
        width: 100%;
        padding-top: 9%;
    }
    #lux .plan_text p {
        font-size: var(--sp-fs16);
        margin-bottom: 5.5%;
    }
    #lux .plan_text p small {
        display: block;
        font-size: var(--sp-fs13);
        margin-top: -0.3%;
    }
    #lux .plan_text .period small {
        font-size: 3.2vw;
    }
    #lux .gray-box .btn_reserve {
        font-size: var(--sp-fs15);
        width: 65.974%;
        height: auto;
        aspect-ratio: 1 / 0.1924;
    }
    #lux .annotation {
        font-size: var(--sp-fs12);
        text-align: left;
        padding-top: 6%;
    }
}
/* /about_benefit */

/* about_room */
#lux .about_room {
    background-color: #404040;
    padding: 56px 20px 54px;
}
#lux .about_room_wrapper {
    max-width: 1020px;
    margin-inline: auto;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}
#lux .about_room li {
    width: 490px;
}
#lux .about_room li p {
    color: #FFF;
}
#lux .about_room li .room-type {
    font-family: sofia-pro, sans-serif;
    font-size: 24px;
    letter-spacing: .04em;
    padding-block: 13px 20px;
}
#lux .about_room li .room-type span {
    font-family: m-plus-1p, sans-serif;
    font-size: 16px;
    transform: rotate(0.05deg);/*m-plus-1pのジャギー対策*/
    margin-left: 16px;
    letter-spacing: 0;
}
#lux .about_room li .room-caption {
    font-size: 16px;
    transform: rotate(0.05deg);/*m-plus-1pのジャギー対策*/
    line-height: 1.8;
}
@media screen and (max-width:1060px) {
    #lux .about_room li {
        width: 48%;
    }
}
@media screen and (max-width:700px) {
    #lux .about_room {
        padding: 10.7% 5.3334% 1.3%;
    }
    #lux .about_room_wrapper {
        display: block;
    }
    #lux .about_room li {
        width: 100%;
        padding-bottom: 10.5%;
    }
    #lux .about_room li .room-type {
        font-size: var(--sp-fs21);
    }
    #lux .about_room li .room-type span {
        font-size: var(--sp-fs14);
        margin-left: 4%;
    }
    #lux .about_room li .room-caption {
        font-size: var(--sp-fs14);
    }
    #lux .about_room li .room-type {
        padding-block: 3.5% 4%;
    }
}
/* /about_room */

/* reserve_room */
#lux .reserve_wrapper {
    padding: 80px 20px;
}
#lux .reserve_text {
    font-size: 18px;
    text-align: center;
    transform: rotate(0.05deg);/*m-plus-1pのジャギー対策*/
    padding-bottom: 25px;
}
#lux .reserve_wrapper .subheading {
    margin-bottom: 9px;
}
#lux .reserve_wrapper dl {
    transform: rotate(0.05deg);/*m-plus-1pのジャギー対策*/
}
#lux .reserve_wrapper dt {
    font-size: 18px;
    text-align: center;
    line-height: 1.8;
    padding-bottom: 8px;
}
#lux .reserve_wrapper dd {
    font-size: 15px;
    text-align: center;
    padding-bottom: 33px;
}
#lux .reserve_wrapper .gray-box {
    padding-block: 30px 10px;
}
@media screen and (max-width:700px) {
    #lux .reserve_wrapper {
        padding: 13% 5.3334%;
    }
    #lux .reserve_text {
        font-size: var(--sp-fs16);
        padding-bottom: 5.7%;
    }
    #lux .reserve_wrapper .gray-box {
        padding-block: 6.7% 2.5%;
        padding-inline: 6%;
    }
    #lux .reserve_wrapper dt {
        font-size: var(--sp-fs16);
        padding-bottom: 2.2%;
    }
    #lux .reserve_wrapper dd {
        font-size: var(--sp-fs14);
        line-height: 1.8;
        padding-bottom: 6.5%;
    }
}
/* /reserve_room */

/* footer */
#lux footer {
    background-color: #CCCCCC;
    padding-block: 80px;
}
#lux footer address {
    font-style: normal;
}
#lux footer dl {
    color: #404040;
    transform: rotate(0.05deg);/*m-plus-1pのジャギー対策*/
}
#lux footer dl a {
    color: #404040;
}
#lux footer dt {
    font-size: 16px;
    line-height: 1.6;
    text-align: center;
    padding-bottom: 20px;
}
#lux footer dd {
    font-size: 15px;
    line-height: 2;
    text-align: center;
}
#lux address dt a::after {
    content: "";
    display: inline-block;
    width: 14px;
    height: 14px;
    background-image: url(../img/lux/icon_external.svg);
    background-size: 100%;
    background-repeat: no-repeat;
    margin-bottom: -1px;
    margin-left: 5px;
}
@media screen and (max-width:700px) {
    #lux footer {
        padding-block: 13% 9.5%;
        padding-inline: 5.3334%;
    }
    #lux footer dt {
        font-size: var(--sp-fs14);
        padding-bottom: 4.5%;
        text-align: left;
    }
    #lux footer dd {
        font-size: var(--sp-fs13);
        text-align: left;
        line-height: 1.6;
    }
    #lux footer dd p {
        padding-bottom: 3.5%;
    }
    #lux address dt a::after {
        width: 3.5821%;
        height: auto;
        aspect-ratio: 1;
        margin-bottom: -0.1%;
        margin-left: 1.1%;
    }
}
/* /footer */