* {
    color: #56340f;
    font-family: dnp-shuei-nmincho-std, sans-serif;
    font-style: normal;
    font-weight: 400;
}
footer {
    background-color: #56340f;
}

main {
    background-color: #f9f2ea;
}
.header_area {
    align-items: flex-start;
    display: flex;
    justify-content: space-between;
}
.tel_link_area {
    align-items: center;
    display: flex;
    justify-content: flex-end;
    text-decoration: none;
}
.menu_list {
    align-items: center;
    display: flex;
    justify-content: space-between;
}
.contents:nth-child(odd) {
    background-image: url("../img/main_bg.jpg");
    background-size: cover;
    box-shadow: 0 50px 50px -3px #f9f2ea inset, 0 -50px 50px -3px #f9f2ea inset;
    padding: 100px 0;
}
.contents:nth-child(even) {
    padding: 50px 0;
}
.topics_flex {
    display: flex;
    justify-content: space-between;
}
.topic_image_area {
    box-shadow: 0 0 10px 10px #fff inset;
    width: 100%;
}
.concept_h3 {
    text-align: center;
}
.possible_list {
    display: flex;
    flex-wrap: wrap;
}
.possible_list_item {
    display: flex;
    justify-content: space-between;
    margin-top: 50px;
    width: 100%;
}
.possible_item_title {
    text-align: center;
}
.online_shop_link_area {
    align-items: center;
    background-color: #fff;
    border-radius: 50px;
    display: flex;
    justify-content: flex-start;
}
.online_shop_link_area:hover {
    background-color: #56340f;
}
.online_shop_link_area:hover .before_hover_icon {
    display: none;
}
.online_shop_link_area:hover .after_hover_icon {
    display: block;
}
.online_shop_link_area:hover .shop_link_text {
    color: #fff;
}
.online_shop_link_area {
    padding: 10px 30px;
}
.icon_image_area {
    width: 30px;
}
.after_hover_icon {
    display: none;
}
.shop_link {
    display: block;
    text-decoration: none;
}
.company_information_area {
    align-items: flex-start;
    display: flex;
    justify-content: space-between;
}
.company_information_table th,
.company_information_table td,
.company_overview th,
.company_overview td {
    padding: 10px;
}

.company_information_table th,
.company_information_table td,
.company_overview th,
.company_overview td {
    border: 1px dashed #000;
}
.map_note {
    line-height: 1.5;
}
.white_blur {
    position: absolute;
    box-shadow: 0 0 10px 10px #fff inset;
    z-index: 100000;
    width: 100%;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
}

@media (min-width: 768px) {
    p {
        line-height: 2.5;
    }
    h2 {
        font-size: 35px;
    }
    .inner {
        padding: 0 20px;
        max-width: 1240px;
        margin: 0 auto;
    }
    .header_area {
        padding: 0 30px;
    }
    .logo_img {
        width: 100px;
    }
    .tel_link_area {
        margin-top: 20px;
    }
    .tel_image_area {
        width: 15%;
    }
    .tel_num {
        font-size: 20px;
        margin-top: 5px;
    }
    .menu_list {
        margin: 80px auto 40px;
        width: 50%;
    }
    .menu_list_item {
        text-align: center;
        width: 30%;
    }
    .topics_flex {
        margin: 40px auto;
        width: 90%;
    }
    .topic_content_area {
        width: 28%;
    }
    .concept_h3 {
        font-size: 45px;
        margin: 30px 0;
    }
    .possible_item_title {
        font-size: 30px;
    }
    .shop_link {
        margin: 20px auto 0;
        width: 60%;
    }
    .shop_link_text {
        margin-left: 20px;
    }
    .concept_text_area {
        text-align: center;
    }
    .company_information_area {
        margin-top: 40px;
    }
    .company_information_table,
    .company_map_area {
        width: 48%;
    }
    .company_information_table th {
        width: 37%;
    }
    .company_information_table td {
        width: 63%;
    }
    .possible_list_item:nth-child(even) {
        flex-direction: row-reverse;
    }
    .possible_item_text_area {
        width: 50%;
    }
    .company_overview {
        margin: 30px auto 0;
    }
    .company_overview th {
        width: 18%;
    }
    .company_overview td {
        width: 82%;
    }
    .company_detail {
        margin-top: 50px;
    }
}

@media (max-width: 767px) {
    .header_area {
        align-items: center;
        padding: 0 20px;
    }
    .tel_image_area {
        width: 20%;
    }
    .topics_flex,
    .company_information_area,
    .menu_list {
        flex-wrap: wrap;
    }
    .menu_list_item {
        margin-top: 20px;
        text-align: center;
        width: 100%;
    }
    .topic_content_area {
        margin-top: 30px;
    }
    .concept_text_area {
        margin-top: 20px;
        text-align: left;
    }
    .concept_h3 {
        font-size: 25px;
        line-height: 1.5;
    }
    .company_information_area,
    .company_map_area {
        margin-top: 20px;
    }
    .company_overview {
        margin-top: 30px;
    }
    .company_information_table th,
    .company_overview th {
        width: 40%;
    }
    .company_information_table td,
    .company_overview td {
        width: 60%;
    }
    .possible_list_item {
        flex-wrap: wrap;
        flex-direction: column-reverse;
    }
    .possible_item_title {
        font-size: 20px;
    }
    .possible_item_image {
        margin-top: 20px;
    }
    .online_shop_link_area {
        margin-top: 20px;
    }
    .shop_link_text {
        margin-left: 20px;
    }
    .company_detail {
        margin-top: 30px;
    }
}
