@charset "UTF-8";
.pc {
  display: block !important;
}
@media screen and (max-width: 767px) {
  .pc {
    display: none !important;
  }
}
@media screen and (min-width: 1025px) {
  .pc--inline {
    display: inline !important;
  }
}
@media screen and (min-width: 1025px) {
  .pc--flex {
    display: flex !important;
  }
}

.sp {
  display: none !important;
}
@media screen and (max-width: 767px) {
  .sp {
    display: block !important;
  }
}
@media screen and (max-width: 767px) {
  .sp--inline {
    display: inline !important;
  }
}
@media screen and (max-width: 767px) {
  .sp--flex {
    display: flex !important;
  }
}

.top__bnr {
  position: fixed;
  z-index: 7000;
  right: 30px;
  bottom: 20px;
  transition-duration: 0.3s;
  transition-timing-function: ease-in-out;
  transform-style: preserve-3d;
}
@media screen and (max-width: 767px) {
  .top__bnr {
    right: 20px;
    left: 20px;
  }
}
.top__bnr__close {
  position: absolute;
  right: -10px;
  top: -10px;
  font-size: 0;
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
@media screen and (max-width: 767px) {
  .top__bnr__close {
    right: 0;
    top: -30px;
  }
}
.top__bnr__close span {
  display: block;
  position: relative;
  width: 50px;
  height: 50px;
  border: 4px solid #37962f;
  border-radius: 50%;
  background: #fff7f5;
}
.top__bnr__close span::before, .top__bnr__close span::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 4px;
  height: 30px;
  background: #37962f;
}
.top__bnr__close span::before {
  transform: translate(-50%, -50%) rotate(45deg);
}
.top__bnr__close span::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}
.top__bnr__img {
  width: 446px;
  border-radius: 10px;
  overflow: hidden;
  display: block;
  box-shadow: 0px 0px 10px 0px rgba(39, 71, 23, 0.9);
}
@media screen and (max-width: 767px) {
  .top__bnr__img {
    width: 100%;
    border-radius: 20px;
  }
}
.top__bnr__img img {
  width: 100%;
}
.top .slide {
  bottom: 112px;
}
@media screen and (max-width: 767px) {
  .top .slide {
    bottom: 76px;
  }
}

.fes {
  font-family: "Noto Sans JP", sans-serif;
}
.fes .contents {
  color: #333333;
}
.fes button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
.fes #headerArea.pc {
  margin-bottom: 0;
}
.fes__mv {
  width: 100%;
  border-bottom: 10px solid #007C42;
  position: relative;
}
@media screen and (max-width: 767px) {
  .fes__mv {
    border-bottom: 0 solid #007C42;
  }
}
.fes__mv__lavel {
  width: 18.8020833333%;
  height: auto;
  position: absolute;
  left: 14.84375%;
  bottom: 1.25%;
}
@media screen and (max-width: 767px) {
  .fes__mv__lavel {
    width: 32.6822916667%;
    left: 3.3854166667%;
    bottom: -3.90625%;
  }
}
.fes__mv__lavel img {
  width: 100%;
  height: auto;
}
.fes__mv__txt {
  position: absolute;
  bottom: 0;
  width: 100%;
}
.fes__mv__txt .lavel {
  width: 13.671875%;
  height: auto;
  display: block;
  margin-left: 23.6979166667%;
  margin-bottom: 18px;
}
@media screen and (max-width: 767px) {
  .fes__mv__txt .lavel {
    width: 29.9075520833%;
    margin-left: 1.8229166667%;
    margin-bottom: -11px;
  }
}
.fes__mv__txt .lavel img {
  width: 100%;
  height: auto;
}
.fes__mv__txt .text {
  padding: 22px;
  background-size: cover;
  text-align: center;
  display: block;
  background-image: url("/kodomo/open/tv/images/festival/bg_01.png");
}
@media screen and (max-width: 767px) {
  .fes__mv__txt .text {
    padding: 7px 32px;
  }
}
.fes__mv__txt .text img {
  width: 100%;
  max-width: 990px;
}
.fes__mv .is--pc {
  width: 100%;
}
.fes .fes-content-area {
  width: 100%;
}
.fes .title0-area {
  padding-bottom: 80px;
}
@media screen and (max-width: 767px) {
  .fes .title0-area {
    padding-bottom: 40px;
  }
}
.fes .title-area {
  padding-bottom: 80px;
}
@media screen and (max-width: 767px) {
  .fes .title-area {
    padding-bottom: 23px;
  }
}
.fes .heading-area {
  padding-bottom: 21px;
}
.fes__date {
  font-size: 30px;
  font-size: 3rem;
  line-height: 30px;
  color: #fff;
  font-weight: bold;
  margin-top: 20px;
}
@media screen and (max-width: 767px) {
  .fes__date {
    font-size: 36px;
    font-size: clamp(14px, 4.6875vw, 36px);
    margin-top: 1.0416666667%;
  }
}
.fes__txt {
  font-size: 18px;
  font-size: 1.8rem;
  line-height: 30px;
  color: #fff;
  font-weight: 100;
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .fes__txt {
    font-size: 26px;
    font-size: clamp(14px, 3.3854166667vw, 26px);
    margin-top: 3.90625%;
  }
}
.fes .movie-list-result-top {
  margin-top: 22px;
}
@media screen and (max-width: 767px) {
  .fes .movie-list-result-top {
    margin-left: 20px;
    margin-right: 20px;
  }
}
.fes .movie-list-result {
  height: 515px;
  background-color: #f03f79;
}
@media screen and (max-width: 767px) {
  .fes .movie-list-result {
    margin-left: 20px;
    margin-right: 20px;
    height: auto;
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .fes .movie-list-result li {
    width: 100%;
  }
}
.fes .movie-list-result li .movie-list-result-row {
  height: auto;
}
.fes .movie-list-result li .movie-list-result-row .song-no {
  width: 103px;
  min-height: 0;
  padding: 0 17px;
}
@media screen and (max-width: 767px) {
  .fes .movie-list-result li .movie-list-result-row .song-no {
    width: 12.890625%;
    padding-left: 0.9114583333%;
    padding-right: 0.9114583333%;
  }
}
.fes .movie-list-result li .movie-list-result-row .song-name span {
  font-size: 22px;
  font-size: 2.2rem;
  line-height: normal;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .fes .movie-list-result li .movie-list-result-row .song-name span {
    font-size: 26px;
    font-size: clamp(14px, 3.3854166667vw, 26px);
    line-height: 26px;
  }
}
.fes .movie-list-result li a {
  background-color: #fff;
  text-underline-offset: 10px;
  align-items: stretch;
}
@media screen and (max-width: 767px) {
  .fes .movie-list-result li a {
    text-underline-offset: 8px;
  }
}
.fes .movie-list-result li a:hover {
  opacity: 1;
}
.fes .movie-list-result li a:hover .song-no, .fes .movie-list-result li a:hover .song-name, .fes .movie-list-result li a:hover .song-img {
  opacity: 0.7;
}
.fes__tbox {
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
  padding: 26px 20px 20px;
  background-color: #fff;
  max-width: 1160px;
  margin: 0 auto;
  width: calc(100% - 40px);
  line-height: 170%;
  position: relative;
}
@media screen and (max-width: 767px) {
  .fes__tbox {
    line-height: 150%;
    font-size: 36px;
    font-size: clamp(14px, 4.6875vw, 36px);
    width: calc(100% - 80px);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    max-height: 570px;
    overflow: scroll;
    text-align: left;
    padding: 40px 20px;
  }
}
.fes__tbox__green {
  color: #e12020;
}
.fes__tbox__note {
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: normal;
  margin-left: 1em;
}
@media screen and (max-width: 767px) {
  .fes__tbox__note {
    font-size: 26px;
    font-size: clamp(14px, 3.3854166667vw, 26px);
  }
  .fes__tbox__note:last-of-type {
    margin-top: 5.2vw;
  }
}
.fes__tbox__note::first-letter {
  margin-left: -1em;
}
.fes__tbox__note a {
  text-underline-offset: 10px;
  color: #0081d3;
  text-decoration: underline;
}
.fes__tbox__bottom span {
  font-size: 13px;
}
.fes__tbox__label {
  width: 185px;
  height: auto;
  position: absolute;
  bottom: -73px;
  right: -21px;
}
.fes__tbox__label img {
  width: 100%;
  height: auto;
}
.fes__thank {
  display: block;
  margin: 62px 6.51vw 13px;
  width: calc(100% - 13.02vw);
  text-align: center;
}
.fes__thank img {
  width: 100%;
  max-width: 521px;
}
@media screen and (max-width: 767px) {
  .fes__thank {
    margin-top: 40px;
  }
}
.fes__sche {
  display: block;
  margin: 0 6.51vw 20px;
  width: calc(100% - 13.02vw);
}
.fes__sche img {
  width: 100%;
  max-width: 513px;
}
.fes__sche--bottom {
  margin: 0 auto 20px;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .fes__sche {
    margin-bottom: 0px;
  }
}
.fes__entext {
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
  margin: 40px 20px 0;
}
@media screen and (max-width: 767px) {
  .fes__entext {
    font-size: 26px;
    font-size: clamp(14px, 3.3854166667vw, 26px);
    margin-top: 20px;
  }
}
.fes__ensong {
  margin: 38px 20px 0;
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
}
@media screen and (max-width: 767px) {
  .fes__ensong {
    gap: 20px;
    margin-top: 19px;
  }
}
.fes__ensong li {
  width: calc((100% - 54px) / 4);
}
@media screen and (max-width: 767px) {
  .fes__ensong li {
    width: calc((100% - 20px) / 2);
  }
}
.fes .contents_btn {
  margin: 63px 40px 0;
  width: calc(100% - 80px);
}
@media screen and (max-width: 767px) {
  .fes .contents_btn {
    margin-top: 30px;
  }
}
.fes .offers {
  text-align: left;
  font-size: 18px;
  font-size: 1.8rem;
  margin: 40px auto 0;
  font-weight: 100;
  width: 94%;
}
@media screen and (max-width: 767px) {
  .fes .offers {
    font-size: 26px;
    font-size: clamp(14px, 3.3854166667vw, 26px);
    margin-top: 5.2083333333%;
  }
}
.fes .offers p {
  margin-left: 1em;
}
.fes .offers p::first-letter {
  margin-left: -1em;
}
.fes .btn_area {
  margin: 80px 40px 0;
}
@media screen and (max-width: 767px) {
  .fes .btn_area {
    margin-top: calc(60px - 2rem);
  }
}
.fes__abmodal {
  position: fixed;
  z-index: 9999;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: all 0.3s ease-in-out;
  background: rgba(0, 0, 0, 0.7);
  display: none;
}
.fes__abmodal__close {
  display: block;
  position: absolute;
  width: 50px;
  height: 50px;
  font-size: 0;
  top: 6.5104166667%;
  right: 30px;
}
.fes__abmodal__close::before, .fes__abmodal__close::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 7px; /* 棒の幅（太さ） */
  height: 60px; /* 棒の高さ */
  background: #fff;
}
.fes__abmodal__close::before {
  transform: translate(-50%, -50%) rotate(45deg);
}
.fes__abmodal__close::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}
.fes__abmodal__label {
  position: absolute;
  width: 28.90625%;
  height: auto;
  right: 27px;
  top: calc(50% + 186px);
}
.fes__abmodal__label img {
  width: 100%;
  height: auto;
}
.fes .contents_btn {
  content: url("/kodomo/open/tv/images/festival/sp/btn_01.png");
}
.fes .active {
  display: block;
}/*# sourceMappingURL=style.css.map */