@charset "UTF-8";

@media print, screen and (min-width: 46.9375em) {
  body {
    min-width: 1360px !important;
  }
}

body {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  color: #222222;
  word-wrap: break-word;
  background-image: url(../img/sorapo_left.gif), url(../img/sorapo_right.gif), url("../img/bg.png");
  background-repeat: no-repeat, no-repeat, repeat;
  background-size: 20%, 20%, 5%;
  background-position: left 1% bottom 3%, right 1% bottom 3%, center;
  background-attachment: fixed, fixed, fixed;
}

/* header{
    background-color: #0074bd;
    width: 100%;
    height: 32px;
    padding: 8px 0 0 0;
    text-align: center;
}

footer{
    background-color: #0074bd;
    color: #FFF;
	font-size:12px;
	text-align:center;
    padding: 1.5vh;
}
 */

footer a,
header a {
  text-decoration: none;
}

img {
  flex-shrink: 0; /*IE画像 flexで変倍*/
  image-rendering: -webkit-optimize-contrast; /*Chromeの画像ボケ*/
}

#Wrap {
  max-width: 1080px;
  margin: auto;
  padding: 5vh;
  overflow: hidden;
}

#Wrap img {
  width: 100%;
  height: auto;
  display: block;
}

h1 {
  margin-bottom: 2vw;
}

h2 {
  text-align: center;
  font-weight: bold;
  font-size: 180%;
  margin-bottom: 3vh;
}

.small {
  font-size: 90% !important;
}

/* PCで改行する位置 */
.pc_only {
  display: block;
}

.sp_only {
  display: none;
}

@media screen and (max-width: 1400px) {
  body {
    background-image: none, none, url(../img/bg.png);
    background-repeat: repeat;
    background-size: 10%;
    background-attachment: scroll;
  }
}

@media screen and (max-width: 1024px) {
  #Wrap {
    padding: 3vh;
  }
}

@media screen and (max-width: 600px) {
  body {
    background-size: 18%;
  }
  #Wrap {
    padding: 3vh 2vh;
  }

  h1 {
    margin-bottom: 3vh;
  }

  h2 {
    font-size: 140%;
    margin-bottom: 3vh;
  }

  .pc_only {
    display: none;
  }

  .sp_only {
    display: block;
  }
}

/*================================================
 *  おすすめ番組
 ================================================*/
#Swiper {
  margin-top: 5vh;
}

#OAB {
  margin: 5vh 0 2vh;
  verflow: hidden;
}

#OAB #OAB_Inner {
  display: flex;
  flex-wrap: wrap;
  margin-right: -4%;
}

#OAB #OAB_Inner div {
  background-color: #ffffff;
  width: 46%;
  margin: 0 4% 6% 0;
  box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.2);
  -webkit-box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.2);
}

#OAB #OAB_Inner div dl {
  padding: 4%;
}

#OAB #OAB_Inner div dt {
  font-weight: bold;
  text-align: center;
  color: #ffffff;
  padding: 3% 6%;
  display: table;
  background-color: #fc8523;
}

#OAB #OAB_Inner div dd {
  font-size: 100%;
  line-height: 160%;
  margin-top: 3%;
}

#OAB #OAB_Inner div dd.name {
  font-size: 130%;
  font-weight: bold;
  line-height: 150%;
  border-bottom: 3px solid #222;
  padding-bottom: 2%;
}

#OAB #OAB_Inner div dd.name a,
#OAB #OAB_Inner div dd.name a:visited {
  color: #222222;
}

#OAB #OAB_Inner div dd.name a:hover {
  color: #0068b7;
}

@media screen and (max-width: 1024px) {
  #OAB #OAB_Inner div dl {
    padding: 5%;
  }

  #OAB #OAB_Inner div dd.name {
    font-size: 120%;
  }
}

@media screen and (max-width: 600px) {
  #OAB #OAB_Inner {
    margin-right: 0;
  }

  #OAB #OAB_Inner div {
    width: 100%;
    margin: 0 0 8% 0;
  }
}

/*================================================
 *  Program
 ================================================*/
#Program .accordion label {
  display: block;
  cursor: pointer;
  color: #fff;
  background-color: #222;
  font-size: 110%;
  font-weight: bold;
  padding: 1.5% 2%;
  margin-bottom: 1%;
}

#Program .accordion label:hover {
  background-color: #444;
}

#Program .accordion input {
  display: none;
}

#Program .accordion .details {
  transition: 0.2s;
  height: 0;
  overflow: hidden;
}

#Program .accordion input:checked + .details {
  height: auto;
  padding: 1% 0;
}

#Program .details p {
  font-size: 110%;
  font-weight: bold;
  margin-bottom: 1vh;
  position: relative;
  padding: 1.5% 3%;
  background: #27ae60;
  color: #fff;
  width: 180px;
  text-align: center;
}

#Program .details p:after {
  position: absolute;
  content: "";
  top: 100%;
  left: 30px;
  border: 10px solid transparent;
  border-top: 15px solid #27ae60;
  width: 0;
  height: 0;
}

#Program .details p.sat {
  background-color: #3498db;
}

#Program .details p.sat:after {
  border-top: 15px solid #3498db;
}

#Program .details p.sun {
  background-color: #e74c3c;
}

#Program .details p.sun:after {
  border-top: 15px solid #e74c3c;
}

#Program table {
  width: 100%;
  margin: 0 0 3%;
  line-height: 130%;
}

#Program table a:hover {
  color: #ff7c20 !important;
}

#Program table a,
#Program table a:visited {
  color: #222222;
}

#Program table th,
#Program table td {
  padding: 2%;
  border: 1px solid #c8c8c8;
  box-sizing: border-box;
  -webkit-box-sizing: border-box;
  line-height: 1.6;
}

#Program table th {
  background: #ebebeb;
  width: 18%;
  text-align: center;
  vertical-align: middle;
  font-weight: bold;
}

#Program table td {
  background-color: #ffffff;
}

@media screen and (max-width: 1024px) {
  #Program table th {
    width: 25%;
  }
}

@media only screen and (max-width: 600px) {
  #Program .accordion label {
    padding: 4%;
    margin-bottom: 2%;
  }

  #Program .details p {
    padding: 4%;
    width: 60%;
  }

  #Program table {
    margin: 0 0 8%;
  }

  #Program table th {
    width: 100%;
  }

  #Program table th,
  #Program table td {
    display: block;
    padding: 3.5% 4%;
    border-top: none;
  }

  #Program table tr:first-child th {
    border-top: 1px solid #ddd;
  }
}

/*================================================
 *  Page-top
 ================================================*/
#Page-top {
  position: fixed;
  bottom: 15px;
  right: 15px;
  z-index: 100;
}

#Page-top a {
  display: block;
  text-decoration: none;
}

#Page-top img {
  background: #000;
}

#Page-top img:hover {
  background: #333;
}
