:root {
  --maincolor: #121659;
  --white: #fff;
  --black: #000;
  --notojp: "Noto Sans JP", sans-serif;
  --roboto: "Roboto", sans-serif;
  font-size: 10px;
}

@media screen and (max-width: 1200px) {
  :root {
    font-size: calc(100vw * 10 / 1200);
  }
}

@media screen and (max-width: 767px) {
  :root {
    font-size: calc(100vw * 10 / 375);
  }
}

.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

body {
  background-color: var(--maincolor);
  color: var(--textcolor);
  font-family: var(--notojp);
  font-size: 1.4rem;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  letter-spacing: normal;
  line-height: 1.6;
  -webkit-text-size-adjust: 100%;
     -moz-text-size-adjust: 100%;
      -ms-text-size-adjust: 100%;
          text-size-adjust: 100%;
  word-wrap: break-word;
  overflow-wrap: break-word;
  overflow-x: hidden;
  opacity: 0;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}

body.show {
  opacity: 1;
}

#header {
  padding: 0;
  background-color: var(--maincolor);
}

#header .outer {
  width: 75rem;
  margin: 0 auto;
  position: relative;
}

#header .outer .inner {
  width: 100%;
  height: 61.86rem;
  position: relative;
  font-size: 0;
}

#header .outer .inner h1 {
  position: absolute;
  width: 44.99rem;
  top: 9.8rem;
  left: 0;
  z-index: 3;
}

#header .outer .inner #subcopy {
  position: absolute;
  width: 64.2rem;
  top: 41rem;
  left: 0;
  z-index: 2;
}

#header .outer .inner #heroimg {
  position: absolute;
  width: 90rem;
  width: 59.49rem;
  right: 0;
  bottom: 0;
  z-index: 1;
}

#header .outer .inner #heroimg .hero-slide {
  display: block;
  position: absolute;
  right: 0;
  bottom: 0;
  opacity: 0;
  -webkit-transition: opacity 1s ease-in-out;
  transition: opacity 1s ease-in-out;
}

#header .outer .inner #heroimg .hero-slide.active {
  opacity: 1;
}

@media (max-width: 767px) {
  #header .outer {
    width: auto;
    padding: 0;
  }
  #header .outer .inner {
    height: 53.6rem;
  }
  #header .outer .inner h1 {
    width: 28.4rem;
    top: 8rem;
    left: 3rem;
  }
  #header .outer .inner #subcopy {
    width: 20.4rem;
    top: 31.4rem;
    left: 3rem;
  }
  #header .outer .inner #heroimg {
    width: 32rem;
  }
}

#sec1 {
  padding: 0;
  background-color: var(--maincolor);
}

#sec1 .outer {
  padding: 18.7rem 0 18.4rem;
}

#sec1 .outer .inner {
  width: 87rem;
  margin: 0 auto;
}

#sec1 .outer .inner h2 {
  width: 53.3rem;
  margin: 0 auto 8.9rem;
}

#sec1 .outer .inner p {
  width: 68.1rem;
  margin: 0 auto;
}

@media (max-width: 767px) {
  #sec1 .outer {
    padding: 12.4rem 0 11.7rem;
  }
  #sec1 .outer .inner {
    width: 31.5rem;
  }
  #sec1 .outer .inner h2 {
    width: 22.4rem;
    margin: 0 auto 4.6rem;
  }
  #sec1 .outer .inner p {
    width: 28.6rem;
    margin: 0 auto;
  }
}

#sec2 {
  padding: 0;
  background-color: var(--white);
}

#sec2 .outer {
  padding: 18.6rem 0 16.5rem;
}

#sec2 .outer .inner {
  position: relative;
}

#sec2 .outer .inner .award {
  width: 60.6rem;
  margin: 0 auto 9.3rem;
  line-height: 0;
}

#sec2 .outer .inner .award h2 {
  margin: 0 auto 2.9rem;
}

#sec2 .outer .inner .award ul {
  margin: 0 auto 3.2rem;
}

#sec2 .outer .inner .award .name {
  margin: 0 auto 1.3rem;
}

#sec2 .outer .inner .award .awardtext {
  width: 60.3rem;
  margin: 0 auto 3.6rem;
}

#sec2 .outer .inner .award h3 {
  width: 23.6rem;
  margin: 0 auto 0.58rem;
}

#sec2 .outer .inner .award .awardcomment {
  width: 60.3rem;
  margin: 0 auto;
  padding-bottom: 9.23rem;
  background: url(/images/bdr_award.svg) no-repeat 50% 100%;
}

#sec2 .outer .inner .award.a01 h2 {
  width: 19.1rem;
}

#sec2 .outer .inner .award.a01 .name {
  width: 35.5rem;
}

#sec2 .outer .inner .award.a02 h2 {
  width: 20.7rem;
}

#sec2 .outer .inner .award.a02 .name {
  width: 29.4rem;
}

#sec2 .outer .inner .award.a03 {
  margin-bottom: 9.23rem;
}

#sec2 .outer .inner .award.a03 h2 {
  width: 49.3rem;
}

#sec2 .outer .inner .award.a03 ul {
  width: 46.4rem;
}

#sec2 .outer .inner .award.a03 .name {
  width: 44.3rem;
}

#sec2 .outer .inner .award.a03 .awardcomment {
  background: none;
  padding-bottom: 0;
}

#sec2 .outer .inner .award.a04 h2 {
  width: 49.3rem;
}

#sec2 .outer .inner .award.a04 .name {
  width: 30.2rem;
}

#sec2 .outer .inner .award.a05 {
  margin-bottom: 9.23rem;
}

#sec2 .outer .inner .award.a05 h2 {
  width: 37.8rem;
}

#sec2 .outer .inner .award.a05 .name {
  width: 30.2rem;
}

#sec2 .outer .inner .award.a05 .awardcomment {
  background: none;
  padding-bottom: 0;
}

#sec2 .outer .inner .award.a06 {
  margin-bottom: 3.2rem;
}

#sec2 .outer .inner .award.a06 .name {
  width: 51.2rem;
}

#sec2 .outer .inner .award.a06 .awardcomment {
  background: none;
}

#sec2 .outer .inner .award.a06 .awardcaution {
  width: 50rem;
  margin: 0 auto;
}

#sec2 .outer .inner .award.grandprix {
  width: 101.2rem;
  margin: 0 auto 9.3rem;
}

#sec2 .outer .inner .award.grandprix h1 {
  width: 42.5rem;
  margin: 0 auto 9rem;
}

#sec2 .outer .inner .award.grandprix h2 {
  width: 60.5rem;
  margin: 0 auto 2.9rem;
}

#sec2 .outer .inner .award.grandprix ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin: 0 auto 2.9rem;
}

#sec2 .outer .inner .award.grandprix ul li {
  width: 49.6rem;
}

#sec2 .outer .inner .award.grandprix .name {
  width: 35.1rem;
  margin: 0 auto 1.4rem;
}

#sec2 .outer .inner .award.grandprix .awardtext {
  width: 60.3rem;
  margin: 0 auto 3.85rem;
}

#sec2 .outer .inner .award.grandprix h3 {
  width: 23.6rem;
  margin: 0 auto 0.71rem;
}

#sec2 .outer .inner .award.grandprix .awardcomment {
  width: 60.3rem;
  margin: 0 auto;
  padding-bottom: 7.13rem;
  background: url(/images/bdr_award.svg) no-repeat 50% 100%;
}

#sec2 .outer .inner #summary {
  margin-bottom: 4.9rem;
}

#sec2 .outer .inner #summary li {
  margin-bottom: 1.1rem;
  line-height: 0;
}

#sec2 .outer .inner .btns {
  line-height: 0;
  position: relative;
  width: 12.5rem;
}

#sec2 .outer .inner .btns a {
  display: block;
  cursor: pointer;
}

#sec2 .outer .inner .btns a img {
  height: auto;
  left: 0;
  position: absolute;
  width: 100%;
}

#sec2 .outer .inner .btns a .hover {
  opacity: 0;
  -webkit-transition: opacity .3s ease-out;
  transition: opacity .3s ease-out;
}

#sec2 .outer .inner .btns a:hover img {
  opacity: 1;
}

#sec2 .outer .inner #term {
  position: absolute;
  right: 0.1rem;
  top: 9.8rem;
}

#sec2 .outer .inner #termsp {
  display: none;
}

#sec2 .outer .inner #application {
  position: absolute;
  right: 0.1rem;
  top: 27.8rem;
}

#sec2 .outer .inner #application ul li {
  position: relative;
  height: 2.4rem;
  margin-bottom: 0.25rem;
  line-height: 0;
}

#sec2 .outer .inner #applicationsp {
  display: none;
}

#sec2 .outer .judges {
  width: 66.66rem;
  margin: auto;
}

#sec2 .outer .judges h2 {
  width: 8.2rem;
  margin: 0 auto 1.4rem;
}

#sec2 .outer .judges .flex {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

#sec2 .outer .judges .flex li {
  width: 21.3rem;
}

@media (max-width: 767px) {
  #sec2 .outer {
    padding: 12.3rem 0 4.7rem;
  }
  #sec2 .outer .inner {
    width: 31.0rem;
    margin: 0 auto;
  }
  #sec2 .outer .inner .award {
    width: 31.0rem;
    margin: 0 auto 4.9rem;
  }
  #sec2 .outer .inner .award h2 {
    margin: 0 auto 2.3rem;
  }
  #sec2 .outer .inner .award ul {
    margin: 0 auto 2.4rem;
  }
  #sec2 .outer .inner .award .name {
    margin: 0 auto 2.4rem;
  }
  #sec2 .outer .inner .award .awardtext {
    width: 31.0rem;
    margin: 0 auto 2.4rem;
  }
  #sec2 .outer .inner .award h3 {
    width: 18.9rem;
    margin: 0 auto 1.3rem;
  }
  #sec2 .outer .inner .award .awardcomment {
    width: 31.0rem;
    margin: 0 auto;
    padding-bottom: 4.95rem;
    background: url(/images/bdr_award_sp.svg) no-repeat 50% 100%;
  }
  #sec2 .outer .inner .award.a01 h2 {
    width: 13.8rem;
  }
  #sec2 .outer .inner .award.a01 .name {
    width: 28.4rem;
  }
  #sec2 .outer .inner .award.a02 h2 {
    width: 14.6rem;
  }
  #sec2 .outer .inner .award.a02 .name {
    width: 23.5rem;
  }
  #sec2 .outer .inner .award.a03 {
    margin-bottom: 4.95rem;
  }
  #sec2 .outer .inner .award.a03 h2 {
    width: 30.7rem;
  }
  #sec2 .outer .inner .award.a03 ul {
    width: 22.3rem;
  }
  #sec2 .outer .inner .award.a03 .name {
    width: 31.0rem;
  }
  #sec2 .outer .inner .award.a03 .awardcomment {
    background: none;
    padding-bottom: 0;
  }
  #sec2 .outer .inner .award.a04 .name {
    width: 24.2rem;
  }
  #sec2 .outer .inner .award.a05 {
    margin-bottom: 4.95rem;
  }
  #sec2 .outer .inner .award.a05 h2 {
    width: 26.6rem;
  }
  #sec2 .outer .inner .award.a05 .name {
    width: 24.2rem;
  }
  #sec2 .outer .inner .award.a05 .awardcomment {
    background: none;
    padding-bottom: 0;
  }
  #sec2 .outer .inner .award.a06 {
    margin-bottom: 4.7rem;
  }
  #sec2 .outer .inner .award.a06 .name {
    width: 28.0rem;
  }
  #sec2 .outer .inner .award.a06 .awardcomment {
    background: none;
    padding-bottom: 5.7rem;
  }
  #sec2 .outer .inner .award.a06 .awardcaution {
    width: 27rem;
    margin: 0 auto;
  }
  #sec2 .outer .inner .award.grandprix {
    width: 31.0rem;
    margin: 0 auto 4.95rem;
  }
  #sec2 .outer .inner .award.grandprix h1 {
    width: 20.4rem;
    margin: 0 auto 7.5rem;
  }
  #sec2 .outer .inner .award.grandprix h2 {
    width: 26.7rem;
    margin: 0 auto 2.23rem;
  }
  #sec2 .outer .inner .award.grandprix ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin: 0 auto 2.47rem;
  }
  #sec2 .outer .inner .award.grandprix ul li {
    width: 31.0rem;
    margin-bottom: 0.45rem;
  }
  #sec2 .outer .inner .award.grandprix ul li:last-child {
    margin-bottom: 0;
  }
  #sec2 .outer .inner .award.grandprix .name {
    width: 28.1rem;
    margin: 0 auto 2.47rem;
  }
  #sec2 .outer .inner .award.grandprix .awardtext {
    width: 31.0rem;
    margin: 0 auto 2.47rem;
  }
  #sec2 .outer .inner .award.grandprix h3 {
    width: 18.9rem;
    margin: 0 auto 1.44rem;
  }
  #sec2 .outer .inner .award.grandprix .awardcomment {
    width: 31.0rem;
    margin: 0 auto;
    padding-bottom: 4.93rem;
    background: url(/images/bdr_award_sp.svg) no-repeat 50% 100%;
  }
  #sec2 .outer .inner #summary li {
    margin-bottom: 1.5rem;
  }
  #sec2 .outer .inner .btns {
    display: none;
  }
  #sec2 .outer .inner #termsp {
    position: absolute;
    right: 0;
    top: 35.6rem;
    width: 31.5rem;
    display: block;
  }
  #sec2 .outer .inner #applicationsp {
    position: absolute;
    right: 0;
    top: 73.4rem;
    width: 31.5rem;
    display: block;
  }
  #sec2 .outer .inner #applicationsp ul li {
    position: relative;
    height: 3rem;
    margin-bottom: 0.8rem;
  }
  #sec2 .outer .judges h2 {
    width: 9.5rem;
    margin: 0 auto 1.4rem;
  }
  #sec2 .outer .judges .flex {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  #sec2 .outer .judges .flex li {
    width: 100%;
    margin-bottom: 2rem;
  }
}

#sec3 {
  padding: 0;
  background-color: var(--maincolor);
}

#sec3 .outer {
  padding: 18rem 0;
}

#sec3 .outer .inner {
  width: 90.6rem;
  margin: 0 auto;
  line-height: 0;
}

#sec3 .outer .inner h2 {
  width: 27.8rem;
  margin: 0 auto 2.3rem;
}

#sec3 .outer .inner h3 {
  width: 48.6rem;
  margin: 0 auto 1.5rem;
}

#sec3 .outer .inner p {
  width: 51.7rem;
  margin: 0 auto 4rem;
}

#sec3 .outer .inner ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  width: 90.6rem;
  -ms-flex-line-pack: justify;
      align-content: space-between;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 3rem;
}

#sec3 .outer .inner ul li {
  width: 28.1rem;
  height: 5rem;
  position: relative;
}

#sec3 .outer .inner ul li:nth-child(3) {
  margin-right: 0;
}

#sec3 .outer .inner ul li:nth-child(4) {
  margin-bottom: 0;
}

#sec3 .outer .inner ul li:nth-child(5) {
  margin-bottom: 0;
}

#sec3 .outer .inner ul li a {
  display: block;
  cursor: pointer;
}

#sec3 .outer .inner ul li a img {
  height: auto;
  left: 0;
  position: absolute;
  width: 100%;
}

#sec3 .outer .inner ul li a .hover {
  opacity: 0;
  -webkit-transition: opacity .3s ease-out;
  transition: opacity .3s ease-out;
}

#sec3 .outer .inner ul li a:hover img {
  opacity: 1;
}

@media (max-width: 767px) {
  #sec3 .outer {
    padding: 12.5rem 0 12.8rem;
  }
  #sec3 .outer .inner {
    width: 31.5rem;
  }
  #sec3 .outer .inner h2 {
    width: 14.4rem;
    margin: 0 auto 1.4rem;
  }
  #sec3 .outer .inner h3 {
    width: 28.1rem;
    margin: 0 auto 1.2rem;
  }
  #sec3 .outer .inner p {
    width: 30.9rem;
    margin: 0 auto 3rem;
  }
  #sec3 .outer .inner ul {
    display: block;
    width: 31.1rem;
    margin: 0 auto;
  }
  #sec3 .outer .inner ul li {
    width: 31.1rem;
    height: 3rem;
    margin: 0 auto 1.6rem;
  }
  #sec3 .outer .inner ul li:nth-child(4) {
    margin-bottom: 1.6rem;
  }
  #sec3 .outer .inner ul li a {
    display: block;
    cursor: pointer;
  }
  #sec3 .outer .inner ul li a img {
    height: auto;
    left: 0;
    position: absolute;
    width: 100%;
  }
  #sec3 .outer .inner ul li a .hover {
    display: none;
  }
}

#footer {
  background-color: var(--white);
  padding: 8.7rem 0;
}

#footer .outer .inr p {
  width: 22rem;
  margin: 0 auto;
}

@media (max-width: 767px) {
  #footer {
    padding: 3rem 0;
  }
  #footer .outer .inr p {
    width: 12rem;
  }
}
/*# sourceMappingURL=common.css.map */