@charset "utf-8";

/* CSS INFORMATION -====================================================
File name : index.css
Description :
===================================================================== */

/* =====================================================================
*    mv
* =================================================================== */
#wrapper {
    padding-top: 0;
}

.mv {
}

.mv_category {
    width: calc(318 / 750 * 100%);
    margin: calc(552 / 750 * 100%) auto 0;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 2;
}

.mv_ttl {
    width: calc(636 / 750 * 100%);
    margin: calc(586 / 750 * 100%) auto 0;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 2;
}

.mv_date {
    width: calc(616 / 750 * 100%);
    margin: calc(665 / 750 * 100%) auto 0;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 2;
}

.mv_photo {
}

.mv_ani {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
}

.mv_ani li {
    position: absolute;
    top: 0;
    left: 0;
}

.mv_ani li::before, .mv_ani li::after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background: url(../images/index/img_mv_tv.png) repeat left top;
    position: absolute;
    top: 0;
    left: 0;
}

.mv_ani li::after {
    background: none;
    -webkit-box-shadow: 0 0 4vw 1px rgba(255,255,255,1);
    box-shadow: 0 0 4vw 1px rgba(255,255,255,1);
    opacity: 0;
}

.mv_ani_01 {
    width: calc(198 / 750 * 100%);
    padding-top: calc(150 / 750 * 100%);
    margin: calc(125 / 750 * 100%) 0 0 calc(280 / 750 * 100%);
}

.mv_ani_start .mv_ani_01::before {
    -webkit-animation: mv_anime 0.5s linear 0s forwards;
    animation: mv_anime 1s cubic-bezier(.54,.05,.86,.19) 0s forwards;
}

.mv_ani_start .mv_ani_01::after {
    -webkit-animation: mv_anime2 0.5s linear 0s both;
    animation: mv_anime2 1s cubic-bezier(.54,.05,.86,.19) 0s both;
}

.mv_ani_02 {
    width: calc(151 / 750 * 100%);
    padding-top: calc(102 / 750 * 100%);
    margin: calc(135 / 750 * 100%) 0 0 calc(481 / 750 * 100%);
}

.mv_ani_start .mv_ani_02::before {
    -webkit-animation: mv_anime 0.2s linear 1.8s forwards;
    animation: mv_anime 0.2s linear 1.8s forwards;
}

.mv_ani_start .mv_ani_02::after {
    -webkit-animation: mv_anime2 0.2s linear 1.8s both;
    animation: mv_anime2 0.2s linear 1.8s both;
}

.mv_ani_03 {
    width: calc(151 / 750 * 100%);
    padding-top: calc(102 / 750 * 100%);
    margin: calc(139 / 750 * 100%) 0 0 calc(127 / 750 * 100%);
}

.mv_ani_start .mv_ani_03::before {
    -webkit-animation: mv_anime 0.3s linear 1s forwards;
    animation: mv_anime 0.3s linear 1s forwards;
}

.mv_ani_start .mv_ani_03::after {
    -webkit-animation: mv_anime2 0.3s linear 1s both;
    animation: mv_anime2 0.3s linear 1s both;
}

.mv_ani_04 {
    width: calc(106 / 750 * 100%);
    padding-top: calc(72 / 750 * 100%);
    margin: calc(147 / 750 * 100%) 0 0 calc(636 / 750 * 100%);
}

.mv_ani_start .mv_ani_04::before {
    -webkit-animation: mv_anime 0.2s linear 1.3s forwards;
    animation: mv_anime 0.2s linear 1.3s forwards;
}

.mv_ani_start .mv_ani_04::after {
    -webkit-animation: mv_anime2 0.2s linear 1.3s both;
    animation: mv_anime2 0.2s linear 1.3s both;
}

.mv_ani_05 {
    width: calc(106 / 750 * 100%);
    padding-top: calc(72 / 750 * 100%);
    margin: calc(149 / 750 * 100%) 0 0 calc(8 / 750 * 100%);
}

.mv_ani_start .mv_ani_05::before {
    -webkit-animation: mv_anime 0.2s linear 1.5s forwards;
    animation: mv_anime 0.2s linear 1.5s forwards;
}

.mv_ani_start .mv_ani_05::after {
    -webkit-animation: mv_anime2 0.2s linear 1.5s both;
    animation: mv_anime2 0.2s linear 1.5s both;
}

.mv_ani_06 {
    width: calc(84 / 750 * 100%);
    padding-top: calc(56 / 750 * 100%);
    margin: calc(226 / 750 * 100%) 0 0 calc(641 / 750 * 100%);
}

.mv_ani_start .mv_ani_06::before {
    -webkit-animation: mv_anime 0.2s linear 2s forwards;
    animation: mv_anime 0.2s linear 2s forwards;
}

.mv_ani_start .mv_ani_06::after {
    -webkit-animation: mv_anime2 0.2s linear 2s both;
    animation: mv_anime2 0.2s linear 2s both;
}

.mv_ani_07 {
    width: calc(84 / 750 * 100%);
    padding-top: calc(56 / 750 * 100%);
    margin: calc(228 / 750 * 100%) 0 0 calc(38 / 750 * 100%);
}

.mv_ani_start .mv_ani_07::before {
    -webkit-animation: mv_anime 0.2s linear 1.9s forwards;
    animation: mv_anime 0.2s linear 1.9s forwards;
}

.mv_ani_start .mv_ani_07::after {
    -webkit-animation: mv_anime2 0.2s linear 1.9s both;
    animation: mv_anime2 0.2s linear 1.9s both;
}

@-webkit-keyframes mv_anime {
    0% {
        opacity: 1;
    }

    100% {
        opacity: 0;
    }
}

@keyframes mv_anime {
    0% {
        opacity: 1;
    }

    100% {
        opacity: 0;
    }
}

@-webkit-keyframes mv_anime2 {
    0% {
        opacity: 0;
    }
    
    70% {
        opacity: 1;
    }

    100% {
        opacity: 0;
    }
}

@keyframes mv_anime2 {
    0% {
        opacity: 0;
    }
    
    70% {
        opacity: 1;
    }

    100% {
        opacity: 0;
    }
}

.header {
    position: relative;
}

.fixed.header {
    position: relative;
}

.header_nav {
    z-index: 100;
}

.fixed .header_nav {
    position: fixed;
    top: 0;
    width: 100%;
}

.menu_btn::before {
    display: none;
}

@media screen and (min-width: 768px) {
    .mv {
        background: url(../images/index/bg_mv_pc.png) no-repeat center bottom, url(../images/index/bg_mv_pc2.png) repeat-x left top;
        background-size: calc(2000 / 1100 * 100%) auto, auto 100%;
    }
    
    .mv_category {
        width: calc(318 / 1100 * 100%);
        margin: calc(421 / 1100 * 100%) auto 0;
    }
    
    .mv_ttl {
        width: calc(636 / 1100 * 100%);
        margin: calc(458 / 1100 * 100%) auto 0;
    }
    
    .mv_date {
        width: calc(616 / 1100 * 100%);
        margin: calc(539 / 1100 * 100%) auto 0;
    }
    
    .mv_photo {
        width: calc(1000 / 1100 * 100%);
        margin: 0 auto;
        -webkit-box-shadow: 0 0 2.73vw 0.64vw rgba(59,47,23,0.3);
        box-shadow: 0 0 2.73vw 0.64vw rgba(59,47,23,0.3);
    }
    
    .mv_ani_01 {
        margin: calc(92 / 1000 * 100%) 0 0 calc(375 / 1000 * 100%);
    }
    
    .mv_ani_02 {
        margin: calc(105 / 1000 * 100%) 0 0 calc(644 / 1000 * 100%);
    }
    
    .mv_ani_03 {
        margin: calc(110 / 1000 * 100%) 0 0 calc(169 / 1000 * 100%);
    }
    
    .mv_ani_04 {
        margin: calc(121 / 1000 * 100%) 0 0 calc(853 / 1000 * 100%);
    }
    
    .mv_ani_05 {
        margin: calc(124 / 1000 * 100%) 0 0 calc(11 / 1000 * 100%);
    }
    
    .mv_ani_06 {
        margin: calc(227 / 1000 * 100%) 0 0 calc(859 / 1000 * 100%);
    }
    
    .mv_ani_07 {
        margin: calc(229 / 1000 * 100%) 0 0 calc(50 / 1000 * 100%);
    }
    
    .mv_ani li::after {
        -webkit-box-shadow: 0 0 2.73vw 1px rgba(255,255,255,1);
        box-shadow: 0 0 2.73vw 1px rgba(255,255,255,1);
    }
    
    .fixed .header_nav {
        position: relative;
    }
}

@media screen and (min-width: 1100px) {
    .mv {
        background-size: 2000px auto, auto 100%;
    }
    
    .mv_photo {
        -webkit-box-shadow: 0 0 30px 7px rgba(59,47,23,0.3);
        box-shadow: 0 0 30px 7px rgba(59,47,23,0.3);
    }
    
    .mv_ani li::after {
        -webkit-box-shadow: 0 0 30px 1px rgba(255,255,255,1);
        box-shadow: 0 0 30px 1px rgba(255,255,255,1);
    }
}


/* =====================================================================
*    mydo
* =================================================================== */
.mydo {
    background: url(../images/common/line_tate_white.png) repeat left top #38d0f2;
    background-size: calc(20 / 750 * 100%) auto;
}

.mydo .inner {
    width: calc(530 / 750 * 100%);
    margin: 0 auto;
    padding: calc(40 / 750 * 100%) 0;
    background-color: #38d0f2;
    text-align: center;
}

.mydo a {
    display: inline-block;
    padding: 0 0.1em 0.5em;
    color: #000;
    font-size: 3rem;
    font-weight: 700;
    line-height: 1;
    text-align: center;
    background: url(../images/common/line_dot_bk2.png) repeat-x left bottom;
    background-size: auto 6.77%;
}

.mydo a strong {
    font-size: 4rem;
    font-weight: 700;
}

@media screen and (min-width: 768px) {
    .mydo {
        background-size: calc(10 / 1100 * 100%) auto;
    }
    
    .mydo .inner {
        width: calc(600 / 1100 * 100%);
        padding: calc(23 / 1100 * 100%) 0;
    }
    
    .mydo a {
        padding: 0 0.2em 0.4em;
        font-size: 2rem;
        background-size: auto 5.75%;
    }
    
    .mydo a:hover {
        opacity: 0.7;
    }
    
    .mydo a strong {
        font-size: 2.7rem;
    }
}

@media screen and (min-width: 1100px) {
    .mydo {
        background-size: 10px auto;
    }
    
    .mydo .inner {
        width: 600px;
        padding: 23px 0;
    }
}


/* =====================================================================
*    top_bnr
* =================================================================== */
.top_bnr {
    padding: calc(68 / 750 * 100%) 0 calc(50 / 750 * 100%);
    background: url(../images/common/line_tate_yellow.png) repeat left top;
    background-size: calc(20 / 750 * 100%) auto;
}

.top_bnr_box {
    width: calc(630 / 750 * 100%);
    margin: 0 auto calc(75 / 750 * 100%);
}

.top_bnr .inner div:last-child {
    margin-bottom: 0;
}

.top_bnr_box a::before {
    background: #ffe822;
}

@media screen and (min-width: 768px) {
    .top_bnr {
        padding: calc(50 / 1100 * 100%) 0 calc(30 / 1100 * 100%);
        background-size: calc(10 / 1100 * 100%) auto;
    }
    
    .top_bnr_box {
        width: calc(807 / 1100 * 100%);
        margin: 0 auto calc(50 / 1100 * 100%);
    }
}

@media screen and (min-width: 1100px) {
    .top_bnr {
        padding: 50px 0 30px;
        background-size: 10px auto;
    }
}


/* =====================================================================
*    nextstory
* =================================================================== */
.nextstory {
    padding: calc(100 / 750 * 100%) 0;
    background-color: #ffe822;
}

.nextstory::after {
    content: "";
    display: block;
    width: 100%;
    padding-top: calc(203 / 750 * 100%);
    background: url(../images/common/line_tate_white.png) repeat left top;
    background-size: calc(20 / 750 * 100%) auto;
    position: absolute;
    left: 0;
    bottom: 0;
}

.nextstory .inner {
    z-index: 2;
}

#nextstory_load {
    margin: 0 0 calc(63 / 750 * 100%);
}

#nextstory_load::before {
    content: "";
    display: block;
    width: 100%;
    padding-top: calc(310 / 750 * 100%);
    background: url(../images/index/bg_nextstory_icon_sp.png) no-repeat left top;
    background-size: 100% auto;
    position: absolute;
    bottom: 0;
    left: 0;
    margin: 0 0 calc(-56 / 750 * 100%);
}

.nextstory_thumb {
    width: calc(700 / 750 * 100%);
    margin: 0 auto calc(74 / 750 * 100%);
    background: url(../images/index/bg_nextstory_movie.png) no-repeat left top;
    background-size: 100% auto;
}

.nextstory_thumb_img {
    width: calc(550 / 700 * 100%);
    margin: 0 0 0 calc(68 / 700 * 100%);
    padding: calc(15 / 700 * 100%) 0 calc(24 / 700 * 100%);
}

.nextstory_thumb_link {
    position: absolute;
    top: 0;
    left: 0;
    margin: calc(15 / 550 * 100%) 0 0;
}

.nextstory_thumb_link a::before {
	content: "";
    display: block;
	width: calc(120 / 750 * 100vw);
	height: calc(120 / 750 * 100vw);
	background-color: rgba(229,0,79,0.8);
    border-radius: 50%;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
    z-index: 2;
}

.nextstory_thumb_link a::after {
    content: "";
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 2.8vw 0 2.8vw 4.5vw;
    border-color: transparent transparent transparent #fff;
    position: absolute;
	top: 0;
	bottom: 0;
	left: 1vw;
	right: 0;
	margin: auto;
    z-index: 2;
}

.nextstory_txt {
}

.nextstory_number {
    font-size: 4.5rem;
    font-weight: 900;
    line-height: 1;
    text-align: center;
    margin: 0 0 1em;
}

.nextstory_number span {
    display: inline-block;
    margin: 0 0.4em;
    color: #e5004f;
    font-size: 180%;
    font-weight: 900;
}

.nextstory_number::after {
    content: "";
    display: inline-block;
    width: 0.74em;
    height: 0.74em;
    background: url(../images/story/bg_number.png) no-repeat left top;
    background-size: 100% auto;
    vertical-align: top;
    margin: -0.6em 0.65em 0 -1.3em;
}

.nextstory_number img {
    display: inline-block;
    width: auto;
    height: 1.7em;
    margin: 0 0.7em;
    top: 0.15em;
}

.nextstory_ttl strong {
    display: block;
    font-size: 3.6rem;
    font-weight: 700;
    line-height: 1;
    text-align: center;
    margin: 0 0 0.7em;
}

.nextstory_ttl span {
    display: block;
    font-size: 2.2rem;
    font-weight: 400;
    line-height: 1;
    text-align: center;
}

.nextstory_btn {
    width: calc(450 / 750 * 100%);
    margin: 0 auto;
}

.nextstory_btn a {
}

.nextstory_btn a::before {
    background-color: #e5004f;
    margin: calc(-18 / 450 * 100%) 0 0 calc(-18 / 450 * 100%);
    margin: -4% 0 0 -4%;
}

@media screen and (min-width: 768px) {
    .nextstory {
        padding: calc(100 / 1100 * 100%) 0;
    }
    
    .nextstory::after {
        padding-top: calc(180 / 1100 * 100%);
        background-size: calc(10 / 1100 * 100%) auto;
    }
    
    #nextstory_load {
        margin: 0 0 calc(50 / 1100 * 100%);
    }
    
    #nextstory_load::before {
        padding-top: calc(290 / 1100 * 100%);
        background: url(../images/index/bg_nextstory_icon_pc.png) no-repeat left top;
        background-size: 100% auto;
        margin: 0 0 calc(-145 / 1100 * 100%);
    }
    
    .nextstory_thumb {
        width: calc(950 / 1100 * 100%);
        margin: 0 auto calc(38 / 1100 * 100%);
    }
    
    .nextstory_thumb_img {
        width: calc(746 / 950 * 100%);
        padding: calc(21 / 950 * 100%) 0 calc(32 / 950 * 100%);
    }
    
    .nextstory_thumb_link a::before {
        width: calc(80 / 1100 * 100vw);
        height: calc(80 / 1100 * 100vw);
        -webkit-transition: 0.2s ease;
        transition: 0.2s ease;
    }
    
    .nextstory_thumb_link a:hover::before {
        background-color: rgba(0,0,0,0.8);
        -webkit-transition: 0.2s ease;
        transition: 0.2s ease;
    }
    
    .nextstory_thumb_link a::after {
        border-width: 1.27vw 0 1.27vw 2.09vw;
        left: 0.64vw;
    }
    
    .nextstory_number {
        font-size: 3rem;
    }
    
    .nextstory_number img {
        height: 1.65em;
    }
    
    .nextstory_ttl strong {
        font-size: 2.4rem;
    }
    
    .nextstory_ttl span {
        font-size: 1.4rem;
    }
    
    .nextstory_btn {
        width: calc(340 / 1100 * 100%);
    }
}

@media screen and (min-width: 1100px) {
    .nextstory {
        padding: 100px 0;
    }
    
    .nextstory::after {
        padding-top: 180px;
        background-size: 10px auto;
    }
    
    .nextstory_thumb_link a::before {
        width: 80px;
        height: 80px;
    }
    
    .nextstory_thumb_link a::after {
        border-width: 14px 0 14px 23px;
        left: 7px;
    }
}


/* =====================================================================
*    previously
* =================================================================== */
.previously {
    background-color: #e5004f;
}

.previously_box {
    width: calc(710 / 750 * 100%);
    margin: 0 auto;
    padding: calc(20 / 750 * 100%) 0;
}

@media screen and (min-width: 768px) {
    .previously {
        background: url(../images/common/bg_previously.png) repeat center top;
        background-size: calc(42 / 1100 * 100%) auto;
    }
    
    .previously::before {
        content: "";
        display: block;
        width: calc(800 / 1100 * 100%);
        padding-top: calc(250 / 1100 * 100%);
        background-color: #e5004f;
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        margin: 0 auto;
    }
    
    .previously_box {
        width: calc(1000 / 1100 * 100%);
        padding: calc(30 / 1100 * 100%) 0;
    }
    
    .previously_box_btn {
        width: calc(238 / 1000 * 100%);
        padding-top: calc(64 / 1000 * 100%);
        position: absolute;
        bottom: 0;
        right: 0;
        margin: 0 calc(53 / 1000 * 100%) calc(-20 / 1000 * 100%) 0;
    }
    
    .previously_box_btn::before, .previously_box_btn::after {
        content: "";
        display: block;
        width: 100%;
        height: 100%;
        background: url(../images/index/btn_previously_pc.png) no-repeat left bottom;
        background-size: 100% auto;
        position: absolute;
        top: 0;
        left: 0;
        -webkit-transition: 0.2s ease;
        transition: 0.2s ease;
    }
    
    .previously_box_btn::after {
        background: url(../images/index/btn_previously_pc_hover.png) no-repeat left bottom;
        background-size: 100% auto;
        opacity: 0;
        -webkit-transition: 0.2s ease 0.1s;
        transition: 0.2s ease 0.1s;
    }
    
    .previously_box a:hover .previously_box_btn::before {
        opacity: 0;
        -webkit-transition: 0.2s ease 0.1s;
        transition: 0.2s ease 0.1s;
    }
    
    .previously_box a:hover .previously_box_btn::after {
        opacity: 1;
        -webkit-transition: 0.2s ease;
        transition: 0.2s ease;
    }
}

@media screen and (min-width: 1100px) {
    .previously {
        background-size: 42px auto;
    }
    
    .previously::before {
        width: 800px;
        padding-top: 250px;
    }
}


/* =====================================================================
*    chain
* =================================================================== */
.chain {
    background: url(../images/index/bg_chain_sp.png) no-repeat left bottom, url(../images/common/line_tate_yellow.png) repeat left top;
    background-size: 100% auto, calc(20 / 750 * 100%) auto;
    overflow: hidden;
}

.chain_box {
    width: calc(710 / 750 * 100%);
    margin: 0 auto;
    padding: calc(20 / 750 * 100%) 0;
}

.chain_box a::after {
    content: "";
    display: block;
    width: calc(278 / 710 * 100%);
    padding-top: calc(240 / 710 * 100%);
    margin: 0 auto calc(-31 / 710 * 100%);
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: url(../images/index/img_chain_photo.png) no-repeat left bottom;
    background-size: 100% auto;
}

@media screen and (min-width: 768px) {
    .chain {
        background: url(../images/index/bg_chain_pc.png) no-repeat center bottom, url(../images/common/line_tate_yellow.png) repeat left top;
        background-size: calc(1500 / 1100 * 100%) auto, calc(10 / 1100 * 100%) auto;
    }
    
    .chain_box {
        width: calc(1000 / 1100 * 100%);
        padding: calc(30 / 1100 * 100%) 0;
    }
    
    .chain_box a::after {
        width: calc(278 / 1000 * 100%);
        padding-top: calc(240 / 1000 * 100%);
        margin: 0 auto calc(-30 / 1000 * 100%) calc(368 / 1000 * 100%);
    }
    
    .chain_box_btn {
        width: calc(238 / 1000 * 100%);
        padding-top: calc(64 / 1000 * 100%);
        position: absolute;
        bottom: 0;
        right: 0;
        margin: 0 calc(53 / 1000 * 100%) calc(-20 / 1000 * 100%) 0;
    }
    
    .chain_box_btn::before, .chain_box_btn::after {
        content: "";
        display: block;
        width: 100%;
        height: 100%;
        background: url(../images/index/btn_chain_pc.png) no-repeat left bottom;
        background-size: 100% auto;
        position: absolute;
        top: 0;
        left: 0;
        -webkit-transition: 0.2s ease;
        transition: 0.2s ease;
    }
    
    .chain_box_btn::after {
        background: url(../images/index/btn_chain_pc_hover.png) no-repeat left bottom;
        background-size: 100% auto;
        opacity: 0;
        -webkit-transition: 0.2s ease 0.1s;
        transition: 0.2s ease 0.1s;
    }
    
    .chain_box a:hover .chain_box_btn::before {
        opacity: 0;
        -webkit-transition: 0.2s ease 0.1s;
        transition: 0.2s ease 0.1s;
    }
    
    .chain_box a:hover .chain_box_btn::after {
        opacity: 1;
        -webkit-transition: 0.2s ease;
        transition: 0.2s ease;
    }
}

@media screen and (min-width: 1100px) {
    .chain {
        background-size: 1500px auto, 10px auto;
    }
}


/* =====================================================================
*    news
* =================================================================== */
.widget {
    padding: calc(100 / 750 * 100%) 0;
    background-color: #38d0f2;
}

.widget::after {
    content: "";
    display: block;
    width: 100%;
    padding-top: calc(203 / 750 * 100%);
    background: url(../images/common/line_tate_white.png) repeat left top;
    background-size: calc(20 / 750 * 100%) auto;
    position: absolute;
    left: 0;
    bottom: 0;
}

.widget .inner {
    z-index: 2;
}

.news_box {
    width: calc(630 / 750 * 100%);
    margin: 0 auto calc(80 / 750 * 100%);
    padding: calc(50 / 750 * 100%) calc(50 / 750 * 100%) calc(50 / 750 * 100%) 0;
    background-color: #ffe822;
}

.news_list {
    height: 18.8em;
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
    font-size: 2.6rem;
    background: url(../images/index/bg_news_list.png) repeat-y left top #fff;
    background-size: 100% auto;
}

.news_list li {
    padding: calc(40 / 580 * 100%) 0 0;
}

.news_list li:last-child {
    padding-bottom: calc(40 / 580 * 100%);
}

.news_date {
    width: calc(290 / 580 * 100%);
    margin: 0 0 calc(20 / 580 * 100%) calc(30 / 580 * 100%);
    padding: 0.5em 0 0.58em 3.6em;
    background-color: #000;
    color: #39d7fc;
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 1;
}

.news_link {
    margin: 0 calc(60 / 580 * 100%) 0 calc(114 / 580 * 100%);
}

.news_link a {
    color: #e5003b;
    font-weight: 700;
    line-height: 1.4;
}

@media screen and (min-width: 768px) {
    .widget {
        padding: calc(100 / 1100 * 100%) 0;
    }
    
    .widget::after {
        padding-top: calc(200 / 1100 * 100%);
        background-size: calc(10 / 1100 * 100%) auto;
    }
    
    .widget .inner {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
        width: calc(1000 / 1100 * 100%);
        margin: 0 auto;
    }
    
    .news {
        width: calc(475 / 1000 * 100%);
    }
    
    .news_box {
        width: 100%;
        margin: 0;
        padding: calc(40 / 475 * 100%) calc(40 / 475 * 100%) calc(40 / 475 * 100%) 0;
    }
    
    .news_list {
        height: 31.25em;
        font-size: 1.6rem;
    }
    
    .news_list li {
        padding: calc(25 / 435 * 100%) 0 0;
    }
    
    .news_list li:first-child {
        padding: calc(40 / 435 * 100%) 0 0;
    }
    
    .news_list li:last-child {
        padding-bottom: calc(40 / 435 * 100%);
    }
    
    .news_date {
        width: calc(160 / 1100 * 100vw);
        margin: 0 0 calc(10 / 1100 * 100vw) calc(30 / 1100 * 100vw);
        padding: 0.5em 0 0.58em 3.2em;
        font-size: 1.4rem;
    }
    
    .news_link a:hover {
        opacity: 0.7;
    }
}

@media screen and (min-width: 1100px) {
    .widget {
        padding: 100px 0;
    }
    
    .widget::after {
        padding-top: 200px;
        background-size: 10px auto;
    }
    
    .widget .inner {
        width: 1000px;
    }
    
    .news_date {
        width: 160px;
        margin: 0 0 10px 30px;
    }
}


/* =====================================================================
*    twitter
* =================================================================== */
.twitter {
}

.twitter_box {
    width: calc(630 / 750 * 100%);
    margin: 0 auto calc(80 / 750 * 100%);
    padding: calc(50 / 750 * 100%);
    background-color: #ffe822;
}

.twitter_box iframe {
    width: 740px !important;
    font-size: 2rem;
    height: 20em !important;
    background-color: #fff;
    -webkit-overflow-scrolling: touch;
}

@media screen and (min-width: 768px) {
    .widget_sns {
        width: calc(475 / 1000 * 100%);
    }
    
    .twitter_box {
        width: 100%;
        padding: calc(40 / 475 * 100%);
        margin: 0 auto calc(52 / 475 * 100%);
    }
    
    .twitter_box iframe {
        height: 16.87em !important;
        font-size: 1.6rem;
    }
}


/* =====================================================================
*    instagram
* =================================================================== */
.instagram .sec_subttl {
    margin: 0 0 calc(53 / 750 * 100%);
}

.insta_btn {
    width: calc(450 / 750 * 100%);
    margin: 0 auto;
}

.insta_btn .btn_box::before {
    margin: calc(-18 / 450 * 100%) 0 0 calc(-18 / 450 * 100%);
    margin: -4% 0 0 -4%;
}

.insta_btn .btn_box_border {
    color: #000;
}

@media screen and (min-width: 768px) {
    .insta_btn {
        width: calc(340 / 475 * 100%);
    }
    
    .insta_btn .btn_box:hover::before {
        margin: 0;
    }
}


/* =====================================================================
*    buzznavi
* =================================================================== */
.buzznavi {
    margin: calc(80 / 750 * 100%) 0 0;
}

.buzznavi_box {
    width: calc(630 / 750 * 100%);
    margin: 0 auto;
    padding: calc(50 / 750 * 100%);
    background-color: #ffe822;
}

.buzznavi_inner {
    padding: calc(53 / 530 * 100%) 0 calc(40 / 530 * 100%);
    background-color: #fff;
}

.buzznavi_box h2 {
    width: calc(375 / 530 * 100%);
    margin: 0 auto calc(18 / 530 * 100%);
}

.buzznavi_list {
    width: calc(424 / 530 * 100%);
    margin: 0 auto calc(64 / 530 * 100%);
}

.buzznavi li {
    padding: 0 0 calc(30 / 424 * 100%);
    background: url(../images/common/line_dot_bk3.png) repeat-x left bottom;
    background-size: calc(12 / 424 * 100%) auto;
}

.buzznavi_num {
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 1;
    margin: 0 0 2%;
}

.buzznavi_txt {
    font-size: 2.8rem;
    font-weight: 700;
    line-height: 1.3;
    margin: 0 0 calc(25 / 424 * 100%);
}

.buzznavi_date {
    color: #e5004f;
    font-size: 2rem;
    line-height: 1;
    text-align: right;
}

.buzznavi_btn {
    width: calc(450 / 530 * 100%);
    margin: 0 auto;
}

.buzznavi_btn .btn_box::before {
    background-color: #00aaeb;
    margin: calc(-17 / 450 * 100%) 0 0 calc(-17 / 450 * 100%);
}

@media screen and (min-width: 768px) {
    .buzznavi {
        width: calc(800 / 1000 * 100%);
        margin: calc(60 / 1000 * 100%) auto 0;
    }
    
    .buzznavi_box {
        width: 100%;
        padding: calc(40 / 800 * 100%);
    }
    
    .buzznavi_inner {
        padding: calc(53 / 720 * 100%) 0 calc(50 / 720 * 100%);
    }
    
    .buzznavi_box h2 {
        width: calc(375 / 720 * 100%);
        margin: 0 auto calc(40 / 720 * 100%);
    }
    
    .buzznavi_list {
        width: calc(374 / 720 * 100%);
        margin: 0 auto calc(42 / 720 * 100%);
    }
    
    .buzznavi li {
        padding: 0 0 calc(30 / 374 * 100%);
        background: url(../images/common/line_dot_bk3.png) repeat-x left bottom;
        background-size: calc(6 / 374 * 100%) auto;
    }
    
    .buzznavi_num {
        font-size: 1.4rem;
    }
    
    .buzznavi_txt {
        font-size: 1.8rem;
        line-height: 1.5;
        margin: 0 0 calc(15 / 374 * 100%);
    }
    
    .buzznavi_date {
        font-size: 1.4rem;
    }
    
    .buzznavi_btn {
        width: calc(338 / 720 * 100%);
    }
    
    .buzznavi_btn .btn_box::before {
        margin: -3.78% 0 0 -3.78%;
    }
    
}


/* =====================================================================
*    platinight
* =================================================================== */
.platinight {
    padding: calc(20 / 750 * 100%);
    background: url(../images/common/line_tate_yellow.png) repeat left top;
    background-size: calc(20 / 750 * 100%) auto;
}

.platinight_box {
    padding: calc(60 / 710 * 100%) 0;
    background-color: #fff;
    border-radius: 2em;
    font-size: 2.8rem;
}

.platinight h2 {
    width: calc(626 / 710 * 100%);
    margin: 0 auto calc(45 / 710 * 100%);
}

.platinight_txt {
    font-weight: 400;
    line-height: 1.5;
    text-align: center;
}

.platinight_txt strong {
    font-size: 3.2rem;
    font-weight: 700;
    background: -webkit-gradient(linear, left top, left bottom, color-stop(10%, transparent), color-stop(10%, #ffe822));
    background: linear-gradient(transparent 10%, #ffe822 10%);
}

@media screen and (min-width: 768px) {
    .platinight {
        padding: calc(50 / 1100 * 100%) 0;
        background-size: calc(10 / 1100 * 100%) auto;
    }
    
    .platinight_box {
        width: calc(1000 / 1100 * 100%);
        margin: 0 auto;
        padding: calc(50 / 1100 * 100%) 0;
        font-size: 1.8rem;
        border-radius: 2.5em;
    }
    
    .platinight h2 {
        width: calc(466 / 1000 * 100%);
        margin: 0 auto calc(25 / 1000 * 100%);
    }
    
    .platinight_txt {
        line-height: 2;
    }
    
    .platinight_txt strong {
        font-size: 2.1rem;
    }
}

@media screen and (min-width: 1100px) {
    .platinight {
        padding: 50px 0;
        background-size: 10px auto;
    }
}



/* =====================================================================
*    hulu 追加
* =================================================================== */
.hulu.sec_ttl {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    font-size: 5.3rem;
    letter-spacing: -0.1em;
}
.hulu.sec_ttl em {
    display: inline-block;
    margin-right: -0.2em;
    font-size: 6rem;
    font-weight: 700;
    font-style: normal;
    letter-spacing: -0.05em;
}

.hulu.sec_ttl::before, .hulu.sec_ttl::after {
    margin: 0;
    position: relative;
    top: 0.05em;
}

.hulu_intro_box {
    margin: 0 0 calc(90 / 750 * 100%);
}

.hulu_intro_box::before {
    content: "";
    display: block;
    width: 100%;
    padding-top: calc(257 / 750 * 100%);
    background: url(../images/hulu/bg_hulu_icon_sp.png) no-repeat left top;
    background-size: 100% auto;
    position: absolute;
    top: 0;
    left: 0;
    margin: calc(360 / 750 * 100%) 0 0;
}

.hulu_intro_thumb {
    width: calc(700 / 750 * 100%);
    margin: 0 auto calc(70 / 750 * 100%);
    background: url(../images/index/bg_nextstory_movie.png) no-repeat left top;
    background-size: 100% auto;
}

.hulu_intro_thumb_img {
    width: calc(550 / 700 * 100%);
    margin: 0 0 0 calc(68 / 700 * 100%);
    padding: calc(15 / 700 * 100%) 0 calc(24 / 700 * 100%);
}

.hulu_movie_wrap {
    width: 100%;
    padding-top: 56.25%;
    position: relative;
}

.bc-player-default_default {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}

.hulu_only {
    /* width: calc(592 / 750 * 100%); */
    width: calc(651 / 750 * 100%);
    margin: 0 auto calc(35 / 750 * 100%);
}

.hulu_date {
    font-size: 3.6rem;
    font-weight: 700;
    line-height: 1.5;
    text-align: center;
}

@media screen and (min-width: 768px) {
    .hulu_intro_box {
        margin: 0 0 calc(40 / 1100 * 100%);
    }
    .hulu.sec_ttl em {
    margin-right: 0;
    font-size: 6.4rem;
}
    .hulu.sec_ttl {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin: 0 auto calc(50 / 1100 * 100%);
    font-size: 6rem;
}
    .hulu.sec_ttl::before{
        margin: 0 calc(34 / 1100 * 100%) 0 0;
    }
    .hulu.sec_ttl::after{
        margin: 0 0 0 calc(34 / 1100 * 100%);
    }
    .hulu_intro_box::before {
        padding-top: calc(177 / 1100 * 100%);
        background: url(../images/hulu/bg_hulu_icon_pc.png) no-repeat left top;
        background-size: 100% auto;
        margin: calc(497 / 1100 * 100%) 0 0;
    }
    
    .hulu_intro_thumb {
        width: calc(950 / 1100 * 100%);
        margin: 0 auto calc(58 / 1100 * 100%);
    }
    
    .hulu_intro_thumb_img {
        width: calc(746 / 950 * 100%);
        padding: calc(21 / 950 * 100%) 0 calc(32 / 950 * 100%);
    }
    
    .hulu_only {
        /* width: calc(444 / 1100 * 100%); */
        width: calc(511 / 1100 * 100%);
        margin: 0 auto calc(30 / 1100 * 100%);
    }
    
    .hulu_date {
        font-size: 2.4rem;
    }
    
}