@charset "UTF-8";
/* 文字コードの指定 */
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;900&display=swap");

*,
*:before,
*:after {
  box-sizing: border-box;
}

html {
  font-size: 62.5%;
  scroll-padding: 10rem;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.7;
  color: #767676;
  background-color: #ffffff;
  overflow-x: hidden;
}

small {
  font-size: 1.2rem;
}

a {
  color: #767676;
  text-decoration: none;
}

img {
  max-width: 100%;
  vertical-align: bottom;
}

.container {
  width: 100%;
  max-width: 76.8rem;
}

@media (min-width: 769px) {
  .container {
    width: 100%;
    max-width: 108rem;
    margin: 0 auto;
    padding: 0 2rem;
  }
}

.section-heading {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  width: 100vw;
  height: 4rem;
  background-color: #a3d6cc;
  margin: 0;
  padding: 0 2rem 0;
}

@media (min-width: 769px) {
  .section-heading {
    justify-content: flex-start;
    max-width: 108rem;
    height: 5rem;
    margin: 0 auto;
  }
}

h2 {
  display: inline-block;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 2.3rem;
  line-height: 1.7;
  color: #ffffff;
  text-align: start;
  text-transform: capitalize;
  margin: 0;
}

@media (min-width: 769px) {
  h2 {
    font-size: 3rem;
  }
}

.view-all {
  display: inline-block;
  font-size: 1.2rem;
  line-height: 1.5;
  text-transform: uppercase;
  color: #ffffff;
}

@media (min-width: 769px) {
  .view-all {
    font-size: 1.6rem;
    margin-left: 2rem;
  }
}

.view-arrow {
  display: inline-block;
  font-size: 1.2rem;
  line-height: 1.7;
  font-weight: solid;
  color: #ffffff;
}

@media (min-width: 769px) {
  .view-arrow {
    font-size: 1.6rem;
    font-weight: solid;
  }
}

@media (min-width: 769px) {
  .view-all {
    position: relative;
  }

  .view-all::after {
    position: absolute;
    left: 0;
    content: "";
    width: 100%;
    height: 0.1rem;
    background: #ffffff;
    bottom: -0.01rem;
    visibility: hidden;
  }

  .view-all:hover::after {
    visibility: visible;
  }
}

.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 5rem;
  box-sizing: border-box;
  z-index: 1000;
  background-color: rgba(163, 214, 204, 0.8);
}

@media (min-width: 769px) {
  .header {
    height: 6rem;
  }
}

.header-container {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  max-width: 76.8rem;
  height: 5rem;
  padding: 0 2rem;
  margin: 0 auto;
}

@media (min-width: 769px) {
  .header-container {
    max-width: 108rem;
    height: 6rem;
    padding: 0 2rem;
  }
}

.nav-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  margin: 0;
  padding: 0;
  font-size: 2rem;
  color: #ffffff;
  cursor: pointer;
}

@media (min-width: 769px) {
  .nav-button {
    display: none;
  }
}

.sp-nav {
  position: absolute;
  top: 5rem;
  left: 0;
  display: none;
  width: 100%;
  height: 100vh;
  background-color: rgba(255, 255, 255, 0.8);
  text-align: center;
  padding: 0 2rem;
  box-sizing: border-box;
  z-index: 900;
}

.sp-nav-list {
  display: list-item;
  text-align: match-parent;
  list-style: none;
  padding: 0;
  margin: 9.3rem 0 8.3rem 0;
}

.sp-nav-list a {
  font-family: "Noto Sans JP", sans-serif;
  color: #25b7c0;
  font-size: 2rem;
  line-height: 1.7;
  font-weight: 400;
  text-transform: capitalize;
}

.sp-nav-list li {
  margin-bottom: 4rem;
  padding: 0;
  list-style: none;
  z-index: 1000;
}

.sns {
  display: flex;
  padding: 0;
  margin: 1.5rem auto auto;
  align-items: center;
  justify-content: center;
  list-style: none;
}

.sns li {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.2rem;
  height: 3.2rem;
  margin: 0 1.4rem 0 0;
  font-size: 2rem;
  background-color: #c8c2c8;
  border-radius: 50%;
}

.sns li:last-child {
  margin-right: 0rem;
}

@media (min-width: 769px) {
  .sns li {
    width: 3.6rem;
    height: 3.6rem;
    margin: 0 2rem 0 0;
    font-size: 2.2rem;
  }
}

.sns a {
  color: #ffffff;
}

@media (min-width: 769px) {
  .sns li:hover {
    background-color: rgba(200, 194, 200, 0.8);
  }
}

.pc-nav {
  display: none;
}

@media (min-width: 769px) {
  .pc-nav {
    display: block;
    height: 6rem;
  }
}

.pc-nav .pc-nav-list {
  display: flex;
  align-items: center;
  justify-content: end;
  height: 100%;
  padding: 0;
  margin: 0;
  list-style: none;
}

.pc-nav .pc-nav-list a {
  font-family: "Noto Sans JP", sans-serif;
  color: #ffffff;
  font-size: 2rem;
  line-height: 1.7;
  font-weight: 400;
  text-transform: capitalize;
}

.pc-nav .pc-nav-list li {
  margin: 0 0 0 4rem;
  padding: 0;
  list-style: none;
}

.pc-nav-list a {
  position: relative;
}

.pc-nav-list a::after {
  position: absolute;
  left: 0;
  content: "";
  width: 100%;
  height: 0.1rem;
  background: #ffffff;
  bottom: -0.1rem;
  visibility: hidden;
}

.pc-nav-list a:hover::after {
  visibility: visible;
}

.slick-dots {
  bottom: 0.6rem;
}

.slick-dots li button:before {
  opacity: 80%;
  color: #ffffff;
}

.slick-dots li.slick-active button:before {
  opacity: 1;
  color: #25b7c0;
}

@media screen and (max-width: 768px) {
  .message-container {
    display: flex;
    flex-direction: column;
    padding: 0 2rem 0;
  }

  .message-contents {
    display: contents;
  }

  .message-img {
    order: 2;
  }

  .logo-message {
    order: 1;
    margin: 2.5rem auto 5rem;
  }

  .message-text {
    order: 3;
    text-align: center;
    margin: 2.6rem auto;
  }

  .message-text p {
    margin: 1.8rem auto;
  }
}

@media (min-width: 769px) {
  .message-container {
    max-width: 108rem;
    display: flex;
    flex-direction: row;
    align-content: center;
    justify-content: space-between;
    margin: 10rem auto;
    padding: 0 2rem;
  }

  .message-img {
    max-width: 53rem;
    width: 49%;
  }

  .message-contents {
    display: flex;
    width: 49%;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 0 2rem;
  }

  .message-text {
    text-align: center;
  }
}

.gallery-body {
  width: 100%;
  margin-bottom: 9.5rem;
}

@media (min-width: 769px) {
  .gallery-body {
    max-width: 108rem;
    margin: 6rem auto 13.4rem;
  }
}

img {
  max-width: 100%;
  height: auto;
}

.slideshow {
  padding: 0;
  margin: 0 calc(50% - 50vw);
  width: 100vw;
}

@media (min-width: 769px) {
  .slideshow {
    width: 49%;
    max-width: 53rem;
    margin: 0;
    padding: 0;
  }
}

.thumbnail {
  display: flex;
  padding: 0 2rem 0;
  list-style: none;
  margin: 2rem 0 1.6rem;
}

@media (min-width: 769px) {
  .thumbnail {
    padding: 0;
  }
}

.thumbnail li {
  width: 25%;
  cursor: pointer;
  margin: 0 1.6rem 0 0;
}

.thumbnail li:last-child {
  margin-right: 0rem;
}

@media (min-width: 769px) {
  .thumbnail li {
    margin: 0 2rem 0 0;
  }
}

@media (max-width: 768px) {
  .sp-gallery {
    display: block;
    font-size: 1.5rem;
    font-weight: 400;
    margin: 7rem auto 0.5rem 2rem;
  }

  .pc-gallery {
    display: none;
  }
}

@media (min-width: 769px) {
  .sp-gallery {
    display: none;
  }

  .pc-gallery {
    display: block;
    width: 48%;
    text-align: center;
  }

  .gallery-slide_1 {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 5.4rem;
  }

  .gallery-slide_2 {
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
    align-items: center;
  }

  .thumbnail li:hover {
    opacity: 0.5;
  }
}

.lesson .section-heading {
  display: flex;
  align-items: baseline;
  justify-content: flex-start;
  width: 100vw;
  height: 4rem;
  background-color: #a3d6cc;
  margin: 0;
  padding: 0 2rem 0;
}

@media (min-width: 769px) {
  .lesson .section-heading {
    justify-content: flex-start;
    max-width: 108rem;
    height: 5rem;
    margin: 0 auto;
  }
}

.gallery-title {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 3rem;
  color: #767676;
  font-weight: 400;
  line-height: 1.7;
  text-align: center;
  margin: 5rem auto;
  text-transform: capitalize;
}

@media (min-width: 769px) {
  .gallery-title {
    font-size: 6rem;
    margin: 7rem auto;
  }
}

.lesson-subtitle {
  font-size: 1.4rem;
  color: white;
  margin-left: 1.6rem;
}

@media (min-width: 769px) {
  .lesson-subtitle {
    margin-left: 2.6rem;
  }
}

.works-body {
  margin: 3rem auto 7rem;
}

.works-item {
  text-align: center;
}

.works-image {
  display: block;
  max-width: 56%;
  height: auto;
  margin: 7rem auto 1rem;
}

.works-text {
  display: inline-block;
  font-size: 1.5rem;
}

.external-link {
  display: inline-block;
  margin-left: 0.8rem;
}

.works-item p {
  margin: 0;
  font-size: 1.4rem;
}

@media (min-width: 769px) {
  .works-body {
    display: flex;
    justify-content: space-between;
    max-width: 108rem;
    margin: 6rem auto 9.8rem;
  }

  .works-item {
    width: 32%;
  }

  .works-image {
    max-width: 100%;
    margin: 0;
  }

  .works-image:hover {
    opacity: 0.5;
  }

  .works-text {
    font-size: 1.6rem;
    line-height: 1.7;
    margin-top: 1.2rem;
  }

  .works-text:hover {
    opacity: 0.5;
  }

  .works-item p {
    margin: 0;
    font-size: 1.4rem;
  }

  /* .works-item_2 { */
  /* pointer-events: none; */
  /* } */

  /* .works-item_3 { */
  /* pointer-events: none; */
  /* } */
}

@media screen and (max-width: 768px) {
  .about-body {
    display: flex;
    flex-direction: column;
    padding: 0 2rem 0;
    margin: 10rem auto 11rem;
  }

  .about-contents {
    display: contents;
  }
}

@media screen and (max-width: 768px) and (min-width: 769px) {
  .about-contents {
    max-width: 53rem;
    width: 49%;
  }
}

@media screen and (max-width: 768px) {
  .about-img {
    order: 1;
  }
}

@media screen and (max-width: 768px) {
  .about-youtube {
    order: 3;
  }
}

@media screen and (max-width: 768px) {
  .about-text {
    order: 2;
    font-size: 1.4rem;
    line-height: 1.5;
    margin: 7.6rem 0;
  }

  .about-memo {
    font-size: 1.2rem;
  }
}

@media screen and (max-width: 768px) {
  .about-text-inner {
    width: 84%;
    margin: 0 auto;
  }
}

@media screen and (max-width: 768px) {
  .about-text-emb {
    margin: 4.5rem auto;
  }
}

@media screen and (max-width: 768px) {
  .about-text span {
    margin-left: 2rem;
  }
}

@media (min-width: 769px) {
  .about-body {
    max-width: 108rem;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    margin: 6rem auto;
  }

  .about-text {
    width: 48%;
    margin: 0 autp;
    align-items: center;
  }

  .about-text-inner {
    width: 62%;
    margin: 0 auto;
  }

  .about-text span {
    margin-left: 2.4rem;
  }

  .about-text-emb {
    margin: 6rem auto;
  }

  .about-memo {
    font-size: 1.4rem;
  }

  .about-img {
    max-width: 53rem;
    margin-bottom: 15rem;
  }

  .about-youtube {
    max-width: 53rem;
  }
}

.footer-information {
  display: flex;
  flex-direction: column;
  text-align: center;
  margin-bottom: 11rem;
}

@media (min-width: 769px) {
  .footer-information {
    margin-bottom: 10rem;
  }
}

.button {
  width: 12rem;
  height: 4rem;
  text-align: center;
  background-color: #a3d6cc;
  margin: 2rem auto 0;
  color: #ffffff;
  font-size: 2rem;
  border-radius: 2rem;
  box-sizing: border-box;
  line-height: 4rem;
}

@media (min-width: 769px) {
  .button {
    width: 17rem;
    height: 5.7rem;
    font-size: 2.4rem;
    border-radius: 2.85rem;
    line-height: 5.7rem;
  }
}

.button:hover {
  background-color: rgba(163, 214, 204, 0.8);
}

.copyright {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100vw;
  height: 4rem;
  background-color: #a3d6cc;
  margin: 0;
  padding: 0 2rem 0;
}

@media (min-width: 769px) {
  .copyright {
    justify-content: center;
    max-width: 100vw;
  }
}

@media (min-width: 769px) {
  .button:hover {
    background-color: rgba(163, 214, 204, 0.8);
  }

  .logo_footer:hover {
    opacity: 0.5;
  }
}

.cover {
  display: flex;
  width: 100vw;
  margin: 0 calc(50% - 50vw);
  align-items: center;
  justify-content: center;
  flex-direction: column;
  height: 25rem;
  background-size: cover;
  background-position: center;
}

@media (min-width: 769px) {
  .cover {
    height: 50rem;
  }
}

@media (max-width: 768px) {
  .sp-cover {
    background-image: url(../images/cover/sp_cover.jpg);
  }
}

@media (min-width: 769px) {
  .pc-cover {
    background-image: url(../images/cover/pc_cover.jpg);
  }
}

.original-container {
  margin-bottom: 6rem;
}

.lesson-container {
  margin: 6rem 0;
}

.embroidery-body {
  padding: 0 1rem;
  margin: 0 auto;
}

@media (min-width: 769px) {
  .embroidery-body {
    max-width: 112rem;
    padding: 0 2rem;
    margin: 0 auto;
  }
}

.embroidery {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}

@media (min-width: 769px) {
  .embroidery {
    max-width: 108rem;
  }
}

.embroidery a {
  width: 50%;
  padding: 0 1rem;
}

@media (min-width: 769px) {
  .embroidery a {
    width: 33.3%;
    padding: 0 1rem;
  }
}

.square {
  margin-bottom: 2rem;
}

.square:hover {
  opacity: 0.5;
}

/*# sourceMappingURL=style.css.map */