@charset "utf-8";
#floating-banner {
  position: fixed;
  right: min(2.9vw, 40px);
  bottom: 16px;
  z-index: 991;
  display: block;
  width: 329.7px;
}
#floating-banner .close-btn {
  position: absolute;
  top: -5px;
  left: -2px;
  width: 24.48px;
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
}
.sp-fixed-banner {
  display: none;
}
@media screen and (max-width: 1024px) {
  #floating-banner {
    width: 280px;
  }
}
@media screen and (max-width: 767px) {
  #floating-banner {
    position: absolute;
    right: 12px;
    bottom: 25px;
    width: 71.83vw;
    max-width: 269.38px;
  }
  .sp-fixed-banner {
    position: fixed;
    right: 0;
    bottom: 27px;
    left: 0;
    z-index: 666;
    display: block;
    pointer-events: none;
    transition: opacity 0.4s ease;
    opacity: 0;
  }
  .sp-fixed-banner.is-visible {
    pointer-events: auto;
    opacity: 1;
  }
  .sp-fixed-banner a {
    display: flex;
    align-content: center;
    flex-wrap: wrap;
    justify-content: center;
    width: 82.4vw;
    max-width: 309px;
    height: 68px;
    margin: auto;
    padding-top: 3px;
    border: solid 2px #fff;
    border-radius: 53px;
    box-shadow: 7px 7px rgb(0 0 0 / 16%);
    background-color: #f06634;
    text-align: center;
    color: #fff;
  }
  .sp-fixed-banner a span {
    display: block;
    font-size: var(--font-size12);
  }
  .sp-fixed-banner a p {
    position: relative;
    padding-top: 3px;
    font-size: var(--font-size18);
    font-weight: bold;
  }
  .sp-fixed-banner a p:before {
    display: inline-block;
    width: 21.79px;
    height: 22.28px;
    margin: 0 11px 5px 0;
    background-image: url(../img/common/icon_try_01.svg);
    background-repeat: no-repeat;
    background-size: contain;
    vertical-align: middle;
    content: "";
  }
}

/* ====================================================
mainvisual
==================================================== */
.mainvisual {
  width: 100%;
  background-color: #f5e829;
  background-image: url(../img/home/mv_bg.png);
  background-repeat: no-repeat;
  background-size: cover;
  vertical-align: middle;
}
.mainvisual-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-height: 100vh;
  margin: auto;
  padding: 5.5vw 3vw 0 7.5vw;

  aspect-ratio: 1 / 0.562;
  gap: 4.758vw;
}
.mainvisual-inner .sp-only {
  display: none;
}
.mainvisual-text {
  position: relative;
  width: 34.19vw;
  max-width: 467.05px;
  margin-top: -59px;
}
.mainvisual-text a {
  position: absolute;
  right: 0;
  bottom: -149px;
  left: 0;
  display: block;
  width: 80%;
  max-width: 374px;
  margin: auto;
  border: solid 3px #fff;
  border-radius: 48px;
  background-color: #f06634;
  font-size: var(--font-size22);
  font-weight: bold;
  line-height: 83px;
  text-align: center;
  color: #fff;
}
.mainvisual-text a span {
  position: relative;
}
.mainvisual-text a span::before {
  display: inline-block;
  width: 34.71px;
  height: 35.5px;
  margin: 0 14px 5px 0;
  background-image: url(../img/common/icon_try_01.svg);
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
  content: "";
}
.mainvisual-text a:hover {
  animation: pulsation 0.7s forwards;
  opacity: 1;
}
@keyframes pulsation {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(0.9);
  }
  100% {
    transform: scale(1);
  }
}
.mainvisual-text .icon_03 {
  position: absolute;
  top: max(-130px, -9.5vw);
  left: -60px;
  width: 8.2vw;
  max-width: 113px;
}
.mainvisual-slide {
  position: relative;
  flex: 1 1 0;
  border-radius: 35px;
  background: #fff;

  aspect-ratio: 1 / 0.759;
}
.mainvisual-slide .icon_01 {
  position: absolute;
  top: -19px;
  right: 0;
  z-index: 1;
  width: 24.65vw;
  max-width: 336.76px;
}
.mainvisual-slide .icon_02 {
  position: absolute;
  bottom: -48px;
  left: max(-57px, -4.17vw);
  z-index: 2;
  width: 16.2vw;
  max-width: 222.16px;
}
.mainvisual-slide .slide-item {
  position: absolute;
  overflow: hidden;
  border-radius: 35px;
  transition: opacity 1s ease;
  opacity: 0;

  inset: 12px;
}
.mainvisual-slide .slide-item.active {
  opacity: 1;
}
@media screen and (max-width: 1024px) {
  .mainvisual-inner {
    padding: 0 5%;

    gap: 40px;
  }
  .mainvisual-text {
    width: 43%;
  }
  .mainvisual-text a {
    bottom: -6em;
    padding: 12px 0;
    font-size: var(--font-size18);
    line-height: normal;
  }
  .mainvisual-text a span::before {
    width: 22.71px;
    height: 24.5px;
    margin: 0 9px 2px 0;
  }
}
@media screen and (max-width: 767px) {
  .mainvisual {
    background-image: url(../img/home/mv_bg_sp.png);
  }
  .mainvisual-inner {
    position: relative;
    display: block;
    align-items: flex-start;
    max-height: none;
    padding: 50px 4.26% 100px;
  }
  .mainvisual-inner:after {
    position: absolute;
    bottom: 11.7px;
    left: 0;
    z-index: 1;
    display: inline-block;
    width: 31.84vw;
    background-image: url(../img/home/mv_slide_icon.svg);
    background-repeat: no-repeat;
    background-size: contain;
    vertical-align: middle;
    content: "";

    aspect-ratio: 1 / 0.818;
  }
  .mainvisual-inner .sp-only {
    display: inline-block;
    margin-bottom: 22px;
    padding: 8px 15px;
    border: 34px;
    border-radius: 34px;
    background-color: #fff;
    font-size: var(--font-size14);
  }
  .mainvisual-text {
    width: 100%;
    margin: 0 auto 35px;
  }
  .mainvisual-text a {
    display: none;
  }
  .mainvisual-text .mv-copy {
    width: 90%;
    margin: auto;
  }
  .mainvisual-slide {
    z-index: 2;
    width: 100%;
    max-width: 510px;
    margin: auto;

    aspect-ratio: 1 / 1.012;
  }
  .mainvisual-slide .slide-item {
    inset: 8px;
  }
  .mainvisual-slide .icon_01 {
    top: 25vw;
    right: -14px;
    width: 18.13vw;
    max-width: 90px;
  }
  .mainvisual-slide .icon_02 {
    top: 0;
    bottom: auto;
    left: -10px;
    width: 26.4vw;
    max-width: 120px;
  }
  .mainvisual-text .icon_03 {
    display: none;
  }
}
/* ====================================================
about
==================================================== */
.about {
  overflow: hidden;
  padding: min(7.68vw, 105px) 0 min(5.12vw, 70px);
}
.about .about-inner {
  position: relative;
  max-width: 1450px;
  margin: auto;
  padding-bottom: 65px;
  text-align: center;
}
.about .about-inner figure {
  position: absolute;
  top: 0;
  right: -7.17vw;
  width: 37.96vw;
  max-width: 518.56px;
}
.about .about-inner figure:last-child {
  position: absolute;
  top: auto;
  right: auto;
  bottom: 0;
  left: -5.4vw;
  z-index: -1;
  width: 35.21vw;
  max-width: 480.99px;
}
.about .about-inner span {
  display: inline-block;
  margin-bottom: 39px;
  font-size: var(--font-size23);
  font-weight: bold;
  line-height: 1;
  color: #f06634;
}
.about .about-inner h2 {
  margin-bottom: 50px;
  font-size: var(--font-size45);
  font-weight: bold;
  line-height: 1.55;
}
.about .about-inner p {
  margin-bottom: 60px;
  font-size: var(--font-size19);
  line-height: 1.7;
}
@media screen and (max-width: 1024px) {
  .about .about-inner h2 {
    font-size: var(--font-size38);
  }
  .about .about-inner figure {
    width: 35vw;
  }
  .about .about-inner figure:last-child {
    width: 32vw;
  }
}
@media screen and (max-width: 767px) {
  .about {
    padding: 54px 0 75px;
  }
  .about .about-inner {
    padding: 0 5.3% 286px;
  }
  .about .about-inner span {
    margin-bottom: 16px;
    font-size: var(--font-size16);
  }
  .about .about-inner h2 {
    margin-bottom: 45px;
    font-size: var(--font-size28);
    line-height: 1.46;
  }
  .about .about-inner p {
    margin-bottom: 35px;
    font-size: var(--font-size15);
  }
  .about .about-inner figure,
  .about .about-inner figure:last-child {
    top: auto;
    bottom: 0;
  }
  .about .about-inner figure {
    bottom: -30px;
    width: 56vw;
    max-width: 310px;
  }
  .about .about-inner figure:last-child {
    bottom: 70px;
    width: 54vw;
    max-width: 300px;
  }
}
/* ====================================================
choose
==================================================== */
.choose {
  padding: 48px 0 min(10.61vw, 145px);
  background-color: #f7f8f8;
}
.choose .choose-inner {
  max-width: 1185px;
  margin: 0 auto;
  padding: 0 40px;
}
.choose .choose-inner .choose-header {
  margin-bottom: 75px;
  text-align: center;
}
.choose .choose-inner .choose-header figure {
  width: 78.01px;
  margin: 0 auto 18px;
}
.choose .choose-inner .choose-header h2 {
  margin-bottom: 35px;
  font-size: var(--font-size27);
  font-weight: bold;
  line-height: 1.5;
}
.choose .choose-inner .choose-header h2 span {
  display: block;
  font-size: var(--font-size41);
  color: #f06634;
}
.choose .choose-inner .choose-header p {
  font-size: var(--font-size20);
  line-height: 1.8;
}
.choose .choose-inner .flex {
  justify-content: space-between;

  gap: 20px;
}
.choose .choose-inner .flex .num-list {
  position: relative;
  flex: 1;
  padding: 67px 30px 32px;
  border-radius: 25px;
  box-shadow: 0 0 6px rgb(0 0 0 / 16%);
  background-color: #fff;
}
.choose .choose-inner .flex .num-list span {
  position: absolute;
  top: -40px;
  left: 22px;
  font-size: var(--font-size90);
  font-weight: bold;
  line-height: 1;
  letter-spacing: -2px;
  color: #f5e829;
}
.choose .choose-inner .flex .num-list h3 {
  margin-bottom: 30px;
  font-size: var(--font-size28);
  font-weight: bold;
  line-height: 1.5;
}
.choose .choose-inner .flex .num-list figure {
  width: 100%;
  margin-bottom: 35px;
}
.choose .choose-inner .flex .num-list p {
  font-size: var(--font-size16);
  line-height: 1.7;
}
@media screen and (max-width: 1024px) {
  .choose .choose-inner .flex {
    gap: 10px;
  }
  .choose .choose-inner .flex .num-list {
    padding: 50px 3% 28px;
  }
  .choose .choose-inner .flex .num-list span {
    top: -31px;
    left: 19px;
    font-size: var(--font-size75);
  }
  .choose .choose-inner .flex .num-list h3 {
    margin-bottom: 20px;
    font-size: var(--font-size27);
    letter-spacing: normal;
  }
  .choose .choose-inner .flex .num-list figure {
    margin-bottom: 25px;
  }
  .choose .choose-inner .flex .num-list p {
    line-height: 1.5;
  }
}
@media screen and (max-width: 767px) {
  .choose {
    padding: 60px 0 40px;
  }
  .choose .choose-inner {
    padding: 0 5.3%;
  }
  .choose .choose-inner .choose-header {
    margin-bottom: 42px;
  }
  .choose .choose-inner .choose-header figure {
    width: 42px;
    margin: 0 auto 16px;
  }
  .choose .choose-inner .choose-header h2 {
    margin-bottom: 34px;
    font-size: var(--font-size21);
    line-height: 1.45;
  }
  .choose .choose-inner .choose-header h2 span {
    padding-top: 3px;
    font-size: var(--font-size29);
  }
  .choose .choose-inner .choose-header p {
    font-size: var(--font-size16);
  }
  .choose .choose-inner .flex {
    flex-direction: column;

    gap: 20px;
  }
  .choose .choose-inner .flex .num-list {
    padding: 32px 7.46% 29px;
    border-radius: 20px;
  }
  .choose .choose-inner .flex .num-list .num-tlt {
    display: flex;
    align-items: center;
    margin-bottom: 19px;

    gap: 12px;
  }
  .choose .choose-inner .flex .num-list span {
    position: static;
    font-size: var(--font-size56);
  }
  .choose .choose-inner .flex .num-list h3 {
    margin-bottom: 0;
    font-size: var(--font-size21);
    letter-spacing: inherit;
  }
  .choose .choose-inner .flex .num-list figure {
    width: 87.9%;
    margin: 0 auto 19px;
  }
  .choose .choose-inner .flex .num-list p {
    font-size: var(--font-size15);
    line-height: 1.6;
  }
}
/* ====================================================
.cmn-try
==================================================== */
@media screen and (max-width: 767px) {
  .cover-color:after {
    content: none;
  }
}
/* ====================================================
three-course
==================================================== */
.three-course {
  margin-bottom: min(8.93vw, 122px);
  padding-top: min(6.8vw, 93px);
}
.three-course .three-header {
  margin-bottom: 70px;
  text-align: center;
}
.three-course .three-header figure {
  width: 94.05px;
  margin: 0 auto 28px;
}
.three-course .three-header h2 {
  margin-bottom: 15px;
  font-size: var(--font-size44);
  font-weight: bold;
  line-height: 1;
}
.three-course .three-header p {
  font-size: var(--font-size16);
}
.three-course article {
  margin-bottom: 60px;
  border: solid 1px #ccc;
  border-radius: 25px;
}
.three-course article .art-head {
  width: 100%;
  height: 82px;
  margin-bottom: 44px;
  padding: 0 4.5% 0 4.39%;
  border-radius: 25px 25px 0 0;
  background-color: #5bb971;
  line-height: 82px;
  color: #fff;
}
.three-course article .art-head .flex {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
.three-course article .art-head .flex p {
  font-size: var(--font-size25);
  font-weight: bold;
}
.three-course article .subject {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  align-items: center;
  -ms-flex-align: center;

  gap: 7px;
}
.three-course article .subject li {
  padding: 5px 13px;
  border-radius: 22px;
  background-color: #fff;
  font-size: var(--font-size15);
  line-height: 1;
  color: #038c33;
}
.three-course article .art-contents {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding: 0 4.49% 44px 3.41%;

  gap: 5%;
}
.three-course article .art-contents .course-contents {
  width: 40.97%;
  max-width: 386px;
}
.three-course article .art-contents .course-contents .course-logo {
  max-width: 159.23px;
  margin-bottom: 20px;
}
.three-course article .art-contents .course-contents h2 {
  margin-bottom: 32px;
  font-size: var(--font-size38);
  font-weight: bold;
  line-height: 1.4;
  letter-spacing: normal;
}
.three-course article .art-contents .course-contents p {
  margin-bottom: 28px;
  font-size: var(--font-size17);
  line-height: 1.9;
}
.three-course article .art-contents figure {
  flex: 1;
  max-width: 508.24px;
}
/* ディスカバリーパーク */
.three-course article.discovery .art-head {
  background-color: #fcc200;
}
.three-course article.discovery .flex ul li {
  color: #f06634;
}
.three-course article.discovery .art-contents .course-contents .course-logo {
  max-width: 267.3px;
}
/* ロボット・プログラミング */
.three-course article.robot .art-head {
  background-color: #ec4949;
}
.three-course article.robot .flex ul li {
  color: #ec4949;
}
.three-course article.robot .art-contents .course-contents .course-logo {
  max-width: 91.85px;
}
@media screen and (max-width: 767px) {
  .three-course {
    padding-top: 61px;
  }
  .three-course .three-header {
    margin-bottom: 42px;
  }
  .three-course .three-header figure {
    width: 42px;
    margin: 0 auto 16px;
  }
  .three-course .three-header h2 {
    margin-bottom: 34px;
    font-size: var(--font-size29);
    line-height: 1.45;
  }
  .three-course article {
    margin-bottom: 30px;
    border-radius: 20px;
  }
  .three-course article .art-head {
    height: 54px;
    margin-bottom: 13px;
    padding: 0 20px;
    border-radius: 20px 20px 0 0;
    line-height: 54px;
  }
  .three-course article .art-head .flex {
    display: block;
  }
  .three-course article .art-head .flex p {
    font-size: var(--font-size15);
  }
  .three-course article .art-head .subject {
    display: none;
  }
  .three-course article .art-contents {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
        flex-direction: column-reverse;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    padding: 0 20px 32px;
  }
  .three-course article .art-contents .course-contents {
    width: 100%;
    max-width: none;
  }
  .three-course article .art-contents figure {
    width: 100%;
    max-width: 500px;
    margin: 0 auto 24px;
  }
  .three-course article .art-contents .course-contents .course-logo {
    display: none;
  }
  .three-course article .subject {
    margin-bottom: 25px;

    gap: 6px;
  }
  .three-course article .subject li {
    padding: 8px 11px;
    background-color: #5bb971;
    font-size: var(--font-size14);
    color: #fff;
  }
  .three-course article.discovery .subject li {
    background-color: #fcc200;
  }
  .three-course article.robot .subject li {
    background-color: #ec4949;
  }
  .three-course article .art-contents .course-contents h2 {
    margin-bottom: 18px;
    font-size: var(--font-size24);
  }
  .three-course article .art-contents .course-contents p {
    margin-bottom: 18px;
    font-size: var(--font-size15);
    line-height: 1.5;
  }
  .three-course article .art-contents .course-contents .h-txtlink {
    font-size: var(--font-size16);
  }
}
/* ====================================================
online-contents
==================================================== */
.online-contents {
  padding: min(9.29vw, 127px) 0 min(11.49vw, 157px);
}
.online-contents h2 {
  margin-bottom: 45px;
  font-size: var(--font-size44);
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .online-contents {
    padding: 0;
  }
  .online-contents h2 {
    display: none;
  }
}
/* ====================================================
academia
==================================================== */
.academia {
  padding: min(7.17vw, 98px) 0 min(9.2vw, 127px);
  background-color: #f7f8f8;
}
.academia .inner {
  max-width: 1051px;
  margin: auto;
}
.academia .academia-header {
  position: relative;
  margin-bottom: 70px;
}
.academia .academia-header a {
  position: absolute;
  right: 16px;
  bottom: -8px;
}
.academia .academia-header h2 {
  margin-bottom: 30px;
  font-size: var(--font-size44);
  font-weight: bold;
  line-height: 1;
  text-align: center;
}
.academia .academia-header p {
  font-size: var(--font-size16);
  line-height: 1.8;
  text-align: center;
}
.academia .flex {
  gap: 3.81%;
}
.academia .flex article {
  width: calc(100% / 3);
  border-radius: 15px;
  background-color: #fff;
}
.academia .flex article figure {
  width: 100%;
  margin-bottom: 20px;
}
.academia .flex article figure img {
  border: solid 5px #fff;
  border-radius: 15px 15px 0 0;
}
.academia .flex article .inner {
  max-width: none;
  padding: 0 20px 36px;
}
.academia .flex article time {
  display: block;
  margin-bottom: 10px;
  font-size: var(--font-size13);
  font-weight: bold;
  color: #727272;
}
.academia .flex article h1 {
  margin-bottom: 9px;
  font-size: var(--font-size20);
  font-weight: bold;
}
.academia .flex article span {
  margin-right: 17px;
  font-size: var(--font-size14);
  letter-spacing: normal;
  color: #7f7f7f;
}
/* hover */
.academia .flex article:hover {
  animation: floatUp 0.8s forwards;
}
@keyframes floatUp {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-15px);
  }
  100% {
    transform: translateY(0);
  }
}

.academia-arrows {
  margin-top: 5px;
}
.academia-arrows .academia-arrow {
  position: relative;
  width: 50px;
  height: 50px;
  padding: 0;
  border: none;
  border-radius: 0;
  background-color: transparent;
  cursor: pointer;
}
.academia-arrows .academia-arrow::before {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 17px;
  height: 17px;
  border-top: 2px solid #272724;
  border-right: 2px solid #272724;
  content: "";
  transform: translate(-65%, -50%) rotate(45deg);
}
.academia-arrows .academia-arrow::after {
  position: absolute;
  top: 24px;
  left: 12px;
  width: 21px;
  height: 2px;
  background-color: #272724;
  content: "";
}
.academia-arrows .academia-arrow.prev::before {
  transform: translate(-35%, -50%) rotate(-135deg);
}
.academia-arrows .academia-arrow.prev::after {
  left: 17px;
}
@media screen and (max-width: 1024px) {
  .academia .academia-header {
    margin-bottom: 30px;
  }
  .academia .academia-header a {
    position: static;
    display: block;
    text-align: right;
  }
  .academia .flex {
    gap: 2%;
  }
}
@media screen and (max-width: 767px) {
  .academia {
    overflow: hidden;
    padding: 73px 0 40px;
  }
  .academia .inner {
    padding-right: 0;
  }
  .academia .academia-header {
    padding-right: 5.3%;
  }
  .academia .academia-header h2 {
    font-size: var(--font-size24);
  }
  .academia .academia-header p {
    margin-bottom: 22px;
    font-size: var(--font-size15);
    text-align: left;
  }
  .academia .flex {
    flex-wrap: nowrap;
    padding-right: 22px;
    transition: transform 0.3s ease;

    gap: 20px;
  }
  .academia .flex article {
    flex: 0 0 84vw;
    width: auto;
    max-width: 228px;
  }
  .academia .flex article figure {
    margin-bottom: 28px;
  }
  .academia .flex article figure img {
    border: none;
  }
  .academia .flex article .inner {
    padding: 0 18px 20px;
  }
  .academia .flex article time {
    margin-bottom: 17px;
    font-size: var(--font-size11);
  }
  .academia .flex article h1 {
    font-size: var(--font-size15);
  }
  .academia .flex article span {
    font-size: var(--font-size11);
  }
  .academia .flex article span:last-child {
    margin-right: 0;
  }
  .academia-arrows {
    padding-right: 5.3%;
  }
}
/* ====================================================
   course-voices
==================================================== */
.course-voices {
  padding: 60px 0 min(9.2vw, 127px);
  background-color: #fff;
}
.course-voices .inner {
  max-width: 1260px;
}
.course-voices .voices-header {
  margin-bottom: 35px;
  text-align: center;
}
.course-voices .voices-header figure {
  width: 61px;
  margin: 0 auto 6px;
}
.course-voices .voices-header h2 {
  font-size: var(--font-size36);
  font-weight: bold;
}
.course-voices .voices-header p {
  padding-top: 25px;
  font-size: var(--font-size16);
}
.course-voices .voices-list {
  display: flex;

  gap: 2.5%;
}
.course-voices .voices-list .voice-card {
  display: flex;
  flex: 1;
  flex-direction: column;
  padding: 34px 2.1% 34px;
  border-radius: 25px;
  background-color: #f7f8f8;
}
.course-voices .voices-list .voice-card .voice-image {
  width: 112px;
  margin: 0 auto 18px;
}
.course-voices .voices-list .voice-card .voice-text {
  margin-bottom: 16px;
  font-size: var(--font-size16);
  line-height: 1.75;
}
.course-voices .voices-list .voice-card .voice-person {
  margin-top: auto;
  font-size: var(--font-size16);
  font-weight: bold;
  text-align: center;
}
.course-voices .voices-arrows {
  margin-top: 15px;
}
.course-voices .voices-arrows .voice-arrow {
  position: relative;
  width: 50px;
  height: 50px;
  padding: 0;
  border: none;
  border-radius: 0;
  background-color: transparent;
  cursor: pointer;
}
.course-voices .voices-arrows .voice-arrow::before {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 17px;
  height: 17px;
  border-top: 2px solid #272724;
  border-right: 2px solid #272724;
  content: "";
  transform: translate(-65%, -50%) rotate(45deg);
}
.course-voices .voices-arrows .voice-arrow::after {
  position: absolute;
  top: 24px;
  left: 12px;
  width: 21px;
  height: 2px;
  background-color: #272724;
  content: "";
}
.course-voices .voices-arrows .voice-arrow.prev::before {
  transform: translate(-35%, -50%) rotate(-135deg);
}
.course-voices .voices-arrows .voice-arrow.prev::after {
  left: 17px;
}
@media screen and (max-width: 1024px) {
  .course-voices .voices-list {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;

    gap: 10px;
  }
  .course-voices .voices-list .voice-card {
    flex: auto;
    width: 45%;
    padding: 25px 4%;
  }
  .course-voices .voices-list .voice-card .voice-image {
    width: 80px;
    margin-bottom: 10px;
  }
  .course-voices .voices-list .voice-card .voice-text {
    font-size: var(--font-size15);
  }
}
@media screen and (max-width: 767px) {
  .course-voices {
    overflow: hidden;
    padding: 63px 0 100px;
  }
  .course-voices .inner {
    padding-right: 0;
  }
  .course-voices .voices-header {
    margin-bottom: 30px;
    padding-right: 5.3%;
  }
  .course-voices .voices-header figure {
    width: 40.32px;
  }
  .course-voices .voices-header h2 {
    font-size: var(--font-size25);
  }
  .course-voices .voices-header p {
    padding-top: 15px;
    font-size: var(--font-size15);
  }
  .course-voices .voices-list {
    flex-wrap: nowrap;
    padding-right: 22px;
    transition: transform 0.3s ease;

    gap: 15px;
  }
  .course-voices .voices-list .voice-card {
    flex: 0 0 84vw;
    width: auto;
    max-width: 244px;
    padding: 30px 6% 34px;
  }
  .course-voices .voices-list .voice-card .voice-image {
    width: 90px;
  }
  .course-voices .voices-list .voice-card .voice-text {
    margin-bottom: 20px;
    font-size: var(--font-size15);
    line-height: 1.7;
    letter-spacing: normal;
  }
  .course-voices .voices-list .voice-card .voice-person {
    font-size: var(--font-size15);
  }
}
/* ====================================================
insta-contents
==================================================== */
.insta-contents {
  padding: 85px 0 0;
}

/* ====================================================
news
==================================================== */
.news {
  margin-bottom: 144px;
  padding-top: min(9.88vw, 135px);
}
.news h2.scr {
  margin-bottom: 40px;
  font-size: var(--font-size44);
  font-weight: bold;
  text-align: center;
}
.news .post-box article {
  padding: 25px 1% 25px 3.2%;
  border-top: solid 1px #e2e2e2;
}
.news .post-box article:last-child {
  border-bottom: solid 1px #e2e2e2;
}
.news .post-box article .flex {
  -webkit-box-align: start;
  align-items: flex-start;
  -ms-flex-align: start;

  gap: 7.1%;
}
.news .post-box article .flex > figure {
  width: 220px;
}
.news .post-box article .flex > figure img {
  border-radius: 15px;
}
.news .post-box article .flex .txt {
  flex: 1;
  padding-top: 1em;
}
.news .post-box article .flex .txt time {
  display: block;
  margin-bottom: 11px;
  font-size: var(--font-size13);
  line-height: 1;
}
.news .post-box article .flex .txt h1 {
  margin-bottom: 12px;
  font-size: var(--font-size22);
  font-weight: bold;
}
.news .post-box article .flex .txt p {
  font-size: var(--font-size16);
}
.news .post-box article .flex .txt p:last-child {
  margin-bottom: 0;
}
.banner-box {
  margin-top: 119px;
}
.banner-box .banner-img {
  max-width: 700px;
  margin: auto;
}
/* hover */
.banner-box .banner-img a:hover {
  animation: floatUp 0.8s forwards;
}
@keyframes floatUp {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-15px);
  }
  100% {
    transform: translateY(0);
  }
}
.banner-box .banner-img a {
  display: inline-block;
}
.banner-box .banner-img img {
  display: block;
  width: auto;
  max-width: 100%;
  height: auto;
}
@media screen and (max-width: 767px) {
  .news {
    margin-bottom: 55px;
    padding-top: 5px;
  }
  .news h2.scr {
    margin-bottom: 55px;
    font-size: var(--font-size27);
  }
  .news .post-box article {
    margin-bottom: 30px;
    padding: 0 0 30px 0;
    border-top: none;
    border-bottom: solid 1px #e2e2e2;
  }
  .news .post-box article .flex {
    display: block;
  }
  .news .post-box article .flex figure {
    width: 100%;
  }
  .news .post-box article .flex figure img {
    height: 184px;

    object-fit: cover;
  }
  .news .post-box article .flex .txt time {
    margin-bottom: 18px;
  }
  .news .post-box article .flex .txt h1 {
    margin-bottom: 13px;
    font-size: var(--font-size20);
  }
  .news .post-box article .flex .txt p {
    font-size: var(--font-size15);
    line-height: 1.65;
  }
  .banner-box {
    margin-top: 20px;
  }
}
