@charset "UTF-8";
@charaset utf-8;
/* ========================================================
page_top.css - トップページ用カスタムスタイル
======================================================== */
/* colorXX - サイト共通色 */
/* mainvisual - メインビジュアルの設定
-------------------------------------------------------- */
/* layout */
.mainvisual {
  background: url(../../img/top/bg_mainvisual_sp@3x.jpg) no-repeat 100% 0;
  background-size: cover;
  position: relative;
  height: 370px;
}

/* theme */
.mainvisual-image {
  height: 100%;
}

.mainvisual-logo {
  position: absolute;
  top: 1rem;
}

.mainvisual-logo img {
  width: 100px;
  height: auto;
}

.mainvisual-catch-01,
.mainvisual-catch-02 {
  position: absolute;
}

.mainvisual-catch-01 img {
  width: 70%;
  height: auto;
}

.mainvisual-catch-02 img {
  width: 70%;
  height: auto;
}

/* sp */
@media screen and (max-width: 767px) {
  .mainvisual-logo {
    left: 1rem;
  }
  .mainvisual-catch-01 {
    top: 5rem;
    left: 1rem;
  }
  .mainvisual-catch-02 {
    bottom: 2rem;
    left: 2rem;
  }
}

/* sp */
@media screen and (max-width: 767px) and (orientation: landscape) {
  .mainvisual-catch-02 {
    display: none;
  }
}

/* pc */
@media screen and (min-width: 768px) {
  .mainvisual {
    background: url(../../img/top/bg_mainvisual_pc@2x.jpg) no-repeat 0% 0%;
    background-size: cover;
    height: 700px;
  }
  .mainvisual-logo {
    right: 1rem;
  }
  .mainvisual-logo img {
    width: 160px;
  }
  .mainvisual-catch-01 {
    left: 7rem;
    top: 13rem;
  }
  .mainvisual-catch-02 {
    left: 5rem;
    top: 40rem;
  }
  .mainvisual-catch-01 img {
    width: 460px;
  }
  .mainvisual-catch-02 img {
    width: 507px;
  }
}

/* company
-------------------------------------------------------- */
.company img {
  width: 100%;
  height: auto;
}

/* category-ttl
-------------------------------------------------------- */
.category-ttl {
  line-height: 1.4;
  margin-top: 4rem;
}

.category-ttl-txt {
  position: relative;
}

.category-ttl-txt span {
  display: block;
  margin: 0.5rem 0;
}

.category-ttl-lead {
  background-color: rgba(255, 255, 255, 0.3);
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 2rem;
}

/* sp */
@media screen and (max-width: 767px) {
  .category-ttl-txt {
    margin-top: -15rem;
    position: relative;
    padding: 1rem 0 0.5rem 0;
  }
  .category-ttl-lead {
    margin: 1.5rem;
    font-size: 1.4rem;
  }
}

/* sp */
/* pc */
@media screen and (min-width: 768px) {
  .category-ttl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    height: 455px;
  }
  .category-ttl img {
    width: 546px;
    height: auto;
  }
  .category-ttl-txt {
    width: 557px;
    height: 455px;
  }
  .category-ttl-txt span {
    margin: 3rem 0;
  }
  .category-ttl-lead {
    position: absolute;
    bottom: 2.5rem;
    left: 2.5rem;
    width: 500px;
  }
}

/* btn-entry
-------------------------------------------------------- */
.btn-entry img {
  width: 80%;
  height: auto;
}

/* pc */
@media screen and (min-width: 768px) {
  .btn-entry img {
    margin-bottom: 4rem;
    margin-left: -6rem;
    width: 510px;
  }
}

/* agent
-------------------------------------------------------- */
.worry {
  line-height: 1.4;
}

.worry img {
  margin-bottom: 4rem;
  width: 80%;
  height: auto;
}

/* pc */
@media screen and (min-width: 768px) {
  .worry img {
    width: 100%;
  }
}

/* flow
-------------------------------------------------------- */
.flow-step {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.flow-step-item {
  line-height: 1.4;
  width: 300px;
}

.flow-step-ttl {
  color: #be8f5c;
  display: block;
  font-size: 2rem;
  padding-bottom: 1rem;
}

.flow-step-item dd {
  font-size: 1.2rem;
  letter-spacing: 0;
}

.flow-step-item img {
  margin-bottom: 1rem;
  width: 121px;
  height: auto;
}

/* sp */
@media screen and (max-width: 767px) {
  .flow-step-item {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
  .flow-step-item dd {
    padding-left: 2rem;
  }
}

/* pc */
@media screen and (min-width: 768px) {
  .flow {
    position: relative;
  }
  .flow .category-ttl {
    position: absolute;
    right: 0;
  }
  .flow-step {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    padding-top: 455px;
  }
  .flow-step-item {
    text-align: center;
    width: 20%;
  }
}

/* proof
-------------------------------------------------------- */
.proof-count {
  text-align: center;
}

.proof-count img {
  margin: 0 auto 2rem auto;
  width: 200px;
  height: auto;
}

.proof-example-item {
  margin-bottom: 2rem;
}

.proof-example-item:first-child {
  margin-bottom: 0;
}

.proof-example-item .before,
.proof-example-item .after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
}

.proof-example-item .before,
.proof-example-item .after {
  line-height: 1.4;
  position: relative;
  margin-bottom: 1rem;
  padding: 2rem;
}

.proof-example-item .before {
  border: 1px solid #adacac;
  color: #5e5d5d;
}

.proof-example-item .before:before {
  content: " ";
  background: url(../../img/top/txt_before@3x.png) no-repeat 0% 0%;
  background-size: 100%;
  width: 50px;
  height: 73px;
  position: absolute;
  top: 0;
  right: 1rem;
}

.proof-example-item .before:after {
  content: " ";
  background: url(../../img/top/icon_arrow_down@3x.png) no-repeat 0% 0%;
  background-size: 100%;
  width: 14px;
  height: 180px;
  position: absolute;
  top: 3rem;
  right: 1rem;
}

.proof-example-item .after {
  border: 1px solid #be8f5c;
  color: #8b634c;
}

.proof-example-item .after:before {
  content: " ";
  background: url(../../img/top/txt_after@3x.png) no-repeat 0% 0%;
  background-size: 100%;
  width: 40px;
  height: 73px;
  position: absolute;
  bottom: -3rem;
  right: 1rem;
}

.proof-example-item .before img,
.proof-example-item .after img {
  margin-right: 2rem;
  width: 60px;
  height: auto;
}

.proof-example-item .arrow {
  display: none;
}

.proof-example-item .arrow img {
  width: 218px;
  height: auto;
}

.proof-example-ttl img {
  width: 70px;
  height: auto;
}

.proof-example-ttl {
  display: none;
}

/* sp */
@media screen and (max-width: 767px) and (orientation: landscape) {
  .proof-count {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: distribute;
        justify-content: space-around;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
}

/* pc */
@media screen and (min-width: 768px) {
  .proof-count,
  .proof-example-item {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: distribute;
        justify-content: space-around;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
  .proof-count img {
    width: 247px;
  }
  .proof-example-item .before,
  .proof-example-item .after {
    width: 300px;
  }
  .proof-example-ttl {
    font-size: 2rem;
  }
  .proof-example-item .arrow {
    display: block;
  }
  .proof-example-item .before:before,
  .proof-example-item .before:after,
  .proof-example-item .after:before {
    display: none;
  }
}
