@charset "UTF-8";
:root {
  /* color */
  --base-color: #fff;
  --main-color: #000;
  --brown-color: #282327;
  --orange-color: #dd9362;
  --green-color: #83b17b;
  --gray-color: #c8c8c8;
  --beige-color: #e5cdaa;
}

/* -- FOUNDATION -- */
html {
  font-size: 62.5%;
}

body {
  position: relative;
  width: 100%;
  font-family: "Shippori Mincho", serif;
  font-style: normal;
  font-weight: 500;
  font-size: 1.6rem;
  font-optical-sizing: auto;
  color: var(--main-color);
  line-height: 1;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}

@media (max-width:768px) {
  body {
    font-size: 3.733vw;
  }
}
img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

a {
  text-decoration: none;
  color: var(--main-color);
  -webkit-transition: 0.2s;
  transition: 0.2s;
}

@media (min-width:769px) {
  a:hover {
    opacity: 0.7;
  }
}
/* -- LAYOUT -- */
#loader {
  position: fixed;
  inset: 0;
  background: var(--brown-color);
  z-index: 9999;
}

.toggle {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  display: block;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 101;
  margin: 0;
  padding: 0;
  width: 8rem;
  height: 8rem;
  border: none;
  background: var(--main-color);
  -webkit-transition: background-color 0.2s ease;
  transition: background-color 0.2s ease;
  cursor: pointer;
}
.toggle > span, .toggle:before, .toggle:after {
  display: block;
  position: absolute;
  top: 3.7rem;
  right: 2.5rem;
  width: 3.1rem;
  height: 0.2rem;
  background-color: #fff;
}
.toggle > span {
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
  will-change: opacity;
}
.toggle::before, .toggle::after {
  content: "";
  -webkit-transition: background-color 0.3s ease;
  transition: background-color 0.3s ease;
}
.toggle::before {
  -webkit-transform: translateY(-0.9rem);
          transform: translateY(-0.9rem);
}
.toggle::after {
  -webkit-transform: translateY(0.9rem);
          transform: translateY(0.9rem);
}
.toggle[aria-expanded=true] > span {
  opacity: 0;
}
.toggle[aria-expanded=true]::before, .toggle[aria-expanded=true]::after {
  background-color: white;
}
.toggle[aria-expanded=true]::before {
  -webkit-animation: 0.3s ease closeBar1 forwards;
          animation: 0.3s ease closeBar1 forwards;
}
.toggle[aria-expanded=true]::after {
  -webkit-animation: 0.3s ease closeBar2 forwards;
          animation: 0.3s ease closeBar2 forwards;
}
.toggle.-close::before {
  -webkit-animation: 0.3s ease closeBar1Rev forwards;
          animation: 0.3s ease closeBar1Rev forwards;
}
.toggle.-close::after {
  -webkit-animation: 0.3s ease closeBar2Rev forwards;
          animation: 0.3s ease closeBar2Rev forwards;
}

@media (max-width:768px) {
  .toggle {
    width: 13.433vw;
    height: 13.433vw;
    font-size: 2.133vw;
  }
  .toggle > span, .toggle:before, .toggle:after {
    top: 6.533vw;
    right: 3.333vw;
    width: 7.067vw;
    height: 0.267vw;
    background-color: #fff;
  }
  .toggle::before {
    -webkit-transform: translateY(-1.733vw);
            transform: translateY(-1.733vw);
  }
  .toggle::after {
    -webkit-transform: translateY(1.733vw);
            transform: translateY(1.733vw);
  }
}
.humnav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-flex-line-pack: center;
      align-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: url(../img/bg.png);
  background-repeat: repeat;
  background-position: top center;
  color: black;
  -webkit-transition: opacity 0.3s ease, visibility 0.3s ease;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.humnav[aria-hidden=true] {
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
}
.humnav[aria-hidden=false] {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
}

@media (max-width:768px) {
  .humnav {
    display: block;
  }
}
.menu li {
  position: relative;
}
.menu li:hover {
  opacity: 0.7;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.menu li a {
  display: block;
  font-family: "Shippori Mincho", serif;
  font-style: normal;
  font-weight: 600;
  font-size: 3rem;
  text-align: center;
}
.menu li a:hover {
  opacity: 1;
}
.menu li + li {
  margin-top: 6rem;
}

@media (max-width:768px) {
  .menu {
    width: 32rem;
    max-width: 90vw;
    margin: 0 auto;
    padding-left: 0;
  }
  .menu li a {
    font-size: 2rem;
  }
  .menu li + li {
    margin-top: 4rem;
  }
}
@-webkit-keyframes closeBar1 {
  0% {
    -webkit-transform: translateY(-0.7em);
            transform: translateY(-0.7em);
  }
  50% {
    -webkit-transform: translateY(0) rotate(0);
            transform: translateY(0) rotate(0);
  }
  100% {
    -webkit-transform: translateY(0) rotate(45deg);
            transform: translateY(0) rotate(45deg);
  }
}
@keyframes closeBar1 {
  0% {
    -webkit-transform: translateY(-0.7em);
            transform: translateY(-0.7em);
  }
  50% {
    -webkit-transform: translateY(0) rotate(0);
            transform: translateY(0) rotate(0);
  }
  100% {
    -webkit-transform: translateY(0) rotate(45deg);
            transform: translateY(0) rotate(45deg);
  }
}
@-webkit-keyframes closeBar2 {
  0% {
    -webkit-transform: translateY(0.7em);
            transform: translateY(0.7em);
  }
  50% {
    -webkit-transform: translateY(0) rotate(0);
            transform: translateY(0) rotate(0);
  }
  100% {
    -webkit-transform: translateY(0) rotate(-45deg);
            transform: translateY(0) rotate(-45deg);
  }
}
@keyframes closeBar2 {
  0% {
    -webkit-transform: translateY(0.7em);
            transform: translateY(0.7em);
  }
  50% {
    -webkit-transform: translateY(0) rotate(0);
            transform: translateY(0) rotate(0);
  }
  100% {
    -webkit-transform: translateY(0) rotate(-45deg);
            transform: translateY(0) rotate(-45deg);
  }
}
@-webkit-keyframes closeBar1Rev {
  0% {
    -webkit-transform: translateY(0) rotate(45deg);
            transform: translateY(0) rotate(45deg);
  }
  50% {
    -webkit-transform: translateY(0) rotate(0);
            transform: translateY(0) rotate(0);
  }
  100% {
    -webkit-transform: translateY(-0.7em);
            transform: translateY(-0.7em);
  }
}
@keyframes closeBar1Rev {
  0% {
    -webkit-transform: translateY(0) rotate(45deg);
            transform: translateY(0) rotate(45deg);
  }
  50% {
    -webkit-transform: translateY(0) rotate(0);
            transform: translateY(0) rotate(0);
  }
  100% {
    -webkit-transform: translateY(-0.7em);
            transform: translateY(-0.7em);
  }
}
@-webkit-keyframes closeBar2Rev {
  0% {
    -webkit-transform: translateY(0) rotate(-45deg);
            transform: translateY(0) rotate(-45deg);
  }
  50% {
    -webkit-transform: translateY(0) rotate(0);
            transform: translateY(0) rotate(0);
  }
  100% {
    -webkit-transform: translateY(0.7em);
            transform: translateY(0.7em);
  }
}
@keyframes closeBar2Rev {
  0% {
    -webkit-transform: translateY(0) rotate(-45deg);
            transform: translateY(0) rotate(-45deg);
  }
  50% {
    -webkit-transform: translateY(0) rotate(0);
            transform: translateY(0) rotate(0);
  }
  100% {
    -webkit-transform: translateY(0.7em);
            transform: translateY(0.7em);
  }
}
.header {
  position: relative;
  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;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-flow: column;
          flex-flow: column;
  height: 91.5rem;
  background: url(../img/header_bg.jpg);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center bottom 8rem;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.header_logo {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 2.7rem;
     -moz-column-gap: 2.7rem;
          column-gap: 2.7rem;
  height: 8rem;
  width: 100%;
  padding-left: 2.2rem;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.header_rakuten {
  width: 18rem;
}
.header_rakuten img {
  width: 100%;
}

.header_tfm {
  width: 12.1rem;
}

.header_jfn {
  width: 4.6rem;
}

.header_kv {
  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: 70.7rem;
  height: auto;
  max-height: calc(100vh - 18rem);
  margin: 0 auto 5rem;
  overflow: hidden;
}
.header_kv picture {
  display: contents;
}
.header_kv img {
  display: block;
  width: 100%;
  height: 100%;
  max-height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.header_time {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  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: 100%;
  height: 8rem;
  background: var(--brown-color);
}
.header_time > img {
  width: 80.1rem;
  max-width: 90%;
}

@media (max-width:768px) {
  .header {
    height: 141.6vw;
    background: url(../img/sp/header_bg.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center bottom 11.735vw;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  .header_logo {
    -webkit-column-gap: 3.2vw;
       -moz-column-gap: 3.2vw;
            column-gap: 3.2vw;
    height: 13.433vw;
    padding-left: 3.6vw;
  }
  .header_rakuten {
    width: 27.6vw;
  }
  .header_tfm {
    width: 16.667vw;
  }
  .header_jfn {
    width: 6.4vw;
  }
  .header_kv {
    width: 86.133vw;
    height: 116.8vw;
    max-height: inherit;
    margin: 0;
  }
  .header_kv img {
    max-height: 100%;
  }
  .header_time {
    height: 11.735vw;
  }
  .header_time > img {
    width: 91.467vw;
    max-width: inherit;
  }
}
.main {
  background: url(../img/bg.png);
  background-repeat: repeat;
  background-position: top center;
}

.about {
  padding: 8.2rem 0 0;
}

.about_heading {
  width: 26.3rem;
  margin: 0 auto;
}

.about_txt {
  margin: 3rem 0 auto;
  font-size: clamp(1.4rem, 0.0684rem + 1.732vw, 1.8rem);
  font-family: "Zen Old Mincho", serif;
  font-style: normal;
  font-weight: 500;
  line-height: 2.5555555556;
  letter-spacing: 0.05em;
  text-align: center;
}

.about_radiko {
  display: block;
  width: 35.6rem;
  margin: 3.5rem auto 0;
}

.about_ph {
  display: block;
  width: 69.2rem;
  max-width: 96%;
  margin: 5rem auto 0;
}

.about_btnBox {
  margin: 3rem auto 0;
  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;
  -webkit-column-gap: 3rem;
     -moz-column-gap: 3rem;
          column-gap: 3rem;
}

.about_entry {
  display: block;
  width: 35.6rem;
}

.about_check {
  display: block;
  width: 35.6rem;
}

@media (max-width:768px) {
  .about {
    padding: 12.4vw 0 0;
  }
  .about_heading {
    width: 51.467vw;
  }
  .about_txt {
    width: 89.333vw;
    margin: 6vw auto 0;
    font-size: 3.467vw;
    font-family: "Zen Old Mincho", serif;
    font-style: normal;
    font-weight: 500;
    line-height: 2.5996153846;
    letter-spacing: 0.01em;
    text-align: left;
  }
  .about_radiko {
    width: 69.467vw;
    margin: 9.067vw auto 0;
  }
  .about_ph {
    width: 100%;
    max-width: inherit;
    margin: 8.267vw auto 0;
  }
  .about_btnBox {
    margin: 8.533vw auto 0;
    display: block;
  }
  .about_entry {
    width: 69.467vw;
    margin: 0 auto;
  }
  .about_check {
    width: 69.467vw;
    margin: 3.467vw auto 0;
  }
}
.cast {
  padding: 12.7rem 0 0;
}

.cast_heading {
  width: 18.9rem;
  margin: 0 auto;
}

.cast_container {
  width: 100rem;
  max-width: 92.4%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -ms-flex-flow: wrap;
      flex-flow: wrap;
  gap: clamp(2.805274rem, -0.5062rem + 4.306vw, 3.8rem) 3.8%;
  margin: 5.8rem auto 0;
}

.cast_card {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 48.1%;
  padding: 0 0 0 3.5%;
  aspect-ratio: 481/238;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.cast_card.--orange {
  background: var(--orange-color);
  background-image: url(../img/cast_bd.svg);
  background-repeat: no-repeat;
  background-size: 98.7525988%;
  background-position: center center;
}
.cast_card.--green {
  background: var(--green-color);
  background-image: url(../img/cast_bd.svg);
  background-repeat: no-repeat;
  background-size: 98.7525988%;
  background-position: center center;
}
.cast_card.--gray {
  background: var(--gray-color);
  background-image: url(../img/cast_bd.svg);
  background-repeat: no-repeat;
  background-size: 98.7525988%;
  background-position: center center;
}
.cast_card.--beige {
  background: var(--beige-color);
  background-image: url(../img/cast_bd.svg);
  background-repeat: no-repeat;
  background-size: 98.7525988%;
  background-position: center center;
}

.cast_ph {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 38.6694386694%;
          flex: 0 0 38.6694386694%;
  width: 38.6694386694%;
}

.cast_txt {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 54%;
          flex: 0 0 54%;
  width: 54%;
  font-family: "Shippori Mincho", serif;
  font-style: normal;
  font-weight: 500;
  text-align: center;
}

.cast_name {
  font-size: clamp(2.4rem, -0.0157rem + 3.141vw, 3rem);
  letter-spacing: 0.14em;
}

.cast_roma {
  margin-top: 1.5rem;
  font-size: clamp(1.3rem, 0.5676rem + 0.952vw, 1.52rem);
  letter-spacing: 0.14em;
}

.cast_list {
  position: absolute;
  inset: 0;
  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: auto;
  font-size: 2rem;
  font-family: "Shippori Mincho", serif;
  font-style: normal;
  font-weight: 500;
  line-height: 2;
  text-align: center;
}

@media (max-width:768px) {
  .cast {
    padding: 16.533vw 0 0;
  }
  .cast_heading {
    width: 36.667vw;
  }
  .cast_container {
    max-width: 90vw;
    gap: 4vw 0;
    margin: 5.8rem auto 0;
  }
  .cast_card {
    width: 100%;
    padding: 0 0 0 6.667vw;
  }
  .cast_ph {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 34.925vw;
            flex: 0 0 34.925vw;
    width: 34.925vw;
  }
  .cast_name {
    font-size: 5.613vw;
    font-family: "Shippori Mincho", serif;
    font-style: normal;
    font-weight: 600;
  }
  .cast_roma {
    margin-top: 3.467vw;
    font-size: 2.844vw;
    font-family: "Shippori Mincho", serif;
    font-style: normal;
    font-weight: 600;
  }
  .cast_list {
    font-size: 3.743vw;
  }
}
.staff {
  padding: 10.8rem 0 0;
}

.staff_heading {
  width: 26.2rem;
  margin: 0 auto;
}

.staff_name {
  margin: 4.4rem auto 0;
  font-size: 1.8rem;
  font-family: "Shippori Mincho", serif;
  font-style: normal;
  font-weight: 600;
  line-height: 2.6666666667;
  letter-spacing: 0.1em;
  text-align: center;
}

@media (max-width:768px) {
  .staff {
    padding: 12.4vw 0 0;
  }
  .staff_heading {
    width: 50.8vw;
  }
  .staff_name {
    margin: 7.333vw auto 0;
    font-size: 3.467vw;
  }
}
.slide {
  position: relative;
  width: 100%;
  height: 26.7rem;
  margin: 13rem auto 0;
  background-position: 0 0;
  -webkit-animation: bgroop 50s linear infinite;
          animation: bgroop 50s linear infinite;
  background: url(../img/slide.jpg);
  background-size: 160rem auto;
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
}

@-webkit-keyframes bgroop {
  from {
    background-position: 0 0;
  }
  to {
    background-position: -160rem 0;
  }
}

@keyframes bgroop {
  from {
    background-position: 0 0;
  }
  to {
    background-position: -160rem 0;
  }
}
@media (max-width:768px) {
  .slide {
    margin: 20.933vw auto 0;
    height: 66.933vw;
    background-size: auto 100%;
  }
}
.drama {
  padding: 11.4rem 0 0;
}

.drama_heading {
  width: 31.9rem;
  margin: 0 auto;
}

.drama_container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -ms-flex-flow: wrap;
      flex-flow: wrap;
  gap: 7.7rem;
  width: 95.7rem;
  max-width: 96%;
  margin: 8.3rem auto 0;
}

.drama_box {
  width: 44rem;
}

.drama_ttl {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 2.1rem 2.5rem;
  aspect-ratio: 440/262;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.drama_ttl:before, .drama_ttl:after {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  background: url(../img/drama_bd.svg);
  background-size: 100%;
  background-repeat: no-repeat;
  content: "";
}
.drama_ttl:before {
  background-position: center top;
}
.drama_ttl:after {
  -webkit-transform: scaleY(-1);
          transform: scaleY(-1);
}

.drama_ttlNum {
  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;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  padding-right: 1.5rem;
  font-size: 5.1rem;
  font-family: "Shippori Mincho", serif;
  font-style: normal;
  font-weight: 500;
  -webkit-writing-mode: vertical-lr;
      -ms-writing-mode: tb-lr;
          writing-mode: vertical-lr;
  border-right: 0.2rem dotted #000;
}

.drama_ttlBody {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
          flex: 1 1 auto;
  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;
  font-size: 3rem;
  font-family: "Shippori Mincho", serif;
  font-style: normal;
  font-weight: 600;
  line-height: 1.2;
  text-align: center;
}
.drama_ttlBody.melody {
  margin-right: -1rem;
  letter-spacing: -0.04em;
}

.drama_cast {
  min-height: 4.8rem;
  margin: 2rem auto 0;
  font-family: "Shippori Mincho", serif;
  font-style: normal;
  font-weight: 700;
  line-height: 1.75;
  text-align: center;
}

.drama_more {
  display: block;
  width: 35.6rem;
  margin: 2.8rem auto 0;
  cursor: pointer;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
}
.drama_more:hover {
  opacity: 0.8;
}

@media (max-width:768px) {
  .drama {
    padding: 14.267vw 0 0;
  }
  .drama_heading {
    width: 58.267vw;
  }
  .drama_container {
    gap: 11.733vw;
    width: 86.133vw;
    max-width: inherit;
    margin: 7.467vw auto 0;
  }
  .drama_box {
    width: 100%;
  }
  .drama_ttl {
    padding: 3.867vw 4.933vw;
  }
  .drama_ttlNum {
    padding-right: 3.333vw;
    font-size: 10.145vw;
    border-right: 0.267vw dotted #000;
  }
  .drama_ttlBody {
    font-size: 5.877vw;
  }
  .drama_ttlBody.melody {
    margin-right: -2vw;
  }
  .drama_cast {
    min-height: inherit;
    margin: 5.467vw auto 0;
    font-size: 3.467vw;
    font-family: "Shippori Mincho", serif;
    font-style: normal;
    font-weight: 700;
    line-height: 1.92;
    text-align: center;
  }
  .drama_more {
    display: block;
    width: 69.6vw;
    margin: 10.4vw auto 0;
  }
}
.modal_wrapper {
  position: relative;
}

.modal_close {
  position: absolute;
  top: -5rem;
  right: 0;
  width: 4rem;
  height: 4rem;
  cursor: pointer;
}

.modal_inner {
  position: relative;
  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;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-flow: column;
          flex-flow: column;
  padding: 5.8rem 0 7.4rem;
  background: url(../img/bg.png);
  background-repeat: repeat;
  background-position: top center;
}
.modal_inner:after {
  position: absolute;
  inset: 1rem;
  display: block;
  border: 0.2rem dotted #000;
  content: "";
}

.modal_txt {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  max-width: 80%;
  margin: 4.5rem auto 0;
  font-size: 1.8rem;
  font-family: "Shippori Mincho", serif;
  font-style: normal;
  font-weight: 700;
  line-height: 1.8888888889;
}

.modaal-content-container, .modaal-container {
  padding: 0;
  background: none;
}

@media (max-width:768px) {
  .modal_wrapper {
    padding-top: 1vw;
  }
  .modal_close {
    position: relative;
    top: 0;
    width: 10vw;
    height: 10vw;
    margin: 1vw 0 1vw auto;
  }
  .modal_inner {
    padding: 7vw 3vw;
  }
  .modal_inner .drama_box {
    padding: 0vw 3vw;
  }
  .modal_inner .drama_cast {
    font-size: 3vw;
  }
  .modal_txt {
    width: 90%;
    max-width: inherit;
    margin: 7vw auto 0;
    font-size: 4vw;
  }
  .modaal-inner-wrapper {
    padding: 2vw;
  }
}
.program {
  padding: 11.9rem 0 15.6rem;
  text-align: center;
}

.program_heading {
  position: relative;
  padding-bottom: 2rem;
  font-size: 3rem;
  font-family: "Shippori Mincho", serif;
  font-style: normal;
  font-weight: 700;
}
.program_heading:not(:first-child) {
  margin: 10rem auto 0;
}
.program_heading:before {
  position: absolute;
  right: 0;
  left: 0;
  bottom: 0;
  display: block;
  width: 3.8rem;
  height: 0.4rem;
  margin: 0 auto;
  background: var(--orange-color);
  content: "";
}

.program_ttl {
  margin: 5rem auto 0;
  font-size: 3rem;
  font-family: "Shippori Mincho", serif;
  font-style: normal;
  font-weight: 600;
}

.program_name {
  margin: 3rem auto 0;
  font-size: 2rem;
  font-family: "Shippori Mincho", serif;
  font-style: normal;
  font-weight: 600;
}

.program_narration {
  margin: 3.7rem auto 0;
  font-size: 2rem;
  font-family: "Shippori Mincho", serif;
  font-style: normal;
  font-weight: 600;
}

@media (max-width:768px) {
  .program {
    padding: 13.867vw 0 14.8vw;
  }
  .program_heading {
    padding-bottom: 3.467vw;
    font-size: 5.187vw;
    font-family: "Shippori Mincho", serif;
    font-style: normal;
    font-weight: 700;
  }
  .program_heading:not(:first-child) {
    margin: 18.4vw auto 0;
  }
  .program_heading:before {
    width: 6.667vw;
    height: 0.533vw;
  }
  .program_ttl {
    margin: 8.267vw auto 0;
    font-size: 5.187vw;
  }
  .program_name {
    margin: 4vw auto 0;
    font-size: 3.467vw;
  }
  .program_narration {
    margin: 6.4vw auto 0;
    font-size: 3.467vw;
  }
}
.footer {
  position: relative;
  padding: 0;
}

.footer_bnr {
  background: var(--base-color);
}

.footer_bnrPrimary {
  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;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-flow: column;
          flex-flow: column;
  row-gap: 7.5rem;
  padding: 5.7rem 0 7.5rem;
  border-bottom: 0.2rem dotted #000;
}

.footer_sb {
  display: block;
  width: 58.1rem;
}

.footer_ssb {
  display: block;
  width: 26.1rem;
}

.footer_bnrSecondary {
  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;
  padding: 8rem 0;
}

.footer_rakuten {
  display: block;
  width: 28.4rem;
}

.footer_common {
  margin: 0 auto;
  border-top: 0.2rem solid #000;
  font-family: sans-serif;
}

.footer_common-pc {
  display: block;
}

.footer_common-sp {
  display: none;
}

.footer_bg {
  display: block;
  width: 100%;
}
.footer_bg img {
  width: 100%;
}

.footer_share {
  position: absolute;
  bottom: 1.7rem;
  left: 1.4rem;
}

.footer_icon {
  display: inline-block;
  width: 3.8rem;
  margin-right: 0.5rem;
}

.footer_copyright {
  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;
  height: 7.1rem;
  margin: 0 auto;
  color: var(--base-color);
  font-size: 1.6rem;
  font-family: "Shippori Mincho", serif;
  font-style: normal;
  font-weight: 500;
  text-align: center;
  background: var(--brown-color);
}

@media (max-width: 1000px) {
  .footer_common {
    padding: 0;
  }
  .footer_common-pc {
    display: none;
  }
  .footer_common-sp {
    display: block;
  }
}
@media (max-width:768px) {
  .footer {
    background: var(--brown-color);
    padding-bottom: 12.267vw;
  }
  .footer_bnrPrimary {
    row-gap: 8.933vw;
    padding: 6vw 0 9.867vw;
  }
  .footer_sb {
    width: 86.667vw;
  }
  .footer_ssb {
    width: 55.467vw;
  }
  .footer_bnrSecondary {
    padding: 16.2667vw 0;
  }
  .footer_rakuten {
    display: block;
    width: 50vw;
  }
  .footer_share {
    position: relative;
    bottom: inherit;
    left: inherit;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 6vw auto 0;
  }
  .footer_icon {
    width: min(10.8vw, 4.5rem);
    margin-right: 1.4vw;
    margin-left: 1.4vw;
  }
  .footer_copyright {
    height: auto;
    margin: 4.667vw auto;
    font-size: 2.667vw;
  }
}
.follow {
  position: fixed;
  right: 0;
  top: 19.6rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: auto;
  max-height: calc(100vh - 22.4rem);
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-flow: column wrap;
          flex-flow: column wrap;
}

.follow_entry {
  display: block;
  width: 6.6rem;
  margin-bottom: 1.4rem;
}

.follow_radiko {
  display: block;
  width: 6.7rem;
}

@media (max-width:768px) {
  .follow {
    left: 0;
    top: inherit;
    bottom: 0;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-flow: row;
            flex-flow: row;
    max-height: inherit;
  }
  .follow_entry {
    width: 50%;
    margin-bottom: 0;
  }
  .follow_radiko {
    width: 50%;
  }
}
.pagetop-pc {
  position: fixed;
  right: 2.5rem;
  bottom: 2.5rem;
  cursor: pointer;
  z-index: 2;
}
.pagetop-pc img {
  width: 6rem;
}

.pagetop-sp {
  display: none;
}

@media (max-width:768px) {
  .pagetop-pc {
    display: none !important;
  }
  .pagetop-sp {
    position: absolute;
    bottom: 24.1vw;
    right: 4.933vw;
    display: block;
    width: min(11.264vw, 4.5rem);
  }
}
/* -- UTILITY -- */
/* 共通フッター用 もしくはブレイクポイントごとの表示指定 */
.pcflex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.pc {
  display: block;
}

.sp {
  display: none;
}

@media (max-width:768px) {
  .sp {
    display: block;
  }
  .pc {
    display: none;
  }
  .pcflex {
    display: none;
  }
}
.u-fadeIn {
  opacity: 0;
  -webkit-filter: blur(8px);
          filter: blur(8px);
  visibility: hidden;
  will-change: filter, opacity, transform;
}

.u-fadeInUp {
  opacity: 0;
  -webkit-filter: blur(2px);
          filter: blur(2px);
  visibility: hidden;
  will-change: filter, opacity, transform;
}