html,
body {
    min-height: 100%;
}

.home-page {
    margin: 0;
    background: #050505;
    color: #111;
    font-family: "Source Han Serif SC", "Songti SC", "SimSun", "PingFang SC", "Microsoft Yahei", serif;
    letter-spacing: .06em;
    -webkit-font-smoothing: antialiased;
}

.home-page *,
.home-page *::before,
.home-page *::after {
    box-sizing: border-box;
}

.home-page a {
    color: inherit;
    text-decoration: none;
}

.home-page ul,
.home-page p,
.home-page h1,
.home-page h2,
.home-page h3 {
    margin: 0;
    padding: 0;
}

.home-page ul {
    list-style: none;
}

.block-loading {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: #000;
    transition: opacity .5s ease, visibility .5s ease;
}

.block-loading.is-hidden {
    opacity: 0;
    visibility: hidden;
}

.base-full-container {
    width: 100%;
}

.base-min-container {
    width: min(1088px, calc(100% - 48px));
    margin: 0 auto;
}

.pc-only {
    display: block;
}

.sp-only {
    display: none;
}

.home-header {
    position: relative;
    z-index: 1000;
}

.header-pc {
    display: flex;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    min-width: 1088px;
    height: 94px;
    background: #000;
    color: #fff;
}

.header-logo {
    display: flex;
    align-items: center;
    gap: 12px;
    position: absolute;
    top: 0;
    left: 45px;
    height: 94px;
    transition: opacity .2s ease;
}

.header-logo:hover {
    opacity: .65;
}

.logo-mark {
    display: grid;
    place-items: center;
    width: 46px;
    height: 46px;
    border: 1px solid currentColor;
    border-radius: 50%;
    font-family: Georgia, serif;
    font-size: 15px;
    letter-spacing: .08em;
}

.logo-text {
    font-family: Georgia, serif;
    font-size: 11px;
    line-height: 1.35;
    letter-spacing: .18em;
}

.gnav-pc {
    width: 100%;
}

.gnav-pc-items {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 26px;
    height: 94px;
    font-family: Georgia, serif;
    font-size: 13px;
    letter-spacing: .12em;
}

.gnav-pc-item {
    height: 94px;
}

.gnav-ttl {
    display: flex;
    align-items: center;
    height: 94px;
    transition: opacity .2s ease;
}

.gnav-pc-item:hover .gnav-ttl {
    opacity: .58;
}

.gnav-sub {
    display: none;
    position: absolute;
    top: 94px;
    left: 0;
    width: 100%;
    background: #1c2225;
}

.gnav-sub-inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 285px;
}

.gnav-sub-list {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 30px;
    padding-left: max(80px, calc((100vw - 1088px) / 2));
    color: #fff;
    font-size: 15px;
}

.gnav-sub-list a {
    transition: opacity .2s ease;
}

.gnav-sub-list a:hover {
    opacity: .58;
}

.gnav-sub-preview {
    position: relative;
    overflow: hidden;
}

.nav-preview-card {
    display: none;
    position: absolute;
    inset: 0;
    align-items: center;
    justify-content: center;
    color: rgba(255, 255, 255, .72);
    font-family: Georgia, serif;
    font-size: 38px;
    letter-spacing: .24em;
}

.nav-preview-card.is-active {
    display: flex;
}

.toppage-mv {
    position: relative;
    height: 100vh;
    min-height: 680px;
    overflow: hidden;
    background: #000;
    color: #fff;
}

.toppage-mv-visual {
    position: absolute;
    left: 50%;
    bottom: 0;
    display: grid;
    grid-template-columns: 1fr 1.34fr 1fr;
    gap: 20px;
    width: min(1174px, 92vw);
    height: 66vh;
    transform: translateX(-50%);
}

.mv-frame {
    position: relative;
    overflow: hidden;
    background: linear-gradient(145deg, #28241f, #9a8c77 45%, #171717 100%);
}

.mv-frame::before {
    content: '';
    position: absolute;
    inset: 9%;
    border: 1px solid rgba(255, 255, 255, .22);
}

.mv-frame::after {
    content: '';
    position: absolute;
    left: 50%;
    top: 22%;
    width: 58%;
    height: 30%;
    border: 12px solid rgba(0, 0, 0, .72);
    border-radius: 50%;
    transform: translateX(-50%) rotate(-8deg);
    box-shadow: 0 0 0 2px rgba(255, 255, 255, .18), 0 34px 70px rgba(0, 0, 0, .35);
}

.mv-frame-main {
    background: linear-gradient(145deg, #181818, #b9aa8c 48%, #272017 100%);
}

.mv-frame-right {
    background: linear-gradient(145deg, #141414, #7d7465 48%, #272727 100%);
}

.toppage-mv-ttl {
    position: absolute;
    left: 0;
    bottom: 60%;
    width: 100%;
    text-align: center;
    font-family: Georgia, serif;
}

.toppage-mv-ttl h1 {
    color: #fff;
    font-size: 30px;
    font-weight: 400;
    letter-spacing: .24em;
}

.toppage-mv-ttl p {
    margin-top: 8px;
    color: #c2c7cb;
    font-size: 12px;
    letter-spacing: .18em;
}

.toppage-mv-scroll {
    position: absolute;
    left: 0;
    bottom: 78px;
    width: 100%;
    color: #c2c7cb;
    text-align: center;
    font-family: Arial, sans-serif;
    font-size: 12px;
    letter-spacing: .16em;
}

.toppage-mv-scroll span::after {
    content: '';
    display: block;
    width: 9px;
    height: 9px;
    margin: 20px auto 0;
    border-right: 1px solid currentColor;
    border-bottom: 1px solid currentColor;
    transform: rotate(45deg);
}

.toppage-story {
    position: relative;
    height: 78vh;
    min-height: 520px;
    background: #050505;
    overflow: hidden;
}

.story-bg {
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, rgba(0, 0, 0, .72), rgba(0, 0, 0, .12)), radial-gradient(circle at 70% 42%, #9d8f7a, #37312a 34%, #0a0a0a 65%);
}

.story-link {
    position: absolute;
    left: 50%;
    bottom: 16%;
    color: #fff;
    font-family: Georgia, serif;
    font-size: 30px;
    letter-spacing: .22em;
    transform: translateX(-50%);
}

.toppage-phs {
    background: #d7dcde;
    padding: 115px 0 120px;
}

.phs-block {
    display: grid;
    grid-template-columns: 38% 1fr;
    align-items: center;
    gap: 64px;
}

.phs-copy h2,
.split-card h2 {
    font-family: Georgia, serif;
    font-size: 30px;
    font-weight: 400;
    letter-spacing: .18em;
}

.phs-copy p {
    margin-top: 32px;
    font-size: 22px;
    line-height: 2.05;
}

.text-link {
    display: inline-block;
    margin-top: 28px;
    font-family: Arial, sans-serif;
    font-size: 13px;
    letter-spacing: .14em;
    border-bottom: 1px solid currentColor;
}

.phs-image,
.split-card-img {
    position: relative;
    display: grid;
    place-items: center;
    min-height: 390px;
    overflow: hidden;
    color: rgba(255, 255, 255, .78);
    background: linear-gradient(140deg, #1d1c1a, #a99673 54%, #242424);
    font-family: Georgia, serif;
    font-size: 28px;
    letter-spacing: .18em;
}

.phs-image::after,
.split-card-img::after {
    content: '';
    position: absolute;
    inset: 0;
    background: #1f2529;
    transform: translateX(0);
    transition: transform 1s cubic-bezier(.76, 0, .24, 1);
}

.phs-image.is-on::after,
.split-card-img.is-on::after {
    transform: translateX(100%);
}

.phs-image span,
.split-card-img span {
    position: relative;
    z-index: 1;
}

.history-shops {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 38px;
    margin-top: 96px;
}

.split-card {
    display: grid;
    grid-template-columns: 44% 1fr;
    min-height: 272px;
    background: rgba(255, 255, 255, .3);
}

.split-card > div:first-child {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 30px;
}

.split-card-img {
    min-height: 272px;
    font-size: 24px;
}

.toppage-brand_factory {
    padding: 118px 0 130px;
    background: #1f2529;
    color: #fff;
}

.common-ttl-1 {
    font-family: Georgia, serif;
    font-size: 30px;
    font-weight: 400;
    text-align: center;
    letter-spacing: .2em;
}

.color-white {
    color: #fff;
}

.color-black {
    color: #000;
}

.brand-list {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    margin-top: 54px;
}

.brand-card a {
    display: block;
    height: 100%;
    background: #fff;
    color: #111;
    transition: transform .25s ease, opacity .25s ease;
}

.brand-card a:hover {
    transform: translateY(-8px);
}

.brand-img {
    display: grid;
    place-items: center;
    height: 230px;
    color: rgba(255, 255, 255, .78);
    font-family: Georgia, serif;
    font-size: 22px;
    letter-spacing: .18em;
}

.brand-detail {
    padding: 24px 22px 28px;
}

.brand-detail h3 {
    font-size: 19px;
    font-weight: 400;
    line-height: 1.55;
}

.brand-detail p {
    min-height: 58px;
    margin-top: 12px;
    color: #555;
    font-size: 13px;
    line-height: 1.8;
}

.brand-detail span {
    display: inline-block;
    margin-top: 18px;
    font-family: Arial, sans-serif;
    font-size: 12px;
    letter-spacing: .12em;
}

.factory-block {
    margin-top: 112px;
    text-align: center;
}

.factory-comment {
    margin-top: 34px;
    color: #e8eaeb;
    font-size: 22px;
    line-height: 2;
}

.bdr-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 250px;
    height: 44px;
    margin: 42px auto 0;
    border: 1px solid currentColor;
    font-family: Arial, sans-serif;
    font-size: 13px;
    letter-spacing: .16em;
    transition: background .2s ease;
}

.bdr-btn:hover {
    background: rgba(255, 255, 255, .15);
}

.toppage-culture {
    padding: 118px 0 124px;
    background: #d7dcde;
}

.culture-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 34px;
    margin-top: 54px;
}

.culture-card {
    display: grid;
    grid-template-columns: 1fr 45%;
    min-height: 280px;
    background: #fff;
}

.culture-detail {
    display: flex;
    flex-direction: column;
    padding: 34px 30px;
}

.culture-detail h3 {
    font-size: 23px;
    font-weight: 400;
    line-height: 1.65;
}

.culture-detail p {
    margin-top: 18px;
    color: #555;
    font-size: 14px;
    line-height: 1.9;
}

.date-view {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: auto;
    font-family: Arial, sans-serif;
    font-size: 12px;
    letter-spacing: .1em;
}

.culture-img {
    min-height: 100%;
}

.toppage-shops {
    background: #15191c;
    color: #fff;
}

.shops-hero {
    display: grid;
    place-items: center;
    height: 360px;
    background: radial-gradient(circle at 50% 50%, #9b8c74, #2c2f31 42%, #050505 76%);
}

.shops-hero h2 {
    color: #fff;
    font-family: Georgia, serif;
    font-size: 34px;
    font-weight: 400;
    letter-spacing: .22em;
}

.shops-content {
    padding: 78px 0 104px;
    text-align: center;
}

.shops-main {
    font-size: 25px;
}

.shops-sub {
    margin-top: 20px;
    color: #d6d8d9;
    font-size: 16px;
    line-height: 1.9;
}

.shops-list {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 22px;
    margin-top: 52px;
}

.shops-list li {
    text-align: left;
}

.shop-thumb {
    height: 160px;
}

.shops-list h3 {
    margin-top: 16px;
    font-family: Georgia, serif;
    font-size: 17px;
    font-weight: 400;
    letter-spacing: .12em;
}

.shops-list p {
    margin-top: 10px;
    color: #c2c7cb;
    font-size: 13px;
    line-height: 1.7;
}

.toppage-news {
    padding: 108px 0 112px;
    background: #050505;
    color: #fff;
}

.news-list {
    max-width: 820px;
    margin: 48px auto 0;
    border-top: 1px solid #383838;
}

.news-list a {
    display: grid;
    grid-template-columns: 120px 82px 1fr;
    gap: 22px;
    align-items: center;
    min-height: 76px;
    border-bottom: 1px solid #383838;
    color: #fff;
    font-size: 14px;
}

.news-list time,
.news-list span {
    color: #b5b8ba;
    font-family: Arial, sans-serif;
    font-size: 12px;
}

.news-list span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 58px;
    height: 22px;
    border: 1px solid #707070;
}

.news-list strong {
    font-weight: 400;
    line-height: 1.7;
}

.recruit-contact {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 300px;
}

.recruit-item {
    display: grid;
    place-items: center;
    position: relative;
    overflow: hidden;
    color: #fff;
    background: radial-gradient(circle at 50% 45%, #8c7e6a, #202020 62%, #060606);
}

.recruit-item.contact {
    background: radial-gradient(circle at 50% 45%, #6e716d, #1b1f22 62%, #050505);
}

.recruit-item span {
    display: block;
    font-family: Georgia, serif;
    font-size: 30px;
    letter-spacing: .22em;
}

.recruit-item small {
    display: block;
    margin-top: 10px;
    text-align: center;
    font-size: 14px;
}

.home-footer {
    padding: 86px 0 64px;
    background: #000;
    color: #fff;
}

.footer-inner {
    text-align: center;
}

.footer-logo {
    display: inline-flex;
    align-items: center;
    gap: 16px;
    font-family: Georgia, serif;
    letter-spacing: .18em;
}

.footer-nav,
.footer-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 24px;
    margin-top: 54px;
    font-family: Georgia, serif;
    font-size: 13px;
    letter-spacing: .12em;
}

.footer-links {
    margin-top: 28px;
    color: #c2c7cb;
    font-family: inherit;
    font-size: 12px;
}

.copyright {
    margin-top: 52px;
    color: #8f9497;
    font-family: Georgia, serif;
    font-size: 11px;
    letter-spacing: .12em;
}

.reveal {
    opacity: 0;
    transform: translateY(34px);
    transition: opacity .9s ease, transform .9s ease;
}

.reveal.is-active {
    opacity: 1;
    transform: translateY(0);
}

.tone-sand,
.tone-amber {
    background: linear-gradient(145deg, #191716, #b39a70 55%, #34302b);
}

.tone-olive,
.tone-stone,
.tone-warm {
    background: linear-gradient(145deg, #1c211d, #8b866f 55%, #32362e);
}

.tone-slate,
.tone-smoke,
.tone-graphite {
    background: linear-gradient(145deg, #111, #727a7e 55%, #24282b);
}

.tone-ink,
.tone-night,
.tone-charcoal,
.tone-deep,
.tone-history,
.tone-shop {
    background: linear-gradient(145deg, #060606, #575a5d 55%, #171717);
}

@media (max-width: 900px) {
    .pc-only {
        display: none !important;
    }

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

    .base-min-container {
        width: calc(100% - 32px);
    }

    .header-sp {
        position: fixed;
        top: 0;
        left: 0;
        align-items: center;
        justify-content: center;
        width: 100%;
        height: 64px;
        background: #000;
        color: #fff;
        z-index: 9999;
    }

    .header-sp .header-logo {
        position: static;
        height: auto;
    }

    .header-sp .logo-mark {
        width: 38px;
        height: 38px;
        font-size: 13px;
    }

    .header-menu-switch {
        position: absolute;
        left: 18px;
        top: 21px;
        width: 36px;
        height: 22px;
        padding: 0;
        border: 0;
        background: transparent;
    }

    .header-menu-switch span,
    .header-menu-switch::before,
    .header-menu-switch::after {
        content: '';
        position: absolute;
        left: 0;
        width: 100%;
        height: 1px;
        background: #fff;
        transition: transform .35s ease, opacity .35s ease;
    }

    .header-menu-switch span {
        top: 50%;
    }

    .header-menu-switch::before {
        top: 0;
    }

    .header-menu-switch::after {
        bottom: 0;
    }

    .header-menu-switch.is-open span {
        opacity: 0;
    }

    .header-menu-switch.is-open::before {
        top: 50%;
        transform: rotate(45deg);
    }

    .header-menu-switch.is-open::after {
        bottom: auto;
        top: 50%;
        transform: rotate(-45deg);
    }

    .header-menu-container {
        display: none;
        position: fixed;
        top: 64px;
        left: 0;
        width: 100%;
        height: calc(100vh - 64px);
        background: #000;
        z-index: 9998;
    }

    .header-menu-body {
        width: 100%;
        height: 100%;
        padding: 32px 18px 48px;
        overflow: auto;
    }

    .gnav-sp-items {
        border-top: 1px solid #555;
    }

    .gnav-sp-item a {
        display: flex;
        align-items: center;
        height: 62px;
        border-bottom: 1px solid #555;
        color: #fff;
        font-family: Georgia, serif;
        font-size: 15px;
        letter-spacing: .14em;
    }

    .nav-other-list {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 18px;
        margin-top: 34px;
        color: #c2c7cb;
        font-size: 12px;
    }

    .body-fixed {
        position: fixed;
        left: 0;
        width: 100%;
        overflow: hidden;
    }

    .toppage-mv {
        min-height: 620px;
        padding-top: 64px;
    }

    .toppage-mv-visual {
        grid-template-columns: 1fr;
        gap: 0;
        width: 100%;
        height: 72vh;
    }

    .mv-frame-left,
    .mv-frame-right {
        display: none;
    }

    .mv-frame-main {
        height: 100%;
    }

    .toppage-mv-ttl {
        bottom: 58%;
        padding: 0 20px;
    }

    .toppage-mv-ttl h1 {
        font-size: 24px;
        letter-spacing: .18em;
    }

    .toppage-story {
        height: 68vh;
        min-height: 460px;
    }

    .toppage-phs,
    .toppage-brand_factory,
    .toppage-culture,
    .toppage-news {
        padding: 76px 0 84px;
    }

    .phs-block,
    .history-shops,
    .brand-list,
    .culture-list,
    .shops-list,
    .recruit-contact {
        grid-template-columns: 1fr;
    }

    .phs-copy p,
    .factory-comment,
    .shops-main {
        font-size: 19px;
    }

    .phs-image,
    .split-card-img {
        min-height: 260px;
    }

    .split-card,
    .culture-card {
        grid-template-columns: 1fr;
    }

    .brand-img {
        height: 220px;
    }

    .culture-img {
        min-height: 220px;
        order: -1;
    }

    .shops-hero {
        height: 260px;
    }

    .news-list a {
        grid-template-columns: 1fr;
        gap: 10px;
        padding: 22px 0;
    }

    .recruit-contact {
        min-height: 460px;
    }
}
