body {
  position: relative;
  font-size: 16px;
  font-weight: normal;
  line-height: 1;
  color: #000;
  overflow-wrap: break-word;
  word-wrap: break-word;
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  width: 100%;
  max-width: 1000px;
}

main {
  padding-top: 30px;
}

/*  */
a {
  text-decoration: none;
}

sup {
  font-size: 70%;
}

main {
  max-width: 996px;
  margin: 0 auto;
}

main p {
  margin: 0;
}

main img {
  width: 100%;
}

.head-sponsor {
  text-align: right;
}

.head-sponsor p {
  padding: 20px 0 0;
}

.head-sponsor p+p {
  padding-bottom: 20px;
}

.head-sponsor a {
  display: inline-block;
  font-size: 10px;
  color: #000;
  text-align: center;
  line-height: 1.5;
}

.head-sponsor a img {
  width: 35px;
}

h1 {
  font-size: 34px;
  padding-bottom: 30px;
  line-height: 1.4;
  font-weight: bold;
  margin: 0;
}

.main {
  display: table-row;
}

.main-L {
  display: table-cell;
  width: 65%;
  padding-top: 40px;
  padding-right: 20px;
  vertical-align: top;
}

.lead {
  font-weight: bold;
  line-height: 1.8;
  padding-bottom: 40px;
}

.img-cap,
.outline p.img-cap {
  padding-top: 5px;
  font-size: 14px;
}

h2 {
  font-size: 28px;
  line-height: 1.2;
  font-weight: bold;
  padding-top: 60px;
  margin: 0;
}

.outline {
  padding-bottom: 40px;
}

.outline p {
  line-height: 1.8;
  padding-top: 20px;
}

.outline img {
  padding-top: 20px;
}

.outline a {
  display: block;
  margin-top: 20px;
}

.outline p a {
  display: inline;
  margin: 0;
}

a.banner:hover {
  opacity: .8;
}

.outline a img {
  padding: 0;
}

.movie {
  background: #E5E5E5;
  padding: 20px;
  margin-top: 50px;
}

.movie h3 {
  display: inline-block;
  font-size: 20px;
  font-weight: bold;
  margin: 0;
  line-height: 1.4;
}

.movie h3+p {
  display: inline-block;
  padding-left: 15px;
  padding-top: 0;
  font-size: 14px;
}

.movie .player,
.outline .player {
  margin-top: 10px;
  width: 100%;
  aspect-ratio: 16 / 9;
}

.btn-detail {
  display: inline-block;
  margin: 0 auto;
  width: 90%;
  max-width: 300px;
}

.product {
  padding-bottom: 20px;
}

.column {
  margin-top: 60px;
  border: 1px solid #333;
  padding: 20px;
}

.column h2 {
  padding: 0 0 15px;
  border-bottom: 1px solid #333;
}

.column p img {
  width: 200px;
  float: left;
  vertical-align: bottom;
  margin-right: 15px;
}

@media screen and (max-width: 768px) {

  .column p img {
    display: block;
    width: 60%;
    min-width: 200px;
    margin: 0 auto 15px;
    float: none;
  }
}

.caption {
  font-size: 12px;
}

.caption ul {
  padding-left: 0;
}

.caption-1 li {
  list-style-type: '＊';
  margin-left: 13px;
  line-height: 1.2;
}

.caption-2 li {
  list-style-type: '●';
  margin-left: 13px;
  line-height: 1.2;
  margin-top: 6px;
}

.caption-31 {
  list-style-type: '＊1：';
  margin-left: 33px;
  line-height: 1.2;
}

.caption-32 {
  list-style-type: '＊2：';
  margin-left: 33px;
  line-height: 1.2;
  margin-top: 6px;
}

.caption-33 {
  list-style-type: '＊3：';
  margin-left: 33px;
  line-height: 1.2;
  margin-top: 6px;
}

.caption-34 {
  list-style-type: '＊4：';
  margin-left: 33px;
  line-height: 1.2;
  margin-top: 6px;
}

.caption-35 {
  list-style-type: '＊5：';
  margin-left: 33px;
  line-height: 1.2;
  margin-top: 6px;
}

.caption-36 {
  list-style-type: '＊6：';
  margin-left: 33px;
  line-height: 1.2;
  margin-top: 6px;
}

.caption a{
  display: inline-block;
  margin-top: 0;
}

.contact {
  padding-top: 20px;
}

.info {
  margin: 9px 0 40px;
  position: relative;
}

.info a{
  display: block;
  border: 1px solid #333;
}

.main-R {
  display: table-cell;
  width: 35%;
  padding-top: 40px;
  padding-left: 20px;
}

.side-info {
  padding: 20px 0;
}

.side-info a {
  display: block;
  border: 1px solid #333;
}

.link a {
  display: flex;
  margin-bottom: 10px;
  color: #fff;
  background: rgb(22,120,190);
  padding: 10px;
}

.link .img {
  width: 30%;
  padding-right: 10px;
}

.link .text {
  width: 70%;
  line-height: 1.2;
}

.hp {
  margin-top: 40px;
}

.sp {
  display: none;
}

@media screen and (max-width: 1036px) {
  .head-sponsor {
    padding-right: 20px;
  }

  h1 {
    padding: 0 20px 30px;
  }

  .main-L {
    padding-left: 20px;
  }

  .main-R {
    padding-right: 20px;
  }

  section.hero {
    padding: 0;
  }
}

@media screen and (max-width: 768px) {
  .sp {
    display: block;
  }

  .pc {
    display: none !important;
  }

  .main {
    display: block;
    padding: 0 20px;
  }

  .main-L,
  .main-R {
    display: block;
    width: 100%;
    padding: 40px 0 0;
  }

  .link {
    padding-bottom: 40px;
  }

  .logo {
    top: 25.2%;
    left: 7.2%;
    width: 16%;
  }
}