/*Mv
=======================================================*/
.mv{
  position: relative;
  margin-top: 60px!important;
  background: #DAF6FF;
}
.mv-catch-top{
  font-family: "KaiseiDecol Bold";
  background: #FFF700;
  clip-path: polygon(100% 0, 85% 50%, 100% 100%, 0 100%, 0 0);
  width: fit-content;
  padding: 10px 25px 10px 10px;
  line-height: 1.1;
  font-size: 23px;
}
.mv-catch{
  width: 100%;
  margin: 0 auto;
  position: relative;
  height: 70vh;
  z-index: 1;
}
.mv-catch-box{
  width: 100%;
  z-index: 1;
  font-family: "KaiseiDecol Bold";
  margin-top: -30px;
  text-align: center;
  position: relative;
}
.mv-catch-box::after{
  content: "";
  background: url(/wp-content/themes/memorialsupport_lp/img/map.png) no-repeat;
  background-size: contain;
  background-position: center;
  width: 100px;
  height: 130px;
  position: absolute;
  top: -40px;
  right: 77px;
  z-index: -1;
}
.mv-catch-box-catch1{
  font-size: 80px;
  line-height: 1;
  color:#FFF700;
  position: relative;
  z-index: 1;
}
.mv-catch-box-catch1::before{
  content: "遺品整理\A生前整理";
  white-space: pre;
  font-size: 80px;
  color: #0869AC;
  width: 100%;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%) translateY(0%);
  transform: translateX(-50%) translateY(0%);
  z-index: -1;
  -webkit-text-stroke: 4px #022C48;
  text-shadow: 4px 5px 0 #0869AC;
}
.mv-catch-box-sub1{
  font-size: 30px;
  line-height: 1;
  padding-bottom: 5px;
  color:#fff;
  position: relative;
  z-index: 1;
}
.mv-catch-box-sub1::before{
  content:"関西全域対応";
  font-size: 30px;
  -webkit-text-stroke: 3px #004372;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%) translateY(0%);
  transform: translateX(-50%) translateY(0%);
  z-index: -1;
}
.mv-catch-box-sub2{
  font-size: 25px;
  line-height: 1;
  padding-top: 10px;
}
img.mv-price{
  object-fit: contain;
  width: 75%;
  margin: 0 auto;
  display: block;
}
img.mv-main{
  object-fit: contain;
  width: 80%;
  margin: 0 auto;
  display: block;
}
img.mv-bubble{
  object-fit: contain;
  position: absolute;
  bottom: 18vh;
  width: 120px;
  left: 2%;
}
.mv-medal{
  display: flex;
  justify-content: center;
  gap:20px;
  margin-top: -13vh;
}
.mv-medal-box{
  background: url(/wp-content/themes/memorialsupport_lp/img/medal1.png) no-repeat;
  background-size: contain;
  background-position: center;
  font-family: "KaiseiDecol Bold";
  color:#9C4518;
  text-align: center;
  font-size: 23px;
  line-height: 1.3;
  width: 150px;
  height: 150px;
  display: flex;
  justify-content: center;
  align-items: center;
}
img.mv-bg{
  object-fit: contain;
  position: absolute;
  bottom: 40px;
  width: 100%;
}

@media screen and (max-width: 768px){
  .mv-catch{
    height: auto;
  }
  .mv-catch-top{
    font-size: 5vw;
  }
  .mv-catch-box-sub1{
    font-size: 6vw;
  }
  .mv-catch-box-sub1::before{
    font-size: 6vw;
  }
  .mv-catch-box-catch1{
    font-size: 20vw;
  }
  .mv-catch-box-catch1::before{
    font-size: 20vw;
  }
  .mv-catch-box-sub2{
    font-size: 6vw;
  }
  img.mv-bubble{
    width: 25vw;
    bottom: 32%;
  }
  .mv-medal-box{
    font-size: 5vw;
    width: 35vw;
    height: 35vw;
  }
}
@media screen and (max-width: 480px){
  .mv-catch{
    height: 80vh;
  }
  .mv-catch-box-catch1{
    font-size: 19vw;
  }
  .mv-catch-box-catch1::before{
    font-size: 19vw;
  }
  .mv-catch-box-sub2 {
    font-size: 5vw;
  }
  .mv-medal-box {
    font-size: 4.5vw;
    width: 32vw;
    height: 32vw;
  }
  img.mv-bubble{
    bottom: 23%;
  }
}

/*サービス
=======================================================*/
.service{
  background: url(/wp-content/themes/memorialsupport_lp/img/service-bg.png) no-repeat;
  background-size: cover;
  padding-bottom: 20px;
}
.service h2{
  color:#fff;
  background: #0869AC;
  font-family: "KaiseiDecol Bold";
  border-radius: 50px;
  width: fit-content;
  margin: 0 auto;
  font-size: 30px;
  padding: 0 20px;
  line-height: 1.5;
  position: relative;
}
.service h2::after{
  content: "";
  width: 0;
  height: 0;
  border-left: 15px solid transparent;
  border-right: 15px solid transparent;
  border-top: 20px solid #0869AC;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  bottom: -20px;
}
.service-wrap{
  margin-top: 30px;
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  justify-content: center;
  align-items: center;
}
.service-txt{
  background: #65C0FF;
  color: #fff;
  border-radius: 5px;
  padding: 0 13px;
  font-size: 17px;
}
img.service-slide-img{
  padding: 0 10px;
}
.slick-dots li{
  margin: 0;
}
.slick-dots li button:before{
  font-size: 50px;
  opacity: 1;
  color:#D9D9D9;
}
.slick-dots li.slick-active button:before{
  opacity: 1;
  color: #076BAF;
}

@media screen and (max-width: 768px){
}
@media screen and (max-width: 480px){
}

/*選ばれる5つの理由
=======================================================*/
.reason-ttl{
  position: relative;
}
.reason-ttl::before,
.reason-ttl::after{
  content: "";
  width: 100px;
  height: 140px;
  position: absolute;
  z-index: -1;
}
.reason-ttl::before{
  background: url(/wp-content/themes/memorialsupport_lp/img/reason-ttl-deco1.png) no-repeat;
  background-size: contain;
  top: 0;
  left: 0;
}
.reason-ttl::after{
  background: url(/wp-content/themes/memorialsupport_lp/img/reason-ttl-deco2.png) no-repeat;
  background-size: contain;
  top: 0;
  right: 0;
}
.reason h2{
  font-family: "KaiseiDecol Bold";
  text-align: center;
  font-size: 25px;
  line-height: 1;
  position: relative;
}
.reason h2::before{
  content: "";
  background: url(/wp-content/themes/memorialsupport_lp/img/logo2.png) no-repeat;
  background-size: contain;
  width: 60px;
  height: 60px;
  display: block;
  position: absolute;
  top: -40px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  z-index: -1;
}
img.reason-ttl-img{
  display: block;
  margin: 5px auto 0;
  width: 80%;
}
.reason-ttl-txt{
  text-align: center;
  line-height: 1.5;
  margin-top: 5px;
  font-family: "NotoSansJP Medium";
  font-size: 15px;
}
.reason-box-num{
  background: url(/wp-content/themes/memorialsupport_lp/img/reason-num.png) no-repeat;
  background-size: contain;
  margin-left: -6%;
  font-family: "KaiseiOpti Bold";
  color:#9C4518;
  font-size: 20px;
  padding: 10px 15px 15px 5px;
}
.reason-box-num span{
  font-size: 40px;
  line-height: 1.5;
}
.reason-box{
  position: relative;
  margin-top: 30px;
}
.reason-box::after{
  content: "";
  background: url(/wp-content/themes/memorialsupport_lp/img/reason-bg.png) no-repeat;
  background-size: contain;
  background-position: top center;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 25px;
  z-index: -1;
}
h3.reason-box-ttl{
  text-align: center;
  color:#7B1B00;
  margin-top: -20px;
  line-height: 1.3;
  font-size: 25px;
}
img.reason-img{
  display: block;
  margin: 10px auto;
  height: 130px;
}
.reason-box-txt{
  font-family: "NotoSansJP Medium";
  text-align: center;
  font-size: 13px;
  line-height: 1.5;
}

@media screen and (max-width: 768px){
}
@media screen and (max-width: 480px){
  .reason-ttl-txt{
    font-size: 3.6vw;
  }
  .reason-box-num{
    padding: 15px 15px 20px 5px;
  }
  .reason-box-num span{
    font-size: 30px;
  }
  img.reason-img{
    height: 110px;
  }
  .reason-box-txt{
    font-size: 2.8vw;
  }
}

/*ポイント
=======================================================*/
.point{
  background: #DAF6FF;
  margin-top: 25px;
  position: relative;
}
.point::before{
  content: "";
  width: 0;
  height: 0;
  border-left: 40px solid transparent;
  border-right: 40px solid transparent;
  border-top: 40px solid #fff;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
}
img.point-logo{
  display: block;
  width: 70%;
  margin: 10px auto 20px;
}
h2.point-ttl{
  color:#076BAF;
  text-align: center;
  font-size: 50px;
  line-height: 1.2;
  font-family: "NotoSansJP Black";
}
h2.point-ttl span.point-ttl-sub{
  display: block;
  font-size: 33px;
}
h2.point-ttl span.point-ttl-sub-s{
  font-size: 25px;
}
.point-detail{
  position: relative;
}
.point-detail-txt{
  width: 50%;
  padding: 30px 0;
  line-height: 1.5;
  font-family: "NotoSansJP Medium";
}
.point-box{
  display: flex;
  gap: 5px;
  justify-content: center;
  align-items: center;
}
.point-box img.point-img{
  object-fit: contain;
  width: calc(100% / 3);
}
.point-deco{
  position: absolute;
  width: 50%;
  object-fit: contain;
  top: 0;
  right: 0;
  z-index: -1;
}

@media screen and (max-width: 768px){
  h2.point-ttl{
    font-size: 10vw;
  }
  h2.point-ttl span.point-ttl-sub{
    font-size: 7vw;
  }
  h2.point-ttl span.point-ttl-sub-s{
    font-size: 5vw;
  }
  .point-detail-txt{
    font-size: 3.5vw;
  }
}
@media screen and (max-width: 480px){

}

/*最安値宣言
=======================================================*/
.cheap{
  background: url(/wp-content/themes/memorialsupport_lp/img/cheap-bg.png) no-repeat;
  background-size: cover;

}
.cheap-ttl{
  background: #076BAF;
  color:#fff;
  font-family: "NotoSansJP Black";
  font-size: 35px;
  text-align: center;
  position: relative;
  padding: 20px 0;
  line-height: 1;
}
.cheap-ttl::after{
  content: "";
  width: 0;
  height: 0;
  border-left: 40px solid transparent;
  border-right: 40px solid transparent;
  border-top: 40px solid #076BAF;
  position: absolute;
  left: 50%;
  bottom: -30px;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
}
.cheap-wrap{
  position: relative;
}
.cheap-wrap::after{
  content: "";
  background: url(/wp-content/themes/memorialsupport_lp/img/map.png) no-repeat;
  background-size: contain;
  background-position: center;
  width: 100px;
  height: 130px;
  position: absolute;
  top: -30px;
  right: 50px;
  z-index: -1;
}
.cheap-box{
  text-align: center;
  font-family: "KaiseiDecol Bold";
  font-size: 25px;
  line-height: 1.2;
  margin-bottom: 20px;
}
.cheap-box-l{
  color:#FFDA82;
  font-size: 70px;
  position: relative;
  z-index: 1;
}
.cheap-box-l::after{
  content: "最安値宣言";
  white-space: pre;
  font-size: 70px;
  color: #9C4518;
  width: 100%;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%) translateY(0%);
  transform: translateX(-50%) translateY(0%);
  z-index: -1;
  -webkit-text-stroke: 5px #9C4518;
  text-shadow: 0px 6px 0 #9C4518;
}
.cheap-price{
  object-fit: contain;
  width: 90%;
  margin: 0 auto;
  display: block;
}

@media screen and (max-width: 768px){
  .cheap-ttl{
    font-size: 7vw;
  }
  .cheap-box-l{
    font-size: 16vw;
  }
  .cheap-box-l::after{
    font-size: 16vw;
  }
}
@media screen and (max-width: 480px){
}

/*ワンストップ
=======================================================*/
.onestop{
  background: #DAF6FF
}
.onestop-ttl{
  clip-path: polygon(0 0, 100% 0, 98% 50%, 100% 100%, 0 100%, 2% 50%);
  background: #FFF29B;
  text-align: center;
  font-size: 18px;
  width: 100%;
  padding: 5px;
  position: relative;
}
.onestop-ttl-shadow{
  filter: drop-shadow(0px 4px 0px #FFBD67);
}
.onestop-flow{
  display: flex;
  margin-top: 20px;
  justify-content: space-between;
}
.onestop-flow-box{
  writing-mode: vertical-rl;
  background: #fff;
  border: 2px solid #076BAF;
  padding: 30px 10px;
  font-size: 20px;
  position: relative;
  letter-spacing: 3px;
}
.onestop-flow-box::after{
  content: "";
  width: 0;
  height: 0;
  border-left: 15px solid #076BAF;
  border-top: 15px solid transparent;
  border-bottom: 15px solid transparent;
  position: absolute;
  top: 50%;
  right: -15px;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
}
.onestop-flow-box:last-child:after{
  content: unset;
}
.results{
  margin-top: 40px;
}
.results-ttl-sub{
  font-size: 20px;
  text-align: center;
}
.results-ttl{
  font-family: "KaiseiDecol Bold";
  text-align: center;
  font-size: 35px;
  line-height: 1.3;
}
.results-wrap{
  margin-top: 20px;
}
img.results-img{
  object-fit: contain;
  margin-bottom: 20px;
  display: block;
  width: 100%;
}
img.results-img:last-child{
  margin-bottom: 0;
}

@media screen and (max-width: 768px){
  .onestop-ttl{
    font-size: 3.8vw;
  }
  .onestop-flow-box{
    font-size: 4vw;
  }
  .results-ttl-sub{
    font-size: 5vw;
  }
  .results-ttl{
    font-size: 8.5vw;
  }
}
@media screen and (max-width: 480px){
  .onestop-flow-box{
    padding: 20px 10px;
    line-height: 1.5;
  }
  .onestop-flow-box::after{
    border-left: 10px solid #076BAF;
    border-top: 10px solid transparent;
    border-bottom: 10px solid transparent;
    right: -10px;
  }
}

/*流れ
=======================================================*/
.flow{
  background: #FFF7DE;
}
.flow-ttl{
  text-align: center;
  font-size: 30px;
}
.flow-txt{
  font-family: "NotoSansJP Medium";
  text-align: center;
  font-size: 18px;
  line-height: 1.5;
}
.flow-wrap{
  margin-top: 20px;
}
.flow-box{
  background: #FFFFFF;
  border-radius: 10px;
  margin-bottom: 20px;
}
.flow-box:last-child{
  margin-bottom: 0;
}
h3.flow-box-ttl{
  background: #FFBD67;
  border-radius: 10px 10px 0 0;
  text-align: center;
  position: relative;
  width: 100%;
  padding: 10px;
}
h3.flow-box-ttl span{
  color: #fff;
  position: absolute;
  font-size: 50px;
  bottom: -5px;
  left: 10px;
  line-height: 1;
}
.flow-box-detail{
  padding: 10px;
}
img.flow-box-detail-img{
  object-fit: contain;
  height: 140px;
  display: block;
  margin: 10px auto;
}
.flow-box-detail-txt{
  font-family: "NotoSansJP Medium";
  font-size: 15px;
  line-height: 1.6;
}

@media screen and (max-width: 768px){
  .flow-box-detail-txt{
    font-size: 3.2vw;
  }
}
@media screen and (max-width: 480px){
}

/*よくあるご質問
=======================================================*/
.faq{
  background: #F4F4F4;
}
h2.faq-ttl{
  text-align: center;
  font-size: 30px;
}
.faq-wrap{
  margin-top: 30px;
}
.faq-box{
  margin-bottom: 10px;
}
.faq-box:last-child{
  margin-bottom: 0;
}
.faq-box-q{
  display: flex;
  background: #BDE4FF;
  align-items: center;
  justify-content: space-between;
  padding: 10px;
}
.faq-box-q-num{
  font-size: 34px;
  background: #fff;
  color: #076BAF;
  line-height: 1;
  width: 40px;
  height: 40px;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-right: 10px;
  border-radius: 5px;
	font-family: "NotoSans Bold";
}
.faq-box-q-txt{
  width: 88%;
  font-size: 16px;
  line-height: 1.5;
  font-family: "NotoSansJP Medium";
}
img.faq-box-arrow{
  object-fit: contain;
  object-position: center;
  width: 20px;
  transition: transform .3s ease-in-out, top .3s ease-in-out;
}
.faq-box-q.open img.faq-box-arrow{
  transform: rotate(-180deg);
}
.faq-box-a{
  display: none;
}
.faq-box-a-detail{
  display: flex;
  background: #fff;
  padding: 10px;
}
.faq-box-a-num{
  background: #A2D9FF;
  color:#fff;
  width: 35px;
  height: 35px;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-right: 10px;
  border-radius: 5px;
  font-size: 30px;
  font-family: "NotoSans Bold";
}
.faq-box-a-txt{
  width: 90%;
  font-size: 14px;
  font-family: "NotoSansJP Medium";
}

@media screen and (max-width: 768px){
}
@media screen and (max-width: 480px){
  .faq-box-q-num{
    font-size: 8vw;
    width: 8vw;
    height: 8vw;
  }
  .faq-box-q-txt{
    font-size: 3.5vw;
  }
  img.faq-box-arrow{
    width: 15px;
  }
  .faq-box-a-num{
    width: 7vw;
    height: 7vw;
    font-size: 6vw;
  }
  .faq-box-a-txt{
    font-size: 3.3vw;
  }
}

/*お問い合わせ
=======================================================*/
.contact{
  background: #FFF7BE;
}
.contact-ttl{
  font-family: "NotoSansJP Medium";
  text-align: center;
  font-size: 25px;
  line-height: 1.3;
  margin-bottom: 30px;
}
.contact-ttl span{
  color:#FF0004;
  font-family: "NotoSansJP Black";
  font-size: 40px;
  display: block;
}
img.contact-img{
  object-fit: contain;
  width: 100%;
  margin: 0 auto 20px;
  display: block;
}
a.contact-tel-btn img{
  filter: drop-shadow(0 8px 0 #023E66);
  transition: .2s ease-in-out;
}
a.contact-tel-btn img:hover{
  filter: unset;
  transform: translate(0, 8px);
}
a.contact-line-btn img{
  filter: drop-shadow(0 8px 0 #035003);
  transition: .2s ease-in-out;
  margin-top: 10px;
}
a.contact-line-btn img:hover{
  filter: unset;
  transform: translate(0, 8px);
}
a.contact-mail-btn img{
  filter: drop-shadow(0 8px 0 #8F490D);
  transition: .2s ease-in-out;
  margin-top: 10px;
}
a.contact-mail-btn img:hover{
  filter: unset;
  transform: translate(0, 8px);
}

@media screen and (max-width: 768px){
  .contact-ttl{
    font-size: 6vw;
  }
  .contact-ttl span{
    font-size: 8vw;
  }
}
@media screen and (max-width: 480px){
}