@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Outfit:wght@100..900&display=swap');

body{
    font-size:16px;
    font-family: "Noto Sans JP", sans-serif;
    line-height:1.6em;
    letter-spacing:0.05em;
    color:#436e87;
    background:#eef1f4;
    min-height:100vh;
    position:relative;
}

a{
    color:#436e87;
}

.fa-classic, .fa-regular, .fa-solid, .far, .fas{
    font-family: "Noto Sans JP", sans-serif !important;
    font-weight:normal !important;
}

.fa-classic:before,
.fa-regular:before,
.fa-solid:before,
.far:before,
.fas:before{
    font-family: "Font Awesome 6 Free";
    font-weight:900;
}

.btnara{
    text-align:center;
}

.btnara .btn{
    padding:.5em 1em;
    background:#436e87;
    color:#fff;
    width:300px;
    text-align:center;
    display:block;
    max-width:80%;
    margin:1em auto;
    font-weight:700;
}

.btnara .btn.sub{
    border:solid 1px;
    color:#436e87;
    background:none;
}


@media screen and (max-width:961px){
    body:before{
        content:'';
        background-size:300%;
        filter:blur(2px);
    }
}

.sp{
    display:none !important;
}

@media screen and (max-width:961px){
    .pc{
        display:none !important;
    }

    .sp{
        display:block !important;
    }
}

.wrap{
    overflow:hidden;
    position:relative;
    z-index:1;
}

.inr{
    width:1024px;
    max-width:90%;
    margin:0 auto;
    position:relative;
    z-index:1;
}


section{
    position:relative;
    overflow:hidden;
}

section:after{
    content: '';
    font-size: 10vw;
    color: #436e8720;
    position: absolute;
    top: 0;
    left: 0;
    transform: rotate(-1deg);
    font-weight: 900;
    letter-spacing: -.05em;
    z-index: 0;
    line-height: .6em;
    font-family: "Outfit", sans-serif;
}

section.mainvisual:after{
    content: 'WILD BUNNY BLUES';
    line-height: .7em;
}

section.notes:after{
    content:'LINER';
}

section.tour:after{
    content:'TOUR';
}

section.listen:after{
    content:'SUBSCRIPTION';
}

section.buy:after{
    content:'STORE';
}

section.event:after{
    content:'EVENT';
}

section .inr{
    padding:3em 0;
    position:relative;
    top:3em;
    opacity:0;
    transition:.3s;
}

section .inr.started{
    top:0;
    opacity:1;
}

@media screen and (max-width:961px){
    section{
        padding:1.5em 0;
    }
}


*{
    margin:0;
    padding:0;
    list-style:none;
    font-style:normal;
    font-weight:400;
    text-decoration:none;
    box-sizing:border-box;
}

img{
    max-width:100%;
}

.loading {
    min-height:100svh;
    position:fixed;
    top:0;
    width:100%;
    transition:.3s;
    z-index:1;
    background:#fff;
    background-size:cover;
    z-index:2;
}

.loading span{
    position: absolute;
    transform: translate(-50%, -50%);
    top: 50%;
    left: 50%;
    font-weight:800;
    color:#190e0a;
    text-align:center;
}

@media screen and (max-width:961px){
    .loading .sp{
        display:inline !important;
    }
}


.loading .logo{
    z-index:3;
}

.loaded .loading{
    top:-100vh;
}

.logo {
    width:60%;
    position:absolute;
    transform:translate(-50%, -50%);
    top:50%;
    left:50%;
    transition:.3s;
    filter: drop-shadow(5px 5px 10px #fff) drop-shadow(-6px -5px 10px #fff);
}

.logo img{
    display:block;
    margin:0 auto;
    /* scale:0; */
    transition:.1s .2s;
}

.logo img.pc,
.logo img.sp{
    filter: drop-shadow(0px 6px 0px #998268);
}

.logo .txt{
    margin-top:.5em;
    text-align:center;
    color:#000;
}

.logo .txt span{
    display:block;
    margin-top:.5em;
    font-weight:700;
    filter: drop-shadow(2px 4px 4px #fff) drop-shadow(-4px -2px 4px #fff);
}




h2{
    font-family: "Outfit", sans-serif;
    text-align:center;
    margin:.5em 0 1em;
    font-weight:normal;
    font-size:2.5em;
    line-height:1em;
    font-weight:900;
}


h3{
    font-weight:bold;
}

.box{
    padding:2em;
    background:#ffffffaa;
    border-radius:1.3em;
    position:relative;
    text-align:center;
    box-shadow: 1px 3px 10px #00000050 inset;
}


.player{
    width:100%;
    padding-top:56.25%;
    position:relative;
}

.player iframe{
    width:100%;
    height:100%;
    position:absolute;
    top:0;
    right:0;
}


.mainvisual{
    /* background:url(../img/bg_loading.png); */
    background-size:cover;
    padding:70px 0 3em;
    top:0;
    opacity:1;
    height:auto;
    min-height: 750px;
}

.mainvisual:before{
    content:'';
    background:url(../img/jkt.jpg) center top no-repeat;
    position:absolute;
    top:0;
    width:150%;
    height: 100%;
    background-size:cover;
    filter:blur(10px);
}

.mainvisual .logo{
    position:relative;
    transform:translate(0, 0);
    left:0;
    margin:0 auto;
    width:640px;
    padding:1.5em 0;
    max-width:80%;
    transition:.3s .3s;
    top:3em;
    opacity:0;
    animation: purun 10s 1s infinite;
}

.loaded .mainvisual .logo{
    top:0;
    opacity:1;
    z-index:1;
}

.mainvisual .logo .txt{
    top:-1.5em;
}

.mainvisual .caption {
    font-weight:normal;
    padding: 0.5em; ;
    text-align:center;
    /* background:#6ddcff; */
    background:#4f9ed680;
    color:#fff;
    font-size: 1.3em;
    line-height:1.6em;
    box-shadow: 1px 1px 10px #00000050 inset;
}

.mainvisual .caption p{
    font-weight:700;
}

section:nth-child(even) {
    background:#ffffff30;
}

.notes .detail{
    display:flex;
    flex-wrap:wrap;
    justify-content:space-between;
    align-items:center;
}

.notes .detail > div{
    width:49%;
}

.notes .detail_txt{
    font-size:.8em;
    line-height:1.5em;
}

.notes .detail_txt h4{
    font-size:1.1em;
    font-weight:bold;
    margin-bottom:.5em;
}

.notes .detail_txt .dtl_txt{
    background:#ffffff80;
    padding:1em;
}

.notes .detail_txt ol{
    font-size:1.1em;
    margin:.5em 0;
    line-height:1.7em;
}

.notes .liner_ara{
    margin-bottom:2.5em;
    background:#ffffffcc;
    padding:1.5em;
}

.notes .liner_ara .txt_liner{
    color:#666;
}

.notes .liner_ara .txt_liner h3{
    text-align:center;
}

.notes .liner_ara .txt_liner .writer{
    text-align:right;
    font-size:.8em;
}

.notes .liner_ara .txt_liner .caption{
    text-align:left;
    font-weight:500;
}

.notes .liner_ara .txt_liner .liner_year{
    margin:2em 0;
}

.notes .liner_ara .txt_liner h5{
    font-size:1.05em;
    font-weight:500;
}

.notes .liner_ara .txt_liner p{
    margin:1em 0;
    font-size:14px;
}

.notes .liner_ara .more-link-after a{
    display:block;
    text-align:center;
    background:#436e8709;
    padding:.5em;
    margin-top:1em;
}

.listen .inr > div,
.buy .inr > div{
    padding:2em 0;
}



.listen ul,
.buy ul{
    display:flex;
    flex-wrap:wrap;
    justify-content:space-between;
}

.listen .subscription ul{
    width:500px;
    margin:1em auto;
    max-width:80%;
}

.listen .subscription ul li{
    width:calc(100% / 6 - 1.5em);
}

.buy  h4{
    font-weight:600;
    font-size:1.4em;
    text-align:center;
    margin-bottom:.5em;
}

.buy  #ec-link ul{
    justify-content:flex-start;
}

.buy  #ec-link ul li{
    display:inline-block;
    margin:0 .3em .5em;
}

.buy  #ec-link ul li a{
    border: 1px solid #cccccc;
    background: #ffffff;
    border-radius: 5px;
    box-shadow: inset -4px -4px 12px rgba(0, 0, 0, 0.06);
    position: relative;
    display: block;
    padding: 0.6em 1em;
    color: #336699 !important;
    text-decoration: none;
}

.buy  #ec-link ul li a:before{
    margin-right:.5em;
    font-size:.8em;
}

.buy  #ec-link p{
    margin:1em .5em 1em;
    color:#666600;
    padding-left: 1.5em;
    text-indent: -1.5em;
    line-height: 1.2em;
}

.buy  #ec-link p:before{
    margin-right:.5em;
    font-size:.8em;
}

.buy .toku ol{
    display:flex;
    flex-wrap:wrap;
    justify-content:space-between;
}

.buy .toku ol li{
    width:calc(100% / 3 - .25em);
    background:#fff;
    margin-bottom:.3em;
    padding:.5em;
    position:relative;
}

.buy .toku ol li.end:after{
    content:'期間終了';
    background:#cc2222dd;
    color:#fff;
    position:absolute;
    transform:rotate(-5deg) translate(-50%, -50%);
    top:50%;
    left:50%;
    padding:.5em 1em;
    letter-spacing:.1em;
    min-width:5em;
    text-align:center;
}

.buy .toku ol li span{
    display:block;
    text-align:center;
    font-weight:600;
    font-size:.9em;
}

.buy .toku ol li figure{
    position:relative;
    width:100%;
    padding-top:100%;
}

.buy .toku ol li figure img{
    position:absolute;
    width:100%;
    height:100%;
    transform:translate(-50%, -50%);
    top:50%;
    left:50%;
    object-fit:contain;
}

.buy .toku ol li em{
    position:absolute;
    transform:translate(-50%, 0);
    bottom:.5em;
    left:50%;
    background:#436e87;
    color:#fff;
    padding:0 .5em;
    font-size:.8em;
}

.tour h3{
    margin-bottom: .5em;
    font-family: "Outfit", sans-serif;
    font-weight: 900;
    font-size:1.7em;
    color: #5d80a5;
}

.tour .dateara{
    width:640px;
    margin:0 auto;
    max-width:100%;
}

.tour ul{
    margin-bottom:2em;
}

.tour ul li{
    font-size:1.5em;
    line-height:1.7em;
    border-bottom:solid 1px #5d80a520;
    padding:0 .5em;
    font-family: "Outfit", 'Noto sans JP', sans-serif;
}

.tour ul li *{
    font-weight:700;
}

.tour ul li > span{
    min-width:5em;
    display:inline-block;
    font-family: "Outfit", sans-serif;
    text-align: right;
    margin-right: .5em;
}

.tour ul li em{
    font-size: .7em;
    min-width: 3em;
    display: inline-block;
    text-align: right;
}

.tour ul li i{
    font-size:.8em;
    min-width:3.5em;
    margin-right:.5em;
    display:inline-block;
    text-align:center;
}

.tour ol{
    display:flex;
    justify-content:space-between;
    width:200px;
    margin:1em auto;
}

.tour ol li{
    width:calc(100% / 3 - .25em);
}

.tour ol li a{
    background:#000;
    border-radius:10px;
    display:block;
    padding:.3em;
    line-height:1em;
}

.tour ol li.pia a{background:#3264c8}
.tour ol li.lawson a{background:#0074be}
.tour ol li.eplus a{background:#e85298}


.event h4{
    text-align:center;
    font-weight:800;
}

.event .text p{
    text-align:center;
}

.event .text p:nth-child(1){
    text-align:center;
    margin:1em 0;
}

.event .text p span{
    background:#436e87;
    color:#fff;
    padding:.2em 1em;
}

.event .text .caution{
    font-size:.8em;
    margin:1em;
}

.event .text .caution li{
    padding-left:1em;
    text-indent:-1em;
}

.event .single_show{
    padding:2em 0;
    position:relative;
}

.event .single_show .zu{
    position:absolute;
    width:20%;
    right:0;
    top:0;
}

.event .inr .single_show:nth-child(1){
    padding:0 0 2em;
    border-bottom:solid 1px #436e87;
}

.event .text .caution em{
    display:block;
    margin-top:1em;
    text-indent:0;
}

@media screen and (max-width:961px){
    body{
        background-size:70vw;
    }

    section:after{
        font-size:15vw;
    }

    .mainvisual{
        height:100vh;
    }
    .mainvisual .logo{
        width: 90%;
        transform: translate(-50%, -50%);
        position:absolute;
        top:60%;
        left:50%;
    }

    .loaded .mainvisual .logo{
        top:50%;
        max-width:500px;
    }

    .logo .txt{
        top:-1em;
        width:100%;
        padding:.5em 1em;
    }

    .logo .prd{
        width:95%;
        margin-top:-.5em;
    }

    .mainvisual{
        padding:0 0 1.5em;
    }
    .mainvisual .logo{
        padding:0 0 2em;
    }
    .mainvisual .caption{
        font-size:.9em;
    }

    .notes .detail > div{
        width:100%;
        margin-bottom:1em;
    }

    .buy .toku ol li{
        width:calc(100% / 2 - .25em);
        margin-bottom:.5em;
    }

    .buy #ec-link ul{
        font-size:.8em;
    }

    .buy .toku ol li em{
        min-width:10em;
        text-align:center;
    }

    .tour ul li{
        display:flex;
        font-size:1.2em;
    }

    .tour ul li strong{
        display:flex;
        text-align:left;
    }

    .tour ul li strong span{
        text-align:left;
    }

    .tour ul li strong em{
        width:100%;
        text-align:left;
        line-height:1em;
    }


    .listen .subscription ul li {
        width: calc(100% / 3 - 1em);
        margin-bottom:1em;
    }
}


footer{
    font-family: "Noto Sans JP", sans-serif;
    background: #436e87;
    padding:1em;
    text-align:center;
    color:#fff;
    margin-top:5em;
    position:relative;
}

footer span{
    margin:0 0.5em;
}

footer span em{
    font-size:1.3em;
}

@media screen and (max-width:961px){
    footer span{
        display:block;
        margin-bottom:.3em;
    }
}

