footer {
  padding-top: 25rem;
}
@media screen and (max-width: 767px) {
  footer {
    padding-top: 20vw;
  }
}

.m-title {
  text-align: center;
  font-size: 6rem;
  font-family: "Roboto", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
  font-variation-settings: "wdth" 100;
  letter-spacing: 0.05em;
  padding: 10.5rem 0;
}
@media screen and (max-width: 767px) {
  .m-title {
    font-size: 10.6666666667vw;
    padding: 13.3333333333vw 0;
  }
}

.s-title {
  text-align: center;
  font-size: 5rem;
  font-family: "Roboto", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
  font-variation-settings: "wdth" 100;
  letter-spacing: 0.05em;
  padding: 9.5rem 0 6rem;
}
@media screen and (max-width: 767px) {
  .s-title {
    font-size: 7.4666666667vw;
    padding: 10.6666666667vw 0 6.6666666667vw;
  }
}

.btn-outer {
  padding: 3rem 0;
}
.btn-outer .btn {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  background: #F2F2F2;
  margin: 25px auto 0;
  max-width: 300px;
  position: relative;
  min-height: 60px;
  font-size: 1.8rem;
  border: 2px solid #F2F2F2;
}
.btn-outer .btn span {
  display: inline-block;
}
@media screen and (min-width: 768px) {
  .btn-outer .btn:hover {
    opacity: 0.7;
  }
}

.p-list {
  padding-bottom: 15.5rem;
}
@media screen and (min-width: 768px) {
  .p-list ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 9rem 7rem;
  }
}
@media only screen and (min-width: 767px) and (max-width: 1050px) {
  .p-list ul {
    gap: 5rem;
  }
}
.p-list ul li .p-list-inner {
  display: block;
}
.p-list ul li .p-list-inner > span {
  display: block;
}
.p-list ul li .p-list-inner figure {
  display: block;
  position: relative;
  overflow: hidden;
  padding-top: 68%;
  filter: drop-shadow(1px 3px 5px rgba(0, 0, 0, 0.5));
}
.p-list ul li .p-list-inner figure img {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  transform: translate(-50%, -50%);
}
.p-list ul li .p-list-inner .title {
  font-size: 2.2rem;
  margin-top: 2.2rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-list ul li .p-list-inner .title {
    font-size: 4.2666666667vw;
    margin-top: 3.2vw;
  }
}
@media screen and (min-width: 768px) {
  .p-list ul li > a:hover figure img {
    transform: translate(-50%, -50%) scale(1.1);
  }
}
@media screen and (max-width: 767px) {
  .p-list ul li + li {
    margin-top: 12vw;
  }
}

.movie-outer {
  filter: drop-shadow(1px 3px 5px rgba(0, 0, 0, 0.5));
}
.movie-outer video {
  width: 100%;
  border: none;
}

@media screen and (max-width: 767px) {
  #blog .blog_body .thumb {
    width: 100vw;
    margin: 0 calc(50% - 50vw);
  }
}
#blog .blog_body .thumb figure {
  filter: drop-shadow(1px 3px 5px rgba(0, 0, 0, 0.5));
}
#blog .blog_body .body {
  margin: 6rem auto 0;
}
@media screen and (min-width: 768px) {
  #blog .blog_body .body {
    display: grid;
    grid-template-columns: max-content 1fr;
    max-width: 80%;
  }
}
@media screen and (max-width: 767px) {
  #blog .blog_body .body {
    margin: 9.3333333333vw auto 0;
  }
}
@media screen and (min-width: 768px) {
  #blog .blog_body .body dl {
    display: contents;
  }
}
#blog .blog_body .body dl dt,
#blog .blog_body .body dl dd {
  font-size: 2rem;
  line-height: 1.7;
}
@media screen and (min-width: 768px) {
  #blog .blog_body .body dl dt,
  #blog .blog_body .body dl dd {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
  }
}
@media screen and (max-width: 767px) {
  #blog .blog_body .body dl dt,
  #blog .blog_body .body dl dd {
    font-size: 4.2666666667vw;
  }
}
@media screen and (max-width: 767px) {
  #blog .blog_body .body dl dt {
    border-bottom: 1px solid #333;
    padding-bottom: 1.3333333333vw;
  }
}
#blog .blog_body .body dl dd {
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  #blog .blog_body .body dl dd {
    padding-left: 4rem;
  }
}
@media screen and (max-width: 767px) {
  #blog .blog_body .body dl dd {
    padding-top: 1.3333333333vw;
  }
}
#blog .blog_body .body dl dd a {
  text-decoration: underline;
}
@media screen and (min-width: 768px) {
  #blog .blog_body .body dl dd a:hover {
    text-decoration: none;
  }
}
@media screen and (max-width: 767px) {
  #blog .blog_body .body dl dd + dt {
    margin-top: 6.6666666667vw;
  }
}/*# sourceMappingURL=styles.css.map */