@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP&display=swap");
/* =======================================
 app page
======================================= */
.app-inner {
  font-family: "Noto Sans JP", "dnp-shuei-gothic-gin-std", sans-serif;
  -webkit-font-feature-settings: initial;
          font-feature-settings: initial;
}
@media screen and (min-width: 768px) {
  .app-inner {
    margin-inline: auto;
    max-width: 1200px;
    width: 93.75%;
  }
}
@media screen and (max-width: 767px) {
  .app-inner .none-sp {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .app-inner .none-pc {
    display: none;
  }
}

.app-headline2 {
  background: linear-gradient(0deg, rgb(92, 7, 12) 0%, rgb(184, 28, 34) 100%);
  color: #fff;
  font-weight: 500;
  position: relative;
}
@media screen and (max-width: 767px) {
  .app-headline2 {
    font-size: 5.067vw;
    letter-spacing: 0.075em;
    line-height: 1.2;
    padding-block: 1.067vw;
    padding-inline: 6.667vw 2.667vw;
  }
}
@media screen and (min-width: 768px) {
  .app-headline2 {
    font-size: 2.344vw;
    letter-spacing: 0.08em;
    line-height: 1.667;
    padding-block: 0.781vw;
    padding-inline: 3.906vw 4vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-headline2 {
    font-size: 30px;
    padding-block: 10px;
    -webkit-padding-start: 50px;
            padding-inline-start: 50px;
  }
}
.app-headline2::before {
  background: #fff;
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  .app-headline2::before {
    height: calc(100% - 2.66vw);
    left: 4.8vw;
    width: 0.4vw;
  }
}
@media screen and (min-width: 768px) {
  .app-headline2::before {
    height: calc(100% - 2.344vw);
    left: 2.109vw;
    width: 4px;
  }
}
@media screen and (min-width: 1280px) {
  .app-headline2::before {
    height: calc(100% - 30px);
    left: 27px;
  }
}

.app-headline3 {
  color: #231815;
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.2;
  position: relative;
}
@media screen and (max-width: 767px) {
  .app-headline3 {
    border-bottom: 3px solid #eabbbd;
    font-size: 4.8vw;
    margin-inline: auto;
    padding-block: 2vw;
    width: 91.867vw;
  }
}
@media screen and (min-width: 768px) {
  .app-headline3 {
    border-bottom: 2px solid #eabbbd;
    font-size: 2.031vw;
    letter-spacing: 0.05em;
    padding-block: 0.781vw;
    -webkit-padding-start: 2.344vw;
            padding-inline-start: 2.344vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-headline3 {
    font-size: 26px;
    padding-block: 10px;
    -webkit-padding-start: 30px;
            padding-inline-start: 30px;
  }
}
.app-headline3::before {
  background: #b81c22;
  bottom: 0;
  content: "";
  display: block;
  left: 0;
  position: absolute;
  -webkit-transform: translateY(100%);
          transform: translateY(100%);
}
@media screen and (max-width: 767px) {
  .app-headline3::before {
    height: 3px;
    width: 4.533vw;
  }
}
@media screen and (min-width: 768px) {
  .app-headline3::before {
    height: 2px;
    width: 2.344vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-headline3::before {
    width: 30px;
  }
}

@media screen and (max-width: 767px) {
  .app-headline2 + .app-headline3 {
    -webkit-margin-before: 6.667vw;
            margin-block-start: 6.667vw;
  }
}
@media screen and (min-width: 768px) {
  .app-headline2 + .app-headline3 {
    -webkit-margin-before: 2.344vw;
            margin-block-start: 2.344vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-headline2 + .app-headline3 {
    -webkit-margin-before: 30px;
            margin-block-start: 30px;
  }
}

.app-text {
  color: #1a1a1a;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .app-text {
    font-size: 3.467vw;
    letter-spacing: 0.16em;
    line-height: 1.731;
    width: 92vw;
  }
}
@media screen and (min-width: 768px) {
  .app-text {
    font-size: 1.406vw;
    letter-spacing: 0.05em;
    line-height: 1.667;
    width: 89.063vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-text {
    font-size: 18px;
    width: 1140px;
  }
}
.app-text p + p {
  -webkit-margin-before: 1.4em;
          margin-block-start: 1.4em;
}

.app-note {
  color: #1a1a1a;
}
@media screen and (max-width: 767px) {
  .app-note {
    font-size: 3.2vw;
  }
}
@media screen and (min-width: 768px) {
  .app-note {
    font-size: 1.25vw;
    letter-spacing: 0;
  }
}
@media screen and (min-width: 1280px) {
  .app-note {
    font-size: 16px;
  }
}

/* app-kv */
.app-kv {
  color: #fff;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .app-kv {
    background: url(../img/kv_bg_sp.jpg) 0 0/cover no-repeat;
    height: 156.533vw;
  }
}
@media screen and (min-width: 768px) {
  .app-kv {
    background: url(../img/kv_bg_pc.jpg) 50% 0/auto 100% no-repeat;
    height: 57.969vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-kv {
    background-size: cover;
    height: 742px;
  }
}

.app-kv_title {
  font-weight: 500;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .app-kv_title {
    font-size: 4vw;
    letter-spacing: 0.08em;
    -webkit-padding-before: 7.467vw;
            padding-block-start: 7.467vw;
  }
}
@media screen and (min-width: 768px) {
  .app-kv_title {
    font-size: 2.5vw;
    letter-spacing: 0.1em;
    -webkit-padding-before: 4.688vw;
            padding-block-start: 4.688vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-kv_title {
    font-size: 32px;
    -webkit-padding-before: 60px;
            padding-block-start: 60px;
  }
}

.app-kv_lead {
  border: solid #fff;
  display: inline-block;
  font-weight: 500;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .app-kv_lead {
    border-width: 1px 0;
    font-size: 4.933vw;
    letter-spacing: 0.16em;
    line-height: 1.757;
    -webkit-margin-before: 2vw;
            margin-block-start: 2vw;
    width: 91.333vw;
  }
}
@media screen and (min-width: 768px) {
  .app-kv_lead {
    border-width: 2px 0;
    font-size: 2.969vw;
    letter-spacing: 0.2em;
    line-height: 1.658;
    -webkit-margin-before: 1.172vw;
            margin-block-start: 1.172vw;
    min-width: 55.781vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-kv_lead {
    font-size: 38px;
    -webkit-margin-before: 15px;
            margin-block-start: 15px;
    min-width: 714px;
  }
}

.app-kv_catch {
  font-weight: 500;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .app-kv_catch {
    font-size: 8vw;
    letter-spacing: 0.1em;
    -webkit-margin-before: 3.333vw;
            margin-block-start: 3.333vw;
  }
}
@media screen and (min-width: 768px) {
  .app-kv_catch {
    font-size: 5.781vw;
    letter-spacing: 0.2em;
    -webkit-margin-before: 1.563vw;
            margin-block-start: 1.563vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-kv_catch {
    font-size: 74px;
    -webkit-margin-before: 20px;
            margin-block-start: 20px;
  }
}

.app-kv_image {
  margin-inline: auto;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .app-kv_image {
    -webkit-margin-before: 8vw;
            margin-block-start: 8vw;
    width: 92vw;
  }
}
@media screen and (min-width: 768px) {
  .app-kv_image {
    -webkit-margin-before: 2.969vw;
            margin-block-start: 2.969vw;
    width: 89.063vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-kv_image {
    -webkit-margin-before: 38px;
            margin-block-start: 38px;
    width: 1140px;
  }
}

.app-logo {
  background: rgba(255, 255, 255, 0.75);
}
@media screen and (max-width: 767px) {
  .app-logo {
    -webkit-margin-before: -20vw;
            margin-block-start: -20vw;
    padding-block: 24.933vw 5.6vw;
  }
}
@media screen and (min-width: 768px) {
  .app-logo {
    -webkit-margin-before: -4.375vw;
            margin-block-start: -4.375vw;
    padding-block: 6.406vw 1.719vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-logo {
    -webkit-margin-before: -56px;
            margin-block-start: -56px;
    padding-block: 82px 22px;
  }
}

.app-logo_list {
  display: flex;
}
@media screen and (max-width: 767px) {
  .app-logo_list {
    flex-wrap: wrap;
    gap: 2.133vw 3.467vw;
    justify-content: center;
  }
}
@media screen and (min-width: 768px) {
  .app-logo_list {
    justify-content: space-between;
  }
}

@media screen and (max-width: 767px) {
  .app-logo_item {
    width: 44vw;
  }
}
@media screen and (min-width: 768px) {
  .app-logo_item {
    width: 20.859vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-logo_item {
    width: 267px;
  }
}

/* app-strength */
@media screen and (max-width: 767px) {
  .app-strength {
    padding-block: 9.333vw 11.333vw;
  }
}
@media screen and (min-width: 768px) {
  .app-strength {
    padding-block: 4.531vw 6.406vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-strength {
    padding-block: 58px 82px;
  }
}

.app-strength_title {
  border: solid #b81c22;
  color: #b81c22;
  font-weight: 700;
  letter-spacing: 0.08em;
  margin-inline: auto;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .app-strength_title {
    border-width: 1px 0;
    font-size: 5.733vw;
    line-height: 2;
    width: 84vw;
  }
}
@media screen and (min-width: 768px) {
  .app-strength_title {
    border-width: 2px 0;
    font-size: 2.656vw;
    letter-spacing: 0.2em;
    line-height: 1.824;
    width: 39.219vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-strength_title {
    font-size: 34px;
    width: 502px;
  }
}

.app-strength_list {
  display: flex;
  justify-content: space-between;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .app-strength_list {
    -webkit-margin-before: 6.667vw;
            margin-block-start: 6.667vw;
    width: 92vw;
  }
}
@media screen and (min-width: 768px) {
  .app-strength_list {
    -webkit-margin-before: 4.297vw;
            margin-block-start: 4.297vw;
    width: 89.063vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-strength_list {
    -webkit-margin-before: 55px;
            margin-block-start: 55px;
    width: 1140px;
  }
}

@media screen and (max-width: 767px) {
  .app-strength_item {
    width: 29.333vw;
  }
}
@media screen and (min-width: 768px) {
  .app-strength_item {
    width: 28.125vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-strength_item {
    width: 360px;
  }
}

.app-strength_link {
  border: solid #b81c22;
  display: flex;
  flex-direction: column;
  height: 100%;
  position: relative;
}
@media screen and (max-width: 767px) {
  .app-strength_link {
    border-width: 2px 2px 2vw;
    padding-block: 3.333vw 4.667vw;
  }
}
@media screen and (min-width: 768px) {
  .app-strength_link {
    border-width: 1px 1px 0.781vw;
    padding-block: 2.344vw 1.563vw;
    -webkit-padding-start: 8.438vw;
            padding-inline-start: 8.438vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-strength_link {
    border-width: 1px 1px 10px;
    padding-bottom: 30px 20px;
    -webkit-padding-start: 108px;
            padding-inline-start: 108px;
  }
}
@media (any-hover: hover) {
  .app-strength_link:hover {
    background: #f6e4e4;
    opacity: 0.8;
  }
  .app-strength_link:hover .app-strength_item_title::before {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2093%2093%22%3E%20%3Cpath%20fill%3D%22%23f6e4e4%22%20d%3D%22M0%2093h93V0%22%2F%3E%3C%2Fsvg%3E");
  }
}

.app-strength_item_title {
  color: #b81c22;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .app-strength_item_title {
    position: relative;
    -webkit-margin-start: 2.667vw;
            margin-inline-start: 2.667vw;
  }
}
@media screen and (min-width: 768px) {
  .app-strength_item_title {
    left: 1.719vw;
    position: absolute;
    top: 1.563vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-strength_item_title {
    left: 22px;
    top: 20px;
  }
}
.app-strength_item_title::before, .app-strength_item_title::after {
  aspect-ratio: 1/1;
  background-repeat: no-repeat;
  background-size: auto 100%;
  content: "";
  position: absolute;
}
@media screen and (max-width: 767px) {
  .app-strength_item_title::before, .app-strength_item_title::after {
    bottom: -4vw;
    height: 12.4vw;
    left: 5.333vw;
  }
}
@media screen and (min-width: 768px) {
  .app-strength_item_title::before, .app-strength_item_title::after {
    bottom: -2.344vw;
    height: 7.266vw;
    left: 3.125vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-strength_item_title::before, .app-strength_item_title::after {
    bottom: -30px;
    height: 93px;
    left: 40px;
  }
}
.app-strength_item_title::before {
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2093%2093%22%3E%20%3Cpath%20fill%3D%22%23fff%22%20d%3D%22M0%2093h93V0%22%2F%3E%3C%2Fsvg%3E");
}
.app-strength_item_title::after {
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2093.52%2093.52%22%3E%20%3Cpath%20fill%3D%22none%22%20stroke%3D%22%23b81c22%22%20stroke-miterlimit%3D%2210%22%20d%3D%22M93.17.35.35%2093.17%22%2F%3E%3C%2Fsvg%3E");
}

.app-strength_item_lead {
  letter-spacing: 0.1em;
}
@media screen and (max-width: 767px) {
  .app-strength_item_lead {
    font-size: 3.2vw;
    -webkit-padding-start: 0.25em;
            padding-inline-start: 0.25em;
  }
}
@media screen and (min-width: 768px) {
  .app-strength_item_lead {
    font-size: 1.875vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-strength_item_lead {
    font-size: 24px;
  }
}

.app-strength_item_num {
  display: block;
  letter-spacing: 0.05em;
  -webkit-margin-before: -0.1em;
          margin-block-start: -0.1em;
}
@media screen and (max-width: 767px) {
  .app-strength_item_num {
    font-size: 10.933vw;
  }
}
@media screen and (min-width: 768px) {
  .app-strength_item_num {
    font-size: 6.406vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-strength_item_num {
    font-size: 82px;
  }
}

@media screen and (max-width: 767px) {
  .app-strength_item_icon {
    position: absolute;
    right: 3.467vw;
    top: 14.667vw;
    width: 11.333vw;
    z-index: 1;
  }
}
@media screen and (min-width: 768px) {
  .app-strength_item_icon {
    margin-inline: auto;
    width: 6.25vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-strength_item_icon {
    width: 80px;
  }
}
@media screen and (max-width: 767px) {
  .app-strength_item_icon.--point03 {
    right: 2vw;
    top: 15.333vw;
    width: 15.067vw;
  }
}

.app-strength_item_text {
  color: #333;
  position: relative;
  text-align: center;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .app-strength_item_text {
    align-items: center;
    font-size: 3.2vw;
    display: flex;
    justify-content: center;
    letter-spacing: 0;
    line-height: 1.25;
    -webkit-margin-before: 13.333vw;
            margin-block-start: 13.333vw;
    min-height: 14.667vw;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .app-strength_item_text {
    font-size: 1.563vw;
    letter-spacing: 0.1em;
    line-height: 1.5;
    -webkit-margin-before: 0.781vw;
            margin-block-start: 0.781vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-strength_item_text {
    font-size: 20px;
    -webkit-margin-before: 10px;
            margin-block-start: 10px;
  }
}

.app-strength_btn {
  font-weight: 500;
  letter-spacing: 0.1em;
  margin-inline: auto;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .app-strength_btn {
    font-size: 3.92vw;
    line-height: 3.605;
    -webkit-margin-before: 7.467vw;
            margin-block-start: 7.467vw;
    width: 92vw;
  }
}
@media screen and (min-width: 768px) {
  .app-strength_btn {
    font-size: 1.563vw;
    line-height: 3.8;
    -webkit-margin-before: 4.219vw;
            margin-block-start: 4.219vw;
    width: 39.063vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-strength_btn {
    -webkit-margin-before: 54px;
            margin-block-start: 54px;
    width: 500px;
  }
}

.app-strength_btn_link {
  background: #000;
  color: #fff;
  display: block;
  position: relative;
}
@media screen and (max-width: 767px) {
  .app-strength_btn_link {
    border: 1px solid #b0b1b0;
    border-radius: 1.333vw;
  }
}
@media screen and (min-width: 768px) {
  .app-strength_btn_link {
    border: 2px solid #b0b1b0;
    border-radius: 0.781vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-strength_btn_link {
    border-radius: 10px;
  }
}

.app-strength_btn_arrow {
  fill: none;
  position: absolute;
  stroke: #fff;
  stroke-miterlimit: 10;
  stroke-width: 2;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  .app-strength_btn_arrow {
    right: 4.667vw;
    width: 2.533vw;
  }
}
@media screen and (min-width: 768px) {
  .app-strength_btn_arrow {
    right: 1.953vw;
    width: 1.016vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-strength_btn_arrow {
    right: 25px;
    width: 13px;
  }
}

/* app-skim */
@media screen and (max-width: 767px) {
  .app-skim {
    padding-block: 0 20vw;
  }
}
@media screen and (min-width: 768px) {
  .app-skim {
    padding-block: 0 9.375vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-skim {
    padding-block: 0 120px;
  }
}

.app-skim_logo {
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .app-skim_logo {
    -webkit-margin-before: 10.667vw;
            margin-block-start: 10.667vw;
    width: 85.2vw;
  }
}
@media screen and (min-width: 768px) {
  .app-skim_logo {
    -webkit-margin-before: 5.469vw;
            margin-block-start: 5.469vw;
    width: 45.313vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-skim_logo {
    -webkit-margin-before: 70px;
            margin-block-start: 70px;
    width: 580px;
  }
}

@media screen and (max-width: 767px) {
  .app-text.--skim {
    -webkit-margin-before: 10vw;
            margin-block-start: 10vw;
  }
}
@media screen and (min-width: 768px) {
  .app-text.--skim {
    -webkit-margin-before: 5.078vw;
            margin-block-start: 5.078vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-text.--skim {
    -webkit-margin-before: 65px;
            margin-block-start: 65px;
  }
}

.app-skim_box {
  background: #f5f5f5;
  border: 1px solid #999;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .app-skim_box {
    -webkit-margin-before: 14.667vw;
            margin-block-start: 14.667vw;
    padding-block: 8vw 6.667vw;
    width: 92vw;
  }
}
@media screen and (min-width: 768px) {
  .app-skim_box {
    -webkit-margin-before: 5.469vw;
            margin-block-start: 5.469vw;
    padding-block: 5.078vw;
    width: 85.938vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-skim_box {
    -webkit-margin-before: 70px;
            margin-block-start: 70px;
    padding-block: 65px;
    width: 1100px;
  }
}

.spp-skim_box_title {
  color: #231815;
  display: inline-block;
  font-weight: 700;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .spp-skim_box_title {
    border-bottom: 2px solid #b81c22;
    font-size: 3.2vw;
    letter-spacing: 0.1em;
    -webkit-padding-after: 1.333vw;
            padding-block-end: 1.333vw;
    padding-inline: 3.333vw 2vw;
  }
}
@media screen and (min-width: 768px) {
  .spp-skim_box_title {
    border-bottom: 4px solid #b81c22;
    font-size: 2.188vw;
    letter-spacing: 0.08em;
    -webkit-padding-after: 2vw;
            padding-block-end: 2vw;
    padding-inline: 3.125vw 1.333vw;
  }
}
@media screen and (min-width: 1280px) {
  .spp-skim_box_title {
    font-size: 28px;
    -webkit-padding-after: 15px;
            padding-block-end: 15px;
    padding-inline: 40px 10px;
  }
}

.spp-skim_box_image {
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .spp-skim_box_image {
    -webkit-margin-before: -3.467vw;
            margin-block-start: -3.467vw;
    width: 85.333vw;
  }
}
@media screen and (min-width: 768px) {
  .spp-skim_box_image {
    -webkit-margin-before: -3.125vw;
            margin-block-start: -3.125vw;
    width: 78.906vw;
  }
}
@media screen and (min-width: 1280px) {
  .spp-skim_box_image {
    -webkit-margin-before: -40px;
            margin-block-start: -40px;
    width: 1010px;
  }
}

.spp-skim_box_text {
  color: #231815;
  margin-inline: auto;
  position: relative;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .spp-skim_box_text {
    font-size: 3.067vw;
    letter-spacing: 0.03em;
    line-height: 1.739;
    -webkit-margin-before: 6.667vw;
            margin-block-start: 6.667vw;
    padding-block: 1.333vw;
    padding-inline: 1.333vw;
    width: 83.467vw;
  }
}
@media screen and (min-width: 768px) {
  .spp-skim_box_text {
    font-size: 2.031vw;
    letter-spacing: 0.08em;
    line-height: 1.538;
    -webkit-margin-before: 2.734vw;
            margin-block-start: 2.734vw;
    padding-block: 1.172vw;
    padding-inline: 0.781vw;
    width: 60.938vw;
  }
}
@media screen and (min-width: 1280px) {
  .spp-skim_box_text {
    font-size: 26px;
    -webkit-margin-before: 35px;
            margin-block-start: 35px;
    padding-block: 15px;
    padding-inline: 10px;
    width: 780px;
  }
}
.spp-skim_box_text::before, .spp-skim_box_text::after {
  border: 1px solid #4d4d4d;
  content: "";
  display: block;
  height: 100%;
  position: absolute;
  top: 0;
}
@media screen and (max-width: 767px) {
  .spp-skim_box_text::before, .spp-skim_box_text::after {
    width: 1.333vw;
  }
}
@media screen and (min-width: 768px) {
  .spp-skim_box_text::before, .spp-skim_box_text::after {
    width: 0.781vw;
  }
}
@media screen and (min-width: 1280px) {
  .spp-skim_box_text::before, .spp-skim_box_text::after {
    width: 10px;
  }
}
.spp-skim_box_text::before {
  border-right: 0;
  left: 0;
}
.spp-skim_box_text::after {
  border-left: 0;
  right: 0;
}

/* app-point */
.app-point {
  background: #f5f5f5;
}
@media screen and (max-width: 767px) {
  .app-point {
    padding-block: 11.333vw 14.667vw;
  }
}
@media screen and (min-width: 768px) {
  .app-point {
    padding-block: 8.594vw 9.766vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-point {
    padding-block: 110px 125px;
  }
}

@media screen and (max-width: 767px) {
  .app-point_sec {
    margin-inline: auto;
    width: 92vw;
  }
}
@media screen and (max-width: 767px) {
  .app-point_sec:not(:nth-of-type(1)) {
    -webkit-margin-before: 8.667vw;
            margin-block-start: 8.667vw;
  }
}
@media screen and (min-width: 768px) {
  .app-point_sec:not(:nth-of-type(1)) {
    -webkit-margin-before: 5.078vw;
            margin-block-start: 5.078vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-point_sec:not(:nth-of-type(1)) {
    -webkit-margin-before: 65px;
            margin-block-start: 65px;
  }
}

.app-point_header {
  display: flex;
  position: relative;
}
@media screen and (max-width: 767px) {
  .app-point_header {
    border-bottom: 1px solid #eabbbd;
    gap: 8.667vw;
    -webkit-padding-after: 3.333vw;
            padding-block-end: 3.333vw;
  }
}
@media screen and (min-width: 768px) {
  .app-point_header {
    border-bottom: 2px solid #eabbbd;
    gap: 3.516vw;
    -webkit-padding-after: 2.734vw;
            padding-block-end: 2.734vw;
    -webkit-padding-start: 2.344vw;
            padding-inline-start: 2.344vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-point_header {
    gap: 45px;
    padding-block: 35px;
    -webkit-padding-start: 30px;
            padding-inline-start: 30px;
  }
}
.app-point_header::before {
  background: #b81c22;
  bottom: 0;
  content: "";
  display: block;
  left: 0;
  position: absolute;
  -webkit-transform: translateY(100%);
          transform: translateY(100%);
}
@media screen and (max-width: 767px) {
  .app-point_header::before {
    height: 1px;
    width: 4.8vw;
  }
}
@media screen and (min-width: 768px) {
  .app-point_header::before {
    height: 2px;
    width: 2.344vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-point_header::before {
    width: 30px;
  }
}

.app-point_title {
  color: #b81c22;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .app-point_title {
    width: 13.333vw;
  }
}
@media screen and (min-width: 768px) {
  .app-point_title {
    width: 7.813vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-point_title {
    width: 100px;
  }
}

.app-point_lead {
  letter-spacing: 0.1em;
}
@media screen and (max-width: 767px) {
  .app-point_lead {
    font-size: 3.2vw;
    -webkit-padding-start: 0.25em;
            padding-inline-start: 0.25em;
  }
}
@media screen and (min-width: 768px) {
  .app-point_lead {
    font-size: 1.875vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-point_lead {
    font-size: 24px;
  }
}

.app-point_num {
  display: block;
  letter-spacing: 0.05em;
  -webkit-margin-before: -0.1em;
          margin-block-start: -0.1em;
}
@media screen and (max-width: 767px) {
  .app-point_num {
    font-size: 10.933vw;
  }
}
@media screen and (min-width: 768px) {
  .app-point_num {
    font-size: 6.406vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-point_num {
    font-size: 82px;
  }
}

.app-point_catch {
  color: #231815;
  font-weight: 600;
  margin-block: 0;
}
@media screen and (max-width: 767px) {
  .app-point_catch {
    font-size: 4.8vw;
    letter-spacing: 0;
    line-height: 1.611;
    width: 70vw;
  }
}
@media screen and (min-width: 768px) {
  .app-point_catch {
    font-size: 2.656vw;
    letter-spacing: 0.08em;
    line-height: 1.471;
    width: 78.125vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-point_catch {
    font-size: 34px;
    width: 1000px;
  }
}

@media screen and (max-width: 767px) {
  .app-point_main {
    -webkit-margin-before: 10.667vw;
            margin-block-start: 10.667vw;
  }
}
@media screen and (min-width: 768px) {
  .app-point_main {
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
    -webkit-margin-before: 3.516vw;
            margin-block-start: 3.516vw;
    margin-inline: auto;
    width: 89.063vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-point_main {
    -webkit-margin-before: 45px;
            margin-block-start: 45px;
    width: 1140px;
  }
}
@media screen and (min-width: 768px) {
  .app-point_main.--point03 {
    display: inherit;
  }
}

@media screen and (min-width: 768px) {
  .app-point_image {
    width: 39.844vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-point_image {
    width: 510px;
  }
}

@media screen and (max-width: 767px) {
  .app-point_content {
    -webkit-margin-before: 5.333vw;
            margin-block-start: 5.333vw;
  }
}
@media screen and (min-width: 768px) {
  .app-point_content {
    width: 46.094vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-point_content {
    width: 590px;
  }
}

.app-point_text {
  color: #1a1a1a;
}
@media screen and (max-width: 767px) {
  .app-point_text {
    font-size: 3.467vw;
    letter-spacing: 0;
    line-height: 1.731;
    width: 92vw;
  }
}
@media screen and (min-width: 768px) {
  .app-point_text {
    font-size: 1.406vw;
    letter-spacing: 0.05em;
    line-height: 1.667;
  }
}
@media screen and (min-width: 1280px) {
  .app-point_text {
    font-size: 18px;
  }
}
.app-point_text p + p {
  -webkit-margin-before: 1.4em;
          margin-block-start: 1.4em;
}
.app-point_text strong {
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .app-point_text strong {
    font-size: 1.563vw;
    line-height: 1.3;
  }
}
@media screen and (min-width: 1280px) {
  .app-point_text strong {
    font-size: 20px;
  }
}

.app-point_note {
  color: #1a1a1a;
}
@media screen and (max-width: 767px) {
  .app-point_note {
    font-size: 2.4vw;
    letter-spacing: 0.05em;
  }
}
@media screen and (min-width: 768px) {
  .app-point_note {
    font-size: 1.016vw;
    letter-spacing: 0.05em;
  }
}
@media screen and (min-width: 1280px) {
  .app-point_note {
    font-size: 13px;
  }
}

.app-satisfaction {
  align-items: baseline;
  display: flex;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .app-satisfaction {
    gap: 1.333vw;
    -webkit-margin-after: 3.2vw;
            margin-block-end: 3.2vw;
  }
}
@media screen and (min-width: 768px) {
  .app-satisfaction {
    gap: 0.781vw;
    -webkit-margin-after: 2.344vw;
            margin-block-end: 2.344vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-satisfaction {
    gap: 10px;
    -webkit-margin-after: 30px;
            margin-block-end: 30px;
  }
}

.app-satisfaction_lead {
  color: #1a1a1a;
}
@media screen and (max-width: 767px) {
  .app-satisfaction_lead {
    font-size: 4.267vw;
    letter-spacing: 0;
  }
}
@media screen and (min-width: 768px) {
  .app-satisfaction_lead {
    font-size: 2.031vw;
    letter-spacing: 0.05em;
  }
}
@media screen and (min-width: 1280px) {
  .app-satisfaction_lead {
    font-size: 26px;
  }
}

.app-satisfaction_data {
  color: #b81c22;
  font-weight: 700;
  letter-spacing: 0;
}
@media screen and (max-width: 767px) {
  .app-satisfaction_data {
    font-size: 10.4vw;
  }
}
@media screen and (min-width: 768px) {
  .app-satisfaction_data {
    font-size: 4.688vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-satisfaction_data {
    font-size: 60px;
  }
}

.app-satisfaction_small {
  font-size: 70%;
  font-weight: 400;
}

@media screen and (max-width: 767px) {
  .app-voice {
    -webkit-margin-before: 12vw;
            margin-block-start: 12vw;
  }
}
@media screen and (min-width: 768px) {
  .app-voice {
    -webkit-margin-before: 5.469vw;
            margin-block-start: 5.469vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-voice {
    -webkit-margin-before: 70px;
            margin-block-start: 70px;
  }
}

.app-voice_title {
  color: #231815;
  margin-inline: auto;
  position: relative;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .app-voice_title {
    font-size: 4.4vw;
    letter-spacing: 0.08em;
    line-height: 1.788;
    width: 71.467vw;
  }
}
@media screen and (min-width: 768px) {
  .app-voice_title {
    font-size: 2.344vw;
    letter-spacing: 0;
    line-height: 1.667;
    width: 34.375vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-voice_title {
    font-size: 30px;
    width: 440px;
  }
}
.app-voice_title::before, .app-voice_title::after {
  border: 1px solid #4d4d4d;
  content: "";
  display: block;
  height: 100%;
  position: absolute;
  top: 0;
}
@media screen and (max-width: 767px) {
  .app-voice_title::before, .app-voice_title::after {
    width: 1.6vw;
  }
}
@media screen and (min-width: 768px) {
  .app-voice_title::before, .app-voice_title::after {
    width: 0.781vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-voice_title::before, .app-voice_title::after {
    width: 10px;
  }
}
.app-voice_title::before {
  border-right: 0;
  left: 0;
}
.app-voice_title::after {
  border-left: 0;
  right: 0;
}

.app-voice_list {
  display: flex;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .app-voice_list {
    flex-direction: column;
    gap: 8.667vw;
    -webkit-margin-before: 11.333vw;
            margin-block-start: 11.333vw;
    width: 89.333vw;
  }
}
@media screen and (min-width: 768px) {
  .app-voice_list {
    justify-content: space-between;
    -webkit-margin-before: 5.859vw;
            margin-block-start: 5.859vw;
    width: 89.063vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-voice_list {
    -webkit-margin-before: 75px;
            margin-block-start: 75px;
    width: 1140px;
  }
}

.app-voice_item {
  background: #fff;
  position: relative;
}
@media screen and (max-width: 767px) {
  .app-voice_item {
    border: 2px solid #b81c22;
    min-height: 39.333vw;
    padding-block: 3.333vw;
  }
}
@media screen and (min-width: 768px) {
  .app-voice_item {
    border: 4px solid #b81c22;
    padding-block: 16.406vw 6.25vw;
    width: 27.344vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-voice_item {
    padding-block: 210px 80px;
    width: 350px;
  }
}

.app-voice_avatar {
  position: absolute;
}
@media screen and (max-width: 767px) {
  .app-voice_avatar {
    top: -3.333vw;
  }
}
@media screen and (min-width: 768px) {
  .app-voice_avatar {
    font-size: 1.406vw;
    line-height: 1.75;
    margin-inline: auto;
    width: 21.875vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-voice_avatar {
    font-size: 18px;
    width: 280px;
  }
}
@media screen and (max-width: 767px) {
  .app-voice_avatar.--01 {
    left: 0.267vw;
    width: 32.267vw;
  }
}
@media screen and (min-width: 768px) {
  .app-voice_avatar.--01 {
    left: 4.844vw;
    top: -2.813vw;
    width: 18.906vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-voice_avatar.--01 {
    left: 62px;
    top: -36px;
    width: 242px;
  }
}
@media screen and (max-width: 767px) {
  .app-voice_avatar.--02 {
    left: 57.333vw;
    width: 27.733vw;
  }
}
@media screen and (min-width: 768px) {
  .app-voice_avatar.--02 {
    left: 5.313vw;
    top: -2.656vw;
    width: 16.25vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-voice_avatar.--02 {
    left: 68px;
    top: -34px;
    width: 208px;
  }
}
@media screen and (max-width: 767px) {
  .app-voice_avatar.--03 {
    left: 4.8vw;
    width: 26.133vw;
  }
}
@media screen and (min-width: 768px) {
  .app-voice_avatar.--03 {
    left: 6.875vw;
    top: -1.953vw;
    width: 15.313vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-voice_avatar.--03 {
    left: 88px;
    top: -25px;
    width: 196px;
  }
}

.app-voice_text {
  color: #1a1a1a;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 767px) {
  .app-voice_text {
    font-size: 3.467vw;
    line-height: 1.75;
    width: 50.133vw;
  }
}
@media screen and (min-width: 768px) {
  .app-voice_text {
    font-size: 1.406vw;
    line-height: 1.75;
    margin-inline: auto;
    width: 21.875vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-voice_text {
    font-size: 18px;
    width: 280px;
  }
}

.app-voice_name {
  color: #1a1a1a;
  letter-spacing: 0.1em;
  line-height: 1;
  position: absolute;
  text-align: right;
}
@media screen and (max-width: 767px) {
  .app-voice_name {
    bottom: 3.333vw;
    font-size: 3.467vw;
    width: 30.667vw;
  }
}
@media screen and (min-width: 768px) {
  .app-voice_name {
    border-top: 1px solid #808080;
    bottom: 2.5vw;
    font-size: 1.406vw;
    left: 1.953vw;
    margin-inline: auto;
    -webkit-padding-before: 1.406vw;
            padding-block-start: 1.406vw;
    width: 21.875vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-voice_name {
    bottom: 32px;
    font-size: 18px;
    left: 25px;
    width: 280px;
  }
}

@media screen and (max-width: 767px) {
  .app-voice_item:nth-child(2n+1) .app-voice_text {
    -webkit-margin-start: 34.667vw;
            margin-inline-start: 34.667vw;
  }
}
@media screen and (max-width: 767px) {
  .app-voice_item:nth-child(2n+1) .app-voice_name {
    left: 0;
  }
}
@media screen and (max-width: 767px) {
  .app-voice_item:nth-child(2n) .app-voice_text {
    -webkit-margin-start: 4.8vw;
            margin-inline-start: 4.8vw;
  }
}
@media screen and (max-width: 767px) {
  .app-voice_item:nth-child(2n) .app-voice_name {
    left: 56vw;
  }
}

/* app-distribution */
@media screen and (max-width: 767px) {
  .app-distribution {
    padding-block: 12.667vw 16.667vw;
  }
}
@media screen and (min-width: 768px) {
  .app-distribution {
    padding-block: 9.766vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-distribution {
    padding-block: 125px;
  }
}

@media screen and (max-width: 767px) {
  .app-text.--distribution {
    -webkit-margin-before: 6.667vw;
            margin-block-start: 6.667vw;
  }
}
@media screen and (min-width: 768px) {
  .app-text.--distribution {
    -webkit-margin-before: 2.734vw;
            margin-block-start: 2.734vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-text.--distribution {
    -webkit-margin-before: 35px;
            margin-block-start: 35px;
  }
}

.app-graph {
  background: #f5f5f5;
  border: 1px solid #999;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .app-graph {
    -webkit-margin-before: 12vw;
            margin-block-start: 12vw;
    padding-block: 5.333vw;
    width: 94.667vw;
  }
}
@media screen and (min-width: 768px) {
  .app-graph {
    -webkit-margin-before: 6.25vw;
            margin-block-start: 6.25vw;
    padding-block: 3.125vw;
    width: 85.938vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-graph {
    -webkit-margin-before: 80px;
            margin-block-start: 80px;
    padding-block: 40px;
    width: 1100px;
  }
}
@media screen and (max-width: 767px) {
  .app-graph.--price {
    -webkit-margin-before: 9.333vw;
            margin-block-start: 9.333vw;
    -webkit-padding-after: 6.667vw;
            padding-block-end: 6.667vw;
  }
}
@media screen and (min-width: 768px) {
  .app-graph.--price {
    -webkit-margin-before: 5.469vw;
            margin-block-start: 5.469vw;
    -webkit-padding-after: 5.078vw;
            padding-block-end: 5.078vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-graph.--price {
    -webkit-margin-before: 70px;
            margin-block-start: 70px;
    -webkit-padding-after: 65px;
            padding-block-end: 65px;
  }
}

.app-graph_caption {
  color: #231815;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
  margin-block: 0;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .app-graph_caption {
    font-size: 3.467vw;
  }
}
@media screen and (min-width: 768px) {
  .app-graph_caption {
    font-size: 2.188vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-graph_caption {
    font-size: 28px;
  }
}

.app-graph_image {
  display: block;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .app-graph_image {
    -webkit-margin-before: 5.333vw;
            margin-block-start: 5.333vw;
    width: 88vw;
  }
}
@media screen and (min-width: 768px) {
  .app-graph_image {
    -webkit-margin-before: 4.688vw;
            margin-block-start: 4.688vw;
    width: 76.875vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-graph_image {
    -webkit-margin-before: 60px;
            margin-block-start: 60px;
    width: 984px;
  }
}
@media screen and (max-width: 767px) {
  .app-graph_image.--number {
    -webkit-margin-before: 6.667vw;
            margin-block-start: 6.667vw;
  }
}

/* app-info */
.app-info {
  background: linear-gradient(180deg, rgb(184, 28, 34) 0%, rgb(92, 7, 12) 100%);
}
@media screen and (max-width: 767px) {
  .app-info {
    padding-block: 10vw 16.667vw;
  }
}
@media screen and (min-width: 768px) {
  .app-info {
    padding-block: 7.813vw 8.984vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-info {
    padding-block: 100px 115px;
  }
}

.app-info_lead {
  color: #fff;
  font-weight: 700;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .app-info_lead {
    font-size: 5.867vw;
    letter-spacing: 0.1em;
    line-height: 1.455;
  }
}
@media screen and (min-width: 768px) {
  .app-info_lead {
    font-size: 2.813vw;
    letter-spacing: 0.08em;
    line-height: 1.556;
  }
}
@media screen and (min-width: 1280px) {
  .app-info_lead {
    font-size: 36px;
  }
}
.app-info_lead::after {
  background: #fff;
  content: "";
  display: block;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .app-info_lead::after {
    height: 2px;
    -webkit-margin-before: 6vw;
            margin-block-start: 6vw;
    width: 13.6vw;
  }
}
@media screen and (min-width: 768px) {
  .app-info_lead::after {
    height: 3px;
    -webkit-margin-before: 1.953vw;
            margin-block-start: 1.953vw;
    width: 7.813vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-info_lead::after {
    -webkit-margin-before: 25px;
            margin-block-start: 25px;
    width: 100px;
  }
}

.app-info_title {
  color: #fff;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .app-info_title {
    font-size: 4vw;
    -webkit-margin-before: 6.667vw;
            margin-block-start: 6.667vw;
  }
}
@media screen and (min-width: 768px) {
  .app-info_title {
    font-size: 2.031vw;
    -webkit-margin-before: 2.734vw;
            margin-block-start: 2.734vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-info_title {
    font-size: 26px;
    -webkit-margin-before: 35px;
            margin-block-start: 35px;
  }
}

.app-screenshot {
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .app-screenshot {
    display: grid;
    grid-template-columns: repeat(4, 19.6vw);
    grid-template-rows: repeat(2, 1fr);
    gap: 4vw 2.667vw;
    -webkit-margin-before: 10vw;
            margin-block-start: 10vw;
    margin-inline: auto;
    width: 81.067vw;
  }
}
@media screen and (min-width: 768px) {
  .app-screenshot {
    display: flex;
    gap: 4.063vw;
    justify-content: center;
    -webkit-margin-before: 4.297vw;
            margin-block-start: 4.297vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-screenshot {
    gap: 52px;
    -webkit-margin-before: 55px;
            margin-block-start: 55px;
  }
}

@media screen and (min-width: 768px) {
  .app-screenshot_item {
    width: 20.781vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-screenshot_item {
    width: 266px;
  }
}
@media screen and (max-width: 767px) {
  .app-screenshot_item.--01 {
    grid-area: 1/2/2/4;
  }
}
@media screen and (max-width: 767px) {
  .app-screenshot_item.--02 {
    grid-area: 2/1/3/3;
  }
}
@media screen and (max-width: 767px) {
  .app-screenshot_item.--03 {
    grid-area: 2/3/3/5;
  }
}

.app-info_box {
  background: #fff;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .app-info_box {
    border-radius: 2vw;
    -webkit-margin-before: -30vw;
            margin-block-start: -30vw;
    padding-block: 36.667vw 11.333vw;
    width: 92vw;
  }
}
@media screen and (min-width: 768px) {
  .app-info_box {
    border-radius: 1.172vw;
    -webkit-margin-before: -11.719vw;
            margin-block-start: -11.719vw;
    padding-block: 14.844vw 5.469vw;
    width: 85.938vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-info_box {
    border-radius: 15px;
    -webkit-margin-before: -150px;
            margin-block-start: -150px;
    padding-block: 190px 70px;
    width: 1100px;
  }
}

.app-info_list {
  color: #1a1a1a;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .app-info_list {
    font-size: 3.2vw;
    letter-spacing: 0;
    line-height: 1.917;
    width: 81.067vw;
  }
}
@media screen and (min-width: 768px) {
  .app-info_list {
    font-size: 1.406vw;
    letter-spacing: 0.05em;
    line-height: 1.667;
    width: 75.781vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-info_list {
    font-size: 18px;
    width: 970px;
  }
}

@media screen and (max-width: 767px) {
  .app-info_item:not(:nth-of-type(1)) {
    -webkit-margin-before: 6.667vw;
            margin-block-start: 6.667vw;
  }
}

.app-download {
  border-top: 1px solid #808080;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .app-download {
    -webkit-margin-before: 10vw;
            margin-block-start: 10vw;
    -webkit-padding-before: 11.333vw;
            padding-block-start: 11.333vw;
    width: 81.333vw;
  }
}
@media screen and (min-width: 768px) {
  .app-download {
    -webkit-margin-before: 2.344vw;
            margin-block-start: 2.344vw;
    -webkit-padding-before: 3.516vw;
            padding-block-start: 3.516vw;
    width: 78.125vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-download {
    -webkit-margin-before: 30px;
            margin-block-start: 30px;
    -webkit-padding-before: 45px;
            padding-block-start: 45px;
    width: 1000px;
  }
}

.app-download_title {
  color: #231815;
  font-weight: 700;
  line-height: 1;
  margin-block: 0;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .app-download_title {
    font-size: 3.733vw;
    letter-spacing: 0;
  }
}
@media screen and (min-width: 768px) {
  .app-download_title {
    font-size: 1.875vw;
    letter-spacing: 0.08em;
  }
}
@media screen and (min-width: 1280px) {
  .app-download_title {
    font-size: 24px;
  }
}

.app-download_list {
  display: flex;
}
@media screen and (max-width: 767px) {
  .app-download_list {
    flex-direction: column;
    gap: 4vw;
    -webkit-margin-before: 6.667vw;
            margin-block-start: 6.667vw;
  }
}
@media screen and (min-width: 768px) {
  .app-download_list {
    gap: 4.688vw;
    justify-content: center;
    -webkit-margin-before: 2.734vw;
            margin-block-start: 2.734vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-download_list {
    gap: 60px;
    -webkit-margin-before: 35px;
            margin-block-start: 35px;
  }
}

@media screen and (min-width: 768px) {
  .app-download_item {
    width: 21.094vw;
  }
}
@media screen and (min-width: 1280px) {
  .app-download_item {
    width: 270px;
  }
}/*# sourceMappingURL=page_app.css.map */