@charset "UTF-8";
/****************
mixin
****************/
/* line 51, ../scss/_common.scss */
.visible-pc {
  display: block;
}
@media screen and (max-width: 480px) {
  /* line 51, ../scss/_common.scss */
  .visible-pc {
    display: none !important;
  }
}

/* line 57, ../scss/_common.scss */
.visible-sp {
  display: block;
}
@media screen and (min-width: 481px) {
  /* line 57, ../scss/_common.scss */
  .visible-sp {
    display: none !important;
  }
}

.visible-s-sp {
  display: block;
}
@media screen and (min-width: 321px) {
  /* line 57, ../scss/_common.scss */
  .visible-s-sp {
    display: none !important;
  }
}

a:focus{
  outline: none;
}

.mpr{
  font-family: "M PLUS Rounded 1c"; 
}
/* line 63, ../scss/_common.scss */
.overFlowHidden {
  overflow: hidden;
}

/* line 66, ../scss/_common.scss */
.w105 {
  width: 105px !important;
}

/* line 69, ../scss/_common.scss */
/*episodeのタブレット・スマホの表示をそろえる*/
/*.mg {
  margin: 5px 0px 5px 340px !important;
}*/

/* line 72, ../scss/_common.scss */
.mxWidthNone {
  transition: 0.4s ease;
  max-width: 100%;
  opacity: 0;
}
@media screen and (max-width: 480px) {
  .mxWidthNone {
    position: relative;/*モーダル時androidズレ防止*/
  }
}
/* line 77, ../scss/_common.scss */
.mxWidth1200 {
  transition: 0.4s ease;
  /*max-width: 1200px;*/
}

/* line 82, ../scss/_common.scss */
.blurShow {
  -webkit-animation: apparition 800ms cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
  animation: apparition 800ms cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}

/* line 87, ../scss/_common.scss */
.blurHide {
  -webkit-animation: disparition 800ms cubic-bezier(0.55, 0.085, 0.68, 0.53) forwards;
  animation: disparition 800ms cubic-bezier(0.55, 0.085, 0.68, 0.53) forwards;
}

@-webkit-keyframes apparition {
  0% {
    filter: blur(0px);
    opacity: 1;
  }
  100% {
    filter: blur(50px);
    opacity: 0;
  }
}
@keyframes apparition {
  0% {
    filter: blur(0px);
    opacity: 1;
  }
  100% {
    filter: blur(50px);
    opacity: 0;
  }
}
@-webkit-keyframes disparition {
  0% {
    filter: blur(50px);
    opacity: 0;
  }
  100% {
    filter: blur(0px);
    opacity: 1;
  }
}
@keyframes disparition {
  0% {
    filter: blur(50px);
    opacity: 0;
  }
  100% {
    filter: blur(0px);
    opacity: 1;
  }
}

/* line 156, ../scss/_common.scss */
.menuAn {
  -webkit-animation: fadeInA 800ms ease forwards;
  animation: fadeInA 800ms ease forwards;
}

@-webkit-keyframes fadeInA {
  0% {
    -webkit-transform: translateY(30%);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateY(0%);
    opacity: 1;
  }
}
@keyframes fadeInA {
  0% {
    transform: translateY(30%);
    opacity: 0;
  }
  100% {
    transform: translateY(0%);
    opacity: 1;
  }
}
/* line 180, ../scss/_common.scss */
.fadeIn {
  -webkit-animation: fadeInB 800ms ease forwards;
  animation: fadeInB 800ms ease forwards;
}

@-webkit-keyframes fadeInB {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeInB {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
/* line 200, ../scss/_common.scss */
.fadeOut {
  -webkit-animation: fadeOut 800ms ease forwards;
  animation: fadeOut 800ms ease forwards;
}

@-webkit-keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}

/* line 290, ../scss/_common.scss */
/*.more {
  position: absolute;
  bottom: 5px;
  right: 7px;
  padding: 0 4px;
  box-sizing: border-box;
  cursor: pointer;
}
.more img{
  max-width: 53px;
}*/

/* line 300, ../scss/_common.scss */
.onair-shadow {
 font-size: 27px;
 text-align: center;
 color: #fff;
 text-shadow: 0px 0px 8px #11fab3;
 margin-bottom: 45px;
}

@media screen and (min-width: 481px) {
  #top footer {
    max-width: 950px;
    margin: 8px auto 10px;
    padding-left: 10px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  #bannerMain {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
  #bannerMain li {
    margin-right: 20px;
  }
}

@media screen and (min-width: 481px) and (max-width: 1200px) {
  #top footer {
    margin-left: 125px;
    width: 100%;
  }
}
body:not(#top) footer {
  background-color: #f5f5f5;
  position: relative;
  padding-top: 15px;
}
body:not(#top) .copy {
  padding: 15px 0 12px;
}
@media screen and (max-width: 480px) {
  body:not(#top) footer {
    padding-top: 25px;
    border-top: 2px solid #4c484c;
  }
}


#bannerMain img {
  max-width: 180px;
  vertical-align: bottom;
}
@media screen and (max-width: 480px) {
  #bannerMain img {
    max-width: 200px;
  }
}

.copy {
  font-size: 1.2rem;
  text-align: center;
  padding: 10px 0;
}
@media screen and (max-width: 480px) {
  .copy {
    font-size: 1.4rem;
    background: #403d40;
    color: #fff;
    padding: 8px 0;
  }
}

/* line 308, ../scss/_common.scss */
.copy2 {
  width: 100%;
  padding: 5px 0 15px;
  color: #211515;
  font-weight: 700;
  font-size: 1.2rem;
  text-align: center;
  background: #fff;
}
@media screen and (max-width: 480px) {
  .copy2 {
    background: #14e8cd;
    color: #fff;
  }
}

/* line 322, ../scss/_common.scss */
.menu-trigger.active {
  -moz-transform: rotate(360deg) !important;
  -webkit-transform: rotate(360deg) !important;
  transform: rotate(360deg) !important;
}

.menu-trigger.active span:nth-of-type(1) {
  -moz-transform: rotate(28deg) !important;
  -webkit-transform: rotate(28deg) !important;
  transform: rotate(28deg) !important;
  top: 48%!important;
}

#navToggle.menu-trigger.active span:nth-of-type(2) {
  display: none;
}

/* line 344, ../scss/_common.scss */
.menu-trigger.active span:nth-of-type(3) {
  -moz-transform: rotate(-28deg) !important;
  -webkit-transform: rotate(-285deg) !important;
  transform: rotate(-28deg) !important;
  top: 48%!important;
}

/* line 356, ../scss/_common.scss */
::selection {
  background: #d74594;
  color: #fff;
}

/* line 360, ../scss/_common.scss */
::-moz-selection {
  background: #d74594;
  color: #fff;
}

a {
  display: block;
  text-decoration: none;
  color: #da1259;
  transition: .4s ease;
}
/* line 369, ../scss/_common.scss */
a img {
  outline: none;
}
@media screen and (min-width: 481px) {
  /* line 373, ../scss/_common.scss */
  a:hover {
    opacity: 0.4;
  }
}
/* line 377, ../scss/_common.scss */
a:active {
  text-decoration: none;
  border-width: 0px;
  border-style: none;
  border-color: transparent;
}

/* line 384, ../scss/_common.scss */
#close {
  transition: 1s ease;
}
/* line 386, ../scss/_common.scss */
#close:hover {
  opacity: 0.4;
}

@media all and (-ms-high-contrast: none) and (min-width: 481px){
  .w-ie{
    width: 100%;
    min-width: 1200px;
  }
}

/* line 390, ../scss/_common.scss */
html {
  width: 100%;
  height: 100%;
  font-size: 62.5% /* 基準を10pxに */
}
@media screen and (max-width: 480px) {
  html {
    font-size: 54.5%
  }
}


/* line 394, ../scss/_common.scss */
body {
  width: 100%;
  height: 100%;
  font-size: 1.6em; /* 16px ここだけem指定 */
  font-family: "Noto Sans JP","游ゴシック", Yu Gothic, "ヒラギノ丸ゴ Pro W4", "Hiragino Maru Gothic Pro", sans-serif;
  font-weight: 500;
  line-height: 1.5;
  color: #494549;
  -webkit-text-size-adjust: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}


/* line 408, ../scss/_common.scss */
img {
  pointer-events: none;
  max-width: 100%;
}


/*TOPアニメーション*/
.top-hide {
  opacity: 0;
}
.loading {
  position: fixed;
  top: 0;
  z-index: 9999999;
  width: 100vw;
  height: 100vh;
  background: #fff;
}
.loading-img {
  text-align: center;
}
.loading-img svg {
  width: 600px;
  margin-top: calc((100vh - 200px) / 2);
}
@media screen and (max-width: 480px) {
  .loading-img svg {
    width: 300px;
  }
}
.line {
  stroke:#4c484c;
  fill:#333;
  fill-opacity: 0;
  stroke-width:1;
  stroke-dasharray: 3000;
  stroke-dashoffset: 3000;
  -webkit-animation: Line 5s ease-in 0s forwards;
  animation: Line 5s ease-in 0s forwards;
}
.line2 {
  stroke-dasharray: 700;
  stroke-dashoffset: 700;
  -webkit-animation: Line2 5s ease-in 0s forwards;
  animation: Line2 5s ease-in 0s forwards;
}
@keyframes Line{
  0% {stroke-dashoffset: 3000; fill-opacity: 0;}
  50% {fill-opacity: 0;}
  60% {fill-opacity: 1; stroke-opacity: 1;}
  80% {stroke-opacity: 0;}
  100% {stroke-dashoffset: 0; stroke-opacity: 0; fill-opacity: 1;}
}
@-webkit-keyframes Line{
  0% {stroke-dashoffset: 3000; fill-opacity: 0;}
  50% {fill-opacity: 0;}
  60% {fill-opacity: 1; stroke-opacity: 1;}
  80% {stroke-opacity: 0;}
  100% {stroke-dashoffset: 0; stroke-opacity: 0; fill-opacity: 1;}
}
@keyframes Line2{
  0% {stroke-dashoffset: 700; fill-opacity: 0;}
  50% {fill-opacity: 0;}
  60% {fill-opacity: 1; stroke-opacity: 1;}
  65% {stroke-opacity: 0;}
  100% {stroke-dashoffset: 0; stroke-opacity: 0; fill-opacity: 1;}
}
@-webkit-keyframes Line2{
  0% {stroke-dashoffset: 700; fill-opacity: 0;}
  50% {fill-opacity: 0;}
  60% {fill-opacity: 1; stroke-opacity: 1;}
  65% {stroke-opacity: 0;}
  100% {stroke-dashoffset: 0; stroke-opacity: 0; fill-opacity: 1;}
}

/*
@-webkit-keyframes blink{
    0% {opacity:0;}
    100% {opacity:.8;}
}
@keyframes blink{
    0% {opacity:0;}
    100% {opacity:.8;}
}
*/

/* IEでは非表示 */
_:-ms-lang(x)::-ms-backdrop, .loading {
  display: none;
}


/* font */
h2,
.more-btn,
.youtube #close,
.back-btn,
#cast h3,
.tab,
#music h4 {
  font-family: mr-eaves-modern, sans-serif;
  font-weight: 800;
  font-style: normal;
}

#menu,
#menuSP {
  font-family: mr-eaves-modern, sans-serif;
  font-weight: 800;
  font-style: normal;
}
#menu span,
#menuSP span {
  font-family: noto sans JP;
  font-size: 0.7em;
  font-weight: 600;
  padding: 0 .1em;
}
/* line 412, ../scss/_common.scss */
#menu.PC{
  padding: 5px 0 0 40px;
}

/* line 418, ../scss/_common.scss */
#menu.PC > li:last-of-type {
  margin-bottom: 30px;
}
/* line 421, ../scss/_common.scss */
#menu.PC > li a {
  padding: 10px 0 5px;
  font-size: 1.9rem;
  color: #636063;
}
/* coming soon */
#menu.PC > li.cs {
  padding: 10px 0 5px;
  font-size: 1.9rem;
  color: #b7b7b7;
}

#menu.PC > li a:hover{
  opacity: 1;
  color: #93bfc3;
}

/* line 431, ../scss/_common.scss */
#sns.PC {
  margin-top: 20px;
  text-align: center;
  background-color: #93bfc3;
  padding: 5px 0;
  border-radius: 0 2em 2em 0;
}
/* line 435, ../scss/_common.scss */
#sns.PC > li {
  display: inline-block;
}
/* line 437, ../scss/_common.scss */
#sns.PC > li:nth-of-type(1) {
  margin-right: 20px;
}
/* line 440, ../scss/_common.scss */
#sns.PC > li a {
  display: block;
}
/* line 442, ../scss/_common.scss */
#sns.PC > li a img {
  display: inline-block;
  vertical-align: bottom;
  width: 29px;
}

/* line 450, ../scss/_common.scss */
main {
  width: 100%;
  margin: 0 auto;
  position: relative;
}
#home {
  max-width: 1200px;
  width: 1200px;
}
@media screen and (max-width: 480px) {
  /* line 450, ../scss/_common.scss */
  main {
    max-width: 768px;
    min-width: initial;
    overflow: hidden;
  }
  #home {
    width: 100%;
  }
}

/* line 459, ../scss/_common.scss */
main #modalVideo {
  display: none;
  z-index: 99999;
  width: 100vw;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  background: -moz-linear-gradient(left, #b0c9cb 30%, #4c484c 30%, #4c484c 31%, #ffffff 31%); 
  background: -webkit-linear-gradient(left, #b0c9cb 30%, #4c484c 30%, #4c484c 31%, #ffffff 31%); 
  background: linear-gradient(to right, #b0c9cb 30%, #4c484c 30%, #4c484c 31%, #ffffff 31%);
}
/* line 467, ../scss/_common.scss */
main #modalVideo #video {
  cursor: default;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  display: block;
  z-index: 99;
  box-shadow: 0px 0px 10px 3px rgba(0, 0, 0, 0.4);
  width: 90%;
  max-width: 900px;
}
/* line 479, ../scss/_common.scss */
main #modalVideo #video .youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
/* line 483, ../scss/_common.scss */
main #modalVideo #video .youtube #close {
  position: absolute;
  top: -45px;
  right: 0px;
  cursor: pointer;
  z-index: 9;

  display: inline-block;
  padding: 0 .2em 0 1.4em;
  color: #8bb8bb;
  font-size: 2.1rem;
  line-height: 1;
  border-bottom: 2px dotted #8bb8bb;
}
main #modalVideo #video .youtube #close::after {
  content: "";
  display: inline-block;
  width: 17px;
  height: 2px;
  border-bottom: 2px dotted #8bb8bb;
  -webkit-transform: rotate(-23deg);
  transform: rotate(-23deg);
  position: absolute;
  bottom: 1px;
  left: -1px;
}
/* line 490, ../scss/_common.scss */
main #modalVideo #video .youtube #close img {
  display: block;
  width: 100%;
}
/* line 495, ../scss/_common.scss */
main #modalVideo #video .youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}
/* line 504, ../scss/_common.scss */
main #modalVideo #modal {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 100vw;
  height: 100vh;
}
/* line 514, ../scss/_common.scss */
main > section {
  margin: 0 auto;
  width: 100%;
  background-position: top;
  background-repeat: no-repeat;
  display: flex;
  justify-content: space-between;
  align-items: stretch !important;
}

@media screen and (min-width: 481px) and (max-width: 1000px) {
  main > section {
  background-size: auto;
 }
}
@media screen and (max-width: 480px) {
  /* line 514, ../scss/_common.scss */
  main > section {
    display: block;
    /*min-height: calc(100vh - 35px - 50px);*/
    /* #contentのmargin-top分とコピーライト分を引く*/
  }
}
#mainInner {
  position: relative;
}
@media screen and (min-width: 481px) {
  #mainInner #content > h1 img {
    display: block;
    height: 100px;
    margin-left: 60px;
  } 
}
@media screen and (max-width: 480px) {
  #mainInner #content > h1 img {
    display: inline-block;
    height: 60px;
    margin-top: 10px;
  } 
}

/* line 528, ../scss/_common.scss */
main > section nav {
  width: 100%;
}

main:not(#home) .sp-top-nav {
  width: 100%;
  position: absolute;
  top: 0;
  z-index: 2;
}
main:not(#home) .yoko,
#home .tate {
  display: block;
}
#home .yoko,
main:not(#home) .tate {
  display: none;
}
/* sp logo tate */
.tate {
  width: 40px;
  position: absolute;
  top: 27px;
  left: 11px;
  z-index: 1;
}
/*top sp logo*/
.logo-sp {
  width: 222px;
  position: absolute;
  left: 3vw;
  bottom: 2%;
}
@media screen and (max-width: 360px) {
  .logo-sp {
    width: 200px;
  }
}
@media screen and (max-width: 320px) {
  .logo-sp {
    width: 180px;
  }
}
/* line 531, ../scss/_common.scss */
/*main > section nav .navInner header {
  padding: 8px;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 999;
  display: flex;
  box-sizing: border-box;
}*/
main:not(#home) .sp-top-nav header {
  padding: 12px 0;
  border-bottom: 2px solid #494549;
  background-color: #fff;
}

main:not(#home) .sp-top-nav h1 {
  max-width: 120px;
  margin: auto;
  margin-left: 30px;
}
main:not(#home) .sp-top-nav h1 img {
  margin-top: 4px;
}

/* line 560, ../scss/_common.scss */
main > section nav .navInner header > div:nth-of-type(1) div.contFrameTop {
  margin: 0 auto;
  width: 100%;
  max-width: 350px;
}
/* line 564, ../scss/_common.scss */
main > section nav .navInner header > div:nth-of-type(1) div.contFrameTop:before, main > section nav .navInner header > div:nth-of-type(1) div.contFrameTop:after {
  content: none;
}
/* line 567, ../scss/_common.scss */
main > section nav .navInner header > div:nth-of-type(1) div.contFrameTop p {
  color: #cf0576;
  font-size: 11px;
  text-align: center;
  line-height: 1.8;
  width: 90%;
  margin: 2px auto;
  padding: 2px 4px;
}

.navInner header > .menu-trigger {
  position: fixed;
  top: 5px;
  right: 0px;
  z-index: 9999998;
}
@media screen and (max-width: 480px) {
  /* line 583, ../scss/_common.scss */
  #navToggle {
    width: 50px;
    height: 45px;
  }
}
/* line 603, ../scss/_common.scss */
#navToggle > span {
  display: block;
  width: 56%;
  border-bottom: solid 2px #4c484c;
  -moz-transition: .35s ease-in-out;
  -webkit-transition: -webkit-transform .35s ease-in-out;
  transition: .35s ease-in-out;
  position: absolute;
  left: 24%;
}
#navToggle.menu-trigger.active > span {
  border-bottom: solid 2px #4c484c;
}
/* line 612, ../scss/_common.scss */
#navToggle > span:nth-child(1) {
  top: 36%;
}
/* line 615, ../scss/_common.scss */
#navToggle > span:nth-child(2) {
  top: 47%;
}
/* line 618, ../scss/_common.scss */
#navToggle > span:nth-child(3) {
  top: 58%;
}
/* line 624, ../scss/_common.scss */
.navInner #menuSP {
  display: none;
  position: fixed;
  z-index: 999999;
  right: 0px;
  top: 0;
  background-color: #b0c9cb;
  width: 100%;
  height: 100vh;
  box-sizing: border-box;
}
/* line 639, ../scss/_common.scss */
.navInner #menuSP div {
  display: -ms-flex;
  display: flex;
  -ms-flex-direction: column;
  flex-direction: column;
  /*height: calc(100vh - 160px);*/
}
/* line 645, ../scss/_common.scss */
#menuSP .SP {
  padding-left: 50px;
}
#menuSP .SP > li {
  margin-bottom: 15px;
}
@media screen and (max-width: 320px) {
  #menuSP .SP > li {
    margin-bottom: 10px;
  }
}
/* line 648, ../scss/_common.scss */
#menuSP .SP a {
  color: #636063;
  font-size: 2.6rem;
}
/* coming soon  */
#menuSP .SP .cs {
  font-size: 2.6rem;
  color: #b7b7b7;
}

#menuSP > div {
  background: -moz-linear-gradient(left, #b0c9cb 17%, #fff 17%); 
  background: -webkit-linear-gradient(left, #b0c9cb 17%, #fff 17%); 
  background: linear-gradient(to right, #b0c9cb 17%, #fff 17%);
  padding: 32px 0;
}
.menu-logo {
  text-align: center;
  margin-bottom: 40px;
}
.menu-logo img {
  width: 175px;
}

#sns-sp {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding-top: 35px;
}
#sns-sp li:first-of-type {
  margin-right: 37px;
}
#sns-sp img {
  width: 45px;
}

@media screen and (max-height: 640px) {
  .navInner #menuSP div {
    height: calc(100vh - 160px);
  }
  .menu-logo {
    margin-bottom: 10px;
  }
  #sns-sp {
    padding-top: 25px;
  }
}


/* line 678, ../scss/_common.scss */
main > section aside {
  align-items: center;
  min-height: 100vh;
  background-size: auto 100%;
  background-repeat: no-repeat;
}
main > section aside#fixRe {
  position: absolute;
  z-index: 1;
}
main:not(#home) > section aside {
  position: fixed;
}

@media screen and (max-width: 480px) {
  /* line 678, ../scss/_common.scss */
  main > section aside {
    display: block;
  }
}


.asideInner {
  width: 155px;
  box-sizing: border-box;
}
.logo {
  margin-top: 35px;
  margin-left: 40px;
  width: 310px;
}
.logo img {
  display: block;
  width: 100%;
  margin: auto;
}
main:not(#home) .logo {
  width: 210px;
}

.asideInner #bannerMain ul li{
  width: 100%;
  margin-bottom: 10px;
  margin-left: 42px;
}
/* line 733, ../scss/_common.scss */
#recentArea {
  margin: 40px 20px 0 40px;
}

/*safari対応*/
@media screen and (-webkit-min-device-pixel-ratio:0) {
  _::-webkit-full-page-media, _:future, :root #recentArea {
    width: 100%;
  }
}
@media screen and (max-width: 480px) {
  /* line 733, ../scss/_common.scss */
  #recentArea {
    display: none;
  }
}
/* line 755, ../scss/_common.scss */
#recentArea h1 img {
  width: 100%;
  vertical-align: bottom;
}
/* line 763, ../scss/_common.scss */
#recentArea ul {
  min-width: 240px;
  position: relative;
  box-sizing: border-box;
  padding: 25px 20px;
  background: rgba(255,255,255,.85);
}
/* line 766, ../scss/_common.scss */
#recentArea ul li {
  line-height: 1.4;
  margin-bottom: 15px;
  padding-bottom: 15px;
  border-bottom: solid 1px #6a84f0;
  font-size: 1.3rem;
}
/* line 771, ../scss/_common.scss */
#recentArea ul li:last-child {
  padding-bottom: 0;
  border-bottom: none;
  margin-bottom: 0;
}
/* line 776, ../scss/_common.scss */
#recentArea ul li a {
  color: #0d0701;
  line-height: 1.6;
  font-weight: 500;
}

@media screen and (max-width: 320px) {
  /* line 8, ../scss/_home.scss */
  #home.saf > section #pr {
    bottom: calc(21vh - 100px) !important;
  }
}
/* line 14, ../scss/_home.scss */
#home.saf > section #scllBt {
  top: calc(100vh - 40px) !important;
}
@media screen and (max-width: 480px) {
  /* line 14, ../scss/_home.scss */
  #home.saf > section #scllBt {
    top: calc(100vh - 40px) !important;
    width: 100%;
   margin-top: 30px;
  }
}


@media screen and (min-width: 481px) {
  #home .main-content{
    width: calc(100% - 125px);
    margin-left: 125px;
  }
  .kv{
    width: 950px;
  }
  .r-content{
    width: 560px;
    height: 100%;
    position: absolute;
    top: 0;
    right: 40px;
    box-sizing: border-box;
    padding-right: 10px;
  }
}

/*kv*/
.kv {
  position: relative;
}
.kv p {
  padding-top: 70px;
}
@media screen and (max-width: 480px){
  .kv p {
    padding: 40px 20px;
    box-shadow: 0 1px 10px rgba(186, 199, 199, .6);
  }
}

#mediaLink {
  width: 160px;
  position: absolute;
  left: 30px;
  top: 42%;
  z-index: 1;
}

@media screen and (max-width: 480px){
  #mediaLink {
    width: 102px;
    left: auto;
    right: 25px;
    top: 14.5%;
  }
}


.cf-anime-link {
  width: 185px;
  margin: 0 10px 0 auto;
  box-shadow: 2px 2px 5px rgba(57,54,57,.35);
}
.cf-anime-link img {
  vertical-align: bottom;
}

@media screen and (max-width: 480px) {
  .cf-anime-link {
    width: 130px;
    position: fixed;
    left: 15px;
    top: auto;
    bottom: 25px;
    z-index: 2;
  }
}


/* r-content */
.top-onair {
  margin-top: 40px;
  margin-bottom: 35px;
}
.top-onair img {
  max-width: 520px;
}
@media screen and (max-width: 480px) {
  .top-onair {
    position: absolute;
    top: 27px;
    left: 60px;
    margin-top: 0;
  }
  .top-onair img {
    max-width: 82.5%;
  }
}

#pvMain {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  margin-bottom: 13px;
}
@media screen and (max-width: 480px) {
  #pvMain {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    background-color: #e9f0f1;
    padding: 40px 20px;
    margin-bottom: 0;
    border-bottom: 2px solid #403d40;
  }
}

#pvMain h2 {
  color: #4c484c;
  font-size: 3.6rem;
  line-height: .7;
  padding-right: 13px;
  border-right: 2px solid #494549;
  margin-right: 10px;
}
.before-img img {
  max-width: 320px;
  vertical-align: bottom;
}
.playBtn {
  display: inline-block;
  position: relative;
}
.playBtn > img {
  max-width: 195px;
  vertical-align: bottom;
}
.playBtn > a {
  cursor: pointer;
  position: absolute;
  width: 55px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
}
.playBtn:nth-of-type(1) {
  z-index: 1;
  margin-right: 10px;
}


@media screen and (max-width: 480px) {
  #pvMain h2 {
    font-size: 3.3rem;
  }
  .playBtn > img,
  .before-img img {
    max-width: 70vw;
  }
  .playBtn > a {
    width: 65px;
  }
  .playBtn:nth-of-type(1){
    margin-right: 0;
  }
  .playBtn:nth-of-type(2){
    margin-top: 20px;
  }
}
@media screen and (max-width: 320px) {
  .playBtn > img,
  .before-img img {
    max-width: 67vw;
  }
}


#newsMain {
  width: 230px;
  margin: 0 0 30px auto;
  text-align: right;
}
#newsMain > h2{
  text-align: right;
  font-size: 3.6rem;
  color: #f96389;
}
.tn-cont {
  margin-bottom: 15px;
}
.tn-cont p.date {
  color: #f96389;
  font-size: 1.3rem;
  line-height: 1.4;
}
.tn-cont p.title {
  color: #494549;
  font-size: 1.6rem;
  font-weight: 500;
  margin-bottom: 10px;
  line-height: 1.4;
}
#newsMain .more-btn a {
  color: #f96389;
}
@media screen and (max-width: 480px) {
  #newsMain {
    width: calc(90% - 20px);
    padding: 20px 20px 30px 0;
    margin-bottom: 0;
    position: relative;
  }
  #newsMain > h2 {
    font-size: 3.3rem;
    display: inline-block;
    position: absolute;
    right: 20px;
    top: -20px;
    z-index: 1;
  }
  #newsMain > h2::after {
    content: "";
    display: inline-block;
    width: 3.1em;
    height: .9em;
    background-color: #fff;
    position: absolute;
    bottom: 0;
    left: -.3em;
    z-index: -1;
  }
}


#twitterMain {
  width: 320px;
  position: absolute;
  bottom: 125px;
  left: -518px;
  padding: 0 0 25px;
  background: rgba(255,255,255,.7);
}
#twitterMain > h2 {
  font-size: 3.6rem;
  color: #00b3b7;
  line-height: 1.2;
  position: relative;
  z-index: 1;
  margin-top: -23px;
}


.twitter-bg {
  margin-bottom: 15px;
  padding: 0 25px 0 0;
  box-sizing: border-box;
  height: 190px;
  /*overflow: auto;/*ios twitterスクロールさせる*/
  /*-webkit-overflow-scrolling:touch;/*ios twitterスクロールさせる*/
  /*-ms-overflow-style:none;/*IE Edgeスクロールバー非表示*/
}
.twitter-cont::-webkit-scrollbar{
  display: none;/*chrome safari スクロールバー非表示*/
}
.twitter-cont {
  height: 100%;
  max-height: 200px;
  overflow: scroll;/*ios twitterスクロールさせる*/
  -webkit-overflow-scrolling: touch;/*ios twitterスクロールさせる*/
  -ms-overflow-style: none;/*IE Edgeスクロールバー非表示*/
}
#twitterMain .more-btn,
#twitterMain .more-btn::after {
  border-color: #00b3b7;
}
#twitterMain .more-btn a {
  color: #00b3b7;
  padding-right: 1.1em;
}
#twitterMain .more-btn a::after {
  content: "";
  display: inline-block;
  width: 12px;
  height: 14px;
  background-image: url(../img/outside_icon.svg);
  background-repeat: no-repeat;
}
@media screen and (max-width: 480px) {
  #twitterMain {
    width: 100%;
    border-top: 2px solid #403d40;
    border-bottom: 2px solid #403d40;
    position: relative;
    bottom: 0;
    left: 0;
    background-color: #e9f0f1;
    padding-bottom: 30px;
  }
  #twitterMain::after {
    content: "";
    display: inline-block;
    width: 13%;
    height: 100%;
    background-color: #fff;
    position: absolute;
    top: 0;
    right: 0;
    border-left: 2px solid #403d40;
  }
  #twitterMain h2 {
    font-size: 3.3rem;
    line-height: 1.5;
    display: inline-block;
    position: absolute;
    left: 20px;
    top: -20px;
    z-index: 1;
    margin-top: 0;
  }
  #twitterMain h2::after {
    content: "";
    display: inline-block;
    width: 4.5em;
    height: .9em;
    background-color: #e9f0f1;
    position: absolute;
    bottom: 0;
    left: -.2em;
    z-index: -1;
  }
  .twitter-bg {
    height: 250px;
    padding: 25px 15px;
    width: calc(95% - 30px);
    margin-bottom: 0;
  }
  #twitterMain .more-btn {
    margin-left: 20px;
  }
}

@media screen and (max-width: 480px) {
  #top #bannerMain {
    padding: 30px 0;
    text-align: right;
    position: relative;
  }
  #top #bannerMain::after {
    content: "";
    display: inline-block;
    width: calc(100% - 242px);
    height: 100%;
    background-color: #b0c9cb;
    position: absolute;
    top: 0;
    left: 0;
    border-right: 2px solid #403d40;
  }
  #bannerMain {
    padding-bottom: 13px;
    text-align: center;
  }
  #bannerMain li {
    margin: 0 20px 13px;
  }
  #bannerMain li,
  #bannerMain li a {
    display: inline-block;
  }
}


.more-btn {
  display: inline-block;
  font-size: 2.1rem;
  line-height: 1;
  border-bottom: 2px dotted #f96389;
  position: relative;
}
.more-btn a {
  padding: 0 1.4em 0 .2em;
}
.more-btn::after {
  content: "";
  display: inline-block;
  width: 17px;
  height: 2px;
  border-bottom: 2px dotted #f96389;
  -webkit-transform: rotate(23deg);
  transform: rotate(23deg);
  position: absolute;
  bottom: 1px;
  right: -1px;
}
.more-btn:hover,
.back-btn:hover {
  opacity: .4;
  transition: 0.8s ease;
}

.back-btn {
  display: inline-block;
  font-size: 2.1rem;
  line-height: 1;
  border-bottom: 2px dotted #f96389;
  position: relative;
}
.back-btn::after {
  content: "";
  display: inline-block;
  width: 17px;
  height: 2px;
  border-bottom: 2px dotted #f96389;
  -webkit-transform: rotate(-23deg);
  transform: rotate(-23deg);
  position: absolute;
  bottom: 1px;
  left: -1px;
}
.back-btn a {
  padding: 0 .5em 0 1.4em;
}


/*IE対応*/
_:-ms-lang(x)::-ms-backdrop, main {
  display: block;
}
@media screen and (min-width: 481px) {
  _:-ms-lang(x)::-ms-backdrop, #mainInner {
    min-height: calc(100vh - 35px);
  }
}



#mainInner {
  width: calc(100% - 200px);
  margin-left: 200px;
}
@media screen and (max-width: 480px) {
  #mainInner {
    width: 100%;
    margin: 0;
  }
}
/* 装飾 */
#mainInner::before {
  content: "";
  display: inline-block;
  width: 250px;
  height: 200px;
  position: fixed;
  top: 140px;
}
#mainInner::after {
  content: "";
  display: inline-block;
  width: 120px;
  height: 150px;
  position: fixed;
  top: 516px;
}
#content {
  margin-left: 100px;
  padding-top: 80px;
  min-height: calc(100vh - 200px);
  /* footerとpadding-top分 */
  border-left: 2px solid #4c484c;

  /*background-size: 220px;
  background-repeat: no-repeat;
  background-position: top 300px right 30px;
  background-attachment: fixed;*/
}
#content::before {
  content: "";
  display: inline-block;
  width: 219px;
  height: 144px;
  position: fixed;
  top: 300px;
  right: 30px;
}
@media screen and (min-width: 481px) {
  #content {
    min-width: 700px;
  }
}
@media screen and (max-width: 480px) {
  /*見えにくそう
  #mainInner::before {
    width: 150px;
    background-size: contain;
    background-repeat: no-repeat;
    top: 130px;
    left: 10px;
  }
  #mainInner::after {
    width: 60px;
    background-size: contain;
    background-repeat: no-repeat;
    top: 410px;
    left: 10px;
  }
  #content::before {
    width: 120px;
    background-size: contain;
    background-repeat: no-repeat;
    top: 240px;
    right: 10px;
  }*/
  #mainInner::before,
  #mainInner::after,
  #content::before {
    content: none;
  }
}
#content > div {
  width: 93.5%;
  max-width: 1000px;
  position: relative;
  margin: 30px auto 0;
  padding-bottom: 60px;
  z-index: 1;
}
#content #pgNation {
  margin: 0 auto;
  padding-bottom: 30px;
}

main:not(#home) h2 {
  display: inline-block;
  font-size: 3.5rem;
  line-height: 1;
  color: #4c484c;
  border-bottom: 4px solid #4c484c;
  padding: 0 60px 0 3px;
}
@media screen and (max-width: 480px) {
  main:not(#home) h2 {
    font-size: 3.3rem;
    border-bottom: 3px solid #4c484c;
  }
  #content {
    margin-left: 25px;
    min-height: calc(100vh - 300px);
  }
}


/*CHARA*/
#character #mainInner {
  background: -moz-linear-gradient(bottom, #e0f1f7 95px, #f3f9fb 95px, #f3f9fb 700px, #fff 700px); 
  background: -webkit-linear-gradient(bottom, #e0f1f7 95px, #f3f9fb 95px, #f3f9fb 700px, #fff 700px); 
  background: linear-gradient(to top, #e0f1f7 95px, #f3f9fb 95px, #f3f9fb 700px, #fff 700px);
}
#character #content > div {
  width: 100%;
  padding-bottom: 0;
} 
#content #charaDetail {
  margin-top: 20px;
}
@media screen and (max-width: 480px) {
  #character #mainInner {
    background: -moz-linear-gradient(bottom, #e0f1f7 224px, #f3f9fb 224px, #f3f9fb 882px, #fff 882px); 
    background: -webkit-linear-gradient(bottom, #e0f1f7 224px, #f3f9fb 224px, #f3f9fb 882px, #fff 882px); 
    background: linear-gradient(to top, #e0f1f7 224px, #f3f9fb 224px, #f3f9fb 882px, #fff 882px);
  }

  #charaDetail {
    width: 100%;
    box-sizing: border-box;
    padding: 0;
  }
}
@media screen and (min-width: 481px) and (max-width: 991px) {
  /*タブレットのみ背景追加*/
  #charaDetail {
    background: -moz-linear-gradient(bottom, #e0f1f7 95px, #f3f9fb 95px, #f3f9fb 700px, #fff 700px); 
    background: -webkit-linear-gradient(bottom, #e0f1f7 95px, #f3f9fb 95px, #f3f9fb 700px, #fff 700px); 
    background: linear-gradient(to top, #e0f1f7 95px, #f3f9fb 95px, #f3f9fb 700px, #fff 700px);
  }
}
/* line 70, ../scss/_character.scss */
#charaDetail img {
  display: block;
  width: 100%;
  margin: auto;
}

#charaDetail .slider-nav-wrap {
  margin-bottom: 50px;
}
@media screen and (max-width: 480px) {
	#charaDetail .slider-nav-wrap {
	  margin-bottom: 20px;
	}
}
/* line 79, ../scss/_character.scss */
#charaDetail .slider-nav {
  text-align: center;
}
/* line 81, ../scss/_character.scss */
#charaDetail .slider-nav li {
  outline: none;
  cursor: pointer;
  float: none;
  display: inline-block;
  max-width: 130px;
  margin-left: -15px;
  vertical-align: bottom;
}
@media screen and (min-width: 481px) {
  #charaDetail .slider-nav li:first-of-type {
    margin-left: 0;
  }
}
@media screen and (max-width: 480px) {
  #charaDetail .slider-nav li {
    max-width: 75px;
    min-width: 40px;
    margin-left: -10px;
  }
}

#charaDetail .slider-nav li img{
  width: 100%;
  display: block;
  pointer-events: auto;
  transition-duration: 0.3s;  /*変化に掛かる時間*/
}
#charaDetail .slider-nav li img:hover {
  opacity: .5;
}


/* line 99, ../scss/_character.scss */
#charaDetail .slider {
  max-width: 600px;
  margin: 0 auto;
}
#charaDetail .slider-main {
  line-height: 0;
}
#charaDetail .slider-main button {
  background-color: rgba(0,0,0,0);
  border: none;
  width: 90px;
  height: 19px;
  outline: none;
  cursor: pointer;
}
#charaDetail .slider-main button:hover {
  opacity: .7;
}
#charaDetail .slider-main button[class="slick-prev slick-arrow"] {
  position: absolute;
  bottom: 105px;
  left: -15%;
  z-index: 1;
}
#charaDetail .slider-main button[class="slick-next slick-arrow"] {
  position: absolute;
  bottom: 105px;
  right: -15%;
  z-index: 1;
}
@media screen and (max-width: 1150px){
  #charaDetail .slider-main button[class="slick-prev slick-arrow"] {
    left: -5%;
  }
  #charaDetail .slider-main button[class="slick-next slick-arrow"] {
    right: -5%;
  }
}
@media screen and (max-width: 480px) {
  #charaDetail .slider-main button[class="slick-prev slick-arrow"] {
    left: 2%;
    bottom: 20px;
  }
  #charaDetail .slider-main button[class="slick-next slick-arrow"] {
    right: 2%;
    bottom: 20px;
  }
}

#charaDetail .slider-main li {
  position: relative;
}
#charaDetail .slider-main li:focus {
  outline: none;
}


.name {
  width: 336px;
  margin: 80px auto 40px 40px;
}
.full-body {
  width: 207px;
  position: absolute;
  top: 5px;
  right: 0;
}
#charaDetail .profile {
  height: 92px;
  margin: 0 auto 50px 60px;
  font-size: 1.4rem;
  line-height: 1.7;
}
.face {
  width: 366px;
  margin-bottom: 190px;
}

@media screen and (max-width: 480px) {
  .name {
    width: 80%;
    margin: 30px auto 20px 20px;
  }
  .full-body {
    width: 190px;
    position: static;
    margin: auto;
    /*margin-right: 10px;*/
  }

  #charaDetail .profile {
    margin: 20px auto 60px 20px;
  }
  .face {
    /*width: 260px;
    position: absolute;
    top: 17%;
    left: 10px;
    z-index: -1;*/

    display: none;
  }
}

/*NEWS*/
#news #mainInner::before,
#news-d #mainInner::before {
  background-image: url(../img/news/news_bg00.jpg);
}
#news #mainInner::after,
#news-d #mainInner::after {
  background-image: url(../img/news/news_bg02.jpg);
}
#news #content::before,
#news-d #content::before {
  background-image: url(../img/news/news_bg01.jpg);
}

#news #newsDetail {
  padding-bottom: 40px;
}

@media screen and (max-width: 480px) {
  #newsEntries {
    padding: 0;
    margin-right: 0;
    width: 100%;
  }
}
#newsEntries .entry {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  margin-bottom: 20px;
  box-sizing: border-box;
  padding: 10px 25px 10px 20px;
  background: #fff;
  border: 1px solid #494549;
}

#newsEntries .entry:last-of-type {
  margin-bottom: 0px;
}

#newsEntries p.date {
  font-size: 1.3rem;
  font-weight: 500;
  color: #f96389;
  margin-top: .2em;
  margin-right: 20px;
}

#newsEntries .entry h3 {
  font-size: 1.8rem;
  font-weight: 500;
}
#news #newsEntries .entry h3 {
  font-weight: 400;
}
#newsEntries .entry h3 {
  color: #494549;
}
@media screen and (max-width: 480px) {
  #newsEntries .entry {
    display: block;
    padding: 10px 15px;
    margin-bottom: 15px;
  }
  #newsEntries p.date {
    width: 100%;
  }
  #newsEntries .entry h3 {
    font-size: 1.6rem;
  }
}
@media screen and (min-width: 481px) {
  #newsEntries .entry {
    position: relative;
    min-width: 500px;
  }
  #newsEntries .arrow {
    width: 40px;
    height: 2px;
    border-bottom: 2px dotted #f96389;
    position: absolute;
    top: 46%;
    right: -25px;
  }
  #newsEntries .arrow::after {
    content: "";
    display: inline-block;
    width: 13px;
    height: 2px;
    border-bottom: 2px dotted #f96389;
    -webkit-transform: rotate(23deg);
    transform: rotate(23deg);
    position: absolute;
    bottom: 1px;
    right: -1px;
  }
}

/* news-d */
#news-d .entry {
  display: block;
  padding: 0;
  border: none;
  background: transparent;
}
#newsEntries .title {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  padding: 10px 20px;
  background: #fff;
  border: 2px solid #494549;
  margin-bottom: 15px;
}

#newsEntries .entryBody {
  padding: 30px;
  background: rgba(255, 255, 255, .9);
  margin-bottom: 30px;
}
#newsEntries .entryBody p img {
  height: auto;
}
#newsEntries .entryBody img {
  display: block;
  width: 100%;
  margin: 0 auto 50px;
  max-width: 750px;
}
@media screen and (max-width: 480px) {
  #newsEntries .title {
    display: block;
    padding: 10px 15px;
  }
  #newsEntries .entryBody {
    padding: 20px 15px;
  }
  #newsEntries .entryBody img {
    margin-bottom: 25px;
  }
}

#newsEntries .entryBody p {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.7;
  margin-bottom: 20px;
}
#newsEntries .entryBody p.sample-video {
  padding: 0;
}
/* line 125, ../scss/_news.scss */
#newsEntries .entryBody p a {
  display: inline;
  text-decoration: underline;
  color: #f86e93;
}
/* line 131, ../scss/_news.scss */
#newsEntries .share {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
#newsEntries .share li:first-of-type {
 margin-right: 15px;
}
/* line 136, ../scss/_news.scss */
#newsEntries .share li img {
  width: 35px;
  margin-bottom: 0;
}
/*フォーム入力*/
#news span.wpcf7-list-item,
#news-d span.wpcf7-list-item {
  display: block;/*チェックボックス整列*/
  margin-bottom: .4em;
}
label b {
  display: inline-block;
  margin-bottom: 1em;
}
@media screen and (max-width: 480px) {
  #news span.wpcf7-list-item,#news-d span.wpcf7-list-item{
    margin-bottom: 1em;
  }
	#newsEntries article.entry form p label span input,
  #newsEntries article.entry form p span input[type="text"],
	#newsEntries article.entry form p label span textarea,
  #newsEntries article.entry form p span textarea,
  #newsEntries article.entry form select {
		width: 98%;
	}
  #newsEntries article.entry form p label span input[type="radio"],
  #newsEntries article.entry form p label span input[type="checkbox"] {
    width: auto;
  }
}

#pgNation {
  margin-top: 50px;
}
@media screen and (max-width: 480px) {
  /* line 146, ../scss/_news.scss */
  #pgNation {
    margin-top: 30px;
    padding-bottom: 15px;
  }
}
/* line 154, ../scss/_news.scss */
#pgNation ol {
  display: flex;
  justify-content: center;
  align-items: center;
}
/* line 162, ../scss/_news.scss */
#pgNation li, #pgNation li.active{
  width: 25px;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 31px;
  text-align: center;
  margin-right: 8px;
}
#pgNation li a {
  color: #494549;
}
/* line 176, ../scss/_news.scss */
#pgNation li.active {
  color: #fff;
  background: #fbb2c4;
}
/* line 191, ../scss/_news.scss */
#pgNation li:last-child {
  margin-right: 0;
}

.back-btn {
  margin-left: calc((100% - 90px) / 2);
}
.back-btn a {
  color: #f96389;
}

/*STORY*/
#episode #mainInner::before {
  background-image: url('../img/story/story_bg00.jpg');
}
#episode #mainInner::after {
  background-image: url('../img/story/story_bg02.jpg');
}
#episode #content::before {
  background-image: url('../img/story/story_bg01.jpg');
}

#content .tabbox {
  margin-top: 20px;
}

 /*タブ分け部分について*/
.tabbox input { display: none; }
  /* ▼タブの中身(共通装飾＋非選択状態の装飾) */
  .tabbox label{
    display: inline-block;
  }
  .tabbox label{
    cursor:pointer;
  }
 .tabcont {
    display: none;             /* 標準では非表示にする */
    padding-bottom: 30px;
 }
 /* ▼チェックが入っているラジオボタンに対応するタブの中身を表示する */
#intro:checked ~ #cont-story {
  display: block;
  animation: fadeIn 0.5s cubic-bezier(0.55, 0.055, 0.675, 0.19) 0s 1 normal;
  -webkit-animation: fadeIn 0.5s cubic-bezier(0.55, 0.055, 0.675, 0.19) 0s 1 normal;
  position: relative;
   }

 @media screen and (max-width: 480px) {
  #intro:checked ~ #cont-story::before {
  left: -20%;
 }
}
#story:checked ~ #cont-episode { 
  display: block;
  animation: fadeIn 0.5s ease 0s 1 normal;
  -webkit-animation: fadeIn 0.5s ease 0s 1 normal;
}

@keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}

@-webkit-keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}
/*ここまでタブ分け*/

/*タブデザイン*/
.tab {
  width: 215px;
  box-sizing: border-box;
  font-size: 2.5rem;
  text-align: center;
  line-height: 1.4;
  color: #494549;
  background-color: #fff;
  position: relative;
  margin-bottom: 20px;
  z-index: 1;
  transition: .3s ease;
}
@media screen and (max-width: 480px) {
  .tab {
    width: 130px;
    font-size: 1.8rem;
    padding: 2px 0;
    margin-bottom: 0;
  }
}
@media screen and (max-width: 320px) {
  .tab {
    width: 120px;
    font-size: 1.6rem;
  }
}
.tab::before,
.tab::after {
  content: "";
  display: inline-block;
  width: calc(100% + 5px);
  height: calc(100% + 5px);
  border: 2px solid #494549;
  position: absolute;
  bottom: 0;
  right: 0;
  box-sizing: border-box;
}
.tab::after {
  border: 1px solid #494549;
  top: 0;
  left: 0;
  bottom: auto;
  right: auto;
}

#intro:checked ~ #intro-tab,
#story:checked ~ #story-tab {
  background-color: #ff9a4d;
}
@media screen and (min-width: 481px) {
  .tab:hover {
    background-color: #ff9a4d;
  }
}

#intro-tab{
  margin-left: calc((100% - 475px) /2);
}
@media screen and (max-width: 480px) {
  #intro-tab{
    margin-left: 15px;
  }
}
@media screen and (max-width: 320px) {
  #intro-tab{
    margin-left: 5px;
  }
}

#story-tab{
  margin-left: 30px;
}
@media screen and (max-width: 480px) {
  #story-tab{
    margin-left: 20px;
  }
}
@media screen and (max-width: 320px) {
  #story-tab{
    margin-left: 15px;
  }
}

#storyDetail {
  text-align: left;
}
#storyDetail .intro{
  line-height: 1.8;
  font-size: 1.8rem;
  text-align: center;
  padding: 30px;
}
@media screen and (max-width: 480px) {
  #storyDetail .intro{
    padding: 35px 15px 0;
    font-size: 1.65rem;
    text-align: left;
  }
}


#storyDetail .intro p {
  margin-top: 30px;
}
#storyDetail .intro p:first-of-type {
  margin-top: 0;
}
#storyDetail .intro p span {
  letter-spacing: -.1em;
}
@media screen and (max-width: 480px) {
  #storyDetail .intro p {
    margin-top: 25px;
  }
}

#storyDetail article {
  max-width: 600px;
  margin: auto;
}

#episodeEntries {
  box-sizing: border-box;
  width: 100%;/*IE用*/
  padding-top: 30px;
  margin: auto;
}
@media screen and (max-width: 480px) {
  /* line 72, ../scss/_episode.scss */
  #episodeEntries {
    padding: 0;
  }
}
@media screen and (max-width: 480px) {
  #episodeEntries {
    margin-right: 0;
    width: 100%;
  }
}

#episodeEntries article.entry {
  box-sizing: border-box;
  padding: 0 30px;
  margin-bottom: 60px;
}
@media screen and (max-width: 480px) {
  #episodeEntries article.entry {
    padding:0;
  }
  #episodeEntries article.entry:first-of-type {
    padding-top: 25px;
  }
}
#episodeEntries article.entry:last-of-type {
  margin-bottom: 0;
}

#episodeEntries h3 {
  display: inline-block;
  color: #494549;
  font-size: 2.1rem;
  background-color: #fff;
  border: 2px solid #4c484c;
  padding: 5px 20px 0;
  line-height: 1.3;
  margin-bottom: 15px;
}
.num {
  font-family: "Josefin Sans", sans-serif;
  font-style: italic; 
  font-size: 3.5rem;
  margin-right: .5em;
  vertical-align: middle;
}
@media screen and (max-width: 480px) {
  #episodeEntries h3 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 10px 15px;
    font-size: 1.7rem;
  }
  .num {
    font-size: 3rem;
  }
  #episodeEntries h3 .title {
    line-height: 1.5;
    padding-top: 2px;
  }
}


#episodeEntries .scene {
  margin-bottom: 15px;
}
/* line 151, ../scss/_episode.scss */
#episodeEntries .scene ul {
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-sizing: border-box;
  width: 100%;
}
@media screen and (max-width: 480px) {
  #episodeEntries .scene ul {
    display: block;
    padding: 0 15px;
  }
}
/* line 164, ../scss/_episode.scss */
#episodeEntries .entry li {
  width: 50%;
}
#episodeEntries .entry li:nth-of-type(1){
	margin-right: 10px;
}
#episodeEntries .entry li:nth-of-type(2){
	margin-left: 10px;
}
@media screen and (max-width: 480px) {
  #episodeEntries .entry li {
    width: 100%;
    border: none !important;
  }
  #episodeEntries .entry li:nth-of-type(1){
		margin-right: 0px;
		margin-bottom: 10px;
	}
	#episodeEntries .entry li:nth-of-type(2){
		margin-left: 0px;
	}
}

#episodeEntries .entry li img {
  display: block;
  width: 100%;
}
#episodeEntries .entry > p {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.8;
  background: rgba(255,255,255,.6);
  padding: 15px;
}
@media screen and (max-width: 480px) {
  #episodeEntries .entry > p {
    padding: 10px 15px;
    line-height: 1.7;
  }
}

#episode a.page-top {
  margin-top: 15px;
  margin-left: auto;
  width: 31px;
}
/* line 221, ../scss/_episode.scss */
#episode a.page-top img {
  display: block;
  width: 15px;
  height: 15px;
  margin-right: 5px;
  background-color: rgba(255, 255, 255, 0.5);
  border-radius: 50%;
  padding: 7px;
  border: 1px solid #cf0576;
}

/* line 233, ../scss/_episode.scss */
#page-topSP, #page-topPC {
  z-index: 99999;
  right: 15px;
  bottom: 15px;
  position: fixed;
}
/* line 240, ../scss/_episode.scss */
#page-topSP:hover, #page-topPC:hover {
  -webkit-transform: scale(1.1) !important;
  transform: scale(1.1) !important;
}
@media screen and (max-width: 480px) {
  /* line 233, ../scss/_episode.scss */
  #page-topSP, #page-topPC {
    width: 45px;
    height: auto;
  }
}
/* line 248, ../scss/_episode.scss */
#page-topSP img, #page-topPC img {
  width: 100%;
}

/* line 252, ../scss/_episode.scss */
#page-topSP {
  display: none;
}
@media screen and (max-width: 480px) {
  /* line 252, ../scss/_episode.scss */
  #page-topSP {
    display: block;
    cursor: pointer;
  }
}

/* line 258, ../scss/_episode.scss */
#page-topPC {
  display: none;
}
@media screen and (min-width: 481px) {
  /* line 258, ../scss/_episode.scss */
  #page-topPC {
    display: block;
  }
}

/*safari用*/
@media screen and (-webkit-min-device-pixel-ratio:0) {
  _::-webkit-full-page-media, _:future, :root #page-topPC,#page-topSP {
    display: none;
  }
}




/*STAFF / CAST*/
#cast #mainInner::before {
  background-image: url('../img/cast/staff_bg00.jpg');
}
#cast #mainInner::after {
  background-image: url('../img/cast/staff_bg02.jpg');
}
#cast #content::before {
  background-image: url('../img/cast/staff_bg01.jpg');
}


#cast h2 span {
  font-family: noto sans JP;
  font-size: .8em;
  font-weight: 600;
  padding: 0 .2em;
}

#cast h3 {
  font-size: 2.5rem;
  text-align: center;
  line-height: 1.4;
  width: 170px;
  color: #494549;
  background-color: #fffa6b;
  position: relative;
  margin-bottom: 20px;
}
#cast .staff {
  padding-top: 4px;
}
#cast h3::before,
#cast h3::after {
  content: "";
  display: inline-block;
  width: 175px;
  height: 40px;
  border: 2px solid #494549;
  position: absolute;
  bottom: 0;
  right: 0;
  box-sizing: border-box;
}
#cast h3::after {
  border: 1px solid #494549;
  top: 0;
  left: 0;
  bottom: auto;
  right: auto;
}
@media screen and (max-width: 480px) {
  #cast h3 {
    font-size: 2.3rem;
    width: 140px;
    margin-bottom: 10px;
  }
  #cast h3::before,
  #cast h3::after {
    width: 145px;
    height: 33px;
  }
}
#cast h4 {
  display: inline-block;
  font-size: 1.4rem;
  font-weight: 500;
  padding: 0 1em;
  border: 2px solid #494549;
  margin-bottom: 20px;
}

#castDetail article > div {
  background: rgba(255,255,255,.9);
  padding: 20px 20px 20px 50px;
  box-sizing: border-box;
  margin: auto;
  margin-left: 15px;
  position: relative;
}
@media screen and (max-width: 480px) {
  #castDetail article > div {
    padding: 20px 15px;
    margin-left: 0;
  }
}

#castDetail .staff {
  margin-bottom: 50px;
}

#castDetail article dl{
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  text-align: left;
  margin: auto;
}
@media screen and (max-width: 480px) {
	#castDetail dl {
	  width: 100%;
	}
}
#castDetail dl > div {
  width: 33.33%;
  margin-bottom: 40px;
  box-sizing: border-box;
  padding-left: 15px;
  border-left: 4px solid #494549;
  margin-left: 5px;
}
#castDetail dl > div:nth-of-type(n) {
  width: 36%;
}
#castDetail dl > div:nth-of-type(3n+2) {
  width: 33%;
}
#castDetail dl > div:nth-of-type(3n) {
  width: 27%;
}
#castDetail .staff dl > div:last-of-type {
  margin-bottom: 0;
}
#castDetail .cast dl > div {
  margin-bottom: 0;
}


@media screen and (max-width: 480px) {
  #castDetail dl > div {
    border-left: 3px solid #494549;
    padding-left: 8px;
    margin-left: 0;
  }
  #castDetail .staff dl > div,
  #castDetail .cast dl > div {
    width: 50%;
  }
  #castDetail .cast dl > div:nth-of-type(1),
  #castDetail .cast dl > div:nth-of-type(2) {
    margin-bottom: 40px;
  }
}

#castDetail dt {
  color: #827D82;
  font-size: 1.3rem;
  line-height: 1.1;
  margin-bottom: 3px;
}

#castDetail dd{
  font-size: 1.8rem;
  font-weight: 400;
}
@media screen and (max-width: 480px){
  #castDetail dd {
    font-size: 1.5rem;
  }
}




/*GOODS*/
#goods #mainInner::before,
#goods-d #mainInner::before {
  background-image: url('../img/goods/goods_bg00.jpg');
}
#goods #mainInner::after,
#goods-d #mainInner::after {
  background-image: url('../img/goods/goods_bg02.jpg');
}
#goods #content::before,
#goods-d #content::before {
  background-image: url('../img/goods/goods_bg01.jpg');
}

/* GOODS LIST */
.goods-list {
  margin: auto;
  font-size: 1.6rem;

  display:-webkit-box;
  display:-ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.goods-item {
  width: 230px;
  margin-right: 35px;
  margin-bottom: 45px;
}
@media screen and (min-width: 481px) {
  .goods-list {
    min-width: 760px;
  }
  .goods-item:nth-of-type(3n) {
    margin-right: 0;
  }
}
@media screen and (max-width: 480px) {
  .goods-item {
    width: calc(50% - 10px);
    margin-right: 10px;
    margin-bottom: 35px;
  }
  .goods-item:nth-of-type(2n) {
    margin-right: 0;
    margin-left: 6px;
  }
}
.goods-thumb {
  width: 100%;
  box-sizing: border-box;
  background-color: #fff;
  padding: 10px;
  margin: 0 auto 15px;
  border: solid 2px #4c484c;
  position: relative;
  height: 230px;
}
.goods-thumb::after,
#goodsDetail h3::after,
#musicDetail h3::after,
#special-dDetail h3::after {
  content: "";
  display: inline-block;
  position: absolute;
  z-index: -1;
  width: 100%;
  height: 100%;
  background-color: #b0c9cb;
  top: 10px;
  left: 10px;
}
.goods-thumb p {
  width: 100%;
  height: 100%;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
.goods-title {
  color: #494549;
  padding-left: .3em;
}

@media screen and (max-width: 480px) {
  .goods-thumb {
    height: 200px;
    margin-bottom: 10px;
  }
  .goods-thumb::after {
    top: 8px;
    left: 8px;
  }
  .goods-title {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 320px) {
  .goods-thumb {
    height: 170px;
  }
}

/* GOODS-D */
#goodsDetail article, 
#musicDetail article,
#special-dDetail article {
  width: 100%;
  font-size: 1.5rem;
  font-weight: 400;
  margin: 0 auto 30px;
  position: relative;
}
#goodsDetail h3,
#musicDetail h3,
#special-dDetail h3 {
  display: inline-block;
  font-size: 1.8rem;
  font-weight: 500;
  padding: 10px 20px;
  background: #fff;
  border: 2px solid #494549;
  margin-bottom: 15px;
  position: relative;
}
#goodsDetail h3::after,
#musicDetail h3::after,
#special-dDetail h3::after {
  top: 8px;
  left: 8px;
}
@media screen and (max-width: 480px){
  #goodsDetail h3,
  #musicDetail h3,
  #special-dDetail h3 {
    font-size: 1.7rem;
    padding: 10px 15px;
  }
  #goodsDetail h3::after,
  #musicDetail h3::after,
  #special-dDetail h3::after {
    top: 6px;
    left: 6px;
  }
}
#goodsDetail article a,
#musicDetail article a,
#special-dDetail article a {
  color: #f86e93;
}

#goodsDetail .entryBody,
#musicDetail .entryBody {
  box-sizing: border-box;
  background: rgba(255,255,255,.9);
  padding: 30px;

  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
@media screen and (max-width: 480px){
  #goodsDetail .entryBody,
  #musicDetail .entryBody {
    padding: 20px 15px;
  }
}
#goodsDetail article p, 
#musicDetail article p {
  margin-bottom: .9em;
}
.comic-img {
  width: 45%;
  margin-bottom: 20px;
}
.comic-img img {
    width: 100%;
}
.comic-img .line {
   border: solid 1px #d9d9d9;
}
.right-box {
  width: 55%;
  box-sizing: border-box;
  padding-left: 40px;
}
@media screen and (max-width: 480px){
  .comic-img,
  .right-box{
    width: 100%;
  }
  .right-box{
    padding-left: 0;
  }
}
#goodsDetail .full,
#goodsDetail .benefit {
  width: 100%;
  display: block;
}
#goodsDetail .benefit {
  margin-top: 20px;
}

#goodsDetail .buy-btn {
  display: inline-block;
  position: relative;
  margin: 20px 5px 35px;
}

@media screen and (max-width: 480px) {
  #goodsDetail .benefit {
    margin-top: 25px;
  }
  #goodsDetail .buy-btn{
    margin-bottom: 15px;
    margin-left: calc((100% - 145px) / 2);
  }
  #goodsDetail .benefit .buy-btn {
    margin-top: 10px;
    margin-bottom: 35px;
  }
}

#goodsDetail .buy-btn::before,
#goodsDetail .buy-btn::after {
  content: "";
  display: inline-block;
  width: calc(100% + 5px);
  height: calc(100% + 5px);
  border: 2px solid #494549;
  position: absolute;
  bottom: 0;
  right: 0;
  box-sizing: border-box;
}
#goodsDetail .buy-btn::after {
  border: 1px solid #494549;
  top: 0;
  left: 0;
  bottom: auto;
  right: auto;
}
#goodsDetail .buy-btn > a {
  display: inline-block;
  color: #494549;
  padding: 0 1.5em;
  font-weight: 500;
  font-size: 1.7rem;
  line-height: 2;
  border: 1px solid #4c484c;
  border-bottom: 2px solid #4c484c;
  border-right: 2px solid #4c484c;
  transition: 0.3s ease;
  position: relative;
  z-index: 1;
}
#goodsDetail .buy-btn > a:hover{
  border: 1px solid #4c484c;
  border-bottom: 2px solid #4c484c;
  border-right: 2px solid #4c484c;
  background: #ffc4df;
  opacity: 1;
}

#goodsDetail dl div,
#musicDetail dl div {
  margin-bottom: 20px;
}

#goodsDetail .right-box .r-date{
  display: inline-block;
  font-size: 1.8rem;
  font-weight: 500;
  padding: 3px 10px;
  margin-bottom: 20px;
  border-top: 2px solid #4c484c;
  border-bottom: 2px solid #4c484c;
}

#goodsDetail dt,
#musicDetail dt {
  display: inline-block;
  padding-left: 7px;
  color: #4c484c;
  border-left: 4px solid #4c484c;
  font-weight: 600;
  line-height: 1;
  margin-bottom: 10px;
}
@media screen and (max-width: 480px) {
  #goodsDetail dt,
  #musicDetail dt {
    margin-bottom: 6px;
  }
}
.under-box {
  width: 100%;
}

#goodsDetail .benefit h4 {
  font-size: 1.8rem;
  font-weight: 500;
  background: #4c484c;
  color: #fff;
  padding: 0.4em 1em;
  margin-bottom: 30px;
}
@media screen and (max-width: 480px) {
  #goodsDetail .benefit h4 {
    margin-bottom: 20px;
  }
}

#goodsDetail .shop {
  margin: 0 0 30px;
  border-bottom: dotted 1px #4c484c;
  position: relative;
  z-index: 1;
}
#goodsDetail .shop:last-of-type {
  border-bottom: none;
  margin-bottom: 0;
}
@media screen and (max-width: 480px) {
  #goodsDetail .shop {
    margin: 0 0 35px;
  }
}
#goodsDetail .shop-cont {
  padding: 0 5px;
}
#goodsDetail .bene-cont {
  margin-bottom: 25px;
}

#goodsDetail .benefit h5 {
  display: inline-block;
  font-size: 1.6rem;
  color: #4c484c;
  padding: 3px 15px;
  background-color: #fff;
  border: 2px solid #4c484c;
  margin-bottom: 20px;
  position: relative;
}
#goodsDetail .benefit h5::after {
  content: "";
  display: inline-block;
  width: 100%;
  height: 100%;
  background-color: #b0c9cb;
  position: absolute;
  top: 6px;
  left: 6px;
  z-index: -1;
}

#goodsDetail .benefit .bene-img{
  width: 60%;
  margin-top: 15px;
  margin: 15px auto 20px;
  box-sizing: border-box;
}
@media screen and (max-width: 480px) {
  #goodsDetail .benefit .bene-img{
    width: 100%;
  }
}
#goodsDetail .benefit .bene-img img{
  width: 100%;
}
#goodsDetail .benefit .bene-title{
  font-size: 1.6rem;
  font-weight: 500;
}

#goodsDetail .back-btn,
#goodsDetail .back-btn::after {
  border-bottom: 2px dotted #8bb1b4;
}
#goodsDetail .back-btn a {
  color: #8bb1b4;
}



#goods .red{
  color: red;
}
#goods .bold{
  font-weight: 700;
}
.indent {
  text-indent: -1em;
  padding-left: 1em;
}

/*期間限定オーディオコメンタリー*/
.sample-video{
  position: relative;
  width: 100%;
  padding-top: 56.25%!important;
  margin: 10px auto 24px!important;
}
.sample-video iframe{
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}




/*ON AIR*/
#onair #mainInner::before {
  background-image: url('../img/onair/onair_bg00.jpg');
}
#onair #mainInner::after {
  background-image: url('../img/onair/onair_bg02.jpg');
}
#onair #content::before {
  background-image: url('../img/onair/onair_bg01.jpg');
}

#onairDetail .onair-txt{
  text-align: center;
  margin-bottom: 30px;
}
#onairDetail .onair-txt img {
  width: 432px;
}
@media screen and (max-width: 480px) {
  #onairDetail .onair-txt img {
    width: 280px;
  }
}

#onairDetail article > div {
  background: rgba(255,255,255,.9);
  padding: 20px 50px;
  box-sizing: border-box;
  margin: auto;
  margin-left: 15px;
}
@media screen and (max-width: 480px) {
  #onairDetail article > div {
    padding: 20px 15px;
    margin-left: 0;
  }
}

#onairDetail article:last-child {
  margin-bottom: 0;
}

#onairDetail h3 {
  text-align: center;
  line-height: 1.4;
  width: 170px;
  height: 35px;
  background-color: #9de0fe;
  position: relative;
  margin-bottom: 15px;
}
#onairDetail h3::before,
#onairDetail h3::after {
  content: "";
  display: inline-block;
  width: 175px;
  height: 40px;
  border: 2px solid #494549;
  position: absolute;
  bottom: 0;
  right: 0;
  box-sizing: border-box;
}
#onairDetail h3::after {
  border: 1px solid #494549;
  top: 0;
  left: 0;
  bottom: auto;
  right: auto;
}
#onairDetail h3 img {
  width: 81px;
  vertical-align: middle;
  margin-top: 3px;
}
@media screen and (max-width: 480px) {
  #onairDetail h3 {
    width: 140px;
    height: 28px;
    margin-bottom: 10px;
  }
  #onairDetail h3::before,
  #onairDetail h3::after {
    width: 145px;
    height: 33px;
  }
  #onairDetail h3 img {
    width: 70px;
  }
}
.broadcast {
  margin-bottom: 50px;
}
#onair #content > div {
  padding-bottom: 60px;
}

#onairDetail dl div {
  font-size: 1.6rem;
  margin-bottom: 40px;
  box-sizing: border-box;
  padding-left: 15px;
  border-left: 4px solid #494549;
  margin-left: 5px;
}
#onairDetail dl div:last-of-type {
  margin-bottom: 0;
}
#onairDetail dl div:last-of-type dd {
  margin-bottom: 0;
}

#onairDetail dl dt{
  font-weight: 700;
  line-height: 1;
  margin-bottom: 3px;
}

#onairDetail dl dt a {
  text-decoration: underline;
  color: #261607;
  display: inline-block;
}
#onairDetail dd {
  font-weight: 400;
}
#onairDetail dl dd .p-indent{
  display: block;
  padding-left: 8em;
  font-size: .9em;
}
/*#onair > section #mainInner #content #onairDetail article dl dd[class="indent"] {
 line-height: 1.7; 
}*/

@media screen and (max-width: 480px) {
  #onairDetail dl dt{
    width: 100%;
    margin-bottom: 7px;
  }
  #onairDetail dl dd{
    width: 100%;
  }
}

/*SPECIAL*/
#special #mainInner::before,
#special-d #mainInner::before {
  background-image: url('../img/special/special_bg00.jpg');
}
#special #mainInner::after,
#special-d #mainInner::after {
  background-image: url('../img/special/special_bg02.jpg');
}
#special #content::before,
#special-d #content::before {
  background-image: url('../img/special/special_bg01.jpg');
}

@media screen and (min-width: 481px) {
  #special #content {
    min-width: 850px;
  }
}
#content #specialDetail {
  margin-top: 70px;
}
@media screen and (max-width: 480px) {
  #content #specialDetail {
    margin-top: 50px;
  }
}

#special #specialDetail ul {
  /*max-width: 670px;*/
}

#special #specialDetail li {
  margin-bottom: 30px;
  box-sizing: border-box;
  position: relative;
}
#special #specialDetail li:nth-of-type(2n) {
  text-align: right;
}

#specialDetail a {
  display: inline-block;
}
.sp-thumb {
  display: inline-block;
  width: 360px;
}
.sp-thumb::after {
  content: "";
  display: inline-block;
  width: 360px;
  height: 100%;
  background-color: #31b3be;
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: -1;
}
.sp-thumb.snap::after {
  background-color: #ffc164;
}
.sp-thumb.bag::after {
  background-color: #93d6a4;
}
.sp-thumb.coordinate::after {
  background-color: #f686be;
}
li:nth-of-type(2n) .sp-thumb::after {
  right: -10px;
  left: auto;
}

#special .sp-title {
  font-size: 2.4rem;
  color: #4c484c;
  line-height: 1.3;
  position: absolute;
  bottom: 40px;
  left: 230px;
}
#special li:nth-of-type(2n) .sp-title {
  left: auto;
  right: 230px;
}

#special .sp-title span {
  display: inline-block;
  background-color: #fff;
  padding: 0 8px;
  border: 2px solid #4c484c;
  margin-bottom: 3px;
}
#specialDetail img {
  vertical-align: bottom;
}

@media screen and (max-width: 480px) {
  #special #specialDetail li {
    margin-bottom: 50px;
  }
  .sp-thumb {
    width: 80%;
    top: 10px;
    left: 10px;
  }
  .sp-thumb::after {
    width: 80%;
    top: 5px;
    left: 5px;
  }
  li:nth-of-type(2n) .sp-thumb::after {
    left: auto;
    right: -5px;
  }
  #special .sp-title {
    font-size: 1.8rem;
    bottom: 10px;
    left: auto;
    right: 0;
  }
  #special li:nth-of-type(2n) .sp-title {
    left: auto;
    right: 30%;
  }
  
  #special li:nth-of-type(2n) .snap + .sp-title,
  #special li:nth-of-type(2n) .coordinate + .sp-title {
    right: auto;
    left: 0;
  }
}
@media screen and (max-width: 320px) {
  #special li:nth-of-type(2n) .sp-title {
    left: auto;
    right: 20%;
  }
}
/* IE対応 */
_:-ms-lang(x)::-ms-backdrop, #specialDetail img {
  width: 100%;
}




/*SPECIAL-D*/
#special-d article {
  box-sizing: border-box;
  background-color: rgba(255,255,255,.9);
  padding: 30px;
}
#special-dEntries h4 {
  display: inline-block;
  font-size: 1.8rem;
  color: #fff;
  background-color: #31b3be;
  padding: .1em 1em;
  border: 2px solid #4c484c;
  margin-bottom: 30px;
}
#special-dEntries .entry img {
  width: 100%;
  height: 100%;
  display: block;
  max-width: 750px;
  margin: 0 auto 50px;
}
#special-dEntries .entry p {
  margin-bottom: 10px;
}
/*テキストリンク改行させない*/
#special-dEntries .entry a {
  display: inline;
  text-decoration: underline;
}
@media screen and (max-width: 480px) {
  #special-dEntries .entry {
    padding: 20px 15px;
  }
  #special-dEntries h4 {
    margin-bottom: 20px;
  }
  #special-dEntries .entry img {
    margin-bottom: 20px;
  }
}

/* キャラ直接リンク */
#special-d #kaname {
  padding-top: 90px;
  margin-top: -90px;
}
@media screen and (max-width: 480px) {
  #special-d #kaname {
    padding-top: 70px;
    margin-top: -70px;
  }
}

/* インタビューカラー */
#special-dDetail.interview h3::after,
#special-dDetail.interview h4 {
  background-color: #31b3be;
} 
.interview .back-btn,
.interview .back-btn::after {
  border-bottom: 2px dotted #31b3be;
}
.interview .back-btn a {
  color: #31b3be;
}

/* ストリートスナップカラー */
#special-dDetail.snap h3::after,
#special-dDetail.snap h4 {
  background-color: #ffc164;
} 
.snap .back-btn,
.snap .back-btn::after {
  border-bottom: 2px dotted #ffc164;
}
.snap .back-btn a {
  color: #ffc164;
}

/* カバンカラー */
#special-dDetail.bag h3::after,
#special-dDetail.bag h4 {
  background-color: #93d6a4;
} 
.bag .back-btn,
.bag .back-btn::after {
  border-bottom: 2px dotted #93d6a4;
}
.bag .back-btn a {
  color: #93d6a4;
}

/* コーディネートカラー */
#special-dDetail.coordinate h3::after,
#special-dDetail.coordinate h4 {
  background-color: #f686be;
} 
.coordinate .back-btn,
.coordinate .back-btn::after {
  border-bottom: 2px dotted #f686be;
}
.coordinate .back-btn a {
  color: #f686be;
}

/* スナップcss */
.snap #special-dEntries .entry img {
  max-width: 500px;
  margin-bottom: 30px;
}
.snap .entry p {
  line-height: 1.6;
}
.snap .entry .head {
  font-size: 1.5em;
}
@media screen and (max-width: 480px) {
  .snap .entry .head {
    font-size: 1.4em;
  }
}
.snap #special-dEntries .entry .info {
  font-size: 0.8em;
  line-height: 1.5;
  text-align: center;
  max-width: 10em;
  padding: 0.6em 1.5em;
  border-top: double 3px #4c484c;
  border-bottom: double 3px #4c484c;
  margin: 0 auto 25px;
}
/* バッグcss */
.bag #special-dEntries .entry .head {
  margin-bottom: 20px;
}
@media screen and (min-width: 480px) {
  .bag .entry .head {
    font-size: 1.4em;
  }
}
/*今週のコーデcss*/
@media screen and (min-width: 481px) {
  .coordinate #special-dEntries p {
    text-align: center;
  }
}

/*ブラウザバック 動画崩れ防止*/
#special-dEntries .wp-video {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  margin: 10px auto 0;
}
/*jsかかってるのでタグが異なるので2つ指定*/
#special-dEntries .wp-video video, 
#special-dEntries .wp-video .wp-video-shortcode {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}/*#mep_0は動画共通ではなく、動画ごとに変わるのでclassの方を指定してあげる*/

/*オーディオ100%表示*/
@media screen and (max-width: 480px) {
  #special-dEntries table{
    width: 100%!important;
  }
}
@media screen and (max-width: 480px) {
  #special-dEntries table td{
    display: block;
    width: 100%!important;
  }
  #special-dEntries table td:nth-of-type(2n) {
    margin-bottom: .7em;
  } 
}

/* MUSIC */
#music #mainInner::before {
  background-image: url('../img/music/music_bg00.jpg');
}
#music #mainInner::after {
  background-image: url('../img/music/music_bg02.jpg');
}
#music #content::before {
  background-image: url('../img/music/music_bg01.jpg');
}

#music .entry {
  margin-bottom: 40px;
}
#music .entry:last-of-type {
  margin-bottom: 0;
}
#music .under-box {
  text-align: center;
  margin-top: 50px;
}
#music h4 {
  display: inline-block;
  font-size: 2.1rem;
  color: #4c484c;
  padding: .1em 2em;
  border-top: 2px solid #4c484c;
  border-bottom: 2px solid #4c484c;
  margin-bottom: 10px;
}
.video-frame {
  width: 60%;
  margin: auto;
}
@media screen and (max-width: 480px) {
  /*#music .under-box {
    text-align: left;
  }*/
  #music .under-box {
    margin-top: 15px;
  }
  #music h4 {
    font-size: 1.9rem;
    padding: 0 2em;
    margin-bottom: 5px;
  }
  .video-frame {
    width: 100%;
  }
}