@import url('https://fonts.googleapis.com/css?family=Noto+Serif+JP:300');
@import url('https://fonts.googleapis.com/css?family=Cormorant+Garamond');

html,
body,
a,
p,
ul,
li,
h1,
h2,
h3,
h4,
h5,
h6,
figure{
    margin: 0;
    padding: 0;
}

* {
    box-sizing: border-box;
    letter-spacing: 0.02em;
    font-family: 游明朝, "Yu Mincho", YuMincho, 'Noto Serif JP', "Hiragino Mincho ProN", "Hiragino Mincho Pro", HGS明朝E, メイリオ, Meiryo, serif;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    tap-highlight-color: rgba(0, 0, 0, 0);
}

::selection {
    background: #000000;
    color: #a8afff;
}

/* for Firefox */
::-moz-selection {
    background: #000000;
    color: #a8afff;
}

h3 {
    font-weight: normal;
}

body {
    overflow-x: hidden;
}

img {
    width: 100%;
}

a {
    text-decoration: none;
}

li {
    list-style-type: none;
}

.sp {
    display: none;
}

@media screen and (max-width: 767px) {
    .pc {
        display: none;
    }

    .sp {
        display: block;
    }
}

@media screen and (max-width: 767px) {
    .pc {
        display: none;
    }

    .sp {
        display: block;
    }
}

.modal {
    position: fixed;
    top: 0;
    z-index: 999999999;
    width: 100%;
    height: 100vh;
    display: none;
}

.overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: #000;
    opacity: 0.6;
}

.modal_content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    display: none;
}

img.modal_content {
    width: auto;
    height: auto;
    max-width: 90%;
    max-height: 90%;
}

#youtube {
    width: 80%;
    max-width: 1200px;
}

#youtube .iframe {
    width: 100%;
    padding-bottom: 56.25%;
    height: 0px;
    position: relative;
    background: #000;
}

#youtube iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.close_btn {
    width: 60px;
    height: 60px;
    position: absolute;
    right: 25px;
    top: 15px;
    transition-duration: 0.2s;
    z-index: 99999999;
    transform: rotate(45deg) scale(1, 1);
    cursor: pointer;
}

@media screen and (max-width: 767px) {
    img.modal_content {
        width: auto;
        height: auto;
        max-width: 90%;
        max-height: 70%;
    }

    #youtube {
        width: 100%;
        max-width: 1200px;
    }

    .close_btn {
        width: 40px;
        height: 40px;
        position: absolute;
        right: 15px;
        top: 15px;
        transition-duration: 0.2s;
        z-index: 99999999;
        transform: rotate(45deg) scale(1, 1);
        cursor: pointer;
    }
}

.close_btn::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 50%;
    width: 2px;
    height: 100%;
    margin-left: -1px;
    background: #fff;
}


/* horizontal line */

.close_btn::after {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    height: 2px;
    margin-top: -1px;
    background: #fff;
}

.loading {
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 0;
    background: #fff;
    z-index: 999999999;
}

.loading span {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: block;
    z-index: 13;
    margin: 15px auto;
    width: 100px;
    height: 100px;
    border: 5px solid transparent;
    border-radius: 50%;
    background-color: transparent;
}

.loading span:before {
    position: absolute;
    display: block;
    content: '';
    z-index: 12;
    top: 4px;
    left: 4px;
    width: 82px;
    height: 82px;
    border-radius: 50%;
    background-color: #fff;
}

.loading span:after {
    position: absolute;
    display: block;
    top: 0;
    content: '';
    z-index: 11;
    top: 0px;
    left: 0px;
    width: 45px;
    height: 45px;
    border-radius: 200px 0 0 0;
    background: linear-gradient(45deg, rgba(255, 255, 255, 0) 0%, #70b5ff 25%, #bc90ff 75%, rgba(255, 255, 255, 0) 100%);
    opacity: 0.7;
    animation: loading 0.9s linear infinite;
}

@keyframes loading {
    0% {
        transform-origin: 100% 100%;
        transform: rotate(0deg);
    }

    100% {
        transform-origin: 100% 100%;
        transform: rotate(360deg);
    }
}

.loading.fadeout {
    opacity: 0;
    transition-duration: 0.5s;
}

.wrap {
    opacity: 0;
}

.wrap.fadein {
    opacity: 1;
}

.blur {
    filter: blur(5px);
}

header {
    display: block;
    width: 100%;
    height: 120px;
    padding: 0 25px;
    position: fixed;
    background: #fff;
    top: 0;
    z-index: 999;
    box-shadow: 0 0px 15px rgba(0, 0, 0, .1);
}

header {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

header h1 {
    line-height: 1.2;
    user-select: none;
    font-weight: normal;
    width: 200px;


}

header h1 img {
    font-size: 0;
    display: block;
}

@media screen and (max-width: 1080px) {
    header {
        height: 60px;
        padding: 0 5%;
    }

    header {
        display: flex;
        align-items: center;
        justify-content: space-between;
    }

    header h1 {
        width: 130px;

    }


}

.menu-trigger .trigger_icon span {
    display: inline-block;
    transition: all .4s;
    box-sizing: border-box;
}

.menu-trigger {
    display: none;
}

@media screen and (max-width: 1080px) {
    .menu-trigger {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        justify-content: center;
        cursor: pointer;
    }
}

.trigger_icon {
    position: relative;
    width: 20px;
    height: 16px;
    margin-right: 10px;
    transition-duration: 0.4s;
}

.menu-trigger .trigger_icon span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
}

.menu-trigger .trigger_icon span:nth-of-type(1) {
    top: 0;
    background: #70b5ff;
}

.menu-trigger .trigger_icon span:nth-of-type(2) {
    top: calc(50% - 1px);
    background: #97a2ff;
}

.menu-trigger .trigger_icon span:nth-of-type(3) {
    bottom: 0;
    background: #bc90ff;
}

.menu-trigger.active .trigger_icon {
    transform: rotate(360deg);
}

.menu-trigger.active .trigger_icon span:nth-of-type(1) {
    transform: translateY(7px) rotate(-45deg);
    background-image: linear-gradient(to right, #bc90ff 0%, #70b5ff 100%);
}

.menu-trigger.active .trigger_icon span:nth-of-type(2) {
    opacity: 0;
}

.menu-trigger.active .trigger_icon span:nth-of-type(3) {
    transform: translateY(-7px) rotate(45deg);
    background-image: linear-gradient(to left, #bc90ff 0%, #70b5ff 100%);
}

.menu-trigger .trigger_txt {
    font-size: 14px;
    font-weight: bold;
    color: #666;


}

.menu-trigger .trigger_txt span:first-child {
    display: block;
    font-family: 'Cormorant Garamond', serif;
    letter-spacing: 0.15em;
}

.menu-trigger.active .trigger_txt span:first-child {
    display: none;
}

.menu-trigger .trigger_txt span:last-child {
    display: none;
    font-family: 'Cormorant Garamond', serif;
    letter-spacing: 0.15em;
}

.menu-trigger.active .trigger_txt span:last-child {
    display: block;
}

header nav ul {
    display: flex;
}

header nav ul li {
    border-right: solid 1px #ccc;
    position: relative;
}

header nav ul li a {
    display: block;
    color: #333;
    font-size: 16px;
    font-weight: 900;
    padding: 0 15px;
    line-height: 1.4;
    letter-spacing: 0;
    text-align: center;
    transition-duration: 0.5s;
}

header nav ul li:last-child {
   
    border: none;
}

header nav ul li.sns {
    display: flex;
    align-items: center;
    padding: 0 0 0 10px;
}

header nav ul li.sns a {
    padding: 0 10px;
}

header nav ul li.sns img {
    width: 20px;
}

header nav ul li a:hover {
    opacity: 0.6;
}

header nav ul li::after {
    content: "";
    display: block;
    position: absolute;
    bottom: -15px;
    left: calc(50% - 4px);
    width: 8px;
    height: 8px;
    background-image: linear-gradient(90deg, #c7a2ff 0%, #8bcaff 100%);
    border-radius: 5px;
    transform: translateY(5px);
    opacity: 0;
    transition-duration: 0.5s;
}

header nav ul li.sns::after {
    display: none;
}

header nav ul li:hover::after {
    transform: translateY(0px);
    opacity: 1;
}

header nav ul li a .en {
    display: block;
    font-size: 11px;
    font-family: 'Cormorant Garamond', serif;
    letter-spacing: 0.15em;
}

@media screen and (max-width: 1080px) {
    header nav {
        position: fixed;
        top: 60px;
        left: 0;
        background: #fff;
        width: 100%;
        height: 100%;
        display: none;
    }

    header nav.active {
        display: block;
    }

    header nav ul {
        max-width: 400px;
        margin: 0 auto;
        padding-top: 25px;
        display: flex;
        flex-wrap: wrap;
        justify-content: center;


    }


    header nav ul li {
        width: 45%;
        border-right: none;
        margin-bottom: 25px;
    }

    header nav ul li a {
        padding: 5px 15px;
    }

    header nav ul li.sns {
        justify-content: center;
        padding: 0 0px;
    }

    header nav ul li.sns a {
        padding: 10px;
    }

    header nav ul li.sns img {
        width: 25px;
    }
}

main {
    margin-top: 119px;
    display: block;
}

.top {
    overflow: hidden;
}

.top img {
    display: block;
    font-size: 0;
}

@media screen and (max-width: 1080px) {
    main {
        margin-top: 59px;
        display: block;
    }
}

.cd_info {
    width: 100%;
    display: flex;
    align-items: center;
}

.cd_info .jacket {
    width: 40%;
    min-width: 300px;
}

.cd_info .jacket img {
    border: solid 1px #ddd;
}

.jacket {
    margin-right: 50px;
}

.cd_detail {
    width: 60%;
    padding-bottom: 50px;
}

.cd_info {
    font-size: 50px;
}

.cd_info h3 {
    line-height: 1.2;
   font-size: 55px;
}

.cd_info .date {
    font-size: 50%;
    font-weight: bold;
}

.cd_info .price {
    font-size: 30%;
}

@media screen and (max-width: 767px) {
    .cd_info {
        display: block;
    }

    .cd_info .jacket {
        width: 100%;
        min-width: 0;
    }

    .jacket {
        margin-right: 0px;
    }

    .cd_detail {
        width: 100%;
        padding-bottom: 0px;
    }

    .cd_info {
        font-size: 40px;
    }

    .cd_info h3 {
        line-height: 1.2;
        font-size: 40px;
    }

    .cd_info .date {
        font-size: 50%;
        font-weight: bold;
    }

    .cd_info .price {
        font-size: 30%;
    }
}

.off {
    transition-duration: 1s;
    opacity: 0;
    transform: translateY(25px);
}

.on {
    opacity: 1;
    transform: translateY(0px);
}

.heading {
    width: 50px;
    text-align: center;
    perspective: 2000px;
    margin-right: 25px;
    backface-visibility: hidden;
}

.heading h2 {
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    text-align: left;
    display: inline-block;
    font-family: 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 30px;
    transition-duration: 1s;
    line-height: 1.1;
    user-select: none;
}

.heading h2 span {
    display: inline-block;
    font-weight: normal;

}

.heading h2 span:nth-child(odd) {
    transform: translate(10px, 0px) rotateY(90deg) rotateX(20deg);
    transition-duration: 1.5s;
}

.heading h2 span:nth-child(even) {
    transform: translate(-10px, 0px) rotateY(-90deg) rotateX(-20deg);
    transition-duration: 1.5s;
}

.heading.on h2 span {
    transform: translateX(0px) rotateY(0deg);
}

.heading h2 small {
    display: block;
    opacity: 1;
    font-size: 12px;
    padding-top: 2.6em;
    position: relative;
    color: ##70b5ff;
    background-image: linear-gradient(0deg, #bc90ff 0%, #70b5ff 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.heading h2 small::after {
    content: "";
    position: absolute;
    top: 0.3em;
    left: calc(50% - 1px);
    width: 1px;
    height: 2em;
    background-image: linear-gradient(0deg, #bc90ff 0%, #70b5ff 100%);
    opacity: 0.6;
}

@media screen and (max-width: 767px) {
    .heading {
        width: 100%;
        text-align: center;
        perspective: 2000px;
        margin-right: 25px;
    }

    .heading h2 {
        font-size: 25px;
        margin-bottom: 25px;
    }

    .heading h2 small {
        font-size: 10px;
    }
}


.movie {
    width: 100%;
    height: 700px;
    max-height: 70vh;
    background: rgba(0, 0, 0, 0.3);
    position: relative;
}

.movie video {
    display: none;
}

.play_btn {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    transition-duration: 0.5s;
    cursor: pointer;
}

.play_btn:hover {
    opacity: 0.6;
}

.play_btn img {
    width: 60px;
    margin-bottom: 5px;
}

.play_btn span {
    display: block;
    color: #fff;
    font-weight: bold;
    font-size: 20px;
}

.background-movie {
    position: fixed;
    top: 0;
    left: 0;
    overflow: hidden;
    z-index: -1;
    padding-top: 119px;
}

#sample {
    width: 100%;
    height: 100%;
    transform: scale(1.5, 1.5);
}

@media screen and (max-width: 767px) {
    .movie {
        width: 100vw;
        height: 55vw;
        background: #000;
        position: relative;
        overflow: hidden;
    }

    .movie video {
        width: 100%;
        display: block;
        opacity: 0.7;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }

    .play_btn {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        text-align: center;
    }

    .play_btn img {
        width: 50px;
        margin-bottom: 0px;
    }

    .play_btn span {
        display: block;
        color: #fff;
        font-weight: bold;
        font-size: 14px;
    }

    .background-movie {
        display: none;
    }

    #sample {
        display: none;
    }
}

section {
    background: #fff;
}

.section_flex {
    background: #fff;
}

.section_flex_inner {
    display: flex;
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 100px 0;
    justify-content: space-between;
}

.section_inner {
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 100px 0;
    display: flex;
    align-items: stretch;
}

.section_flex section {
    width: 50%;
    position: relative;
    z-index: 2;


}

.section_flex .section_inner {
    padding: 0;
    width: 100%;
}

.section_flex section:first-child {
    padding-right: 50px;
    margin-right: 50px;
    border-right: solid 1px #ccc;
}

@media screen and (max-width: 767px) {
    .section_flex_inner {
        display: block;
        padding: 0;
    }

    .section_inner {
        display: block;
        padding: 50px 0;
    }

    .section_flex section {
        width: 100%;
        position: relative;
        z-index: 2;
    }

    .section_flex .section_inner {
        padding: 50px 0;
        width: 100%;
    }

    .section_flex section:first-child {
        margin-right: 0px;
        padding-right: 0px;
        border-right: none;
        position: relative;
        z-index: 10;
        border-bottom: solid 1px #ccc;
    }
}





.container {
    width: 100%;
}

#schedule {
    padding-top: 100px;
    margin-top: -100px;
}

#calendar {
    width: 100%;
    position: relative;
}

@media screen and (max-width: 767px) {
    .top_news_list a {
        display: block;
        font-size: 16px;
    }

    .top_news_list a .post_date {
        margin-right: 0em;
        margin-bottom: 5px;
        font-size: 14px;
    }
}

#profile {
    background: url(../img/profile_bg.jpg);
}

.prf_cnt {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.prf_img {
    width: 40%;
}

.prf_txt {
    width: calc(60% - 50px);
    color: #000;
}

.prf_txt p:first-child {
    font-size: 20px;
    margin-bottom: 25px;
    padding-bottom: 25px;
    line-height: 2.5;
    border-bottom: solid 1px #ccc;
}

.prf_txt p:first-child span {
    display: inline-block;
    width: 7em;
    font-weight: bold;
}

.prf_txt p:last-child {
    font-size: 16px;
    line-height: 1.8;
}

.prf_txt p:last-child span {
    display: inline-block;
    font-weight: bold;
    margin-bottom: 0.3em;
    font-size: 20px;
}

.gallery {
    margin-top: 100px;
}

.gallery h3 {
    text-align: center;
    font-size: 24px;
    margin-bottom: 50px;
    padding-bottom: 15px;
    position: relative;
    font-weight: bold;
}

.gallery h3::after {
    content: "";
    display: block;
    position: absolute;
    left: calc(50% - 1em);
    bottom: 0;
    width: 2em;
    height: 3px;
    background-image: linear-gradient(90deg, #c7a2ff 0%, #8bcaff 100%);
}

.gallery_list {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap:25px;
   
}

.gallery_list li {
    overflow: hidden;
    background: #fff;
    cursor: pointer;
    aspect-ratio: 1 / 1;
}

.gallery_list li img {
   width: 100%;
    height: 100%;
    object-fit: cover;
    font-size: 0;
    transition-duration: 0.7s;
}

.gallery_list li:hover img {
    transform: scale(1.05, 1.05);
    opacity: 0.7;
}

@media screen and (max-width: 767px) {

    #profile {
        background: url(../img/profile_bg_sp.jpg);
    }


    .prf_cnt {
        display: block;
    }

    .prf_img {
        width: 100%;
    }

    .prf_txt {
        width: 100%;
    }

    .prf_txt p:first-child {
        font-size: 16px;
        margin-bottom: 15px;
        padding-bottom: 15px;
        line-height: 2.5;
    }

    .prf_txt p:first-child span {
        display: inline-block;
        width: 6em;
        font-weight: bold;
    }

    .prf_txt p:last-child {
        font-size: 16px;
        line-height: 1.8;
    }

    .prf_txt p:last-child span {
        display: inline-block;
        font-weight: bold;
        margin-bottom: 0.3em;
        font-size: 20px;
    }

    .gallery {
        margin-top: 50px;
    }

    .gallery h3 {
        font-size: 20px;
        margin-bottom: 25px;
        padding-bottom: 10px;
    }

    .gallery_list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap:20px;
   
}
}


#blog {
    background: #fafafa;
}

#blog .section_inner{
    justify-content: space-between;
    align-items:flex-start;
}
.instagram{
    display: flex;
    width: calc(50% - 20px);
}
.instagram ul{
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap:10px;
    width: 100%;
}

.instagram li{
    aspect-ratio: 1 / 1;
}

.instagram li img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.blog{
    display: flex;
    width: calc(50% - 20px);
}
.blog_list li {
    border-bottom: solid 1px #eee;
}

.blog_list li:first-child {
    border-top: solid 1px #eee;
}

.blog_list li a {
    display: block;
    color: #666;
    align-items: center;
    padding: 1.5em 1em;
    flex-wrap: wrap;
}

.blog_date {
    opacity: 0.6;
    display: block;
    font-size: 16px;
    width: 10em;
    position: relative;
}


.blog_title {
    font-size: 18px;
    font-weight: bold;
    width: 15em;

}

.blog_txt {
    display: block;
    font-size: 14px;
}



.link_btn {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    padding: 75px 0;
}

.blog_btn {
    font-size: 16px !important;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 10px;
    text-align: center;
    width: 16em;
    border-radius: 10em;
    padding: 1em 0;
    color: #fff !important;
    letter-spacing: 0.07em;
    font-weight: 900;
    transition-duration: 0.5s;
    line-height: 1.8;
    position: relative;
    border: none;
    box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.1);
    margin: 50px auto 0;
}

.instagram .blog_btn{
    background: linear-gradient(45deg, rgba(254, 212, 117, 1) 0%, rgba(229, 61, 93, 1) 50%, rgba(194, 49, 134, 1) 70%, rgba(156, 56, 187, 1) 100%);
}
.blog_btn:hover {
    opacity: 0.6;
}

.blog_btn img {
    display: inline;
    width: 1.5em;
    margin-right: 0.5em;
    filter: brightness(100);
}

.insta_btn {
    background: linear-gradient(120deg, #5478f2 0%, #f23f79 60%, orange 100%);
}

.blog_btn {
    background: #2d8c3c;
}
@media screen and (max-width: 767px) {
    
    .instagram{
        width: 100%;
        display: block;
        margin-bottom: 75px;
    }
    
    .blog{
        width: 100%;
        display: block;
    }
    .blog_list{
        width: 100%;
    }

    .blog_list li {
        border-bottom: solid 1px #eee;
    }

    .blog_list li:first-child {
        border-top: solid 1px #eee;
    }

    .blog_list li a {
        display: block;
        color: #666;
        align-items: center;
        padding: 1em 1em;
    }

    .blog_date {
        opacity: 0.6;
        display: block;
        font-size: 12px;
        width: 10em;
        position: relative;
    }


    .blog_title {
        font-size: 16px;
        font-weight: bold;
        width: 15em;

    }

    .blog_txt {
        display: block;
        font-size: 12px;
    }
    

}

.fanclub_info {
    background: #fff;
    padding: 50px 0;
}

.fanclub_info h3 {
    text-align: center;
    font-size: 30px;
    padding-bottom: 15px;
    margin-bottom: 25px;
    position: relative;
}

.fanclub_info h3::after {
    content: "";
    display: block;
    position: absolute;
    left: calc(50% - 1em);
    bottom: 0;
    width: 2em;
    height: 3px;
    background-image: linear-gradient(90deg, #c7a2ff 0%, #8bcaff 100%);
}


@media screen and (max-width: 767px) {

    .fanclub_info h3 {
        text-align: center;
        font-size: 25px;
        padding-bottom: 15px;
        margin-bottom: 25px;
        position: relative;
    }

}

.fan_club_btn {
    font-size: 18px !important;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 10px;
    text-align: center;
    width: 14em;
    border-radius: 10em;
    padding: 1em 0;
    color: #fff !important;
    letter-spacing: 0.07em;
    font-weight: 900;
    transition-duration: 0.5s;
    line-height: 1.8;
    position: relative;
    border: none;
    box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.1);
    margin: 0 auto 0;
}

.fan_club_btn {
    background-image: linear-gradient(120deg, #bc90ff 0%, #70b5ff 100%);
}

.fan_club_btn:hover {
    opacity: 0.6;
}


@media screen and (max-width: 767px) {

    .link_btn {
        padding: 50px 0;
    }

    .link_btn {
        display: block;
    }

    .link_btn a {
        font-size: 14px !important;
        margin: 0 auto;
    }

    .fan_club_btn {
        margin-bottom: 25px !important;
    }
}

.btn_s {
    font-size: 16px !important;
    display: block;
    margin: 0 auto;
    text-align: center;
    width: 13em;
    background-image: linear-gradient(120deg, #bc90ff 0%, #70b5ff 50%, #bc90ff 100%);
    background-size: 200% auto;
    background-position: 0;
    border-radius: 10em;
    padding: 0.7em 0;
    color: #fff;
    letter-spacing: 0.07em;
    font-weight: 900;
    transition-duration: 0.5s;
    line-height: 1.8;
    position: relative;
    border: none;
    box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.1);
}

.btn_s:hover {
    background-position: 100%;
    opacity: 0.7;
}

.btn_s::after {
    content: "";
    display: block;
    position: absolute;
    right: 15px;
    top: calc(50% - 5px);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 5px 0 5px 8px;
    border-color: transparent transparent transparent #ffffff;
}

.btn_flex {
    display: flex;
    flex-wrap: wrap;
    margin-top: 50px;
}

.btn_flex .btn_s {
    margin: 10px 0;
}

.btn_flex .btn_s:first-child {
    margin-right: 25px;
}

@media screen and (max-width: 767px) {
    .btn_flex {
        display: block;
        margin-top: 50px;
    }

    .btn_flex .btn_s {
        margin: 0px auto;
    }

    .btn_flex .btn_s:first-child {
        margin-right: auto;
        margin-bottom: 25px;
    }
}

#news {
    min-height: calc(100vh - 320px);
}

.news_list {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 20px;
}

.top_news_list{
    margin-bottom:50px; 
}
.news_list figure{
    aspect-ratio: 2 / 1;
    background: #eee;
    overflow: hidden;
}

.news_list img{
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
transition-duration: 0.7s;
}

.news_list a:hover img{
    transform: scale(1.05, 1.05);
    opacity: 0.7;
}

.news_list  a {
    display: block;
    box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.1);
}



.news_list a .post_title {
    font-size: 16px;
    opacity: 0.7;
    padding: 20px;
    color: #000;
    font-weight: bold;
    transition-duration: 0.4s;
}
.news_list a:hover .post_title{
    opacity: 0.2;
}
.news_list a .post_title span{
    font-size: 80%;
    display: block;
    margin-bottom: 10px;
}

.pagination {
    display: flex;
    margin-top: 25px;
    justify-content: center;
}

.news_detail {
    width: 80%;
    margin: 0 auto;
}

.news_detail article {
    margin-bottom: 50px;
}

.news_detail .post_date {
    font-size: 20px;
    margin-bottom: 10px;
}

.news_detail .post_title {
    width: 100%;
    font-size: 25px;
    border-bottom: solid 1px #ccc;
    padding-bottom: 25px;
    margin-bottom: 50px;
    word-wrap: break-word;
}

.pagination p,
.pagination a {
    color: #666;
    font-size: 20px;
    margin: 0 15px;
}

.current {
    opacity: 0.5;
}

.post_txt figure {
    width: 100%;
    height: auto;
    display: block;
    margin: 0 auto;
    margin: 20px 0;
}

.post_txt .youtube {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
}

.post_txt .youtube iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100% !important;
    height: 100% !important;
}

.post_txt img {
    width: auto;
    max-width: 100%;
    display: block;
}

.post_txt a {
    color: #000;
    font-weight: bold;
    text-decoration: underline;
}

@media screen and (max-width: 767px) {
    .news_list{
        grid-template-columns: 1fr;
    }
    .news_list article a {
        display: block;
        font-size: 16px;
    }

    .news_list article a .post_date {
        margin-right: 0em;
        margin-bottom: 5px;
        font-size: 14px;
    }

    .news_detail {
        width: 100%;
    }

    .news_detail .post_date {
        font-size: 14px;
        margin-bottom: 10px;
    }

    .news_detail .post_title {
        width: 100%;
        font-size: 20px;
        border-bottom: solid 1px #ccc;
        padding-bottom: 25px;
        margin-bottom: 50px;
        word-wrap: break-word;
    }

    .pagination p,
    .pagination a {
        color: #666;
        font-size: 18px;
        margin: 0 15px;
    }

    .current {
        opacity: 0.5;
    }

    .post_txt img {
        width: 100%;
        max-width: 100%;
        height: auto;
        display: block;
    }
}

.disco_list {
    width: 100%;
}

.disco_list ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 100%;
    margin: 0 auto;
}

.disco_list li {

    width: calc(33.33% - 25px);
    margin: 0 0 50px;
}

.disco_list .old li {
    width: calc(25% - 15px);
}

.disco_list li a {
    display: block;
}

.disco_list li img {
    width: 100%;
    margin-bottom: 12.5px;
    -webkit-filter: drop-shadow(0px 7px 10px rgba(0, 0, 0, .15));
    filter: drop-shadow(0px 7px 10px rgba(0, 0, 0, .15));
}

.disco_list li p {
    color: #000;
    border-left: solid 5px #ccc;
    padding-left: 7.5px;
    line-height: 1.2;
    font-weight: bold;
    font-size: 18px;
}

.disco_list li p .number {
    display: block;
    font-size: 10px;
    color: #aaa;
    margin-bottom: 15px;
    font-weight: normal;
}

.disco_list li p .date {
    display: block;
    font-size: 14px;
    font-weight: bold;
    margin-bottom: 5px;
}

.disco_list li p .credit {
    display: block;
    font-size: 12px;
    line-height: 1.2;
    margin: 5px 0 10px;
}

.disco_list li p .cw_song {
    font-size: 15px;
}



.disco_list h3 {
    text-align: center;
    font-size: 24px;
    margin-bottom: 50px;
    padding-bottom: 15px;
    position: relative;
    font-weight: bold;
    margin-top: 50px;
}

.disco_list h3::after {
    content: "";
    display: block;
    position: absolute;
    left: calc(50% - 1em);
    bottom: 0;
    width: 2em;
    height: 3px;
    background-image: linear-gradient(90deg, #c7a2ff 0%, #8bcaff 100%);
}

@media screen and (max-width: 767px) {
    .disco_list {
        display: block;
    }

    .disco_list li {
        width: 100%;
        margin: 0 0 50px;
    }

    .disco_list li:last-child {
        display: none;
    }

    .disco_list .old li {
        width: 100%;
    }

    .disco_list h3 {
        font-size: 20px;
        margin-bottom: 50px;
        padding-bottom: 10px;
        margin-top: 25px;
    }

}

#fanclub h3 {
    text-align: center;
    font-size: 24px;
    margin-bottom: 50px;
    padding-bottom: 15px;
    position: relative;
    font-weight: bold;
}

#fanclub h3::after {
    content: "";
    display: block;
    position: absolute;
    left: calc(50% - 1em);
    bottom: 0;
    width: 2em;
    height: 3px;
    background-image: linear-gradient(90deg, #c7a2ff 0%, #8bcaff 100%);
}

.special {
    border-bottom: solid 1px #ccc;
    padding-bottom: 100px;
}

.special ul {
    display: flex;
    flex-wrap: wrap;
}

.special ul li {
    width: 50%;
    text-align: center;
}

.special ul li img {
    width: 100%;
}

.special ul li p {
    font-size: 18px;
    font-weight: bold;
    line-height: 1.2;
}

.special ul li p span {
    font-size: 14px;
}

.expenses {
    font-size: 30px;
    text-align: center;
    font-weight: bold;
    border-bottom: solid 1px #ccc;
    padding-bottom: 100px;
}

.expenses span {
    display: block;
    font-size: 14px;
}

.expenses h3 {
    margin-top: 100px;
}

.app h3 {
    margin-top: 100px;
    position: relative;
}

.app p {
    text-align: center;
}
.app a {
    color: #000;
    text-decoration: underline;
}

.addition span {
    font-size: 14px;
    font-weight: bold;
}



@media screen and (max-width: 767px) {
    #fanclub h3 {
        font-size: 20px;
        margin-bottom: 25px;
        padding-bottom: 10px;
    }

    .special {
        border-bottom: solid 1px #ccc;
        padding-bottom: 50px;
    }

    .special ul li {
        width: 100%;
        margin-bottom: 25px;
    }

    .special ul li p {
        font-size: 16px;
    }

    .special ul li p span {
        font-size: 12px;
    }

    .expenses {
        font-size: 18px;
        padding-bottom: 50px;
    }

    .expenses span {
        display: block;
        font-size: 12px;
    }

    .expenses h3 {
        margin-top: 50px;
    }

    .app h3 {
        margin-top: 50px;
        position: relative;
    }

    .app p {
        text-align: center;
        font-size: 14px;
    }

    .addition span {
        font-size: 12px;
        font-weight: bold;
    }

    .addition a {
        font-size: 15px;
        font-weight: bold;
        color: #000;
        text-decoration: underline;
    }
}

/*フォーム*/

.app form {
    width: 600px;
    margin: 50px auto;
    font-size: 18px;
}

.contact_form form {
    width: 100%;
    max-width: 700px;
    margin: 0 auto;
    font-size: 18px;
}

form dl {
    margin-bottom: 25px;
    display: flex;
}

form dt {
    width: 25%;
    font-weight: bold;
    color: #666;
}

form dd {
    width: 75%;
}

form dd input[type="text"],
form dd input[type="email"] {
    width: 100%;
    padding: 0.4em 1em;
    font-size: 14px;
    background: #fcfcfc;
    border: solid 1px #ccc;
    border-radius: 3px;
    box-shadow: 3px 3px 5px rgba(0, 0, 0, 0.05);
}

.contact_form form dd input[type="text"],
.contact_form form dd input[type="email"] {
    width: 80%;
}

form dd textarea {
    width: 100%;
    height: 10em;
    padding: 0.4em 1em;
    font-size: 14px;
    background: #fcfcfc;
    border: solid 1px #ccc;
    border-radius: 3px;
    box-shadow: 3px 3px 5px rgba(0, 0, 0, 0.05);
    resize: none;
}

#form_submit {
    margin-top: 50px;
}

@media screen and (max-width: 767px) {
    .app form {
        width: 100%;
        margin: 25px auto 50px;
        font-size: 16px;
    }

    .contact_form form {
        width: 100%;
        margin: 0 auto;
        font-size: 16px;
    }

    form dl {
        margin-bottom: 25px;
        display: block;
    }

    form dt {
        width: 100%;
        font-weight: bold;
        color: #666;
        margin-bottom: 10px;
    }

    form dd {
        width: 100%;
        margin: 0;
    }

    form dd input[type="text"],
    form dd input[type="email"] {
        width: 100%;
        padding: 0.4em 1em;
        font-size: 14px;
        background: #fcfcfc;
        border: solid 1px #ccc;
        border-radius: 3px;
        box-shadow: 3px 3px 5px rgba(0, 0, 0, 0.05);
    }

    .contact_form form dd input[type="text"],
    .contact_form form dd input[type="email"] {
        width: 80%;
    }

    form dd textarea {
        width: 100%;
        height: 10em;
        padding: 0.4em 1em;
        font-size: 14px;
        background: #fcfcfc;
        border: solid 1px #ccc;
        border-radius: 3px;
        box-shadow: 3px 3px 5px rgba(0, 0, 0, 0.05);
        resize: none;
    }
}

/*会社概要*/

.contact_form {
    margin: 0 auto;
    width: 100%;
}

#company {
    background: #f3f3f3;
    min-height: calc(100vh - 300px);
    display: flex;
    align-items: center;
}

#company p {
    margin: 0 auto;
    line-height: 2;
}


/*サンクスページ*/
.thanks {
    height: calc(100vh - 120px);
    position: relative;
}

.thanks div {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.thanks p {
    text-align: center;
    margin-bottom: 50px;
}



.thanks span {
    font-size: 30px;
    display: block;
    margin-bottom: 10px;
}

.news_detail .btn_s::after,
.thanks .btn_s::after {
    display: none;
}

@media screen and (max-width: 767px) {

    .thanks {
        height: 100%;
        position: relative;
        padding: 50px 0;
    }

    .thanks div {
        position: static;
        top: 50%;
        left: 50%;
        transform: translate(0, 0);
    }

    .thanks p {
        text-align: center;
        margin-bottom: 25px;
        font-size: 14px;
        padding: 0px 5%;
    }



    .thanks span {
        font-size: 20px;
        display: block;
        margin-bottom: 10px;
    }
}


/*フッター*/

footer {
    padding: 50px 0;
    background-image: linear-gradient(120deg, #bc90ff 0%, #70b5ff 100%);
}

footer ul {
    width: 650px;
    margin: 0 auto 10px;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}

footer ul li a {
    display: block;
    color: #fff;
    padding: 0 15px;
    margin-bottom: 10px;
    transition-duration: 0.6s;
}
footer a {
    transition-duration: 0.6s;
}
footer a:hover {
    opacity: 0.6;
}

footer .sns {
    display: flex;
    justify-content: center;
}

footer .sns a {
    display: block;
    margin: 0 10px;
    width: 25px;
    filter: brightness(100);
}

footer .bnr{
    display: block;
    width: 260px;
    margin: 0 auto;
}

footer .bnr img{
    display: block;
}
footer .copy {
    text-align: center;
    font-size: 12px;
    color: #fff;
    margin-top: 25px;
}

@media screen and (max-width: 767px) {
    footer ul {
        width: 100%;
        margin: 0 auto 25px;
        display: block;
    }

    footer li {
        text-align: center;
        margin-bottom: 10px;
    }

    footer ul li a {
        display: block;
        color: #fff;
        padding: 0 15px;
        margin-bottom: 20px;
    }

    footer .foot_sns {
        display: flex;
        justify-content: center;
    }

    footer .foot_sns a {
        margin: 0 10px;
        width: 25px;
    }
    
    footer .bnr{
        width: 230px;
    }

    footer .copy {
        text-align: center;
        font-size: 12px;
        color: #fff;
        margin-top: 25px;
    }
}
