@charset "UTF-8";
/* CSS INFORMATION -====================================================
File name : subpage.css
Description : 下層ページ
===================================================================== */
/* =====================================================================
    共通
======================================================================*/
.wrapper {
  background: url(../images/common/bg_pattern02_black.jpg) repeat top center/49.7rem auto;
}

#story .wrapper,
#cast .wrapper {
  background: url(../images/common/bg_pattern05.jpg) repeat top center/160rem auto;
}
@media screen and (min-width: 768px) {
  #story .wrapper,
  #cast .wrapper {
    background-size: 100% auto;
  }
}

.main > section {
  padding-top: 15rem;
}

.sns-share {
  position: relative;
  width: calc(571 / 650 * 100%);
  font-size: 107%;
  -webkit-transform: rotate(355deg);
          transform: rotate(355deg);
  background: url(../images/common/bg_sns_share.png) no-repeat center/100% 100%;
  -webkit-filter: drop-shadow(0 0.3rem 0.4rem rgba(41, 43, 45, 0.2));
          filter: drop-shadow(0 0.3rem 0.4rem rgba(41, 43, 45, 0.2));
  z-index: 1;
}
.sns-share dt {
  text-align: center;
  margin-bottom: 1em;
  padding-top: 19.2644483363%;
  font-weight: normal;
}
.sns-share dd {
  padding-bottom: 12.2591943958%;
}
.sns-share dd ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.sns-share dd ul li {
  margin: 0 2.1015761821%;
}
.sns-share dd ul li:nth-child(1) a {
  background-image: url(../images/common/bg_sns_circle01.svg);
}
.sns-share dd ul li:nth-child(2) a {
  background-image: url(../images/common/bg_sns_circle02.svg);
}
.sns-share dd ul li:nth-child(3) a {
  background-image: url(../images/common/bg_sns_circle03.svg);
}
.sns-share dd ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 3.6em;
  height: 3.3em;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
.sns-share dd ul li a svg {
  width: 45%;
  height: 44%;
  fill: #233581;
}

@media screen and (min-width: 768px) {
  .sns-share {
    width: calc(441 / 1000 * 100%);
  }
}
/* =====================================================================
    submv
======================================================================*/
.submv {
  padding: 3rem 0 2rem;
  background-color: #4d4d4d;
  overflow: hidden;
}
.submv::before {
  content: "";
  position: absolute;
  display: block;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 61rem;
  height: 67.4rem;
  background: url(../images/common/img_rikka.png) no-repeat center/contain;
}
.submv::after {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../images/common/bg_pattern04.jpg) repeat center/50rem auto;
  mix-blend-mode: soft-light;
}
.submv h1 {
  margin: 0 auto;
  width: calc(364 / 650 * 100%);
}
.submv-date {
  margin: 2.3rem auto 0;
}

@media screen and (min-width: 768px) {
  .submv .inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .submv h1 {
    margin: 0;
    width: calc(287 / 1000 * 100%);
  }
  .submv h1 a:hover {
    -webkit-transform: translate(0);
            transform: translate(0);
  }
  .submv-date {
    margin: 0 0 0 calc(50 / 1000 * 100%);
    width: calc(468 / 1000 * 100%);
  }
}
/* =====================================================================
    intro
======================================================================*/
#intro .wrapper {
  background: none;
}

.intro {
  padding: 16rem 0;
}
.intro-content {
  width: auto;
}
.intro-content-sb {
  padding-bottom: 5rem;
  overflow-y: hidden;
  overflow-x: auto;
  direction: rtl;
  -ms-overflow-style: auto;
  /* IE, Edge 対応 */
  scrollbar-width: auto;
  /* Firefox 対応 */
}
.intro-content-sb::-webkit-scrollbar {
  /* Chrome, Safari 対応 */
  display: initial;
  width: initial;
  height: initial;
}
.intro-content-sb img {
  width: 209.1rem;
}
.intro-content-sb .simplebar-track.simplebar-horizontal {
  margin: 0 auto;
  height: 0.5rem;
  background: #232E33;
  border-radius: 0.25rem;
}
.intro-content-sb .simplebar-scrollbar {
  height: 10px;
  background: #fff100;
  border-radius: 0.25rem;
}

@media screen and (min-width: 768px) {
  .intro-content {
    margin-left: calc(-130 / 1000 * 100%);
    width: calc(1260 / 1000 * 100%);
  }
  .intro-content-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    padding-bottom: 5rem;
    overflow-y: hidden;
    overflow-x: auto;
    cursor: -webkit-grab;
    cursor: grab;
  }
  .intro-content-item::-webkit-scrollbar {
    height: 0.5rem;
  }
  .intro-content-item::-webkit-scrollbar-track {
    background: #232E33;
    border-radius: 0.25rem;
  }
  .intro-content-item::-webkit-scrollbar-thumb {
    background: #fff100;
    border-radius: 0.25rem;
  }
  @supports not selector(::-webkit-scrollbar) {
    .intro-content-item {
      scrollbar-color: #fff100 #232E33;
    }
  }
  .intro-content-item img {
    width: 274.8rem;
  }
}
/* =====================================================================
    story
======================================================================*/
.story {
  padding-bottom: 16rem;
}
.story-head {
  position: relative;
  margin-bottom: 4rem;
  padding-bottom: 14.4rem;
}
.story-head::before {
  content: "";
  position: absolute;
  display: block;
  bottom: 0;
  left: 0;
  margin: 0 calc(50% - 50vw);
  width: 100vw;
  height: 49rem;
  background: url(../images/common/bg_fence.png) no-repeat center bottom/cover;
  z-index: -1;
}
.story-movie {
  position: relative;
  padding: calc(18 / 650 * 100%) calc(23 / 650 * 100%) calc(28 / 650 * 100%) calc(16 / 650 * 100%);
  background: url(../images/common/bg_img_movie.png) no-repeat center/100% 100%;
  z-index: 1;
}
.story-subttl {
  position: absolute;
  bottom: -0.28em;
  right: -2rem;
  font-family: "Bebas Neue", sans-serif;
  font-size: 24rem;
  color: rgba(47, 49, 78, 0.4);
  letter-spacing: 0;
}
.story-subttl span {
  font-size: 120%;
}
.story-date {
  text-align: center;
  margin-bottom: 4rem;
  color: #233581;
  letter-spacing: 0;
  font-size: 166%;
  white-space: nowrap;
}
@media screen and (max-width: 767px) {
  .story-date {
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
  }
}
.story-date span {
  margin-right: 0.3em;
  color: #8e2525;
}
.story-text {
  line-height: 1.785;
}
.story-text-list > li:not(:last-child) {
  margin-bottom: 6rem;
}
.story-text-list > li > *:not(:last-child) {
  margin-bottom: 6rem;
}
.story-text-list > li > p {
  line-height: 1.666;
}
.story-text-list > li > p b,
.story-text-list > li > p strong {
  font-weight: 500;
  color: #233581;
}
.story-images-list li {
  margin-top: 3rem;
}
.story-images-list li:first-child {
  margin-top: 0;
}
.story-text-list, .story-images-list {
  margin: 8rem auto 0;
}
.story .sns-share {
  margin: 5rem auto;
}
.story-btn {
  margin-top: 5rem;
}

@media screen and (min-width: 768px) {
  .story-head {
    margin-bottom: 1rem;
    padding-bottom: 5.7rem;
  }
  .story-head::before {
    height: 50rem;
  }
  .story-movie {
    margin: 0 auto;
    width: calc(839 / 1000 * 100%);
  }
  .story-movie a:hover {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  .story-subttl {
    right: -18rem;
    font-size: 32rem;
  }
}
@media screen and (min-width: 768px) and (min-width: 1600px) {
  .story-subttl {
    right: -28rem;
  }
}
@media screen and (min-width: 768px) {
  .story-date {
    margin-bottom: 3rem;
  }
  .story-date span {
    margin-right: 1em;
  }
  .story-images-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .story-images-list li {
    margin-top: 4rem;
    width: calc(470 / 1000 * 100%);
  }
  .story-images-list li:nth-child(-n+2) {
    margin-top: 0;
  }
  .story-images-list li:nth-child(2n) {
    margin-left: calc(60 / 1000 * 100%);
  }
}
.backnumber {
  padding: 12rem 0 !important;
  background-color: #000000;
  overflow: initial;
  z-index: 1;
}
.backnumber::before, .backnumber::after {
  content: "";
  position: absolute;
  display: block;
  left: 0;
  width: 100%;
  height: 1rem;
  background-repeat: no-repeat;
  background-size: cover;
}
.backnumber::before {
  top: -0.9rem;
  background-image: url(../images/common/bg_sideline_black-t.png);
  background-position: left top;
}
.backnumber::after {
  bottom: -0.9rem;
  background-image: url(../images/common/bg_sideline_black-b.png);
  background-position: left bottom;
}
.backnumber-ttl {
  text-align: center;
  margin-bottom: 8rem;
  font-family: "Bebas Neue", sans-serif;
  font-size: 6.4rem;
  color: #ffffff;
}
.backnumber-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 767px) {
  .backnumber-list li:nth-child(even), .backnumber-list li:last-child {
    margin-right: 0;
  }
}
.backnumber-list li {
  margin: 0 calc(34 / 650 * 100%) 4rem 0;
  width: calc(308 / 650 * 100%);
}
.backnumber-list li dd {
  margin-top: 0.1em;
  text-align: right;
  font-family: "Bebas Neue", sans-serif;
  font-size: 178%;
  color: #ffffff;
}

@media screen and (min-width: 768px) {
  .backnumber {
    padding: 8rem 0 !important;
  }
  .backnumber-ttl {
    margin-bottom: 5rem;
    font-size: 311%;
  }
  .backnumber-list li {
    margin: 0 calc(20 / 1000 * 100%) 4rem 0;
    width: calc(184 / 1000 * 100%);
  }
  .backnumber-list li:nth-child(5n), .backnumber-list li:last-child {
    margin-right: 0;
  }
  .backnumber-list li dd {
    font-size: 144%;
  }
}
/* =====================================================================
    chart
======================================================================*/
.chart {
  padding-bottom: 17rem;
  overflow: initial;
  z-index: 1;
}
.chart-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.chart-bg-img {
  position: sticky;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: url(../images/chart/bg_whiteboard-sp.jpg) no-repeat center/cover;
  z-index: -1;
}
.chart-bg-img::before, .chart-bg-img::after {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 2rem;
  background: url(../images/chart/bg_whiteboard_frame.jpg) repeat-x center/auto 100%;
  -webkit-box-shadow: 0 0.4rem 0.5rem 0 rgba(41, 43, 45, 0.3);
          box-shadow: 0 0.4rem 0.5rem 0 rgba(41, 43, 45, 0.3);
}
.chart-bg-img::after {
  top: auto;
  bottom: 0;
}
.chart-box {
  position: relative;
  margin-left: calc(-47 / 650 * 100%);
  width: calc(744 / 650 * 100%);
}
.chart-img {
  position: relative;
  z-index: 1;
}
.chart-note {
  text-align: center;
  margin-top: 10rem;
}
.chart-btn {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.chart-btn li {
  position: absolute;
  top: 0;
  left: 0;
}
.chart-btn [data-popup=chart_id_01] {
  width: calc(382 / 1000 * 100%);
  padding-top: calc(508 / 1000 * 100%);
  margin: calc(1018 / 1000 * 100%) 0 0 calc(571 / 1000 * 100%);
}
.chart-btn [data-popup=chart_id_02] {
  width: calc(322 / 1000 * 100%);
  padding-top: calc(448 / 1000 * 100%);
  margin: calc(1605 / 1000 * 100%) 0 0 calc(182 / 1000 * 100%);
}
.chart-btn [data-popup=chart_id_03] {
  width: calc(322 / 1000 * 100%);
  padding-top: calc(448 / 1000 * 100%);
  margin: calc(919 / 1000 * 100%) 0 0 calc(73 / 1000 * 100%);
}
.chart-btn [data-popup=chart_id_04] {
  width: calc(260 / 1000 * 100%);
  padding-top: calc(360 / 1000 * 100%);
  margin: calc(2088 / 1000 * 100%) 0 0 calc(38 / 1000 * 100%);
}
.chart-btn [data-popup=chart_id_05] {
  width: calc(260 / 1000 * 100%);
  padding-top: calc(360 / 1000 * 100%);
  margin: calc(1990 / 1000 * 100%) 0 0 calc(702 / 1000 * 100%);
}
.chart-btn [data-popup=chart_id_06] {
  width: calc(260 / 1000 * 100%);
  padding-top: calc(360 / 1000 * 100%);
  margin: calc(2396 / 1000 * 100%) 0 0 calc(716 / 1000 * 100%);
}
.chart-btn [data-popup=chart_id_07] {
  width: calc(225 / 1000 * 100%);
  padding-top: calc(315 / 1000 * 100%);
  margin: calc(2132 / 1000 * 100%) 0 0 calc(345 / 1000 * 100%);
}
.chart-btn [data-popup=chart_id_08] {
  width: calc(225 / 1000 * 100%);
  padding-top: calc(315 / 1000 * 100%);
  margin: calc(2485 / 1000 * 100%) 0 0 calc(62 / 1000 * 100%);
}
.chart-btn [data-popup=chart_id_09] {
  width: calc(225 / 1000 * 100%);
  padding-top: calc(315 / 1000 * 100%);
  margin: calc(2474 / 1000 * 100%) 0 0 calc(331 / 1000 * 100%);
}
.chart-btn [data-popup=chart_id_10] {
  width: calc(225 / 1000 * 100%);
  padding-top: calc(315 / 1000 * 100%);
  margin: calc(2830 / 1000 * 100%) 0 0 calc(47 / 1000 * 100%);
}
.chart-btn [data-popup=chart_id_11] {
  width: calc(260 / 1000 * 100%);
  padding-top: calc(360 / 1000 * 100%);
  margin: calc(1579 / 1000 * 100%) 0 0 calc(687 / 1000 * 100%);
}
.chart-btn [data-popup=chart_id_12] {
  width: calc(260 / 1000 * 100%);
  padding-top: calc(360 / 1000 * 100%);
  margin: calc(393 / 1000 * 100%) 0 0 calc(699 / 1000 * 100%);
}
.chart-btn [data-popup=chart_id_13] {
  width: calc(260 / 1000 * 100%);
  padding-top: calc(360 / 1000 * 100%);
  margin: calc(2839 / 1000 * 100%) 0 0 calc(513 / 1000 * 100%);
}
.chart-list-head {
  margin-bottom: 5rem;
}
.chart-list-head figure {
  margin: 0 0 3rem 16.7272727273%;
  width: 68.1818181818%;
}
.chart-list-name {
  text-align: center;
  font-size: 142%;
  line-height: 1.3;
}
.chart-list-name dt {
  font-size: 148%;
  font-weight: normal;
  color: #c7bb00;
}
.chart-list-name dt ruby {
  letter-spacing: 0.1em;
}
.chart-list-name dt .age {
  font-size: 60%;
}
.chart-list-name dt rt {
  text-align: center;
  font-size: 40%;
  letter-spacing: 0.05em;
  -webkit-transform: translateY(-0.3em);
          transform: translateY(-0.3em);
}
.chart-list-name dd {
  margin-top: 0.3em;
  color: #233581;
  letter-spacing: 0.2em;
}
.chart-list-comment {
  margin-top: 12rem;
}
.chart-list-comment dt {
  line-height: 1;
}

.popup-chart .popup-list {
  background-color: transparent;
}
.popup-chart .popup-list li {
  padding-top: 0;
}
.popup-chart .popup-list li::before {
  content: "";
  position: absolute;
  display: block;
  bottom: 0;
  left: 0;
  width: 100%;
  height: calc(100% - 31.8rem);
  background: url(../images/common/bg_pattern01.jpg) repeat top center/10rem auto;
  -webkit-box-shadow: 0 0.5rem 1rem 0 rgba(41, 43, 45, 0.14);
          box-shadow: 0 0.5rem 1rem 0 rgba(41, 43, 45, 0.14);
  z-index: -1;
}

@media screen and (min-width: 768px) {
  .chart-bg-img {
    background-image: url(../images/chart/bg_whiteboard-pc.jpg);
  }
  .chart-box {
    margin: 0 auto;
    width: 80%;
    max-width: 559px;
  }
  .chart-btn li {
    cursor: pointer;
  }
  .chart-list-head {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-bottom: 3rem;
  }
  .chart-list-head figure {
    margin: 0 calc(100 / 1000 * 100%);
    width: calc(273 / 1000 * 100%);
  }
  .chart-list-name {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    text-align: left;
    font-size: 166%;
  }
  .popup-chart .popup-list li::before {
    height: calc(100% - 6.8rem);
  }
}
/* =====================================================================
   cast & staff
======================================================================*/
.staff-item {
  margin-bottom: 28rem;
}
.staff-item:last-child {
  margin-bottom: 8rem;
}
.staff-list li {
  position: relative;
}
.staff-list li:not(:last-child) {
  margin-bottom: 1.8em;
}
.staff-list li.space {
  margin-bottom: 3.2em;
}
.staff-list li dl {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  line-height: 1.875;
  font-size: 114%;
  letter-spacing: 0;
}
.staff-list li dl dt {
  position: relative;
  top: 0.1em;
  text-align: right;
  padding-right: 1em;
  width: 50%;
  font-weight: normal;
  color: #233581;
}
.staff-list li dl dt::after {
  content: "";
  position: absolute;
  display: block;
  top: 0.66em;
  right: -0.27em;
  width: 0.55em;
  height: 0.55em;
  background: url(../images/common/img_shape_hexagon.svg) no-repeat center/contain;
}
.staff-list li dl dd {
  padding-left: 1em;
  width: 50%;
}
.staff-list li dl dd small {
  font-size: 65%;
}
.staff-list-comment {
  position: relative;
  display: inline-block !important;
  margin-left: 0.6em;
  width: 1.3em;
  height: 1.1em;
  background-color: #fff100;
}
.staff-list-comment::before {
  content: "…";
  position: absolute;
  display: block;
  top: 50%;
  left: 50%;
  font-size: 80%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.staff-list-comment::after {
  content: "";
  position: absolute;
  display: block;
  top: 50%;
  left: -0.3em;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 0.2em solid transparent;
  border-bottom: 0.2em solid transparent;
  border-right: 0.35em solid #fff100;
  border-left: 0;
}
@media screen and (max-width: 767px) {
  .staff-group .staff-list li:not(:last-child) {
    margin-bottom: 2.4em;
  }
  .staff-group .staff-list li:not(:last-child)::after {
    content: "";
    position: absolute;
    display: block;
    bottom: -1.6em;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 0.55em;
    height: 0.55em;
    background: url(../images/common/img_shape_hexagon.svg) no-repeat center/contain;
  }
  .staff-group .staff-list li dl {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .staff-group .staff-list li dl > * {
    text-align: center;
    padding: 0;
    width: 100%;
  }
  .staff-group .staff-list li dl dt::after {
    display: none;
  }
}

.popup-list li[id^=staff-id-] {
  padding-top: 7rem;
  padding-bottom: 7rem;
  line-height: 1;
  background-color: #e2e3e9;
  border: 1px solid #a8acc4;
}

@media screen and (min-width: 768px) {
  .staff-list li dl {
    font-size: 122%;
  }
  .staff-list-comment:hover {
    -webkit-transform: translateX(-0.3em) !important;
            transform: translateX(-0.3em) !important;
  }
}
/* =====================================================================
   music & original
======================================================================*/
.music,
.original {
  padding-bottom: 8rem;
}
.music-group,
.original-group {
  position: relative;
  padding-bottom: 10rem;
}
.music-group::before,
.original-group::before {
  content: "";
  position: absolute;
  display: block;
  bottom: 0;
  left: 0;
  width: 100%;
  height: calc(100% - 11rem);
  background: url(../images/common/bg_pattern01.jpg) repeat top center/10rem auto;
  z-index: -1;
}
.music-head-ttl,
.original-head-ttl {
  text-align: center;
  margin-bottom: 1.5em;
}
.music-head-ttl span,
.original-head-ttl span {
  display: inline-block;
  font-size: 170%;
  color: #c7bb00;
  line-height: 1.333;
}
.music-head-ttl span small,
.original-head-ttl span small {
  display: block;
  margin-top: 0.3em;
  font-size: 36%;
  color: #000000;
}
.music-comment,
.original-comment {
  margin: 10rem auto 0;
  width: calc(550 / 650 * 100%);
}
.music-comment .name,
.original-comment .name {
  display: block;
  text-align: right;
}

.original-head-ttl span {
  text-align: left;
}
.original-head-ttl span small {
  text-align: right;
  padding-right: 1em;
}

.music-head-photo,
.original-head-book {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 0 auto 7rem;
  padding: 3rem 0;
  width: calc(500 / 650 * 100%);
  background: url(../images/common/bg_pattern06.jpg) no-repeat center/100% 100%;
  -webkit-box-shadow: 0 0.2rem 0.6rem 0 rgba(41, 43, 45, 0.2);
          box-shadow: 0 0.2rem 0.6rem 0 rgba(41, 43, 45, 0.2);
}
.music-head-photo::before,
.original-head-book::before {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  margin: 29.6% 0 0 -6.2%;
  width: 15%;
  padding-top: 30.2%;
  background: url(../images/common/img_tape03.png) no-repeat center/contain;
  opacity: 0.3;
}
.music-head-photo::after,
.original-head-book::after {
  content: "";
  position: absolute;
  display: block;
  bottom: 0;
  right: 0;
  margin: 0 -4.4% -6.8% 0;
  width: 31.4%;
  padding-top: 20%;
  background: url(../images/common/img_tape02.png) no-repeat center/contain;
  opacity: 0.3;
}
.music-head-photo li,
.original-head-book li {
  position: relative;
  margin: 1%;
  width: 28.2%;
  z-index: 1;
}

.music-head-photo {
  padding: 3.5rem 0;
}
.music-head-photo img {
  position: relative;
  margin: auto;
  width: 82%;
  z-index: 1;
}

.music-head-artist,
.original-head-author {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: 2rem;
}
.music-head-artist dl,
.original-head-author dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 1em;
  letter-spacing: 0.025em;
  font-size: 1.3em;
}
.music-head-artist dl dt,
.original-head-author dl dt {
  margin-right: 0.4em;
  padding: 0.15em;
  font-weight: normal;
  font-size: 78%;
  background-color: #e2e3e9;
}

@media screen and (min-width: 768px) {
  .music .sec-ttl,
  .original .sec-ttl {
    margin: 0 calc(55 / 1000 * 100%) -3.2rem auto;
  }
  .music-group::before,
  .original-group::before {
    margin-left: calc(-130 / 1000 * 100%);
    width: calc(1260 / 1000 * 100%);
    height: calc(100% - 7.4rem);
  }
  .music-head,
  .original-head {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .music-head-right,
  .original-head-right {
    padding-top: 7.4rem;
    width: calc(450 / 1000 * 100%);
  }
  .music-head-ttl span,
  .original-head-ttl span {
    font-size: max(4rem, 23px);
  }
  .music-head-btn,
  .original-head-btn {
    width: 71.1111111111%;
    min-width: 250px;
  }
  .music-comment,
  .original-comment {
    margin: 5rem 0 0;
    width: 100%;
  }
  .original-head-ttl {
    text-align: left;
  }
  .music-head-photo,
  .original-head-book {
    margin: 0 0 0 calc(-25 / 1000 * 100%);
    width: calc(500 / 1000 * 100%);
  }
  .music-head-artist,
  .original-head-author {
    margin-bottom: 3rem;
  }
  .music-head-artist dl,
  .original-head-author dl {
    font-size: max(2.9rem, 16px);
  }
  .original-head-author {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
  .original-head-btn {
    margin-left: 0;
  }
}
/* =====================================================================
    topics
======================================================================*/
.topics .article-list-date {
  color: #233581;
}
.topics-wrap {
  position: relative;
}
.topics-wrap::before {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  margin-left: calc(-20 / 650 * 100%);
  width: calc(690 / 650 * 100%);
  height: 100%;
  background: url(../images/common/bg_pattern01.jpg) repeat top center/10rem auto;
  z-index: -1;
}
.topics-wrap::after {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  right: 0;
  margin: calc(-54 / 650 * 100%) calc(-47 / 650 * 100%) 0 0;
  width: calc(280 / 650 * 100%);
  padding-top: calc(143 / 650 * 100%);
  background: url(../images/common/img_tape04.png) no-repeat center/contain;
}
.topics-list {
  padding: 10rem calc(30 / 650 * 100%);
}
.topics-list li {
  position: relative;
}
.topics-list li .article-list-img {
  margin-bottom: 0;
}
.topics-list li figure {
  margin-bottom: 0;
}
.topics-list li h4 {
  margin-bottom: 1em;
}
.topics-list li:first-child a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (max-width: 767px) {
  .topics-list li:first-child a .article-list-img {
    margin-bottom: 1.3em;
  }
  .topics-list li:not(:last-child) {
    margin-bottom: 6rem;
  }
  .topics-list li:not(:last-child) a {
    padding-bottom: 6rem;
    border-bottom: 1px solid #b7b7b7;
  }
  .topics-list li:not(:first-child) a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .topics-list li:not(:first-child) a .article-list-img {
    width: 45.7627118644%;
  }
  .topics-list li:not(:first-child) a .article-list-text {
    width: 49.1525423729%;
  }
}

@media screen and (min-width: 768px) {
  .topics-wrap::before {
    margin-left: calc(-130 / 1000 * 100%);
    width: calc(1260 / 1000 * 100%);
  }
  .topics-wrap::after {
    margin: calc(-42 / 1000 * 100%) calc(-167 / 1000 * 100%) 0 0;
    width: calc(254 / 1000 * 100%);
    padding-top: calc(120 / 1000 * 100%);
  }
  .topics-list {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    padding: 8rem 0 2rem;
  }
  .topics-list li .article-list-img {
    margin-bottom: 3rem;
  }
  .topics-list li:nth-child(3n+1), .topics-list li:first-child {
    margin-right: 0;
  }
  .topics-list li:first-child {
    width: 100%;
  }
  .topics-list li:first-child a {
    margin-left: auto;
    margin-right: auto;
    width: calc(800 / 1000 * 100%);
  }
}
.topics-article::before {
  height: calc(100% - 16rem);
}
.topics-article > * {
  position: relative;
}
.topics-article-date {
  position: relative;
  margin-bottom: 1em;
}
.topics-article-date::before {
  content: "";
  position: absolute;
  display: block;
  top: -1.2em;
  left: -0.6em;
  width: 7.6em;
  height: 4.4em;
  background: url(../images/common/img_circle01.svg) no-repeat center/contain;
  z-index: -1;
}
.topics-article-contents {
  margin: 0 auto;
  padding: 9rem 0;
  width: calc(590 / 650 * 100%);
}
.topics-article-contents > * {
  position: relative;
  margin-bottom: 5rem;
  line-height: 1.785;
}
.topics-article-contents > *:last-child {
  margin-bottom: 0 !important;
}
.topics-article-contents header h3 {
  position: relative;
  margin-bottom: 2em;
  padding-bottom: 1em;
  font-size: 121%;
  line-height: 1.941;
}
.topics-article-contents header h3::before {
  content: "";
  position: absolute;
  display: block;
  bottom: 0;
  left: 0;
  width: 90%;
  height: 1em;
  background: url(../images/common/img_marker02.png) no-repeat bottom left/100% 100%;
}
.topics-article-contents p a {
  display: inline;
  color: #233581;
  border-bottom: 1px solid;
}
.topics-article-contents p b,
.topics-article-contents p strong {
  font-weight: 500;
}
.topics-article-contents p b {
  color: #c7bb00;
}
.topics-article-contents p strong {
  background-color: #f2ed9c;
}
.topics-article-contents .img-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-bottom: 3rem;
}
.topics-article-contents .img-list li {
  margin-bottom: 2rem;
  width: 50%;
}
.topics-article-contents .img-list li.wide {
  width: 100%;
}
.topics .sns-share {
  margin-left: auto;
}
.topics-btn {
  margin-top: 7rem;
}
.topics-btn a::after {
  top: calc(50% + 0.15em);
  right: auto;
  left: 1.3em;
  -webkit-transform: rotate(225deg);
          transform: rotate(225deg);
}

@media screen and (min-width: 768px) {
  .topics-article::before {
    height: calc(100% - 12rem);
  }
  .topics-article-contents {
    width: 100%;
    max-width: 800px;
  }
  .topics-article-contents header h3 {
    font-size: 133%;
  }
  .topics-article-contents .img-list li.wide {
    margin-left: auto;
    margin-right: auto;
    width: 87.5%;
  }
  .topics-article-contents p a {
    -webkit-transition-property: color;
    transition-property: color;
  }
  .topics-article-contents p a:hover {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    color: #c7bb00;
  }
}
/* =====================================================================
    movie
======================================================================*/
.movie {
  overflow: initial;
}
.movie::before {
  content: "";
  position: absolute;
  display: block;
  top: 1.7rem;
  left: 0;
  width: 100%;
  height: calc(100% + 20rem);
  background: url(../images/movie/bg_rikka-sp.png) space top center/100% auto;
}
.movie-wrap {
  padding: 10rem 0;
  overflow: hidden;
}
.movie-wrap:first-of-type {
  padding-top: 0;
}
.movie-wrap .article-list-date {
  color: #fff100;
}
.movie-wrap h4 {
  color: #ffffff;
}
.movie-subttl {
  text-align: center;
  margin: 0 auto 0.7rem;
  width: calc(416 / 650 * 100%);
  background: url(../images/common/bg_ink.png) no-repeat center/100% 100%;
}
.movie-subttl span {
  display: block;
  padding: 26.4423076923% 0 16.3461538462%;
  font-size: 3.6rem;
  color: #ffffff;
}
.movie-pickup a {
  position: relative;
  margin: 0 auto;
  width: calc(612 / 650 * 100%);
}
@media screen and (max-width: 767px) {
  .movie-pickup .article-list-date,
  .movie-pickup h4 {
    padding: 0 4.0849673203%;
  }
}
.movie-list {
  margin-top: 9rem;
}
@media screen and (max-width: 767px) {
  .movie-list .slick-list {
    overflow: visible;
  }
}
.movie-list .slick-slide {
  margin: 0 4.5rem;
}
.movie-list .slick-disabled {
  display: none !important;
}
.movie-list .slick-arrow {
  display: block;
  position: absolute;
  top: calc(50% - 5em);
  width: 2.5em;
  height: 2.5em;
  background: #233581;
  z-index: 3;
}
.movie-list .slick-arrow::before {
  content: "";
  position: absolute;
  display: block;
  top: 50%;
  left: 48%;
  width: 0.55em;
  height: 0.55em;
  margin-right: 3rem;
  border-top: 2px solid #fff100;
  border-right: 2px solid #fff100;
  -webkit-transform: rotate(45deg) translate(-50%, -50%);
          transform: rotate(45deg) translate(-50%, -50%);
  -webkit-transform-origin: top left;
          transform-origin: top left;
}
.movie-list .slick-arrow.prev {
  left: 0;
  margin-left: -1em;
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
}
.movie-list .slick-arrow.next {
  right: 0;
  margin-right: -1em;
}
.movie-list li {
  width: 41rem !important;
}
.movie-list li a {
  position: relative;
}
.movie-list li a::before {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

@media screen and (min-width: 768px) {
  .movie::before {
    top: 10rem;
    background-image: url(../images/movie/bg_rikka-pc.png);
  }
  .movie-wrap {
    padding: 6rem 0;
  }
  .movie-subttl {
    width: 320px;
  }
  .movie-subttl span {
    font-size: 166%;
  }
  .movie-pickup {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .movie-pickup a {
    width: calc(800 / 1000 * 100%);
  }
  .movie-list {
    margin: 5rem auto 0;
    width: calc(880 / 1000 * 100%);
  }
  .movie-list .slick-list {
    padding-top: 1rem;
  }
  .movie-list .slick-slide {
    margin: 0 2.5rem;
  }
  .movie-list .slick-arrow {
    cursor: pointer;
    -webkit-transition: 0.3s ease;
    transition: 0.3s ease;
  }
  .movie-list .slick-arrow.prev {
    margin-left: -3.5em;
  }
  .movie-list .slick-arrow.next {
    margin-right: -3.5em;
  }
  .movie-list .slick-arrow:hover.prev {
    margin-left: -4em;
  }
  .movie-list .slick-arrow:hover.next {
    margin-right: -4em;
  }
  .movie-list li {
    margin: 0;
    width: 259px !important;
  }
}
/* =====================================================================
    file
======================================================================*/
.file {
  padding-bottom: 15rem;
  overflow: initial;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .file-content {
    margin: 0 auto;
    width: calc(550 / 650 * 100%);
  }
}
.file-content > li {
  margin-bottom: 12rem;
  line-height: 1.206;
}
.file-content > li > *:not(:last-child) {
  margin-bottom: 5rem;
}
.file-content > li dl dt {
  margin-bottom: 0.4em;
  font-size: 207%;
  font-weight: normal;
  color: #233581;
}
.file-content > li dl dd {
  font-size: 107%;
  line-height: 1.933;
}
.file-content > li dl dd span {
  color: #6d6d6d;
}
.file-content-num {
  position: relative;
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  padding: 0.1em 0;
  width: 4.7em;
  font-family: "Caveat", cursive;
  font-size: 6rem;
  -webkit-filter: drop-shadow(3px 3px 2px rgba(0, 0, 0, 0.3));
          filter: drop-shadow(3px 3px 2px rgba(0, 0, 0, 0.3));
}
.file-content-num::before {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #daecf4;
  -webkit-clip-path: polygon(100% 0, 100% 91%, 89% 97%, 75% 99%, 50% 100%, 0 100%, 0 0);
          clip-path: polygon(100% 0, 100% 91%, 89% 97%, 75% 99%, 50% 100%, 0 100%, 0 0);
  -webkit-transform: rotate(-2deg);
          transform: rotate(-2deg);
  z-index: -1;
}
.file-content-img {
  margin-bottom: 0 !important;
}
.file-content-img li {
  position: relative;
  margin: 0 auto 5rem;
  width: 98.1818181818%;
}
.file-content-img li::before {
  content: "";
  position: absolute;
  display: block;
  top: 1rem;
  left: 1rem;
  width: 99.5%;
  height: 99.5%;
  background-color: rgba(65, 65, 65, 0.2);
  -webkit-transform: skewY(1deg);
          transform: skewY(1deg);
  -webkit-transform-origin: top left;
          transform-origin: top left;
  -webkit-filter: blur(2px);
          filter: blur(2px);
  z-index: -1;
}
.file-content-img li::after {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  right: 0;
  margin: -1.4814814815% auto 0;
  width: 6.6666666667%;
  padding-top: 6.6666666667%;
  background: url(../images/common/img_pin.png) no-repeat center/contain;
}
.file-content-img li.large {
  margin-left: -4.5454545455%;
  width: 109.0909090909%;
}
.file .sns-share {
  margin: -7rem calc(-20 / 650 * 100%) 0 auto;
}

.delivery02 {
  position: relative;
  padding: 15.7rem 0 14.5rem;
}
.delivery02::before {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  margin-left: calc(-33 / 650 * 100%);
  width: calc(683 / 650 * 100%);
  height: 100%;
  background: url(../images/common/bg_delivery02.png) no-repeat center/100% 100%;
  z-index: -1;
}
.delivery02-ttl {
  text-align: center;
  margin-bottom: 1em;
  font-size: 107%;
}
.delivery02 .banner-list li a {
  -webkit-box-shadow: 0 0.5rem 1.2rem 0px rgba(41, 43, 45, 0.3);
          box-shadow: 0 0.5rem 1.2rem 0px rgba(41, 43, 45, 0.3);
}

@media screen and (min-width: 768px) {
  .file {
    padding-bottom: 10rem;
  }
  .file-content > li {
    margin-bottom: 9rem;
  }
  .file-content > li > *:not(:last-child) {
    margin-bottom: 3.5rem;
  }
  .file-content > li dl {
    margin-left: auto;
    margin-right: auto;
    width: calc(500 / 1000 * 100%);
  }
  .file-content > li dl dt {
    font-size: 188%;
  }
  .file-content > li dl dd {
    font-size: 100%;
  }
  .file-content-num {
    font-size: 5rem;
  }
  .file-content-img {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .file-content-img li {
    margin: 0 calc(40 / 1000 * 100%) 3.5rem 0;
    width: calc(480 / 1000 * 100%);
  }
  .file-content-img li:nth-child(2n) {
    margin-right: 0;
  }
  .file-content-img li.large {
    margin-left: 0;
    margin-right: 0;
    width: calc(600 / 1000 * 100%);
  }
  .file .sns-share {
    margin-top: -22rem;
  }
  .delivery02 {
    margin-left: calc(-12 / 1000 * 100%);
    width: calc(633 / 1000 * 100%);
  }
  .delivery02::before {
    margin-left: 0;
    width: 100%;
  }
  .delivery02-ttl {
    font-size: 133%;
  }
  .delivery02 .banner-list li {
    width: 60.0315955766%;
  }
}/*# sourceMappingURL=subpage.css.map */
