@charset "utf-8";

/* 共通 */
/* =========================================== */
main {
    font-family: "Open Sans", sans-serif;
    font-size: 14px;
    font-weight: 400;
    font-style: normal;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    color: #000;
    margin-top: 75px;
    overflow-x: hidden;
}

.ly-inner {
    margin: 0 auto;
    padding: 0 50px;
    max-width: 1300px;
}

.pc-only {
    display: block !important;
}

.sp-only {
    display: none !important;
}

.orange {
    color: #FF6A14;
}

/* フォント */
@font-face {
    font-family: "Hannari";
    src: url("../fonts/Hannari.otf") format("woff");
}

@font-face {
    font-family: "PorterBold";
    src: url("../fonts/Porter_Bold.ttf") format("woff");
}

@font-face {
    font-family: "SnellRoundhand";
    src: url("../fonts/SnellRoundhand.ttc") format("woff");
}

.SnellRoundhand {
    font-family: "SnellRoundhand", serif;
}

.Hannari {
    font-family: "Hannari", serif;
}

.PorterBold {
    font-family: "PorterBold", serif;
}

.sorts-mill-goudy {
    font-family: "Sorts Mill Goudy", serif;
}

.open-sans {
    font-family: "Open Sans", sans-serif;
}

.noto-sans-cjk {
    font-family: "noto-sans-cjk-jp", sans-serif;
}

/* 縦書きh3タイトル */
.vertical-lv3-heading {
    font-size: 36px;
    letter-spacing: -.08em;
    color: #000;
    display: flex;
    align-items: center;
    margin-left: -17px;
    line-height: 1;
    position: relative;
}

.vertical-lv3-heading--en {
    font-size: 32px;
    color: #000;
    letter-spacing: .06em;
    position: relative;
    writing-mode: vertical-rl;
    line-height: 1.468;
    padding-right: 16px;
    margin-right: 30px;
}

.vertical-lv3-heading--en::after {
    position: absolute;
    content: "";
    width: 1px;
    height: 100%;
    top: 50%;
    transform: translateY(-50%);
    right: 0;
    background-color: #000;
}

/* h4タイトル */
.lv4-heading {
    font-size: 28px;
    line-height: 1.636;
    padding-bottom: 4px;
    letter-spacing: -.08em;
    min-width: 500px;
}

/* おすすめ一覧ボタン */
.recommend-btn {
    font-size: 14px;
    letter-spacing: .09em;
    width: 398px;
    max-width: 100%;
    height: 58px;
    position: relative;
    margin: 15px auto 0;
}

.recommend-btn + .recommend-btn {
    margin: 41px auto 0;
}

.recommend-btn::after {
    position: absolute;
    content: "";
    right: 4px;
    bottom: 4px;
    clip-path: polygon(100% 0, 0% 100%, 100% 100%);
    width: 10px;
    height: 10px;
    background-color: #fff;
    cursor: pointer;
}

.recommend-btn a {
    background-color: #CAB79A;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.online_store-btn {
    width: 300px;
    margin: 80px auto 0 auto;
}

.online_store-btn a {
    display: block;
    background-color: #C6B076;
    width: 300px;
    font-size: 18px;
    text-align: center;
    padding: 20px;
    }

a {
    opacity: 1;
   transition: .3s;
}


@media(hover: hover) {
    a:hover {
        opacity: 0.6;
    }
}

@media(max-width: 1279px) {
    .vertical-lv3-heading--en {
        font-size: 32px;
    }

    .vertical-lv3-heading {
        font-size: 30px;
    }
}


@media screen and (max-width: 743px) {
    .pc-only {
        display: none !important;
    }
    .sp-only {
        display: block !important;
    }

    .ly-inner {
        padding: 0 20px;
    }

    .vertical-lv3-heading--en {
        font-size: 20px;
        margin-right: 18px;
    }

    .vertical-lv3-heading {
        margin-left: 12px;
    }

    .recommend-btn {
        width: auto;
        margin-right: 20px;
        font-size: 16px;
    }
}

/* スライダー */
/* ========================================== */
.sect__cont {
    margin-top: 92px;
}

.scroll-wrap {
    position: relative;
}

.scroll-wrap + .scroll-wrap {
    margin-top: 86px;
}
  
.scroll {
    width: 100%;
    background-color: unset;
    overflow: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-color: unset;
    scrollbar-width: none;
}

.scroll__list {
    white-space: nowrap;
    max-width: 1200px;
    min-width: 700px;
    margin: 0 auto;
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: flex-start;
}

.scroll__list--3col {
    width: 75%;
}

.scroll__list {
    margin: -81px 0 0 -8px;
}

.scroll__name {
    font-size: 16px;
    line-height: 1.56;
    padding-top: 8px;
}

.scroll__img {
    background-color: #F4F4F4;
    display: block;
    height: 302px;
}

.scroll__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.scroll__item {
    width: calc(100% / 4 - 8px);
    min-height: 100%;
    display: inline-block;
    margin: 81px 0 0 8px;
}

.scroll__item--3col {
    width: calc(100% / 3 - 8px);
}

.scroll-nav::-webkit-scrollbar {
    width: 5px;
    height: 6px;
}

.scroll-nav::-webkit-scrollbar-track {
    border-radius: 10px;
    background-color: #333;
}

.scroll-nav::-webkit-scrollbar-thumb {
    border-radius: 10px;
    background-color: rgba(255, 255, 255, 0.6);
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.3);
}

@media(max-width: 1279px) {
    .scroll__name {
        font-size: 13px;
    }

    .scroll__img {
        height: initial;
    }

    .scroll__img img {
        object-fit: contain;
    }

    .sect__cont {
        margin-top: 80px;
    }
}

@media(max-width: 1024px) {
    .scroll__name {
        letter-spacing: -.08em;
    }
}

@media(max-width: 959px) {
    .scroll {
        overflow-x: auto;
    }

    .scroll__list {
        flex-wrap: nowrap;
    }

    .scroll__item {
        min-width: 294px;
        width: 32.56%;
    }
}

@media(max-width: 743px) {
    .scroll-wrap {
        padding-left: 18px;
    }

    .sect__cont {
        margin-top: 48px;
    }

    .scroll-wrap + .scroll-wrap {
        margin-top: 60px;
    }

    .scroll__name {
        letter-spacing: 0;
        font-size: 16px;
    }

    .scroll__name--ls-minus {
        letter-spacing: -.08em;
    }
}

/* pht */
/* ================================ */
.sec_pht {
    padding: 0 20px;
    margin-bottom: 120px;
    position: relative;
}
.sec_pht .about {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 880px;
    margin: 0 auto 40px;
}
.sec_pht .about img {
    width: 49%;
}
.sec_pht .about p {
    width: 49%;
    text-align: right;
}
.sec_pht .about_text {
    font-size: 18px;
    font-weight: 700;
    text-align: center;
    margin-bottom: 90px;
}
.sec_pht .flow {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 880px;
    min-height: 330px;
    margin: 0 auto 80px;
    padding: 40px 50px 35px;
    border: 5px solid #ff6a14;
    border-radius: 22px;
}
.sec_pht .flow_item {
    display: flex;
    flex-flow: column;
    align-items: center;
    position: relative;
    width: 22%;
}
.sec_pht .flow_item p {
    text-align: center;
    line-height: 1.4;
    position: absolute;
    bottom: -60px;
}
.sec_pht .flow_item .title_pht {
    font-size: 16px;
    font-weight: 700;
    top: -50px;
    bottom: auto;
}
.sec_pht .flow_1 .title_pht {
    top: -60px;
}
.sec_pht .flow_3 .title_pht {
    font-weight: 400;
    top: 0;
    bottom: 0;
    margin: auto;
    height: fit-content;
}
.sec_pht .flow_item img {
    width: 85%;
    border-radius: 30px;
}
.sec_pht ul {
    max-width: 710px;
    margin: 0 auto;
}
.sec_pht ul li {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 16px;
    margin-bottom: 20px;
}
.sec_pht ul li span {
    width: 140px;
    height: 35px;
    padding-right: 13px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-weight: 700;
    color: #fff;
    background-color: #ff6a14;
    clip-path: polygon(0 0, 100% 0%, 84% 100%, 0% 100%);
}
.sec_pht ul li p {
    width: 73%;
}
.sec_pht .text {
    font-size: 16px;
    text-align: center;
}
@media screen and (max-width: 768px) {
    .sec_pht {
        padding: 0 20px 40px;
        margin-bottom: 40px;
    }
    .sec_pht::after {
        width: 88%;
    }
    .sec_pht .about {
        display: block;
        margin: 0 auto 30px;
    }
    .sec_pht .about img {
        width: 300px;
        margin: 0 auto 15px;
    }
    .sec_pht .about p {
        width: 100%;
        text-align: center;
    }
    .sec_pht .about_text {
        font-size: 16px;
        margin-bottom: 40px;
    }
    .sec_pht .flow {
        flex-wrap: wrap;
        margin: 0 auto 80px;
        padding: 70px 20px 50px;
        position: relative;
    }
    .sec_pht .flow_item {
        width: 44%;
    }
    .sec_pht .flow_3 {
        width: 100%;
        margin: 80px auto;
    }
    .sec_pht .flow_4 {
        width: 100%;
    }
    .sec_pht .flow_item .title_pht {
        font-size: 14px;
        line-height: 1.2;
        top: -30px;
    }
    .sec_pht .flow_1 .title_pht {
        top: -40px;
    }
    .sec_pht .flow_3 .title_pht {
        top: 0;
    }
    .sec_pht .flow_item p {
        font-size: 12px;
        bottom: -40px;
    }
    .sec_pht .flow_4 p {
        bottom: -23px;
    }
    .sec_pht .flow_item img {
        width: 90%;
    }
    .sec_pht .flow_3 img {
        width: 30%;
    }
    .sec_pht .flow_4 img {
        width: 96%;
        aspect-ratio: 2 / 1;
        object-fit: cover;
        object-position: bottom;
    }
    .sec_pht .arrow-3 {
        position: absolute;
        top: 37%;
        left: 0;
        right: 0;
        margin: auto;
        transform: rotate(90deg);
    }
    .sec_pht .arrow-4 {
        position: absolute;
        bottom: 39%;
        left: 0;
        right: 0;
        margin: auto;
        transform: rotate(90deg);
    }
    .sec_pht ul li {
        display: block;
        font-size: 14px;
    }
    .sec_pht ul li span {
        font-size: 16px;
        margin-bottom: 10px;
    }
    .sec_pht ul li p {
        width: 100%;
        text-align: justify;
    }
    .sec_pht .text {
        font-size: 14px;
        margin-top: 40px;
    }
}

/* LINE */
/* ================================ */
.line_bnr {
    position: fixed;
    bottom: 5dvh;
    left: 0;
    right: 0;
    margin: auto;
    width: 100%;
    max-width: 1320px;
    padding-right: 20px;
    z-index: 999;
}
.line_bnr a {
    display: block;
    width: fit-content;
    height: 100%;
    margin-left: auto;
}
@media screen and (max-width: 768px) {
    .line_bnr a img {
        width: 145px;
    }
}

/* ヘッダー */
/* ================================ */
header {
    padding: 15px 0 15px;
    width: 100%;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 999;
    background-color: #fff;
}

header .header-wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    max-width: 1300px;
}

header .header-wrap__logo {
    width: 180px;
    margin: 0;
}
.header-wrap__logo img {
    width: 100%;
}
.l-container {
    max-width: 1300px;
    margin: 0 auto;
    padding: 0 50px;
}

@media only screen and (max-width: 370px) {
    header .header-wrap__logo {
        width: 120px;
    }
}

header .header-wrap .nav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

header .header-wrap .nav--item:not(:last-child) {
    margin-right: 25px;
}

header .header-wrap .nav--item:nth-child(3) a img {
    width: 19px;
}

header .header-wrap .nav--link img {
    width: 30px;
}

@media only screen and (max-width: 1200px) {
    .l-container {
        padding: 0 20px;
    }
}

/* フッダー */
/* ================================ */
footer {
    position: relative;
    -webkit-transition: -webkit-transform 0.3s;
    transition: -webkit-transform 0.3s;
    transition: transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s;
    background-color: #3c3f42;
    font-family: "M PLUS 1p", sans-serif;
    font-size: 12px;
    padding-bottom: 24px;
    line-height: initial;
}

footer .menu__item__link {
    cursor: default;
    color: #fff !important;
}

footer a {
    color: #fff !important;
    display: block;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

footer a:hover {
    color: #686868;
}

footer .footsns {
    text-align: center;
    margin-top: 20px;
}

footer .footsns ul {
    list-style: none;
    text-align: center;
}

footer .footsns ul li {
    display: inline-block;
    width: 70px;
}

footer .footsns ul li:first-child {
    margin-left: 0;
}

footer .footsns ul li a i {
    font-size: 30px;
}

footer .container-fluid {
    max-width: 1300px;
    margin: 0 auto;
    padding: 40px 50px 0;
}

@media only screen and (max-width: 1000px) {
    footer .container-fluid {
        padding: 40px 20px 0;
    }
}

footer .container-fluid .footer_after {
    width: 450px;
    margin: 0 auto 0 auto;
}

@media only screen and (max-width: 768px) {
    footer .container-fluid .footer_after {
        width: 100%;
        margin: 0 auto;
    }
}

footer .container-fluid .footer_after .footer_logo {
    width: 160px;
    margin: 0 auto 10px;
}

@media only screen and (max-width: 768px) {
    footer .container-fluid .footer_after .footer_logo {
        text-align: center;
        margin: 1em auto;
    }
}

footer .container-fluid .footer_after .link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

footer .container-fluid .footer_logo_area {
    margin-top: 30px;
    text-align: center;
    color: #fff;
}

footer .container-fluid .footer_logo_area .copyright {
    font-size: 1.2em;
    font-weight: bold;
    color: #fff;
    line-height: 32px;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

footer .container-fluid .footer_logo_area .copyright small {
    color: #fff;
}
@media only screen and (max-width: 767px) {
    footer .container-fluid .footer_logo_area .copyright {
        line-height: 26px;
    }
}


/* mv */
/* ========================================== */
.mv__top {
    position: relative;
}

.mv__bg img {
    width: 100%;
}
.mv__l-txt {
    position: absolute;
    top: 31px;
    left: 26px;
    color: #fff;
    font-size: 14.36px;
    letter-spacing: .3em;
    line-height: 1;
    writing-mode: vertical-rl;
    text-transform: uppercase;
}

.mv__lv2-lead {
    position: absolute;
    bottom: 122px;
    left: 49px;
    color: #fff;
    font-size: 22.15px;
}

.mv__lv2-heading {
    position: absolute;
    bottom: 44px;
    left: 69px;
    color: #fff;
    font-size: 36.8px;
    line-height: 1.25;
}

.mv__lv2-heading--lg {
    position: relative;
}

.mv__lv2-heading--lg::before {
    position: absolute;
    content: "";
    background-image: url(../images/2405/mv/mv-parentheses01.png);
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    width: 12px;
    height: 40px;
    top: -15px;
    left: -16px;
}

.mv__lv2-heading--lg::after {
    position: absolute;
    content: "";
    background-image: url(../images/2405/mv/mv-parentheses02.png);
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    width: 12px;
    height: 40px;
    top: 8px;
    right: -13px;
}

.mv__lv2-heading--sm {
    font-size: 24px;
    display: block;
    padding-left: 9px;
}

.mv__bottom {
    background-color: #CAB79A;
    text-align: center;
    padding: 42px 0 57px 0;
}

.mv__bottom-lead {
    font-size: 23.48px;
    line-height: 1.528;
    color: #fff;
}

.mv__bottom-ttl {
    font-size: 36px;
    line-height: 1.3;
    color: #fff;
    margin-top: 12px;
    font-feature-settings: "palt";
}

.mv__bottom-ttl--ml {
    margin-left: -15px;
}

.mv__bottom-ttl--mr {
    margin-right: -15px;
}

.mv__bottom-ttl--en {
    font-size: 20px;
    line-height: 1;
    position: relative;
    margin-top: 12px;
}

.mv__bottom-ttl--en-deco {
    font-size: 36px;
}

@media(max-width: 743px) {
    .mv .ly-inner {
        padding: 0;
    }

    .mv__l-txt {
        top: 57px;
        left: initial;
        right: 20px;
        font-size: clamp(14.36px, 3.82vw, 28px);
        writing-mode: unset;
    }

    .mv__lv2-lead {
        font-size: clamp(22.15px, 5.9vw, 44.3px);
        left: 23px;
    }

    .mv__lv2-heading {
        left: 43px;
    }
    
    .mv__bottom-ttl {
        font-size: 26px;
        line-height: 1.335;
        margin-top: 6px;
    }

    .mv__bottom-ttl--ml {
        margin-left: -10px;
    }
    
    .mv__bottom-ttl--mr {
        margin-right: -10px;
    }

    .mv__bottom-lead {
        font-size: 23.48px;
        line-height: 1.3;
        color: #fff;
    }

    .mv__bottom-ttl--en {
        font-size: 15px;
    }

    .mv__bottom-ttl--en-deco {
        font-size: 28.8px;
    }

    .mv__bottom {
        padding: 42px 0 39px 0;
    }
}

/* recommend */
/* ========================================== */
/* 横書きタイトル */
.horizontal-lv3-heading {
    font-size: 30px;
    letter-spacing: -.08em;
    color: #000;
    margin-bottom: 22px;
}

.horizontal-lv3-heading--en {
    font-size: 32px;
    color: #D2C197;
    letter-spacing: .06em;
    position: relative;
    padding-right: 33px;
    margin-right: 25px;
}

.horizontal-lv3-heading--en::after {
    position: absolute;
    content: "";
    width: 1px;
    height: 28px;
    top: 50%;
    transform: translateY(-50%);
    right: 0;
    background-color: #D2C197;
}

.recommend .ly-inner {
    padding-top: 219px;
    padding-bottom: 205px;
}

@media(max-width: 1279px) {
    .recommend .ly-inner {
        padding-top: 160px;
        padding-bottom: 170px;
    }

    .horizontal-lv3-heading--en {
        font-size: 30px;
    }

    .horizontal-lv3-heading {
        font-size: 28px;
    }
}

@media(max-width: 743px) {
    .recommend .ly-inner {
        padding-right: 0;
        padding-left: 0;
        padding-top: 79px;
        padding-bottom: 146px;
    }

    .horizontal-lv3-heading--en {
        display: block;
        padding-right: 0;
        margin-right: 0;
    }

    .horizontal-lv3-heading {
        font-size: 30px;
        text-align: center;
        display: inline-block;
    }

    .horizontal-lv3-heading--en::after {
        width: 100%;
        height: 1px;
        top: initial;
        bottom: 0;
        transform: translateY(-50%);
        right: 0;
    }

    .recommend__ttl-wrap {
        text-align: center;
    }
}


/* scene */
/* ========================================== */
.scene {
    background-color: #F1EAE0;
}

.scene .ly-inner {
    padding-top: 189px;
    padding-bottom: 78px;
}

@media(max-width: 1279px) {
    .scene .ly-inner {
        padding-top: 152px;
        padding-bottom: 62px;
    }
}

@media(max-width: 743px) {
    .scene .ly-inner {
        padding-right: 0;
        padding-left: 0;
    }
}
/* カテゴリーボタン */
/* ---------------------------- */
.category-btn-wrap {
    max-width: 933px;
    padding: 0 50px;
    margin: 0 auto;
    position: relative;
}

.category-btn-unit {
    display: flex;
    margin: 0 0 0 -35.5px;
    width: 100%;
    position: absolute;
    top: -57px;
    left: 50%;
    transform: translate(-50%);
}

.category-btn-item {
    width: calc(100% / 3 - 71px);
    margin: 0 0 0 71px;
    display: flex;
    justify-content: center;
    position: relative;
}

.category-btn-item a {
    width: 100%;
    text-align: center;
}

.category-btn-item--en {
    padding-top: 11px;
    border-top: #000 1px solid;
    line-height: 3.35;
    font-size: 10px;
    letter-spacing: 1.45em;
}

.category-btn-item--ja {
    letter-spacing: 0;
    top: -50%;
    line-height: 1.4;
    padding: 15px 0;
    font-size: 15px;
    text-align: center;
}

.category-btn-item::after {
    position: absolute;
    content: "";
    background-color: #fff;
    clip-path: polygon(50% 100%, 10% 34%, 90% 34%);
    width: 24px;
    height: 24px;
    bottom: -27px;
}

@media(max-width: 743px) {
    .category-btn-item {
        width: calc(100% / 3 - 20px);
        margin: 0 0 0 20px;
    }

    .category-btn-unit {
        width: 89.33%;
        margin: 0 auto;
    }

    .category-btn-wrap {
        padding: 0 20px;
        margin: 0 0 0 -20px;
    }

    .category-btn-item--ja {
        font-size: 15px;
        padding: 8px 0;
    }

    .category-btn-item--en {
        padding-top: 9px;
        line-height: 1.35;
        font-size: 14px;
        letter-spacing: .02em;
    }

    .category-btn-item::after {
        width: 18px;
        height: 18px;
        bottom: -23px;
    }
}

/* price */
/* ========================================== */
.price {
    background-color: #fff;
}

.price .ly-inner {
    padding-top: 148px;
    padding-bottom: 173px;
}

@media(max-width: 1279px) {
    .price .ly-inner {
        padding-top: 100px;
        padding-bottom: 120px;
    }
}

@media(max-width: 743px) {
    .price .ly-inner {
        padding: 87px 0 103px 0;
    }
}

/* trouble */
/* ========================================== */
.trouble {
    position: relative;
}

.trouble .ly-inner {
    padding-top: 139px;
}

.trouble__bk {
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: #F1EAE0;
    height: 80.1%;
}

.trouble-lv4-heading {
    font-size: 24px;
    line-height: 1.9;
    padding-bottom: 4px;
    letter-spacing: -.08em;
}

@media(max-width: 1279px) {
    .trouble .ly-inner {
        padding-top: 100px;
    }

    .trouble-lv4-heading {
        font-size: 22px;
    }
}

@media(max-width: 743px) {
    .trouble .ly-inner {
        padding: 87px 0 101px 0;
    }

    .trouble-lv4-heading {
        font-size: 24px;
    }

    .trouble__bk {
        height: 100%;
    }
}

/* cta */
/* ========================================== */
.cta {
    width: 595px;
    max-width: 100%;
    margin: 161px auto 120px;
}

.cta img {
    width: 100%;
}

@media(max-width: 1279px) {
    .cta {
        margin: 120px auto 90px;
    }
}

@media(max-width: 743px) {
    .cta {
        margin: 103px 20px 108px;
        width: auto;
    }

    .cta img {
        width: 100%;
    }
}

/* wrapping */
/* ========================================== */
.wrapping__col-wrap {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.wrapping-lv3-heading {
    transform: translateY(20%);
}

.wrapping-lv3-heading--en {
    display: block;
    font-size: 20px;
    letter-spacing: .81em;
    line-height: 2.35;
}

.wrapping-lv3-heading--border {
    display: block;
    border-top: 1px solid #000;
    font-size: 36px;
    letter-spacing: -.08em;
    line-height: 1.27;
    padding-top: 9px;
}

.wrapping__col-img {
    width: 45.916%;
    position: relative;
}

.wrapping__col-img img {
    width: 100%;
}

.wrapping {
    position: relative;
}

.wrapping__bk {
    position: absolute;
    bottom: 0;
    right: 0;
    left: 0;
    top: 38.45%;
    background-color: #F3F3F3;
}

.wrapping__3col {
    padding-top: 72px;
    padding-bottom: 82px;
}

.wrapping__3col-list {
    position: relative;
    display: flex;
    justify-content: space-evenly;
    gap: 100px;

}

.wrapping__3col-item {
    width: calc(100% / 2);
}

/* .wrapping__col-l {
    width: 28%;
} */

.wrapping__col-r {
    width: calc(100% - 28% - 56px);
}

.wrapping__3col-img {
    width: 100%;
}

.wrapping__3col-img img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    aspect-ratio: 390/297;
}

.wrapping__3col-txt {
    font-size: 20px;
    text-align: center;
    line-height: 1.395;
    padding-top: 17px;
}

.wrapping__3col-txt--sm {
    font-size: 13px;
    padding-top: 6px;
}

/* 20240528追加 */
.wrapping__3col-txt--ssm {
    text-align: center;
    font-size: 14px;
    letter-spacing: 0.5rem;
    line-height: 0.9rem;
}
/* 20240528追加ここまで */

.wrapping__bottom-outer {
    padding-top: 103px;
    padding-bottom: 145px;
}

.wrapping__bottom {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
}

.wrapping__bottom-txt {
   color: #CAB79A;
   font-size: clamp(27px, 2.63vw, 36px);
   font-weight: 700;
   line-height: 1.44;
   text-align: center;
   display: block;
   width: 31.75%;
}

.wrapping__bottom-img {
    width: 33.5%;
}

.wrapping__bottom-img img {
    width: 100%;
}

@media(max-width: 1279px) {
    .wrapping-lv3-heading--en {
        font-size: 18px;
    }

    .wrapping-lv3-heading--border {
        font-size: 34px;
        padding-top: 5px;
    }

    .wrapping__bk {
        top: 34.45%;
    }

    .wrapping__3col-txt {
        font-size: 16px;
    }

    .wrapping__3col-txt--sm {
        font-size: 12px;
        padding-right: 10px;
        padding-left: 10px;
    }
}

@media(max-width: 743px) {
    .wrapping__bottom-outer {
        padding-right: 0;
        padding-left: 0;
    }

    .wrapping__col-wrap {
        display: block;
    }

    .wrapping .ly-inner {
        padding-right: 0;
        padding-left: 0;
    }

    .wrapping-lv3-heading {
        text-align: center;
        transform: none;
    }

    .wrapping-lv3-heading--border {
        display: inline-block;
        font-size: 30px;
        padding-top: 9px;
    }

    .wrapping-lv3-heading--en {
        display: block;
        margin-left: 3.5%;
    }

    .wrapping__col-img {
        width: 100%;
        margin-top: 0;
    }

    .wrapping__3col-list {
        display: block;
    }

    .wrapping__3col-item {
        width: 100%;
        margin: 0 auto;
    }

    .wrapping__3col-item + .wrapping__3col-item {
        margin-top: 42px;
    }

    .wrapping__3col-item:nth-child(1),
    .wrapping__3col-item:nth-child(2) {
        max-width: 330px;
    }

    .wrapping__3col-item:nth-child(3) .wrapping__3col-img img {
        aspect-ratio: 335/106;
    }

    .wrapping__3col-img {
        width: 100%;
        max-width: 550px;
        margin: 0 auto;
    }
    
    .wrapping__3col {
        padding: 47px 20px 50px;
    }

    .wrapping__bk {
        top: 100px;
    }

    .wrapping__3col-txt {
        font-size: 20px;
        padding-top: 12px;
    }

    .wrapping__3col-txt--sm {
        font-size: 13px;
        text-align: left;
        max-width: 300px;
        margin: 0 auto;
        padding-right: 0;
        padding-left: 0;
    }

    .wrapping__bottom {
        display: block;
    }

    .wrapping__bottom-txt {
        width: 100%;
    }

    .wrapping__bottom-img {
        width: 80%;
        margin: 30px auto 0;
    }

    .wrapping__bottom-outer {
        padding-top: 62px;
        padding-bottom: 77px;
    }
}

/* shop */
/* ========================================== */
.shop {
    text-align: center;
}

.shop-lv3-heading {
    font-size: 28px;
    letter-spacing: -.08em;
    line-height: 1.27;
    margin-bottom: 15px;
}

.shop__bg {
    background-image: url(../images/2405/shop/shop-bg.jpg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    padding: 116.5px 0;
}

.shop__btn {
    font-size: 24px;
    letter-spacing: .09em;
    margin: 0 auto;
}

.shop__btn a {
    background-color: rgb(248 228 197 / 70%);
}

.shop__btn::after {
    mix-blend-mode: plus-lighter;
}

@media(max-width: 1279px) {
    .shop__btn a {
        font-size: 20px;
    }

    .shop__bg {
        padding: 105px 0;
    }
}

@media(max-width: 743px) {
    .shop-lv3-heading {
        font-size: 30px;
        margin-bottom: 17px;
    }

    .shop__bg {
        padding: 56px 20px;
    }
}

/* banner */
/* ========================================== */

.banner .ly-inner {
    padding-top: 184px;
    padding-bottom: 118px;
    padding-right: 0;
    padding-left: 0;
}

.sns {
    text-align: center;
    margin-top: 155px;
    margin-bottom: 118px;
}

.sns__ttl {
    font-size: 39.04px;
    line-height: 1.56;
    color: #C6B076;
    position: relative;
    display: inline-block;
    margin-bottom: 17px;
}

.sns__ttl::before {
    position: absolute;
    content: "";
    width: 3px;
    height: 35.47px;
    background-color: #C6B076;
    transform: rotate(-24deg);
    left: -18px;
    top: 11px;
}

.sns__ttl::after {
    position: absolute;
    content: "";
    width: 3px;
    height: 35.47px;
    background-color: #C6B076;
    transform: rotate(24deg);
    top: 10px;
    right: -17px;
}

.sns__list {
    display: flex;
    align-items: center;
    justify-content: center;
}

.sns__item {
    width: 71px;
    height: 71px;
    object-fit: contain;
    margin: 0 10px;
}

.sns__item a {
    display: block;
}

.sns__item a img {
    width: 100%;
}

.banner__img {
    /* width: 80%; */
    max-width: 750px;
    margin: 0 auto;
}

.banner__img  a {
    display: block;
}

.banner__img a img {
    width: 100%;
}

/* naganuma */

.banner__img2 {
    /* width: 80%; */
    max-width: 1073px;
    margin: 100px auto 0;
}

.banner__img2  a {
    display: block;
    text-align: center;
}

.banner__img2 a img {
    width: 100%;
}


@media(max-width: 1279px) {
    .banner .ly-inner {
        padding-top: 110px;
        padding-bottom: 100px;
    }

    .sns {
        margin-top: 100px;
        margin-bottom: 80px;
    }

    .sns__ttl {
        font-size: 30px;
        margin-bottom: 12px;
    }

    .sns__ttl::before {
        height: 30px;
        left: -17px;
        top: 9px;
    }

    .sns__ttl::after {
        height: 30px;
        top: 7px;
        right: -17px;
    }

    .sns__item {
        width: 60px;
        height: 60px;
        margin: 0 8px;
    }
}

@media(max-width: 743px) {
    .sns {
        margin-top: 41px;
        margin-bottom: 31px;
    }

    .banner .ly-inner {
        padding-top: 93px;
        padding-bottom: 20px;
    }

    .sns__ttl {
        font-size: 26.39px;
        margin-bottom: 10px;
        line-height: 1.56;
    }

    .sns__ttl::before,
    .sns__ttl::after {
        width: 2px;
        height: 23.97px;
    }

    .sns__ttl::before {
        left: -12.5px;
        top: 7px;
    }

    .sns__ttl::after {
        top: 5px;
        right: -12px;
    }

    .sns__item {
        width: 48px;
        height: 48px;
        margin: 0 6.5px;
    }

    .banner__img {
        width: 100%;
    }

/* naganuma */
    .online_store-btn {
        margin-top: 41px;
        margin-bottom: 31px;
    }
}