/*****************************************
　　　　　　　　　　全体
******************************************/
/* フォントの指定（from Adobeフォント） */
body {
    /* モリサワフォント
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 300;
    font-style: normal;
*/

    /* 筑紫A丸ゴシック */
    font-family: "fot-tsukuardgothic-std", sans-serif;
    font-weight: 400;
    font-style: normal;
}


/* ヘッダー */
header {
    padding-top: 10px;
    padding-bottom: 5px;
}

.gap_25 {
    height: 25px;
}

.gap_50 {
    height: 50px;
}

.gap_100 {
    height: 100px;
}


.header_logo {
    text-align: center;
}


.header_logo img {
    width: 13vw;
}

/* ページ内リンクでちょうど良い表示位置にするため */
[id] {
    scroll-margin-top: 80px;
}


/*****************************************
　　　　　　　　　nav要素
******************************************/
/* 既存のスタイルはそのままに */
.nav-menu {
    position: relative;
    width: 570px;
    display: flex;
    justify-content: space-between;
    margin: 0 auto;
}

.nav-menu a {
    font-size: 14.5px;
    font-weight: 600;
    letter-spacing: 1.5px;
}


/* ハンバーガー初期状態は非表示 */
.hamburger {
    display: none;
    flex-direction: column;
    width: 30px;
    height: 25px;
    justify-content: space-between;
    cursor: pointer;
    position: absolute;
    top: 10px;
    right: 20px;
    z-index: 10;
}

.hamburger .bar {
    height: 3px;
    width: 100%;
    background-color: #333;
    border-radius: 2px;
}

/* チェックボックス非表示 */
.menu-toggle {
    display: none;
}


/*　ホバー時の下線アニメーション指定　*/
.underline-hover {
    /* 👇が無いと、ホバー時に全てのaタグに下線が出る */
    position: relative;
    color: #000;
    text-decoration: none;
}

.underline-hover::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: -2px;
    width: 0;
    height: 2px;
    background-color: #000;
    transition: width 0.3s ease;
}

.underline-hover:hover::after {
    width: 100%;
}


/*****************************************
　　　　　　　　　TOP画像
******************************************/
.top_img {
    position: relative;
}

.top_img img {
    width: 100%;
    box-shadow: 0 10px 10px rgba(0, 0, 0, 0.219);
    border-radius: 8px;
}

.top_img p {
    width: 550px;
    font-size: 30px;
    font-weight: bold;
    font-style: italic;
    color: white;
    text-align: center;
    line-height: 1.3;
    position: absolute;
    top: 50%;
    left: 70%;
    transform: translate(-50%, -50%);
}

/***************************************************************

　　　　　　            　　　 ご挨拶

***************************************************************/
.greeting {
    max-width: 840px;
    margin: 0 auto;
    position: relative;
}

.greeting h2 {
    writing-mode: vertical-rl;
    margin: 0;
    border-right: #000 solid 2px;
    position: absolute;
}

.greeting_sub {
    max-width: 600px;
    margin: 0 auto;
    padding-top: 50px;
}

.greeting_sub img {
    width: 100%;
}

.greeting_sub>p {
    font-size: 32px;
    font-weight: bold;
    letter-spacing: 1.7px;
    line-height: 1.5;
    margin: 0;
}

.greeting_sub2 {
    max-width: 500px;
    margin: 0 auto;
    margin-top: 20px;
    margin-bottom: 60px;
}

.greeting_sub2 p {
    font-size: 15px;
    line-height: 2;
    margin: 0;
}




/*
.greeting {
    width: 840px;
    margin: 0 auto;
    position: relative;
}

.greeting h2 {
    font-size: 22px;
    writing-mode: vertical-rl;
    margin: 0;
    border-right: #000 2px solid;
    letter-spacing: 4px;
}

.greeting_title {
    position: absolute;
    top: 10px;
    left: 115px;
    font-size: 32px;
    letter-spacing: 2px;
    font-weight: bold;
}

.greeting_text_div {
    width: 440px;
    margin: 0 auto;
    margin-top: 50px;
}

.greeting_text {
    font-size: 14.5px;
    letter-spacing: 1.6px;
    line-height: 2;
    word-wrap: break-word;
}

.greeting_img {
    width: 100%;
    text-align: center;
}

.greeting_img img {
    max-width: 100%;
    width: 600px;
    box-shadow: 0 10px 10px rgba(0, 0, 0, 0.219);
    border-radius: 8px;

}
    */

/***************************************************************

　　　　　　            　　 挿入画像

***************************************************************/
.insert_img img {
    width: 100%;
    height: 430px;
    object-fit: cover;
    box-shadow: 0 10px 10px rgba(0, 0, 0, 0.219);
    border-radius: 8px;

}



/***************************************************************

　　　　　            　　　 私たちの仕事

***************************************************************/
.our_works {
    max-width: 840px;
    margin: 0 auto;
    position: relative;
}

.our_works h2 {
    writing-mode: vertical-rl;
    margin: 0;
    border-right: #000 solid 2px;
    position: absolute;
}

.our_works_sub {
    max-width: 600px;
    margin: 0 auto;
    padding-top: 120px;
}

.our_works_sub img {
    width: 100%;
}

.our_works_sub>p {
    font-size: 32px;
    font-weight: bold;
    letter-spacing: 1.7px;
    line-height: 1.5;
    margin: 0;
}

.our_works_sub2 {
    margin-top: 20px;
    margin-bottom: 60px;
}

.our_works_sub2 p {
    font-size: 15px;
    line-height: 2;
    margin: 0;
}

.our_works_products_imgs {
    width: 100%;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
}

.our_works_products_img img {
    /*height: 126px;
    width: 192px;*/
    object-fit: contain;
}

.our_works_view_more {
    text-align: center;
}





/*
.our_works {
    width: 840px;
    margin: 0 auto;
    position: relative;
}

.our_works h2 {
    position: absolute;
    top: 0px;
    left: 0px;
    font-size: 20px;
    writing-mode: vertical-rl;
    margin: 0;
    border-right: #000 2px solid;
    letter-spacing: 4px;
}

.our_works_title {
    font-size: 30px;
    letter-spacing: 2px;
    font-weight: bold;
    margin-left: 115px;
}

.our_works_text_div {
    width: 455px;
    margin: 0 auto;
    margin-top: 20px;
}

.our_works_text {
    font-size: 13px;
    letter-spacing: 1.6px;
    line-height: 2;
}

.our_works_products_imgs {
    width: 600px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
}

.our_works_products_img img {
    height: 126px;
    width: 192px;
    object-fit: contain;
    box-shadow: 0 10px 10px rgba(0, 0, 0, 0.219);
    border-radius: 8px;

}

.our_works_view_more {
    margin: 0 auto;
    text-align: center;
}
*/

/***************************************************************

　　　　　            　　　 お知らせ

***************************************************************/
.info {
    max-width: 840px;
    margin: 0 auto;
    position: relative;
    background-color: #e5e5e5;
    padding-top: 30px;
    padding-bottom: 30px;
}

.info h2 {
    writing-mode: vertical-rl;
    margin: 0;
    border-right: #000 solid 2px;
    position: absolute;
}

.info_sub {
    max-width: 600px;
    margin: 0 auto;
    padding-top: 50px;
}

.info_sub>p {
    font-size: 18px;
    letter-spacing: 1.7px;
    line-height: 1.5;
    margin: 0;
}


/*
.info {
    width: 840px;
    margin: 0 auto;
    position: relative;

    background-color: #e5e5e5;
}

.info h2 {
    position: absolute;
    top: 0px;
    left: 0px;
    font-size: 20px;
    writing-mode: vertical-rl;
    margin: 0;
    border-right: #000 2px solid;
    letter-spacing: 4px;
}


.info_message {
    margin-left: 115px;
}

*/

/***************************************************************

　　　　　            　　　 ショップ情報

***************************************************************/
.shop_info {
    max-width: 840px;
    margin: 0 auto;
    position: relative;
}

.shop_info h2 {
    writing-mode: vertical-rl;
    margin: 0;
    border-right: #000 solid 2px;
    position: absolute;
}

.shop_info_sub {
    max-width: 600px;
    margin: 0 auto;
    padding-top: 120px;
    display: flex;
}

.shop_info_sub img {
    max-width: 230px;
    margin-right: 15px;
}

.shop_info_sub>p {
    font-size: 15px;
    letter-spacing: 1.7px;
    line-height: 1.8;
    margin: 0;
}

.shop_info_table {
    max-width: 300px;
    margin: 0 auto;
    font-size: 14px;
    margin-top: 60px;
    margin-bottom: 100px;
}

.shop_info_table a {
    text-decoration: none;
}












/*
.shop_info {
    width: 840px;
    height: 500px;
    margin: 0 auto;
    position: relative;
    margin-bottom: 30px;
}

.shop_info h2 {
    position: absolute;
    top: 0px;
    left: 0px;
    font-size: 20px;
    writing-mode: vertical-rl;
    margin: 0;
    border-right: #000 2px solid;
    letter-spacing: 4px;
}

/* 横並び */
/*
.flex {
    width: 600px;
    display: flex;
    margin: 0 auto;
}

.image {
    width: 230px;
    height: 345px;
    object-fit: cover;
    margin: 0;
    padding: 0;
    overflow: hidden;
    position: relative;
    flex-shrink: 0;
}

.flex .right {
    margin: 0 0 0 20px;
    padding: 0;
    flex: 1;
}

.flex .title {
    margin: 0;
    padding: 0;
    font-weight: bold;
    font-size: 18px;
}

.flex .text {
    font-size: 14px;
    letter-spacing: 1.3px;
    line-height: 2;
    margin: 0;
    padding: 0;
}

/* 画像を天地中央表示 */
/*
.flex .image {
    overflow: hidden;
    position: relative;
}

.flex .image::before {
    content: "";
    display: block;
    padding-top: 58%;
}

.flex .image img {
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;

}

/*
.shop_info_detail_box {
    width: 600px;
    margin: 0 auto;
    margin-bottom: 130px;
}

.shop_info_detail {
    margin-right: 100px;
    display: inline-block;
}

*/
/*
.shop_info_detail_box {
    margin: 0 auto;
    margin-bottom: 130px;
}


.shop_info_detail {
    width: 400px;
    margin: 0 auto;
}

.shop_info_detail h3 {
    font-size: 14px;
    display: inline-block;
    margin-right: 20px;
}

.shop_info_detail p {
    font-size: 14px;
    display: inline-block;
}


.shop_info_table {
    width: 300px;
    margin: 0 auto;
    font-size: 14px;
    margin-bottom: 130px;
}

.shop_info_table a {
    text-decoration: none;
}

*/



/***************************************************************

　　　　　            　　　 お問い合わせ

***************************************************************/
.contact {
    padding-top: 100px;
    background-color: #e5e5e5;
    padding-bottom: 100px;
}

.contact h2 {
    text-align: center;
    margin-bottom: 22px;
}

.contact p {
    font-size: 14px;
    width: 334px;
    text-align: center;
    margin: 0 auto;
    margin-bottom: 15px;
}

.contact_email {
    text-align: center;
    padding-bottom: 100px;
}

.input_form {
    text-align: center;
}

/*
.input_form_item {
    width: fit-content;
    text-align: left;
    margin: 0 auto;
}
    */
.input_form_item {
    max-width: 550px;
    text-align: left;
    margin: 0 auto;
}



.privacy_policy_chk {
    width: 550px;
    margin: 0 auto;
    margin-bottom: 40px;
}

.privacy_policy_chk a {
    font-size: 14px;
    text-decoration: none;
    border-bottom: #000 solid 1px;
    line-height: 1.4;
}

.privacy_policy_chk a:visited {
    color: #000;
}

.privacy_policy_chk a:hover {
    color: #1774cc;
    border-color: #1774cc;
}

.privacy_policy_chk label {
    font-size: 14px;
}

.input_form_label {
    display: flex;
    align-items: center;
}

.input_form_label {
    font-size: 17px;
}

.input_form_label p {
    width: fit-content;
    font-size: 14px;
    background-color: #050f77;
    color: white;
    margin-left: 6px;
    margin-right: 0px;
    margin-top: 0px;
    margin-bottom: 0px;

    padding: 2px 4px;
    line-height: 1;
}

.input_field {
    width: 550px;
    height: 35px;
    font-size: 18px;
    margin-bottom: 35px;
}

#content_input {
    width: 550px;
    height: 300px;
    padding: 10px;
    font-size: 16px;
    margin-bottom: 35px;
}



.send_button_div {
    width: 550px;
    margin: 0 auto;
    text-align: center;
}

.send_button {
    width: 220px;
    height: 55px;
    background-color: #010177;
    color: white;
    border: none;
    border-radius: 30px;
    font-size: 22px;
    font-weight: bold;
    letter-spacing: 3px;
    cursor: pointer;
    outline: none;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    transition: background-color 0.3s ease, box-shadow 0.3s ease;
}

.send_button:hover {
    background-color: #0000cd;
    /* ホバー時に少し明るい青色に */
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.3);
    /* ホバー時に影を濃くする */
}

.send_button:active {
    background-color: #000070;
    /* クリック時にさらに濃い青色に */
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    /* クリック時に影を控えめに */
    transform: translateY(2px);
    /* クリック時に少し下に沈むように */
}

/***************************************************************

　　　　　            　　　 フッター

***************************************************************/
footer {
    width: 100%;
    height: 279px;
    background-color: #222;
    padding-top: 16px;
    padding-bottom: 16px;
}

.nav-menu_footer {
    position: relative;
    width: 589px;
    display: flex;
    justify-content: space-between;
    margin: 0 auto;
    margin-top: 48px;
    margin-bottom: 25px;
}

.nav-menu_footer a {
    color: white;
    font-size: 14.5px;
    font-weight: 600;
    letter-spacing: 1.5px;
}

.footer_logo {
    width: auto;
    margin: 0 auto;
    margin-top: 40px;
    margin-bottom: 40px;
    text-align: center;
}

.footer_logo a {
    margin-left: 10px;
    margin-right: 10px;
}

/*
.footer_logo img {
    width: 50px;
}
    */

.ig_logo {
    width: 50px;
}

.yt_logo {
    width: 100px;
}


.privacy_policy {
    width: 100%;
    text-align: center;
}

.privacy_policy a {
    font-size: 10px;
    color: white;
    text-decoration: none;
}

.copyright p {
    color: white;
    font-size: 10px;
    text-align: center;
}


/***************************************************************
*                                                              *
*                                                              *
*                                                              *
*                                                              *
*                                                              *
*　　            　　　 プライバシーポリシー                      *
*                                                              *
*                                                              *
*                                                              *
*                                                              *
*                                                              *
***************************************************************/


.privacy_policy_page {
    width: 860px;
    margin: 0 auto;
    padding-top: 70px;
    padding-bottom: 70px;
    background-color: #f0f0f0;
    margin-bottom: 30px;
}

.privacy_policy_page h1 {
    font-size: 24px;
    text-decoration: underline;
    letter-spacing: 4px;
    margin-bottom: 60px;
    text-align: center;
}

.privacy_policy_page p {
    font-size: 13.5px;
    letter-spacing: 1.5px;
    line-height: 2;
    margin-left: 40px;
    margin-right: 40px;
    text-align: left;
}































/***************************************************************

　　　　　　　             レスポンシブ対応

***************************************************************/
/*****************************************
　　　　　　　　　840px以下
******************************************/
@media (max-width: 840px) {
    .nav-menu {
        width: 478px;
    }

    .nav-menu a {
        font-size: 13.5px;
    }

    .greeting_sub {
        max-width: 400px;
    }

    .greeting h2 {
        font-size: 20px;
    }

    .greeting_sub>p {
        font-size: 24px;
    }

    .our_works_sub {
        max-width: 400px;
    }

    .our_works h2 {
        font-size: 20px;
    }

    .our_works_sub>p {
        font-size: 24px;
    }


    .info_sub {
        max-width: 400px;
    }


    .shop_info_sub {
        max-width: 400px;
        display: block;
    }


    /*
    .greeting {
        margin-left: 0px;
        margin-right: 0px;
    }
        */

    .top_img p {
        font-size: 20px;
    }

    /*
    .greeting h2 {
        font-size: 16px;
        letter-spacing: 2px;
    }

    .greeting_title {
        font-size: 24px;
    }

    .greeting_text_div {
        width: 400px;
        margin-left: 140px;
        margin-right: 0;
    }
*/
    /*
    .our_works h2 {
        font-size: 16px;
        letter-spacing: 2px;
    }

    .our_works_text_div {
        margin-left: 140px;
    }

    .our_works_title {
        font-size: 24px;
    }
*/
    /*
    .info h2 {
        font-size: 16px;
        letter-spacing: 2px;
    }
        */
    /*
    .shop_info h2 {
        font-size: 16px;
        letter-spacing: 2px;
    }
*/
    /*
    .our_works_title {
        margin-left: 60px;
    }

    .our_works_text_div {
        width: 400px;
        margin-left: 60px;
        margin-right: 0;
    }

    .our_works_products_imgs {
        width: 400px;
        margin-left: 60px;
        margin-right: 0;

    }

    .our_works_products_img img {
        width: 120px;
    }
*/

    /*
    .info_message h3 {
        font-size: 16px;
    }
        */

    .flex {
        margin-left: 60px;
    }

    .input_field {
        width: 430px;
    }

    #content_input {
        width: 430px;
    }

    /*
    .contact {
        width: 460px;
    }
*/
    .send_button_div {
        width: 460px;
    }

    .flex {
        width: 400px;
        display: block;
        text-align: center;
        margin-right: 0;
    }

    .right {
        width: 300px;
    }

    .image {
        width: 300px;
        height: auto;
    }

    /*
    .shop_info_table {
        margin-top: 500px;
    }
*/
    /*
    .greeting {
        width: 460px;
    }
*/
    /*
    .our_works {
        width: 460px;
    }
*/
    .privacy_policy_chk {
        width: 400px;
    }

    .nav-menu_footer {
        width: 460px;
    }

    .input_form_item {
        max-width: 460px;
    }

    .top_img p {
        width: 250px;
    }
}


/*****************************************
　　　　　　　　　540px以下
******************************************/
/* メディアクエリでハンバーガー化 */
@media (max-width: 540px) {
    .nav-menu {
        display: none;
        position: absolute;
        top: 50px;
        left: 0;
        right: 0;
        flex-direction: column;
        background-color: #fff;
        width: 100%;
        padding: 10px 20px;
        box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
        z-index: 9;
        width: auto;
    }

    .menu-toggle:checked+.hamburger+.nav-menu {
        display: flex;
    }

    .hamburger {
        display: flex;
    }

    .nav-menu a {
        padding: 10px 0;
        font-size: 12px;
        text-align: center;
        display: inline-block;
        position: relative;
    }



    .underline-hover {
        display: none;
        /* 👇が無いと、ホバー時に全てのaタグに下線が出る */
        position: relative;
        color: #000;
        text-decoration: none;
    }

    .underline-hover::after {
        display: none;
        content: '';
        position: absolute;
        left: 0;
        bottom: -2px;
        width: 0;
        height: 2px;
        background-color: #000;
        transition: width 0.3s ease;
    }

    .underline-hover:hover::after {
        display: none;
        width: 100%;
    }

    .top_img p {
        font-size: 16px;
    }

    .greeting_sub {
        max-width: 340px;
    }

    .greeting h2 {
        font-size: 19px;
    }



    .our_works_sub {
        max-width: 340px;
    }

    .our_works h2 {
        font-size: 19px;
    }

    .info_sub {
        max-width: 340px;
    }

    .shop_info_sub {
        max-width: 340px;
    }



    /*
    .greeting_title {
        left: 60px;
    }

    .greeting_text_div {
        margin-left: 60px;
    }
        */
    /*
    .our_works_title {
        margin-left: 60px;
    }

    .our_works_text_div {
        width: 400px;
        margin-left: 60px;
        margin-right: 0;
    }

    .our_works_products_imgs {
        width: 400px;
        margin-left: 60px;
        margin-right: 0;

    }

    .our_works_products_img img {
        width: 120px;
    }
*/

    .info_message h3 {
        font-size: 16px;
    }

    .flex {
        margin-left: 60px;
    }

    .input_field {
        width: 100%;
    }

    #content_input {
        width: 100%;
    }

    /*
    .contact {
        width: 460px;
    }
*/
    .send_button_div {
        width: 460px;
    }

    .flex {
        width: 400px;
        display: block;
        text-align: center;
        margin-right: 0;
    }

    .right {
        width: 300px;
    }

    .image {
        width: 300px;
        height: auto;
    }

    /*
    .shop_info_table {
        margin-top: 500px;
    }
*/
    /*
    .greeting {
        width: 460px;
    }
*/
    /*
    .our_works {
        width: 460px;
    }
*/

    .privacy_policy_chk {
        width: 400px;
    }

    .nav-menu_footer {
        width: 460px;
    }

    .input_form_item {
        max-width: 340px;
    }

    .top_img p {
        width: 250px;
    }
}