@charset "utf-8";

#main-contents #journalOa h3.sub-ttl span {
  background:linear-gradient(transparent 65%, #85fc95 65%);
}
#main-contents #journalOa .more-btn {
  background: #1dbc32;
}

/* mainvisual */
#main-contents .mainvisual {
  background: url("../../img/main.png") no-repeat center top;
  height: 750px;
}
#main-contents .mainvisual .center {
  padding: 45px 0 0 0px;
}
#main-contents .mainvisual .ttl {
  font-size: 0;
}


/* cast */
#main-contents #cast .center {
  width: 980px;
}
#main-contents #cast .archive {
  margin-bottom: 60px;
  text-align: center;
}
#main-contents #cast .archive li {
  display: inline-block;
  margin: 5px 0;
  border-right: 1px #000 solid;
}
#main-contents #cast .archive li:first-child {
  border-left: 1px #000 solid;
}
#main-contents #cast .archive li a {
  display: block;
  padding: 0 10px;
  font-weight: 600;
}
#main-contents #cast .archive li.active a {
  color: #205fe5;
}
#main-contents #cast .inblock {
  padding: 40px 60px 20px 60px;
}
#main-contents #cast .inblock .message {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 30px;
  color: #205fe5;
  font-weight: bold;
  font-size: 1.125em;
  text-align: center;
}
#main-contents #cast .inblock .message:before,
#main-contents #cast .inblock .message:after {
  display: inline-block;
  content: "";
  /*width: 23px;
  height: 42px;*/
  width: 20px;
  height: 35px;
  margin: 0 10px;
  background: url("../../original/img/slash.gif") no-repeat left top / 100% 100%;
}
#main-contents #cast .inblock .message:after {
  transform: scale(-1,1);
}
#main-contents #cast .inblock .message br {
  display: none;
}
#main-contents #cast .inblock .mentai .message {
  color: #ff4fa2;
}
#main-contents #cast .inblock .mentai .message:before,
#main-contents #cast .inblock .mentai .message:after {
  background: url("../../original/img/slash_p.gif") no-repeat left top / 100% 100%;
}
#main-contents #cast .group {
  margin-bottom: 80px;
  text-align: center;
}
#main-contents .barihaya h3.sub-ttl span {
  background: linear-gradient(transparent 65%, #c7eaff 65%);
}
#main-contents .mentai h3.sub-ttl span {
  background: linear-gradient(transparent 65%, #ffc7e1 65%);
}
#main-contents #cast .inner {
  display: flex;
  justify-content: center;
  align-items: stretch;
  margin-bottom: 30px;
}
#main-contents #cast .mbase-inblock {
  width: 270px;
  margin: 0 7px 30px 7px;
  border-radius: 8px;
  overflow: hidden;
}
#main-contents #cast .barihaya .mbase-inblock {
  background: #69c7ff;
  box-shadow:0px 2px 0px 0px rgba(109,172,210,1);
}
#main-contents #cast .mentai .mbase-inblock {
  background: #ff4fa2;
  box-shadow:0px 2px 0px 0px rgba(190,80,132,1);
}
#main-contents #cast .mbase-inblock .link-prof {
  background: #fff;
}
#main-contents #cast .mbase-inblock .link-prof a {
  display: block;
}
#main-contents #cast .mbase-inblock .castImg {
  position: relative;
  padding-top: 100%;
  overflow: hidden;
}
#main-contents #cast .mbase-inblock .castImg img {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
}
#main-contents #cast h4 {
  min-height: 74px;
  padding: 10px 15px;
  text-align: center;
}
#main-contents #cast .barihaya h4 {
  background: #c7eaff;
}
#main-contents #cast .mentai h4 {
  background: #ffc7e1;
}
#main-contents #cast h4 .name {
  display: block;
  font-weight: bold;
  font-size: 1.125em;
}
#main-contents #cast h4 .status {
  display: inline-block;
  min-width: 130px;
  line-height: 1.4;
  margin: 8px auto 0;
  padding: 5px 20px;
  border-radius: 14px;
  background: #fff;
  color: #ababab;
  font-size: 0.813em;
}
#main-contents #cast .switch {
  position: relative;
  padding: 0 15px;
  font-weight: bold;
}
#main-contents #cast .switch:before {
  display: block;
  content: "";
  position: absolute;
  top: -7px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 8px 7px 8px;
}
#main-contents #cast .barihaya .switch:before {
  border-color: transparent transparent #69c7ff transparent;
}
#main-contents #cast .mentai .switch:before {
  border-color: transparent transparent #ff4fa2 transparent;
}
#main-contents #cast .switch .comment {
  line-height: 1.4;
  padding-top: 15px;
  color: #fff;
  font-size: 1em;
  letter-spacing: 0;
}
#main-contents #cast .switch .comment:after {
  display: block;
  content: "";
  height: 4px;
  margin-top: 10px;
  border-radius: 2px;
}
#main-contents #cast .barihaya .switch .comment:after {
  background: #c7eaff;
}
#main-contents #cast .mentai .switch .comment:after {
  background: #ffc7e1;
}
#main-contents #cast .switch .mov {
  padding: 13px 0 15px;
}
#main-contents #cast .switch .popup {
  color: #fff;
  font-size: 0.938em;
}
#main-contents #cast .switch .popup .play {
  display: inline-block;
  width: 18px;
  height: 18px;
  padding-left: 1px;
  border: 2px #fff solid;
  border-radius: 50%;
  text-align: center;
}
#main-contents #cast .switch .popup .play img {
  display: inline-block;
  width: 7px;
  vertical-align: 1px;
}
#main-contents #cast .cast-mov {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-wrap: wrap;
  margin-top: 30px;
}
#main-contents #cast .cast-mov .mov-block {
  width: 270px;
  margin: 0 7px 30px;
}
#main-contents #cast .cast-mov .mov-trim {
  position: relative;
  margin-bottom: 10px;
  border: 1px #e4e4e4 solid;
  border-radius: 4px;
  overflow: hidden;
}
#main-contents #cast .cast-mov .mov-trim:after {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50% , -50%);
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: url("../../original/img/icon_play.svg") no-repeat 28px center / 30px auto;
  background-color: rgba(0, 0, 0, 0.5);
}
.hover #main-contents #cast .cast-mov .popup:hover .mov-trim:after {
  background-color: rgba(0, 0, 0, 1);
  transition: .3s;
}
#main-contents #cast .cast-mov .mov-ttl {
  line-height: 1.5;
  text-align: left;
  font-size: 0.938em;
}
#main-contents #cast .repair {
  margin-bottom: 60px;
}
#main-contents #cast .repair .article {
  max-width: 760px;
  width: 100%;
  margin: 0 auto 25px;
  padding: 28px;
  background: url("../../original/2023/img/bg_repair.jpg") no-repeat center top / cover;
  border-radius: 8px;
}
#main-contents #cast .repair .article.patt-03 .pic {
  display: flex;
  justify-content: space-between;
  align-items:baseline;
  border-radius: 10px;
  overflow: hidden;
}
#main-contents #cast .repair .article.patt-03 .pic .first {
  width: 300px;
}
#main-contents #cast .repair .article.patt-03 .pic .others {
  width: 400px;
}
#main-contents #cast .repair .article.patt-03 .pic .others img:first-child {
  margin-bottom: 4px;
}
#main-contents #cast .repair .article .text {
  line-height: 1.8;
  margin: 25px 0 20px 0;
  color: #fff;
  letter-spacing: 0.04em;
}
#main-contents #cast .repair .article .tw-btn {
  width: 220px;
  padding: 8px;
  border-radius: 4px;
  background: #fff;
  box-shadow: 4px 5px 0px 0px rgb(0 0 0 / 15%);
}
#main-contents #cast .repair .article .tw-btn a {
  display: flex;
  align-items: center;
  height: 100%;
  font-size: 0.938em;
}
#main-contents #cast .repair .article .tw-btn a img {
  width: 28px;
  margin-right: 10px;
  border-radius: 4px;
}
#main-contents #cast .pr {
  padding-bottom: 60px;
}


#main-contents .media .mbase-inblock {
  background: #fff;
  box-shadow: 0px 2px 0px 0px rgb(0 0 0 / 10%);
}

.event__ttl {
  line-height: 1.4;
  margin-bottom: 35px;
  font-weight: 600;
  text-align: center;
}
.event__ttl .message {
  margin-bottom: 12px !important;
}
.event__ttl strong {
  font-size: 40px;
}
.event__ttl strong br {
  display: none;
}

@media all and (max-width:812px) {
  .event__ttl {
    margin-bottom: 30px !important;
  }
  .event__ttl strong br {
    display: block !important;
  }
  .event__ttl .message {
    align-items: flex-end !important;
    margin-bottom: 10px !important;
  }
}

@media all and (max-width:520px) {
  .event__ttl {
    margin-bottom: 20px !important;
    }
  .event__ttl strong {
    margin-bottom: 30px;
    font-size: 7vw !important;
  }
  .event__ttl .message {
    font-size: 3.7vw !important;
  }
}

.event__block {
  margin-bottom: 50px;
}

.event__block .flex {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: stretch;
  padding: 0 20px;
}

@media all and (max-width:812px) {
  .event__block .flex  {
    padding: 0 3%
  }
}

@media all and (max-width:812px) {
  .event__block .flex {
    display: block
  }
}

.article .common-text {
  position: relative;
  padding: 0 20px;
  line-height: 2;
}

@media all and (max-width:812px) {
  .article .common-text {
    line-height: 1.8;
    padding: 0 3%
  }
}

@media all and (max-width:520px) {
  .article .common-text {
    font-size: .938rem
  }
}

.article .ttl-h3 {
  background: #205FE5;
}

.item {
  width: 49%;
  border-radius: 8px;
  background: #f0f0f0;
  overflow: hidden;
  display: flex;
  flex-direction: column
}

@media all and (max-width:812px) {
  .item {
    width: 100%
  }
}

.about .capture {
  display: flex;
  flex-direction: column;
  gap: 10px 0;
  width: 47%
}

@media all and (max-width:812px) {
  .about .capture {
    width: 100%;
    margin-bottom: 15px
  }
}

.about .capture img {
  border-radius: 4px
}

.about .common-text {
  width: 49.5%;
  padding: 0;
  text-align: justify
}

@media all and (max-width:812px) {
  .about .common-text {
    width: 100%;
  }
}

.place strong {
  display: block;
  line-height: 1.6;
  margin-bottom: 10px;
  font-weight: 600;
}
.place span {
  color: #205FE5;
}
.place table {
  line-height: 1.6;
  margin: 20px 0;
}
.place th, .place td {
  padding: 2px 0;
}
.place th {
  width: 50px;
}

.entry .common-text p {
  margin-bottom: 15px
}

.entry .common-text p strong {
  display: block;
  margin-bottom: 10px;
  color: #d60707;
  font-weight: 600;
  font-size: 1.25em
}

.entry .common-text p a {
  display: inline-block;
  line-height: 1.4;
  margin-right: 5px;
  border-bottom: 1px solid #d60707;
  color: #d60707
}

.entry .common-text p a::after {
  display: inline-block;
  content: "";
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="22" height="21" viewBox="0 0 22 21"><path id="newtab" class="cls-1" d="M14.662,1A0.637,0.637,0,0,1,14.4.3,0.738,0.738,0,0,1,15.13,0h5.656a0.912,0.912,0,0,1,.688.3,0.952,0.952,0,0,1,.281.672V6.625a0.7,0.7,0,0,1-.3.719,0.669,0.669,0,0,1-.7-0.281L18.818,5.156,8.349,15.625,6.161,13.406,16.6,2.906Zm2.8,17.109a0.926,0.926,0,0,1-.672.3H4.318a0.926,0.926,0,0,1-.672-0.3,0.926,0.926,0,0,1-.3-0.672V4.969a0.926,0.926,0,0,1,.3-0.672A0.927,0.927,0,0,1,4.318,4h7.844V1.625H3.505a2.365,2.365,0,0,0-1.812.719,2.47,2.47,0,0,0-.75,1.813V18.25a2.469,2.469,0,0,0,.75,1.813,2.469,2.469,0,0,0,1.813.75H17.568A2.561,2.561,0,0,0,20.13,18.25V10.344H17.755v7.094A0.927,0.927,0,0,1,17.458,18.109Z" style="fill:%23d60707"/></svg>') no-repeat left center/100% auto;
  width: 15px;
  height: 15px;
  margin-left: 3px
}

.entry .note {
  color: #d60707
}

.entry .note li {
  margin-bottom: 2px
}

.entry__btn {
  width: min(480px, 100%);
  margin: 40px auto 0
}

.entry__okazawa {
  width: min(370px, 85%);
  margin: 0 auto
}

@media all and (max-width:520px) {
  .entry__btn {
    margin-top: 30px
  }
}

.entry__btn a {
  display: block;
  position: relative;
  line-height: 1.4;
  padding: 23px 5%;
  border: 3px solid #000;
  border-radius: 100px;
  background-color: #ffe538;
  color: #000;
  font-weight: 600;
  font-size: min(25px, 5.5vw);
  text-align: center
}

@media all and (max-width:520px) {
  .entry__btn a {
    padding: 4vw 5%
  }
}

.entry__btn a::after {
  display: block;
  content: "";
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="17" viewBox="0 0 12 17"><path id="right" class="cls-1" d="M0.669,14.378l2.64,2.631L11.866,8.43,3.521,0.017,0.716,2.742l5.8,5.83Z" style="fill:%23000000" /></svg>') no-repeat left center/auto 100%;
  width: 15px;
  height: 15px;
  position: absolute;
  top: 50%;
  right: 5%;
  translate: 0 -50%
}

.entry__btn a span {
  display: block;
  font-size: .8em
}

.entry__end {
  line-height: 1.5;
  margin-top: 30px;
  padding: 20px 0;
  border: 1px solid #000;
  color: #000;
  font-weight: 600;
  font-size: 2rem;
  text-align: center;
  word-break: keep-all;
}

@media all and (max-width:812px) {
  .entry__end {
    font-size: 4vw
  }
}

@media all and (max-width:520px) {
  .entry__end {
    padding: 4.5% 0;
    font-size: 5vw
  }
}

.entry__end span {
  display: block;
  margin-top: 5px;
  color: #d60707;
  font-size: .75em
}

.entry .overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #fff;
  opacity: .6
}

.timespan .common-text {
  font-weight: 600;
  font-size: min(25px, 5.4vw)
}

.clothes dl {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 30px 0
}

@media all and (max-width:812px) {
  .clothes dl {
    display: block
  }
}

.clothes dt {
  width: 120px;
  line-height: 1
}

.clothes dt span {
  display: block;
  padding: 7px 0;
  border: 2px solid #1dbc32;
  border-radius: 30px;
  background-color: #fff;
  color: #1dbc32;
  font-weight: 600;
  font-size: 1.125rem;
  text-align: center
}

@media all and (max-width:812px) {
  .clothes dt {
    width: 100%;
    margin-bottom: 10px
  }
}

.clothes dd {
  width: calc(100% - 140px);
  vertical-align: top
}

.clothes dd strong {
  display: block;
  font-weight: 600
}

.clothes dd ul {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
}

@media all and (max-width:812px) {
  .clothes dd {
    width: 100%;
    margin-bottom: 20px
  }
}

.caution p {
  margin-bottom: 30px;
  color: #d60707;
  font-weight: 600;
  font-size: 1.25em
}

@media all and (max-width:812px) {
  .caution p {
    line-height: 1.5;
    margin-bottom: 20px
  }
}

.caution__list li {
  position: relative;
  line-height: 1.7;
  margin-bottom: 5px;
  padding-left: 20px;
  font-feature-settings: "palt"0;
  letter-spacing: .04em;
  color: #222
}

.caution__list li::before {
  display: block;
  content: "";
  position: absolute;
  top: 7px;
  left: 0;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  overflow: hidden;
  background-color: #56bbfb
}



@media all and (max-width: 812px) {

  /* cast */
  #main-contents #cast .center {
    width: 85%;
  }
  #main-contents #cast .group {
    margin-bottom: 60px;
  }
  #main-contents #cast .inblock {
    padding: 30px 2.5% 1%;
  }
  #main-contents #cast .group .inner {
    display: flex;
    flex-wrap:wrap;
    justify-content: center;
    width: 100%;
  }
  #main-contents #cast .mbase-inblock {
    display: block;
    width: 45%;
    margin: 0 1.5% 30px;
  }
  #main-contents #cast .inblock .message {
    margin-bottom: 20px;
    font-size: 1em;
  }
  #main-contents #cast .inblock .message:before, #main-contents #cast .inblock .message:after {
    width: 15px;
    height: 30px;
  }
  #main-contents #cast .mbase-inblock .castImg {
    padding-top: 120%;
  }
  #main-contents #cast .mbase-inblock .castImg img {
    width: auto;
    height: 100%;
  }
  #main-contents #cast .cast-mov {
    margin-top: 0px;
  }
  #main-contents #cast .cast-mov .mov-block {
    width: 45%;
    margin: 0 1.5% 20px;
  }
  #main-contents #cast .cast-mov .mov-ttl {
    font-size: 0.875em;
  }
  #main-contents #cast .cast-mov .mov-trim:after {
    width: 12vw;
    height: 12vw;
    background: url("../../original/img/icon_play.svg") no-repeat 4vw center / 5vw auto;
    background-color: rgba(0, 0, 0, 0.5);
  }
  
  #main-contents #cast .repair {
    margin-bottom: 40px;
  }
  #main-contents #cast .repair .article {
    margin: 0 auto 25px;
    padding: 4%;
  }
  #main-contents #cast .repair .article.patt-03 .pic .first {
    margin-right: 4px;
  }
  #main-contents #cast .repair .article .text {
    margin: 15px 0;
  }
  #main-contents #cast .pr {
    padding-bottom: 40px;
  }
}



@media all and (max-width: 568px) {
  /* cast */
  #main-contents #cast .center {
    width: 90%;
  }
  #main-contents #cast .archive {
    margin-bottom: 10vw;
  }
  #main-contents #cast .archive li a {
    font-size: 0.875em;
  }
  #main-contents #cast .inner {
    margin-bottom: 15px;
  }
  #main-contents #cast .inblock {
    padding: 6% 2.5% 1%;
  }
  #main-contents #cast .inblock .message {
    line-height: 1.4;
  }
  #main-contents #cast .inblock .message:before, #main-contents #cast .inblock .message:after {
    /*margin: 0;*/
  }
  #main-contents #cast .inblock .message br {
    display: block;
  }
  #main-contents #cast h4 {
    padding: 10px 5px;
  }
  #main-contents #cast h4 .name {
    font-size: 1em;
  }
  #main-contents #cast h4 .status {
    max-width: 130px;
    min-width: auto;
    width: 100%;
    margin: 6% auto 0;
    padding: 5px 0;
    border-radius: 15px;
    font-size: 0.7em;
  }
  #main-contents #cast .switch {
    padding: 0 10px;
  }
  #main-contents #cast .switch .comment {
    padding-top: 10px;
  }
  #main-contents #cast .switch .comment:after {
    margin-top: 7px;
  }
  #main-contents #cast .cast-mov .mov-trim {
    margin-bottom: 5px;
  }
  
  #main-contents #cast .repair .article.patt-03 .pic {
    display: block;
  }
  #main-contents #cast .repair .article.patt-03 .pic span {
    display: block;
  }
  #main-contents #cast .repair .article.patt-03 .pic .first {
    width: 100%;
    height: 50vw;
    margin: 0 auto 4px;
    overflow: hidden;
  }
  #main-contents #cast .repair .article.patt-03 .pic .first img {
    margin-top: -4vw;
  }
  #main-contents #cast .repair .article.patt-03 .pic .others {
    width: 100%;
  }
  #main-contents #cast .repair .article .text {
    font-size: 0.938em;
  }
}




























