@charset "UTF-8";

main{
  padding-top: 100px;
}
@media only screen and (max-width: 768px) {
  main{
    padding-top: 48px;
  }
}
/*---------------------*/
/*見出し*/
/*---------------------*/
.h1_ttl{
  text-align: center;
  background: #1C5E1F;
  font-size: 2.8rem;
  font-weight: 100;
  color: #fff;
  padding: 14px 0;
}
.h2_ttl {
  text-align: center;
}
.h2_ttl p{
  font-size: 1.4rem;
  font-family: 'Red Hat Display';
  color: #1C5E1F;
}
.h2_ttl h2{
  font-size: 2.4rem;
  font-weight: bold;
}

.h3_ttl{
  text-align: center;
  font-weight: bold;
  font-size: 1.8rem;
}
.h4_ttl{
  text-align: center;
  font-weight: bold;
  font-size: 1.6rem;
}
.h5_ttl{
  text-align: center;
  font-weight: bold;
  font-size: 1.4rem;
}
@media only screen and (max-width: 768px) {
  .h1_ttl{
    font-size: 2.4rem;
    padding: 11px 0;
  }
}
/*---------------------*/
/*ぱんくず*/
/*---------------------*/
.bread_nav{
  padding: 20px 0 20px 48px;
}
.bread_nav li{
  position: relative;
  padding-left: 20px;
  display: inline;
  margin-right: 4px;
  font-size: 1.4rem;
}
.bread_nav li:before{
  content:"";
  display: block;
  width: 16px;
  height: 16px;
  background: url(/common/images/icn_breadcrumb.svg) 0 0 no-repeat;
  background-size: cover;
  position: absolute;
  top: 3px;
  left: 0;
}
.bread_nav li:first-of-type{padding-left: 0;}
.bread_nav li:first-of-type:before{
  display: none;
}
.bread_nav a{
  font-size: 1.4rem;
}

/*---------------------*/
/*リード文*/
/*---------------------*/
.lead_l{
  font-size: 1.6rem;
  color: #535353;
  max-width: 740px;
  margin: 0 auto;
  padding: 0 16px;
}
.lead{
  font-size: 1.4rem;
  color: #535353;
  max-width: 740px;
  margin: 0 auto;
  padding: 0 16px;
}

.txt_box{
  padding: 0 16px;
  max-width: 740px;
  margin: 0 auto;
}
.txt_box .inner{
  border: 1px solid #E5E5E5;
  background: #fff;
  padding: 32px;
  font-size: 1.4rem;
  color: #535353;
}
@media only screen and (max-width: 768px) {
  .txt_box .inner{
    padding: 16px;
  }

}
/*---------------------*/
/*.wrapper*/
/*---------------------*/
section > .wrapper{
  /* max-width: calc(100% / 16 * 8); */
  max-width: 1080px;;
  margin: 0 auto;
  padding: 96px 0;
}
@media only screen and (max-width: 768px) {
  section > .wrapper{
    padding: 48px 0;
  }
}
section:first-of-type > .wrapper{
  padding-top: 0;
}
/*---------------------*/
/*画像とテキスト左右分割1*/
/*---------------------*/
.img_text .box,
.img_text .box{
  width: 50%;
  padding: 0 16px;
}

.img_text .text{
  font-size: 1.6rem;
  color: #535353;
}
@media only screen and (max-width: 768px) {
  .img_text{
    display: block;
  }
  .img_text .box,
  .img_text .box{
    width: 100%;
    padding: 0 16px;
  }
}
/*---------------------*/
/*通常のリスト*/
/*---------------------*/
.check_list,
ol.normal,
ul.normal{
  max-width: 740px;
  margin: 0 auto;
  padding: 0 16px;
}
.check_list li,
ol.normal li,
ul.normal li{
  background: #fff;
  font-size: 1.4rem;
  color: #535353;
  padding: 9px 8px 9px 32px;
  position: relative;
  box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.08);
}
.check_list li + li,
ol.normal li + li,
ul.normal li + li{
  margin-top: 2px;
}
ol.normal li:after,
ol.normal li:before,
ul.normal li:before,
.check_list li:before{
  display: block;
  content:"";
}
ul.normal li:before{
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #1C5E1F;
  position: absolute;
  left: 11px;
  top: 12px;
}
ol.normal li:after{
  content:"1";
  font-size: 1.4rem;
  color: #fff;
  position: absolute;
  width: 26px;
  top: 50%;
  left: 0;
  text-align: center;
  transform: translateY(-50%);
}
ol.normal li:before{
  width: 26px;
  height: 100%;
  background: #1C5E1F;
  position: absolute;
  top: 0;
  left: 0;
  line-height: 36px;
}
ol.normal li:nth-of-type(2):after{content:"2";}
ol.normal li:nth-of-type(3):after{content:"3";}
ol.normal li:nth-of-type(4):after{content:"4";}
ol.normal li:nth-of-type(5):after{content:"5";}
ol.normal li:nth-of-type(6):after{content:"6";}
ol.normal li:nth-of-type(7):after{content:"7";}
ol.normal li:nth-of-type(8):after{content:"8";}
ol.normal li:nth-of-type(9):after{content:"9";}
ol.normal li:nth-of-type(10):after{content:"10";}

/*---------------------*/
/*チェックリスト*/
/*---------------------*/
.check_list li:before{
  background: url(/common/images/icn_checkmark.svg) 0 0 no-repeat;
  background-size: 16px;
  width: 16px;
  height: 16px;
  position: absolute;
  left: 5px;
  top: 12px;
  l
}

/*---------------------*/
/*通常のテーブル*/
/*---------------------*/
.tbl{
  max-width: 740px;
  margin: 0 auto;
  padding: 0 16px;
  font-size: 1.4rem;
}
table{
  width: 100%;
}

th,
td{
  border: 1px solid #E5E5E5;
  padding: 8px;
  background: #fff;
  color: #292929;
}
th{
  color: #fff;
  background: #1C5E1F;
  vertical-align: middle;
}
@media only screen and (max-width: 768px) {
  .tbl table,
  .tbl tbody,
  .tbl tr,
  .tbl th,
  .tbl td{
    display: block;
    width: 100%;
  }
}
/*---------------------*/
/*スマホでは複雑テーブルはスクロール*/
/*---------------------*/
@media only screen and (max-width: 768px) {
  .tbl_sp_overflow{
    width: 100%;
    margin: 0 auto;
    overflow-x: auto;
    padding: 0 16px;
  }
  .tbl_sp_overflow .tbl_inner{
    width: 1080px;
    padding-right: 16px;
  }
}
/*---------------------*/
/*レイアウト変更なしのテーブル*/
/*---------------------*/
.normal_tbl{
  width: 100%;
}
.normal_tbl table{
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .normal_tbl{
    padding: 0 16px;
  }
}
/*---------------------*/
/*アコーディオン*/
/*---------------------*/
.acd_wrap{
  max-width: 740px;
  margin: 0 auto;
  padding: 0 16px;
}
.acd_wrap .row{
  background: #fff;
  box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.08);
}
.acd_wrap .row + .row{
  margin-top: 8px;
}
.acd_wrap h5{
  font-size: 1.4rem;
  font-weight: bold;
  padding: 9px 36px 9px 8px;
  position: relative;
  color: #000;
  cursor: pointer;
}
.acd_wrap h5:after{
  display: block;
  content:"";
  display: block;
  width: 20px;
  height: 20px;
  background: url(/common/images/icn_toggle_open.svg) 0 0 no-repeat;
  background-size: cover;
  position: absolute;
  top: 50%;
  right: 8px;
  transform: translateY(-50%);
}
.acd_wrap h5.open:after{
  background: url(/common/images/icn_toggle_close.svg) 0 0 no-repeat;
  background-size: cover;
}
.acd_wrap .hide_area{
  font-size: 1.4rem;
  color: #535353;
  padding: 8px 36px 8px 8px;
  display: none;
}

.acd_wrap .q span,
.acd_wrap .a span{
  display: block;
  width: 20px;
  height: 20px;
  border-radius: 4px;
  background: #1C5E1F;
  color: #fff;
  text-align: center;
  position: absolute;
  top: 8px;
  left: 8px;
}
.acd_wrap .q,
.acd_wrap .a{
  padding-left: 36px;
  position: relative;
}
.acd_wrap .a span{
  background: #D9AB21;
}
@media only screen and (max-width: 768px) {
  .acd_wrap .q span, .acd_wrap .a span{
    top: 10px;
  }
}

/*---------------------*/
/*スモールリンク*/
/*---------------------*/
.radius_btn a{
  display: inline-block;
  font-size: 1.4rem;
  color: #1C5E1F;
  line-height: 1.5;
  padding: 3px 11px;
  text-decoration: none;
  border: 1px solid #1C5E1F;
  border-radius: 48px;
  background: #fff;
  transition: 0.2s;
}
.radius_btn a:hover{
  background: #E5E5E5;
}
/*---------------------*/
/*ボタン*/
/*---------------------*/
.green_btn,
.white_btn{
  max-width: 328px;
}
.white_btn a,
.green_btn a{
  display: block;
  text-align: center;
  text-decoration: none;
  color: #fff;
  font-size: 1.4rem;
  padding: 13px 0;
  background: url(/common/images/icn_link.svg) 12px 50% no-repeat #1C5E1F;
  background-size: 20px;
  transition: 0.2s;
}
.green_btn a:hover{
  background-color: #063B08;
}
.white_btn a{
  background: url(/common/images/icn_link2.svg) 12px 50% no-repeat #fff;
  background-size: 20px;
  border: 1px solid #1C5E1F;
  color: #1C5E1F;
  padding: 12px 0;

}
.white_btn a:hover{
  background-color: #E5E5E5;
}
/*---------------------*/
/*フル画像*/
/*---------------------*/
.full_img{
  padding: 0px 16px;
  max-width: 1280px;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  .full_img{
    padding: 0px;
  }
}
/*---------------------*/
/*画像下に被りテキスト*/
/*---------------------*/
.column2 .box,
.column2 .box{
  width: 50%;
  padding: 12px 16px;
}
.suffer_box .text_area{
  padding: 0 24px;
  margin-top: -80px;
}
.suffer_box .text_area .text_inner a{
  display: block;
  background: #fff;
  box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.08);
  padding: 16px;
  position: relative;
  color: #000;
  text-decoration: none;
}
.suffer_box .text_area .text_inner a h4{
  color: #000;
}
.suffer_box .text_area .text_inner a .text{
  color: #535353;
}
.suffer_box .text_area .text_inner a:after{
  content:"";
  display: block;
  width: 24px;
  height: 24px;
  background: url(/common/images/icn_weapon.svg) 0 0 no-repeat;
  background-size: 24px;
  position: absolute;
  top: 0;
  right: 0;
}
.suffer_box .text_area .no{
  font-size: 3.2rem;
  color: #1C5E1F;
}
.suffer_box .text_area .h4_ttl{
  text-align: left;
  margin-top: 8px;
}
.suffer_box .text_area .text{
  margin-top: 12px;
  font-size: 1.4rem;
}
@media only screen and (max-width: 768px) {
  .column2{display: block;}
  .column2 .box,
  .column2 .box{
    width: 100%;
  }
  .column2 .box, .column2 .box{
    padding: 0 8px;
  }
  .suffer_box .text_area{
    padding: 0 8px;
  }
  .column2 .box + .box{
    margin-top: 16px;
  }
}
/*---------------------*/
/*3カラム、下テキスト*/
/*4カラム、下テキスト*/
/*---------------------*/
.column3 .box{
  width: calc(100% / 3);
  padding: 16px;
}

.column4 .box{
  width: calc(100% / 4);
  padding: 16px;
}
.column4 .box a,
.column3 .box a{
  display: block;
  text-decoration: none;
  height: 100%;
}
.column3 .box .box_inner,
.column4 .box .box_inner{
  height: 100%;
  background: #fff;
}
.column4 .text_area,
.column3 .text_area{
  padding: 16px;
}
.column3 .text_area .ttl,
.column4 .text_area .ttl{
  text-align: center;
  font-size: 1.4rem;
  font-weight: bold;
  color: #000;
}
.column3 .text_area .text,
.column4 .text_area .text{
  font-size: 1.4rem;
  color: #535353;
  margin-top: 8px;
}
@media only screen and (max-width: 768px) {
  .column3{display: block;}
  .column3 .box{
    width: 100%;
    padding: 8px 16px;
  }
  .column4 .box{
    width: 50%;
    padding: 8px;
  }
}
/*---------------------*/
/*4カラム、下被りテキスト*/
/*---------------------*/
.suffer_box2 .box_inner{
  position: relative;
}
.suffer_box2 .ribbon{
  position: absolute;
  width: 100%;
  width: calc(100% - 32px);
  bottom: -18px;
}
.suffer_box2 .name{
  text-align: center;
  font-size: 1.4rem;
  font-weight: bold;
  padding: 9px 8px;
  color: #fff;
  background: #000;
}
.suffer_box2  a{
  display: block;
}
.suffer_box2 .box{
  padding-bottom: 18px;
  padding-bottom: 34px;
}
@media only screen and (max-width: 768px) {
  .suffer_box2 .box{
    padding-bottom: 26px;
  }
}
/*---------------------*/
/*お知らせ*/
/*---------------------*/
.news{
  padding: 0 16px;
}
.news dl{
  background: #fff;
  box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.08);
}
.news dl + dl{
  margin-top: 8px;
}
.news dd,
.news a{
  display: block;
  text-decoration: none;
  color: #535353;
  font-size: 1.4rem;
}
.news  dt{
  width: 344px;
  padding: 18px 0;
}
.news  dd{
  width: calc(100% - 344px);
  padding: 18px 16px;
}
.news .day{
  color: #1C5E1F;
  font-size: 1.4rem;
  width: 164px;
  text-align: center;
  font-family: 'Red Hat Display';
}
.news .icn_info,
.news .icn_news{
  text-align: center;
  width: 180px;
  padding: 0 16px;
}
.news .icn_info span,
.news .icn_news span{
  color: #fff;
  background: #1C5E1F;
  display: block;
}
.news .icn_news span{
  background: #D9AB21;
  font-size: 1.4rem;
}
@media only screen and (max-width: 768px) {
  .news{
    padding: 0 8px;
  }
  .news dl{
    display: block;
  }
  .news dl + dl{
    margin-top: 4px;
  }
  .news  dd{
    width: 100%;
    padding: 0;
  }
  .news  dd a{
    padding: 0 8px;
    padding-bottom: 28px;
  }
  .news  dt{
    width: 100%;
    padding: 0 0;
  }
  .news .day{
    width: 50%;
    text-align: left;
    padding: 12px 10px 12px 12px;
  }
  .news .icn_info,
  .news .icn_news{
    width: 50%;
    padding: 8px;
  }
  .news .icn_info span,
  .news .icn_news span{
    padding: 2px 0;
  }
}
/*---------------------*/
/*背景グレー*/
/*---------------------*/
.bg_gray{
  background: #F0F0F0;
  box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.08);
}
/*---------------------*/
/*背景イエロー*/
/*---------------------*/
.bg_yellow{
  background: #F7F1DE;
  box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.08);
}
/*---------------------*/
/*背景ホワイト*/
/*---------------------*/
.bg_white{
  background: #fff;
  box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.08);
}
@media only screen and (max-width: 768px) {
  /* .bg_gray .box + .box,
  .bg_yellow .box + .box,
  .bg_white .box + .box{
    margin-top: 16px;
  } */
}

/*---------------------*/
/*TOPICS*/
/*---------------------*/
.label02,
.label01{
  font-size: 1.4rem;
  background: #1C5E1F;
  color: #fff;
  display: inline-block;
  text-align: center;
  width: 128px;
  padding: 4px 0;
}
.label02{
  background: #D9AB21;
}
.topics{
  max-width: 740px;
  margin: 48px auto 0;
  width: 100%;
  font-size: 1.4rem;
  padding: 0 16px;
}
.topics .main_text img{
  display: block;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  .topics{padding: 0;}
}
/*---------------------*/
/*埋め込み動画*/
/*---------------------*/
.movie{
  width: 100%;
  height: 0;
  position: relative;
  padding-top: 56.25%;
}
.movie iframe{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}


/*---------------------*/
/*イレギュラー*/
/*---------------------*/
.gra01{
  background: #F7F1DE;
}
.gra02{
  background: #f7dfdf;
  background: -moz-linear-gradient(left, #F7F1DE 0%, #f7dfdf 100%);
  background: -webkit-gradient(linear, left center, right center, from(#F7F1DE), to(#f7dfdf));
  background: -webkit-linear-gradient(left, #F7F1DE 0%, #f7dfdf 100%);
  background: -o-linear-gradient(left, #F7F1DE 0%, #f7dfdf 100%);
  background: linear-gradient(to right, #F7F1DE 0%, #f7dfdf 100%);
}
.gra03{
  background: #f7dfdf;
}
.gradation01{
  width: 90px;
  position: relative;
}
.gradation01:before,
.gradation01:after{
  display: block;
  content:"";
  width: 30px;
  margin: 0 auto;
  height: 60px;
  background: url(/common/images/decontamination/img_technique_low@2x.png) 0 0 no-repeat;
  background-size: cover;

}
.gradation01:after{
  background: url(/common/images/decontamination/img_technique_high@2x.png) 0 0 no-repeat;
  background-size: cover;
}
.arrow_cell{
  width: 90px;
  border: none;
  background: none;
  position: relative;
}
.arrow_cell p{
  height: calc(100% - 120px);
  background: #E48201;
  background: -moz-linear-gradient( #3E8F8C 0%, #E48201 100%);
  background: -webkit-gradient(linear, left top, left bottom, from(#3E8F8C), to(#E48201));
  background: -webkit-linear-gradient( #3E8F8C 0%, #E48201 100%);
  background: -o-linear-gradient( #3E8F8C 0%, #E48201 100%);
  background: linear-gradient( #3E8F8C 0%, #E48201 100%);
  position: absolute;
  top: 50%;
  left: 50%;
  width: 30px;
  transform: translate(-50%,-50%);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-flow: row wrap;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-align-items: center;
  -ms-align-items: center;
  align-items: center;
  text-align: center;
  color: #fff;
}
.arrow_cell p:before,
.arrow_cell p:after{
  display: block;
  content:"";
  width: 30px;
  margin: 0 auto;
  height: 60px;
  background: url(/common/images/decontamination/img_technique_low@2x.png) 0 0 no-repeat;
  background-size: cover;
  position: absolute;
  top: -60px;
  left: 50%;
  transform: translateX(-50%);
}
.arrow_cell p:after{
  background: url(/common/images/decontamination/img_technique_high@2x.png) 0 0 no-repeat;
  background-size: cover;
  top:auto;
  bottom: -60px;
}

.gradation01 span{
  background: #E48201;
  background: -moz-linear-gradient( #3E8F8C 0%, #E48201 100%);
  background: -webkit-gradient(linear, left top, left bottom, from(#3E8F8C), to(#E48201));
  background: -webkit-linear-gradient( #3E8F8C 0%, #E48201 100%);
  background: -o-linear-gradient( #3E8F8C 0%, #E48201 100%);
  background: linear-gradient( #3E8F8C 0%, #E48201 100%);
  width: 30px;
  margin: 0 30px;
  display: block;
  vertical-align: middle;
  height: calc(100% - 120px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-flow: row wrap;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-align-items: center;
  -ms-align-items: center;
  align-items: center;
  text-align: center;
  color: #fff;
}
.gradation01 + .tbl_sp_overflow{
  width: calc(100% - 90px);
}
@media only screen and (max-width: 768px) {
  .gradation01{
    width: 62px;
  }
  .gradation01 + .tbl_sp_overflow{
    width: calc(100% - 62px);
  }
  .gradation01 span{
    margin: 0 16px;
  }
  .arrow_cell{
    width: 60px;
  }
}
.g,
table .g th,table .g td{
  background: #dff7e3;
  color: #292929;
}
.y,
table .y th,table .y td{
  background: #F7F1DE;
  color: #292929;
}




.anchors_wrap{
  max-width: 740px;
  margin: 0 auto;
  padding: 0 16px;
}
.anchors2 .faze2,
.anchors .faze{
  width: calc((100% - 64px) / 3);
  margin-right: 32px;
  text-align: center;
  border-radius: 16px;
  border: 2px solid #1C5E1F;
}
.anchors2 .faze2.txt{
  text-align: left;
}
.anchors2 .faze2{
  border-color: #a2ab32;
}
.brd0{border: 0 !important;}
.anchors2 .faze2:last-of-type,
.anchors .faze:last-of-type{
  margin-right: 0;
}
.anchors2 .faze2{
  margin-top: 24px;
}
.anchors2 .faze2 a:visited,
.anchors2 .faze2 a,
.anchors .faze a:visited,
.anchors .faze a{
  display: block;
  color: #292929;
  text-decoration: none;
  padding: 16px 0;

}

.anchors .arw{
  position: relative;
}
.anchors .arw:after{
  content:"";
  display: block;
  width: 16px;
  height: 16px;
  background: url(/common/images/decontamination/arrow_right.svg) 0 0 no-repeat;
  background-size: cover;
  position: absolute;
  top: 50%;
  right: -32px;
  transform: translate(-50%,-50%);
}
.anchors .txt_faze,
.anchors2 .txt_faze{
  font-size: 1.4rem;
}
.anchors .ttl,
.anchors2 .ttl{
  font-weight: bold;
}
@media only screen and (min-width: 769px) {
  .anchors_wrap{display: block;}
}
@media only screen and (max-width: 768px) {
  .anchors2,
  .anchors{
    display: block;
    width: calc((100% - 16px) /2);
  }
  .anchors{
    margin-right: 16px;
  }
  .anchors2 .faze2, .anchors .faze{
    width: 100%;
  }
  .anchors2 .faze2{
    margin-top: 0;
  }
  .anchors .faze + .faze{
    margin-top: 32px;
  }
  .anchors .arw:after{
    top: auto;
    right: auto;
    left: 50%;
    bottom: -32px;
    transform: translate(-50%,-50%) rotate(90deg);
  }
  .anchors2{
    margin-top: 50px;
  }
  .anchors2 .faze2.txt{
    text-align: center;
  }
}

/*フェイズ〇〇*/
.faze_ttl{
  padding: 16px;
  font-size: 1.8rem;
  font-weight: bold;
  line-height: 32px;
}
.faze_ttl span{
  display: inline-block;
  color: #fff;
  background: #1C5E1F;
  padding: 0 8px;
  margin-right: 16px;
  font-size: 1.6rem;
}

/* 動画セミナー */
.lity{
  z-index: 99999;
}
/*estate*/


.estate_flow {
}
.estate_flow__block {
  margin-left: 16px;
  margin-right: 16px;
  position: relative;
}

.estate_flow__block.--border-green {
  border-radius: 8px;
  box-shadow: inset 0 0 0 3px #1C5E1F;
  padding: 22px;
}
.estate_flow__block.--border-green .h4_ttl {
  margin-bottom: 16px;
}
.estate_flow__block {}
.estate_flow__block__text {

}
.flow_group_flex {
  display: flex;
}
.flow_block_flex {
  display: flex;
}
@media only screen and (max-width: 768px) {
  .flow_block_flex {
    flex-wrap: wrap;
  }
}
.flow_block_flex__items {
  flex: 1;
}
@media only screen and (max-width: 768px) {
  .flow_block_flex__items {
    flex: auto;
    width: 100%;
  }
  .flow_block_flex__items:nth-of-type(1n+2) {
    padding-top: 16px;
  }
}
.flow_block_flex__items__image {
  margin-left: 16px;
  margin-right: 16px;
}
.flow_block_flex__items__text {
  padding-left: 16px;
  padding-right: 16px;
}

/* 流れを表す矢印 */
.estate_flow__block.--flow-arrow-b:nth-of-type(1n+2) {
  margin-top: 104px;
}
.estate_flow__block.--flow-arrow-b:nth-of-type(1n+2)::after {
  background-image: url(/common/images/estate/img_drawing_arrow_01@2x.png);
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: contain;
  top: -106px;
  content: '';
  display: block;
  height: 82px;
  left: 0;
  position: absolute;
  width: 100%;
  z-index: -1;
}
@media only screen and (max-width: 768px) {
  .estate_flow__block.--flow-arrow-b:nth-of-type(1n+2)::after {
    top: calc(-106px - 5%);
  }
}
.flow_group_flex .estate_flow__block {
  width: 50%;
}
.flow_group_flex .estate_flow__block.--flow-arrow-b {
  margin-top: 80px;
}
.flow_group_flex .estate_flow__block.--flow-arrow-b::after {
  background-image: url(/common/images/estate/img_drawing_arrow_01@2x.png);
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  display: block;
  height: 82px;
  left: 0;
  position: absolute;
  top: -106px;
  width: 100%;
  z-index: -1;
}

@media only screen and (max-width: 768px) {
  .flow_group_flex {
    flex-wrap: wrap;
    overflow: hidden;
  }
  .flow_group_flex .estate_flow__block {
    width: 100%;
  }
  .flow_group_flex .estate_flow__block.--flow-arrow-b {
    margin-top: 80px;
  }
  .flow_group_flex .estate_flow__block.--flow-arrow-b::after {
    top: -106px;
    width: 45%;
  }
  .flow_group_flex .estate_flow__block.--flow-arrow-b:nth-of-type(2) {
    margin-top: 136px;
  }
  .flow_group_flex .estate_flow__block.--flow-arrow-b:nth-of-type(2):after {
    background-image: url(/common/images/estate/img_drawing_arrow_02@2x.png);
    background-position: 100% 50%;
    left: auto;
    right: 0;
    height: 160vw;
    top: auto;
    bottom: 100%;
  }
}
/*---------------------*/
/* business/underground.html */
/*---------------------*/
.udgr .box{
  width: calc((100% - 64px) / 3);
  margin-right: 32px;
  border: 2px solid #1C5E1F;
  padding: 16px 8px;
  border-radius: 16px;
}
.udgr .box:last-of-type{
  margin-right: 0;
}
.udgr .arw{position: relative;}
.udgr .arw:after{
  content: "";
  display: block;
  width: 16px;
  height: 16px;
  background: url(/common/images/decontamination/arrow_right.svg) 0 0 no-repeat;
  background-size: cover;
  position: absolute;
  top: 50%;
  right: -32px;
  transform: translate(-50%,-50%);
}
@media only screen and (max-width: 768px) {
  .udgr .flex{display: block;}
  .udgr .box{
    width: 100%;
    margin-right: 0;
    max-width: 280px;
    margin: 0 auto;
  }
  .udgr .box + .box{
    margin: 32px auto 0;
  }
  .udgr .arw:after{
    top: auto;
    right: auto;
    left: 50%;
    bottom: -32px;
    transform: translate(-50%,-50%) rotate(90deg);
  }
}

/*追従ボタン*/
.fixed_btn{
  position: fixed;
  top: 50%;
  right: 0;
  text-align: center;
  transform: translateY(-50%);
}
.fixed_btn a{
  display: inline-block;
  background: #1C5E1F;
  color: #fff;
  text-decoration: none;
  padding: 8px 24px;
  padding-bottom: 40px;
  position: relative;
  font-size: 1.4rem;
}
.fixed_btn a span{
  font-size: 1.2rem;
}
.fixed_btn a:after,
.fixed_btn a:before{
  display: block;
  content:"";
  width: 24px;
  height: 24px;
  background: #fff;
  border-radius: 50%;
  position: absolute;
  bottom: 8px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
}
.fixed_btn a:after{
  background: url(/common/images/icn_breadcrumb.svg) 50% 50% no-repeat;
  background-size: 20px;
  z-index: 2;
  transform: translateX(-50%) rotate(90deg);

}

@media only screen and (max-width: 768px) {
  .fixed_btn{
    top: auto;
    bottom: 0;
    right:auto;
    transform: translateY(0%);
    width: 100%;
  }
  .fixed_btn a{
    display: block;
    width: 100%;
    padding: 8px 0;
    padding-bottom: 8px;
    line-height: 1.3;
  }
  .fixed_btn a:after,
  .fixed_btn a:before{
    width: 20px;
    height: 20px;
    bottom: auto;
    left: auto;
    transform: translateX(0%) translateY(-50%);
    right: 8px;
    top: 50%;
  }





  .fixed_btn a:after{
    background-size: 12px;
    z-index: 2;
    transform: translate(0%,-50%) rotate(90deg);

  }

}

/*------------------*/
/* 210816add */
/*------------------*/
.fz18{font-size: 1.8rem !important;}
.fz16{font-size: 1.6rem !important;}
