@charset "utf-8";
.support__top {
  padding-top: clamp(5rem, 3.667rem + 2.78vw, 7rem);
}
.support-top__inner {
  padding: 0 clamp(2.5rem, -7.833rem + 21.53vw, 18rem);
}
.support-top__container {
      display: flex;
    align-items: center;
    column-gap: clamp(1.25rem, -2.583rem + 7.99vw, 7rem);
}
.support-top__left {
  width: 50%;
}
.support-top-left__title {
      margin-top: clamp(2.5rem, 0.833rem + 3.47vw, 5rem);
    line-height: 1.5;
    font-family: "Zen Old Mincho", serif;
    font-weight: 700;
    font-size: clamp(1.5rem, 1.167rem + 0.69vw, 2rem);
}
.support-top-left__text {
      margin-top: clamp(1.25rem, 0.417rem + 1.74vw, 2.5rem);
    font-size: clamp(1rem, 0.833rem + 0.35vw, 1.25rem);
    font-weight: 500;
    line-height: 1.6;
    font-family: "Zen Old Mincho", serif;
}
.support-top__right {
  width: 50%;
}
.support-top-right__img {
      clip-path: polygon(25% 0%, 75% 0%, 100% 50%, 75% 100%, 25% 100%, 0% 50%);
    object-fit: cover;
    aspect-ratio: 672/583;
}

.confront {
  padding-top: clamp(3.75rem, 1.042rem + 5.64vw, 7.813rem);
}
.confront__title {
      font-size: clamp(1.75rem, 1.583rem + 0.35vw, 2rem);
    font-weight: 700;
    font-family: "Zen Old Mincho", serif;
    text-align: center;
}
.confront__title--sp {
      font-size: clamp(1.75rem, 1.583rem + 0.35vw, 2rem);
    font-weight: 700;
    font-family: "Zen Old Mincho", serif;
    text-align: center;
    display: none;
}
.confront__content {
      margin-top: clamp(2.5rem, 1.667rem + 1.74vw, 3.75rem);
    background-image: url(https://choufarci.co.jp/system_panel/uploads/images/t-case-bg.png);
    background-size: cover;
    padding: clamp(3.125rem, 2.958rem + 0.35vw, 3.375rem) clamp(1.25rem, -18.5rem + 41.15vw, 30.875rem);
    display: flex;
    flex-wrap: wrap;
  justify-content: center;
    gap: 10px;
}
.confront-content__item {
      padding: clamp(0.313rem, -0.104rem + 0.87vw, 0.938rem) clamp(1.25rem, 0.625rem + 1.3vw, 2.188rem);
    background-color: #EA5C42;
    border-radius: 28px;
  text-align: center;
  color: #fff;
}
.confront__text {
      font-size: clamp(0.75rem, 0.583rem + 0.35vw, 1rem);
    font-weight: 400;
    text-align: end;
    padding-right: clamp(1.25rem, -9.917rem + 23.26vw, 18rem);
}

.support {
  padding-top: clamp(5rem, 2.667rem + 4.86vw, 8.5rem);
}
.support__inner {
  padding: 0 clamp(1.25rem, -9.917rem + 23.26vw, 18rem);
}
.support__title {
      font-size: clamp(1.75rem, 1.583rem + 0.35vw, 2rem);
    text-align: center;
    font-family: "Zen Old Mincho", serif;
    font-weight: 700;
}
.traning__text {
      font-family: "Zen Old Mincho", serif;
    text-align: center;
    font-weight: 500;
    line-height: 2;
    margin-top: clamp(1.25rem, 0.417rem + 1.74vw, 2.5rem);
}
.support__items {
      margin-top: clamp(3.625rem, 1.792rem + 3.82vw, 6.375rem);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    row-gap: clamp(3.625rem, 1.792rem + 3.82vw, 6.375rem);
    column-gap: clamp(1.25rem, -0.417rem + 3.47vw, 3.75rem);
}
.support__item {
      display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    background-color: #2D2F65;
    padding: 58px clamp(1.25rem, 0.083rem + 2.43vw, 3rem);
}
.support-item__sub {
      position: absolute;
    padding: 10px clamp(1.875rem, 1.458rem + 0.87vw, 2.5rem);
    background-color: #C60808;
    border-radius: 33px;
    color: #fff;
      line-height: 1.5;
    font-size: clamp(1.5rem, 1.333rem + 0.35vw, 1.75rem);
    font-weight: 700;
    font-family: "Zen Old Mincho", serif;
    top: -8%;
}
.traning-box__wrap {
      display: flex;
    flex-direction: column;
    width: 100%;
  row-gap: clamp(1.25rem, 1.042rem + 0.43vw, 1.563rem);
}
.traning__line {
  border-bottom: 1px dashed #fff;
}
.support-item__main {
  background-color: #E5E5FA;
    font-size: clamp(0.875rem, 0.792rem + 0.17vw, 1rem);
    line-height: 1.3;
    font-family: "Zen Old Mincho", serif;
    font-weight: 700;
  border-radius: 28px;
  padding: 5px 15px;
  width: fit-content;
}
.support-item__text {
        margin-top: clamp(0.938rem, 0.729rem + 0.43vw, 1.25rem);
    color: #Fff;
    font-size: clamp(0.75rem, 0.5rem + 0.52vw, 1.125rem);
    font-weight: 400;
    line-height: 2;
}

.traning__bottom {
      margin-top: clamp(3.75rem, -0.417rem + 8.68vw, 10rem);
    background-image: url(https://choufarci.co.jp/system_panel/uploads/images/traning-bottom-bg.png);
    background-size: cover;
    background-position: center;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
  margin-bottom: clamp(6.25rem, 4.583rem + 3.47vw, 8.75rem);
}
.traning-bottom__bg {
      background-color: rgba(2,36,110,0.39);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
  padding: clamp(4.375rem, 1.667rem + 5.64vw, 8.438rem) 0 clamp(4.375rem, 3.625rem + 1.56vw, 5.5rem);
}
.traning-bottom__inner {
  padding: 0 clamp(2.5rem, -24.333rem + 55.9vw, 42.75rem);
}
.traning-bottom__container {
      display: flex;
    flex-direction: column;
    align-items: center;
    row-gap: 40px;
}
.traning-bottom__text {
      text-align: center;
    font-size: clamp(1.125rem, 0.875rem + 0.52vw, 1.5rem);
    font-weight: 500;
    color: #fff;
    line-height: 1.7;
    font-family: "Zen Old Mincho", serif;
}
.footer {
  background-color: #FFf;
}

@media (max-width: 767px) {
  .support__top {
    padding-top: 32px;
  }
  .support-top__inner {
    padding: 0 clamp(1.25rem, -2.629rem + 15.92vw, 5rem);
  }
  .support-top__container {
        flex-direction: column-reverse;
    row-gap: 42px;
  }
  .support-top__left {
    width: 100%;
  }
  .support-top__right {
    width: 80%;
  }
  .confront__title {
    display: none;
  }
  .confront__title--sp {
    display: block;
  }
  .confront-content__item {
    font-size: clamp(0.75rem, 0.621rem + 0.53vw, 0.875rem);
  }
  .support__items {
        grid-template-columns: repeat(1, 1fr);
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
  }
  .support-item__text {
    font-size: clamp(0.875rem, 0.616rem + 1.06vw, 1.125rem);
  }
}

@media (max-width: 389px) {
  .support-top-left__title {
    font-size: 20px;
  }
  .support-top-left__text {
    font-size: 14px;
  }
  .confront__title--sp {
        padding: 0 20px;
    font-size: 24px;
  }
  .support__title {
    font-size: 24px;
  }
  .traning-bottom__text {
    font-size: 14px;
  }
}