@media screen and (min-width: 769px) {
  .sp {
    display: none;
  }

  #main_visual {
    box-sizing: border-box;
    position: relative;
    width: 100%;
    max-width: 1000px;
    height: 460px;
    padding-top: 314px;
    background: url(../img/about/img_about_main.png) no-repeat center top;
    background-size: contain;
  }
  #main_visual #borad {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 90%;
    max-width: 880px;
    height: 108px;
    margin: 0 auto;
    background: #6abc86;
    background: -webkit-linear-gradient(to left, #6abc86, #4d5dca);
    background: -mozlinear-gradient(to left, #6abc86, #4d5dca);
    background: -ms-linear-gradient(to left, #6abc86, #4d5dca);
    background: linear-gradient(to left, #6abc86, #4d5dca);
    text-align: center;
  }
  #main_visual #borad p {
    margin-bottom: 0;
    color: #fff;
    font-weight: bold;
    line-height: 2;
  }
  #main_visual #borad p span {
    color: #f6ff00;
  }

  #anchor_link {
    display: flex;
    justify-content: space-between;
    width: 100%;
    box-shadow: 3px 3px 0px rgba(0, 0, 0, 0.08);
  }
  #anchor_link li {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 25%;
    height: 87px;
    background-color: #f6ff00;
    border-left: 1px solid #d1d900;
    text-align: center;
  }
  #anchor_link li:first-child {
    border-left: none;
  }
  #anchor_link li:before {
    position: absolute;
    top: 50%;
    left: 23px;
    display: inline-block;
    content: "\f107";
    width: 1em;
    height: 1em;
    background-color: transparent;
    font-family: 'Font Awesome 5 Free';
    font-weight: bold;
    transform: translateY(-50%);
  }
  #anchor_link li:hover:before {
    top: 55%;
  }
  #anchor_link li a {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 87px;
    padding: 0 38px;
    color: #505050;
    font-weight: bold;
    text-decoration: none;
  }

  #background_purpose .flex_box {
    margin-bottom: 20px;
  }
  #background_purpose .flex_box .left {
    max-width: 373px;
  }
  #background_purpose .flex_box .right {
    margin-left: 40px;
  }
  #background_purpose .flex_box .right h4 {
    margin-bottom: 10px;
    color: #6bbc86;
    font-size: 24px;
  }
  #background_purpose .flex_box .right h4:before {
    display: none;
  }
  #background_purpose .flex_box .right p {
    line-height: 1.8;
  }
  #background_purpose #problem {
    display: flex;
    justify-content: space-between;
    justify-content: space-around;
    padding: 40px 12px 30px;
    background-color: #f5f5f5;
  }
  #background_purpose #problem .unit {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    width: 23%;
    max-width: 223px;
    padding: 28px 2% 38px;
    background-color: #fff;
  }
  #background_purpose #problem .unit:before {
    position: absolute;
    top: -15px;
    left: 50%;
    display: block;
    content: "PROBLEM // 01";
    width: 133px;
    height: 30px;
    padding: 0 10px;
    color: #fff;
    background: #6abc86;
    background: -webkit-linear-gradient(to top, #6abc86, #4d5dca);
    background: -mozlinear-gradient(to top, #6abc86, #4d5dca);
    background: -ms-linear-gradient(to top, #6abc86, #4d5dca);
    background: linear-gradient(to top, #6abc86, #4d5dca);
    transform: translateX(-50%);
    font-size: 14px;
    line-height: 30px;
    text-align: center;
  }
  #background_purpose #problem .unit.problem01:before {
    content: "PROBLEM // 01";
  }
  #background_purpose #problem .unit.problem02:before {
    content: "PROBLEM // 02";
  }
  #background_purpose #problem .unit.problem03:before {
    content: "PROBLEM // 03";
  }
  #background_purpose #problem .unit.problem04:before {
    content: "PROBLEM // 04";
  }
  #background_purpose #problem .unit p {
    margin: 0 0 5px;
    color: #6bbc86;
    font-size: 16px;
    font-weight: bold;
    text-align: center;
  }
  #background_purpose #problem .unit img {
    display: block;
    width: 85px;
  }

  #feature .points {
    display: flex;
    justify-content: space-between;
    justify-content: space-around;
    flex-wrap: wrap;
    padding: 40px 12px 30px;
    background-color: #f5f5f5;
  }
  #feature .points .unit {
    position: relative;
    width: 48%;
    max-width: 466px;
    padding: 28px 30px 38px;
    background-color: #fff;
  }
  #feature .points .unit:before {
    position: absolute;
    top: -15px;
    left: 50%;
    display: block;
    content: "POINT // 01";
    width: 105px;
    height: 30px;
    padding: 0 10px;
    color: #fff;
    background: #6abc86;
    background: -webkit-linear-gradient(to top, #6abc86, #4d5dca);
    background: -mozlinear-gradient(to top, #6abc86, #4d5dca);
    background: -ms-linear-gradient(to top, #6abc86, #4d5dca);
    background: linear-gradient(to top, #6abc86, #4d5dca);
    transform: translateX(-50%);
    font-size: 14px;
    line-height: 30px;
    text-align: center;
  }
  #feature .points .unit.point01:before {
    content: "POINT // 01";
  }
  #feature .points .unit.point02:before {
    content: "POINT // 02";
  }
  #feature .points .unit.point03 {
    margin-top: 38px;
  }
  #feature .points .unit.point03:before {
    content: "POINT // 03";
  }
  #feature .points .unit.point04 {
    margin-top: 38px;
  }
  #feature .points .unit.point04:before {
    content: "POINT // 04";
  }
  #feature .points .unit h4 {
    margin: 0 0 10px;
    color: #6bbc86;
    font-size: 18px;
    font-weight: bold;
    text-align: center;
  }
  #feature .points .unit h4:before {
    display: none;
  }
  #feature .points .unit img {
    display: block;
    width: 112px;
    margin: 0 auto 12px;
  }
  #feature .points .unit p {
    font-size: 16px;
    line-height: 1.8;
  }

  #how_it_works .img img {
    width: 100%;
  }
  #how_it_works .works {
    display: flex;
    justify-content: space-between;
    justify-content: space-around;
    padding: 40px 12px 30px;
    background-color: #f5f5f5;
  }
  #how_it_works .works .unit {
    position: relative;
    width: 23%;
    max-width: 223px;
    background-color: #fff;
  }
  #how_it_works .works .unit .ttl {
    display: flex;
    justify-content: space-between;
    justify-content: space-around;
    align-items: center;
    width: 100%;
    height: 46px;
    padding: 0 10px;
    color: #fff;
    background: #6abc86;
    background: -webkit-linear-gradient(to top, #6abc86, #4d5dca);
    background: -mozlinear-gradient(to top, #6abc86, #4d5dca);
    background: -ms-linear-gradient(to top, #6abc86, #4d5dca);
    background: linear-gradient(to top, #6abc86, #4d5dca);
    font-size: 17px;
    font-weight: bold;
  }
  #how_it_works .works .unit p {
    margin: 18px;
  }

  #flow_of_use {
    padding-bottom: 80px;
  }
  #flow_of_use .flow {
    position: relative;
    margin-bottom: 40px;
  }
  #flow_of_use .flow:before {
    position: absolute;
    top: 0;
    left: 32px;
    display: block;
    content: "";
    width: 3px;
    height: 90%;
    background: #4e61c8;
  }
  #flow_of_use .flow .unit {
    position: relative;
    width: calc(100% - 92px);
    margin-left: 92px;
    margin-bottom: 16px;
    padding: 28px;
    background-color: #f5f5f5;
  }
  #flow_of_use .flow .unit:before {
    position: absolute;
    top: 0;
    left: -90px;
    display: block;
    content: "";
    width: 92px;
    height: 64px;
    background: url(../img/about/icn_flow_01.png) no-repeat left top;
    background-size: 92px 64px;
  }
  #flow_of_use .flow .unit.flow01:before {
    background: url(../img/about/icn_flow_01.png) no-repeat left top;
  }
  #flow_of_use .flow .unit.flow02:before {
    background: url(../img/about/icn_flow_02.png) no-repeat left top;
  }
  #flow_of_use .flow .unit.flow03:before {
    background: url(../img/about/icn_flow_03.png) no-repeat left top;
  }
  #flow_of_use .flow .unit.flow04:before {
    background: url(../img/about/icn_flow_04.png) no-repeat left top;
  }
  #flow_of_use .flow .unit.flow05:before {
    background: url(../img/about/icn_flow_05.png) no-repeat left top;
  }
  #flow_of_use .flow .unit.flow06:before {
    background: url(../img/about/icn_flow_06.png) no-repeat left top;
  }
  #flow_of_use .flow .unit.flow07:before {
    background: url(../img/about/icn_flow_07.png) no-repeat left top;
  }
  #flow_of_use .flow .unit h5 {
    margin-bottom: 10px;
    color: #6abc86;
    font-size: 20px;
    line-height: 1.2;
  }
  #flow_of_use .flow .unit p {
    line-height: 1.8;
  }
  #flow_of_use a {
    color: #6bbb87;
    text-decoration: underline;
  }
  #flow_of_use a:hover {
    text-decoration: none;
  }

  #en #main_visual {
    background: url(../img/about/img_about_main_en.png) no-repeat center top;
    background-size: contain;
  }
}
@media (min-width: 768px) and (max-width: 1024px) {
  #main_visual {
    box-sizing: border-box;
    position: relative;
    width: 100%;
    height: auto;
    margin: 0 auto 20px;
    padding-top: 31%;
    background: url(../img/about/img_about_main.png) no-repeat center top;
    background-size: contain;
  }
}
/* SP */
@media screen and (max-width: 768px) {
  #main_visual {
    box-sizing: border-box;
    position: relative;
    width: 100%;
    margin-bottom: 20px;
    padding-top: 34.4411%;
    background: url(../img/about/img_about_main_sp.png) no-repeat center top;
    background-size: contain;
  }
  #main_visual #borad {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 90%;
    max-width: 880px;
    height: 86px;
    margin: 0 auto;
    background: #6abc86;
    background: -webkit-linear-gradient(to left, #6abc86, #4d5dca);
    background: -mozlinear-gradient(to left, #6abc86, #4d5dca);
    background: -ms-linear-gradient(to left, #6abc86, #4d5dca);
    background: linear-gradient(to left, #6abc86, #4d5dca);
    text-align: center;
  }
  #main_visual #borad p {
    margin-bottom: 0;
    color: #fff;
    line-height: 1.2;
    font-size: 11px;
  }
  #main_visual #borad p span {
    color: #f6ff00;
    font-size: 11px;
  }

  #anchor_link {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    width: 100%;
    box-shadow: 3px 3px 0px rgba(0, 0, 0, 0.08);
  }
  #anchor_link li {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 50%;
    min-height: 50px;
    padding: 5px 0;
    background-color: #f6ff00;
    border-top: 1px solid #d1d900;
    border-left: 1px solid #d1d900;
    text-align: center;
  }
  #anchor_link li:first-child, #anchor_link li:nth-child(3) {
    border-left: none;
  }
  #anchor_link li:nth-child(1), #anchor_link li:nth-child(2) {
    border-top: none;
  }
  #anchor_link li:before {
    position: absolute;
    top: 50%;
    left: 10px;
    display: inline-block;
    content: "\f107";
    width: 1em;
    height: 1em;
    background-color: transparent;
    font-family: 'Font Awesome 5 Free';
    font-weight: bold;
    transform: translateY(-50%);
  }
  #anchor_link li:hover:before {
    top: 55%;
  }
  #anchor_link li a {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    padding: 0 12px 0 22px;
    color: #505050;
    font-weight: bold;
    font-size: 11px;
    text-decoration: none;
  }

  #background_purpose .flex_box {
    display: block;
    margin-bottom: 20px;
  }
  #background_purpose .flex_box .left {
    max-width: 373px;
    margin: 0 auto;
    text-align: center;
  }
  #background_purpose .flex_box .left img {
    width: 100%;
  }
  #background_purpose .flex_box .right {
    margin-left: 0;
  }
  #background_purpose .flex_box .right h4 {
    margin-bottom: 10px;
    color: #6bbc86;
    font-size: 18px;
    text-align: center;
  }
  #background_purpose .flex_box .right h4:before {
    display: none;
  }
  #background_purpose .flex_box .right p {
    line-height: 1.8;
  }
  #background_purpose #problem {
    padding: 30px 12px 15px;
    background-color: #f5f5f5;
  }
  #background_purpose #problem .unit {
    position: relative;
    width: 100%;
    margin-bottom: 30px;
    padding: 28px 2% 38px;
    background-color: #fff;
    text-align: center;
  }
  #background_purpose #problem .unit:last-child {
    margin-bottom: 0;
  }
  #background_purpose #problem .unit:before {
    position: absolute;
    top: -15px;
    left: 50%;
    display: block;
    content: "PROBLEM // 01";
    width: 128px;
    height: 30px;
    padding: 0 10px;
    color: #fff;
    background: #6abc86;
    background: -webkit-linear-gradient(to top, #6abc86, #4d5dca);
    background: -mozlinear-gradient(to top, #6abc86, #4d5dca);
    background: -ms-linear-gradient(to top, #6abc86, #4d5dca);
    background: linear-gradient(to top, #6abc86, #4d5dca);
    transform: translateX(-50%);
    font-size: 11px;
    line-height: 30px;
  }
  #background_purpose #problem .unit.problem01:before {
    content: "PROBLEM // 01";
  }
  #background_purpose #problem .unit.problem02:before {
    content: "PROBLEM // 02";
  }
  #background_purpose #problem .unit.problem03:before {
    content: "PROBLEM // 03";
  }
  #background_purpose #problem .unit.problem04:before {
    content: "PROBLEM // 04";
  }
  #background_purpose #problem .unit p {
    margin: 0 0 10px;
    color: #6bbc86;
    font-size: 16px;
    font-weight: bold;
    text-align: center;
  }
  #background_purpose #problem .unit img {
    display: block;
    width: 85px;
    margin: 0 auto;
  }

  #feature .points {
    padding: 40px 12px 15px;
    background-color: #f5f5f5;
  }
  #feature .points .unit {
    position: relative;
    width: 100%;
    padding: 26px 15px 19px;
    margin-bottom: 30px;
    background-color: #fff;
  }
  #feature .points .unit:last-child {
    margin-bottom: 0;
  }
  #feature .points .unit:before {
    position: absolute;
    top: -15px;
    left: 50%;
    display: block;
    content: "POINT // 01";
    width: 108px;
    height: 30px;
    padding: 0 10px;
    color: #fff;
    background: #6abc86;
    background: -webkit-linear-gradient(to top, #6abc86, #4d5dca);
    background: -mozlinear-gradient(to top, #6abc86, #4d5dca);
    background: -ms-linear-gradient(to top, #6abc86, #4d5dca);
    background: linear-gradient(to top, #6abc86, #4d5dca);
    transform: translateX(-50%);
    font-size: 11px;
    line-height: 30px;
    text-align: center;
  }
  #feature .points .unit.point01:before {
    content: "POINT // 01";
  }
  #feature .points .unit.point02:before {
    content: "POINT // 02";
  }
  #feature .points .unit.point03:before {
    content: "POINT // 03";
  }
  #feature .points .unit.point04:before {
    content: "POINT // 04";
  }
  #feature .points .unit h4 {
    margin: 0 0 10px;
    color: #6bbc86;
    font-size: 18px;
    font-weight: bold;
    text-align: center;
  }
  #feature .points .unit h4:before {
    display: none;
  }
  #feature .points .unit img {
    display: block;
    width: 112px;
    margin: 0 auto 12px;
  }
  #feature .points .unit p {
    font-size: 16px;
    line-height: 1.8;
  }

  #how_it_works .img img {
    width: 100%;
  }
  #how_it_works .works {
    padding: 12px;
    background-color: #f5f5f5;
  }
  #how_it_works .works .unit {
    position: relative;
    width: 100%;
    margin-bottom: 15px;
    background-color: #fff;
  }
  #how_it_works .works .unit:last-child {
    margin-bottom: 0;
  }
  #how_it_works .works .unit .ttl {
    display: flex;
    justify-content: space-between;
    justify-content: space-around;
    align-items: center;
    width: 100%;
    height: 46px;
    padding: 0 10px;
    color: #fff;
    background: #6abc86;
    background: -webkit-linear-gradient(to top, #6abc86, #4d5dca);
    background: -mozlinear-gradient(to top, #6abc86, #4d5dca);
    background: -ms-linear-gradient(to top, #6abc86, #4d5dca);
    background: linear-gradient(to top, #6abc86, #4d5dca);
    font-size: 17px;
    font-weight: bold;
  }
  #how_it_works .works .unit p {
    margin: 0;
    padding: 18px;
  }

  #flow_of_use {
    padding-bottom: 0;
  }
  #flow_of_use .flow {
    position: relative;
    margin-bottom: 30px;
  }
  #flow_of_use .flow:before {
    position: absolute;
    top: 0;
    left: 15px;
    display: block;
    content: "";
    width: 3px;
    height: 90%;
    background: #4e61c8;
  }
  #flow_of_use .flow .unit {
    position: relative;
    width: calc(100% - 46px);
    margin-left: 46px;
    margin-bottom: 16px;
    padding: 14px;
    background-color: #f5f5f5;
  }
  #flow_of_use .flow .unit:before {
    position: absolute;
    top: 0;
    left: -46px;
    display: block;
    content: "";
    width: 46px;
    height: 32px;
    background: url(../img/about/icn_flow_01.png) no-repeat left top;
    background-size: 46px 32px;
  }
  #flow_of_use .flow .unit.flow01:before {
    background: url(../img/about/icn_flow_01.png) no-repeat left top;
    background-size: 46px 32px;
  }
  #flow_of_use .flow .unit.flow02:before {
    background: url(../img/about/icn_flow_02.png) no-repeat left top;
    background-size: 46px 32px;
  }
  #flow_of_use .flow .unit.flow03:before {
    background: url(../img/about/icn_flow_03.png) no-repeat left top;
    background-size: 46px 32px;
  }
  #flow_of_use .flow .unit.flow04:before {
    background: url(../img/about/icn_flow_04.png) no-repeat left top;
    background-size: 46px 32px;
  }
  #flow_of_use .flow .unit.flow05:before {
    background: url(../img/about/icn_flow_05.png) no-repeat left top;
    background-size: 46px 32px;
  }
  #flow_of_use .flow .unit.flow06:before {
    background: url(../img/about/icn_flow_06.png) no-repeat left top;
    background-size: 46px 32px;
  }
  #flow_of_use .flow .unit.flow07:before {
    background: url(../img/about/icn_flow_07.png) no-repeat left top;
    background-size: 46px 32px;
  }
  #flow_of_use .flow .unit h5 {
    margin-bottom: 10px;
    color: #6abc86;
    font-size: 20px;
    line-height: 1.2;
  }
  #flow_of_use .flow .unit p {
    line-height: 1.8;
  }
  #flow_of_use a {
    color: #6bbb87;
    text-decoration: underline;
  }
  #flow_of_use a:hover {
    text-decoration: none;
  }

  #en #main_visual {
    background: url(../img/about/img_about_main_en_sp.png) no-repeat center top;
    background-size: contain;
  }
}

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