
/***************************************
 *  25th
 */
html,body{
    height: 100%;
}

.tf-body{
    background: #FFF;
}

.tf-body #wrapper{
    visibility: none;
}


#tf-frame{
    background: #FFF;
    width:100%;
    height:100%;
    top:0;
    left:0;
    position:fixed;
    z-index:10000;
}

#tf-motion-area{
    position:absolute;
    top:0;
    left:0;
    width:1280px;
    height:720px;
    transform-origin:0 0;
}

#tf-image{
    position: absolute;
    display: none;
}

#tf-image #tf-kv{
    width:100%;
    height:100%;
}

#tf-footprints{
    position: absolute;
    display: none;
}

/***************************************
 *  TOP CSS
 */

section{
    max-width: 1560px;
    margin:auto;
}

.caption {
    display: inline;
    font-size: 32px;
    line-height: 38px;
    font-weight: normal;
}

section.black{
    color:#EEE;
    background-color: #000;
}

section.white{
    color:#CCC;
    background-color: #FFF;
}

ul{
    list-style: none;
    margin:0;
    padding:0;
}


/***************************************
 *  topics
 */

.topics{
    background:#444;
    font-size:12px;
    line-height: 12px;
    color:#999;
    height: 40px;
}

.topics .fixed_frame{
    padding: 8px 0;
    position: relative;
}


.topics .header{
    background-color:#999;
    float:left;
    text-align: center;
    width:60px;
    color:#000;
    font-weight: bold;
    padding:7px 0px 6px;
    height: 12px;
    border-radius: 3px 0 0 3px;
    vertical-align: middle;
}

.topics .topics_count{
    float:left;
    margin-left:0px;
    padding:6px 6px 5px;
    border:1px solid #999;
    border-left: none;
    border-radius: 0 3px 3px 0;
    width:40px;
    text-align: center;
}

.topics .navi{
    width:48px;
    position: absolute;
    right:0;
    top:9px;
}

.topics .navi a{
    display: block;
    float:left;
    width:22px;
    height: 22px;
    margin-left:2px;
}

#topics_list{
    position: relative;
    height: 24px;
    top:2px;
    left:10px;
    padding: 0;
    float:left;
    overflow: hidden;
    width: 770px;
}

#topics_list li{
    display: none;
    width:100%;
    position: absolute;
    top:0;
    left:0;
    height:22px;
    line-height: 22px;
    background:#444;
}

#topics_list li:first-child{
    display: block;
}


/***************************************
 *  content common
 */

.header{
    text-align: center;
}

.section_navi{
    height: 33px;
    margin: 0 auto;
    padding: 20px 0;
    vertical-align:middle;
    position: relative;
}

.section_navi .caption{
    display: inline;
    vertical-align: 12%;
    padding:0 15px;
}

.section_navi .more{
    display:inline-block;
    font-size: 18px;
    padding:0;
    margin:0;
    position: absolute;
    right:30px;
    top:20px;
    text-decoration: none;
    height:34px;
    padding-left: 40px;
    line-height: 34px;
}

.white .section_navi .more{
    color:#CCC;
    background : url(../img/common/navi_allow_wh_right.png) no-repeat;
}

.white .section_navi .more:hover{
    color:#333;
    background-image:url(../img/common/navi_allow_wh_right_on.png);
}

.black .section_navi .more{
    color:#888;
    background : url(../img/common/navi_allow_bk_right.png) no-repeat;
}
.black .section_navi .more:hover{
    color:#FFF;
    background-image:url(../img/common/navi_allow_bk_right_on.png);
}

.section_navi .more img{
    vertical-align: middle;
    padding-right:10px;
}

.variable_frame{
    padding:0 20px;
}




/***************************************
 *  billboard
 */

.billboard{
    line-height: 0;
    position: relative;
}

.billboard_list::before{
    content : " ";
    display: block;
    background: url("../img/common/bill_grade.png");
    position: absolute;
    top:0;
    left:0;
    width:100%;
    height:70px;
    z-index: 2;
}

.billboard_list>div{
    position: absolute;
    top:0;
    left:0;
}

.billboard .pagenation_nav{
    position: absolute;
    z-index: 101;
    width:74px;
    top:14px;
    left:0;
    right:0;
    margin:0 auto;
}

.billboard .pagenation_nav a{
    display: block;
    width: 32px;
    float:left;
    margin-left:10px;
}

.billboard .pagenation_nav a:first-child{
    margin-left: 0;
}



.billboard .bill_info{
    position: absolute;
    right :10px;
    top:10px;
    z-index: 100;
    width:400px;
    padding:15px;
    line-height: 1.8em;
    background:url("../img/common/bill_info_bg.png");
    border:1px solid;
    border-color:#777;
    border-color:rgba(255,255,255,0.3);
    border-radius: 6px;
}

.billboard .bill_info header{
    font-size: 18px;
    line-height: 1.35em;
    font-weight: bold;
}

.billboard .bill_info_body{
    margin-top: 12px;
}

.billboard  a.more_info{
    display: inline-block;
    height:40px;
    padding-left:42px;
    background: url(/img/common/navi_link_allow.png) no-repeat left center;
    vertical-align: middle;
    line-height: 42px;
    font-size: 16px;
    color:#FFF;
    text-decoration: none;
    margin-top:10px;
}

.billboard a.more_info:hover{
    background-image:url(/img/common/navi_link_allow_on.png);
}

.billboard_nav{
    position: absolute;
    z-index: 3;
    top:10px;
    left:10px;
}

.billboard_nav li{
    cursor: pointer;
    position: relative;
    width: 36px;
    height:36px;
    float:left;
    margin: 4px;
    cursor: pointer;
}

.billboard_nav li img{
    position: absolute;
    top:0;
    left:0;
    right:0;
    bottom:0;
    margin:auto;
    border:1px solid #FFF;
    border-radius: 3px;
    cursor: pointer;
}


.billboard_nav li.current img{
    border:3px solid #FFF;
}

/***************************************
 *  news
 */

.news_scroll_area{
    position: relative;
    width:100%;
    height: 345px;
    padding-bottom: 20px;
    overflow: hidden;
}

.news_list{
    position: absolute;
    margin:auto;
    height: 345px;
}

.news_list li{
    position: absolute;
    top:0;
    left:0;
}

.news_list li,
.news_list li a{
    display: block;
    width:280px;
    height:345px;
    overflow: hidden;
    text-decoration: none;
    color: #FFF;
    background: #323436;
    border-radius: 5px;
    cursor: pointer;
}

.news_list li:first-child{
    margin-left: 0;
}

.news_list li img{
    border-radius: 5px 5px 0 0; 
}

.news_list li.border img{
    box-sizing:border-box;
    width:280px;
    height:210px;
    border:1px solid #444;
}

.news_list li .date{
    font-size:18px;
    font-weight: bold;
    color:#666;
    margin: 10px;
}

.news_list li p{
    font-size: 14px;
    margin:10px;
    overflow:hidden;
    max-height:80px;
    line-height: 20px;
}



/***************************************
 *  ss_video
 */
.ss_video{
    padding-bottom: 20px;
}

section.ss_video{
    overflow: hidden;
}

.ss_video .variable_frame{
    margin:0px 20px;
    padding:0;
    position: relative;
}

.video_list{
    margin:0;
    padding:0;
    position: relative;
    width:100%;
    height: 100%;
    height: 800px;
}

.video_list li{
    margin:0;
    padding:0;
    width: 100%;
    position: absolute;
    list-style: none;
}

.video_list li a{
    display: block;
}


.video_list li img.large_thumb{
    width:100%;
    border-radius: 5px;
}

.video_list li .play_btn{
    position: absolute;
    top:    0;
    left:   0;
    bottom: 0;
    right:  0;
    margin:auto;

}

#video_thumb{
    position: absolute;
    top :20px;
    left:20px;
}


#video_thumb li{
    float:left;
    padding:3px;
    border:1px solid #DDD;
    margin-right:4px;
    border-radius:4px;
}

#video_thumb li:hover{
    border:1px solid #444;
}

#video_thumb li.current{
    border:1px solid #444;
}

#video_thumb li a{
    display: block;
    width  :40px;
    height: 30px;
}

#video_thumb li img{
    border-radius: 3px;
}

#video_frame{
    position: absolute;
    top:0;
    left:0;
}

.ss_video iframe{
    position: relative;
    z-index:-1;
}


/***************************************
 *  fanclub
 */
.fanclub{
    background-color:#000;
    padding:20px 0;
}

.fanclub header{
    margin-bottom: -3px;
}

.fanclub h2.caption{
}

.fanclub a{
    display: block;
    margin-top:20px;
}

.fanclub .banner{
    width:100%;
    border-radius: 5px;
}

.artist_photo{
    background-color:#000;
    padding:0 20px 20px;
	max-width: 1520px;
}
.artist_photo img{
	
}

#footer{
    margin-top: 0px;
}


/***************************************
 *  EMERGENCY
 */

#emergency_frame strong{
    color:#D00;
    font-weight: bold;
}

#emergency_frame a        { color : #225588; }
#emergency_frame a:hover  { color : #000000; text-decoration: none; }

#emergency_header{
    font-size:16px;
    font-weight: bold;
    color:#000;
	text-align:center;
	margin:0 80px; 
}

#emergency_body{
    margin-top:30px;
    line-height: 1.75em;
    font-size: 14px;
    color :#333;
}

#emergency_body img{
    max-width: 720px;
    margin-top:30px;
}


