#wrap {
  color: #fff;
}

.pc {
  display: block;
}

.sp {
  display: none;
}

img {
  width: 100%;
  max-width: 100%;
  vertical-align: bottom;
}

.flex {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}

section .inner {
  max-width: 920px;
  margin: 0 auto;
}

header {
  background-color: #001f3c;
}
header .inner {
  max-width: 1200px;
  justify-content: space-between;
  padding: 20px 30px;
  box-sizing: border-box;
}
header h1 {
  max-width: 429px;
  width: 46%;
}
header ul {
  width: 54%;
  justify-content: flex-end;
}
header ul li {
  font-weight: 700;
  padding-left: 7%;
  font-size: 18px;
}
header ul li span {
  color: #02a7e9;
  border-bottom: 2px solid #02a7e9;
}
header ul li a {
  color: #fff;
}
header ul li a.gold {
  color: #d7b061;
}

#kv {
  background-color: #000;
  background-image: url("../images/bg_kv_left.png"), url("../images/bg_kv_right.png");
  background-position: 0 0, right bottom;
  background-repeat: no-repeat;
  padding-bottom: 95px;
}
#kv .inner {
  max-width: 1360px;
  margin: 0 auto;
  padding: 130px 20px 85px;
  justify-content: space-between;
}
#kv .inner .left {
  max-width: 626px;
  width: 46%;
}
#kv .inner .right {
  max-width: 611px;
  width: 45%;
}
#kv .inner .right a {
  display: block;
  max-width: 276px;
  margin-top: 30px;
}
#kv .inner .right a:hover {
  opacity: 0.8;
  transition: .2s;
}
#kv .logo {
  max-width: 288px;
  margin: 0 auto;
}
#kv .message {
  padding-top: 20px;
  font-weight: 700;
  font-size: 24px;
}

#about {
  background-color: #001f3c;
  padding: 70px 20px;
}
#about h2 {
  max-width: 397px;
  margin-bottom: 30px;
}
#about article {
  padding-left: 18%;
  font-weight: 700;
}
#about article p {
  margin-bottom: 30px;
  font-size: 18px;
}
#about article dl {
  padding-top: 10px;
  border-bottom: 1px solid #02a7e9;
  padding-bottom: 10px;
  margin-bottom: 10px;
}
#about article dl dt {
  width: 15%;
  color: #02a7e9;
}
#about article dl dd {
  width: 85%;
}

#speaker {
  background-color: #000;
  padding: 110px 20px 90px;
}
#speaker h2 {
  max-width: 521px;
  float: right;
}
#speaker .flex {
  clear: both;
  justify-content: space-between;
  align-items: start;
}
#speaker .flex .left {
  max-width: 278px;
  width: 30%;
}
#speaker .flex .right {
  max-width: 600px;
  width: 65%;
}
#speaker .flex .right .small {
  color: #02a7e9;
  font-size: 14px;
}
#speaker .flex .right .title, #speaker .flex .right .b-title {
  font-size: 18px;
  margin-bottom: 20px;
}
#speaker .flex .right .name {
  font-size: 18px;
}

#timetable {
  background-color: #001f3c;
  padding: 80px 20px;
}
#timetable .inner {
  max-width: 1024px;
}
#timetable .flex {
  align-items: start;
  justify-content: space-between;
}
#timetable .flex .left {
  max-width: 393px;
  width: 38.3%;
}
#timetable .flex .right {
  max-width: 585px;
  width: 57.1%;
}
#timetable .flex .right dl {
  display: flex;
  flex-wrap: wrap;
  border: 1px solid #02a7e9;
  width: 100%;
  padding: 20px;
  margin-bottom: 20px;
  font-weight: 700;
  box-sizing: border-box;
}
#timetable .flex .right dl dt {
  color: #02a7e9;
  font-size: 24px;
  line-height: 1.3;
  width: 20%;
}
#timetable .flex .right dl dd {
  width: 80%;
  font-size: 18px;
}

footer {
  padding: 50px 0;
}
footer p {
  max-width: 207px;
  margin: 0 auto;
}

#award {
  background-color: #000;
  padding: 90px 0;
}
#award .inner {
  max-width: 1200px;
  padding: 0 20px;
}
#award h2 {
  max-width: 392px;
  margin: 0 auto 70px;
}
#award h3 {
  text-align: center;
}
#award .block {
  margin-bottom: 50px;
  padding-bottom: 50px;
  background-color: #282843;
}
#award .block h4 {
  font-size: 24px;
  font-weight: 700;
}
#award .block.typeA {
  min-height: 650px;
  background-image: url(../images/bg_gold_left.png), url(../images/bg_gold_right.png), url(../images/bg_bottom.png);
  background-repeat: no-repeat;
  background-position: 0 bottom, right bottom, 0 bottom;
}
#award .block.typeA h4 {
  padding: 40px 0 20px;
}
#award .block.typeA .title {
  margin-top: 40px;
}
#award .block.typeB {
  min-height: 570px;
  background-image: url(../images/bg_silver_left.png), url(../images/bg_silver_right.png), url(../images/bg_bottom.png);
  background-repeat: no-repeat;
  background-position: 0 bottom, right bottom, 0 bottom;
}
#award .block.typeB h4 {
  padding: 40px 0 10px;
}
#award .block.typeB .title {
  margin-top: 20px;
}
#award .block.typeC {
  min-height: 510px;
  background-image: url(../images/bg_bronze_left.png), url(../images/bg_bronze_right.png), url(../images/bg_bottom.png);
  background-repeat: no-repeat;
  background-position: 0 bottom, right bottom, 0 bottom;
}
#award .block.typeC h4 {
  padding: 40px 0 10px;
}
#award .block.typeC .title {
  margin-top: 20px;
}
#award .block:last-child {
  margin-bottom: 0;
}
#award .box {
  max-width: 910px;
  margin: 0 auto;
  padding: 0 20px;
}
#award .box .comment {
  font-size: 18px;
  line-height: 1.4;
  padding-bottom: 20px;
}
#award .box .title {
  font-weight: 700;
}
#award .box .text {
  line-height: 1.4;
}
#award .flex {
  align-items: start;
  justify-content: space-between;
}
#award .flex .left {
  max-width: 640px;
  width: 70%;
}
#award .flex .right {
  max-width: 240px;
  width: 30%;
}

@media screen and (min-width: 769px) and (max-width: 1000px) {
  header ul li {
    font-size: 1.5vw;
  }

  #about article {
    padding-left: 0;
  }

  #award .box .comment {
    font-size: 16px;
  }

  #award .box .text {
    font-size: 14px;
  }
}
@media screen and (max-width: 768px) {
  .pc {
    display: none;
  }

  .sp {
    display: block;
  }

  .flex {
    flex-direction: column;
  }

  header {
    position: relative;
  }
  header .inner {
    display: none;
    padding-bottom: 0;
    position: fixed;
    width: 100%;
    left: 0;
    top: 0;
    z-index: 99;
    background-color: #001f3c;
  }
  header ul {
    width: 100%;
  }
  header ul li {
    margin-right: 0;
    margin-bottom: 20px;
  }
  header ul li a {
    display: block;
  }

  .h-btn {
    position: absolute;
    top: 10px;
    right: 10px;
  }

  .menu-trigger,
  .menu-trigger span {
    display: inline-block;
    transition: all .4s;
    box-sizing: border-box;
  }

  .menu-trigger {
    position: relative;
    z-index: 99;
    width: 30px;
    height: 24px;
    background: none;
    border: none;
    appearance: none;
    cursor: pointer;
  }

  .menu-trigger span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #02a7e9;
    border-radius: 4px;
  }

  .menu-trigger span:nth-of-type(1) {
    top: 0;
  }

  .menu-trigger span:nth-of-type(2) {
    top: 10px;
  }

  .menu-trigger span:nth-of-type(3) {
    bottom: 2px;
  }

  .menu-trigger.active span:nth-of-type(1) {
    transform: translateY(10px) rotate(-45deg);
  }

  .menu-trigger.active span:nth-of-type(2) {
    opacity: 0;
  }

  .menu-trigger.active span:nth-of-type(3) {
    transform: translateY(-10px) rotate(45deg);
  }

  #kv {
    background-image: url("../images/bg_kv_top_sp.png"), url("../images/bg_kv_bottom_sp.png");
    background-size: contain;
    padding-bottom: 65px;
  }
  #kv .inner {
    padding: 50px 0 20px;
  }
  #kv .inner .left {
    max-width: 230px;
    margin-bottom: 30px;
    width: 100%;
  }
  #kv .inner .right {
    max-width: 306px;
    width: 100%;
  }
  #kv .inner .right a {
    max-width: 309px;
    margin: 30px auto 0;
  }
  #kv .logo {
    max-width: 144px;
  }
  #kv .message {
    padding-top: 10px;
    font-size: 5vw;
  }

  #about {
    padding: 35px 4vw;
  }
  #about h2 {
    max-width: 185px;
    margin-bottom: 25px;
  }
  #about article {
    padding-left: 0;
    font-weight: 700;
  }
  #about article p {
    margin-bottom: 20px;
    font-size: 3.8vw;
  }
  #about article dl {
    flex-direction: row;
    align-items: start;
  }
  #about article dl dt {
    width: 20%;
    font-size: 3.8vw;
  }
  #about article dl dd {
    width: 80%;
    font-size: 3.8vw;
  }

  #speaker {
    padding: 35px 4vw;
  }
  #speaker h2 {
    max-width: 243px;
    margin-bottom: 15px;
  }
  #speaker .flex {
    flex-direction: row;
  }
  #speaker .flex .left {
    width: 45%;
  }
  #speaker .flex .right {
    width: 53%;
  }
  #speaker .flex .right .small {
    font-size: 3vw;
  }
  #speaker .flex .right .title, #speaker .flex .right .name {
    font-size: 4vw;
    font-weight: 700;
  }
  #speaker .flex .right .title {
    margin-bottom: 10px;
  }
  #speaker .flex .right .b-title {
    font-size: 3.4vw;
    margin-bottom: 10px;
  }
  #speaker .text {
    font-size: 3.8vw;
  }

  #timetable {
    padding: 40px 4vw 20px;
  }
  #timetable h2 {
    max-width: 295px;
    margin-bottom: 20px;
  }
  #timetable .flex .left {
    width: 100%;
    max-width: 100%;
  }
  #timetable .flex .right {
    width: 100%;
    max-width: 100%;
  }
  #timetable .flex .right dl {
    padding: 10px 4vw;
  }
  #timetable .flex .right dl dt {
    width: 25%;
    font-size: 5vw;
    padding-right: 0;
  }
  #timetable .flex .right dl dd {
    width: 75%;
    font-size: 3.8vw;
  }

  footer {
    padding: 20px 0 30px;
  }
  footer p {
    max-width: 104px;
  }

  #award {
    padding: 40px 0;
  }
  #award .inner {
    padding: 0;
  }
  #award h2 {
    max-width: 196px;
    margin: 0 auto 20px;
  }
  #award .block {
    margin: 0 4vw 20px;
    padding-bottom: 7px;
  }
  #award .block h4 {
    font-size: 5vw;
  }
  #award .block.typeA {
    background: url(../images/bg_award01_sp.png) no-repeat center bottom;
    background-size: contain;
    min-height: auto;
  }
  #award .block.typeA h3 {
    padding: 0;
  }
  #award .block.typeA h4 {
    padding: 0 0 10px;
  }
  #award .block.typeB {
    background: url(../images/bg_award02_sp.png) no-repeat center bottom;
    min-height: auto;
  }
  #award .block.typeB h3 {
    padding: 0;
  }
  #award .block.typeB h4 {
    padding: 0 0 10px;
  }
  #award .block.typeC {
    background: url(../images/bg_award03_sp.png) no-repeat center bottom;
    min-height: auto;
  }
  #award .block.typeC h3 {
    padding: 0;
  }
  #award .block.typeC h4 {
    padding: 0 0 10px;
  }
  #award .block:last-child {
    margin-bottom: 0;
  }
  #award .box {
    background-color: #282843;
    padding: 20px 4vw;
  }
  #award .box .comment {
    font-size: 3.8vw;
    padding-bottom: 10px;
  }
  #award .box .title {
    font-size: 3.8vw;
    margin: 10px 0 5px;
  }
  #award .box .text {
    font-size: 3.2vw;
  }
  #award .flex .left {
    width: 100%;
    max-width: 100%;
  }
  #award .flex .left .comment img {
    width: 40%;
    float: right;
    padding: 0 0 10px 10px;
  }
  #award .flex .right {
    width: 100%;
    max-width: 100%;
  }
}
