body{
    background: url(../images/main__bg.jpg);
    background-repeat: repeat-x;
  font-family: "Shippori Mincho B1", serif;
      background-color: #FFFFFF;

}
.mb70{
  margin-bottom: 70px;
}
.mb120{
  margin-bottom: 120px;
}
.mb170{
  margin-bottom: 170px;
}
.pt50{
  padding-top: 50px;
}
.pb70{
  padding-bottom: 70px;
}
.mt50{
  margin-top: 50px;
}
.block{

}


.wrap__one{
  max-width: 1000px;
  width: calc(327 / 375 * 100%);
  margin: auto;
}
.sp_br {
  display: none;
}

.mi__br {
  display: none;
}

@media screen and (max-width: 768px) {
  .sp_br {
    display: block;
  }
}
@media screen and (max-width: 352px) {
  .mi__br {
    display: block;
  }
}
/* パソコンで見たときは"pc"のclassがついた画像が表示される */
.pc { display: block !important; }
.sp { display: none !important; }
 
/* スマートフォンで見たときは"sp"のclassがついた画像が表示される */
@media only screen and (max-width: 1190px) {
    .pc { display: none !important; }
    .sp { display: block !important; }
}

@media screen and (max-width: 875px) {
  .order1{
    order: 2;
}
  .order2{
    order: 1;
}
}

@media screen and (max-width: 520px) {
.s100 img{
  width: 100%;
}}
h1 img,.footer__logo img{
  width: 191px;
  height: 54px;
  @media screen and (max-width: 800px) {
      width: 143px;
  height: 40px;

}}
.header {
  height: 80px;
  background-color: #ffffff;
    display: flex;
  align-items: center;
  position: sticky;
  top: 0;
  z-index: 10;
          @media screen and (max-width: 1024px) {
         height: 60px;
        }
}
.header__wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
        @media screen and (max-width: 1024px) {
        display: block;
        text-align: center;
      }
}
.header__wrap  h1{
        @media screen and (max-width: 1024px) {
        text-align: left;
      }
}
.header__list {
  display: flex;
    align-items: center;
            @media screen and (max-width: 1024px) {
        margin-top: 10px;
        justify-content: center;
        display: none;
      }
}
.header__list li{
  display:flex;
  align-items:center;
  border-right: 1px solid #000000;
  padding: 0 20px;
}
.header__list li.sns{
  border-right: none;
  padding-right: 0;
}
.inst img{
  width: 27px;
  height: 27px;
}
.tw img{
  width: 27px;
  height: 27px;
}
.yt img{
  width: 33px;
  height: 23px;
}
.main {
        @media screen and (max-width: 800px) {
         flex-direction: column;
      }
}
.main__wrap {
  display: flex;
  align-items: center;
  justify-content: center;
    margin-top: 40px;

      @media screen and (max-width: 1225px) {
         flex-direction: column;

  max-width: 1000px;
  width: calc(327 / 375 * 100%);
  margin: auto;

      }
}
.main__text__main {
  color: #FFFFFF;
  font-size: 48px;
  font-weight: bold;
  line-height: 80px;
     @media screen and (max-width: 1225px) {
order: 2;
    width: 100%;
      font-size: 30px;
        line-height: 45px;
    }
}
.main__top__img__main img{
  width: 678px;
  height: 565px;
    @media screen and (max-width: 1225px) {
      width: 100%;
      height: 100%;
    }
}
.main__img__main img{
    @media screen and (max-width: 1225px) {
      width: 100%;
      height: 100%;
    }
}
.main__img__main{
    @media screen and (max-width: 1225px) {
      width: 60%;
      order: 1;
    }
}
.main__text {
  color: #FFFFFF;
  font-size: 48px;
  font-weight: bold;
  line-height: 80px;
     @media screen and (max-width: 800px) {
order: 2;
    width: 100%;
      font-size: 30px;
    }
}
.main__top__img img{
  width: 678px;
  height: 565px;
    @media screen and (max-width: 800px) {
      width: 100%;
      height: 100%;
    }
}
.main__img img{
    @media screen and (max-width: 800px) {
      width: 100%;
      height: 100%;
    }
}
.main__img{
    @media screen and (max-width: 800px) {
      width: 60%;
      order: 1;
    }
}
.main__subtext{
  font-size: 20px;
    line-height: 35px;
    font-weight: normal;
    margin-top: 60px;
          @media screen and (max-width: 800px) {
    margin-top: 30px;
      
    }
}
/* service */
.service {
}
.service__ttl {
  margin-bottom: 45px;
}
.service__box {
    align-items: center;
    margin-bottom: 100px;
      @media screen and (max-width: 767px) {
      display: block;
      
    }
}
.service__img img{
    @media screen and (max-width: 767px) {
      width: 100%;
      margin: 70px 0;
    }
}
.service__list {
    font-size: 20px;
    color: #000000;
    background: #ffffff70;
    border-radius: 10px;
    padding: 40px 125px;
      @media screen and (max-width: 767px) {
            padding: 30px 20px;

    }
}
.service__ul {
  display: grid;
  grid-template-columns: 1fr 2fr 1fr;
  align-items: center;
  padding: 0px 40px;
        @media screen and (max-width: 767px) {
      display: block;
    }
}
.service__title {
  font-size: 20px;
} 
.service__text{
  line-height: 1.4;
  font-size: 16px;
        @media screen and (max-width: 767px) {
          padding: 20px 0px;
        }
}
.service__button{
  text-align: right;
}
.service__line{
  border-bottom: #000000 0.5px solid;
  margin: 40px 0px;
}

/* about */
.about {
}
.about__ttl {
  background: url(../images/about__bg.svg) no-repeat;
  background-size: cover;
  
}
.about__boxinner{
          background-color: #7E7E7E;
}
.about__box {
    align-items: center;
      @media screen and (max-width: 767px) {
      display: block;
    }
}
.about__img img{
    @media screen and (max-width: 767px) {
      width: 100%;
      margin: 70px 0;
    }
}
.about__list {
    font-size: 20px;
    color: #000000;
}
.about__ul {
  display: grid;
  grid-template-columns: 3fr 2fr 1fr;
  align-items: center;
  color: #FFFFFF;
  padding: 50px 0px;
        @media screen and (max-width: 767px) {
      display: block;
    }
}
.about__title {
  margin-bottom: 10px;
  font-size: 20px;
  line-height: 1.8;
        @media screen and (max-width: 767px) {
            margin-bottom: 30px;

    }
} 
.about__text{
  line-height: 1.8;
  font-size: 16px;
}
.about__button{
  text-align: right;
  width: 40px;
  height: 40px;
}
.button__size img{
  width: 40px;
  height: 40px;
          @media screen and (max-width: 767px) {
            margin-top: 30px;
              }
}
.about__line{
  border-bottom: #000000 0.5px solid;
  margin: 40px 0px;
}


/*==================================================
スライダーのためのcss
===================================*/
.slider{
  z-index: 0;
}

.slider img {
    width:100%;/*スライダー内の画像を横幅100%に*/
    height:auto;

}

/*slickのJSで書かれるタグ内、スライド左右の余白調整*/
.slider,
.slick-slider,
.slick-list,
.slick-track {
  position: relative;
  z-index: -1;
}

.slider .slick-slide {
    margin:0 0;/*スライド左右の余白調整*/
    background-color: #7E7E7E;
    padding-bottom: 80px;
}


.access{
  margin-bottom: 170px;
            @media screen and (max-width: 870px) {
     margin-bottom: 50px;

}

}
.access__ttl{}
.access__box,.service__box{
  display: flex;
  justify-content: space-between;
  align-items: center;
          @media screen and (max-width: 870px) {
flex-direction: column;    }
}
.access__map iframe{
  width: 400px;
  height: 300px;
          @media screen and (max-width: 870px) {
  width: 100%;
  height: 100%;
          }
}
.access__text{
  font-size: 16px;
  line-height: 1.8;
            @media screen and (max-width: 870px) {
margin-top: 30px;
          }
}

.recruit{
  background: url("../images/recruit__bg.jpg") center center / cover no-repeat;
  padding: 80px 0;
  height: 520px;
}
.recruit__ttl{}
.recruit__box{
  background: #ffffff80;
    max-width: 1100px;
  margin: 0 auto;
  height: 380px;
}
.recruit__textbox{
  position: relative;
  width: 100%;
  height: 150px;
  display: flex;
  align-items: center;
              @media screen and (max-width: 767px) {
                display: block;
                  padding: 60px 30px;
                   height: auto;
    flex-direction: column;
    gap: 20px; 
    padding: 40px 0;
              }
}
.recruit__text{
  font-size: 20px;
    flex: 1;
  text-align: center;
  font-size: 28px;       
  font-weight: 500;
  @media screen and (max-width: 767px) {
                line-height: 1.8;
                font-size: 20px;
              }
}
.recruit__button{
    position: absolute;
  right: 90px;     
  top: 50%;
  transform: translateY(-50%);
    @media screen and (max-width: 767px){
  position: static;  
    transform: none;
        display: flex;
    justify-content: center;
    margin: 0 auto;
    padding-top: 30px;
    }

}


.button{
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 35px;
  padding-bottom: 220px;
  padding-top: 170px;
            @media screen and (max-width: 1042px) {
      display: block;
  padding-bottom: 120px;
  padding-top: 100px;

          }
}
.button__3line{
grid-template-columns: repeat(3, 1fr);
}
.button__2line{
 grid-template-columns: repeat(2, 1fr);
}
.dfc{
  display: flex;
  align-items: center;
}
.white__button{
  background-color: #FFFFFF;
  border-radius: 10px;
  border: #E9DACB 5px solid;
  justify-content: space-between;
  padding: 40px 70px;
}
.yellow__button{
    background-color: #E9DACB;
  border-radius: 10px;
  border: #E9DACB 5px solid;
  justify-content: space-between;
  padding: 40px 70px;
}
.yellow__button img,.white__button img{
  width: 32px;
  height: 32px;
}
.faq{}
.blog{
              @media screen and (max-width: 1042px) {
margin: 10px 0px;
          }
}
.contact{}

.footer__bg{
    background: url("../images/footer__bg.jpg") no-repeat;
      background-size: cover;

}

.footer{
  display: flex;
  justify-content: space-between;
  color: #FFFFFF;
  padding-bottom: 60px;

}
.footer__left{

}
.footer__logo{
  margin-bottom: 55px;
}
.footer__left__text{
    line-height: 2.0;
margin-bottom: 100px;
            @media screen and (max-width: 880px) {
margin-bottom: 20px;

          }
}
.footer__left__sns{
  display: flex;
  gap: 10px;
  align-items: center;
}
.footer__right{
  display: grid;
  grid-template-columns: repeat(2, 1fr); 
  row-gap: 70px;
  column-gap: 120px;
              @media screen and (max-width: 880px) {
      display: none;

          }
}
.footer__service{}
.footer__ttl{
  font-size: 24px;
}
.footer__service__ttl{
}
.footer__service__text{}
.footer__about{}
.footer__about__ttl{}
.footer__about__text{}
.footer__recruit{}
.footer__recruit__ttl{}
.footer__recruit__text{}
.footer__other{}
.footer__other__ttl{}
.footer__box{
  line-height: 2.0;
}
small{
  color: #FFFFFF;
  display: block;
  text-align: center;
  padding-bottom: 20px;
  line-height: 2.0;
  }

  .sub__wrap{
   display: flex;
  align-items: center;
  justify-content: center;
    margin-top: 40px;
    gap: 60px;
    margin-top: 60px;
          @media screen and (max-width: 800px) {
         flex-direction: column;

  max-width: 1000px;
  width: calc(327 / 375 * 100%);
  margin: auto;

      }
  }
  .sub__main__text {
  color: #FFFFFF;
  font-size: 48px;
  font-weight: bold;
  line-height: 80px;
     @media screen and (max-width: 800px) {
order: 2;
    width: 100%;
      font-size: 30px;
    }
}
.sub__img img{
    @media screen and (max-width: 800px) {
      width: 55%;
      justify-content: center;
    }
}

  .sub__text{
    font-size: 24px;
    line-height: 1.8;
  }


  .service__sub__bg{
    background-color: #FFFFFF;
    max-width: 1300px;
    width: calc(327 / 375 * 100%);
    margin: auto;
    border:#E9DACB  solid 15px;
    border-radius: 10px;
  }
  .service__box{
    gap: 50px;
  }
  .service__text__ttl{
    font-size: 32px;
    margin-bottom: 20px;
  }
  .service__text__sub__top{

    width: 40%;
    line-height: 1.8;
              @media screen and (max-width: 870px) {
width: 100%;

      }
  }

  .service__ttl__sub{
    margin-top: 60px;
  }

  .service__box__sub{
    margin-bottom: 100px;
      @media (max-width: 600px) {
    margin-bottom: 0px;

}
  }
.service__list__sub{
      font-size: 20px;
    color: #000000;
    border-radius: 10px;
    padding: 40px 0px;
}
.service__ul__sub{
    display: flex;
    justify-content: space-between;
  align-items: center;
  padding: 0px 40px;
            @media screen and (max-width: 1210px) {
display: block;
padding: 0px;
      }
}

.service__title__sub{
  margin-right: 30px;
  width: 55%;
    white-space: nowrap;
    line-height: 1.6;
    font-size: 24px;
}
.service__text__sub{
  font-size: 16px;
      line-height: 1.8;
      width: 85%;
  @media screen and (max-width: 1210px) {
    padding-top: 30px;
      }
}
.service__line__sub{  
  border-bottom: #E9DACB 3px solid;
  margin: 40px 0px;
border-top-width: 0px;
}
.service__sisakuhinn img{
  @media screen and (max-width: 1210px){
    width: 100%;
  }
}

.points{
  padding-bottom: 80px;
  max-width: 1200px;
  margin: 0 auto;
}

.point__top{
  display: grid;
  grid-template-columns: repeat(3, 1fr);

}

@media screen and (max-width: 1210px){
  .point__top{
    width: 100%;
    grid-template-columns: 1fr; 
    row-gap: 40px;
  }
}

.point__bottom{
  display: flex;
  justify-content: center;
  margin-top: 80px;
}

@media screen and (max-width: 1210px){
  .point__bottom{
    margin-top: 40px;
    flex-direction: column;
    gap: 40px;
    align-items: center;
  }
}

.point{
  text-align: center;
}

@media screen and (max-width: 1210px){
  .point{
    margin-bottom: 40px;
  }
}

.flow__point__img img{
  height: auto;
  margin-bottom: 25px;
  width: 300px;
  height: 140px;
  @media screen and (max-width: 800px){
    width: 100%;
    height: 100%;
  }
}

.point__head{
  font-size: 32px;
  margin-bottom: 25px;
  justify-content: center;
  align-items: center;
  gap: 6px;
}

.point__num{
  font-weight: bold;
  font-size: 32px;
}

.point__body{
  font-size: 16px;
  line-height: 1.8;
}

.point__border{
  border-left: 6px solid #e1cfb9;
  @media screen and (max-width: 1210px){
    border: none;
  }
}
.point__ma{
    margin-left: 20px;
  padding-left: 20px;
  @media screen and (max-width: 1200px){

    padding-left: 0px;
    margin-left: 0px;
  }}

@media screen and (max-width: 1200px){
  .point__border{
    padding-left: 0px;
    border: none;
  }
}

@media screen and (max-width: 1200px) {
  .point__top,
  .point__bottom {
    display: block;
  }
}

  .products-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  width: 100%;
  border-collapse: collapse;
  padding-bottom: 170px;
  @media screen and (max-width: 767px) {
    grid-template-columns: repeat(1, 1fr);
      max-width: 1000px;
  width: calc(327 / 375 * 100%);
  margin: auto;
    padding-bottom: 0px;

  }
}

.products-grid .item img {
  width: 100%;
  height: 100%;
}
.item{
    @media screen and (max-width: 767px) {
margin-top: 50px;
  }
}
.history___ttl__sub{
  font-size: 30px;
}
.history__line__sub{  
  border-bottom: #E9DACB 3px solid;
  margin: 20px 0px;
border-top-width: 0px;
}
.history__list__sub{
  padding: 0px 0px;
}
.history__ul{
    display: grid;
  grid-template-columns: 1fr 2fr 2fr;
  align-items: center;
  padding: 50px 0px;
  padding: 0px 40px;
            @media screen and (max-width: 800px) {
display: block;
padding: 0px;
      }
}
.mp__history{
  display: none;
@media screen and (max-width: 800px) {
display: block;
padding: 0px;
      }
}
.service__text__sub__ml{
  font-size: 16px;
      line-height: 1.8;
  @media screen and (max-width: 800px) {
    padding-top: 30px;
      }
}
.service__text__sub__mt span ,.service__text__sub__ml span{
  font-size: 20px;
}
.service__text__sub__mt{
  font-size: 16px;
  line-height: 1.8;

}
.overview{
  margin-bottom: 140px;
}
.overview__ttl{
  padding-bottom: 80px;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}


.overview__item {
  display: flex;
  align-items: stretch;
  border-bottom: 1px solid #8d8d8d;
}

.overview__left {
  width: 50%;
  background: #e5d8c7;

  display: flex;
  align-items: center;
  justify-content: center;

  padding: 25px 20px;
  font-size: 15px;
  line-height: 1.6;}

.overview__right {
  flex: 1;

  padding: 25px 30px;
  font-size: 15px;
  line-height: 1.6;
  vertical-align: middle;
}

.overview__right p {
  margin: 0;
  white-space: normal;
  word-break: break-word;
}

.work__text__sub__top{
  width: 50%;
    line-height: 1.8;
    @media screen and (max-width: 767px) {
      width: 100%;
}}
.work__ttl__text{
  font-size: 20px;
  font-weight: bold;
}
.work__img__top{
      @media screen and (max-width: 767px) {
      margin-top: 30px;
}
}
.philosophy{
  position: relative;
  background: url("../images/philosophy__bg.jpg") center center / cover no-repeat;
  padding: 140px 0;
  height: 520px;
}

.philosophy__textbox{
  padding: 70px 140px;
  gap: 60px;
        @media screen and (max-width: 675px) {
          padding: 20px 10px;
        }
}
.philosophy__text{
  text-align: center;
  font-size: 25px;
}

.philosophy__box{
  background: #ffffff80;
    max-width: 1100px;
  margin: 0 auto;
  
}
.philosophy__text__ttl{
  font-size: 20px;
  padding-bottom: 30px;
}
.mvv__ttl{
  font-size: 40px;
}
.environment__text{
  text-align: center;
  margin-bottom: 70px;
}
.environment__text p{
  font-size: 32px;
  border-bottom: 5px solid #E9DACB;
  display: inline-block;
}
.voice{
  padding-bottom: 70px;
  margin-bottom: 70px;
}

  .voice__img {
  display: flex;
  justify-content: center;
}
.voice__textbox{
  display: flex;
  justify-content: center;
  padding-top: 40px;
  gap: 70px;
        @media screen and (max-width: 500px) {
          display: block;
        }
}
.voice__button{
  margin-top: 20px;
}
.voice__text{
  font-size: 30px;
  line-height: 1.4;
}

.voice__title__sub{
  margin-right: 30px;
    line-height: 1.6;
    font-size: 27px;
    padding-bottom: 20px;
}

.voice__ul__sub{
  align-items: center;
  padding: 0px 40px;
  @media screen and (max-width: 500px) {
            padding: 0px 0px;
        }
}
.voice__line__sub{  
  border-bottom: #E9DACB 3px solid;
  margin: 40px 0px;
border-top-width: 0px;
}
.voice__pt{
  padding-top: 40px;
}
.contact{
  text-align: center;
}
.contact__ttl{
  font-size: 40px;
  font-weight: bold;
  border-bottom: 3px solid #E9DACB;
  display: inline-block;
  padding-bottom: 10px;
  margin-bottom: 120px;
}
/*
SLIDE MENU
================================================ */
/* 開閉ボタン */
.btn-menu {

  position: fixed;
  right: 0.75rem;
  top: 0.75rem;
  z-index: 1;

  width: 2.4rem;
  height: 2.4rem;
  padding: 0.15rem;

  border: 1px solid #000;
  border-radius: 50%;
  transition: .4s;
  display: none;


      @media screen and (max-width: 1024px) {
    display: block;
    }
}

.btn-menu svg {
    fill: var(--brown);
    margin-top: .25rem;
    height: 1.5rem;
    width: 2rem;
}

/* 閉じるボタン */
#menu-close {
    border: 1px solid #00144C;
}
#menu-close svg {
    fill: var(--light-green);
}

/* スライドメニューパネル */
#menu-panel {
    position: fixed;
    top: 0;
    right: 0;
    z-index: 3000;
    padding: 8rem 2rem 2rem;
    width: max(32vw, 18rem);
    height: 100vh;
    background-color: #ffffff;
    box-shadow: 0 0 2rem #00144C;
    translate: 100vw;
}
.menu-list {
    list-style: none;
}
.menu-list li {
    margin: 1.5rem 0;
    opacity: 0;
}
.menu-list a {
    color: #000000;
    text-decoration: none;
    font-size: 2rem;
}

.menu-list {
  position: absolute;

  z-index: 9999;
}

.slider {
  position: relative;
  z-index: 0;
}

.item {
  position: relative;
  overflow: hidden;
}

.item::before {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.6);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 20px;
    opacity: 0;
    transition: all .3s ease-in-out;
    pointer-events: none;
    white-space: pre-wrap;
    line-height: 1.7;
    padding: 15px;
}

.item:hover::before {
    opacity: 1;
}

.item img {
    display: block;
    width: 100%;
}

/* 個別テキスト（ここを自由に変更できます） */
.item1::before { content: "四輪用インテークマニフォールド 　　工法：射出成形/振動溶着ナットインサートカラーアウトサート"; }
.item2::before { content: "四輪用エアクリーナーカバー　　工法：射出成形/ナットインサート"; }
.item3::before { content: "四輪用エアクリーナーケース　　工法：射出成形/ナットインサート"; }
.item4::before { content: "四輪用エアクリーナーエレメント　　工法：射出成形/不織布インサート"; }
.item5::before { content: "四輪用(燃料電池車)イオン交換機　　工法：射出成形/ナット、PPメッシュインサート"; }
.item6::before { content: "四輪用AIS レゾネーター　　　　工法：射出成形/振動溶着"; }
.item7::before { content: "四輪用過給配管アウトレット　　工法：射出成形/カラーアウトサート"; }
.item8::before { content: "四輪車用 ATFカバー　　　　　　工法：射出成形/振動溶着/カラーアウトサート"; }
.item9::before { content: "二輪車用エアクリーナーケース　　　工法：真空注型"; }

/*==================================================
アコーディオンのためのcss
===================================*/

/*アコーディオン全体*/
.accordion-area{
    list-style: none;
    width: 96%;
    max-width: 900px;
    margin:0 auto;
    margin-bottom: 150px;
}

.accordion-area li{
}

.accordion-area section {
	border: 1px solid #ccc;
}

/*アコーディオンタイトル*/
.title {
    position: relative;/*+マークの位置基準とするためrelative指定*/
    cursor: pointer;
    font-size:1rem;
    font-weight: normal;
    padding: 3% 3% 3% 50px;
    transition: all .5s ease;
    background: #ffffff;
    border: #E9DACB solid 10px;
}

/*アイコンの＋と×*/
.title::before,
.title::after{
    position: absolute;
    content:'';
    width: 15px;
    height: 2px;
    background-color: #333;
    
}
.title::before{
    top:48%;
    left: 15px;
    transform: rotate(0deg);
    
}
.title::after{    
    top:48%;
    left: 15px;
    transform: rotate(90deg);

}
.title.close::before{
	transform: rotate(45deg);
}

.title.close::after{
	transform: rotate(-45deg);
}

.box {
    display: none;
    background: #ffffff;
    padding: 3%;
    border: #E9DACB solid 3px;

}

.service__list__sub__hr {
    position: relative;
}

.service__list__sub__hr::before {
    content: "";
    position: absolute;
    top: 0;
    left: 57%;
    transform: translateX(-50%);
    width: 2px;
    height: 100%;
    background-color: #C9B8A8; 
    z-index: 1;
          @media screen and (max-width: 800px) {
    display: none;
    }
}

.gap{
  gap: 40px;
}
/* フォーム全体のスタイル */
.wpcf7 {
background-color: #f0f0f0; /* ライトグレー */
padding: 20px;
border-radius: 10px;
max-width: 600px;
margin: auto;
margin-bottom: 120px;
}
/* ラベルのスタイル */
.wpcf7-form label {
display: block;
margin-bottom: 10px;
font-size: 16px;
color: #333333; /* ダークグレー */
padding-bottom: 20px;
 display: flex;
  flex-direction: column;
  gap: 12px;
}
/* labelは縦flexにしない */
.wpcf7-form label {
  display: block;
}

/* タイトル（文字＋必須）の下に余白 */
.wpcf7-form label > .wpcf7-form-control-wrap {
  display: block;
  margin-top: 12px;
}

/* 必須フィールドのラベルスタイル */
.wpcf7-form .required {
background-color: #ff0000; /* レッド */
color: white;
padding: 2px 5px;
border-radius: 3px;
margin-left: 10px;
font-size: 12px;
}
/* インプットフィールドのスタイル */
.wpcf7-form textarea {
width: 100%;
padding: 10px;
border: 1px solid #cccccc; /* ライトグレー */
border-radius: 5px;
margin-bottom: 20px;
font-size: 16px;
background-color: #ffffff; /* 白 */
margin-top: 15px;
}
/* テキストエリアのスタイル */
.wpcf7-form textarea {
height: 150px;
resize: vertical;
}
/* 送信ボタンのスタイル */
.wpcf7-form input[type="submit"] {
background-color: #333333; /* ブルー */
color: white;
cursor: pointer;
transition: background-color 0.3s ease;
border: none;
text-align: center;
}
.wpcf7-form input[type="submit"]:hover {
background-color: #C9B8A8; /* 濃いブルー */
}
/* エラーメッセージと成功メッセージのスタイル */
.wpcf7-form .wpcf7-not-valid-tip {
color: red;
font-size: 14px;
}
.wpcf7-form .wpcf7-mail-sent-ok {
color: #000000;
font-size: 16px;
margin-bottom: 20px;
}
.wpcf7-form textarea {
    height: 150px;
    resize: vertical;
}
.wpcf7-form-control-wrap{
border-radius: 5px;
margin-bottom: 20px;
font-size: 16px;
}
/* input / textarea 共通 */
.wpcf7-form input,
.wpcf7-form textarea {
  width: 100%;
  padding: 10px;
  border: 1px solid #cccccc;
  border-radius: 5px;
  font-size: 16px;
  box-sizing: border-box;
  background-color: #ffffff;
}

/* textarea 高さ */
.wpcf7-form textarea {
  height: 150px;
  resize: vertical;
}


.wpcf7-form-control {
}

.wpcf7-form input[type="submit"] {
  display: block;
  margin: 0 auto;
}
.wpcf7-form input,
.wpcf7-form textarea,
.wpcf7-form select {
  width: 100%;
  padding: 10px;
  border: 1px solid #cccccc;
  border-radius: 5px;
  font-size: 16px;
  background-color: #ffffff;
  box-sizing: border-box;
}
@media screen and (max-width: 767px) {
.wpcf7-form input,
.wpcf7-form textarea,
.wpcf7-form select {
  font-size: 13px;
}
  /* フォーム全体 */
  .wpcf7 {
    padding: 16px;
    max-width: 100%;
    margin: 0 16px 80px;
    border-radius: 8px;
  }

  /* ラベル */
  .wpcf7-form label {
    font-size: 14px;
    padding-bottom: 12px;
  }

  /* 必須マーク */
  .wpcf7-form .required {
    font-size: 10px;
    margin-left: 6px;
  }

  /* 入力フィールド共通 */
  .wpcf7-form-control-wrap {
    margin-bottom: 16px;
  }

  .wpcf7-form-control {
    font-size: 14px;
    padding: 8px;
  }

  /* テキストエリア */
  .wpcf7-form textarea {
    height: 120px;
    font-size: 14px;
  }

  /* 送信ボタン */
  .wpcf7-form input[type="submit"] {
    width: 100%;
    padding: 14px 0;
    font-size: 16px;
    border-radius: 6px;
  }

  /* エラーメッセージ */
  .wpcf7-form .wpcf7-not-valid-tip {
    font-size: 12px;
  }

  /* 送信完了メッセージ */
  .wpcf7-form .wpcf7-mail-sent-ok {
    font-size: 14px;
  }
  /* 入力フィールド共通：はみ出し防止 */
.wpcf7-form-control-wrap,
.wpcf7-form-control,
.wpcf7-form input,
.wpcf7-form textarea,
.birth {
  box-sizing: border-box;
  width: 100%;
}

  .wpcf7-form input,
  .wpcf7-form textarea {
    padding: 8px;
    font-size: 14px;
  }

  .wpcf7-form textarea {
    height: 120px;
  }

}
.birth {
  display: flex;
  gap: 10px;
  margin-top: 12px;
  margin-bottom: 50px;
}

.birth select {
  width: auto;
  min-width: 90px;
}


.single__ttl{
  font-size: 32px;
  margin-bottom: 55px;
}
.single{
  margin-bottom: 250px;
}
.single__img{
  margin-bottom: 55px;
}
.single__img img{
  width: 100%;
  height: 100%;
}
.single__text{

}



/* 記事一覧（3カラム） */
.post-list {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
}

.post-item {
  width: calc((100% - 60px) / 3);
  background: #fff;
  border-radius: 10px;
  position: relative;
}

/* サムネイル */
.post-item img {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 10px 10px 0 0;
}

/* 記事ヘッダー */
.post-header {
  padding: 1rem;
}

.post-title {
  margin-bottom: .5rem;
  line-height: 1.5;
}

.post-date {
  font-size: .75rem;
  color: #ccc;
}

/* ナビゲーション */
.nav-links {
  display: flex;
  justify-content: center;
  gap: 2rem;
  margin-top: 3rem;
}

/* レスポンシブ（タブレット以下は2→1列） */
@media (max-width: 900px) {
  .post-item {
    width: calc((100% - 30px) / 2);
  }
}

@media (max-width: 600px) {
  .post-item {
    width: 100%;
  }
}
.nav-links {
    display: flex;
    justify-content: center;
    gap: 2rem;
}
.nav-links a{
    padding: .75rem 1rem .85rem;
    background: #7E7E7E;
    border-radius: 6px;
    color: #ffffff;
    box-shadow: 0 4px 10px #333333;
    margin-bottom: 40px;
}
.section-ttl {
  margin-top: 50px;
}


/* 英語タイトル */
.section-ttl__en {
  position: relative;
  display: inline-block; /* ← 文字幅を取得するため重要 */
  font-size: 50px;
  margin-bottom: 32px;
}
.section-ttl__hg {
  position: relative;
  display: inline-block; /* ← 文字幅を取得するため重要 */
  font-size: 40px;
  margin-bottom: 32px;
}

/* 横ライン（文字幅に追従） */
.section-ttl__en::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -16px;
  width: 100%;            /* ← 文字の横幅 */
  height: 3px;
  background-color: #e6d6c6;
  border-radius: 2px;
}
.section-ttl__hg::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -16px;
  width: 100%;            /* ← 文字の横幅 */
  height: 3px;
  background-color: #e6d6c6;
  border-radius: 2px;
}

/* 日本語 */
.section-ttl__jp {
  font-size: 25px;
}


.section-ttl__white {
  margin-top: 50px;
}


/* 英語タイトル */
.section-ttl__en__white {
  position: relative;
  display: inline-block; /* ← 文字幅を取得するため重要 */
  font-size: 50px;
  margin-bottom: 32px;
  color: #ffffff;
  padding-top: 20px;
}


/* 横ライン（文字幅に追従） */
.section-ttl__en__white::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -16px;
  width: 100%;            /* ← 文字の横幅 */
  height: 3px;
  background-color: #E9DACB;
  border-radius: 2px;
}


/* 日本語 */
.section-ttl__jp__white {
  font-size: 25px;
    color: #ffffff;

}
@media screen and (max-width: 767px) {
  .section-ttl__en {
    font-size: 40px;   /* ← 少し小さく */
  }}