@charset "utf-8";
:root {
    
    /* ======================================================
       Font
    ====================================================== */
    --font-base: "Shippori Mincho", serif;

    /* ======================================================
       Colors
    ====================================================== */
    /* Primitive (数値そのもの) */
    --color-black: #000000;
    --color-gray: #adadad;
    --color-white: #ffffff;
    --color-primary-light: #f8fcff;
    --color-primary: #669DD7;
    --color-primary-dark: #357bc5;

    /* Semantic (用途固定) */
    --color-bg-primary: var(--color-primary-light);
    --color-bg-inverse: var(--color-primary);
    --color-bg-section: var(--color-white);
    --color-bg-light: #669DD710;

    --color-text-primary: var(--color-primary);
    --color-text-inverse: var(--color-white);

    --color-btn-primary: var(--color-primary);
	--color-btn-inverse: var(--color-white);

    --color-tag-primary: var(--color-primary);
    --color-tag-inverse: var(--color-white);

    /* ======================================================
       4px Grid (spacing)
    ====================================================== */
    --space-1: 4px;
    --space-2: 8px;
    --space-3: 12px;
    --space-4: 16px;
    --space-5: 20px;
    --space-6: 24px;
    --space-7: 28px;
    --space-8: 32px;
    --space-9: 36px;
    --space-10: 40px;
    --space-12: 48px;
    --space-14: 56px;
    --space-16: 64px;
    --space-20: 80px;

    /* ======================================================
       Section専用スケール (ページレイアウト用)
    ====================================================== */
    --section-ratio-last: 1.5;  
    --section-base-pc: calc(var(--space-16) * 3);
    --section-base-sp: calc(var(--space-16) * 2);
    --section-base-last-pc: calc(var(--section-base-pc) * var(--section-ratio-last));
    --section-base-last-sp: calc(var(--section-base-sp) * var(--section-ratio-last));

    /* ======================================================
       Radius
    ====================================================== */
    --radius-s: 4px;
    --radius-m: 8px;
    --radius-full: 9999px; /* 完全円形用 */

    /* ======================================================
       Z-index - 基本レイヤー
    ====================================================== */
    --z-background: -1;   /* 背景 */
    --z-base: 1;         /* 通常コンテンツ */
    --z-content: 10;     /* メインコンテンツ */
    --z-footer: 20;     /* フッター */
    --z-nav: 30;         /* ナビゲーション */
    --z-nav-btn: 31;     /* ナビゲーションボタン */
    --z-loader: 100;      /* ローダー */

    /* ======================================================
       Elevation (Surface)
    ====================================================== */
    --elevation: 0 0px 16px #357bc525;

}



/*===================================================
  anim
====================================================*/
.js .loader{
    position: fixed;
    height: 100%;
    width: 100%;
    background: var(--color-bg-inverse);
    z-index: var(--z-loader);
    pointer-events: none;
}

.js .action.act01 {
    transform: scale(0.9);
    opacity:0;
    transition: 1s ease-out;
}
.js .loaded .action.act01 {
    transform: scale(1);
    opacity:1;
    transition-delay: 1.5s;
}

.js .action.act02 {
    opacity:0;
    transition: 1s ease-out;
}
.js .loaded .action.act02 {
    opacity:1;
    transition-delay: 2s;
}

.js #fv .fvInner,
.js #fv .artistLogo,
.js #fv .scrollBox,
.js #fv .snsList,
.js #fv .decoBox span img {
    transition: all .5s ease;
}
.js .scrolled #fv .fvInner,
.js .scrolled #fv .artistLogo,
.js .scrolled #fv .scrollBox,
.js .scrolled #fv .snsList,
.js .scrolled #fv .decoBox span img {
    opacity: 0;
}
.js .scrolled #fv .fvInner,
.js .scrolled #fv .decoBox span img {
    transform: scale(0.9);
}

.js .anim.fadeX,
.js .anim.fadeY {
    opacity: 0;
    transition: all .5s ease-out;
}
.js .anim.fadeX {
    transform: translateX(20px);
}
.js .anim.fadeY {
    transform: translateY(20px);
}
.js .anim.fadeX.on,
.js .anim.fadeY.on {
    opacity: 1;
}
.js .anim.fadeX.on {
    transform: translateX(0px);
}
.js .anim.fadeY.on {
    transform: translateY(0px);
}

@media screen and (max-width: 960px){}


/*===================================================
    bgBox
====================================================*/
.bgBox {
    position: absolute;
    z-index: var(--z-background);
    inset: 0;
    background: var(--color-bg-primary);
    overflow: hidden;
    pointer-events: none;
}
.bgBox .bg {
    position: absolute;
    inset: 0;
}
.bgBox .bg01 {
    z-index: 1;
    background: url(/static/stu48/fansite/feature/9th_aniv/image/bg_0r3C0u5k.jpg);
    background-position: center top;
    background-size: contain;
    background-repeat: repeat-y;
    mix-blend-mode: color-burn;
    opacity: 0.8;
}
.bgBox .bg02 {
    z-index: 2;
    background: url(/static/stu48/fansite/feature/9th_aniv/image/bg_sub_01_0r3C0u5k.png);
    background-position: center top;
    background-size: contain;
    background-repeat: repeat-y;
    will-change: transform;
}
.bgBox .bg03 {
    z-index: 3;
    background: url(/static/stu48/fansite/feature/9th_aniv/image/bg_sub_02_0r3C0u5k.png); 
    background-position: center top;
    background-size: contain;
    background-repeat: repeat-y;
    will-change: transform;
}


@media screen and (min-width: 961px) {}

@media screen and (max-width: 960px) {

    .bgBox {}
    .bgBox .bg {}
    .bgBox .bg01 {
        background: url(/static/stu48/fansite/feature/9th_aniv/image/bg_sp_0r3C0u5k.jpg);
        background-position: center top;
        background-size: contain;
        background-repeat: repeat-y;
    }
    .bgBox .bg02 {
        background: url(/static/stu48/fansite/feature/9th_aniv/image/bg_sub_01_sp_0r3C0u5k.png);
        background-position: center top;
        background-size: contain;
        background-repeat: repeat-y;
    }
    .bgBox .bg03 {
        background: url(/static/stu48/fansite/feature/9th_aniv/image/bg_sub_02_sp_0r3C0u5k.png); 
        background-position: center top;
        background-size: contain;
        background-repeat: repeat-y;
        opacity: 0.6;
    }

}


/*===================================================
	nav
====================================================*/
.navList {
    position: fixed;
    z-index: var(--z-nav);
    top: var(--space-6);
    right: var(--space-6);
    display: flex;
    gap: var(--space-4);
    flex-direction: column;
    align-items: flex-end;
}
.navList li {}
.navList li img { height: 32px; }
.navList li.middle img { height: 36px; }
.navList li.large img { height: 40px; }
.navList li:nth-child(6) {margin-top: -4px;}

@media screen and (min-width: 961px) {

    .hamBtn,
    .navigation {
        display: none;
    }

}

@media screen and (max-width: 960px) {

    .navList {
        display: none;
    }

    .hamBtn {
        position: fixed;
        z-index: var(--z-nav-btn);
        right: var(--space-4);
        top: var(--space-4);
        display: block;
        width: 40px;
        height: 40px;
        background: var(--color-btn-primary);
        transition: all .3s ease;
        border-radius: var(--radius-full);
    }
    .hamBtn.open {}
    .hamBtn span {
        position: absolute;
        display: block;
        right: 20%;
        width: 60%;
        height: 2px;
        background: var(--color-btn-inverse);
        transition: all .3s ease;
    }
    .hamBtn :nth-of-type(1) {
        top: 12px;
    }
    .hamBtn :nth-of-type(2) {
        top: 50%;
        transform: translateY(-50%);
    }
    .hamBtn :nth-of-type(3) {
        bottom: 12px;
    }
    .hamBtn.open span {}
    .hamBtn.open span:nth-of-type(1) {
        transform: translateY(-50%) rotate(-45deg);
        top: 50%;
    }
    .hamBtn.open span:nth-of-type(2) {
        opacity: 0;
    }
    .hamBtn.open span:nth-of-type(3) {
        transform: translateY(50%) rotate(45deg);
        bottom: 50%;
    }

    .navigation {
        position: fixed;
        z-index: var(--z-nav);
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        color: var(--color-text-inverse);
        transition: all 0.5s ease-out;
        opacity: 0;
        pointer-events: none;
    }
    .navigation.active {
        transition: opacity 0.5s ease;
        opacity:1;
        pointer-events:auto;
    }

    .navigation .headerNavBox {
        background: var(--color-bg-primary);
        margin: 0 auto;
        position: fixed;
        top: 0;
        width: 100vw;
        height: 100vh;
        box-sizing: border-box;
        transition: all 0.5s ease;
        display: flex;
        flex-direction: column;
        text-align: center;
        align-items: center;
        justify-content: center;
        flex-flow: column;
    }
    .navigation .headerNavBox .headerNav {}

    .navigation .headerNav li {
        position: relative;
        padding: 0;
        margin: 0 0 var(--space-4);
    }
    .navigation .headerNav li:nth-child(1) {}
    .navigation .headerNav li:nth-child(2) {margin-bottom: 14px;}
    .navigation .headerNav li:nth-child(3) {}
    .navigation .headerNav li:nth-child(4) {}
    .navigation .headerNav li:nth-child(5) {margin-bottom: 12px;}
    .navigation .headerNav li:last-child {
        margin: 0;
    }

    .navigation .headerNav li img {
        height: 40px;
        width: auto;
        margin: 0 auto;
    }
    .navigation .headerNav li.middle img { height: 44px; }
    .navigation .headerNav li.large img { height: 48px; }

}


/*===================================================
	all
====================================================*/
html {
    scroll-behavior: smooth;
    scroll-padding-top: 128px;
    background: var(--color-bg-primary);
}

body {
    background: var(--color-bg-primary);
}

.mainWrap {
    position: relative;
    z-index: var(--z-base);
    font-family: var(--font-base);
	font-size: 16px;
    color: var(--color-text-primary);
    line-height: 1.5;
    overflow: hidden;
}
.mainWrap img {
	display: block;
}

.container {
    position: relative;
    z-index: var(--z-content);
}

section {
    padding-bottom: var(--section-base-pc);
}
section:last-of-type {
    padding-bottom: var(--section-base-last-pc);
}

section .inBox {
    position: relative;
    z-index: 1;
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;
    margin-bottom: var(--space-12);
    background: var(--color-bg-section);
    padding: 112px var(--space-16) var(--space-16);
    box-shadow: var(--elevation);
    border-radius: var(--radius-m);
}
section .inBox:last-of-type {
    margin-bottom: 0;
}

section .inBox h3 {
    position: absolute;
    top: 0;
    left: -32px;
    transform: translateY(-50%);
    width: 720px;
    max-width: 80%;
    pointer-events: none;
}

section .inBox .btn a {
	display: block;
    width: 100%;
    max-width: 300px;
    margin: 0 auto;
    padding: var(--space-6) var(--space-4);
    color: var(--color-btn-inverse);
    background: var(--color-btn-primary);
    border: 1px solid var(--color-btn-primary);
    text-align: center;
    font-weight: bold;
    text-decoration: none;
    border-radius: var(--radius-full);
}
section .inBox .btn.fin a {
	background: var(--color-gray);
    border: 1px solid var(--color-gray);
    pointer-events: none;
}

.soon {
    padding: var(--space-6) 0 var(--space-8);
    font-size: 24px; 
    font-weight: bold;
    text-align: center;
}

@media screen and (min-width: 961px){

	.sp { 
		display: none;
	}

	a {
		-webkit-transition: all 0.3s ease-out;
		transition: all 0.3s ease-out;
	}

	section .inBox .btn a:hover {
        color: var(--color-btn-primary);
        background: var(--color-btn-inverse);
	}
	
}

@media screen and (max-width: 960px){

	.pc {
		display: none;
	}
	
	html {
	    scroll-padding-top: var(--space-20);
	}

    .mainWrap {
        font-size: 14px;
    }

    .container {}

    section {
        padding-bottom: var(--section-base-sp);
    }
    section:last-of-type {
        padding-bottom: var(--section-base-last-sp);
    }

	section .inBox {
        padding: var(--space-12) var(--space-6) var(--space-6);
        margin-bottom: var(--space-4);
	}
    section#schedule .inBox,
    section#ticket .inBox {
        padding: var(--space-14) var(--space-6) var(--space-6);
    }

    section .inBox h3 {
        width: 420px;
        max-width: 90%;
        left: -2.5vw;
    }

    section .inBox .btn a {
        width: 90%;
        padding: var(--space-4);
    }

    .soon {
        padding: var(--space-3) 0 var(--space-6);
        font-size: 20px;
    }

}


/*===================================================
	fv
====================================================*/
#fv {
    position: relative;
    width: 100%;
    height: 100vh;
    min-height: 600px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

#fv .fvInner {
    position: fixed;
    z-index: 2;
    height: 77.5%;
    max-width: 90%;
    aspect-ratio: 309 / 269;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
}
#fv .fvInner h2 {}

#fv .artistLogo {
    position: fixed;
    z-index: 1;
    width: 96px;
    aspect-ratio: 3 / 1;
    top: var(--space-6);
    left: var(--space-6);
}

#fv .scrollBox {
    position: fixed;
    z-index: 1;
    width: 100%;
    height: 100svh;
    top: 0;
    left: 0;
    pointer-events: none;
}
#fv .scrollBox .scroll {
    position: absolute;
    width: 120px;
    aspect-ratio: 1 / 1;
    left: var(--space-6);
    bottom: 0;
    transform: translateY(50%);
}
#fv .scrollBox .scroll img {
    animation: scrollAnim 15s linear infinite;
}
@keyframes scrollAnim {
    from {
      transform: rotate(0deg);
    }
    to {
      transform: rotate(-360deg);
    }
}

#fv .snsList {
    position: fixed;
    z-index: 1;
    right: 0;
    bottom: 0;
    font-size: 20px;
    color: var(--color-tag-inverse);
    background: var(--color-tag-primary);
    padding: var(--space-3) var(--space-6);
    border-radius: var(--radius-m) 0 0 0;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: var(--space-4);
    line-height: 1;
}
#fv .snsList li {}
#fv .snsList li a {}

@media screen and (min-width: 961px){}

@media screen and (max-width: 960px){

	#fv {
        height: 100svh;
	    min-height: 450px;
        margin-bottom: var(--space-12);
	}
			
	#fv .fvInner {}
			
    #fv .scrollBox {}
	#fv .scrollBox .scroll {
        width: 96px;
        height: 96px;
        left: -24px;
        bottom: -24px;
        transform: initial;
    }

}

/* deco */
#fv .decoBox {
    position: fixed;
    z-index: -1;
    inset: 0;
    min-height: 600px;
}
#fv .decoBox .deco {
    position: absolute;
    z-index: -1;
}
#fv .decoBox .deco.deco01 {
    top: 20%;
    left: 22%;
    width: 9%;
    max-width: 120px;
}
#fv .decoBox .deco.deco02 {
    top: 23%;
    right: 16%;
    width: 5%;
    max-width: 80px;
}
#fv .decoBox .deco.deco03 {
    bottom: 22%;
    left: 14%;
    width: 5%;
    max-width: 80px;
}
#fv .decoBox .deco.deco04 {
    bottom: 13%;
    left: 19%;
    width: 5%;
    max-width: 80px;
}
#fv .decoBox .deco.deco05 {
    bottom: 18%;
    right: 17%;
    width: 10%;
    max-width: 160px;
}
#fv .decoBox .deco.tl {transform: translate(-50%, -50%)}
#fv .decoBox .deco.tr {transform: translate(50%, -50%)}
#fv .decoBox .deco.bl {transform: translate(-50%, 50%)}
#fv .decoBox .deco.br {transform: translate(50%, 50%)}

@media screen and (max-width: 960px) {

    #fv .decoBox {
        min-height: 450px;
    }

    #fv .decoBox .deco.deco01 {
        top: 22%;
        left: 15%;
        width: 14%;
        max-width: 80px;
    }
    #fv .decoBox .deco.deco02 {
        top: 23%;
        right: 12%;
        width: 7%;
        max-width: 48px;
    }
    #fv .decoBox .deco.deco03 {
        bottom: 22%;
        left: 10%;
        width: 10%;
        max-width: 48px;
    }
    #fv .decoBox .deco.deco04 {
        bottom: 20%;
        left: 22%;
        width: 8%;
        max-width: 48px;
    }
    #fv .decoBox .deco.deco05 {
        bottom: 18%;
        right: 16%;
        width: 16%;
        max-width: 112px;
    }

}


/*===================================================
	about
====================================================*/
#about {}
#about .inBox {}
#about .inBox h3 {}

#about .inBox .lead {
    font-size: clamp(16px, 2.8vw, 32px);
    font-weight: bold;
    text-align: center;
    padding: var(--space-8) 0;
}

@media screen and (min-width: 961px){}

@media screen and (max-width: 960px){

    #about {}
    #about .inBox {}
    #about .inBox h3 {}

    #about .inBox .lead {
        padding: var(--space-6) 0;
        font-size: clamp(12px, 5.4vw, 28px);
    }
    
}


/*===================================================
	schedule
====================================================*/
#schedule {}
#schedule .inBox {}
#schedule .inBox h3 {}

#schedule .inBox .scheduleWrap {
    padding-bottom: var(--space-12);
    margin-bottom: var(--space-12);
    border-bottom: 1px dashed;
}
#schedule .inBox .scheduleWrap:last-of-type {
    padding-bottom: 0;
    margin-bottom: 0;
    border: none;
}
#schedule .inBox .scheduleWrap .liveLogo {
    margin: 0 auto var(--space-8);
    width: 75%;
    pointer-events: none;
}
#schedule .inBox .scheduleWrap .scheduleBox {
    border: 1px solid;
    padding: var(--space-8);
    margin: 0 0 var(--space-6);
    border-radius: var(--radius-m);
}
#schedule .inBox .scheduleWrap .scheduleBox:last-of-type {
    margin-bottom: 0;
}
#schedule .inBox .scheduleWrap .scheduleBox .tit {
    display: inline-block;
    font-size: 20px;
    font-weight: bold;
    padding: 0.5em 1em;
    margin: 0 0 var(--space-4);
    background: var(--color-tag-primary);
    color: var(--color-tag-inverse);
    border-radius: var(--radius-s);
}
#schedule .inBox .scheduleWrap .scheduleBox .date {
    font-size: 20px;
    font-weight: bold;
    margin-bottom: var(--space-1);
}
#schedule .inBox .scheduleWrap .scheduleBox .date span {
    font-size: 14px;
    padding: 0 var(--space-1);
}
#schedule .inBox .scheduleWrap .scheduleBox .date span:last-of-type {
    padding-right: 0;
}
#schedule .inBox .scheduleWrap .scheduleBox .date span.part {
    font-size: 20px;
}
#schedule .inBox .scheduleWrap .scheduleBox .venue {
    font-size: 24px;
    font-weight: bold;
    margin: 0 0 var(--space-2);
}
#schedule .inBox .scheduleWrap .scheduleBox .venue .tag {
    display: inline-block;
    font-size: 16px;
    border: 1px solid;
    padding: 0.5em 1em;
    line-height: 1;
    margin: 0 var(--space-2) 0 0;
    border-radius: var(--radius-s);
}
#schedule .inBox .scheduleWrap .scheduleBox .venue .sub {
    font-size: 16px;
    padding-left: var(--space-1);
}
#schedule .inBox .scheduleWrap .scheduleBox .time {
    margin-bottom: var(--space-6);
}
#schedule .inBox .scheduleWrap .scheduleBox .time:last-child {
    margin-bottom: 0;
}
#schedule .inBox .scheduleWrap .scheduleBox .detailBox {}
#schedule .inBox .scheduleWrap .scheduleBox .detailBox .detailTit {
    font-weight: bold;
    border-left: 4px solid;
    padding: 0 0 0 var(--space-2);
    margin: 0 0 var(--space-3);
}
#schedule .inBox .scheduleWrap .scheduleBox .detailBox .detailTxt {
    font-size: 14px;
}

@media screen and (min-width: 961px) {

    /* solo */
    #schedule .inBox .scheduleWrap .scheduleBox.solo {
        display: flex;
        flex-direction: row-reverse;
        align-items: center;
        justify-content: space-between;
        gap: var(--space-6);
    }
    #schedule .inBox .scheduleWrap .scheduleBox.solo .liveLogo {
        width: 32.5%;
        margin: 0;
    }
    #schedule .inBox .scheduleWrap .scheduleBox.solo .scheduleSolo {
        width: 67.5%;
    }

}

@media screen and (max-width: 960px) {

    #schedule {}
    #schedule .inBox {}
    #schedule .inBox h3 {}

    #schedule .inBox .scheduleWrap {
        padding-bottom: var(--space-6);
        margin-bottom: var(--space-6);
    }
    #schedule .inBox .scheduleWrap .liveLogo {
        width: 100%;
        max-width: 600px;
        margin: 0 auto var(--space-6);
    }
    #schedule .inBox .scheduleWrap .scheduleBox {
        padding: var(--space-4);
        margin: 0 0 var(--space-2);
        border-radius: var(--radius-s);
    }
    #schedule .inBox .scheduleWrap .scheduleBox:last-of-type {}
    #schedule .inBox .scheduleWrap .scheduleBox .tit {
        font-size: 16px;
        margin: 0 0 var(--space-3);
    }
    #schedule .inBox .scheduleWrap .scheduleBox .date {
        font-size: 18px;
    }
    #schedule .inBox .scheduleWrap .scheduleBox .date span {
        padding: 0 2px;
        font-size: 12px;
    }
    #schedule .inBox .scheduleWrap .scheduleBox .date span:last-of-type {}
    #schedule .inBox .scheduleWrap .scheduleBox .date span.part {
        font-size: 18px;
    }
    #schedule .inBox .scheduleWrap .scheduleBox .venue {
        font-size: 20px;
    }
    #schedule .inBox .scheduleWrap .scheduleBox .venue .tag {
        font-size: 14px;
        padding: 0.25em 0.5em;
    }
    #schedule .inBox .scheduleWrap .scheduleBox .venue .sub {
        display: block;
        padding: 0;
        font-size: 14px;
        line-height: 1.2;
    }
    #schedule .inBox .scheduleWrap .scheduleBox .time {
        margin-bottom: var(--space-4);
    }
    #schedule .inBox .scheduleWrap .scheduleBox .detailBox {}
    #schedule .inBox .scheduleWrap .scheduleBox .detailBox .detailTit {
        margin: 0 0 var(--space-2);
    }
    #schedule .inBox .scheduleWrap .scheduleBox .detailBox .detailTxt {
        font-size: 12px;
    }

    /* solo */
    #schedule .inBox .scheduleWrap .scheduleBox.solo {}
    #schedule .inBox .scheduleWrap .scheduleBox.solo .liveLogo {
        width: 75%;
        max-width: 320px;
        margin: 0 auto var(--space-4);
    }
    #schedule .inBox .scheduleWrap .scheduleBox.solo .scheduleSolo {}

}
    

/*===================================================
	ticket
====================================================*/
#ticket {}
#ticket h3 {}
#ticket .inBox {}

#ticket .inBox .ticketWrap {
    margin: 0 0 var(--space-9);
    padding: 0 0 var(--space-10);
    border-bottom: 1px dashed;
}
#ticket .inBox .ticketWrap:last-of-type {
    margin: 0;
    padding: 0;
    border-bottom: none;
}

#ticket .inBox .ticketWrap .ticketBoxTit {
    font-size: 24px;
    font-weight: bold;
    margin: 0 0 var(--space-2);
}
#ticket .inBox .ticketWrap .ticketBoxTit:last-of-type {
    margin: 0 0 var(--space-4);
}
#ticket .inBox .ticketBoxTit .date {
    display: inline-block;
    font-size: 16px;
    padding: 0.25em 1em;
    margin: 0 0 var(--space-1);
    border: 1px solid;
    border-radius: var(--radius-s);
}

#ticket .inBox .ticketBox {}

/*============ accordion ===========*/
#ticket .inBox .op_ticket {
    margin: 0 0 var(--space-1);
}
#ticket .inBox .op_ticket:last-of-type {
    margin: 0;
}
#ticket .op_ticket .ticketTit {
    background: var(--color-tag-primary);
    color: var(--color-tag-inverse);
    padding: var(--space-8) var(--space-16) var(--space-8) var(--space-8);
    font-size: 20px;
    font-weight: bold;
    position: relative;
    cursor: pointer;
    transition: 0.5s ease;
    border-radius: var(--radius-m);
}
#ticket .op_ticket .ticketTit.open {
    border-radius: var(--radius-m) var(--radius-m) 0 0;   
}
#ticket .op_ticket .ticketTit span {
    position: absolute;
    top: 50%;
    right: var(--space-8);
    width: 20px;
    height: 20px;
    transform: rotate(180deg) translateY(50%);
    transition: 0.3s ease;
}
#ticket .op_ticket .ticketTit span:before,
#ticket .op_ticket .ticketTit span:after {
    content: "";
    position: absolute;
    z-index: 1;
    display: block;
    width: 20px;
    height: 0;
    border-bottom: solid 2px;
    top: 40%;
    right: 0px;
    transition: all 0.3s ease-out;
}
#ticket .op_ticket .ticketTit span:before {
    transform: rotate(90deg);
}
#ticket .op_ticket .ticketTit.open span:before {
    -webkit-transform: rotate(0);
    transform: rotate(0);
}

#ticket .inBox .indent {
    display: inline-block;
    text-indent: -0.25em;
}

#ticket .op_ticket .ticketDetail {
    display: none;
    padding: var(--space-8);
    border-radius: 0 0 var(--radius-m) var(--radius-m);
    border: 1px solid;
    border-top: none;
}

#ticket .op_ticket .detailList {
    display: flex;
    border-bottom: 1px solid;
    padding: 0 0 var(--space-6);
    margin: 0 0 var(--space-8);
    align-items: stretch;
}
#ticket .op_ticket .detailList:first-child {
    border-top: 1px solid;
    padding: var(--space-6) 0;
}
#ticket .op_ticket .detailList:last-child {
    margin: 0;
}
#ticket .op_ticket .detailList dt {
    width: 20%;
    padding: 0 var(--space-12) 0 0;
    display: flex;
    align-items: center;
    font-weight: 500;
}
#ticket .op_ticket .detailList dd {
    width: 80%;
    position: relative;
    padding: 0 0 0 var(--space-12);
    display: flex;
    align-items: center;
}
#ticket .op_ticket .detailList dd:before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 1px;
    background: var(--color-white);
}
#ticket .op_ticket .detailList dd > * {
    margin-bottom: var(--space-4);
}
#ticket .op_ticket .detailList dd > *:last-child {
    margin-bottom:0;
}
#ticket .op_ticket .detailList dd .detailInner {
    width: 100%;
}
#ticket .op_ticket .detailList dd .detailInner > *{
    margin-bottom: var(--space-2);
}
#ticket .op_ticket .detailList dd .detailInner  > *:last-child{
    margin-bottom: 0;
}

/*============ accordion fin ===========*/
#ticket .inBox .op_ticket.op_ticket_fin {}
#ticket .op_ticket .ticketTit.ticketTitFin {
    background: var(--color-tag-inverse);
    color: var(--color-tag-primary);
    border: 1px solid var(--color-tag-primary);
}
#ticket .op_ticket .ticketTit.ticketTitFin.open {
    border-radius: var(--radius-m);
}
#ticket .op_ticket .ticketDetail.ticketDetailFin {
    padding: var(--space-1) 0 0;
    border: none;
    border-radius: 0;
}

/*============ priceBox ===========*/
#ticket .priceWrap {}

#ticket .priceWrap .priceBox {
    background: var(--color-bg-light);
    padding: var(--space-8);
    margin: 0 0 var(--space-6);
    border-radius: var(--radius-m);
}
#ticket .priceWrap .priceBox:first-child {
    margin-top: var(--space-10);
}
#ticket .priceWrap .priceBox:last-of-type {
    margin: 0;
}

#ticket .priceWrap .priceBox .txtList {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}
#ticket .priceWrap .priceBox .txtList li {
    text-indent: -1em;
    padding: 0 0 0 1em;
}
#ticket .priceWrap .priceBox .txtList.note li {
    font-size: 14px;
}
#ticket .priceWrap .priceBox .txtList li a {
    text-decoration: underline;
    word-break: break-all;
}

#ticket .priceWrap .priceBox .txtBox {
    margin-bottom: var(--space-6);
}
#ticket .priceWrap .priceBox .txtBox .boxTit {
    display: inline-block;
    background: var(--color-tag-primary);
    color: var(--color-tag-inverse);
    font-size: 16px;
    font-weight: bold;
    padding: 0.25em 1em;
    margin: 0 0 var(--space-2);
    border: 1px solid;
    border-radius: var(--radius-s);
}
#ticket .priceWrap .priceBox .txtBox .boxTit span {
    padding: 0 0 0 var(--space-1);
}

#ticket .priceWrap .priceBox .areaBox {
    margin-bottom: var(--space-6);
}
#ticket .priceWrap .priceBox .areaBox .area {
    max-width: 520px;
    margin: 0 auto var(--space-3);
    border-radius: var(--radius-m);
    overflow: hidden;
}
#ticket .priceWrap .priceBox .areaBox .areaNote {
    font-size: 14px;
    text-align: center;
}

#ticket .priceWrap .priceBox .areaBoxTxt {
    border: 1px solid;
    padding: var(--space-6);
    margin: 0 0 var(--space-4);
    border-radius: var(--radius-m);
}
#ticket .priceWrap .priceBox .areaBoxTxt:last-child {
    margin-bottom: 0;
}
#ticket .priceWrap .priceBox .areaBoxTxt .tit {
    font-weight: bold;
    border-left: 4px solid;
    padding: 0 0 0 var(--space-2);
    margin: 0 0 var(--space-3);
}
#ticket .priceWrap .priceBox .areaBoxTxt .txtList {
    font-size: 14px;
}

#ticket .priceWrap .priceBox .attList {}
#ticket .priceWrap .priceBox .attList li {}                

@media screen and (min-width: 961px){

    #ticket .op_ticket .ticketTit:hover {
        opacity: 0.7;
    }

}

@media screen and (max-width: 960px){

    #ticket {}
    #ticket h3 {}
    #ticket .inBox {}

    #ticket .inBox .ticketWrap {
        margin: 0 0 var(--space-6);
        padding: 0 0 var(--space-6);
    }

	#ticket .inBox .ticketWrap .ticketBoxTit {
        font-size: 16px;
        margin: 0 0 var(--space-2);
    }
    #ticket .inBox .ticketWrap .ticketBoxTit:last-of-type {
        margin: 0 0 var(--space-2);
    }
    #ticket .inBox .ticketBoxTit .date {
        font-size: 14px;
        padding: 0.25em 0.75em;
    }

    #ticket .inBox .ticketBox {}
    #ticket .inBox .ticketBox:last-child {}

    #ticket .inBox .ticketBox .area {
        font-size: 14px;
        margin: 0 0 var(--space-2);
    }

    #ticket .inBox .op_ticket {}
	#ticket .op_ticket .ticketTit {
        padding: var(--space-4) var(--space-10) var(--space-4) var(--space-4);
        font-size: 14px;
        border-radius: var(--radius-s);
	}
    #ticket .op_ticket .ticketTit.open {
        border-radius: var(--radius-s) var(--radius-s) 0 0;   
    }
    #ticket .op_ticket .ticketTit span {
        right: var(--space-4);
        width: 16px;
        height: 16px;
    }
    #ticket .op_ticket .ticketTit span:before,
    #ticket .op_ticket .ticketTit span:after {
        width: 16px;
    }
	#ticket .op_ticket .ticketDetail {
        padding: var(--space-4);
        font-size: 14px;
        border-radius: 0 0 var(--radius-s) var(--radius-s);
	}
	#ticket .op_ticket .detailList {
	    display: block;
	    margin: 0 0 var(--space-4);
        padding-bottom: var(--space-4);
	}
	#ticket .op_ticket .detailList:first-child {
        padding: var(--space-4) 0;
    }
	#ticket .op_ticket .detailList dt {
        width: 100%;
        margin: 0 0 var(--space-2);
        font-weight: bold;
        border-left: 4px solid;
        padding: 0 0 0 var(--space-2);
	}
	#ticket .op_ticket .detailList dd {
	    width: 100%;
	    position: relative;
	    padding: 0;
	}
	#ticket .op_ticket .detailList dd:before {
	    content: none
	}
    section#ticket .inBox .op_ticket .btn a {}

    /*============ accordion fin ===========*/
    #ticket .inBox .op_ticket.op_ticket_fin {}
    #ticket .op_ticket .ticketTit.ticketTitFin {}
    #ticket .op_ticket .ticketTit.ticketTitFin.open {
        border-radius: var(--radius-s);
    }
    #ticket .op_ticket .ticketDetail.ticketDetailFin {}

    /*============ priceBox ===========*/
    #ticket .priceWrap {}

    #ticket .priceWrap .priceBox {
        margin-bottom: var(--space-4);
        padding: var(--space-4);
        border-radius: var(--radius-s);
    }
    #ticket .priceWrap .priceBox:first-child {
        margin-top: var(--space-6);
    }

    #ticket .priceWrap .priceBox .txtList {}
    #ticket .priceWrap .priceBox .txtList li {}
    #ticket .priceWrap .priceBox .txtList.note li {
        font-size: 12px;
    }

    #ticket .priceWrap .priceBox .txtBox {
        margin-bottom: var(--space-4);
    }
    #ticket .priceWrap .priceBox .txtBox .boxTit {
        font-size: 14px;
        padding: 0.25em 0.75em;
        margin: 0 0 var(--space-2);
    }
    #ticket .priceWrap .priceBox .txtBox .boxTit span {}

    #ticket .priceWrap .priceBox .areaBox {
        margin-bottom: var(--space-4);
    }
    #ticket .priceWrap .priceBox .areaBox .area {
        margin-bottom: var(--space-2);
        border-radius: var(--radius-s);
    }
    #ticket .priceWrap .priceBox .areaBox .areaNote {
        text-align: left;
        font-size: 12px;
        text-indent: -1em;
        padding: 0 0 0 1em;
    }

    #ticket .priceWrap .priceBox .areaBoxTxt {
        padding: var(--space-4);
        margin: 0 0 var(--space-2);
        border-radius: var(--radius-s);
    }
    #ticket .priceWrap .priceBox .areaBoxTxt .tit {
        margin-bottom: var(--space-2);
    }
    #ticket .priceWrap .priceBox .areaBoxTxt .txtList {
        font-size: 12px;
    }

    #ticket .priceWrap .priceBox .attList {}
    #ticket .priceWrap .priceBox .attList li {}                
	
}


/*===================================================
	goods
====================================================*/
#goods {}
#goods .inBox {}
#goods .inBox h3 {}

@media screen and (min-width: 961px){}

@media screen and (max-width: 960px){

    #goods {}
    #goods .inBox {}
    #goods .inBox h3 {}

}


/*===================================================
	special
====================================================*/
#special {}
#special .inBox {}
#special .inBox h3 {}

@media screen and (min-width: 961px){}

@media screen and (max-width: 960px){

    #special {}
    #special .inBox {}
    #special .inBox h3 {}

}


/*===================================================
	attention
====================================================*/
#attention {}
#attention .inBox {}
#attention .inBox h3 {}

#attention .inBox .attMainTit {
    font-size: 18px;
    font-weight: bold;
    margin: 0 0 var(--space-6);
    padding: 0 0 var(--space-6);
    border-bottom: 1px solid;
}
#attention .inBox .attMainTit span {
    font-size: 16px;
    padding-left: var(--space-1);
}

#attention .inBox .attInBox {
    margin: 0 0 var(--space-6);
    padding: 0 0 var(--space-6);
    border-bottom: 1px dashed;
}
#attention .inBox .attInBox:last-of-type {
    border-bottom: 1px solid;
}
#attention .inBox .attInBox .attTit {
    font-weight: bold;
    border-left: 4px solid;
    padding: 0 0 0 var(--space-2);
    margin: 0 0 var(--space-3);
}
#attention .inBox .attInBox .attList {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}
#attention .inBox .attInBox .attList li {
    font-size: 14px;
}
#attention .inBox .attInBox .attList.ind li {
    text-indent: -1em;
    padding: 0 0 0 1em;
}

#attention .inBox .attTxt {}

@media screen and (min-width: 961px){}

@media screen and (max-width: 960px){

    #attention {}
    #attention .inBox {}
    #attention .inBox h3 {}

    #attention .inBox .attMainTit {
        font-size: 16px;
        margin: 0 0 var(--space-4);
        padding: 0 0 var(--space-4);
    }
    #attention .inBox .attMainTit span {
        display: block;
        font-size: 14px;
        padding-left: 0;
    }

    #attention .inBox .attInBox {
        margin: 0 0 var(--space-4);
        padding: 0 0 var(--space-4);
    }
    #attention .inBox .attInBox .attTit {
        margin: 0 0 var(--space-2);
    }
    #attention .inBox .attInBox .attList {}
    #attention .inBox .attInBox .attList li {
        font-size: 12px;
    }
    #attention .inBox .attInBox .attList.ind li {}

    #attention .inBox .attTxt {}

}


/*===================================================
	footer
====================================================*/
#footer {
    position: relative;
    z-index: var(--z-footer);
    width: 100%;
    padding: var(--space-16) 5% var(--space-6);
    background: var(--color-bg-inverse);
    color: var(--color-text-inverse);
}

#footer .footerLogo {
    width: 160px;
    margin: 0 auto var(--space-8);
}

#footer .snsWrap {
    margin: 0 0 var(--space-16);
    font-size: 20px;
}
#footer .snsWrap ul {
    display: flex;
    justify-content: center;
    gap: var(--space-4);
}

#footer .copyLight {
    font-size: 12px;
    line-height: 1;
    text-align: center;
}

@media screen and (min-width: 961px){

	#footer .footerLogo a:hover,
	#footer .snsWrap ul li a:hover {
	    opacity: 0.7;
	}

}

@media screen and (max-width: 960px){

	#footer {
		padding: var(--space-12) 0 var(--space-4);
	}

	#footer .footerLogo {
        width: 96px;
        margin: 0 auto var(--space-6);
	}

	#footer .snsWrap {
        margin: 0 0 var(--space-12);
    }

}