@charset "UTF-8";
@import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP:400,700|Open+Sans:400,700&display=swap&subset=japanese");
@import url("https://fonts.googleapis.com/css2?family=Staatliches&display=swap");
/*size*/
/*color*/
/*sns*/
/* mixinCSS Document */
/*----------common----------*/
/*alt*/
/*hover*/
/*
 caster.css
*/
/* caster
========================================== */
.caster {
  position: relative;
  z-index: 10;
}
.caster_header {
  padding: 60px 0;
}
@media only screen and (max-width: 750px) {
  .caster_header {
    padding: 8% 0;
  }
}
.caster_title {
  background: url("/oha4/caster/images/title.png") no-repeat center center;
  background-size: contain;
  margin: auto;
  width: 517px;
  height: 45px;
  text-indent: -9999px;
  display: block;
  overflow: hidden;
}
@media only screen and (max-width: 750px) {
  .caster_title {
    padding-top: 6%;
    max-width: 517px;
    width: 68.93%;
    height: 0;
  }
}
.caster_article {
  margin: auto;
  padding: 0 20px 30px;
  max-width: 960px;
}
@media screen and (max-width: 992px) {
  .caster_article {
    padding: 0 3% 3%;
  }
}
.caster_card {
  padding-bottom: 30px;
}
@media only screen and (max-width: 750px) {
  .caster_card {
    padding-bottom: 4%;
  }
}
.caster_card:nth-child(3), .caster_card:nth-child(8) {
  margin-bottom: 40px;
}
.caster_card:nth-child(1)::before, .caster_card:nth-child(4)::before, .caster_card:nth-child(9)::before {
  content: "月曜日";
  display: block;
  margin: 0.5em 0 1em;
  border-bottom: 4px solid #ff738f;
  color: #ff738f;
  font-weight: 600;
  line-height: 2;
  font-size: 2.4rem;
}
.caster_card:nth-child(1)::before {
  content: "メインキャスター";
}
.caster_card:nth-child(4)::before {
  content: "曜日キャスター";
}
.caster_card:nth-child(9)::before {
  content: "キャスター";
}
@media only screen and (max-width: 750px) {
  .caster_card:nth-child(3), .caster_card:nth-child(8) {
    margin-bottom: 6%;
  }
  .caster_card:nth-child(1)::before, .caster_card:nth-child(4)::before, .caster_card:nth-child(9)::before {
    border-bottom: 2px solid #ff738f;
    font-size: 1.7rem;
  }
}

/* -----card----- */
.card {
  background-color: #fff;
  border-radius: 8px;
  -webkit-box-shadow: 0 2px 6px 0 rgba(0, 0, 0, 0.2);
  box-shadow: 0 2px 6px 0 rgba(0, 0, 0, 0.2);
}
.card_header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-flow: row wrap;
          flex-flow: row wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: relative;
  line-height: 0;
}
.card_photo {
  width: 300px;
  background: #ffd9e0;
  border-radius: 8px 0 0 8px;
}
.card_photo img {
  border-radius: 8px 0 0 8px;
  width: 100%;
}
.card_text {
  padding-top: 25px;
  width: calc(100% - 320px);
}
.card_segment {
  margin-bottom: 0.5em;
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.1em;
  line-height: 1.6em;
  color: #ff738f;
}
.card_name_ja {
  margin-right: 0.2em;
  font-size: 28px;
  font-weight: bold;
  color: #222;
  letter-spacing: 0.1em;
  line-height: 1.6em;
}
.card_name_en {
  display: block;
  margin-bottom: 0.5em;
  font-size: 16px;
  color: #222;
  letter-spacing: 0.1em;
  line-height: 1.6em;
}
.card_name_sup {
  display: block;
  font-size: 13px;
  color: #222;
  line-height: 1.6em;
}
.card_button {
  display: inline-block;
  width: 44px;
  height: 44px;
  cursor: pointer;
  position: absolute;
  right: 16px;
  bottom: 16px;
}
.card_button span {
  display: inline-block;
  -webkit-transition: all 0.6s;
  transition: all 0.6s;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: absolute;
  left: 0;
  width: 100%;
  height: 3px;
  background-color: #ff738f;
}
.card_button span:nth-of-type(1) {
  top: calc(50% - 1px);
}
.card_button span:nth-of-type(2) {
  top: calc(50% - 1px);
  -webkit-transform: rotate(-90deg);
  transform: rotate(-90deg);
  opacity: 1;
}
.card_button.-link span {
  width: 80%;
}
.card_button.-link span:nth-of-type(1) {
  top: 27%;
  -webkit-transform: rotate(30deg);
  transform: rotate(30deg);
}
.card_button.-link span:nth-of-type(2) {
  top: auto;
  bottom: 27%;
  -webkit-transform: rotate(-30deg);
  transform: rotate(-30deg);
  opacity: 1;
}
@media only screen and (min-width: 640px) {
  .card_button.-link:hover span:nth-of-type(1) {
    left: 10px;
    -webkit-transform: rotate(30deg);
    transform: rotate(30deg);
  }
  .card_button.-link:hover span:nth-of-type(2) {
    left: 10px;
    -webkit-transform: rotate(-30deg);
    transform: rotate(-30deg);
    opacity: 1;
  }
}

.card.-open .card_photo img {
  border-radius: 8px 0 0 0;
}
.card.-open .card_button span:nth-of-type(1) {
  -webkit-transform: rotate(360deg);
  transform: rotate(360deg);
}
.card.-open .card_button span:nth-of-type(2) {
  -webkit-transform: rotate(-270deg);
  transform: rotate(-270deg);
  opacity: 0;
}

@media screen and (max-width: 992px) {
  .card_text {
    padding-top: 15px;
  }
  .card_segment {
    margin-bottom: 0;
  }
  .card_name_ja {
    font-size: 20px;
    font-size: 3.125vw;
    letter-spacing: 0.04em;
  }
}
@media only screen and (max-width: 750px) {
  .card_photo {
    width: 33%;
    background: #ffd9e0;
    padding: 3% 0;
  }
  .card_photo img {
    width: 100%;
    height: auto;
    border-radius: 0;
  }
  .card_text {
    padding: 3% 0;
    width: 64%;
  }
  .card_text img {
    border-radius: 0;
  }
}
@media only screen and (max-width: 750px) and (max-width: 640px) {
  .card_segment {
    font-size: 16px;
    font-size: 2.5vw;
  }
  .card_name_ja {
    font-size: 24px;
    font-size: 3.75vw;
    letter-spacing: 0.04em;
    margin-right: 0;
  }
  .card_name_en {
    font-size: 10px;
    font-size: 1.5625vw;
  }
  .card_name_sup {
    font-size: 10px;
    font-size: 1.5625vw;
  }
  .card_button {
    padding-top: 5%;
    width: 5%;
    height: 0;
    right: 8px;
    bottom: 8px;
  }
}
/* -----profile----- */
.profile {
  margin: auto;
}
.profile_data {
  padding: 30px 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-flow: row wrap;
          flex-flow: row wrap;
}
.profile_data dl {
  padding-bottom: 0.5em;
}
.profile_data dl dt {
  padding: 0 1em;
  display: inline-block;
  border-radius: 30px;
  border: 1px solid #ff738f;
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.1em;
  line-height: 28px;
  color: #ff738f;
}
.profile_data dl dd {
  padding: 0 1.5em 0 0.2em;
  display: inline-block;
  font-size: 16px;
  line-height: 30px;
  color: #222;
}
.profile_faq {
  padding: 0 40px;
}
.profile_faq dl dt {
  padding-bottom: 0.5em;
  display: inline-block;
  border-bottom: 1px solid #ff738f;
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.1em;
  line-height: 1.6em;
  color: #ff738f;
}
.profile_faq dl dd {
  padding-top: 0.5em;
  padding-bottom: 2em;
  font-size: 16px;
  line-height: 1.6em;
  color: #222;
}
.profile_comment {
  padding: 20px;
}
.profile_comment dl {
  background-color: #fffdcc;
  padding: 20px;
  border-radius: 10px;
}
.profile_comment dl dt {
  padding-bottom: 0.5em;
  text-align: center;
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.1em;
  line-height: 1.6em;
  color: #ff738f;
}
.profile_comment dl dd {
  font-size: 16px;
  line-height: 1.6em;
  color: #222;
}

@media only screen and (max-width: 750px) {
  .profile_data {
    padding: 4% 5%;
  }
}
@media only screen and (max-width: 750px) and (max-width: 640px) {
  .profile_data dl dt {
    font-size: 16px;
    font-size: 2.5vw;
    line-height: 2em;
    border-radius: 1em;
  }
  .profile_data dl dd {
    font-size: 16px;
    font-size: 2.5vw;
    line-height: 2.05em;
  }
}
@media only screen and (max-width: 750px) {
  .profile_faq {
    padding: 0 5%;
  }
}
@media only screen and (max-width: 750px) and (max-width: 640px) {
  .profile_faq dl dt {
    font-size: 16px;
    font-size: 2.5vw;
    line-height: 2em;
  }
  .profile_faq dl dd {
    font-size: 16px;
    font-size: 2.5vw;
  }
}
@media only screen and (max-width: 750px) {
  .profile_comment {
    padding: 3%;
  }
  .profile_comment dl {
    padding: 3%;
  }
}
@media only screen and (max-width: 750px) and (max-width: 640px) {
  .profile_comment dl dt {
    font-size: 16px;
    font-size: 2.5vw;
  }
  .profile_comment dl dd {
    font-size: 16px;
    font-size: 2.5vw;
  }
}
.oha4_main {
  position: relative;
  overflow: hidden;
}

/* -----bg_sorajiro----- */
.bg_sorajiro {
  max-width: 800px;
  width: 100%;
  height: auto;
  position: absolute;
  z-index: 0;
  opacity: 0.3;
}
.bg_sorajiro.-bg1 {
  top: 2%;
  right: 60%;
  -webkit-transform: rotate(20deg);
          transform: rotate(20deg);
}
.bg_sorajiro.-bg2 {
  bottom: 20%;
  left: 56%;
  -webkit-transform: rotate(30deg);
          transform: rotate(30deg);
}