/*---------------------------------
  トップ
---------------------------------*/
#topMain {
  width: 100%;
  max-width: 100%;
  height: 100vh;
  background-image: url(../img/top_main.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top 50px left 50%;
  position: relative;
}


#topMain h2 {
  width: 80%;
  height: 0;
  position: absolute;
  padding-bottom: 74%;
  background-image: url(../img/.png);
  background-repeat: no-repeat;
  background-size: contain;
  bottom: 10%;
  left: 0;
  right: 0;
  margin: auto;
}
#topMain h2 span {
  display: none;
}
/*---------------------------------
  ストーリー
---------------------------------*/
#storyWrapper {
  padding-top: 60px;
  padding-bottom: 160px;
  min-height: 100vh;
  background-image: url(../img/world_image.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  box-sizing: border-box;
  position: relative;
}
#storyBox {
  padding: 0 20px;
}
#storyBox #storyTxt h3 {
  margin-top: 30px;
  line-height: 1.4em;
  font-size: 24px;
  color: #fff;
  text-shadow: 2px 2px 4px rgba(20, 49, 99, 1.0), 2px -2px 4px rgba(20, 49, 99, 1.0), -2px 2px 4px rgba(20, 49, 99, 1.0), -2px -2px 4px rgba(20, 49, 99, 1.0), 4px 4px 8px rgba(20, 49, 99, 1.0), 4px -4px 8px rgba(20, 49, 99, 1.0), -4px 4px 8px rgba(20, 49, 99, 1.0), -4px -4px 8px rgba(20, 49, 99, 1.0);
}
#storyBox #storyTxt ul li p {
  margin-top: 30px;
  line-height: 2.4em;
  font-size: 16px;
  text-shadow: 2px 2px 4px rgba(255, 255, 255, 1.0), 2px -2px 4px rgba(255, 255, 255, 1.0), -2px 2px 4px rgba(255, 255, 255, 1.0), -2px -2px 4px rgba(255, 255, 255, 1.0), 4px 4px 8px rgba(255, 255, 255, 1.0), 4px -4px 8px rgba(255, 255, 255, 1.0), -4px 4px 8px rgba(255, 255, 255, 1.0), -4px -4px 8px rgba(255, 255, 255, 1.0);
}
#storyFooter a:after {
  background-image: url("../img/tm-logo-w.svg");
}
#storyFooter a h3 {
  color: #fff;
}
/*---------------------------------
  キャラクター
---------------------------------*/
#characterMain {
  padding-top: 60px;
  padding-bottom: 160px;
  min-height: 100vh;
  background-image: url(../img/share.png);
  background-repeat: no-repeat;
  background-position: 50% -100px;
  background-size: 50%;
  background-attachment: fixed;
}
#characterSelect {
  margin: 20px 10px 20px 20px;
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
}
#characterSelect li {
  padding-top: 10px;
  padding-right: 10px;
  width: 80px;
  height: auto;
  box-sizing: border-box;
}
#characterMain #characterSelect li a {
  border: solid 1px #143367;
  display: block;
  box-sizing: border-box;
  background-color: #fff;
}
#characterMain #characterSelect li a img {
  width: 100%;
  max-width: 100%;
}
#characterMain #characterSelect li a img:hover {
  opacity: 0.7;
  transition: 0.25s;
}
#characterMain #characterBox {
  padding: 0 20px;
}
#characterMain #characterBox ul > li {
  margin: 0 0;
  padding: 20px 0;
  border-top: solid 1px #143367;
  display: flex;
  flex-flow: row nowrap;
}
#characterMain #characterBox ul li:first-child {
}
#characterMain #characterBox ul li dl {
  padding-right: 20px;
  box-sizing: border-box;
  flex: 6 1 150px;
}
#characterMain #characterBox dl dt {
  text-align: left;
}
#characterMain #characterBox dl dt h3 {
  font-size: 26px;
  line-height: 26px;
  font-weight: lighter;
}
#characterMain #characterBox dl dt p {
  margin-top: 6px;
  padding: 0px 4px;
  font-size: 9px;
  background-color: #143367;
  color: #fff;
  display: inline-block;
  text-transform: capitalize;
  text-shadow: 2px 2px 6px rgba(79, 152, 259, 0.75), 2px -2px 6px rgba(79, 152, 259, 0.75), -2px 2px 6px rgba(79, 152, 259, 0.75), -2px -2px 6px rgba(79, 152, 259, 0.75);
}
#characterMain #characterBox dl .characterTxt {
  margin-top: 10px;
  text-align: justify;
}
#characterMain #characterBox .characterImg {
  flex: 1 2 150px;
}
#characterMain #characterBox .characterImg img {
  width: 100%;
  max-width: 100%;
  height: auto;
}
.tumbBox {
  display: none;
}
/*---------------------------------
  キーワード
---------------------------------*/
#keywordMain {
  padding-top: 60px;
  padding-bottom: 160px;
  min-height: 100vh;
  background-image: url(../img/share.png);
  background-repeat: no-repeat;
  background-position: 50% -100px;
  background-size: 50%;
  background-attachment: fixed;
}
#pointBox {
  margin-top: 20px;
  padding: 0 20px;
}
#pointBox li:first-child h3 {
  margin-top: 30px;
  font-size: 24px;
  text-align: center;
  font-weight: normal;
}
#pointBox > li:first-child p {
  margin: 10px 0 10px;
  text-align: justify;
}
#pointBox .pointTxt {
  margin: 20px 0 20px;
  padding-bottom: 20px;
  border-bottom: solid 1px #143367;
}
#pointBox .pointTxt:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}
#pointBox .pointTxt div {
  margin: 0 auto;
  width: 60%;
  height: auto;
}
#pointBox .pointTxt div img {
  width: 100%;
  max-width: 100%;
}
#pointBox dl li:first-child {
  margin: 10px auto 0;
  display: inline-block;
}
#pointBox dl li:first-child h3 {
  margin-top: 0;
  font-size: 24px;
  line-height: 24px;
  text-align: center;
  font-weight: normal;
  display: block;
  float: left;
}
#pointBox dl li:first-child p {
  margin-left: 4px;
  padding: 0px 4px;
  font-size: 9px;
  background-color: #143367;
  color: #fff;
  display: inline-block;
  vertical-align: middle;
  text-transform: capitalize;
  text-shadow: 2px 2px 6px rgba(79, 152, 259, 0.75), 2px -2px 6px rgba(79, 152, 259, 0.75), -2px 2px 6px rgba(79, 152, 259, 0.75), -2px -2px 6px rgba(79, 152, 259, 0.75);
}
#pointBox dl li:nth-child(2) p {
  margin-top: 10px;
  text-align: justify;
}
/*---------------------------------
  アウトライン
---------------------------------*/
#outlineMain {
  margin: 0 20px;
  padding-top: 60px;
  padding-bottom: 160px;
  min-height: 100vh;
  background-image: url(../img/share.png);
  background-repeat: no-repeat;
  background-position: 50% -100px;
  background-size: 50%;
  background-attachment: fixed;
}
#outlineMain > ul > li {
  margin-top: 20px;
  padding-bottom: 20px;
  border-bottom: solid 1px #143367;
}
#outlineMain > ul > li:first-child {
  margin-top: 30px;
}
#outlineMain > ul > li:last-child {
  padding-bottom: 0;
  border-bottom: none;
}
.outlineBox {
  margin-top: 20px;
  padding: 0 20px;
}
.outlineBox li h3 {
  padding: 0px 4px;
  font-size: 9px;
  background-color: #143367;
  color: #fff;
  display: inline-block;
  text-transform: capitalize;
  text-shadow: 2px 2px 6px rgba(79, 152, 259, 0.75), 2px -2px 6px rgba(79, 152, 259, 0.75), -2px 2px 6px rgba(79, 152, 259, 0.75), -2px -2px 6px rgba(79, 152, 259, 0.75);
}
.outlineBox li p {
  margin-top: 9px;
  font-size: 12px;
  line-height: 1.8em;
  color: #143367;
}
.outlineBox li .subTxt {
  font-size: 9px;
}
.outlineBox li h4 {
  margin-top: 10px;
  font-size: 22px;
  line-height: 1.4em;
  font-weight: lighter;
}
.outlineBox #release p {
  font-size: 20px;
  text-decoration: underline;
}
.outlineBox .outlineImg {
  margin: 10px auto 10px;
  width: 180px;
}
.outlineBox .outlineImg img {
  width: 100%;
  max-width: 100%;
  border: solid 1px #143367;
  height: auto;
  box-sizing: border-box;
}
#dlBox li a {
  color: #143367;
}
#dlBox li:nth-child(2) a, #dlBox li:nth-child(2) a:hover #dlBox li:nth-child(2) a:visited {
  line-height: 1.8em;
  color: #143367;
}
#dlBox li:nth-child(3) {
  margin-top: 20px;
}
#dlBox li:nth-child(3) a {
  padding: 6px 6px 6px 10px;
  background-color: #fff;
  border: solid 1px #143367;
  font-size: 1.2em;
  box-sizing: border-box;
  font-weight: bolder;
  text-decoration: none;
  letter-spacing: .25em;
  color: #143367;
  display: inline-block;
}
#dlBox li:nth-child(3) a:hover {
  color: #fff;
  background-color: #143367;
}
@media screen and (min-width: 800px) {
  /*---------------------------------
  トップ
---------------------------------*/
  #topMain {
    background-image: url../img/share.png);
    background-size: auto 100%;
    background-position: top 10px right 75%;
  }

  #topMain h2 {
    width: 337px;
    height: 277px;
    padding-bottom: 0;
    background-image: url(../img/top_main_banner.png);
    top: 20%;
    left: 50%;
  }
  /*---------------------------------
  ストーリー
---------------------------------*/
  #storyBox #storyTxt ul li p {
    text-align: left;
  }
  #storyBox #storyTxt ul li:first-child p {
    padding-left: 8em;
  }
  #storyBox #storyTxt ul li:nth-child(2) p {
    padding-left: 16em;
  }
  #storyBox #storyTxt ul li:nth-child(3) p {
    padding-left: 12em;
  }
  /*---------------------------------
  キャラクター
---------------------------------*/
  #characterSelect li {
    width: 60px;
  }
  #characterMain #characterBox dl dt h3 {
    float: left
  }
  #characterMain #characterBox dl dt p {
    margin-top: 4px;
    margin-left: 6px;
  }
  #characterMain #characterBox dl {}
  #characterMain #characterBox .characterImg {}
  .tumbBox {
    display: flex;
    flex-flow: row wrap;
    justify-content: flex-start;
  }
  .tumbBox a {
    margin: 10px 10px 0 0;
    background-color: #fff;
  }
  .tumbBox a img {
    width: 100%;
    width: 120px;
    height: 72px;
    display: block;
    object-fit: cover;
    object-position: top;
  }
  .tumbBox a img:hover {
    opacity: 0.7;
    transition: all 0.25s;
  }
  /*---------------------------------
  キーワード
---------------------------------*/
  #pointBox .pointTxt {
    margin: 20px 0 20px;
    padding-bottom: 20px;
  }
  #pointBox > li:first-child p {
    text-align: center;
  }
  #pointBox .pointTxt {
    display: flex;
    flex-flow: row nowrap;
  }
  #pointBox .pointTxt div {
    margin-right: 10px;
    flex: 1 2 150px;
  }
  #pointBox .pointTxt img {
    height: 100%;
    object-fit: cover;
  }
  #pointBox .pointTxt dl {
    flex: 6 1 150px;
  }
  #pointBox dl li:first-child {
    width: 100%;
    text-align: left;
  }
  /*---------------------------------
  アウトライン
---------------------------------*/
  #outlineMain {
    margin: 0 auto;
  }
  .outlineFlexs {
    width: 700px;
    margin: 20px auto 0;
    display: flex;
    flex-flow: row wrap;
  }
  .outlineBox .outlineImg {
    margin: 0;
    width: 240px;
  }
  .outlineBox li ul {
    width: 450px;
    padding-left: 10px;
    text-align: left;
  }
  @media screen and (min-width: 1024px) {
    /*---------------------------------
  キャラクター
---------------------------------*/
    #characterMain #characterBox ul > li {
      margin: 0 0;
    }
  }
}