@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: #E5E5FA;
    border-radius: 28px;
  text-align: center;
}
.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);
}

.achievement {
      margin-top: clamp(3.75rem, -0.583rem + 9.03vw, 10.25rem);
    background-image: url(https://choufarci.co.jp/system_panel/uploads/images/support2.png);
    background-size: cover;
    background-position: center;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}
.achievement__bg {
      background-color: rgba(129,147,199,0.5);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}
.achievement__inner {
    padding: clamp(2.5rem, 1.833rem + 1.39vw, 3.5rem) clamp(2.5rem, -13.583rem + 33.51vw, 26.625rem);
}
.achievement__container {
      padding: 60px clamp(1.5rem, -0.167rem + 3.47vw, 4rem);
    background-color: rgba(255,255,255,0.35);
    filter: brightness(1.18);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-radius: 3px;
    box-shadow: 0 3px 12px rgba(0,0,0,0.16);
}
.achievement__title {
      text-align: center;
    font-size: clamp(1.5rem, 1.167rem + 0.69vw, 2rem);
    font-weight: 700;
    font-family: "Zen Old Mincho", serif;
}
.achievement__content {
      display: flex;
    margin-top: 10px;
    column-gap: clamp(1rem, 0.125rem + 1.82vw, 2.313rem);
}
.achievement__left {
      display: flex;
    align-items: center;
    column-gap: 8px;
    width: 34%;
}
.achievement__img {
      width: 50%;
    object-fit: contain;
}
.achievement__text {
      width: 66%;
    font-weight: 400;
    line-height: 1.7;
}

.support {
  padding-top: clamp(5rem, 2.667rem + 4.86vw, 8.5rem);
}
.support__inner {
  padding: 0 clamp(1.25rem, -19.125rem + 42.45vw, 31.813rem);
}
.support__title {
      font-size: clamp(1.75rem, 1.25rem + 1.04vw, 2.5rem);
    text-align: center;
    font-family: "Zen Old Mincho", serif;
    font-weight: 700;
}
.support__items {
      margin-top: clamp(3.625rem, 1.792rem + 3.82vw, 6.375rem);
    display: grid;
    grid-template-columns: repeat(2, 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.417rem + 3.47vw, 3.75rem);
}
.support-item__sub {
      position: absolute;
    font-size: clamp(1.125rem, 0.875rem + 0.52vw, 1.5rem);
    padding: 5px 20px;
    background-color: #C60808;
    border-radius: 33px;
    color: #fff;
    top: -4%;
}
.support-item__main {
      color: #fff;
    font-size: 24px;
    text-align: center;
    line-height: 1.3;
    font-family: "Zen Old Mincho", serif;
    font-weight: 700;
}
.support-item__icon {
      margin-top: 20px;
    width: 145px;
    object-fit: contain;
}
.support-item__text {
      margin-top: 20px;
    color: #Fff;
    font-size: 14px;
    font-weight: 400;
    line-height: 2;
}

.support-bottom__bg {
      margin-top: 20px;
    background: linear-gradient(0deg, #EFEFEF, #F6F4FF 40%, #fff);
    padding-bottom: clamp(7.5rem, 5.833rem + 3.47vw, 10rem);
}
.flow {
  padding-top: clamp(5rem, 1.667rem + 6.94vw, 10rem);
}
.flow__inner {
  padding: 0 clamp(1.25rem, -16.667rem + 37.33vw, 28.125rem);
}
.flow__items {
  margin-top: clamp(2.5rem, 0.833rem + 3.47vw, 5rem);
}
.flow__item {
      display: flex;
    position: relative;
    padding-left: clamp(1.25rem, -0.5rem + 3.65vw, 3.875rem);
}
.flow__item:not(:last-child) {
    padding-bottom: clamp(1.875rem, 1.458rem + 0.87vw, 2.5rem);
  border-left: 1px solid #C70809;
}
.flow__item::before {
      content: "";
    position: absolute;
    left: -6px;
    top: 0;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background-color: #C70809;
}
.flow-item__left {
      display: flex;
    flex-direction: column;
    align-items: center;
    padding-right: clamp(1rem, -0.583rem + 3.3vw, 3.375rem);
    border-bottom: 1px dashed #143064;
}
.flow-item__sub {
      font-size: clamp(0.625rem, 0.458rem + 0.35vw, 0.875rem);
    font-weight: 700;
    font-family: "Zen Old Mincho", serif;
  line-height: 1;
}
.flow-item__number {
      font-size: clamp(2rem, 1.667rem + 0.69vw, 2.5rem);
    font-weight: 700;
    font-family: "Zen Old Mincho", serif;
    line-height: 1;
}
.flow-item__right {
      padding-bottom: clamp(0.875rem, 0.375rem + 1.04vw, 1.625rem);
    border-bottom: 1px dashed #143064;
    width: 100%;
}
.flow-item__title {
      font-size: 24px;
    font-weight: 500;
    font-family: "Zen Old Mincho", serif;
}
.flow-item__text {
  font-size: clamp(0.75rem, 0.584rem + 0.35vw, 1rem);
      margin-top: 8px;
    font-weight: 400;
}

.voice {
  padding-top: clamp(5rem, 1.667rem + 6.94vw, 10rem);
}
.voice__inner {
  padding: 0 clamp(1.25rem, -17.708rem + 39.5vw, 29.688rem);
}
.voice__content {
      margin-top: clamp(2.5rem, 1.667rem + 1.74vw, 3.75rem);
    padding: 40px clamp(2rem, 1.25rem + 1.56vw, 3.125rem) clamp(2.5rem, 1.667rem + 1.74vw, 3.75rem);
    background-color: #fff;
    box-shadow: 6px 3px 10px rgba(0,0,0,0.16);
}
.voice__title {
      font-size: clamp(1.25rem, 1.083rem + 0.35vw, 1.5rem);
    font-weight: 700;
    line-height: 1.5;
    font-family: "Zen Old Mincho", serif;
    padding-bottom: 14px;
    border-bottom: 1px solid #2D2F65;
}
.voice__text1 {
      margin-top: 16px;
    font-weight: 400;
}
.voice__text2 {
      margin-top: 16px;
    font-weight: 400;
}
.voice__btn {
      display: flex;
    justify-content: center;
    margin-top: clamp(3.75rem, 2.917rem + 1.74vw, 5rem);
}

@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);
  }
  .achievement__content {
        flex-direction: column;
    row-gap: 38px;
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
  }
  .achievement__left {
        width: 80%;
    margin-left: auto;
    margin-right: auto;
  }
  .achievement__text {
    width: 100%;
  }
  .support__items {
        grid-template-columns: repeat(1, 1fr);
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
  }
}

@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;
  }
  .confront__content {
        padding-left: 16px;
    padding-right: 16px;
  }
  .achievement__text {
    font-size: 12px;
  }
  .support__title {
    font-size: 24px;
  }
  .flow__inner {
    padding: 0 20px;
  }
  .flow-item__title {
    font-size: clamp(1.25rem, 0.091rem + 5.8vw, 1.5rem);
  }
  .voice__content {
        padding-left: 24px;
    padding-right: 24px;
  }
}
