@charset "UTF-8";
/* 20180321 */
@import "https://fonts.googleapis.com/earlyaccess/notosansjapanese.css";
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video { margin: 0; padding: 0; border: 0; font: inherit; font-size: 100%; vertical-align: baseline; }

html { line-height: 1; }

ol, ul { list-style: none; }

table { border-collapse: collapse; border-spacing: 0; }

caption, th, td { text-align: left; font-weight: normal; vertical-align: middle; }

q, blockquote { quotes: none; }
q:before, q:after, blockquote:before, blockquote:after { content: ""; content: none; }

a img { border: none; }

article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary { display: block; }

/* ========================================================================== mar/pad ========================================================================== */
.mt--0 { margin-top: 0px !important; }

.mt--5 { margin-top: 5px !important; }

.mt--10 { margin-top: 10px !important; }

.mt--20 { margin-top: 20px !important; }

.mt--30 { margin-top: 30px !important; }

.mt--40 { margin-top: 40px !important; }

.mt--50 { margin-top: 50px !important; }

.mt--60 { margin-top: 60px !important; }

.mt--70 { margin-top: 70px !important; }

.mt--80 { margin-top: 80px !important; }

.mt--90 { margin-top: 90px !important; }

.mt--100 { margin-top: 100px !important; }

.mb--0 { margin-bottom: 0px !important; }

.mb--5 { margin-bottom: 5px !important; }

.mb--10 { margin-bottom: 10px !important; }

.mb--20 { margin-bottom: 20px !important; }

.mb--30 { margin-bottom: 30px !important; }

.mb--40 { margin-bottom: 40px !important; }

.mb--50 { margin-bottom: 50px !important; }

.mb--60 { margin-bottom: 60px !important; }

.mb--70 { margin-bottom: 70px !important; }

.mb--80 { margin-bottom: 80px !important; }

.mb--90 { margin-bottom: 90px !important; }

.mb--100 { margin-bottom: 100px !important; }

.mr--0 { margin-right: 0px !important; }

.mr--5 { margin-right: 5px !important; }

.mr--10 { margin-right: 10px !important; }

.mr--20 { margin-right: 20px !important; }

.mr--30 { margin-right: 30px !important; }

.mr--40 { margin-right: 40px !important; }

.mr--50 { margin-right: 50px !important; }

.mr--60 { margin-right: 60px !important; }

.mr--70 { margin-right: 70px !important; }

.mr--80 { margin-right: 80px !important; }

.mr--90 { margin-right: 90px !important; }

.mr--100 { margin-right: 100px !important; }

.ml--0 { margin-left: 0px !important; }

.ml--5 { margin-left: 5px !important; }

.ml--10 { margin-left: 10px !important; }

.ml--20 { margin-left: 20px !important; }

.ml--30 { margin-left: 30px !important; }

.ml--40 { margin-left: 40px !important; }

.ml--50 { margin-left: 50px !important; }

.ml--60 { margin-left: 60px !important; }

.ml--70 { margin-left: 70px !important; }

.ml--80 { margin-left: 80px !important; }

.ml--90 { margin-left: 90px !important; }

.ml--100 { margin-left: 100px !important; }

.pt--0 { padding-top: 0px !important; }

.pt--5 { padding-top: 5px !important; }

.pt--10 { padding-top: 10px !important; }

.pt--15 { padding-top: 15px !important; }

.pt--20 { padding-top: 20px !important; }

.pt--30 { padding-top: 30px !important; }

.pt--40 { padding-top: 40px !important; }

.pt--50 { padding-top: 50px !important; }

.pt--60 { padding-top: 60px !important; }

.pt--70 { padding-top: 70px !important; }

.pt--80 { padding-top: 80px !important; }

.pt--90 { padding-top: 90px !important; }

.pt--100 { padding-top: 100px !important; }

.pb--0 { padding-bottom: 0px !important; }

.pb--5 { padding-bottom: 5px !important; }

.pb--10 { padding-bottom: 10px !important; }

.pb--20 { padding-bottom: 20px !important; }

.pb--30 { padding-bottom: 30px !important; }

.pb--40 { padding-bottom: 40px !important; }

.pb--50 { padding-bottom: 50px !important; }

.pb--60 { padding-bottom: 60px !important; }

.pb--70 { padding-bottom: 70px !important; }

.pb--80 { padding-bottom: 80px !important; }

.pb--90 { padding-bottom: 90px !important; }

.pb--100 { padding-bottom: 100px !important; }

.pr--0 { padding-right: 0px !important; }

.pr--5 { padding-right: 5px !important; }

.pr--10 { padding-right: 10px !important; }

.pr--20 { padding-right: 20px !important; }

.pr--30 { padding-right: 30px !important; }

.pr--40 { padding-right: 40px !important; }

.pr--50 { padding-right: 50px !important; }

.pr--60 { padding-right: 60px !important; }

.pr--70 { padding-right: 70px !important; }

.pr--80 { padding-right: 80px !important; }

.pr--90 { padding-right: 90px !important; }

.pr--100 { padding-right: 100px !important; }

.pl--0 { padding-left: 0px !important; }

.pl--5 { padding-left: 5px !important; }

.pl--10 { padding-left: 10px !important; }

.pl--20 { padding-left: 20px !important; }

.pl--30 { padding-left: 30px !important; }

.pl--40 { padding-left: 40px !important; }

.pl--50 { padding-left: 50px !important; }

.pl--60 { padding-left: 60px !important; }

.pl--70 { padding-left: 70px !important; }

.pl--80 { padding-left: 80px !important; }

.pl--90 { padding-left: 90px !important; }

.pl--100 { padding-left: 100px !important; }

footer { width: 100%; height: auto; margin: 0 auto; padding: 0; box-sizing: border-box; -moz-box-sizing: border-box; -webkit-box-sizing: border-box; display: block; position: relative; background: #333; padding-bottom: 20px; }
@media screen and (max-width: 768px) { footer { padding-bottom: 80px; } }
footer .footerMenu { width: 100%; height: auto; margin: 0 auto; padding: 30px 0 10px; box-sizing: border-box; -moz-box-sizing: border-box; -webkit-box-sizing: border-box; display: block; text-align: center; }
footer .footerMenu li { width: auto; height: auto; margin: 0; padding: 5px 0; box-sizing: border-box; -moz-box-sizing: border-box; -webkit-box-sizing: border-box; display: inline-block; position: relative; }
footer .footerMenu li a { width: auto; height: auto; margin: 0 auto; padding: 0 10px; box-sizing: border-box; -moz-box-sizing: border-box; -webkit-box-sizing: border-box; position: relative; font-size: 14px; color: #fff; text-decoration: none; border-right: 1px solid #fff; }
footer .footerMenu li:last-child a { border: none; }
footer .copyright { width: 100%; height: 50px; margin: 0; padding: 0 0; box-sizing: border-box; -moz-box-sizing: border-box; -webkit-box-sizing: border-box; display: block; font-size: 14px; background: #333; text-align: center; color: #fff; font-size: 0.8em; text-align: center; line-height: 50px; }
@media screen and (max-width: 768px) { footer .copyright { line-height: 1.1; padding: 0 15px; } }

#toTop { position: fixed; z-index: 10001; right: 0; bottom: 77px; width: 70px; height: 70px; background-color: rgba(184, 13, 0, 0.65); -webkit-transition: all 0.3s ease; transition: all 0.3s ease; }

#toTop.hidden { right: -70px; }

/* ##############################################################
#    #fixedNav
############################################################## */
#fixedNav { position: fixed; z-index: 10001; right: 0; bottom: 0; padding-right: 12px; font-size: 0; background-color: #fff; box-shadow: 0 0 18px 0 rgba(0, 0, 0, 0.5); -webkit-transform: scale(0.75); transform: scale(0.75); -webkit-transform-origin: right bottom; transform-origin: right bottom; -webkit-transition: all 0.3s ease; transition: all 0.3s ease; line-height: 0; }

#fixedNav.hidden { right: -700px; }

#fixedNav li { display: inline-block; vertical-align: middle; font-size: 12px; }

#fixedNav li:nth-child(2) { margin-left: 24px; }

#fixedNav li:nth-child(3) { margin-left: 34px; }

#fixedNav li:nth-child(4) { margin-left: 19px; }

#fixedNav li:nth-child(5) { margin-left: 10px; }

@media screen and (max-width: 768px) { /* ############################################################## #    #fixedNav ############################################################## */
  #fixedNav { position: fixed; right: 0; bottom: 0; padding-right: 1.88%; -webkit-transform: scale(1); transform: scale(1); }
  #fixedNav.hidden { right: 0; bottom: -100px; }
  #fixedNav li:nth-child(1) { width: 28.75%; }
  #fixedNav li:nth-child(2) { width: 13.75%; margin-left: 3.75%; }
  #fixedNav li:nth-child(3) { width: 10.16%; margin-left: 5.31%; }
  #fixedNav li:nth-child(4) { width: 16.09%; margin-left: 2.97%; }
  #fixedNav li:nth-child(5) { width: 15.3%; margin-left: 1.56%; }
  #fixedNav img { max-width: 100%; width: 100%; height: auto; } }
body { font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Noto Sans Japanese", "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, Meiryo, sans-serif; font-weight: 700; font-size: 16px; line-height: 1.5; color: #333; }

.inner { position: relative; max-width: 1280px; width: 100%; margin: 0 auto; -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; }

li { display: inline-block; }

a { color: #333; text-decoration: none; -moz-transition: all 0.5s; -o-transition: all 0.5s; -webkit-transition: all 0.5s; transition: all 0.5s; }
a:hover { text-decoration: none; }

a.hoveropacity:hover { text-decoration: none; filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=70); opacity: 0.7; }

br.tiny { display: none; }
@media screen and (max-width: 320px) { br.tiny { display: block; } }

.title { background: #ed6c00; width: 100%; display: block; text-align: center; position: relative; }
.title h2 { display: block; vertical-align: middle; font-size: 70px; line-height: 1; padding: 0.5em 0 0.5em 0; color: #fff; z-index: 2; position: relative; }
@media screen and (max-width: 768px) { .title h2 { font-size: 6vw; } }
.title:after { content: ""; position: absolute; border-left: 42px solid transparent; border-right: 42px solid transparent; border-top: 42px solid #ed6c00; bottom: -42px; left: 50%; margin-left: -42px; }
@media screen and (max-width: 768px) { .title:after { bottom: -21px; z-index: 1; } }

.playmark { position: absolute; top: 50%; left: 50%; z-index: 10; margin-top: -84px; margin-left: -84px; -moz-transform-origin: center 50%; -ms-transform-origin: center 50%; -webkit-transform-origin: center 50%; transform-origin: center 50%; }
@media screen and (max-width: 768px) { .playmark { -moz-transform: scale(0.6, 0.6); -ms-transform: scale(0.6, 0.6); -webkit-transform: scale(0.6, 0.6); transform: scale(0.6, 0.6); } }
.playmark a { display: block; -moz-transform: scale(0.9, 0.9); -ms-transform: scale(0.9, 0.9); -webkit-transform: scale(0.9, 0.9); transform: scale(0.9, 0.9); -moz-transition: all 0.5s; -o-transition: all 0.5s; -webkit-transition: all 0.5s; transition: all 0.5s; }
.playmark a:hover { -moz-transform: scale(1, 1); -ms-transform: scale(1, 1); -webkit-transform: scale(1, 1); transform: scale(1, 1); }
.playmark a:focus { outline: none; }

.sp_banner { display: none; }
@media screen and (max-width: 768px) { .sp_banner { display: block; } }
.sp_banner a { display: block; height: 53px; }
.sp_banner a img { height: 53px; width: auto; }

.topics_new { position: relative; }
@media screen and (max-width: 768px) { .topics_new { margin-top: 40px !important; } }

.topics_new:before { content: "NEW!"; position: absolute; top: 8px; left: -55px; font-size: 10px; display: block; background: red; padding: 1px 5px; vertical-align: middle; letter-spacing: 1px; }
@media screen and (max-width: 768px) { .topics_new:before { content: "NEW!"; position: absolute; top: -15px; left: 0; font-size: 10px; display: block; background: red; padding: 1px 5px; vertical-align: middle; letter-spacing: 1px; } }

/* header */
header { position: relative; background-image: url("../images/mainvisual.jpg"); background-size: cover; background-position: top center; z-index: 1; overflow: hidden; }
header .inner { z-index: 20; }
header section.top { max-height: 874px; }
header h1 { filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=0); opacity: 0; padding-top: 54px; }
header h1 img { max-width: 100%; height: auto; }
@media screen and (max-width: 1280px) { header h1 { padding-left: 15px; width: 37%; height: auto; } }
@media screen and (max-width: 768px) { header h1 { padding-top: 27px; width: 60%; height: auto; padding-left: 15px; } }
header p.read { filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=0); opacity: 0; padding: 50px 0 77px 0; }
header p.read img { max-width: 100%; height: auto; }
@media screen and (max-width: 1280px) { header p.read { padding-left: 15px; width: 50%; height: auto; padding-bottom: 15; } }
@media screen and (max-width: 768px) { header p.read { padding-top: 27px; width: 43%; height: auto; padding-left: 15px; padding-bottom: 15; } }
header .horse { filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=0); opacity: 0; position: absolute; right: 0; bottom: 120px; z-index: -1; text-align: right; }
header .horse img { max-width: 100%; height: auto; }
@media screen and (max-width: 960px) { header .horse { right: -27%; bottom: 0; } }
@media screen and (max-width: 768px) { header .horse { right: -160px; bottom: 0; } }
header .sp_top { display: none; }
@media screen and (max-width: 768px) { header .sp_top { display: block; }
  header .sp_top p { font-size: 0; }
  header .sp_top p img { width: 100%; }
  header section.top { display: none; } }
header .sns { position: absolute; left: 10px; top: 10px; z-index: 999; }
@media screen and (max-width: 768px) { header .sns { left: auto; right: 10px; } }
header .sns li { margin-right: 10px; }
header .sns li a { display: block; -moz-transition: all 0.3s; -o-transition: all 0.3s; -webkit-transition: all 0.3s; transition: all 0.3s; }
header .sns li a:hover { -moz-transform: scale(1.05, 1.05); -ms-transform: scale(1.05, 1.05); -webkit-transform: scale(1.05, 1.05); transform: scale(1.05, 1.05); }
header .right_banner { position: absolute; right: 27px; top: 300px; width: 220px; z-index: 80; }
header .right_banner a { display: block; margin: 20px 0; line-height: 0; -moz-box-shadow: 0 0 10px rgba(0, 0, 0, 0.2); -webkit-box-shadow: 0 0 10px rgba(0, 0, 0, 0.2); box-shadow: 0 0 10px rgba(0, 0, 0, 0.2); -moz-transition: all 0.3s; -o-transition: all 0.3s; -webkit-transition: all 0.3s; transition: all 0.3s; }
header .right_banner a:hover { filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=70); opacity: 0.7; }
@media screen and (max-width: 768px) { header .right_banner a { -moz-box-shadow: 0 0 0 rgba(0, 0, 0, 0.2); -webkit-box-shadow: 0 0 0 rgba(0, 0, 0, 0.2); box-shadow: 0 0 0 rgba(0, 0, 0, 0.2); } }
@media screen and (max-width: 768px) { header .right_banner { width: auto; position: absolute; bottom: 0; top: unset; right: unset; left: 2%; margin-bottom: 60px; text-align: left; }
  header .right_banner a { display: inline-block; box-shadow: none; margin: 10px 0; margin-right: 5px; }
  header .right_banner a img { width: auto; height: 15vw; } }

.banner { position: absolute; right: 27px; top: 0; z-index: 9999; }
@media screen and (max-width: 768px) { .banner { display: none; } }
.banner a { display: block; line-height: 0; -moz-box-shadow: 0 0 10px rgba(0, 0, 0, 0.2); -webkit-box-shadow: 0 0 10px rgba(0, 0, 0, 0.2); box-shadow: 0 0 10px rgba(0, 0, 0, 0.2); -moz-transition: all 0.3s; -o-transition: all 0.3s; -webkit-transition: all 0.3s; transition: all 0.3s; }
.banner a:hover { filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=70); opacity: 0.7; }

main { position: relative; z-index: 100; }

/* nav */
nav { width: 100%; background-color: #ed6c00; position: relative; z-index: 90; }
nav ul { display: table; table-layout: fixed; border-right: solid 1px #fff; }
@media screen and (max-width: 1280px) { nav ul { border-right: none; } }
nav ul li { width: 25%; padding: 0 0px; border-left: solid 1px #fff; display: table-cell !important; @inlude border-box("border-box"); }
@media screen and (max-width: 1280px) { nav ul li:first-child { border-left: none; } }
nav ul li a { font-size: 20px; display: block; padding: 50px 0; text-align: center; color: #fff; line-height: 17px; line-height: 1.3; }
@media screen and (max-width: 768px) { nav ul li a { font-size: 3.125vw; line-height: 1.3; padding: 12px 0; } }
nav ul li a span { display: inline-block; position: relative; vertical-align: middle; }
@media screen and (max-width: 768px) { nav ul li a span { font-size: 10px; padding: 0 5px; } }
@media screen and (max-width: 320px) { nav ul li a span { padding: 0 3px; } }
nav ul li a span br { display: none; }
@media screen and (max-width: 768px) { nav ul li a span br { display: block; } }
nav ul li a span:before { position: relative; content: "\f061"; font-family: FontAwesome; font-size: 17px; margin-right: 5px; top: -1px; }
@media screen and (max-width: 768px) { nav ul li a span:before { display: none; } }
nav ul li a:hover { color: #ed6c00; }

/* movie */
section.movie { position: relative; line-height: 0; height: 41vw; background-color: #000; }
section.movie .mainImgWrap { width: 100%; height: 100%; position: absolute; top: 0; left: 0; }
@media screen and (max-width: 768px) { section.movie .mainImgWrap { position: relative; } }
section.movie .mainImgWrap .mainImg { width: 100%; height: auto; }
@media screen and (max-width: 768px) { section.movie .mainImgWrap .mainImg { width: auto; height: 100%; } }
section.movie .mainImgWrap .mainImgSp { width: 100%; height: auto; }
@media screen and (max-width: 768px) { section.movie .mainImgWrap .mainImgSp { width: 100%; height: auto; } }

/* topics */
section.topics { padding: 80px 0; background: #9ea9ad; }
@media screen and (max-width: 768px) { section.topics { padding: 40px 0; } }
section.topics .topics_area { display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: flex-start; align-items: flex-start; }
@media screen and (max-width: 768px) { section.topics .topics_area { display: block; } }
section.topics .topics_area h2 { background-color: #ed6c00; color: #fff; display: inline-block; padding: 0px 0 0px 12px; line-height: 50px; font-size: 26px; margin-right: 10%; position: relative; height: 50px; letter-spacing: 2px; }
section.topics .topics_area h2:after { content: ""; border-style: solid; border-width: 25px 0 25px 25px; border-color: transparent transparent transparent #ed6c00; position: absolute; right: -25px; }
section.topics .topics_area dl { color: #fff; font-size: 22px; margin-left: 9em; }
section.topics .topics_area dl dt { display: inline-block; clear: both; float: left; text-align: left; position: relative; margin-left: -9em; }
section.topics .topics_area dl dt:after { content: "/"; text-align: center; display: inline-block; width: 3em; position: absolute; }
section.topics .topics_area dl dd { display: inline-block; float: left; text-align: left; margin-bottom: 5px; }
section.topics .topics_area dl dd a { color: #fff; }
section.topics .topics_area dl .youtube_link a { outline: none; }
@media screen and (max-width: 768px) { section.topics .topics_area dl { font-size: 3.75vw; margin: 15px; display: block; }
  section.topics .topics_area dl dt { display: block; float: none; margin: 0; }
  section.topics .topics_area dl dd { display: block; float: none; } }

/* series */
section.series { background-image: url("../images/series_bg.jpg"); background-size: cover; background-position: top center; padding-bottom: 100px; }
@media screen and (max-width: 960px) { section.series { padding-bottom: 50px; } }
section.series .concept { padding: 120px 0 80px 0; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: flex-start; align-items: flex-start; }
@media screen and (max-width: 960px) { section.series .concept { display: block; padding: 60px 15px; } }
section.series .concept h3 { color: #ed6c00; font-size: 48px; line-height: 64px; }
@media screen and (max-width: 960px) { section.series .concept h3 { text-align: left; font-size: 10vw; line-height: 1.3; } }
section.series .concept p { padding-top: 3px; text-align: left; font-size: 20px; line-height: 32px; }
@media screen and (max-width: 960px) { section.series .concept p { text-align: left; margin-top: 10px; font-size: 4.375vw; line-height: 1.3; } }
@media screen and (max-width: 375px) { section.series .concept p { font-size: 4vw; } }
@media screen and (max-width: 320px) { section.series .concept p { font-size: 3.9vw; } }
section.series .content_few { margin-top: 90px; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-wrap: wrap; flex-wrap: wrap; }
@media screen and (max-width: 960px) { section.series .content_few { padding: 0 15px; } }
@media screen and (max-width: 768px) { section.series .content_few { margin-top: 45px; } }
section.series .content_few .one_block { max-width: 376px; width: 100%; margin: 40px 0; }
@media screen and (max-width: 1280px) { section.series .content_few .one_block { width: 28%; } }
@media screen and (max-width: 960px) { section.series .content_few .one_block { width: 44%; } }
@media screen and (max-width: 768px) { section.series .content_few .one_block { max-width: 768px; width: 100%; } }
section.series .content_full { display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; }
@media screen and (max-width: 960px) { section.series .content_full { padding: 0 15px; } }
@media screen and (max-width: 768px) { section.series .content_full { display: block; } }
section.series .content_full .left { width: 39%; -moz-box-sizing: borde-box; -webkit-box-sizing: borde-box; box-sizing: borde-box; }
section.series .content_full .left.one_block { padding: 20px; }
@media screen and (max-width: 960px) { section.series .content_full .left { width: 50%; } }
@media screen and (max-width: 768px) { section.series .content_full .left { width: auto; } }
section.series .content_full .right { width: 64%; -moz-box-sizing: borde-box; -webkit-box-sizing: borde-box; box-sizing: borde-box; line-height: 0; position: relative; overflow: hidden; }
section.series .content_full .right img { height: 100%; width: auto; }
@media screen and (max-width: 960px) { section.series .content_full .right { width: 50%; } }
@media screen and (max-width: 768px) { section.series .content_full .right { width: 100%; } }
section.series .one_block { position: relative; display: block; background-color: #fff; padding: 20px 20px; }
section.series .one_block .logo { text-align: center; }
section.series .one_block .logo img { max-width: 250px; width: 100%; height: auto; }
section.series .one_block .name { font-size: 24px; padding-bottom: 10px; color: #ed6c00; border-bottom: 2px solid #000; font-weight: bold; text-align: center; display: table; table-layout: fixed; width: 100%; }
@media screen and (max-width: 768px) { section.series .one_block .name { font-size: 18px; } }
section.series .one_block .name span { display: table-cell; vertical-align: middle; }
section.series .one_block .catch { padding-top: 12px; text-align: center; font-weight: 400; font-size: 16px; line-height: 1.8; }
@media screen and (max-width: 768px) { section.series .one_block .catch { font-size: 14px; } }
@media screen and (max-width: 375px) { section.series .one_block .catch { font-size: 13px; } }
@media screen and (max-width: 320px) { section.series .one_block .catch { font-size: 12px; } }
section.series .one_block .link { margin: 12px auto 0; text-align: center; }
section.series .one_block .link a { color: #000; padding: 10px 25px; display: inline-block; border: 2px solid #000; }
section.series .one_block .link a:before { position: relative; content: "\f061"; font-family: FontAwesome; font-size: 17px; margin-right: 5px; top: -1px; }
section.series .close_block:before { position: absolute; content: "開催終了"; background-color: #fff; left: 0; top: -0.8em; font-size: 26px; color: #ed6c00; padding: 9px 10px; border: solid 1px #ed6c00; line-height: 1; }
@media screen and (max-width: 768px) { section.series .close_block:before { font-size: 16px; top: -18px; } }
section.series .off_block:before { position: absolute; content: "coming soon"; background-color: #fff; left: 0; top: -0.8em; font-size: 26px; color: #ed6c00; padding: 9px 10px; border: solid 1px #ed6c00; line-height: 1; }
@media screen and (max-width: 768px) { section.series .off_block:before { font-size: 16px; top: -18px; } }
section.series .sp_block:before { position: absolute; content: "6月3日（日）より開催"; background-color: #fff; left: 0; top: -0.8em; font-size: 26px; color: #ed6c00; padding: 9px 10px; border: solid 1px #ed6c00; line-height: 1; }
@media screen and (max-width: 768px) { section.series .sp_block:before { font-size: 16px; top: -18px; } }
section.series .label { position: absolute; background-color: #ed6c00; left: 0; top: -0.8em; font-size: 26px; color: #fff; padding: 9px 10px; border: solid 1px #ed6c00; line-height: 1; }
@media screen and (max-width: 768px) { section.series .label { font-size: 16px; top: -18px; } }
section.series .label:after { content: ""; border-style: solid; border-width: 22px 0 24px 24px; border-color: transparent transparent transparent #ed6c00; position: absolute; right: -25px; top: -1px; }
@media screen and (max-width: 768px) { section.series .label:after { font-size: 16px; border-width: 18px 0px 18px 19px; right: -19px; } }

/* special */
section.special { background-color: #ebebeb; }
section.special .read { padding: 120px 0 80px 0; font-size: 20px; line-height: 32px; text-align: center; }
@media screen and (max-width: 768px) { section.special .read { text-align: left; margin-top: 10px; font-size: 4.375vw; line-height: 1.3; padding: 40px 15px; } }
@media screen and (max-width: 375px) { section.special .read { font-size: 4vw; } }
@media screen and (max-width: 320px) { section.special .read { font-size: 3.9vw; } }
section.special .sp_movie { position: relative; }
section.special .sp_movie .sp_mainImgWrap { font-size: 0; }
section.special .sp_movie .sp_mainImgWrap img { width: 100%; height: auto; }
section.special .inner { text-align: center; padding: 40px 0; }
section.special .inner .player_movie { overflow: hidden; width: 100%; max-width: 800px; background: #fff; margin: auto; }
section.special .inner .player_movie .toggle { width: 100%; max-width: 800px; background: #ed6c00; color: #fff; padding: 16px 0; display: block; margin: auto; position: relative; cursor: pointer; }
section.special .inner .player_movie .toggle:hover { opacity: 0.7; }
section.special .inner .player_movie .toggle:after { content: "▼"; position: absolute; margin-left: 15px; display: inline-block; }
section.special .inner .player_movie .inner_child { display: none; }
section.special .inner .player_movie ul { margin: auto; padding: 60px 0; width: 100%; max-width: 700px; }
section.special .inner .player_movie ul li { display: block; width: 100%; text-align: left; box-sizing: border-box; padding: 20px 50px; border-top: 1px dotted #EC6C02; }
@media screen and (max-width: 768px) { section.special .inner .player_movie ul li { padding: 20px; }
  section.special .inner .player_movie ul li .link { width: 80%; margin: 20px 0; } }
section.special .inner .player_movie ul li .label { display: inline-block; background: #ed6c00; color: #fff; font-size: 14px; padding: 5px 15px; position: relative; width: 42px; }
section.special .inner .player_movie ul li .label:after { content: ""; border-style: solid; border-width: 15px 0 16px 16px; border-color: transparent transparent transparent #ed6c00; position: absolute; right: -16px; top: 0; }
section.special .inner .player_movie ul li .date { display: inline-block; padding-left: 50px; padding-right: 20px; width: 100px; }
section.special .inner .player_movie ul li .icon { display: inline-block; vertical-align: -7px; padding-left: 50px; float: right; }
@media screen and (max-width: 768px) { section.special .inner .player_movie ul li .icon { padding-left: 0; margin: 20px 0; } }
section.special .inner .player_movie ul li .icon img { padding-top: 3px; }
section.special .inner .player_movie ul li a { outline: none; }
section.special .inner .player_movie ul li:last-child { border-bottom: 1px dotted #EC6C02; }

/* place */
section.place { background-image: url("../images/place_bg.jpg"); background-size: cover; background-position: top center; padding-bottom: 100px; }
@media screen and (max-width: 1280px) { section.place .inner { padding: 0 15px; } }
section.place .read { padding: 80px 0; font-size: 20px; line-height: 32px; text-align: center; }
@media screen and (max-width: 768px) { section.place .read { text-align: left; margin-top: 10px; font-size: 4.375vw; line-height: 1.3; padding: 40px 0; } }
@media screen and (max-width: 375px) { section.place .read { font-size: 4vw; } }
@media screen and (max-width: 320px) { section.place .read { font-size: 3.9vw; } }
section.place .list { display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-align-items: flex-start; align-items: flex-start; -webkit-flex-wrap: wrap; flex-wrap: wrap; }
@media screen and (max-width: 1280px) { section.place .list { -webkit-justify-content: center; justify-content: center; } }
@media screen and (max-width: 768px) { section.place .list { -webkit-justify-content: center; justify-content: center; } }
section.place .list li { padding: 0 10px; margin-bottom: 36px; text-align: center; }
section.place .list li img { max-width: 100%; height: auto; }
@media screen and (max-width: 1280px) { section.place .list li.large { width: 100%; display: block; } }
@media screen and (max-width: 768px) { section.place .list li { width: 44%; }
  section.place .list li img { max-width: 100%; height: auto; }
  section.place .list li.large { width: 100%; text-align: center; } }
@media screen and (max-width: 375px) { section.place .list li { width: 40%; } }
section.place .list li a { display: block; line-height: 0; }

/* site */
section.site { background-color: #9ba7ab; padding-bottom: 100px; }
@media screen and (max-width: 1280px) { section.site .inner { padding: 0 15px; } }
section.site .read { padding: 80px 0; color: #ffffff; font-size: 20px; line-height: 32px; text-align: center; }
@media screen and (max-width: 768px) { section.site .read { text-align: left; margin-top: 10px; font-size: 4.375vw; line-height: 1.3; padding: 40px 0; } }
section.site .link { color: #fff; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-align-items: flex-start; align-items: flex-start; }
@media screen and (max-width: 1280px) { section.site .link { display: block; } }
@media screen and (max-width: 960px) { section.site .link { display: block; } }
section.site .link .left { margin-top: 70px; }
section.site .link .left .frame { padding: 48px; border: solid 1px #fff; position: relative; margin: 0 30px; padding-top: 84px; width: 758px; -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; }
@media screen and (max-width: 1280px) { section.site .link .left .frame { max-width: 758px; width: 100%; margin: 0 auto; } }
@media screen and (max-width: 960px) { section.site .link .left .frame { width: auto; margin: 0 auto; padding: 48px 24px 24px 24px; } }
section.site .link .left .frame h4 { display: inline-block; position: absolute; top: -70px; left: 0; width: calc(70% - 36px); text-align: center; margin-left: 15%; background-color: #ed6c00; color: #fff; line-height: 1.8; font-size: 26px; border: solid 1px #fff; padding: 18px; }
@media screen and (max-width: 960px) { section.site .link .left .frame h4 { width: 90%; margin-left: 5%; -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; padding: 9px; font-size: 15px; } }
section.site .link .left .frame h4:after, section.site .link .left .frame h4:before { top: 100%; left: 50%; border: solid transparent; content: " "; height: 0; width: 0; position: absolute; pointer-events: none; }
section.site .link .left .frame h4:after { border-color: rgba(255, 147, 23, 0); border-top-color: #ed6c00; border-width: 15px; margin-left: -15px; }
section.site .link .left .frame h4:before { border-color: rgba(255, 255, 255, 0); border-top-color: #ffffff; border-width: 16px; margin-left: -16px; }
section.site .link .left .block { display: inline-block; text-align: center; padding-right: 39px; }
section.site .link .left .block p { font-size: 20px; font-weight: 400; margin-bottom: 10px; }
@media screen and (max-width: 960px) { section.site .link .left .block p { font-size: 16px; } }
section.site .link .left .block a { display: block; line-height: 0; }
@media screen and (max-width: 768px) { section.site .link .left .block { display: block; padding: 0; margin: 10px 0; }
  section.site .link .left .block img { width: 100%; height: auto; } }
section.site .link .left .up { border-bottom: dotted 1px #fff; padding-bottom: 10px; margin-bottom: 10px; text-align: center; }
@media screen and (max-width: 768px) { section.site .link .left .up { border: none; margin: 0; padding: 0; } }
section.site .link .left .down { text-align: center; }
section.site .link .right { padding-left: 50px; }
@media screen and (max-width: 1280px) { section.site .link .right { padding-top: 50px; padding-left: 0; } }
@media screen and (max-width: 768px) { section.site .link .right { padding-top: 0; padding-left: 0; } }
@media screen and (max-width: 1280px) { section.site .link .right .right-inner { max-width: 758px; margin: 0 auto; letter-spacing: -6px; } }
section.site .link .right .app, section.site .link .right .sns { margin-bottom: 30px; }
@media screen and (max-width: 1280px) { section.site .link .right .app, section.site .link .right .sns { display: inline-block; width: 50%; letter-spacing: normal; vertical-align: top; } }
@media screen and (max-width: 768px) { section.site .link .right .app, section.site .link .right .sns { margin-right: 0; } }
section.site .link .right .app, section.site .link .right .sns { background: #fff; text-align: center; letter-spacing: 1.0em; width: 383px; }
@media screen and (max-width: 1280px) { section.site .link .right .app, section.site .link .right .sns { width: 48%; margin-left: 4%; margin-bottom: 0; } }
@media screen and (max-width: 960px) { section.site .link .right .app, section.site .link .right .sns { width: 100%; margin: 0 auto 30px; }
  section.site .link .right .app:last-child, section.site .link .right .sns:last-child { margin-bottom: 0; } }
section.site .link .right .app .hp_sns, section.site .link .right .sns .hp_sns { width: 100%; text-align: center; letter-spacing: 0.2em; font-size: 1.5vw; background-color: #ed6c00; box-sizing: border-box; padding: 10px; position: relative; border: 1px solid #fff; }
@media screen and (max-width: 960px) { section.site .link .right .app .hp_sns, section.site .link .right .sns .hp_sns { font-size: 25px; } }
section.site .link .right .app .hp_sns:after, section.site .link .right .app .hp_sns:before, section.site .link .right .sns .hp_sns:after, section.site .link .right .sns .hp_sns:before { top: 100%; left: 50%; border: solid transparent; content: " "; height: 0; width: 0; position: absolute; pointer-events: none; }
section.site .link .right .app .hp_sns:after, section.site .link .right .sns .hp_sns:after { border-color: rgba(255, 147, 23, 0); border-top-color: #ed6c00; border-width: 15px; margin-left: -15px; }
section.site .link .right .app .hp_sns:before, section.site .link .right .sns .hp_sns:before { border-color: rgba(255, 255, 255, 0); border-top-color: #ffffff; border-width: 16px; margin-left: -16px; }
section.site .link .right .app .inner, section.site .link .right .sns .inner { box-sizing: border-box; padding: 35px 20px 20px 20px; }
@media screen and (max-width: 1280px) { section.site .link .right .app .inner, section.site .link .right .sns .inner { display: table; table-layout: fixed; } }
@media screen and (max-width: 1280px) { section.site .link .right .app .inner-item, section.site .link .right .sns .inner-item { display: table-cell; vertical-align: middle; } }
@media screen and (max-width: 1280px) { section.site .link .right .app { margin-left: 0; } }
section.site .link .right .sns_fb, section.site .link .right .sns_tw { display: inline-block; }
section.site .link .right .sns_fb img, section.site .link .right .sns_tw img { width: 100%; max-width: 90px; }
@media screen and (max-width: 1280px) { section.site .link .right { width: auto; }
  section.site .link .right img { max-width: 100%; height: auto; } }
@media screen and (max-width: 960px) { section.site .link .right { margin-top: 30px; text-align: center; }
  section.site .link .right li { display: block; } }

/* buy */
section.buy { background-color: #e8eef0; padding-bottom: 100px; }
@media screen and (max-width: 1280px) { section.buy { padding-bottom: 50px; }
  section.buy .inner { padding: 0 15px; } }
section.buy .read { padding: 80px 0; color: #000000; font-size: 20px; line-height: 32px; text-align: center; }
@media screen and (max-width: 768px) { section.buy .read { text-align: left; margin-top: 10px; font-size: 4.375vw; line-height: 1.3; padding: 40px 0; } }
section.buy .link { text-align: center; }
section.buy .link a { display: block; line-height: 0; -moz-transition: all 0.3s; -o-transition: all 0.3s; -webkit-transition: all 0.3s; transition: all 0.3s; }
section.buy .link a:hover { -moz-transform: scale(1.05, 1.05); -ms-transform: scale(1.05, 1.05); -webkit-transform: scale(1.05, 1.05); transform: scale(1.05, 1.05); }
@media screen and (max-width: 768px) { section.buy .link img { max-width: 100%; height: auto; } }

.environment { margin-top: 20px; padding: 0 15px; }
.environment p { font-size: 10px; line-height: 1.1; font-size: 11px; color: #939393; font-weight: 400; }
.environment br.sp { display: none; }
@media screen and (max-width: 768px) { .environment br.sp { display: block; } }

/* hover.css update */
.hvr-bounce-to-right:before { background-color: #ed6c00; }

.hvr-bounce-to-bottom:before { background-color: #ffffff; }

/* loading */
#movieOverlay { display: block; width: 100%; height: 100%; position: absolute; z-index: 100; top: 0; left: 0; filter: progid:DXImageTransform.Microsoft.Alpha(enabled=false); opacity: 1; -moz-transition: width 0.5s linear; -o-transition: width 0.5s linear; -webkit-transition: width 0.5s linear; transition: width 0.5s linear; }
#movieOverlay .movieOverlayInner { display: block; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.6); position: relative; }

#progressWrap { display: block; width: 100%; position: absolute; left: 0; bottom: 0; }
#progressWrap #progressBar { display: block; width: 0%; height: 5px; background-color: #ee6b00; -moz-transition: width 0.5s linear; -o-transition: width 0.5s linear; -webkit-transition: width 0.5s linear; transition: width 0.5s linear; }
