@charset "utf-8";
/* CSS Document */

/**********************************************************/
/* PC */
/**********************************************************/




/**********************************
section共通
**********************************/
.un-ttl{
  font-family:'Roboto', sans-serif;
  font-size: 2.2rem;
  position: relative;
  color: #BE0000;
}
.un-ttl::after{
  position: absolute;
  content: "";
  width: 437px;
  height: 1px;
  background: #FFFFFF;
  top: 45px;
  left: 0;
}
.un-sbttl{
  font-family: 'Noto Serif', serif;
  font-size: 3.6rem;
  color: #fff;
  margin-top: 55px;
  font-weight: 600;
}


/**********************************
　ファーストビュー
**********************************/
.fv {
  height: auto;
  margin-bottom: 50px;
  position: relative;
  min-height: 670px
}
.mv-picture{
  position: absolute;
  width: 57%;
  height: 281px;
  top:260px;
  right: 0;
  z-index: -1;
}
.mv-picture img{
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.mv-picture-pro{
  position: absolute;
  width: 50%;
  height: 395px;
  top:	155px;
  right: 0;
  z-index: -1;
}
.mv-picture-pro img{
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.fv::before{
  position: absolute;
  content: "";
  top: 531px;
  left:0;
  background: #707070;
  width: 30vw;
  height: 1px;
}
.fv .ttl-bg{
  background: #000;
  width: 666px;
  height: 245px;
  padding: 90px 0 0 100px;
  color: #fff;
  font-size: 3.6rem;
  margin-top: 138px;
}
.fv div.flex{
  justify-content: space-between;
}
.fv .ttl-bg span{
  font-size: 1.8rem;
}
.fv .txt-wrap{
  margin:36px auto 76px 100px;
}
.fv .txt-wrap p:first-of-type{
  font-size: 4rem;
}
.fv .txt-wrap p:nth-of-type(2){
  font-size:6.5rem;
  color: #BE0000;
  margin-bottom: 22px;
  position: relative;
}
.fv .txt-wrap p:nth-of-type(2)::after{
  position: absolute;
  content: "";
  top:72px;
  left:0;
  background: #707070;
  width: 290px;
  height: 1px;
}

.fv .txt-wrap p:last-of-type{
  color: #BE0000;
  margin-top: 20px;
}
.fv .txt-wrap img{
  width: 294px;
  margin: 5px auto 0;
}
.fv .pic-wrap{
  margin-top: 563px;
}
.fv .pic-wrap li{
  margin-left: 20px;
}
.fv .pic-wrap li:nth-of-type(2) img{
  margin-bottom: 4px;
}



/**********************************
  WARNING
**********************************/
.warning{
  background: #000;
  margin: -77px 50px 0 0;
  padding-top: 78px;
  margin-bottom: 80px;
}
.w__inner{
  width: 50%;
}
.warning h2{
  margin-top: -44px;
  font-family:'Roboto', sans-serif;
}
.warning h2,
.warning h3{
  margin-left: -32px;
}
.warning .w__inner:first-of-type{
  margin-left: 72px;
}
.warning .w_list{
  margin: 45px auto 40px;
}
.warning .w_list li{
  font-size: 2rem;
  color: #fff;
  font-weight: bold;
  background: #BE0000;
  margin-bottom: 23px;
  line-height: 2;
  width: 430px;
  padding-left: 10px;
}
.warning p{
  color: #fff;
  line-height: 2;
  margin-bottom: 40px;
}
.warning .sec_btn {
  padding: 18px 0;
  margin-bottom: 37px;
}
.warning .w__inner:last-of-type{
  position: relative;
}
.warning .w__inner:last-of-type img:first-of-type{
  position: absolute;
  top:97px;
  left:86px;
  width: 220px;
}
.warning .w__inner:last-of-type img:nth-of-type(2){
  position: absolute;
  top:55px;
  left:391px;
  width: 229px;
}
.warning .w__inner:last-of-type img:last-of-type{
  position: absolute;
  top:311px;
  left:265px;
  width: 318px;
}


/**********************************
  MOVIE
**********************************/
.movie {
  margin:70px auto 115px;
}
.movie .ttl-box{
  margin: 0 114px 57px auto;
  width: 437px;
}
.movie .sec-ttl {
  margin-bottom: 50px;
}
.movie .video {
  margin: 0 auto;
  text-align: center;
}



/**********************************
  生態について
**********************************/
.ecology{
  position: relative;
}
.ecology::after{
  position: absolute;
  content: "";
  top:321px;
  left:50px;
  width:calc(100% - 50px);
  height: 802px;
  background: #F0F0F0;
  z-index: -1;
}
.ecology .txt-wrap{
  width: 482px;
}
.ecology .flex{
  justify-content: space-between;
  max-width: 1168px;
}
.ecology .flex:first-of-type{
  margin-bottom: 147px;
}
.ecology h2{
  text-align: center;
  font-size: 2.8rem;
  margin-bottom: 106px;
}
.ecology h3{
  font-size: 2.2rem;
  padding: 25px 0;
  border: solid 1px #333;
  width: 320px;
  margin-bottom: 60px;
  text-align: center;
  background: #fff;
}
.ecology img{
  width: 530px;  
}
.ecology p{
  line-height: 2;
  width: 482px;
  letter-spacing: 0.05em;
}
.ecology p span{
  font-size: 2.8rem;
}
.ecology .sec_btn {
  padding: 17px 0;
  margin-top: 60px;
}
/**********************************
  駆除宣言
**********************************/
.extermination-sec{
  margin-top: 23px;
  color: #fff;
}
.extermination-sec .ttl_wrap{
  background-image: url("../images/top/extermination.jpg");
  background-repeat: no-repeat;
  background-position: center;
  margin: auto;
}
.ttl_wrap .inner2{
  width: 100%;
  justify-content: space-between;
  align-items: center;
  padding: 112px 0;
}
.extermination-sec .ttl_wrap h2{
  border:solid 1px #fff;
  margin-right: 40px;
}
.extermination-sec h3,
.extermination-sec h4{
  margin-left: 90px;
}
.extermination-sec .wrap{
  margin:-40px 100px 0 0;
  background: #000;
  padding-top:10px
}
.extermination-sec .wrap div{
  margin:0 10px 0 0;
  border-top:solid 1px #fff;
  border-right:solid 1px #fff;
  padding: 80px 0;
}
.extermination-sec dl{
  max-width: 561px;
  margin: 0 auto 87px;
}
.extermination-sec dt{
  font-size: 2rem;
  background: #BE0000;
  width: 409px;
  line-height: 1.3;
  padding-left: 10px;
}
.extermination-sec dd{
  line-height: 2;
  margin:10px 0 0 22px;
}

/**********************************
  駆除対象
**********************************/
.service-sec{
  margin: 100px auto 120px;
  text-align: center;
}
.service-sec ul li{
  width: 20%;
  margin-top: 50px;
}
.service-sec ul li img{
  height: 99px;
}
.service-sec ul li h4{
  font-size: 2rem;
  font-weight: bold;
  position: relative;
}
.service-sec ul li h4::after{
  position: absolute;
  content: "";
  width: 123px;
  height: 1px;
  background: #707070;
  top: 24px;
  left:50%;
  transform: translateX(-50%);
}
.service-sec ul li h5{
  font-size: 2rem;
  font-weight: bold;
  color: #BE0000;
  margin-top: 10px;
}
.service-sec ul li p {
  font-size: 1.6rem;
  width: 80%;
  text-align: center;
  margin: auto;
  letter-spacing: 0.2em;
  line-height: 1.6;
}
.beast{
  background-image: url("../images/service/beast-bg.jpg");
}
.pest{
  background-image: url("../images/service/pest-bg.jpg");
}

.beast,
.pest{
  background-repeat: no-repeat;
  background-position: center;
  background-size: 1034px 492px;
}
.service-sec dl{
  margin-top: 14px;
}
.service-sec dt{
  font-size: 2.2rem;
  color: #BE0000;
}
.service-sec dd{
  width: 555px;
  margin: 9px auto 44px;
}


/**********************************
  メディア実績
**********************************/
.media-under{
  margin:100px auto 124px;
  text-align: center;
}
.media-under .ttl-box{
  text-align: left;
  margin-left: 2%;
}
.media-under .flex ul{
  justify-content: space-between;
}

.media-under .flex li{
  width: 33%;
  margin-bottom: 30px;
  padding: 0 2%;
}
.media-under .flex li img,
.media-under iframe{
  width: 348px;
  height: 195px;
  box-shadow: 1px 3px 3px rgba(0,0,0,.2);

}
.media-under .flex li p{
  font-size: 1.8rem;
  letter-spacing: 1.7;
  margin: 23px auto 0;
  line-height: 1.4;
}
.media-more{
  margin-top: 25px;
}
.media-more-wrap .flex{
  flex-wrap: wrap;
}
.media-more summary {
  background: none;
  margin-bottom: 100px;
  padding: 0;
  height: 49px;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
}
.media-more details summary::before {
  margin-right: auto;
  position: absolute;
  top: 50%;
  right: auto;
  left:50%;
  transform: translate(-50%,-50%);
  font-size: 1.4rem;
  content: "さらに見る";
  background: #BE0000;
  border-radius: 5px;
  width: 260px;
  height: 49px;
  color: #fff;
  display: block;
  text-align: center;
  line-height: 49px;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  border: solid 1px #BE0000;
  transition: 0.3s;
}
.media-more details summary:hover::before{
  background-color: #fff;
  color: #BE0000;
  transition: 0.3s;
}

.media-more details[open] summary::before {
  content: "閉じる"
}
.media-more details p {
  line-height: 1.4;
}
/**********************************
  工事実績
**********************************/
.achievement-sec{
  margin-bottom: 117px;
}

/**********************************************************/
/* SP用 */
/**********************************************************/

@media(max-width: 768px) {

/**********************************
　ファーストビュー
**********************************/
.fv {
    min-height: auto;
    position: relative;
    width: 100%;
    height: 580px;
}
.mv-picture{
    position: absolute;
    width: 81%;
    height: 176px;
    top:132px;
    right: 0;
}
.mv-picture-pro{
    position: absolute;
    width: 81%;
    height: 176px;
    top:145px;
    right: 0;
}

.fv::before {
    top: 452px;
    width: 27%;
}
.fv .ttl-bg {
    background: #000;
    width: 80%;
    height: 145px;
    padding: 49px 0 0 4%;
    color: #fff;
    font-size: 2.6rem;
    margin-top: 100px;
}
.fv div.flex {
    display: block;
}
.fv .txt-wrap p:first-of-type {
    font-size: 2.6rem;
}
.fv .txt-wrap p:nth-of-type(2) {
    font-size: 2.6rem;
    color: #BE0000;
    margin-bottom: 16px;
    margin-left: 65px;
    position: relative;
}
.fv .txt-wrap {
    position: absolute;
    top: 396px;
    left: 4%;
    width: 96%;
    margin: 0;
}
.fv .txt-wrap p:nth-of-type(2)::after {
    top: 30px;
    width: 41%;
}
.fv .txt-wrap p:last-of-type {
    color: #BE0000;
    margin-top: 30px;
}
.fv .pic-wrap {
    position: absolute;
    top: 330px;
    right: 0;
    font-size: 1.2rem;
    width: 57%;
    margin-top: 0;
}
.fv .pic-wrap li {
    margin-left: 0;
    margin-right: 10px;
}
.fv .pic-wrap li:nth-of-type(2) img {
    margin-bottom: 4px;
    width: 36px;
}
.fv .position{
    position: relative;
}
.chibakun-wrap {
  top: -20px;
  right: 10px;
}
  
  
  
/**********************************
  WARNING
**********************************/
.warning {
    margin: 0 4% 0 0;
}
.warning ul.flex{
    display: block;
    text-align: center;
}
.w__inner {
    width: 100%;
}
.warning h2, .warning h3 {
    margin-left: 2%;
    text-align: left;
}
.warning h3 span{
    margin-left: 66px;
    font-weight: 600;
}
.un-ttl::after {
    position: absolute;
    content: "";
    width: 290px;
    height: 1px;
    background: #707070;
    top: 45px;
    left: 0;
}
.un-sbttl {
    font-size: 2.6rem;
    margin-top: 43px;
}
.warning .w__inner:first-of-type {
    margin-left: 0%;
}
.warning .w__inner:last-of-type {
    position: relative;
    height: 619px;
}
.warning .w_list {
    margin: 25px auto 40px 2%;
    text-align: left;
}
.warning p {
    margin-bottom: 20px;
    padding: 0 2%;
    text-align: left;
}
.warning .w_list li {
    font-size: 1.4rem;
    width: 321px;
    padding-left: 2%;
}  
.warning .sec_btn {
    padding: 15px 0;
    margin-bottom: 50px;
}  
.warning .w__inner:last-of-type img:first-of-type {
    position: absolute;
    top: 196px;
    left: 0;
    width: 208px;
}  
.warning .w__inner:last-of-type img:nth-of-type(2) {
    position: absolute;
    top: 0;
    left: auto;
    right: 0;
    width: 216px;
}
.warning .w__inner:last-of-type img:last-of-type {
    position: absolute;
    top: 385px;
    left: auto;
    right: 0;
    width: 300px;
}  
  
/**********************************
  MOVIE
**********************************/  
.movie.inner {
    margin: 60px auto 0;
}
.movie .sec-ttl {
    margin-bottom: 47px;
}  
.movie .ttl-box {
    margin: 0 auto 22px 2%;
    width: 98%;
}
.movie .video {
  position: relative;
  width: 94%;
  padding-top: 56.25%; /* = height ÷ width × 100 */
}
.movie .video iframe{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.movie .video_pro {
  position: relative;
  width: 94%;
  margin-top: -90px;
}
.movie .video_pro iframe{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
  
/**********************************
  生態について
**********************************/
.ecology {
    position: relative;
    margin-top: 112px;
    margin-bottom: 100px;
}
.ecology .flex {
    padding: 0 4%;
    display: block;
}
.ecology::after {
    position: absolute;
    content: "";
    top: 580px;
    left: 0;
    width: 100%;
    height: 1000px;
    background: #F0F0F0;
    z-index: -1;
}
.ecology .txt-wrap{
  width: 100%;
}
.ecology h3 {
    font-size: 2.2rem;
    padding: 16px 0;
    height: 55px;
    border: solid 1px #333;
    width: 215px;
    margin-bottom: 30px;
    text-align: center;
    background: #fff;
}
.ecology .flex:first-of-type {
    margin-bottom: 300px;
    display: block;
    position: relative;
}
.ecology .flex:last-of-type {
    text-align: center;
    position: relative;
}
.ecology .flex:last-of-type p{
      text-align: left;
}
.ecology img {
    width: 335px;
	margin-top: 15px;
}
.ecology .flex:first-of-type img {
    width: 335px;
    position: absolute;
    top: 313px;
    left: 4%;
}
.ecology .flex:last-of-type img {
    width: 335px;
    position: absolute;
    top: 548px;
    left: 4%;
}
.ecology p{
  width: auto;
}

.ecology p span {
    font-size: 2.6rem;
}
.ecology .sec_btn {
    margin-top: 268px;
} 
  
  
/**********************************
  メディア
**********************************/
.media-under .sec-ttl {
    margin-bottom: 50px;
}
.media-under .flex li {
    width: 100%;
}  
.media-under .flex li p {
    font-size: 1.4rem;
    letter-spacing: 1.7;
    margin: 10px auto 0;
}
.media-under .sec_btn {
    padding: 17px 0;
    margin-top: 0;
}
  .media-more summary {
    margin-bottom: 0;
}
  .media-more details summary::before{
    width: 187px;
    height: 46px;
    line-height: 46px;
  }
  .media-more-wrap{
    margin-top: 30px;
  }
/**********************************
  工事実績
**********************************/
.achievement-sec {
    margin-bottom: 70px;
    margin-top: 134px;
}
  
  
  
/**********************************
  工事実績
**********************************/

.service-sec dd {
    width: 271px;
    margin: 7px auto;
}  
.service-sec ul li {
    width: 50%;
    margin-top: 74px;
}  
.service-sec dt {
    font-size: 1.4rem;
    letter-spacing: 0.07em;
}
.service-sec dl {
    margin-top: 85px;
}
.service-sec .sec_btn {
    padding: 16px 0;
}
  


  
}