@charset "UTF-8";
@media screen and (max-width: 1400px) {
  /***************************************************************
  サブ共通
  ***************************************************************/
  main .table01 tr th {
    width: 150px;
  }
  main .table01 tr td {
    width: calc(100% - 150px);
  }
  /***************************************************************
  company
  ***************************************************************/
  main .company02 .company02_inner .company02_row .company02_row_item.company02_row_right {
    padding-left: 50px;
  }
}
@media screen and (max-width: 767px) {
  /*----------------------------------------------------------------

  フォントサイズ

  ----------------------------------------------------------------*/
  .f_10 {
    font-size: 2.8vw;
  }
  .f_12 {
    font-size: 2.8vw;
  }
  .f_14 {
    font-size: 2.8vw;
  }
  .f_16 {
    font-size: 3.2vw;
  }
  .f_18 {
    font-size: 3.6vw;
  }
  .f_20 {
    font-size: 3.8vw;
  }
  .f_22 {
    font-size: 4vw;
  }
  .f_24 {
    font-size: 4.2vw;
  }
  .f_26 {
    font-size: 4.4vw;
  }
  .f_28 {
    font-size: 4.6vw;
  }
  .f_30 {
    font-size: 4.6vw;
  }
  .f_32 {
    font-size: 4.8vw;
  }
  .f_34 {
    font-size: 4.8vw;
  }
  .f_36 {
    font-size: 4.8vw;
  }
  .f_38 {
    font-size: 5vw;
  }
  .f_40 {
    font-size: 5vw;
  }
  .f_42 {
    font-size: 5vw;
  }
  .f_44 {
    font-size: 5.2vw;
  }
  .f_46 {
    font-size: 5.2vw;
  }
  .f_48 {
    font-size: 5.4vw;
  }
  .f_50 {
    font-size: 5.4vw;
  }
  .f_52 {
    font-size: 5.6vw;
  }
  .f_54 {
    font-size: 5.6vw;
  }
  .f_56 {
    font-size: 5.8vw;
  }
  .f_58 {
    font-size: 5.8vw;
  }
  .f_60 {
    font-size: 6vw;
  }
  .f_62 {
    font-size: 6vw;
  }
  .f_64 {
    font-size: 6.2vw;
  }
  .f_66 {
    font-size: 6.2vw;
  }
  .f_68 {
    font-size: 6.4vw;
  }
  .f_70 {
    font-size: 6.4vw;
  }
  .f_72 {
    font-size: 6.6vw;
  }
  .f_74 {
    font-size: 6.6vw;
  }
  .f_76 {
    font-size: 6.8vw;
  }
  .f_78 {
    font-size: 6.8vw;
  }
  .f_80 {
    font-size: 7vw;
  }
  .f_82 {
    font-size: 7vw;
  }
  .f_84 {
    font-size: 7.2vw;
  }
  .f_86 {
    font-size: 7.2vw;
  }
  .f_88 {
    font-size: 7.4vw;
  }
  .f_90 {
    font-size: 7.4vw;
  }
  .f_92 {
    font-size: 7.6vw;
  }
  .f_94 {
    font-size: 7.6vw;
  }
  .f_96 {
    font-size: 7.8vw;
  }
  .f_98 {
    font-size: 7.8vw;
  }
  .f_100 {
    font-size: 8vw;
  }
  .f_102 {
    font-size: 8vw;
  }
  .f_104 {
    font-size: 8.2vw;
  }
  .f_106 {
    font-size: 8.2vw;
  }
  .f_108 {
    font-size: 8.4vw;
  }
  .f_110 {
    font-size: 8.4vw;
  }
  .f_112 {
    font-size: 8.6vw;
  }
  .f_114 {
    font-size: 8.6vw;
  }
  .f_116 {
    font-size: 8.8vw;
  }
  .f_118 {
    font-size: 8.8vw;
  }
  .f_120 {
    font-size: 9vw;
  }
  .f_122 {
    font-size: 9vw;
  }
  .f_124 {
    font-size: 9.2vw;
  }
  .f_126 {
    font-size: 9.2vw;
  }
  .f_128 {
    font-size: 9.4vw;
  }
  .f_130 {
    font-size: 9.4vw;
  }
  .f_132 {
    font-size: 9.6vw;
  }
  .f_134 {
    font-size: 9.6vw;
  }
  .f_136 {
    font-size: 9.8vw;
  }
  .f_138 {
    font-size: 9.8vw;
  }
  .f_140 {
    font-size: 10vw;
  }
  .f_142 {
    font-size: 10vw;
  }
  .f_144 {
    font-size: 10.2vw;
  }
  .f_146 {
    font-size: 10.2vw;
  }
  .f_148 {
    font-size: 10.4vw;
  }
  .f_150 {
    font-size: 10.4vw;
  }
  .f_152 {
    font-size: 10.6vw;
  }
  .f_154 {
    font-size: 10.6vw;
  }
  .f_156 {
    font-size: 10.8vw;
  }
  .f_158 {
    font-size: 10.8vw;
  }
  .f_160 {
    font-size: 11vw;
  }
  .f_162 {
    font-size: 11vw;
  }
  .f_164 {
    font-size: 11vw;
  }
  .mt10 {
    margin-top: 1vw;
  }
  .mb10 {
    margin-bottom: 1vw;
  }
  .ml10 {
    margin-left: 1vw;
  }
  .mr10 {
    margin-right: 1vw;
  }
  .my10 {
    margin-top: 1vw;
    margin-bottom: 1vw;
  }
  .mx10 {
    margin-left: 1vw;
    margin-right: 1vw;
  }
  .mt20 {
    margin-top: 2vw;
  }
  .mb20 {
    margin-bottom: 2vw;
  }
  .ml20 {
    margin-left: 2vw;
  }
  .mr20 {
    margin-right: 2vw;
  }
  .my20 {
    margin-top: 2vw;
    margin-bottom: 2vw;
  }
  .mx20 {
    margin-left: 2vw;
    margin-right: 2vw;
  }
  .mt30 {
    margin-top: 3vw;
  }
  .mb30 {
    margin-bottom: 3vw;
  }
  .ml30 {
    margin-left: 3vw;
  }
  .mr30 {
    margin-right: 3vw;
  }
  .my30 {
    margin-top: 3vw;
    margin-bottom: 3vw;
  }
  .mx30 {
    margin-left: 3vw;
    margin-right: 3vw;
  }
  .mt40 {
    margin-top: 4vw;
  }
  .mb40 {
    margin-bottom: 4vw;
  }
  .ml40 {
    margin-left: 4vw;
  }
  .mr40 {
    margin-right: 4vw;
  }
  .my40 {
    margin-top: 4vw;
    margin-bottom: 4vw;
  }
  .mx40 {
    margin-left: 4vw;
    margin-right: 4vw;
  }
  .mt50 {
    margin-top: 5vw;
  }
  .mb50 {
    margin-bottom: 5vw;
  }
  .ml50 {
    margin-left: 5vw;
  }
  .mr50 {
    margin-right: 5vw;
  }
  .my50 {
    margin-top: 5vw;
    margin-bottom: 5vw;
  }
  .mx50 {
    margin-left: 5vw;
    margin-right: 5vw;
  }
  .mt60 {
    margin-top: 6vw;
  }
  .mb60 {
    margin-bottom: 6vw;
  }
  .ml60 {
    margin-left: 6vw;
  }
  .mr60 {
    margin-right: 6vw;
  }
  .my60 {
    margin-top: 6vw;
    margin-bottom: 6vw;
  }
  .mx60 {
    margin-left: 6vw;
    margin-right: 6vw;
  }
  .mt70 {
    margin-top: 7vw;
  }
  .mb70 {
    margin-bottom: 7vw;
  }
  .ml70 {
    margin-left: 7vw;
  }
  .mr70 {
    margin-right: 7vw;
  }
  .my70 {
    margin-top: 7vw;
    margin-bottom: 7vw;
  }
  .mx70 {
    margin-left: 7vw;
    margin-right: 7vw;
  }
  .mt80 {
    margin-top: 8vw;
  }
  .mb80 {
    margin-bottom: 8vw;
  }
  .ml80 {
    margin-left: 8vw;
  }
  .mr80 {
    margin-right: 8vw;
  }
  .my80 {
    margin-top: 8vw;
    margin-bottom: 8vw;
  }
  .mx80 {
    margin-left: 8vw;
    margin-right: 8vw;
  }
  .mt90 {
    margin-top: 9vw;
  }
  .mb90 {
    margin-bottom: 9vw;
  }
  .ml90 {
    margin-left: 9vw;
  }
  .mr90 {
    margin-right: 9vw;
  }
  .my90 {
    margin-top: 9vw;
    margin-bottom: 9vw;
  }
  .mx90 {
    margin-left: 9vw;
    margin-right: 9vw;
  }
  .mt100 {
    margin-top: 10vw;
  }
  .mb100 {
    margin-bottom: 10vw;
  }
  .ml100 {
    margin-left: 10vw;
  }
  .mr100 {
    margin-right: 10vw;
  }
  .my100 {
    margin-top: 10vw;
    margin-bottom: 10vw;
  }
  .mx100 {
    margin-left: 10vw;
    margin-right: 10vw;
  }
  .mt110 {
    margin-top: 11vw;
  }
  .mb110 {
    margin-bottom: 11vw;
  }
  .ml110 {
    margin-left: 11vw;
  }
  .mr110 {
    margin-right: 11vw;
  }
  .my110 {
    margin-top: 11vw;
    margin-bottom: 11vw;
  }
  .mx110 {
    margin-left: 11vw;
    margin-right: 11vw;
  }
  .mt120 {
    margin-top: 12vw;
  }
  .mb120 {
    margin-bottom: 12vw;
  }
  .ml120 {
    margin-left: 12vw;
  }
  .mr120 {
    margin-right: 12vw;
  }
  .my120 {
    margin-top: 12vw;
    margin-bottom: 12vw;
  }
  .mx120 {
    margin-left: 12vw;
    margin-right: 12vw;
  }
  .mt130 {
    margin-top: 13vw;
  }
  .mb130 {
    margin-bottom: 13vw;
  }
  .ml130 {
    margin-left: 13vw;
  }
  .mr130 {
    margin-right: 13vw;
  }
  .my130 {
    margin-top: 13vw;
    margin-bottom: 13vw;
  }
  .mx130 {
    margin-left: 13vw;
    margin-right: 13vw;
  }
  .mt140 {
    margin-top: 14vw;
  }
  .mb140 {
    margin-bottom: 14vw;
  }
  .ml140 {
    margin-left: 14vw;
  }
  .mr140 {
    margin-right: 14vw;
  }
  .my140 {
    margin-top: 14vw;
    margin-bottom: 14vw;
  }
  .mx140 {
    margin-left: 14vw;
    margin-right: 14vw;
  }
  .mt150 {
    margin-top: 15vw;
  }
  .mb150 {
    margin-bottom: 15vw;
  }
  .ml150 {
    margin-left: 15vw;
  }
  .mr150 {
    margin-right: 15vw;
  }
  .my150 {
    margin-top: 15vw;
    margin-bottom: 15vw;
  }
  .mx150 {
    margin-left: 15vw;
    margin-right: 15vw;
  }
  .mt160 {
    margin-top: 16vw;
  }
  .mb160 {
    margin-bottom: 16vw;
  }
  .ml160 {
    margin-left: 16vw;
  }
  .mr160 {
    margin-right: 16vw;
  }
  .my160 {
    margin-top: 16vw;
    margin-bottom: 16vw;
  }
  .mx160 {
    margin-left: 16vw;
    margin-right: 16vw;
  }
  .mt170 {
    margin-top: 17vw;
  }
  .mb170 {
    margin-bottom: 17vw;
  }
  .ml170 {
    margin-left: 17vw;
  }
  .mr170 {
    margin-right: 17vw;
  }
  .my170 {
    margin-top: 17vw;
    margin-bottom: 17vw;
  }
  .mx170 {
    margin-left: 17vw;
    margin-right: 17vw;
  }
  .mt180 {
    margin-top: 18vw;
  }
  .mb180 {
    margin-bottom: 18vw;
  }
  .ml180 {
    margin-left: 18vw;
  }
  .mr180 {
    margin-right: 18vw;
  }
  .my180 {
    margin-top: 18vw;
    margin-bottom: 18vw;
  }
  .mx180 {
    margin-left: 18vw;
    margin-right: 18vw;
  }
  .mt190 {
    margin-top: 19vw;
  }
  .mb190 {
    margin-bottom: 19vw;
  }
  .ml190 {
    margin-left: 19vw;
  }
  .mr190 {
    margin-right: 19vw;
  }
  .my190 {
    margin-top: 19vw;
    margin-bottom: 19vw;
  }
  .mx190 {
    margin-left: 19vw;
    margin-right: 19vw;
  }
  .mt200 {
    margin-top: 20vw;
  }
  .mb200 {
    margin-bottom: 20vw;
  }
  .ml200 {
    margin-left: 20vw;
  }
  .mr200 {
    margin-right: 20vw;
  }
  .my200 {
    margin-top: 20vw;
    margin-bottom: 20vw;
  }
  .mx200 {
    margin-left: 20vw;
    margin-right: 20vw;
  }
  .mt210 {
    margin-top: 21vw;
  }
  .mb210 {
    margin-bottom: 21vw;
  }
  .ml210 {
    margin-left: 21vw;
  }
  .mr210 {
    margin-right: 21vw;
  }
  .my210 {
    margin-top: 21vw;
    margin-bottom: 21vw;
  }
  .mx210 {
    margin-left: 21vw;
    margin-right: 21vw;
  }
  .mt220 {
    margin-top: 22vw;
  }
  .mb220 {
    margin-bottom: 22vw;
  }
  .ml220 {
    margin-left: 22vw;
  }
  .mr220 {
    margin-right: 22vw;
  }
  .my220 {
    margin-top: 22vw;
    margin-bottom: 22vw;
  }
  .mx220 {
    margin-left: 22vw;
    margin-right: 22vw;
  }
  .mt230 {
    margin-top: 23vw;
  }
  .mb230 {
    margin-bottom: 23vw;
  }
  .ml230 {
    margin-left: 23vw;
  }
  .mr230 {
    margin-right: 23vw;
  }
  .my230 {
    margin-top: 23vw;
    margin-bottom: 23vw;
  }
  .mx230 {
    margin-left: 23vw;
    margin-right: 23vw;
  }
  .mt240 {
    margin-top: 24vw;
  }
  .mb240 {
    margin-bottom: 24vw;
  }
  .ml240 {
    margin-left: 24vw;
  }
  .mr240 {
    margin-right: 24vw;
  }
  .my240 {
    margin-top: 24vw;
    margin-bottom: 24vw;
  }
  .mx240 {
    margin-left: 24vw;
    margin-right: 24vw;
  }
  .mt250 {
    margin-top: 25vw;
  }
  .mb250 {
    margin-bottom: 25vw;
  }
  .ml250 {
    margin-left: 25vw;
  }
  .mr250 {
    margin-right: 25vw;
  }
  .my250 {
    margin-top: 25vw;
    margin-bottom: 25vw;
  }
  .mx250 {
    margin-left: 25vw;
    margin-right: 25vw;
  }
  .mt260 {
    margin-top: 26vw;
  }
  .mb260 {
    margin-bottom: 26vw;
  }
  .ml260 {
    margin-left: 26vw;
  }
  .mr260 {
    margin-right: 26vw;
  }
  .my260 {
    margin-top: 26vw;
    margin-bottom: 26vw;
  }
  .mx260 {
    margin-left: 26vw;
    margin-right: 26vw;
  }
  .mt270 {
    margin-top: 27vw;
  }
  .mb270 {
    margin-bottom: 27vw;
  }
  .ml270 {
    margin-left: 27vw;
  }
  .mr270 {
    margin-right: 27vw;
  }
  .my270 {
    margin-top: 27vw;
    margin-bottom: 27vw;
  }
  .mx270 {
    margin-left: 27vw;
    margin-right: 27vw;
  }
  .mt280 {
    margin-top: 28vw;
  }
  .mb280 {
    margin-bottom: 28vw;
  }
  .ml280 {
    margin-left: 28vw;
  }
  .mr280 {
    margin-right: 28vw;
  }
  .my280 {
    margin-top: 28vw;
    margin-bottom: 28vw;
  }
  .mx280 {
    margin-left: 28vw;
    margin-right: 28vw;
  }
  .mt290 {
    margin-top: 29vw;
  }
  .mb290 {
    margin-bottom: 29vw;
  }
  .ml290 {
    margin-left: 29vw;
  }
  .mr290 {
    margin-right: 29vw;
  }
  .my290 {
    margin-top: 29vw;
    margin-bottom: 29vw;
  }
  .mx290 {
    margin-left: 29vw;
    margin-right: 29vw;
  }
  .mt300 {
    margin-top: 30vw;
  }
  .mb300 {
    margin-bottom: 30vw;
  }
  .ml300 {
    margin-left: 30vw;
  }
  .mr300 {
    margin-right: 30vw;
  }
  .my300 {
    margin-top: 30vw;
    margin-bottom: 30vw;
  }
  .mx300 {
    margin-left: 30vw;
    margin-right: 30vw;
  }
  .pt10 {
    padding-top: 1vw;
  }
  .pb10 {
    padding-bottom: 1vw;
  }
  .pl10 {
    padding-left: 1vw;
  }
  .pr10 {
    padding-right: 1vw;
  }
  .py10 {
    padding-top: 1vw;
    padding-bottom: 1vw;
  }
  .px10 {
    padding-left: 1vw;
    padding-right: 1vw;
  }
  .pt20 {
    padding-top: 2vw;
  }
  .pb20 {
    padding-bottom: 2vw;
  }
  .pl20 {
    padding-left: 2vw;
  }
  .pr20 {
    padding-right: 2vw;
  }
  .py20 {
    padding-top: 2vw;
    padding-bottom: 2vw;
  }
  .px20 {
    padding-left: 2vw;
    padding-right: 2vw;
  }
  .pt30 {
    padding-top: 3vw;
  }
  .pb30 {
    padding-bottom: 3vw;
  }
  .pl30 {
    padding-left: 3vw;
  }
  .pr30 {
    padding-right: 3vw;
  }
  .py30 {
    padding-top: 3vw;
    padding-bottom: 3vw;
  }
  .px30 {
    padding-left: 3vw;
    padding-right: 3vw;
  }
  .pt40 {
    padding-top: 4vw;
  }
  .pb40 {
    padding-bottom: 4vw;
  }
  .pl40 {
    padding-left: 4vw;
  }
  .pr40 {
    padding-right: 4vw;
  }
  .py40 {
    padding-top: 4vw;
    padding-bottom: 4vw;
  }
  .px40 {
    padding-left: 4vw;
    padding-right: 4vw;
  }
  .pt50 {
    padding-top: 5vw;
  }
  .pb50 {
    padding-bottom: 5vw;
  }
  .pl50 {
    padding-left: 5vw;
  }
  .pr50 {
    padding-right: 5vw;
  }
  .py50 {
    padding-top: 5vw;
    padding-bottom: 5vw;
  }
  .px50 {
    padding-left: 5vw;
    padding-right: 5vw;
  }
  .pt60 {
    padding-top: 6vw;
  }
  .pb60 {
    padding-bottom: 6vw;
  }
  .pl60 {
    padding-left: 6vw;
  }
  .pr60 {
    padding-right: 6vw;
  }
  .py60 {
    padding-top: 6vw;
    padding-bottom: 6vw;
  }
  .px60 {
    padding-left: 6vw;
    padding-right: 6vw;
  }
  .pt70 {
    padding-top: 7vw;
  }
  .pb70 {
    padding-bottom: 7vw;
  }
  .pl70 {
    padding-left: 7vw;
  }
  .pr70 {
    padding-right: 7vw;
  }
  .py70 {
    padding-top: 7vw;
    padding-bottom: 7vw;
  }
  .px70 {
    padding-left: 7vw;
    padding-right: 7vw;
  }
  .pt80 {
    padding-top: 8vw;
  }
  .pb80 {
    padding-bottom: 8vw;
  }
  .pl80 {
    padding-left: 8vw;
  }
  .pr80 {
    padding-right: 8vw;
  }
  .py80 {
    padding-top: 8vw;
    padding-bottom: 8vw;
  }
  .px80 {
    padding-left: 8vw;
    padding-right: 8vw;
  }
  .pt90 {
    padding-top: 9vw;
  }
  .pb90 {
    padding-bottom: 9vw;
  }
  .pl90 {
    padding-left: 9vw;
  }
  .pr90 {
    padding-right: 9vw;
  }
  .py90 {
    padding-top: 9vw;
    padding-bottom: 9vw;
  }
  .px90 {
    padding-left: 9vw;
    padding-right: 9vw;
  }
  .pt100 {
    padding-top: 10vw;
  }
  .pb100 {
    padding-bottom: 10vw;
  }
  .pl100 {
    padding-left: 10vw;
  }
  .pr100 {
    padding-right: 10vw;
  }
  .py100 {
    padding-top: 10vw;
    padding-bottom: 10vw;
  }
  .px100 {
    padding-left: 10vw;
    padding-right: 10vw;
  }
  .pt110 {
    padding-top: 11vw;
  }
  .pb110 {
    padding-bottom: 11vw;
  }
  .pl110 {
    padding-left: 11vw;
  }
  .pr110 {
    padding-right: 11vw;
  }
  .py110 {
    padding-top: 11vw;
    padding-bottom: 11vw;
  }
  .px110 {
    padding-left: 11vw;
    padding-right: 11vw;
  }
  .pt120 {
    padding-top: 12vw;
  }
  .pb120 {
    padding-bottom: 12vw;
  }
  .pl120 {
    padding-left: 12vw;
  }
  .pr120 {
    padding-right: 12vw;
  }
  .py120 {
    padding-top: 12vw;
    padding-bottom: 12vw;
  }
  .px120 {
    padding-left: 12vw;
    padding-right: 12vw;
  }
  .pt130 {
    padding-top: 13vw;
  }
  .pb130 {
    padding-bottom: 13vw;
  }
  .pl130 {
    padding-left: 13vw;
  }
  .pr130 {
    padding-right: 13vw;
  }
  .py130 {
    padding-top: 13vw;
    padding-bottom: 13vw;
  }
  .px130 {
    padding-left: 13vw;
    padding-right: 13vw;
  }
  .pt140 {
    padding-top: 14vw;
  }
  .pb140 {
    padding-bottom: 14vw;
  }
  .pl140 {
    padding-left: 14vw;
  }
  .pr140 {
    padding-right: 14vw;
  }
  .py140 {
    padding-top: 14vw;
    padding-bottom: 14vw;
  }
  .px140 {
    padding-left: 14vw;
    padding-right: 14vw;
  }
  .pt150 {
    padding-top: 15vw;
  }
  .pb150 {
    padding-bottom: 15vw;
  }
  .pl150 {
    padding-left: 15vw;
  }
  .pr150 {
    padding-right: 15vw;
  }
  .py150 {
    padding-top: 15vw;
    padding-bottom: 15vw;
  }
  .px150 {
    padding-left: 15vw;
    padding-right: 15vw;
  }
  .pt160 {
    padding-top: 16vw;
  }
  .pb160 {
    padding-bottom: 16vw;
  }
  .pl160 {
    padding-left: 16vw;
  }
  .pr160 {
    padding-right: 16vw;
  }
  .py160 {
    padding-top: 16vw;
    padding-bottom: 16vw;
  }
  .px160 {
    padding-left: 16vw;
    padding-right: 16vw;
  }
  .pt170 {
    padding-top: 17vw;
  }
  .pb170 {
    padding-bottom: 17vw;
  }
  .pl170 {
    padding-left: 17vw;
  }
  .pr170 {
    padding-right: 17vw;
  }
  .py170 {
    padding-top: 17vw;
    padding-bottom: 17vw;
  }
  .px170 {
    padding-left: 17vw;
    padding-right: 17vw;
  }
  .pt180 {
    padding-top: 18vw;
  }
  .pb180 {
    padding-bottom: 18vw;
  }
  .pl180 {
    padding-left: 18vw;
  }
  .pr180 {
    padding-right: 18vw;
  }
  .py180 {
    padding-top: 18vw;
    padding-bottom: 18vw;
  }
  .px180 {
    padding-left: 18vw;
    padding-right: 18vw;
  }
  .pt190 {
    padding-top: 19vw;
  }
  .pb190 {
    padding-bottom: 19vw;
  }
  .pl190 {
    padding-left: 19vw;
  }
  .pr190 {
    padding-right: 19vw;
  }
  .py190 {
    padding-top: 19vw;
    padding-bottom: 19vw;
  }
  .px190 {
    padding-left: 19vw;
    padding-right: 19vw;
  }
  .pt200 {
    padding-top: 20vw;
  }
  .pb200 {
    padding-bottom: 20vw;
  }
  .pl200 {
    padding-left: 20vw;
  }
  .pr200 {
    padding-right: 20vw;
  }
  .py200 {
    padding-top: 20vw;
    padding-bottom: 20vw;
  }
  .px200 {
    padding-left: 20vw;
    padding-right: 20vw;
  }
  .pt210 {
    padding-top: 21vw;
  }
  .pb210 {
    padding-bottom: 21vw;
  }
  .pl210 {
    padding-left: 21vw;
  }
  .pr210 {
    padding-right: 21vw;
  }
  .py210 {
    padding-top: 21vw;
    padding-bottom: 21vw;
  }
  .px210 {
    padding-left: 21vw;
    padding-right: 21vw;
  }
  .pt220 {
    padding-top: 22vw;
  }
  .pb220 {
    padding-bottom: 22vw;
  }
  .pl220 {
    padding-left: 22vw;
  }
  .pr220 {
    padding-right: 22vw;
  }
  .py220 {
    padding-top: 22vw;
    padding-bottom: 22vw;
  }
  .px220 {
    padding-left: 22vw;
    padding-right: 22vw;
  }
  .pt230 {
    padding-top: 23vw;
  }
  .pb230 {
    padding-bottom: 23vw;
  }
  .pl230 {
    padding-left: 23vw;
  }
  .pr230 {
    padding-right: 23vw;
  }
  .py230 {
    padding-top: 23vw;
    padding-bottom: 23vw;
  }
  .px230 {
    padding-left: 23vw;
    padding-right: 23vw;
  }
  .pt240 {
    padding-top: 24vw;
  }
  .pb240 {
    padding-bottom: 24vw;
  }
  .pl240 {
    padding-left: 24vw;
  }
  .pr240 {
    padding-right: 24vw;
  }
  .py240 {
    padding-top: 24vw;
    padding-bottom: 24vw;
  }
  .px240 {
    padding-left: 24vw;
    padding-right: 24vw;
  }
  .pt250 {
    padding-top: 25vw;
  }
  .pb250 {
    padding-bottom: 25vw;
  }
  .pl250 {
    padding-left: 25vw;
  }
  .pr250 {
    padding-right: 25vw;
  }
  .py250 {
    padding-top: 25vw;
    padding-bottom: 25vw;
  }
  .px250 {
    padding-left: 25vw;
    padding-right: 25vw;
  }
  .pt260 {
    padding-top: 26vw;
  }
  .pb260 {
    padding-bottom: 26vw;
  }
  .pl260 {
    padding-left: 26vw;
  }
  .pr260 {
    padding-right: 26vw;
  }
  .py260 {
    padding-top: 26vw;
    padding-bottom: 26vw;
  }
  .px260 {
    padding-left: 26vw;
    padding-right: 26vw;
  }
  .pt270 {
    padding-top: 27vw;
  }
  .pb270 {
    padding-bottom: 27vw;
  }
  .pl270 {
    padding-left: 27vw;
  }
  .pr270 {
    padding-right: 27vw;
  }
  .py270 {
    padding-top: 27vw;
    padding-bottom: 27vw;
  }
  .px270 {
    padding-left: 27vw;
    padding-right: 27vw;
  }
  .pt280 {
    padding-top: 28vw;
  }
  .pb280 {
    padding-bottom: 28vw;
  }
  .pl280 {
    padding-left: 28vw;
  }
  .pr280 {
    padding-right: 28vw;
  }
  .py280 {
    padding-top: 28vw;
    padding-bottom: 28vw;
  }
  .px280 {
    padding-left: 28vw;
    padding-right: 28vw;
  }
  .pt290 {
    padding-top: 29vw;
  }
  .pb290 {
    padding-bottom: 29vw;
  }
  .pl290 {
    padding-left: 29vw;
  }
  .pr290 {
    padding-right: 29vw;
  }
  .py290 {
    padding-top: 29vw;
    padding-bottom: 29vw;
  }
  .px290 {
    padding-left: 29vw;
    padding-right: 29vw;
  }
  .pt300 {
    padding-top: 30vw;
  }
  .pb300 {
    padding-bottom: 30vw;
  }
  .pl300 {
    padding-left: 30vw;
  }
  .pr300 {
    padding-right: 30vw;
  }
  .py300 {
    padding-top: 30vw;
    padding-bottom: 30vw;
  }
  .px300 {
    padding-left: 30vw;
    padding-right: 30vw;
  }
  .sp {
    display: block !important;
  }
  .pc {
    display: none !important;
  }
  ::-webkit-input-placeholder {
    font-size: 3.6vw;
    letter-spacing: 0.12em;
    color: #cccccc;
  }
  ::-moz-placeholder {
    font-size: 3.6vw;
    letter-spacing: 0.12em;
    color: #cccccc;
  }
  :-ms-input-placeholder {
    font-size: 3.6vw;
    letter-spacing: 0.12em;
    color: #cccccc;
  }
  ::-ms-input-placeholder {
    font-size: 3.6vw;
    letter-spacing: 0.12em;
    color: #cccccc;
  }
  ::placeholder {
    font-size: 3.6vw;
    letter-spacing: 0.12em;
    color: #cccccc;
  }
  .wrap_btn {
    right: 5px;
    bottom: 70px;
    width: 40px;
    height: 40px;
  }
  .wrap_btn span {
    font-size: 40px;
  }
  .wrap_btn_img {
    width: 40px;
    height: 40px;
  }
  .wrap_btn_img:hover {
    opacity: 1;
  }
  .wrap_btn p {
    font-size: 12px;
  }
  .f_140.half {
    font-size: 16vw;
  }
  .vertical_text p {
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    position: relative;
    z-index: 1;
  }
  .vertical_text p.f_50 {
    font-size: 5.5vw;
    padding: 1.9vw 0.5vw;
    letter-spacing: 5px;
  }
  .vertical_text p.f_50 span.f_50 {
    font-size: 5.5vw;
  }
  .vertical_text p span.no_vertical.double.start {
    -webkit-transform: translate(-1.5vw, 1.5vw);
            transform: translate(-1.5vw, 1.5vw);
  }
  .vertical_text p span.no_vertical.double.end {
    -webkit-transform: translate(1.5vw, 1.5vw);
            transform: translate(1.5vw, 1.5vw);
  }
  /*****************************************************
  cmn_btn
  *****************************************************/
  .cmn_btn {
    width: 100%;
    padding: 3vw 8vw;
  }
  .cmn_btn span.material-symbols-outlined {
    font-size: 6vw;
  }
  /*----------------------------------------------------------------

  ハンバーガーメニュー

  ----------------------------------------------------------------*/
  .hamburger {
    height: 60px;
    z-index: 1000;
  }
  .hamburger.scrollin .hamburger_contents .hamburger_row {
    position: relative;
  }
  .hamburger.scrollin .hamburger_contents .hamburger_row::after {
    background-color: #000679;
  }
  .hamburger.scrollin .hamburger_contents .hamburger_row .sp_logo span.f_14 {
    opacity: 0;
  }
  .hamburger .hamburger_contents {
    height: 60px;
  }
  .hamburger .hamburger_contents .hamburger_row {
    height: 60px;
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  .hamburger .hamburger_contents .hamburger_row::after {
    content: "";
    display: block;
    background-color: transparent;
    position: absolute;
    width: calc(100% - 6vw);
    height: 50px;
    border-radius: 10px;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .hamburger .hamburger_contents .hamburger_row .sp_logo {
    margin-top: 0;
    position: relative;
  }
  .hamburger .hamburger_contents .hamburger_row .sp_logo a {
    padding-left: 10px;
  }
  .hamburger .hamburger_contents .hamburger_row .sp_logo a:hover {
    color: #FFFFFF;
  }
  .hamburger .hamburger_contents .hamburger_row .sp_logo span.f_14 {
    position: absolute;
    width: 80vw;
    left: 1vw;
  }
  .hamburger .hamburger_contents .hamburger_row .btn_row .contact_btn {
    height: 60px;
    position: fixed;
    bottom: 0;
    left: 0;
    border-radius: 10px 10px 0 0 !important;
    width: 100%;
    font-size: 5.5vw;
    z-index: 1000;
  }
  .hamburger .hamburger_contents .hamburger_row .btn_row .contact_btn span {
    font-size: 7.5vw;
    margin-left: 4vw;
  }
  .hamburger .hamburger_contents .hamburger_row .btn_row .contact_btn:hover {
    background-color: #000679;
    color: #FFFFFF;
  }
  .hamburger .hamburger_contents .hamburger_row .btn_row .contact_btn:hover span {
    color: #FFFFFF;
  }
  .hamburger .hamburger_contents .hamburger_row .btn_row .menu_trigger {
    z-index: 1003;
    width: 60px;
    height: 50px;
    padding: 10px 15px;
    position: relative;
    cursor: pointer;
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  .hamburger .hamburger_contents .hamburger_row .btn_row .menu_trigger * {
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  .hamburger .hamburger_contents .hamburger_row .btn_row .menu_trigger::after {
    content: "MENU";
    font-size: 12px;
    bottom: 4px;
  }
  .hamburger .hamburger_contents .hamburger_row .btn_row .menu_trigger span {
    z-index: 1003;
    display: inline-block;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    position: absolute;
    left: 15px;
    width: 25px;
    height: 2px;
    background-color: #ffffff;
    -webkit-transition: all 0.4s ease;
    transition: all 0.4s ease;
  }
  .hamburger .hamburger_contents .hamburger_row .btn_row .menu_trigger span:nth-of-type(1) {
    top: 10px;
  }
  .hamburger .hamburger_contents .hamburger_row .btn_row .menu_trigger span:nth-of-type(2) {
    top: 17px;
    width: 30px;
  }
  .hamburger .hamburger_contents .hamburger_row .btn_row .menu_trigger span:nth-of-type(3) {
    bottom: 24px;
  }
  .hamburger .hamburger_contents .hamburger_row .btn_row .menu_trigger.active {
    background-color: #FFFFFF;
  }
  .hamburger .hamburger_contents .hamburger_row .btn_row .menu_trigger.active::after {
    color: #000679;
  }
  .hamburger .hamburger_contents .hamburger_row .btn_row .menu_trigger.active span {
    background-color: #000679;
  }
  .hamburger .hamburger_contents .hamburger_row .btn_row .menu_trigger.active span:nth-of-type(1) {
    margin-top: 7px;
    left: 17px;
    width: 25px;
  }
  .hamburger .hamburger_contents .hamburger_row .btn_row .menu_trigger.active span:nth-of-type(2) {
    width: 0px;
  }
  .hamburger .hamburger_contents .hamburger_row .btn_row .menu_trigger.active span:nth-of-type(3) {
    margin-bottom: 7px;
    width: 25px;
    left: 17px;
  }
  .hamburger .hamburger_contents nav {
    width: 100%;
    height: 100%;
    padding: 100px 0 30px;
    left: 200%;
  }
  .hamburger .hamburger_contents nav.open {
    left: 0;
  }
  .hamburger .hamburger_contents nav .nav_inner .sp_menu_list a:hover {
    color: #FFFFFF;
  }
  /*****************************************************
  TOP
  *****************************************************/
  main .text_roop_wrap .text_roop.text_roop02 {
    top: 15%;
  }
  main .text_roop_wrap .text_roop p {
    font-size: 14vw;
  }
  main .mv .mv_inner .mv_slider {
    height: 100vh;
  }
  main .mv .mv_inner .mv_slider .mv_slider_item img {
    width: 100%;
    min-height: 100vh;
    height: 100vh;
  }
  main .mv .mv_inner .mv_line img {
    max-height: 100vh;
  }
  main .mv .mv_inner .text_wrap {
    top: 45%;
    left: 5%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  main .mv .mv_inner .text_wrap p.ml150 {
    margin-left: 0;
  }
  main .mv .mv_inner .text_wrap p span {
    z-index: 1;
  }
  main .mv .mv_inner .text_wrap p span.white {
    font-size: 11.5vw;
  }
  main .mv .mv_inner .text_wrap p span.white::after {
    font-size: 11.5vw;
  }
  main .mv .mv_inner .text_wrap p span.main {
    font-size: 11.5vw;
  }
  main .mv .mv_inner .text_roop_wrap {
    bottom: -7vw;
  }
  main .mv .mv_inner .text_roop_wrap .text_roop {
    mix-blend-mode: overlay;
    opacity: 0.6;
  }
  main .top01 {
    padding-bottom: 100vw;
  }
  main .top01 img.position-absolute {
    max-width: 100vw;
  }
  main .top01 img.position-absolute.bg01 {
    top: 0;
    left: 0;
    z-index: -1;
  }
  main .top01 img.position-absolute.bg02 {
    bottom: 0;
    right: 0;
    z-index: -1;
  }
  main .top01 .top01_inner .top01_row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    position: relative;
  }
  main .top01 .top01_inner .top01_row .top01_row_item.top01_row_left {
    position: absolute;
    top: -9vw;
    left: 5%;
    height: 100%;
  }
  main .top01 .top01_inner .top01_row .top01_row_item.top01_row_left .vertical_text {
    height: auto;
  }
  main .top01 .top01_inner .top01_row .top01_row_item.top01_row_right .img p {
    margin-top: 20vw;
    width: 80%;
    margin-left: auto;
    margin-right: auto;
  }
  main .top01 .top01_inner .top01_row .top01_row_item.top01_row_right .text_wrap {
    width: 80%;
    margin-left: auto;
    margin-right: auto;
  }
  main .top01 .top01_inner .top01_row .top01_row_item.top01_row_right .text_wrap p.f_18 {
    margin-top: 6vw;
  }
  main .top02 .top02_inner .top02_row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-top: -70vw;
  }
  main .top02 .top02_inner .top02_row .top02_row_item.top02_row_left {
    width: 100%;
  }
  main .top02 .top02_inner .top02_row .top02_row_item.top02_row_left img {
    width: 100%;
    height: 100%;
  }
  main .top02 .top02_inner .top02_row .top02_row_item.top02_row_right {
    width: 100%;
  }
  main .top02 .top02_inner .top02_row .top02_row_item.top02_row_right h2 {
    -webkit-box-pack: center !important;
        -ms-flex-pack: center !important;
            justify-content: center !important;
  }
  main .top02 .top02_inner .top02_row .top02_row_item.top02_row_right p.f_140 {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    font-size: 14vw;
    text-align: center;
    margin-top: -9vw;
    color: rgba(255, 255, 255, 0.8);
  }
  main .top03 .top03_inner .top03_row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  main .top03 .top03_inner .top03_row .top03_row_item:first-child {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.5);
  }
  main .top03 .top03_inner .top03_row .top03_row_item p.f_100 {
    font-size: 13vw;
  }
  main .top03 .top03_inner .top03_row .top03_row_item.col-md-4:nth-child(2) {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.5);
  }
  main .top03 .top03_inner .top03_row .top03_row_item.col-md-4 .col-10 {
    padding-top: 10vw;
    padding-bottom: 10vw;
  }
  main .top03 .top03_inner .top03_row .top03_row_item.col-md-4 .col-10 .img {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
  }
  main .top03 .top03_inner .top03_row .top03_row_item.col-md-4 .col-10 .img.position-absolute {
    bottom: 0;
    right: 0;
  }
  main .top03 .top03_inner .top03_row .top03_row_item.col-md-4 .col-10 h2 {
    font-size: 6vw;
    margin-top: 4vw;
  }
  main .top03 .top03_inner .top03_row .top03_row_item.col-md-4 .col-10 a {
    margin-top: 4vw;
  }
  main .top03 .top03_inner .top03_row .top03_row_item.col-md-4 p.position-absolute {
    font-size: 13vw;
    left: 5%;
    top: 4vw;
  }
  main .top04 .top04_inner .text_roop_wrap {
    -webkit-transform: translateY(4vw);
            transform: translateY(4vw);
  }
  main .top05 {
    position: relative;
  }
  main .top05::after {
    content: "";
    background-size: 250%;
  }
  main .top05 .top05_inner .top05_item01 {
    background-image: url(../img/top/top05_sp.jpg);
    background-size: cover;
    background-position: bottom right;
    min-height: 120vh;
    padding-top: 12vw;
    padding-bottom: 25vw;
  }
  main .top05 .top05_inner .top05_item01 .text_wrap {
    margin-left: auto;
    margin-right: auto;
  }
  main .top05 .top05_inner .top05_item01 .text_wrap h2 {
    margin-top: 6vw;
  }
  main .top05 .top05_inner .top05_item01 .text_wrap a {
    margin-top: 7vw;
  }
  main .top05 .top05_inner .top05_item01 .text_wrap .img {
    -webkit-transform: translateX(-6vw);
            transform: translateX(-6vw);
    margin-left: auto;
    margin-right: auto;
  }
  main .top05 .top05_inner .top05_item02 {
    margin-top: -25vw;
  }
  main .top05 .top05_inner .top05_item02 img.position-absolute {
    top: 0;
    right: 0;
    width: auto;
    height: 100%;
  }
  main .top05 .top05_inner .top05_item02 .top05_item02_row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    position: relative;
  }
  main .top05 .top05_inner .top05_item02 .top05_item02_row .top05_item02_row_item.top05_item02_row_left .img p {
    margin-top: -60px;
  }
  main .top05 .top05_inner .top05_item02 .top05_item02_row .top05_item02_row_item.top05_item02_row_right {
    margin-top: 0;
    position: absolute;
    top: -19%;
    left: 8vw;
  }
  main .foot_contact .foot_contact_inner {
    background-image: url(../img/common/contact_bg_sp.jpg);
    height: auto;
    padding-top: 52vw;
    padding-bottom: 20vw;
  }
  main .foot_contact .foot_contact_inner .col-10 .vertical_text {
    bottom: calc(100% + 10vw);
  }
  main .foot_contact .foot_contact_inner .col-10 h2 span.f_130 {
    font-size: 16vw;
  }
  main .foot_contact .foot_contact_inner .col-10 .foot_contact_row {
    position: unset !important;
    -webkit-transform: translateX(0%);
            transform: translateX(0%);
    margin-top: 8vw;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  main .foot_contact .foot_contact_inner .col-10 .foot_contact_row a {
    width: 100%;
  }
  main .foot_contact .foot_contact_inner .col-10 .foot_contact_row a:first-child {
    margin-bottom: 5vw;
  }
  main .foot_contact .foot_contact_inner .col-10 .foot_contact_row a .d-flex span.material-symbols-outlined {
    width: 20vw;
    font-size: 8vw;
    min-width: unset;
    height: 20vw;
  }
  /***************************************************************
  サブ共通
  ***************************************************************/
  main .head {
    padding-top: 20vw;
    padding-bottom: 10vw;
  }
  main .head::before {
    height: 60px;
    width: 70vw;
    min-width: unset;
  }
  main .head.recruit {
    border-bottom: 10px solid #325BFF;
  }
  main .head .head_inner .f_140 {
    font-size: 10vw;
  }
  main h3 span.f_30 .f_50 {
    font-size: 7vw;
  }
  main .sub_section_title span.f_140 {
    font-size: 16vw;
  }
  main .sub_section_title span.position-absolute {
    font-size: 15vw;
    line-height: 0.9;
  }
  main .sub_section_title_line::before {
    width: 25px;
    height: 4px;
  }
  main .table01 tr:first-child th {
    border-top: 1px solid #FFFFFF;
  }
  main .table01 tr th, main .table01 tr td {
    display: block;
    padding-top: 4vw;
    padding-bottom: 4vw;
    letter-spacing: 2px;
    width: 100%;
    padding-right: 0;
    padding-left: 0;
  }
  main .table01 tr th {
    border-right: none;
    padding-bottom: 0;
    font-size: 4.2vw;
    letter-spacing: 3px;
  }
  main .table01 tr td {
    border-bottom: 1px solid #FFFFFF;
  }
  /***************************************************************
  company
  ***************************************************************/
  main .company01 .company01_inner {
    padding-top: 10vw;
  }
  main .company01 .company01_inner .vertical_text.position-absolute {
    top: 5vw;
    right: 9vw;
  }
  main .company01 .company01_inner .company01_row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  main .company01 .company01_inner .company01_row .company01_row_item.company01_row_left {
    height: 70vw;
  }
  main .company01 .company01_inner .company01_row .company01_row_item.company01_row_left img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: right;
    object-position: right;
  }
  main .company01 .company01_inner .company01_row .company01_row_item.company01_row_right .pr90 {
    padding-right: 0;
  }
  main .company02 .company02_inner .company02_row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
  main .company02 .company02_inner .company02_row .company02_row_item.company02_row_left .pl90 {
    padding-left: 0;
  }
  main .company02 .company02_inner .company02_row .company02_row_item.company02_row_left img.position-absolute {
    width: 50vw;
    max-width: unset;
    min-width: unset;
  }
  main .company02 .company02_inner .company02_row .company02_row_item.company02_row_right {
    padding: 0;
  }
  main .company02 .company02_inner .company02_row .company02_row_item.company02_row_right img {
    width: 100%;
    height: 100vw;
  }
  main .company03 .company03_inner .company03_item .map iframe {
    height: 100vw;
  }
  /***************************************************************
  contact
  ***************************************************************/
  main .contact01 img.position-absolute {
    top: 0;
    left: 10%;
  }
  main .contact01 .contact01_inner a {
    margin-top: 6vw;
    padding: 3vw 8vw;
    font-size: 7vw;
  }
  main .contact01 .contact01_inner a span.material-icons-outlined {
    font-size: 7vw;
    margin-top: 3px;
  }
  /***************************************************************
  about
  ***************************************************************/
  main .about01.top05 .top05_inner .top05_item01 {
    background-image: url(../img/about/about01_sp.png);
    height: 65vw;
    background-size: cover;
  }
  main .about01.top05 .top05_inner .top05_item02 {
    margin-top: -20vw;
  }
  main .about01.top05 .top05_inner .top05_item02 .top05_item02_row .top05_item02_row_item.top05_item02_row_right {
    margin-top: -25%;
  }
  /***************************************************************
  business
  ***************************************************************/
  main .business01 .business01_inner .business01_item01 .img {
    height: 100vw;
  }
  main .business01 .business01_inner .business01_item01 .img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center;
  }
  main .business01 .business01_inner .business01_item01::after {
    content: none;
  }
  main .business01 .business01_inner .business01_item01 .bg_main {
    margin-top: 0;
    width: 100%;
  }
  main .business01 .business01_inner .business01_item01 .bg_main .vertical_text {
    bottom: 90%;
  }
  main .business01 .business01_inner .business01_item01 .bg_main .vertical_text .f_50 {
    font-size: 6.5vw;
  }
  main .business01 .business01_inner .business01_item01 .bg_main .text_wrap {
    padding: 0;
  }
  main .business01 .business01_inner .business01_item01 .bg_main h3 {
    margin-bottom: 6vw;
  }
  main .business01 .business01_inner .business01_item01 .bg_main h3 span.f_100 {
    left: 90%;
    font-size: 10vw;
  }
  main .business01 .business01_inner .business01_item02 img.position-absolute {
    bottom: 0;
    right: 0;
    height: 100%;
    width: auto;
  }
  main .business01 .business01_inner .business01_item02 img.position-absolute.mr_auto {
    right: unset;
    left: 0;
  }
  main .business01 .business01_inner .business01_item02 .business01_item02_row {
    margin-top: 10vw;
  }
  main .business01 .business01_inner .business01_item02 .business01_item02_row::before {
    height: 90%;
    top: -10%;
    -webkit-transform: translateY(0%) skew(-10deg);
            transform: translateY(0%) skew(-10deg);
  }
  main .business01 .business01_inner .business01_item02 .business01_item02_row div.d-flex {
    -webkit-box-orient: vertical !important;
    -webkit-box-direction: reverse !important;
        -ms-flex-direction: column-reverse !important;
            flex-direction: column-reverse !important;
  }
  main .business01 .business01_inner .business01_item02 .business01_item02_row .business01_item02_row_item.business01_item02_row_left {
    width: 100%;
    margin-top: 8vw;
  }
  main .business01 .business01_inner .business01_item02 .business01_item02_row .business01_item02_row_item.business01_item02_row_right {
    width: 100%;
  }
  main .business01 .business01_inner .business01_item02 .business01_item02_row .business01_item02_row_item.business01_item02_row_right p span.f_24 {
    font-size: 4.6vw;
  }
  main .business01 .business01_inner .business01_item02 .business01_item02_row .business01_item02_row_item.business01_item02_row_right p span.f_38 {
    font-size: 6.2vw;
  }
  main .business01 .business01_inner .business01_item02 .business01_item02_row .business01_item02_row_item.business01_item02_row_right p::before {
    content: "";
    display: block;
    height: 3px;
  }
  /***************************************************************
  recruit
  ***************************************************************/
  main .recruit01 {
    background-position: left 36% bottom;
  }
  main .recruit01 img.position-absolute {
    width: 70vw;
  }
  main .recruit01 .recruit01_inner .recruit01_row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  main .recruit01 .recruit01_inner .recruit01_row .recruit01_row_item.recruit01_row_left {
    margin-bottom: 6vw;
  }
  main .recruit01 .recruit01_inner .recruit01_row .recruit01_row_item.recruit01_row_left p.f_100 {
    font-size: 15vw;
  }
  main .recruit01 .recruit01_inner .recruit01_row .recruit01_row_item.recruit01_row_left h3 {
    width: 100%;
    text-align: center;
  }
  main .recruit02::after {
    content: none;
  }
  main .recruit02 .top05_inner .top05_item01 {
    background-image: url(../img/recruit/recruit02_sp.jpg);
    background-size: 90vw;
    min-height: 54vw;
    top: 60px;
  }
  main .recruit02 .top05_inner .top05_item02 {
    margin-top: -5vw;
  }
  main .recruit02 .top05_inner .top05_item02 p.position-absolute {
    right: 0;
    top: -11vw;
  }
  main .recruit02 .top05_inner .top05_item02 .top05_item02_row .top05_item02_row_item.top05_item02_row_left {
    width: 70%;
    margin-left: auto;
  }
  main .recruit02 .top05_inner .top05_item02 .top05_item02_row .top05_item02_row_item.top05_item02_row_right {
    left: 0;
  }
  main .recruit02 .top05_inner .top05_item02 .top05_item02_row .top05_item02_row_item.top05_item02_row_right .vertical_text {
    -webkit-box-pack: end !important;
        -ms-flex-pack: end !important;
            justify-content: flex-end !important;
  }
  main .recruit03 .recruit03_inner .recruit03_item p.position-absolute {
    right: 0;
    top: -11vw;
  }
  main .recruit03 .recruit03_inner .recruit03_item p.reverse {
    right: unset;
    left: 0;
  }
  main .recruit03 .recruit03_inner .recruit03_item .recruit03_row {
    -webkit-box-orient: vertical !important;
    -webkit-box-direction: normal !important;
        -ms-flex-direction: column !important;
            flex-direction: column !important;
    margin-left: auto;
    margin-right: auto;
  }
  main .recruit03 .recruit03_inner .recruit03_item .recruit03_row .recruit03_row_item.recruit03_row_left {
    width: 100%;
    margin-top: 0%;
  }
  main .recruit03 .recruit03_inner .recruit03_item .recruit03_row .recruit03_row_item.recruit03_row_right {
    width: 100%;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  main .recruit03 .recruit03_inner .recruit03_item .recruit03_row .recruit03_row_item.recruit03_row_right h3 span.img {
    width: 14vw;
  }
  main .recruit03 .recruit03_inner .recruit03_item .recruit03_row.ml_auto .recruit03_row_item.recruit03_row_right {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  /***************************************************************
  crosstalk
  ***************************************************************/
  main .crosstalk01 {
    height: 70vh;
    background-image: url(../img/crosstalk/crosstalk01_sp.jpg);
    background-position: bottom center;
  }
  main .crosstalk01 img.position-absolute {
    width: 30vw;
  }
  main .crosstalk02 {
    padding-top: 20vw;
  }
  main .crosstalk02 .crosstalk02_inner h3 span.f_100 {
    font-size: 12vw;
  }
  main .crosstalk02 .crosstalk02_inner .crosstalk02_row {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  main .crosstalk02 .crosstalk02_inner .crosstalk02_row .crosstalk02_row_item {
    width: 49%;
    margin-bottom: 5vw;
  }
  main .crosstalk03 .crosstalk03_inner .crosstalk03_item .vertical_text {
    top: 5vw;
    left: -4%;
  }
  main .crosstalk03 .crosstalk03_inner .crosstalk03_item .vertical_text p.ml20 {
    margin-left: 1vw;
  }
  main .crosstalk03 .crosstalk03_inner .crosstalk03_item .vertical_text p span {
    font-size: 4vw;
  }
  main .crosstalk03 .crosstalk03_inner .crosstalk03_item .vertical_text.ml_auto {
    left: unset;
    right: -4%;
  }
  main .crosstalk03 .crosstalk03_inner .crosstalk03_item02 {
    padding-right: 0% !important;
    padding-left: 0% !important;
  }
  main .crosstalk03 .crosstalk03_inner .crosstalk03_item02::before {
    bottom: -10vw;
    height: 110%;
  }
  main .crosstalk03 .crosstalk03_inner .crosstalk03_item02 h4::before {
    margin-right: 10px;
    width: 10vw;
    height: 4px;
  }
  main .crosstalk03 .crosstalk03_inner .crosstalk03_item02 h4 span.position-absolute {
    font-size: 13vw;
    right: -3%;
  }
  main .crosstalk03 .crosstalk03_inner .crosstalk03_item02 .text_wrap .box {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  main .crosstalk03 .crosstalk03_inner .crosstalk03_item02 .text_wrap .box .icon {
    width: 18vw;
  }
  main .crosstalk03 .crosstalk03_inner .crosstalk03_item02 .text_wrap .box .text {
    width: calc(100% - 25vw);
    min-height: 17vw;
  }
  main .crosstalk03 .crosstalk03_inner .crosstalk03_item02 .text_wrap .box .text::before {
    content: "";
    position: absolute;
    top: 35px;
    left: -28px;
    margin-top: -15px;
    border: 10px solid transparent;
  }
  main .crosstalk03 .crosstalk03_inner .crosstalk03_item02 .text_wrap .box .text.bg_blue01::before {
    border-right: 18px solid #325BFF;
  }
  main .crosstalk03 .crosstalk03_inner .crosstalk03_item02 .text_wrap .box .text.bg_gray::before {
    border-right: 18px solid #E6E7F2;
  }
  /***************************************************************
  plan
  ***************************************************************/
  main .plan01 .plan01_inner .sp_scroll_wrap {
    overflow-x: scroll;
  }
  main .plan01 .plan01_inner h3 {
    padding: 0;
    width: 100%;
  }
  main .plan01 .plan01_inner .plan01_row {
    padding: 0 5vw;
    width: 200vw;
  }
  main .plan01 .plan01_inner .plan01_row .plan01_row_item {
    width: 24%;
  }
  main .plan02 .plan02_inner .plan02_item img.position-absolute {
    max-width: unset;
    width: 35vw;
    min-width: unset;
  }
  main .plan02 .plan02_inner .plan02_item .plan02_row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  main .plan02 .plan02_inner .plan02_item .plan02_row .plan02_row_item.plan02_row_left {
    width: 100%;
    -webkit-transform: translateY(0);
            transform: translateY(0);
    margin-top: -11vw;
  }
  main .plan02 .plan02_inner .plan02_item .plan02_row .plan02_row_item.plan02_row_right {
    width: 92%;
    margin-left: auto;
    padding: 4vw 0;
  }
  main .plan03 .plan03_inner .schedule_wpap .schedule_row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-top: 10vw;
  }
  main .plan03 .plan03_inner .schedule_wpap .schedule_row::before {
    width: 3px;
    height: calc(100% - 14vw);
    top: 16vw;
    left: 6.5vw;
  }
  main .plan03 .plan03_inner .schedule_wpap .schedule_row .schedule_row_item.schedule_row_left {
    width: 100%;
  }
  main .plan03 .plan03_inner .schedule_wpap .schedule_row .schedule_row_item.schedule_row_left .clock {
    width: 14vw;
  }
  main .plan03 .plan03_inner .schedule_wpap .schedule_row .schedule_row_item.schedule_row_left .text_wrap {
    width: calc(100% - 23vw);
    padding: 5vw;
  }
  main .plan03 .plan03_inner .schedule_wpap .schedule_row .schedule_row_item.schedule_row_left .text_wrap p {
    margin-top: 3vw;
  }
  main .plan03 .plan03_inner .schedule_wpap .schedule_row .schedule_row_item.schedule_row_right {
    width: 85%;
    margin-left: auto;
    margin-top: 5vw;
  }
  /***************************************************************
  benefits
  ***************************************************************/
  main .benefits01 {
    padding-top: 20vw;
  }
  main .benefits01 .benefits01_inner h3 span.f_100 {
    font-size: 12vw;
  }
  main .benefits01 .benefits01_inner p.pt30::before {
    width: 30vw;
    height: 3px;
    margin-bottom: 5vw;
  }
  main .benefits01 .benefits01_inner .benefits01_row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  main .benefits01 .benefits01_inner .benefits01_row .benefits01_row_item {
    width: 100% !important;
    padding: 10vw 7vw 6vw 7vw;
  }
  main .benefits01 .benefits01_inner .benefits01_row .benefits01_row_item:first-child {
    border-right: none;
    border-bottom: 1px solid #325BFF;
  }
  main .benefits01 .benefits01_inner .benefits01_row .benefits01_row_item h4 span.f_96 {
    font-size: 14vw;
  }
  main .benefits01 .benefits01_inner .benefits01_row .benefits01_row_item .anchor_wrap a {
    margin-bottom: 3vw;
  }
  main .benefits02 {
    overflow-x: hidden;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box01 {
    -webkit-transform: translateY(10vw);
            transform: translateY(10vw);
  }
  main .benefits02 .benefits02_inner .benefits02_item .box01.pr100 {
    padding-right: 15vw;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box01.pl100 {
    padding-left: 15vw;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box01::after {
    height: 105%;
    -webkit-transform: skewX(-6deg) translateY(-50%);
            transform: skewX(-6deg) translateY(-50%);
    left: -18%;
    z-index: -1;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box01.box01_02::after {
    background-color: #FFFFFF;
    left: unset;
    right: -10%;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box01 .box01_row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box01 .box01_row .box01_row_item.box01_row_left {
    width: 100%;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box01 .box01_row .box01_row_item.box01_row_left h4 span.position-absolute {
    left: -10%;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box01 .box01_row .box01_row_item.box01_row_right {
    width: 100%;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box02.bg_blue01 img.position-absolute {
    right: unset;
    left: 0;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box02.bg_blue01 .box {
    padding-left: 0;
    padding-right: 0;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box02 img.position-absolute {
    top: 0;
    right: 0;
    height: 100%;
    width: auto;
    z-index: -2;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box02 .box {
    padding: 8vw 5vw;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box02 .box.blue {
    padding-left: 0;
    padding-right: 0;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box02 .box ul {
    margin-top: 7vw !important;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box02 .box ul li {
    width: 40%;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box02 .box_row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box02 .box_row .box_row_item {
    width: 100%;
    margin-bottom: 4vw;
    padding-top: 3vw;
    padding-bottom: 6vw;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box02 .box_row .box_row_item:last-child {
    margin-bottom: 0;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box02 .box_row .box_row_item::after {
    -webkit-clip-path: polygon(8% 0, 100% 0%, 92% 100%, 0% 100%);
            clip-path: polygon(8% 0, 100% 0%, 92% 100%, 0% 100%);
  }
  main .benefits02 .benefits02_inner .benefits02_item .box02 .box_row02 {
    row-gap: 3vw;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box02 .box_row02::after {
    content: "";
    display: block;
    width: 24%;
  }
  main .benefits02 .benefits02_inner .benefits02_item .box02 .box_row02 .box_row02_item {
    width: 48%;
  }
  main .benefits03 .benefits03_inner .benefits03_row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  main .benefits03 .benefits03_inner .benefits03_row table {
    width: 100%;
  }
  main .benefits03 .benefits03_inner .benefits03_row table tr th {
    width: 30vw;
    padding-left: 3vw;
  }
  main .benefits03 .benefits03_inner .benefits03_row table tr td {
    padding-left: 5vw;
    width: calc(100% - 30vw);
  }
  /*----------------------------------------------------------------

  footer

  ----------------------------------------------------------------*/
  footer {
    overflow-y: hidden;
    padding-bottom: 60px;
  }
  footer img.position-absolute {
    left: 0;
    bottom: 0;
    height: auto;
    width: 100%;
  }
  footer .footer_inner .footer_row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  footer .footer_inner .footer_row .footer_row_item.footer_row_left p.f_64 {
    font-size: 10vw;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 auto;
  }
  footer .footer_inner .footer_row .footer_row_item.footer_row_right {
    padding-top: 10vw;
    padding-bottom: 15vw;
  }
  footer .footer_inner .footer_row .footer_row_item.footer_row_right a.f_32 {
    font-size: 6vw;
    text-align: center;
  }
  footer .footer_inner .footer_row .footer_row_item.footer_row_right .text_row {
    display: block !important;
    margin-top: 4vw;
  }
  footer .footer_inner .footer_row .footer_row_item.footer_row_right .text_row p {
    text-align: center;
    line-height: 2;
  }
  footer .footer_inner .footer_row .footer_row_item.footer_row_right .text_row p.mr40 {
    margin-right: 0;
  }
  footer .footer_inner .footer_row .footer_row_item.footer_row_right .footer_nav_row {
    border-top: 1px solid #FFFFFF;
    gap: 0 40px;
  }
  footer .footer_inner .footer_row .footer_row_item.footer_row_right .footer_nav_row ul li {
    margin-bottom: 20px;
  }
  footer .footer_inner .footer_row .footer_row_item.footer_row_right .footer_nav_row ul li:last-child {
    margin-bottom: 0;
  }
}