/* common */
#main {
    background-color: #333333;
    position: relative;
    z-index: 0;
}
#main::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: 35vh;
    width: 100%;
    z-index: -1;
}
#main .inner {
    padding: 90px 5% 40px;
}
#main .title {
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 9vw;
    margin-bottom: 20px;
    line-height: 1;
}
#main .title span {
    font-size: 3vw;
    padding-top: 1vh;
    display: block;
}
#main .title.sub {
    font-size: 7vw;
}
input::placeholder {
	color: #575757;
}
	/* news */
.news_box {
    background-color: #444444;
    padding: 5%;
    position: relative;
    z-index: 0;
    margin-bottom: 30px;
}
.news_box::before {
    display: block;
    content: '';
    position: absolute;
    width: 100%;
    height: 20vh;
    background: #000000;
    left: 0;
    top: 0;
    z-index: -1;
}
.news_box .update {
    color: #8A8A8A;
    font-size: 3.0vw;
    font-family: 'Heebo', sans-serif;
    font-weight: 400;
    margin-bottom: 5px;
}
.news_box .update .mrk {
    background-color: #C91818;
    color: #FFFFFF;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 3.0vw;
    line-height: 15px;
    width: 50px;
    text-align: center;
    display: inline-block;
    margin-right: 10px;
    position: relative;
    top: -1px;
    padding-top: 1.5px;
}
.news_box .post_ttl {
    font-size: 4.0vw;
    line-height: 1.4;
    font-weight: 700;
    margin-bottom: 15px;
}
.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: 20px;
    padding: 6%;
    background: #555;
}
.news_box .post_text p {
    font-size: 3.2vw;
    word-break: break-all;
}
.news_box .post_text p:not(:last-child) {
    margin-bottom: 20px;
}
.news_box .post_text p a {
    text-decoration: underline;
}
/*.news_box {
    background-color: #444444;
    display: flex;
    justify-content: space-between;
    margin-bottom: 40px;
}
.news_box .date {
    width: 70px;
    height: 70px;
    text-align: center;
    font-family: 'Heebo', sans-serif;
    background-color: rgba(0, 0, 0, 1.00);
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
}
.news_box .date div {
    width: 100%;
}
.news_box .date div span {
    line-height: 1;
    display: block;
    text-align: center;
}
.news_box .date div span:first-child {
    font-size: 12px;
    font-weight: 500;
    margin-bottom: 3px;
}
.news_box .date div span:last-child {
    font-size: 36px;
    font-weight: 500;
}
.news_box .content {
    width: calc(100% - 70px);
    padding: 20px 5%;
}
.news_box .content .post_ttl {
    display: flex;
    justify-content: space-between;
    margin-bottom: 10px;
}
.news_box .content .post_ttl .label {
    background-color: #C91818;
    color: #FFFFFF;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 12px;
    line-height: 1;
    padding: 2px 0 0;
    width: 50px;
    text-align: center;
    margin-bottom: 5px;
    display: block;
}
.news_box .content .post_ttl .ttl {
    font-size: 4.2vw;
    line-height: 1.4;
    font-weight: 700;
}
.news_box .content .eyecatch {
    margin-bottom: 15px;
}
.news_box .content .post_text {
    margin-bottom: 20px;
}
.news_box .content .post_text p {
    font-size: 13px;
    word-break: break-all;
}
.news_box .content .post_text p:not(:last-child) {
    margin-bottom: 20px;
}
.news_box .content .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.5);
    padding: 12px 5%;
    position: relative;
}
.list_news_other li a .update {
    color: #8A8A8A;
    font-size: 3.0vw;
    font-family: 'Heebo', sans-serif;
    font-weight: 400;
    margin-bottom: 5px;
}
.list_news_other li a .update .mrk {
    background-color: #C91818;
    color: #FFFFFF;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 3.0vw;
    line-height: 15px;
    width: 50px;
    text-align: center;
    display: inline-block;
    margin-right: 10px;
    position: relative;
    top: -1px;
    padding-top: 1.5px;
}
.list_news_other li a .ttl {
    font-weight: 700;
    font-size: 3.4vw;
}
.list_news_other li a svg {
    fill: #FFFFFF;
    width: 20px;
    height: 7px;
    position: absolute;
    bottom: 10px;
    right: 10px;
}
/* live */
.new_live .info {
    padding: 5%;
    margin-bottom: 40px;
    background-color: #000000;
}
.new_live .info .txt {
    font-size: 3.2vw;
    margin-bottom: 15px;
}
.new_live .info .btn {}
.new_live .info .btn a {
    border: 1px solid #FFFFFF;
    display: block;
    line-height: 5vh;
    text-align: center;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 16px;
    position: relative;
    background-color: #000000;
}
.new_live .info .btn a svg {
    fill: #FFFFFF;
    width: 30px;
    height: 10px;
    position: absolute;
    top: 45%;
    margin-top: -4px;
    right: 10px;
}
.list_live {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.list_live li {
    width: 48%;
    margin-bottom: 15px;
}
.list_live li a {
    display: block;
    background-color: #404040;
    position: relative;
    padding: 6% 3%;
    z-index: 0;
    transition: 0.2s linear;
}
.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.nolink {
    pointer-events: none;
}
.list_live li a .label {
    background-color: #AA0002;
    font-size: 2.4vw;
    font-family: 'Heebo', sans-serif;
    font-weight: 400;
    position: absolute;
    top: 3px;
    left: -7px;
    line-height: 18px;
    padding: 0 8px;
    z-index: 10;
    letter-spacing: inherit;
    transform: rotate(-10deg);
}
.list_live li a figure {
    margin-bottom: 10px;
    padding: 0 15%;
}
.list_live li a .conts .ttl {
    text-align: center;
    font-size: 3vw;
    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: 2.6vw;
    color: #999999;
}
.live_head {}
.live_head figure {
    width: 65%;
    margin-bottom: 15px;
}
.live_head figure img {
    width: 100%;
}
.live_head .conts {
    margin-bottom: 30px;
}
.live_head .conts label {
    background-color: #000000;
    font-family: 'Heebo', sans-serif;
    font-weight: 400;
    font-size: 3.2vw;
    line-height: 1;
    padding: 5px 10px 4px;
    color: #FFFFFF;
    margin-bottom: 6px;
    display: inline-block;
}
.live_head .conts .ttl {
    font-size: 5vw;
    font-weight: 700;
    margin-bottom: 10px;
}
.live_head .conts .date {
    font-size: 3.2vw;
    color: #CCCCCC;
    margin-bottom: 30px;
}
.live_head .conts .info .ttl_lead {
    font-size: 4.4vw;
    margin-bottom: 10px;
    font-weight: 700;
}
.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 {
    margin-bottom: 40px;
}
.tbl_schedule {
    font-size: 14px;
}
.tbl_schedule tr {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.tbl_schedule tr th {
    display: none;
}
.tbl_schedule tr td {
    padding: 4px 5%;
    /*border: 1px solid #555555;*/
    background-color: #212121;
}
.tbl_schedule tr td:nth-last-child(2) {
    width: 30%;
}
.tbl_schedule tr td:last-child {
    width: 70%;
}
.tbl_schedule tr td.time {
    padding-bottom: 8px;
    padding-top: 0px;
}
.tbl_schedule tr td:first-child {
    background-color: #000000;
    padding: 8px 5%;
    font-weight: 700;
    width: 100%;
    font-size: 3.6vw;
}
.tbl_schedule tr td:nth-child(2) {
    width: 100%;
    font-size: 3.8vw;
    padding-top: 5px;
}
.tbl_schedule tr td:nth-last-child(-n+2) {}
.repo_btn {
    text-align: center;
    margin-bottom: 60px;
}
.repo_btn a {
    display: inline-block;
    text-align: center;
    width: 90%;
    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: 30px;
}
.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: 25vh;
    width: 100vw;
    z-index: -1;
    top: 0;
}
.live_repo .contents {
    padding: 0 5% 50px;
}
.live_repo .contents .repo_eyecatch {
    margin-bottom: 30px;
}
.live_repo .contents .repo_eyecatch img {
    width: 100%;
}
.live_repo .contents .ttl_repo {
    font-size: 3.6vw;
    margin-bottom: 20px;
    font-weight: 700;
}
.live_repo .contents .text {
    margin-bottom: 30px;
}
.live_repo .contents .text p {
    margin-bottom: 20px;
    font-size: 14px;
}
.repo_photo {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-bottom: 30px;
}
.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 {
    background-color: #444444;
}
.profile figure {}
.profile .right {
    padding: 5vw;
}
.profile .right .name {
    font-size: 4.6vw;
    margin-bottom: 3vw;
    font-weight: 700;
}
.profile .right .name span {
    font-family: 'Heebo', sans-serif;
    font-weight: 400;
    font-size: 3.2vw;
    padding-left: 3.2vw;
}
.profile .right .data {
    margin-bottom: 4vw;
    font-size: 3.6vw;
}
.profile .right .text {
    border-top: 1px solid #B2B2B2;
    padding-top: 3vw;
}
.profile .right .text p, .profile_text p {
    margin-bottom: 5vw;
    font-size: 3.4vw;
}
.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 {
    background-color: #444444;
    padding: 5vw;
    display: none;
}
.history .inner {
    padding: 30px 5% 50px !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: 23px;
    height: 1px;
    position: absolute;
    right: 20px;
    top: 50%;
    margin-top: -1px;
    border-top: 1px solid #FFFFFF;
}
.age_bar::after {
    width: 1px;
    height: 23px;
    position: absolute;
    right: 31px;
    top: 50%;
    margin-top: -12px;
    border-left: 1px solid #FFFFFF;
}
.age_bar a {
    display: flex;
    align-items: center;
    font-family: 'Oswald', sans-serif;
    font-weight: 400;
    font-size: 8vw;
    padding: 0 20px;
    height: 55px;
    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.op a::before {
    width: 100%;
}
.age_bar.op::after {
    display: none;
}
.age_bar a span {
    font-size: 5vw;
    margin-right: 10px;
    position: relative;
    top: 2px;
}
.history_box {
    position: relative;
    z-index: 0;
    background-color: #222222;
    padding: 4%;
    overflow: hidden;
    /*background-image: url(/images/biography/year_bg.jpg);
    background-size: cover;*/
}
.history_box::before {
    display: block;
    content: '';
    position: absolute;
    width: 500%;
    height: 30vw;
    background-color: rgba(0, 0, 0, 0.3);
    right: -250%;
    top: 30%;
    z-index: -1;
    transform: rotate(-45deg);
}
.history_box::after {
    display: block;
    content: '';
    position: absolute;
    width: 300%;
    height: 30vw;
    background: rgba(0, 0, 0, 0.2);
    left: -130%;
    top: 0;
    z-index: -1;
    transform: rotate(45deg);
}
.history_box .main {
    width: 100%;
    margin-bottom: 5%;
}
/*.history_box .photo {
    width: 30%;
}*/
.history_box .photo figure {
    margin-bottom: 15px;
}
.history_box .inbox {}
.history_box .inbox dl dt {
    font-family: 'Oswald', sans-serif;
    font-weight: 400;
    font-size: 4vw;
    margin-bottom: 3px;
}
.history_box .inbox dl dd {
    font-size: 3.2vw;
    margin-bottom: 20px;
}
/* discography */
.cat_discography {
    margin-bottom: 6%;
}
.cat_discography li {}
.cat_discography li a {
    font-family: 'Heebo', sans-serif;
    font-weight: 400;
    display: inline-block;
    position: relative;
    padding-left: 10%;
    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 {
    color: #FFFFFF;
}
.cat_discography li a.ac:before {
    border-top: 1px solid #FFFFFF;
}
.list_disco {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.list_disco li {
    width: 48%;
    margin-bottom: 4%;
    background-color: #444444;
    border: 1px solid #444444;
    transition: 0.2s linear;
    border-radius: 2px;
}
.list_disco li a {
    display: block;
    padding: 5%;
}
.list_disco li:hover {
    border: 1px solid #999999;
}
.list_disco li a figure {
    margin-bottom: 10px;
    text-align: center;
    background-color: #666666;
    position: relative;
    overflow: hidden;
}
/*.list_disco li a figure::before {
    content: "";
    display: block;
    padding-top: 100%;
}
.list_disco li a figure img {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    height: 100%;
    margin: 0 auto;
}*/
.list_disco li a label {
    background-color: #000000;
    font-family: 'Heebo', sans-serif;
    font-weight: 400;
    font-size: 2.8vw;
    line-height: 1;
    padding: 4px 8px 2px;
    color: #FFFFFF;
    margin-bottom: 5px;
    display: inline-block;
}
.list_disco li a .ttl {
    font-size: 3.2vw;
    margin-bottom: 5px;
    font-weight: 700;
}
.list_disco li a .release_date {
    font-family: 'Heebo', sans-serif;
    font-weight: 400;
    font-size: 2.8vw;
    color: #999999;
}
.disco_head {}
.disco_head figure {
    width: 65%;
    margin-bottom: 15px;
}
.disco_head figure img {
    width: 100%;
}
.disco_head .conts {}
.disco_head .conts label {
    background-color: #000000;
    font-family: 'Heebo', sans-serif;
    font-weight: 400;
    font-size: 3.2vw;
    line-height: 1;
    padding: 5px 10px 4px;
    color: #FFFFFF;
    margin-bottom: 6px;
    display: inline-block;
}
.disco_head .conts .ttl {
    font-size: 5vw;
    font-weight: 700;
    margin-bottom: 10px;
}
.disco_head .conts .release_date {
    font-size: 3.2vw;
    color: #CCCCCC;
}
.disco_head .conts .release_date {
    margin-bottom: 15px;
}
.disco_head .conts .ttl_info {
    font-size: 3.8vw;
    font-family: 'Heebo', sans-serif;
    font-weight: 700;
}
dl.release_other {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-bottom: 5%;
    font-size: 3.2vw;
}
dl.release_other dt {
    width: 12%;
}
dl.release_other dd {
    width: 87%;
}
.disco_head .conts .txt {
    font-size: 3.2vw;
}
.disco_movie, .disco_tracklist {
    padding: 20px 0 0 5%;
    margin-bottom: 30px;
    position: relative;
}
.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: 15px;
}
.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: 40px;
    height: 40px;
    fill: #FFFFFF;
}
.ttl_disco {
    font-size: 4.6vw;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    margin-bottom: 3%;
}
.disco_tracks {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    background-color: #444444;
    padding: 4% 5%;
}
.track_area {
    width: 100%;
}
.track_wrap {
    background-color: #444444;
    padding: 15px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 100%;
}
.track_box {
    width: 100%;
}
.ttl_disc {
    font-size: 3.6vw;
    margin-bottom: 2%;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
}
.list_track {
    counter-reset: number 0;
    margin-bottom: 30px;
}
.list_track li {
    position: relative;
    font-size: 3vw;
    border-bottom: 1px dotted #707070;
    padding: 4px 6px 5px 12%;
    display: flex;
    justify-content: space-between;
}
.list_track li:first-child {
    border-top: 1px dotted #707070;
}
.list_track li::before {
    position: absolute;
    left: 10px;
    top: 9px;
    counter-increment: number 1;
    content: counter(number) ". ";
}
.list_track li .name {
    width: calc(100% - 65px);
    padding-top: 4px;
}
.list_track li .audio {
    width: 65px;
    padding-top: 1px;
}
.track_box .txt_head {
    font-size: 3vw;
    line-height: 1.4;
    margin-bottom: 10px;
}
.track_box .txt {
    padding: 0px 5%;
    font-size: 3vw;
    line-height: 1.4;
}
.sub_box {
    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: 3%;
    margin-bottom: 10%;
}
.disco_btns li {
    width: 100%;
    margin-bottom: 15px;
    font-size: 3.4vw;
}
.disco_btns li a {
    display: block;
    background-color: #000000;
    text-align: center;
    line-height: 42px;
    position: relative;
    padding-top: 1px;
    border: 1px solid #999999;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
}
.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: 92%;
    padding: 5%;
    background-color: #000000;
    border: 1px solid #707070;
}
.disco_modal_content .ttl {
    font-size: 5vw;
    margin-bottom: 5%;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    text-align: center;
    line-height: 1;
}
.disco_modal_content .ttl svg {
    width: 20px;
    height: 20px;
    margin-right: 10px;
    position: relative;
    top: 2px;
}
.disco_modal_content .ttl_bldvd {
    font-size: 4.4vw;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    margin-bottom: 5px;
}
.disco_modal_content .att {
    font-size: 2.4vw;
}
.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: 4%;
    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 {
    margin-bottom: 6%;
    background-color: #444444;
    padding: 5%;
}
/*movie 非モーダルで追加*/
.big_mov a, .list_mov li a {
    display: block;
}
/*movie 非モーダルで追加 ここまで*/
.big_mov figure {
    position: relative;
    cursor: pointer;
    margin-bottom: 10px;
}
.big_mov figure:before {
    background-color: rgba(0, 0, 0, 0.1);
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    content: '';
}
.big_mov figure svg {
    position: absolute;
    /*top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);*/
    bottom: 10px;
    left: 10px;
    width: 35px;
    height: 35px;
    fill: #FFFFFF;
}
.big_mov .ttl {
    font-size: 3.2vw;
}
.thumb_list img {
    width: 100%;
}
.bnr_youtube {
    margin-bottom: 6%;
}
.list_mov {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-bottom: 5%;
}
.list_mov::after {
    content: "";
    display: block;
    width: 31%;
}
.list_mov li {
    width: 48%;
    padding: 10px;
    background-color: #444444;
    margin-bottom: 4%;
}
.list_mov li figure {
    position: relative;
    cursor: pointer;
    margin-bottom: 3%;
}
.list_mov li figure:before {
    background-color: rgba(0, 0, 0, 0.1);
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    content: '';
}
.list_mov li figure svg {
    position: absolute;
    /*top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);*/
    bottom: 10px;
    left: 10px;
    width: 26px;
    height: 26px;
    fill: #FFFFFF;
}
.list_mov li .ttl {
    font-size: 2.6vw;
}
#header_login {
    background: linear-gradient(-30deg, #BCA16B 0%, #C1A773 50%, #A3813C 70%, #A9894A 100%);
}
#fc {
    background-color: #FFFFFF;
}
.fanclub_fv {
    position: relative;
    top: 60px;
    width: 100%;
    height: 137%;
    padding: 137% 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_sp.jpg);
}
.login_wrap {
    background-color: #FFFFFF;
    padding: 25px 6%;
    position: relative;
}
.login_wrap .text {
    position: absolute;
    top: -12vh;
    z-index: 10;
    font-family: 'Oswald', sans-serif;
    font-weight: 400;
    font-size: 6vw;
    line-height: 1.3;
    text-shadow: 0 0 6px #333;
}
.login_wrap .text span {
    font-size: 3vw;
    display: block;
    font-family: 'Heebo', sans-serif;
    padding-top: 0.5vh;
}
.login_wrap .logo {
    margin-bottom: 20px;
    text-align: center;
}
.login_wrap .logo img {
    width: 65%;
}
.login_wrap .login_btn {
    text-align: center;
}
.login_wrap .login_btn.mb {
    margin-bottom: 15px;
}
.login_wrap .login_btn a {
    text-align: center;
    display: inline-block;
    width: 80%;
    background: linear-gradient(-30deg, #BCA16B 0%, #C1A773 50%, #A3813C 70%, #A9894A 100%);
    color: #FFFFFF;
    line-height: 5.5vh;
    font-weight: 700;
    transition: 0.2s linear;
    position: relative;
}
.login_wrap .login_btn a svg {
    fill: #FFFFFF;
    width: 30px;
    height: 10px;
    position: absolute;
    top: 45%;
    margin-top: -4px;
    right: 20px;
    transition: 0.2s linear;
}
.login_wrap .login_btn a:hover {
    background: linear-gradient(30deg, #BCA16B 0%, #C1A773 50%, #A3813C 70%, #A9894A 100%);
}
.login_wrap .login_btn a:hover svg {
    right: 10px;
}
.login_wrap .register {
	text-align: center;
	font-size: 14px;
	padding-top: 20px;
}
.login_wrap .register a {
	color: #000000;
	text-decoration: underline;
}
#fanclub .contents {
    z-index: 0;
    position: relative;
    background-color: #333333;
}
#fanclub .contents.pt {
    padding-top: 60px;
}
#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: 30vh;
    width: 100%;
    z-index: -1;
}
#fanclub .contents .inner {
    padding: 35px 5% 35px;
}
.title_fc {
    font-family: 'Oswald', sans-serif;
    font-weight: 500;
    font-size: 9vw;
    text-align: center;
    margin-bottom: 30px;
    line-height: 1;
}
.title_fc span {
    text-align: center;
    font-size: 3vw;
    display: block;
    padding-top: 1vh;
}
.list_benefits {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.list_benefits li {
    width: 48%;
    background-color: #FFFFFF;
    color: #000000;
    padding: 8px;
    margin-bottom: 25px;
}
.list_benefits li figure {
    margin-bottom: 10px;
}
.list_benefits li .ttl {
    font-size: 2.8vw;
    text-align: center;
    /*font-weight: 700;
    border-bottom: 1px solid #888888;
    padding-bottom: 10px;
    margin-bottom: 10px;*/
}
.list_benefits li .txt {
    font-size: 14px;
}
.fc_info {
    background-color: #F4F4F4;
    padding: 15px;
    color: #000000;
    margin-bottom: 20px;
}
.fc_info dl {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.fc_info dl dt {
    padding-bottom: 20px;
}
.fc_info dl dd {
    margin-bottom: 20px;
}
.fc_info dl dt {
    width: 100%;
    font-weight: 700;
    border-bottom: 1px solid #888888;
    padding-bottom: 10px;
    margin-bottom: 10px;
    font-size: 3.6vw;
}
.fc_info dl dd {
    width: 100%;
    font-size: 3.2vw;
}
.fc_info dl dd .att_list {
    font-size: 3.2vw;
}
.fc_info .btns {
    display: flex;
    justify-content: space-between;
    margin-bottom: 20px;
}
.fc_info .btns li {
    width: 48.5%;
}
.fc_info .btns li a {
    display: block;
    font-size: 3.0vw;
    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: 20px;
    font-size: 3.2vw;
    font-weight: 700;
    color: #C30003;
}
.fcfaq_topbox {
    background-color: #F4F4F4;
    padding: 15px;
    color: #000000;
    margin-bottom: 20px;
}
.fcfaq_topbox .txt {
    margin-bottom: 30px;
}
.btn_fc {
    text-align: center;
    margin-bottom: 20px;
}
.btn_fc.mb0 {
    margin-bottom: 0;
}
.btn_fc a {
    text-align: center;
    display: inline-block;
    width: 100%;
    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;
    position: relative;
}
.btn_fc a svg {
    fill: #FFFFFF;
    width: 30px;
    height: 10px;
    position: absolute;
    top: 45%;
    margin-top: -4px;
    right: 20px;
}
.support_links {}
.support_links li {
    width: 100%;
    background-color: #FFFFFF;
    padding: 20px 5%;
    margin-bottom: 20px;
    color: #000000;
}
.support_links li .ttl {
    font-size: 3.6vw;
    font-weight: 700;
    border-bottom: 1px solid #CCCCCC;
    padding-bottom: 10px;
    margin-bottom: 10px;
}
.support_links li .txt {
    font-size: 15px;
    margin-bottom: 15px;
}
.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;
    position: relative;
    font-size: 3.2vw;
}
.support_links li .btn a svg {
    fill: #FFFFFF;
    width: 30px;
    height: 10px;
    position: absolute;
    top: 45%;
    margin-top: -4px;
    right: 10px;
}
.text_contents {
    background-color: #F4F4F4;
    padding: 20px;
    margin-bottom: 20px;
    color: #000000;
    font-size: 3.2vw;
}
.text_contents .ttl_jo {
    font-size: 4vw;
    font-weight: 700;
    margin-bottom: 15px;
    padding-bottom: 10px;
    border-bottom: 1px solid #999999;
}
.text_contents .txt {
    margin-bottom: 30px;
    font-size: 3.2vw;
}
.text_contents .txt.mb10 {
    margin-bottom: 5px;
}
.text_contents .list_num {
    padding-left: 20px;
    font-size: 3.2vw;
    margin-bottom: 30px;
}
.text_contents .list_num li {
    list-style-type: decimal;
    margin-bottom: 5px;
}
.text_contents .num_text {
    margin-bottom: 30px;
    font-size: 3.2vw;
}
.text_contents .num_text dt {
    font-weight: 700;
    margin-bottom: 5px;
}
.text_contents .num_text dd {
    margin-bottom: 20px;
    padding-left: 15px;
}
.faq_navi {
    margin-bottom: 20px;
}
.faq_navi li {
    font-size: 3.2vw;
    margin-bottom: 3px;
}
.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_topbox {
    background-color: #F4F4F4;
    padding: 20px 6%;
    color: #000000;
    margin-bottom: 20px;
}
.faq_topbox .ttl {
    padding-bottom: 15px;
    margin-bottom: 20px;
    border-bottom: 1px solid #999999;
    font-weight: 700;
    font-size: 3.8vw;
}
.faq_topbox .ttl span {
    background-color: #AE0002;
    color: #FFFFFF;
    font-size: 13px;
    display: inline-block;
    margin-right: 10px;
    line-height: 20px;
    padding: 0 10px;
    position: relative;
    top: -2px;
}
.faq_topbox dl dt {
    font-size: 3.8vw;
    font-weight: 700;
    margin-bottom: 8px;
}
.faq_topbox dl dd {
    font-size: 3.2vw;
    margin-bottom: 20px;
}
.faq_topbox dl dd .att_list {
    font-size: 3.2vw;
}
.faq_topbox .card_info {}
.faq_topbox .card_info figure {
    margin-bottom: 20px;
    text-align: center;
}
.faq_topbox .card_info figure img {
    width: 60%;
}
.faq_topbox .card_info .text {
    font-size: 3.2vw;
}
.faq_topbox .card_info .ttl_info {
    font-size: 4vw;
    font-weight: 700;
    margin-bottom: 20px;
}
.faq_topbox .card_info .text p.txt {
    margin-bottom: 15px;
    text-align: left;
}
.faq_topbox .card_info .text p.txt.mini {
    font-size: 2.8vw;
}
.faq_topbox .card_info .text p.txt a {
    text-decoration: underline;
    font-weight: 700;
}
.faq_topbox .card_info .text .btn {}
.faq_topbox .card_info .text .btn a {
    display: block;
    line-height: 34px;
    text-align: center;
    background-color: #000000;
    padding: 0 25px;
    color: #FFFFFF;
    font-weight: 700;
}
.faq_topbox .fc_return_info {
    font-size: 3.2vw;
}
.faq_topbox .fc_return_info .text p {
    margin-bottom: 20px;
}
.faq_topbox .fc_return_info .text p strong {
    font-weight: 700;
    text-decoration: underline;
}
.faq_topbox .fc_return_info .payment {}
.faq_topbox .fc_return_info .payment .box {
    background-color: #FFFFFF;
    padding: 20px;
}
.faq_topbox .fc_return_info .payment .box .ttl_payment {
    font-weight: 700;
    margin-bottom: 10px;
}
.faq_topbox .fc_return_info .payment .box .txt {
    margin-bottom: 10px;
}
.faq_area {
    padding-top: 30px;
}
.ttl_faq_cate {
    background: #000000;
    font-size: 3.8vw;
    font-weight: 700;
    padding: 8px 15px;
}
dl.faq {
    margin-bottom: 30px;
}
dl.faq dt, dl.faq dd {
    color: #000000;
    font-size: 3.6vw;
    background-color: #FFFFFF;
}
dl.faq dd a {
    text-decoration: underline;
    color: #000000;
}
dl.faq dt {
    background-color: #F4F4F4;
    position: relative;
    padding-left: 60px;
    cursor: pointer;
    margin-bottom: 1px;
    padding: 15px 30px 15px 45px;
}
dl.faq dt::before {
    content: "Q.";
    position: absolute;
    top: 10px;
    left: 4%;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 5.4vw;
}
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: 15px;
    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);
    margin-top: -2px;
}
dl.faq dd {
    position: relative;
    cursor: pointer;
    font-size: 15px;
    display: none;
    padding: 15px 15px 15px 45px;
}
dl.faq dd::before {
    content: "A.";
    color: #AE0002;
    position: absolute;
    top: 10px;
    left: 4%;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 5.4vw;
}
.support {
    background-color: #F4F4F4;
    padding: 20px 5%;
    color: #000000;
}
.support .ttl {
    padding-bottom: 15px;
    margin-bottom: 20px;
    border-bottom: 1px solid #999999;
    font-weight: 700;
    font-size: 3.8vw;
}
.support .text p {
    margin-bottom: 20px;
    font-size: 3.2vw;
}
.support .text p a {
    text-decoration: underline;    
}
.support .text p strong {
    font-weight: 700;
}
.support .text p.txt_big {
    font-size: 3.8vw;
    font-weight: 700;
    margin-bottom: 10px;
    color: #2969A6;
}
.support .card {
    margin-bottom: 20px;
}
.support .btn_card a {
    text-align: center;
    display: block;
    background: linear-gradient(-30deg, #BCA16B 0%, #C1A773 50%, #A3813C 70%, #A9894A 100%);
    color: #FFFFFF;
    line-height: 5.5vh;
    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 svg {
    right: 10px;
}
.reentry_example {
    background-color: #E3E3E3;
    padding: 20px;
    font-size: 3.2vw;
    margin-bottom: 30px;
}
.reentry_example .ttl_ex {
    font-size: 3.0vw;
    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: 3.4vw;
    margin-bottom: 5px;
}
.fc_attbox ul li {
    position: relative;
    padding-left: 18px;
    font-size: 3.2vw;
}
.fc_attbox ul li:after {
    content: "※";
    position: absolute;
    top: 0px;
    left: 0px;
}
.fc_attbox ul li a {
    text-decoration: underline;    
}
.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 - 60px);*/
    padding: 30px 6%;
}
.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 {
    position: relative;
    /*top: 30%;*/
    /*transform: translateY(-30%);*/
    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: 3.6vw;
    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: 14px;
    text-decoration: underline;
    position: relative;
    padding-left: 15px;
}
.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: 4vw;
}
.btn_fcform svg {
    fill: #FFFFFF;
    width: 30px;
    height: 10px;
    position: absolute;
    top: 45%;
    margin-top: -4px;
    right: 20px;
    transition: 0.2s linear;
}
#members {
    padding: 0 0 0;
    color: #000000;
}
#members .top_head {
    background: #FFFFFF;
    padding: 2vh 5%;
    width: 100%;
}
#members .top_head .logo {
    text-align: center;
}
#members .top_head .logo img {
    width: 70%;
}
#members .content {
    width: 100%;
    background-image: url("/images/fc/bg_silver.jpg");
    background-size: 100%;
    background-position: top 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 {
    padding: 30px 5%;
}
.title_member {
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 7vw;
    line-height: 1;
    margin-bottom: 15px;
	text-align: left;
}
.list_news_fc {
    margin-bottom: 40px;
}
.list_news_fc li {
    margin-bottom: 15px;
}
.list_news_fc li a {
    display: block;
    background-color: #FFFFFF;
    padding: 12px 5%;
    position: relative;
    box-shadow: 0px 0px 5px 5px rgba(0, 0, 0, 0.1);
}
.list_news_fc li a.nolink {
    pointer-events: none;
}
.list_news_fc li a .update {
    color: #8A8A8A;
    font-size: 3.0vw;
    font-family: 'Heebo', sans-serif;
    font-weight: 400;
    margin-bottom: 5px;
}
.list_news_fc li a .update .mrk {
    background-color: #C91818;
    color: #FFFFFF;
    font-family: 'Heebo', sans-serif;
    font-weight: 500;
    font-size: 3.0vw;
    line-height: 15px;
    width: 50px;
    text-align: center;
    display: inline-block;
    margin-right: 10px;
    position: relative;
    top: -1px;
    padding-top: 1.5px;
}
.list_news_fc li a .ttl {
    font-weight: 700;
    font-size: 3.4vw;
}
.list_news_fc li a svg {
    fill: #666666;
    width: 20px;
    height: 7px;
    position: absolute;
    bottom: 10px;
    right: 10px;
}

.bnr_fc {
    margin-bottom: 20px;
}
.bnr_fc li {
    margin-bottom: 15px;
}
.fc_conts_box {
    background-color: #FFFFFF;
    padding-top: 0px;
    padding-right: 10px;
    padding-left: 10px;
    padding-bottom: 10px;
    position: relative;
    margin-bottom: 40px;
}
.fc_conts_box .date {
    position: absolute;
    left: 0;
    top: 0;
    width: 70px;
    height: 70px;
    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: 12px;
    font-weight: 500;
    margin-bottom: 2px;
    padding-top: 6px;
}
.fc_conts_box .date div span:last-child {
    font-size: 38px;
    font-weight: 500;
}
.fc_conts_box .ttl {
    color: #000000;
    padding-left: 70px;
    padding-top: 10px;
    letter-spacing: 0;
    height: 70px;
    display: flex;
    align-items: center;
    margin-bottom: 10px;
}
.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: 4vw;
    font-weight: 700;
    line-height: 1.4;
}
.fc_conts_box figure {
    position: relative;
    margin-bottom: 8px;
}
.fc_conts_box figure svg {
    position: absolute;
    bottom: 15px;
    left: 15px;
    width: 40px;
    height: 40px;
    fill: #FFFFFF;
}
.fc_conts_box .tweet_box .txt {
    margin-bottom: 8px;
    font-size: 3.2vw;
}
.fc_conts_box .tweet_box .btn_tweet {
    text-align: right;
}
.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: 3vw;
  padding: 12px 4%;
  border: 1px solid #666666;
	margin-bottom: 40px;
	background: #FFFFFF;
}
.fc_conts_box .att_txt {
    font-size: 3vw;
}
.next_info {
    font-family: 'Oswald', sans-serif;
    font-weight: 500;
    font-size: 8vw;
    line-height: 1.0;
    text-align: center;
    letter-spacing: normal;
    background-color: rgba(0,0,0,0.40);
    color: #FFFFFF;
    padding: 20px 0;
    margin-bottom: 100px;
}
.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: 96%;
}
.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: 65vh;
}
.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: 20vw;
    margin-bottom: 10px;
}
.not_found div .sub {
    line-height: 1;
    font-size: 10vw;
    margin-bottom: 30px;
}
.not_found div .txt {
    font-size: 3.6vw;
    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: 50px;
    height: 15px;
    position: absolute;
    top: 50%;
    margin-top: -4px;
    right: -40px;
    transition: 0.2s linear;
}
.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;
    display: block;
    margin: auto;
}
.dt-btn:hover{
    background: #323232;
}

.btn input,.btn a {
	display: block;
	width: 300px;
	text-align:center;
	line-height: 36px;
	background-image: linear-gradient(-45deg, #DBC8A1, #917438, #BCA26C, #A08145);
	background-size: 200% 200%;
	text-align: center;
	font-family: 'Heebo', sans-serif;
	font-weight: 500;
	font-size: 16px;
	margin: auto auto 5px auto;
	color: #fff;
	padding: 5px 0;
}

.btn input:hover,.btn a:hover {
	opacity: 0.5;
}

.ttl2 {
	font-size: 17px;
}

.mt20 {
	margin-top: 20px;
}

.mypage_menu ul {
	flex-wrap:wrap 
}

.mypage_menu li {
	width: 49%;
	padding-top: 8px;
}

.mypage_data_in th,.mypage_data_in td {
	display: block;
	width: 100%;
	box-sizing: border-box;
}

#member-table th,#member-table td {
	display: block;
	width: 100%;
}

#member-table td {
	padding: 15px 0;
}

.mailmaga-form li {
	display: block;
}

.mailmaga-form label,.mailmaga-form input[type="password"],.fogmail input[type=text] {
	width: 100%;
}

.new_pass {
	padding-bottom: 5px;
}

.pass_retype th,td {
	width: 100%;
	display: block;
}

.login_wrap .redframe .spl a {
	font-size: 13px;
	line-height: 150%;
	padding: 10px;
}

.mainte {
	background: #000;
}

.mainte div {
	margin: 40px 10px !important;
}

.mainte h1 {
	margin: 40px auto !important;
}


.mainte p {
	font-size: 18px;
}

.mini-rn {
	font-size: 12px;
	color: #000;
	width: 90%;
	margin: 0 auto;
}

.rn-flow {
	text-align: center;
	font-size: 13px;
	margin-bottom: 25px;
}

.rn-flow a:link,.rn-flow a:hover {
	color: #000;
	text-decoration: underline;
}

.rn-flow a:visited,.rn-flow a:active {
	color: #999999;
	text-decoration: underline;
}