@charset "UTF-8";
/* CSS Document */
.top_wrap, #dream, #tenbo, #movie {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}

.tei {
  display: none !important;
}

#top {
  position: relative;
  display: flex;
  justify-content: flex-end;
}
#top .top_racer {
  position: absolute;
  width: 51%;
  height: 100%;
  top: 0;
  left: 0;
}
#top .top_racer img {
  width: 100%;
  height: 100%;
}
#top .top_racer .namelabel {
  position: absolute;
  left: 0;
  bottom: 1rem;
  padding-bottom: 0.3rem;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  font-weight: 700;
}
#top .top_racer .namelabel::before {
  content: "";
  display: inline-block;
  background: url(../images/tit_sub.svg) no-repeat center;
  background-size: contain;
}
#top .top_wrap {
  z-index: 1;
}
#top .top_wrap::before {
  content: "";
  display: inline-block;
  background: url(../images/top_flag.svg) no-repeat top right;
  background-size: contain;
  position: absolute;
  top: 0;
  right: 0;
}
#top .tit_wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  background: rgba(77, 32, 14, 0.8509803922);
}
#top .tit_wrap .tit {
  background: url(../images/tit.png) no-repeat center;
  background-size: contain;
}
#top .tit_wrap .tit_sub {
  background: url(../images/tit_sub.svg) no-repeat center;
  background-size: contain;
}
#top .tit_wrap .tit_day {
  background: url(../images/tit_day.png) no-repeat center;
  background-size: contain;
}
#top .top_btn {
  display: flex;
  justify-content: center;
  align-items: center;
}
#top .top_btn li {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}
#top .top_btn li .sub {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  position: absolute;
  background: #252F40;
  color: #fff;
}
#top .top_btn li .sub p {
  font-family: "Noto Serif JP", serif;
  font-size: 2rem;
}
#top .top_btn li .sub p span {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 900;
  font-size: 2.5rem;
}
#top .top_btn a {
  display: flex;
  justify-content: center;
  align-items: center;
  color: #252F40;
  text-align: center;
  filter: drop-shadow(-0.1rem -0.1rem 0 rgba(255, 246, 228, 0.7490196078));
}
#top .top_btn a p {
  font-family: "Noto Serif JP", serif;
  font-weight: 900;
}
#top .top_btn a p span {
  font-family: "Noto Serif JP", serif;
  font-weight: 900;
}

#topic {
  width: 100%;
  position: relative;
  background: #FF7FA5;
}
#topic::after {
  content: "";
  display: inline-block;
  position: absolute;
  width: 100%;
  height: 20rem;
  background: url(../images/topic_bg.png) no-repeat top center;
  background-size: contain;
  top: 100%;
  left: 0;
}
#topic .splide__slide img {
  width: 100%;
  height: 100%;
}
#topic .splide__arrows {
  display: flex;
  justify-content: space-between;
  padding: 0 5rem;
  width: calc(100% - 10rem);
  position: absolute;
  top: 35%;
}
#topic .splide__arrows button {
  display: block;
  background: #6C321C;
  width: 2.2rem;
  height: 5.8rem;
  clip-path: polygon(0% 0%, 100% 50%, 0% 100%);
  cursor: pointer;
}
#topic .splide__arrows button:first-child {
  transform: rotate(180deg);
}
#topic .splide__track {
  position: relative;
  z-index: 1;
}
#topic button {
  border: none;
  padding: 0;
}
#topic .splide__pagination {
  margin-top: 2rem;
}
#topic .splide__pagination__page {
  background: #FFF6E4;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 50%;
  margin: 0 0.5rem;
}
#topic .splide__pagination__page.is-active {
  background: #6C321C;
}

#dream {
  position: relative;
}
#dream .dr_member {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 1rem;
  border-radius: 0.5rem;
}
#dream .dr_member li {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  background: url(../images/dr_mem_bg.svg) no-repeat center;
  background-size: contain;
  padding: 1rem;
}
#dream .dr_member li:nth-child(1) .tei {
  background: #fff;
  color: #000;
}
#dream .dr_member li:nth-child(1) .tei::after {
  border-color: #000;
}
#dream .dr_member li:nth-child(2) .tei {
  background: #000;
}
#dream .dr_member li:nth-child(3) .tei {
  background: #E70000;
}
#dream .dr_member li:nth-child(4) .tei {
  background: #004BFF;
}
#dream .dr_member li:nth-child(5) .tei {
  background: #FFF700;
  color: #000;
}
#dream .dr_member li:nth-child(5) .tei::after {
  border-color: #000;
}
#dream .dr_member li:nth-child(6) .tei {
  background: #00BC06;
}
#dream .tei {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  color: #fff;
  margin-right: 1rem;
  font-family: "Oswald", sans-serif;
  font-weight: 700;
}
#dream .tei span {
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1em;
}
#dream .tei::after {
  content: "";
  display: inline-block;
  border: solid 0.3rem #fff;
  position: absolute;
}
#dream .member {
  color: #FFF6E4;
  text-align: center;
  font-weight: 700;
  font-family: "Noto Sans JP", sans-serif;
  margin-top: 0.6rem;
  margin-bottom: 0.5rem;
}
#dream .member .name_wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  border-bottom: solid 0.1rem #FFF6E4;
}
#dream .member .name {
  font-family: "Noto Serif JP", serif;
}
#dream .member .name .chotai {
  display: inline-block;
  font-family: "Noto Serif JP", serif;
  transform: scaleX(0.85);
  width: calc(100% + 3rem);
  margin-left: -1rem;
}
#dream .member .class {
  padding: 0.2rem 1rem 0.3rem;
  margin-left: 0.7rem;
  border-radius: 0.5rem;
  border-color: #FFF6E4;
  border-width: 0.1rem;
  border-style: solid;
}
#dream .photo {
  position: relative;
}
#dream .photo img {
  width: 100%;
  height: 100%;
}
#dream .photo .seiseki {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  position: absolute;
  background: url(../images/dr_seal.png) no-repeat center;
  background-size: contain;
  top: -1.3rem;
  right: -0.9rem;
  color: #fff;
  line-height: 2rem;
  font-family: "Noto Serif JP", serif;
  font-size: 4.2rem;
  font-weight: 700;
}
#dream .photo .seiseki span {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2rem;
  position: relative;
  top: -1rem;
}
#dream .kome {
  color: #6C321C;
  text-align: right;
}
#dream .kome li:first-child {
  margin-right: 1rem;
}
#dream .choco {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
}
#dream .choco div {
  animation: choco steps(2) 2s infinite;
}
#dream .choco .clock {
  background: url(../images/dr_clock.svg) no-repeat center;
  background-size: contain;
  position: absolute;
}
#dream .choco .heart {
  background: url(../images/dr_heart.svg) no-repeat center;
  background-size: contain;
  position: absolute;
  animation: choco steps(2) 2s reverse infinite;
}
#dream .choco .pstar {
  background: url(../images/dr_pstar.svg) no-repeat center;
  background-size: contain;
  position: absolute;
}

#tenbo {
  width: 100%;
  position: relative;
  background: #6ACDC6;
}
#tenbo::after {
  content: "";
  display: inline-block;
  position: absolute;
  width: 100%;
  height: 20rem;
  background: url(../images/tenbo_bg.png) no-repeat top center;
  background-size: contain;
  top: 100%;
  left: 0;
}

#dream, #tenbo, #movie {
  margin-top: -10rem;
  padding-top: 10rem;
}

/***********************************************************************
ミディアムデバイス (スマートフォン) のスタイル
**********************************************************************/
@media screen and (max-width: 750px) {
  .sp_non {
    display: none !important;
  }
  #top {
    height: 95.5rem;
  }
  #top .top_racer {
    width: 45rem;
  }
  #top .top_racer .splide__slide {
    height: 67.5rem;
  }
  #top .top_racer .namelabel {
    justify-content: flex-end;
    /*background: url(../images/tit_sub.svg) no-repeat top 1rem center ,#00000080;*/
    font-size: 3.4rem;
    flex-direction: column;
    width: 32rem;
    height: 13rem;
    padding: 1rem 0 1rem;
    bottom: 0;
  }
  #top .top_racer .namelabel .name {
    order: 1;
  }
  #top .top_racer .namelabel .num {
    order: 0;
    margin-bottom: -1rem;
  }
  #top .top_wrap {
    width: 100%;
    height: 95.5rem;
    justify-content: flex-start;
    background: url(../images/top_bg_sp.png) no-repeat top right;
    background-size: 44rem;
  }
  #top .top_wrap::before {
    width: 20rem;
    height: 14rem;
  }
  #top .tit_wrap {
    margin-top: 19.5rem;
    margin-left: auto;
    margin-right: 0;
    margin-bottom: 4rem;
    padding-top: 2rem;
    padding-left: 2.3rem;
    padding-right: 2.3rem;
    padding-bottom: 2rem;
  }
  #top .tit_wrap .tit {
    width: 44rem;
    height: 15.4rem;
  }
  #top .tit_wrap .tit_sub {
    width: 28em;
    height: 5rem;
  }
  #top .tit_wrap .tit_day {
    width: 46.8rem;
    height: 3.9rem;
    margin-top: 1.5rem;
  }
  #top .top_btn {
    margin-top: 20rem;
  }
  #top .top_btn li {
    flex-direction: column;
    justify-content: flex-start;
    text-align: center;
  }
  #top .top_btn li .sub {
    position: absolute;
    top: -2rem;
    line-height: 2.8rem;
  }
  #top .top_btn li a {
    font-size: 3.4rem;
  }
  #top .top_btn li a span {
    font-size: 3rem;
  }
  #top .top_btn li a p {
    line-height: 4.4rem;
    padding-top: 1.5rem;
  }
  #top .top_btn li:nth-child(1) {
    background: url(../images/top_btn1_sp.png) no-repeat center;
    background-size: contain;
    width: 44rem;
    height: 20rem;
    margin-right: 2.5rem;
  }
  #top .top_btn li:nth-child(1) .sub {
    padding-top: 0.5rem;
    padding-left: 5rem;
    padding-right: 5rem;
    padding-bottom: 0.5rem;
  }
  #top .top_btn li:nth-child(2) {
    background: url(../images/top_btn2_sp.png) no-repeat center;
    background-size: contain;
    width: 24.5rem;
    height: 20rem;
  }
  #top .top_btn li:nth-child(2) .sub {
    padding-top: 0.5rem;
    padding-left: 2rem;
    padding-right: 2rem;
    padding-bottom: 0.5rem;
  }
  #topic {
    padding-top: 5rem;
    padding-bottom: 1rem;
  }
  #topic::after {
    height: 11rem;
    background-position: top right -2rem;
    background-size: cover;
    top: 99.7%;
  }
  #topic .splide__slide {
    width: 37.6rem !important;
    height: 18.2rem;
  }
  #dream .tit {
    background: url(../images/dr_tit_sp.svg) no-repeat center;
    background-size: contain;
    width: 72rem;
    height: 19.3rem;
    margin-top: 6rem;
    margin-bottom: 8rem;
  }
  #dream .dr_member {
    width: 71rem;
    position: relative;
    background: url(../images/dr_bg_sp.svg) no-repeat top left;
    background-size: contain;
    padding-top: 1rem;
    padding-left: 1rem;
    padding-right: 3rem;
    padding-bottom: 3rem;
  }
  #dream .dr_member li {
    width: 33rem;
    height: 33rem;
  }
  #dream .dr_member li:nth-child(-n+4) {
    margin-bottom: 1rem;
  }
  #dream .name_wrap {
    width: 22.9rem;
  }
  #dream .tei {
    width: 9.1rem;
    height: 9.1rem;
    font-size: 5.4rem;
  }
  #dream .tei span {
    font-size: 2.2rem;
  }
  #dream .tei::after {
    width: 7.4rem;
    height: 7.4rem;
  }
  #dream .member {
    font-size: 2.3rem;
  }
  #dream .member .name {
    font-size: 3.4rem;
  }
  #dream .member .class {
    font-size: 1.8rem;
  }
  #dream .seiseki {
    width: 13.1rem;
    height: 13.3rem;
  }
  #dream .kome {
    width: 70rem;
    font-size: 2rem;
    margin-top: 1.5rem;
  }
  #dream .choco .clock {
    width: 14rem;
    height: 16rem;
    top: 151rem;
    left: 2rem;
  }
  #dream .choco .heart {
    width: 12.5rem;
    height: 11.2rem;
    top: 32rem;
    left: 1rem;
  }
  #dream .choco .pstar {
    width: 16.5rem;
    height: 14rem;
    top: 32.5rem;
    right: 0rem;
  }
}
/***********************************************************************
ラージデバイス (デスクトップ) のスタイル
**********************************************************************/
@media screen and (min-width: 751px) {
  .pc_non {
    display: none !important;
  }
  #top .namelabel {
    justify-content: flex-end !important;
    /*background: url(../images/tit_sub.svg) no-repeat center left 5rem ,#00000080;*/
    background-size: 25rem;
    font-size: 4.4rem;
    width: 66rem;
    height: 8rem;
    padding: 0 10rem 0 5rem;
  }
  #top .top_wrap {
    justify-content: flex-start;
    width: 116rem;
    height: 70rem;
    background: url(../images/top_bg.png) no-repeat center right;
    background-size: contain;
  }
  #top .top_wrap::before {
    width: 28rem;
    height: 19.5rem;
  }
  #top .tit_wrap {
    margin-left: 11rem;
    margin-bottom: 4rem;
    padding-top: 5rem;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
    padding-bottom: 4rem;
  }
  #top .tit_wrap .tit {
    width: 59.5rem;
    height: 20.8rem;
  }
  #top .tit_wrap .tit_sub {
    width: 37.5rem;
    height: 6.6rem;
  }
  #top .tit_wrap .tit_day {
    width: 63rem;
    height: 5.2rem;
    margin-top: 1.5rem;
  }
  #top .top_btn li .sub {
    padding: 0 1rem;
    left: 0;
    height: 12rem;
    flex-shrink: 0;
    line-height: 3rem;
  }
  #top .top_btn li:nth-child(1) {
    background: url(../images/top_btn1.png) no-repeat center;
    background-size: contain;
    width: 51rem;
    height: 20rem;
    margin-left: 5rem;
    margin-right: 3rem;
  }
  #top .top_btn li:nth-child(2) {
    background: url(../images/top_btn2.png) no-repeat center;
    background-size: contain;
    width: 40rem;
    height: 20rem;
  }
  #top .top_btn li:nth-child(2) .sub {
    line-height: 4rem;
  }
  #top .top_btn li:nth-child(2) .sub p {
    font-size: 2.6rem;
  }
  #top .top_btn li:nth-child(2) .sub p span {
    font-size: 3rem;
  }
  #top .top_btn li a {
    justify-content: flex-end;
    padding-right: 3rem;
    padding-bottom: 1rem;
    font-size: 3.8rem;
    font-family: "Noto Serif JP", serif;
    font-weight: 900;
  }
  #top .top_btn li a span {
    font-size: 2.8rem;
  }
  #topic {
    padding: 3rem 0;
  }
  #topic .splide__track {
    width: 170rem;
    margin: auto;
  }
  #topic .splide__slide {
    width: 38.6rem;
    height: 22.8rem;
  }
  #dream {
    padding-top: 20rem;
  }
  #dream .tit {
    background: url(../images/dr_tit.svg) no-repeat center;
    background-size: contain;
    width: 98.6rem;
    height: 19.8rem;
    margin-bottom: 5rem;
  }
  #dream .dr_member {
    width: 122rem;
    position: relative;
    left: -2rem;
    z-index: 1;
  }
  #dream .dr_member::before {
    content: "";
    display: inline-block;
    position: absolute;
    background: url(../images/dr_lace.png) no-repeat top center;
    background-size: contain;
    width: 168.5rem;
    height: 94.6rem;
    top: 0;
    left: -17rem;
    z-index: -1;
    pointer-events: none;
  }
  #dream .dr_member::after {
    content: "";
    display: inline-block;
    background: url(../images/dr_bg_pc.svg) no-repeat top left;
    background-size: contain;
    width: calc(100% + 2rem);
    height: calc(100% + 3.5rem);
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    pointer-events: none;
  }
  #dream .dr_member li {
    width: 38rem;
    height: 38rem;
  }
  #dream .dr_member li:nth-child(-n+3) {
    margin-bottom: 1rem;
  }
  #dream .tei {
    width: 10.5rem;
    height: 10.5rem;
    font-size: 6.3rem;
  }
  #dream .tei span {
    font-size: 2.6rem;
  }
  #dream .tei::after {
    width: 8.5rem;
    height: 8.5rem;
  }
  #dream .member {
    width: 26.5rem;
    font-size: 2.5rem;
  }
  #dream .member .name {
    font-size: 4rem;
  }
  #dream .member .class {
    font-size: 2rem;
  }
  #dream .photo {
    width: 38rem;
    height: 26.5rem;
  }
  #dream .seiseki {
    width: 13.8rem;
    height: 13.9rem;
  }
  #dream .kome {
    margin-top: 4rem;
    margin-bottom: 3rem;
    width: 120rem;
    font-size: 1.8rem;
  }
  #dream .choco .clock {
    width: 20rem;
    height: 23rem;
    top: 40rem;
    left: 5rem;
  }
  #dream .choco .heart {
    width: 14rem;
    height: 12.5rem;
    top: 92rem;
    left: 15rem;
  }
  #dream .choco .pstar {
    width: 27rem;
    height: 23rem;
    top: 108rem;
    right: 4.5rem;
  }
}
@keyframes choco {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(25deg);
  }
}/*# sourceMappingURL=index.css.map */