body {
  background: #f4f1e9; }

.allwrap {
  /*
  overflow: hidden;
  */ }

#hasei_main {
  height: 870px; }

#hasei_main .img_area img {
  -webkit-filter: blur(0);
          filter: blur(0); }

@media screen and (max-width: 800px) {
  #hasei_main {
    height: 600px; }
    #hasei_main img {
      width: 154%; }

  #hasei_main .img_area {
    padding-top: 440px; }

  #hasei_main span {
    display: none; } }
/* ==========================================================================
	flow
========================================================================== */
.flow {
  width: 86.666%;
  margin: 0 auto;
  padding: 10vw 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start; }
  .flow .fit_img {
    display: none; }
  .flow_inner {
    width: 76.923%; }
  .flow .side_area {
    width: 16.923%;
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    -webkit-box-ordinal-group: 0;
        -ms-flex-order: -1;
            order: -1; }
  .flow_item {
    position: relative;
    padding: 0 8%;
    background-color: #fff;
    border-radius: 5px; }
    .flow_item:not(:last-of-type) {
      margin-bottom: 50px; }
    .flow_item .num {
      color: #fff;
      font-size: clamp(22px, 2.13vw, 32px);
      letter-spacing: 0.03em;
      width: 220px;
      height: 100px;
      width: clamp(180px, 14.666vw, 220px);
      height: clamp(80px, 6.666vw, 100px);
      position: absolute;
      top: 0;
      left: 0;
      background-color: var(--base-link-color);
      border-radius: 5px 0 10px 0;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center; }
    .flow_item_head {
      position: relative;
      padding-top: 60px;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
      -webkit-box-pack: justify;
          -ms-flex-pack: justify;
              justify-content: space-between;
      -webkit-box-align: end;
          -ms-flex-align: end;
              align-items: flex-end; }
      .flow_item_head .img_area {
        text-align: right;
        width: 240px;
        position: relative; }
        .flow_item_head .img_area::before {
          content: '';
          display: block;
          position: absolute;
          background-repeat: no-repeat;
          background-position: right top;
          background-size: 100%; }
      .flow_item_head .text_box {
        width: 66.666%;
        width: calc(95.238% - 240px);
        padding: 60px 0;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
        -ms-flex-line-pack: center;
            align-content: center; }
      .flow_item_head h2 {
        color: var(--base-link-color);
        font-size: var(--fz22);
        font-weight: 500;
        line-height: 1.4;
        letter-spacing: 0.1em;
        margin-bottom: 0.9em; }
      .flow_item_head .txt {
        font-size: var(--fz16);
        line-height: 2.125;
        letter-spacing: 0.1em; }
    .flow_item#step01 .flow_item_head, .flow_item#step02 .flow_item_head {
      border-bottom: 1px solid #ebe5d5; }
    .flow_item#step01 {
      padding-bottom: 90px; }
      .flow_item#step01 .flow_item_head {
        margin-bottom: 40px; }
        .flow_item#step01 .flow_item_head .img_area {
          margin-right: 4.761%; }
          .flow_item#step01 .flow_item_head .img_area::before {
            width: 27px;
            height: 160px;
            right: 4.449%;
            bottom: 130px;
            background-image: url(../image/flow/comment01.png); }
          .flow_item#step01 .flow_item_head .img_area img {
            width: 74.166%; }
    .flow_item#step02 {
      padding-bottom: 80px; }
      .flow_item#step02 .flow_item_head {
        margin-bottom: 50px; }
        .flow_item#step02 .flow_item_head .img_area {
          margin-right: 2.380%; }
          .flow_item#step02 .flow_item_head .img_area::before {
            width: 27px;
            height: 158px;
            right: 4.166%;
            bottom: 118px;
            background-image: url(../image/flow/comment02.png); }
          .flow_item#step02 .flow_item_head .img_area img {
            width: 100%; }
    .flow_item#step03 .flow_item_head .img_area {
      margin-right: 1.666%; }
      .flow_item#step03 .flow_item_head .img_area::before {
        width: 47px;
        height: 136px;
        right: -5.909%;
        bottom: 141px;
        background-image: url(../image/flow/comment03.png); }
      .flow_item#step03 .flow_item_head .img_area img {
        width: 91.666%; }
    .flow_item#step04 .flow_item_head .img_area {
      margin-right: 1.666%; }
      .flow_item#step04 .flow_item_head .img_area::before {
        width: 48px;
        height: 156px;
        right: -7.777%;
        bottom: 131px;
        background-image: url(../image/flow/comment04.png); }
      .flow_item#step04 .flow_item_head .img_area img {
        width: 75%; }
    .flow_item_list ul li {
      font-size: var(--fz17);
      letter-spacing: 0.1em;
      line-height: 1.714;
      position: relative;
      padding: 26px 3.571% 26px calc(3.571% + 36px);
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center; }
      .flow_item_list ul li:nth-child(odd) {
        background-color: #faf8f4; }
      .flow_item_list ul li::before, .flow_item_list ul li::after {
        content: '';
        display: block;
        position: absolute;
        left: 3.571%;
        z-index: 1; }
      .flow_item_list ul li::before {
        width: 22px;
        height: 22px;
        content: '';
        display: block;
        position: absolute;
        top: 30px;
        background-color: #fff;
        border: 2px solid var(--base-link-color);
        border-radius: 5px;
        -webkit-box-sizing: border-box;
                box-sizing: border-box; }
      .flow_item_list ul li::after {
        width: 8px;
        height: 4px;
        top: 37px;
        left: calc(3.571% + 6px);
        border-left: 2px solid #de3900;
        border-bottom: 2px solid #de3900;
        -webkit-transform: rotate(-45deg);
                transform: rotate(-45deg);
        z-index: 2; }
    .flow_item_plan {
      margin-bottom: clamp(40px, 4vw, 80px); }
      .flow_item_plan ul li {
        position: relative;
        padding: 4.761%;
        background-color: #f4f1e9;
        border-radius: 5px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        -webkit-box-pack: justify;
            -ms-flex-pack: justify;
                justify-content: space-between; }
        .flow_item_plan ul li:not(:last-of-type) {
          margin-bottom: 10px; }
        .flow_item_plan ul li:nth-child(1)::before, .flow_item_plan ul li:nth-child(1)::after, .flow_item_plan ul li:nth-child(2)::before, .flow_item_plan ul li:nth-child(2)::after {
          content: '';
          display: block;
          position: absolute;
          background-color: var(--base-yellow-color02);
          z-index: 2; }
        .flow_item_plan ul li:nth-child(1)::before, .flow_item_plan ul li:nth-child(2)::before {
          width: 50px;
          height: 10px;
          left: 42px;
          bottom: -10px; }
        .flow_item_plan ul li:nth-child(1)::after, .flow_item_plan ul li:nth-child(2)::after {
          width: 10px;
          height: 50px;
          left: 61px;
          bottom: -30px; }
        .flow_item_plan ul li .text_box {
          width: 50%;
          padding: 3.571% 0 5.238%; }
          .flow_item_plan ul li .text_box h3 {
            font-size: var(--fz28);
            font-weight: 500;
            letter-spacing: 0.1em;
            line-height: 1.3;
            margin-bottom: 14px; }
          .flow_item_plan ul li .text_box .en {
            color: var(--base-link-color);
            font-size: 13px;
            margin-bottom: 28px; }
          .flow_item_plan ul li .text_box .txt {
            font-size: var(--fz15);
            line-height: 2.133;
            letter-spacing: 0.1em; }
        .flow_item_plan ul li .img_area {
          width: 42.851%; }
          .flow_item_plan ul li .img_area img {
            border-radius: 5px; }
    .flow_item .bnr_plan a:hover {
      opacity: 0.6; }
  .flow .p-menu {
    padding: 100px 0 0 22.727%; }
    .flow .p-menu li {
      margin-bottom: 80px; }
      .flow .p-menu li:not(:last-of-type) a::after {
        width: 2px;
        height: 80px;
        content: '';
        display: block;
        position: absolute;
        left: 9px;
        top: 20px;
        background-color: #ebe5d5; }
      .flow .p-menu li a {
        position: relative;
        display: inline-block;
        padding-left: 28px;
        margin-right: 38px; }
        .flow .p-menu li a:before {
          content: "";
          display: block;
          width: 20px;
          height: 20px;
          background: #fff;
          border: 5px solid #ebe5d5;
          -webkit-box-sizing: border-box;
                  box-sizing: border-box;
          border-radius: 50%;
          position: absolute;
          left: 0;
          top: -1px;
          -webkit-transition: border 0.4s var(--easeOutQuad);
          transition: border 0.4s var(--easeOutQuad); }
        .flow .p-menu li a span {
          position: relative;
          font-size: 20px;
          font-size: var(--fz20);
          letter-spacing: 0.05em;
          color: #dccfad;
          -webkit-transition: color 0.4s var(--easeOutQuad);
          transition: color 0.4s var(--easeOutQuad); }
        .flow .p-menu li a:hover::before {
          border-color: var(--base-link-color);
          -webkit-transition: border 0.4s var(--easeOutQuad);
          transition: border 0.4s var(--easeOutQuad); }
        .flow .p-menu li a:hover span {
          color: var(--base-link-color);
          -webkit-transition: color 0.4s var(--easeOutQuad);
          transition: color 0.4s var(--easeOutQuad); }
      .flow .p-menu li.active a::before {
        border-color: var(--base-link-color);
        -webkit-transition: border 0.4s var(--easeOutQuad);
        transition: border 0.4s var(--easeOutQuad); }
      .flow .p-menu li.active a span {
        color: var(--base-link-color);
        -webkit-transition: color 0.4s var(--easeOutQuad);
        transition: color 0.4s var(--easeOutQuad); }

@media screen and (max-width: 800px) {
  .flow {
    width: 100%;
    padding: 0; }
    .flow_inner {
      width: 100%; }
    .flow_item {
      margin-bottom: 0;
      padding: 0 6.41%;
      border-bottom: 5px solid var(--base-link-color);
      border-left: 10px solid var(--base-link-color);
      border-radius: 0; }
      .flow_item:not(:last-of-type) {
        margin-bottom: 0; }
      .flow_item .num {
        font-size: var(--fz20);
        width: 140px;
        height: 60px;
        border-radius: 0; }
      .flow_item_head .text_box {
        width: 100%;
        padding: 0; }
      .flow_item_head h2 {
        font-size: var(--fz19);
        font-weight: 500;
        line-height: 1.4;
        letter-spacing: 0.1em;
        margin-bottom: 0.9em; }
      .flow_item_head .txt {
        font-size: var(--fz15);
        line-height: 2.125;
        letter-spacing: 0.1em; }
      .flow_item#step01 {
        padding-bottom: 50px; }
        .flow_item#step01 .flow_item_head {
          padding-top: 105px;
          border-bottom: none; }
      .flow_item#step02 .flow_item_head {
        border-bottom: none; }
      .flow_item#step03 .flow_item_head {
        padding-bottom: 80px; }
      .flow_item#step04 .flow_item_head {
        padding-bottom: 50px; }
      .flow_item#step02 .num, .flow_item#step03 .num, .flow_item#step04 .num {
        margin-top: -35px; }
      .flow_item_list ul li {
        font-size: var(--fz14);
        padding: 23px 15px 23px 45px; }
        .flow_item_list ul li::before, .flow_item_list ul li::after {
          z-index: 1; }
        .flow_item_list ul li::before {
          width: 19px;
          height: 19px;
          top: 26px;
          left: 15px;
          border-width: 1px; }
        .flow_item_list ul li::after {
          width: 7px;
          height: 4px;
          top: 32px;
          left: 20px; }
      .flow_item_plan {
        margin-bottom: 25px; }
        .flow_item_plan ul li {
          position: relative;
          padding: 7.35%;
          background-color: #f4f1e9;
          border-radius: 5px;
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -ms-flex-wrap: wrap;
              flex-wrap: wrap;
          -webkit-box-align: center;
              -ms-flex-align: center;
                  align-items: center;
          -webkit-box-pack: justify;
              -ms-flex-pack: justify;
                  justify-content: space-between; }
          .flow_item_plan ul li:not(:last-of-type) {
            margin-bottom: 10px; }
          .flow_item_plan ul li:nth-child(1)::before, .flow_item_plan ul li:nth-child(1)::after, .flow_item_plan ul li:nth-child(2)::before, .flow_item_plan ul li:nth-child(2)::after {
            content: '';
            display: block;
            position: absolute;
            background-color: var(--base-yellow-color02);
            z-index: 2; }
          .flow_item_plan ul li:nth-child(1)::before, .flow_item_plan ul li:nth-child(2)::before {
            width: 48px;
            height: 10px;
            left: calc(50% - 24px);
            bottom: -10px; }
          .flow_item_plan ul li:nth-child(1)::after, .flow_item_plan ul li:nth-child(2)::after {
            width: 10px;
            height: 48px;
            left: calc(50% - 5px);
            bottom: -29px; }
          .flow_item_plan ul li .text_box {
            width: 100%;
            padding: 28px 0 14px; }
            .flow_item_plan ul li .text_box h3 {
              font-size: var(--fz20);
              text-align: center;
              margin-bottom: 14px; }
            .flow_item_plan ul li .text_box .en {
              font-size: 13px;
              text-align: center;
              margin-bottom: 13px; }
            .flow_item_plan ul li .text_box .txt {
              font-size: var(--fz14);
              line-height: 1.714; }
          .flow_item_plan ul li .img_area {
            width: 100%;
            -webkit-box-ordinal-group: 0;
                -ms-flex-order: -1;
                    order: -1; } }

/*# sourceMappingURL=flow.css.map */