/* common */
#header {
    background-color: #000000;
}
#main {
    background-color: #333333;
    position: relative;
    z-index: 0;
}
#main::before {
	display: block;
	content: '';
	position: absolute;
	background-color: #333333;
	height: 380px;
	width: 100%;
	z-index: -1;
	background-image: url(/images/common/bg_oblique.png);
	background-repeat: repeat;
	background-size: 40px 40px;
}
#main .inner {
    max-width: 1180px;
    margin: 0 auto;
    padding: 150px 50px 60px;
}
#main .title {
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 60px;
    margin-bottom: 30px;
}
#main .title span {
    font-size: 16px;
    display: block;
}
#main .title.sub {
    font-size: 48px;
}
/* news */
.news_box {
    background-color: #444444;
    padding: 50px 100px;
    max-width: 1080px;
    margin: 0 auto 50px;
    position: relative;
    z-index: 0;
}
.news_box::before {
    display: block;
    content: '';
    position: absolute;
    width: 100%;
    height: 200px;
    background: #000000;
    left: 0;
    top: 0;
    z-index: -1;
}
.news_box .update {
    color: #8A8A8A;
    font-size: 14px;
    font-family: 'Heebo', sans-serif;
    font-weight: 400;
    margin-bottom: 10px;
}
.news_box .update .mrk {
    background-color: #C91818;
    color: #FFFFFF;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 12px;
    line-height: 16px;
    width: 54px;
    text-align: center;
    display: inline-block;
    margin-right: 10px;
    position: relative;
    top: -1px;
}
.news_box .post_ttl {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 30px;
}
.news_box .post_ttl .label {
    background-color: #C91818;
    color: #FFFFFF;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 12px;
    line-height: 16px;
    width: 54px;
    text-align: center;
    margin-bottom: 7px;
    display: block;
}
.news_box .post_text {
    margin-bottom: 40px;
    padding: 50px;
    background: #555;
}
.news_box .post_text p {
    font-size: 15px;
}
.news_box .post_text p:not(:last-child) {
    margin-bottom: 20px;
}
.news_box .post_text p a {
    text-decoration: underline;
}
.list_news_other li {
    margin-bottom: 10px;
}
.list_news_other li a {
    display: block;
    background-color: rgba(0, 0, 0, 0.6);
    position: relative;
    padding: 20px;
}
.list_news_other li a:hover {
    background-color: rgba(0, 0, 0, 0.9);
    transition: 0.2s linear;
}
.list_news_other li a .update {
    color: #8A8A8A;
    font-size: 14px;
    font-family: 'Heebo', sans-serif;
    font-weight: 400;
    margin-bottom: 8px;
}
.list_news_other li a .update .mrk {
    background-color: #C91818;
    color: #FFFFFF;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 12px;
    line-height: 16px;
    width: 54px;
    text-align: center;
    display: inline-block;
    margin-right: 10px;
    position: relative;
    top: -2px;
}
.list_news_other li a .ttl {
    font-weight: 700;
}
.list_news_other li a svg {
    fill: #FFFFFF;
    width: 30px;
    height: 10px;
    position: absolute;
    top: 50%;
    margin-top: -4px;
    right: 25px;
    transition: 0.2s linear;
}
.list_news_other li a:hover svg {
    right: 15px;
}
/* live */
.new_live .info {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 30px 4%;
    margin-bottom: 60px;
    background-color: #000000;
}
.new_live .info .txt {
    width: 68%;
    font-size: 15px;
}
.new_live .info .btn {
    width: 28%;
}
.new_live .info .btn a {
    border: 1px solid #FFFFFF;
    display: block;
    line-height: 56px;
    text-align: center;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 16px;
    position: relative;
    background-color: #000000;
    transition: 0.2s linear;
}
.new_live .info .btn a svg {
    fill: #FFFFFF;
    width: 30px;
    height: 10px;
    position: absolute;
    top: 45%;
    margin-top: -4px;
    right: 20px;
    transition: 0.2s linear;
}
.new_live .info .btn a:hover {
    background-color: #2E2E2E;
}
.new_live .info .btn a:hover svg {
    right: 10px;
}
.list_live {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding-bottom: 100px;
}
.list_live::before {
    content: "";
    display: block;
    width: 23.5%;
    order: 1;
}
.list_live::after {
    content: "";
    display: block;
    width: 23.5%;
}
.list_live li {
    width: 23.5%;
    margin-bottom: 1.5vw;
}
.list_live li a {
    display: block;
    background-color: #404040;
    position: relative;
    padding: 25px;
    z-index: 0;
    transition: 0.2s linear;
    border: 1px solid transparent;
}
.list_live li a.nolink {
    pointer-events: none;
}
.list_live li a::before {
    display: block;
    content: '';
    position: absolute;
    background-color: #222222;
    height: 45%;
    width: 100%;
    z-index: -1;
    left: 0;
    bottom: 0;
}
.list_live li a:hover {
    border: 1px solid #999999;
}
.list_live li a .label {
    background-color: #AA0002;
    font-size: 11px;
    font-family: 'Heebo', sans-serif;
    font-weight: 400;
    position: absolute;
    top: 15px;
    left: 10px;
    line-height: 18px;
    padding: 0 8px;
    z-index: 10;
    letter-spacing: inherit;
    transform: rotate(-10deg);
}
.list_live li a figure {
    margin-bottom: 15px;
    padding: 0 15%;
}
.list_live li a .conts .ttl {
    text-align: center;
    font-size: 13px;
    font-weight: 700;
    margin-bottom: 5px;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1.4;
}
.list_live li a .conts .date {
    text-align: center;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 12px;
    color: #999999;
}
.live_head {
    width: 900px;
    margin: 0 auto 50px;
    display: flex;
    justify-content: space-between;
}
.live_head figure {
    width: 40%;
}
.live_head figure img {
    width: 100%;
}
.live_head .conts {
    width: 60%;
    padding-left: 50px;
    padding-top: 50px;
}
.live_head .conts label {
    background-color: #000000;
    font-family: 'Heebo', sans-serif;
    font-weight: 400;
    font-size: 14px;
    line-height: 1;
    padding: 5px 15px 4px;
    color: #FFFFFF;
    margin-bottom: 10px;
    display: inline-block;
}
.live_head .conts .ttl {
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 15px;
}
.live_head .conts .date {
    font-size: 14px;
    color: #CCCCCC;
    margin-bottom: 40px;
}
.live_head .conts .info .ttl_lead {
    font-size: 24px;
    margin-bottom: 15px;
}
.live_head .conts .info .text p {
    font-size: 14px;
    margin-bottom: 20px;
}
.live_head .conts .info .text p:last-child {
    margin-bottom: 0;
}
.live_schedule {
    width: 900px;
    margin: 0 auto;
    padding-bottom: 100px;
}
.tbl_schedule {
    font-size: 14px;
}
.tbl_schedule tr th, .tbl_schedule tr td {
    padding: 10px;
    border: 1px solid #555555;
    background-color: #212121;
}
.tbl_schedule tr th {
    background-color: #000000;
    text-align: center;
}
.tbl_schedule tr th.date {
    width: 200px;
}
.tbl_schedule tr th.time {
    width: 150px;
}
.tbl_schedule tr td.time {
    text-align: center;
}
.tbl_schedule tr td {}
.repo_btn {
    text-align: center;
    margin-bottom: 60px;
}
.repo_btn a {
    display: inline-block;
    text-align: center;
    width: 400px;
    border: 1px solid #FFFFFF;
    line-height: 56px;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 16px;
    position: relative;
    background-color: #000000;
    transition: 0.2s linear;
}
.repo_btn a svg {
    fill: #FFFFFF;
    width: 30px;
    height: 10px;
    position: absolute;
    top: 45%;
    margin-top: -4px;
    right: 20px;
    transition: 0.2s linear;
}
.repo_btn a:hover {
    background-color: #2E2E2E;
}
.repo_btn a:hover svg {
    right: 10px;
}
.live_repo {
    width: 100%;
    position: relative;
    padding-top: 50px;
}
.live_repo::before {
    display: block;
    content: '';
    position: absolute;
    background-color: #333333;
    background-image: linear-gradient(-45deg, #333333 25%, #111111 25%, #111111 50%, #333333 50%, #333333 75%, #111111 75%, #111111);
    background-size: 4px 4px;
    height: 380px;
    width: 100vw;
    z-index: -1;
    top: 0;
}
.live_repo .contents {
    width: 900px;
    margin: 0 auto;
    padding-bottom: 50px;
}
.live_repo .contents .repo_eyecatch {
    margin-bottom: 40px;
}
.live_repo .contents .repo_eyecatch img {
    width: 100%;
}
.live_repo .contents .ttl_repo {
    font-size: 20px;
    margin-bottom: 30px;
    font-weight: 700;
}
.live_repo .contents .text {
    margin-bottom: 40px;
}
.live_repo .contents .text p {
    margin-bottom: 20px;
    font-size: 15px;
}
.repo_photo {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-bottom: 40px;
}
.repo_photo li:only-child {
    width: 100%;
}
.repo_photo li:first-child:nth-last-child(2), .repo_photo li:first-child:nth-last-child(2) ~ li {
    width: 48%;
}
.repo_photo li:first-child:nth-last-child(3), .repo_photo li:first-child:nth-last-child(3) ~ li {
    width: 31%;
}
.repo_photo li:first-child:nth-last-child(4), .repo_photo li:first-child:nth-last-child(4) ~ li {
    width: 23.5%;
}
.repo_photo li:first-child:nth-last-child(5), .repo_photo li:first-child:nth-last-child(5) ~ li {
    width: 19%;
}
/* biography */
.profile {
    max-width: 1080px;
    margin: 0 auto;
    background-color: #444444;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.profile figure {
    width: 50%;
}
.profile .right {
    width: 50%;
    padding: 50px;
}
.profile .right .name {
    font-size: 26px;
    margin-bottom: 15px;
    font-weight: 700;
    padding-top: 20px;
}
.profile .right .name span {
    font-family: 'Heebo', sans-serif;
    font-weight: 400;
    font-size: 15px;
    padding-left: 15px;
}
.profile .right .data {
    margin-bottom: 20px;
    font-size: 18px;
}
.profile .right .text {
    border-top: 1px solid #B2B2B2;
    padding-top: 20px;
}
.profile .right .text p, .profile_text p {
    margin-bottom: 20px;
    font-size: 14px;
}
.profile .right .more {
    text-align: right;
}
.profile .right .more a {
    position: relative;
    display: inline-block;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    padding-left: 25px;
    transition-property: all;
    transition: 0.2s linear;
    right: 0;
}
.profile .right .more a::before, .profile .right .more a::after {
    content: '';
    display: block;
}
.profile .right .more a::before {
    width: 14px;
    height: 2px;
    position: absolute;
    left: 0;
    top: 50%;
    margin-top: -2px;
    border-top: 2px solid #FFFFFF;
}
.profile .right .more a::after {
    width: 2px;
    height: 14px;
    position: absolute;
    left: 6px;
    top: 50%;
    margin-top: -8px;
    border-left: 2px solid #FFFFFF;
}
.profile .right .more a:hover {
    right: -5px;
}
.profile_text {
    max-width: 1080px;
    margin: 0 auto 50px;
    background-color: #444444;
    padding: 50px;
    display: none;
}
.history .inner {
    max-width: 1080px !important;
    margin: 0 auto;
    padding: 0px 0px 100px !important;
}
.age_area {
    margin-bottom: 15px;
}
.age_bar {
    position: relative;
    background-color: #000000;
}
.age_bar::before, .age_bar::after {
    content: '';
    display: block;
    z-index: 2;
}
.age_bar::before {
    width: 29px;
    height: 1px;
    position: absolute;
    right: 20px;
    top: 50%;
    margin-top: -1px;
    border-top: 1px solid #FFFFFF;
}
.age_bar::after {
    width: 1px;
    height: 29px;
    position: absolute;
    right: 33px;
    top: 50%;
    margin-top: -15px;
    border-left: 1px solid #FFFFFF;
}
.age_bar a {
    display: flex;
    align-items: center;
    font-family: 'Oswald', sans-serif;
    font-weight: 400;
    font-size: 42px;
    padding: 0 20px;
    height: 70px;
    position: relative;
    z-index: 1;
}
.age_bar a::before {
    display: block;
    content: "";
    position: absolute;
    width: 0%;
    height: 100%;
    top: 0;
    left: 0%;
    z-index: -1;
    transition: all 0.5s ease;
}
.age_bar.a1970 a::before {
    background-color: #20284B;
}
.age_bar.a1980 a::before {
    background-color: #6C0079;
}
.age_bar.a1990 a::before {
    background-color: #5F1616;
}
.age_bar.a2000 a::before {
    background-color: #5F4D16;
}
.age_bar.a2010 a::before {
    background-color: #114500;
}
.age_bar.a2020 a::before {
    background-color: #256AB5;
}
.age_bar a:hover::before, .age_bar.op a::before {
    width: 100%;
}
.age_bar.op::after {
    display: none;
}
.age_bar a span {
    font-size: 24px;
    margin-right: 15px;
}
.history_box {
    padding: 50px;
    position: relative;
    z-index: 0;
    background: #222;
    overflow: hidden;
}
.history_box::before {
    display: block;
    content: '';
    position: absolute;
    width: 300%;
    height: 200px;
    background-color: rgba(0, 0, 0, 0.3);
    left: -30%;
    top: -20%;
    z-index: -1;
    transform: rotate(-45deg);
}
.history_box::after {
    display: block;
    content: '';
    position: absolute;
    width: 300%;
    height: 200px;
    background: rgba(0, 0, 0, 0.2);
    left: -130%;
    top: 0;
    z-index: -1;
    transform: rotate(45deg);
}
.history_box .main {
    width: 100%;
    margin-bottom: 30px;
}
.history_box .photo {
    width: 30%;
}
.history_box .photo figure {
    margin-bottom: 20px;
}
.history_box .inbox dl {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.history_box .inbox dl dt {
    font-family: 'Oswald', sans-serif;
    font-weight: 400;
    font-size: 15px;
    width: 17%;
    position: relative;
    top: -1px;
}
.history_box .inbox dl dd {
    font-size: 14px;
    margin-bottom: 20px;
    width: 83%;
}
/* discography */
.cat_discography {
    margin-bottom: 40px;
}
.cat_discography li {
    display: inline-block;
    margin-right: 30px;
}
.cat_discography li a {
    font-family: 'Heebo', sans-serif;
    font-weight: 400;
    display: block;
    position: relative;
    padding-left: 45px;
    color: #999999;
    transition: 0.2s linear;
}
.cat_discography li a:before {
    display: block;
    content: '';
    position: absolute;
    top: 50%;
    width: 30px;
    height: 1;
    border-top: 1px solid #999999;
    left: 0;
    margin-top: -1px;
}
.cat_discography li a.ac, .cat_discography li a:hover {
    color: #FFFFFF;
}
.cat_discography li a.ac:before, .cat_discography li a:hover:before {
    border-top: 1px solid #FFFFFF;
}
.list_disco {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding-bottom: 100px;
}
.list_disco::before {
    content: "";
    display: block;
    width: 23.5%;
    order: 1;
}
.list_disco::after {
    content: "";
    display: block;
    width: 23.5%;
}
.list_disco li {
    width: 23.5%;
    margin-bottom: 1.5vw;
    background-color: #444444;
    border: 1px solid #444444;
    transition: 0.2s linear;
    border-radius: 2px;
    display: flex;
}
.list_disco li a {
    display: block;
    padding: 15px;
    width: 100%;
}
.list_disco li:hover {
    border: 1px solid #999999;
}
.list_disco li a figure {
    margin-bottom: 10px;
    text-align: center;
    background-color: #666666;
}
/*.list_disco li a figure img {
    max-height: 221.8px;
}*/
.list_disco li a label {
    background-color: #000000;
    font-family: 'Heebo', sans-serif;
    font-weight: 400;
    font-size: 11px;
    line-height: 1;
    padding: 4px 10px;
    color: #FFFFFF;
    margin-bottom: 5px;
    display: inline-block;
}
.list_disco li a .ttl {
    font-size: 13px;
    margin-bottom: 5px;
    font-weight: 700;
}
.list_disco li a .release_date {
    font-family: 'Heebo', sans-serif;
    font-weight: 400;
    font-size: 11px;
    color: #999999;
}
.disco_head {
    width: 900px;
    margin: 0 auto 50px;
    display: flex;
    justify-content: space-between;
}
.disco_head figure {
    width: 45%;
}
.disco_head figure img {
    width: 100%;
}
.disco_head .conts {
    width: 55%;
    padding-left: 50px;
}
.disco_head .conts label {
    background-color: #000000;
    font-family: 'Heebo', sans-serif;
    font-weight: 400;
    font-size: 14px;
    line-height: 1;
    padding: 5px 15px 4px;
    color: #FFFFFF;
    margin-bottom: 10px;
    display: inline-block;
}
.disco_head .conts .ttl {
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 15px;
}
.disco_head .conts .release_date {
    font-size: 14px;
    color: #CCCCCC;
    margin-bottom: 15px;
}
.disco_head .conts .ttl_info {
    font-size: 14px;
    font-weight: 700;
}
dl.release_other {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-bottom: 15px;
    font-size: 13px;
}
dl.release_other dt {
    width: 15%;
}
dl.release_other dd {
    width: 85%;
}
.disco_head .conts .txt {
    font-size: 14px;
}
.disco_movie, .disco_tracklist {
    width: 900px;
    margin: 0 auto 50px;
    position: relative;
    padding: 30px 0 0 60px;
}
.disco_movie::before, .disco_tracklist::before {
    display: block;
    content: '';
    position: absolute;
    background-color: #000000;
    height: 180px;
    width: 100%;
    top: 0;
    left: 0;
    z-index: -1;
}
.disco_movie .mov {
    background-color: #444444;
    padding: 40px;
}
.disco_movie .mov figure {
    position: relative;
    cursor: pointer;
}
.disco_movie .mov figure:before {
    background-color: rgba(0, 0, 0, 0.1);
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    content: '';
}
.disco_movie .mov figure svg {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 60px;
    height: 60px;
    fill: #FFFFFF;
}
.ttl_disco {
    font-size: 28px;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    margin-bottom: 20px;
}
.disco_tracklist {
    width: 900px;
    margin: 0 auto 50px;
    position: relative;
    padding: 40px 0 0 60px;
}
.disco_tracks {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    background-color: #444444;
    width: 900px;
    margin: 0 auto;
    padding: 50px;
}
.track_wrap {
    background-color: #444444;
    padding: 40px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.track_box {
    width: 100%;
}
.track_wrap.cnt1 {
    width: 100%;
}
.track_wrap.cnt2 .track_box, .track_wrap.cnt3 .track_box, .track_wrap.cnt4 .track_box, .track_wrap.cnt5 .track_box, .track_wrap.cnt6 .track_box, .track_wrap.cnt7 .track_box, .track_wrap.cnt8 .track_box {
    width: 48%;
    margin-bottom: 30px;
}
.ttl_disc {
    font-size: 18px;
    margin-bottom: 15px;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
}
.list_track {
    counter-reset: number 0;
}
.list_track li {
    position: relative;
    font-size: 14px;
    border-bottom: 1px dotted #707070;
    padding: 12px 10px 10px 38px;
    display: flex;
    justify-content: space-between;
}
.list_track li:first-child {
    border-top: 1px dotted #707070;
}
.list_track li::before {
    position: absolute;
    left: 10px;
    counter-increment: number 1;
    content: counter(number) ". ";
}
.list_track li .name {
    width: calc(100% - 65px);
}
.list_track li .name.w100 {
    width: 100%;
}
.list_track li .audio {
    width: 65px;
}
.track_box .txt_head {
    padding-bottom: 15px;
    font-size: 14px;
    line-height: 1.4;
}
.track_box .txt {
    padding: 15px 10px;
    font-size: 14px;
    line-height: 1.4;
}
.sub_box {
    width: 900px;
    margin: 0 auto;
    padding: 35px 50px;
    background-color: #111111;
    /*border: 1px solid #222222;*/
}
.sub_box .ttl {
    font-size: 20px;
    margin-bottom: 20px;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    text-align: center;
    line-height: 1;
}
.disco_btns {
    padding-top: 30px;
}
.disco_btns li {
    width: 300px;
    margin-bottom: 15px;
    font-size: 15px;
}
.disco_btns li a {
    display: block;
    background-color: #000000;
    text-align: center;
    line-height: 42px;
    position: relative;
    padding-top: 1px;
    border: 1px solid #999999;
    transition: 0.2s linear;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
}
.disco_btns li a:hover {
    transform: translateX(10px);
}
.disco_btns li a svg {
    position: absolute;
    top: 10px;
    left: 15px;
    width: 20px;
    height: 20px;
    fill: #FFFFFF;
    margin-right: 10px;
}
.thumb_list img {
    width: 100%;
}
.disco_modal {
    display: none;
    position: fixed;
    top: 0;
    height: 100vh;
    width: 100%;
    z-index: 999;
}
.disco_modal .bg {
    position: absolute;
    height: 100vh;
    width: 100%;
    background: rgba(0, 0, 0, 0.8);
}
.disco_modal_content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    /*overflow: scroll;*/ /* はみ出た部分はスクロールさせる */
    /*height: 60%;*/
    width: 600px;
    padding: 40px;
    background-color: #000000;
    border: 1px solid #707070;
}
.disco_modal_content .ttl {
    font-size: 30px;
    margin-bottom: 25px;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    text-align: center;
    line-height: 1;
}
.disco_modal_content .ttl svg {
    width: 30px;
    height: 30px;
    margin-right: 15px;
    position: relative;
    top: 2px;
}
.disco_modal_content .ttl_bldvd {
    font-size: 22px;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    margin-bottom: 5px;
}
.disco_modal_content .att {
    font-size: 12px;
}
.disco_modal_content span.close {
    position: absolute;
    width: 40px;
    height: 40px;
    display: block;
    right: 0;
    top: -50px;
}
.disco_modal_content span.close::before, .disco_modal_content span.close::after {
    position: absolute;
    top: 21px;
    left: 2px;
    width: 40px;
    height: 2px;
    content: "";
    background-color: #999999;
}
.disco_modal_content span.close::before {
    transform: rotate(45deg);
}
.disco_modal_content span.close::after {
    transform: rotate(135deg);
}
.list_buy, .list_listen {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.list_buy li:first-child {
    width: 100%;
}
.list_buy li, .list_listen li {
    width: 48%;
    margin-bottom: 1vw;
    background-color: #FFFFFF;
}
.list_buy li a, .list_listen li a {
    display: block;
    transition: 0.2s linear;
}
.list_buy li a:hover, .list_listen li a:hover {
    opacity: 0.7;
}
/* movie */
.modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    height: 100vh;
    width: 100%;
    z-index: 9999;
    background: rgba(0, 0, 0, 0.8);
}
.modal .mov {
    display: none;
}
.modal .mov.show {
    padding: 0 5%;
    position: relative;
    top: 50%;
    transform: translateY(-50%);
    display: block;
}
.modal .mov.show .in {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
}
.modal .mov .in iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
}
.modal_close {
    position: absolute;
    right: 5%;
    top: -50px;
    cursor: pointer;
}
.modal_close span {
    position: relative;
    width: 46px;
    height: 46px;
    display: block;
}
.modal_close span {
    position: relative;
    width: 40px;
    height: 40px;
    display: block;
}
.modal_close span::before, .modal_close span::after {
    position: absolute;
    top: 21px;
    left: 2px;
    width: 40px;
    height: 2px;
    content: "";
    background-color: #999999;
}
.modal_close span::before {
    transform: rotate(45deg);
}
.modal_close span::after {
    transform: rotate(135deg);
}
.big_mov {
    max-width: 1080px;
    margin: 0 auto 50px;
    background-color: #444444;
    padding: 40px;
}
/*movie 非モーダルで追加*/
.big_mov a, .list_mov li a {
    display: block;
    overflow: hidden;
}
.big_mov figure:hover::before, .list_mov li figure:hover::before {
    background-color: rgba(0, 0, 0, 0.0);
}
.big_mov figure img, .list_mov li figure img {
    transition: 0.2s linear;
}
.big_mov figure:hover img, .list_mov li figure:hover img {
    transform: scale(1.03);
}
/*movie 非モーダルで追加 ここまで*/
.big_mov figure {
    position: relative;
    cursor: pointer;
    margin-bottom: 20px;
}
.big_mov figure:before {
    background-color: rgba(0, 0, 0, 0.2);
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    content: '';
    transition-property: all;
    transition: 0.2s linear;
}
.big_mov figure svg {
    position: absolute;
    /*top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);*/
    bottom: 30px;
    left: 30px;
    width: 60px;
    height: 60px;
    fill: #FFFFFF;
}
.big_mov .ttl {
    font-size: 15px;
}
.bnr_youtube {
    max-width: 760px;
    margin: 0 auto 50px;
}
.list_mov {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    max-width: 1080px;
    margin: 0 auto;
    padding-bottom: 100px;
}
.list_mov::after {
    content: "";
    display: block;
    width: 31%;
}
.list_mov li {
    width: 31%;
    padding: 10px;
    background-color: #444444;
    margin-bottom: 2.2vw;
}
.list_mov li figure {
    position: relative;
    cursor: pointer;
    margin-bottom: 10px;
}
.list_mov li figure::before {
    background-color: rgba(0, 0, 0, 0.1);
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    content: '';
    transition: 0.2s linear;
}
/*.list_mov li figure img {
    object-fit: cover;
    width: 100%;
    height: 14vw;
}*/
.list_mov li figure svg {
    position: absolute;
    /*top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);*/
    bottom: 15px;
    left: 15px;
    width: 40px;
    height: 40px;
    fill: #FFFFFF;
}
.list_mov li .ttl {
    font-size: 13px;
}
#fc {
    background-color: #FFFFFF;
}
.fanclub_fv {
    position: relative;
    top: 80px;
    width: 100%;
    height: 100%;
    padding: 65% 0 0; /*padding-top(%) = 高さ / 横幅 * 100*/
}
.fanclub_fv .in {
    background-size: cover;
    background-position: center top;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: url(/images/fanclub/fv.jpg);
}
.fanclub_fv .in .r_wrap {
    background-color: #FFFFFF;
    width: 50%;
    height: 100%;
    margin-right: 0;
    margin-left: auto;
    padding: 0 30px;
}
.fanclub_fv .in .r_wrap .logo {
    margin-bottom: 40px;
    text-align: center;
    padding-top: 15%;
}
.fanclub_fv .in .r_wrap .logo img {
    width: 80%;
}
.fanclub_fv .in .r_wrap .login_btn {
    text-align: center;
    margin-bottom: 15px;
}
.fanclub_fv .in .r_wrap .login_btn a {
    text-align: center;
    display: inline-block;
    width: 350px;
    background: linear-gradient(-30deg, #BCA16B 0%, #C1A773 50%, #A3813C 70%, #A9894A 100%);
    color: #FFFFFF;
    line-height: 50px;
    font-weight: 700;
    transition: 0.2s linear;
    position: relative;
}
.fanclub_fv .in .r_wrap .login_btn a svg {
    fill: #FFFFFF;
    width: 30px;
    height: 10px;
    position: absolute;
    top: 45%;
    margin-top: -4px;
    right: 20px;
    transition: 0.2s linear;
}
.fanclub_fv .in .r_wrap .login_btn a:hover {
    background: linear-gradient(30deg, #BCA16B 0%, #C1A773 50%, #A3813C 70%, #A9894A 100%);
}
.fanclub_fv .in .r_wrap .login_btn a:hover svg {
    right: 10px;
}
.fanclub_fv .in .r_wrap .register {
	text-align: center;
	font-size: 14px;
	padding-top: 10px;
}
.fanclub_fv .in .r_wrap .register a {
	color: #000000;
	text-decoration: underline;
}
#fanclub .contents {
    z-index: 0;
    position: relative;
    background-color: #333333;
}
#fanclub .contents::before {
    display: block;
    content: '';
    position: absolute;
    background-color: #333333;
    background-image: linear-gradient(-45deg, #333333 25%, #111111 25%, #111111 50%, #333333 50%, #333333 75%, #111111 75%, #111111);
    background-size: 4px 4px;
    height: 380px;
    width: 100%;
    z-index: -1;
}
#fanclub .contents .inner {
    max-width: 1080px;
    margin: 0 auto;
    padding: 80px 15px;
}
.title_fc {
    font-family: 'Oswald', sans-serif;
    font-weight: 500;
    font-size: 50px;
    text-align: center;
    margin-bottom: 40px;
}
.title_fc span {
    text-align: center;
    font-size: 16px;
    display: block;
}
.list_benefits {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.list_benefits li {
    width: 31%;
    background-color: #FFFFFF;
    color: #000000;
    padding: 12px;
    margin-bottom: 35px;
}
.list_benefits li figure {
    margin-bottom: 15px;
}
.list_benefits li .ttl {
    font-size: 15px;
    font-weight: 700;
    text-align: center;
}
.list_benefits li .txt {
    font-size: 14px;
}
.fc_info {
    max-width: 980px;
    margin: 0 auto 40px;
    background-color: #F4F4F4;
    padding: 50px;
    color: #000000;
}
.fc_info dl {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    font-size: 15px;
    margin-bottom: 30px;
}
.fc_info dl dt, .fc_info dl dd {
    padding-bottom: 20px;
    margin-bottom: 20px;
    border-bottom: 1px solid #CCCCCC;
}
.fc_info dl dt:nth-last-child(-n+2), .fc_info dl dd:last-child {
    padding-bottom: initial;
    margin-bottom: initial;
    border-bottom: initial;
}
.fc_info dl dt {
    width: 23%;
    font-weight: 700;
}
.fc_info dl dd {
    width: 77%;
}
.fc_info dl dd .att_list {
    font-size: 14px;
}
.fc_info .btns {
    display: flex;
    justify-content: space-between;
    width: 500px;
    margin: 0 auto 30px;
}
.fc_info .btns li {
    width: 48%;
}
.fc_info .btns li a {
    display: block;
    font-size: 15px;
    background: #000000;
    border: 1px solid #CCCCCC;
    text-align: center;
    line-height: 38px;
    position: relative;
    color: #FFFFFF;
}
.fc_info .btns li a:after {
    display: block;
    content: '';
    position: absolute;
    top: 50%;
    width: 8px;
    height: 8px;
    border-right: 2px solid #FFFFFF;
    border-bottom: 2px solid #FFFFFF;
    transform: rotate(-45deg);
    margin-top: -4px;
    right: 10px;
}
.fc_info .txt {
    text-align: center;
    margin-bottom: 30px;
    font-size: 15px;
    font-weight: 700;
    color: #C30003;
}
.fc_info .txt br {
    display: none;
}
.btn_fc {
    text-align: center;
    margin-bottom: 30px;
}
.btn_fc.mb0 {
    margin-bottom: 0;
}
.btn_fc a {
    text-align: center;
    display: inline-block;
    width: 400px;
    background-image: linear-gradient(168deg, rgba(163, 129, 60, 1.00) 0%, rgba(188, 161, 107, 1.00) 14.86%, rgba(193, 167, 115, 1.00) 33%, rgba(163, 129, 60, 1.00) 69.95%, rgba(169, 137, 74, 1.00) 100%);
    color: #FFFFFF;
    line-height: 60px;
    font-weight: 700;
    transition: 0.2s linear;
    position: relative;
}
.btn_fc a svg {
    fill: #FFFFFF;
    width: 30px;
    height: 10px;
    position: absolute;
    top: 45%;
    margin-top: -4px;
    right: 20px;
    transition: 0.2s linear;
}
.btn_fc a:hover {
    background-image: -webkit-linear-gradient(138deg, rgba(163, 129, 60, 1.00) 0%, rgba(188, 161, 107, 1.00) 14.86%, rgba(193, 167, 115, 1.00) 33%, rgba(163, 129, 60, 1.00) 69.95%, rgba(169, 137, 74, 1.00) 100%);
    background-image: -moz-linear-gradient(138deg, rgba(163, 129, 60, 1.00) 0%, rgba(188, 161, 107, 1.00) 14.86%, rgba(193, 167, 115, 1.00) 33%, rgba(163, 129, 60, 1.00) 69.95%, rgba(169, 137, 74, 1.00) 100%);
    background-image: -o-linear-gradient(138deg, rgba(163, 129, 60, 1.00) 0%, rgba(188, 161, 107, 1.00) 14.86%, rgba(193, 167, 115, 1.00) 33%, rgba(163, 129, 60, 1.00) 69.95%, rgba(169, 137, 74, 1.00) 100%);
    background-image: linear-gradient(312deg, rgba(163, 129, 60, 1.00) 0%, rgba(188, 161, 107, 1.00) 14.86%, rgba(193, 167, 115, 1.00) 33%, rgba(163, 129, 60, 1.00) 69.95%, rgba(169, 137, 74, 1.00) 100%);
}
.btn_fc a:hover svg {
    right: 10px;
}
.support_links {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.support_links li {
    width: 48.5%;
    background-color: #FFFFFF;
    padding: 20px;
    margin-bottom: 30px;
    color: #000000;
}
.support_links li .ttl {
    font-size: 16px;
    font-weight: 700;
    border-bottom: 1px solid #CCCCCC;
    padding-bottom: 15px;
    margin-bottom: 20px;
    letter-spacing: 0;
}
.support_links li .txt {
    font-size: 15px;
    margin-bottom: 25px;
}
.support_links li .btn a {
    text-align: center;
    display: block;
    background-image: linear-gradient(168deg, rgba(163, 129, 60, 1.00) 0%, rgba(188, 161, 107, 1.00) 14.86%, rgba(193, 167, 115, 1.00) 33%, rgba(163, 129, 60, 1.00) 69.95%, rgba(169, 137, 74, 1.00) 100%);
    color: #FFFFFF;
    line-height: 50px;
    font-weight: 700;
    transition: 0.2s linear;
    position: relative;
    font-size: 13px;
    letter-spacing: 0;
}
.support_links li .btn a svg {
    fill: #FFFFFF;
    width: 22px;
    height: 8px;
    position: absolute;
    top: 50%;
    margin-top: -6px;
    right: 10px;
    transition: 0.2s linear;
}
.support_links li .btn a:hover {
    background-image: linear-gradient(312deg, rgba(163, 129, 60, 1.00) 0%, rgba(188, 161, 107, 1.00) 14.86%, rgba(193, 167, 115, 1.00) 33%, rgba(163, 129, 60, 1.00) 69.95%, rgba(169, 137, 74, 1.00) 100%);
}
.support_links li .btn a:hover svg {
    right: 5px;
}
.text_contents {
    width: 1080px;
    margin: 0 auto 40px;
    background-color: #F4F4F4;
    padding: 50px;
    color: #000000;
    font-size: 15px;
}
.text_contents .ttl_jo {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 20px;
    padding-bottom: 15px;
    border-bottom: 1px solid #999999;
}
.text_contents .txt {
    margin-bottom: 40px;
    font-size: 15px;
}
.text_contents .txt.mb10 {
    margin-bottom: 10px;
}
.text_contents .list_num {
    padding-left: 20px;
    font-size: 15px;
    margin-bottom: 40px;
}
.text_contents .list_num li {
    list-style-type: decimal;
}
.text_contents .num_text {
    margin-bottom: 40px;
    font-size: 15px;
}
.text_contents .num_text dt {
    font-weight: 700;
    margin-bottom: 5px;
}
.text_contents .num_text dd {
    margin-bottom: 20px;
    padding-left: 15px;
}
.faq_navi {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 0 50px;
    margin-bottom: 40px;
}
.faq_navi li {
    width: 33%;
    font-size: 15px;
}
.faq_navi li a {
    display: block;
    position: relative;
    padding-left: 45px;
    color: #FFFFFF;
    transition: 0.2s linear;
}
.faq_navi li a:before {
    display: block;
    content: '';
    position: absolute;
    top: 50%;
    width: 30px;
    height: 1;
    border-top: 1px solid #999999;
    left: 0;
    margin-top: -1px;
}
.faq_navi li a.ac, .faq_navi li a:hover {
    color: #FFFFFF;
}
.faq_navi li a.ac:before, .faq_navi li a:hover:before {
    border-top: 1px solid #FFFFFF;
}
/*.faq_links {
    display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
    padding: 0 50px;
}
.faq_links li {
    width: 31%;
    font-size: 15px;
}
.faq_links li a {
    border: 1px solid #F8F8F8;
    line-height: 40px;
    text-align: center;
    position: relative;
    background-color: #020202;
    display: block;
}
.faq_links li a:after {
	display: block;
	content: '';
	position: absolute;
	top: 50%;
	width: 8px;
	height: 8px;
	border-right: 2px solid #FFFFFF;
	border-bottom: 2px solid #FFFFFF;
	transform: rotate(-45deg);
    margin-top: -4px;
	right: 8px;
}*/
.faq_area {
    width: 880px;
    margin: 0 auto;
    padding-top: 30px;
}
.ttl_faq_cate {
    background: #000000;
    font-size: 18px;
    font-weight: 700;
    padding: 10px 15px;
}
dl.faq {
    margin-bottom: 30px;
}
dl.faq dt, dl.faq dd {
    color: #000000;
    font-size: 15px;
}
dl.faq dt {
    background-color: #F4F4F4;
    position: relative;
    padding-left: 60px;
    cursor: pointer;
    margin-top: 1px;
    padding: 15px 15px 15px 60px;
}
dl.faq dt::before {
    content: "Q.";
    position: absolute;
    top: 9px;
    left: 25px;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 24px;
}
dl.faq dt::after {
    display: block;
    content: '';
    position: absolute;
    top: 50%;
    width: 10px;
    height: 10px;
    border-right: 2px solid #333333;
    border-bottom: 2px solid #333333;
    transform: rotate(45deg);
    right: 30px;
    margin-top: -7px;
}
dl.faq dt.op p {
    font-weight: 700;
}
dl.faq dt.op::after {
    top: 50%;
    width: 10px;
    height: 10px;
    transform: rotate(-135deg);
    right: 30px;
    margin-top: -2px;
}
dl.faq dd {
    position: relative;
    cursor: pointer;
    font-size: 15px;
    display: none;
    padding: 20px 20px 20px 60px;
    background-color: #FFFFFF;
}
dl.faq dd::before {
    content: "A.";
    color: #AE0002;
    position: absolute;
    top: 14px;
    left: 25px;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 24px;
}
dl.faq dd a {
    text-decoration: underline;
    color: #000000;
}
.support {
    width: 1080px;
    margin: 0 auto 40px;
    background-color: #F4F4F4;
    padding: 40px;
    color: #000000;
}
.support .ttl {
    padding-bottom: 15px;
    margin-bottom: 30px;
    border-bottom: 1px solid #999999;
    font-weight: 700;
    font-size: 18px;
}
.support .ttl br {
    display: none;
}
.support .text p {
    margin-bottom: 30px;
    font-size: 15px;
}
.support .text p a {
    text-decoration: underline;
	color: #000000;
}
.support .text p strong {
    font-weight: 700;
}
.support .text p.txt_big {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 10px;
    color: #2969A6;
}
.support .card {
    margin-bottom: 20px;
}
.support .btn_card a {
    text-align: center;
    display: inline-block;
    width: 350px;
    background: linear-gradient(-30deg, #BCA16B 0%, #C1A773 50%, #A3813C 70%, #A9894A 100%);
    color: #FFFFFF !important;
    line-height: 50px;
    font-weight: 700;
    transition: 0.2s linear;
    position: relative;
    text-decoration: none !important;
}
.support .btn_card a svg {
    fill: #FFFFFF;
    width: 30px;
    height: 10px;
    position: absolute;
    top: 45%;
    margin-top: -4px;
    right: 20px;
    transition: 0.2s linear;
}
.support .btn_card a:hover {
    background: linear-gradient(30deg, #BCA16B 0%, #C1A773 50%, #A3813C 70%, #A9894A 100%);
}
.support .btn_card a:hover svg {
    right: 10px;
}
.reentry_example {
    background-color: #E3E3E3;
    padding: 25px;
    font-size: 14px;
    margin-bottom: 40px;
}
.reentry_example .ttl_ex {
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 5px;
}
.reentry_example .txt {
    margin-bottom: 20px;
}
.fc_attbox {
    border: 1px solid #666666;
    padding: 20px;
    margin-bottom: 30px;
}
.fc_attbox .ttl_att {
    font-weight: 700;
    font-size: 15px;
    margin-bottom: 5px;
}
.fc_attbox ul li {
    position: relative;
    padding-left: 18px;
    font-size: 14px;
    margin-bottom: 4px;
    line-height: 1.5;
}
.fc_attbox ul li:after {
    content: "※";
    position: absolute;
    top: 0px;
    left: 0px;
}
.fc_attbox ul li a {
    text-decoration: underline;
	color: #000000;
}
.fc_attbox ul li p.txt_bl {
    color: #2969A6;
    font-weight: 700;
}
.fc_attbox .txt {
    font-size: 14px;
}
.login_area {
    background-image: url(/images/fanclub/login_bg.jpg);
    background-size: cover;
    background-position: center center;
    position: relative;
    z-index: 0;
    width: 100%;
    height: calc(100vh - 72px);
}
.login_area::before {
    background-color: rgba(0, 0, 0, 0.5);
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    content: '';
    z-index: -1;
}
.login_box {
    width: 400px;
    margin: 0 auto;
    position: relative;
    top: 50%;
    transform: translateY(-50%);
    text-align: center;
}
.login_box .ttl {
    font-family: 'Oswald', sans-serif;
    font-weight: 500;
    font-size: 50px;
    margin-bottom: 20px;
}
.login_box .text {
    font-size: 15px;
    margin-bottom: 30px;
}
dl.login {
    margin-bottom: 40px;
}
dl.login dt {
    text-align: left;
    margin-bottom: 5px;
}
dl.login dd {
    margin-bottom: 20px;
}
.login_link li {
    text-align: center;
}
.login_link li a {
    font-size: 15px;
    position: relative;
    padding-left: 15px;
    text-decoration: underline;
}
.login_link li a::before {
    display: block;
    content: '';
    position: absolute;
    top: 50%;
    width: 0;
    height: 0;
    border: 3px solid transparent;
    border-left: 5px solid #FFFFFF;
    left: 0;
    margin-top: -4px;
}
.login_link li:last-child {
	padding-top: 10px;
	font-size: 16px;
}
.login_link li:last-child a {
	font-weight: 700;
}
.btn_fcform {
    text-align: center;
    display: block;
    background: linear-gradient(-30deg, #BCA16B 0%, #C1A773 50%, #A3813C 70%, #A9894A 100%);
    color: #FFFFFF;
    line-height: 50px;
    font-weight: 700;
    transition: 0.2s linear;
    position: relative;
    width: 100%;
    margin-bottom: 30px;
    font-size: 16px;
}
.btn_fcform svg {
    fill: #FFFFFF;
    width: 30px;
    height: 10px;
    position: absolute;
    top: 45%;
    margin-top: -4px;
    right: 20px;
    transition: 0.2s linear;
}
.btn_fcform:hover {
    background: linear-gradient(30deg, #BCA16B 0%, #C1A773 50%, #A3813C 70%, #A9894A 100%);
}
.btn_fcform:hover svg {
    right: 10px;
}
#members {
    padding: 80px 0 0;
}
/*#members::before {
    display: block;
    content: '';
    position: absolute;
    background-color: #333333;
    background-image: linear-gradient(-45deg, #333333 25%, #111111 25%, #111111 50%, #333333 50%, #333333 75%, #111111 75%, #111111);
    background-size: 4px 4px;
    background-attachment: fixed;
    height: 100%;
    width: 100%;
    z-index: -1;
}
#members::after {
    display: block;
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    background-size: contain;
    height: 100%;
    width: 50%;
    z-index: -1;
    background-image: url(/images/fc/contents_bg.jpg);
    background-position: left bottom;
    background-repeat: no-repeat;
    background-attachment: fixed;
}
*/
#members .top_head {
    background: #FFFFFF;
    padding: 40px 0;
    width: 100%;
    box-shadow: 0px 6px 6px 0px rgba(0, 0, 0, 0.2);
    position: relative;
    z-index: 1;
}
#members .top_head .logo {
    text-align: center;
    margin-bottom: 50px;
    width: 800px;
    margin: 0 auto;
}
#members .top_head .logo img {
    width: 65%;
}
#members .content {
    width: 100%;
    background-image: url("/images/fc/bg_silver.jpg");
    background-size: cover;
    background-position: center center;
    position: relative;
    z-index: 0;
    color: #000000;
}
#members .content::before {
    background-color: rgba(255, 255, 255, 0.60);
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    content: '';
    z-index: -1;
}
#members .content .inner {
    width: 1080px;
    margin: 0 auto;
    padding: 60px 0 80px;
}
.title_member {
    font-family: 'Oswald', sans-serif;
    font-weight: 500;
    font-size: 40px;
    line-height: 1;
    margin-bottom: 25px;
	text-align: left;
}
.list_news_fc {
    margin-bottom: 60px;
}
.list_news_fc li {
    margin-bottom: 15px;
}
.list_news_fc li a {
    display: block;
    background-color: #FFFFFF;
    position: relative;
    padding: 20px;
    color: #000000;
    box-shadow: 0px 0px 5px 5px rgba(0, 0, 0, 0.1);
}
.list_news_fc li a:hover {
    transition: 0.2s linear;
}
.list_news_fc li a.nolink {
    pointer-events: none;
}
.list_news_fc li a .update {
    color: #8A8A8A;
    font-size: 14px;
    font-family: 'Heebo', sans-serif;
    font-weight: 400;
    margin-bottom: 8px;
}
.list_news_fc li a .update .mrk {
    background-color: #C91818;
    color: #FFFFFF;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 12px;
    line-height: 18px;
    width: 54px;
    text-align: center;
    display: inline-block;
    margin-right: 10px;
    position: relative;
    top: -1px;
}
.list_news_fc li a .ttl {
    font-weight: 700;
}
.list_news_fc li a svg {
    fill: #666666;
    width: 30px;
    height: 10px;
    position: absolute;
    top: 50%;
    margin-top: -4px;
    right: 25px;
    transition: 0.2s linear;
}
.list_news_fc li a:hover svg {
    right: 15px;
}
.bnr_fc {
    margin-bottom: 40px;
}
.bnr_fc li {
    margin-bottom: 30px;
}
.fc_conts_box {
    background-color: #FFFFFF;
    padding-right: 15px;
    padding-left: 15px;
    padding-bottom: 15px;
    position: relative;
    margin-bottom: 40px;
    box-shadow: 0px 0px 5px 5px rgba(0, 0, 0, 0.1);
}
.fc_conts_box .date {
    position: absolute;
    left: 0;
    top: 0;
    width: 100px;
    height: 100px;
    text-align: center;
    font-family: 'Heebo', sans-serif;
    background: linear-gradient(-30deg, #BCA16B 0%, #C1A773 50%, #A3813C 70%, #A9894A 100%);
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    color: #FFFFFF;
}
.fc_conts_box .date div {
    width: 100%;
}
.fc_conts_box .date div span {
    line-height: 1;
    display: block;
    text-align: center;
}
.fc_conts_box .date div span:first-child {
    font-size: 14px;
    font-weight: 500;
    margin-bottom: 5px;
}
.fc_conts_box .date div span:last-child {
    font-size: 50px;
    font-weight: 500;
}
.fc_conts_box .ttl {
    color: #000000;
    padding-left: 110px;
    padding-top: 15px;
    letter-spacing: 0;
    margin-bottom: 15px;
    height: 100px;
    display: flex;
    align-items: center;
}
.fc_conts_box .ttl div .label {
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 14px;
    line-height: 1;
    margin-bottom: 5px;
}
.fc_conts_box .ttl div .label span {
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 14px;
    display: inline-block;
    margin-right: 10px;
    background-color: #C91818;
    line-height: 18px;
    padding: 2px 10px 0px;
    color: #FFFFFF;
}
.fc_conts_box .ttl div h2 {
    font-size: 18px;
    font-weight: 700;
}
.fc_conts_box figure {
    position: relative;
    cursor: pointer;
    overflow: hidden;
    margin-bottom: 20px;
}
.fc_conts_box figure svg {
    position: absolute;
    bottom: 30px;
    left: 30px;
    width: 60px;
    height: 60px;
    fill: #FFFFFF;
}
.fc_conts_box figure img {
    transition: 0.2s linear;
}
.fc_conts_box figure:hover img {
    transform: scale(1.03);
}

.fc_conts_box .tweet_box .txt {
    margin-bottom: 8px;
    font-size: 14px;
}
.fc_conts_box .tweet_box .btn_tweet a {
    font-size: 13px;
    background-color: rgb(29 161 242);
    display: inline-block;
    padding: 3px 10px 4px;
    border-radius: 2px;
    transition: 0.3s linear;
    text-align: center;
    font-weight: 700;
    color: #FFFFFF;
}
.fc_conts_box .tweet_box .btn_tweet a svg {
        width: 16px;
        height: 16px;
        fill: #FFFFFF;
        margin-right: 8px;
        position: relative;
        top: 3px;
    }
.fc_att_txt {
  font-size: 13px;
  padding: 15px;
  border: 1px solid #666666;
	margin-bottom: 40px;
	background: #FFFFFF;
}
.fc_conts_box .att_txt {
    font-size: 12px;
}
.next_info {
    font-family: 'Oswald', sans-serif;
    font-weight: 500;
    font-size: 60px;
    line-height: 1.0;
    text-align: center;
    letter-spacing: normal;
    /*background: linear-gradient(-30deg, #BCA16B 0%, #C1A773 50%, #A3813C 70%, #A9894A 100%);*/
    color: #FFFFFF;
    padding: 40px 0;
    margin-bottom: 160px;
    background-color: rgba(0, 0, 0, 0.40);
}
.vimeo_modal {
    display: none;
    position: fixed;
    top: 0;
    height: 100vh;
    width: 100%;
    z-index: 9999;
}
.vimeo_modal_bg {
    position: absolute;
    height: 100vh;
    width: 100%;
    background: rgba(0, 0, 0, 0.85);
}
.vimeo_modal_content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    overflow: scroll;
    /*height: 60%;*/
    width: 90%;
}
.vimeo_modal_close_btn {
    position: fixed;
    right: 20px;
    top: 10px;
}
.vimeo_modal_close_btn span {
    position: relative;
    width: 40px;
    height: 40px;
    display: block;
}
.vimeo_modal_close_btn span::before, .vimeo_modal_close_btn span::after {
    position: absolute;
    top: 21px;
    left: 2px;
    width: 40px;
    height: 2px;
    content: "";
    background-color: #FFFFFF;
}
.vimeo_modal_close_btn span::before {
    transform: rotate(45deg);
}
.vimeo_modal_close_btn span::after {
    transform: rotate(135deg);
}
.vimeo_modal_content div {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
}
.vimeo_modal_content div iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
}
.not_found {
    height: 60vh;
}
.not_found div {
    text-align: center;
    position: relative;
    top: 50%;
    transform: translateY(-50%);
    font-family: 'Oswald', sans-serif;
    font-weight: 500;
}
.not_found div .ttl {
    line-height: 1;
    font-size: 160px;
    margin-bottom: 10px;
}
.not_found div .sub {
    line-height: 1;
    font-size: 70px;
    margin-bottom: 30px;
}
.not_found div .txt {
    font-size: 15px;
    margin-bottom: 20px;
}
.not_found div .btn a {
    display: inline-block;
    position: relative;
    padding: 20px;
    font-size: 20px;
}
.not_found div .btn a svg {
    fill: #FFFFFF;
    width: 60px;
    height: 20px;
    position: absolute;
    top: 50%;
    margin-top: -7px;
    right: -50px;
    transition: 0.2s linear;
}
.not_found div .btn a:hover svg {
    right: -60px;
}
.login_att {
    background: #FFF;
    color: #BA0003;
    border: 2px solid #BA0003;
    font-size: 13px;
    padding: 15px;
    text-align: left;
    margin-bottom: 20px;
}
.login_att strong {
    text-decoration: underline;
    font-weight: 700;
}

/*DG櫻井追加
=====================================*/

/*ダイヤモンドチケット　ボタン*/
.dt-btn{
    padding: 20px 20px;
    background: #000;
    color: #ffc041;
    transition: .3s;
    font-weight: bold;
    border: solid 1px #ffc041;
}
.dt-btn:hover{
    background: #323232;
}