/*
Theme Name: Beaver Builder Child Theme
Theme URI: http://www.wpbeaverbuilder.com
Version: 1.0
Description: An example child theme that can be used as a starting point for custom development.
Author: The Beaver Builder Team
Author URI: http://www.fastlinemedia.com
template: bb-theme
*/

/* Add your custom styles here... */

* {
    transition: all 0.5s 0s ease;
}

a {
	-webkit-transition: 0.4s;
    -moz-transition: 0.4s;
    -ms-transition: 0.4s;
    -o-transition: 0.4s;
    transition: 0.4s;
}

@media print {
 a[href]:after {
 content: "" !important;
 }

 abbr[title]:after {
 content: "" !important;
 }
}

@media (max-width: 768px) {
	.fl-col-small,
	.fl-col-small:not(.fl-col-small-full-width) {
		max-width: 100%;
	}
}

.block_link {
	cursor: pointer;
}

.block_link:hover {
	opacity: 0.9;
}

/*グリッドのガターサイズ*/
.row-0{
    margin-left:0px;
    margin-right:0px;
}
.row-0 > div{
	padding-right:0px;
	padding-left:0px;
}
.row-10{
    margin-left:-5px;
    margin-right:-5px;
}
.row-10 > div{
	padding-right:5px;
	padding-left:5px;
}
.row-20{
    margin-left:-10px;
    margin-right:-10px;
}
.row-20 > div{
	padding-right:10px;
	padding-left:10px;
}
.row-30{
    margin-left:-15px;
    margin-right:-15px;
}
.row-30 > div{
	padding-right:15px;
	padding-left:15px;
}
.row-40{
    margin-left:-20px;
    margin-right:-20px;
}
.row-40 > div{
	padding-right:20px;
	padding-left:20px;
}





/*transition & delay*/
.transition10{transition:all 1s cubic-bezier(0.190, 1.000, 0.220, 1.000);}
.delay01{transition-delay: .1s;}
.delay02{transition-delay: .2s;}
.delay03{transition-delay: .3s;}
.delay04{transition-delay: .4s;}
.delay05{transition-delay: .5s;}
.delay06{transition-delay: .6s;}
.delay07{transition-delay: .7s;}
.delay08{transition-delay: .8s;}
.delay09{transition-delay: .9s;}
.delay10{transition-delay: 1s;}
.delay11{transition-delay: 1.1s;}



/*スライドバナー*/
.slideBanner .slick-slide:not(.slick-center) {
	-webkit-filter: grayscale(100%);
	-moz-filter: grayscale(100%);
	-o-filter: grayscale(100%);
	-ms-filter: grayscale(100%);
	filter: grayscale(100%);
	transition: 0.2s linear;
}


/*MW WP FORM Generatorのスタイルでg-standardを選択した時のデザインを調整*/
.mw_wp_form_g-standard table {
    border-collapse:separate;
    border-spacing: 0px 10px;
}

.mw_wp_form_g-standard table,
.mw_wp_form_g-standard table th,
.mw_wp_form_g-standard table td {
    border:none;
}

.mw_wp_form_g-standard table th {
    position: relative;
    padding: 1.1em;
		background-color: #efefef;
}

.mw_wp_form_g-standard table td {
		background-color: #f9f9f9;
}

.mw_wp_form_g-standard.mw_wp_form_confirm table th {
    padding: 1em;
}

.mw_wp_form_g-standard table th .require {
    position: absolute;
    top: 0px;
    right: 0px;
    font-size: 0px;
}

.mw_wp_form_g-standard table th .require::after {
    content: "必須";
    position: absolute;
    top: 20px;
    right: 15px;
    font-size: 12px;
    width: 50px;
    background-color: #E53838;
    color: #ffffff;
    text-align: center;
    white-space: nowrap;
    line-height: 1;
    padding: 5px;
}

.mw_wp_form_g-standard.mw_wp_form_confirm table th .require::after {
    top: 18px;
    right: 15px;
}

@media (max-width: 767px) {
.mw_wp_form_g-standard table tr {
	margin-bottom: 10px;
}
.mw_wp_form_g-standard table th{
    border-bottom: none;
    padding: 0.5em;
}
.mw_wp_form_g-standard table th .require::after {
    top: 6px !important;
    right: 6px !important;

}
}

/*テキストエディタモジュールのclassにbgWhiteBoxを設定する*/
.bgWhiteBox {
    position: relative;
}

.bgWhiteBox p {
    position: relative;
    display: inline-block;
    background-color: #ffffff;
    padding: 15px;
    z-index: 10;
}

.table-scroll{
    overflow: auto;
    white-space: nowrap;
    }


/*matuno.co.jp custom css*/
.pp-advanced-menu-horizontal.pp-toggle-arrows .pp-has-submenu-container > a > span {
    padding-right: 25px !important;
}

header.fl-theme-builder-header-scrolled #headerWrap > .fl-row-content-wrap {
    background-color: #ffffff;
}

@media (min-width: 992px) {
.pp-advanced-menu ul.sub-menu {
    padding: 5px 0px 0px !important;
}
}

header.fl-theme-builder-header-scrolled #headerWrap .pp-advanced-menu .menu > li > a,
header.fl-theme-builder-header-scrolled #headerWrap .pp-advanced-menu .menu > li > .pp-has-submenu-container > a {
    color: #016F51;
    border-color: rgba(1, 111, 82, 0.5);
}

header.fl-theme-builder-header-scrolled #headerWrap .pp-advanced-menu .pp-toggle-arrows .pp-menu-toggle:before,
header.fl-theme-builder-header-scrolled #headerWrap .pp-advanced-menu .pp-toggle-none .pp-menu-toggle:before {
    border-color: #016F51;
}

header.fl-theme-builder-header-scrolled {
    box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.1);
}

.fl-module-pp-advanced-menu .pp-advanced-menu-mobile-toggle {
    padding: 13px 8px;
}

#mobileGnavPanel .menu > li a {
    margin-bottom: 8px;
    background-color: #FCFCEF;
    border-radius: 10px;
}

#mobileGnavPanel .menu > li#menu-item-329 a {
    background-color: #7FC24E !important;
    color: #ffffff !important;
}

#mobileGnavPanel .menu > li#menu-item-330 a {
    background-color: #016F51 !important;
    color: #ffffff !important;
}

#mobileGnavPanel .menu li ul {
    box-shadow: none !important;
    margin-left: 15px;
}

#mobileGnavPanel .menu li ul a {
    font-size: 14px;
}

#mobileGnavPanel .fl-menu-accordion.fl-toggle-plus .fl-menu-toggle {
    width: 60px;
}

#gNav .menu > li#menu-item-333 a,
#gNav .menu > li#menu-item-329 a,
#gNav .menu > li#menu-item-330 a,
#gNav .menu > li#menu-item-2038 a {
    border-right: none !important;
}

#gNav .menu > li#menu-item-329 a {
    background-color: #7FC24E;
    color: #ffffff;
    margin-right: 10px;
    border-radius: 10px;
}

#gNav .menu > li#menu-item-330 a {
    background-color: #016F51;
    color: #ffffff;
    border-radius: 10px;
}


  /* コンテナ */
  .heading-container {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 0 10px;
    box-sizing: border-box;
    overflow: hidden;
    font-family: "Zen Old Mincho", serif;
  }

  /* 両脇の線 */
  .heading-container::before,
  .heading-container::after {
    content: "";
    display: block;
    width: 50px;
    height: 1px;
    background-color: #fff;
    flex-shrink: 0;
    position: relative;
    z-index: 10;
  }

  .heading-container::before {
    margin-right: -25px;
  }

  .heading-container::after {
    margin-left: -25px;
  }

  /* 緑色の斜めボックス */
  .skew-box {
    background-color: #005842;
    color: #fff;
    padding: 13px 33px;
    transform: skewX(-20deg);
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    position: relative;
    z-index: 1;
  }

  /* テキストラッパー */
  .skew-content {
    transform: skewX(20deg);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    /* PCでの間隔 */
    font-size: 2rem;
    letter-spacing: 0.1em;
    white-space: nowrap;
  }

  .cross-mark {
    font-weight: 300;
    font-size: 1.2em;
    opacity: 0.9;
    line-height: 1;
    /* 高さの影響を最小限に */
  }

  /* ----------------------------- */
  /* スマホ向けレスポンシブ設定 */
  /* ----------------------------- */
  @media (max-width: 768px) {

    .heading-container::before,
    .heading-container::after {
      width: 40px;
      /* 線は少し短く控えめに */
      margin: 0;
      /* 食い込み解除 */
    }

    /* 線とボックスの間を少し詰める */
    .heading-container::before {
      margin-right: -20px;
    }

    .heading-container::after {
      margin-left: -20px;
    }

    /* ボックスのパディング調整（上下を少しタイトに） */
    .skew-box {
      padding: 15px 45px;
    }

    .skew-content {
      flex-direction: column;
      text-align: center;
      padding: 0;
      gap: 0;
      /* 隙間を完全に削除 */
    }

    .text-part {
      font-size: 1.5rem;
      display: block;
      line-height: 1.2;
      /* 行高さを詰める */
    }

    .cross-mark {
      font-size: 1.4rem;
      /* ×を少し大きく */
      margin: 2px 0;
      /* 上下のマージンを最小限に（必要ならマイナス値も可） */
      display: block;
    }
  }

  .footerSubMenu ul,
  .footerSubMenu ul li {
    list-style: none;
    margin: 0px;
    padding: 0px
  }

  .footerSubMenu ul li {
    font-weight: normal !important;
    color: #000000 !important;
    margin-left: 15px;
    position: relative;
    line-height: 1.8 !important;
  }

  .footerSubMenu ul li::before {
    content: "- ";
    position: absolute;
    left: -1em;
  }

/* カーソルとアニメーションの定義 */
/* ホバー時に浮くアニメーション */
.boxLink > .fl-col-content {
    transition: all 0.5s 0s ease;
}

.boxLink > .fl-col-content:hover {
    transform: translateY(-5px);
    cursor: pointer;
    box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.0.5);
    transition: all 0.5s 0s ease;
}

.animsition {
  overflow: hidden;
}


/* tag:hokkaido_tohoku region */
.pref-label.label-hokkaido,
.pref-label.label-aomori,
.pref-label.label-iwate,
.pref-label.label-miyagi,
.pref-label.label-akita,
.pref-label.label-yamagata,
.pref-label.label-fukushima {
    background-color: #64a0c3;
}
/* tag:kanto regin */
.pref-label.label-ibaraki,
.pref-label.label-tochigi,
.pref-label.label-gunma,
.pref-label.label-saitama,
.pref-label.label-chiba,
.pref-label.label-tokyo,
.pref-label.label-kanagawa {
    background-color: #7ab86b;
}
/* tag:koshinetsu_hokuriku region */
.pref-label.label-niigata,
.pref-label.label-toyama,
.pref-label.label-ishikawa,
.pref-label.label-fukui,
.pref-label.label-yamanashi,
.pref-label.label-nagano {
    background-color: #cfadcb;
}
/* tag:tokai region */
.pref-label.label-gifu,
.pref-label.label-shizuoka,
.pref-label.label-aichi,
.pref-label.label-mie {
    background-color: #df9a20;
}
/* tag:kansai region */
.pref-label.label-shiga,
.pref-label.label-kyoto,
.pref-label.label-osaka,
.pref-label.label-hyougo,
.pref-label.label-nara,
.pref-label.label-wakayama {
    background-color: #d05a65;
}
/* tag:chugoku region */
.pref-label.label-tottori,
.pref-label.label-shimane,
.pref-label.label-okayama,
.pref-label.label-hiroshima,
.pref-label.label-yamaguchi {
    background-color: #b58050;
}
/* tag:shikoku region */
.pref-label.label-tokushima,
.pref-label.label-kagawa,
.pref-label.label-ehime,
.pref-label.label-kouchi {
    background-color: #a85d88;
}
/* tag:kyushu_okinawa region */
.pref-label.label-fukuoka,
.pref-label.label-saga,
.pref-label.label-nagasaki,
.pref-label.label-kumamoto,
.pref-label.label-ooita,
.pref-label.label-miyazaki,
.pref-label.label-kagoshima,
.pref-label.label-okinawa {
    background-color: #ef9556;
}


/* =========================================
   サイドバーウィジェット用スタイル
   テーマカラー: #016F51
   ========================================= */

/* --- 共通: ウィジェットタイトル --- */
.widget_vegeful_categories .widget-title,
.widget_vegeful_area_select .widget-title {
    background: #016F51; /* テーマカラー */
    color: #fff;
    padding: 12px 15px;
    margin: 0;
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 0.05em;
    border-radius: 4px 4px 0 0; /* 上部だけ角丸 */
}

/* =========================================
   1. カテゴリーリスト (.widget_vegeful_categories)
   ========================================= */
.widget_vegeful_categories ul {
    list-style: none;
    padding: 0;
    margin: 0;
    border: 1px solid #e0e0e0;
    border-top: none; /* タイトルと接するので上線は消す */
    background: #fff;
    border-radius: 0 0 4px 4px; /* 下部を角丸に */
}

.widget_vegeful_categories ul li {
    border-bottom: 1px dashed #e0e0e0; /* 点線の区切り */
    margin: 0;
}

.widget_vegeful_categories ul li:last-child {
    border-bottom: none;
}

.widget_vegeful_categories ul li a {
    display: block;
    padding: 12px 15px;
    color: #333;
    text-decoration: none;
    transition: all 0.3s ease;
    font-size: 12px;
    position: relative;
}

/* ホバー時の動き */
.widget_vegeful_categories ul li a:hover {
    background-color: #f4fcf9; /* ごく薄い緑 */
    color: #016F51;
    padding-left: 20px; /* 右へ少し動く */
}

/* ホバー時に左端にアクセントを表示 */
.widget_vegeful_categories ul li a:hover::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background-color: #016F51;
}

/* =========================================
   2. 地域プルダウン (.widget_vegeful_area_select)
   ========================================= */
.widget_vegeful_area_select {
    margin-bottom: 30px;
    background: #fff;
    /* 必要であれば枠線を追加 */
    /* border: 1px solid #e0e0e0; */
    /* border-radius: 4px; */
}

/* セレクトボックスの装飾 */
.widget_vegeful_area_select select {
    width: 100%;
    padding: 12px 15px;
    font-size: 12px;
    color: #333;
    background-color: #f9f9f9;
    border: 2px solid #e0e0e0; /* 少し太めの枠線 */
    border-radius: 4px;
    cursor: pointer;
    transition: border-color 0.3s, box-shadow 0.3s;
    
    /* ブラウザ標準の矢印を消してカスタムアイコンにする場合（任意） */
    appearance: none; 
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23016F51' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 15px center;
    background-size: 16px;
}

/* セレクトボックス フォーカス時（選択中） */
.widget_vegeful_area_select select:focus {
    outline: none;
    border-color: #016F51; /* テーマカラー */
    background-color: #fff;
    box-shadow: 0 0 0 3px rgba(1, 111, 81, 0.1); /* 薄い緑の光彩 */
}



h2 {
    margin: 0px!important;
}


/*改行設定*/

  .br_sp {
      display: none;
  }
  
    .br_pc {
      display: inline-block;
  }
  
   @media (max-width: 992px) {
    .br_sp {
      display: inline-block;
  }
  
     .br_pc {
      display: none;
  }
   }
   
    @media (max-width: 480px) {
        .br_small_device {
            display: inline-block;
        }
    }
   
   
    
    .service-btn {
        position: relative;
        height:110px;
    }
    
    .service-btn .fl-col-content {
        display: flex;
        flex-direction: row;
        align-items:center;
        justify-content: center!important;
        height:100%;
    }
    
     .service-btn .right-icon {
        position: absolute;
        padding: 15px;
        right: 0px;
        top: 50%;
    transform: translateY(-50%);
    }
    
  @media (max-width: 1200px) {   
    .service-btn {
        height:80px;
    }  
  }
    
  @media (max-width: 992px) {   
    .service-btn {
        height:110px;
    }  
  }    
    
  @media (max-width: 480px) {    
    .service-btn {
        height:80px;
    }
    
     .service-btn .right-icon {
        padding: 10px;
    }
  }
  
  .page-nav-box {
      position: relative;
  }
  
  .right-arrow {
      position: absolute;
      right: 0px;
  }

/*ページタイトル装飾*/  

  .page-title {
        display: flex;
  }
  
  .page-title .green-bg {
      background: #016F51;
      display: flex;
      padding: 30px 94px 40px 60px;
      clip-path:polygon(0 0%, 100% 0, 87% 100%, 0 100%);
      height: auto;
      align-items: flex-end;
  }
  
.page-title .green-bg h2 {
      color: #fff;
      margin-right: 20px!important;
      font-size: 40px;
      font-weight: 700;
      display: inline-block;
      line-height: 1.5;
      white-space: nowrap;
  }
    
  
  .page-title .green-bg p {
      color: #7FC24E;
      font-size: 20px;
      line-height: 1.5;
      font-weight: 700;
      display: inline-block;
      margin-top: auto;
      margin-bottom: 0px;
  }
  
  .page-title-h1 h1 {
      font-size: 40px;
      padding: 30px 40px 40px 40px;
      color: #016F51;
      font-weight: 700;
      margin: 0px;
       line-height: 1.5;
  }
  
  /* 小さなデスクトップのみ */
@media only screen and (min-width: 992px) and (max-width: 1199.98px) {
	.page-title-h1 h1 {
      font-size: 30px;
  }
}
  
  
  @media (max-width: 992px) { 
      
       
  .page-title {
        display: flex;
        flex-direction: column;
  }       
      
  .page-title .green-bg {
      padding: 15px 80px 20px 20px;
      clip-path:polygon(0 0%, 100% 0, 100% 100%, 0 100%);
  }
  
.page-title .green-bg h2 {
      margin-right: 16px!important;
      font-size: 30px;
  }
    
  
  .page-title .green-bg p {
      font-size: 14px;
  }
  
  .page-title-h1 h1 {
      padding: 15px 20px 20px 20px;
      font-size: 30px;
  }
  }  
  
  @media (max-width: 480px) {   
      
  .page-title .green-bg {
      padding: 8px 10px 10px 10px;
  }      
      
.page-title .green-bg h2 {
      margin-right: 10px!important;
      font-size: 18px;
  }
    
  
  .page-title .green-bg p {
      font-size: 14px;
  }
  
  .page-title-h1 h1 {
      padding: 8px 10px 10px 10px;
      font-size: 18px;
  }
  }   
  
  
  /*カラムタイトル装飾*/
  
  .column-title {
     align-items: center; /* 横線を上下中央 */
     display: flex; /* 文字と横線を横並び */
     white-space: nowrap;
     font-feature-settings: "palt";
     position: relative;
  }
  
  .column-title::before {
      background-color:#7FC24E;
      content:"";
      height: 5px;
      width: 75px!important;
      margin-right: 20px;
  }
    
    
  .column-title::after{
      background-color:#7FC24E;
      content:"";
      height: 5px;
      flex-grow: 1;
      flex-shrink: 0;
    margin-left: 20px;
  }
  
  
    @media (max-width: 1200px) {
   .column-title::before {
      width: 40px!important;
  }
    }
    
  
  
  @media (max-width: 992px) {
   .column-title::before {
      height: 3px;
      margin-right: 10px;
      width: 35px!important;
  }
    
    
  .column-title::after{
      height: 3px;
      margin-left: 10px;
  }     
  }
  
     @media (max-width: 480px) {
   .column-title::before {
      width: 20px!important;
  }
     }
  
  /*設備-table*/
  
  .equipment-table {
      font-feature-settings: "palt";
      background-color: #FCFCEF;
      padding: 20px;
      border-radius: 10px;
  }
  
    @media (max-width: 992px) {
  .equipment-table {
      padding: 15px;
  }
        
    }
    
    /*特長-li*/
    
    .features-point .features li {
        list-style: none;
        background: #FCFCEF;
        margin-bottom: 10px;
        border-left: 6px #016F51 solid;
        padding: 20px;
    }
    
    .features-point ul {
        padding: 0px;
    }
    
        @media (max-width: 992px) {
  .features-point .features li {
      padding: 15px;
  }
        }
  
  /*企業情報*/
  
  .company-info-table td,
  .history-table td {
      background: #FCFCEF;
  }
  
    .company-info-table tr,
    .history-table tr {
      border-bottom: 5px #fff solid!important;
  }
  
  .company-info-table th,
  .company-info-table td,
  .history-table th,
  .history-table td {
      padding: 20px;
  }
  
  .company-info-table th,
  .history-table th {
      background-color: #7FC24E;
      color: #fff;
      padding: 15px;
  }
  
  .history-month {
      color: #7FC24E;
      font-weight: 700;
  }
  
  
@media (max-width: 992px) {
  .company-info-table table,
  .company-info-table tbody,
  .company-info-table tr,
  .company-info-table th,
  .company-info-table td,
  .history-table table,
  .history-table tbody,
  .history-table tr,
  .history-table th,
  .history-table td {
      display: block!important;
      width: 100%!important;
  }
  
  .company-info-table tr,
  .history-table tr {
      margin-bottom:10px!important;
  }
  
  .history-month {
      padding: 20px 20px 0px!important;
  }
  }
  
  /*map*/
 @media (max-width: 992px) { 
  .google-map iframe {
      height: 300px!important;
  }
 }
 
 /*お問い合わせ*/
 
 .contact-container .page-nav-box .fl-col-content{
     display: flex;
     flex-direction: row;
     align-items: center;
     }
     
     
     .contact-container .page-nav-box .fl-col-content .fl-module-photo {
         width: 35%;
     }
     
     
@media (max-width: 1200px) { 
     .contact-container .page-nav-box .fl-col-content .fl-module-photo {
         width: 30%;
     }

}

/*ベジフルジャーナル個別*/

.pref-label {
    color: #fff;
    font-weight: normal;
    padding: 4px 10px;
    display: inline-block;
    background-color: #333;
    font-size: 0.6em !important;
    transform: translateY(-3px);
}

.imgFloat {
    margin-bottom: 0px;
}

/* スマホのみ */
@media only screen and (max-width: 768px) {
.imgFloat {
    display: block;
    clear: both;
    float: none;
    margin: 0px auto 10px;
}
}

.pp-menu-nav.pp-off-canvas-menu {
    z-index: -1;
}