@charset "UTF-8";

main {
    padding-top: 14px;
    background: #fff;
    color: #000;
}

main p {
    margin: 0;
}

.cat_attention {
    padding-bottom: 70px;
}

/* sp 見積もり 追従ボタン */
@media screen and (max-width: 767px) {
  .to_reserve_fixed {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: center;
    justify-content: center;
  }
  .to_reserve_fixed p {
    width: 100%;
  }
  .to_reserve_fixed a {
    width: 48%;
    margin: 10px 0 0;
  }
  .to_reserve_fixed a.pc {
    display: block!important;
    margin-left: 2%;
  }
}

@media screen and (max-width: 374px) {
  .to_reserve_fixed p {
    font-size: 1.2rem;
  }
  .to_reserve_fixed a span {
    font-size: 1.2rem;
  }
}

/* -----------------------------------------------
category_title
----------------------------------------------- */
.category_title .text_wrap h2 {
  font-weight: bold;
  line-height: 1.47;
}

.category_title .text_wrap h2 span {
  display: block;
  color: #009CD0;
  font-weight: bold;
  font-family: 'Inter', sans-serif;
}

.category_title .text_wrap strong {
  font-weight: bold;
  display: block;
}

.category_title .text_wrap p {
  font-weight: 500;
}

@media screen and (max-width: 767px) {
  .category_title {
      margin-top: 11px;
  }

  .category_title .text_wrap {
      margin-top: 10px;
  }

  .category_title .text_wrap h2 {
      font-size: 3.4rem;
  }

  .category_title .text_wrap h2 span {
      margin-top: 7px;
      font-size: 1.6rem;
  }

  .category_title .text_wrap p {
      font-size: 1.4rem;
      line-height: 1.85;
      margin-top: 19px;
  }

  .category_title .text_wrap strong {
      font-size: 2.2rem;
      line-height: 1.72;
      margin-top: 40px;
  }
}

@media screen and (min-width: 768px) {
  .category_title {
      position: relative;
      width: 100%;
      height: 453px;
      margin-top: 10px;
  }

  .category_title .img {
      position: absolute;
      top: 0;
      right: 0;
      width: 60.93%;
      height: 100%;
      overflow: hidden;
  }

  .category_title img {
      height: 100%;
      border-radius: 8px 0 0 8px;
      position: absolute;
      left: 0;
      top: 0;
      width: auto;
      max-width: none;
  }
  
  .category_title .inner_wrap {
      position: absolute;
      top: auto;
      bottom: 40px;
      left: 50%;
      transform: translateX(-50%);
      width: 100%;
  }

  /* デザイン通りの場合 */
  /* .category_title .text_wrap {
      position: relative;
      width: 100%;
      height: 100%;
      padding-top: 96px;
  }

  .category_title .text_wrap p {
      position: absolute;
      bottom: -1px;
      padding: 30px 68px 30px 0;
      background: #FFFFFF;
      border-radius: 0 8px 0 0;
  } */

  /* テキストをひとまとめにする場合 */
  .category_title .inner_wrap {
      height: auto;
  }

  .category_title .text_wrap {
      display: inline-block;
      padding: 30px 50px 30px 0;
      background: rgba(255,255,255,.9);
      border-radius: 0 8px 8px 0;
      width: 568px;
  }

  .category_title .text_wrap h2 {
      font-size: 48px;
  }

  .category_title .text_wrap h2 span {
      margin-top: 9px;
      font-size: 20px;
  }

  .category_title .text_wrap p {
      font-size: 16px;
      line-height: 2;
      margin-top: 15px;
  }

  .category_title .text_wrap strong {
      font-size: 26px;
      line-height: 1.69;
      margin-top: 40px;
  }
}

/* v2h用 */
/* @media screen and (min-width: 768px) {
    .fs-body-category-v2h .category_title{
        height: 320px;
    }
    .fs-body-category-v2h .category_title .img {
        width: 65.15%;
    }
    .fs-body-category-v2h .category_title .text_wrap {
        padding: 30px 68px 30px 0;
        width: auto;
    }
} */

/* -----------------------------------------------
reform_point_wrap
----------------------------------------------- */
.reform_point_wrap {
  background-color: #E8F6FB;
}

.conditions + .reform_point_wrap {
    margin-top: 0;
}

.reform_point_wrap .point_item .heading {
  background-color: #fff;
  display: -webkit-flex;
display: -ms-flexbox;
display: flex;
-webkit-justify-content: flex-start;
-ms-flex-pack: start;
justify-content: flex-start;
-webkit-align-items: center;
-ms-flex-align: center;
align-items: center;
}

.reform_point_wrap .point_item .heading span {
  background-color: #E8F6FB;
  color: #009CD0;
  border-radius: 50%;
  text-align: center;
  font-weight: bold;
  font-family: 'Inter', sans-serif;
}

.reform_point_wrap .point_item .heading strong {
  font-weight: bold;
  flex: 1;
}

.reform_point_wrap .point_item .text {
  background-color: #fff;
}

.reform_point_wrap .point_item .text p {
  font-weight: 500;
}

.reform_point_wrap p.att {
  font-weight: 300;
}

@media screen and (max-width: 767px) {
  .reform_point_wrap {
      margin-top: 50px;
      padding-bottom: 30px;
  }

  .reform_point_wrap .head_wrap {
      width: 102%;
      padding-top: 71px;
  }

  .reform_point_wrap .point_item .heading {
      grid-area: heading;
      padding: 20px 5.79% 20px;
      border-radius: 8px 8px 0 0;
  }

  .reform_point_wrap .point_item .heading span {
      width: 56px;
      height: 56px;
      line-height: 56px;
      font-size: 34px;
      margin-right: 14px;
  }

  .reform_point_wrap .point_item .heading strong {
      font-size: 2rem;
      line-height: 1.4;
  }
  
  .reform_point_wrap .point_item .img img {
      height: auto;
      width: 100%;
  }

  .reform_point_wrap .point_item .text {
      padding: 20px 5.79% 30px;
      border-radius: 0 0 8px 8px;
  }

  .reform_point_wrap .point_item .text p {
      font-size: 1.4rem;
      line-height: 1.85;
  }

  .reform_point_wrap p.att {
      margin-top: 60px;
      font-size: 1.4rem;
      line-height: 1.85;
  }

  .reform_point_wrap .slick-track {
      display: -webkit-flex;
      display: -ms-flexbox;
      display: flex;
      -webkit-align-items: stretch;
      -ms-flex-align: stretch;
      align-items: stretch;
  }

  .reform_point_wrap .slick-slide {
      height: auto !important;
      background-color: #fff;
      border-radius: 8px;
  }

  .reform_point_wrap .slick-prev {
      width: 50px;
      height: 50px;
      z-index: 1;
      left: -15px;
  }
  
  .reform_point_wrap .slick-next {
      width: 50px;
      height: 50px;
      z-index: 1;
      right: -15px;
  }

  .reform_point_wrap .slick-prev:before {
      background-image: url(../img/top/mv_arrow_prev.svg);
  }
  
  .reform_point_wrap .slick-next:before {
      background-image: url(../img/top/mv_arrow_next.svg);
  }
  
  .reform_point_wrap .slick-prev:before,
  .reform_point_wrap .slick-next:before {
      content: '';
      display: inline-block;
      background-size: 100%;
      background-repeat: no-repeat;
      background-position: center;
      width: 50px;
      height: 50px;
  }

  .reform_point_wrap .slick-dots {
      bottom: -32px;
  }
  
  .reform_point_wrap .slick-dots li {
      display: inline-block;
      width: 10px;
      height: 10px;
      margin: 0 5px;
  }
  
  .reform_point_wrap .slick-dots li button {
      width: 10px;
      height: 10px;
  }
  
  .reform_point_wrap .slick-dots li button:before {
      width: 10px;
      height: 10px;
  }
  
  .reform_point_wrap .slick-dots button::before {
      opacity: 1;
      content: '';
      background: #E5E5E5;
      border-radius: 50%;
  }
  
  .reform_point_wrap .slick-dots .slick-active button::before {
      background: #009CD0;
      opacity: 1;
  }

  .reform_point_wrap .point_item .text ul.att_text {
    margin-top: 10px;
  }
  .reform_point_wrap .point_item .text ul.att_text li {
    font-size: 12px;
    line-height: 1.83;
    letter-spacing: 0;
    text-indent: -1em;
    padding-left: 1em;
  }
}

@media screen and (min-width: 768px) {
  .reform_point_wrap {
      margin-top: 60px;
      padding-bottom: 60px;
  }

  .reform_point_wrap .head_wrap {
      padding-top: 85px;
  }

  .reform_point_wrap .head_wrap h2 {
      margin-bottom: 40px;
  }

  .reform_point_wrap .point_item {
      display: grid; 
      grid-auto-flow: column dense; 
      grid-template-columns: 54.68% 45.3%; 
      grid-template-rows: auto 1fr; 
      gap: 0px 0px; 
      grid-template-areas: 
          "heading img"
          "text img"; 
  }

  .reform_point_wrap .point_item:not(:first-child) {
      margin-top: 40px;
  }

  .reform_point_wrap .point_item .heading {
      grid-area: heading;
      padding: 40px 7.14% 28px;
      border-radius: 8px 0 0 0;
  }

  .reform_point_wrap .point_item .heading span {
      width: 54px;
      height: 54px;
      line-height: 53px;
      font-size: 30px;
      margin-right: 16px;
  }

  .reform_point_wrap .point_item .heading strong {
      font-size: 24px;
      line-height: 1.5;
  }

  .reform_point_wrap .point_item .img {
      grid-area: img;
      background-color: #fff;
      border-radius: 0 8px 8px 0;
      display: -webkit-flex;
      display: flex;
      -webkit-justify-content: flex-end;
      justify-content: flex-end;
      -webkit-align-items: center;
      align-items: center;
  }
  
  .reform_point_wrap .point_item .img img {
      border-radius: 0 8px 8px 0;
      /* height: 100%;
      width: auto;
      object-fit: cover;
      object-position: left top; */
  }

  .reform_point_wrap .point_item .text {
      grid-area: text;
      padding: 0 7.14% 47px;
      border-radius: 0 0 0 8px;
  }

  .reform_point_wrap .point_item .text p {
      font-size: 16px;
      line-height: 2;
  }

  .reform_point_wrap p.att {
      margin-top: 50px;
      font-size: 16px;
      line-height: 1.62;
  }

  .reform_point_wrap .point_item .text ul.att_text {
    margin-top: 10px;
  }
  .reform_point_wrap .point_item .text ul.att_text li {
    font-size: 12px;
    line-height: 1.83;
    letter-spacing: 0;
    text-indent: -1em;
    padding-left: 1em;
  }
}

/* -----------------------------------------------
reason_wrap
----------------------------------------------- */
@media screen and (max-width: 767px) {
    .reason_wrap {
        margin-top: 69px;
    }

    .conditions + .reason_wrap {
        margin-top: 0;
    }
}

@media screen and (min-width: 768px) {
    .reason_wrap {
        margin-top: 120px;
    }

    .conditions + .reason_wrap {
        margin-top: 0;
    }
}

/* -----------------------------------------------
contact_wrap
----------------------------------------------- */


@media screen and (max-width: 767px) {
    .contact_wrap {
        margin-top: 123px;
    }
}

@media screen and (min-width: 768px) {
    .contact_wrap {
        margin-top: 161px;
    }
}

/* -----------------------------------------------
rec-serv
----------------------------------------------- */
@media screen and (max-width: 767px) {
    .rec-serv {
        margin-top: 40px;
    }
    .conditions + .rec-serv {
        margin-top: 0;
    }
}

@media screen and (min-width: 768px) {
    .rec-serv {
        margin-top: 76px;
    }
    .conditions + .rec-serv {
        margin-top: 0;
    }
}

/* -----------------------------------------------
cat_section
----------------------------------------------- */
@media screen and (max-width: 767px) {
    .cat_section {
        padding-bottom: 80px;
    }
}

@media screen and (min-width: 768px) {
    .cat_section {
        padding-bottom: 184px;
    }
}

/* -----------------------------------------------
campaign
----------------------------------------------- */
section.campaign {
    background-color: #FFFAC7;
    /* margin-top: 50px; */
}

.campaign_wrap {
    padding-top: 40px;
    padding-bottom: 40px;
}

/* .campaign_banner {
    margin-bottom: 30px;
} */

.campaign_banner img {
    width: 100%;
}

/* キャンペーン適用条件 */
.conditions {
    background: #FFFAC7;
    margin-top: 50px;
  }
  .conditions .conditions_text {
    background: #fff;
    overflow-y: scroll;
    position: relative;
  }
  .conditions_text ul {
    width: 100%;
  }
  /* .conditions_text ul li:before {
    color: #1899CC;
    content: "●";
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  } */
  .conditions_text {
    box-sizing: border-box;
  }
  /* .conditions_text li {
    padding-left: 1em;
    text-indent: -1em;
  } */
  
  .conditions_text strong {
    display: block;
  }
  
  @media screen and (max-width: 767px) {
    
      .conditions {
        padding-bottom: 30px;
      }
      .conditions_text {
        padding: 22px 20px;
        max-height: 120px;
      }
      /* .conditions_text ul li,
      .conditions_text strong {
        font-size: 1.4rem;
        line-height: 1.68;
        margin-bottom: 1.4em;
      } */
      .conditions_text ul li {
          font-size: 1.4rem;
          line-height: 1.8;
          margin-bottom: 1.4em;
      }
      .conditions_text strong {
          font-size: 1.4rem;
          line-height: 1.8;
      }
    
  }
    
  @media screen and (min-width: 768px) {
      
      .conditions {
        padding-bottom: 80px;
      }
      .conditions_text {
        padding: 37px 60px;
        max-height: 230px;
      }
      /* .conditions_text ul li,
      .conditions_text strong {
        font-size: 14px;
        line-height: 1.48;
        margin-bottom: 1.4em;
      } */
      .conditions_text ul li {
        font-size: 14px;
        line-height: 1.8;
        margin-bottom: 1.4em;
      }
      .conditions_text strong {
        font-size: 14px;
        line-height: 1.8;
      }
    
  }

/* -----------------------------------------------
contact_fx_wrap
----------------------------------------------- */
.contact_fx_wrap {
    background-color: #E8F6FB;
}

.reform_point_wrap + .contact_fx_wrap {
    margin-top: 0;
}

.campaign + .contact_fx_wrap,
.conditions + .contact_fx_wrap {
    margin-top: 0;
}

.contact_fx_inner {
    background-color: #fff;
    border-radius: 8px;
}

.contact_fx_wrap strong {
    display: block;
    text-align: center;
    font-weight: bold;
}

.contact_fx_wrap .contact_fx a {
    background-color: #009CD0;
    display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
}

.contact_fx_wrap .contact_fx span {
    font-weight: bold;
    color: #fff;
}

/* .contact_fx_wrap .contact_fx a:nth-child(2) {
    display: none;
} */

@media screen and (max-width: 767px) {
    .contact_fx_wrap {
        margin-top: 60px;
        padding: 40px 0;
    }

    .contact_fx_inner {
        padding: 35px 5.79% 30px;
    }

    .contact_fx_wrap strong {
        font-size: 24px;
        line-height: 1.5;
    }

    .contact_fx_wrap .contact_fx {
        margin-top: 28px;
    }

    .contact_fx_wrap .contact_fx a {
        width: 100%;
        height: 60px;
        border-radius: 6px;
        position: relative;
    }

    .contact_fx_wrap .contact_fx a:nth-child(2) {
        margin-top: 10px;
    }

    .contact_fx_wrap .contact_fx span::after {
        content: '';
        display: inline-block;
        background-image: url(../img/common/icon_arrow_white.svg);
        background-size: contain;
        background-repeat: no-repeat;
        position: absolute;
        left: 15px;
        top: 50%;
        width: 20px;
        height: 20px;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
    }

    .contact_fx_wrap .contact_fx span {
        font-size: 16px;
    }
}

@media screen and (min-width: 768px) {
    .contact_fx_wrap {
        margin-top: 200px;
        padding: 60px 0;
    }

    .contact_fx_inner {
        padding: 56px 10px 60px;
    }

    .contact_fx_wrap strong {
        font-size: 34px;
    }

    .contact_fx_wrap .contact_fx {
        margin-top: 24px;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-justify-content: center;
        -ms-flex-pack: center;
        justify-content: center;
        -webkit-align-items: center;
        -ms-flex-align: center;
        align-items: center;
    }

    .contact_fx_wrap .contact_fx a {
        width: 36.5%;
        height: 106px;
        border-radius: 8px;
    }

    .contact_fx_wrap .contact_fx a:nth-child(2) {
        margin-left: 3.17%;
    }

    .contact_fx_wrap .contact_fx span {
        font-size: 28px;
        padding-left: 28px;
        position: relative;
    }

    .contact_fx_wrap .contact_fx span::after {
        content: '';
        display: inline-block;
        background-image: url(../img/common/icon_arrow_white.svg);
        background-size: contain;
        background-repeat: no-repeat;
        position: absolute;
        left: 0;
        top: 50%;
        width: 20px;
        height: 20px;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
    }
}