@charset "UTF-8";
/* sp */
@media (max-width: 767px) { .ds-pc { display: none; } }

@media (max-width: 767px) { h1, h2, h3, h4, h5, h6 { letter-spacing: 0; } }

/*==============================================================================
fv
============================================================================= */
/* sp */
@media (max-width: 767px) { .fv__ttl { margin: 0 -0.2rem; }
  .fv__note { margin: .2rem 0 0; color: #fff; font-size: .2rem; }
  .fv-bottom { padding: 1.1rem 0 1rem; background-color: #3db7ee; }
  .fv-bottom .fv__note { text-align: center; }
  .fv-bottom__txt01 { position: absolute; width: 7.5rem; top: -1.4rem; left: 50%; transform: translateX(-50%); } }

/* pc */
@media (min-width: 768px) { .fv__bg { padding: 35px 0 50px; background: url("../img/top/fv_bg01.jpg") no-repeat 50% 0/cover; }
  .fv__ttl { width: 842px; }
  .fv__note { margin: 25px 0 0; font-size: 14px; text-shadow: 1px 1px 0 #FFF, -1px -1px 0 #FFF, -1px 1px 0 #FFF, 1px -1px 0 #FFF, 0px 1px 0 #FFF, -1px 0 #FFF, -1px 0 0 #FFF, 1px 0 0 #FFF; }
  .fv-bottom { background-color: #000790; }
  .fv-bottom__txt01 { position: absolute; width: 232px; top: -44px; left: -50px; }
  .fv-bottom__txt02 { width: 812px; margin-left: 168px; }
  .fv-bottom__txt02__info { width: 812px; margin: auto; }
  }

/*==============================================================================
about01
============================================================================= */
.about01__bg { position: relative; padding: .5rem 0 0; background: #ededed url("../img/top/about01_bg01_sp.jpg") no-repeat center top/7.5rem; }
.about01__bg__info { position: relative; padding: .5rem 0 0; background: #ededed no-repeat center top/7.5rem;background-image:none; }

.about01::after { content: ""; position: absolute; width: 0; height: 0; left: 50%; transform: translateX(-50%); border-style: solid; border-width: .7rem 3.75rem; border-color: #ededed transparent transparent transparent; z-index: 2; }

.about01__ttl { width: 5.62rem; }

.about01__lead01 { margin: .4rem 0 0; border: solid #0066fb; border-width: .05rem 0; background-color: #fff; color: #0066fb; font-size: .5rem; font-weight: bold; text-align: center; line-height: 1.7; }

.about01__desc { position: relative; margin: .2rem 0 0; }

.about01__txt01 { border-radius: 10px; overflow: hidden; }

.about01__txt02 { width: 3.8rem; position: absolute; left: 3.15rem; bottom: .3rem; color: #333; font-size: .26rem; }

.about01__txt02 .size { font-size: .1rem; position: relative; top: -.04rem; }

.about01__note { margin: .1rem 0 0; font-size: .24rem; line-height: 1.75; }

.about01__bottom { margin: .65rem -0.2rem 0; padding: .35rem 0 .3rem; background: url("../img/top/about01_bg02_sp.jpg") no-repeat 50% 0/contain; }

.about01__lead02 { color: #333; font-size: .38rem; font-weight: bold; text-align: center; line-height: 1.3; }

.about01__lead02 .size { color: #0066fb; font-size: .48rem; }

.about01__txt03 { margin: .8rem 0 0 2.85rem; font-size: .32rem; line-height: 1.4; }

.about01__txt04 { margin: .1rem 0 0 2.85rem; font-size: 0; }

.about01__txt04 .txt-bg { display: inline-block; margin: 0 0 0 -3px; padding: 4px; background-color: #fcff00; font-size: .36rem; font-weight: bold; line-height: 1.1; }

/* pc */
@media (min-width: 768px) { .about01__bg { padding: 58px 0 20px; background: #ededed url("../img/top/about01_bg01_pc.jpg") no-repeat center top; }
  .about01__bg__info { padding: 58px 0 20px; background: #ededed url("../img/top/about01_bg01_pc.jpg") no-repeat center top; background-image:none; }
  .about01::after { border-width: 60px 320px; }
  .about01__ttl { width: 677px; }
  .about01__lead01 { margin: 40px 0 0; border-width: 5px 0; font-size: 40px; line-height: 1.7; }
  .about01__desc { margin: 20px 0 0; }
  .about01__txt01 { border-radius: 10px; overflow: hidden; }
  .about01__txt02 { width: auto; left: 320px; bottom: 30px; font-size: 22px; line-height: 1.9; }
  .about01__txt02 .size { top: -8px; font-size: 15px; }
  .about01__note { margin: 5px 0 0; font-size: 14px; text-align: center; }
  .about01__bottom { margin: 20px 0 0 -37px; padding: 45px 0 24px 172px; background: url("../img/top/about01_bg02_pc.jpg") no-repeat center top; }
  .about01__lead02 { font-size: 24px; line-height: 1; }
  .about01__lead02 .size { font-size: 36px; }
  .about01__txt03 { margin: 55px 0 0 85px; font-size: 24px; }
  .about01__txt03 .txt-bg { display: inline-block; margin: 2px 0 0 -8px; padding: 8px 8px; background-color: #fcff00; font-size: 32px; font-weight: bold; line-height: 1; } }

/*============================================================================== about02 ============================================================================= */
.about02__bg { padding: .4rem 0; background-color: #0066fb; }

.about02__ttl { margin: 0 -0.2rem; }

.about02__desc { padding: .54rem .2rem .2rem; background-color: #e9efff; border-radius: .2rem; }

.about02__lead { width: 6.53rem; margin: 0 auto; }

.about02__table { margin: .1rem 0 0; }

.about02__txt01 { position: relative; margin: .3rem 0 0; background-color: #ff3600; border-radius: .8rem; color: #fff; font-size: .36rem; font-weight: bold; text-align: center; line-height: .8rem; }

.about02__txt01::before { content: ""; position: absolute; width: 0; height: 0; right: 80px; top: -0.4rem; border-style: solid; border-width: .2rem; border-color: transparent transparent #ff3600 transparent; }

.about02__txt01 .asterisk { position: absolute; top: -0.05rem; right: .5rem; font-size: .18rem; }

.about02__note { margin: .2rem 0 0; color: #333; font-size: .2rem; text-align: center; }

.about02__item02 { margin: .5rem 0 0; padding: .3rem 0; background-color: #fff; border-radius: .2rem; }

.about02__txt02 { position: relative; font-size: .34rem; font-weight: bold; text-align: center; }

.about02__txt02::before, .about02__txt02::after { content: ""; position: absolute; width: .8rem; height: .08rem; top: 50%; transform: translateY(-50%); border-radius: .08rem; background-color: #d2deff; }

.about02__txt02::before { left: .25rem; }

.about02__txt02::after { right: .25rem; }

.about02__txt03 { position: relative; margin: .1rem 0 0 1.95rem; font-size: .3rem; }

.about02__txt03::before { content: ""; position: absolute; width: .98rem; height: .98rem; top: 50%; left: -1.4rem; transform: translateY(-50%); background: url("../img/top/about02_item01.png") no-repeat 50% 0/cover; }

.about02__txt03 .asterisk { position: relative; top: -0.08rem; font-size: .18rem; }

/* pc */
@media (min-width: 768px) { .about02 { overflow: hidden; }
  .about02__bg { padding: 0 0 90px; }
  .about02__ttl { width: 1606px; margin: 0 -313px; }
  .about02__desc { padding: 30px 40px 55px 45px; border-radius: 20px; }
  .about02__lead { width: 725px; }
  .about02__flex { display: flex; justify-content: space-between; margin: 10px 0 0; }
  .about02__item01 { width: 520px; }
  .about02__table { width: 540px; margin: 0 0 0 -18px; }
  .about02__txt01 { margin: 24px 0 0; border-radius: 60px; font-size: 28px; line-height: 60px; }
  .about02__txt01::before { right: 80px; top: -32px; border-width: 16px; }
  .about02__txt01 .asterisk { top: -5px; right: 40px; font-size: 14px; }
  .about02__note { margin: 20px 0 0; font-size: 16px; text-align: center; }
  .about02__item02 { width: 350px; height: 390px; margin: 48px 0 0; padding: 40px 0 30px; border-radius: 20px; }
  .about02__txt02 { font-size: 24px; }
  .about02__txt02::before, .about02__txt02::after { content: none; }
  .about02__txt03 { position: relative; margin: 140px 0 0; font-size: 20px; text-align: center; line-height: 1.4; }
  .about02__txt03::before { width: 93px; height: 93px; top: -110px; left: 50%; transform: translateX(-50%); }
  .about02__txt03 .asterisk { position: relative; top: -5px; font-size: 14px; } }

/*==============================================================================
price01
============================================================================= */
.price01 { position: relative; }

.price01::after { content: ""; position: absolute; width: 7.5rem; height: .85rem; bottom: -0.85rem; left: 0; background: url("../img/top/price01_item05_sp.png") no-repeat 50% 0/cover; z-index: 3; }

.price01__bg { position: relative; overflow: hidden; padding: .95rem 0 .8rem; background-color: #d9d9d9; }

.price01__ttl { font-size: .5rem; color: #0066fb; text-align: center; line-height: 1.2; text-shadow: .05rem .05rem 0 #c9c9c9; }

.price01__ttl .space { letter-spacing: -0.02em; }

.price01__ttl .dot { position: relative; }

.price01__ttl .dot::after { content: "・"; position: absolute; top: -0.5rem; left: 0; color: #ff3600; text-shadow: none; }

.price01__ttl .size { color: #000; font-size: .9rem; letter-spacing: -0.04em; }

.price01__ttl::before { content: ""; position: absolute; width: .89rem; height: 1.2rem; top: .48rem; left: -.2rem; background: url(../img/top/price01_item01.png) no-repeat 50% 0/cover; z-index: 2; }

.price01__ttl::after { content: ""; position: absolute; width: 1rem; height: 1.26rem; top: 0; right: -.2rem; background: url(../img/top/price01_item01.png) no-repeat 50% 0/cover; transform: scale(-1, 1); z-index: 2; }

.price01__txt01 { position: relative; margin: .75rem 0 0; padding: .7rem .35rem .35rem; background-color: #fff; border-radius: .1rem; font-size: .36rem; font-weight: bold; line-height: 1.8; box-shadow: 0 .2rem .4rem #979797; }

.price01__txt01 .subtxt { position: absolute; width: 3.27rem; left: 50%; top: -0.48rem; transform: translateX(-50%); }

.price01__txt01 .color { margin: 0 .05rem 0 -0.1rem; padding: .1rem; background-color: #fcff00; color: #0057d7; }

.price01__txt01::after { content: ""; position: absolute; width: 2.04rem; height: 3.83rem; bottom: 0; right: -0.8rem; background: url("../img/top/price01_person01.png") no-repeat 50% 0/cover; }

.price01__flex { display: flex; justify-content: space-between; margin: .6rem 0 0; letter-spacing: -0.02em; }

.price01__item01 { position: relative; display: flex; align-items: center; justify-content: center; width: 2.7rem; background-color: #fff; border: .1rem solid #cbcbcb; border-radius: .1rem; }

.price01__item01::before { content: ""; position: absolute; width: .91rem; height: .83rem; top: .7rem; left: 50%; transform: translateX(-50%); background: url("../img/top/price01_item03.png") no-repeat 50% 0/cover; }

.price01__item01 .txt { color: #333; font-size: .55rem; font-weight: bold; }

.price01__item02 { position: relative; width: 3.6rem; }

.price01__item02::before, .price01__item02::after { content: ""; position: absolute; width: .5rem; height: .13rem; top: 45.5%; left: -0.65rem; background-color: #404040; }

.price01__item02::after { top: 51%; }

.price01__item02 .parts { position: relative; display: flex; align-items: center; justify-content: center; height: 1rem; background-color: #404040; border-radius: .1rem; }

.price01__item02 .parts:not(:first-of-type) { position: relative; margin: .12rem 0 0; }

.price01__item02 .parts:not(:first-of-type)::after { content: ""; position: absolute; width: .45rem; height: .45rem; top: -0.3rem; left: 50%; transform: translateX(-50%); background: url("../img/top/price01_item04.png") no-repeat 50% 0/cover; }

.price01__item02 .parts .txt { color: #fff; font-size: .48rem; font-weight: bold; }

.price01__item02 .parts .txt .size { font-size: .33rem; }

.price02__bg { padding: 1.15rem 0 1rem; background: url("../img/top/price02_bg01.png"); }

.price02__list { margin: .4rem 0 0; font-weight: bold; }

.price02__item { padding: .08rem; background-color: #fff; border-radius: .1rem; }

.price02__item:not(:first-of-type) { margin: .3rem 0 0; }

.price02__item__ttl { position: relative; padding: .3rem .3rem 0; font-size: .5rem; line-height: 1.3; letter-spacing: 0; margin-bottom: .2rem; }

.price02__item__ttl .size { display: block; margin-bottom: .15rem; color: #999; font-size: .24rem; line-height: 1; letter-spacing: -0.04em; }

.price02__item__ttl .color { color: #005ce3; }

.price02__item__ttl::after { content: ""; position: absolute; width: 2.47rem; height: 2.1rem; bottom: -0.2rem; right: .2rem; background: url("../img/top/price02_person01_sp.png") no-repeat 50% 0/cover; }

.price02__item:nth-of-type(2) .price02__item__ttl::after { height: 2.53rem; height: 2.17rem; background-image: url("../img/top/price02_person02_sp.png"); }

.price02__item:nth-of-type(3) .price02__item__ttl::after { width: 2.13rem; height: 2.22rem; background-image: url("../img/top/price02_person03_sp.png"); }

.price02__item:nth-of-type(3) .price02__item__parts02 { padding: .28rem .2rem .5rem; }

.price02__item__flex { display: flex; align-items: flex-end; text-align: center; }

.price02__item__parts01 { position: relative; width: 3.13rem; padding: .2rem; background-color: #8c8c8c; }

.price02__item__parts01::after { content: ""; position: absolute; width: .66rem; height: .91rem; top: .75rem; right: -.7rem; transform: translateX(-50%); background: url(../img/top/price02_item01.png) no-repeat 50% 0/cover; z-index: 2; }

.price02__item__parts01 .lead { background-color: #fff; border-radius: .2rem; color: #8c8c8c; font-size: .28rem; }

.price02__item__parts01 .txt { margin: .15rem 0 0 .1rem; color: #fff; font-size: .26rem; line-height: 1.4; text-align: left; }

.price02__item__parts01 .txt .float { position: absolute; right: .47rem; bottom: .2rem; height: 1.1rem; -ms-writing-mode: tb-rl; writing-mode: vertical-rl; -webkit-text-orientation: upright; text-orientation: upright; letter-spacing: .04em; }

.price02__item__parts02 { position: relative; width: calc( 7.1rem - 3.13rem); padding: .3rem .2rem; background: linear-gradient(135deg, #ff1200, #ff6600); }

.price02__item__parts02::after { content: ""; position: absolute; width: 0; height: 0; top: 0; left: -0.4rem; border-width: .1rem .2rem; border-style: solid; border-color: transparent #870000 #870000 transparent; }

.price02__item__parts02 .lead { background-color: #fff; border-radius: .2rem; color: #ff3600; font-size: .28rem; }

.price02__item__parts02 .txt { width: 1.52rem; margin: .1rem auto 0; font-size: 0; }

.price02__item__parts02 .txt02 { margin: .35rem 0 0 .18rem; font-size: 0; }

.price02__txt { margin: .2rem 0 .1rem; background-color: #fff; border: .04rem solid #d4d4d4; border-radius: .5rem; color: #8c8c8c; font-size: .3rem; text-align: center; }

.price02__note { margin: .1rem 0 0; font-size: .24rem; font-weight: normal; line-height: 1.75; }

/* pc */
@media (min-width: 768px) { .price01::after { content: ""; position: absolute; width: 1523px; height: 570px; bottom: -570px; left: 50%; transform: translateX(-50%); background: url(../img/top/price01_item05_pc.png) no-repeat 50% 0/cover; z-index: 1; }
  .price01__bg { position: relative; padding: 80px 0 70px; }
  .price01 .inner::before { content: ""; position: absolute; width: 241px; height: 549px; bottom: -70px; left: -200px; background: url("../img/top/price01_person02.jpg") no-repeat 50% 0/cover; }
  .price01__ttl { font-size: 50px; text-shadow: 5px 5px 0 #c9c9c9; }
  .price01__ttl .dot::after { position: absolute; top: -45px; left: 50%; transform: translateX(-50%); }
  .price01__ttl .size { font-size: 90px; }
  .price01__ttl::before { content: ""; position: absolute; width: 109px; height: 120px; top: 45px; left: 95px; background: url(../img/top/price01_item01.png) no-repeat 50% 0/cover; z-index: 2; }
  .price01__ttl::after { content: ""; position: absolute; width: 109px; height: 120px; top: 0; right: 128px; background: url(../img/top/price01_item01.png) no-repeat 50% 0/cover; z-index: 2; transform: scale(-1, 1); }
  .price01__txt01 { width: 1012px; margin: 55px 0 0; padding: 80px 0 35px; position: relative; left: 50%; transform: translateX(-50%); border-radius: 10px; font-size: 30px; text-align: center; line-height: 1.6; }
  .price01__txt01 .subtxt { position: absolute; width: 258px; top: -20px; }
  .price01__txt01 .color { margin: 0 0 0 -40px; padding: 5px; font-size: 40px; }
  .price01__txt01 .color .size { font-size: 30px; }
  .price01__txt01::after { width: 174px; height: 299px; right: -70px; }
  .price01__flex { margin: 55px 0 0; }
  .price01__item01 { width: 215px; border: 10px solid #cbcbcb; border-radius: 10px; }
  .price01__item01::before { width: 78px; height: 71px; top: -32px; left: 50%; }
  .price01__item01 .txt { font-size: 32px; }
  .price01__item02 { display: flex; width: 720px; margin: 0 0 0 60px; }
  .price01__item02::before, .price01__item02::after { width: 43px; height: 12px; top: 41%; left: -51px; }
  .price01__item02::after { top: 53%; }
  .price01__item02 .parts { width: 180px; height: 170px; border-radius: 10px; }
  .price01__item02 .parts:not(:first-of-type) { margin: 0 0 0 14px; }
  .price01__item02 .parts:not(:first-of-type)::after { width: 39px; height: 39px; top: 50%; left: -26px; transform: translateY(-50%); }
  .price01__item02 .parts .txt { font-size: 32px; text-align: center; line-height: 1.1; }
  .price01__item02 .parts .txt .size { font-size: 26px; vertical-align: top; }
  .price02 { position: relative; }
  .price02__bg { position: relative; padding: 108px 0 90px; }
  .price02__ttl { position: relative; width: 968px; margin: 0 auto; z-index: 2; }
  .price02__list { position: relative; margin: 50px 0 0; z-index: 2; }
  .price02__item { padding: 8px; border-radius: 10px; }
  .price02__item:not(:first-of-type) { margin: 35px 0 0; }
  .price02__item__ttl { padding: 30px 30px 0; font-size: 50px; margin-bottom: 15px; }
  .price02__item__ttl .size { margin-bottom: 10px; font-size: 24px; }
  .price02__item__ttl::after { width: 263px; height: 180px; background: url("../img/top/price02_person01.png") no-repeat 50% 0/cover; background-size: 100%; bottom: -20px; right: -16px; }
  .price02__item:nth-of-type(2) .price02__item__ttl::after { width: 263px; height: 181px; background: url("../img/top/price02_person02.png") no-repeat 50% 0/cover; background-size: 100%; }
  .price02__item:nth-of-type(3) .price02__item__ttl::after { width: 186px; height: 170px; background: url("../img/top/price02_person03.png") no-repeat 50% 0/cover; background-size: 100%; right: -20px; bottom: -25px; }
  .price02__item__parts01 { height: 150px; display: flex; width: 514px; padding: 28px; }
  .price02__item__parts01::after { width: 60px; height: 79px; top: 50%; right: -38px; transform: translateY(-50%); }
  .price02__item__parts01 .lead { width: 200px; display: flex; align-items: center; justify-content: center; border-radius: 20px; font-size: 24px; }
  .price02__item__parts01 .txt { margin: 0 0 0 32px; font-size: 24px; }
  .price02__item__parts01 .txt .float { position: absolute; right: 45px; bottom: 32px; height: 85px; -ms-writing-mode: tb-rl; writing-mode: vertical-rl; -webkit-text-orientation: upright; text-orientation: upright; font-size: 20px; letter-spacing: .06em; }
  .price02__item__parts02 { height: 170px; display: flex; align-items: center; justify-content: space-between; width: calc( 100% - 514px); padding: 30px 45px 27px 54px; }
  .price02__item__parts02::after { left: -40px; border-width: 10px 20px; }
  .price02__item__parts02 .lead { padding: 18px 14px; border-radius: 20px; font-size: 28px; line-height: 1.2; }
  .price02__item__parts02 .txt { width: 152px; margin: 0; }
  .price02__item__parts02 .txt02 { width: 205px; margin: 0; font-size: 0; }
  .price02__item:last-of-type .price02__item__parts01 { height: 160px; }
  .price02__item:last-of-type .price02__item__parts02 { position: relative; height: 180px; align-items: start; padding: 50px 12px 0 50px; }
  .price02__txt { width: 900px; margin: 0 auto 10px; border: 4px solid #d4d4d4; border-radius: 50px; font-size: 24px; position: relative; }
  .price02__note { margin: 5px 0 0; font-size: 14px; text-align: center; } }

/*==============================================================================
trouble01
============================================================================= */
.trouble01 { position: relative; }

.trouble01__bg { position: relative; padding: 1rem 0 .8rem; background-color: #e9e9e9; overflow: hidden; }

.trouble01__subttl { position: relative; width: 4rem; margin: 0 auto; font-size: .3rem; font-weight: bold; text-align: center; letter-spacing: .04em; z-index: 1; }

.trouble01__subttl::before, .trouble01__subttl::after { content: ""; position: absolute; width: .19rem; height: .44rem; top: 50%; transform: translateY(-50%); background: url(../img/top/trouble01_item01.png) no-repeat 50% 0/cover; }

.trouble01__subttl::before { left: 0; }

.trouble01__subttl::after { right: 0; transform: translateY(-50%) rotateY(180deg); }

.trouble01__ttl { position: relative; width: 5.6rem; height: .7rem; margin: .25rem auto 0; background: url("../img/top/trouble01_bg01_sp.png") no-repeat 50% 0/cover; color: #fff; font-size: .4rem; text-align: center; line-height: .7rem; letter-spacing: .04em; z-index: 1; }

.trouble01__txt01 { position: relative; margin: .25rem 0 0; font-size: .46rem; font-weight: bold; text-align: center; z-index: 1; }

.trouble01__txt01 .color { color: #ff3600; }

.trouble01__graph { position: relative; margin: .5rem 0 0; z-index: 1; }

.trouble01__note { position: absolute; bottom: .35rem; left: .35rem; color: #666; font-size: .2rem; }

.trouble01__txt02 { margin: .6rem 0 0; font-size: .46rem; font-weight: bold; text-align: center; letter-spacing: -0.04em; }

.trouble01::after { content: ""; position: absolute; width: 2.01rem; height: 1.04rem; bottom: -0.5rem; left: 50%; transform: translateX(-50%); background: url("../img/top/trouble_arrow01.png") no-repeat 50% 0/cover; }

/* sp */
@media (max-width: 767px) { .trouble01__bg::after { content: ""; position: absolute; width: 2.98rem; height: 4.4rem; top: .05rem; right: 0; background: url("../img/top/trouble01_person01_sp.png") no-repeat 50% 0/cover; }
  .trouble01__txt01 .sp-color { position: relative; z-index: 2; }
  .trouble01__txt01 .sp-color::after { content: ""; position: absolute; width: 102%; height: 1em; bottom: 0; left: 50%; transform: translateX(-50%); background-color: #fcff00; z-index: -1; } }

/* pc */
@media (min-width: 768px) { .trouble01::after { width: 201px; height: 104px; bottom: -50px; }
  .trouble01__bg { padding: 70px 0 80px; }
  .trouble01 .inner::after { content: ""; position: absolute; width: 290px; height: 596px; bottom: 120px; left: 10px; background: url("../img/top/trouble01_person01.jpg") no-repeat 50% 0/cover; }
  .trouble01__subttl { width: 420px; font-size: 30px; letter-spacing: .04em; }
  .trouble01__subttl::before, .trouble01__subttl::after { content: ""; width: 19px; height: 44px; }
  .trouble01__ttl { width: 100%; height: 100px; margin: 30px auto 0; background-image: url("../img/top/trouble01_bg01_pc.png"); font-size: 44px; line-height: 100px; letter-spacing: .04em; }
  .trouble01__txt01 { margin: 20px 0 0; font-size: 32px; letter-spacing: .04em; }
  .trouble01__txt01 .color { position: relative; }
  .trouble01__txt01 .color::after { content: ""; position: absolute; width: 102%; height: 15px; bottom: -5px; left: 50%; transform: translateX(-50%); background-color: #fcff00; border-radius: 15px; z-index: -1; }
  .trouble01__graph { width: 620px; margin: 60px 0 0 360px; }
  .trouble01__note { bottom: 25px; left: 45px; font-size: 16px; }
  .trouble01__txt02 { margin: 50px 0 0; font-size: 46px; letter-spacing: -0.04em; } }

/*==============================================================================
trouble02
============================================================================= */
.trouble02__bg { padding: 1rem 0 .9rem; background-color: #61b7ff; }

.trouble02__note01 { margin: .2rem 0 0; font-size: .2rem; text-align: center; }

.trouble02__list01 { margin: 1rem 0 0; }

.trouble02__item01 { position: relative; padding: .8rem .2rem .2rem; background-color: #fff; border-radius: .1rem; }

.trouble02__item01:not(:first-of-type) { margin: 1.1rem 0 0; }

.trouble02__item01:nth-of-type(1) .ttl::after { width: .94rem; height: 1.55rem; top: -0.53rem; right: .37rem; }

.trouble02__item01:nth-of-type(2) .ttl::after { width: 1.04rem; height: .95rem; top: -0.38rem; right: .4rem; background-image: url("../img/top/trouble02_item02.png"); }

.trouble02__item01 .ttl { position: absolute; width: 6.68rem; height: .8rem; left: 50%; top: -0.4rem; transform: translateX(-50%); background: url("../img/top/trouble02_bg01.png") no-repeat 50% 0/cover; color: #fff; font-size: .4rem; text-align: center; line-height: .8rem; }

.trouble02__item01 .ttl::after { content: ""; position: absolute; width: .94rem; height: 1.55rem; background: url("../img/top/trouble02_item01.png") no-repeat 50% 0/cover; }

.trouble02__item01 .item02 { display: flex; align-items: center; font-weight: bold; }

.trouble02__item01 .item02:not(:first-of-type) { margin: .2rem 0 0; }

.trouble02__item01 .item02__left { width: 3.4rem; padding: .4rem 0 .3rem; background-color: #f4f4f4; border-radius: .1rem; }

.trouble02__item01 .item02__left .left-txt01 { font-size: .4rem; text-align: center; }

.trouble02__item01 .item02__left .left-txt01 .size { font-size: .7rem; }

.trouble02__item01 .item02__left .left-txt02 { color: #ff3600; font-size: .5rem; text-align: center; line-height: 1.2; }

.trouble02__item01 .item02__left .left-txt02 .color { color: #777; font-size: .44rem; }

.trouble02__item01 .item02__left .left-txt02.size01 { font-size: .6rem; }

.trouble02__item01 .item02__left .left-txt02.size02 { font-size: .44rem; }

.trouble02__item01 .item02__right { width: 2.75rem; margin: 0 0 0 .4rem; }

.trouble02__item01 .item02__right .right-txt { font-size: .3rem; text-align: center; line-height: 1.2; }

.trouble02__item01 .item02__right .right-img { margin: .18rem auto 0; }

.trouble02__note02 { margin: .15rem 0 0; font-size: .26rem; text-align: center; letter-spacing: .04em; }

/* pc */
@media (min-width: 768px) { .trouble02__bg { padding: 100px 0 90px; }
  .trouble02__ttl { width: 830px; margin: 0 auto; }
  .trouble02__note01 { margin: 20px 0 0; font-size: 18px; }
  .trouble02__list01 { margin: 90px 0 0; display: flex; justify-content: space-between; }
  .trouble02__item01 { position: relative; width: 484px; padding: 55px 15px 15px; border-radius: 10px; }
  .trouble02__item01:not(:first-of-type) { margin: 0; }
  .trouble02__item01 .ttl { position: absolute; width: 455px; height: 54px; top: -27px; font-size: 30px; line-height: 54px; }
  .trouble02__item01 .ttl ::after { width: 50px; height: 50px; top: 0; left: 0; }
  .trouble02__item01:nth-of-type(1) .ttl::after { width: 64px; height: 106px; top: -35px; right: 25px; }
  .trouble02__item01:nth-of-type(2) .ttl::after { width: 71px; height: 64px; top: -26px; right: 27px; }
  .trouble02__item01 .item02:not(:first-of-type) { margin: 15px 0 0; }
  .trouble02__item01 .item02__left { width: 230px; height: 194px; border-radius: 15px; }
  .trouble02__item01 .item02__left .left-txt01 { font-size: 27px; }
  .trouble02__item01 .item02__left .left-txt01 .size { font-size: 47px; }
  .trouble02__item01 .item02__left .left-txt02 { font-size: 34px; }
  .trouble02__item01 .item02__left .left-txt02 .color { font-size: 30px; }
  .trouble02__item01 .item02__left .left-txt02.size01 { margin: -5px 0 0; font-size: 40px; }
  .trouble02__item01 .item02__left .left-txt02.size02 { margin: 5px 0 0; font-size: 30px; line-height: 1.4; }
  .trouble02__item01 .item02__right { width: 200px; margin: 0 0 0 25px; }
  .trouble02__item01 .item02__right .right-txt { font-size: 20px; }
  .trouble02__item01 .item02__right .right-img { margin: 10px auto 0; }
  .trouble02__note02 { margin: 10px 0 0; font-size: 18px; text-align: right; } }

/*==============================================================================
case
============================================================================= */
.case__bg { position: relative; background: url("../img/top/case_bg01.png"); padding: 1rem 0 .8rem; }

.case__bg::after { content: ""; position: absolute; width: 2.77rem; height: 5.26rem; top: 0; right: -0.75rem; background: url("../img/top/case_person01.png") no-repeat 50% 0/cover; }

.case__ttl { position: relative; width: 6.71rem; margin: 0 auto; z-index: 1; }

.case__txt01 { width: 7.1rem; height: .85rem; margin: .5rem 0 0; padding: .12rem 0 .3rem; background: url("../img/top/case_bg02_sp.png") no-repeat 50% 0/cover; font-size: .42rem; font-weight: bold; text-align: center; line-height: 1; }

.case__list { margin: .15rem 0 0; font-weight: bold; }

.case__item:not(:first-of-type) { margin: .3rem 0 0; }

.case__border { border: .06rem solid #000; border-radius: .1rem; }

.case__note { margin: .2rem 0 0; color: #fff; font-size: .26rem; text-align: center; }

.case__note .normal { font-weight: normal; }

/* sp */
@media (max-width: 767px) { .case__txtbox { display: flex; align-items: center; height: 1.94rem; background-color: #fff; font-weight: bold; }
  .case__txtbox .lead { display: flex; align-items: center; height: 100%; }
  .case__txtbox .num { position: relative; display: flex; align-items: center; justify-content: center; width: 1.25rem; height: 100%; background-color: #000; color: #fff; font-size: .4rem; }
  .case__txtbox .num::after { content: ""; position: absolute; width: 0; height: 0; top: 50%; right: -0.3rem; transform: translateY(-50%); border: .15rem solid transparent; border-left: .15rem solid #000; }
  .case__txtbox .txt { width: 2.5rem; padding-left: .35rem; font-size: .54rem; text-align: center; letter-spacing: -0.04em; }
  .case__txtbox .price { position: relative; padding-left: .45rem; color: #ff3600; font-size: .43rem; }
  .case__txtbox .price .size { font-size: .8rem; }
  .case__txtbox .price::after { content: ""; position: absolute; width: .45rem; height: .85rem; top: 50%; left: 0; transform: translateY(-50%); background: url("../img/top/case_arrow01.png") no-repeat 50% 0/cover; }
  .case__img img { border-radius: 0 0 .05rem .05rem; } }

/* pc */
@media (min-width: 768px) { .case__bg { position: relative; padding: 90px 0 155px; }
  .case__bg::after { width: 277px; height: 526px; top: 50px; right: calc(50% - 709px); }
  .case__ttl { width: 915px; margin: 0 auto; }
  .case__txt01 { position: relative; width: 100%; height: 85px; margin: 60px 0 0; padding: 12px 0 .30px; background-image: url("../img/top/case_bg02_pc.png"); font-size: 42px; z-index: 1; }
  .case__list { position: relative; margin: 25px 0 0; z-index: 1; }
  .case__item:not(:first-of-type) { margin: 30px 0 0; }
  .case__border { display: flex; border: 6px solid #000; border-radius: 10px; }
  .case__txtbox { width: calc(100% - 424px); }
  .case__txtbox .lead { padding-left: 30px; background-color: #000; color: #fff; font-size: 40px; line-height: 75px; }
  .case__txtbox .lead .txt { display: inline; margin-left: 20px; }
  .case__txtbox .price { position: relative; height: calc(100% - 75px); padding: 40px 0 0 170px; background-color: #fff; border-radius: 0 0 0 5px; color: #ff3600; font-size: 43px; line-height: 1; }
  .case__txtbox .price .size { font-size: 80px; }
  .case__txtbox .price::after { content: ""; position: absolute; width: 45px; height: 80px; top: 50%; left: 115px; transform: translateY(-50%); background: url("../img/top/case_arrow01.png") no-repeat 50% 0/cover; }
  .case__img { width: 424px; }
  .case__note { margin: 15px 0 0; font-size: 18px; } }

/*==============================================================================
difference
============================================================================= */
.difference01__bg01 { position: relative; margin: -0.5rem 0 0; padding: 1.28rem 0 .75rem; background: url(../img/top/difference01_bg01_sp.png) no-repeat 50% 0/cover; }

.difference01__bg01::before { content: ""; position: absolute; width: 3.24rem; height: 4.56rem; right: -0.45rem; bottom: 0; background: url("../img/top/difference01_person01.png") no-repeat 50% 0/cover; }

.difference01__ttl01 { position: relative; margin: 0 0 0 .1rem; width: 5.16rem; z-index: 2; }

.difference01__bg02 { position: relative; padding: 1rem 0 2.15rem; }

.difference01__bg02::after { content: ""; position: absolute; width: 3.91rem; height: 1.33rem; bottom: .75rem; left: 50%; transform: translateX(-50%); background: url("../img/top/difference01_arrow01.png") no-repeat 50% 0/cover; }

.difference01__ttl02 { font-size: .4rem; text-align: center; line-height: 1.6; letter-spacing: -0.04em; }

.difference01__ttl02 .color01 { color: #002868; }

.difference01__ttl02 .color02 { color: #ff3600; }

.difference01__ttl02 .subttl { position: relative; display: block; width: 5.2rem; margin: 0 auto; font-size: .6rem; }

.difference01__ttl02 .subttl::before, .difference01__ttl02 .subttl::after { content: ""; position: absolute; width: .55rem; height: .85rem; top: 50%; transform: translateY(-50%); background: url("../img/top/difference_item01.png") no-repeat 50% 0/cover; }

.difference01__ttl02 .subttl::before { left: 0; }

.difference01__ttl02 .subttl::after { right: 0; transform: translateY(-50%) rotateY(-180deg); }

.difference01__table { margin: .25rem 0 0; }

.difference01__txt { margin: .5rem 0 0; font-size: .41rem; font-weight: bold; text-align: center; letter-spacing: -0.04em; }

.difference01__txt .color { color: #ff3600; }

.difference01__note { margin: .08rem 0 0; font-size: .2rem; text-align: center; }

/* pc */
@media (min-width: 768px) { .difference01__bg01 { margin: -135px 0 0; padding: 150px 0 50px; background-image: url(../img/top/difference01_bg01_pc.png); }
  .difference01__bg01::before { width: 318px; height: 413px; bottom: 0; right: calc(50% - 673px); }
  .difference01__ttl01 { width: 830px; }
  .difference01__bg02 { padding: 75px 0 210px; }
  .difference01__bg02::after { content: ""; width: 391px; height: 133px; bottom: 90px; }
  .difference01__ttl02 { font-size: 40px; line-height: 1.8; }
  .difference01__ttl02 .subttl { width: 550px; font-size: 60px; }
  .difference01__ttl02 .subttl::before, .difference01__ttl02 .subttl::after { width: 55px; height: 85px; }
  .difference01__table { margin: 30px 0 0; }
  .difference01__txt { margin: 30px 0 0; font-size: 42px; }
  .difference01__note { font-size: 20px; } }

/*==============================================================================
difference02
============================================================================= */
.difference02__bg { position: relative; padding: 2.7rem 0 .85rem; background-color: #0062f2; }

.difference02__bg::after { content: ""; position: absolute; width: 1.97rem; height: 5.87rem; top: -2.05rem; right: -0.1rem; background: url("../img/top/difference02_person01.png") no-repeat 50% 0/cover; }

.difference02__ttl { position: absolute; width: 6.8rem; top: -3.2rem; left: 50%; transform: translateX(-50%); z-index: 1; }

.difference02__list01 { position: relative; padding-bottom: .6rem; background-color: #fff; border-radius: .1rem; z-index: 1; }

.difference02__item01 .lead { background-color: #dfe3ff; color: #0129ba; font-size: .4rem; text-align: center; line-height: 1rem; letter-spacing: -0.02em; text-shadow: .05rem .05rem 0 #ced2ec; }

.difference02__item01 .lead .color { color: #ff3600; }

.difference02__item01 .lead .color .size { font-size: .2rem; vertical-align: super; }

.difference02__item01:first-of-type .lead { border-radius: .1rem .1rem 0 0; }

.difference02__item01:last-of-type { margin: .55rem 0 0; border-radius: 0 0 .1rem .1rem; }

.difference02__item01:last-of-type .difference02__item02 { height: 1.3rem; }

.difference02__item01:last-of-type .difference02__item02 .item-txt { width: 2.55rem; line-height: 1.4; }

.difference02__item01:last-of-type .difference02__item02 .item-price01 { width: 2.16rem; }

.difference02__item01:last-of-type .difference02__item02 .item-price01 .size { margin: 0 0 0 .06rem; }

.difference02__item01:last-of-type .difference02__item02 .item-price02 { padding-left: .3rem; width: 2.01rem; }

.difference02__top-txt { display: flex; justify-content: space-between; align-items: center; padding-left: 3.55rem; height: .8rem; }

.difference02__top-txt .top-txt01, .difference02__top-txt .top-txt02 { width: 1.7rem; font-size: .26rem; text-align: center; }

.difference02__top-txt .top-txt02 { width: 1.8rem; color: #ff3600; }

.difference02__top-txt.ds-pc { display: none; }

.difference02__item02 { display: flex; align-items: center; height: .9rem; padding: 0 0 0 .28rem; font-size: .32rem; font-weight: bold; }

.difference02__item02:nth-of-type(odd) { background-color: #ebebeb; }

.difference02__item02 .item-txt { width: 3.3rem; font-size: .3rem; }

.difference02 .item-price01 { position: relative; line-height: 1.4; }

.difference02 .item-price01::after { content: ""; position: absolute; width: .28rem; height: .34rem; top: 50%; right: -0.3rem; transform: translateY(-50%); background: url("../img/top/difference02_arrow01.png") no-repeat 50% 0/cover; }

.difference02 .item-price01 .tax-in { display: block; font-weight: normal; }

.difference02 .item-price02 { width: 1.37rem; padding-left: .5rem; font-size: 0; }

.difference02__bottom .bottom-txt01 { padding: .2rem 0 0 .2rem; font-size: .22rem; }

.difference02__bottom .bottom-txt02 { width: 6.55rem; margin: .35rem auto 0; font-size: 0; }

/* sp */
@media (max-width: 767px) { .difference02 .item-price01 { position: relative; width: 1.7rem; font-size: .32rem; line-height: 1.2; }
  .difference02 .item-price01 .size { margin: 0 0 0 .1rem; font-size: .18rem; font-weight: normal; -ms-writing-mode: tb-rl; writing-mode: vertical-rl; vertical-align: middle; } }

/* pc */
@media (min-width: 768px) { .difference02__bg { padding: 270px 0 95px; }
  .difference02__bg::after { width: 296px; height: 888px; top: -169px; right: calc(50% - 634px); }
  .difference02__ttl { position: absolute; width: 678px; top: -320px; }
  .difference02__list01 { padding-bottom: 60px; border-radius: 10px; }
  .difference02__item01 .lead { font-size: 40px; line-height: 100px; text-shadow: 5px 5px 0 #ced2ec; }
  .difference02__item01 .lead .color .size { font-size: 14px; }
  .difference02__item01:first-of-type { border-radius: 10px 10px 0 0; }
  .difference02__item01:first-of-type .lead { border-radius: 10px 10px 0 0; }
  .difference02__item01:first-of-type .difference02__top-box { display: flex; height: 70px; align-items: center; justify-content: flex-end; }
  .difference02__item01:first-of-type .difference02__top-box .difference02__top-txt p:nth-of-type(odd) { margin: 0 0 0 185px; }
  .difference02__item01:first-of-type .difference02__list02 { display: flex; flex-wrap: wrap; }
  .difference02__item01:first-of-type .difference02__item02 { width: 50%; height: 70px; padding: 0 0 0 40px; font-size: .32rem; font-weight: bold; }
  .difference02__item01:first-of-type .difference02__item02:nth-of-type(odd) { background-color: #fff; }
  .difference02__item01:first-of-type .difference02__item02:nth-of-type(odd) .item-txt { width: 225px; }
  .difference02__item01:first-of-type .difference02__item02:nth-of-type(even) { padding: 0 0 0 30px; }
  .difference02__item01:first-of-type .difference02__item02:nth-of-type(even) .item-txt { width: 200px; }
  .difference02__item01:first-of-type .difference02__item02:nth-of-type(1), .difference02__item01:first-of-type .difference02__item02:nth-of-type(2), .difference02__item01:first-of-type .difference02__item02:nth-of-type(5), .difference02__item01:first-of-type .difference02__item02:nth-of-type(6) { background-color: #ebebeb; }
  .difference02__item01:first-of-type .difference02__item02 .item-txt { width: 220px; font-size: 18px; }
  .difference02__item01:first-of-type .difference02__item02 .item-price01 { width: 123px; font-size: 18px; }
  .difference02__item01:first-of-type .difference02__item02 .item-price01 .size { font-size: 12px; }
  .difference02__item01:first-of-type .difference02__item02 .item-price02 { width: 97px; padding-left: 30px; font-size: 0; }
  .difference02__item01:first-of-type .lead { border-radius: 10px 10px 0 0; }
  .difference02__item01:last-of-type { margin: 35px 0 0; border-radius: 10px 10px 0 0; }
  .difference02__item01:last-of-type .difference02__top-txt { width: 370px; height: 60px; margin: 0 0 0 460px; }
  .difference02__item01:last-of-type .difference02__top-txt .top-txt02 { margin: 0 0 0 100px; }
  .difference02__item01:last-of-type .difference02__item02 { height: 70px; padding: 0 0 0 150px; font-size: 18px; }
  .difference02__item01:last-of-type .difference02__item02 .item-txt { width: 320px; font-size: 18px; }
  .difference02__item01:last-of-type .difference02__item02 .item-price01 { width: 170px; }
  .difference02__item01:last-of-type .difference02__item02 .item-price01 .size { font-size: .18rem; }
  .difference02__item01:last-of-type .difference02__item02 .item-price02 { width: 248px; padding-left: 50px; }
  .difference02__top-txt { padding-left: 0; display: flex; justify-content: space-between; align-items: center; height: 70px; }
  .difference02__top-txt .top-txt01, .difference02__top-txt .top-txt02 { padding-top: 20px; font-size: 16px; text-align: left; }
  .difference02__top-txt .top-txt01 { width: 130px; }
  .difference02__top-txt .top-txt02 { width: 140px; }
  .difference02__item02 .item-price01 { position: relative; }
  .difference02__item02 .item-price01::after { width: 28px; height: 34px; right: -25px; }
  .difference02__bottom .bottom-txt01 { margin: 20px 0 0; padding: 0; font-size: 16px; text-align: center; }
  .difference02__bottom .bottom-txt02 { width: 870px; margin: 40px auto 0; }
  .difference02 .item-price01 .tax-in { padding: 0 0 0 14px; font-size: 14px; } }

/*==============================================================================
feature
============================================================================= */
.feature__bg { padding: 0 0 .6rem; }

.feature__ttl { width: 7.5rem; margin: 0 -0.2rem; }

.feature__box01 { position: relative; margin: -2.5rem 0 0; padding: .35rem .2rem .45rem; border: .15rem solid #d5d5d5; border-radius: .2rem; background-color: #f7f7f7; }

.feature__lead01 { font-size: .34rem; font-weight: bold; text-align: center; letter-spacing: 0; }

.feature__img01 { margin: .3rem 0 0; }

.feature__txt01 { margin: .35rem 0 0; font-size: .34rem; font-weight: bold; text-align: center; line-height: 1.2; }

.feature__txt01 .color { color: #0129ba; }

.feature__txt01 .color .size { font-size: .74rem; }

.feature__txt01 .underline { position: relative; z-index: 1; }

.feature__txt01 .underline::after { content: ""; position: absolute; width: 102%; height: .07rem; bottom: -0.14rem; left: 50%; transform: translateX(-50%); background-color: #0129ba; border-radius: .07rem; z-index: -1; }

.feature__txt02 { margin: .3rem 0 0; font-size: .28rem; text-align: center; }

.feature__note { margin: .2rem 0 0; font-size: .2rem; text-align: center; }

.feature__box02 { position: relative; margin: .9rem 0 0; padding: .6rem .2rem 0; border: .16rem solid #0129ba; border-radius: .2rem; font-weight: bold; }

.feature__box02::before { content: ""; position: absolute; width: 6.47rem; height: 1.34rem; left: 50%; top: -0.85rem; transform: translateX(-50%); background: url("../img/top/feature_arrow01.png") no-repeat 50% 0/cover; }

.feature__lead02 { color: #0129ba; font-size: .66rem; font-weight: bold; text-align: center; letter-spacing: 0; }

.feature__lead02 .size { font-size: .54rem; }

.feature__img02 { margin: .5rem 0 0; }

.feature__txt03 { margin: .2rem 0 0; font-size: .32rem; text-align: center; }

.feature__txt04 { position: relative; margin: .4rem -0.21rem -1px; padding: .25rem 0 .25rem 1.5rem; background-color: #0129ba; border-radius: 0 0 .03rem .03rem; color: #fff; font-size: .34rem; }

.feature__txt04::after { content: ""; position: absolute; width: 1.25rem; height: 1.25rem; left: 0; top: 50%; transform: translateY(-50%); background: url("../img/top/feature_item01.png") no-repeat 50% 0/cover; }

/* pc */
@media (min-width: 768px) { .feature__bg { padding: 0 0 70px; }
  .feature__ttl { width: 686px; margin: 0 auto; }
  .feature__box01 { margin: 0; padding: 40px 35px 50px; border: 15px solid #d5d5d5; border-radius: 20px; }
  .feature__lead01 { font-size: 34px; }
  .feature__img01 { position: absolute; width: 390px; right: 35px; bottom: 38px; margin: 0; }
  .feature__txt01 { margin: 50px 410px 0 0; font-size: 26px; line-height: 1.1; }
  .feature__txt01 .color .size { font-size: 56px; }
  .feature__txt01 .underline::after { width: 102%; height: 5px; bottom: -10px; border-radius: 5px; }
  .feature__txt02 { margin: 30px 420px 0 0; font-size: 20px; text-align: left; }
  .feature__note { margin: 10px 0 0; font-size: 14px; }
  .feature__box02 { margin: 90px 0 0; padding: 60px 0 0; border: 15px solid #0129ba; border-radius: 20px; }
  .feature__box02::before { width: 647px; height: 134px; top: -85px; }
  .feature__lead02 { font-size: 56px; }
  .feature__lead02 .size { font-size: 46px; }
  .feature__img02 { width: 613px; margin: 25px auto 0; }
  .feature__txt03 { margin: 10px 0 0; font-size: 28px; line-height: 1.4; }
  .feature__txt04 { position: relative; margin: 25px 0 0; padding: 25px 0 25px 155px; font-size: 28px; line-height: 1.8; }
  .feature__txt04::after { width: 105px; height: 105px; left: 17px; top: 20%; transform: none; } }

/*==============================================================================
reason
============================================================================= */
.reason__bg { position: relative; background: url("../img/top/reason_bg01.png"); padding: .7rem 0 1rem; }

.reason__bg::after { content: ""; position: absolute; width: 3.46rem; height: 4.73rem; top: .25rem; right: -0.5rem; background: url("../img/top/reason_person01_sp.png") no-repeat 50% 0/cover; }

.reason__ttl { width: 4.8rem; margin: 0 0 0 .17rem; position: relative; z-index: 2; }

.reason__list01 { position: relative; margin: .58rem 0 0; z-index: 1; }

.reason__item01 { position: relative; }

.reason__item01:not(:first-of-type) { margin: .5rem 0 0; }

.reason__item01 .ttlbox { display: flex; align-items: center; padding: .25rem .2rem .3rem; background: linear-gradient(120deg, #4baaf2, #006cff); border-radius: .1rem .1rem 0 0; }

.reason__item01 .ttlbox .num { width: 1.21rem; font-size: 0; }

.reason__item01 .ttlbox .lead { margin: 0 0 0 .2rem; color: #fff; font-size: .46rem; }

.reason__item01 .ttlbox .lead .color { color: #fcff00; }

.reason .contents { padding: 0 .3rem .5rem; background-color: #fff; border-radius: 0 0 .1rem .1rem; position: relative; z-index: 2; }

.reason .img01 { position: absolute; width: 2.75rem; height: 2.97rem; left: .15rem; }

.reason .txt01 { padding: .85rem 0 .4rem 2.6rem; }

.reason .item-txt { margin: .3rem -.1rem 0; font-size: .28rem; line-height: 1.8; }

.reason .pic { padding: .3rem 0 0; }

.reason .num2 .wrap01, .reason .num2 .wrap02 { position: relative; }

.reason .num2 .wrap01 .pic { width: 2.58rem; position: absolute; bottom: -.4rem; right: -.16rem; }

.reason .num2 .wrap01 .item-txt { width: 4.05rem; margin: 0; padding: .7rem 0 0; }

.reason .num2 .wrap02 .chart { margin: .32rem 0 0; }

.reason .lead02 { position: relative; margin: .5rem -.1rem 0; padding: .2rem 0; font-size: .34rem; font-weight: bold; text-align: center; line-height: 1.5; }

.reason .lead02::after, .reason .lead02::before { content: ""; position: absolute; width: 102%; height: .08rem; left: 50%; background-color: #2ba3ff; border-radius: .08rem; transform: translateX(-50%); }

.reason .lead02::before { top: 0; }

.reason .lead02::after { bottom: 0; }

.reason__guide .list02 { display: flex; justify-content: space-between; margin: .15rem 0 0; }

.reason__guide .item02 { width: 3.1rem; }

.reason__guide .item02 .item-txt { text-align: center; }

.reason__guide .lead02::after, .reason__guide .lead02::before { width: 2.2rem; height: .08rem; top: 50%; background-color: #ccc; border-radius: .08rem; transform: translateY(-50%); }

.reason__guide .lead02::before { left: 0; }

.reason__guide .lead02::after { left: auto; right: 0; }

.reason__guide .item03 { width: 3.1rem; }

.reason__guide .item03 .item-txt { font-weight: bold; text-align: center; }

.reason__guide .item03 .shop { width: 3.1rem; }

.reason__guide .item03 .address { margin: .1rem 0 0; font-size: .24rem; }

.reason__guide .pc-block { display: flex; }

.reason__bottom .lead02 { margin: .65rem 0 0; }

.reason__bottom .bottom-list { position: relative; margin: .3rem 0 0; padding: 0 0 0 3rem; }

.reason__bottom .bottom-list::before { content: ""; position: absolute; width: 2.42rem; height: 2.72rem; left: .2rem; top: 50%; transform: translateY(-50%); background: url(../img/top/reason_item01.png) no-repeat 50% 0/cover; }

.reason__bottom .bottom-item { font-size: .3rem; line-height: 1.8; }

.reason__bottom .bottom-txt { margin: .4rem 0 0; font-size: 0; }

/* spのみ */
@media (max-width: 767px) { .reason .list03 { display: flex; overflow: scroll; overflow-y: hidden; padding: 0 0 .3rem; }
  .reason .list03::-webkit-scrollbar { width: 100%; border-radius: .1rem; }
  .reason .list03::-webkit-scrollbar-thumb { background-color: #737373; border-radius: .1rem; box-shadow: 0 0 0 1px #737373; }
  .reason .list03.sp-block::-webkit-scrollbar-track { background-color: #e6e6e6; border-radius: .1rem; box-shadow: inset 0 0 .03rem #e6e6e6; }
  .reason .item03:not(:last-of-type) { margin-right: .3rem; } }

/* pc */
@media (min-width: 768px) { .reason__bg { padding: 86px 0 100px; }
  .reason__bg::after { width: 344px; height: 434px; background: url("../img/top/reason_person01_pc.png") no-repeat 50% 0/cover; top: 30px; right: calc(50% - 485px); }
  .reason__ttl { width: 535px; margin: 0 0 0 100px; }
  .reason__list01 { margin: 58px 0 0; }
  .reason__item01:not(:first-of-type) { margin: 40px 0 0; }
  .reason__item01 .ttlbox { position: relative; padding: 18px 30px; border-radius: 10px 10px 0 0; z-index: 1; }
  .reason__item01 .ttlbox .num { width: 121px; }
  .reason__item01 .ttlbox .lead { margin: 0 -20px 0 25px; font-size: 50px; letter-spacing: 0; }
  .reason__item01.num1 .contents { position: relative; padding: 30px 0 90px 30px; }
  .reason__item01.num1 .item-txt { width: 600px; margin: 15px 0 0; }
  .reason__item01.num2 .contents { padding: 30px 30px 50px 30px; position: relative; z-index: 2; }
  .reason__item01.num2 .contents .wrap01, .reason__item01.num2 .contents .wrap02 { position: relative; }
  .reason__item01.num2 .contents .wrap02 { z-index: 2; }
  .reason__item01.num2 .contents .pic { width: 238px; position: absolute; top: -45px; right: 30px; }
  .reason__item01.num2 .contents .item-txt { width: 605px; font-size: 20px; letter-spacing: .02em; }
  .reason__item01.num2 .contents .item-txt:nth-child(2) { margin: 0; }
  .reason__item01.num2 .contents .chart { margin: 40px 0 0; }
  .reason__item01.num3 .contents { padding: 30px 30px 0; }
  .reason__item01.num3 .contents .pc-flex { display: flex; justify-content: space-between; }
  .reason__item01.num3 .contents .pc-flex:nth-of-type(1) { flex-direction: row-reverse; }
  .reason__item01.num3 .contents .pc-flex:nth-of-type(1) .item-txt { width: 400px; }
  .reason__item01.num3 .contents .pc-flex:nth-of-type(2) { margin: 30px 0 0; }
  .reason__item01.num3 .contents .pc-flex .pic { width: 485px; margin: 0 0 0 30px; }
  .reason__item01.num3 .contents .pc-flex .lead02 { width: 400px; padding: 30px 0; font-size: 30px; text-align: center; letter-spacing: -0.02em; }
  .reason__item01.num3 .item-txt { width: 600px; margin: 15px 0 0; }
  .reason .contents { padding: 0 30px; border-radius: 0 0 10px 10px; }
  .reason .img01 { width: 260px; left: auto; right: 30px; top: 5px; }
  .reason .txt01 { width: 484px; margin: 0 0 0 -10px; padding: 0; }
  .reason .item-txt { margin: 0; font-size: 20px; line-height: 1.8; }
  .reason .pic { padding: .3rem 0 0; }
  .reason .chart { margin: .32rem 0 0; }
  .reason .lead02 { position: relative; margin: .5rem 0 0; padding: .2rem 0; font-size: .34rem; font-weight: bold; text-align: center; line-height: 1.5; }
  .reason .lead02::after, .reason .lead02::before { content: ""; position: absolute; width: 102%; height: 6px; border-radius: 6px; }
  .reason .lead02::before { top: 0; }
  .reason .lead02::after { bottom: 0; }
  .reason__guide { position: relative; margin: 70px -30px 0; padding: 40px 30px 55px 30px; background-color: #e9f2ff; }
  .reason__guide .lead01 { position: absolute; width: 210px; left: 60px; top: 100px; color: #0129ba; font-size: 40px; font-weight: bold; line-height: 1.1; letter-spacing: -0.02em; }
  .reason__guide .lead01 .size01 { font-size: 30px; }
  .reason__guide .lead01 .size02 { display: block; font-size: 26px; line-height: 1.4; }
  .reason__guide .list02 { display: flex; justify-content: space-between; margin: 0 0 0 270px; }
  .reason__guide .item02 { width: 310px; }
  .reason__guide .item02 .item-txt { width: 310px; text-align: center; }
  .reason__guide .item02 .shop { margin: 15px 0 0; }
  .reason__guide .lead02 { font-size: 30px; }
  .reason__guide .lead02::after, .reason__guide .lead02::before { width: 375px; height: 7px; background-color: #fff; border-radius: 7px; }
  .reason__guide .lead02::before { top: 50%; left: 0; }
  .reason__guide .lead02::after { left: auto; right: 0; }
  .reason__guide .list03 { display: flex; flex-wrap: wrap; justify-content: space-between; }
  .reason__guide .list03.pc-block { display: flex; justify-content: space-between; flex-wrap: wrap; }
  .reason__guide .item03 { width: 290px; }
  .reason__guide .item03 .item-txt { width: 290px; margin: 30px 0 0; }
  .reason__guide .item03 .shop { width: 290px; margin: 5px 0 0; }
  .reason__guide .item03 .address { margin: 12px 0 0; font-size: 16px; }
  .reason__guide .show-btn { position: relative; width: 500px; margin: 40px auto 0; padding: 15px 0; background-color: #fff; border-radius: 10px; box-shadow: 0 7px #b6c6e0; cursor: pointer; }
  .reason__guide .show-btn::after { position: absolute; content: ""; width: 15px; height: 15px; border-right: 5px solid #7d7d7d; border-top: 5px solid #7d7d7d; display: inline-block; top: 36%; right: 100px; transform: rotate(135deg); }
  .reason__guide .show-btn.open::after { top: 38%; transform: rotate(-45deg); }
  .reason__guide .show-btn .show-txt { font-size: 22px; font-weight: bold; text-align: center; }
  .reason__guide .show-contents { display: none; }
  .reason__guide .pc-block { width: 920px; flex-wrap: wrap; justify-content: space-between; }
  .reason__bottom { padding: 50px 0 55px; }
  .reason__bottom .lead02 { margin: 0 0 0 270px; padding: 20px 0; font-size: 28px; letter-spacing: -0.02em; }
  .reason__bottom .bottom-list { margin: 30px 0 0; padding: 0 0 0 270px; display: flex; flex-wrap: wrap; }
  .reason__bottom .bottom-list::before { width: 242px; height: 272px; left: .2rem; top: -200px; transform: none; }
  .reason__bottom .bottom-item { font-size: 20px; line-height: 1.8; }
  .reason__bottom .bottom-item:nth-of-type(3n+1) { width: 180px; margin: 0 0 0 10px; }
  .reason__bottom .bottom-item:nth-of-type(3n+2) { width: 250px; }
  .reason__bottom .bottom-item:nth-of-type(3n) { width: 200px; }
  .reason__bottom .bottom-txt { width: 742px; margin: 50px auto 0; } }

/*==============================================================================
service
============================================================================= */
.service__bg { padding: 1rem 0 1rem; background: url("../img/top/service_bg_sp.jpg") no-repeat center/cover; }

.service__ttl { width: 6.43rem; margin: 0 auto .65rem; }

.service__box { padding: .15rem; background-color: #001fff; border-radius: .2rem; }

.service__list { background: #fff; border-radius: .1rem; }

.service__list__item { position: relative; margin: 0 -1px; }

.service__list__item__block01 { background: url("../img/top/service_box_bg_sp.png") no-repeat center/cover; }

.service__list__item__block01 h3 { padding: .4rem 0 .2rem; color: #fff; font-size: .5rem; font-weight: bold; text-align: center; line-height: 1; box-sizing: border-box; }

.service__list__item__block01 h3 .yellow { color: #fcff00; }

.service__list__item__block01 h3 .small-txt { font-size: .4rem; }

.service__list__item__block01 p { padding: 0 0 .55rem; color: #fff; font-size: .32rem; font-weight: bold; text-align: center; line-height: 1; }

.service__list__item__block01 p .size { font-size: .18rem; vertical-align: super; }

.service__list__item__block02 { padding: .16rem .25rem .6rem; display: flex; align-items: center; }

.service__list__item__pic { width: 3.1rem; }

.service__list__item__txt { width: 3.1rem; font-size: .3rem; font-weight: bold; margin: 0 0 0 .2rem; }

.service__list__item__note { position: absolute; left: .95rem; bottom: .2rem; font-size: .2rem; text-align: center; }

.service__list__item:first-child { position: relative; padding: 0; }

.service__list__item:first-child:after { content: ''; width: .65rem; height: 1.47rem; background: url("../img/top/service_item01_sp.png") no-repeat top; background-size: 100% auto; position: absolute; top: -.2rem; right: -.05rem; z-index: 1; }

.service__list__item:nth-child(2):after { content: ''; width: 1.04rem; height: 1.47rem; background: url("../img/top/service_item02_sp.png") no-repeat top; background-size: 100% auto; position: absolute; top: -.11rem; right: -.14rem; z-index: 1; }

.service__list__item:nth-child(3):after { content: ''; width: 1.09rem; height: 1.48rem; background: url("../img/top/service_item03_sp.png") no-repeat top; background-size: 100% auto; position: absolute; top: -.17rem; right: -.05rem; z-index: 1; }

.service__list__item:nth-child(4):after { content: ''; width: 1.29rem; height: .97rem; background: url("../img/top/service_item04_sp.png") no-repeat top; background-size: 100% auto; position: absolute; top: -.1rem; right: .15rem; z-index: 1; }

.service__list__item:nth-child(5):after { content: ''; width: 1.74rem; height: 1.13rem; background: url("../img/top/service_item05_sp.png") no-repeat top; background-size: 100% auto; position: absolute; top: -.56rem; right: -.6rem; z-index: 1; }

.service__list__item:nth-child(5) .service__list__item__block02 { display: block; }

.service__list__item:nth-child(5) .service__list__item__block02 .service__list__item__pic { display: flex; width: 6.3rem; padding: 0 0 .3rem; }

.service__list__item:nth-child(5) .service__list__item__block02 .service__list__item__pic .service__list__item__pic01 { width: 3.1rem; }

.service__list__item:nth-child(5) .service__list__item__block02 .service__list__item__pic .service__list__item__pic02 { width: 3.1rem; margin-left: .1rem; }

.service__list__item:nth-child(5) .service__list__item__block02 .service__list__item__txt { width: 100%; }

/* pc */
@media (min-width: 768px) { .service__bg { padding: 100px 0; background: url("../img/top/service_bg_pc.jpg") no-repeat center/cover; }
  .service__ttl { width: 864px; margin: 0 auto 59px; }
  .service__box { padding: 16px; border-radius: 16px; }
  .service__list { display: flex; justify-content: space-between; flex-wrap: wrap; padding: 20px; border-radius: 10px; }
  .service__list__item { width: 445px; position: relative; }
  .service__list__item__block01 { background: url("../img/top/service_box_bg01_pc.png") no-repeat center/cover; }
  .service__list__item__block01 h3 { padding: 40px 0 26px; font-size: 40px; position: relative; z-index: 2; }
  .service__list__item__block01 h3 .small-txt { font-size: 40px; }
  .service__list__item__block01 p { padding: 0 0 55px; font-size: 22px; }
  .service__list__item__block01 p .size { font-size: 12px; }
  .service__list__item__block02 { padding: 16px 0 60px; display: block; }
  .service__list__item__pic { width: 310px; margin: 0 auto; }
  .service__list__item__txt { width: 100%; font-size: 20px; margin: 20px 0 0 0; }
  .service__list__item__txt p { text-align: center; }
  .service__list__item__note { width: 530px; left: 0; bottom: 40px; font-size: 14px; text-align: left; }
  .service__list__item:first-child { padding: 0; }
  .service__list__item:first-child:after { content: ''; width: 50px; height: 114px; background: url("../img/top/service_item01_pc.png") no-repeat top; background-size: 100% auto; position: absolute; top: -13px; right: 11px; z-index: 1; }
  .service__list__item:nth-child(2):after { content: ''; width: 85px; height: 71px; background: url("../img/top/service_item02_pc.png") no-repeat top; background-size: 100% auto; position: absolute; top: -18px; right: 2px; z-index: 1; }
  .service__list__item:nth-child(3):after { content: ''; width: 88px; height: 115px; background: url("../img/top/service_item03_pc.png") no-repeat top; background-size: 100% auto; position: absolute; top: -13px; right: 9px; z-index: 1; }
  .service__list__item:nth-child(4):after { content: ''; width: 91px; height: 73px; background: url("../img/top/service_item04_pc.png") no-repeat top; background-size: 100% auto; position: absolute; top: -11px; right: 21px; z-index: 1; }
  .service__list__item:nth-child(5) { width: 910px; }
  .service__list__item:nth-child(5):after { content: ''; width: 142px; height: 87px; background: url("../img/top/service_item05_pc.png") no-repeat top; background-size: 100% auto; position: absolute; top: -13px; right: 21px; z-index: 1; }
  .service__list__item:nth-child(5) .service__list__item__block01 { background: url("../img/top/service_box_bg02_pc.png") no-repeat center/cover; }
  .service__list__item:nth-child(5) .service__list__item__block02 .service__list__item__pic { width: 630px; padding: 0; }
  .service__list__item:nth-child(5) .service__list__item__block02 .service__list__item__pic .service__list__item__pic01 { width: 310px; }
  .service__list__item:nth-child(5) .service__list__item__block02 .service__list__item__pic .service__list__item__pic02 { width: 310px; margin-left: 10px; }
  .service__list__item:nth-child(5) .service__list__item__block02 .service__list__item__txt { width: 100%; } }

/*==============================================================================
special
============================================================================= */
@media (max-width: 767px) { .special__bg { padding: 0 0 .65rem; background: #ffb901; }
  .special__ttl { margin: 0 -0.2rem; }
  .special__list { margin: -1.1rem 0 0; }
  .special__item { position: relative; height: 4.12rem; background: #fff; border-radius: .2rem; }
  .special__item:not(:first-of-type) { margin: .8rem 0 0; }
  .special__item__num { position: absolute; width: 1.7rem; height: .88rem; top: -0.44rem; left: 50%; transform: translateX(-50%); padding: .18rem 0 .2rem; background: #000; border-radius: .2rem; color: #fff; font-size: .35rem; font-weight: bold; line-height: 1; text-align: center; }
  .special__item__num .size { font-size: .5rem; letter-spacing: -0.1em; }
  .special__item__lead { height: 2.07rem; padding: .65rem 0 0; background: #ff3600; border-radius: .2rem .2rem 0 0; color: #fff; font-size: .44rem; font-weight: bold; text-align: center; line-height: 1.3; }
  .special__item__lead .size01 { font-size: .42rem; }
  .special__item__lead .size02 { font-size: .34rem; }
  .special__item__lead .tax { font-size: .28rem; }
  .special__item__lead .super { font-size: .2rem; vertical-align: super; }
  .special__item:nth-of-type(4) { height: 5rem; }
  .special__item:first-of-type .special__item__lead, .special__item:nth-of-type(8) .special__item__lead { padding: .85rem 0 0; }
  .special__item:nth-of-type(7) .special__item__lead, .special__item:last-of-type .special__item__lead { padding: .65rem 0 0 .1rem; }
  .special__item__txt { padding: .35rem .4rem; font-size: .3rem; line-height: 1.45; }
  .special__item__txt .super { font-size: .15rem; vertical-align: super; }
  .special__item__img { position: absolute; width: 2.2rem; top: 2.15rem; right: .24rem; }
  .special__note { margin: .4rem 0 0; font-size: .2rem; text-align: center; line-height: 1.5; }
  .special__note .block { display: block; margin: .2rem 0 0; } }

@media (min-width: 768px) { .special__bg { padding: 0 0 60px; background: #ffb901; }
  .special__ttl { width: 1190px; margin: 0 -105px; }
  .special__list { margin: -150px 0 0; display: flex; flex-wrap: wrap; justify-content: space-between; }
  .special__item { position: relative; width: 482px; height: 355px; background: #fff; border-radius: 20px; }
  .special__item:nth-of-type(n+3) { margin: 50px 0 0; }
  .special__item__num { position: absolute; width: 134px; height: 70px; top: -30px; left: 50%; transform: translateX(-50%); padding: 15px 0 10px; background: #000; border-radius: 20px; color: #fff; font-size: 28px; font-weight: bold; line-height: 1; text-align: center; }
  .special__item__num .size { font-size: 40px; letter-spacing: -0.1em; }
  .special__item__lead { height: 156px; padding: 60px 0 0; background: #ff3600; border-radius: 20px 20px 0 0; color: #fff; font-size: 28px; font-weight: bold; text-align: center; line-height: 1.3; letter-spacing: -0.01em; }
  .special__item__lead .size02 { font-size: 25px; }
  .special__item__lead .tax { font-size: 18px; }
  .special__item__lead .super { font-size: 16px; vertical-align: super; }
  .special__item:first-of-type .special__item__lead, .special__item:nth-of-type(8) .special__item__lead { padding: 70px 0 0; }
  .special__item:nth-of-type(7) .special__item__lead, .special__item:last-of-type .special__item__lead { padding: 60px 0 0 5px; }
  .special__item__txt { padding: 23px 45px; font-size: 20px; }
  .special__item__txt .super { font-size: 12px; vertical-align: super; }
  .special__item:nth-of-type(6) .special__item__txt { line-height: 1.5; }
  .special__item__img { position: absolute; width: 145px; bottom: 38px; right: 26px; }
  .special__note { margin: 40px 0 0 58px; font-size: 14px; line-height: 1.4; }
  .special__note .block { display: block; margin: 7px 0 0; } }

/*==============================================================================
merit
============================================================================= */
/* sp */
@media (max-width: 767px) { .merit__bg { background: #ffba00 url(../img/top/merit_bg01_pc.jpg) no-repeat 50% 0; }
  .merit__ttl { margin: 0 -.2rem; }
  .merit__item { padding: .16rem; border-radius: .15rem; background: #fff; }
  .merit__item + .merit__item { margin: .38rem 0 0; }
  .merit__item + .merit__item02 { margin: .38rem 0 0; }
  .merit__item__block01 { display: flex; flex-wrap: wrap; justify-content: flex-start; align-items: center; padding: .3rem 0 .34rem .2rem; border-radius: .12rem; background: #fff1ca; font-weight: bold; }
  .merit__item__num { width: 1.3rem; padding: 0 0 .2rem; background: url(../img/top/merit_deco01.png) no-repeat 50% bottom; background-size: cover; color: #ff3600; font-size: .28rem; text-align: center; line-height: 1.3; }
  .merit__item__num .font-large { font-size: .48rem; }
  .merit__item__ttl { margin: 0 0 0 .2rem; font-size: .44rem; line-height: 1.2; letter-spacing: -0.02em; }
  .merit__item__ttl .size01 { font-size: .5rem; }
  .merit__item__ttl .size03 { font-size: .39rem; }
  .merit__item__ttl .size04 { font-size: .38rem; }
  .merit__item__ttl .size05 { font-size: .36rem; }
  .merit__item__block02 { position: relative; padding: .5rem 0; }
  .merit__item__block02__pic { position: absolute; top: .15rem; left: -.4rem; width: 2.2rem; z-index: 1; }
  .merit__item01 .merit__item__block02 { position: relative; }
  .merit__item01 .merit__item__block02__txt01 { margin: 0 0 0 2.05rem; font-size: .3rem; line-height: 1.7; }
  .merit__item02 .merit__item__block02 { position: relative; padding: .3rem 0; }
  .merit__item02 .merit__item__block02__txt01 { font-size: .34rem; font-weight: bold; text-align: center; }
  .merit__item02 .merit__item__block02__txt02 { margin: .28rem .15rem 0 2.05rem; font-size: .3rem; line-height: 1.7; }
  .merit__item02 .merit__item__block02__pic { top: 1.6rem; }
  .merit__item02 .merit__item__block03 { position: relative; margin: .4rem 0 0; padding: .5rem 0 .35rem 1.8rem; background: #efefef; }
  .merit__item02 .merit__item__block03__txt01 { position: absolute; top: -.31rem; left: 0; right: 0; width: 2.47rem; margin: 0 auto; font-size: .2rem; }
  .merit__item02 .merit__item__block03__txt02 { font-size: .3rem; font-weight: bold; line-height: 1.7; }
  .merit__item02 .merit__item__block03__icon { position: absolute; top: .74rem; left: .4rem; width: .96rem; font-size: .2rem; }
  .merit__item03 .merit__item__block02 { position: relative; padding: .5rem 0; }
  .merit__item03 .merit__item__block02__txt01 { margin: 0 0 0 2.05rem; font-size: .3rem; line-height: 1.7; }
  .merit__item03 .merit__item__block02__pic { top: .08rem; }
  .merit__item03 .merit__item__block03 { position: relative; padding: .35rem .14rem .5rem; background: #efefef; background: linear-gradient(to bottom right, #efefef 72%, #dcdcdc 72%); }
  .merit__item03 .merit__item__block03__ttl01 { color: #ff7800; font-size: .4rem; font-weight: bold; text-align: center; letter-spacing: .01em; }
  .merit__item03 .merit__item__block03__txt01 { margin: .28rem 0 0; font-size: .32rem; font-weight: bold; text-align: center; }
  .merit__item03 .merit__item__block03__txt01 .emphasis { display: inline-block; margin: 0 0 0 -0.1rem; padding: 0 .05rem; background: #ff0000; color: #fff; font-size: .36rem; font-weight: bold; }
  .merit__item03 .merit__item__block03__balloon { position: relative; width: 4.1rem; margin: .3rem 0 0; padding: .15rem; background: #fff; border-radius: 10px; color: #ff7800; font-size: .3rem; line-height: 1; text-align: center; }
  .merit__item03 .merit__item__block03__balloon::before { position: absolute; bottom: -.11rem; left: 0; right: 0; width: 0; height: 0; margin: 0 auto; border-style: solid; border-width: .12rem .06rem 0 .06rem; border-color: #fff transparent transparent transparent; content: ""; }
  .merit__item03 .merit__item__block03__txt02 { width: 4.3rem; margin: .22rem 0 0 .15rem; font-size: .25rem; line-height: 1.48; }
  .merit__item03 .merit__item__block03__txt02 .color-red { color: #ff0000; }
  .merit__item03 .merit__item__block03__phone01 { position: absolute; top: 2.7rem; right: .2rem; width: 2.1rem; }
  .merit__item04 .merit__item__ttl { font-size: .38rem; line-height: 1.3; }
  .merit__item04 .merit__item__ttl .tax { font-size: .2rem; }
  .merit__item04 .merit__item__block02 { position: relative; padding: .6rem 0; }
  .merit__item04 .merit__item__block02__txt01 { margin: 0 0 0 2.1rem; font-size: .3rem; }
  .merit__item04 .merit__item__block02__price { width: 6.27rem; margin: .54rem auto 0; }
  .merit__item04 .price { position: relative; }
  .merit__item04 .tax-in { position: absolute; left: .36rem; bottom: -0.28rem; font-size: .2rem; letter-spacing: 0; }
  .merit__item05 .merit__item__ttl { font-size: .44rem; }
  .merit__item05 .merit__item__ttl .font-small { font-size: .22rem; }
  .merit__item05 .merit__item__block02 { position: relative; padding: .38rem 0; }
  .merit__item05 .merit__item__block02__txt01 { margin: 0 0 0 2.05rem; font-size: .3rem; }
  .merit__item05 .merit__item__block02__txt02 { margin: .3rem 0 0 2.05rem; font-size: .24rem; line-height: 1.3; }
  .merit .merit__bottom__txt { margin: 0 -.2rem; } }

/* pc */
@media (min-width: 768px) { .merit__bg { min-width: 1000px; padding: 100px 0 0; background: #ffba00 url(../img/top/merit_bg01_pc.jpg) no-repeat 50% 0; }
  .merit__list { margin: 62px 0 0; }
  .merit__item { padding: 16px; border-radius: 15px; background: #fff; }
  .merit__item + .merit__item { margin: 40px 0 0; }
  .merit__item + .merit__item02 { margin: 75px 0 0; }
  .merit__item__block01 { display: flex; flex-wrap: wrap; justify-content: flex-start; align-items: center; padding: 20px 25px; border-radius: 10px; background: #fff1ca; font-weight: bold; }
  .merit__item__num { width: 130px; padding: 0 0 28px; background: url(../img/top/merit_deco01.png) no-repeat 50% bottom; background-size: cover; color: #ff3600; font-size: 28px; text-align: center; line-height: 1.3; }
  .merit__item__num .font-large { font-size: 48px; }
  .merit__item__ttl { margin: 0 0 0 45px; font-size: 44px; line-height: 1.2; }
  .merit__item__ttl .size01 { font-size: 50px; }
  .merit__item__ttl .size02 { font-size: 41px; }
  .merit__item__block02 { position: relative; padding: 50px 0; }
  .merit__item__block02__pic { position: absolute; top: 11px; left: -46px; width: 220px; z-index: 1; }
  .merit__item01 .merit__item__block02 { position: relative; }
  .merit__item01 .merit__item__block02__txt01 { margin: 0 0 0 203px; font-size: 20px; line-height: 2; }
  .merit__item02 .merit__item__block02 { position: relative; padding: 50px 0; }
  .merit__item02 .merit__item__block02__txt01 { margin: 0 0 0 203px; font-size: 24px; font-weight: bold; }
  .merit__item02 .merit__item__block02__txt02 { margin: 28px 0 0 203px; font-size: 20px; line-height: 2; }
  .merit__item02 .merit__item__block03 { position: relative; margin: 10px 0 0; padding: 50px 0 30px 150px; background: #efefef; }
  .merit__item02 .merit__item__block03__txt01 { position: absolute; top: -31px; left: 0; right: 0; width: 247px; margin: 0 auto; }
  .merit__item02 .merit__item__block03__txt02 { font-size: 24px; font-weight: bold; line-height: 1.7; }
  .merit__item02 .merit__item__block03__icon { position: absolute; top: 46px; left: 40px; width: 78px; }
  .merit__item03 .merit__item__block02 { position: relative; padding: 50px 0; }
  .merit__item03 .merit__item__block02__txt01 { margin: 0 0 0 203px; font-size: 20px; line-height: 2; }
  .merit__item03 .merit__item__block02__pic { top: -8px; }
  .merit__item03 .merit__item__block03 { position: relative; margin: 10px 0 0; padding: 40px 60px; background: #efefef; background: linear-gradient(to bottom right, #efefef 72%, #dcdcdc 72%); }
  .merit__item03 .merit__item__block03__txt-wrap { width: 530px; }
  .merit__item03 .merit__item__block03__ttl01 { color: #ff7800; font-size: 32px; font-weight: bold; }
  .merit__item03 .merit__item__block03__txt01 { margin: 20px 0 0; font-size: 26px; font-weight: bold; }
  .merit__item03 .merit__item__block03__txt01 .emphasis { display: inline-block; background: #ff0000; color: #fff; font-size: 32px; font-weight: bold; }
  .merit__item03 .merit__item__block03__balloon { display: inline-block; position: relative; margin: 30px 0 0; padding: 7px 72px; background: #fff; border-radius: 10px; color: #ff7800; font-size: 21px; line-height: 1; }
  .merit__item03 .merit__item__block03__balloon::before { position: absolute; bottom: -9px; left: 0; right: 0; width: 0; height: 0; margin: 0 auto; border-style: solid; border-width: 10px 5px 0 5px; border-color: #fff transparent transparent transparent; content: ""; }
  .merit__item03 .merit__item__block03__txt02 { margin: 17px 0 0; font-size: 18px; }
  .merit__item03 .merit__item__block03__txt02 .color-red { color: #ff0000; }
  .merit__item03 .merit__item__block03__phone01 { position: absolute; top: -40px; right: 63px; width: 215px; }
  .merit__item04 .merit__item__ttl { letter-spacing: -0.02em; }
  .merit__item04 .merit__item__ttl .price { position: relative; }
  .merit__item04 .merit__item__ttl .price .tax { position: absolute; width: 52px; top: -20px; right: -11px; font-size: 15px; }
  .merit__item04 .merit__item__block02 { position: relative; padding: 50px 0 40px; }
  .merit__item04 .merit__item__block02__txt01 { margin: 0 0 0 203px; font-size: 20px; line-height: 2; }
  .merit__item04 .merit__item__block02__price { position: absolute; top: 20px; right: 30px; width: 418px; }
  .merit__item04 .price { position: relative; }
  .merit__item04 .tax-in { position: absolute; left: 38px; bottom: -28px; font-size: 20px; letter-spacing: 0; }
  .merit__item05 .merit__item__ttl .font-small { font-size: 22px; }
  .merit__item05 .merit__item__block02 { position: relative; padding: 50px 0 40px; }
  .merit__item05 .merit__item__block02__txt01 { margin: 0 0 0 190px; font-size: 20px; line-height: 2; }
  .merit__item05 .merit__item__block02__txt02 { margin: 20px 0 0 190px; font-size: 14px; } }

/*==============================================================================
csr
============================================================================= */
.csr__bg { background: url("../img/top/csr_bg_sp.jpg") no-repeat center/cover; padding: 1rem 0 3.35rem; }

.csr__ttl { width: 4.86rem; margin: 0 auto .36rem; }

.csr__item01 { padding: 0 .2rem; position: relative; z-index: 2; }

.csr__item01__bg { width: 7.46rem; position: absolute; top: 0; left: -.35rem; }

.csr__item01__txt { padding: .6rem 0 .25rem; position: relative; font-size: .36rem; color: #fff; font-weight: bold; }

.csr__item01__txt p { text-align: center; }

.csr__item02 { padding: 0 .2rem; position: relative; z-index: 1; }

.csr__item02__pic { width: 3.25rem; position: absolute; top: -.2rem; left: 4.07rem; }

.csr__item02__lst { padding: .2rem 0 0; font-size: .36rem; color: #fff; font-weight: bold; line-height: 1.5; }

.csr__item02__lst__item { padding: .5rem 0; position: relative; }

.csr__item02__lst__item::after { content: ''; width: 3.91rem; height: 1px; background: url("../img/top/csr_item01_line_sp.png") no-repeat center; background-size: 100% auto; position: absolute; bottom: 0; left: 0; }

.csr__item02__lst__item:last-of-type::after { content: none; }

.csr__item02__txt { margin: .5rem 0 .6rem; }

.csr__item02__txt p { font-size: .26rem; color: #fff; line-height: 1.69; }

.csr__item03 { position: relative; }

.csr__item03__bg { width: 7.61rem; position: absolute; top: 0; left: -.25rem; z-index: 1; }

.csr__item03__txt01 { padding: 1.8rem 0 0; position: relative; font-size: .4rem; color: #cc1819; font-weight: bold; text-align: center; letter-spacing: .04em; z-index: 2; }

.csr__item03__txt02 { padding: 5.1rem 0 .8rem; position: relative; font-size: .26rem; text-align: center; z-index: 2; }

/* pc */
@media (min-width: 768px) { .csr__bg { background: url("../img/top/csr_bg_pc.jpg") no-repeat 50% 0/cover; padding: 102px 0 113px; }
  .csr__ttl { width: 933px; margin: 0 auto 60px; }
  .csr__item01 { padding: 0; }
  .csr__item01__bg { width: 1016px; position: absolute; top: 0; left: -36px; }
  .csr__item01__txt { padding: 99px 0 73px; font-size: 32px; }
  .csr__item01__txt p { line-height: 1; }
  .csr__item02 { padding: 0; }
  .csr__item02__pic { width: 271px; position: absolute; top: 10px; left: 724px; }
  .csr__item02__lst { padding: 30px 0 0; font-size: 32px; }
  .csr__item02__lst__item { padding: 20px 0; line-height: 1; }
  .csr__item02__lst__item::after { content: ''; width: 492px; height: 1px; background: url("../img/top/csr_item01_line_pc.png") no-repeat center/cover; position: absolute; bottom: 0; left: 0; }
  .csr__item02__lst__item:last-of-type::after { content: none; }
  .csr__item02__txt { width: 670px; margin: 30px 0 80px; }
  .csr__item02__txt p { font-size: 16px; line-height: 1.93; }
  .csr__item03 { position: relative; }
  .csr__item03__bg { width: 966px; top: 0; left: 7px; }
  .csr__item03__txt01 { padding: 117px 0 0; font-size: 24px; line-height: 1; }
  .csr__item03__txt02 { padding: 283px 0 26px; font-size: 16px; line-height: 1.87; } }

/*==============================================================================
faq
============================================================================= */
.faq__bg { background: url(../img/top/faq_bg01.jpg); background-size: cover; }

.faq__txtbox .question { position: relative; z-index: 100; display: flex; align-items: center; background: #0129ba; }

.faq__txtbox .question::after { transform: rotate(135deg); }

.faq__txtbox .question.open::after { transform: rotate(-45deg); }

.faq__txtbox .answer { display: none; }

.faq__txtbox .flex { display: flex; }

@media (max-width: 767px) { .faq__bg { padding: .8rem 0; }
  .faq__title .img01 { width: 4.28rem; margin: 0 auto .7rem; line-height: 1; }
  .faq__txtbox { margin: .36rem 0; }
  .faq__txtbox .question { width: 7.1rem; border-radius: .1rem; box-shadow: 0 .1rem #00139a; }
  .faq__txtbox .question::after { position: absolute; content: ""; width: .26rem; height: .26rem; border-right: .08rem solid #fff; border-top: .08rem solid #fff; display: inline-block; transform: rotate(135deg); top: .75rem; right: .3rem; }
  .faq__txtbox .txt01 { font-size: .6rem; font-weight: bold; color: #fff; line-height: 1; margin: .47rem 0 .47rem .19rem; }
  .faq__txtbox .txt02 { font-size: .34rem; color: #fff; font-weight: bold; margin: .32rem 0 .32rem .18rem; }
  .faq__txtbox .answer { width: 7.1rem; padding: .5rem .2rem .4rem .3rem; border-radius: 0 0 .1rem .1rem; background: #fff; box-shadow: 0 0.1rem rgba(207, 207, 207, 0.4); }
  .faq__txtbox .txt03 { font-size: .6rem; font-weight: bold; color: #ff3600; line-height: 1; }
  .faq__txtbox .txt04 { width: 5.8rem; font-size: .29rem; color: #555; margin: 0 0 0 .15rem; }
  .faq__txtbox .txt04 .font01 { vertical-align: super; font-size: 50%; }
  .faq__txtbox .txt04 .font02 { font-size: .24rem; } }

@media (min-width: 768px) { .faq__bg { padding: 95px 0 100px; }
  .faq__title .img01 { width: 386px; margin: 0 auto 69px; }
  .faq__txtbox { margin: 30px 0 0; cursor: pointer; }
  .faq__txtbox .question { width: 980px; border-radius: 10px; box-shadow: 0 10px #00139a; }
  .faq__txtbox .question::after { position: absolute; content: ""; width: 26px; height: 26px; border-right: 8px solid #fff; border-top: 8px solid #fff; display: inline-block; top: 36%; right: 40px; }
  .faq__txtbox .txt01 { font-size: 50px; font-weight: bold; color: #fff; line-height: 1; margin: 21px 0 21px 28px; }
  .faq__txtbox .txt02 { margin: 28px 0 28px 18px; color: #fff; font-size: 24px; font-weight: bold; }
  .faq__txtbox .answer { display: none; width: 980px; border-radius: 0 0 10px 10px; background: #fff; box-shadow: 0 10px rgba(207, 207, 207, 0.4); padding: 47px 0 42px; }
  .faq__txtbox .txt03 { font-size: 50px; font-weight: bold; color: #ff3600; line-height: 1; margin: 0 0 0 28px; }
  .faq__txtbox .txt04 { font-size: 18px; color: #555; margin: 0 0 0 18px; }
  .faq__txtbox .txt04 .font01 { vertical-align: super; font-size: 10px; }
  .faq__txtbox .txt04 .font02 { font-size: 15px; }
  .faq__txtbox .txt04.margin { margin: 10px 0 0 18px; } }
