body {
    /* font-family: "BIZ UDPMincho", serif; */
    font-family: "Zen Old Mincho", serif;
}

.private_main {
    background-color: #fff;
}

.private_main .container {
    width: 95%;
}

.sp_br {
    display: none;
}

@media screen and (max-width:767px) {
    .sp_br {
        display: block;
    }
}

/* =================================mv================================= */

.private_main .top_mv {
    width: 100%;
    height: 100vh;
    background-image: url(../img/p_header_mv.png);
    background-size: cover;
    background-position: center;
}

.private_main .top_mv_catch {
    writing-mode: vertical-rl;
    color: #FFF;
    font-size: 22px;
    font-weight: 500;
    letter-spacing: 12px;
    line-height: 2.8;
    position: absolute;
    top: 150px;
    left: 150px;
}

.private_main .top_mv_scroll {
    position: absolute;
    left: 50%;
    bottom: 26px;
    transform: translateX(-50%);
}

.private_main .top_mv_scroll_img {
    width: 44px;
    margin: 0 auto;
}

.private_main .top_mv_scroll_text {
    text-align: center;
    color: #FFF;
    font-size: 18px;
    font-weight: 500;
    letter-spacing: 2.5px;
    line-height: 1.2;
    padding-top: 11px;
}

@media screen and (max-width:767px) {
    .private_main .top_mv_catch {
        font-size: 20px;
        top: 25%;
        left: 5%;
    }
    .private_main .top_mv_scroll {
        bottom: 18px;
    }
    .private_main .top_mv_scroll_img {
        width: 30px;
    }
    .private_main .top_mv_scroll_text {
        color: #FFF;
    }
}

/* =================================project============================= */

.private_main .top_project {
    position: relative;
}

.private_main .top_project::before {
    content: "PROJECT";
    position: absolute;
    color: #f7f7f9;
    font-size: 108px;
    font-weight: 700;
    letter-spacing: .2em;
    line-height: 1.2;
    font-family: Arial, sans-serif;
    top: 265px;
    left: 84px;
}

.container {
    width: 100%;
    max-width: 1153px;
    margin: 0 auto;
}

.t_project_container {
    padding: 224px 160px 0;
    position: relative;
}

.top_project_content {
    display: flex;
    justify-content: space-between;
}

.top_project_content_left {
    width: 62%;
}

.top_project_content_left_title {
    width: 237px;
}

.top_project_content_left_title span {
    font-size: 20px;
}

.top_project_content_left_text {
    margin-top: 18px;
    color: #000;
    font-size: 12px;
    font-weight: 400;
    line-height: 2;
    letter-spacing: .25em;
}

.top_project_content_right {
    position: relative;
}

.top_project_content_right_catchcopy {
    writing-mode: vertical-rl;
    color: #000;
    font-size: 28.5px;
    font-weight: 400;
    line-height: 2;
    letter-spacing: .2em;
    text-align: left;
    position: absolute;
    top: -25px;
}

.top_detail {
    display: table;
    color: #FFF;
    font-size: 11.5px;
    font-weight: 400;
    line-height: 3.6;
    letter-spacing: .15em;
    padding: 0 70px;
    background-color: #3e3f42;
    background-image: url(../img/yazirushi_white.png);
    background-size: 3px 6px;
    background-repeat: no-repeat;
    background-position: 170px 52%;
}

.top_project_content_right_detail {
    margin-top: 478px;
}

.top_project_scroll {
    width: 100%;
    display: flex;
    margin-top: 78px;
    overflow-x: hidden;
}

.top_project_scroll_img {
    margin-left: 28px;
    flex: 0 0 auto;
}

.scroll_1 {
    width: 446px;
    margin-top: 45px;
}

.scroll_2 {
    width: 310px;
    margin-top: 234px;
}

.scroll_3 {
    width: 354px;
    margin-top: 126px;
}

.scroll_4 {
    width: 290px;
}

@media screen and (max-width:767px) {
    .private_main .top_project::before {
        font-size: 50px;
        letter-spacing: .1em;
        line-height: 1.2;
        top: 6%;
        left: 3%;
    }
    .t_project_container {
        padding: 100px 20px 0;
        position: relative;
        width: 100%;
        max-width: 500px;
        margin: 0 auto;
    }
    .top_project_content {
        display: block;
        justify-content: space-between;
        position: relative;
    }
    .top_project_content_left {
        width: 80%;
    }
    .top_project_content_left_title {
        width: 150px;
    }
    .top_project_content_left_text {
        margin-top: 15px;
        color: #000;
        font-size: 10px;
        font-weight: 400;
        line-height: 1.5;
        letter-spacing: .15em;
    }
    .top_project_content_right {
        position: static;
    }
    .top_project_content_right_catchcopy {
        font-size: 20px;
        line-height: 1.5;
        letter-spacing: .15em;
        position: absolute;
        top: -25px;
        right: 0;
    }
    .top_detail {
        display: table;
        color: #FFF;
        font-size: 11.5px;
        font-weight: 400;
        line-height: 3.6;
        letter-spacing: .15em;
        padding: 0 70px;
        background-color: #3e3f42;
        background-image: url(../img/yazirushi_white.png);
        background-size: 3px 6px;
        background-repeat: no-repeat;
        background-position: 170px 52%;
    }
    .top_project_content_right_detail {
        margin: 50px auto 0;
    }
    .top_project_scroll {
        margin-top: 30px;
    }
    .top_project_scroll_img {
        margin-left: 15px;
        flex: 0 0 auto;
    }
    .scroll_1 {
        width: 223px;
        margin-top: 22.5px;
    }
    .scroll_2 {
        width: 155px;
        margin-top: 11.54px;
    }
    .scroll_3 {
        width: 178px;
        margin-top: 63px;
    }
    .scroll_4 {
        width: 72.5px;
    }
}

/* =================================original============================== */

.p_original {
    position: relative;
}

.p_original_mv {
    position: absolute;
    width: 53%;
    z-index: 1;
    top: -100px;
    left: 0;
}

/* ドットのcss */

.p_original_mv_box .slick-dots {
    writing-mode: vertical-rl;
    position: absolute;
    bottom: 5px;
    right: -30px;
}

.p_original_mv_box .slick-dots li {
    margin: 10px 5px 0;
}

.p_original_mv_box .slick-dots li button:before {
    content: "";
    position: absolute;
    background-color: #000;
    background-size: 1px 24px;
    width: 1px;
    height: 24px;
    left: 8px;
}

.p_original_mv_box_img {
    border-radius: 0 18px 18px 0;
}

.p_original_container {
    margin-top: 280px;
    padding: 45px 0;
    background-color: #f7f7f9;
    position: relative;
}

.p_original_container::before {
    content: "ORIGINAL";
    position: absolute;
    color: #f7f7f9;
    font-size: 93px;
    font-weight: 700;
    letter-spacing: .1em;
    line-height: 1.2;
    font-family: Arial, sans-serif;
    top: -86px;
    right: 0px;
}

.p_original_top {
    display: flex;
}

/* .top_work_top_left{
    position: absolute;
    width: 57%;
    left: 0;
} */

.p_original_top_right {
    margin: 0 0 0 auto;
    width: 40%;
}

.p_original_top_right_title {
    writing-mode: vertical-rl;
    color: #000;
    font-size: 28.5px;
    font-weight: 500;
    line-height: 2.4;
    letter-spacing: .25em;
    position: absolute;
    top: -100px;
    right: 62px;
}

.p_original_top_right_text {
    display: block;
    writing-mode: vertical-rl;
    color: #000;
    font-size: 13px;
    font-weight: 400;
    line-height: 2;
    letter-spacing: .3em;
    height: 337px;
}

.p_original_top_right_detail {
    margin-top: 53px;
}

.p_original_bottom {
    margin: 90px 0 80px;
    display: none;
}

.p_original_bottom_img {
    width: 82%;
    margin: 0 auto;
}

.sp_p_original_mv {
    display: none;
}

@media screen and (max-width:767px) {
    .p_original_mv {
        display: none;
        position: absolute;
        width: 53%;
        z-index: 1;
        top: -100px;
        left: 0;
    }
    .sp_p_original_mv {
        display: block;
        width: 90%;
        max-width: 500px;
        margin: 20px auto 0;
    }
    /* ドットのcss */
    .p_original_mv_box .slick-dots {
        writing-mode: vertical-rl;
        position: absolute;
        bottom: 5px;
        right: -30px;
    }
    .p_original_mv_box .slick-dots li {
        margin: 10px 5px 0;
    }
    .p_original_mv_box .slick-dots li button:before {
        content: "";
        position: absolute;
        background-color: #000;
        background-size: 1px 24px;
        width: 1px;
        height: 24px;
        left: 8px;
    }
    .p_original_mv_box_img {
        border-radius: 0 18px 18px 0;
    }
    .p_original_container {
        width: 90%;
        margin: 80px auto 0;
        padding: 0;
        padding: 30px 20px;
    }
    .p_original_container::before {
        font-size: 60px;
        letter-spacing: .05em;
        top: -53px;
        left: 0px;
    }
    .p_original_top {
        display: block;
    }
    /* .top_work_top_left{
        position: absolute;
        width: 57%;
        left: 0;
    } */
    .p_original_top_right {
        margin: 0;
        width: 100%;
    }
    .p_original_top_right_title {
        writing-mode: horizontal-tb;
        font-size: 20px;
        line-height: 1.5;
        letter-spacing: .15em;
        position: static;
    }
    .p_original_top_right_text {
        margin-top: 20px;
        writing-mode: horizontal-tb;
        font-size: 13px;
        font-weight: 400;
        line-height: 1.5;
        letter-spacing: .15em;
        height: 100%;
    }
    .p_original_top_right_detail {
        margin: 30px auto 0;
    }
    .p_original_bottom {
        margin: 30px 0 0 0;
    }
    .p_original_bottom_img {
        width: 100%;
        max-width: 500px;
        margin: 0 auto;
    }
}

/* =================================shop============================== */

.p_shop {
    position: relative;
    display: flex;
    flex-direction: row-reverse;
}

.p_shop_mv_1 {
    width: 46%;
}

/* ドットのデザイン */

.p_shop_mv_1_box .slick-dots {
    writing-mode: vertical-lr;
    bottom: 5px;
    left: -32px;
}

.p_shop_mv_1_box .slick-dots li {
    margin: 10px 5px 0
}

.p_shop_mv_1_box .slick-dots li button:before {
    content: "";
    position: absolute;
    background-color: #000;
    background-size: 1px 24px;
    width: 1px;
    height: 24px;
    left: 8px;
}

.p_shop_1 {
    margin-top: 163px;
}

.container.p_shop_container_1 {
    width: calc(100% - 56%);
    margin: 0 0 0 auto;
    padding-right: 70px;
}

.p_shop_soy {
    max-width: 570px;
}

.p_shop_soy_title {
    color: #000;
    font-size: 25px;
    font-weight: 500;
    line-height: 2;
    letter-spacing: .2em;
}

.p_shop_soy_text {
    margin-top: 37px;
    color: #000;
    font-size: 13px;
    font-weight: 400;
    letter-spacing: .25em;
    line-height: 1.75;
}

.p_shop_soy_detail {
    margin-top: 20px;
}

.p_shop_link {
    margin-top: 30px;
    width: 100%;
    max-width: 567px;
    display: flex;
}

.p_shop_link_list {
    width: calc(50% - 16px);
}

.p_shop_link_list+.p_shop_link_list {
    margin-left: 32px;
}

.p_shop_link_list_content {
    display: block;
    color: #FFF;
    font-size: 13px;
    font-weight: 400;
    line-height: 4;
    letter-spacing: .2em;
    text-align: center;
    background-color: #a9281f;
    background-image: url(../img/cart_white.png), url(../img/yazirushi_white.png);
    background-repeat: no-repeat;
    background-size: 27px 22px, 5px 10px;
    background-position: 8% 50%, 90% 50%;
}

.sp_p_shop_mv_1 {
    display: none;
}

@media screen and (max-width: 767px) {
    .p_shop {
        display: flex;
        flex-direction: column-reverse;
        padding: 0 20px;
    }
    .p_shop_mv_1 {
        width: 95%;
        margin: 40px 0 0 auto;
    }
    /* ドットのデザイン */
    .p_shop_mv_1_box .slick-dots {
        writing-mode: vertical-lr;
        bottom: 5px;
        left: -32px;
    }
    .p_shop_mv_1_box .slick-dots li {
        margin: 10px 5px 0
    }
    .p_shop_mv_1_box .slick-dots li button:before {
        content: "";
        position: absolute;
        background-color: #000;
        background-size: 1px 24px;
        width: 1px;
        height: 24px;
        left: 8px;
    }
    .p_shop_1 {
        margin-top: 60px;
    }
    .container.p_shop_container_1 {
        width: 100%;
        margin: 0;
        padding-right: 0;
    }
    .p_shop_soy {
        max-width: 570px;
        margin: 0 auto;
    }
    .p_shop_soy_title {
        font-size: 20px;
        line-height: 1.3;
    }
    .p_shop_soy_text {
        margin-top: 20px;
        font-size: 13px;
    }
    .p_shop_soy_detail {
        margin-top: 20px;
    }
    .p_shop_link {
        margin-top: 20px;
        display: block;
    }
    .p_shop_link_list {
        width: 100%;
        max-width: 350px;
        margin: 0 auto
    }
    .p_shop_link_list+.p_shop_link_list {
        margin-left: auto;
        margin-top: 10px;
    }
    .p_shop_link_list_content {
        display: block;
        color: #FFF;
        font-size: 13px;
        font-weight: 400;
        line-height: 4;
        letter-spacing: .2em;
        text-align: center;
        background-color: #a9281f;
        background-image: url(../img/cart_white.png), url(../img/yazirushi_white.png);
        background-repeat: no-repeat;
        background-size: 27px 22px, 5px 10px;
        background-position: 8% 50%, 90% 50%;
    }
}

/* ==================================shop2================================== */

.p_shop_mv_2 {
    width: 46%;
    position: absolute;
    top: 28%;
    left: 0;
}

/* ドットのデザイン */

.p_shop_mv_2 .slick-dots {
    writing-mode: vertical-rl;
    position: absolute;
    bottom: 5px;
    right: -30px;
}

.p_shop_mv_2 .slick-dots li {
    margin: 10px 5px 0;
}

.p_shop_mv_2 .slick-dots li button:before {
    content: "";
    position: absolute;
    background-color: #000;
    background-size: 1px 24px;
    width: 1px;
    height: 24px;
    left: 8px;
}

.p_shop_container_2 {
    margin-top: 137px;
}

.p_shop_wheat {
    width: 50%;
    margin: 0 0 0 auto;
}

.p_shop_wheat_title {
    color: #000;
    font-size: 25px;
    font-weight: 500;
    letter-spacing: .2em;
    line-height: 1.5;
}

.p_shop_wheat_text {
    margin-top: 47px;
    color: #000;
    font-size: 13px;
    font-weight: 400;
    letter-spacing: .25em;
    line-height: 1.75;
}

.p_shop_wheat_detail {
    margin-top: 20px;
}

.sp_p_shop_mv_2 {
    display: none;
}

@media screen and (max-width:767px) {
    .p_shop_mv_2 {
        display: none;
    }
    .sp_p_shop_mv_2 {
        display: block;
        width: 90%;
        max-width: 600px;
        margin: 20px auto 0;
    }
    /* ドットのデザイン */
    .sp_p_shop_mv_2 .slick-dots {
        writing-mode: vertical-rl;
        position: absolute;
        bottom: 5px;
        right: -30px;
    }
    .sp_p_shop_mv_2 .slick-dots li {
        margin: 10px 5px 0;
    }
    .sp_p_shop_mv_2 .slick-dots li button:before {
        content: "";
        position: absolute;
        background-color: #000;
        background-size: 1px 24px;
        width: 1px;
        height: 24px;
        left: 8px;
    }
    .p_shop_container_2 {
        width: 90%;
        margin: 50px auto 0;
    }
    .p_shop_wheat {
        width: 100%;
        margin: 0;
    }
    .p_shop_wheat_title {
        font-size: 18px;
        letter-spacing: .1em;
        line-height: 1.2;
    }
    .p_shop_wheat_text {
        margin-top: 20px;
        font-size: 11px;
        font-weight: 400;
        letter-spacing: .15em;
        line-height: 1.5;
    }
    .p_shop_wheat_detail {
        margin: 20px auto 0;
    }
}

/* =================================oatmeal============================= */

.p_oatmeal {
    padding-top: 274px;
}

.p_oatmeal_title {
    color: #000;
    font-weight: 500;
    font-size: 28.5px;
    letter-spacing: .25em;
    line-height: 2;
    text-align: center;
    position: relative;
    z-index: 1;
}

.p_oatmeal_title::before {
    content: "OATMEAL RECIPE";
    position: absolute;
    color: #f7f7f9;
    font-size: 87.5px;
    font-weight: 700;
    letter-spacing: .05em;
    line-height: 0;
    font-family: Arial, sans-serif;
    top: 50%;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    z-index: -1;
}

.p_oatmeal_container {
    background-color: #f7f7f9;
    padding: 30px 0 57px 0;
}

.p_oatmeal_text {
    color: #000;
    font-size: 13px;
    font-weight: 400;
    letter-spacing: .2em;
    line-height: 2;
    text-align: center;
}

.p_oatmeal_list {
    display: flex;
    width: 100%;
    max-width: 1150px;
    margin: 23px auto 0;
    padding-top: 75px;
}

.p_oatmeal_list_item {
    width: calc(25% - 34.5px);
    position: relative;
}

.p_oatmeal_list_item+.p_oatmeal_list_item {
    margin-left: 46px;
}

.p_oatmeal_list_item::before {
    content: "";
    position: absolute;
    background-size: 56px 60px;
    width: 56px;
    height: 60px;
    top: -75px;
    left: 50%;
    transform: translateX(-50%);
}

.oatmeal_ranking_1::before {
    background-image: url(../img/p_oatmeal_ranking_1.png);
}

.oatmeal_ranking_2::before {
    background-image: url(../img/p_oatmeal_ranking_2.png);
}

.oatmeal_ranking_3::before {
    background-image: url(../img/p_oatmeal_ranking_3.png);
}

.p_oatmeal_list_item a {
    display: block;
}

.p_oatmeal_list_item_text {
    margin-top: 12px;
    color: #000;
    font-size: 12px;
    font-weight: 400;
    line-height: 2;
    letter-spacing: .175em;
}

.p_oatmeal_detail {
    margin: 30px auto 0;
}

@media screen and (max-width:767px) {
    .p_oatmeal {
        padding-top: 80px;
    }
    .p_oatmeal_title {
        font-size: 24px;
        letter-spacing: .15em;
        line-height: 1.5;
    }
    .p_oatmeal_title::before {
        font-size: 50px;
        top: 58%;
    }
    .p_oatmeal_container {
        padding: 20px 0 30px 0;
    }
    .p_oatmeal_text {
        font-size: 11px;
        letter-spacing: .1em;
        line-height: 1.5;
    }
    .p_oatmeal_list {
        display: block;
        width: 90%;
        max-width: 400px;
        margin: 10px auto 0;
        padding-top: 0px;
    }
    .p_oatmeal_list_item {
        width: 100%;
        max-width: 600px;
        margin: 0 auto;
        padding-top: 80px;
    }
    .p_oatmeal_list_item_img {
        width: 80%;
        margin: 0 auto;
    }
    .p_oatmeal_list_item+.p_oatmeal_list_item {
        margin-left: 0px;
        margin-top: 15px;
    }
    .p_oatmeal_list_item::before {
        background-size: contain;
        width: 67px;
        height: 72px;
        top: 0;
    }
    .oatmeal_ranking_1::before {
        background-image: url(../img/p_oatmeal_ranking_1.png);
    }
    .oatmeal_ranking_2::before {
        background-image: url(../img/p_oatmeal_ranking_2.png);
    }
    .oatmeal_ranking_3::before {
        background-image: url(../img/p_oatmeal_ranking_3.png);
    }
    .p_oatmeal_list_item_text {
        margin-top: 6px;
        line-height: 1.5;
        letter-spacing: .1em;
        text-align: center;
    }
    .p_oatmeal_detail {
        margin: 30px auto 0;
    }
    .pc_br {
        display: none;
    }
}

/* その他 */

.private_main .top_recruit_title::before {
    color: #f7f7f9;
}

.private_main .top_news_top_title::before {
    color: #f7f7f9;
}

.private_main .top_csr_outline_title::before {
    color: #f7f7f9;
}

.private_main .top_csr {
    padding-bottom: 100px;
}

.private_main .top_csr_bottom {
    background-color: #f7f7f9;
    padding: 70px 30px 40px;
}