/*店舗詳細*/
.area_content {
    overflow: hidden;
    max-width: 1240px;
    margin: 20px auto;
    padding: 0 20px;
    color: var(--color-black);
}
.area_content a {
    text-decoration: underline;
    color: #0068B7;
}
.area_shop_nav {
    margin: 0 auto;
    padding-top: 0;
    margin-bottom: 2em;
}
.area_shop_nav ul {
    position: relative;
    display: flex;
    justify-content: space-around;
    width: 100%;
    list-style-type: none;
    color: #ffffff;
    background-color: var(--color-black);
    padding: 0;
    align-items: center;
}
.area_shop_nav ul li {
    width: calc( 100% / 3 );
    margin-bottom: 0;
}
.area_shop_nav ul li a, .area_shop_nav ul li span {
    position: relative;
    display: inline-block;
    width: 100%;
    text-align: center;
    line-height: 2;
    font-size: 1.5em;
    font-weight: 500;
    color: inherit;
    text-decoration: none;
}
.area_shop_nav ul li a:before {
    content: '';
    position: absolute;
    left: -1px;
    top: 10%;
    width: 2px;
    height: 80%;
    background-color: #ffffff;
}
.area_shop_nav ul li:first-of-type a:before {
    display: none;
}
#shop_top table tr{
    width:100%;
}
#shop_top table tr td, #shop_top table tr td a{
    text-align: justify;
    word-break: break-all;
}
@media screen and (max-width: 640px){
    .area_shop_nav ul li a, .area_shop_nav ul li span {
        font-size: 2.8vw;
    }
    #map_big{
        width:100%;
    }

    /*
    #shop_top table, #shop_top tr, #shop_top tr th,#shop_top tr td{
        display: block !important;
        padding: 0;
        width:100% !important;
    }
    #shop_top tr th{
        background-color: #f3f3f3;
    }
    #shop_top tr td{
        padding: 5px 0 10px;
        word-break: break-all;
    }

     */
}

.area_shopsummary {
    overflow: hidden;
    margin: 20px auto;
    padding-right: 40px;
    padding-top: 0;
    line-height: 1.2em;
}
.area_shopsummary .shop_image {
    max-height: 500px;
    max-width: 500px;
}
.area_shopsummary .shop_gallery {
    display: block;
    float: left;
    width: 48%;
    text-align: center;
}
.capiton {
    bottom: 0;
    width: 100%;
    padding: 0.5em 0 0 0;
    font-size: 0.9em;
}
.area_shopsummary .area_shopsummary_detail {
    position: relative;
    float: right;
    width: 51.5%;
    font-size: 1.5em;
}

.meta_address, .meta_tel, .meta_category {
    font: var(--font-round);
    font-size: 0.7em;
}
.meta_address:before {
    content: '';
    display: inline-block;
    width: 0.9em;
    height: 0.9em;
    margin-right: 0.2em;
    background: url(/img/icon_map.svg) no-repeat center center;
    background-size: contain;
}
.meta_category:before {
    content: ' ｜ ';
}
.area_shopname .meta_shop, .area_shopname .meta_shop_sub {
    font: var(--font-round);
}
.area_shopname {
    color: var(--main-color);
}
.area_shopname .meta_shop_sub {
    margin-right: 0.7em;
    font-size: 0.75em;
}
.area_box_plan .box_plan_title span, .area_shopname .meta_shop, .area_shopname .meta_shop_sub {
    overflow-wrap: anywhere;
}
.area_shopsummary .area_shopsummary_detail .meta_shop_sub {
    margin-top: 0.3em;
}
.area_shopsummary .area_shopsummary_detail p {
    padding: 0 10px;
    line-height: 1.5;
}
.area_shopsummary .area_shopsummary_detail .meta_copy {
    clear: both;
    margin-top: 0.5em;
    padding-top: 0.5em;
    padding-bottom: 0.5em;
    font-size: 0.9em;
    font-weight: 700;
    border-top: dotted 3px gray;
}

#shop_menu {
    margin: 50px auto;
    text-align: center;
}
.shop_sub_title {
    margin: 1em 0;
    line-height: 2.2;
    font-size: 1.6em;
    font-weight: 700;
    text-align: center;
    background-color: var(--sub-bg-color);
}
#shop_menu .shop_message_image {
    display: block;
    text-align: center;
    padding-bottom: 1.5em;
}
#shop_menu .shop_message_image img{
    max-height: 500px;
    max-width: 500px;
    margin-right: 1em;
}
#shop_menu .shop_message_detail {
    margin: 1em auto;
    max-width: 800px;
    text-align: left;
    font-size: 1.5em;
    font-weight: 500;
    line-height: 1.5em;
}
#shop_info table {
    font-size: 1.2em;
}

@media screen and (max-width: 640px){
    .area_content {
        padding: 0 0;
    }

    .area_shop_nav ul {
        padding: 0 0 4px;
    }
    .area_shopsummary {
        padding-right: 0;
    }
    .area_shopsummary .shop_gallery {
        display: block;
        float: none;
        width: 100%;
    }
    .area_shopsummary .area_shopsummary_detail {
        position: relative;
        float: none;
        width: 100%;
        font-size: 1.3em;
    }
    .area_shopsummary .area_shopsummary_detail p {
        padding: 0 0;
    }
    #shop_menu {
        margin: 0 auto 30px
    }
    #shop_menu .shop_message_image {
        display: block;
        float: none;
        width: 100%;
    }
    .area_shopsummary .shop_image {
        max-width: 100%;
        max-height: 300px;
    }
    #shop_menu .shop_message_image img{
        max-width: 100%;
        max-height: 300px;
    }

    .supporters_sub_title{
        text-align: justify;
        line-height: 1.5;
        margin-top: 0;
    }
}