@charset "utf-8";

/* DIY REPORT */

.diy-intro{
  position: relative;
  margin: 0;
  padding: 1em 1em 0 1em;
  width: calc(100% - 2rem);
  max-width: 120rem;
  display: block;
  overflow: hidden;
  border-radius: 0.4em;
  background: rgb(241,241,241);
  background: linear-gradient(180deg, rgba(241,241,241,1) 20%, rgba(247,237,230,1) 100%); 
  z-index: 1;
}

.diy-intro .diy-contents-title{
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-start;
  border-bottom: none;
  z-index: 10;
}

.diy-intro .diy-contents-title img{
  margin: 0;
  padding: 0;
  width: 8rem;
  align-self: flex-start;
  order: 1;
}

.diy-intro .diy-contents-title span{
  margin: 0;
  padding: 0 0 0 0.5em;
  width: calc(100% - 8rem);
  color: #755643;
  font-size: var(--font-size-xxl);
  line-height: 1.4;
  text-shadow: 0.1rem 0.1rem 0 #f1f1f1, 0.1rem 0.1rem 0.3rem #f1f1f1, 0.1rem 0.1rem 0.5rem #f1f1f1, 0.1rem 0.1rem 0.5rem #f1f1f1;
  order: 2;
}

.diy-intro .diy-contents-title em{
  margin: 0;
  padding: 0;
  display: block;
  font-size: var(--font-size-m);
  line-height: 1.6;
  letter-spacing: 0;
}

.diy-intro .diy-lead-txt{
  position: relative;
  margin: 0;
  padding: 1.5em 0;
  font-size:  var(--font-size-l);
  line-height: 1.8;
  text-shadow: 0.1rem 0.1rem 0 #f1f1f1, 0.1rem 0.1rem 0.3rem #f1f1f1, 0.1rem 0.1rem 0.5rem #f1f1f1, 0.1rem 0.1rem 0.5rem #f1f1f1;
  z-index: 10;
}

.diy-intro .bg-image{
  position: absolute;
  top: 0;
  right: 0;
  margin: 0;
  padding: 0;
  width: 100%;
  max-width: 54.8rem;
  display: block;
  opacity: 0.5;
  z-index: 2;
}

.diy-intro .diy-report-link{
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-start;
  z-index: 10;
}

.diy-intro .diy-report-link .diy-man{ display: none;}

.diy-intro .link-list{
  margin: 0;
  padding: 1.5em 0 1.5em 0;
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  order: 2;
}

.diy-intro .link-list li{
  position: relative;
  margin: 0.5em 0 0 0;
  padding: 0.8em 0.5em;
  width: 48.5%;
  display: block;
  background: rgb(255,255,255);
  background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(241,241,241,1) 100%); 
  border-radius: 0.6em;
  border: 0.2rem solid #fff;  
  box-shadow: 0 0 0.8rem rgba(0,0,0,0.2);
  counter-increment: sub-title;
}

.diy-intro .link-list li a{
  position: relative;
  margin: 0;
  padding: 0 0 0 2em;
  width: 100%;
  display: block;
  color: #036;
  font-size: var(--font-size-m);
  line-height: 1.4;  
}

.diy-intro .link-list li:before {
  position: absolute;
  top: 0;
  left: 0.5em;
  bottom: 0;
  margin: auto;
  padding: 0;
  width: 2.4rem;
  height: 2.4rem;
  display: block;
  border-radius: 0.2em;
  background-color: #1079be;
  color: #fff;
  font-size: var(--font-size-l);
  font-weight: 600;
  line-height: 1.4;
  text-align: center;
  content:counter(sub-title) "";
  z-index: 20;
}

.diy-intro .link-list li a:after{
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  padding: 0;
  width: 1.4rem;
  height: 1.4rem;
  display: block;
  background: url(/service/common/img/icon_arrow_blue.svg) center center no-repeat;
  background-size: contain;
  transform: rotate(90deg);
  aspect-ratio: 1 / 1;
  content: "";
  z-index: 100;
}

.diy-intro .link-list li img{
  margin: 0;
  padding: 0;
  width: 6rem;
}

.diy-intro .link-list li p{
  margin: 0;
  padding: 0 0 0 1em;
  width: calc(100% - 6rem);
  color: #333;
  font-size: var(--font-size-s);
  line-height: 1.6;
  text-align: left;  
}

.diy-intro .link-list li em{
  position: relative;
  margin: 0;
  padding: 0 0 0.2em 0;
  display: block;
  color: #1079be;
  font-size: var(--font-size-m);
  font-weight: 600;
  line-height: 1.6;
  text-align: left;  
}

.movie-section {
  position: relative;
  margin: auto;
  padding: 4em 0;
  width: calc(100% - 2rem);
  max-width: 120rem;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: space-between;
  z-index: auto;
}

.movie-section .inner{
  margin: 0;
  padding: 0;
  width: 100%;
}

.movie-section .inner h2{
  margin: 0 0 1em 0;
  padding: 1em;
  border-bottom: 0.1rem solid #999;
  font-size: var(--font-size-l);
  line-height: 1.4;
  text-align: center;
}

.movie-section .inner p{
  margin: 0;
  padding: 0 0 1em;
  font-size: var(--font-size-m);
  line-height: 1.6;
  text-align: left;
}

.movie-section .movie-box-4x3{
  margin: auto;
  padding: 0;
  width: 96%;
  max-width: 48rem;
  background-color: #000;
  box-shadow: 0 1.5rem 1rem -1rem rgba(0,0,0,0.6);
}

.movie-section .movie-box-4x3 .movie-body{ position: relative; padding-bottom: 75%; width:100%; text-align: left;}

.movie-section .movie-box-4x3 video{
  position: absolute;
  top: 0;
  left: 0;
  margin: 0;
  padding: 0;
  width: 100%;
}

.diy-report{
  margin: auto;
  width: calc(100% - 2rem);
  max-width: 100rem;
  counter-reset: title;
  
  display: block;
}

.diy-report .section-title{
  position: relative;
  margin: 0 0 1em 0;
  padding: 0.7em 0.5em 0.7em 2.5em;
  border-radius: 0.4em;
  border-bottom: none;
  color: #036;
  font-size: var(--font-size-xl);
  line-height: 1.4;
  counter-increment: title;
  background: rgb(255,255,255);
  background: linear-gradient(90deg, rgba(255,255,255,1) 20%, rgba(243,248,251,1) 100%); 
}

.diy-report .section-title:before {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
  padding: 0;
  width: 4.5rem;
  height: 4.5rem;
  display: block;
  color: #fff;
  font-size: var(--font-size-xxl);
  font-weight: 600;
  line-height: 1.6;
  text-align: center;
  content:counter(title) "";
  z-index: 20;
}

.diy-report .section-title:after{
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
  padding: 0;
  width: 4.5rem;
  height: 4.5rem;
  display: block;
  border-radius: 0.2em;
  background-color: #1079be;
  content:"";
  z-index: 12;
}

.diy-report .section-sub-title{
  position: relative;
  margin: 0 0 1.5em 0;
  padding: 0;
  border-bottom: 0.1rem dotted #999;
  font-size: var(--font-size-l);
  line-height: 1.6;
}

.diy-report .section-sub-title::before{ display: none;}

.diy-report .section-sub-title em{
  margin: 0 0 0.2em 0;
  padding: 0.4em 0.8em;
  display: block;
  border-left: 0.5rem solid #1079be;
}

.diy-report .txt{
  margin: 0 0 1em 0;
  font-size: var(--font-size-s);
  line-height: 1.6;
}

.diy-report .list-ol li,
.diy-report .list-ul li{
  padding-bottom: 0.5em;
  font-size: var(--font-size-s);
  line-height: 1.6;
}

.diy-report .notice-txt{
  position: relative;
  margin: 0 0 1em 0;
  padding: 1.5em 1.5em 1.5em 4em;
  border-radius: 0.2em;
  background-color: #ffffe5;
  color: #c00;
  font-size: var(--font-size-s);
  line-height: 1.7;
}

.diy-report .notice-txt:before{
  position: absolute;
  top: 1em;
  left: 1em;
  margin: 0;
  padding: 0;
  width: 3rem;
  height: 3rem;
  display: block;
  background: url(/service/common/img/icon_notice.svg) center center no-repeat;
  background-size: contain;
  aspect-ratio: 1 / 1;
  content:"";
}

.diy-report .inner-block{
  margin: 0;
  padding: 0 0 2em 0;
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.diy-report .inner-left,
.diy-report .inner-right{
  margin: 0;
  width: 50%;
  display: flex;
  justify-content: center;
}

.diy-report .inner-image{
  margin: auto;
  padding-bottom: 1em;
  width: 100%;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

.diy-report .inner-image-l{
  margin: auto;
  padding-bottom: 1em;
  width: 100%;
  text-align: center;
}

.diy-report .inner-image-l img{
  margin: auto;
  width: 96%;
  max-width: 60rem;
}

.diy-report .inner-image div{
  margin: 1em;
  padding: 0;
  width: 50%;
  max-width: 40rem;  
}

.diy-report .inner-left-img,
.diy-report .inner-right-img{
  margin: auto;
  padding: 0 1em 1em;
  width: 100%;
  max-width: 40rem;
}

.diy-report .inner-left-img img,
.diy-report .inner-right-img img{ margin: auto;}

.diy-report .inner-left-txt,
.diy-report .inner-right-txt{
  margin: 0;
  width: 100%;
}


.diy-report .one-point{
  margin: 1em auto;
  padding: 0.5em;
  width: 96%;
  display: block;
  border-top: 0.5rem solid #1079be;
  background-color: #f1f1f1;
  font-size: var(--font-size-m);
  line-height: 1.6;
}

.diy-report .one-point h4{
  margin: 0;
  padding: 0 0 0.5em 0;
  color: #036;
  font-size: var(--font-size-m);
  font-weight: 600;
  line-height: 1.6;
}

.diy-report .one-point ul li{
  margin: 0 0 0.5em 1.5em;
  padding: 0;
  list-style-type: disc;
  font-size: var(--font-size-s);
}



/* REPORT 03 */

.report-03-intro{
  position: relative;
  margin: 0 0 4em 0;
  padding: 1em;
  width: 100%;
  display: block;
  border-radius: 0.4em;
  background: url(/service/img/report/report_03_main_bg.avif) top right no-repeat, linear-gradient(180deg, rgba(244,252,255,1) 0%, rgba(251,251,251,1) 100%);  
  background-size: contain, auto;
  z-index: 1;
}

.report-03-intro:after {
  position: absolute;
  top: 0.4rem;
  left: 0.4rem;
  margin: 0;
  width: calc(100% - 1rem);
  height: calc(100% - 1rem);
  border-radius: 0.4em;
  border: 0.1rem solid #fff;
  content: '';
  pointer-events: none;
  z-index: 10;
}

.report-03-intro .report-contents-title{
  position: relative;
  margin: 0;
  padding: 0 0 0.5em 0;
  z-index: 30;
}

.report-03-intro .report-contents-title span{
  margin: 0 0 0 0;
  padding: 0;
  display: block;
  color: #0b2484;
  font-size: var(--font-size-xxl);
  line-height: 1.2;
  text-shadow: 0.1rem 0.1rem 0 #f1f1f1, 0.1rem 0.1rem 0.3rem #f1f1f1, 0.1rem 0.1rem 0.5rem #f1f1f1, 0.1rem 0.1rem 0.5rem #f1f1f1;
  order: 2;
}
.report-03-intro .report-contents-title span:first-letter{ margin: 0 0 0 -0.5em;}


.report-03-intro .report-contents-title em{
  margin: 0 0 0.2em 0;
  padding: 0.2em 1.5em;
  display: inline-block;
  background-color: #0b2484;
  color: #fff;
  font-size: var(--font-size-xs);
  line-height: 1.6;
  letter-spacing: 0;
  text-shadow: none;
}

.report-03-intro .lead-txt{
  position: relative;
  margin: 0;
  padding: 0 0 0.5em 0;
  width: calc(100% - 12rem);
  font-size: var(--font-size-m);
  line-height: 1.5;
  text-shadow: 0.1rem 0.1rem 0 #f1f1f1, 0.1rem 0.1rem 0.3rem #f1f1f1, 0.1rem 0.1rem 0.5rem #f1f1f1, 0.1rem 0.1rem 0.5rem #f1f1f1;
  z-index: 30;
}

.report-03-intro .image{
  position: absolute;
  bottom: -2em;
  right: 1em;
  margin: 0;
  padding: 0;
  width: 34%;
  max-width: 9rem;
  display: block;
  z-index: 21;
}




.common-report .section-title{
  position: relative;
  margin: 0 0 1em 0;
  padding: 0.7em 0.5em 0.7em 2.5em;
  border-radius: 0.4em;
  border-bottom: none;
  color: #036;
  font-size: var(--font-size-xl);
  line-height: 1.4;
  background: rgb(255,255,255);
  background: linear-gradient(90deg, rgba(255,255,255,1) 20%, rgba(243,248,251,1) 100%); 
}

.common-report .section-title:before {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
  padding: 0;
  width: 4rem;
  height: 4rem;
  display: block;
  background: url(/service/common/img/icon_point.svg) center center no-repeat;
  background-size: contain;
  content: "";
  z-index: 20;
}

.common-report .section-title:after{
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
  padding: 0;
  width: 4rem;
  height: 4rem;
  display: block;
  border-radius: 0.2em;
  background-color: #1079be;
  content:"";
  z-index: 12;
}

.common-report .sub-title {
  margin: 0 auto 1em;
  padding: 0 0 0.2em 0;
  display: block;
  border-bottom: 0.1rem dotted #999;
  font-size: var(--font-size-l);
  line-height: 1.6;
}

.common-report .sub-title.caution {
  margin: 0 auto 1.5em;
  color: #c00;
  font-weight: 600;
}

.common-report .list-ul{
  font-size: var(--font-size-m);
  line-height: 1.6; 
}

.common-report .list-ul.caution{ color: #c00;}


.common-report .annotation{
  margin: 2em 0;
  padding: 1em;
  border-radius: 0.4em;
  background-color: #f1f1f1;
  font-size: var(--font-size-m);
  line-height: 1.6; 
}

.common-report .annotation-line{
  margin: 2em 0;
  padding: 1em;
  display: block;
  border-radius: 0.4em;
  border: 0.1rem solid #999;
  font-size: var(--font-size-m);
  line-height: 1.6; 
}

.common-report .annotation-line .image{
  margin: auto;
  width: 90%;
  max-width: 40rem;
  display: block;
}

.common-report .annotation-line .list-ul{
  margin: 0;
  padding: 1em 0 0 0;
  width: 100%;
}

.common-report .annotation-line .list-ul .button{
  margin: 0.5em 0 0 0;
  padding: 1em 0;
  border-top: 0.1rem dotted #999;
  list-style-type: none;
}

.common-report .annotation-line .list-ul .button a{ font-size: var(--font-size-m);}

.common-report .annotation-line .list-ul .button span{ display: none;}


.common-report .step-list{ 
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
counter-reset: number;}

.common-report .step-list li{
  position: relative;
  margin: 0 0 1.5em 0;
  padding: 1em 1em 1em 3.5em;
  width: 49%;
  overflow: hidden;
  border-radius: 0.4em;
  border: 0.1rem solid #ccc;
  font-size: var(--font-size-m);
  line-height: 1.6;
  counter-increment: number;
}

.common-report .step-list li:before {
  position: absolute;
  top: 1rem;
  left: 1rem;
  margin: auto;
  padding: 0;
  width: 3rem;
  height: 3rem;
  display: block;
  color: #fff;
  font-size: var(--font-size-l);
  font-weight: 600;
  line-height: 1.6;
  text-align: center;
  content:counter(number) "";
  z-index: 20;
}

.common-report .step-list li:after{
  position: absolute;
  top: 1rem;
  left: 1rem;
  margin: auto;
  padding: 0;
  width: 3rem;
  height: 3rem;
  display: block;
  border-radius: 0.2em;
  background-color: #1079be;
  opacity: 0.5;
  content:"";
  z-index: 12;
}

.common-report .step-list img{
  position: relative;
  float: right;
  margin: 0 0 0.5em 0.5em;
  padding: 0;
  width: 1.1rem;
}


.report-section{
  width: 100%;


  

}

.report-section .lead-txt{
  position: relative;
  margin: 0;
  padding: 0 0 1em 0;
  font-size: var(--font-size-l);
  line-height: 1.4;
  
  

}



.common-report .step-list .notice{
  position: relative;
  margin: 1em 0 0 0;
  padding: 0 0 0 1.5em;
  display: block;
  font-size: var(--font-size-s);
  line-height: 1.6;
}

.common-report .step-list .notice:before {
  position: absolute;
  top: 0;
  left: 0;
  color: #c00;
  content: '\203B';
}



/* REPORT 05 */

.report-05-intro{
  position: relative;
  margin: 0 0 4em 0;
  padding: 1em;
  width: 100%;
  display: block;
  border-radius: 0.4em;
  background: url(/service/img/report/report_05_main_bg.avif) top right no-repeat, linear-gradient(180deg, rgba(244,252,255,1) 0%, rgba(251,251,251,1) 100%);  
  background-size: contain, auto;
  z-index: 1;
}

.report-05-intro:after {
  position: absolute;
  top: 0.4rem;
  left: 0.4rem;
  margin: 0;
  width: calc(100% - 1rem);
  height: calc(100% - 1rem);
  border-radius: 0.4em;
  border: 0.1rem solid #fff;
  content: '';
  pointer-events: none;
  z-index: 10;
}

.report-05-intro .report-contents-title{
  position: relative;
  margin: 0;
  padding: 0 0 0.5em 0;
  z-index: 30;
}

.report-05-intro .report-contents-title span{
  margin: 0;
  padding: 0;
  display: block;
  color: #0b2484;
  font-size: var(--font-size-xxl);
  line-height: 1.4;
  text-shadow: 0.1rem 0.1rem 0 #f1f1f1, 0.1rem 0.1rem 0.3rem #f1f1f1, 0.1rem 0.1rem 0.5rem #f1f1f1, 0.1rem 0.1rem 0.5rem #f1f1f1;
  order: 2;
}

.report-05-intro .report-contents-title span:first-letter{ margin: 0 0 0 -0.5em;}

.report-05-intro .report-contents-title span .sp-block{ display: none;}

.report-05-intro .report-contents-title em{
  margin: 0 0 0.2em 0;
  padding: 0.2em 1.5em;
  display: inline-block;
  background-color: #0b2484;
  color: #fff;
  font-size: var(--font-size-xs);
  line-height: 1.6;
  letter-spacing: 0;
  text-shadow: none;
}

.report-05-intro .lead-txt{
  position: relative;
  margin: 0;
  padding: 0 0 0.5em 0;
  font-size: var(--font-size-m);
  line-height: 1.5;
  text-shadow: 0.1rem 0.1rem 0 #f1f1f1, 0.1rem 0.1rem 0.3rem #f1f1f1, 0.1rem 0.1rem 0.5rem #f1f1f1, 0.1rem 0.1rem 0.5rem #f1f1f1;
  z-index: 30;
}




.report-5-image{
  position: relative;
  margin: 0;
  padding: 0 0 2em 0;
  width: 100%;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

.report-5-image li{
  position: relative;
  margin: 0;
  padding: 1em 0.5em;
  width: 50%;
  text-align: center;
}

.report-5-image li img{ margin: auto; max-width: 30rem;}



.report-spec-table{
  margin: 0 auto 2em;
  width: 100%;
  border-collapse: collapse;
  border: 0.1rem solid #ccc;
  background-color: #fff;
  font-size: var(--font-size-s);
  line-height: 1.6;
}


.report-spec-table th{
  padding: 0.8em;
  background-color: #eee;
  border: 0.1rem solid #ccc;
  font-weight: 600;
  text-align: center;
  vertical-align: middle;
  white-space: nowrap;
}

.report-spec-table th span{ font-size: var(--font-size-xs);}

.report-spec-table td{
  padding: 0.8em;
  background-color: #fff;
  border: 0.1rem solid #ccc;
  text-align: left;
  vertical-align: middle;
}

.report-spec-table .top-td{
  text-align: center;
  white-space: nowrap;
}



/* LATCH MAINTENANCE */


.latch-maintenance .anchor {  
  margin: 1em auto 2em;
  width: 100%;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: space-between;
}

.latch-maintenance .anchor li {
  margin: 0 0 0.8em 0;
  padding: 0;
  width: 49%;
}

.latch-maintenance .anchor li a{
  position: relative;
  margin: 0;
  padding: 0.6em 1em 0.6em 2.4em;  
  width: 100%;
  max-width: inherit;
  display: block;
  border-radius: 2em;
  border: 0.1rem solid #ccc;
  background-color: #fff;
  font-size: var(--font-size-m);
  line-height: 1.6;
  text-align: left;
}

.latch-maintenance .anchor li a:before{
  position: absolute;
  top: 0;
  left: 0.5em;
  bottom: 0;
  margin: auto;
  padding: 0;
  width: 2.4rem;
  height: 2.4rem;
  display: block;
  background: url(/service/common/img/icon_notice.svg) center center no-repeat;
  background-size: contain;
  content: "";
  z-index: 100;
}

.latch-maintenance .anchor li a:after{
  position: absolute;
  top: 0;
  right: 0.5em;
  bottom: 0;
  margin: auto;
  padding: 0;
  width: 1.4rem;
  height: 1.4rem;
  display: block;
  background: url(/service/common/img/icon_arrow_blue.svg) no-repeat;
  background-size: contain;
  transform:  rotate(90deg);
  content: "";
  z-index: 100;
}

.latch-mente-section{
  position: relative;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.latch-mente-section .section-title{
  position: relative;
  margin: 0 0 1em 0;
  padding: 0.7em 0.5em 0.7em 2.5em;
  width: 100%;
  border-radius: 0.4em;
  border-bottom: none;
  font-size: var(--font-size-l);
  line-height: 1.4;
  background: rgb(255,255,255);
  background: linear-gradient(90deg, rgba(255,255,255,1) 20%, rgba(241,241,241,1) 100%); 
}

.latch-mente-section .section-title:before {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
  padding: 0;
  width: 4rem;
  height: 4rem;
  display: block;
  background: url(/service/common/img/icon_notice.svg) center center no-repeat;
  background-size: contain;
  content: "";
  z-index: 20;
}

.latch-mente-section .section-title span{
  position: relative;
  margin: 0 0 0.5em 0;
  padding: 0.4em 1em;
  width: 12em;
  display: block;
  border-radius: 2em;
  background-color: #999;
  color: #fff;
  font-size: var(--font-size-xs);
  font-weight: 600;
  line-height: 1.4;
  text-align: center;
}

.latch-mente-section .sub-title{
  position: relative;
  margin: 0;
  padding: 0 0 0.5em 0;
  border-bottom: none;
  color: #c00;
  font-size: var(--font-size-l);
  font-weight: 600;
  line-height: 1.6;
}

.latch-mente-section .image{
  position: relative;
  margin: 0 auto 1em;
  width: 94%;
  max-width: 28rem;
  order: 1;  
}

.latch-mente-section .inner{
  position: relative;
  margin: 0;
  width: 100%;
  order: 2;  
}

.latch-mente-section .txt{ font-size: var(--font-size-m);}

.latch-mente-section .notice-list{
  position: relative;
  margin: 0 0 1em;
  font-size: var(--font-size-m);
  line-height: 1.6;
}

.latch-mente-section .notice-list li{
  position: relative;
  margin: 0.5em 0 0 0;
  padding: 0 0 0 1.5em;
  list-style: none;
}

.latch-mente-section .notice-list li:before {
  position: absolute;
  top: 0;
  left: 0;
  color: #c00;
  content: '\203B';
}





@media screen and (max-width: 640px) {

/* DIY REPORT 640 */

.diy-intro .link-list li{ width: 100%;}


.report-spec-table{
  padding-bottom: 1em;
  display: block;
  overflow-x: scroll;
  white-space: nowrap;
  -webkit-overflow-scrolling: touch;
  border: none;
}

} /* End SP 640 */


@media screen and (max-width: 480px) {

.diy-report .inner-image div{
  margin: 1em auto;
  padding: 0;
  width: 96%;
  max-width: 40rem;  
}


.common-report .step-list{ display: block;}
.common-report .step-list li{ width: 100%;}

.report-05-intro .report-contents-title span .sp-block{ display: block;}

.report-5-image li{
  padding: 1em;
  width: 100%;
}

.report-5-image li img{ max-width: 240px;}

.latch-maintenance .anchor li { width: 100%;}

.torituke .intro .contents-title span span{ display: block;}

} /* End SP 480 */



@media screen and (min-width: 768px), print {


/* DIY REPORT TAB */

.diy-intro{ padding: 1.5em 1.5em 0 1.5em;}

.diy-intro .diy-contents-title img{ width: 12rem;}

.diy-intro .diy-contents-title span{
  width: calc(100% - 12rem);
  font-size: var(--font-size-xxl);
  line-height: 1.4;
  letter-spacing: 0.1em;
}

.diy-intro .diy-contents-title em{ font-size: var(--font-size-l);}

.diy-intro .diy-lead-txt{
  font-size: var(--font-size-l);
  line-height: 1.8;
}

.diy-intro .bg-image{ opacity: 1;}

.diy-intro .link-list li{
  margin: 0 0 0.5em 0;
  padding: 0.8em;
  width: 48.5%;
}

.diy-intro .link-list li em{
  margin: 0;
  padding: 0 0 0 1em;  
}

.movie-section:after{
  position: absolute;
  top: 0;
  left: 0;
  margin: auto;
  padding: 0;
  width: 50%;
  height: 100%;
  display: block;
  background: rgb(16,121,190);
  background: url(/service/img/home/diy_bg_logo.svg) center center no-repeat, radial-gradient(circle, rgba(16,121,190,0.7) 0%, rgba(255,255,255,1) 65%); 
  background-size: contain, auto;
  content: "";
  opacity: 0.2;
  z-index: -1;
}

.movie-section .inner{ width: 50%;}

.movie-section .inner h2{ font-size: var(--font-size-xl); text-shadow: 0 0 0.8rem #fff, 0 0 0.6rem #fff, 0.1rem 0.1rem 0 #fff;}

.movie-section .inner p{
  margin: 0;
  padding: 0 1.5em;
  text-shadow: 0 0 0.8rem #fff, 0 0 0.6rem #fff, 0.1rem 0.1rem 0 #fff;
}

.movie-section .movie-box-4x3{
  width: 48%;
  max-width: 48rem;
}

.diy-intro .link-list li em:before{
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
  padding: 0;
  width: 1.4rem;
  height: 1.4rem;
  display: block;
  background: url(/service/common/img/icon_arrow_blue.svg) center center no-repeat;
  background-size: contain;
  content: "";
  z-index: 100;
}

.diy-report .section-title{ font-size: var(--font-size-xl);}

.diy-report .section-title:before {
  width: 4.5rem;
  height: 4.5rem;
  font-size: var(--font-size-xxl);
}

.diy-report .section-title:after{
  width: 4.5rem;
  height: 4.5rem;
}

.diy-report .section-sub-title{
  position: relative;
  margin: 0 0 1.5em 0;
  padding: 0;
  border-bottom: 0.1rem dotted #999;
  font-size: var(--font-size-l);
  line-height: 1.6;
}

.diy-report .section-sub-title em{
  margin: 0 0 0.2em 0;
  padding: 0.4em 0.8em;
  display: block;
  border-left: 0.5rem solid #1079be;
}

.diy-report .txt{
  margin: 0 0 1em 0;
  width: 100%;
  font-size: var(--font-size-m);
  line-height: 1.7;
}

.diy-report .list-ol li,
.diy-report .list-ul li{
  padding-bottom: 0.5em;
  width: 100%;
  font-size: var(--font-size-m);
  line-height: 1.7;
}

.diy-report .inner-block{
  margin: 0;
  padding: 0 0 2em 0;
  width: 100%;
  display: flex;
  flex-wrap: wrap;
}

.diy-report .inner-image div{
  margin: 1em 2em;
  padding: 0;
  width: 50%;
  max-width: 40rem;  
}

.diy-report .inner-left-img,
.diy-report .inner-right-img{
  margin: 0;
  width: 40%;
  max-width: 40rem;
}

.diy-report .inner-left-txt,
.diy-report .inner-right-txt{
  margin: 0;
  width: 58%;
}

.diy-report .one-point{
  margin: 1em auto;
  padding: 1em;
  width: 90%;
  display: block;
  border-top: 0.5rem solid #1079be;
  background-color: #f1f1f1;
  font-size: var(--font-size-m);
  line-height: 1.6;
}

.diy-report .one-point h4{
  margin: 0;
  padding: 0 0 0.5em 0;
  color: #036;
  font-size: var(--font-size-m);
  font-weight: 600;
  line-height: 1.6;
}

.diy-report .one-point ul li{
  margin: 0 0 0.5em 1.5em;
  padding: 0;
  list-style-type: disc;
  font-size: var(--font-size-s);
}

.faq-movie .movie-txt{ width: 50%;}


/* REPORT 03 TAB */

.report-03-intro{
  position: relative;
  margin: 0 0 4em 0;
  padding: 1em;
  width: 100%;
  display: block;
  border-radius: 0.4em;
  background: url(/service/img/report/report_03_main_bg.avif) top right no-repeat, linear-gradient(180deg, rgba(244,252,255,1) 0%, rgba(251,251,251,1) 100%);  
  background-size: 46% auto ,auto;
  z-index: 1;
}

.report-03-intro .report-contents-title{
  position: relative;
  margin: 0;
  padding: 0.5em;
  z-index: 10;
}

.report-03-intro .report-contents-title span{

  font-size: var(--font-size-xxl);
  line-height: 1.4;
  letter-spacing: 0.05em;
}

.report-03-intro .report-contents-title em{
  margin: 0 0 0.5em 0;
  padding: 0.2em 1.5em;
  font-size: var(--font-size-s);
  line-height: 1.6;
}

.report-03-intro .lead-txt{
  padding: 0 0 0.5em 0.5em;
  font-size: var(--font-size-xl);
  line-height: 1.8;
}

.report-03-intro .image{
  bottom: 0.5em;
  right: 5em;
  width: 40%;
  max-width: 12rem;
}


.common-report .section-title{ font-size: var(--font-size-xl);}

.common-report .section-title:before {
  width: 4.5rem;
  height: 4.5rem;
}

.common-report .section-title:after{
  width: 4.5rem;
  height: 4.5rem;
}

.common-report .sub-title { font-size: var(--font-size-l);}

.common-report .annotation{ padding: 1.5em;}

.common-report .annotation-line{
  margin: 2em 0;
  padding: 1em;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.common-report .annotation-line .image{
  margin: 0;
  width: 30rem;
  max-width: 30rem;
}

.common-report .annotation-line .list-ul{
  margin: 0;
  padding: 0 0 0 2em;
  width: calc(100% - 30rem);
}

.common-report .annotation-line .list-ul .button{ padding: 1em;}

.common-report .annotation-line .list-ul .button span{ display: inline-block;}



/* REPORT 05 TAB */

.report-05-intro{
  position: relative;
  margin: 0 0 4em 0;
  padding: 1em;
  width: 100%;
  display: block;
  border-radius: 0.4em;
  background: url(/service/img/report/report_05_main_bg.avif) top right no-repeat, linear-gradient(180deg, rgba(244,252,255,1) 0%, rgba(251,251,251,1) 100%);  
  background-size: 40% auto ,auto;
  z-index: 1;
}

.report-05-intro .report-contents-title{
  position: relative;
  margin: 0;
  padding: 0.5em;
  z-index: 10;
}

.report-05-intro .report-contents-title span{

  font-size: var(--font-size-xxl);
  line-height: 1.4;
  letter-spacing: 0.05em;
}

.report-05-intro .report-contents-title em{
  margin: 0 0 0.5em 0;
  padding: 0.2em 1.5em;
  font-size: var(--font-size-s);
  line-height: 1.6;
}

.report-05-intro .lead-txt{
  padding: 0 0 0.5em 0.5em;
  font-size: var(--font-size-xl);
  line-height: 1.8;
}



.report-spec-table{
  margin: 0 auto;
  width: 96%;
  border-collapse: collapse;
  border: 0.1rem solid #ccc;
  background-color: #fff;
  font-size: var(--font-size-s);
  line-height: 1.6;
}

.report-spec-table th{
  padding: 0.8em;
  background-color: #eee;
  border: 0.1rem solid #ccc;
  font-weight: 600;
  text-align: center;
  vertical-align: middle;
  white-space: nowrap;
}

.report-spec-table th span{ font-size: var(--font-size-xs);}

.report-spec-table td{
  padding: 0.8em;
  background-color: #fff;
  border: 0.1rem solid #ccc;
  text-align: left;
  vertical-align: middle;
}

.report-spec-table .top-td{
  text-align: center;
  white-space: nowrap;
}





/* LATCH MAINTENANCE TAB */

.latch-maintenance .anchor li { width: 32%;}

.latch-mente-section .image{
  position: relative;
  margin: 0;
  width: 28rem;
  order: 1;  
}

.latch-mente-section .inner{
  position: relative;
  margin: 0;
  width: calc(100% - 30rem);
  order: 2;  
}

.latch-mente-section .movie-list li{
  position: relative;
  margin: 0;
  padding: 1em;
  width: 50%;
  border: none;
}


}/* TAB */





@media screen and (min-width: 1000px) {

/* DIY REPORT PC */

.diy-intro:after{
  position: absolute;
  bottom: 0.5em;
  right: 0.5em;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  display: block;
  background: url(/service/img/home/diy_bg_txt.svg) right bottom no-repeat;
  background-size: 80% auto;
  opacity: 0.4;
  z-index: 2;
  content: "";
}

.diy-intro:before{
  position: absolute;
  bottom: 30%;
  left: 13%;
  margin: 0;
  padding: 0;
  width: 18rem;
  height: 18rem;
  display: block;
  background: url(/service/img/home/diy_bg_logo.svg) center center no-repeat;
  background-size: contain;
  opacity: 0.8;
  z-index: -10;
  content: "";
}

.diy-intro .diy-report-link{
  margin: -1.5em 0 0 0;
}
/*
.diy-intro .diy-report-link .diy-man{
  position: relative;
  margin: 0 0 -1rem;
  padding: 0;
  width: 22%;
  max-width: 22rem;
  aspect-ratio: 220 / 256;
  display: block;
  order: 1;
}
*/

.diy-intro .diy-report-link .diy-man{
  position: relative;
  margin: 0 0 -1rem;
  padding: 0;
  width: 22%;
  max-width: 22rem;
  aspect-ratio: 440 / 520;
  display: block;
  order: 1;
}

.diy-intro .diy-report-link .diy-man img{
  width: 100%;
  display: block;
  
}


.diy-intro .link-list{
  margin: 0;
  padding: 1.5em 0 1em 1em;
  width: calc(100% - 22%);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  order: 2;
}

.report-03-intro{
  background: url(/service/img/report/report_03_main_bg.avif) top right no-repeat, linear-gradient(180deg, rgba(244,252,255,1) 0%, rgba(251,251,251,1) 100%);  
  background-size: 38% auto ,auto;
}


.report-5-image li{
  position: relative;
  margin: 0;
  padding: 1em;
  width: 32%;
  text-align: center;
}


}/* PC */






.aspect-600-450{
  max-width: 60rem;
  aspect-ratio: 600 / 450;
}

.aspect-850-450{
  max-width: 85rem;
  aspect-ratio: 850 / 450;
}

.aspect-850-300{
  max-width: 85rem;
  aspect-ratio: 850 / 300;
}

.aspect-455-220{
  max-width: 45.5rem;
  aspect-ratio: 455 / 220;
}

.aspect-455-310{
  max-width: 45.5rem;
  aspect-ratio: 455 / 310;
}

.aspect-455-325{
  max-width: 45.5rem;
  aspect-ratio: 455 / 325;
}

.aspect-455-160{
  max-width: 45.5rem;
  aspect-ratio: 455 / 160;
}

.aspect-884-237{
  max-width: 88.4rem;
  aspect-ratio: 884 / 237;
}


