#recruit {
  position: relative;
  z-index: 0; }
  #recruit::after {
    position: absolute;
    bottom: 0;
    left: 0;
    content: "";
    display: block;
    width: 100%;
    height: 360px;
    background-color: #fff;
    z-index: -1; }
    @media (max-width: 480px) {
      #recruit::after {
        content: none; } }
  @media (max-width: 480px) {
    #recruit.section {
      padding-bottom: 0; } }
  #recruit .section_content {
    max-width: 1600px;
    height: auto;
    margin: 0 auto; }
    @media (max-width: 480px) {
      #recruit .section_content {
        max-width: 100%; } }
    #recruit .section_content .section_inner {
      position: relative;
      max-width: 1350px;
      margin-left: 15.6%; }
      @media (max-width: 480px) {
        #recruit .section_content .section_inner {
          max-width: 100%;
          margin-left: 4%; } }
      #recruit .section_content .section_inner .section_title .en {
        position: relative;
        left: -8px;
        bottom: 8px;
        font-size: 15.2rem;
        font-weight: 800;
        line-height: 0.7;
        letter-spacing: 0;
        color: #fff; }
        @media (max-width: 480px) {
          #recruit .section_content .section_inner .section_title .en {
            left: -1.0256410256vw;
            bottom: 1.2820512821vw;
            font-size: 19.2307692308vw;
            letter-spacing: -0.6666666667vw; } }
      #recruit .section_content .section_inner .txt {
        position: relative;
        height: auto;
        font-size: 1.4rem;
        font-weight: 500;
        background-color: #fff;
        padding: 45px 100px 260px; }
        @media (max-width: 480px) {
          #recruit .section_content .section_inner .txt {
            font-size: 4.1025641026vw;
            line-height: 1.45;
            padding: 11.2820512821vw 4% 8.9743589744vw; } }
        #recruit .section_content .section_inner .txt p {
          letter-spacing: 0; }
          #recruit .section_content .section_inner .txt p:not(:last-child) {
            margin-bottom: 25px; }
            @media (max-width: 480px) {
              #recruit .section_content .section_inner .txt p:not(:last-child) {
                margin-bottom: 6.4102564103vw; } }
        #recruit .section_content .section_inner .txt .v-rl {
          position: absolute;
          top: -110px;
          left: 50%;
          -webkit-transform: translateX(260%);
                  transform: translateX(260%);
          font-size: 4rem;
          font-weight: bold;
          letter-spacing: 0.4rem;
          -webkit-writing-mode: vertical-rl;
              -ms-writing-mode: tb-rl;
                  writing-mode: vertical-rl;
          text-orientation: upright; }
          @media (max-width: 480px) {
            #recruit .section_content .section_inner .txt .v-rl {
              top: -4.6153846154vw;
              left: 4.8717948718vw;
              -webkit-transform: none;
                      transform: none;
              font-size: 5.1282051282vw;
              letter-spacing: 0.5128205128vw;
              -webkit-writing-mode: inherit;
                  -ms-writing-mode: inherit;
                      writing-mode: inherit; } }
          #recruit .section_content .section_inner .txt .v-rl .bg-b {
            color: #fff;
            background-color: #333;
            padding: 10px 0;
            margin-top: 5px; }
            @media (max-width: 480px) {
              #recruit .section_content .section_inner .txt .v-rl .bg-b {
                padding: 0.7692307692vw 1.0256410256vw; } }
    #recruit .section_content .img {
      position: relative;
      top: -225px;
      left: 50%;
      -webkit-transform: translateX(-76.3%);
              transform: translateX(-76.3%);
      max-width: 1048px;
      width: 100%;
      height: auto;
      margin-bottom: -125px; }
      @media (max-width: 480px) {
        #recruit .section_content .img {
          top: -5.3846153846vw;
          left: 0;
          -webkit-transform: none;
                  transform: none;
          max-width: 100%;
          width: 91.0256410256vw;
          margin-bottom: 0; } }
  #recruit #list {
    width: 1100px;
    margin: 0 auto; }
    @media (max-width: 480px) {
      #recruit #list {
        width: 100%; } }
    #recruit #list.section {
      padding: 0; }
      @media (max-width: 480px) {
        #recruit #list.section {
          padding-top: 5.1282051282vw; } }
    #recruit #list .flex_in {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: justify;
          -ms-flex-pack: justify;
              justify-content: space-between;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      margin-bottom: 30px; }
      @media (max-width: 480px) {
        #recruit #list .flex_in {
          -webkit-box-orient: vertical;
          -webkit-box-direction: normal;
              -ms-flex-direction: column;
                  flex-direction: column;
          gap: 7.6923076923vw;
          margin: 0 8%; } }
      #recruit #list .flex_in .list_item {
        display: grid;
        grid-template-rows: 150px 70px auto;
        justify-items: center;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        width: 344px;
        min-height: 378px;
        background-color: #fff;
        -webkit-box-shadow: 1px 1px 16px 0 rgba(213, 213, 213, 0.4);
                box-shadow: 1px 1px 16px 0 rgba(213, 213, 213, 0.4);
        mix-blend-mode: multiply;
        padding: 40px 27px 30px; }
        @media (max-width: 480px) {
          #recruit #list .flex_in .list_item {
            grid-template-rows: 23.5897435897vw 11.7948717949vw auto;
            width: 100%;
            min-height: 65.2564102564vw;
            padding: 6.4102564103vw 6.1538461538vw; } }
        #recruit #list .flex_in .list_item .icon {
          width: 140px;
          height: auto; }
          @media (max-width: 480px) {
            #recruit #list .flex_in .list_item .icon {
              width: 21.7948717949vw; } }
        #recruit #list .flex_in .list_item .ttl {
          font-size: 2.4rem;
          font-weight: 600; }
          @media (max-width: 480px) {
            #recruit #list .flex_in .list_item .ttl {
              font-size: 4.6153846154vw; } }
        #recruit #list .flex_in .list_item .txt {
          -ms-flex-item-align: start;
              align-self: flex-start;
          line-height: 1.4; }
          @media (max-width: 480px) {
            #recruit #list .flex_in .list_item .txt {
              font-size: 4.1025641026vw; } }
    #recruit #list .link_btn {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: end;
          -ms-flex-pack: end;
              justify-content: flex-end; }
      @media (max-width: 480px) {
        #recruit #list .link_btn {
          padding-top: 7.6923076923vw;
          margin-right: 4%; } }
      #recruit #list .link_btn a {
        display: -webkit-inline-box;
        display: -ms-inline-flexbox;
        display: inline-flex;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        font-size: 2rem;
        color: #333;
        text-decoration: none; }
        @media (max-width: 480px) {
          #recruit #list .link_btn a {
            font-size: 4.6153846154vw; } }
        #recruit #list .link_btn a .arrow {
          display: -webkit-inline-box;
          display: -ms-inline-flexbox;
          display: inline-flex;
          -webkit-box-pack: center;
              -ms-flex-pack: center;
                  justify-content: center;
          -webkit-box-align: center;
              -ms-flex-align: center;
                  align-items: center;
          width: 34px;
          height: 34px;
          background-color: #2183ca;
          border-radius: 50%;
          margin-left: 16px; }
          @media (max-width: 480px) {
            #recruit #list .link_btn a .arrow {
              width: 7.6923076923vw;
              height: 7.6923076923vw; } }
          #recruit #list .link_btn a .arrow img {
            position: relative;
            width: 11px;
            height: 9px;
            -webkit-transform: translateX(0);
                    transform: translateX(0);
            -webkit-transition: -webkit-transform 0.3s;
            transition: -webkit-transform 0.3s;
            transition: transform 0.3s;
            transition: transform 0.3s, -webkit-transform 0.3s; }
            @media (max-width: 480px) {
              #recruit #list .link_btn a .arrow img {
                width: 2.5641025641vw;
                height: 2.0512820513vw; } }
        @media (min-width: 480px) {
          #recruit #list .link_btn a:hover {
            color: #2183ca; }
            #recruit #list .link_btn a:hover .arrow img {
              -webkit-transform: translateX(5px);
                      transform: translateX(5px); } }

@media (max-width: 480px) {
  #flow.section {
    padding: 0; } }
@media (max-width: 480px) {
  #flow .wrap {
    padding: 0; } }
@media (max-width: 480px) {
  #flow .wrap .section_title .jp {
    padding-left: 4%; } }
#flow .flow_list .list_item {
  position: relative; }
  #flow .flow_list .list_item:not(:last-child) {
    margin-bottom: 70px; }
    @media (max-width: 480px) {
      #flow .flow_list .list_item:not(:last-child) {
        margin-bottom: 16.1538461538vw; } }
  #flow .flow_list .list_item .num {
    display: inline-block;
    position: relative;
    left: -5px;
    top: 8px;
    font-size: 8.76rem;
    font-weight: 800;
    line-height: 0.8;
    color: #fff; }
    @media (max-width: 480px) {
      #flow .flow_list .list_item .num {
        position: absolute;
        left: auto;
        right: 0;
        top: -8.7179487179vw;
        font-size: 11.5384615385vw; } }
  #flow .flow_list .list_item .list_item_inner {
    display: grid;
    grid-template-columns: 160px 1fr;
    grid-template-rows: 40% 60%;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    justify-items: start;
    width: 100%;
    min-height: 134px;
    background-color: #fff;
    padding: 25.5px 35px; }
    @media (max-width: 480px) {
      #flow .flow_list .list_item .list_item_inner {
        grid-template-columns: 1fr;
        grid-template-rows: 10.2564102564vw auto;
        min-height: 43.4615384615vw;
        height: 100%;
        padding: 7.6923076923vw 8%; } }
    #flow .flow_list .list_item .list_item_inner .icon {
      grid-column: 1 / 2;
      grid-row: 1 / 3;
      width: 117px;
      height: auto; }
      @media (max-width: 480px) {
        #flow .flow_list .list_item .list_item_inner .icon {
          display: none; } }
    #flow .flow_list .list_item .list_item_inner .ttl {
      grid-column: 2 / 3;
      grid-row: 1 / 2;
      -ms-flex-item-align: start;
          align-self: flex-start;
      font-size: 2.4rem;
      font-weight: 600;
      line-height: 1;
      color: #2183ca; }
      @media (max-width: 480px) {
        #flow .flow_list .list_item .list_item_inner .ttl {
          grid-column: 1 / 2;
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -webkit-box-pack: center;
              -ms-flex-pack: center;
                  justify-content: center;
          -webkit-box-align: center;
              -ms-flex-align: center;
                  align-items: center;
          justify-self: center;
          font-size: 4.6153846154vw;
          margin-bottom: 2.0512820513vw; } }
      #flow .flow_list .list_item .list_item_inner .ttl .sp-icon {
        display: none; }
        @media (max-width: 480px) {
          #flow .flow_list .list_item .list_item_inner .ttl .sp-icon {
            display: inline-block;
            width: 10.8974358974vw;
            margin-left: 2.5641025641vw; } }
    #flow .flow_list .list_item .list_item_inner .txt {
      grid-column: 2 / 3;
      grid-row: 2 / 3;
      -ms-flex-item-align: end;
          align-self: flex-end; }
      @media (max-width: 480px) {
        #flow .flow_list .list_item .list_item_inner .txt {
          grid-column: 1 / 2; } }
      #flow .flow_list .list_item .list_item_inner .txt ul {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap; }
        #flow .flow_list .list_item .list_item_inner .txt ul li {
          display: inline-block;
          line-height: 1.4; }
          @media (max-width: 480px) {
            #flow .flow_list .list_item .list_item_inner .txt ul li {
              font-size: 3.8461538462vw;
              line-height: 1.6;
              text-indent: -3.8461538462vw;
              padding-left: 3.8461538462vw; } }
          #flow .flow_list .list_item .list_item_inner .txt ul li:not(:last-child) {
            margin-right: 40px; }
            @media (max-width: 480px) {
              #flow .flow_list .list_item .list_item_inner .txt ul li:not(:last-child) {
                margin-right: 0; } }
  @media (max-width: 480px) {
    #flow .flow_list .list_item.list01 .list_item_inner .ttl .sp-icon {
      margin-left: 0; } }
  @media (max-width: 480px) {
    #flow .flow_list .list_item.list02 .list_item_inner .ttl {
      margin-bottom: 2.5641025641vw; } }
@media (max-width: 480px) {
  #flow .flow_list.list-top {
    padding-top: 23.0769230769vw; } }
#flow .flow_list.list-top .list_item .list_item_inner .ttl,
#flow .flow_list.list-top .list_item .list_item_inner .txt {
  -ms-flex-item-align: center;
      align-self: center; }

#overview .section_title .en {
  left: -5%; }
@media (max-width: 480px) {
  #overview .table_base {
    padding-top: 12.8205128205vw; } }

#flow .section_title,
#overview .section_title {
  position: relative;
  margin-bottom: 55px; }
  #flow .section_title .en,
  #overview .section_title .en {
    font-size: 15.2rem;
    font-weight: 800;
    line-height: 0.7;
    letter-spacing: 0;
    color: #565656;
    opacity: 0.08;
    mix-blend-mode: multiply; }
    @media (max-width: 480px) {
      #flow .section_title .en,
      #overview .section_title .en {
        position: absolute;
        top: -15.1282051282vw;
        height: 242.5641025641vw;
        font-size: 31.2179487179vw;
        line-height: 0.7;
        letter-spacing: 0.2564102564vw;
        -webkit-writing-mode: sideways-rl;
            -ms-writing-mode: sideways-rl;
                writing-mode: sideways-rl;
        text-orientation: upright; } }
  #flow .section_title .jp,
  #overview .section_title .jp {
    position: absolute;
    left: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: 3rem;
    font-weight: bold;
    line-height: 1;
    letter-spacing: 0.4rem; }
    @media (max-width: 480px) {
      #flow .section_title .jp,
      #overview .section_title .jp {
        -webkit-transform: translateY(-14%);
                transform: translateY(-14%);
        font-size: 6.4102564103vw;
        letter-spacing: 1.0256410256vw; } }
    #flow .section_title .jp .sub,
    #overview .section_title .jp .sub {
      font-size: 2rem;
      color: #333;
      padding-left: 30px; }
      @media (max-width: 480px) {
        #flow .section_title .jp .sub,
        #overview .section_title .jp .sub {
          font-size: 4.6153846154vw;
          letter-spacing: 0.2564102564vw;
          padding-left: 3.8461538462vw; } }

.message_content {
  background-color: #fff;
  border-radius: 10px;
  padding: 20px;
  margin-bottom: 60px; }
  @media (max-width: 480px) {
    .message_content {
      font-size: 3.8461538462vw;
      padding: 2.5641025641vw 0;
      margin-bottom: 7.6923076923vw; } }
  .message_content .ttl {
    font-size: 2.8rem;
    font-weight: bold;
    text-align: center;
    margin-bottom: 20px; }
    @media (max-width: 480px) {
      .message_content .ttl {
        font-size: 6.4102564103vw; } }
  .message_content .flex_in {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 40px; }
    @media (max-width: 480px) {
      .message_content .flex_in {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        gap: 5.1282051282vw; } }
    .message_content .flex_in .logo {
      width: 20%;
      margin: 0 auto; }
      @media (max-width: 480px) {
        .message_content .flex_in .logo {
          width: 40%; } }
    .message_content .flex_in .msg {
      width: 73%; }
      @media (max-width: 480px) {
        .message_content .flex_in .msg {
          width: 100%; } }
      .message_content .flex_in .msg .large {
        font-size: 2.4rem;
        font-weight: 500; }
        @media (max-width: 480px) {
          .message_content .flex_in .msg .large {
            font-size: 4.6153846154vw; } }
      .message_content .flex_in .msg .signature {
        font-size: 1.8rem;
        line-height: 1.6;
        text-align: right;
        padding-top: 10px; }
        @media (max-width: 480px) {
          .message_content .flex_in .msg .signature {
            font-size: 4.1025641026vw;
            padding-top: 1.2820512821vw; } }

.table_ttl {
  font-size: 2.8rem;
  font-weight: bold;
  text-align: center;
  margin-bottom: 20px; }
  @media (max-width: 480px) {
    .table_ttl {
      font-size: 6.4102564103vw; } }
