@charset "utf-8";

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

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

#contact > div > div {
    margin: 8px 0 24px 0;
}

#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;
}

.wpcf7 .wpcf7-not-valid {
    padding: 8px 0;
    margin-bottom: 4px;
    display: block;
}
/**************************/

@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 {
        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: 100px;
        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;
    }

    #featured_post2 li:last-child {
        margin-bottom: 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;
    }

    .barb_cont_wrap {
        margin: 0 0 15px 0;
    }

    #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;
    }

    .barb_cont_wrap {
        margin: 0 0 0 0;
        padding: 0 0 50px 0;
    }

    .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;
}

#recommend_gallery.full_width {
    width: 99.39vw;
    margin-left: calc(50% - 50vw);
    /* margin-top: 25px; */
}
@media screen and (max-width: 1024px) {
    #recommend_gallery.full_width {
        width: 100vw;
    }
}
@media screen and (max-width: 768px) {
    #recommend_gallery.full_width {
        width: 100%;
        margin-left: 0;
    }
}
#recommend_gallery.full_width img {
    width: 100%;
    height: auto;
}



#global_menu {
    bottom: auto;
}


#footer_banner .lead-text {
    padding: 15px 15px 0 15px;
}
@media screen and (max-width: 640px) {
    #footer_banner .lead-text {
        padding: 0px 15px 0 15px;
    }
}
/********* 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) {
    #header_wrap ~ .header_banner_wrapper.sm .textwidget {
        display: none;
    }
    .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;
    }

}

/*----------------------------------
全体背景
----------------------------------*/
body {
	background: #fff;
	letter-spacing:0.08rem;
    font-family: "Lato","Helvetica Neue",Helvetica,Arial,"Yu Gothic Medium","游ゴシック Medium","游ゴシック体",YuGothic,"Hiragino Kaku Gothic ProN","Hiragino Kaku Gothic Pro","Meiryo","メイリオ","ＭＳ ゴシック",sans-serif;
	-webkit-text-size-adjust: 100%;/** 文字の拡大防止 **/}

img{
	vertical-align:bottom;}

/*----------------------------------
イメージロールオーバー
----------------------------------*/
body a:hover img{
	opacity: 0.8;}

/*----------------------------------
ヘッダロゴ背景
----------------------------------*/
@media screen and (max-width: 640px) {
/*　メインビジュアル下の調整　*/
#index_top {
    margin-top: 0;
	padding:0;/*横幅いっぱい*/}
}


/*----------------------------------
サイト説明文部分
----------------------------------*/
#desc_wrap {
	letter-spacing:0.15rem;}

#site_description {
	font-weight:normal;}

@media screen and (max-width: 640px) {
#header{
	min-height: 40px;
	padding:7px 0 0 0;}
}


/*----------------------------------
グローバルメニュー
----------------------------------*/
#menu_wrap {
	letter-spacing:0.15rem;}

#global_menu li a {
	font-size: 14px;
	font-weight:bold;}


@media screen and (max-width: 640px) {
/**** 折りたたみメニュー ****/
#menu_fit{
	margin:40px 0 0 0;}


/**** メニューボタン ****/
#header a.menu_button {
    padding: 10px;
    line-height:1;
	font-weight:bold;}

#header a.menu_button:hover,
#header a.menu_button:active {
	opacity: 1.0;
    box-shadow:none;}


#global_menu {
	margin-top: 40px;
	top: 0;}

#global_menu li a {
	padding:2px 10px 0 32px;
	line-height: 37px;}

}

/*----------------------------------
電話番号・お問い合わせ
----------------------------------*/
.header_banner .banner_row .barb_text_banner {
	font-size:16px;
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;}

.header_banner .banner_row {
    margin-top: 0px;
    width: 335px;}

.header_banner .banner_row .barb_text_banner span {
    letter-spacing:0.1rem;}

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

/**** 住所　文字間 ****/
.textwidget{
	letter-spacing:0.1rem;}



@media screen and (max-width: 640px) {
/*　電話番号・お問い合わせ　矩形　*/
.header_banner_wrapper {
    padding: 0 15px 0 15px;
}

.header_banner > div {
	font-size:14px;
	line-height: 1.0;
	letter-spacing:0.1rem;
    margin:18px 0 0 0;
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;}

/*　電話番号・お問い合わせリンク　*/
.header_banner > div a{
	text-decoration:none;}


/*　住所テキスト　*/
.textwidget{
	line-height:1.5;
	padding:0 0 11px 0;}
}


/*----------------------------------
ピックアップ
----------------------------------*/
#index_pickup {
	margin: 0 0 0 0;}

/*----------------------------------
一覧画像 ※firefoxでの線消し
----------------------------------*/
@media screen and (min-width: 641px) {/**  PC ***/
#post_list a.image img{
	max-width:initial;}
}


/*----------------------------------
top記事・サムネイル等　テキスト(下層関連情報も含む)
----------------------------------*/
#related_post .info{
	font-size:12px;}

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

#post_list li,
#featured_post .post1,
#featured_post ul.post2,
#featured_post2 li {
    border-bottom: 1px dotted #999;}

#recent_post .info .excerpt {/*トップ　C 最新の記事テキスト*/
    margin: 0 15px;
	text-align:justify;}


#post_list .excerpt,/*下層　一覧テキスト*/
#featured_post .post1 .excerpt {
    padding-right: 0;}

#post_list .title,
#related_post .title,
#featured_post .post1 .title,
#featured_post ul.post2 li .title,
#featured_post2 .post1 .title,
#featured_post2 li .title{
    font-size: 14px;
	margin: 0 0 3px 0;}


@media screen and (min-width: 641px) {/**  PC ***/
#featured_post .post1 .title{
	margin: 0 0 5px 0;}

#featured_post ul.post2 li{
    width: 350px;
    margin: 0 15px 0 0;}

#featured_post2 li .info {
    width: 260px;}

#featured_post ul.post2 li .info {
    width: 255px;}

#post_list .info {
    width: 365px;
    margin:0;}

#recent_post .title {
    font-size: 14px;
    border-top: none;
    padding: 0 0 0 0;
	margin:7px 14px 5px 14px;}

#recent_post li {
	width: 180px;
	margin: 0 2px 0 5px;
	padding: 0 0 0 0;
	min-height: 270px;}

#recent_post .image {
    width: 160px;
    height: 160px;}

#footer_banner ol {
    margin: 15px 0 0 0;}

#footer_banner li {
	margin: 0 8px 0 15px;}

}

@media screen and (max-width: 640px) {
/*ブロック隙間　調整*/
#recent_post,
#featured_post,
#featured_post2,
#footer_banner{
    margin:0 0 0 0;
	padding: 0 0 50px 0;}

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

#post_list .excerpt{
    font-size: 12px;}

#post_list .info {
    width:100%;}

#main_col #recent_post li,
#related_post li{
    border-bottom: 1px dotted #999;
	margin: 0;}

#main_col #recent_post .title{
    border-top: none;
	padding: 0 0 0 0;}

#recent_post .title,
#featured_post .post1 .title,
#featured_post ul.post2 li .title,
#featured_post2 .post1 .title,
#featured_post2 li .title{
   margin-bottom:8px;}

#recent_post .info,
#related_post .info,
#featured_post ul.post2 li .info,
#featured_post2 li .info{
    width: 62%;
    float: right;
    margin: 0 5px 0 0;
	line-height:1.6;
	font-size:12px;}

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

#post_list .image_area {
    margin:0;}

#featured_post .post1 .image,
#featured_post2 .post1 .image_area {
    margin: 0 0 0 0;}

#featured_post .post1 .image img,
#featured_post2 .post1 .image img,
#post_list .image img {
    padding: 0 0 15px 0;}

#contents .past_list_link {
    margin: 15px 15px 0 0;}

#contents .text_recent_post .past_list_link{/* H 投稿リストの一覧はこちら */
    margin: 15px 0 0 0;}

}


/*----------------------------------
お知らせ
----------------------------------*/
#contents .text_recent_post .post_list li,
#contents .text_recent_post .post_list li:not(:last-child){
    border-bottom: 1px dotted #999;}


/*** お知らせリスト***/
#contents .text_recent_post .post_list li a{
	letter-spacing:0.1rem;
	text-decoration:none;}


@media screen and (min-width: 641px) {
#contents .text_recent_post {/***ニュース　お知らせ枠調整**/
	padding:10px 0 0 0;}

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

#contents .text_recent_post .list_title {/*タイトル*/
	margin-left:15px;}
}


@media screen and (max-width: 640px) {
#contents .text_recent_post {/***ニュース　お知らせ枠調整**/
	margin:0 0 0 0;
	padding:10px 15px 50px 15px;}


#contents .text_recent_post .post_list li{
	padding: 8px 0 5px 0;}

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

#contents .text_recent_post .list_date {/*日付*/
	width: 30%;
	margin-left: 0px;
	line-height:1.2;}

#contents .text_recent_post .list_title {/*タイトル*/
    margin-left:0;
	line-height:1.2;}
}


/*----------------------------------
トップ・下層ページ共通調整
----------------------------------*/
#content {
    border: none;
	padding-bottom:0;}/*下層ページブロック*/

.post img.aligncenter, div.aligncenter {/*下層のセンタリング画像*/
   margin: 0 auto;}


@media screen and (min-width: 641px) {
#contents {
	margin:67px auto 45px auto;}/*大外枠/********* ※要考察 *********/

#content .post img{/*下層　リセット*/
    padding:0 0 15px 0;
	vertical-align: bottom;}

}


@media screen and (max-width: 640px) {
#main_col {
    padding:30px 0 0 0;}

#content {
	padding-bottom:0;}/*下層ページブロック　bottom調整*/

#content .post img{/*下層　リセット*/
    padding:0 0 10px 0;
	vertical-align: bottom;}

}


/*----------------------------------
ページタイトルヘッダー　※下層も含む
----------------------------------*/
#main_col .headline1,
.headline2,
.headline3{
	font-size: 16px;}

.headline3{
	margin-top:50px;}


@media screen and (min-width: 641px) {
#recent_post .headline1 {
    margin: 0 0 15px 0;}
}


@media screen and (max-width: 640px) {
#main_col .headline1,
.headline2,
.headline3{/*トップ・他　調整*/
	height: 22px;
	line-height:1.3;
	padding-bottom:5px;}

#page_headline.headline1{/*トップ・他　調整*/
	height: auto;}

#page_headline{
	padding:0 15px;}
}



/*----------------------------------
フッター
----------------------------------*/
@media screen and (max-width: 640px) {
#footer_wrap {
    padding:40px 0 5px 0;}

#footer .footer_menu_wrap {
    margin-bottom:0;}

#footer .footer_menu {
    width:90%;
    margin:0 auto;
	text-align:center;}

#footer .footer_menu ul{
	margin: 0 0 20px 0;}

#footer li {
    line-height:1.6;
    margin: 0 0 10px 0;}
}


/*----------------------------------
ページナビ
----------------------------------*/
@media only screen and (min-width:641px) {
.page_navi{
	margin:10px 0 15px 15px;}
}


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



/*----------------------------------
レスポンシブテーブル
----------------------------------*/
@media screen and (max-width: 640px){
    table.responsive {
        width: 100%;
    }
    table.responsive tbody {
        display: flex;
        width: 100%;
    }
    table.responsive th,
    table.responsive td {
        display: block;
    }
}



}
