@charset "utf-8";
/* CSS INFORMATION -====================================================
File name : top.css
Description : TOPページCSS
===================================================================== */

/* =====================================================================
*    header
* =================================================================== */
.mv {
    background: url(../images/bg_red.png) repeat center center;
    background-size: calc(286 / 750 * 100%) auto;
}

.mv_box {
    position: relative;
}

.site_ttl {
    width: calc(760 / 750 * 100%);
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 2;
    margin: calc(900 / 750 * 100%) auto calc(0 / 750 * 100%) calc(0 / 750 * 100%);
}

.mv_onair {
	width: calc(750 / 750 * 100%);
    background-color: #c4b883;
    padding: calc(32 / 750 * 100%) calc(44 / 750 * 100%);
    z-index: 100;
}

.official_link {
    position: absolute;
    width: calc(683 / 750 * 100%);
    bottom: 0;
    right: 0;
    margin: 0 calc(30 / 750 * 100%) calc(30 / 750 * 100%) 0;
}

@media screen and (min-width:700px){
    .mv {
        background-size: calc(143 / 1040 * 100%) auto;
    }

    .mv_box {
    }
    .mv_img{
        width: calc(1500 / 1600 * 100%);
    }

    .site_ttl {
        width: calc(520 / 750 * 100%);
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        z-index: 2;
        margin: calc(815 / 750 * 100%) 0 0 calc(-8 / 750 * 100%);
    }

    .mv_onair {
        width: 100%;
        background-color: #c4b883;
        z-index: 1;
        padding: 0 calc(200 / 740 * 100%) calc(-50 / 740 * 100%) calc(10 / 740 * 100%);
    }

    .official_link {
        position: absolute;
        z-index: 100;
        bottom: 0;
        right: 0;
        width: calc(166 / 740 * 100%);
        margin: 0 calc(10 / 740 * 100%) calc(-40 / 740 * 100%) calc(300 / 740 * 100%);
              }

      .official_link a {
        width: 100%;
        padding-top: 100%;
        margin: 0;
        background: url(../images/btn_official.png) no-repeat center;
        background-size: contain;

      }
      .official_link a:hover {
        background: url(../images/btn_official_h.png) no-repeat center;
        background-size: contain;
      }

}

@media screen and (min-width:1040px){
    .mv {
        background-size: 300px auto;
    }
    .mv_onair {
        width: 100%;
        background-color: #c4b883;
        z-index: 1;
        padding: 0 calc(100 / 740 * 100%) calc(-50 / 740 * 100%) calc(120 / 740 * 100%);
    }
}


/* =====================================================================
*    intro
* =================================================================== */
.intro {
    padding: calc(70 / 750 * 100%) 0 calc(120 / 750 * 100%);
}

.intro_box {
   padding: 0 calc(40 / 750 * 100%);
}

.intro::before {
    content: "";
    display: block;
    width: 100%;
    padding-top: calc(375 / 750 * 100%);
    background: url(../images/bg_mark_bottom.png) no-repeat center bottom;
    background-size: contain;
    position: absolute;
    bottom: 0;
    right: 0;
    margin: 0 calc(-200 / 750 * 100%) calc(-200 / 750 * 100%) 0;
}
.intro::after {
    content: "";
    display: block;
    width: 100%;
    padding-top: calc(375 / 750 * 100%);
    background: url(../images/bg_mark_top.png) no-repeat left bottom;
    background-size: contain;
    position: absolute;
    top: 0;
    left: 0;
    margin: calc(-120 / 750 * 100%) 0 0 calc(-118 / 750 * 100%);
}

@media screen and (min-width:700px){
    .intro {
        padding: calc(135 / 1040 * 100%) 0 0;
        background-size: calc(256 / 1040 * 100%) auto;
    }

    .intro_box {
        margin: calc(70 / 750 * 100%) auto 0;
        width: 100%;
    }

    .intro_box::before {
        padding-top: calc(89 / 710 * 100%);
    }
    .intro::before {
        padding-top: calc(150 / 750 * 100%);
        margin: 0 calc(-180 / 750 * 100%) calc(-60 / 750 * 100%) 0;
    }
    .intro::after {
        padding-top: calc(276 / 750 * 100%);
        margin: calc(-121 / 750 * 100%) 0 0 calc(-22 / 750 * 100%);
    }
}

@media screen and (min-width:1040px){
    .intro {
        padding: calc(30 / 750 * 100%) 0;
    }
}
/* =====================================================================
*    bg
* =================================================================== */
.bg{
    background: url(../images/bg_white.jpg) repeat center center;
    background-size: calc(160 / 750 * 100%) auto;

}
@media screen and (min-width:1040px){
    .bg {
    background: url(../images/bg_white.jpg) repeat center center;
    background-size: calc(85 / 750 * 100%) auto;
}
}
/* =====================================================================
*    staff
* =================================================================== */
.staff {
   padding: calc(100 / 750 * 100%) 0;
     /* background: url(../images/bg_white.jpg) repeat center center;
    background-size: calc(286 / 750 * 100%) auto; */

}
.staff_box {
    /* background-image: url(../images/bg_frame_top.jpg), url(../images/bg_frame_bottom.jpg), url(../images/bg_frame_middle.jpg);
    background-repeat: no-repeat, no-repeat, repeat-y;
    background-position: top, bottom, center;
    background-size: contain; */
    width: 90%;
    margin: 0 auto;
  }


.staff_list {
    text-align: center;
}

.staff_list dt {
    color: #f4efe9;
    font-size: 2.8rem;
    line-height: 1.428;
    letter-spacing: 0.05em;
}

.staff_list dt:not(:first-of-type) {
    margin: 2em 0 0;
}

.staff_list dt::after {
    content: "・・・";
    display: block;
    padding: 0 0 0 0.2em;
    letter-spacing: 0.2em;
}

.staff_list dd {
    color: #ffca3f;
    font-size: 3.6rem;
    font-weight: 700;
    line-height: 1.15;
    letter-spacing: 0.05em;
}

.staff_list dd.staff_txt1 {
    margin: 1em 0 0;
    font-size: 2.8rem;
    line-height: 1.727;
}

.staff_list dd.staff_txt2 {
    font-size: 2.2rem;
    font-weight: 400;
}

.staff_list dd.color_w {
    color: #f4efe9;
}

.none{
    display: none;
}
@media screen and (min-width:700px){
    .staff {
        padding: calc(80 / 1040 * 100%) 0 calc(90 / 1040 * 100%);
        background-size: calc(143 / 1040 * 100%) auto;
    }

    .staff_list dt {
        font-size: 2.1rem;
    }

    .staff_list dd {
        font-size: 2.7rem;
    }

    .staff_list dd.staff_txt1 {
        font-size: 2.1rem;
    }

    .staff_list dd.staff_txt2 {
        font-size: 1.65rem;
    }
}

@media screen and (min-width:1040px){
    .staff {
        padding: 80px 0 90px;
        background-size: 143px auto;
    }
}


/* =====================================================================
*    cast
* =================================================================== */
.cast {
    padding: calc(0 / 750 * 100%) 0 calc(230 / 750 * 100%);
    /* background: url(../images/bg_white.jpg) repeat center center;
    background-size: calc(165 / 750 * 100%) auto; */
}
.cast_box {
    /* background-image: url(../images/bg_frame_top.jpg), url(../images/bg_frame_bottom.jpg), url(../images/bg_frame_middle.jpg);
    background-repeat: no-repeat, no-repeat, repeat-y;
    background-position: top, bottom, center;
    background-size: contain; */
    width: 90%;
    margin: 0 auto;
  }

.cast .staff_list dt {
    color: #3a2e25;
}

.cast .staff_list dd {
    color: #bc3e40;
}

@media screen and (min-width:700px){
    .cast {
        padding: calc(80 / 1040 * 100%) 0 calc(220 / 1040 * 100%);
        background-size: calc(256 / 1040 * 100%) auto;
    }
}

@media screen and (min-width:1040px){
    .cast {
        padding: 80px 0 220px;
        background-size: 256px auto;
    }
}
