@charset "UTF-8";
/* マップ型変数breakpointsを定義 */
/* メディアクエリ用のmixinを定義。デフォ値はmd */
/* ====================================================
// common - 共通
==================================================== */
html {
  font-size: 62.5%;
}

body {
  font-family: "Noto Serif JP", serif;
  font-size: 1.6rem;
  line-height: 1.6;
  color: #2f2f2f;
  height: 100%;
  margin: 0 auto;
  font-weight: 500;
}

a:hover {
  opacity: 0.8;
}

.is-pc {
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .is-pc {
    /*     この中をカスタムできる */
    display: none;
  }
}

.is-sp {
  display: none;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .is-sp {
    /*     この中をカスタムできる */
    display: block;
  }
}

.container {
  min-width: 120rem;
  overflow: hidden;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .container {
    /*     この中をカスタムできる */
    min-width: 320px;
  }
}

.inner {
  max-width: 100rem;
  margin: 0 auto;
  padding: 0 2rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .inner {
    /*     この中をカスタムできる */
    padding: 0 3vw;
  }
}

.title {
  background: rgb(165, 194, 122);
  background: linear-gradient(90deg, rgb(165, 194, 122) 0%, rgb(104, 119, 31) 100%);
}

.title__inner {
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .title__inner {
    /*     この中をカスタムできる */
    padding: 0;
    display: flex;
    justify-content: center;
    align-items: center;
  }
}

.title__inner img {
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .title__inner img {
    /*     この中をカスタムできる */
    width: 130%;
  }
}

.title__inner img.small {
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .title__inner img.small {
    /*     この中をカスタムできる */
    width: 110%;
  }
}

.section {
  padding: 6rem 0;
  background-color: #f5f6fb;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .section {
    /*     この中をカスタムできる */
    padding: 3rem 0;
  }
}

.triangle {
  width: 100%;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .triangle {
    /*     この中をカスタムできる */
    margin-bottom: 3rem;
  }
}

.marker {
  background: linear-gradient(transparent 0%, #ffe954 0%);
  display: inline;
  padding: 0.4rem 0.2rem 0.4rem;
}

.red {
  color: #f04f65;
}

.blue {
  color: #0a73b1;
}

.bold {
  font-weight: bold;
}

.btn {
  max-width: 80rem;
  margin: 0 auto;
}

.btn a {
  display: inline-block;
  width: 100%;
  height: 100%;
}

.limit {
  text-align: center;
  font-size: 2.6rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .limit {
    /*     この中をカスタムできる */
    font-size: 4.25vw;
    font-weight: bold;
    font-style: italic;
  }
}

.libre {
  font-family: "Libre Baskerville", serif;
  font-style: italic;
  font-weight: bold;
  letter-spacing: 0.1em;
}

/* ====================================================
// firstView - ファーストビュー
==================================================== */
.firstView {
  background-image: url(../img/FV.jpg);
  background-position: center top;
  background-repeat: no-repeat;
  max-width: 270rem;
  background-size: cover;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .firstView {
    /*     この中をカスタムできる */
    background: none;
  }
}

.firstView__inner {
  max-width: 95rem;
  margin: 0 auto;
}

/* ====================================================
// area - エリア
==================================================== */
.area1 {
  background-image: url(../img/bg1.jpg);
  background-size: cover;
  background-position: center;
  padding-bottom: 6rem;
  padding-top: 6rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .area1 {
    /*     この中をカスタムできる */
    padding-bottom: 7vw;
    padding-top: 6vw;
  }
}

.area1__inner {
  max-width: 86rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .area1__inner {
    /*     この中をカスタムできる */
    padding: 5vw 6vw 0;
  }
}

.present__title {
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .present__title {
    /*     この中をカスタムできる */
    margin-bottom: 6vw;
  }
}

.present__img {
  margin-bottom: 6rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .present__img {
    /*     この中をカスタムできる */
    margin-bottom: 10vw;
  }
}

.area2 {
  background-image: url(../img/bg2.jpg);
  background-size: cover;
  background-position: center;
}

.area2__inner,
.area3__inner {
  padding: 6rem 4rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .area2__inner,
  .area3__inner {
    /*     この中をカスタムできる */
    padding: 9vw 5vw;
  }
}

.area2__text,
.area3__items {
  font-size: 2.4rem;
  background-color: #fff;
  padding: 8rem 4rem;
  line-height: 1.8;
  box-shadow: 0 0 1rem rgba(3, 69, 6, 0.68);
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .area2__text,
  .area3__items {
    /*     この中をカスタムできる */
    padding: 9vw 6vw;
    font-size: 4.5vw;
    line-height: 1.6;
  }
}

.area2 .img {
  float: right;
  width: 30%;
  opacity: 0.9;
  padding: 4rem 2rem 0 1rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .area2 .img {
    /*     この中をカスタムできる */
    width: 35%;
    padding: 5vw 5vw 0vw 0vw;
  }
}

.video {
  margin: 0 auto;
  position: relative;
  overflow: hidden;
  padding-top: 56.25%;
  margin-top: 6rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .video {
    /*     この中をカスタムできる */
    margin-top: 3rem;
  }
}

.video iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -o-object-fit: cover;
     object-fit: cover;
}

.area3 {
  background-image: url(../img/bg7.jpg);
  background-size: cover;
  background-position: center;
}

.area3__inner {
  max-width: 78rem;
}

.area3__item {
  margin-bottom: 1.8rem;
  position: relative;
  padding-left: 6rem;
  border-bottom: 0.2rem dashed #717171;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .area3__item {
    /*     この中をカスタムできる */
    margin-bottom: 4vw;
    padding-bottom: 1vw;
    border-bottom: 0.1rem dashed #717171;
    padding-left: 7vw;
  }
}

.area3__item:last-child {
  margin-bottom: 0;
}

.area3__item::before {
  content: "";
  display: inline-block;
  position: absolute;
  background-size: contain;
  background-repeat: no-repeat;
  background-image: url(../img/ico1.svg);
  width: 3rem;
  height: 3rem;
  top: 50%;
  transform: translateY(-50%);
  left: 2rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .area3__item::before {
    /*     この中をカスタムできる */
    width: 5vw;
    height: 5vw;
    left: 1vw;
    transform: translateY(-60%);
  }
}

.area4 {
  height: 100%;
  position: relative;
  background: url("../img/bg4.jpeg") no-repeat 20% center;
  background-attachment: fixed;
  background-size: cover;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .area4 {
    /*     この中をカスタムできる */
    background-attachment: local;
  }
}

.area4__inner {
  max-width: 80rem;
  padding: 4rem 0;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .area4__inner {
    /*     この中をカスタムできる */
    padding: 5vw 0;
  }
}

.area5 {
  background-image: url(../img/bg1.jpg);
  background-size: cover;
  background-position: center;
  padding-bottom: 6rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .area5 {
    /*     この中をカスタムできる */
    padding-bottom: 7vw;
  }
}

.area5__inner {
  padding-top: 4rem;
  max-width: 100rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .area5__inner {
    /*     この中をカスタムできる */
    padding-top: 5vw;
    padding: 7vw 3vw 0;
  }
}

.voice,
.lesson {
  margin-bottom: 6rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .voice,
  .lesson {
    /*     この中をカスタムできる */
    margin-bottom: 8vw;
  }
}

.voice__card:not(:last-child),
.lesson__img:not(:last-child) {
  margin-bottom: 4rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .voice__card:not(:last-child),
  .lesson__img:not(:last-child) {
    /*     この中をカスタムできる */
    margin-bottom: 6vw;
  }
}

.voice__card {
  background-color: #efcb5a;
  padding: 0.8rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .voice__card {
    /*     この中をカスタムできる */
    padding: 2vw;
  }
}

.voice__card__inner {
  background-color: #fff;
  padding: 4rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .voice__card__inner {
    /*     この中をカスタムできる */
    padding: 4vw;
  }
}

.voice__card__number {
  width: 28%;
  margin: 0 auto;
  position: relative;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .voice__card__number {
    /*     この中をカスタムできる */
    width: 60%;
    margin-bottom: 6vw;
  }
}

.voice__card__number__text {
  position: absolute;
  font-size: 3.4rem;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -46%);
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .voice__card__number__text {
    /*     この中をカスタムできる */
    font-size: 6vw;
    transform: translate(-50%, -44%);
  }
}

.voice__card__top {
  display: flex;
  align-items: center;
  -moz-column-gap: 4%;
       column-gap: 4%;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .voice__card__top {
    /*     この中をカスタムできる */
    -moz-column-gap: 2%;
         column-gap: 2%;
    margin-bottom: 2vw;
  }
}

.voice__card__top__figure {
  width: 20%;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .voice__card__top__figure {
    /*     この中をカスタムできる */
    width: 26%;
  }
}

.voice__card__top__right {
  flex: 1 0 0;
}

.voice__card__title {
  font-size: 4rem;
  color: #558800;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .voice__card__title {
    /*     この中をカスタムできる */
    font-size: 5vw;
  }
}

.voice__card__name {
  font-size: 3rem;
  text-align: right;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .voice__card__name {
    /*     この中をカスタムできる */
    font-size: 4.5vw;
  }
}

.voice__card__text {
  font-size: 2.8rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .voice__card__text {
    /*     この中をカスタムできる */
    font-size: 4.5vw;
  }
}

.area6 {
  background-image: url(../img/bg2.jpg);
  background-size: cover;
  background-position: center;
  padding-bottom: 6rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .area6 {
    /*     この中をカスタムできる */
    padding-bottom: 6vw;
  }
}

.area6__inner {
  max-width: 80rem;
  padding-top: 4rem;
  padding-bottom: 6rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .area6__inner {
    /*     この中をカスタムできる */
    padding: 6vw 0 4vw;
  }
}

.lesson-top {
  margin-bottom: 2rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .lesson-top {
    /*     この中をカスタムできる */
    margin-bottom: 4vw;
  }
}

.lesson__img.-text {
  width: 80%;
  margin: 0 auto;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .lesson__img.-text {
    /*     この中をカスタムできる */
    width: 90%;
  }
}

.area7 {
  background-image: url(../img/bg8.jpg);
  background-size: cover;
  background-position: center;
  padding-bottom: 6rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .area7 {
    /*     この中をカスタムできる */
    padding-bottom: 0;
  }
}

.area7__inner {
  padding-top: 4rem;
  max-width: 80rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .area7__inner {
    /*     この中をカスタムできる */
    padding: 5vw 1vw;
  }
}

/* ====================================================
// footer - フッター
==================================================== */
.footer {
  background-color: #2f2f2f;
  padding: 1rem 0;
  text-align: center;
  font-size: 1.2rem;
  color: #fff;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .footer {
    /*     この中をカスタムできる */
    font-size: 3vw;
  }
}

.privacyPolicy {
  margin-bottom: 1rem;
  /* map-get(マップ型変数, キー)で値を取得 */
}
@media screen and (max-width: 768px) {
  .privacyPolicy {
    /*     この中をカスタムできる */
    margin-bottom: 1.6vw;
  }
}/*# sourceMappingURL=style.css.map */