@charset "UTF-8";
@import url("global.css");
.intro {
  margin-bottom: 140px; }
  .intro .catch {
    text-align: center;
    font-size: 35px;
    font-weight: bold;
    font-family: "Shippori Mincho", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    margin-bottom: 30px; }
  .intro p:not([class]) {
    text-align: center;
    margin: 0 auto 50px; }
  .intro .img {
    width: 100%;
    height: 500px; }

.need {
  border: 2px solid #252122;
  border-radius: 5px;
  padding: 80px 80px 60px;
  position: relative;
  margin-bottom: 80px; }
  .need .lead {
    display: inline-block;
    background-color: #fff;
    position: absolute;
    top: -20px;
    left: 50%;
    transform: translateX(-50%);
    line-height: 1;
    padding: 0 20px;
    font-size: 30px;
    font-weight: bold; }
    .need .lead::before {
      content: "";
      width: 82px;
      height: 34px;
      background: url("../money/img/hdpoint.png") no-repeat center center;
      background-size: contain;
      position: absolute;
      left: 50%;
      top: -50px;
      transform: translateX(-50%); }
  .need > p:not([class]) {
    text-align: center; }
  .need .list {
    margin: 50px auto;
    display: flex;
    justify-content: center; }
    .need .list li {
      width: calc(100% / 3);
      max-width: 400px;
      padding: 0 15px; }
      .need .list li .inner {
        height: 100%;
        background: #eee;
        box-sizing: border-box; }
        .need .list li .inner .text {
          padding: 20px 30px 30px; }
          .need .list li .inner .text h3 {
            text-align: center;
            line-height: 1.4;
            margin-bottom: 20px;
            font-size: 23px;
            font-weight: bold;
            font-family: "Shippori Mincho", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
          .need .list li .inner .text p {
            color: #F08803;
            font-weight: bold; }
            .need .list li .inner .text p span {
              color: #252122;
              font-size: 90%;
              font-weight: normal; }
  .need .em {
    text-align: center;
    line-height: 1.4;
    font-size: 18px;
    font-weight: bold; }
    .need .em span {
      display: inline-block; }
      .need .em span i {
        padding: 0 5px;
        display: inline-block;
        background: linear-gradient(transparent 60%, rgba(240, 136, 3, 0.5) 60%);
        font-size: 24px;
        font-style: normal; }

.review {
  padding: 80px 0;
  background: #eee; }
  .review .f_inner {
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
    align-items: center; }
  .review .text {
    width: 47%; }
    .review .text .lead {
      margin-bottom: 30px;
      font-size: 35px;
      font-weight: bold;
      font-family: "Shippori Mincho", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
    .review .text p:not([class]) {
      margin-bottom: 20px;
      text-align: justify; }
  .review .img {
    width: 48%; }

.after {
  padding: 80px 0 0; }
  .after .f_inner {
    display: flex;
    justify-content: space-between;
    align-items: center; }
  .after .text {
    width: 47%; }
    .after .text .lead {
      margin-bottom: 30px;
      font-size: 35px;
      font-weight: bold;
      font-family: "Shippori Mincho", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
    .after .text p:not([class]) {
      margin-bottom: 20px;
      text-align: justify; }
  .after .img {
    width: 48%; }

/* ------------------------------------------------------------------------------------------------------------------------

 Responsive-Breakpoint-1 (1300px)
 
------------------------------------------------------------------------------------------------------------------------ */
@media only screen and (max-width: 1300px) {
  .intro .img {
    height: 400px; }

  .need {
    padding: 60px 60px 40px;
    margin-bottom: 80px; }
    .need .list {
      margin: 50px -15px; }
      .need .list li {
        max-width: initial; }

  .review {
    padding: 70px 0; }
    .review .f_inner {
      align-items: stretch; }

  .after {
    padding: 70px 0 0; }
    .after .f_inner {
      align-items: stretch; } }
/* ------------------------------------------------------------------------------------------------------------------------

 Responsive-Breakpoint-2 ( 960px )
 
------------------------------------------------------------------------------------------------------------------------ */
@media only screen and (max-width: 959px) {
  .intro {
    margin-bottom: 120px; }
    .intro .catch {
      font-size: 28px;
      margin-bottom: 20px; }
    .intro p:not([class]) {
      margin: 0 auto 30px; }
    .intro .img {
      height: 300px; }

  .need {
    margin-bottom: 50px; }
    .need .lead {
      font-size: 26px; }
    .need > p:not([class]) {
      text-align: justify; }
      .need > p:not([class]) br {
        display: none; }
    .need .list {
      margin: 40px auto;
      display: block; }
      .need .list li {
        width: 100%;
        padding: 0;
        margin-bottom: 30px; }
        .need .list li:last-of-type {
          margin-bottom: 0; }

  .review {
    padding: 50px 0; }
    .review .f_inner {
      display: block; }
    .review .text {
      width: 100%; }
      .review .text .lead {
        font-size: 28px; }
    .review .img {
      width: 100%;
      height: 0;
      padding-top: 60%;
      position: relative;
      overflow: hidden; }
      .review .img img {
        width: 100%;
        position: absolute;
        left: 0;
        top: 0; }

  .after {
    padding: 50px 0 0; }
    .after .f_inner {
      display: block; }
    .after .text {
      width: 100%; }
      .after .text .lead {
        font-size: 28px; }
    .after .img {
      width: 100%;
      height: 0;
      padding-top: 60%;
      position: relative;
      overflow: hidden; }
      .after .img img {
        width: 100%;
        position: absolute;
        left: 0;
        top: 0; } }
/* ------------------------------------------------------------------------------------------------------------------------

 Responsive-Breakpoint-3 ( 644px )
 
------------------------------------------------------------------------------------------------------------------------ */
@media only screen and (max-width: 644px) {
  .intro {
    margin-bottom: 100px; }
    .intro .catch {
      font-size: 24px; }
    .intro p:not([class]) {
      text-align: justify;
      margin: 0 auto 20px; }
    .intro .img {
      height: 200px; }

  .need {
    padding: 40px 25px 20px;
    margin-bottom: 40px; }
    .need .lead {
      white-space: nowrap;
      padding: 0 5px;
      top: -15px;
      font-size: 23px; }
    .need .list {
      margin: 30px auto; }
      .need .list li {
        margin-bottom: 20px; }
        .need .list li .inner .text {
          padding: 15px; }
    .need .em {
      font-size: 16px; }
      .need .em span i {
        font-size: 20px; }

  .review {
    padding: 40px 0; }
    .review .text .lead {
      font-size: 24px; }
    .review .img {
      padding-top: 66%; }

  .after {
    padding: 40px 0 0; }
    .after .text .lead {
      font-size: 24px; }
    .after .img {
      padding-top: 66%; } }
