@charset "UTF-8";
/*============================
共通パーツ
============================*/
.container a:hover {
  opacity: 0.6;
  text-decoration: none;
  text-decoration: none;
  cursor: pointer;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}

#globalNavi.naviFixed {
  display: none;
}

.sp section.trailer .staticFrame .prevew li a:after {
  content: "";
  display: inline-block;
  width: 100%;
  height: 100%;
  background: url(/img/pc/parts/play_m.png) 50% 50% no-repeat;
  background-size: cover;
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0.6;
}

section ul.menu {
  display: table;
  width: 970px;
  margin: 1em 0;
}
section ul.menu li {
  display: table-cell;
  text-align: center;
}
section ul.menu li a {
  display: block;
  margin: 2px;
  padding: 10px;
  font-size: 20px;
  color: #333;
  text-decoration: none;
}
section ul.menu.border li a {
  border: 3px solid #ccc;
}
section h1.border {
  max-width: 900px;
  width: 90%;
  margin: 0 auto 3%;
  padding: 10px;
  border: 3px solid #ccc;
  text-align: center;
}
section h1.border + h2 {
  margin-top: 1em;
  font-size: 14px;
  text-align: center;
}
section h1.verImg + h2 {
  margin-top: 1em;
  text-align: center;
}
section ul.menu.borderSide li {
  border-right: 1px solid #ccc;
}
section ul.menu.borderSide li:first-child {
  border-left: 1px solid #ccc;
}
section h1 {
  font-size: 30px;
}
section h1.mainCatch_1 {
  padding: 10px;
  color: #fff;
  text-align: center;
  text-shadow: -1px -1px 0 #2196f3, 1px -1px 0 #2196f3, 1px 1px 0 #2196f3, -1px 1px 0 #2196f3, 0 2px 10px #2196f3, 0 2px 40px #2196f3;
}
section h1.mainCatch_1 + h2 {
  text-align: center;
  line-height: 1.75;
}
section h1.headerMain {
  min-height: 500px;
}
section h2 {
  width: 90%;
  margin: 0 auto 2%;
  line-height: 1.4;
  font-size: 20px;
  max-width: 32em;
  letter-spacing: 1px;
  font-size: 26px;
}
section .summary {
  padding: 1% 1% 1% 2%;
  text-align: left;
}
section h3 {
  max-width: 50em;
  margin: 0 auto;
  padding: 2%;
  text-align: center;
  line-height: 1.5;
  word-break: break-word;
  font-size: 120%;
}
section h4 {
  word-break: break-word;
}
section h4:empty {
  display: none;
}
section h1 > small {
  margin-left: 1em;
  font-size: 20px;
}
section .staticFrame p.txt {
  padding: 0 2% 2%;
  line-height: 1.5;
  width: 94%;
  margin: 0 auto;
  text-align: left;
  font-size: 17px;
}
section[class^=sectionType] div.unit {
  margin: 1em 0;
}
section[class^=sectionType] div.unit div.img {
  margin: 0 auto 1em;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  box-sizing: border-box;
  max-width: 90%;
  vertical-align: top;
}
section[class^=sectionType] div.unit div.img a {
  display: inline-block;
}

.contents {
  margin: 0 auto;
}
.contents .topicPath {
  max-width: 970px;
  width: 100%;
  margin: 0 auto;
  padding: 0;
  line-height: 3;
}
.contents section {
  width: 100%;
  margin: 0 auto;
  text-align: center;
}
.contents section.copyright {
  text-align: center;
  color: #bfbfbf;
  font-size: 10px;
  padding: 1% 0 15%;
}

/*============================
.typeHeader
============================*/
section {
  width: 100%;
}
section img {
  display: block;
  margin: 0 auto;
}
section a.btn {
  width: 600px;
  margin: 1em auto;
  display: block;
  font-size: 20px;
  line-height: 3;
}
section a.headerButton_1 {
  display: block;
  position: relative;
  width: 550px;
  height: 84px;
  margin: 5% auto;
  background-color: #ff8d04;
  color: #fff;
  font-size: 30px;
  font-weight: bold;
  text-align: center;
  line-height: 2.8;
  letter-spacing: 1px;
  border-radius: 42px;
  -webkit-box-shadow: 0 4px #af6003;
  box-shadow: 0 4px #af6003;
}
section a.headerButton_1:before {
  display: inline-block;
  position: absolute;
  top: 22px;
  right: 38px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #fff;
  content: "";
}
section a.headerButton_1:after {
  position: absolute;
  top: 28px;
  right: 33px;
  border: 13px solid transparent;
  border-left: 18px solid #ff8d04;
  content: "";
}
section a.headerButton_1:hover {
  opacity: 0.8;
  -webkit-box-shadow: 0 1px 0 #aa5421;
  box-shadow: 0 1px 0 #aa5421;
  -webkit-transform: translateY(3px);
          transform: translateY(3px);
}
section a.headerButton_2 {
  display: block;
  position: relative;
  width: 550px;
  height: 86px;
  margin: 5% auto 5%;
  background-color: #c00;
  color: #fff;
  font-size: 30px;
  font-weight: bold;
  text-align: center;
  line-height: 2.8;
  letter-spacing: 1px;
  border-radius: 5px;
  -webkit-box-shadow: 0 4px #8e0202;
  box-shadow: 0 4px #8e0202;
}
section a.headerButton_2:after {
  display: block;
  position: absolute;
  top: 36%;
  right: 6%;
  width: 19px;
  height: 19px;
  border-top: 4px solid #fff;
  border-right: 4px solid #fff;
  content: "";
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
section a.headerButton_2:hover {
  opacity: 0.8;
  -webkit-box-shadow: 0 1px 0 #aa5421;
          box-shadow: 0 1px 0 #aa5421;
  -webkit-transform: translateY(3px);
          transform: translateY(3px);
}
section a.headerButton_3 {
  display: block;
  position: relative;
  width: 550px;
  height: 86px;
  margin: 5% auto 2%;
  border: solid 3px #c00;
  background-color: #fff;
  color: #c00;
  font-size: 30px;
  font-weight: bold;
  text-align: center;
  line-height: 2.8;
  letter-spacing: 1px;
}
section a.headerButton_3:after {
  display: block;
  position: absolute;
  top: 36%;
  right: 6%;
  width: 19px;
  height: 19px;
  border-top: 4px solid #c00;
  border-right: 4px solid #c00;
  content: "";
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
section a.headerButton_3:hover {
  background-color: #ffe5e5;
}
section a.headerButton_4 {
  display: block;
  font-size: 26px;
  font-weight: bold;
  text-decoration: underline;
  text-align: center;
  margin-top: 1em;
  letter-spacing: -1px;
}
section a.headerButton_4:hover {
  opacity: 0.6;
}
section ul.gnav {
  display: box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 970px;
  -webkit-box-pack: justify;
  -ms-flex-pack: center;
      justify-content: center;
  margin: 0 auto;
  padding: 5px 0;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  color: #fff;
  font-size: 40px;
  font-weight: 900;
  text-align: center;
  line-height: 1.5;
}
section ul.gnav li {
  position: relative;
  display: inline-block;
  -webkit-box-flex: 1;
  -ms-flex: 1 0 auto;
      flex: 1 0 auto;
}
section ul.gnav li a {
  width: 100%;
  display: block;
}
section div.navi_1 {
  margin: 30px 0 50px;
  line-height: 34px;
}
section div.navi_1 ul {
  background: #2bb3eb;
  width: 970px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
section div.navi_1 ul li {
  position: relative;
  border-top: 3px solid #fff;
  border-bottom: 3px solid #ffffff;
  background: #2bb3eb;
}
section div.navi_1 ul li a {
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
  width: 100%;
  padding-right: 30px;
  border-right: 1px dotted #fff;
  color: #fff;
  font-size: 22px;
  font-weight: bold;
  line-height: 1.7;
}
section div.navi_1 ul li:last-of-type a {
  border-right: none;
}
section div.navi_1 ul li a:before {
  display: inline-block;
  position: absolute;
  top: 8px;
  right: 13px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #fff;
  content: "";
}
section div.navi_1 ul li a:after {
  display: inline-block;
  position: absolute;
  top: 15px;
  right: 12px;
  width: 0;
  height: 0;
  margin-right: 5px;
  border: 6px solid transparent;
  border-top: 8px solid #2bb3eb;
  border-bottom: 0 solid transparent;
  content: "";
}
section div.navi_2 {
  margin-bottom: 50px;
  line-height: 34px;
}
section div.navi_2 ul.gnav {
  display: box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 970px;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
      justify-content: space-between;
}
section div.navi_2 li {
  margin: 0 6px;
}
section div.navi_2 li:hover {
  background-color: #f1f1f1;
}
section div.navi_2 li a {
  display: block;
  margin: 1rem 0;
  padding-top: 8px;
  border-bottom: 9px solid #f3376c;
  color: #f3376c !important;
  font-size: 32px;
  line-height: 1;
  letter-spacing: -1px;
}
section div.navi_2 li a span {
  display: block;
  padding: 5px 0;
  font-size: 14px;
  font-weight: normal;
}
section div.navi_2 li a:hover {
  opacity: 1;
}
section div.navi_3 ul.gnav {
  background: #fff;
}
section div.navi_3 ul.gnav li a {
  display: block;
  border-bottom: 6px solid transparent;
  color: #010101 !important;
  font-size: 32px;
  line-height: 1;
  letter-spacing: -1px;
  padding-top: 1%;
}
section div.navi_3 ul.gnav li a span {
  display: block;
  padding: 5px 0;
  font-size: 14px;
  letter-spacing: 1px;
}
section div.navi_3 ul.gnav li a:hover {
  border-bottom: 6px solid #ef322c;
}
section div.navi_4 {
  margin-bottom: 50px;
  background: transparent;
  line-height: 34px;
}
section div.navi_4 ul {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
section div.navi_4 ul li {
  display: inline-block;
  position: relative;
  margin: 0 4px;
  border: solid 2px #bfe099;
  background: #8bc34a;
  line-height: 1;
}
section div.navi_4 ul li a {
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
  width: 100%;
  padding: 8px 3px 2px 0;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  line-height: 0.9;
  letter-spacing: 1px;
}
section div.navi_4 ul li a span {
  display: block;
  padding: 5px 0;
  font-size: 12px;
  font-weight: normal;
}
section div.navi_4 ul li a:after {
  display: inline-block;
  position: absolute;
  top: 17px;
  right: 0;
  width: 0;
  height: 0;
  margin-right: 5px;
  border: 6px solid transparent;
  border-top: 8px solid #fff;
  border-bottom: 0 solid transparent;
  content: "";
}
section div.navi_5 {
  margin-bottom: 50px;
  background: #2bb3eb;
  line-height: 34px;
}
section div.navi_5 ul {
  padding: 10px 0;
}
section div.navi_5 ul li {
  position: relative;
  background: #2bb3eb;
}
section div.navi_5 ul li a {
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
  width: 100%;
  padding-right: 0;
  border-right: 1px dotted #fff;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
}
section div.navi_5 ul li:first-of-type a {
  border-left: 1px dotted #fff;
}
section div.navi_6 {
  margin-bottom: 50px;
  background: #2bb3eb;
  line-height: 34px;
}
section div.navi_6 ul {
  padding: 10px 0;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
      justify-content: center;
}
section div.navi_6 ul li {
  display: inline-block;
  position: relative;
  margin: 0 4px;
  background: #2bb3eb;
}
section div.navi_6 ul li:first-of-type a {
  border-left: 1px dotted #fff;
}
section div.navi_6 ul li a {
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
  width: 100%;
  border-right: 1px dotted #fff;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.6;
  letter-spacing: 1px;
}
section div.navi_6 ul li a:after {
  display: inline-block;
  position: absolute;
  top: 0.7em;
  left: 10px;
  width: 0;
  height: 0;
  margin-right: 5px;
  border: 6px solid transparent;
  border-top: 8px solid #fff;
  border-bottom: 0 solid transparent;
  content: "";
}
section div.navi_7 {
  margin-bottom: 50px;
  background: transparent;
  line-height: 34px;
}
section div.navi_7 ul {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
section div.navi_7 ul li {
  position: relative;
  margin: 0 1px;
  border: solid 2px #917f4f;
  background: #3e3928;
}
section div.navi_7 ul li a {
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
  width: 100%;
  text-shadow: -1px -1px 0 #3e3928, 1px -1px 0 #3e3928, 1px 1px 0 #3e3928, -1px 1px 0 #3e3928, 0 2px 10px #d5c589, 0 2px 20px #d5c589, 0 2px 30px #d5c589;
  color: #fff;
  font-size: 15px;
  font-weight: normal;
  line-height: 3.5;
  letter-spacing: 1px;
}
section div.navi_7 ul li a:hover {
  background: #2c291e;
}
section div.navi_8 {
  margin-bottom: 50px;
  line-height: 34px;
}
section div.navi_8 ul {
  padding: 2px 0;
  background: #74714f url(/special/common/img/navi_Bg.png) no-repeat;
}
section div.navi_8 ul li {
  position: relative;
  background: transparent;
}
section div.navi_8 ul li a {
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
  width: 100%;
  border-left: 1px solid #72745e;
  text-shadow: 0 1px 1px rgba(0, 0, 0, 0.75);
  color: #fff;
  font-size: 22px;
  font-weight: normal;
  line-height: 3;
}
section div.navi_8 ul li:hover {
  background: rgba(224, 211, 99, 0.35);
}
section div.navi_8 ul li:last-of-type a {
  border-right: none;
}
section.typeHeader2 div.img {
  display: inline-block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 480px;
  vertical-align: top;
}
section.typeHeader2 div.img img {
  margin: 0.5em 0;
}
section.typeHeader2 div.txt {
  display: inline-block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: -webkit-calc(480px);
  width: 480px;
  padding-left: 10px;
  vertical-align: top;
}
section.typeHeader2 div.txt img {
  margin: 0.5em 0;
}
section.typeHeader2 div.txt a.btn {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 480px;
  margin: 1em 0;
}

/*============================
.trailer
============================*/
[class^=ttlTyp] {
  margin: 3% 0 3%;
  text-align: center;
}
[class^=ttlTyp] small,
[class^=ttlTyp] span {
  display: block;
}

h1.ttlTyp_1 {
  width: 900px;
  margin: 2% auto 1%;
  padding: 30px 35px 2%;
  background: -webkit-gradient(linear, left top, left bottom, from(#eef0f3), to(rgba(255, 255, 255, 0.2)));
  background: linear-gradient(#eef0f3, rgba(255, 255, 255, 0.2));
}
h1.ttlTyp_1 span {
  background: #2bb3eb;
  color: #fff;
  font-size: 36px;
  line-height: 1.2;
  padding-top: 2%;
}
h1.ttlTyp_1 span small {
  display: block;
  text-shadow: 0 0 0 #000;
  color: #ffffff;
  font-size: 18px;
  font-weight: normal;
  letter-spacing: 4px;
  padding-bottom: 1%;
}
h1.ttlTyp_2 {
  font-size: 60px;
  color: #fff;
  text-shadow: 0 0 17px #f27021;
  text-align: center;
  text-shadow: 0 0 20px #f27021, 0 0 30px #f27021, 0 0 40px #f27021;
}
h1.ttlTyp_2 small {
  display: block;
  margin-top: 10px;
  text-shadow: 0 0 0 #000;
  color: #f17022;
  font-size: 18px;
  font-weight: normal;
  letter-spacing: 4px;
}
h1.ttlTyp_3 {
  font-size: 36px;
  color: #010101;
  line-height: 1.75;
  border-bottom: 2px solid #131313;
  width: 100%;
  max-width: 970px;
  margin: 0 auto 2%;
}
h1.ttlTyp_3 small {
  display: block;
}
h1.ttlTyp_4 {
  background: url(/special/common/img/chck_bg.png) no-repeat center;
}
h1.ttlTyp_4 span {
  line-height: 65px;
  color: #7d7d7d;
}
h1.ttlTyp_4 span small {
  display: block;
}
h1.ttlTyp_5 {
  font-size: 36px;
  color: #fff;
  line-height: 1.75;
  background: #2bb3eb;
}
h1.ttlTyp_5 small {
  display: block;
}
h1.ttlTyp_6 {
  width: 970px;
  margin: 3% auto 2%;
  border-bottom: 2px solid #fff;
  color: #fff;
  font-size: 30px;
  text-indent: 1em;
  text-align: left;
  line-height: 1.75;
}
h1.ttlTyp_6 small {
  display: inline-block;
  margin: 0 2%;
  font-size: 14px;
  font-weight: normal;
}
h1.ttlTyp_7 {
  background: #000;
  color: #fff;
  font-size: 38px;
  font-weight: normal;
}
h1.ttlTyp_7 span {
  display: inline-block;
  position: relative;
  padding: 10px 0;
  color: #d5c589;
}
h1.ttlTyp_7 span:after {
  display: inline-block;
  position: absolute;
  right: -157px;
  bottom: 22px;
  width: 147px;
  height: 74px;
  background: url(/special/common/img/waku_2.png) no-repeat 0 bottom;
  content: "";
}
h1.ttlTyp_7 span small {
  display: block;
  font-size: 14px;
}
h1.ttlTyp_7 span:before {
  display: inline-block;
  position: absolute;
  bottom: 22px;
  left: -157px;
  width: 147px;
  height: 74px;
  background: url(/special/common/img/waku_1.png) no-repeat 0 bottom;
  content: "";
}
h1.ttlTyp_7 small {
  display: block;
}
h1.ttlTyp_9, h1.ttlTyp_10, h1.ttlTyp_11 {
  margin: 3% 0 1%;
}

section.trailer h2 {
  text-align: center;
}
section.trailer .staticFrame {
  margin: 0 auto;
  overflow: hidden;
}
section.trailer .staticFrame .prevew li a {
  display: block;
  position: relative;
}
section.trailer .staticFrame .prevew li a img {
  width: 100%;
}
section.trailer .staticFrame .prevew li a:after {
  content: "";
  display: inline-block;
  width: 100%;
  height: 100%;
  background: url(/img/pc/parts/play_m.png) 50% 50% no-repeat;
  background-size: 100%;
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0.6;
}
section.trailer .staticFrame .prevew li p.movieTtl {
  font-size: 110%;
  font-weight: bold;
  line-height: 2;
  letter-spacing: 1px;
}
section.trailer > div .trailermovie {
  width: 640px;
  margin: 0 auto 10px;
}
section.trailer > div .tralerAria {
  width: 100%;
  overflow: hidden;
}
section.trailer > div .tralerAria ul.prevew {
  letter-spacing: 0.4em;
}
section.trailer > div .tralerAria ul.prevew li {
  width: 22%;
  display: inline-block;
  text-align: center;
  letter-spacing: normal;
}
section.trailer > div .tralerAria ul.prevew li p {
  line-height: 2;
}
section.trailer div.trailer_type2 .trailermovie {
  margin: 0 10px 0 0;
  float: left;
}
section.trailer div.trailer_type2 .tralerAria {
  width: 250px;
}
section.trailer div.trailer_type2 .tralerAria ul.prevew li {
  width: 100%;
}

/*============================
INTRO
============================*/
.staticFrame {
  width: 900px;
  margin: 0 auto;
}
.staticFrame > img {
  padding-bottom: 4px;
}
.staticFrame img {
  width: 100%;
}

img.ttlTyp_img {
  margin: 3% auto 3%;
}

/*============================
.sectionType1
============================*/
section.sectionType1 p.txt {
  padding: 1% 2%;
  line-height: 1.5;
  width: 94%;
  margin: 0 auto;
  text-align: left;
  font-size: 17px;
}
section.sectionType1 div.imgContainer {
  margin: 3% auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 900px;
}
section.sectionType1 div.imgContainer div.unit img {
  width: 100%;
  max-width: 100%;
  padding-bottom: 2px;
  padding-bottom: 1%;
}
section.sectionType1 div.imgContainer div.unit img a {
  display: block;
}
section.sectionType1 div.imgContainer div.unit:nth-child(1) {
  float: left;
  width: 60%;
  height: auto;
}
section.sectionType1 div.imgContainer:before, section.sectionType1 div.imgContainer:after {
  display: block;
  clear: both;
  content: "";
}

.pc section.sectionType1 div.imgContainer div.unit {
  margin: 0;
}

.pc section.sectionType1 div.imgContainer div.unit:nth-child(2),
.pc section.sectionType1 div.imgContainer div.unit:nth-child(3) {
  float: right;
  width: 40%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 0 0 2px 4px;
  height: 235px;
}
.pc section.sectionType1 div.imgContainer div.unit:nth-child(2) img,
.pc section.sectionType1 div.imgContainer div.unit:nth-child(3) img {
  padding-bottom: 0;
  height: 233px;
}

.pc section.sectionType1 div.imgContainer div.unit:nth-child(2) img {
  padding-bottom: 0;
}

.pc section.sectionType1 div.imgContainer div.unit:nth-of-type(n+4) {
  float: left;
  width: 25%;
  height: auto;
  padding: 1px 2px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.pc section.sectionType1 div.imgContainer div.unit:nth-of-type(1) {
  margin: 0 0 2px;
}
.pc section.sectionType1 div.imgContainer div.unit:nth-of-type(1) img {
  padding-bottom: 0;
}

/*============================
.sectionType2
============================*/
.sectionType2 div.imgContainer {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  display: box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-box-pack: justify;
  -ms-flex-pack: start;
      justify-content: flex-start;
  margin: 0 auto 2%;
  max-width: 900px;
}
.sectionType2 div.imgContainer div.unit {
  width: calc(25% - 4px);
  margin: 0 2px 2px;
  display: inline-block;
}
.sectionType2 div.imgContainer div.unit img {
  width: 100%;
}

/*============================
.sectionType3
============================*/
section {
  /*============================
  .sectionType5
  ============================*/
  /*============================
  .sectionType6
  ============================*/
  /*============================
  .sectionType7
  ============================*/
  /*============================
  .sectionType12
  ============================*/
  /*============================
  present 共通
  ============================*/
}
section.sectionType4 div.unit {
  margin: 1em 0;
  position: relative;
  min-height: 310px;
}
section.sectionType4 div.unit div.img {
  display: inline-block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 465px;
  margin-bottom: 1em;
  vertical-align: top;
}
section.sectionType4 div.unit div.txt {
  display: inline-block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 430px;
  padding-left: 10px;
  vertical-align: top;
  line-height: 1.8;
}
section.sectionType4 div.unit div.txt h3:empty {
  display: none;
  background: pink;
}
section.sectionType4 div.unit div.txt p.txt {
  padding: 0 2% 5%;
}
section.sectionType4#story div.unit div.img {
  position: absolute;
  left: 0;
  top: 0;
}
section.sectionType4#story div.unit div.txt {
  display: inline-block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 900px;
  vertical-align: top;
  line-height: 1.8;
  padding-left: 470px;
  text-align: left;
}
section.sectionType5 div.imgContainer {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  display: box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-box-pack: justify;
  -ms-flex-pack: start;
      justify-content: flex-start;
  margin: 0 auto 2%;
  max-width: 900px;
}
section.sectionType5 div.imgContainer div.unit {
  width: 18%;
  width: calc(20% - 4px);
  max-width: calc(20% - 4px);
  margin: 0 2px 1%;
  text-align: center;
  display: inline-block;
  -webkit-box-flex: 1;
  -ms-flex: 1 0 auto;
      flex: 1 0 auto;
}
section.sectionType5 div.imgContainer div.unit a {
  color: #014d94 !important;
  display: block;
}
section.sectionType5 div.imgContainer div.unit img {
  width: 98%;
  padding: 0 1%;
}
section.sectionType6 div.unit {
  margin: 1em 0;
}
section.sectionType6 div.unit div.img {
  display: inline-block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 23%;
  margin-bottom: 1%;
  vertical-align: top;
}
section.sectionType6 div.unit div.txt {
  display: inline-block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 69%;
  width: -webkit-calc(100% - 31%);
  width: 69%;
  padding-left: 10px;
  vertical-align: top;
  text-align: left;
  line-height: 1.8;
}
section.sectionType6 div.unit div.txt a {
  color: #014d94 !important;
}
section.sectionType6 div.unit div.txt h3 {
  text-align: left;
  padding: 0 0 1%;
  line-height: 1.2;
}
section.sectionType6 div.unit div.txt .actor_name {
  font-size: 110%;
}
section.sectionType6 div.unit div.txt p.txt {
  padding: 0 2% 2%;
  line-height: 1.5;
  width: 94%;
  margin: 0 auto;
  text-align: left;
  font-size: 17px;
}
section.sectionType7 div.imgContainer {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  display: box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-box-pack: justify;
  -ms-flex-pack: start;
      justify-content: flex-start;
}
section.sectionType7 div.imgContainer div.unit {
  width: 30%;
  width: calc(33.3333333333% - 4px);
  margin: 0.5em 2px 2em;
  text-align: center;
}
section.sectionType7 div.imgContainer div.unit div.txt {
  line-height: 1.4;
}
section.sectionType7 div.imgContainer div.unit div.txt p.txt {
  padding: 0 2% 2%;
  line-height: 1.5;
  width: 94%;
  margin: 0 auto;
  text-align: left;
  font-size: 110%;
}
section.sectionType12 div.imgContainer {
  display: box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-box-pack: justify;
  -ms-flex-pack: start;
      justify-content: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  width: 100%;
}
section.sectionType12 div.imgContainer div.unit {
  margin: 2px;
  text-align: center;
  width: 24%;
  display: inline-block;
}
section.sectionType12 div.imgContainer div.unit div.txt {
  line-height: 1.4;
}
section.sectionType12 div.imgContainer div.unit div.txt p.txt {
  padding: 0 2% 2%;
  line-height: 1.5;
  width: 94%;
  margin: 0 auto;
  text-align: left;
  font-size: 17px;
}
section.present h2 + h3 {
  margin: 0 auto 2%;
  padding: 0;
}
section.present div.imgContainer {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 1%;
  display: box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 98%;
  -webkit-box-pack: justify;
  -ms-flex-pack: distribute;
      justify-content: space-around;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
section.present div.imgContainer div.unit {
  display: inline-block;
  position: relative;
  max-width: 23%;
  margin: 0.5em 2px 1em;
  border: solid 5px #2bb3eb;
  border-radius: 9px;
  background-color: #fff;
  text-align: center;
}
section.present div.imgContainer div.unit div.txt {
  width: 94%;
  color: #333;
  font-weight: bold;
  text-align: center;
  padding: 0 2% 2%;
  line-height: 1.5;
  width: 94%;
  margin: 0 auto;
  text-align: left;
  font-size: 17px;
}
section.present div.imgContainer div.unit div.txt .presentBox {
  color: #91c426;
  font-size: 40px;
}
section.present a.btn {
  display: block;
  width: 600px;
  margin: 1em auto;
  font-size: 20px;
  line-height: 3;
}

section.searchTag {
  width: 970px;
  margin: 8em auto;
  text-align: center;
}
section.searchTag h1 {
  width: 800px;
  margin: 20px auto;
  margin-bottom: 20px;
  padding-left: 25px;
  color: #9a9a9a;
  font-size: 180%;
  font-size: 180%;
  line-height: 40px;
}
section.searchTag ul {
  letter-spacing: -0.4em;
}
section.searchTag ul li {
  display: inline-block;
  margin: 1%;
  letter-spacing: 0;
}
section.searchTag ul li a {
  display: block;
  padding: 10px;
  font-size: 17px;
  border: 1px solid #a9a8a8;
  border-radius: 1px;
  -webkit-box-shadow: 0 0 2px rgba(0, 0, 0, 0.17) inset;
          box-shadow: 0 0 2px rgba(0, 0, 0, 0.17) inset;
}

div.top {
  position: fixed;
  right: 10px;
  bottom: 30px;
  margin: -3em 0 1em 0;
  text-align: right;
  width: 50px;
  height: 50px;
}
div.top a {
  display: block;
}
div.top img {
  width: 100%;
}

section#footer {
  background: #fff;
  color: #333;
}

.footer_link {
  margin-top: 20px;
  font-size: 22px;
  font-weight: bold;
  text-decoration: underline;
  text-align: center;
}

/* sns */
.sns_Aria {
  width: 970px;
  margin: 0 auto 100px;
  position: relative;
}
.sns_Aria ul.sns_Btn {
  display: table;
  border-spacing: 3px 0;
  border-collapse: separate;
  width: 400px;
  margin: 0 auto 5px;
  position: absolute;
  right: 0;
}
.sns_Aria ul.sns_Btn li {
  display: table-cell;
  width: 33%;
  margin: 0 1%;
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 3px;
  text-align: center;
  vertical-align: middle;
}
.sns_Aria ul.sns_Btn li.snsTw {
  background: #000 url(/special/common/img/xIcon.png) no-repeat 0 center;
  background-size: 31px;
  background-position: 3px center;
}
.sns_Aria ul.sns_Btn li.snsFb {
  background: #3b5999 url(/static/mtm/base/img/fbIcon.png) no-repeat 0 center;
  background-size: 28px;
  letter-spacing: 2px;
}
.sns_Aria ul.sns_Btn li a {
  display: block;
  color: #fff;
  line-height: 44px;
}
.sns_Aria ul.sns_Btn li.snsTw a {
  padding-left: 35px;
}
.sns_Aria ul.sns_Btn li.snsFb a {
  padding-left: 24px;
}

ul.sns_Btn li.snsLi {
  display: none;
}

/*============================================================================================================================================
SP
============================*/
.sp {
  /*============================
  .typeHeader
  ============================*/
  /*============================
  .trailer
  ============================*/
  /*============================
  .sectionType1
  ============================*/
  /*============================
  .sectionType2
  ============================*/
  /*============================
  .sectionType3
  ============================*/
  /*============================
  .sectionType4
  ============================*/
  /*============================
  .sectionType5
  ============================*/
  /*============================
  .sectionType6
  ============================*/
  /*============================
  .sectionType7
  ============================*/
  /*============================
  .present
  ============================*/
}
.sp .sns_Aria {
  width: 98%;
  margin: 1% 0 10% 1%;
  padding-bottom: 8%;
}
.sp ul.sns_Btn {
  display: table;
  border-spacing: 3px 0;
  border-collapse: separate;
  width: 98%;
  margin: 0 auto 5px;
  position: absolute;
  right: 0;
}
.sp ul.sns_Btn li.snsLi {
  display: table-cell;
  padding-left: 0;
  background: #00b900;
  text-align: left;
}
.sp ul.sns_Btn li a {
  height: 40px;
  line-height: 40px;
}
.sp ul.sns_Btn li.snsLi span {
  display: block;
  position: relative;
}
.sp ul.sns_Btn li.snsLi span a {
  position: relative;
  z-index: 10;
}
.sp ul.sns_Btn li.snsLi a img {
  width: auto;
}
.sp ul.sns_Btn li.snsLi span:after {
  position: absolute;
  z-index: 1;
  top: 50%;
  left: 48px;
  margin-top: -0.6em;
  color: #fff;
  letter-spacing: 2px;
  content: "LINE";
}
.sp .spgnav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  margin-bottom: 3.4vw;
}
.sp .spgnav li {
  -webkit-box-flex: 2;
      -ms-flex: 2 1 auto;
          flex: 2 1 auto;
  line-height: 44px;
  border-right: 1px solid #fff;
}
.sp .spgnav li a {
  display: block;
  background: #ed6299;
  color: #fff;
  font-size: 130%;
  font-size: 4.5vw;
}
.sp .spgnav li a:hover {
  background: #d84469;
  opacity: 1;
}
.sp .spgnav li:last-of-type {
  border: none;
}
.sp .spnavi_2 .spgnav li {
  border: none;
  position: relative;
}
.sp .spnavi_2 .spgnav li::after {
  position: absolute;
  top: 50%;
  right: 0;
  width: 1px;
  height: 1.3rem;
  margin-top: -0.7rem;
  content: "";
  pointer-events: none;
  background-color: #d9dde3;
}
.sp .spnavi_2 .spgnav li:last-child::after {
  display: none;
}
.sp .spnavi_2 .spgnav li a {
  background: #f1f4f6;
  color: #484848;
  font-size: 120%;
  font-size: 4.2vw;
}
.sp .spnavi_2 .spgnav li a:hover {
  background: #ff790d;
  opacity: 1;
  color: #fff;
}
.sp #spmenu_bar.fadeBtn ul.spgnav {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  z-index: 1;
  opacity: 0.94;
}
.sp #midokoro,
.sp #related,
.sp #cast,
.sp #story,
.sp #intro,
.sp #soukan,
.sp #trailer,
.sp #menu1,
.sp #menu2,
.sp #menu3,
.sp #menu4,
.sp #menu5 {
  margin-top: -44px;
  padding-top: 44px;
}
.sp section h1.border {
  padding: 6px;
  border: 1px solid #CCC;
  text-align: center;
}
.sp section h1.border + h2 {
  text-align: center;
  margin: 1em 0;
  font-size: 14px;
}
.sp section h1.verImg + h2 {
  text-align: center;
  margin: 1em 0;
}
.sp section [class$=_bar] + h2 {
  padding: 3% 0;
}
.sp section [class$=_bar] + h2:empty {
  display: none;
}
.sp section [class^=ttlTyp] {
  margin: 0 0 2vw;
  text-align: center;
}
.sp section h1 {
  font-size: 21px;
}
.sp section h1.headerMain {
  min-height: 150px;
}
.sp section h2 {
  font-size: 14px;
  font-weight: normal;
}
.sp section h3,
.sp section h4 {
  word-break: break-word;
  font-size: 14px;
}
.sp section h1 > small {
  margin-left: 1em;
  font-size: 14px;
}
.sp section .summary,
.sp section p.txt {
  font-size: 12px;
}
.sp section h2,
.sp section h3,
.sp section h4,
.sp section .summary,
.sp section p.txt {
  margin: 0 0.2em;
}
.sp section h3,
.sp section h4,
.sp section .summary,
.sp section p.txt {
  font-weight: normal;
  line-height: 1.5;
}
.sp div.container {
  width: 100%;
  margin: 0 auto;
}
.sp div.container article.contents {
  width: 100%;
}
.sp div.container article.contents .topicPath {
  margin: 0;
  padding: 1vw 2vw 0;
  font-size: 10px;
  max-width: 970px;
  width: 95vw;
  margin-bottom: 1vw;
  line-height: 2;
  overflow: auto;
  white-space: nowrap;
}
.sp div.container article.contents .topicPath span {
  line-height: 1.6;
  font-weight: normal;
  display: inline-block;
  vertical-align: top;
}
.sp div.container article.contents section {
  margin: 0 auto;
  padding-top: 0;
}
.sp div.container article.contents section .mainHeader {
  margin: 0 auto;
}
.sp div.container article.contents section .spnavibox {
  height: 44px;
}
.sp div.container article.contents section.copyright {
  text-align: center;
  width: 90%;
}
.sp section h1.mainCatch_1 {
  padding: 0 0 1vw;
  -webkit-text-stroke: 1px #2196f3;
  text-shadow: 0 0 3px #2196f3;
}
.sp section img {
  margin: 0;
  width: 100%;
}
.sp section a.btn {
  width: 94%;
  margin: 1em auto;
  display: block;
  font-size: 140%;
  line-height: 3;
}
.sp section a.headerButton_1 {
  display: inline-block;
  position: relative;
  width: 84%;
  border-radius: 42px;
  background-color: #ff8d04;
  -webkit-box-shadow: 0 3px 0 #af6003;
  box-shadow: 0 3px 0 #af6003;
  color: #fff;
  font-weight: 900;
  letter-spacing: 0.5px;
  font-size: 140%;
  height: auto;
  margin: 5% auto;
}
.sp section a.headerButton_1:before {
  display: none;
}
.sp section a.headerButton_1:after {
  display: none;
}
.sp section a.headerButton_1:hover {
  opacity: 0.8;
  -webkit-box-shadow: 0 1px 0 #aa5421;
          box-shadow: 0 1px 0 #aa5421;
  -webkit-transform: translateY(2px);
  transform: translateY(2px);
}
.sp section a.headerButton_2 {
  display: block;
  position: relative;
  font-size: 6vw;
  height: auto;
  width: 80%;
  padding-right: 5%;
  margin: 5% auto;
  background-color: #c00;
  color: #fff;
  font-weight: bold;
  text-align: center;
  line-height: 2.8;
  letter-spacing: 1px;
  border-radius: 5px;
  -webkit-box-shadow: 0 3px #8e0202;
  box-shadow: 0 3px #8e0202;
}
.sp section a.headerButton_2:after {
  display: block;
  position: absolute;
  top: 36%;
  right: 5%;
  width: 10px;
  height: 10px;
  border-top: 3px solid #fff;
  border-right: 3px solid #fff;
  content: "";
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.sp section a.headerButton_2:hover {
  opacity: 0.8;
  -webkit-box-shadow: 0 1px 0 #aa5421;
          box-shadow: 0 1px 0 #aa5421;
  -webkit-transform: translateY(2px);
          transform: translateY(2px);
}
.sp section a.headerButton_3 {
  display: block;
  position: relative;
  height: auto;
  width: 90%;
  padding-right: 5%;
  margin: 5% auto;
  border: solid 3px #c00;
  background-color: #fff;
  color: #c00;
  font-size: 6vw;
  font-weight: bold;
  text-align: center;
  line-height: 2.8;
  letter-spacing: 1px;
}
.sp section a.headerButton_3:after {
  display: block;
  position: absolute;
  top: 36%;
  right: 5%;
  width: 10px;
  height: 10px;
  border-top: 3px solid #c00;
  border-right: 3px solid #c00;
  content: "";
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.sp section a.headerButton_3:hover {
  background-color: #ffe5e5;
}
.sp section a.headerButton_4 {
  display: block;
  font-size: 6vw;
  margin-top: 1em;
  text-decoration: underline;
  text-align: center;
  letter-spacing: 1px;
}
.sp section a.headerButton_4:hover {
  background-color: #ffe5e5;
}
.sp section.typeHeader2 div.img {
  display: block;
  width: 100%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  vertical-align: top;
}
.sp section.typeHeader2 div.img img {
  margin: 0.5em 0;
  width: 100%;
}
.sp section.typeHeader2 div.txt {
  display: block;
  width: 100%;
  padding-left: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  vertical-align: top;
}
.sp section.typeHeader2 div.txt img {
  margin: 0.5em 0;
  width: 100%;
}
.sp section.typeHeader2 div.txt a.btn {
  width: 80%;
  margin: 0.5em auto;
  display: block;
  font-size: 16px;
  line-height: 1;
}
.sp section.trailer .staticFrame > * {
  width: 100%;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.sp section.trailer .staticFrame > * .trailermovie {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 98%;
          flex: 0 0 98%;
  margin: 0 0 1%;
}
.sp section.trailer .staticFrame > * .tralerAria {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  width: 100%;
}
.sp section.trailer .trailermovie li.videoBox.snapshot {
  text-align: center;
}
.sp section.trailer .trailerInfo ul.prevew {
  display: inline-block;
  width: 100%;
  margin-top: 0;
}
.sp section.trailer .trailerInfo ul.prevew li:nth-child(even) {
  background: rgba(255, 250, 250, 0.7);
  color: #292929;
}
.sp section.trailer .trailerInfo ul.prevew li {
  margin: 0;
  padding: 1%;
  text-align: left;
  display: box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 98%;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background: rgba(37, 32, 32, 0.5);
  color: #fff;
}
.sp section.trailer .trailerInfo ul.prevew li a {
  display: inline-block;
  width: 60%;
  line-height: 1.3;
  letter-spacing: 0;
  position: relative;
}
.sp section.trailer .trailerInfo ul.prevew li a:after {
  content: "";
  display: inline-block;
  width: 100%;
  height: 100%;
  background: url(/img/pc/parts/play_m.png) 50% 50% no-repeat;
  background-size: cover;
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0.6;
}
.sp section.trailer .trailerInfo ul.prevew li p.movieTtl {
  display: inline-block;
  width: 40%;
  vertical-align: top;
  margin-left: 0.5em;
  font-size: 100%;
  font-weight: normal;
  line-height: 1.5;
  letter-spacing: 0;
  text-align: center;
}
.sp section.trailer .trailerInfo ul.prevew li img {
  width: 100%;
  vertical-align: top;
}
.sp section.sectionType1 p.txt {
  font-size: 100%;
}
.sp section.sectionType1 .imgContainer:before,
.sp section.sectionType1 .imgContainer:after {
  display: none;
}
.sp section.sectionType1 div.imgContainer {
  margin: 1em 0;
  width: 100%;
  /*IE10*/
}
.sp section.sectionType1 div.imgContainer div.unit {
  float: none;
  width: 48%;
  width: calc(50% - 2px);
}
.sp section.sectionType1 div.imgContainer div.unit img {
  width: 100%;
}
.sp section.sectionType1 div.imgContainer div.unit:nth-of-type(1) {
  width: 100%;
  height: auto;
  display: block;
  margin: 1% 0 0;
}
.sp section.sectionType1 div.imgContainer div.unit:nth-child(even),
.sp section.sectionType1 div.imgContainer div.unit:not(:first-of-type) {
  margin: 0 2px 0 0;
  text-align: center;
}
.sp section.sectionType2 h2 + img {
  margin-top: 1em;
  width: 100%;
}
.sp section.sectionType2 .staticFrame img:first-of-type {
  width: 100%;
  padding-bottom: 0;
}
.sp section.sectionType2 .staticFrame .imgContainer {
  display: box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 99%;
  -webkit-box-pack: justify;
  -ms-flex-pack: start;
      justify-content: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  width: 100%;
}
.sp section.sectionType2 .staticFrame .imgContainer div.unit {
  width: 48%;
  width: calc(50% - 2px);
  margin: 2px 1px 0;
  text-align: center;
  position: relative;
}
.sp section.sectionType2 .staticFrame p.txt {
  font-size: 100%;
}
.sp section.sectionType3 h2 + img {
  margin-top: 1em;
  width: 100%;
}
.sp section.sectionType3 div.imgContainer div.unit {
  width: 48%;
  width: calc(50% - 4px);
  margin: 2px;
  text-align: center;
}
.sp section.sectionType3 div.imgContainer div.unit img {
  width: 100%;
}
.sp section.sectionType3 p.txt {
  font-size: 100%;
}
.sp section.sectionType4 div.unit {
  margin: 1em 0;
  min-height: auto;
}
.sp section.sectionType4 div.unit div.img {
  display: block;
  width: 100%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  vertical-align: top;
  margin-bottom: 0;
  max-width: 100%;
}
.sp section.sectionType4 div.unit div.img img {
  width: 100%;
}
.sp section.sectionType4 div.unit div.txt {
  display: block;
  width: 100%;
  padding-left: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  vertical-align: top;
  line-height: 1.4;
  margin-top: 3%;
}
.sp section.sectionType4 div.unit div.txt p.txt {
  font-size: 100%;
}
.sp section.sectionType4#story div.unit div.img {
  position: relative;
}
.sp section.sectionType4#story div.unit .txt {
  width: 98%;
  vertical-align: top;
  line-height: 1.8;
  padding: 0 1vw;
  text-align: left;
  font-size: 100%;
}
.sp section.sectionType5 h3 {
  font-size: 90%;
  line-height: 1.2;
  min-height: 2rem;
}
.sp section.sectionType5 div.imgContainer {
  display: box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-box-pack: justify;
  -ms-flex-pack: start;
      justify-content: flex-start;
  -webkit-box-pack: start;
          justify-content: flex-start;
}
.sp section.sectionType5 div.imgContainer div.unit {
  width: 31%;
  width: 33.3333333333%;
  max-width: 33.3333333333%;
  margin: 0.5em 0 1em;
  text-align: center;
  display: inline-block;
}
.sp section.sectionType5 div.imgContainer div.unit img {
  width: 98%;
  padding: 0 1%;
}
.sp section.sectionType5#intro div.imgContainer div.unit {
  width: 24%;
  width: 25%;
  max-width: 25%;
}
.sp section.sectionType6 div.unit:nth-child(odd) {
  background: #f7f7f7;
}
.sp section.sectionType6 div.imgContainer {
  width: 100%;
}
.sp section.sectionType6 div.imgContainer div.unit {
  display: box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 98%;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin: 0;
  padding: 1em 1% 0 1%;
  margin-bottom: 1vw;
}
.sp section.sectionType6 div.imgContainer div.unit .img img {
  width: 100%;
}
.sp section.sectionType6 div.imgContainer div.unit p.txt {
  display: block;
  width: 100%;
  text-align: left;
  font-size: 100%;
}
.sp section.sectionType6#midokoro .staticFrame .unit .img {
  width: 85%;
  padding-bottom: 20px;
}
.sp section.sectionType6#midokoro .staticFrame .unit .img + .txt {
  width: 98%;
  margin: 0 auto;
}
.sp section.sectionType7 div.imgContainer {
  display: box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-box-pack: justify;
  -ms-flex-pack: start;
      justify-content: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.sp section.sectionType7 div.imgContainer div.unit {
  width: 30%;
  width: calc(33.3333333333% - 4px);
  margin: 0.5em 2px 1em;
  text-align: center;
}
.sp section.sectionType7 div.imgContainer div.unit img {
  width: 100%;
}
.sp section.sectionType7 div.imgContainer div.unit div.txt p.txt {
  font-size: 100%;
}
.sp section.sectionType12 p.subtxt {
  line-height: 1.3;
}
.sp section.sectionType12 div.imgContainer {
  display: box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-box-pack: justify;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.sp section.sectionType12 div.imgContainer div.unit {
  margin: 2px;
  text-align: center;
  width: 48%;
  display: inline-block;
}
.sp section.sectionType12 div.imgContainer div.unit img {
  width: 100%;
}
.sp section.sectionType12 div.imgContainer div.unit div.txt p.txt {
  font-size: 100%;
}
.sp section.present h2 {
  font-weight: bold;
}
.sp section.present h2 + h3 {
  text-align: left;
  line-height: 1.25;
  font-size: 100%;
  margin-bottom: 5%;
  width: 98%;
}
.sp section.present div.imgContainer {
  display: box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 99%;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  max-width: 99%;
}
.sp section.present div.imgContainer div.unit {
  width: 48%;
  width: calc(50% - 4px);
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin: 0.5em 2px 1em;
  text-align: center;
  position: relative;
  max-width: 50%;
  border: solid 2px #2bb3eb;
  padding-top: 5px;
}
.sp section.present div.imgContainer div.unit h3 {
  padding: 0;
}
.sp section.present div.imgContainer div.unit h3 span {
  position: absolute;
  left: 0;
  width: 100%;
  background: #000;
  color: #fff;
  font-size: 90%;
  vertical-align: middle;
  line-height: 1.5;
  bottom: 3em;
  display: block;
  height: 1.6em;
  letter-spacing: 1px;
}
.sp section.present div.imgContainer div.unit img {
  width: 100%;
}
.sp section.present div.imgContainer div.unit div.txt {
  padding: 0 2% 2%;
  line-height: 1.5;
  width: 94%;
  margin: 0 auto;
  text-align: left;
  font-size: 110%;
  text-align: center;
  color: #333;
  font-weight: bold;
  width: 94%;
}
.sp section.present div.imgContainer div.unit div.txt p.txt {
  font-size: 100%;
}
.sp section.present div.imgContainer div.unit div.txt .presentBox {
  font-size: 200%;
  color: #91c426;
}
.sp section.present a.btn {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 80%;
  margin: 0.5em auto;
  display: block;
  font-size: 16px;
  line-height: 1;
}
.sp h1.ttlTyp_1 {
  width: 94%;
  margin: 2% auto 1%;
  padding: 3% 3% 2%;
  background: -webkit-gradient(linear, left top, left bottom, from(#eef0f3), to(rgba(255, 255, 255, 0.2)));
  background: linear-gradient(#eef0f3, rgba(255, 255, 255, 0.2));
  font-size: 100%;
}
.sp h1.ttlTyp_1 span {
  background: #2bb3eb;
  color: #fff;
  font-size: 160%;
  line-height: 1.2;
  padding: 2% 0 1%;
}
.sp h1.ttlTyp_1 span small {
  font-size: 10px;
  letter-spacing: 2px;
}
.sp .trailer .staticFrame {
  width: 100%;
  margin: 0 auto;
}
.sp .staticFrame {
  width: 98%;
  margin: 0 auto;
}
.sp section.sectionType1 div.imgContainer {
  margin: 3% auto;
  display: box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 99%;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  max-width: 99%;
}
.sp section div#menu_bar {
  display: none;
}
.sp section.sectionType1 p.txt {
  padding: 1%;
  line-height: 1.5;
  width: 98%;
  margin: 0 auto 2%;
  text-align: left;
  font-size: 100%;
}
.sp .staticFrame {
  width: 98%;
  margin: 0 auto;
}
.sp section h2 {
  width: 96%;
  margin: 0 auto 1%;
  line-height: 1.4;
  max-width: 32em;
  letter-spacing: 0;
  font-size: 110%;
}
.sp h1.ttlTyp_2 {
  line-height: 1.1;
  margin: 0;
  text-shadow: 0 0 6px #f17023, 1px 1px 6px #f17023, -1px -1px 6px #f17023, 2px 2px 6px #f17023, -2px -2px 6px #f17023;
  color: #fff;
  font-size: 9.5vw;
  text-align: center;
  letter-spacing: 3px;
  -webkit-text-stroke: 1px rgba(242, 112, 33, 0.6);
  margin-bottom: 1%;
  padding: 3% 0 0;
}
.sp h1.ttlTyp_2 small {
  font-size: 4vw;
  letter-spacing: 2px;
  padding-bottom: 1em;
  margin-top: 0.5em;
}
.sp h1.ttlTyp_3 {
  font-size: 120%;
  width: 98%;
  margin: 0 auto 1%;
}
.sp h1.ttlTyp_4 {
  font-size: 160%;
  width: 98%;
  margin: 4vw auto;
}
.sp h1.ttlTyp_4 span {
  line-height: 2;
}
.sp h1.ttlTyp_6 {
  width: 98%;
  margin: 3% auto 2%;
  border-bottom: 2px solid #fff;
  color: #fff;
  text-indent: 1em;
  font-size: 120%;
  text-align: left;
  line-height: 1.75;
}
.sp h1.ttlTyp_6 span small {
  font-size: 10px;
  letter-spacing: 1px;
}
.sp h1.ttlTyp_7 span {
  background-image: url(/special/common/img/waku_2.png), url(/special/common/img/waku_1.png);
  background-position: 99% 72%, 1% 72%;
  background-repeat: no-repeat;
  background-size: 24vw;
  padding: 1vw 25vw;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  max-width: 100%;
  overflow: hidden;
  font-size: 18px;
}
.sp h1.ttlTyp_7 span:before, .sp h1.ttlTyp_7 span:after {
  display: none;
}
.sp .intro_bar + h2,
.sp .story_bar + h2 {
  font-size: 110%;
  text-align: left;
}
.sp .searchTag {
  width: 98%;
  margin: 0 auto;
  margin-bottom: 4%;
  padding: 1% 0 0 0;
  background: #fff;
  font-size: 130%;
  line-height: 1.5;
}
.sp .searchTag h1 {
  width: 98%;
  margin: 0 auto;
  margin-bottom: 4%;
  padding: 4% 0 0 0;
  font-size: 6vw;
  line-height: 1.5;
}
.sp .searchTag ul {
  border: 1px solid #dadada;
  border-top: 1px solid transparent;
  text-align: left;
}
.sp .searchTag ul li {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  margin: 0;
  border-top: 1px solid #dadada;
  vertical-align: top;
  letter-spacing: 0;
  text-align: left;
  padding: 4px;
}
.sp .searchTag ul li:nth-of-type(even) {
  border-right: 1px solid transparent;
}
.sp .searchTag ul li a {
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  overflow: hidden;
  width: 100%;
  height: 44px;
  padding: 0;
  border: none;
  background: #fff;
  color: #000;
  color: #333 !important;
  font-size: 93%;
  text-indent: 1em;
  text-align: left;
  line-height: 44px;
  white-space: nowrap;
  text-overflow: ellipsis;
  -o-text-overflow: ellipsis;
  border: none;
  -webkit-box-shadow: 0 0 0 #fff;
          box-shadow: 0 0 0 #fff;
  position: relative;
}
.sp .searchTag ul li a:before {
  content: "";
  width: 5px;
  height: 24px;
  background: orange;
  display: block;
  position: absolute;
  left: 3px;
  top: 10px;
}
.sp .footer_link {
  margin-top: 10%;
  font-size: 120%;
  font-weight: bold;
  text-decoration: underline;
  text-align: center;
  line-height: 2;
}

/*============================================================
player fit
============================================================*/
.fitWindows header,
.fitWindows #globalNavi,
.fitWindows #headerUtility,
.fitWindows footer {
  display: none;
}
.fitWindows article.contents section {
  display: none;
  margin: 0;
}
.fitWindows article.contents section div#movieInfo .trailTTL {
  display: none;
  margin: 0;
}
.fitWindows article.contents section.trailer {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
}
.fitWindows article.contents section.trailer h2 {
  display: none !important;
}
.fitWindows div.container section.trailer div.txt, .fitWindows div.container section.trailer div.notice {
  display: none !important;
}
.fitWindows article.contents section.trailer {
  margin: 0;
  padding: 0;
  background: none;
}
.fitWindows article.contents section.trailer div.trailermovie,
.fitWindows article.contents section.trailer li.player {
  display: block;
}
.fitWindows article.contents section.trailer div.trailermovie,
.fitWindows article.contents section.trailer li.player,
.fitWindows article.contents section.trailer div#silverlightControlHost {
  display: block;
  overflow: hidden;
  width: 100%;
  height: auto;
}
.fitWindows .container div#movieInfo {
  display: block;
  width: 100%;
}
.fitWindows #Rak_Showtime_Top_FBanner {
  display: none;
}

h1.title + table td {
  padding: 2%;
}

.sp #soukan .staticFrame img {
  margin: 0 auto 3%;
  width: 150px;
}

div[class^=trailer_type]:after {
  display: block;
  clear: both;
  content: "";
}

section.totop {
  display: none;
}
/*# sourceMappingURL=style.css.map */