@import url(http://fonts.googleapis.com/earlyaccess/notosansjapanese.css);
.hero {
  background-image: url("/images/entrust/header_bg.png");
  background-position: center;
  background-repeat: no-repeat;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  background-attachment: fixed;
  -webkit-background-size: cover;
          background-size: cover;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  height: 100vh;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .hero {
    height: auto;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
@media screen and (max-width: 479px) {
  .hero {
    height: 100vh;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.hero_heading {
  color: white;
  display: inline-block;
  font-size: 4.8rem;
  font-weight: normal;
  margin-bottom: 3rem;
  position: relative;
}
@media screen and (max-width: 999px) {
  .hero_heading {
    font-size: 4rem;
  }
}
@media screen and (max-width: 767px) {
  .hero_heading {
    font-size: 2rem;
    margin-bottom: .8rem;
  }
}
.hero_lead {
  color: white;
  margin-bottom: 4.4rem;
  font-size: 1.6rem;
}
@media screen and (max-width: 767px) {
  .hero_lead {
    font-size: 1.2rem;
    margin-bottom: 1.6rem;
  }
}
@media screen and (max-width: 767px) {
  .hero_holder {
    margin-top: 7.2rem;
  }
}
@media screen and (max-width: 479px) {
  .hero_holder {
    margin-top: 0;
  }
}
.hero_btn {
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .hero_btn {
    width: 50%;
  }
}
@media screen and (max-width: 479px) {
  .hero_btn {
    width: 100%;
  }
}
.hero_balloon {
  background-image: url("/images/entrust/balloon.png");
  background-position: center;
  background-repeat: no-repeat;
  -webkit-background-size: contain;
          background-size: contain;
  position: absolute;
  top: -8.5rem;
  left: -7.2rem;
  height: 11rem;
  width: 11rem;
}
@media screen and (max-width: 767px) {
  .hero_balloon {
    height: 9rem;
    left: -5.6rem;
    top: -8rem;
    width: 9rem;
  }
}
@media screen and (max-width: 479px) {
  .hero_balloon {
    display: block;
    background: none;
    position: relative;
    top: auto;
    left: auto;
    height: auto;
    width: auto;
  }
}
.hero_balloon_text {
  color: white;
  font-size: 2.4rem;
  left: 0.6rem;
  letter-spacing: -.1rem;
  position: absolute;
  top: 4rem;
  -webkit-transform-origin: 0 0;
      -ms-transform-origin: 0 0;
          transform-origin: 0 0;
  -webkit-transform: rotate(-12deg);
      -ms-transform: rotate(-12deg);
          transform: rotate(-12deg);
}
@media screen and (max-width: 767px) {
  .hero_balloon_text {
    font-size: 1.8rem;
    left: .9rem;
    top: 3.4rem;
  }
}
@media screen and (max-width: 479px) {
  .hero_balloon_text {
    font-size: inherit;
    position: relative;
    top: auto;
    left: auto;
    -webkit-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
            transform: rotate(0deg);
  }
}
.hero_subtitle {
  color: white;
  margin: 0 0 1.5rem 0;
}
.hero_sublead {
  color: white;
  font-size: 1.4rem;
  margin-bottom: 1rem;
}
@media screen and (max-width: 767px) {
  .hero_sublead {
    font-size: 1.2rem;
  }
}
.hero_price {
  display: inline-block;
  color: #eb2256;
  font-family: 'Noto Sans Japanese', serif;
  font-size: 7.2rem;
  line-height: 1;
  position: relative;
}
@media screen and (max-width: 767px) {
  .hero_price {
    margin-bottom: 1rem;
    font-size: 4.8rem;
  }
}
.hero_price > sub {
  bottom: 0;
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: -.1rem;
  margin-left: .4rem;
}
@media screen and (max-width: 767px) {
  .hero_price > sub {
    font-size: 1rem;
  }
}
.hero_price > sup {
  font-size: 1.4rem;
  letter-spacing: -.1rem;
  position: absolute;
  right: 1.2rem;
  top: 4rem;
}
@media screen and (max-width: 767px) {
  .hero_price > sup {
    font-size: 1rem;
    right: .9rem;
    top: 2.8rem;
  }
}
.hero_note {
  color: white;
  font-size: 1.4rem;
  line-height: 3;
}
@media screen and (max-width: 767px) {
  .hero_note {
    font-size: 1rem;
    line-height: 2;
    margin-bottom: 1rem;
  }
}

.recommend_heading {
  margin-bottom: 1.2rem;
}
.recommend_lead {
  margin-bottom: 2.8rem;
}
.recommend_tile {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-bottom: 7rem;
}
@media screen and (max-width: 999px) {
  .recommend_tile {
    margin-bottom: 3.2rem;
  }
}
@media screen and (max-width: 767px) {
  .recommend_tile_item {
    width: 32%;
  }
}
@media screen and (max-width: 479px) {
  .recommend_tile_item {
    margin-bottom: 4%;
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .recommend_tile_item_heading {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 479px) {
  .recommend_tile_item_heading {
    font-size: 1.6rem;
    margin-bottom: .6rem;
  }
}
@media screen and (max-width: 767px) {
  .recommend_tile_item_lead {
    font-size: 1rem;
  }
}
@media screen and (max-width: 479px) {
  .recommend_tile_item_lead {
    font-size: 1.2rem;
  }
}
.recommend_tile img {
  max-width: 19.2rem;
}
@media screen and (max-width: 999px) {
  .recommend_tile img {
    max-width: 59.14468%;
  }
}
.recommend_btn {
  margin: 0 auto;
  width: 50%;
}
@media screen and (max-width: 479px) {
  .recommend_btn {
    width: 100%;
  }
}
.recommend_btn a {
  width: 100%;
}

.feature {
  padding-bottom: 0;
}
.feature_heading {
  margin-bottom: 3rem;
}
.feature_media {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
}
.feature_media_item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  height: 22.8rem;
  margin-right: 4%;
  width: 48%;
}
@media screen and (max-width: 999px) {
  .feature_media_item {
    height: auto;
    margin-bottom: 2%;
    margin-right: 2%;
    width: 49%;
  }
}
@media screen and (max-width: 479px) {
  .feature_media_item {
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-bottom: 6%;
    margin-right: 0;
    text-align: center;
    width: 100%;
  }
}
.feature_media_item:nth-of-type(2n) {
  margin-right: 0;
}
.feature_media_item_thumbnail {
  margin-right: 2rem;
  -webkit-flex-shrink: 0;
      -ms-flex-negative: 0;
          flex-shrink: 0;
  width: 20rem;
}
@media screen and (max-width: 999px) {
  .feature_media_item_thumbnail {
    width: 33.33333%;
  }
}
@media screen and (max-width: 479px) {
  .feature_media_item_thumbnail {
    margin-bottom: 1rem;
    margin-right: 0;
  }
}
.feature_media_item_thumbnail > img {
  width: 100%;
}
.feature_media_item_desc {
  color: #202020;
}
.feature_media_item_desc_title {
  font-size: 1.8rem;
  font-weight: 700;
  margin-bottom: .5rem;
}
.feature_media_item_desc_lead {
  font-size: 1.4rem;
  line-height: 2.4rem;
  letter-spacing: 0;
}

.detail_heading {
  margin-bottom: 3rem;
}
.detail_list_item {
  border: 1px solid #bbbbbb;
  display: table;
  width: 100%;
}
@media screen and (max-width: 479px) {
  .detail_list_item {
    display: block;
  }
}
.detail_list_item:not(:last-of-type) {
  border-bottom: 0;
}
.detail_list_item > dt {
  display: table-cell;
  background-color: #eeeeee;
  border-right: 1px solid #bbbbbb;
  font-size: 1.6rem;
  font-weight: bold;
  height: 6rem;
  padding-left: 2rem;
  text-align: left;
  width: 24%;
  vertical-align: middle;
}
@media screen and (max-width: 767px) {
  .detail_list_item > dt {
    padding-left: 0;
    text-align: center;
  }
}
@media screen and (max-width: 479px) {
  .detail_list_item > dt {
    border-bottom: 1px solid #bbbbbb;
    border-right: 0;
    display: block;
    height: auto;
    padding: 1rem 0;
    width: 100%;
  }
}
.detail_list_item > dd {
  display: table-cell;
  font-size: 1.4rem;
  height: 6rem;
  letter-spacing: 0;
  padding: 1rem;
  text-align: center;
  vertical-align: middle;
  width: 76%;
}
@media screen and (max-width: 479px) {
  .detail_list_item > dd {
    height: auto;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    display: block;
    width: 100%;
  }
}

.question {
  background-color: #efefef;
}
.question_heading {
  color: #228feb;
  letter-spacing: 3px;
  margin-bottom: 2rem;
  text-align: center;
}
.question_lead {
  color: #202020;
  font-size: 1.6;
  line-height: 2;
  margin-bottom: 3rem;
  text-align: center;
}
.question_accordion {
  background-color: white;
  margin: 0 auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.question_accordion_item:not(:last-of-type) {
  margin-bottom: .5rem;
}
.question_accordion_item_title {
  background-color: white;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  color: #228feb;
  cursor: pointer;
  display: block;
  font-size: 1.6rem;
  padding: 1.6rem 2.8rem;
}
@media screen and (max-width: 767px) {
  .question_accordion_item_title {
    font-size: 1.4rem;
  }
}
.question_accordion_item_title:hover {
  background-color: #fdfddc;
  text-decoration: underline;
}
@media screen and (max-width: 999px) {
  .question_accordion_item_title:hover {
    background-color: transparent;
    text-decoration: inherit;
  }
}
.question_accordion_item_toggle {
  display: none;
}
.question_accordion_item_toggle:checked + .question_accordion_item_desc {
  max-height: 100rem;
  opacity: 1;
  padding: 1.6rem 2.8rem;
}
@media screen and (max-width: 767px) {
  .question_accordion_item_toggle:checked + .question_accordion_item_desc {
    padding: 1rem 1.6rem;
  }
}
.question_accordion_item_desc {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 0 2.8rem 0;
  font-size: 1.6rem;
  line-height: 2;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  -webkit-transition: opacity .4s, max-height .4s, padding .4s;
  transition: opacity .4s, max-height .4s, padding .4s;
}
@media screen and (max-width: 767px) {
  .question_accordion_item_desc {
    padding: 0 1.6rem 0;
    font-size: 1.2rem;
    line-height: 2;
  }
}

.flow_heading {
  margin-bottom: 3rem;
}
.flow_step_item {
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #ff5682;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  height: 15.7rem;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 0 4.8rem;
  position: relative;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .flow_step_item {
    padding: 0 2.4rem;
  }
}
@media screen and (max-width: 479px) {
  .flow_step_item {
    padding: 3rem 1.6rem 1.6rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    height: auto;
  }
}
.flow_step_item:not(:last-of-type)::after {
  content: '';
  border-bottom: 35px solid transparent;
  border-left: 55px solid transparent;
  border-right: 55px solid transparent;
  border-top: 35px solid #ff5682;
  bottom: -6.2rem;
  height: 0;
  left: 4.5rem;
  position: absolute;
  width: 0;
  z-index: 1;
}
@media screen and (max-width: 479px) {
  .flow_step_item:not(:last-of-type)::after {
    left: 50%;
    margin-left: -55px;
  }
}
.flow_step_item.purple {
  background-color: #e156ff;
}
.flow_step_item.purple::after {
  border-top-color: #e156ff;
}
.flow_step_item.purple > .flow_step_item_num::before, .flow_step_item.purple > .flow_step_item_num::after {
  color: #e156ff;
}
.flow_step_item.blue {
  background-color: #566eff;
}
.flow_step_item.blue::after {
  border-top-color: #566eff;
}
.flow_step_item.blue > .flow_step_item_num::before, .flow_step_item.blue > .flow_step_item_num::after {
  color: #566eff;
}
.flow_step_item.l-blue {
  background-color: #56b9ff;
}
.flow_step_item.l-blue::after {
  border-top-color: #56b9ff;
}
.flow_step_item.l-blue > .flow_step_item_num::before, .flow_step_item.l-blue > .flow_step_item_num::after {
  color: #56b9ff;
}
.flow_step_item.green {
  background-color: #3be747;
}
.flow_step_item.green::after {
  border-top-color: #3be747;
}
.flow_step_item.green > .flow_step_item_num::before, .flow_step_item.green > .flow_step_item_num::after {
  color: #3be747;
}
.flow_step_item.orange {
  background-color: #ffb556;
}
.flow_step_item.orange::after {
  border-top-color: #ffb556;
}
.flow_step_item.orange > .flow_step_item_num::before, .flow_step_item.orange > .flow_step_item_num::after {
  color: #ffb556;
}
.flow_step_item_num {
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: white;
  border-radius: 50%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 auto;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  height: 10rem;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 10rem;
}
@media screen and (max-width: 767px) {
  .flow_step_item_num {
    height: 8rem;
    width: 8rem;
  }
}
.flow_step_item_num::before {
  color: #ff5682;
  content: 'STEP';
  display: block;
  font-size: 1.8rem;
  line-height: 1;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .flow_step_item_num::before {
    font-size: 1.4rem;
  }
}
.flow_step_item_num::after {
  color: #ff5682;
  content: attr(data-num);
  display: block;
  font-size: 4.8rem;
  font-weight: bold;
  line-height: 1;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .flow_step_item_num::after {
    font-size: 4rem;
  }
}
.flow_step_item_desc {
  color: white;
  -webkit-box-flex: 0;
  -webkit-flex: 0 1 auto;
      -ms-flex: 0 1 auto;
          flex: 0 1 auto;
  width: 65rem;
}
@media screen and (max-width: 999px) {
  .flow_step_item_desc {
    -webkit-box-flex: 1;
    -webkit-flex-grow: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    margin: 0 2%;
  }
}
@media screen and (max-width: 479px) {
  .flow_step_item_desc {
    margin: 4% 0;
    text-align: center;
    width: 100%;
  }
}
.flow_step_item_desc > h3 {
  font-size: 2rem;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .flow_step_item_desc > h3 {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 479px) {
  .flow_step_item_desc > h3 {
    margin-bottom: 1rem;
  }
}
.flow_step_item_desc > p {
  font-size: 1.6rem;
  letter-spacing: 0;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .flow_step_item_desc > p {
    font-size: 1.4rem;
  }
}
.flow_step_item_image {
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 auto;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  height: 10rem;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 10rem;
}
@media screen and (max-width: 767px) {
  .flow_step_item_image {
    height: 8rem;
    width: 8rem;
  }
}
.flow_step_item_image > img {
  width: 100%;
}

.price {
  background-color: #efefef;
  padding-bottom: 6rem;
}
.price_heading {
  margin-bottom: 3rem;
}
.price_lead {
  margin-bottom: 2.4rem;
}
.price_box {
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: white;
  border: 1px solid #202020;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 14.4rem;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 2.4rem;
  margin: 0 auto;
  position: relative;
  width: 100%;
}
.price_catch {
  display: inline-block;
  color: #eb2256;
  font-family: 'Noto Sans Japanese', serif;
  font-size: 7.2rem;
  line-height: 1;
  position: relative;
}
@media screen and (max-width: 479px) {
  .price_catch {
    font-size: 5.6rem;
  }
}
.price_catch > sub {
  bottom: 0;
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: -.1rem;
  margin-left: .4rem;
}
@media screen and (max-width: 479px) {
  .price_catch > sub {
    font-size: 1.2rem;
  }
}
.price_catch > sup {
  font-size: 1.4rem;
  letter-spacing: -.1rem;
  position: absolute;
  right: 1.2rem;
  top: 4rem;
}
@media screen and (max-width: 479px) {
  .price_catch > sup {
    font-size: 1.2rem;
    right: 1rem;
    top: 3rem;
  }
}
.price_note {
  color: #202020;
  font-size: 1.4rem;
  line-height: 3;
  text-align: center;
}
@media screen and (max-width: 479px) {
  .price_note {
    font-size: 1.2rem;
  }
}
