
.frame_line{
  border: 1px solid #D9D9D9;
  padding-top: 4rem;
  padding-bottom: 4rem;
}

.l-container {
  --pc-width: var(--g-width--max-content);
  display: flex;
  flex-direction: column;
  /*gap: var(--g-space--between-section);*/
  width: 100%;
  border: 1px solid #D9D9D9;
  padding-top: 4rem;
  padding-bottom: 4rem;
  @media (max-width: 1023px) {
    padding-left: 1rem;
    padding-right: 1rem;
  }
  @media (min-width: 1024px) {
    width: var(--pc-width);
    margin: auto;
    gap: var(--g-space--between-section--v-2);
  }
}

.article {
  display: grid;
  gap: 2rem;
  @media (min-width: 1024px) {
    grid-template-columns: 400px 1fr;
  }
}
.article__thumb {
  img {
    width: 100%;
  }
}
.article__content {
  display: flex;
  align-items: center;
  height: 100%;
}
.article__content__label {
  width: fit-content;
  padding: 0.25em 0.5em;
  background-color: #ebf1fb;
  color: var(--g-color--blue);
  font-size: var(--g-fz--p2);
  font-weight: 500;
}

.text {
  text-align: center;
}

.profile-section {
  --gap: 2rem;
  display: flex;
  flex-direction: column;
  gap: var(--gap);
  margin-top: 5rem;
  @media (min-width: 1024px) {
    --gap: 2rem;
    --padding: 4rem;
    padding: 0 var(--padding) var(--padding);
    margin-top: auto;
  }
  h4{
    position: relative;
    display: inline-block;
    text-indent: 4.5rem;
    /*padding: ;*/
    &::before,
    &::after{
      content: '';
      position: absolute;
      top: 50%;
      display: inline-block;
      width: 4rem;
      height: 1px;
      background-color: black;
    }
    &::before{
      left:0;
    }
    &::after{
      right: 0;
      width: calc(100% - 17.5rem);
    }
  }
  .profile__content{
    display: flex;
    flex-direction: column;
    gap: var(--gap);
    border-bottom: 1px solid var(--g-color--blue);
    padding-bottom: 3rem;
    a{
      display: contents;
      text-decoration: underline;
    }
  }
}



.c-introduction {
  --gap: 3rem;
  display: flex;
  flex-direction: column;
  gap: var(--gap);
  margin-top: 5rem;
  @media (min-width: 1024px) {
    --gap: 3rem;
    --padding: 4rem;
    padding: 0 var(--padding) var(--padding);
    margin-top: auto;
  }
  h2{
    position: relative;
    &::before,
    &::after {
      position: absolute;
      left: 0;
      bottom: 0;
      height: 4px;
      content: " ";
    }
    padding-bottom: 1rem;
    font-size: var(--g-fz--h2);
    color: var(--g-color--blue);
    &::before {
      width: 100%;
      background-color: #c8daf3;
    }
    &::after {
      width: 9.6rem;
      background: var(--g-color--blue);
    }
  }
  h3{
    position: relative;
    padding-top: 1rem;
    padding-bottom: 1rem;
    font-size: var(--g-fz--h3);
    color: var(--g-color--blue);
  }
  h4{
    position: relative;
    padding-top: 1rem;
    padding-bottom: 1rem;
    font-size: var(--g-fz--h4);
    color: var(--g-color--blue);
  }
  .content{
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
  }
}
.button-cont {
  --width: var(--g-width--content-xs);
  margin: 1rem auto;
  width: var(--width);
  display: grid;
  @media (min-width: 1024px) {
    --width: auto;
    margin: 1rem auto;
  }
}
.g-button--blue{
  --bg-color: var(--g-color--blue);
  --fg-color: var(--g-color--white);
  --border-color: var(--g-color--white);
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
  min-height: 5.1rem;
  border: 1px solid var(--border-color);
  background-color: var(--bg-color);
  text-decoration: none;
  color: var(--fg-color);
  font-size: var(--g-fz--p2);
  @media (min-width: 1024px) {
    min-height: 6.1rem;
    font-size: var(--g-fz--p1);
    min-width:36rem;
    padding-right:5rem;
    padding-left:5rem;
  }
  &::after {
    position: absolute;
    right: 1.5rem;
    aspect-ratio: 1;
    height: 1.8rem;
    background: url("../../components/button-2__icon.png") no-repeat center / contain;
    content: "";
  }
  @media (min-width: 1024px) {
    &::after {
      height: 2.9rem;
    }
  }
}

.g-button--white{
  --bg-color: var(--g-color--white);
  --fg-color: var(--g-color--blue);
  --border-color: var(--g-color--blue);
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
  min-height: 5.1rem;
  border: 1px solid var(--border-color);
  background-color: var(--bg-color);
  text-decoration: none;
  color: var(--fg-color);
  font-size: var(--g-fz--p2);
  @media (min-width: 1024px) {
    min-height: 6.1rem;
    font-size: var(--g-fz--p1);
    padding-right:5rem;
    padding-left:5rem;
  }
  &::after {
    position: absolute;
    right: 1.5rem;
    aspect-ratio: 1;
    height: 1.8rem;
    background: url("../../components/button-2__icon--transparent.png") no-repeat center / contain;
    content: "";
  }
  @media (min-width: 1024px) {
    &::after {
      height: 2.9rem;
    }
  }
}

.img_l{
  width:auto;
  max-width: 98%;
  margin: 1rem auto;
  @media (min-width: 1024px){
    max-width: 900px;
  }
}
.img_s{
  width:auto;
  max-width: 98%;
  margin: 1rem auto;
  @media (min-width: 1024px){
    max-width: 360px;
  }
}



.course-section {
  --gap: 3rem;
  --padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--gap);
  padding-top: 2rem;
  background-color: #F6FAFF;
  @media (min-width: 1024px) {
    --gap: 3rem;
    --padding: 4rem;
  }
}
.course-section__title {
  position: relative;
  display: inline-block;
  &::after{
    content: '';
    position: absolute;
    top: 50%;
    display: inline-block;
    width: calc(100% - 45rem);
    height: 1px;
    background-color: black;
    right: 0;
  }
}

.course-section__content {
  display: flex;
  flex-direction: column;
  gap: var(--gap);
  padding: 0 var(--padding) var(--padding);
}


.course_article {
  display: grid;
  gap: 2rem;
  @media (min-width: 1024px) {
    grid-template-columns: 43rem 1fr;
    gap: 4rem;
  }
}
.course_article__thumb {
  position: relative;
  img {
  }
}
.course_article__thumb-labels {
  position: absolute;
  left: 0;
  top: 0;
  display: flex;
}
.course_article__thumb-label {
  --bg-color: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 2em;
  min-width: 7ic;
  background-color: var(--bg-color);
  font-size: var(--g-fz--p2);
  color: var(--g-color--white);
}
.course_article__thumb-label--student {
  --bg-color: var(--g-color--blue--student);
}
.course_article__thumb-label--pro {
  --bg-color: var(--g-color--blue--pro);
}
.course_article__content {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  @media (min-width: 1024px){
    padding-top:10%;
  }
}
.course_article__title-set {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.course_article__title {
  font-size: var(--g-fz--h3);
  font-weight: bold;
}
.course_article__label {
  width: fit-content;
  padding: 0.25em 0.5em;
  background-color: #ebf1fb;
  color: var(--g-color--blue);
  font-size: var(--g-fz--p3);
}
.course_article__text {
  font-size: var(--g-fz--p2);
}
.course_article-button-container {
  --width: var(--g-width--content-xs);
  margin: auto;
  width: var(--width);
  display: grid;
  @media (min-width: 1024px) {
    --width: 24rem;
    margin: 0.5rem 0;
  }
}
.pc-only{
  display: none;
  @media (min-width: 1024px){
      display: block;
  }
}
.sp-only{
  display: block;
  @media (min-width: 1024px){
      display: none;
  }
}


