@charset "utf-8";

/**************************************************************
barbpack
**************************************************************/

/********* contact *********/
#contact > div {
    margin-bottom: 15px;
}

#contact > div > div {
    margin-bottom: 5px;
}

#contact textarea {
    height: 200px;
}

a.image {
    background: none;
}

#related_post li .title{
    margin-bottom: 10px;
}

.require:before {
    content: "必須";
    display: table-cell;
    float: left;
    margin-left: 20px;
    color: white;
    width: 30px;
    height: 20px;
    font-size: 12px;
    background-color: #ea5532;
    text-align: center;
    vertical-align: middle;
    border-radius: 3px;
    line-height: 20px;
    margin: 0 10px 0 5px;
}

.option:before {
    content: "任意";
    display: table-cell;
    float: left;
    color: white;
    width: 30px;
    height: 20px;
    font-size: 12px;
    background-color: #9d8e87;
    text-align: center;
    vertical-align: middle;
    border-radius: 3px;
    line-height: 20px;
    margin: 0 10px 0 5px;
}

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

@media screen and (max-width: 640px) {
    .pc {
        display: none;
    }
}

@media screen and (min-width: 641px) {
    .sm {
        display: none;
    }
}

#footer .footer_menu {
    width: 300px;
    margin: 0 auto;
}

#footer .footer_menu ul ul {
    padding: 0 0 0 1em;
    margin: 0 0 1em 0;
}

#footer .footer_menu > div > ul > li > a {
    font-size: 1.2em;
}

/********* header *********/
@media screen and (min-width: 641px) {

    #header_wrap {
        background: none;
    }

    #header {
        width: 100%;
    }

    #header {
        height: 196px;
    }

    #header .header_banner {
        width: 600px;
        position: absolute;
        right: 0;
        margin-top: 20px;
        text-align: right;
    }

    #header .header_banner > div {
        float: right;
    }
    .header_banner .banner_row {
        margin-top: 15px;
        width: 335px;
        float: left;
    }

    .header_banner .banner_row > div:first-child {
        float: left;
    }

    .header_banner .banner_row > div:nth-child(2) {
        float: right;
    }

    .header_banner .banner_row > div {
        width: 160px;
        height: 48px;
        position: relative;
    }

    .header_banner .banner_row > div > a {
        position: absolute;
        width: 100%;
        height: 100%;
        top: 0;
        left: 0;
    }

    .header_banner .banner_row .barb_text_banner {
        line-height: 48px;
        font-size: 18px;
        text-align: center;
    }

    .header_banner .banner_row .barb_text_banner .fa {
        margin-right: 0.5em;
    }

    .header_banner a {
        text-decoration: none;
    }

    .header_banner .text_row {
        width: 500px;
    }
    .header_banner .text_row .textwidget {
        margin-top: 8px;
    }

    .header_banner .text_row .textwidget > div {
        height: 20px;
        font-size: 14px;
    }

    .barb_banner_widget {
        display: inline-block;
    }

    #desc_wrap {
        background: #ccc;
        height: 42px;
    }

    #desc_fit {
        width: 994px;
        height: 42px;
        margin: 0 auto;
    }

    #site_description {
        position: relative;
    }

    #header_logo_cover {
        width: 100%;
    }

    #header_logo_wrap {
        width: 994px;
        position: relative;
        margin: 0 auto;
        height: 132px;
    }

    #logo {
        height: 106px;
        top: 0 !important;
        /*bottom: 0;*/
        margin: auto;
        position: absolute;
    }
    #header_logo_wrap #logo {
        bottom: 0;
    }

    #menu_wrap {
        width: 100%;
        height: 48px;
        border-width: 1px 0 1px 0;
        border-style: solid;
        border-color: #ddd;
    }

    a[href^=tel] {
        cursor: default;
    }

    #menu_fit {
        width: 994px;
        height: 48px;
        margin: auto;
    }

    #global_menu {
        left: auto;
    }

    #index_top {
        margin-bottom: 40px;
    }

    #featured_post .post1 .image img {
        margin: 0;
    }

    #featured_post2 .post1 .image_area {
        border: none;
    }

    #featured_post2 .post1 .image {
        margin: 0;
    }

    #contents #featured_post2 + .past_list_link {
        position: relative;
        top: -10px;
        padding-bottom: 5px;
    }

    #post_list {
        border: none;
    }

    #post_list .image_area {
        background: none;
        border: none;
    }

    #post_list .image {
        margin: 0;
    }
    #post_list a.image img {
        width: auto;
        max-height: 210px;
        max-width: 340px;
        margin: 0 auto;
    }

    #recent_post .image {
        margin: 0 auto;
    }
    #recent_post .image img,
    #featured_post .image img {
        width: 100%;
        height: auto;
    }

    #news_wrap,
    #news_ticker {
        display: none;
    }

    #contents {
         margin-top: 67px;
    }


    #content {
        border: none;
    }

    #footer .footer_logo img {
        max-width: 450px;
    }

    #footer .footer_menu_wrap {
        float: right;
        width: 490px;
    }

    #footer #footer_left {
        float: left;
    }
}

@media screen and (max-width: 640px) {

    .title_text {
        padding: 10px 0 0 15px;
        float: left;
        letter-spacing: 0.1rem;
        font-size: 12px;
        color: #E0E0E0;
        display: block;
    }
    .header_banner_wrapper {
        padding: 0 15px;
    }

    .header_banner {
        width: 100%;
    }

    .header_banner > div {
        width: 48%;
        padding: 10px 0;
        font-size: 18px;
        text-align: center;
        line-height: 1.5em;
    }

    .header_banner > div:first-child {
        float: left;
    }

    .header_banner > div:last-child {
        float: right;
    }

    .text_header_banner {
        text-align: center;
        margin-top: 15px
    }

    .text_header_banner .textwidget {
        font-size: 12px;
    }

    #logo {
        display: none;
    }

    #logo_sm {
        text-align: center;
        padding: 20px 15px 0 15px;
    }

    #logo_sm img {
        width: 100%;
    }

    #global_menu {
        margin-top: 30px;
    }

    .barb_banner_widget {
        display: inline-block;
        margin: 0;
        padding: 0;
    }

    #recent_post .past_list_link,
    #featured_post .past_list_link {
        margin: 0 10px 0 0;
    }

    #featured_post2 ul {
        padding-bottom: 30px;
    }

    #contents #featured_post2 + .past_list_link {
        position: relative;
        top: -24px;
        padding-right: 10px;
    }

    .header_banner .barb_banner_widget {
        max-width: 45%;
    }

    #index_top {
        margin-top: 15px;
    }

    #post_list .image img {
        border: none;
    }

    #featured_post .post1 .image img,
    #featured_post2 .post1 .image img,
    #post_list .image img {
        border: 0;
        max-width: none;
        width: 100%;
        margin: 0 auto;
        padding: 4px 0;
    }

    #recent_post .image img,
    #featured_post ul.post2 li .image img,
    #featured_post2 li .image img,
    #related_post .image img {
        border: 0;
        padding: 0;
        width: 32%;
    }

    #related_post li {
        border-bottom: none;
    }
    #related_post .image img {
        border: none;
    }
    .page_navi {
        margin: 20px 0 0 15px;
    }
    #footer .footer_menu_wrap {
        margin-bottom: 40px;
    }
}

/********* top area *********/

#recommend_gallery {
    /* トップ画像枠の非表示 */
    background: transparent;
    border: 0;
    padding: 0;
    width: 660px;
}

@media screen and (max-width: 640px) {
    #recommend_gallery {
        max-width: 100%;
    }
}

#recommend_gallery .rs-caption {
    display: none;
}


#recommend_gallery .rs-thumb-wrap {
    display: none;
}


#global_menu {
    bottom: auto;
}


/********* top body *********/
#recent_post .title,
#featured_post ul.post2 li .title,
#featured_post2 li .title {
    /* トップページ抜粋追加箇所 */
    margin-bottom: 10px;
}

.info .excerpt {
    /* トップページ抜粋追加箇所 */
    font-size: 12px;
}

#recent_post .info .excerpt {
    margin: 0 10px;
}

#contents .text_recent_post {
    padding: 10px;
    border: 1px solid #ccc;
    margin: 0 0 15px 0;
    background: #fff;
}

#contents .page .text_recent_post {
    border: none;
    min-height: 300px;
}

#contents .text_recent_post .post_list {
    margin: 0 0 20px 0;
}

#contents .text_recent_post .post_list li:not(:last-child) {
    border-bottom: 1px dotted #ccc;
}

#contents .text_recent_post .list_date {
    float: left;
    line-height: 1.8;
}

#contents .page .text_recent_post .list_date {
    line-height: 2.0;
}

#contents .text_recent_post .list_title {
    float: left;
    margin-left: 10px;
    line-height: 1.8;
}

@media screen and (max-width: 640px) {
    #contents .text_recent_post .list_date {
        width: 25%;
    }

    #contents .text_recent_post .list_title {
        width: 70%;
    }
}

#contents .past_list_link {
    text-align: right;
    margin-top: 15px;
}

#main_col #recent_post li,
#main_col #featured_post,
#main_col #featured_post2,
#contents #main_col .text_recent_post,
#main_col #footer_banner {
    border: none;
}

/**************************************************************
custom side widget
**************************************************************/
#side_col .barb_side_widget,
#side_col .barb_side_widget-2 {
    margin-bottom: 15px;
}

#side_col .barb_side_widget h3,
#side_col .barb_side_widget-2 h3 {
    margin: 0;
}

.barb_banner_widget img {
    height: auto;
    max-width: 100%;
    width: auto;
}

.barb_custom_widget img {
    width: 80px;
    height: 80px;
    float: left;
}

.barb_custom_widget .info {
    float: left;
    margin-left: 10px;
    width: 90px;
}

.barb_custom_widget .info .title {
    margin-bottom: 5px;
}

.barb_custom_widget ul {
    list-style: none;
}

.barb_custom_widget ul li {
    background-image: none;
    padding: 0px;
}

.barb_custom_widget ul li:not(:last-child) {
    border-bottom: 1px dotted #ddd;
}

/**************************************************************
color
**************************************************************/
@media screen and (max-width: 640px) {
    #main_col,
    #index_top,
    #side_col {
        background: #fff;
    }

    #main_col {
        padding: 0;
    }
}

/*------------------ デフォルトカラー ------------------*/
#menu_wrap {
    background: linear-gradient(to bottom, #f3f3f3 0%, #feffff 100%); /* グローバルナビの背景色 */
}

/* SP */
@media screen and (max-width: 640px) {

    #header a.menu_button:hover {
        background: transparent;
        opacity: 0.9;
        box-shadow: 1px 1px 2px rgba(0, 0, 0, 0.2) inset;
        color: #fff;
    }

    #header a.active {
        background: transparent;
        box-shadow: 1px 1px 2px rgba(0, 0, 0, 0.2) inset;
        color: #fff;
    }

}

/*-------------------------------------------------------*/

#footer_logo_area {
    margin-top: 20px;
}

#footer_logo_area #footer_description2 {
    padding-top: 5px;
    margin-left: 8px;
}

#nav_menu-2.footer_widget {
    margin-top: 8px;
}

#footer_wrap {
    padding: 40px 0;
}

/* フォームボタン */
.mw_wp_form > form .buttons input {
background: linear-gradient(to bottom, #00608d 0%,#001e43 100%); }

/* トップページ　バナーコンテンツ */
.main_banner img {
    width: 100%;
    height: 100%;
}

.main_banner .headline1 {
    margin: 0 0 20px 0;
}

@media screen and (min-width: 641px) {
    .main_banner {
        margin-bottom: 32px;
    }
}

/* SP */
@media screen and (max-width: 640px) {

    .main_banner {
        margin-bottom: 18px;
    }

    /* サイドナビ */
    #side_col {
        text-align: center;
    }

    #side_col #index_side_widget {
        padding: 0 15px;
    }

    #side_col #index_side_widget .side_widget {
        padding: 0;
    }

    #side_col #index_side_widget > div {
        width: 100%;
        text-align: center;
    }

    #side_col .barb_side_widget img {
        width: 100%;
    }

    #footer_banner li img {
        width: 100%;
    }

    #footer_logo {
        display: block;
        padding-top: 40px;
        text-align: center;
    }

    #footer_logo_area #footer_description2 {
        margin: 0 8px;
    }

}

