@charset "UTF-8";
/* --------------------------------------------------
 * online-course-high-school-3 LP 専用設定
 * -------------------------------------------------- */
/* ==========================================================
 * och3-fv : ファーストビュー
 * SP/PC それぞれ1枚の画像で出し分け。
 * ========================================================== */
.och3 {
  padding-top: 0;
}

.och3-fv {
  display: block;
  overflow: hidden;
}
@media only screen and (min-width: 768px) {
  .och3-fv {
    margin-top: 2.5rem;
  }
}
.och3-fv__link {
  display: block;
  transition: opacity 0.3s ease-out;
  line-height: 0;
}
@media only screen and (min-width: 768px) {
  .och3-fv__link {
    max-width: 67.5rem;
    margin: 0 auto;
  }
}
@media (hover: hover) {
  .och3-fv__link:hover {
    opacity: 0.9;
  }
}
@media (hover: none) {
  .och3-fv__link:active {
    opacity: 0.9;
  }
}
.och3-fv__link picture {
  display: block;
}
.och3-fv__link img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 375/466;
}
@media only screen and (min-width: 768px) {
  .och3-fv__link img {
    aspect-ratio: 540/259;
  }
}

/* ==========================================================
 * och3-cta : ＼たった1分で完了／＋ 問合せボタン
 * ========================================================== */
.och3-cta {
  padding: 4.8vw 4.2666666667vw 10.6666666667vw;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .och3-cta {
    padding: 2rem 1rem;
  }
}
.och3-cta__caption {
  margin: 0 0 1.8666666667vw;
  color: #0F2942;
  font-size: 5.3333333333vw;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.45;
  text-align: center;
}
.och3-cta__caption.--white {
  color: #FFFFFF;
}
@media only screen and (min-width: 768px) {
  .och3-cta__caption {
    margin-bottom: 0.75rem;
    font-size: 1.25rem;
  }
}
.och3-cta__btn {
  display: flex;
  position: relative;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 21.3333333333vw;
  margin: 0 auto;
  padding: 0 9.6vw 0.5333333333vw 2.1333333333vw;
  border: 1px solid #00A9DE;
  border-radius: 2.1333333333vw;
  background: linear-gradient(0deg, #00A9DE 0%, #00C3DE 100%);
  box-shadow: 0 1.0666666667vw 2.6666666667vw 0 rgba(0, 169, 222, 0.3);
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
  gap: 1.0666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-cta__btn {
    max-width: 33.75rem;
    height: 4.5rem;
    padding: 0 2.9375rem 0 0;
    border-radius: 1rem;
    box-shadow: 0 0.25rem 0.5rem 0 rgba(0, 169, 222, 0.3);
    gap: 0.5rem;
  }
}
@media (hover: hover) {
  .och3-cta__btn:hover {
    opacity: 0.85;
  }
}
@media (hover: none) {
  .och3-cta__btn:active {
    opacity: 0.85;
  }
}
.och3-cta__btn-container {
  display: inline-block;
  padding-left: 4.2666666667vw;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .och3-cta__btn-container {
    padding-left: 0;
  }
}
.och3-cta__btn-sub {
  position: relative;
  top: 0.5333333333vw;
  color: #FFFFFF;
  font-size: 4.2666666667vw;
  letter-spacing: -0.04em;
  line-height: 1;
}
.och3-cta__btn-sub.--counseling {
  position: relatieve;
  top: 1.0666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-cta__btn-sub.--counseling {
    top: 0;
  }
}
@media only screen and (min-width: 768px) {
  .och3-cta__btn-sub {
    top: 0;
    font-size: 1.125rem;
  }
}
.och3-cta__btn-main {
  color: #FFED92;
  font-size: 6.9333333333vw;
  letter-spacing: -0.02em;
  line-height: 1;
}
@media only screen and (min-width: 768px) {
  .och3-cta__btn-main {
    font-size: 1.375rem;
  }
}
.och3-cta__btn-arrow {
  display: inline-flex;
  position: absolute;
  top: 50%;
  right: 4.2666666667vw;
  width: 6.4vw;
  height: 6.4vw;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
@media only screen and (min-width: 768px) {
  .och3-cta__btn-arrow {
    right: 1.75rem;
    width: 2rem;
    height: 2rem;
  }
}
.och3-cta__btn-arrow img {
  display: block;
  width: 100%;
  height: 100%;
}
.och3-cta__bottom {
  padding: 6.4vw 4.2666666667vw 10.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-cta__bottom {
    display: none;
  }
}

/* ==========================================================
 * och3-worry : お悩みセクション
 * ========================================================== */
.och3-worry {
  position: relative;
  margin: 0 auto;
  overflow: hidden;
  background: #0F2942;
  color: #FFFFFF;
  /* --- ヘッダー ------------------------------------------ */
  /* --- リスト / カード ----------------------------------- */
  /* --- リード文 ------------------------------------------ */
  /* --- 下向き矢印 ---------------------------------------- */
}
@media only screen and (min-width: 768px) {
  .och3-worry {
    max-width: 67.5rem;
    margin-top: 3rem;
  }
}
.och3-worry__bg {
  position: absolute;
  background: linear-gradient(180deg, #657888 0%, #294159 100%);
  line-height: 0;
  pointer-events: none;
  clip-path: polygon(100% 0, 100% calc(100% - 12.2666666667vw), 48% 100%, 0 calc(100% - 12.2666666667vw), 0 0);
  inset: 0;
}
@media only screen and (min-width: 768px) {
  .och3-worry__bg {
    background: linear-gradient(180deg, #657888 0%, #294159 99.9%);
    clip-path: polygon(100% 0, 100% calc(100% - 3.5rem), 48% 100%, 0 calc(100% - 3.5rem), 0 0);
  }
}
.och3-worry__bg-img {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  width: 58.6666666667vw;
  height: auto;
  mix-blend-mode: multiply;
}
@media only screen and (min-width: 768px) {
  .och3-worry__bg-img {
    right: 0;
    left: calc(50% + 1rem);
    width: 28.8125rem;
  }
}
.och3-worry__top {
  position: relative;
  padding: 10.4vw 4.2666666667vw 17.0666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-worry__top {
    padding: 2.6875rem 1rem 3.3125rem;
  }
}
.och3-worry__bottom {
  padding: 6.4vw 4.2666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-worry__bottom {
    padding: 1.5rem 1rem 1.6875rem;
  }
}
.och3-worry__header {
  position: relative;
  z-index: 1;
  margin-bottom: 6.4vw;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .och3-worry__header {
    margin-bottom: 1.375rem;
  }
}
.och3-worry__sub {
  margin: 0 0 1.8666666667vw;
  line-height: 0;
}
@media only screen and (min-width: 768px) {
  .och3-worry__sub {
    position: relative;
    left: -7.625rem;
    margin-bottom: 0.125rem;
  }
}
.och3-worry__sub img {
  width: 42.1333333333vw;
  height: auto;
}
@media only screen and (min-width: 768px) {
  .och3-worry__sub img {
    width: 11.125rem;
  }
}
.och3-worry__heading {
  display: inline-block;
  position: relative;
  margin: 0;
  color: #FFFFFF;
  font-size: 6.4vw;
  font-weight: 700;
  line-height: 1.4;
}
@media only screen and (min-width: 768px) {
  .och3-worry__heading {
    font-size: 1.75rem;
  }
}
.och3-worry__dots {
  color: #FFF20F;
  font-style: normal;
}
.och3-worry__dots .dot-item {
  position: relative;
}
.och3-worry__dots .dot-item::before {
  content: "";
  position: absolute;
  top: -0.2666666667vw;
  left: 50%;
  width: 1.0666666667vw;
  -webkit-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
  border-radius: 50%;
  background: #FFF20F;
  aspect-ratio: 1/1;
}
@media only screen and (min-width: 768px) {
  .och3-worry__dots .dot-item::before {
    top: -0.25rem;
    width: 0.25rem;
  }
}
.och3-worry__list {
  display: flex;
  position: relative;
  z-index: 2;
  flex-direction: column;
  margin: 0 auto;
  list-style: none;
  gap: 3.2vw;
}
@media only screen and (min-width: 768px) {
  .och3-worry__list {
    flex-direction: row;
    gap: 1rem;
    justify-content: center;
  }
}
.och3-worry__item {
  display: flex;
  position: relative;
  align-items: center;
  min-height: 27.7333333333vw;
  padding: 2.6666666667vw 2.1333333333vw 2.6666666667vw 37.0666666667vw;
  border-radius: 2.1333333333vw;
  background: #0F2942;
  text-align: left;
}
@media only screen and (min-width: 768px) {
  .och3-worry__item {
    flex: 1 1 0;
    align-items: flex-start;
    max-width: 15rem;
    min-height: 14.1875rem;
    padding: 7.6875rem 1rem 1rem;
    border-radius: 0.5rem;
    text-align: center;
  }
}
.och3-worry__item-img {
  position: absolute;
  bottom: 0;
  left: 2.1333333333vw;
  flex-shrink: 0;
  width: 34.6666666667vw;
  line-height: 0;
}
@media only screen and (min-width: 768px) {
  .och3-worry__item-img {
    bottom: 6.5rem;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
  }
}
.och3-worry__item-img.--img0 {
  width: 35.2vw;
}
@media only screen and (min-width: 768px) {
  .och3-worry__item-img.--img0 {
    width: 8.125rem;
  }
}
.och3-worry__item-img.--img1 {
  width: 38.1333333333vw;
}
@media only screen and (min-width: 768px) {
  .och3-worry__item-img.--img1 {
    width: 8.9375rem;
  }
}
.och3-worry__item-img.--img2 {
  width: 34.9333333333vw;
}
@media only screen and (min-width: 768px) {
  .och3-worry__item-img.--img2 {
    width: 8.125rem;
  }
}
.och3-worry__item-img img {
  display: block;
  width: 100%;
  height: auto;
}
.och3-worry__item-body {
  display: flex;
  position: relative;
  z-index: 2;
  flex: 1 1 auto;
  flex-direction: column;
  gap: 2.1333333333vw;
}
@media only screen and (min-width: 768px) {
  .och3-worry__item-body {
    gap: 0.5rem;
    width: 100%;
  }
}
.och3-worry__item-txt {
  margin: 0;
  color: #FFFFFF;
  font-size: 3.7333333333vw;
  font-weight: 400;
  line-height: 1.3;
}
@media only screen and (min-width: 768px) {
  .och3-worry__item-txt {
    font-size: 0.875rem;
  }
}
.och3-worry__item-txt strong {
  font-weight: 700;
}
.och3-worry__lead {
  margin: 0 0 6.1333333333vw;
  color: #FFFFFF;
  font-size: 4.2666666667vw;
  font-weight: 400;
  line-height: 1.6;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .och3-worry__lead {
    margin-bottom: 1.4375rem;
    font-size: 1rem;
  }
}
.och3-worry__lead em {
  display: inline-block;
  color: #FFF20F;
  font-size: 5.3333333333vw;
  font-style: normal;
  font-weight: 700;
  line-height: 1.6;
  text-decoration: underline;
  text-underline-offset: 1.3333333333vw;
}
@media only screen and (min-width: 768px) {
  .och3-worry__lead em {
    font-size: 1.25rem;
    text-underline-offset: 0.3125rem;
  }
}
.och3-worry__lead-bold {
  font-weight: 700;
}
.och3-worry__arrow {
  display: flex;
  justify-content: center;
  line-height: 0;
}
.och3-worry__arrow img {
  width: 20.8vw;
  height: auto;
}
@media only screen and (min-width: 768px) {
  .och3-worry__arrow img {
    width: 4.875rem;
  }
}

/* ==========================================================
 * och3-results : 合格実績セクション
 * ========================================================== */
.och3-results {
  background: #F3F7FA;
  color: #0F2942;
  /* --- ヘッダー（タイトル帯） ---------------------------- */
  /* --- 事例リスト ---------------------------------------- */
  /* 上部: プロフィール + スコア横並び */
  /* --- 合格実績多数エリア -------------------------------- */
}
@media only screen and (min-width: 768px) {
  .och3-results {
    max-width: 67.5rem;
    margin: 0 auto;
    margin-top: 5rem;
  }
}
.och3-results__header {
  position: relative;
  height: 37.3333333333vw;
  overflow: hidden;
}
@media only screen and (min-width: 768px) {
  .och3-results__header {
    height: 7.5rem;
  }
}
.och3-results__header-bg {
  position: absolute;
  background: #FFFFFF;
  line-height: 0;
  pointer-events: none;
  clip-path: polygon(100% 0, 100% calc(100% - 10.4vw), 48% 100%, 0 calc(100% - 10.4vw), 0 0);
  inset: 0;
}
@media only screen and (min-width: 768px) {
  .och3-results__header-bg {
    clip-path: none;
  }
}
.och3-results__header-bg img {
  display: block;
  width: 100%;
  height: 100%;
}
.och3-results__header-inner {
  position: relative;
  z-index: 1;
  padding-top: 8.5333333333vw;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .och3-results__header-inner {
    padding-top: 1.8125rem;
  }
}
.och3-results__title {
  margin: 0 0 1.0666666667vw;
  color: #0F2942;
  font-size: 7.4666666667vw;
  font-weight: 700;
  line-height: 1.6;
}
@media only screen and (min-width: 768px) {
  .och3-results__title {
    margin-bottom: 0.25rem;
    font-size: 1.75rem;
  }
}
.och3-results__note {
  margin: 0;
  color: #728889;
  font-size: 2.4vw;
  font-weight: 400;
  letter-spacing: -0.1em;
  line-height: 1.2222222222;
}
@media only screen and (min-width: 768px) {
  .och3-results__note {
    font-size: 0.625rem;
  }
}
.och3-results__stamp {
  position: absolute;
  top: 15.4666666667vw;
  left: calc(50% + 24.8vw);
  width: 21.3333333333vw;
  -webkit-transform: rotate(10deg);
  transform: rotate(10deg);
  line-height: 0;
  pointer-events: none;
}
@media only screen and (min-width: 768px) {
  .och3-results__stamp {
    top: 1.5rem;
    left: calc(50% + 8.5625rem);
    width: 5rem;
  }
}
.och3-results__stamp img {
  display: block;
  width: 100%;
  height: auto;
}
.och3-results__list {
  display: flex;
  flex-direction: column;
  margin: 0;
  padding: 6.4vw 4.2666666667vw;
  list-style: none;
  gap: 2.1333333333vw;
}
@media only screen and (min-width: 768px) {
  .och3-results__list {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 1rem 0.3125rem;
    justify-content: space-between;
    padding: 2.5rem;
  }
}
.och3-results__item {
  display: flex;
  position: relative;
  flex-direction: column;
  padding: 0 2.6666666667vw 3.2vw;
  border-top: 1.0666666667vw solid #00A9DE;
  border-radius: 1.0666666667vw;
  background: #FFFFFF;
  gap: 1.8666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-results__item {
    width: 20.625rem;
    padding: 0 0.75rem 0.75rem;
    border-top: 0.25rem solid #00A9DE;
    border-radius: 0.25rem;
    gap: 0.4375rem;
  }
}
.och3-results__item-head {
  display: flex;
  align-items: flex-end;
  margin-top: -2.6666666667vw;
  gap: 3.2vw;
}
@media only screen and (min-width: 768px) {
  .och3-results__item-head {
    gap: 0.5rem;
    margin-top: -0.625rem;
  }
}
.och3-results__item-profile {
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  width: 25.6vw;
}
@media only screen and (min-width: 768px) {
  .och3-results__item-profile {
    width: 6rem;
  }
}
.och3-results__item-photo {
  position: relative;
  left: 0.5333333333vw;
  width: 17.0666666667vw;
  height: 17.0666666667vw;
  overflow: hidden;
  border-radius: 50%;
  background: #C2EAF5;
}
@media only screen and (min-width: 768px) {
  .och3-results__item-photo {
    left: 0.125rem;
    width: 4rem;
    height: 4rem;
  }
}
.och3-results__item-photo img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.och3-results__item-name {
  position: relative;
  left: 1.0666666667vw;
  margin: 0;
  color: #0F2942;
  letter-spacing: 0.04em;
  line-height: 1.5;
}
@media only screen and (min-width: 768px) {
  .och3-results__item-name {
    left: 0;
  }
}
.och3-results__item-name strong {
  font-size: 3.7333333333vw;
  font-weight: 700;
}
@media only screen and (min-width: 768px) {
  .och3-results__item-name strong {
    font-size: 0.875rem;
  }
}
.och3-results__item-name span {
  font-size: 2.6666666667vw;
  font-weight: 400;
}
@media only screen and (min-width: 768px) {
  .och3-results__item-name span {
    font-size: 0.625rem;
  }
}
.och3-results__item-school {
  position: relative;
  left: 1.0666666667vw;
  margin: 0;
  color: #0F2942;
  font-size: 3.2vw;
  font-weight: 400;
  letter-spacing: 0.04em;
  line-height: 1.5;
}
@media only screen and (min-width: 768px) {
  .och3-results__item-school {
    left: 0;
    font-size: 0.75rem;
  }
}
.och3-results__item-body {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  gap: 1.6vw;
  min-width: 0;
}
@media only screen and (min-width: 768px) {
  .och3-results__item-body {
    gap: 0.375rem;
  }
}
.och3-results__item-deviation {
  display: flex;
  align-items: center;
  height: 7.4666666667vw;
  gap: 1.0666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-results__item-deviation {
    gap: 0.25rem;
    height: 1.75rem;
  }
}
.och3-results__item-deviation-label {
  color: #0F2942;
  font-size: 3.2vw;
  font-weight: 700;
  line-height: 1.8333333333;
  white-space: nowrap;
}
@media only screen and (min-width: 768px) {
  .och3-results__item-deviation-label {
    font-size: 0.75rem;
  }
}
.och3-results__item-deviation-before, .och3-results__item-deviation-after {
  font-family: "Helvetica", "Helvetica Neue", sans-serif;
  font-size: 7.4666666667vw;
  font-weight: 700;
  line-height: 0.7857142857;
}
@media only screen and (min-width: 768px) {
  .och3-results__item-deviation-before, .och3-results__item-deviation-after {
    font-size: 1.75rem;
  }
}
.och3-results__item-deviation-before {
  margin-right: 1.0666666667vw;
  color: #728889;
}
@media only screen and (min-width: 768px) {
  .och3-results__item-deviation-before {
    margin-right: 0.25rem;
  }
}
.och3-results__item-deviation-after {
  color: #F6548F;
}
.och3-results__item-deviation-arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.6666666667vw;
  height: 2.6666666667vw;
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}
@media only screen and (min-width: 768px) {
  .och3-results__item-deviation-arrow {
    width: 0.625rem;
    height: 0.625rem;
  }
}
.och3-results__item-deviation-arrow img {
  aspect-ratio: 1/1;
  display: block;
  width: 3.2vw;
}
@media only screen and (min-width: 768px) {
  .och3-results__item-deviation-arrow img {
    width: 0.75rem;
  }
}
.och3-results__item-deviation-up {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 17.0666666667vw;
  height: 6.4vw;
  padding: 0 1.0666666667vw;
  border: 1px solid #F6548F;
  border-radius: 1.0666666667vw;
  color: #F6548F;
  font-family: "Helvetica", "Helvetica Neue", sans-serif;
  font-size: 3.7333333333vw;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1;
}
@media only screen and (min-width: 768px) {
  .och3-results__item-deviation-up {
    width: 4rem;
    height: 1.5rem;
    padding: 0 0.25rem;
    border-radius: 0.25rem;
    font-size: 0.875rem;
  }
}
.och3-results__item-deviation-up img {
  display: block;
  width: 2.6666666667vw;
  height: 3.4666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-results__item-deviation-up img {
    width: 0.625rem;
    height: 0.8125rem;
  }
}
.och3-results__item-comment {
  margin: 0;
  color: #0F2942;
  font-size: 3.4666666667vw;
  font-weight: 400;
  line-height: 1.5;
  white-space: nowrap;
}
@media only screen and (min-width: 768px) {
  .och3-results__item-comment {
    font-size: 0.8125rem;
  }
}
.och3-results__item-univ {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 2.1333333333vw 3.7333333333vw;
  border-radius: 2.1333333333vw;
  background: #FFF9D8;
  color: #0F2942;
  font-size: 4.2666666667vw;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.375;
  gap: 2.1333333333vw;
}
@media only screen and (min-width: 768px) {
  .och3-results__item-univ {
    margin-top: auto;
    padding: 0.5rem 0.75rem;
    border-radius: 0.5rem;
    font-size: 1rem;
    gap: 0.5rem;
  }
}
.och3-results__item-univ img {
  display: block;
  flex-shrink: 0;
  width: 6.4vw;
  height: 6.4vw;
}
@media only screen and (min-width: 768px) {
  .och3-results__item-univ img {
    width: 1.5rem;
    height: 1.5rem;
  }
}
.och3-results__more {
  position: relative;
  padding: 21.3333333333vw 4.2666666667vw 10.6666666667vw;
  background: #C2EAF5;
}
@media only screen and (min-width: 768px) {
  .och3-results__more {
    padding: 4rem 2.5rem 2.5rem;
  }
}
.och3-results__more-bg {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  height: 32vw;
  line-height: 0;
  pointer-events: none;
}
@media only screen and (min-width: 768px) {
  .och3-results__more-bg {
    height: 5rem;
  }
}
.och3-results__more-bg img {
  display: block;
  width: auto;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.och3-results__more-woman {
  position: absolute;
  top: -26.4vw;
  right: 5.3333333333vw;
  width: 44.5333333333vw;
  line-height: 0;
  pointer-events: none;
}
@media only screen and (min-width: 768px) {
  .och3-results__more-woman {
    top: -6.0625rem;
    right: auto;
    left: calc(50% + 7.8125rem);
    width: 10.4375rem;
  }
}
.och3-results__more-woman img {
  display: block;
  width: 100%;
  height: auto;
}
.och3-results__more-panel {
  position: relative;
  z-index: 1;
  margin-bottom: 4.2666666667vw;
  padding: 4.2666666667vw 4.2666666667vw 6.4vw;
  border-radius: 2.1333333333vw;
  background: #FFFFFF;
}
@media only screen and (min-width: 768px) {
  .och3-results__more-panel {
    margin-bottom: 2rem;
    padding: 1.5rem 3.4375rem;
    border-radius: 0.5rem;
  }
}
.och3-results__more-title {
  position: relative;
  z-index: 2;
  margin: 0 0 4.2666666667vw;
  color: #0F2942;
  font-weight: 700;
  line-height: 1.4;
}
@media only screen and (min-width: 768px) {
  .och3-results__more-title {
    margin-bottom: 0.5625rem;
    text-align: center;
  }
}
.och3-results__more-title .och3-results__more-title-sub {
  font-size: 4.2666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-results__more-title .och3-results__more-title-sub {
    font-size: 1.125rem;
  }
}
.och3-results__more-title .och3-results__more-title-main {
  font-size: 6.4vw;
}
@media only screen and (min-width: 768px) {
  .och3-results__more-title .och3-results__more-title-main {
    font-size: 1.75rem;
  }
}
.och3-results__more-list {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1.0666666667vw 1fr;
  grid-template-columns: repeat(2, 1fr);
  margin: 0;
  padding: 0;
  list-style: none;
  gap: 0 1.0666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-results__more-list {
    -ms-grid-columns: auto 1.5rem auto 1.5rem auto 1.5rem auto 1.5rem auto;
    gap: 0 1.5rem;
    grid-template-columns: auto auto auto auto auto;
  }
}
.och3-results__more-item {
  display: flex;
  align-items: center;
  color: #0F2942;
  font-size: 5.3333333333vw;
  font-weight: 400;
  line-height: 1.45;
  gap: 1.0666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-results__more-item {
    font-size: 1.4375rem;
    gap: 0.375rem;
  }
}
.och3-results__more-item img {
  display: block;
  flex-shrink: 0;
  width: 6.4vw;
  height: 6.4vw;
}
@media only screen and (min-width: 768px) {
  .och3-results__more-item img {
    width: 1.75rem;
    height: 1.75rem;
  }
}

/* ==========================================================
 * och3-service : サービス紹介 ｢キミノスクールって？｣
 * ========================================================== */
.och3-service {
  position: relative;
  margin-top: 15.2vw;
  background: #00A9DE;
  color: #FFFFFF;
  /* --- 上部ラベル ｢キミノスクールって？｣ ----------------- */
  /* --- ヒーロー領域 -------------------------------------- */
  /* --- チェックパネル ------------------------------------ */
  /* --- 説明文 -------------------------------------------- */
}
@media only screen and (min-width: 768px) {
  .och3-service {
    max-width: 67.5rem;
    margin: 0 auto;
    margin-top: 5rem;
  }
}
.och3-service__label {
  display: inline-flex;
  position: absolute;
  z-index: 2;
  top: -4.5333333333vw;
  left: 50%;
  align-items: center;
  justify-content: center;
  width: 64vw;
  height: 9.6vw;
  padding-bottom: 1.0666666667vw;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  border-radius: 9999px;
  background: #0F2942;
  color: #FFFFFF;
  font-size: 4.2666666667vw;
  font-weight: 700;
  line-height: 1;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .och3-service__label {
    top: -1.0625rem;
    width: 25rem;
    height: 3.5rem;
    padding-bottom: 0.0625rem;
    font-size: 1.5rem;
    font-size: 1.5rem;
  }
}
.och3-service__label::after {
  content: "";
  position: absolute;
  bottom: -2.1333333333vw;
  left: 50%;
  width: 5.8666666667vw;
  height: 4.8vw;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  background: #0F2942;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
}
@media only screen and (min-width: 768px) {
  .och3-service__label::after {
    bottom: -0.75rem;
    width: 2.1875rem;
    height: 1.25rem;
  }
}
.och3-service__inner {
  padding: 0 4.2666666667vw 10.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-service__inner {
    padding: 0 2.5rem 2.5rem;
  }
}
.och3-service__hero {
  position: relative;
  margin-bottom: 6.4vw;
  aspect-ratio: 375/300;
}
@media only screen and (min-width: 768px) {
  .och3-service__hero {
    aspect-ratio: 1078/316;
    margin-bottom: -7.25rem;
  }
}
.och3-service__hero img {
  width: 100%;
  height: 100%;
}
.och3-service__panel {
  display: flex;
  position: relative;
  z-index: 1;
  flex-direction: column;
  align-items: center;
  margin: 0 auto;
  padding: 2.1333333333vw;
  border-radius: 1.0666666667vw;
  background: #FFFFFF;
  gap: 1.6vw;
}
@media only screen and (min-width: 768px) {
  .och3-service__panel {
    max-width: 62.5rem;
    margin: 0 auto;
    padding: 0.5rem;
    border-radius: 0.25rem;
    gap: 0.375rem;
  }
}
.och3-service__checks {
  display: flex;
  flex-direction: column;
  width: 100%;
  margin: 0;
  padding: 0;
  list-style: none;
  gap: 1.6vw;
}
@media only screen and (min-width: 768px) {
  .och3-service__checks {
    gap: 0.375rem;
    text-align: center;
  }
}
.och3-service__check {
  display: flex;
  align-items: center;
  color: #0F2942;
  font-size: 4.2666666667vw;
  font-weight: 700;
  line-height: 1.5;
  gap: 2.1333333333vw;
}
@media only screen and (min-width: 768px) {
  .och3-service__check {
    justify-content: center;
    font-size: 1rem;
    gap: 0.5rem;
  }
}
.och3-service__check img {
  display: block;
  flex-shrink: 0;
  width: 6.4vw;
  height: 6.4vw;
}
@media only screen and (min-width: 768px) {
  .och3-service__check img {
    width: 1.5rem;
    height: 1.5rem;
  }
}
.och3-service__arrow {
  line-height: 0;
}
.och3-service__arrow img {
  display: block;
  width: 19.7333333333vw;
  height: auto;
}
@media only screen and (min-width: 768px) {
  .och3-service__arrow img {
    width: 4.625rem;
  }
}
.och3-service__panel-txt {
  margin: 0;
  color: #0F2942;
  font-size: 4.2666666667vw;
  font-weight: 700;
  line-height: 1.6;
  text-align: center;
  -webkit-font-feature-settings: "palt" 1;
  font-feature-settings: "palt" 1;
}
@media only screen and (min-width: 768px) {
  .och3-service__panel-txt {
    font-size: 1rem;
  }
}
.och3-service__lead {
  margin-top: 6.4vw;
  color: #FFFFFF;
  font-size: 4.2666666667vw;
  font-weight: 700;
  font-weight: 700;
  line-height: 1.6;
  line-height: 1.6;
  text-align: center;
  -webkit-font-feature-settings: "palt" 1;
  font-feature-settings: "palt" 1;
}
@media only screen and (min-width: 768px) {
  .och3-service__lead {
    margin-top: 1.5625rem;
    font-size: 1rem;
  }
}
.och3-service__lead em {
  display: inline-block;
  color: #FFF20F;
  font-size: 5.3333333333vw;
  font-style: normal;
  font-weight: 700;
  line-height: 1.6;
  text-decoration: underline;
  text-decoration-color: #FFF20F;
  text-underline-offset: 0.8vw;
}
@media only screen and (min-width: 768px) {
  .och3-service__lead em {
    font-size: 1.25rem;
    text-underline-offset: 0.1875rem;
  }
}

/* ==========================================================
 * och3-media : メディア紹介（令和の虎 / Youtube）
 * ========================================================== */
.och3-media {
  position: relative;
  margin-top: 10.6666666667vw;
  padding-bottom: 10.6666666667vw;
  overflow: hidden;
  background: #0F2942;
  color: #FFFFFF;
  /* --- 令和の虎ブロック ---------------------------------- */
  /* --- Youtubeチャンネル ---------------------------------- */
  /* --- YouTube 本動画 4本（SP Swiper自走 / PC 静止並び） -- */
  /* --- Youtubeショートタイトル ---------------------------- */
  /* --- Youtubeショート 5本（SP Swiper自走 / PC 静止並び） - */
}
@media only screen and (min-width: 768px) {
  .och3-media {
    max-width: 67.5rem;
    margin: 0 auto;
    margin-top: 5rem;
    padding-bottom: 2.5rem;
  }
}
.och3-media__reiwa {
  position: relative;
  z-index: 2;
  padding: 10.6666666667vw 3.2vw 0;
}
@media only screen and (min-width: 768px) {
  .och3-media__reiwa {
    padding: 2.5rem 2.5rem 0;
  }
}
.och3-media__reiwa-contents {
  aspect-ratio: 710/628;
}
@media only screen and (min-width: 768px) {
  .och3-media__reiwa-contents {
    aspect-ratio: 1000/173;
  }
}
.och3-media__channel {
  position: relative;
  margin-top: -9.6vw;
  padding: 21.8666666667vw 4.2666666667vw 12.2666666667vw;
  overflow: hidden;
}
@media only screen and (min-width: 768px) {
  .och3-media__channel {
    margin-top: -3rem;
    padding: 5.625rem 3rem 0;
  }
}
.och3-media__channel-bg {
  position: absolute;
  z-index: 0;
  top: 0;
  right: 0;
  left: 0;
  line-height: 0;
  aspect-ratio: 375/360;
}
@media only screen and (min-width: 768px) {
  .och3-media__channel-bg {
    aspect-ratio: 1000/360;
  }
}
.och3-media__channel-bg img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.och3-media__channel-title {
  display: flex;
  position: relative;
  z-index: 1;
  align-items: center;
  justify-content: center;
  margin-bottom: 3.2vw;
  gap: 1.0666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-media__channel-title {
    gap: 0.25rem;
    margin-bottom: 1.5rem;
  }
}
.och3-media__channel-title .laurel {
  display: block;
  flex-shrink: 0;
  width: 6.9333333333vw;
  height: 16vw;
}
@media only screen and (min-width: 768px) {
  .och3-media__channel-title .laurel {
    width: 1.625rem;
    height: 3.75rem;
  }
}
.och3-media__channel-title .text {
  color: #FFFFFF;
  font-weight: 700;
  line-height: 1.3;
  text-align: center;
}
.och3-media__channel-title .text-sub {
  display: block;
  margin: 0;
  font-size: 4.2666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-media__channel-title .text-sub {
    font-size: 1rem;
  }
}
.och3-media__channel-title .text-main {
  display: block;
  margin: 0;
  font-size: 6.1333333333vw;
}
@media only screen and (min-width: 768px) {
  .och3-media__channel-title .text-main {
    font-size: 1.4375rem;
  }
}
.och3-media__channel-title .text-main em {
  color: #FFED92;
  font-style: normal;
}
.och3-media__channel-image {
  position: relative;
  z-index: 1;
  max-width: 91.4666666667vw;
  margin: 0 auto;
  line-height: 0;
}
@media only screen and (min-width: 768px) {
  .och3-media__channel-image {
    max-width: 30rem;
  }
}
.och3-media__channel-image img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 1.0666666667vw;
  aspect-ratio: 343/160;
}
@media only screen and (min-width: 768px) {
  .och3-media__channel-image img {
    aspect-ratio: 480/224;
    border-radius: 0.25rem;
  }
}
.och3-media__videos {
  position: relative;
  z-index: 3;
  margin: -18.6666666667vw 0 0;
  padding: 0;
  overflow: hidden;
  pointer-events: none;
  touch-action: pan-y;
}
@media only screen and (min-width: 768px) {
  .och3-media__videos {
    margin-top: -2.9375rem;
    padding: 0 2.5rem;
  }
}
.och3-media__videos .swiper-wrapper {
  margin: 0;
  padding: 0;
  transition-timing-function: linear !important;
  list-style: none;
}
@media only screen and (min-width: 768px) {
  .och3-media__videos .swiper-wrapper {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 0.5rem 1fr 0.5rem 1fr 0.5rem 1fr;
    gap: 0.5rem;
    grid-template-columns: repeat(4, 1fr);
  }
}
.och3-media__video {
  box-sizing: border-box;
  flex-shrink: 0;
  width: 49.3333333333vw;
  height: 27.7333333333vw;
  overflow: hidden;
  border-radius: 1.0666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-media__video {
    width: 100%;
    height: auto;
    border-radius: 0.25rem;
    aspect-ratio: 240/135;
  }
}
.och3-media__video img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.och3-media__shorts-title {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 5.3333333333vw 0 3.2vw;
  color: #FFFFFF;
  font-size: 4.8vw;
  font-weight: 700;
  line-height: 1.4;
  gap: 2.1333333333vw;
}
@media only screen and (min-width: 768px) {
  .och3-media__shorts-title {
    margin: 1.5rem 0 0.875rem;
    font-size: 1.125rem;
    gap: 0.5rem;
  }
}
.och3-media__shorts-title img {
  display: block;
  width: 1.6vw;
  height: 4vw;
}
@media only screen and (min-width: 768px) {
  .och3-media__shorts-title img {
    width: 0.375rem;
    height: 0.9375rem;
  }
}
.och3-media__shorts-title img:last-of-type {
  -webkit-transform: scaleX(-1);
  transform: scaleX(-1);
}
.och3-media__shorts {
  margin: 0;
  padding: 0;
  overflow: hidden;
  touch-action: pan-y;
}
@media only screen and (max-width: 767.999px) {
  .och3-media__shorts {
    pointer-events: none;
  }
}
@media only screen and (min-width: 768px) {
  .och3-media__shorts {
    padding: 0 2.5rem;
  }
}
.och3-media__shorts .swiper-wrapper {
  margin: 0;
  padding: 0;
  transition-timing-function: linear !important;
  list-style: none;
}
@media only screen and (min-width: 768px) {
  .och3-media__shorts .swiper-wrapper {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 0.5rem 1fr 0.5rem 1fr 0.5rem 1fr 0.5rem 1fr;
    gap: 0.5rem;
    grid-template-columns: repeat(5, 1fr);
  }
}
.och3-media__short {
  box-sizing: border-box;
  flex-shrink: 0;
  width: 27.4666666667vw;
  overflow: hidden;
  border-radius: 1.0666666667vw;
  aspect-ratio: 107/198;
}
@media only screen and (min-width: 768px) {
  .och3-media__short {
    width: 100%;
    border-radius: 0.25rem;
  }
}
.och3-media__short img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

/* ==========================================================
 * och3-reason : reason（本体）は templates/lp2/reason.php + v-reason.scss を流用
 * ここでは och3 側で追加したい CTA とぴったりブロックだけ定義
 * ========================================================== */
.och3-reason {
  padding: 10.6666666667vw 0;
  background: #F3F7FA;
}
.och3-reason .l-reason__section {
  padding-bottom: 0;
}
@media only screen and (min-width: 768px) {
  .och3-reason {
    margin-top: 5rem;
    padding: 4rem 2.5rem;
  }
}
.och3-reason__head {
  color: #0F2942;
  font-size: 7.4666666667vw;
  font-weight: 700;
  line-height: 1.6;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .och3-reason__head {
    margin-bottom: 2rem;
    font-size: 1.75rem;
    line-height: 1.4642857143;
  }
}

.och3-reason__cta {
  display: none;
}
@media only screen and (min-width: 768px) {
  .och3-reason__cta {
    display: block;
    margin-top: 2rem;
  }
}

/* --- ぴったりの塾エリア -------------------------------- */
.och3-pitari {
  margin-top: 10.6666666667vw;
  padding: 0 4.2666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-pitari {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 2rem;
    padding: 0 1rem;
  }
}
.och3-pitari__title {
  margin: 0 0 4.2666666667vw;
  color: #0F2942;
  font-size: 5.3333333333vw;
  font-weight: 400;
  line-height: 1.6;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .och3-pitari__title {
    margin-bottom: 1rem;
    font-size: 1.25rem;
  }
}
.och3-pitari__list {
  display: flex;
  flex-direction: column;
  margin: 0;
  padding: 0;
  list-style: none;
  gap: 1.0666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-pitari__list {
    gap: 0.25rem;
  }
}
.och3-pitari__item {
  display: flex;
  align-items: center;
  color: #0F2942;
  font-size: 4.8vw;
  font-weight: 700;
  line-height: 1.5;
  gap: 2.1333333333vw;
}
@media only screen and (min-width: 768px) {
  .och3-pitari__item {
    font-size: 1.125rem;
    gap: 0.5rem;
  }
}
.och3-pitari__item img {
  display: block;
  flex-shrink: 0;
  width: 7.4666666667vw;
  height: 7.4666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-pitari__item img {
    width: 1.75rem;
    height: 1.75rem;
  }
}

/* ==========================================================
 * och3-interview : 合格体験記
 * ========================================================== */
.och3-interview {
  position: relative;
  padding: 0 0 10.6666666667vw;
  background: #FFFFFF;
  /* --- リスト ------------------------------------------ */
  /* --- 体験記ヘッダー（人物バナー） ---------------------- */
  /* --- 体験記本文 ---------------------------------------- */
  /* --- SP用CTA --------------------------------------- */
}
@media only screen and (min-width: 768px) {
  .och3-interview {
    max-width: 67.5rem;
    margin: 0 auto;
    margin-top: 5rem;
    padding: 0 0 5rem;
  }
}
@media only screen and (min-width: 768px) {
  .och3-interview__header {
    height: 7.5rem;
    margin-bottom: 1.5rem;
  }
}
.och3-interview__header-bg {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  line-height: 0;
  pointer-events: none;
  aspect-ratio: 375/231;
}
@media only screen and (min-width: 768px) {
  .och3-interview__header-bg {
    aspect-ratio: 1080/120;
  }
}
.och3-interview__header-bg img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.och3-interview__title {
  position: relative;
  z-index: 1;
  margin: 0;
  margin-bottom: 6.4vw;
  padding-top: 10.6666666667vw;
  color: #0F2942;
  font-size: 7.4666666667vw;
  font-weight: 700;
  line-height: 1.4642857143;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .och3-interview__title {
    margin-bottom: 0;
    padding-top: 0.9375rem;
    font-size: 1.75rem;
  }
}
.och3-interview__header-stamp {
  display: none;
}
@media only screen and (min-width: 768px) {
  .och3-interview__header-stamp {
    display: block;
    position: absolute;
    z-index: 1;
    top: 1.4375rem;
    left: calc(50% + 10.4375rem);
    width: 5rem;
    -webkit-transform: rotate(10deg);
    transform: rotate(10deg);
    pointer-events: none;
    aspect-ratio: 1/1;
  }
  .och3-interview__header-stamp img {
    display: block;
    width: 100%;
    height: auto;
  }
}
.och3-interview__list {
  display: flex;
  flex-direction: column;
  margin: 0;
  padding: 0 4.2666666667vw;
  list-style: none;
  gap: 6.4vw;
}
@media only screen and (min-width: 768px) {
  .och3-interview__list {
    flex-direction: row;
    gap: 1.5rem;
    padding: 0;
  }
}
.och3-interview__item {
  display: flex;
  flex-direction: column;
  gap: 4.2666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-interview__item {
    flex: 1 1 0;
    gap: 1rem;
    min-width: 0;
  }
}
.och3-interview__item-hero {
  aspect-ratio: 343/144;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .och3-interview__item-hero {
    aspect-ratio: 528/144;
  }
}
.och3-interview__item-stamp {
  position: absolute;
  z-index: 3;
  top: -9.0666666667vw;
  right: -0.8vw;
  width: 21.3333333333vw;
  -webkit-transform: rotate(10deg);
  transform: rotate(10deg);
  line-height: 0;
  pointer-events: none;
}
@media only screen and (min-width: 768px) {
  .och3-interview__item-stamp {
    display: none;
  }
}
.och3-interview__item-stamp img {
  display: block;
  width: 100%;
  height: auto;
}
.och3-interview__item-body {
  color: #0F2942;
  font-size: 3.7333333333vw;
  font-weight: 400;
  line-height: 1.6;
}
@media only screen and (min-width: 768px) {
  .och3-interview__item-body {
    font-size: 0.875rem;
  }
}
.och3-interview__item-body .marker {
  background: linear-gradient(to top, transparent 0%, #ffed92 0%, #ffed92 15%, transparent 15%);
  font-weight: 700;
}
.och3-interview__cta {
  padding: 4.8vw 4.2666666667vw 0;
}
@media only screen and (min-width: 768px) {
  .och3-interview__cta {
    display: none;
  }
}

/* ==========================================================
 * och3-review : 生徒さんの満足の声（横スクロール）
 * ========================================================== */
.och3-review {
  padding: 10.6666666667vw 0;
  background: #F3F7FA;
  color: #0F2942;
  /* --- Swiperエリア ------------------------------------- */
  /* --- カード（Swiper slide） --------------------------- */
  /* --- CTA ------------------------------------------ */
}
@media only screen and (min-width: 768px) {
  .och3-review {
    padding: 3.5rem 0;
  }
}
.och3-review__head {
  padding: 0 4.2666666667vw 6.4vw;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .och3-review__head {
    padding: 0 1rem 1.5rem;
  }
}
.och3-review__ttl {
  margin: 0 0 3.2vw;
  font-size: 7.4666666667vw;
  font-weight: 700;
  line-height: 1.4;
}
@media only screen and (min-width: 768px) {
  .och3-review__ttl {
    margin-bottom: 0.75rem;
    font-size: 1.75rem;
  }
}
.och3-review__caution {
  margin: 0;
  font-size: 2.6666666667vw;
  font-weight: 400;
  line-height: 1.4;
}
@media only screen and (min-width: 768px) {
  .och3-review__caution {
    font-size: 0.625rem;
  }
}
.och3-review__slider {
  padding: 2.1333333333vw 0 4.2666666667vw;
  overflow: hidden;
}
@media only screen and (min-width: 768px) {
  .och3-review__slider {
    padding: 0.5rem 0 1rem;
  }
}
.och3-review__slider .swiper-wrapper {
  align-items: flex-start;
}
.och3-review__item {
  box-sizing: border-box;
  width: 64vw;
  height: auto;
  padding: 4.2666666667vw;
  overflow: hidden;
  border-radius: 2.1333333333vw;
  background: #FFFFFF;
}
@media only screen and (min-width: 768px) {
  .och3-review__item {
    width: 25rem;
    padding: 1rem;
    border-radius: 0.5rem;
  }
}
.och3-review__item-img {
  width: 8.5333333333vw;
  height: 8.5333333333vw;
  margin: 0 0 2.6666666667vw;
  overflow: hidden;
  border-radius: 50%;
}
@media only screen and (min-width: 768px) {
  .och3-review__item-img {
    width: 2rem;
    height: 2rem;
    margin-bottom: 0.625rem;
  }
}
.och3-review__item-img img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.och3-review__item-info {
  display: flex;
  align-items: center;
  margin-bottom: 2.6666666667vw;
  gap: 2.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-review__item-info {
    gap: 0.625rem;
    margin-bottom: 0.625rem;
  }
}
.och3-review__item-info .star {
  display: block;
  width: 24vw;
  height: 5.3333333333vw;
  line-height: 0;
}
@media only screen and (min-width: 768px) {
  .och3-review__item-info .star {
    width: 5.625rem;
    height: 1.25rem;
  }
}
.och3-review__item-info .star img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
}
.och3-review__item-info .when {
  margin: 0;
  font-size: 3.2vw;
  font-weight: 400;
  line-height: 1.4166666667;
}
@media only screen and (min-width: 768px) {
  .och3-review__item-info .when {
    font-size: 0.75rem;
  }
}
.och3-review__item-txt {
  margin: 0;
  color: #0F2942;
  font-size: 3.2vw;
  font-weight: 400;
  line-height: 1.4166666667;
}
@media only screen and (min-width: 768px) {
  .och3-review__item-txt {
    font-size: 0.75rem;
  }
}
.och3-review__cta {
  padding: 4.2666666667vw 4.2666666667vw 0;
}
@media only screen and (min-width: 768px) {
  .och3-review__cta {
    padding: 1.5rem 1rem 0;
  }
}

/* ==========================================================
 * och3-teacher : 講師紹介
 * footer-new.php の .swiper 初期化（slidesPerView: auto, PC: 3.5）を利用
 * ========================================================== */
.och3-teacher {
  padding: 10.6666666667vw 0;
  background: #FFFFFF;
  color: #0F2942;
  /* --- 講師カード（swiper-slide） ------------------------ */
  /* --- CTA --------------------------------------------- */
}
@media only screen and (min-width: 768px) {
  .och3-teacher {
    padding: 5rem 0 0;
  }
}
.och3-teacher__ttl {
  margin: 0 0 6.4vw;
  color: #0F2942;
  font-size: 7.4666666667vw;
  font-weight: 700;
  line-height: 1.6;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .och3-teacher__ttl {
    margin-bottom: 1.5rem;
    font-size: 1.75rem;
  }
}
.och3-teacher__slider {
  overflow: hidden;
}
@media only screen and (min-width: 768px) {
  .och3-teacher__slider {
    max-width: 67.5rem;
    margin: 0 auto;
    padding: 0 2.5rem;
  }
}
@media only screen and (min-width: 768px) {
  .och3-teacher__slider .swiper-wrapper {
    display: flex;
    gap: 2rem;
    justify-content: center;
    -webkit-transform: none !important;
    transform: none !important;
  }
}
.och3-teacher__item {
  display: flex;
  position: relative;
  box-sizing: border-box;
  flex-direction: column;
  width: 64vw;
  height: auto;
  overflow: hidden;
  border-radius: 2.1333333333vw;
  background: #F3F7FA;
}
@media only screen and (min-width: 768px) {
  .och3-teacher__item {
    width: 20rem;
    border-radius: 0.5rem;
  }
  .och3-teacher__item:nth-child(1) {
    order: 2;
  }
  .och3-teacher__item:nth-child(2) {
    order: 3;
  }
  .och3-teacher__item:nth-child(3) {
    order: 1;
  }
}
.och3-teacher__item-photo {
  aspect-ratio: 240/160;
}
@media only screen and (min-width: 768px) {
  .och3-teacher__item-photo {
    aspect-ratio: 320/160;
  }
}
.och3-teacher__item-body {
  flex: 1 1 auto;
  padding: 4.2666666667vw;
  color: #0F2942;
  font-size: 3.2vw;
  font-weight: 400;
  line-height: 1.5;
  text-align: justify;
}
@media only screen and (min-width: 768px) {
  .och3-teacher__item-body {
    padding: 1rem;
    font-size: 0.75rem;
  }
}
.och3-teacher__cta {
  padding: 6.4vw 4.2666666667vw 0;
}
@media only screen and (min-width: 768px) {
  .och3-teacher__cta {
    padding: 1rem 1rem 0;
  }
}

/* ==========================================================
 * och3-faq : よくある質問（<details>ベースのアコーディオン）
 * ========================================================== */
.och3-faq {
  padding: 10.6666666667vw 4.2666666667vw;
  background: #F3F7FA;
  color: #0F2942;
  /* --- アコーディオン項目 -------------------------------- */
  /* --- Q（accordion-head） ----------------------------- */
  /* --- A wrapper（slideToggle 対象） -------------------- */
  /* --- A（answer） -------------------------------------- */
}
@media only screen and (min-width: 768px) {
  .och3-faq {
    padding: 5rem 0 0;
    background: transparent;
  }
}
.och3-faq .ly-faq__list {
  margin-bottom: 0;
}
.och3-faq .ly-faq__item:nth-child(n+2) {
  margin-top: 3.2vw;
}
@media only screen and (min-width: 768px) {
  .och3-faq .ly-faq__item:nth-child(n+2) {
    margin-top: 1.5rem;
  }
}
.och3-faq .ly-faq__item-head.is-active._pc {
  box-shadow: 0 2px 2px 0 rgba(111, 152, 157, 0.1);
}
@media only screen and (min-width: 768px) {
  .och3-faq .ly-faq__item-head.is-active._pc {
    box-shadow: none;
  }
}
.och3-faq__ttl {
  margin: 0 0 6.4vw;
  color: #0F2942;
  font-size: 7.4666666667vw;
  font-weight: 700;
  line-height: 1.1428571429;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .och3-faq__ttl {
    margin-bottom: 2rem;
    font-size: 1.75rem;
  }
}
.och3-faq__list {
  display: flex;
  flex-direction: column;
  gap: 3.2vw;
  padding: 0 4.2666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-faq__list {
    max-width: 50rem;
    margin: 0 auto;
    padding: 0 1rem;
    gap: 0.75rem;
  }
}
.och3-faq__item {
  overflow: hidden;
  border-radius: 1.0666666667vw;
  background: #FFFFFF;
  box-shadow: 0 1.0666666667vw 2.6666666667vw 0 rgba(15, 41, 66, 0.06);
}
@media only screen and (min-width: 768px) {
  .och3-faq__item {
    border-radius: 0.25rem;
    box-shadow: 0 0.25rem 0.625rem 0 rgba(15, 41, 66, 0.06);
  }
}
.och3-faq__q {
  display: flex;
  position: relative;
  align-items: flex-start;
  padding: 4.8vw 10.6666666667vw 4.8vw 4.2666666667vw;
  color: #0F2942;
  font-size: 4.2666666667vw;
  font-weight: 700;
  line-height: 1.5;
  cursor: pointer;
  gap: 3.2vw;
}
@media only screen and (min-width: 768px) {
  .och3-faq__q {
    padding: 1.125rem 2.5rem 1.125rem 1.25rem;
    font-size: 1rem;
    gap: 0.75rem;
  }
}
.och3-faq__q-label {
  flex-shrink: 0;
  color: #00A9DE;
  font-family: "Oswald", "U-OTF Gothic MB101 Upr", sans-serif;
  font-size: 5.3333333333vw;
  font-weight: 700;
  line-height: 1.2;
}
@media only screen and (min-width: 768px) {
  .och3-faq__q-label {
    font-size: 1.25rem;
  }
}
.och3-faq__q-txt {
  flex: 1 1 auto;
  min-width: 0;
}
.och3-faq__q-arrow {
  position: absolute;
  top: 50%;
  right: 4.2666666667vw;
  width: 2.6666666667vw;
  height: 2.6666666667vw;
  -webkit-transform: translateY(-75%) rotate(45deg);
  transform: translateY(-75%) rotate(45deg);
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
  border-right: 2px solid #0F2942;
  border-bottom: 2px solid #0F2942;
}
@media only screen and (min-width: 768px) {
  .och3-faq__q-arrow {
    right: 1.25rem;
    width: 0.625rem;
    height: 0.625rem;
  }
}
.och3-faq__q.is-active .och3-faq__q-arrow {
  -webkit-transform: translateY(-25%) rotate(-135deg);
  transform: translateY(-25%) rotate(-135deg);
}
.och3-faq__a-wrapper {
  display: none;
}
.och3-faq__a {
  display: flex;
  align-items: flex-start;
  padding: 4.2666666667vw 4.2666666667vw 5.3333333333vw;
  border-top: 1px solid rgba(15, 41, 66, 0.08);
  gap: 3.2vw;
}
@media only screen and (min-width: 768px) {
  .och3-faq__a {
    gap: 0.75rem;
    padding: 1rem 1.25rem 1.5rem;
  }
}
.och3-faq__a-label {
  flex-shrink: 0;
  color: #00A9DE;
  font-family: "Oswald", "U-OTF Gothic MB101 Upr", sans-serif;
  font-size: 5.3333333333vw;
  font-weight: 700;
  line-height: 1.2;
}
@media only screen and (min-width: 768px) {
  .och3-faq__a-label {
    font-size: 1.25rem;
  }
}
.och3-faq__a-txt {
  flex: 1 1 auto;
  min-width: 0;
  color: #0F2942;
  font-size: 4.2666666667vw;
  font-weight: 400;
  line-height: 1.5;
}
@media only screen and (min-width: 768px) {
  .och3-faq__a-txt {
    font-size: 1rem;
  }
}
.och3-faq__a-txt .bold {
  font-weight: 700;
}
.och3-faq__a-txt p {
  margin: 0 0 3.2vw;
}
.och3-faq__a-txt p:last-child {
  margin-bottom: 0;
}
@media only screen and (min-width: 768px) {
  .och3-faq__a-txt p {
    margin-bottom: 0.75rem;
  }
}
.och3-faq__cta {
  padding: 6.4vw 0 0;
}
@media only screen and (min-width: 768px) {
  .och3-faq__cta {
    padding: 1.5rem 0 0;
  }
}

/* ==========================================================
 * och3-flow : お問合せから入塾までの流れ
 * 既存 _v-flow.scss をベースに och3 プレフィックスで別管理
 * ========================================================== */
.och3-flow {
  position: relative;
  padding: 10.6666666667vw 0 0;
  background: #FFFFFF;
}
@media only screen and (min-width: 768px) {
  .och3-flow {
    padding: 5rem 0 0;
  }
}
.och3-flow__inner {
  width: 100%;
  margin: 0 auto;
  padding: 0 4.2666666667vw;
}
@media only screen and (min-width: 768px) {
  .och3-flow__inner {
    padding: 0 3.125rem;
  }
}
.och3-flow__ttl {
  margin: 0 0 6.4vw;
  color: #0F2942;
  font-size: 7.4666666667vw;
  font-weight: 700;
  line-height: 1.6;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .och3-flow__ttl {
    margin-bottom: 1.5rem;
    font-size: 1.75rem;
  }
}
.och3-flow__list {
  padding: 0;
  list-style: none;
}
@media only screen and (min-width: 768px) {
  .och3-flow__list {
    max-width: 45.3125rem;
    margin: 0 auto;
  }
}
@media only screen and (min-width: 768px) {
  .och3-flow__item {
    display: flex;
    flex-direction: row-reverse;
    align-items: center;
    justify-content: flex-start;
    gap: 2.5rem;
  }
}
.och3-flow__item:nth-child(n+2) {
  margin-top: 6.4vw;
}
@media only screen and (min-width: 768px) {
  .och3-flow__item:nth-child(n+2) {
    margin-top: 2rem;
  }
}
@media only screen and (min-width: 768px) {
  .och3-flow__item-head--box {
    flex: 1 1 auto;
  }
}
.och3-flow__item-head {
  display: flex;
  position: relative;
  align-items: center;
  height: 8.5333333333vw;
  margin: 0 0 4.2666666667vw;
  padding-left: 15.7333333333vw;
}
@media only screen and (min-width: 768px) {
  .och3-flow__item-head {
    height: 2rem;
    margin-bottom: 1rem;
    padding-left: 3.6875rem;
  }
}
.och3-flow__item-head .item-txt {
  color: #0F2942;
  font-size: 5.8666666667vw;
  font-weight: 700;
  line-height: 1.4;
}
@media only screen and (min-width: 768px) {
  .och3-flow__item-head .item-txt {
    font-size: 1.375rem;
  }
}
.och3-flow__item-head .item-txt .sm {
  font-size: 4.2666666667vw;
  font-weight: 400;
}
@media only screen and (min-width: 768px) {
  .och3-flow__item-head .item-txt .sm {
    font-size: 1rem;
  }
}
.och3-flow__item-head img.num {
  position: absolute;
  left: 0;
  width: auto;
  height: 8vw;
}
@media only screen and (min-width: 768px) {
  .och3-flow__item-head img.num {
    height: 1.875rem;
  }
}
.och3-flow__item-pic {
  width: 100%;
  margin: 0 0 4.2666666667vw;
  aspect-ratio: 343/140;
}
@media only screen and (min-width: 768px) {
  .och3-flow__item-pic {
    flex: 0 0 auto;
    width: 21.4375rem;
    margin-bottom: 0;
    border-radius: 0.25rem;
  }
}
.och3-flow__item-pic img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.och3-flow__item-txt {
  margin: 0;
  color: #0F2942;
  font-size: 3.7333333333vw;
  font-weight: 400;
  line-height: 1.4285714286;
}
@media only screen and (min-width: 768px) {
  .och3-flow__item-txt {
    font-size: 0.875rem;
    letter-spacing: -0.01em;
  }
}
.och3-flow__cta {
  padding: 6.4vw 4.2666666667vw 0;
}
@media only screen and (min-width: 768px) {
  .och3-flow__cta {
    padding: 1.5rem 1rem 0;
  }
}

@media only screen and (min-width: 768px) {
  .och3-counseling {
    margin-top: 5rem;
  }
}
.och3-counseling .v-counseling {
  margin-bottom: 0;
}
.och3-counseling__cta {
  margin-top: 6.4vw;
}
@media only screen and (min-width: 768px) {
  .och3-counseling__cta {
    margin-top: 2.5rem;
  }
}

@media only screen and (min-width: 768px) {
  .och3-form {
    margin-top: 5rem;
  }
}
.och3-form .c-brochure {
  margin-top: 0;
}