@charset "utf-8";
body {
  font: 16px/1.6 "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  width: 100%;
  position: relative;
  background: url(../img/_bg.jpg) no-repeat fixed center top;
  background-size: 100% auto;
}
body img {
  width: 100%;
}
body .fixedheader {
  position: fixed;
  top: 0;
  z-index: 999;
  background-color: rgba(255, 255, 255, 0.9);
  padding: 5px 0;
  width: 100%;
}
body .fixedheader .logo {
  font-size: 0;
  text-align: center;
}
body .fixedheader .logo .item {
  display: inline-block;
  vertical-align: middle;
}
body .fixedheader .logo .item .anc .logoimg {
  width: 100%;
  height: auto;
}
body .fixedheader .logo .item .anc .logoimg:hover {
  background-color: none;
}
body .fixedheader .logo .kakeru {
  width: 5%;
}
body .fixedheader .logo .kakeru:after {
  content: "×";
  display: inline-block;
  font-size: 2vw;
  font-weight: bold;
  text-align: center;
}
section {
  padding: 16vw 0;
}
.subhead {
  font-size: 8vw;
  line-height: 1;
  padding: 0 3%;
  text-align: center;
}
.fixedheader .logo .item {
  width: 25%;
}
.fixedheader .logo .kakeru {
  width: 5%;
}
.fixedheader .logo .kakeru:after {
  content: "×";
  display: inline-block;
  font-weight: bold;
  text-align: center;
}
.section1 {
  padding-top: 0;
  padding-bottom: 6vw;
  position: relative;
  min-height: 132vw;
}
.section1 .mainvisual {
  width: 100%;
  height: 60vw;
  background: url(../img/_bg_mainvisual.jpg) no-repeat center top;
  background-size: 100% auto;
  position: absolute;
  top: 0;
}
.section1 .mainvisual .maintitle,
.section1 .mainvisual .specialtitle {
  width: 100%;
  margin: auto;
  right: 0;
  left: 0;
  position: absolute;
}
.section1 .mainvisual .maintitle {
  top: 12vw;
  text-align: left;
  margin-left: 2vw;
}
.section1 .mainvisual .maintitle img {
  margin-right: 5%;
  width: 70%;
}
.section1 .mainvisual .specialtitle {
  position: relative;
  top: 50vw;
}
.section1 .leadtext {
  position: relative;
  width: 90%;
  margin: auto;
  top: 86vw;
  right: 0;
  left: 0;
  font-size: 3.75vw;
}
.section2 {
  background-color: #fff433;
}
.section2 .subhead {
  color: #007b65;
}
.booth-list,
.booth-list2 {
  font-size: 0;
  text-align: center;
  width: 96%;
  margin: 6vw auto 0;
}
.booth-list .item,
.booth-list2 .item {
  display: inline-block;
  vertical-align: top;
  margin: 4vw auto 0;
  width: 80%;
}
.booth-list .item .anc,
.booth-list2 .item .anc {
  display: block;
  position: relative;
  width: 100%;
}
.booth-list .item .anc .figure,
.booth-list2 .item .anc .figure {
  width: 94%;
  height: 40vw;
  margin: auto;
  background: url() no-repeat center center;
  background-size: cover;
  background-color: #fff;
}
.booth-list .item .anc .booth-title,
.booth-list2 .item .anc .booth-title {
  width: 100%;
  height: 1.8em;
  overflow: hidden;
  padding: 8px 20px 6px;
  box-sizing: border-box;
  background: #c0dd8d url(../img/name_decorate.png) no-repeat center center;
  background-size: contain;
  color: #007b65;
  -webkit-box-shadow: 0 1px 0 0 #000;
  box-shadow: 0 1px 0 0 #007b65;
  font-size: 3.8vw;
  line-height: 1;
  text-align: left;
  position: absolute;
  white-space: nowrap;
  left: 0;
  bottom: 4.3em;
  -webkit-transform: rotate(-2deg);
  -moz-transform: rotate(-2deg);
  -ms-transform: rotate(-2deg);
  -o-transform: rotate(-2deg);
  transform: rotate(-2deg);
}
.booth-list .item .anc .booth-text,
.booth-list2 .item .anc .booth-text {
  font-size: 3.8vw;
  line-height: 1.3;
  height: 3.8em;
  overflow: hidden;
  text-align: left;
  color: #007b65;
  margin-top: 2em;
}
.booth-list .comingsoon .anc,
.booth-list2 .comingsoon .anc {
  width: 94%;
  height: 40vw;
  margin: auto;
  background-color: #fff;
  text-align: center;
}
.booth-list .comingsoon .anc img,
.booth-list2 .comingsoon .anc img {
  width: auto;
  height: 100%;
}
.booth-list2 .item {
  margin: 10px 1% 0;
  width: 48%;
}
.booth-list2 .item .anc {
  width: 100%;
}
.booth-list2 .item .anc .figure {
  width: 94%;
  height: 30vw;
}
.booth-list2 .item .anc .booth-title {
  width: 100%;
  padding: 8px 15px 6px;
  font-size: 2.8vw;
  bottom: 12vw;
  white-space: nowrap;
}
.booth-list2 .item .anc .booth-text {
  font-size: 2.8vw;
  line-height: 1.3;
  height: 3.6em;
  overflow: hidden;
  text-align: left;
  color: #007b65;
  margin-top: 10px;
}
.booth-list2 .comingsoon .anc {
  width: 94%;
  height: 30vw;
  margin: auto;
  background-color: #fff;
  text-align: center;
}
.booth-list2 .comingsoon .anc img {
  width: auto;
  height: 100%;
}
.section3 {
  background-color: #fff;
}
.video-list {
  width: 94%;
  margin: auto;
  background: url(../img/sectiontitle_video.png) no-repeat center top;
  background-size: 100% auto;
  padding-top: 25vw;
  font-size: 0;
}
.video-list .item {
  background-color: #000;
  font-size: 12px;
  width: 23%;
  margin: 10px 1% 0;
  display: inline-block;
  vertical-align: top;
}
.video-list .bigone {
  width: 60%;
  margin: 0 0 1vw 40%;
}
.video-list .bigone img {
  width: 100%;
}
.section4 {
  background-color: #7cb892;
}
.section4 .subhead {
  color: #fff;
}
.section4 .medalarea {
  width: 96%;
  margin: 8vw auto;
  background: url(../img/_bt_medal.png) no-repeat center bottom;
  background-size: contain;
}
.section4 .medalarea .medalimg {
  width: 48vw;
  height: auto;
  display: block;
  margin: auto;
}
.section4 .winnerlist {
  width: 96%;
  font-size: 0;
  margin: 0 auto;
  text-align: center;
}
.section4 .winnerlist .item {
  font-size: 14px;
  width: 320px;
  margin: 4vw 10px 0;
  display: inline-block;
  vertical-align: top;
  position: relative;
}
.section4 .winnerlist .item .anc {
  color: #000;
}
.section4 .winnerlist .item .anc .prizename {
  font-size: 18px;
  color: #fff;
  text-align: left;
  text-indent: 1.2em;
}
.section4 .winnerlist .item .anc .winnerimg {
  display: block;
  width: 280px;
  height: 170px;
  background-color: #fff;
  margin: auto;
}
.section4 .winnerlist .item .anc .winnerinfo {
  margin-top: 10px;
  border: solid 1px #8b8060;
  border-radius: 4px;
  background: #fff5c5;
  background: -moz-linear-gradient(left, #fff5c5 0%, #b09743 100%);
  background: -webkit-linear-gradient(left, #fff5c5 0%, #b09743 100%);
  background: linear-gradient(to right, #fff5c5 0%, #b09743 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff5c5', endColorstr='#b09743', GradientType=1);
  position: relative;
}
.section4 .winnerlist .item .anc .winnerinfo:before {
  content: "";
  width: 90%;
  height: 1px;
  display: block;
  background: #000000;
  position: absolute;
  margin: auto;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}
.section4 .winnerlist .item .anc .winnerinfo .service,
.section4 .winnerlist .item .anc .winnerinfo .provider {
  line-height: 1.1;
  height: 1em;
  overflow: hidden;
  margin: 10px 0;
}
.section4 .winnerlist .item .anc .winnerinfo .service {
  font-size: 14px;
  width: 8px 6px 6px;
}
.section4 .winnerlist .item .anc .winnerinfo .provider {
  font-size: 12px;
  width: 5px 6px 3px;
}
.section4 .winnerlist .item .ribbon {
  position: absolute;
  top: 25px;
  left: 30px;
}
.section4 .winnerlist .item .ribbon:before {
  content: "";
  width: 20px;
  height: 50px;
  background-color: #fed23d;
  position: absolute;
  top: 0;
  left: 0px;
}
.section4 .winnerlist .item .ribbon:after {
  content: "";
  width: 0;
  height: 0;
  border: solid 1px #000;
  border-width: 6px 10px;
  border-color: transparent #fed23d;
  position: absolute;
  top: 43px;
}
.section4 .winnerlist .item .ribbon .medalimg {
  width: 30px;
  height: auto;
  display: block;
  position: absolute;
  top: 7px;
  left: -5px;
}
section.articles {
  background-color: #fff;
}
section.articles section {
  padding: 0;
}
section.articles .news-list {
  width: 96%;
  margin: auto;
  font-size: 0;
}
section.articles .news-list .item {
  display: inline-block;
  vertical-align: top;
  width: 48%;
  margin: 2.8vw 1% 0;
  font-size: 3.2vw;
  position: relative;
}
section.articles .news-list .item:before {
  content: "";
  background: url(../img/sticker_tgsspecial.png) no-repeat center center;
  background-size: 100% auto;
  width: 120px;
  height: 30px;
  display: block;
  position: absolute;
  top: 5px;
  left: -7px;
  z-index: 1;
  -webkit-transform: rotate(-15deg);
  -moz-transform: rotate(-15deg);
  -ms-transform: rotate(-15deg);
  -o-transform: rotate(-15deg);
  transform: rotate(-15deg);
}
section.articles .news-list .item .link {
  display: block;
  width: 100%;
  height: 40vw;
  overflow: hidden;
  text-align: center;
}
section.articles .news-list .item .link .figure {
  width: auto !important;
  height: 100%;
}
section.articles .news-list .item .figcaption {
  position: relative;
  padding-bottom: 1.5em;
  margin-top: 5px;
}
section.articles .news-list .item .figcaption .tag-li {
  display: none;
}
section.articles .news-list .item .figcaption .title {
  font-weight: 400;
  height: 4em;
  overflow: hidden;
}
section.articles .news-list .item .figcaption .date {
  display: block;
  margin: 0;
  left: 0;
}
.thm-footer {
  margin-top: 0;
  width: 100%;
  min-width: auto;
}
.thm-footer .footer-nav {
  display: none;
}
.thm-footer .inner {
  width: 100%;
  padding: 0;
}
/* 480px以上 */
@media screen and (min-width: 480px) {
  
}
/* 768px以上 */
@media screen and (min-width: 768px) {
  
}
/* 768px以上 */
@media screen and (min-width: 768px) {
  section {
    padding: 80px 0;
  }
  .subhead {
    font-size: 32px;
    line-height: 1;
    text-align: center;
  }
  .fixedheader .logo .item {
    width: auto;
  }
  .fixedheader .logo .item .anc {
    width: auto;
  }
  .fixedheader .logo .item .anc .logoimg {
    width: 100% !important;
    height: auto;
  }
  .fixedheader .logo .kakeru:after {
    font-size: 20px;
  }
  .section1 {
    padding-top: 0;
    position: relative;
    min-height: 800px;
  }
  .section1 .mainvisual {
    width: 100%;
    height: 480px;
    background: url(../img/_bg_mainvisual.jpg) no-repeat center top;
    background-size: 100% auto;
    position: absolute;
    top: 0;
  }
  .section1 .mainvisual .maintitle,
  .section1 .mainvisual .specialtitle {
    width: 1000px;
    margin: auto;
    right: 0;
    left: 0;
    position: absolute;
  }
  .section1 .mainvisual .maintitle {
    top: 60px;
    text-align: left;
  }
  .section1 .mainvisual .maintitle img {
    width: auto;
  }
  .section1 .mainvisual .specialtitle {
    position: relative;
    top: 400px;
  }
  .section1 .leadtext {
    position: relative;
    width: 1000px;
    margin: auto;
    top: 720px;
    right: 0;
    left: 0;
    font-size: 14px;
  }
  .booth-list,
  .booth-list2 {
    font-size: 0;
    text-align: center;
    width: 1050px;
    margin: 30px auto 0;
  }
  .booth-list .item,
  .booth-list2 .item {
    display: inline-block;
    vertical-align: top;
    margin: 10px 10px 0;
    width: 330px;
  }
  .booth-list .item .anc,
  .booth-list2 .item .anc {
    display: block;
    position: relative;
    width: 330px;
    height: auto;
  }
  .booth-list .item .anc .figure,
  .booth-list2 .item .anc .figure {
    width: 320px;
    height: 200px;
    background: url() no-repeat center center;
    background-size: cover;
    background-color: #fff;
  }
  .booth-list .item .anc .booth-title,
  .booth-list2 .item .anc .booth-title {
    width: 330px;
    overflow: hidden;
    box-sizing: border-box;
    font-size: 16px;
    line-height: 1;
    text-align: left;
    position: absolute;
    bottom: 4.0em;
    -webkit-transform: rotate(-2deg);
    -moz-transform: rotate(-2deg);
    -ms-transform: rotate(-2deg);
    -o-transform: rotate(-2deg);
    transform: rotate(-2deg);
  }
  .booth-list .item .anc .booth-text,
  .booth-list2 .item .anc .booth-text {
    font-size: 14px;
    height: 3.8em;
    margin-top: 2em;
  }
  .booth-list .comingsoon .anc,
  .booth-list2 .comingsoon .anc {
    background-color: #fff;
  }
  .booth-list .comingsoon .anc img,
  .booth-list2 .comingsoon .anc img {
    width: 100%;
  }
  .booth-list2 .item {
    margin: 10px 10px 0;
    width: 240px;
  }
  .booth-list2 .item .anc {
    width: 240px;
  }
  .booth-list2 .item .anc .figure {
    width: 230px;
    height: 140px;
  }
  .booth-list2 .item .anc .booth-title {
    width: 240px;
    font-size: 14px;
    bottom: 54px;
  }
  .booth-list2 .item .anc .booth-text {
    font-size: 12px;
    line-height: 1.3;
    height: 3.6em;
  }
  .booth-list2 .comingsoon .anc {
    background-color: #fff;
  }
  .booth-list2 .comingsoon .anc img {
    width: 100%;
  }
  .video-list {
    width: 780px;
    margin: auto;
    background: url(../img/sectiontitle_video.png) no-repeat center top;
    background-size: 100& auto;
    padding-top: 200px;
    font-size: 0;
  }
  .video-list .item {
    background-color: #000;
    font-size: 12px;
    width: 23%;
    margin: 10px 1% 0;
    display: inline-block;
    vertical-align: top;
  }
  .video-list .bigone {
    width: 60%;
    margin: 0 0 20px 40%;
  }
  .video-list .bigone img {
    width: 100%;
  }
  .section4 .medalarea {
    width: 740px;
    margin: 40px auto;
    background-size: cover;
  }
  .section4 .medalarea .medalimg {
    width: 340px;
  }
  .section4 .winnerlist {
    width: 1050px;
    font-size: 0;
    margin: 40px auto 0;
  }
  .section4 .winnerlist .item {
    font-size: 14px;
    width: 320px;
    margin: 0 10px;
  }
  .section4 .winnerlist .item .anc .prizename {
    font-size: 18px;
    text-indent: 1.2em;
  }
  .section4 .winnerlist .item .anc .winnerimg {
    width: 280px;
    height: 170px;
  }
  section.articles section {
    padding: 0;
  }
  section.articles .news-list {
    width: 1000px;
    margin: auto;
    font-size: 0;
  }
  section.articles .news-list .item {
    display: inline-block;
    vertical-align: top;
    width: 230px;
    margin: 10px 10px 0;
    font-size: 14px;
    position: relative;
  }
  section.articles .news-list .item .link {
    display: block;
    width: 230px;
    height: 160px;
    overflow: hidden;
    text-align: center;
  }
  section.articles .news-list .item .link .figure {
    width: auto !important;
    height: 100%;
  }
  section.articles .news-list .item .figcaption {
    position: relative;
    padding-bottom: 1.5em;
    margin-top: 5px;
  }
  section.articles .news-list .item .figcaption .tag-li {
    display: none;
  }
  section.articles .news-list .item .figcaption .title {
    font-weight: 400;
    height: 4em;
    overflow: hidden;
  }
  section.articles .news-list .item .figcaption .date {
    display: block;
    margin: 0;
    left: 0;
  }
  .thm-footer {
    margin-top: 0;
    width: auto;
    min-width: 1040px;
  }
  .thm-footer .footer-nav {
    border-top: solid 2px #ccc;
    display: block;
  }
  .thm-footer .inner {
    width: 1020px;
  }
}
