@charset "UTF-8";
/* ========================================
   about.css / nyatten 2027
   スマホファースト版
   breakpoint:
   - default : mobile
   - 768px〜 : tablet
   - 1024px〜 : pc
   - 1280px〜 : large pc
   ======================================== */


/* ===============================
   ABOUT
   =============================== */

.about {
  padding: 6rem 1.6rem;
  background: #fffdf8;
}

.about__inner {
  width: 100%;
  max-width: 100rem;
  margin: 0 auto;
}

.about__heading {
  margin-bottom: 2.8rem;
  text-align: center;
}

.about__label {
  margin-bottom: 1rem;
  font-size: 1.2rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  color: #b88c5a;
}

.about__title {
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.4;
  color: #2f2a26;
}

/* 写真を入れる場合に使用 */
.about__photo {
  width: 100%;
  margin: 0 auto 2.4rem;
  border-radius: 2rem;
  overflow: hidden;
  box-shadow: 0 1rem 2.8rem rgba(0, 0, 0, 0.08);
}

.about__photo img {
  display: block;
  width: 100%;
  height: auto;
}

.about__content {
  max-width: 76rem;
  margin: 0 auto;
  padding: 2.8rem 2rem;
  background: #ffffff;
  border-radius: 2rem;
  box-shadow: 0 1rem 2.8rem rgba(0, 0, 0, 0.05);
}

.about__content p {
  margin-bottom: 2rem;
  font-size: 1.5rem;
  line-height: 1.95;
  color: #4a433d;
}

.about__content p:last-child {
  margin-bottom: 0;
}

.about__content strong {
  font-weight: 700;
  color: #2f2a26;
}

.about__message {
  margin-top: 2.4rem;
  padding-top: 2rem;
  border-top: 1px solid #e8ddd0;
}


/* ===============================
   FEATURES
   =============================== */

.features {
  padding: 6rem 1.6rem;
  background: #fdfaf5;
}

.features__inner {
  width: 100%;
  max-width: 100rem;
  margin: 0 auto;
}

.features__heading {
  margin-bottom: 2.8rem;
  text-align: center;
}

.features__title {
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.4;
  color: #2f2a26;
}

.features__grid {
  display: flex;
  flex-direction: column;
  gap: 1.6rem;
}

.features__card {
  padding: 2.4rem 2rem;
  background: #ffffff;
  border-radius: 1.8rem;
  box-shadow: 0 1rem 2.4rem rgba(0, 0, 0, 0.05);
}

.features__card-title {
  margin-bottom: 1rem;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
  color: #b88c5a;
}

.features__card-text {
  font-size: 1.4rem;
  line-height: 1.9;
  color: #4a433d;
  text-align: left;
}


/* ===============================
   EXPERIENCE
   =============================== */

.experience {
  padding: 6rem 1.6rem;
  background: #ffffff;
}

.experience__inner {
  width: 100%;
  max-width: 100rem;
  margin: 0 auto;
}

.experience__heading {
  margin-bottom: 3.2rem;
  text-align: center;
}

.experience__label {
  margin-bottom: 1rem;
  font-size: 1.2rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  color: #b88c5a;
}

.experience__title {
  margin-bottom: 1.6rem;
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.4;
  color: #2f2a26;
}

.experience__lead {
  font-size: 1.5rem;
  line-height: 1.9;
  color: #5b534c;
  text-align: left;
}

.experience__grid {
  display: flex;
  flex-direction: column;
  gap: 1.6rem;
}

.experience__card {
  padding: 2.4rem 2rem;
  background: #fffdf8;
  border: 1px solid #f0e5d8;
  border-radius: 1.8rem;
}

.experience__card-title {
  margin-bottom: 1rem;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
  color: #2f2a26;
}

.experience__card-text {
  font-size: 1.4rem;
  line-height: 1.9;
  color: #4a433d;
  text-align: left;
}


/* ===============================
   PROGRAM
   =============================== */

.program {
  padding: 6rem 1.6rem;
  background: #fdfaf5;
}

.program__inner {
  width: 100%;
  max-width: 100rem;
  margin: 0 auto;
}

.program__heading {
  margin-bottom: 3.2rem;
  text-align: center;
}

.program__label {
  margin-bottom: 1rem;
  font-size: 1.2rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  color: #b88c5a;
}

.program__title {
  margin-bottom: 1.6rem;
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.4;
  color: #2f2a26;
}

.program__lead {
  font-size: 1.5rem;
  line-height: 1.9;
  color: #5b534c;
  text-align: left;
}

.program__list {
  display: flex;
  flex-direction: column;
  gap: 1.4rem;
}

.program__item {
  padding: 2.2rem 2rem;
  background: #ffffff;
  border: 1px solid #efe4d7;
  border-radius: 1.8rem;
}

.program__item-title {
  margin-bottom: 0.8rem;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.5;
  color: #2f2a26;
}

.program__item-text {
  font-size: 1.4rem;
  line-height: 1.9;
  color: #4a433d;
}


/* ===============================
   VISION
   =============================== */

.vision {
  padding: 6rem 1.6rem;
  background: #fffdf8;
}

.vision__inner {
  width: 100%;
  max-width: 100rem;
  margin: 0 auto;
  text-align: center;
}

.vision__label {
  margin-bottom: 1rem;
  font-size: 1.2rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  color: #b88c5a;
}

.vision__title {
  margin-bottom: 2.4rem;
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.4;
  color: #2f2a26;
}

.vision__content {
  max-width: 82rem;
  margin: 0 auto;
  padding: 3rem 2rem;
  background: #ffffff;
  border: 1px solid #efe4d7;
  border-radius: 2rem;
}

.vision__text {
  margin-bottom: 1.8rem;
  font-size: 1.5rem;
  line-height: 2;
  color: #4a433d;
  text-align: left;
}

.vision__text:last-of-type {
  margin-bottom: 2.4rem;
}

.vision__message {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.8;
  color: #2f2a26;
}


/* ===============================
   768px〜
   =============================== */

@media (min-width: 768px) {

  .about,
  .features,
  .experience,
  .program,
  .vision {
    padding-left: 2.4rem;
    padding-right: 2.4rem;
  }

  .about {
    padding-top: 8rem;
    padding-bottom: 8rem;
  }

  .about__heading {
    margin-bottom: 3.2rem;
  }

  .about__label {
    font-size: 1.3rem;
  }

  .about__title {
    font-size: 4rem;
  }

  .about__photo {
    margin-bottom: 3.2rem;
    border-radius: 2.4rem;
  }

  .about__content {
    padding: 3.6rem 2.8rem;
    border-radius: 2.4rem;
  }

  .about__content p {
    margin-bottom: 2.4rem;
    font-size: 1.7rem;
    line-height: 2;
  }

  .about__message {
    margin-top: 3rem;
    padding-top: 2.4rem;
  }

  .features {
    padding-top: 8rem;
    padding-bottom: 8rem;
  }

  .features__title {
    font-size: 4rem;
  }

  .features__grid {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 2rem;
  }

  .features__card {
    width: calc(50% - 1rem);
    padding: 2.8rem 2.4rem;
    border-radius: 2rem;
  }

  .features__card-title {
    font-size: 2rem;
  }

  .features__card-text {
    font-size: 1.5rem;
  }

  .experience {
    padding-top: 8rem;
    padding-bottom: 8rem;
  }

  .experience__heading {
    max-width: 76rem;
    margin: 0 auto 4rem;
  }

  .experience__label {
    font-size: 1.3rem;
  }

  .experience__title {
    font-size: 4rem;
  }

  .experience__lead {
    font-size: 1.7rem;
    text-align: center;
  }

  .experience__grid {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 2rem;
  }

  .experience__card {
    width: calc(50% - 1rem);
    padding: 2.8rem 2.4rem;
    border-radius: 2rem;
  }

  .experience__card-title {
    font-size: 2rem;
  }

  .experience__card-text {
    font-size: 1.5rem;
  }

  .program {
    padding-top: 8rem;
    padding-bottom: 8rem;
  }

  .program__heading {
    max-width: 76rem;
    margin: 0 auto 4rem;
  }

  .program__label {
    font-size: 1.3rem;
  }

  .program__title {
    font-size: 4rem;
  }

  .program__lead {
    font-size: 1.7rem;
    text-align: center;
  }

  .program__list {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 2rem;
  }

  .program__item {
    width: calc(50% - 1rem);
    padding: 2.6rem 2.4rem;
    border-radius: 2rem;
  }

  .program__item-title {
    font-size: 2rem;
  }

  .program__item-text {
    font-size: 1.5rem;
  }

  .vision {
    padding-top: 8rem;
    padding-bottom: 8rem;
  }

  .vision__label {
    font-size: 1.3rem;
  }

  .vision__title {
    margin-bottom: 3.2rem;
    font-size: 4rem;
  }

  .vision__content {
    padding: 4.4rem 4rem;
    border-radius: 2.4rem;
  }

  .vision__text {
    margin-bottom: 2rem;
    font-size: 1.7rem;
    text-align: center;
  }

  .vision__text:last-of-type {
    margin-bottom: 3rem;
  }

  .vision__message {
    font-size: 2.8rem;
    line-height: 1.7;
  }
}


/* ===============================
   1024px〜
   =============================== */

@media (min-width: 1024px) {

  .about,
  .features,
  .experience,
  .program,
  .vision {
    padding-left: 3.2rem;
    padding-right: 3.2rem;
  }

  .about {
    padding-top: 10rem;
    padding-bottom: 10rem;
  }

  .about__photo {
    max-width: 110rem;
  }

  .about__content {
    max-width: 80rem;
    padding: 4rem 3.6rem;
  }

  .features {
    padding-top: 10rem;
    padding-bottom: 10rem;
  }

  .features__grid {
    flex-wrap: nowrap;
  }

  .features__card {
    width: 33.333%;
    padding: 3rem 2.6rem;
  }

  .experience {
    padding-top: 10rem;
    padding-bottom: 10rem;
  }

  .experience__heading {
    margin-bottom: 4.8rem;
  }

  .experience__grid {
    gap: 2.4rem;
  }

  .experience__card {
    width: calc(33.333% - 1.6rem);
    padding: 3rem 2.6rem;
  }

  .program {
    padding-top: 10rem;
    padding-bottom: 10rem;
  }

  .program__heading {
    margin-bottom: 4.8rem;
  }

  .program__item {
    width: calc(33.333% - 1.4rem);
    padding: 2.8rem 2.6rem;
  }

  .vision {
    padding-top: 10rem;
    padding-bottom: 10rem;
  }

  .vision__content {
    padding: 5rem 5.2rem;
  }

  .vision__message {
    font-size: 3.2rem;
  }
}


/* ===============================
   1280px〜
   =============================== */

@media (min-width: 1280px) {

  .about,
  .features,
  .experience,
  .program,
  .vision {
    padding-left: 4rem;
    padding-right: 4rem;
  }

  .about {
    padding-top: 12rem;
    padding-bottom: 12rem;
  }

  .features,
  .experience,
  .program,
  .vision {
    padding-top: 12rem;
    padding-bottom: 12rem;
  }

  .about__photo {
    max-width: 120rem;
  }

  .features__inner,
  .experience__inner,
  .program__inner,
  .vision__inner {
    max-width: 110rem;
  }

  .features__card {
    padding: 3.2rem 2.8rem;
  }

  .experience__card {
    padding: 3.2rem 2.8rem;
  }

  .program__item {
    padding: 3rem 2.8rem;
  }

  .vision__content {
    max-width: 88rem;
    padding: 5.6rem 6rem;
  }
}