*,
::before,
::after {
  box-sizing: border-box;
}

.kv {
  background-repeat: no-repeat;
  background-position: 50% 0;
}
@media screen and (min-width: 769px) {
  .kv {
    display: flex;
    align-items: center;
    height: min(350px, 23.334vw);
    margin-top: 10rem;
    background-image: url(../img/mv.jpg);
    background-size: cover;
  }
}
@media screen and (max-width: 768px) {
  .kv {
    margin-top: 12rem;
    padding-top: 75rem;
    background-image: url(../img/sp/mv.jpg);
    background-size: contain;
  }
}

@media screen and (min-width: 769px) {
  .kv_content {
    width: min(1500px, 100vw);
    margin: 0 auto;
    padding-left: min(160px, 10.667vw);
  }
}
@media screen and (max-width: 768px) {
  .kv_content {
    display: flex;
    justify-content: center;
  }
}

.kv_ttl {
  position: relative;
  display: flex;
  flex-direction: column;
  font-weight: 700;
  line-height: 1;
}
@media screen and (min-width: 769px) {
  .kv_ttl {
    font-size: min(51px, 3.4vw);
    padding-bottom: min(5px, 0.334vw);
    letter-spacing: -0.05em;
  }
}
@media screen and (max-width: 768px) {
  .kv_ttl {
    font-size: 7rem;
    padding-bottom: 0.4rem;
  }
}
.kv_ttl::before {
  content: "";
  position: absolute;
  top: 0;
  height: 100%;
  background-color: #d90b18;
}
@media screen and (min-width: 769px) {
  .kv_ttl::before {
    left: min(-30px, -2vw);
    width: min(11px, 0.734vw);
  }
}
@media screen and (max-width: 768px) {
  .kv_ttl::before {
    left: -4.2rem;
    width: 1.5rem;
  }
}
.kv_ttl .en {
  fill: #d90b18;
}
@media screen and (min-width: 769px) {
  .kv_ttl .en {
    width: min(193px, 12.867vw);
    height: min(28px, 1.867vw);
    margin-top: min(10px, 0.667vw);
  }
}
@media screen and (max-width: 768px) {
  .kv_ttl .en {
    width: 29.9rem;
    height: 4.4rem;
    margin-top: 1.5rem;
  }
}

.page_lead {
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  .page_lead {
    padding-top: min(70px, 4.667vw);
    padding-bottom: min(70px, 4.667vw);
    letter-spacing: 0.04em;
    line-height: 1.572em;
    font-size: 2.8rem;
    text-align: center;
  }
  .page_lead > p {
    line-height: inherit;
    font: inherit;
  }
  .page_lead > p:first-of-type {
    margin-top: -0.285em;
  }
  .page_lead > p:last-of-type {
    margin-bottom: -0.285em;
  }
}
@media screen and (max-width: 768px) {
  .page_lead {
    padding: 8rem 6rem;
    line-height: 1.693em;
    font-size: 2.6rem;
  }
  .page_lead > p {
    line-height: inherit;
    font: inherit;
  }
  .page_lead > p:first-of-type {
    margin-top: -0.346em;
  }
  .page_lead > p:last-of-type {
    margin-bottom: -0.346em;
  }
}

@media screen and (min-width: 769px) {
  .sec_movie {
    padding-top: min(80px, 5.334vw);
    padding-bottom: min(130px, 8.667vw);
  }
}
@media screen and (max-width: 768px) {
  .sec_movie {
    padding-top: 8rem;
    padding-bottom: 15rem;
  }
}
.sec_movie:nth-child(odd) {
  background-color: #f8f9f9;
}
.sec_movie:nth-child(even) {
  background-color: #fff;
}

.sec_head {
  font-weight: 700;
  text-align: center;
}
@media screen and (min-width: 769px) {
  .sec_head {
    margin-bottom: min(80px, 5.334vw);
    line-height: 1.5em;
    font-size: 4rem;
  }
  .sec_head > h2 {
    line-height: inherit;
    font: inherit;
  }
  .sec_head > h2:first-of-type {
    margin-top: -0.25em;
  }
  .sec_head > h2:last-of-type {
    margin-bottom: -0.25em;
  }
}
@media screen and (max-width: 768px) {
  .sec_head {
    margin-bottom: 8rem;
    line-height: 1.5em;
    font-size: 4rem;
  }
  .sec_head > h2 {
    line-height: inherit;
    font: inherit;
  }
  .sec_head > h2:first-of-type {
    margin-top: -0.25em;
  }
  .sec_head > h2:last-of-type {
    margin-bottom: -0.25em;
  }
}
.sec_head span {
  position: relative;
  display: inline-block;
}
@media screen and (min-width: 769px) {
  .sec_head span {
    padding: 0 min(7px, 0.467vw) min(25px, 1.667vw);
  }
}
@media screen and (max-width: 768px) {
  .sec_head span {
    padding: 0 0 2.2rem;
  }
}
.sec_head span::before, .sec_head span::after {
  content: "";
  position: absolute;
  bottom: 0;
  width: 50.5%;
}
@media screen and (min-width: 769px) {
  .sec_head span::before, .sec_head span::after {
    height: min(3px, 0.2vw);
  }
}
@media screen and (max-width: 768px) {
  .sec_head span::before, .sec_head span::after {
    height: 0.4rem;
  }
}
.sec_head span::before {
  left: 0;
  background-color: #000;
}
.sec_head span::after {
  right: 0;
  background-color: #e60012;
}

@media screen and (min-width: 769px) {
  .movie_cont {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    -moz-column-gap: min(80px, 5.334vw);
         column-gap: min(80px, 5.334vw);
    row-gap: min(90px, 6vw);
    width: min(1100px, 73.334vw);
    margin: 0 auto;
  }
}
@media screen and (max-width: 768px) {
  .movie_cont {
    display: grid;
    row-gap: 7rem;
    width: 51rem;
    margin: 0 auto;
  }
}
@media screen and (min-width: 769px) {
  .movie_cont:has(.movie_cont_item:only-child) {
    justify-content: center;
  }
}

@media screen and (min-width: 769px) {
  .movie_cont_item {
    width: min(510px, 34vw);
  }
}

.movie_cont_item_head {
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  .movie_cont_item_head {
    margin-top: min(15px, 1vw);
    margin-bottom: min(10px, 0.667vw);
    line-height: 1.462em;
    font-size: 2.6rem;
  }
  .movie_cont_item_head > p {
    line-height: inherit;
    font: inherit;
  }
  .movie_cont_item_head > p:first-of-type {
    margin-top: -0.23em;
  }
  .movie_cont_item_head > p:last-of-type {
    margin-bottom: -0.23em;
  }
}
@media screen and (max-width: 768px) {
  .movie_cont_item_head {
    margin-top: 1.5rem;
    margin-bottom: 1.5rem;
    line-height: 1.412em;
    font-size: 3.4rem;
  }
  .movie_cont_item_head > p {
    line-height: inherit;
    font: inherit;
  }
  .movie_cont_item_head > p:first-of-type {
    margin-top: -0.205em;
  }
  .movie_cont_item_head > p:last-of-type {
    margin-bottom: -0.205em;
  }
}

.movie_cont_item_movie {
  position: relative;
  aspect-ratio: 16/9;
}
.movie_cont_item_movie iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: none;
}

@media screen and (min-width: 769px) {
  .movie_cont_item_movie + .movie_cont_item_txt {
    margin-top: min(20px, 1.334vw);
  }
}
@media screen and (max-width: 768px) {
  .movie_cont_item_movie + .movie_cont_item_txt {
    margin-top: 1rem;
  }
}

@media screen and (min-width: 769px) {
  .movie_cont_item_txt {
    line-height: 1.55em;
    font-size: 2rem;
  }
  .movie_cont_item_txt > p {
    line-height: inherit;
    font: inherit;
  }
  .movie_cont_item_txt > p:first-of-type {
    margin-top: -0.275em;
  }
  .movie_cont_item_txt > p:last-of-type {
    margin-bottom: -0.275em;
  }
}
@media screen and (max-width: 768px) {
  .movie_cont_item_txt {
    line-height: 1.358em;
    font-size: 2.8rem;
  }
  .movie_cont_item_txt > p {
    line-height: inherit;
    font: inherit;
  }
  .movie_cont_item_txt > p:first-of-type {
    margin-top: -0.178em;
  }
  .movie_cont_item_txt > p:last-of-type {
    margin-bottom: -0.178em;
  }
}/*# sourceMappingURL=movie.css.map */