.blue {
  color: #73B4B9;
}

.red {
  color: #FF3F75;
}

#top_image {
  width: 100%;
  height: 100vh;
  position: relative;
  overflow: hidden;
}

#top_image h2 {
  color: #fff;
  font-size: 26px;
  text-align: center;
  width: 100%;
  position: absolute;
  z-index: 5;
  bottom: 0%;
  left: 50%;
  padding: 0.5em 0;
  transform: translate(-50%, 0%);
  background-color: rgba(115, 183, 188, 0.5);
}

#top_image h2 span {
  display: block;
  font-family: "EB Garamond", serif;
  font-weight: normal;
  font-size: 13px;
}

@media screen and (max-width: 480px) {
  #top_image h2 b {
    display: none;
  }
}
#top_image p img {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100vw;
  height: 100vh;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}

#wrapper {
  position: relative;
  z-index: 10;
  margin-top: 0;
}

@media screen and (max-width: 768px) {
  #wrapper {
    margin-top: 0px;
  }
}
#photo {
  text-align: center;
  padding-top: 3em;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 500;
  font-feature-settings: "palt";
  letter-spacing: 0.15rem;
  width: 100%;
  max-width: 1000px;
  padding: 100px 5% 0;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  #photo {
    padding: 70px 7%;
  }
}
#photo h2 {
  padding: 2rem 0 1rem;
  font-weight: 500;
}
#photo h2 > span {
  display: block;
  padding: 0.25rem;
  font-size: 40px;
}
@media screen and (max-width: 768px) {
  #photo h2 > span {
    font-size: 30px;
  }
}
@media screen and (max-width: 480px) {
  #photo h2 > span {
    font-size: 24px;
  }
}
#photo h2 > span small {
  font-size: 22px;
}
@media screen and (max-width: 768px) {
  #photo h2 > span small {
    font-size: 18px;
  }
}
@media screen and (max-width: 480px) {
  #photo h2 > span small {
    font-size: 16px;
  }
}
#photo h2 img {
  width: 100px;
  height: auto;
}
@media screen and (max-width: 480px) {
  #photo h2 img {
    display: none;
  }
}
#photo picture {
  display: block;
}

.w100 {
  width: 100%;
}
.w100 img {
  width: 100%;
  border-radius: 20px;
}

.mb1 {
  margin-bottom: 1rem;
}
@media screen and (max-width: 480px) {
  .mb1 {
    margin-bottom: 0.75rem;
  }
}

.mb2 {
  margin-bottom: 2rem;
}
@media screen and (max-width: 480px) {
  .mb2 {
    margin-bottom: 1rem;
  }
}

.mb3 {
  margin-bottom: 3rem;
}
@media screen and (max-width: 480px) {
  .mb3 {
    margin-bottom: 1.5rem;
  }
}

.mb4 {
  margin-bottom: 4rem;
}
@media screen and (max-width: 480px) {
  .mb4 {
    margin-bottom: 2rem;
  }
}

.disc {
  text-align: justify;
}
.disc > dt {
  font-size: 27px;
  margin-bottom: 1rem;
}
@media screen and (max-width: 900px) {
  .disc > dt {
    font-size: 24px;
  }
}
@media screen and (max-width: 480px) {
  .disc > dt {
    font-size: 18px;
  }
}
.disc > dd {
  line-height: 2;
}
.disc li {
  background: #DEF3F1;
  display: flex;
  justify-content: space-between;
  padding: 20px 30px;
}
@media screen and (max-width: 480px) {
  .disc li {
    display: block;
    text-align: center;
    padding: 20px;
  }
}
.disc li dl {
  width: 50%;
}
@media screen and (max-width: 480px) {
  .disc li dl {
    width: 100%;
    text-align: justify;
  }
}
.disc li dt {
  line-height: 1.7;
  font-size: 110%;
  margin-bottom: 0.25rem;
}
.disc li dd {
  font-size: 90%;
}
.disc li picture {
  display: block;
  margin-top: 0.5rem;
}
.disc li picture img {
  width: 100%;
}
.disc li picture:nth-of-type(1) {
  width: 10%;
}
@media screen and (max-width: 480px) {
  .disc li picture:nth-of-type(1) {
    width: 25%;
    margin: 0 auto 0.5rem;
  }
}
.disc li picture:nth-of-type(2) {
  width: 35%;
}
@media screen and (max-width: 480px) {
  .disc li picture:nth-of-type(2) {
    width: 100%;
  }
}

.course {
  text-align: justify;
  width: 100%;
}
.course li {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 480px) {
  .course li {
    display: block;
  }
}
.course dl {
  width: 50%;
}
@media screen and (max-width: 480px) {
  .course dl {
    width: 100%;
  }
}
.course dt {
  color: #73B4B9;
  font-size: 150%;
  font-weight: 700;
  text-align: left;
  line-height: 1.2;
  margin-bottom: 0.5rem;
}
.course dt span {
  display: inline-block;
  font-size: 80%;
}
.course dd {
  line-height: 2;
  margin-bottom: 1rem;
}
.course dd span {
  display: block;
  margin: 0.5rem 0;
}
.course picture {
  display: block;
  width: 46%;
  overflow: hidden;
}
@media screen and (max-width: 480px) {
  .course picture {
    width: 100%;
  }
}
.course picture img {
  width: 100%;
  border-radius: 10px;
}

.flow {
  text-align: left;
}
.flow h2 {
  color: #73B4B9;
  font-size: 170%;
}
.flow div {
  background: #DEF3F1;
  padding: 4rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-style: normal;
  color: #333;
}
@media screen and (max-width: 900px) {
  .flow div {
    padding: 3rem 3rem 1rem;
  }
}
@media screen and (max-width: 480px) {
  .flow div {
    padding: 1.5rem 1.5rem 0.5rem;
  }
}
.flow div > p {
  margin-bottom: 3rem;
}
.flow li {
  background: #fff;
  padding: 30px 50px;
  width: 80%;
  margin: 0 auto 60px;
  position: relative;
}
@media screen and (max-width: 900px) {
  .flow li {
    padding: 20px 40px;
  }
}
@media screen and (max-width: 480px) {
  .flow li:nth-of-type(3) {
    margin: 0 auto 30px;
  }
}
.flow li a:hover img {
  opacity: 0.7;
}

.flow_box {
  position: relative;
}

.flow1 a {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}
@media screen and (max-width: 480px) {
  .flow1 a {
    display: block;
    margin: 0 auto;
    text-align: center;
  }
}
.flow1 .line {
  width: 20%;
}
@media screen and (max-width: 900px) {
  .flow1 .line {
    width: 15%;
  }
}
@media screen and (max-width: 480px) {
  .flow1 .line {
    width: 30%;
    margin: 0 auto 0.5rem;
  }
}
.flow1 .line img {
  width: 100%;
}
.flow1 p {
  font-size: 110%;
}
@media screen and (max-width: 900px) {
  .flow1 p {
    font-size: 100%;
  }
}
.flow1 .qr {
  width: 30%;
}
@media screen and (max-width: 900px) {
  .flow1 .qr {
    width: 25%;
  }
}
@media screen and (max-width: 480px) {
  .flow1 .qr {
    width: 50%;
    margin: 0.5rem auto 0;
  }
}
.flow1 .qr img {
  width: 100%;
}

.flow .flow2 {
  text-align: center;
  padding: 70px 20px;
  font-size: 120%;
}
@media screen and (max-width: 900px) {
  .flow .flow2 {
    padding: 50px 20px;
    font-size: 110%;
  }
}

.nb {
  position: absolute;
  top: -20px;
  left: -20px;
  border-radius: 3rem;
  background: #73B4B9;
  width: 70px;
  height: 70px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 900px) {
  .nb {
    width: 60px;
    height: 60px;
    top: -15px;
    left: -15px;
  }
}
.nb span {
  display: inline-block;
  font-size: 150%;
  font-weight: 900;
  color: #fff;
}
@media screen and (max-width: 900px) {
  .nb span {
    font-size: 130%;
  }
}

#photo .show {
  text-align: left;
}
#photo .show h2 {
  color: #73B4B9;
  font-size: 170%;
  padding: 0 0 0.5rem;
}
#photo .show ul {
  margin-top: 30px;
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
}
@media screen and (max-width: 480px) {
  #photo .show ul {
    margin-top: 15px;
    gap: 10px;
  }
}
#photo .show li {
  width: calc((100% - 40px) / 3);
}
@media screen and (max-width: 480px) {
  #photo .show li {
    width: calc((100% - 20px) / 3);
  }
}
#photo .show li img {
  width: 100%;
  border-radius: 15px;
}
@media screen and (max-width: 900px) {
  #photo .show li img {
    border-radius: 10px;
  }
}
@media screen and (max-width: 480px) {
  #photo .show li img {
    border-radius: 7px;
  }
}

@media screen and (max-width: 480px) {
  .pc {
    display: none;
  }
}
/*# sourceMappingURL=photo.css.map */