@charset "UTF-8";


/* ========================================
    @media screen and (min-width: 768px),print
======================================== */
@media screen and (min-width: 768px),print {

  /* hero
  -------------------------------------*/
#index {
  transform: translateY(-4px);
}
#index #hero.hero {
  position: relative;
}
#index #hero.hero::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("../images/front-page/hero.png") no-repeat top center;
  background-size: auto 100%;
}

#index #hero.hero::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: min(4.65vw, 8rem);
  height: 75%;
  background: url(../images/common/bg-blue-texture.jpg) repeat;
  z-index: 1;
}



#index #hero .hero__inner {
  position: relative;
  padding-top: clamp(8.8rem, 17.361vw - 4.533rem, 28.8rem);
  padding-top: 8.7%;
  padding-bottom: clamp(10.9rem, 6.944vw + 5.567rem, 18.9rem);
  padding-bottom: 9.5%;
  z-index: 1;

}
#index #hero .hero__content-wrap {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding-left: clamp(4rem, 22.135vw - 13rem, 29.5rem); /*1920px*/
  color: var(--color-main);
}
#index #hero .hero__title img {
  width: min(33.489vw, 643px);
  height: auto;
}
#index #hero .hero__title-read {
  margin-top: 2.8rem;
  font-size: 2rem;
  line-height: 2;
  letter-spacing: 0.07em;
}
#index #hero .hero__title-en {
  width: clamp(30rem, 53.006vw - 10.709rem, 63.5rem);
  margin-top: -6rem;
  margin-left: -3rem;
}
#index #hero .hero__budge {
  margin-top: 2.6rem;
  width: clamp(34.5rem, 7.118vw + 29.033rem, 42.7rem);
  width: clamp(33rem, 60.601vw - 13.542rem, 71.3rem);
  width: 49%;
  transform: translateX(-10%);
}
#index #hero .hero__budge > img {
  width: 100%;
}
#index #hero .hero__figure {
  width: 54.3%;
}
#index #hero .hero__figure img {
  width: 100%
}


  /* con1-worry
  -------------------------------------*/
#index #worry.worry {
  position: relative;
  z-index: 0;
  background-color: var(--color-bg-gray);
}
#index #worry.worry::before {
  content: '';
  position: absolute;
  top: -2px;
  left: 0;
  right: 0;
  bottom: 0;
  background:  url(../images/front-page/con1-worry-bg.png) center top / 100% no-repeat;
  z-index: -1;
  pointer-events: none;
}
#index #worry .worry__inner {
  position: relative;
  z-index: 3;
  padding-top: 6.1rem;
  padding-bottom: 18.4rem;
}
#index #worry .worry__title-wrap {
  text-align: center;
  color: #fff;
}
#index #worry .worry__title {
  font-size: clamp(3.5rem, calc(-1.4655rem + 6.4655vw), 5rem);
  font-weight: 600;
  line-height: calc(60 / 50);
  letter-spacing: 0.04em;
  color: #fff;
}

#index #worry .worry__lead {
  position: relative;
  display: inline-block;
  margin-top: 4rem;
  margin-inline: auto;
  font-size: clamp(2rem, calc(0.676rem + 1.724vw), 2.4rem);
  line-height: calc(29 / 24);
  font-weight: 700;
}
#index #worry .worry__lead span {
  display: inline-block;
  padding-bottom: 1.4rem;
  border-bottom: 1px solid #fff;
}
#index #worry .worry__list {
  position: relative;
  width: 640px;
  margin-top: 6.5rem;
  margin-inline: auto;
}
#index #worry .worry__list::before,
#index #worry .worry__list::after {
  content: "";
  position: absolute;
  background-size: contain;
  display: block;
  z-index: 1;
}
#index #worry .worry__list::before {
  bottom: 7.3rem;
  left: clamp(-420px, calc(-145px + (-275 * (100vw - 768px) / (1500 - 768))), -145px);
  width: min(25.53vw, 388px); /* 388px ÷ 1520px × 100 = 25.53vw */
  aspect-ratio: 388 / 274;
  background-image: url(../images/front-page/con1-worry-list-img01.jpg);
}
@media screen and (max-width: 1550px) {
  #index #worry .worry__list::before {
    bottom: clamp(-160px, calc(-160px + (70 * (100vw - 1550px) / (768 - 1550))), -90px);
    left: clamp(-350px, calc(-350px + (310 * (100vw - 1550px) / (768 - 1550))), -40px);
    z-index: -1;
  }
}


#index #worry .worry__list::after {
  right: clamp(-220px, calc(-220px + (180 * (100vw - 1160px) / (768 - 1160))), -40px);
  right: clamp(-23.7rem, -31.804vw + 20.825rem, -3.6rem);
  top: -5rem;
  width: min(21.7vw, 256px);
  aspect-ratio: 256 / 300;
  background-image: url(../images/front-page/con1-worry-list-img02.jpg);
}
#index #worry .worry__item {
  position: relative;
  padding: 2rem 1em 2rem 9.9rem;
  font-size:  1.8rem;
  line-height: calc(40 / 18);
  letter-spacing: 0.05em;
  background: #fff;
}
#index #worry .worry__item:not(:first-child) {
  margin-top: 2rem;
}
#index #worry .worry__item::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 5.9rem;
  transform: translateY(-40%);
  width: 2.4rem;
  height: 2.4rem;
  background: url(../images/front-page/con1-worry-checkmark.svg) center / contain no-repeat;
}
#index #worry .worry__item span {
  font-weight: 700;
  color: var(--color-accent);
}
#index #worry .worry__item:last-child {
  position: relative;
}
#index #worry .worry__item:last-child::after {
  content: "";
  position: absolute;
  bottom: -5.7rem;
  left: 50%;
  width: 13rem;
  height: 6.5rem;
  transform: translateX(-50%);
  background: url(../images/front-page/con1-worry-list-arrow.svg);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

#index #worry .worry__bottom {
  margin-top: 10.7rem;
  text-align: center;
  transform: translateX(2px);
}
#index #worry .worry__bottom-text {
  font-weight: 600;
  line-height: calc(41 / 34);
  letter-spacing: 0.05em;
}
#index #worry .worry__bottom-text--upper {
  font-size: 3.3rem;
  letter-spacing: 0;
}
#index #worry .worry__bottom-text--lower {
  margin-top: 3.7rem;
  font-size: 3.5rem;
}

#index #worry .worry__bottom-text img {
  margin-top: 4.2rem;
  width: min(79.3vw, 79.3rem);
}
#index #worry .worry__bottom-text--lower span {
  font-size: 5rem;
  font-weight: 600;
  line-height: calc(60 / 50);
}


  /* con2-point
  -------------------------------------*/
#index #point.point {
  position: relative;
  overflow: visible;
}
#index #point.point::before {
  content: "";
  position: absolute;
  top: clamp(-25rem, -9.201vw - 7.333rem, -14.4rem);
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: calc(100% + clamp(21.3rem, 12.066vw + 12.033rem, 35.2rem));
  background: url(../images/front-page/con2-point-bg.webp) no-repeat center;
  background-size: auto 100%;
  z-index: 0;
  pointer-events: none;
}

#index #point .point__inner {
  position: relative;
}
#index #point .point__budge {
  position: absolute;
  top: 2rem;
  right: clamp(10rem, 34.375vw - 16.4rem, 49.6rem);
  width: clamp(140px, -113.077px + 18.077vw, 234px);
  transform: translateY(-100%);
}


#index #point .point__list {
  width: min(95%, 1600px);
  margin-inline: auto;
}

/* point__item */
#index #point .point__item {
  width: 90.65%;
  padding-left: 7rem;
  display: grid;
  grid-template-columns: 54.35% 40.36%;
  column-gap: 3%;
  grid-template-rows: min-content 1fr;
  grid-template-areas:
  "img title"
  "img desc";
}
@media screen and (max-width: 1000px) {
  #index #point .point__item {
    width: 95%;
    grid-template-columns: 45% 52%;
    column-gap: 3%;
  }
}

#index #point .point__item:nth-child(odd) {
  margin-left: 0;
  margin-right: auto;
}

#index #point .point__item:nth-child(even) {
  margin-right: 5.6rem;
  margin-right: 0;
  margin-left: auto;
  padding-left: 7rem;
  justify-content: end;
  transform: translateX(-5.4rem);
  grid-template-columns:40.36% 54.35%;
  grid-template-areas:
  "title img"
  "desc img";
}


#index #point .point__imageWrap {
  align-self: start;
  grid-area: img;
}
#index #point .point__titleWrap {
  align-self: start;
  grid-area: title;
}
#index #point .point__descWrap  {
  align-self: start;
  grid-area: desc;
}


#index #point .point__imageWrap img {
  display: block;
  width: 100%;
}
#index #point .point__pointNum img {
  display: block;
}

#index #point .point__pointNum {
  margin-top: 5.6rem;
}
#index #point .point__title {
  margin-top: 2.5rem;
  font-size: clamp(2.2rem, 1.215vw + 1.267rem, 3.6rem); /* 768~1920 */
  font-weight: 600;
  line-height: calc(43 / 36);
  letter-spacing: 0.07em;
  color: #fff;
}
#index #point .point__title span {
  display: inline-block;
  white-space: nowrap;
}
#index #point .point__title span:not(:first-child) {
  margin-top: 1.8rem;
}
#index #point .point__title span img {
  margin-right: 1rem;
}
#index #point .point__desc-text {
  margin-top: 3.2rem;
  padding-right: 1rem;
  font-size: clamp(1.2rem, 0.694vw + 0.667rem, 2rem); /* 768~1920 */
  line-height: calc(42 / 20);
  letter-spacing: 0.1em;
  color: #fff;
}


/* point__item--2nd */
#index #point .point__item--2nd {
  margin-top: 4.95vw;
  gap: 4.2%;
}
#index #point .point__item--2nd .point__titleWrap,
#index #point .point__item--2nd .point__descWrap {
  min-width: 32rem;
}
#index #point .point__item--2nd .point__pointNum {
  margin-top: 7.2rem;
}
#index #point .point__item--2nd .point__title {
  margin-top: 4.5rem;
}
#index #point .point__item--2nd .point__desc-text {
  margin-top: 1.9rem;
  padding-right: 0;
}

/* point__item--3rd */
#index #point .point__item--3rd {
  margin-top: 4.95vw;
  gap: 2.8%;
}
#index #point .point__item--3rd .point__pointNum {
  margin-top: 3.2rem;
  padding-left: 0.4rem;
}
#index #point .point__item--3rd .point__title {
  margin-top: 4.5rem;
}
#index #point .point__item--3rd .point__desc-text {
  margin-top: 2rem;
}
#index #point .point__item--3rd .point__title .add-txt {
  display: none;
}


#index #point .point__btnWrap {
  width: min(80%, 1100px);
  margin-top: clamp(3rem, calc(-3rem + 7.8125vw), 12rem);
  margin-top: clamp(-3rem, 11.545vw - 11.867rem, 10.3rem);
  margin-inline: auto;
}
#index #point .point__btnWrap a img {
  transition: all 0.2s ease;
}
#index #point .point__btnWrap a img:hover {
  filter: brightness(1.1);
  opacity: 1;
}


/* con3-menu
-------------------------------------*/
#index #point.menu {
  background-color: #fff;
}
#index #menu .menu__inner {
  width: min(95%, 1200px);
  margin-inline: auto;
  padding-top: 18.3rem;
  padding-bottom: 15.6rem;
}
#index #menu .menu__title {
  text-align: center;
}
#index #menu .menu__list {
  display: grid;
  grid-template-columns: 62.58% 34.1%;
  column-gap: 3.32rem;
  row-gap: 6.5rem;
  width: min(94.42vw, 1133px);
  margin-top: 4.8em;
  margin-inline: auto;
}
#index #menu .menu__item {
  position: relative;
}
#index #menu .menu__item--wide {
  grid-column: 1 / -1;
}
#index #menu .menu__item-text {
  width: min(95%, 860px);
  margin-top: 1.2rem;
  margin-inline: auto;
  line-height: calc(30 / 16);
  letter-spacing: 0.05em;
}


/* voiceAndProfile
-------------------------------------*/
.voiceAndProfile {
  position: relative;
  z-index: 2;
}


/* voice
-------------------------------------*/
.voice {
  background: var(--color-bg-gray) url(../images/front-page/con4-voice-bg.png) top center/contain no-repeat;
}
.voice__inner {
  padding-top: 23.9rem;
  padding-top: clamp(180px, 140.667px + 5.122vw, 239px);
  padding-bottom: clamp(360px, 79.333px + 36.545vw, 781px);
  padding-bottom: clamp(360px, -151.595px + 66.614vw, 781px);
}
.voice__title-wrap {
  position: relative;
  text-align: center;
}
.voice__title-wrap::before {
  content: "";
  position: absolute;
  top: -8.9rem;
  left: 50%;
  width: 35.42rem;
  height: 4.2rem;
  transform: translateX(-50%);
  background: url(../images/front-page/con4-voice-title-deco.svg) center/contain no-repeat;
}

.voice__voiceWrap {
  width: min(95%, 1100px);
  margin-top: 7.55rem;
  margin-inline: auto;
  padding: min(4.17vw, 8rem) min(5.21vw, 10rem);
  background: #fff;
}
.voice__panel {
  padding-top: 5rem;
  padding-inline: 5rem;
  padding-bottom: 4.6rem;
  background-color: #EFF0F2;
}
.voice__header {
  display: grid;
  grid-template-columns: 90px 1fr;
  column-gap: 4rem;
}
.voice__item:not(:first-child) {
  margin-top: 4rem;
}
.voice__avatar {
  grid-column: 1;
  grid-row: 1 / 3;
  align-self: center;
}
.voice__meta {
  grid-column: 2;
  grid-row: 1;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1.5rem;
}
.voice__course-name {
  padding: 0.3rem 0.6rem;
  font-weight: 700;
  line-height: calc(19 / 16);
  color: #fff;
  background-color: var(--color-main);
}
.voice__detail {
  font-weight: 500;
  line-height: calc(19 / 16);
  color: var(--color-black);
}
.voice__voice-title {
  grid-column: 2;
  grid-row: 2;
  margin-top: 2rem;
  font-size: 2.2rem;
  line-height: calc(40 /22);
  letter-spacing: 0.05em;
}
.voice__line {
  width: 100%;
  height: 1px;
  margin-top: 1rem;
  background-color: #D5D5D5;
}
.voice__text {
  margin-top: 2.1rem;
  font-weight: 400;
  line-height: calc(32 / 16);
  letter-spacing: 0.05em;
}


/* con5-profile
-------------------------------------*/
.profile {
  position: absolute;
  bottom: -12.5rem;
  left: 50%;
  transform: translateX(-50%);
  width: min(95%, 1280px);
  background-color: #fff;
}
.profile__wrapper {
  position: relative;
  display: grid;
  grid-template-columns: 38.18% 1fr;
  align-items: end;
  gap: clamp(24px, -47.696px + 9.335vw, 83px);
  margin-top: -6rem;
  padding: 0 min(6.43vw, 9rem) min(5.71vw, 8rem);
}
.profile__image {
  grid-column: 1;
  position: relative;
}
.profile__image > img {
  width: 100%;
}
.profile__title {
  grid-column: 2;
  position: absolute;
  top: 0;
  left: 0;
  width: 61.28%;
  transform: translateX(-3rem);
  z-index: 1;
}
.profile__body {
  grid-column: 2;
  position: relative;
  z-index: 2;
}
.profile__nameWrap {
  display: flex;
  align-items: center;
  margin-top: clamp(10px, -2.152px + 1.582vw, 20px);
  padding-bottom: 2.4rem;
  border-bottom: 1px solid #BCBCBC;
  color: #000;
}
.profile__name {
  font-size: clamp(3.5rem, calc(-1.4655rem + 6.4655vw), 5rem);
  font-size: clamp(30px, 5.696px + 3.165vw, 50px);
  font-weight: 600;
  line-height: calc(60 / 50);
  letter-spacing: 0.05em;
}
.profile__name-ruby {
  margin-left: 1.2rem;
  font-size: clamp(13px, 9.354px + 0.475vw, 16px);
  font-weight: 400;
  line-height: calc(19 / 16);
  letter-spacing: 0.05em;
}
.profile__sns-list {
  display: flex;
  align-items: center;
  margin-left: 3rem;
  gap: 4rem;
}
.profile__list {
  margin-top: 4.5rem;
}
.profile__item {
  position: relative;
  padding-left: 1em;
  font-size: 1.8rem;
  font-size: clamp(12px, 4.709px + 0.949vw, 18px);
  font-weight: 500;
  line-height: calc(34 / 18);
  letter-spacing: 0.05em;
}
.profile__item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  display: block;
  width: 1rem;
  height: 1rem;
  background-color: #B4BFD8;
  border-radius: 50%;
}
.profile__achievements {
  margin-top: clamp(10px, -26.456px + 4.747vw, 40px);
  margin-top: 3rem;
}
.profile__group {
  display: flex;
  align-items: center;
  gap: 2rem;
}
.profile__group:not(:first-child) {
  margin-top: 1.2rem;
}
.profile__group dt {
  width: 25%;
  padding: 1.1rem 0;
  font-size: clamp(9px, 0.494px + 1.108vw, 16px);;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.08em;
  text-align: center;
  color: var(--color-main);
  border: 1px solid var(--color-main);
}
.profile__group dd {
  flex: 1;
  font-size: clamp(9px, 0.494px + 1.108vw, 16px);;
  font-weight: 500;
  line-height: calc(30 / 16);
  color: #000;
}


/* seo
-------------------------------------*/
.seo__inner {
  width: min(90%, 120rem);
  margin-inline: auto;
  padding: 4rem;
}
.seo__text {
  font-size: 1.4rem;
  line-height:2;
  letter-spacing: 0.08em;
  text-align: justify;
  color: #000;
}



}


/* ========================================
  @media screen and (max-width: 767px)
======================================== */
@media screen and (max-width: 767px) {

/* hero
-------------------------------------*/
#index #hero.hero {
  position: relative;
}
#index #hero.hero::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("../images/front-page/hero-sp.jpg") no-repeat top center / contain;
}
#index #hero .hero__inner {
  position: relative;
  display: flex;
  flex-direction: column-reverse;
  justify-content: flex-end;
  background-color: transparent;
}
.hero__text-area {
  position: relative;
  margin-top: -30.9vw;
  padding-top: 127.8vw;
  padding-inline: 5.3vw;
  z-index: 10;
}
#index #hero .hero__title {
  width: 100%;
}
#index #hero .hero__title img {
  width: 100%;
}
#index #hero .hero__title-read {
  margin-top: 2.9vw;
  padding-left: 1.9vw;
  font-weight: 600;
  font-size: 3.8vw;
  line-height: calc(30 / 16);
  letter-spacing: 0.07em;
  color: var(--color-main);
}
#index #hero .hero__title-en {
  margin-top: -7.0vw;
}
#index #hero .hero__budge {
  position: relative;
  padding: 0 2.9vw;
  width: 100%;
  z-index: 5;
}
#index #hero .hero__budge > img {
  position: relative;
  width: 100%;
  z-index: 10;
}
#index #hero .hero__figure {
  width: 100%;
}
#index #hero .hero__figure img {
  width: 100%;
}



/* con1-worry
-------------------------------------*/
#index #worry.worry {
  position: relative;
  z-index: 2;
  background-color: var(--color-bg-gray);
}
#index #worry.worry::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: url(../images/front-page/con1-worry-bg-sp.png) center top / 100% no-repeat;
  z-index: -1;
  pointer-events: none;
}
#index #worry .worry__inner {
  position: relative;
  z-index: 3;
  margin-top: -4.3vw;
  padding-top: 21.6vw;
  padding-inline: 5.3vw;
  padding-bottom: 34.5vw;
}
#index #worry .worry__title-wrap {
  margin-top: 3.4vw;
  letter-spacing: 0;
  text-align: center;
  color: #fff;
}
#index #worry .worry__title {
  font-size: 7.4vw;
  font-weight: 600;
  line-height: calc(46 / 30);
  letter-spacing: 0.04em;
  color: #fff;
}
#index #worry .worry__lead {
  position: relative;
  display: inline-block;
  margin-top: 4.1vw;
  margin-inline: auto;
  font-size: 4.3vw;
  line-height: calc(32 / 18);
  font-weight: 700;
  letter-spacing: 0.11em;
}
#index #worry .worry__lead span {
  display: inline-block;
  padding-bottom: 1.5vw;
  border-bottom: 1px solid #fff;
}
#index #worry .worry__list {
  position: relative;
  width: 100%;
  margin-top: 47.1vw;
  margin-inline: auto;
}
#index #worry .worry__list::before,
#index #worry .worry__list::after {
  content: "";
  position: absolute;
  background-size: contain;
  display: block;
  z-index: 1;
}
#index #worry .worry__list::before {
  top: 0;
  left: 4%;
  width: 46.84vw;
  background-image: url(../images/front-page/con1-worry-list-img01.jpg);
  aspect-ratio: 193/137;
  transform: translateY(calc(-100% - 7vw));
}
#index #worry .worry__list::after {
  right: 4%;
  top: 0;
  width: 28.6vw;
  background-image: url(../images/front-page/con1-worry-list-img02.jpg);
  aspect-ratio: 118/140;
  transform: translateY(calc(-100% + 1.7vw));
  z-index: -1;
}
#index #worry .worry__item {
  position: relative;
  padding: 4.3vw 1em 3.9vw 13vw;
  font-size: 3.9vw;
  line-height: calc(23 / 16);
  letter-spacing: 0.05em;
  background: #fff;
  min-height: 19.3vw;
  display: flex;
  align-items: center;
}
#index #worry .worry__item:not(:first-child) {
  margin-top: 3.6vw;
}
#index #worry .worry__item::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 3.6vw;
  transform: translateY(-40%);
  width: 5.8vw;
  height: 5.8vw;
  background: url(../images/front-page/con1-worry-checkmark.svg) center / contain no-repeat;
}
#index #worry .worry__item span {
  font-weight: 700;
  color: var(--color-accent);
}
#index #worry .worry__item:last-child {
  position: relative;
}
#index #worry .worry__item:last-child::after {
  content: "";
  position: absolute;
  bottom: -8.2vw;
  left: 50%;
  width: 31.4vw;
  height: 15.7vw;
  transform: translateX(-50%);
  background: url(../images/front-page/con1-worry-list-arrow.svg);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  z-index: -1;
}
#index #worry .worry__bottom {
  margin-top: 20vw;
  text-align: center;
}
#index #worry .worry__bottom-text {
  font-size: 5.3vw;
  font-weight: 600;
  line-height: calc(26 / 22);
}
#index #worry .worry__bottom-text img {
  margin-top: 8.5vw;
  margin-bottom: 8.2vw;
}
#index #worry .worry__bottom-text-sp-bottom {
  font-size: 6.3vw;
  font-weight: 600;
  line-height: calc(36 / 30);
}
#index #worry .worry__bottom-text-sp-bottom span {
  font-size: 12.1vw;
  font-weight: 600;
  line-height: calc(60 / 50);
}
#index #worry .worry__bottom-text--lower {
  font-size: 7.7vw;
}
#index #worry .worry__bottom-text--lower span {
  font-size: 9.7vw;
}


  /* con2-point
  -------------------------------------*/
#index #point.point {
  position: relative;
  z-index: 3;
}
.point::after {
  content: '';
  position: absolute;
  top: clamp(-14.8rem, calc(-1.787rem - 18.477vw), -8rem);
  width: 100%;
  height: calc(100% - 1.4rem);
  inset: 0;
  top: -1.2rem;
  background:  url(../images/front-page/con2-point-bg-sp.png) top center / cover no-repeat;
  z-index: -1;
  pointer-events: none;
}
#index #point .point__inner {
  position: relative;
  z-index: 1;
  padding-top: 10.4rem;
  padding-inline: 5.34vw;
}

#index #point .point__budge {
  position: absolute;
  text-align: center;
  top: 0;
  left: 50%;
  transform: translate(-50%, -60%);
}
#index #point .point__budge > img {
  width: clamp(19.1rem, 11.048vw + 14.526rem, 23rem);
}

#index #point .point__list {
  margin-inline: auto;
}
#index #point .point__item {
  display: grid;
  grid-template-columns: 1fr;
  column-gap: 3.91%;
  grid-template-rows: auto auto auto;
  grid-template-areas:
  "title"
  "img"
  "desc"
}
#index #point .point__imageWrap { grid-area: img; }
#index #point .point__titleWrap { grid-area: title; }
#index #point .point__descWrap  { grid-area: desc; }


#index #point .point__item:not(:first-child) {
  margin-top: clamp(6.2rem, 11.331vw + 1.509rem, 10.2rem);
}
#index #point .point__imageWrap {
  margin-top: 2.8rem;
}
#index #point .point__imageWrap img {
  display: block;
  width: 100%;
}
#index #point .point__pointNum img {
  display: block;
  width: clamp(6.4rem, 11.331vw + 1.709rem, 10.4rem);
}
#index #point .point__title {
  margin-top: clamp(1.4rem, 4.533vw - 0.476rem, 3rem);
  margin-top: 2.1rem;
  font-size: clamp(2.6rem, 2.833vw + 1.427rem, 3.6rem);
  font-weight: 600;
  line-height: calc(31 / 26);
  letter-spacing: 0.07em;
  color: #fff;
}
#index #point .point__item picture {
  display: inline-block;
  width: fit-content;
}
#index #point .point__title span {
  display: inline-block;
}
#index #point .point__title span:not(:first-child) {
  margin-top: 0.8rem;
}
#index #point .point__title span img {
  text-align: left;
  width: 100%;
  margin-right: 1rem;
}
#index #point .point__title .ttl-3rd-img{
  width: 86% !important;
  position: relative;
}
#index #point .point__title .ttl-3rd-img .add-txt{
  position: absolute;top: -1.4vw;right: -10vw;
}



#index #point .point__item--3rd .point__title span:nth-of-type(2) {
  width: max-content;
}
#index #point .point__desc-text {
  margin-top: 1.6rem;
  padding-inline: 0.3rem;
  font-size: clamp(1.6rem, 1.133vw + 1.131rem, 2rem);
  line-height: calc(30 / 16);
  letter-spacing: 0.1em;
  color: #fff;
}


#index #point .point__item--2nd .point__desc-text {
  margin-top: 2rem;
  padding-inline: 0;
}


#index #point .point__item--3rd .point__pointNum {
  margin-top: -3px;
  padding-left: 3px;
}
#index #point .point__item--3rd .point__desc-text {
  padding-inline: 0;
}

#index #point .point__btnWrap {
  width: 100%;
  margin-top: 5.4rem;
  margin-inline: auto;
}
#index #point .point__btnWrap a img {
  transition: all 0.2s ease;
}
#index #point .point__btnWrap a img:hover {
  filter: brightness(1.1);
  opacity: 1;
}
#index #point .point__item--3rd .point__desc-text {
  margin-top: 2.5rem;
}


/* con3-menu
-------------------------------------*/
#index #point.menu {
  background-color: #fff;
}
#index #menu .menu__inner {
  padding-block: 25.4vw 23.4vw;
}
#index #menu .menu__title {
  width: 45.9vw;
  margin-inline: auto;
  text-align: center;
}
#index #menu .menu__list {
  display: grid;
  grid-template-columns: 1fr;
  row-gap: 10.6vw;
  width: 100%;
  margin-top: 11.4vw;
  margin-inline: auto;
}
#index #menu .menu__item {
  position: relative;
}
#index #menu .menu__item-imageWrap {
  margin-left: 2.7vw;
}
#index #menu .menu__item--wide {
  grid-column: 1 / -1;
}
#index #menu .menu__item-text {
  margin-top: 4.8vw;
  margin-inline: auto;
  padding-inline: 2.4vw;
  font-size: 3.4vw;
  line-height: calc(30 / 14);
  letter-spacing: 0.05em;
}
#index #menu .menu__item:first-child {
  padding-inline: 2.9vw;
}
#index #menu .menu__item:nth-child(2) {
  padding-left: 2.9vw;
}
#index #menu .menu__item:nth-child(3) {
  padding-right: 2.9vw;
  padding-left: 0.5vw;
  margin-top: 2.9vw;
}


/* voiceAndProfile
-------------------------------------*/
.voiceAndProfile {
  position: relative;
  z-index: 2;
}


/* voice
-------------------------------------*/
.voice {
  background: var(--color-bg-gray) url(../images/front-page/con4-voice-bg.png) top center/contain no-repeat;
}
.voice__inner {
  padding-top: 34.7vw;
  padding-bottom: 286vw;
}
.voice__title-wrap {
  position: relative;
  text-align: center;
}
.voice__title-wrap::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  width: 70.57vw;
  aspect-ratio: 292.15/34.62;
  transform: translate(-50%, calc(-100% - 7.5vw));
  background: url(../images/front-page/con4-voice-title-deco.svg) center/contain no-repeat;
}
.voice__title-wrap img {
  width: 35.27vw;
}
.voice__voiceWrap {
  width: min(95%, 700px);
  margin-top: 7.25vw;
  margin-inline: auto;
  padding: 4.83vw 2.41vw;
  background: #fff;
}
.voice__panel {
  padding: 7.2vw 4.8vw 6vw;
  background-color: #EFF0F2;
}
.voice__header {
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 4.8vw;
}
.voice__item:not(:first-child) {
  margin-top: 4.2vw;
}
.voice__avatar {
  grid-column: 1;
  grid-row: 1;
  align-self: center;
  width: 16.9vw;
  height: 16.9vw;
}
.voice__meta {
  grid-column: 2;
  grid-row: 1;
  align-self: center;
  display: flex;
  flex-direction: column;
}
.voice__course-name {
  display: inline-block;
  width: fit-content;
  padding: 1.4vw 2.1vw 1.2vw;
  font-size: 3.3vw;
  font-weight: 700;
  line-height: calc(17/14);
  letter-spacing: 0;
  white-space: nowrap;
  color: #fff;
  background-color: var(--color-main);
}
.voice__detail {
  display: inline-block;
  margin-top: 2.2vw;
  font-size: 3.9vw;
  font-weight: 500;
  line-height: calc(19/16);
  color: var(--color-black);
}
.voice__voice-title {
  grid-column: 1/-1;
  grid-row: 2;
  margin-top: 6.6vw;
  padding-inline: 0.6vw;
  font-size: 4.8vw;
  line-height: calc(34/20);
  letter-spacing: 0.05em;
}
.voice__line {
  width: 100%;
  height: 1px;
  margin-top: 3.1vw;
  background-color: #D5D5D5;
}
.voice__text {
  margin-top: 2.4vw;
  padding-left: 1.7vw;
  font-size: 3.4vw;
  font-weight: 400;
  line-height: calc(30/14);
  letter-spacing: 0.05em;
}


/* con5-profile
-------------------------------------*/
.profile {
  position: absolute;
  bottom: -9.7vw;
  left: 50%;
  transform: translateX(-50%);
  width: min(95%, 700px);
  background-color: #fff;
}
.profile__wrapper {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  align-items: end;
  padding: 15.4vw 6.04vw 9.4vw;
}
.profile__image {
  position: relative;
  order: 2;
}
.profile__image > img {
  width: 100%;
}
.profile__title {
  order: 1;
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(2.4vw, -8.2vw);
  width: 72.5vw;
  z-index: 1;
}
.profile__body {
  order: 3;
  position: relative;
  margin-top: 8.4vw;
  z-index: 2;
}
.profile__position {
  width: 28.3vw;
  padding-left: 1.2vw;
  line-height: 1;
}
.profile__nameWrap {
  display: flex;
  align-items: center;
  margin-top: 3.9vw;
  padding-bottom: 5.6vw;
  border-bottom: 1px solid #BCBCBC;
  color: #000;
}
.profile__name {
  font-size: 6.8vw;
  font-weight: 600;
  line-height: calc(38/30);
  letter-spacing: 0.05em;
}
.profile__ruby {
  margin-left: 0.5vw;
  font-size: 3.4vw;
  font-weight: 400;
  line-height: calc(17/14);
  letter-spacing: 0.05em;
}
.profile__sns-list {
  flex: 1;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 4.2vw;
  margin-top: -2.7vw;
}
.profile__list {
  margin-top: 7.2vw;
}
.profile__item {
  position: relative;
  padding-left: 1.5em;
  font-size: 3.9vw;
  font-weight: 500;
  line-height: calc(26/16);
  letter-spacing: 0.05em;
}
.profile__item:not(:first-child) {
  margin-top: 2.9vw;
}
.profile__item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  display: block;
  width: 2.4vw;
  height: 2.4vw;
  background-color: #B4BFD8;
  border-radius: 50%;
}
.profile__sns-link img {
  width: 4.8vw;
}
.profile__achievements {
  margin-top: 7.5vw;
}
.profile__group {
  display: flex;
  flex-direction: column;
  gap: 3.4vw;
}
.profile__group:not(:first-child) {
  margin-top: 5.7vw;
}
.profile__group dt {
  width: 100%;
  padding: 2.9vw 3.9vw 2.4vw;
  font-size: 3.9vw;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.08em;
  text-align: center;
  color: var(--color-main);
  border: 1px solid var(--color-main);
}
.profile__group dd {
  width: 100%;
  padding-inline: 0.7vw;
  font-size: 3.8vw;
  font-weight: 500;
  line-height: calc(28/16);
  letter-spacing: 0.05em;
  text-align: justify;
  color: #000;
}

/* seo
-------------------------------------*/
.seo__inner {
  width: min(90%, 120rem);
  margin-inline: auto;
  padding: 4rem 2rem 0 2rem;
}
.seo__text {
  font-size: 1.2rem;
  line-height:2;
  letter-spacing: 0.08em;
  text-align: justify;
  color: #000;
}


}
