@charset "UTF-8";

/*****************************
  top
*****************************/
.topsec{
  padding: 10rem 0;
}
@media only screen and (max-width: 1180px) {
  
}
@media only screen and (max-width: 1024px) {
  
}
@media only screen and (max-width: 820px) {
  .topsec{
    padding: 8rem 0;
  }
}
@media only screen and (max-width: 768px) {
  
}
@media only screen and (max-width: 767px) {
  .topsec{
    padding: 5rem 0;
  }
}

/*****************************
topsec-firstview
*****************************/
.topsec-firstview{
  margin-top: 77px;
  padding: 0;
}
.topsec-firstview .slideitem{
  height: calc(100vh - 77px);
}
.topsec-firstview .slideitem::before{
  content: "";
  background: rgba(17, 84, 23, 0);
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
}
.topsec-firstview .catchbox{
  position: absolute;
  top: 62%;
  left: 10%;
  transform: translateY(-50%);
}
.topsec-firstview .catchbox h2 span{
  color: #fff;
  display: block;
  font-size: 4rem;
  line-height: 1.4;
  letter-spacing: 1px;
}
@media screen and (max-width: 1024px) {
.topsec-firstview .catchbox h2 span{
  font-size: 3.2rem;
}
}
@media screen and (max-width: 767px) {
.topsec-firstview .catchbox h2 span{
  font-size: 1.7rem;
}
}

.topsec-firstview .catchbox h2{
  margin-bottom: 3rem;
}
.topsec-firstview .catchbox h3 span{
  color: #fff;
  display: block;
  font-size: 2.5rem;
  line-height: 1.8;
  letter-spacing: 1px;
}
@media screen and (max-width: 1024px) {
.topsec-firstview .catchbox h3 span{
  font-size: 2rem;
}
}
@media screen and (max-width: 767px) {
.topsec-firstview .catchbox h3 span{
  font-size: 1.5rem;
}
}

.topsec-firstview .catchbox h3{
  margin-bottom: 4rem;
}



.topsec-firstview .morebtn1 a{
  background: rgba(255, 255, 255, .85);
  color: #333;
  font-size: 2rem;
}
.topsec-firstview .morebtn1 a::before,
.topsec-firstview .morebtn1 a::after{
  background: #115417;
}
.topsec-firstview .morebtn1 a::after{
  background: #fff;
}
.topsec-firstview .morebtn1 a:hover{
  background-color: #115417;
  color: #fff;
  transition: background-color .3s .2s, color .3s .2s;
}
@media only screen and (max-width: 1180px) {
  
}
@media only screen and (max-width: 1024px) {
  .topsec-firstview .catchbox{
    left: 5rem;
  }
  .topsec-firstview .morebtn1 a {
    font-size: 1.8rem;
  }
  .topsec-firstview .slideitem {
    aspect-ratio: 16 / 9;
    height: auto;
  }
}
@media only screen and (max-width: 820px) {
  
}
@media only screen and (max-width: 768px) {
  
}
@media only screen and (max-width: 767px) {
  .topsec-firstview .slideitem {
    aspect-ratio: 4 / 3;
  }
  .topsec-firstview .catchbox {
    left: 2rem;
  }
  .topsec-firstview .catchbox h2 {
    margin-bottom: 2rem;
  }
  .topsec-firstview .morebtn1 a {
    font-size: 1.6rem;
  }
}

/*****************************
topsec-greeting
*****************************/
.topsec-greeting .morebtn1{
  margin: 3rem 0 0;
  text-align: right;
}
.topsec-greeting .fimgbox{
  width: 45%;
}
.topsec-greeting .ftxtbox{
  width: 52%;
}
@media only screen and (max-width: 1180px) {
  
}
@media only screen and (max-width: 1080px) {
  .topsec-greeting .txtbox p:nth-of-type(2) br:nth-of-type(2) {
    display: none;
  }
}
@media only screen and (max-width: 1024px) {
  .topsec-greeting .txtbox br {
    display: none;
  }
}
@media only screen and (max-width: 820px) {
  
}
@media only screen and (max-width: 768px) {
  
}
@media only screen and (max-width: 767px) {
  .topsec-greeting .fimgbox,
  .topsec-greeting .ftxtbox{
    width: 100%;
  }
  .topsec-greeting .fimgbox{
    margin-top: 3rem;
  }
}

/*****************************
topsec-commitment
*****************************/
.topsec-commitment .fimgbox{
  width: 45%;
}
.topsec-commitment .ftxtbox{
  width: 52%;
}
@media only screen and (max-width: 1180px) {
  
}
@media only screen and (max-width: 1024px) {
}
@media only screen and (max-width: 820px) {
  
}
@media only screen and (max-width: 768px) {
  
}
@media only screen and (max-width: 767px) {
  .topsec-commitment .fimgbox,
  .topsec-commitment .ftxtbox{
    width: 100%;
  }
  .topsec-commitment .fimgbox{
    margin-top: 3rem;
  }
}

/*****************************
topsec-method
*****************************/
.topsec-method{
  padding: 0;
}
/* .topsec-method .fimgbox {
  aspect-ratio: 3/4;
  background: url(../images/top/top_method.webp) no-repeat center / cover;
  background-position-x: 55%;
  margin: 0 auto;
  width: 35%;
}
.topsec-method .fimgbox img{
  opacity: 0;
} */
.topsec-method .ftxtbox .txtbox{
  margin: 3rem 0;
}
.topsec-method .ftxtbox .morebtn1{
  text-align: right;
}
@media only screen and (max-width: 1180px) {
  
}
@media only screen and (max-width: 1024px) {
  
}
@media only screen and (max-width: 820px) {
  
}
@media only screen and (max-width: 768px) {
  
}
@media only screen and (max-width: 767px) {
  .topsec-method {
    padding: 5rem 0;
  }
  .topsec-method .fimgbox,
  .topsec-method .ftxtbox{
    width: 100%;
  }
  .topsec-method .fimgbox{
    /* aspect-ratio: 4 / 3; */
    margin-top: 3rem;
  }
}


/*****************************
topsec-about
*****************************/
.topsec-about .inner1{
  padding: 0 2rem;
}
.topsec-about .ftxtbox,
.topsec-about .fimgbox{
  margin-top: 5rem;
  width: 32%;
}
.topsec-about .ftxtbox .txtbox{
  margin-top: 2rem;
}
.topsec-about .fimgbox a{
  opacity: 1 !important;
}
.topsec-about .fimgbox img{
  box-shadow: 6px 6px 6px #d0d0d0;
}
.topsec-about .morebtn{
  background: #115417;
  border: 1px solid #115417;
  box-shadow: 6px 8px 15px rgb(0 0 0 / 30%);
  color: #fff;
  display: inline-block;
  line-height: 1.4;
  margin: 2rem auto 0;
  min-width: 180px;
  padding: .5rem 2rem;
  position: relative;
  transition: .3s;
}
.topsec-about .morebtn span{
  display: block;
  font-size: 1.3rem;
  line-height: 1;
}
.topsec-about .fimgbox a:hover .morebtn{
  background-color: #fff;
  color: #09290c;
  transition: .3s;
}

@media only screen and (max-width: 1180px) {
  
}
@media only screen and (max-width: 1080px) {
  .topsec-about .inner1{
    padding: 0 4rem;
  }
  .topsec-about .flexbox2{
    justify-content: flex-start;
  }
  .topsec-about .ftxtbox{
    margin: 0;
    width: 100%;
  }
  .topsec-about .fimgbox {
    margin: 5rem .5% 0;
  }
  .topsec-about .txtbox br:not(:first-child,:nth-child(3)){
    display: none;
  }
}
@media only screen and (max-width: 1024px) {
  
}
@media only screen and (max-width: 820px) {
  
}
@media only screen and (max-width: 768px) {
  
}
@media only screen and (max-width: 767px) {
  .topsec-about .fimgbox{
    margin-top: 2rem;
    width: 100%;
  }
  .topsec-about .fimgbox a{
    box-shadow: 6px 8px 15px rgb(0 0 0 / 30%);
    display: flex;
    height: 130px;
  }
  .topsec-about .fimgbox img{
    box-shadow: none;
    object-fit: cover;
    height: 100%;
    width: calc(100% - 150px);
  }
  .topsec-about .morebtn{
    box-shadow: none;
    display: flex;
    flex-direction: column;
    justify-content: center;
    margin: 0;
    height: 100%;
    min-width: none;
    width: 150px;
  }
}

/*****************************
topsec-news
*****************************/
.topsec-news .ttlbox1{
  text-align: center;
}
.topsec-news .tnewsbtn{
  margin-top: 3rem;
  text-align: center;
}