@charset "utf-8";


div.container {
    max-width: var(--content-max-width);
    margin: 0 auto;
}

header {
    height: var(--header-height);
    margin-bottom: 200px;

    div.header {
        display: flex;
        justify-content: space-evenly;
        align-items: flex-end;

        ul {
            display: flex;
            justify-content: space-between;
            margin-top: 30px;

            li a {
                margin-right: var(--spacing-8);
                font-size: var(--font-size-32);
                font-family: var(--font-serif-en);
                color: var(--non-colored-black);
                text-decoration: none;
                padding-bottom: var(--spacing-1);
                transition: .4s;

                &:hover {
                    color: var(--gray-60);
                }

                &:active {
                    color: var(--gray-50);
                }
            }
        }

        a.sns-icon {
            width: var(--icon-btn-size);
            transition: opacity .4s;
            padding-bottom: var(--spacing-1);

            &:hover {
                opacity: 0.5;
            }
        }
    }

    div.reserve {
        background-color: var(--theme-color-font-navy);
        width: 64px;
        height: 32px;
        border-radius: var(--radius-8);
        display: flex;
        justify-content: center;
        align-items: center;
        margin-bottom: var(--spacing-1);
        transition: .4s;

        &:hover {
            opacity: 0.7;
        }

        p a {
            font-size: var(--font-size-16);
            font-family: var(--font-serif-ja);
            color: var(--non-colored-white);
            display: block;
            padding: 4px 16px;
            white-space: nowrap;
        }
    }
}






.sp-nav {
  display: none;
}








main {
    section.hero {
        margin-bottom: 200px;
        display: flex;
        justify-content: space-between;

        div.hero-l {
            img.logo {
                display: block;
                width: 360px;
            }

            img.hero {
                display: block;
                width: 600px;
                margin: 48px 0 0 48px;
            }
        }

        div.hero-r {
            display: flex;
            flex-direction: column;
            align-items: center;
            writing-mode: vertical-rl;
            font-family: var(--font-serif-ja);
            font-size: var(--font-size-28);
            line-height: 100px;
            letter-spacing: 15px;

            p.top {
                margin-bottom: 100px;
            }

            p.bot {
                margin-top: 100px;
            }
        }
    }

    h2 {
        text-align: center;
        font-family: var(--font-serif-en);
        font-size: var(--font-size-48);
        font-weight: var(--font-weight-light);
        margin-bottom: var(--spacing-4);
    }

    div.deco {
        display: flex;
        justify-content: flex-end;
        margin-bottom: var(--spacing-18);
        margin-left: auto;

        img.deco {
            width: 340px;
        }
    }

    div.deco-l {
        display: flex;
        margin-bottom: 100px;
        margin-left: auto;

        img.deco {
            width: 340px;
        }
    }

    div.barber {
        display: flex;
        justify-content: center;
        margin-bottom: 100px;

        img {
            width: var(--spacing-18);
        }
    }

    /* section共通 */
    section {
        div.text {
            display: flex;
            flex-direction: column;
            justify-content: space-between;

            p.catch {
                line-height: var(--line-height-200);
                font-family: var(--font-serif-ja);
                font-weight: var(--font-weight-bold);
                font-size: var(--font-size-20);
            }

            p.text {
                line-height: 40px;
                font-family: var(--font-gothic-ja);
                font-weight: var(--font-weight-light);
                font-size: var(--font-size-16);
            }
        }
    }

    section.about {
        margin-bottom: 100px;

        div.about {
            display: flex;
            justify-content: space-between;
            /*             align-items: center; */

            div.img {
                display: flex;

                div.about-img-l {
                    width: 250px;
                    margin-right: 50px;
                }

                div.about-img-r {
                    width: 250px;
                    margin-top: 100px;
                }
            }

            div.text {
                display: flex;
                flex-direction: column;
                justify-content: space-between;

                p.catch {
                    line-height: var(--line-height-200);
                    font-family: var(--font-serif-ja);
                    font-weight: var(--font-weight-bold);
                    font-size: var(--font-size-20);
                }

                p.text {
                    line-height: 40px;
                    font-family: var(--font-gothic-ja);
                    font-weight: var(--font-weight-light);
                    font-size: var(--font-size-16);
                }
            }
        }
    }

    section.menu {
        margin-bottom: var(--spacing-3);

        div.menu {
            display: flex;
            justify-content: space-between;
            flex-direction: row-reverse;
            /*             align-items: center; */
            margin-bottom: var(--spacing-12);

            div.img {
                display: flex;

                div.menu-img-l {
                    width: 250px;
                    margin-right: 50px;
                    margin-top: 100px;
                }

                div.menu-img-r {
                    width: 250px;
                }
            }

            div.text {
                display: flex;
                flex-direction: column;
                justify-content: space-between;

                p.catch {
                    /* line-height: var(--line-height-200); */
                    font-family: var(--font-serif-ja);
                    font-weight: var(--font-weight-bold);
                    line-height: 40px;
                    font-size: var(--font-size-20);
                }

                p.text {
                    line-height: 40px;
                    font-family: var(--font-gothic-ja);
                    font-weight: var(--font-weight-light);
                    font-size: var(--font-size-16);
                }
            }
        }

        p.menu {
            margin-left: var(--spacing-9);

            a {
                font-family: var(--font-serif-en);
                font-size: var(--font-size-28);
                color: var(--non-colored-black);
                transition: .4s;

                &:hover {
                    color: var(--gray-60);

                    span {

                        &::after {
                            transform: translateX(10px);
                        }
                    }
                }

                span {
                    display: flex;
                    align-items: center;

                    &::after {
                        margin-left: var(--spacing-4);
                        font-family: var(--font-serif-en);
                        font-size: var(--font-size-16);
                        transition: .4s;
                    }
                }
            }

            /* a::after {
                content: attr(data-char);
            } */
        }
    }

    section.gallery {
        margin-bottom: var(--spacing-3);

        div.section-inner {
            max-width: var(--section-inner-size-l);
            margin: 0 auto;

            div.gallery {
                display: grid;
                grid-template-columns: repeat(3, 1fr);
                /* 横に3列 */
                grid-template-rows: repeat(2, auto);
                /* 縦に2行 */
                gap: var(--spacing-6);
                margin-bottom: var(--spacing-10);
            }
        }

        p {
            margin-right: var(--spacing-12);

            display: flex;
            align-items: center;
            justify-content: flex-end;

            a {
                font-family: var(--font-serif-en);
                font-size: var(--font-size-28);
                color: var(--non-colored-black);
                transition: .4s;

                &:hover {
                    color: var(--gray-60);

                    span {

                        &::after {
                            transform: translateX(10px);
                        }
                    }
                }

                span {
                    display: flex;
                    align-items: center;

                    &::after {
                        margin-left: var(--spacing-4);
                        font-family: var(--font-serif-en);
                        font-size: var(--font-size-16);
                        transition: .4s;
                    }
                }
            }
        }
    }

    section.staff {
        margin-bottom: var(--font-size-28);

        div.staff {
            display: flex;
            justify-content: space-around;

            figure {
                text-align: center;

                figcaption {
                    margin: var(--spacing-4);
                    font-size: var(--font-size-20);
                    font-family: var(--font-gothic-ja);
                }
            }
        }
    }

    section.access {
        margin-bottom: var(--spacing-8);

        div.access {
            display: flex;
            justify-content: space-between;

            p {
                margin: 20px 0;
                font-family: var(--font-gothic-ja);
            }

            address {
                margin: 20px 0;
                font-family: var(--font-gothic-ja);
            }

            div.primary {
                color: var(--non-colored-white);
                background-color: var(--theme-color-font-navy);
                width: 80px;
                height: 40px;
                border-radius: var(--radius-8);
                display: flex;
                justify-content: center;
                align-items: center;
                margin-bottom: var(--spacing-1);
            }
        }
    }
}

footer {
    background-color: var(--theme-color-font-navy);

    div.ft-inner {
        display: flex;
        justify-content: space-between;
        align-items: flex-end;
        max-width: var(--content-max-width);
        margin: 0 auto;

        div.ft-logo {

            img {
                width: 600px;
                margin: 0 0 48px 48px;
            }
        }

        div.ft-menu {
            ul {
                text-align: end;
                margin: 80px 80px 48px 0;

                li {
                    margin-bottom: var(--spacing-1);

                    a {
                        margin-bottom: var(--spacing-2);
                        font-family: var(--font-serif-en);
                        font-size: var(--font-size-28);
                        color: var(--non-colored-white);
                        transition: .4s;

                        &:hover {
                            color: var(--gray-50);
                        }

                        &:active {
                            color: var(--gray-50);
                        }

                    }
                }
            }

            div.ft-menu-bot {
                display: flex;
                justify-content: space-between;
                margin: 0 80px 48px 0;

                a.sns-icon {
                    width: var(--icon-btn-size);
                    transition: opacity .4s;

                    &:hover {
                        opacity: 0.5;
                    }
                }

                div.reserve {
                    background-color: var(--non-colored-white);
                    width: 64px;
                    height: 32px;
                    border-radius: var(--radius-8);
                    display: flex;
                    justify-content: center;
                    align-items: center;
                    margin-left: var(--spacing-3);
                    overflow: hidden;
                    transition: .4s;

                    &:hover {
                        opacity: 0.5;
                    }

                    p {
                        a {
                            display: block;
                            padding: 4px 16px;
                            color: var(--theme-color-font-navy);
                            font-family: var(--font-serif-ja);
                        }
                    }
                }
            }
        }
    }

    p {
        text-align: center;
        border-top: 1px solid var(--non-colored-white);
        max-width: var(--content-max-width);
        margin: 0 auto;

        small {
            color: var(--non-colored-white);
        }
    }
}

/* Jquery */
.js-fade {
    opacity: 0;
    visibility: hidden;
    transform: translateY(50px);
    --animation-basic-time: 0.3s;
    --animation-delay: 0.3s;
    transition: opacity 1s, visibility 1s, transform 1s;

    &.delay {
        --animation-time: calc(var(--animation-basic-time) + 1 * var(--animation-delay));
        transition: opacity var(--animation-time), visibility var(--animation-time), transform var(--animation-time);
    }

    &.delay2 {
        --animation-time: calc(var(--animation-basic-time) + 2 * var(--animation-delay));
        transition: opacity var(--animation-time), visibility var(--animation-time), transform var(--animation-time);
    }

    &.delay3 {
        --animation-time: calc(var(--animation-basic-time) + 3 * var(--animation-delay));
        transition: opacity var(--animation-time), visibility var(--animation-time), transform var(--animation-time);
    }

    &.delay4 {
        --animation-time: calc(var(--animation-basic-time) + 4 * var(--animation-delay));
        transition: opacity var(--animation-time), visibility var(--animation-time), transform var(--animation-time);
    }

    &.delay5 {
        --animation-time: calc(var(--animation-basic-time) + 5 * var(--animation-delay));
        transition: opacity var(--animation-time), visibility var(--animation-time), transform var(--animation-time);
    }

    &.delay6 {
        --animation-time: calc(var(--animation-basic-time) + 6 * var(--animation-delay));
        transition: opacity var(--animation-time), visibility var(--animation-time), transform var(--animation-time);
    }


    &.scroll {
        opacity: 1;
        visibility: visible;
        transform: translateY(0px);
    }
}

/* Jquery */

@media (max-width: 768px) {
    body {
        font-size: var(--font-size-16);
    }

    /*     div.deco {
        justify-content: center;
    } */

    div.container {
        max-width: var(--main-max-width);
        min-width: var(--main-min-width);
    }

    header {
        display: none;
    }






.sp-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px 20px;
    background-color: var(--colored-white); /* ベージュ */
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
  }

  /* 2. コンテンツがヘッダーに被らないように隙間を作る */
  main {
    margin-top: 60px; 
  }

  .sp-logo img {
    height: 30px;
    width: auto;
  }

  /* 3. ハンバーガーボタンの見た目 */
  .hamburger-btn {
    width: 30px;
    height: 22px;
    position: relative;
    cursor: pointer;
    z-index: 1100;
  }

  .hamburger-btn span {
    display: block;
    width: 100%;
    height: 2px;
    background-color: #333;
    position: absolute;
    transition: all 0.4s;
  }

  .hamburger-btn span:nth-child(1) { top: 0; }
  .hamburger-btn span:nth-child(2) { top: 10px; }
  .hamburger-btn span:nth-child(3) { top: 20px; }

  /* バツ印への変形 */
  .hamburger-btn.open span:nth-child(1) { transform: translateY(10px) rotate(45deg); }
  .hamburger-btn.open span:nth-child(2) { opacity: 0; }
  .hamburger-btn.open span:nth-child(3) { transform: translateY(-10px) rotate(-45deg); }

  /* 4. メニューリストの設定 */
  .menu-list {
    display: none; 
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    background-color: var(--colored-white); /* ベージュ */
    padding: 20px 0;
    list-style: none;
    text-align: center;
    border-top: 1px solid rgba(0,0,0,0.1);
  }

  .menu-list li a {
    display: block;
    padding: 15px;
    text-decoration: none;
    color: #333;
    font-size: 16px;
    border-bottom: 1px solid rgba(0,0,0,0.05);
  }













    main {
        margin-top: var(--spacing-10);

        section.hero {
            
            display: block;

            margin-bottom: var(--spacing-8);

            div.hero-l {
                img.logo {
                    display: none;
                }

                img.hero {
                    margin-left: 0;
                    margin-top: var(--spacing-25);
                    width: 80%;
                }

                .hero {
                    width: 200px;
                }
            }

            div.hero-r {
                font-size: var(--font-size-14);
                line-height: var(--spacing-6);
                letter-spacing: var(--spacing-1);
                margin-top: var(--spacing-10);
                writing-mode: horizontal-tb;

                p.top {
                    margin-bottom: var(--spacing-2);
                    margin-left: var(--spacing-10);
                }
                p.bot {
                    margin-top: var(--spacing-2);
                    margin-right: var(--spacing-10);
                }
            }
        }

        section.about {

            margin-bottom: var(--spacing-4);

            h2 {
                margin-bottom: 0;
                font-size: var(--font-size-28);
            }

            div.barber {
                margin-bottom: var(--spacing-8);
            }

            div.about {

                flex-direction: column;

                div.img {
                    margin-bottom: var(--spacing-8);
                }

                div.text {
                    p {
                        text-align: center;
                        margin-bottom: var(--spacing-1);
                    }
                    p.catch {
                        font-size: var(--font-size-20);
                    }
                    p.text {
                        font-size: var(--font-size-16);
                    }
                }
            }
        }

        section.menu {

            margin-bottom: var(--spacing-4);

            div.deco {
                margin-bottom: var(--spacing-8);
            }

            h2 {
                margin-bottom: 0;
                font-size: var(--font-size-28);
            }

            div.barber {
                margin-bottom: var(--spacing-8);
            }

            div.menu {

                flex-direction: column;

                div.img {
                    margin-bottom: var(--spacing-8);
                }

                div.text {
                    p {
                        text-align: center;
                        margin-bottom: var(--spacing-1);
                    }
                    p.catch {
                    font-size: var(--font-size-20);
                    }
                    p.text {
                    font-size: var(--font-size-16);
                    }
                }
            }
        }

        section.gallery {

            margin-bottom: var(--spacing-4);

            div.deco-l {
                margin-bottom: var(--spacing-8);
            }

            h2 {
                margin-bottom: 0;
                font-size: var(--font-size-28);
            }

            div.barber {
                margin-bottom: var(--spacing-8);
            }

            div.section-inner {
                div.gallery {
                    grid-template-columns: repeat(2, 1fr);
                }
            }
        }

        section.staff {

            margin-bottom: var(--spacing-4);

            div.deco {
                margin-bottom: var(--spacing-8);
            }

            h2 {
                margin-bottom: 0;
                font-size: var(--font-size-28);
            }

            div.barber {
                margin-bottom: var(--spacing-8);
            }

            div.staff {

                figure {
                    img {
                        width: 80%;
                    }
                    figcaption {
                        font-size: var(--font-size-14);
                    }
                }
            }

        }

        section.access {

            margin-bottom: var(--spacing-4);

            h2 {
                margin-bottom: 0;
                font-size: var(--font-size-28);
            }

            div.barber {
                margin-bottom: var(--spacing-8);
            }

            div.access {
                flex-direction: column;

                /*                 div.access-inner {
                } */
                div.map {

                    margin-bottom: var(--spacing-2);
                    iframe {
                        max-width: 100%;
                    }
                }
            }
        }
    }

    footer {
        div.ft-inner {
            height: var(--spacing-10);
            justify-content: center;
            align-items: center;

            div.ft-logo {
                img {
                    max-width: 200px;
                    margin: 0 auto;
                }
            }

            div.ft-menu {
                display: none;
            }
        }
    }
}