@charset "UTF-8";
/* ----------------------------------------------
body
---------------------------------------------- */
body {
  font-size: 14px;
  font-family: "ヒラギノ丸ゴ Pro W4","ヒラギノ丸ゴ Pro","Hiragino Maru Gothic Pro","Hiragino Kaku Gothic ProN", "游ゴシック", YuGothic, Meiryo, sans-serif;
  line-height: 1.5em;
  color: #333333;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  word-wrap: break-word;
  overflow-x: hidden;
}

html {
  overflow-x: hidden;
}

a {
  text-decoration: none;
  color: #222;
}

a:hover {
  text-decoration: underline;
}

img {
  vertical-align: bottom;
}

.a-center{
  text-align: center;
}

.orange{
  color: #ff9600;
}

.mt-20{
  margin-top: 20px;
}

/* ********************
scroll
******************** */
.cast-popup,
.goods-popup,
.event-popup{
  overflow-y: auto;
  height: 100vh;
}

.cast-popup::-webkit-scrollbar,
.goods-popup::-webkit-scrollbar,
.event-popup::-webkit-scrollbar{
  width: 5px;
  background: #ccc;
}

.cast-popup::-webkit-scrollbar-thumb,
.goods-popup::-webkit-scrollbar-thumb,
.event-popup::-webkit-scrollbar-thumb{
  background: #777;
  border-radius: 2px;
}

/* ********************
cast-popup
******************** */
.cast-popup {
  text-align: center;
  position: relative;
  padding: 30px;
  overflow-x: hidden;
}

.cast-popup__photoWrapper{
  position: relative;
}

.cast-popup__photo {
  position: relative;
}

.cast-popup__photo img {
  max-width: 100%;
}

.cast-popup__link {
  padding: 0;
  text-align: center;
  width: 336px;
  position: relative;
  margin: -60px auto 0 auto;
  }


.cast-popup__name {
  margin-bottom: 15px;
  font-weight: bold;
  font-size: 20px;
  text-align: center;
  border-bottom: 2px dotted #c8c8c8;
  padding: 15px;
}

.sns li {
  width: 52px;
  height: 52px;
  display: block;
  text-indent: -10000px;
  line-height: 0;
  float: left;
  margin: 2px;
}

.sns li a {
  width: 52px;
  height: 52px;
  display: block;
}

.sns li.is_non {
  opacity: 0.3;
}
.sns li.is_non a {
  display: none;
}

.link--twitter {
  background-image: url(../img/cast_twitter.png);
}

.link--hp {
  background-image: url(../img/cast_hp.png);
}

.link--comm {
  background-image: url(../img/cast_com.png);
}

.link--jiten {
  background-image: url(../img/cast_jiten.png);
}

.link--mylist {
  background-image: url(../img/cast_mylist.png);
}

.link--blog {
  background-image: url(../img/cast_blog.png);
}

.cast-popup__place {
  text-align: center;
}
.cast-popup__place li {
  display: inline-block;
  border-radius: 3px;
  margin: 3px;
}
.cast-popup__place li a,
.cast-popup__place li span {
  width: 60px;
  color: #fff;
  text-decoration: none;
  line-height: 25px;
  height: 25px;
  text-align: center;
  display: inline-block;
}


.cast-popup__schedule{
  max-width: 506px;
  margin: 10px auto 0 auto;
}

.schedule{
  margin: 10px 0;
}


.schedule.is_open .schedule-detail{
  animation: show .5s linear 0s;
  display: block;
}

.schedule-title{
  color: #fff;
  border-radius: 2px;
  padding: 2px 10px;
  text-align: left;
  position: relative;
  cursor: pointer;
}

.schedule-title:after{
  position: absolute;
  content:'▼';
  right: 10px;
}

.schedule.is_open .schedule-title:after{
  display: none;
}

.schedule-detail{
  background:#f8f8f8;
  padding: 10px;
  text-align:left;
}

@keyframes show{
    from{
        opacity: 0;
    }
    to{
        opacity: 1;
    }
}

 .shiga {
  background: #003c97;
}
 .oita {
  background: #3f699f;
}
 .tokushima {
  background: #00a6c9;
}
 .miyagi {
  background: #0085d1;
}
 .niigata {
  background: #4faa3c;
}
 .okayama {
  background: #d53664;
}

 .toyama {
  background: #4faa3c;
}

 .hokkaido {
  background: #eb5d00;
}
 .aichi {
  background: #fb3e35;
}
 .osaka {
  background: #573575;
}
 .all {
  background: #ff3060;
}

  .schedule-detail a{
    text-decoration: underline;
  }

  .play{
    display: inline-block;
    background:#222;
    padding: 3px 5px;
    color: #fff;
    font-size: 10px;
    line-height: 1em;
    margin: 0 5px;
    border-radius: 2px;
  }

.play:before{
  content:'生放送▶';
}


.schedule-caution{
margin-top:10px;
padding-top: 5px;
border-top:1px solid #ccc;
font-size: 12px;
}

.schedule-detail li{
margin:5px 0;
}

.schedule-detail .date{
display:inline-block;
width:8em;
}

.schedule-detail{
  display: none;
}




@media screen and (max-width: 420px) {
  .cast-popup {
    padding: 10px;
  }

  .cast-popup__name {
    margin-bottom: 5px;
    font-size: 16px;
    padding: 15px;
  }

  .cast-popup__link {
    width: 180px;
    margin: -35px auto 0 auto;
  }

  .cast-popup__name {
    margin-bottom: 5px;
    font-size: 18px;
    padding: 10px;
  }

  .sns li {
    width: 28px;
    height: 28px;
    display: block;
    text-indent: -10000px;
    line-height: 0;
    margin: 1px;
    background-size: 100% 100%;
  }

  .sns li a {
    width: 28px;
    height: 28px;
    display: block;
  }

  .cast-popup__place {
  }
  .cast-popup__place li {
    display: inline-block;
    border-radius: 2px;
    margin: 2px;
    line-height: 1;
  }
  .cast-popup__place li a,
  .cast-popup__place li span {
    width: 65px;
    color: #fff;
    text-decoration: none;
    font-size: 10px;
    line-height: 13px;
    height: 13px;
    text-align: center;
    display: inline-block;
  }

  .schedule{
    margin: 10px 0;
    font-size: 11px;
  }

  .schedule-title{
    padding: 2px 5px;
  }

  .schedule-detail{
    padding: 5px;
  }

  .play{
    display: inline-block;
    background:#222;
    padding: 2px;
    color: #fff;
    font-size: 8px;
    line-height: 1em;
    margin: 0 2px;
    border-radius: 2px;
  }

  .play:before{
    content:'生';
  }

  .schedule-caution{
    font-size: 10px;
    line-height: 1.1em;
  }

}

/* ********************
goods-popup
******************** */
.goods-popup {
  position: relative;
  padding: 10px 25px;
  overflow-x: hidden;
}

.goods-popup__photo {
  text-align: center;
}

.goods-popup__photo img {
  max-width: 100%;
}

.goods-popup__name {
  border-bottom: 2px dotted #5ad5e2;
  padding: 15px 10px;
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 20px;
  text-align: center;
}

.goods-popup__text {
  margin: 10px 0;
}

.goods-popup__price {
  margin: 10px 0;
  font-weight: bold;
}

@media screen and (max-width: 420px) {
  .goods-popup {
    position: relative;
    padding: 10px;
  }

  .goods-popup__name {
    border-bottom: 2px dotted #5ad5e2;
    padding: 10px 5px;
    font-size: 14px;
    font-weight: bold;
    margin-bottom: 15px;
    text-align: center;
  }
}
/* ********************
event-popup
******************** */
.event-popup {
  position: relative;
  overflow-x: hidden;
}
.event-popup a {
  color: #ff557d;
  text-decoration: underline;
}

.event-popup__name {
  background: #ff8cbe;
  padding: 30px;
  font-size: 20px;
  color: #fff;
  font-weight: bold;
  margin-bottom: 30px;
  text-align: left;
}

.event-popup__photo {
  text-align: center;
  margin: 30px;
}

.event-popup__photo img {
  max-width: 100%;
}

.event-popup__photo ul.photo--1{
  text-align: center;
}

.event-popup__photo ul.photo--1 li{
  width: 100%;
  margin:5px auto;
  float: none;
}

	.event-popup__photo ul.photo--2{
	  margin:0 -1%;
	}
	.event-popup__photo ul li{
	  width: 49%;
	  margin:.5%;
  float: left;
	}


.event-popup__text {
  margin: 30px;
  font-size: 16px;
}
.event-popup__text em {
  color: #ff557d;
}

.event-popup__text .place{
	display:none;
}

.event-popup__text .place.is_open{
	display:block;
}

.event-popup__text .title {
  font-weight: bold;
  border-bottom: 1px dashed #ccc;
  padding: 5px;
  margin-bottom: 10px;
  color: #ff9600;
}
.event-popup__text p {
  margin-bottom: 10px;
}

.userkisha{
  padding: 10px;
  margin: 15px 0;
  border:1px dashed #00a6c9;
}



.userkisha .photo{
  text-align: left;
  width: 38%;
  float: left;
}

.userkisha .photo img{
	max-width: 100%;
}

.userkisha .text{
  text-align: left;
  width: 58%;
  float: right;
}

.userkisha .link{
	font-size: .8em;
}
.userkisha .link a{
	color: #000;
}


.userkisha .text .name{
   color: #fff;
   background:#ff9600;
   border-radius: 0 10px 10px 0;
   margin-bottom:10px;
   padding: 2px 10px;
}
.userkisha .article{
  text-align: left;
  width: 58%;
  float: right;
  margin-top: 20px;
}
/*
.userkisha .article{
  margin-top: 15px;
  border-top:1px dashed #ccc;
  padding-top: 15px;

}*/

.userkisha .article-title{
  font-weight: bold;
  border-bottom: 1px dashed #ccc;
  padding: 5px;
  margin-bottom: 10px;
}

.article-list li{
  margin: 5px 0;
}




@media screen and (max-width: 420px) {
  .event-popup__name {
    padding: 10px;
    font-size: 16px;
    margin-bottom: 10px;
    text-align: center;
  }

  .event-popup__photo {
    margin: 15px;
  }

  .event-popup__text {
    margin: 15px;
    font-size: 13px;
  }

	.event-popup__photo ul.photo--2{
	  margin:0 -1%;
	}
	.event-popup__photo ul li{
	  width: 49%;
	  margin:.5%;
	}
.event-popup__photo ul.photo--1 li{
}


	.userkisha .article{
	  margin-top: 15px;
	  padding-top: 15px;
	  float: none;
	  width: 100%;
	  clear: both;
	}

}


/* ********************
common
******************** */

.linkbutton{
  background:#ff557d;
  border-radius: 2px;
  color: #fff !important;
  padding: 3px 10px;
  text-decoration: none !important;
  margin: 5px 0;
  display: inline-block;
}

.linkbutton:hover{
  background:#ff9600;
}

.margin-tb20{
  margin:20px 0;
}

.arrow-white5 {
  position: relative;
  display: inline-block;
}

.arrow-white5:before {
  content: '';
  display: inline-block;
  border: 5px solid transparent;
  border-left-color: #fff;
  position: relative;
  top: 0px;
}

.arrow-black5 {
  position: relative;
  display: inline-block;
}

.arrow-black5:before {
  content: '';
  display: inline-block;
  border: 5px solid transparent;
  border-left-color: #000;
  position: relative;
  top: 0px;
}


.t12{font-size: 12px;}

.box-yellow{
  border:1px dashed #00a6c9;
  padding: 10px;
  background:#fffee5;
  margin: 15px 0;
}

.box-yellow-title{
  color: #00a6c9;
  font-weight: bold;
  margin-bottom:5px;
}

.is_none{
display:none;
}
