@charset "utf-8";

#wpadminbar .ab-top-secondary {
  float: right;
  top: 0;
  position: absolute;
  z-index: 99999;
  right: 0;
}


body{
    margin: 0;
    padding: 0;
    font-family: 'Shippori Mincho', serif;
}

img{
    width: 100%;
    height: auto;
    object-fit: cover;
    padding: 0;
    height: auto;
  transition: transform 2.6s ease; 
}

 img:hover {
    transform: scale(1.11); /* 拡大 */
  }
li{
    list-style: none;
}

ul{
    display: flex;
    padding: 0;
    margin: 0;
}


a{
  text-decoration: none;
  color: inherit;
}



h2{
  margin: 0;
  text-align: center;
  line-height: 40px;
}

h2 div{
  font-size: 18px;
}

@media screen and (max-width:1250px){
  h2{
    line-height: 30px;
    font-size: 25px;
  }
 
  h2 div{
    font-size: 15px;
  }

}


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

  h2{
    line-height: 20px;
    font-size: 20px;
  }
 
  h2 div{
    font-size: 13px;
  }

  }

 /* reset code */




 header h1{
  position:absolute;
  z-index: 10;
  width: 300px;
  top:20px;
  left: 60px;
}


#top {
    width: 100%;
    height: 100vh;
}



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

header h1{
  width: 250px;
  top:20px;
  left: 45px;
}

#top {
    height: 90vh;
} 

}


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

  header h1{
    width: 180px;
    top:0;
    left: 10px;
  }
  
  #top {
      height: 70vh;
    }
  
  }









/* top 種たけのこだわり */


#ts{
    margin: 70px auto;;
    text-align: center;
}

#ts_text{
    margin: 40px auto 60px;
    line-height: 40px;
 font-size: 18px;
}

.m_btn{
    border: 0.5px solid #333;
    width: 200px;
    margin: auto;
    padding: 10px;
}


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

#ts_text{
    margin: 35px auto 50px;
    line-height: 30px;
    font-size: 15px;
}

.m_btn{
    width: 180px;
    padding: 10px;
    font-size: 15px;
}
 
}
 
  
  @media screen and (max-width:750px){
 
  #ts{
      margin: 70px auto;;
      text-align: center;
      width: 70%;
  }

  #ts_text{
    margin: 30px auto 40px;
    line-height: 25px;
    font-size: 13px;
}

}
  


/* 種たけの製品 */


#tf{
    background-image: url(../img/back.webp);
    background-size: cover;
    background-position: center;
    text-align: center;
    padding: 70px 0;
    display: flex;
}



#tf  .tf_flex{
  display: flex;
  width: 100%;
}

#tf  a{
  width: 50%;
}
#tf  a li{
 margin:  0;
width: 100%;
 font-size: 18px;

}



#tf  a li .tf_img{
  width: 100%;
  height: 400px;
  overflow: hidden; 
}


#tf  a li .tf_img img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}



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





#tf ul a li{
 margin:  20px 0;
 font-size: 15px;
}


}


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

  #tf{
    display: block;
  }
#tf  a li{
 margin:  50px 0;
 font-size: 10px;
}


#tf  a li  .tf_img{
  margin: 10px auto;
  width:100%; 

  height: 200px;
} 

}









/* 製造工程＆食品衛生への取り組み */


#ta{
    display: flex;
    margin: 70px auto 20px;
}

.ta_content{
    width: 50%;
}

.ta_content .ta_img{
    width: 100%;
    height: 320px;
    overflow: hidden; 
}



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

#ta{
    margin: 50px auto 30px;
}

.ta_content .ta_img{
    height: 240px;
}

}
  
  
  @media screen and (max-width:750px){
  
  #ta{
    display: block;
  }
 
  .ta_content{
      width: 100%;
  }

  .ta_content h2{
    margin: 25px auto 15px;
  }
 
  .ta_content .ta_img{
      height: 215px;
  } 
  }





/* 会社概要 */

#tc{
  margin: 50px auto 0;
}

#tc .tc_img {
  width: 100%;
  height: 320px;
  overflow: hidden; 
}

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


  #tc .tc_img{
    height: 240px;
  }


  }
  
  
  @media screen and (max-width:750px){
 
    #tc{
      margin:0 auto;
    }

    #tc h2{
      margin: 0 auto 15px;
    }

    #tc .tc_img{
      height: 215px;
    }
  }
  











/* ニュース */

#tn{
    background-image:url("../img/back.webp");
    text-align: center;
    background-size: cover;
    padding: 70px;
}


#tn ul{
    display: block;
    padding: 20px 0;
}

#tn ul li{
    display: flex;
    /* background-color: red; */
    margin: 20px auto;
    border-bottom: 0.5px solid #333;
    padding: 0 0 20px;
}

#tn ul li .t_c{
  display: flex;
}

#tn ul li .cate{
    width: 100px;
    margin: 0 50px;
    background-color: #fff;
}


@media screen and (max-width:1050px){
  
#tn ul{
    padding: 10px 0 20px;
    font-size: 18px;
}

#tn ul li{
  display: block;
    margin: 18px auto;
    padding: 0 0 15px;
}

#tn ul li .news_title{
  text-align: left;
  padding: 15px 0 10px;
}

#tn ul li .cate{
    width: 180px;
margin: 0;
}

}

 
  
  @media screen and (max-width:750px){
    #tn{
      padding:  50px 30px;
  } 
    #tn ul{
      padding: 10px 0 20px;
      font-size: 18px;
  }
  
  #tn ul li{
    display: block;
      margin: 18px auto;
      padding: 0 0 5px;
      font-size: 15px;
  }
  
  #tn ul li .news_title{
    padding: 10px 0;
  }
  
  #tn ul li .cate{
      width: 90px;
  
  }

  }
  









/* 

コンタクト

*/


#tcon{
    background-color: #5B695E;
    color: #fff;
    padding: 70px;
    display: flex;
}

.tcon_content{
    width: 50%;
    text-align: center;
}

.tcon_content h2{
    margin: 0 0 20px;
}

.tcon_btn{
    background-color: #fff;
    color: #5B695E;
    padding: 10px 20px;
    width: 200px;
    margin: 20px auto;
   font-size: 18px;
}


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

  #tcon{
    padding: 50px 30px;
    display: block;
}

.tcon_content{
    width: 80%;
    margin: auto;
    line-height: 35px;
}


.tcon_btn{
    font-size: 15px;
    padding: 10px 10px;
    width: 200px;
    margin: 25px auto 0;
}

}



/* 

footer
フッター 

*/





footer{
    text-align: center;
    padding: 70px;
    font-size: 18px;}


footer h1{
    margin: auto;
    width: 300px;
    line-height: 50px;
    font-size: 15px;
}

.fc_list_all{
    margin: 90px auto;
}
.fc_list{
    margin: 30px auto;
    line-height: 30px;
}

footer ul{
    margin: auto;
    justify-content: center;
}

footer ul a{
   margin: 0 20px;
}

@media screen and (max-width:1250px){
  
  footer{
    padding: 50px 0;
    font-size: 15px;
  }


footer h1{
    width: 250px;
    line-height: 40px;
    font-size: 13px;
}

.fc_list_all{
    margin: 70px auto;
}
.fc_list{
    margin: 25px auto;
    line-height: 25px;
}

footer ul a{
   margin: 0 12px;
}

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

    footer{
      padding: 50px 0 30px;
      font-size: 13px;
    }
  
  footer h1{
      font-size: 10px;
      width: 210px;
      line-height: 30px;
  }
 
  .fc_list_all{
    margin: 35px auto;
}

.fc_list{
    margin: 20px auto;
    line-height: 15px;
}

footer ul{
  display: block;
  width: 60%;
}

}


/* copylight*/

.cr{
    padding: 10px 5px;
    background-color: #5B695E;
    color: #fff;
    text-align: right;
    font-size: 10px;
}

@media screen and (max-width:750px){
  .cr{
    padding: 5px 2px;
    font-size: 10px;
    text-align: center;
} 
}











































































/* 動き
 */


/*==================================================
ふわっ
===================================*/

/* fadeIn */
.fadeIn{
    animation-name: fadeInAnime;
    animation-duration:3s;
    animation-fill-mode:forwards;
    opacity:0;
    }
    
    @keyframes fadeInAnime{
      from {
        opacity: 0;
      }
    
      to {
        opacity: 1;
      }
    }
    
    /* fadeUp */
    
    .fadeUp{
    animation-name: fadeUpAnime;
    animation-duration:2s;
    animation-fill-mode:forwards;
    opacity:0;
    }
    
    @keyframes fadeUpAnime{
      from {
        opacity: 0;
        transform: translateY(100px);
      }
    
      to {
        opacity: 1;
        transform: translateY(0);
      }
    }
    
    /* fadeDown */
    
    .fadeDown{
    animation-name: fadeDownAnime;
    animation-duration:0.5s;
    animation-fill-mode:forwards;
    opacity:0;
    }
    
    @keyframes fadeDownAnime{
      from {
        opacity: 0;
        transform: translateY(-100px);
      }
    
      to {
        opacity: 1;
        transform: translateY(0);
      }
    }
    
    /* fadeLeft */
    
    .fadeLeft{
    animation-name: fadeLeftAnime;
    animation-duration:0.5s;
    animation-fill-mode:forwards;
    opacity:0;
    }
    
    @keyframes fadeLeftAnime{
      from {
        opacity: 0;
        transform: translateX(-100px);
      }
    
      to {
        opacity: 1;
        transform: translateX(0);
      }
    }
    
    /* fadeRight */
    
    .fadeRight{
    animation-name: fadeRightAnime;
    animation-duration:0.5s;
    animation-fill-mode:forwards;
    opacity:0;
    }
    
    @keyframes fadeRightAnime{
      from {
        opacity: 0;
        transform: translateX(100px);
      }
    
      to {
        opacity: 1;
        transform: translateX(0);
      }
    }
    
    /* スクロールをしたら出現する要素にはじめに透過0を指定　*/
     
    .fadeInTrigger,
    .fadeUpTrigger,
    .fadeDownTrigger,
    .fadeLeftTrigger,
    .fadeRightTrigger{
        opacity: 0;
    }
    
    /*==================================================
    ぱたっ
    ===================================*/
    
    
    /* flipDown */
    .flipDown{
    animation-name: flipDownAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
    opacity:0;
    }
    
    @keyframes flipDownAnime{
      from {
        transform: perspective(2500px) rotateX(100deg);
         opacity: 0;
      }
    
      to {
        transform: perspective(2500px) rotateX(0);
        opacity: 1;
      }
    }
    
    
    /* flipLeft */
    .flipLeft{
    animation-name: flipLeftAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
    perspective-origin: left center;
    opacity:0;
    }
    
    @keyframes flipLeftAnime{
      from {
       transform: perspective(600px) translate3d(0, 0, 0) rotateY(30deg);
         opacity: 0;
      }
    
      to {
      transform: perspective(600px) translate3d(0, 0, 0) rotateY(0deg);
      opacity: 1;
      }
    }
    
    
    /* flipLeftTop */
    .flipLeftTop{
    animation-name: flipLeftTopAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
    opacity:0;
    }
    
    @keyframes flipLeftTopAnime{
      from {
       transform: translate(-20px,80px) rotate(-15deg);
         opacity: 0;
      }
    
      to {
       transform: translate(0,0) rotate(0deg);
        opacity: 1;
      }
    }
    
    /* flipRight */
    .flipRight{
    animation-name: flipRightAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
    perspective-origin: right center;
    opacity:0;
    }
    
    @keyframes flipRightAnime{
      from {
       transform: perspective(600px) translate3d(0, 0, 0) rotateY(-30deg);
         opacity: 0;
      }
    
      to {
      transform: perspective(600px) translate3d(0, 0, 0) rotateY(0deg);
      opacity: 1;
      }
    }
    
    /* flipRightTop */
    .flipRightTop{
    animation-name: flipRightTopAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
    opacity:0;
    }
    
    @keyframes flipRightTopAnime{
      from {
       transform: translate(-20px,80px) rotate(25deg);
       opacity: 0;
      }
    
      to {
       transform: translate(0,1) rotate(0deg);
        opacity: 1;
      }
    }
    
    /* スクロールをしたら出現する要素にはじめに透過0を指定　*/
     
    .flipDownTrigger,
    .flipLeftTrigger,
    .flipLeftTopTrigger,
    .flipRightTrigger,
    .flipRightTopTrigger{
        opacity: 0;
    }
    
    /*==================================================
    くるっ
    ===================================*/
    
    
    /* rotateX */
    .rotateX{
        animation-name: rotateXAnime;
        animation-duration:1s;
        animation-fill-mode:forwards;
    }
    
    @keyframes rotateXAnime{
        from{
            transform: rotateX(0);
            opacity: 0;
            }
        to{
            transform: rotateX(-360deg);
            opacity: 1;
            }
    }
    
    /* rotateY */
    .rotateY{
        animation-name: rotateYAnime;
        animation-duration:1s;
        animation-fill-mode:forwards;
    }
    
    @keyframes rotateYAnime{
        from{
            transform: rotateY(0);
            opacity: 0;
            }
        to{
            transform: rotateY(-360deg);
            opacity: 1;
            }
    }
    
    /* rotateLeftZ */
    .rotateLeftZ{
        animation-name: rotateLeftZAnime;
        animation-duration:1s;
        animation-fill-mode:forwards;
    }
    
    @keyframes rotateLeftZAnime{
        from{
            transform: rotateZ(0);
            opacity: 0;
            }
        to{
            transform: rotateZ(-360deg);
            opacity: 1;
            }
    }
    
    /* rotateRightZ */
    .rotateRightZ{
        animation-name: rotateRightZAnime;
        animation-duration:1s;
        animation-fill-mode:forwards;
    }
    
    @keyframes rotateRightZAnime{
        from{
            transform: rotateZ(0);
            opacity: 0;
            }
        to{
            transform: rotateZ(360deg);
            opacity: 1;
            }
    }
    
    /* スクロールをしたら出現する要素にはじめに透過0を指定　*/
     
    .rotateXTrigger,
    .rotateYTrigger,
    .rotateLeftZTrigger,
    .rotateRightZTrigger{
        opacity: 0;
    }
    
    /*==================================================
    ぶわっ、ぽんっ、どどんっ
    ===================================*/
    
    /* zoomIn */
    .zoomIn{
        animation-name: zoomInAnime;
        animation-duration:0.5s;
        animation-fill-mode:forwards;
    }
    
    @keyframes zoomInAnime{
      from {
        transform: scale(0.6);
        opacity: 0;
      }
    
      to {
        transform: scale(1);
        opacity: 1;
      }
    }
    
    /* zoomOut */
    .zoomOut{
        animation-name: zoomOutAnime;
        animation-duration:0.5s;
        animation-fill-mode:forwards;
    }
    
    @keyframes zoomOutAnime{
      from {
        transform: scale(1.2);
        opacity: 0;
      }
    
      to {
        transform:scale(1);
        opacity: 1;
      }
    }
    
    /* スクロールをしたら出現する要素にはじめに透過0を指定　*/
     
    .zoomInTrigger,
    .zoomOutTrigger{
        opacity: 0;
    }
    
    /*==================================================
    じわっ
    ===================================*/
    
    /* blur */
    .blur{
        animation-name: blurAnime;
        animation-duration:1s;
        animation-fill-mode:forwards;
    }
    
    @keyframes blurAnime{
      from {
        filter: blur(10px);
        transform: scale(1.02);
        opacity: 0;
      }
    
      to {
        filter: blur(0);
        transform: scale(1);
        opacity: 1;
      }
    }
    
    /* スクロールをしたら出現する要素にはじめに透過0を指定　*/
     
    .blurTrigger{
        opacity: 0;
    }
    
    /*==================================================
    にょろっ
    ===================================*/
    
    /* smooth */
    .smooth{
        animation-name: smoothAnime;
        animation-duration:1s;
        animation-fill-mode:forwards;
      /* 　transform-origin: left; */
        opacity:0;
    }
    
    @keyframes smoothAnime{
      from {
      transform: translate3d(0, 100%, 0) skewY(12deg);
      opacity:0;
      }
    
      to {
      transform: translate3d(0, 0, 0) skewY(0);
      opacity:1;
      }
    }
    
    /* スクロールをしたら出現する要素にはじめに透過0を指定　*/
     
    .smoothTrigger{
        opacity: 0;
    }
    /*==================================================
    背景色が伸びて出現
    ===================================*/
    
    .bgextend{
        animation-name:bgextendAnimeBase;
        animation-duration:1s;
        animation-fill-mode:forwards;
        position: relative;
        overflow: hidden;/*　はみ出た色要素を隠す　*/
        opacity:0;
    }
    
    @keyframes bgextendAnimeBase{
      from {
        opacity:0;
      }
    
      to {
        opacity:1;  
    }
    }
    
    /*中の要素*/
    .bgappear{
        animation-name:bgextendAnimeSecond;
        animation-duration:1s;
        animation-delay: 0.6s;
        animation-fill-mode:forwards;
        opacity: 0;
    }
    
    @keyframes bgextendAnimeSecond{
        0% {
        opacity: 0;
        }
        100% {
        opacity: 1;
    }
    }
    
    /*左から右*/
    .bgLRextend::before{
        animation-name:bgLRextendAnime;
        animation-duration:1s;
        animation-fill-mode:forwards;
        content: "";
        position: absolute;
        width: 100%;
        height: 100%;
        background-color: #666;/*伸びる背景色の設定*/
    }
    @keyframes bgLRextendAnime{
        0% {
            transform-origin:left;
            transform:scaleX(0);
        }
        50% {
            transform-origin:left;
            transform:scaleX(1);
        }
        50.001% {
            transform-origin:right;
        }
        100% {
            transform-origin:right;
            transform:scaleX(0);
        }
    }
    
    /*右から左*/
    .bgRLextend::before{
        animation-name:bgRLextendAnime;
        animation-duration:1s;
        animation-fill-mode:forwards;
        content: "";
        position: absolute;
        width: 100%;
        height: 100%;
        background-color: #666;/*伸びる背景色の設定*/
    }
    @keyframes bgRLextendAnime{
        0% {
            transform-origin:right;
            transform:scaleX(0);
        }
        50% {
            transform-origin:right;
            transform:scaleX(1);
        }
        50.001% {
            transform-origin:left;
        }
        100% {
            transform-origin:left;
            transform:scaleX(0);
        }
    }
    
    /*下から上*/
    .bgDUextend::before{
        animation-name:bgDUextendAnime;
        animation-duration:1s;
        animation-fill-mode:forwards;
        content: "";
        position: absolute;
        width: 100%;
        height: 100%;
        background-color: #666;/*伸びる背景色の設定*/
    }
    @keyframes bgDUextendAnime{
        0% {
            transform-origin:bottom;
            transform:scaleY(0);
        }
        50% {
            transform-origin:bottom;
            transform:scaleY(1);
        }
        50.001% {
            transform-origin:top;
        }
        100% {
            transform-origin:top;
            transform:scaleY(0);
        }
    }
    
    /*上から下*/
    .bgUDextend::before{
        animation-name:bgUDextendAnime;
        animation-duration:1s;
        animation-fill-mode:forwards;
        content: "";
        position: absolute;
        width: 100%;
        height: 100%;
        background-color: #666;/*伸びる背景色の設定*/
    }
    @keyframes bgUDextendAnime{
        0% {
            transform-origin:top;
            transform:scaleY(0);
        }
        50% {
            transform-origin:top;
            transform:scaleY(1);
        }
        50.001% {
            transform-origin:bottom;
        }
        100% {
            transform-origin:bottom;
            transform:scaleY(0);
        }
    }
    
    /* スクロールをしたら出現する要素にはじめに透過0を指定　*/
    .bgappearTrigger,
    .bgUDextendTrigger,
    .bgDUextendTrigger,
    .bgRLextendTrigger,
    .bgLRextendTrigger{
        opacity: 0;
    }
    
    /*==================================================
    枠線が伸びて出現
    ===================================*/
    
    /*枠線が伸びて出現*/
    
    .lineTrigger{
      position: relative; /* 枠線が書かれる基点*/
      opacity:0;
    }
    
    .lineTrigger.lineanime{
        animation-name:lineAnimeBase;
        animation-duration:1s;
        animation-fill-mode:forwards;
    }
    
    @keyframes lineAnimeBase{
      from {
        opacity:0;
      }
    
      to {
        opacity:1;  
    }
    }
    
    /*上下線*/
    .lineTrigger::before,
    .lineTrigger::after{
      position: absolute;
      content: '';
      width:0;
      height:1px;
      background:#333;/* 枠線の色*/
    }
    
    /*左右線*/
    .line2::before,
    .line2::after{
      position: absolute;
      content: '';
      width: 1px;
      height:0;
      background:#333;/* 枠線の色*/
    }
    
    /*上線*/
    .lineTrigger::before {
        top:0;
        left:0;
    }
    
    .lineTrigger.lineanime::before {
        animation: lineAnime .5s linear 0s forwards;/*表示されて0秒後に上線が0.5秒かけて表示*/
    }
    
    /*右線*/
    .line2::before{ 
        top:0;
        right:0;
    }
    
    .lineTrigger.lineanime .line2::before {
        animation: lineAnime2 .5s linear .5s forwards;/*表示されて0.5秒後に右線が0.5秒かけて表示*/
    }
    
    /*下線*/
    .lineTrigger::after { 
        bottom:0;
        right:0;
    }
    
    .lineTrigger.lineanime::after {
        animation: lineAnime .5s linear 1s forwards;/*表示されて1秒後に下線が0.5秒かけて表示*/
    }
    
    /*左線*/
    .line2::after{ 
        bottom:0;
        left:0;
    }
    
    .lineTrigger.lineanime .line2::after {
        animation: lineAnime2 .5s linear 1.5s forwards;/*表示されて1.5秒後に左線が0.5秒かけて表示*/
    }
    
    @keyframes lineAnime {
        0% {width:0%;}
        100%{width:100%;}
    }
    
    @keyframes lineAnime2 {
        0% {height:0%;}
        100%{height:100%;}
    }
    
    /*枠線内側の要素*/
    
    .lineTrigger.lineanime .lineinappear{
        animation: lineInnerAnime .5s linear 1.5s forwards;/*1.5秒後に中央のエリアが0.5秒かけて表示*/
        opacity: 0;/*初期値を透過0にする*/	
    }
    
    @keyframes lineInnerAnime{
        0% {opacity:0;}
        100% {opacity:1;}
    }
    
    
    /*==================================================
    アニメーション設定
    ===================================*/
    
    /* アニメーションの回数を決めるCSS*/
    
    .count2{  
        animation-iteration-count: 2;/*この数字を必要回数分に変更*/
    }
    
    .countinfinite{  
        animation-iteration-count: infinite;/*無限ループ*/
    }
    
    /* アニメーションスタートの遅延時間を決めるCSS*/
    
    .delay-time05{  
        animation-delay: 0.25s;
    }
    
    .delay-time1{  
        animation-delay: 0.5s;
    }
    
    .delay-time15{  
        animation-delay: 0.75s;
    }
    
    .delay-time2{  
        animation-delay: 1s;
    }
    
    .delay-time25{  
        animation-delay: 1.25s;
    }
    
    /* アニメーション自体が変化する時間を決めるCSS*/
    
    .change-time05{  
        animation-duration: 0.5s;
    }
    
    .change-time1{  
        animation-duration: 1s;
    }
    
    .change-time15{  
        animation-duration: 1.5s;
    }
    
    .change-time2{  
        animation-duration: 2s;
    }
    
    .change-time25{  
        animation-duration: 2.5s;
    }

    .change-time3{  
      animation-duration: 3s;
  }



/* メニュー */


/* メニューボタン */

/*==================================================
　5-2-2 2本線が×に
===================================*/


/*ボタン外側※レイアウトによってpositionや形状は適宜変更してください*/
.openbtn{
	/*ボタン内側の基点となるためrelativeを指定。
追従するナビゲーションの場合はfixed＋top、rightといった位置をセットで指定*/
	/* position: fixed; */
  position: absolute;
  z-index: 40;
  top: 38px;
  right: 28px;
	width: 50px;
  height:50px;
	cursor: pointer;
	/* background:#fff; */
}

/*ボタン内側*/

.openbtn span{
    display: inline-block;
    transition: all .4s;/*アニメーションの設定*/
    position: absolute;
    right: 13px;
    height: 2.5px;
	/* background-color: #fff; */
    background-color: #333;
  }


.openbtn span:nth-of-type(1) {
	top:22px;	
  width: 100%;
}

.openbtn span:nth-of-type(2) {
	top:36px;
  width:60%;
}

/*activeクラスが付与されると線が回転して×に*/
.openbtn.active span{
  z-index: 40;
}


.openbtn.active span:nth-of-type(1) {
  z-index: 40;
    top: 20px;
    left: 16px;
    transform: translateY(6px) rotate(-45deg);
    width: 35%;
}

.openbtn.active span:nth-of-type(2) {
    top: 32px;
    z-index: 40;
    left: 16px;
    transform: translateY(-6px) rotate(45deg);
    width: 35%;
}

/*========= ナビゲーションのためのCSS ===============*/

#g-nav{
  /*position:fixed;にし、z-indexの数値を小さくして最背面へ*/
  position:fixed;
  z-index: -1;
opacity: 0;/*はじめは透過0*/
  /*ナビの位置と形状*/
top:0;
width:100%;
  height: 100vh;/*ナビの高さ*/
/* background:#5b695eb1;;背景を少し透過させる */
background:#5b695e;
  /*動き*/
transition: all 0.3s;
}

/*アクティブクラスがついたら透過なしにして最前面へ*/
#g-nav.panelactive{
opacity: 1;
z-index:10;
}

/*ナビゲーションの縦スクロール*/
#g-nav.panelactive #g-nav-list{
  /*ナビの数が増えた場合縦スクロール*/
  position: fixed;
  z-index: 999; 
  width: 100%;
  height: 100vh;/*表示する高さ*/
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

/*ナビゲーション*/
#g-nav ul {
  padding: 0;
  text-align: center;
  display: none;/*はじめは非表示*/
  /*ナビゲーション天地中央揃え*/
  position: absolute;
  z-index: 999;
  top:50%;
  left:50%;
  transform: translate(-50%,-50%);
}

#g-nav.panelactive ul {
  display: block;
}
/*リストのレイアウト設定*/

#g-nav li{
list-style: none;
  text-align: center; 
  padding: 0;
}

#g-nav li a{
color: #fff;
text-decoration: none;
padding:10px;
display: block;
text-transform: uppercase;
letter-spacing: 0.1em;
font-weight: bold;
}
/* gnavi */

#g-nav-list li:nth-of-type(1) a{
  font-size: 2rem;
  text-transform: none;
  font-weight: normal;
  line-height: 1;
  white-space: nowrap;
  margin: 0 0 20px 0;
}

#g-nav-list li:nth-of-type(2){
  animation-delay: .1s;
}
#g-nav-list li:nth-of-type(3){
  animation-delay: .2s;
}
#g-nav-list li:nth-of-type(4){
  animation-delay: .3s;
}
#g-nav-list li:nth-of-type(5){
  animation-delay: .4s;
}
#g-nav-list li:nth-of-type(6){
  animation-delay: .5s;
}
#g-nav-list li:nth-of-type(7){
  animation-delay: .6s;
}

#g-nav-list li:nth-of-type(8){
  animation-delay: .7s;
}

#g-nav-list li:nth-of-type(9){
    animation-delay: .8s;
  }


  #g-nav-list li:nth-of-type(10){
    animation-delay: .9s;
  }


@media screen and (max-width:1250px){
  
  .openbtn{
    top: 35px;
    right: 30px;
    width: 50px;
    height:50px;
  }
 
  /*ボタン内側*/
  
  .openbtn span{
      right: 0px;
      height: 2px;
    }


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

    .openbtn{
      top: 15px;
      right: 20px;
      width: 50px;
      height:50px;
    }
    
    /*ボタン内側*/
    
    .openbtn span{
        right: 0px;
        height: 2px;
      }


  }
/*==================================================
じわっ
===================================*/

/* blur */
.clur{
	animation-name: clurAnime;
	animation-duration:1.5s;
	animation-fill-mode:forwards;
}

@keyframes clurAnime{
  from {
	filter: blur(10px);
	transform: scale(1.02);
	opacity: 0;
  }

  to {
	filter: blur(0);
	transform: scale(1);
	opacity: 1;
  }
}

/* スクロールをしたら出現する要素にはじめに透過0を指定　*/

.clurTrigger{
    opacity: 0;
}
@charset "utf-8";
/* サブページヘッダー */


.s_cover{
    background-color: #fff;
    width: 100%;
    height: 120px;
}

.s_title{
    width: 100%;
    height: 200px;
    display: flex;
    background-size: cover;
}

.s_title h3{
    margin: auto;
    font-size: 30px;
    color: #fff;
}


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

  .s_cover{
    height: 110px;
}

.s_title{
    height: 150px;
}

.s_title h3{
    font-size: 25px;
}

}


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

  .s_cover{
    height: 85px;
}

.s_title{
    height: 100px;
}

.s_title h3{
    font-size: 20px;
}

}



/* サブページ　コンテンツ */

.s_content{
    margin: 70px auto;
}

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

  .s_content{
    margin: 30px auto;
    width: 90%;
}

}





/* サブページヘッダー */

.contact_header{
    background-image: url("../img/contact_header.webp");
}

.news_header{
    background-image: url("../img/news_header.webp");
}

.company_header{
    background-image: url("../img/company_header.webp"); 
}

.food-hygiene_header{
    background-image: url("../img/food-hygiene_header.webp");
}

.process_header{
    background-image: url("../img/process\ _header.webp"); 
}

.foods_header{
    background-image: url("../img/foods_header.webp");
}


.strength_header{
  background-image: url("../img/strength_header.webp");
}



.mp_header{
  background-image: url("../img/mp_header.webp");
}

 







/* 

お知らせ
news

*/

.news_content{
    display: block;
 font-family: 'Shippori Mincho', serif;
}

.news_content li{
    display: flex;
    width: 900px;
    margin: 50px auto;
        align-items: top;
}

.news_content li h3{
    line-height: 35px;
    font-size: 25px;
    margin: 0;
}
.news_content li h3 div{
    font-size: 20px;
}

.n_text{
  padding: 0 40px 0 0;
  width: 1800px;
  height: auto;
  font-size: 18px;
}
.n_img{
    width:1200px;
    height: 900px;
    height: auto;
    overflow: hidden;
    margin: 10px 0;
}






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


.news_content li{
    display: block;
    width: 80%;
    margin: 50px auto;
}

.news_content li h3{
    line-height: 28px;
    margin: 8px auto;
    font-size: 23px;
}
.news_content li h3 div{
    font-size: 15px;
}

.n_text{
  line-height: 20px;
  margin: 10px auto;
  font-size: 13px;
  width: 100%;
  padding: 0;
}

.n_img{
    width:100%;
    height: auto;
}

}



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

.news_content li{
    width: 95%;
    margin: 0px auto 40px;
}

.news_content li h3{
    line-height: 23px;
    font-size: 15px;
    margin: 5px auto;
}

.news_content li h3 div{
    font-size: 13px;
}

.n_text{
  line-height: 15px;
  font-size: 13px;
}

}





/* 

会社概要
company

*/

#slogan{
  width: 750px;
  margin: 100px auto 0;
}


#slogan img:hover {
  transform:none;
}

#c_content{
  margin: 100px auto 0; 
}

#c_content h3{
text-align: center;
margin: 80px auto;
font-size: 25px;
}

.cl{
    padding: 0;
    width:100%;
    max-width: 800px;
    margin: 0 auto;
    display: block;
}

.cl li{
    border-bottom: 0.5px solid #333;
    margin: 20px auto;
    font-size: 18px;
    
}
.cl li dl{
    display: flex;
    margin: 30px auto;
    justify-content: space-between;
}


.cl li dl dt{
    width: 20%;
    text-align: center;
}

.cl li dl dd{
  line-height: 30px;
  width: 60%;
  /* background-color: red; */
}








#history{
  width:100%;
  max-width: 800px;
  margin: 150px auto 0; 
}

#history h3{
    text-align: center;
    margin: 80px auto;
    font-size: 25px;
}

.timeline{
    display: block;
    margin: auto;
    width:100%;
    max-width: 700px;
}

.timeline > li {
    overflow: hidden;
    margin: 0;
    position: relative;
  }
  
  .timeline-date {
    width: 180px;
    float: left;
    margin-top: 20px;
    font-size: 18px;
  }

  .timeline-content {
    width: 60%;
    float: left;
    border-left: 1px #333 solid;
    padding-left: 60px;
    font-weight:100;
    letter-spacing:0.2rem;
  }

  .timeline-content h4{
    padding: 0 0 0 30px;
    font-size: 18px;
    font-weight: normal;
  }

  .timeline-content:before {
    content: '';
    width: 12px;
    height: 12px;
    background: #333;
    position: absolute;
    left: 174px;
    top: 24px;
    border-radius: 100%;
  }

  #g_map{
    text-align: center;
    margin: 150px auto;
  }

  #g_map h3{
    margin: 80px auto;
    font-size: 25px;  
  }

  #g_map .a_mes{
    margin: 30px auto;
    line-height: 25px;
    font-size: 18px;
  }




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



#slogan{
  width: 80%;
  margin: 80px auto 0;
}


#c_content{
    margin: 60px auto 0; 
}
    
#c_content h3{
    margin: 30px auto 40px;
    font-size: 20px;
}
    
.cl{
    width: 550px;
}
    
.cl li{
    margin: 10px auto;
    font-size: 15px;
}

.cl li dl{
    margin: 20px auto;
}  

.cl li dl dt{
    width: 30%;
    text-align: center;
}

.cl li dl dd{
   line-height: 19px;
}
    
    
#history{
    width:550px;
    margin: 100px auto 0;
}
    
#history h3{
    margin: 30px auto 40px;
    font-size: 20px;
}

 .timeline-date {
    width: 140px;
    font-size: 15px;
    padding-left: 20px;
}

 .timeline-content {
    width: 67%;
    padding-left: 0px;
    letter-spacing:0.1rem;
}

 .timeline-content h4{
  padding-left: 80px;
    font-size: 15px;
  }
    
.timeline-content:before {
    left: 155px;
} 
    
#g_map{
    margin: 100px auto;
}

#g_map h3{
    margin: 30px auto;
    font-size: 20px;  
}

#g_map .a_mes{
    margin: 25px auto;
    line-height: 20px;
    font-size: 15px;
}

}


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


  #slogan{
    width: 90%;
    margin: 40px auto 0;
  }


#c_content{
    margin: 40px auto 0; 
}
    
#c_content h3{
    margin: 30px auto;
    font-size: 15px;
}
    
.cl{
    width: 90%;
}
    
.cl li{
    font-size: 13px;
}

.cl li dl{
    margin: 13px auto;
}
        
    
.cl li dl dd{
    line-height: 16px;
    width: 60%;
}


    
    #history{
      width:100%;
      margin: 50px auto 0; 
    }
    
    #history h3{
        text-align: center;
        margin: 30px auto;
        font-size: 15px;
    }


      .timeline-date {
        width: 70px;
        margin-top: 14px;
        font-size: 13px;
      }
    
      .timeline-content {
        width: 60%;
        padding-left: 20px;
        letter-spacing:0rem;
      }

      .timeline-content h4{
        padding-left: 10px;
        font-size: 13px;
      }
    
      .timeline-content:before {
        top:15.5px;
        left: 85px;
      }
    
    
    
    
    
   
    
      #g_map{
        margin: 50px auto;
      }

      #g_map h3{
        margin: 20px auto;
        font-size: 15px;  
      }
    
      #g_map .a_mes{
        margin: 10px auto;
        line-height: 20px;
        font-size: 13px;
      }


      #g_map iframe{
        width: 100%;
        height: 300px;
      }



  }



/* 

食品衛生の取り組み
food hygiene

*/



.fh_content{
    width: 1050px;
    text-align: center;
    margin: 30px auto;
}


.fh_content h3{
    margin: 120px auto 50px;
    font-size: 25px;  
}

.fh_content span{
line-height: 30px;
font-size: 18px;

}

.fh_content_flex{
    display: flex;
    margin: 70px auto 20px;
    align-items: center;
   justify-content:space-between;
}
.fh_text{
  width: 500px;
  display: flex;
  text-align: left;
  font-size: 18px;
  line-height: 35px;
  margin: 0 10px;
}

.fh_img{
    width: 500px;
    height: 320px;
    overflow: hidden;
}




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

  .fh_content{
    width: 800px;
  }


.fh_content h3{
    margin: 80px auto 30px;
    font-size: 20px;
}

.fh_content span{
line-height: 30px;
}

.fh_content_flex{
    margin: 30px auto 40px;
}

.fh_text{
  width: 350px;
  font-size: 15px;
  padding: 0  40px 0  0;
}

.fh_img{
    width: 330px;
    height: 220px;
    overflow: hidden;
}

}


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

  .fh_content{
    width: 95%;
    text-align: left;
  }

.fh_content h3{
  text-align: center;
    margin: 40px auto 10px;
    font-size: 15px;
}

.fh_content span{
line-height: 15px;
font-size: 13px;
}

.fh_content_flex{
  display: block;
    margin: 20px auto 30px;
    padding: 0;
    justify-content: center;
    position: relative;
}

.fh_text{
  width: 100%;
  font-size: 13px;
  padding: 0;
  line-height: 20px;
 margin: 10px auto;
}

.fh_img{
  top: 0;
    width: 330px;
    height: 220px;
    overflow: hidden;
    line-height: 20px;
    margin: auto;

}


.fh_res_con{
  height: 350px;
  padding: 0;
  position: relative;
}


.fh_res_con .fh_img{
position: absolute;
left: 50%;
transform: translateX(-50%);
-webkit-transform: translateX(-50%);
-ms-transform: translateX(-50%);
top: 70px;
}

.fh_res_con .fh_text{
  position:relative;
  top: 0;
}

}


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

  .fh_res_con .fh_img{
    top: 110px;
    } 
}



















/* 

制作工程
process

*/


#process_slider{
    text-align: center;
}

#process_slider h3{
  font-size: 25px;
}

#process_slider img{
  transition:none;
}

#process_slider img:hover {
  transform: none;
}

.slider img {
  width:100%;
  height:auto;
}

.slider .slick-slide {
  margin:0 10px;
}

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

  #process_slider h3{
    font-size: 20px;
  } 

}

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

  #process_slider h3{
    font-size: 15px;
  } 

}

#process_map{
display: flex;
border: 1px solid #333;
width: 100%;
max-width: 700px;
margin: auto;
justify-content:space-around;
align-items: center;
padding: 50px;
margin: 100px auto;
}


#process_map img{
    width: 30px;
}

.process_map_box {
  border: 1px solid #333;
  writing-mode: vertical-rl;
  height: 150px;
  font-size: 18px;
  align-items: center;
  display: flex;
  justify-content: center;
  text-align: center;
}

.process_map_box:hover{
  background-color: #333;
  color: #fff;

}



.process_map_box h5{
  margin: 0 10px;
}

#process_content ul{
  display: block;
  width: 100%;
  max-width: 1000px;
  margin: 100px auto;
}

#process_content ul li{
   margin: 50px auto;
   display: flex;
   justify-content: space-between;
}

#process_content ul li .pro_text h4{
   font-size: 18px;
}


#process_content ul li .pro_text{
   font-size: 18px;
   width: 50%;
}

#process_content ul li .pro_img{
   width: 350px;
   height: 230px;
   overflow: hidden;
}

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

#process_map{
  display: flex;
  width: 100%;
  padding: 30px 10px;
  margin: 80px auto;
}
  
#process_map img{
  width: 20px;
}
  
.process_map_box {
  height: 130px;
}

.process_map_box h5{
  margin: 0 10px;
  font-size: 12px;
}

#process_content ul{
    width: 100%;
    max-width: 1000px;
    margin: 00px auto;
}

#process_content ul li{
  margin: 0 auto;
  height: 250px;
}

#process_content ul li .pro_text h4{
  font-size: 18px;
  margin: 10px auto;
}

#process_content ul li .pro_text{
  font-size: 13px;
  width: 100%;
}

#process_content ul li .pro_img{
  width: 550px;
  height: 190px;
}
}

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

#process_map{
   display: flex;
   border:none;
   width: 100%;
   padding: 0px;
   margin: 50px auto;
}     
     
#process_map img{
   width: 20px;
}
      
.process_map_box {
   border: 1px solid #333;
   height: 130px;
   font-size: 18px;
   padding: 5px;
}
    
.process_map_box h5{
   margin: 0 1px;
}

#process_content ul{
   display: block;
   width: 100%;
   max-width: 1000px;
   margin: 50px auto;
}

#process_content ul li{
  margin: 40px auto;
  display: block;
  position: relative;
  height: 320px;
}

#process_content ul li .pro_text h4{
  margin: 20px auto 5px;
}

#process_content ul li .pro_text{
  width: 100%;
}

#process_content ul li .pro_img{
  width: 100%;
  height: 250px;
  margin: 20px auto 0;
}

}








/* 

製品紹介
foods

*/


#f_mes{
 width: 1050px;
 margin: auto;
 padding: 50px 0 0;
}


#f_mes .fit{
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 0px auto 100px;
  }

#f_mes .fit .f_text{
    text-align: left;
    line-height: 40px;
    width: 70%;
    font-size: 18px;
}

#f_mes .fit .f_text h4{
    font-size: 25px;
    margin: 10px auto 18px;
}

#f_mes .fit .f_img{
    width: 25%;
   text-align: center;
}

#f_mes .fit .f_img{
    transition:none;
}

#f_mes .fit .f_img span{
  font-size: 18px;
}


#f_mes  img:hover {
      transform: none;
}


.f_text ul li{
  text-align: center;
   line-height: 20px;
   margin: 0 8px;
}

.f_text ul li img{
    width: 100px;
}


.f2 img{
  width: 200px;
  height: 150px;
}

.f2_flex{
  display: flex;
  text-align: center;
}

.f2_flex .f2_1{
  margin:  0 20px;

}




.tab{
    text-decoration: none;
    display: flex;
    justify-content:center;
    margin: 0 auto;
    padding: 0;
    width: 900px;
    max-width: 100%;
}

.tab li{
    border: 0.2px solid #333;
}

.tab a{
    text-decoration: none;
}

.tab li a{
    color: #fff;
    text-decoration: none;
    font-family:sans-serif;
    display: block;
    background-color: #5b695e7f;
    padding: 5px 74.6px; 
}

.tab li a div{
    width: 100px;
    text-align: center;
}

.tab li.active a{
    color: #5B695E;
    background-color: #fff;
}

.area ul{
    padding: 0;
    margin: 0 auto;
    width: 100%;
    height: 100%;
    display: flex;
    overflow: hidden;
}
.area {
    margin: auto;
    display: none;
    opacity: 0;
    height: auto;
    padding: 0;
    width: 1000px;
    height: 100%;
    border: 0.2px solid #333;
    text-align: center;
}


.foods_list_exp{
  width: 1000px;
    margin: auto;
 font-size: 15px; 
}


.area.is-active {
    display: block;
    animation-name: displayAnime;
    animation-duration: 2s;
    animation-fill-mode: forwards;
}

.area.is-active {
    display: block;
    animation-name: displayAnime;
    animation-duration: 2s;
    animation-fill-mode: forwards;
}

@keyframes displayAnime{
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}
.area ul {
  justify-content: center;
  margin: 20px auto 20px;


}
.area ul .foods_list_res{
  display: flex;
}





.area ul  li{
    height: auto;
    margin: auto;
    overflow: hidden;
    position: relative;
    padding: 0;
    height: 100%;
    width: 200px;
    margin: 0px 10px 0px;
    text-decoration: none;
    color: #5B695E;
    font-size: 15px; 
    overflow: hidden;
  }

  .fz{
    height: 200px;
    width: 200px;
    overflow: hidden; 
  }


  .area ul  li .text{
    padding: 3px;
    font-size: 18px;
    line-height: 17px;
  }



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

#f_mes{
  width: 90%;
}
      
#f_mes .fit{
  margin: 0px auto 70px; 
}
      
#f_mes .fit .f_text{
  line-height: 26px;
  width: 80%;
  font-size: 15px;
}

#f_mes .fit .f_text h4{
  font-size: 20px;
  margin: 0px auto 15px;
}
      

#f_mes .fit .f_img{
  width: 290px;
  margin: 0 0 0 20px;
}

#f_mes .fit .f_img span{
  font-size: 15px;
}

#f_mes .ura{
  display: block;
}
#f_mes .ura .f_img{
  margin: auto;
  width: 255px;
}

#f_mes .ura .f_img img{
 height: 170px;
}

#f_mes .ura .f_text{
  margin: 40px auto;
  width: 100%;
 text-align: center;
}

.f_text ul {
  justify-content: center;
  margin: 20px auto;
}       

.f_text ul li{
  line-height: 20px;
  font-size: 15px;
}
      
.f_text ul li img{
  width: 90px;
}
 
.f2 .f_img{
  height: 180px;
}

    .tab{
      width: 800px;
    }
  
     .tab li a{
        padding: 5px 37.1px; 
    }


    .area {
      margin: auto;
        display: none;
        opacity: 0;
        height: auto;
        padding: 20px 0;
        width: 700px;
        height: auto;
        border: 0.2px solid #333;
        text-align: center;
    }

.foods_list_exp{
width: 700px;
margin: auto;
padding: 20px 0;
}
  
    .area ul{
      margin: 0;
    }
    .area ul .foods_list_res{
      display: block;
      width: 100%;
    }
    
    .area ul  li{
        height: auto;
        margin: 10px auto;
        height: 350px;
        width: 320px;
     font-size: 15px; 
    
      }
    
      .fz{
        height: 310px;
        width: 310px;
        margin: auto;
      }
    
    
      .area ul  li .text{
        padding: 3px;
        font-size: 18px;
      }

      .none_li{
        display: none;
      }
  }




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

#f_mes{
  width:100%;
}

#f_mes .fit{
  margin: 50px auto 80px; 
  height: 500px;
  position: relative;
  display: block;
  text-align: center;
}
      
#f_mes .fit .f_text{
  line-height: 26px;
  width: 100%;
  font-size: 13px;
  margin: 0 auto 10px;
}

#f_mes .fit .f_text h4{
  font-size: 18px;
  margin: 0px auto 8px;
}
      
#f_mes .fit .f_img{
  margin: auto;
  width: 100%;
  height: 200px;
}

#f_mes .fit .f_img span{
  font-size: 13px;
}


#f_mes .fit .f_img img{
   height: 300px;
}



#f_mes .ura {
   height: 430px;
   margin: 120px auto 0;
}

#f_mes .ura  .f_text{
    width: 100%;
    position: absolute;
    top: 330px;
    text-align: left;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
  }

.f_text ul {
     margin: 10px auto;
}       

.f_text ul li{
    margin: 0 4px;
    font-size: 10px;
}
      
  .f_text ul li img{
    width: 50px;
  }
      
  #f_mes .f2{
    height: 450px;
  }

  #f_mes .f2 .f2_flex{
    justify-content: center;
    margin: 0;
  }


  #f_mes .f2  .f_text{
    width: 100%;
  }

  .f2 span{
    font-size: 13px;
  }

  .f2 img{
    width: 90%;
    height: 180px;
  }

  .f2 .f2_1{
    width: 50%;
    margin: 0;
  }     

  .f2 .f2_2{
    width: 50%;
 }   



















    .tab{
      width: 100%;
    }
  
     .tab li a{
        padding: 5px 17px; 
    }
    .tab li a div{
      width: 50px;
      font-size: 15px;
    }
  

    .area {
        width: 339px;
        padding: 0;
    }


.foods_list_exp{
 font-size: 13px; 
 width: 339px;
        padding: 0;

}
    .area ul{
margin: 0;
padding: 0;
    }
   
    .area ul .foods_list_res{
      margin: 0;
      padding: 0;
    }


    .area ul  li{
        height: 180px;
        width: 140px;
     font-size: 13px; 
      }
    
      .fz{
        height: 140px;
        width: 140px;
      }
    
    
      .area ul  li .text{
        font-size: 13px;
      }


  }































/* 

種武のこだわり
strength

*/

.s_mes{
  width: 1050px;
  margin:100px auto;
  font-size: 18px;
  text-align: center;
}

#st_item{
  width: 1050px;
  margin: auto;
}

#st_item .sti{
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 0px auto 100px;
}

#st_item .sti .s_text{
  line-height: 23px;
  width: 500px;
  font-size: 18px;
}

#st_item .sti .s_text h4{
      font-size: 25px;
      margin: 10px auto 18px;
      text-align: center;
}
  


#st_item .sti .s_img{
      width: 500px;
      height: 320px;
     overflow: hidden;
    }



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

.s_mes{
    width: 90%;
    margin:80px auto;
}
    
#st_item{
  width:90%;
}
    
#st_item .sti{
  margin: 0px auto 60px;
}

#st_item .sti .s_text{
  width: 40%;
  font-size: 15px;
  margin: 0 0 0 10px;
}

#st_item .sti .s_text h4{
  font-size: 20px;
  margin: 0 auto 16px;
}

#st_item .sti .s_img{
  width: 55%;
  height: auto;
}
    
}


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


  .s_mes{
    width: 100%;
    margin:50px auto;
    font-size: 13px;
  }
     
  #st_item{
    width: 100%;
  }
  
  #st_item .sti{
    display: block;
    margin: 0px auto 50px;
  }
      
  #st_item .sti .s_text{
    line-height: 20px;
    width: 100%;
    font-size: 13px;
    margin: 0 auto 20px;
  }
  
  #st_item .sti .s_text h4{
    font-size: 18px;
    margin: 15px auto;
  }
   
  #st_item .sti .s_img{
    width: 100%;
    height: 270px;
    margin: auto;
  }

  #st_item .s_res{
    height: 470px;
    position: relative;
    
  }


#st_item .s_res .s_img{
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
}



}


@media screen and (max-width:450px){
   
  #st_item .sti .s_img{
    height: 225px;
  }

#st_item .s_res .s_text{
  top:225px;
}

}



.pp{
    width:100%;
    max-width: 90%;
  margin: 50px auto;
  font-size: 15px;
}

.pp h4{
  font-size: 25px;
}

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


  .pp{
    width: 90%;
    margin: 50px auto;
    font-size: 13px;
  }
  
  .pp h4{
    font-size: 20px;
  }
}


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


  .pp{
    width: 90%;
    margin: 30px auto;
    font-size: 13px;
  }
  
  .pp h4{
    font-size: 18px;
  }

}


.foods_list_exp{
text-align: right;
  
}
.cm{
    text-align: center;
    margin: 70px auto;
    font-size: 15px;
    line-height: 25px;
    width:100%;
    max-width: 700px;
}



@media screen and (max-width:750px){
  .cm{
    margin: 30px auto;
    font-size: 13px;
    line-height: 15px;
  max-width: 90%;
}

}


.cc{
    margin: 70px auto;
    font-size: 15px;
    line-height: 25px;
    width:100%;
    max-width: 700px;
}

@media screen and (max-width:750px){
 .cc{
    margin: 30px auto;
    font-size: 13px;
    line-height: 15px;
width:80%;
}

}



 .form-list{
    padding: 0;
    width:100%;
    max-width: 700px;
    margin: 0 auto 200px;
    display: block;
    height: auto;
}

.form-list span{
    color: red;
    font-size: 13px;
    padding: 0 0 0 15px;
}






.submit-btn{
    width:152px;
    margin: 0 auto 50px;
    text-align: center;
    background-color: #666;
    color: #fff;
    padding: 10px 0;
}

.form-list input[type='submit']{
    color: #333;
    text-align: center;
    padding: 5px 20px;
    width:152px;
    margin: 0 auto;
    transition: all .3s;
}

.form-list input[type='submit']:hover{
    background: #333;
    color: #fff;
}

 .form-list dl{
    justify-content: space-between;
    flex-wrap: wrap;
    padding:0 0 25px 0;
    align-items: center;
    font-size: 18px;
}

 .form-list dt{
    padding: 0 0 10px 0;
    width:100%;
  align-items: center;
}

 .form-list dd{
    
    width:100%;
    height: 20px;
    margin: 0;
}

 .form-list textarea {
  height:200px;
  background-color: #D9D9D9;
  border: none;
}






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


 .form-list dt{
  margin:0 0 10px 0;
}
 .form-list dt,
 .form-list dd{
    width:90%;
    margin: 0px auto;
    font-size: 13px;
}
 .form-list input[type='text'] , input[type='email'] {
  height:30px;
}


}









/* お問い合わせ完了 */


.thank{
    width: 70%;
    margin: 100px  auto;
    line-height: 30px;
}

.thank h3{
    font-weight: bold;
    text-align: center;
    font-size: 25px;
    margin: 40px auto 70px;
}


.thank .top_btn{
    padding: 10px;
    border: 0.5px solid #333;
    color: #fff;
    background-color: #333;
    margin: 60px auto;
    width: 150px;
    text-align: center;
}

.thank .top_btn:hover{
    background-color: #fff;
    color: #333;
}


@media screen and (max-width:1150px){
    .thank{
        width: 85%;
        margin: 50px  auto;
        line-height: 20px;
    }
    
    .thank h3{
        font-size: 22px;
    }
   
    
    .thank .top_btn{
        padding: 5px;
        width: 100px;
    }
}



@media screen and (max-width:750px){
    .thank{
        margin: 50px  auto;
        font-size: 12px;
    }
  
    .thank h3{
        font-size: 20px;
        margin: 30px auto 40px;
    }
    .thank .top_btn{
        margin:40px auto;
    } 
}









.form-list input , button , textarea , select {
  margin:0;
  padding:0;
  border:none;
  outline:none;
  background:none;
  font-size: 18px;
}

.form-list input[type='text'] ,
.form-list input[type='email'] ,
.form-list textarea{
  width:100%;
  /* border:1px solid #666; */
  background:#fff;
  padding: 0px 0;
  -webkit-appearance:none;
     -moz-appearance:none;
          appearance:none;
}

.form-list input[type='text'] , input[type='email'] {
  height:30px;
}

.submit-btn{
    width:152px;
    margin: 0 auto 50px;
    text-align: center;
    background-color: #666;
    color: #fff;
    padding: 10px 0;
}

.form-list input[type='submit']{
    color: #333;
    text-align: center;
    padding: 5px 20px;
    width:152px;
    margin: 0 auto;
    transition: all .3s;
}

.form-list input[type='submit']:hover{
    background: #333;
    color: #fff;
}

#name,
#kana,
#company_name,
#mail,
#tel,
#post-code,
#address,
#title,
#text{
background-color: #D9D9D9; 
padding: 2px 5px;
 font-size: 18px;
   font-weight: normal;
}

#title{
font-size: 15px;
}

.error{
padding: 0;
font-size: 10px;
}


#sidebar{
display: none;
}

.form{
   text-align: left;
}






.mold_content{
    display: flex;
    justify-content: center;
    margin: 20px auto;
}


.mold_content .img{
    width: 45%;
    height: auto;
    overflow: hidden;
}


.mold_content .img img{
  width: 100%;
  height: 100%;
}

@media(max-width:768px){

    .mold_content .img{
        width: 50%;
        height: auto;
        overflow: hidden;
    }
    

}
 /* ===== Timeline ===== */
 .timeline{
    position:relative;
    max-width:1160px;
    margin:0 auto;
    padding:3rem 1rem;         /* 先頭アイテムは padding-top 分だけ下がる */
  }
  /* vertical line */
  .timeline::before{
    content:"";
    position:absolute;
    left:60px;                 /* 線の X 座標 */
    /* ドット(16px)の真下から線を描画 → 3rem(==48px) + 16px = 64px */
    top:calc(3rem + 16px);
    bottom:0;
    width:2px;
    background:#4d665b;
  }

  /* each item */
  .tl-item{
    position:relative;
    /* display:flex; */
    gap:2rem;
    margin-bottom:4rem;
    padding-left:120px;        /* 線・ドットとコンテンツの間隔 */
    opacity:0;
    transform:translateY(40px);
    transition:opacity .6s ease, transform .6s ease;
  }
  .tl-item:last-child{margin-bottom:0;}

  /* dot */
  .tl-item .dot{
    position:absolute;
    left:37px;                /* 線よりやや左に配置 */
    top:0;
    width:16px;
    height:16px;
    border-radius:50%;
    background:#4d665b;
    transform:scale(0);
    transition:transform .6s cubic-bezier(.2,1.4,.4,1);
  }

  /* content area */
  .tl-img{
    flex-shrink:0;
    width:220px;
    height:auto;
    border-radius:4px;
    object-fit:cover;
  }
  .tl-body{max-width:700px;}
  .tl-body p{margin:0;}

  /* animate on show */
  .tl-item.show{opacity:1;transform:none;}
  .tl-item.show .dot{transform:scale(1);}


  @media screen and (max-width:1150px){
      /* vertical line */
  .timeline::before{
    content:"";
    position:absolute;
    left:40px;                 /* 線の X 座標 */
    /* ドット(16px)の真下から線を描画 → 3rem(==48px) + 16px = 64px */
    top:calc(3rem + 16px);
    bottom:0;
    width:2px;
    background:#4d665b;
  }

   /* each item */
   .tl-item{
    position:relative;
    /* display:flex; */
    gap:2rem;
    margin-bottom:4rem;
    padding-left:80px;        /* 線・ドットとコンテンツの間隔 */
    opacity:0;
    transform:translateY(40px);
    transition:opacity .6s ease, transform .6s ease;
   
  }


    /* dot */
    .tl-item .dot{
        position:absolute;
        left:17px;                /* 線よりやや左に配置 */
        top:0;
        width:16px;
        height:16px;
        border-radius:50%;
        background:#4d665b;
        transform:scale(0);
        transition:transform .6s cubic-bezier(.2,1.4,.4,1);
      }



  }
  /* ===== Responsive ===== */
  @media(max-width:768px){
    .timeline{
        position:relative;
        max-width:95%;
        margin: auto;
    }
    .timeline::before{
      left:0px;
      top:calc(2rem + 16px);
    }


    .tl-item{

        /* overflow: hidden; */
      flex-direction:column;
      padding-left:0.5rem;
      margin-left:1rem;
    }

    
    .tl-img{
        width:100%;
    overflow: hidden;
    transition: none; 
}
.tl-img:hover{
    transform: none; /* 拡大 */
}


    .tl-item .dot{left:-39px;}
  }





  .site-circulation {
    margin: 100px auto 0;
    padding: 60px 20px;
    background-color: #f8f8f0;
  }
  
  .circulation-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 30px;
    max-width: 1200px;
    margin: 0 auto;
  }
  
  .circulation-item {
    flex: 1 1 calc(20.333% - 30px);
    text-align: center;
    overflow: hidden;
  }
  
  .circulation-item img {
    width: 100%;
    height: 200px;
    display: block;
    margin: 0 auto 15px;
    border-radius: 8px;
  }
  
  .circulation-item h4 {
    font-size: 1.1rem;
    margin-bottom: 10px;
    color: #333;
  }
  
  .circulation-item p {
    text-align: left;
    font-size: 0.85rem;
    color: #555;
    line-height: 1.5;
  }
  

  @media(max-width:968px){
    .circulation-item {
      flex: 1 1 calc(48.333% - 30px);
      text-align: center;
      overflow: hidden;
    }
    

    .circulation-item img {
      width: 100%;
      height: 150px;
      display: block;
      margin: 0 auto 15px;
      border-radius: 8px;
    }

  }






  /* --- tl-item 本体から padding を外し、wrapper でオフセットする --- */
/* （既存の .tl-item { padding-left:120px; … } は下記のように削除 or コメントアウト） */
/*
.tl-item {
  padding-left: 120px;
}
*/

/* タイトル部分 */
.tl-title {
  margin-left: 0;
  margin-bottom: 1rem;
}

.tl-title h3 {
  margin: 0;
  font-size: 1.3rem;
  color: #333;
  font-weight: bold;
}

/* コンテンツ部分（背景色付き） */
.tl-content {
  margin-left: 0px;
  display: flex;
  gap: 2rem;
  background-color: #F6FDF8;
  padding: 1.5rem;
  border-radius: 6px;
     align-items: center;
}

.tl-img {
  width: 350px;
  height: 200px;
  object-fit: cover;
  border-radius: 4px;
  flex-shrink: 0;
}

.tl-body {
  flex: 1;
}

.tl-body p {
  margin: 0;
  line-height: 2;
  color: #666;
  font-size: 18px;
  align-items: center;
}

/* アニメーション表示 */
.tl-item.show {
  opacity: 1;
  transform: none;
}

.tl-item.show .dot {
  transform: scale(1);
}

/* レスポンシブ対応 */
@media screen and (max-width: 1150px) {
  /* .timeline::before {
      left: 24px;
  }

  .tl-item .dot {
      left: 17px;
  } */
}

@media screen and (max-width: 768px) {
  /* .timeline::before {
      left: 0px;
      top: calc(2rem + 16px);
  }

  .tl-item .dot {
      left: -39px;
  }

  .tl-title {
      margin-left: 40px;
  }
 */

 .tl-title {
  /* margin-left: 0; */
  margin-bottom: 1rem;
}

  .tl-content {
      flex-direction: column;
      gap: 0rem;
  } 

  .tl-content {

    padding: 1rem;
  }


  .tl-img {
      width: 100%;
      height: fit-content;
      margin-bottom: 1rem;
  }


  .tl-body p{
    font-size: 13px;
  }


  .fh_content h3{
    font-size: 1.3rem;
    margin: 0 0 20px 0;
  }
}