html {
  font-size: 62.5%;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 500;
}

/* フォントメトリクスの余白を除去 (Chrome 133+, Safari 18.2+) */
*,
*::before,
*::after {
  text-box-trim: both;
  text-box-edge: cap alphabetic;
}

/* ===== Reset ===== */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
img { display: block; max-width: 100%; }
a { text-decoration: none; color: inherit; }

/* globals.css — 基本定義 */
:root {
  --width-min: 100rem;
  --width-min-2: 50rem;

  --color-back: #0a0a0f;
  --color-primary: #f5f5f7;
  --color-accent: #b4eb22;
  --color-accent-yellow: #f4f453;
  --color-accent-green: #1fc985;
  --color-accent-purple: #7d42fc;
  --color-accent-pink: #ff5fa0;
  --color-accent-orange: #fa541c;
  --color-accent-blue: #3b82f6;
  --color-accent-aqua: #52e4f7;
  --color-card: #131315;
  --color-elevated: #27272a;
  --color-text-secondary: #a1a1aa;
  --color-text-muted: #71717a;
  --color-border: #27272a;
  --text-shadow: 0px 0px 4px #00000077;
  --shadow: drop-shadow(0px 0px 2px #00000006);
  --flatboldfont: 'Space Grotesk', sans-serif;
  --size-t: 0.6rem;
  --size-st: 1rem;
  --size-ss: 1.6rem;
  --size-s: 2rem;
  --size-sn: 2.6rem;
  --size-n: 3.6rem;
  --size-mn: 4.2rem;
  --size-m: 5rem;
  --size-mm: 5.8rem;
  --size-l: 6.8rem;
  --size-lm: 7.2rem;
  --size-ll: 8rem;
  --size-b: 9.4rem;
  --size-bl: 10rem;
  --size-bb: 11rem;
  --size-e: 13rem;
  --size-eb: 15.8rem;
  --radius: var(--size-n);
  --radius-md: var(--size-s);
  --line-height-1: 10rem;

  --label-op-line: 0.8;
  --label-op-back: 0.8;
  --label-op-text: 1;

  --section-padding: clamp(var(--size-l), 5vw, var(--size-ll)) max(8%, calc(50% - 500px));
  --section-padding-wide: max(5%, var(--size-l)) 0;
  --section-padding-sp: max(4%, var(--size-mm)) max(3%, var(--size-s));

  --btn-purple-back: linear-gradient(#6f42ea 0%, #3e2180 100%);
  --btn-lime-back: linear-gradient(#bbe22b 0%, #758b19 100%);
  --btn-line-white-pale: 1px solid #ffffff22;


  /* Rainbow gradient (reusable) */
  --gradient-rainbow: linear-gradient(90deg, #7C3AED 0%, #ff5fa0 33%, #C4F82A 66%, #3B82F6 100%);
  --gradient-rainbow-fade: linear-gradient(90deg, #55e4f700 0%, #52e4f7 15%, #b4eb22 37%, #ff5fa0 62%, #7d42fc 85%, #7c40fc00 100%);

  --gradient-rainbow-mesh:  
                            radial-gradient(at 0% 0%,  var(--color-accent-pink) 0px, transparent 65%),
                            radial-gradient(at 50% 0%,  var(--color-accent-orange) 0px, transparent 65%),
                            radial-gradient(at 100% 0%,  var(--color-accent) 0px, transparent 65%),
                            radial-gradient(at 0% 100%,  var(--color-accent-purple) 0px, transparent 65%),
                            radial-gradient(at 50% 100%,  var(--color-accent-green) 0px, transparent 65%),
                            radial-gradient(at 100% 100%,  var(--color-accent-aqua) 0px, transparent 65%);

@media screen and (max-width: 450px) {
    --size-t: 0.4rem;
    --size-st: 0.6rem;
    --size-ss: 1.0rem;
    --size-s: 1.6rem;
    --size-sn: 2rem;
    --size-n: 2.6rem;
    --size-mn: 3.6rem;
    --size-m: 4.2rem;
    --size-mm: 5rem;
    --size-l: 5.8rem;
    --size-lm: 6.8rem;
    --size-ll: 7.2rem;
    --size-b: 8rem;
    --size-bl: 9.4rem;
    --size-bb: 10rem;
    --size-e: 11rem;
    --size-eb: 13rem;
}

body {
  background: var(--color-back);
  color: var(--color-primary);
  overflow-x: hidden;
}

.shadow { filter: var(--shadow); }

.loading{
  position: fixed;
  width: 100%;
  height: 100vh;
  background-color: var(--color-card);
  z-index: 2000;
}

.loader{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%)translateY(-50%);
  animation: flash 2s linear infinite;
  font-family: 'Space Grotesk', monospace;
  font-size: clamp(2.0rem, 4vw, 5rem);
  font-weight: 500;
  letter-spacing: 0.4rem;
  width: auto;
  height: auto;
}

@keyframes flash {
  0%,100% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
}

/* ===== 共通コンポーネント ===== */

/* セクションタイトル (小: 英語ラベル) */
.template-title-s,
.section-label-en {
  font-family: var(--flatboldfont);
  font-size: 1.2rem;
  font-weight: 400;
  letter-spacing: 0.6rem;
  line-height: 1;
  color: var(--color-primary);
  text-align: center;
  text-transform: uppercase;
}

@media screen and (max-width: 450px) {
  .template-title-s,
  .section-label-en {
    font-size:1.0rem;
  }
}

/* セクションタイトル (大: 日本語) */
.template-title-l,
.section-title-large {
  margin-top: clamp(var(--size-ss), 0.7vw, 1.4rem);
  text-align: center;
}


.template-label-s {
  font-family: 'M PLUS 1p', sans-serif;
  font-size: clamp(3.6rem, 5vw, 5rem);
  font-weight: 700;
  letter-spacing: 0.3rem;
  line-height: 1;
  color: var(--color-primary);
  text-align: center;
}


/* セクションタイトル下のレインボーライン */
.line-rainbow {
  display: flex;
  justify-content: center;
  width: 158px;
  margin: 0 auto;
  margin-top: var(--size-n);
}
.line-rainbow span {
  display: block;
  width: 100%;
  height: 1px;
  background: var(--gradient-rainbow-fade);
}

/* セクション区切り線 */
.section-divider {
  width: 100%;
  height: 2px;
  background: var(--gradient-rainbow);
}

/* section-title-large の padding-bottom (trailing spacer 由来) */
.section-title-large {
  padding-bottom: var(--size-n);
}

/* ========================================= */
/* HERO SECTION                              */
/* ========================================= */
.hero-section {
  position: relative;
  width: 100%;
  height: 100vh;
  overflow: hidden;
}

.hero-live-btn{
  position: relative;
  margin-top: var(--size-sn); 
  display: inline-flex;
  align-items: center;
  border-radius: 100px;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(1.2rem, 1.8vw, 1.4rem);
  font-weight: 700;
  letter-spacing: 0.3rem;
  color: #fff;
  background: linear-gradient(to right, var(--color-accent-pink) 0%, var(--color-accent-purple) 50%, var(--color-accent-green) 100%);
  padding: clamp(1rem, 1.8vw, 1.2rem) var(--size-n);
  border: var(--btn-line-white-pale);
  cursor: pointer;
  transition: transform 0.2s, box-shadow 0.2s;
}

@media screen and (max-width: 450px) {
  .hero-live-btn{
    position: relative;
    margin-top: var(--size-sn);
    font-family: 'Zen Maru Gothic', sans-serif;
    font-size: clamp(1.0rem, 1.8vw, 1.2rem);
    letter-spacing: 0.3rem;
    padding: clamp(0.8rem, 1.8vw, 1.0rem) max(6vw, var(--size-s));
  }
}


.hero-live-btn:hover{
  transform: translateY(-2px);
  box-shadow: 0 8px 24px #00000060;
}






/*modal*/


.live_modal{
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color:rgba(0, 0, 0, 0.7);
  z-index: 1000;
}

.live_modal_click{
  content:"";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index:1001;
}

.live-wrap{
  width: auto;
  height: auto;
  position: absolute;
  top: 50%;
  left: 50%;
  flex-wrap: wrap;
  align-items:center;
  justify-content:center;
  z-index: 1002;
  
  padding: clamp(2.6rem, 2.5vw, 4.2rem) clamp(2.0rem, 2.5vw, 3.6rem);
  background-color:var(--color-primary);
  border-radius:var(--size-st);

  display: flex;
  flex-direction:column;
  gap:var(--size-st);
  transform:translateX(-50%) translateY(-50%);
  height: auto;
  
}

@media screen and (max-width: 1440px){
  .live-wrap{
    position: absolute;
    max-width:1000px;
    height: auto;
    align-items:center;
    justify-content:center;
    
    padding: clamp(2.6rem, 2.5vw, 4.2rem) clamp(2.0rem, 2.5vw, 3.6rem);
    display: flex;
    flex-direction:column;
    gap:var(--size-st);
    transform:translateX(-50%) translateY(-50%);
  }
}


@media screen and (max-width: 768px){
  .live-wrap{
    width: 100%;
    max-width: 85vw;
    padding: clamp(2.0rem, 2.5vw, 2.6rem) clamp(1.6rem, 2.5vw, 2.0rem);
  }
}

@media screen and (max-width: 450px){
  .live-wrap{
    padding: max(var(--size-s), 3vw) max(var(--size-st), 1vw);
  }
}


.live-close{
  position: absolute;
  top: 0;
  right: 0;
  width: 36px;
  height: 36px;
  transform:translateX(50%) translateY(-50%);
  z-index: 1005;
}

.live-close img{
  width: 100%;
  height: 100%;
}

@media screen and (max-width: 768px){
  .live-close{
    width: max(6vw, 36px);
    height: max(6vw, 36px);
  }
}

@media screen and (max-width: 450px){
  .live-close{
    width: max(10vw, 20px);
    height: max(10vw, 20px)
  }
}

.live-title{
  position: relative;
  margin: 0 auto;
  margin-bottom: 0.4rem;
  padding-top: -var(--size-t);
/*  margin-top: var(--size-sn); */
  display: inline-flex;
  align-items: center;
  justify-content:center;
  border-radius: 100px;
  font-family: 'var(--flatboldfont)', sans-serif;
  font-size: var(--size-st);
  font-weight: 700;
  letter-spacing: 0.5rem;
  color: var(--color-accent-purple);
/*  background: linear-gradient(to right, var(--color-accent-pink) 0%, var(--color-accent-purple) 50%, var(--color-accent-green) 100%);*/
  padding: clamp(0.4rem, 1.8vw, 0.6rem) var(--size-s);
  border: 1px solid var(--color-accent-purple);
}

.live-buy{
  position: relative;
  width: auto;
  margin: 0 auto;
  margin-top: clamp(0.6rem, 1vw, 1.4rem);
  display: inline-flex;
  align-items: center;
  justify-content:center;
  border-radius: 100px;
  font-family: 'ZenMaruGothic-Bold.ttf', sans-serif;
  font-size: clamp(1.2rem, 1.8vw, 1.8rem);
  font-weight: 700;
  letter-spacing: 0.2rem;
  color: #fff;
  background: linear-gradient(to right, var(--color-accent-pink) 0%, var(--color-accent-purple) 50%, var(--color-accent-green) 100%);
  padding: clamp(1.0rem, 1.8vw, 1.2rem) clamp(2.6rem, 3vw, 3.6rem);
  border: var(--btn-line-white-pale);
  cursor: pointer;
  transition: transform 0.2s, box-shadow 0.2s;
}



.live-date{
  position: relative;
  margin: 0 auto;
  height: var(--size-s);
  font-family: 'Oswald', sans-serif;
  font-weight: 700;
  letter-spacing: 0.2rem;
  line-height: 1em;
  font-size:var(--size-s);
  color: var(--color-card);
  overflow: hidden;
}

.font-s{
  font-size:0.62em;
  opacity: 65%;
}

.live-place{
  position: relative;
  margin: 0 auto;
  font-family: 'var(--flatboldfont)', sans-serif;
  font-weight: 400;
  letter-spacing: 0.2rem;
  font-size:var(--size-st);
  line-height: 1em;
  color: #00000077;
}

.strong{
  font-weight:700;
}

.live-hr{
  position: relative;
  width: 85%;
  height: 1px;
  margin: var(--size-st);
  background: linear-gradient(to right, #7c40fc00 0%, #7c40fc 30%, #ff6bbf 50%, #7c40fcf7 70%, #7c40fc00 100%);
}

.live-detail-flex{
  width: 100%;
  position: relative;
  display: flex;
  align-items: center;
/*  gap:3%;*/
  justify-content:center;
  font-family: 'ZenMaruGothic-Medium.ttf', sans-serif;
  font-size: var(--size-st);
  font-weight: 400;
  letter-spacing: 0.5rem;
  color: var(--color-card);
  border: var(--btn-line-white-pale);
}

.live-detail-section{
  width: 25rem;
  position: relative;
  display: flex;
  flex-wrap: wrap;
  gap:min(3vw, var(--size-st));
  align-items:center;
  justify-content:space-between;
  flex-direction:column;
/*  padding: clamp(0.8rem, 1.8vw, 1rem) var(--size-s);*/
  color: var(--color-card);
}

@media screen and (max-width: 450px){
  .live-detail-flex{
    justify-content:space-between;
    gap:min(0.6rem, 2vw);
  }
  .live-detail-section{
    width: 100%;
  }
}

.bu-num{
  position: relative;
  padding: var(--size-t) var(--size-st);
  display: inline-flex;
  align-items: center;
  justify-content:center;
  font-family: 'ZenMaruGothic-Bold.ttf', sans-serif;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.1rem;
  line-height: 1em;
  border-radius:4px;
  color: var(--color-card);
}

@media screen and (max-width: 450px){
  .bu-num{
    font-size:min(2vw,1rem);
  }
}

.bu-num-1{
  color: var(--color-accent-green);
  background: #1fc78422;
  border: 1px solid var(--color-accent-green); 
}
.bu-num-2{
  color: var(--color-accent-pink);
  background: #ff5fa022;
  border: 1px solid var(--color-accent-pink); 
}

.live-detail-title{
  position: relative;
  height: var(--size-s);
  font-family:'oswald';
  font-size:var(--size-s);
  font-weight: 700;
  color: var(--color-card);
  line-height: 1em;
  letter-spacing: 0.2rem;
}

@media screen and (max-width: 768px){
  .live-detail-title{
    font-size: max(3vw, 1.4rem);
  }
}

@media screen and (max-width: 450px){
  .live-detail-title{
    font-size: min(3.8vw, 1.4rem);
  }
}

.live-poster-wrap{
  position: relative;
  display: flex;
  align-items:center;
  justify-content:center;
  max-width:85%;
  height: 85%;
  padding: var(--size-s);
  background-color:#00000008;
  border-radius:var(--size-t);
  border: 1px solid #00000010;
  overflow:visible;
  text-align: center;
}

@media screen and (max-width: 1440px){
  .live-poster-wrap{
  max-width:85%;
  height: 85%;
  padding: clamp(var(--size-st), 2.8vw, var(--size-s));
  }
}


@media screen and (max-width: 450px){

  .live-poster-wrap{
    width:100%;
    height: 100%;
  }
}

.live-poster-wrap img{
  margin: auto 0;
  width: 100%;
  height: auto;
}


.live-detail-time{
  position: relative;
  margin-top: var(--size-t);
  display: inline-flex;
  align-items: center;
  gap:var(--size-t);
  justify-content:center;
  font-family: 'ZenMaruGothic-Bold.ttf', sans-serif;
  font-size: 1.2rem;
  font-weight: 700;
  letter-spacing: 0.1rem;
  line-height: 1em;
  color: var(--color-card);
}


@media screen and (max-width: 768px){
  .live-detail-time{
    font-size: clamp(1.2rem, 0.6vw, 1.6rem);
  }
}
@media screen and (max-width: 450px){
  .live-detail-time{
    gap:0.3rem;
    font-size: clamp(0.8rem, 0.6vw, 1.6rem);
    letter-spacing:0.02em;
  }
}

.time-s{
  font-size:0.62em;
  opacity: 0.6;
}

.live-detail-text{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content:center;
  font-family: 'ZenMaruGothic-Medium.ttf', sans-serif;
  font-size: clamp(0.8rem, 1.8vw, 1.2rem);
  font-weight: 400;
  font-style:italic;
  text-align: center;
  letter-spacing: 0.15rem;
  line-height: 1.6em;
}

@media screen and (max-width: 450px){
  .live-detail-text{
    font-family: 'ZenMaruGothic-Medium.ttf', sans-serif;
    font-size:font-size: clamp(0.9rem, 1.8vw, 1.2rem);
    letter-spacing:0.01rem;
  }
}
@media screen and (max-width: 450px){
  .live-detail-text{
    font-family: 'ZenMaruGothic-Medium.ttf', sans-serif;
    font-size: clamp(0.7rem, 0.8vw, 1.1rem);
    letter-spacing:0.01rem;
  }
}

.text-green{
  color: var(--color-accent-green);
}
.text-pink{
  color: var(--color-accent-pink);
}

/*
.live-active{
  transform:translateY(0px);
}*/
/*
@media screen and (max-width: 1024px) {
  .live-btn{
    position: absolute;
    top: max(20px, 4vw);
    right: max(20px, 4vw);
    z-index: 10;
  }
  .live-btn img{
    width: max(100px, 14vw);
    height: auto;
  }
}

@media screen and (max-width: 450px) {
  .live-btn{
    position: absolute;
    top: 16px;
    right: 16px;
  }
  .live-btn img{
    width: max(68px, 20vw);
    height: auto;
  }
}
*/
.hero-artwork {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 120vh;
  overflow: hidden;
}
.hero-artwork img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  will-change: transform;
}

.hero-info {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
  background: linear-gradient(to top, #0A0A0F00 0%, #0a0a0fa6 60%, #0A0A0F 100%);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: var(--size-ll) var(--size-m);
  z-index: 2;
}

@media screen and (max-width: 450px) {
  .hero-info{
    padding: max(16vw, var(--size-mm)) var(--size-sn);
  }
}


.hero-info-content {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  opacity: 0;
  transform:translateY(var(--size-n));
  transition: all 1s;
}

.hero-badge span {
  font-family: var(--flatboldfont);
  font-size:  1.2rem;
  font-weight: 500;
  letter-spacing: 0.6rem;
  color: var(--color-accent);
}

@media screen and (max-width: 450px) {

  .hero-badge span {
    font-size:1rem;
  }
}

.hero-title {
  width: 100%;
  margin-top: var(--size-s);
}

@media screen and (max-width: 1024px) {
  .hero-title {
    margin-top: 1.2vw;
  }
}

.hero-title h1 {
  font-family: var(--flatboldfont);
  font-size: 9.4rem;
  font-weight: 800;
  line-height: 0.75em;
  letter-spacing: 0.6rem;
  color: var(--color-primary);
  filter: var(--shadow);
}

@media screen and (max-width: 1024px) {
  .hero-title h1 {
    font-size: max(7.2rem, 9.5vw);
    line-height: 1em;
  }
}
@media screen and (max-width: 450px) {
  .hero-title h1 {
    font-size: 15vw;
    line-height: 1em;
  }
}

.date {
  margin-top: var(--size-n);
}

@media screen and (max-width: 1024px) {
  .date {
    margin-top: 2vw;
  }
}

.hero-date {
  font-family: var(--flatboldfont);
  font-size: var(--size-sn);
  font-weight: 500;
  line-height: 0.75em;
  letter-spacing: 0.3rem;
  color: var(--color-primary);
  text-shadow: 0 4px 4px #00000040;
}

@media screen and (max-width: 1024px) {
  .hero-date{
    font-size:max(1.6rem, 2.2vw);
  }
}

/* CTA Section (hero 内下部) */
.cta-section {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  display: flex;
  justify-content: center;
  padding: var(--size-mn) var(--size-m);
  background: #00000080;
  z-index: 3;
}

@media screen and (max-width: 450px) {
  .cta-section{
    padding: max(5vw, var(--size-sn));
  }
}

.cta-button-row {
  display: flex;
  gap: var(--size-s);
  justify-content: center;
}

.cta-btn-primary,
.cta-btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: 0.8rem;
  padding: 1.4rem 3.2rem;
  border-radius: 100px;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: var(--size-ss);
  font-weight: 700;
  letter-spacing: 0.3rem;
  color: #fff;
  cursor: pointer;
  transition: transform 0.2s, box-shadow 0.2s;
}

@media screen and (max-width: 1024px) {
  .cta-btn-primary,
  .cta-btn-secondary {
    font-size:min(1.6rem, 2.8vw);
    padding: min(1.4rem, 2.8vw) min(3.2rem, 4.2vw);
  }

}

.live-buy:hover,
.cta-btn-primary:hover,
.cta-btn-secondary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px #00000060;
}

.cta-btn-primary {
  background: var(--btn-lime-back);
  border: 1px solid var(--color-accent);
  color: #0A0A0F;
}
.cta-btn-secondary {
  background: var(--btn-purple-back);
  border: 1px solid var(--color-accent-purple);
}

.cta-btn-primary svg,
.cta-btn-secondary svg,
.cta-btn-primary i,
.cta-btn-secondary i {
  width: clamp(1.4rem, 1vw, 1.8rem);
  height: clamp(1.4rem, 1vw, 1.8rem);
}

/* ========================================= */
/* cf SECTION                         */
/* ========================================= */
.cf-section {
  position: relative;
  width: 100%;
  padding: var(--section-padding);
  display: flex;
  flex-direction: column;
  align-items: center;
  overflow: hidden;
}

/* Mesh gradient overlay */
.liner-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: conic-gradient(from 120deg, #EC489920, #C4F82A20, #3B82F620, #7C3AED20, #FA541C20, #2DD4BF20);
  filter: blur(80px);
  opacity: 0.12;
  pointer-events: none;
}

.liner-section-back-color {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0.2;
  background: var(--gradient-rainbow-mesh);
}

.liner-section-back {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 38vw;
  opacity: 0.4;
  pointer-events: none;
  background: url('images/back_star.png') center / cover no-repeat;
  background-size:100%;
  /* Sparkles will be added via JS or SVG decoration */
}

.liner-back-btm{
  top:auto;
  bottom: 0;
  transform: scale(-1, -1);
}



.movie_yt{
  position: relative;
  width: min(58rem, 100%);
  box-sizing:border-box;
}


.movie_yt::before{
  content: "";
  display: block;
  padding-top: 56.25%;
}

.movie_yt_inner{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}


.yt_thumb{
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: auto;
  transform:translateX(0) translateY(-50%);
}

.yt_play{
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  transform:translateX(-50%) translateY(-50%);
  transition: all .5s ease;
  cursor: pointer;

  display: flex;
  align-items:center;
  justify-content:center;
}

.yt_play div{
  display: flex;
  align-items:center;
  justify-content:center;
  gap: 5%;
  color: var(--color-accent);
  background-color: #00000077;
  border-radius:500px;
  padding: var(--size-s) var(--size-n);
  border: 2px solid var(--color-accent);
  font-family: var(--flatboldfont);
  font-size: 2.6rem;
  font-weight: 700;
  letter-spacing: 0.4rem;
  z-index: 10;
}


@media screen and (max-width: 768px) {
  .yt_play div{
    font-size: 1.8rem;
    padding: var(--size-ss) var(--size-sn);
  }
}

@media screen and (max-width: 450px) {
  .yt_play div{
    font-size: 1.6rem;
    padding: var(--size-ss) var(--size-sn);
  }
}

.yt_play:hover{
  transform:translateX(-50%) translateY(-50%) scale(1.16);
}





/* ========================================= */
/* TRACKLIST SECTION                         */
/* ========================================= */
.tracklist-section {
  position: relative;
  width: 100%;
  padding: var(--section-padding);
  display: flex;
  flex-direction: column;
  align-items: center;
  overflow: hidden;
}

@media screen and (max-width: 768px) {
  .tracklist-section {
    padding: var(--size-ll) max(5%, calc(30% - 160px));
  }
}


.tracklist-bg {
  position: absolute;
  top: 0px;
  left: 50%;
  width: 70%;
  height: 100%;
  max-width:800px;
  background: url('images/parts2.png') center / cover no-repeat;
  background-size:100%;
  opacity: 0.15;
  pointer-events: none;
  transform:translateX(-50%);
}

.tracklist-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: min(var(--width-min), 100%);
  position: relative;
  z-index: 1;
  opacity: 0;
  transform:translateY(36px);
  transition: all 0.8s;
}

@media screen and (max-width: 1024px) {
    .tracklist-content {
        width: 100%;
    }
}



.tracklist-title {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.tracklist-body {
  margin-top: calc(clamp(var(--size-mn), 2.5vw, var(--size-m)) - var(--size-s));
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}

.tracklist-tracks {
  display: flex;
  gap: var(--size-n);
  width: 100%;
}
.tracklist-tracks__col {
  display: flex;
  flex-direction: column;
  flex: 1;
}

.tracklist-track {
  display: flex;
  align-items: center;
  gap: var(--size-ss);
  padding: var(--size-s) 0;
  border-bottom: 1px solid #ffffff1f;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 1.6rem;
  font-weight: 600;
  line-height: 0.88;
  color: var(--color-primary);
}

/* Track number badge (arrow shape) */
.tracklist-num {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 30px;
  height: 20px;
  background: color-mix(in srgb, var(--track-color, var(--color-accent-purple)) 15%, transparent);
  clip-path: polygon(0 0, 80% 0, 100% 50%, 80% 100%, 0 100%);
  font-family: 'Space Mono', monospace;
  font-size: 1rem;
  font-weight: 500;
  line-height: 0.9;
  color: var(--track-color, var(--color-accent-purple));
  padding-right: 4px;
}
.tracklist-num--aqua { --track-color: var(--color-accent-aqua); }

/* Bonus Track Area */
.tracklist-bonus {
  margin-top: 36px;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}

.bonusLabel {
  display: inline-flex;
  align-items: center;
  gap: 0.8rem;
  padding: var(--size-st) var(--size-s);
  border-radius: 230px;
  background: #7c3bed33;
  border: 1px solid var(--color-accent-purple);
  font-family: 'M PLUS 1p', sans-serif;
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1rem;
  color: var(--color-primary);
}
.bonusLabel i,
.bonusLabel svg {
  width: 1.6rem;
  height: 1.6rem;
  color: var(--color-accent-purple);
}
.bonusLabel__cd-only {
  font-family: var(--flatboldfont);
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.4rem;
}

.bonus-tracks-area {
  width: 100%;
  margin-top: 22px;
}

.bonusDivider {
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, #7C3AED00, #7C3AED, #7C3AED00);
}

.bonus-tracks {
  display: flex;
  gap: 32px;
  width: 100%;
  background: linear-gradient(90deg, #0a0a0f00 0%, #0A0A0F88 30%, #0A0A0F88 70%, #0a0a0f00 100%);
  background-size: 100%;
  background-blend-mode: normal;
}

/*.tracklist-track {
  color: #ffffffb3;
}*/
.bonus-tracks__col {
  flex: 1;
}

/* ========================================= */
/* PURCHASE SECTION                          */
/* ========================================= */
.purchase-section {
  position: relative;
  width: 100%;
  padding-bottom: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  overflow: hidden;
  background: linear-gradient(to bottom, #202023 63%, #151518 100%);
  border: 1px solid transparent;
  box-shadow: 0 4px 4px #00000040;
}

.deco-chara-left {
  position: absolute;
  left: 0;
  top: 10%;
  width: auto;
  height: 55vw;
  opacity: 0;
  pointer-events: none;
  transform:translateX(-100%) translateY(0%);
  transition: all 0.8s ease-in-out;
}

.deco-chara-right {
  position: absolute;
  right: 0;
  top: 10%;
  width: auto;
  height: 55vw;
  opacity: 0;
  pointer-events: none;
  transform:translateX(100%) translateY(0%);
  transition: all 0.8s ease-in-out;
}

.deco-chara-left img {
  position: relative;
  height: 100%;
}

.deco-chara-right img {
  position: relative;
  height: 100%;
}

.chara-left-active {
  opacity: 0.2;
  transform:translateX(-40%) translateY(0%);
}
.chara-right-active {
  opacity: 0.2;
  transform:translateX(40%) translateY(0%);
}




.purchase-content-top{
  width: 100%;
  padding: clamp(var(--size-l), 5vw, var(--size-ll)) max(8%, calc(50% - 500px)) var(--size-l) max(8%, calc(50% - 500px));
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 1024px) {
  .purchase-content-top {
    padding: var(--size-mm) max(5%, calc(30% - 160px));
  }
}

.purchase-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  position: relative;
  z-index: 1;
  opacity: 0;
  transform:translateY(36px);
  transition: all 0.8s;
}

@media screen and (max-width: 1024px) {
  .purchase-content {
    padding: 0;
  }
}

.purchase-title {
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* Purchase Button Area */
.purchase-button {
  margin-top: clamp(var(--size-mn), 2.5vw, var(--size-m));
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}

.purchase-gentei-label {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: var(--size-s);
  font-weight: 500;
  letter-spacing: 0.4rem;
  line-height: 0.95;
  color: var(--color-accent-pink);
  text-align: center;
}

/* sp_16, sp_26 は削除 — margin-top で対応 */

.purchase-gentei-caution {
  margin-top: clamp(var(--size-ss), 1.5vw, var(--size-sn));
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 1.1rem;
  font-weight: 500;
  letter-spacing: 0.1rem;
  line-height: 1.2em;
  color: #ffffffb3;
  text-align: center;
}


@media screen and (max-width: 450px) {
  .purchase-gentei-caution{
    margin-top: var(--size-s);
    font-size:max(0.9rem, 2vw);
  }
}

.caution-2 {
  margin-top: 1.0rem;
}

.purchase-cta-btn {
  margin-top: clamp(var(--size-sn), 3.5vw, var(--size-n));
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 2.0rem var(--size-mn);
  border-radius: 100px;
  background: var(--gradient-rainbow-mesh);
  border: 1px solid #ffffff66;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.13em;
  color: #fff;
  cursor: pointer;
  text-shadow: var(--text-shadow);
  transition: transform 0.2s, box-shadow 0.2s;
}

@media screen and (max-width: 1024px) {
  .purchase-cta-btn{
    padding:max(1.8rem, 2vw) max(var(--size-sn), 3.6vw);
    font-size:max(var(--size-ss), 1.4vw);
    margin-top: clamp(var(--size-n), 2.5vw, var(--size-mn));
  }
}
@media screen and (max-width: 450px) {
  .purchase-cta-btn{
    margin-top: max(var(--size-s), 5.8vw);
    padding:max(1.4rem, 3vw) var(--size-sn);
    font-size:1.4rem;
  }
}


.purchase-cta-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 var(--size-s) #ffffff40, 0 8px 24px #00000060;
}

.purchase-list-ready {
  margin-top: var(--size-st);
  font-family: 'Space Mono', monospace;
  font-size: 1.6rem;
  font-weight: 400;
  color: var(--color-accent);
}


/* Store Card */
.store-card {
  margin-top: clamp(var(--size-mn), 2.5vw, var(--size-m));  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 700px;
  padding: clamp(3.2rem, 2.4vw, var(--size-sn)) var(--size-sn);
  border-radius: var(--radius-md);
  border: 1px solid #ffffff33;
  overflow: hidden;
  background: linear-gradient(to top, #ffffff10 5%, #ffffff25 100%);
}

@media screen and (max-width: 1024px) {
  .store-card{
    padding: clamp(var(--size-sn), 3vw, var(--size-n)) max(10%, calc(50% - 325px));
  }
}

@media screen and (max-width: 450px) {
  .store-card{
    margin-top: max(var(--size-s), 5.8vw);
  }
}


/* Mesh gradient background (approximation) */
/*.store-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: conic-gradient(from 90deg, #fa8f7330, #8c5cd930, #47bad930, #f2c76b30, #fa8f7330);
  filter: blur(40px);
  opacity: 0.18;
  pointer-events: none;
}*/

.store-card__label {
  position: relative;
  font-family: var(--flatboldfont);
  font-size: clamp(1.0rem, 0.2vw, 1.2rem);
  font-weight: 400;
  letter-spacing: 0.5rem;
  line-height: 0.95;
  color: var(--color-accent-pink);
}

@media screen and (max-width: 1024px) {
  .store-card__label {
    font-size: max(0.9rem, 0.8vw);
  }
}

.store-card__sublabel {
  position: relative;
  margin-top: var(--size-st);
  font-family: 'M PLUS 1p', sans-serif;
  font-size: var(--size-sn);
  font-weight: 500;
  letter-spacing: 0.2rem;
  line-height: 1;
  color: var(--color-primary);
  text-align: center;
}


@media screen and (max-width: 1024px) {
  .store-card__sublabel {
    margin-top: max(1.0rem, 1vw);
    font-family: 'M PLUS 1p', sans-serif;
    font-size: max(2.6vw, var(--size-sn));
  }
}

@media screen and (max-width: 450px) {
  .store-card__sublabel {
    margin-top: 2vw;
    font-family: 'M PLUS 1p', sans-serif;
    font-size: max(5vw, var(--size-sn));
  }
}

.deco-star-r, .deco-star-l{
  position: absolute;
  font-family: 'M PLUS 1p', sans-serif;
  top: 1.6rem;
  width: 15%;
  opacity: 0.4;
}

.deco-star-l{
  left: var(--size-s);
  transform: scale(-1, 1);
}
.deco-star-r{
  right: var(--size-s);
}

.store-button-row {
  position: relative;
  margin-top: var(--size-s);
  display: flex;
  gap: var(--size-s);
  justify-content: center;
}

@media screen and (max-width: 1024px) {
  .store-button-row {
    margin-top: clamp(var(--size-s), 1vw, var(--size-sn));
  }
}

.store-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.8rem;
  padding: 1.8rem 3.2rem;
  border-radius: 100px;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.3rem;
  color: #fff;
  cursor: pointer;
  transition: transform 0.2s, box-shadow 0.2s;
}
.store-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px #00000060;
}
.store-btn i, .store-btn svg { width: 1.8rem; height: 1.8rem; }

.store-btn--lime {
  background: var(--color-accent);
  border: 1px solid var(--color-accent);
  color: #0A0A0F;
}
.store-btn--purple {
  background: var(--color-accent-purple);
  border: 1px solid var(--color-accent-purple);
}

.deco-sparkle-left,
.deco-sparkle-right {
  position: absolute;
  top: 20px;
  width: 130px;
  height: 80px;
  opacity: 0.3;
  pointer-events: none;
}
.deco-sparkle-left { left: 21px; }
.deco-sparkle-right { right: 21px; }

/* Purchase Cards Section */
.purchase-cards-section {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--size-ll) max(8%, calc(50% - 500px));
  background: linear-gradient(to bottom, #000000b3 0%, #000000 96%);
  background-blend-mode: normal;
  box-shadow: 0 4px 4px #00000040;
  border: 1px solid transparent;
}

@media screen and (max-width: 768px) {
  .purchase-cards-section {
    flex-direction: row;
    align-items:center;
    padding: var(--size-ll) max(5%, calc(30% - 160px)) var(--size-mm) max(5%, calc(30% - 160px));
  }
}

.purchase-cards-row {
  display: flex;
  gap: var(--size-n);
  flex-direction: row;
  width: min(var(--width-min), 100%);
  justify-content: space-between;
  flex-direction: row;
}

@media screen and (max-width: 1024px) {
  .purchase-cards-row {
    gap: 2vw;
  }
}

@media screen and (max-width: 768px) {
  .purchase-cards-row {
    width: 100%;
    gap: var(--size-lm);
    flex-direction: column;
  }
}

@media screen and (max-width: 768px) {
  .purchase-cards-row {
    gap: var(--size-mm);
  }
}

/* Card shared */
.card-standard,
.card-limited {
  position: relative;
  display: flex;
  flex-direction: column;
  flex: 1;
  border-radius: var(--radius-md);
  border: 1px solid;
  z-index: 5;
  opacity: 0;
  transform: translateY(var(--size-n));
  transition: all 0.8s;
}


.fade-up{
  opacity: 1;
  transform: translateY(0);
}

.card-standard {
  padding: var(--size-n) var(--size-s) var(--size-s);
  background: linear-gradient(to top, #09090ad5 50%, #262f11d5 100%);
  border-color: var(--color-accent);
}

@media screen and (max-width: 1024px) {
  .card-standard {
    padding: var(--size-n) var(--size-s);
  }
}

.card-limited {
  padding: var(--size-sn) var(--size-s);
  background: linear-gradient(to top, #09090ad5 50%, #271749d5 100%);
  border-color: var(--color-accent-purple);
}

.card-standard::after{
  content: ' ';
   position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: var(--radius-md);
  background-image: url(images/back-standard.png);
  background-size: 110%;
  background-position: center bottom;
  background-repeat: no-repeat;
  opacity: 0.2;
  z-index: -1;
}


.card-limited::after{
  content: ' ';
   position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: var(--radius-md);
  background-image: url(images/back-limited.png);
  background-size: 110%;
  background-position: center bottom;
  background-repeat: no-repeat;
  opacity: 0.2;
  z-index: -1;
}


/* Purchase badge button (absolute top-left) */
.purchase-btn-badge {
  position: absolute;
  top: -28px;
  left: -1px;
  display: inline-flex;
  align-items: center;
  gap: 1rem;
  padding: var(--size-ss) var(--size-n)  var(--size-ss)  var(--size-s);
  border-radius: var(--size-s) 100px 100px 0;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: var(--size-s);
  font-weight: 700;
  letter-spacing: 0.3rem;
  color: var(--color-accent);
  cursor: pointer;
}

@media screen and (max-width: 1024px) {
  .purchase-btn-badge{
    font-size:max(1.6rem, 2vw);
    padding:max(1.2rem, 1.6vw) max(var(--size-sn), 1.6vw);
    padding-left:max(1.6rem, 1.8vw)
  }
}

.purchase-btn-badge i, .purchase-btn-badge svg { 
  width: clamp(1.4rem, 1vw, 1.8rem);
  height: clamp(1.4rem, 1vw, 1.8rem);
 }

.purchase-btn-badge--lime {
  background: var(--color-back);
  border: 1px solid var(--color-accent);
  color: var(--color-accent);
}
.purchase-btn-badge--purple {
  background: var(--color-back);
  border: 1px solid var(--color-accent-purple);
  color: var(--color-accent-purple);
}

/* Card price area */


.card-standard__price-label,
.card-limited__price-label {
  display: block;
  margin-top: var(--size-sn);
  font-family: var(--flatboldfont);
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: 0.5rem;
  line-height: 0.95;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .card-standard__price-label,
  .card-limited__price-label {
    margin-top:clamp(1.2rem, 0.6vw, var(--size-st));
  }
}

@media screen and (max-width: 450px) {
  .card-standard__price-label,
  .card-limited__price-label {
    margin-top:var(--size-s);
  }
}

.card-standard__price-label { color: var(--color-accent); }
.card-limited__price-label { color: var(--color-accent-purple); }

.card-standard__prices,
.card-limited__prices {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin-top: var(--size-st);
}

@media screen and (max-width: 768px) {
  .card-standard__prices,
  .card-limited__prices {
    margin-top:clamp(var(--size-t), 0.25vw, 1.2rem);
  }
}

@media screen and (max-width: 450px) {
  .card-standard__prices,
  .card-limited__prices {
    margin-top:var(--size-st);
  }
}

.price-group {
  display: inline-flex;
  align-items: baseline;
}
.price-value {
  font-family: var(--flatboldfont);
  font-size: var(--size-sn);
  font-weight: 500;
  letter-spacing: 0.2rem;
  color: var(--color-primary);
}

@media screen and (max-width: 1024px) {
  .price-value{
    font-size:clamp(var(--size-s), 2.8vw, var(--size-sn))
  }
}

.price-unit {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 1.1rem;
  letter-spacing: 0.2rem;
  color: var(--color-primary);
}
.price-tax {
  font-family: var(--flatboldfont);
  font-size: 1.1rem;
  letter-spacing: 0.2rem;
  color: #ffffffbf;
}
.price-star { font-size: 1.4rem; }

.card-standard__divider,
.card-limited__divider {
  margin-top: 20px;
  height: 1px;
  width: 100%;
  opacity: 0.5;
}
.card-standard__divider { background: var(--color-accent); }
.card-limited__divider { background: var(--color-accent-purple); }

/* Card content rows */
.card-standard__content-row,
.card-limited__content-row,
.gentei_white__sticker-row {
  display: flex;
  align-items: center;
  gap: var(--size-st);
  margin-top: var(--size-s);
}

.gentei_white__content-row {
  display: flex;
  align-items: center;
  gap: var(--size-t);
}

.content-count {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 3.6rem;
  font-weight: 600;
  line-height: 0.6em;
  color: var(--color-primary);
}
.content-unit {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 1.6rem;
  font-weight: 600;
  color: var(--color-primary);
}
.content-note {
  font-family: var(--flatboldfont);
  font-size: 1.2rem;
  letter-spacing: 0.1rem;
  color: #ffffffb3;
}

.card-standard__content-row{
  margin-top: var(--size-n);
  justify-content: center;
}

.card-standard__cd-image {
  margin: 0 auto;
  margin-top: var(--size-s);
  width: 32%;
  height: 32%;
  max-width:110px;
  max-height:110px;
  object-fit: cover;
}

.card-standard__cd-image img{
  width: 100%;
  height: auto;
}

.card-limited__title-row {
  margin-top: var(--size-s);
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 2rem;
  font-weight: 600;
  letter-spacing: 0.3rem;
  color: var(--color-primary);
  text-align: center;
}

/* Gentei white box */
.gentei_white {
  position: relative;
  margin-top: var(--size-sn);
  padding: var(--size-sn) var(--size-s) var(--size-s) var(--size-s);
  border-radius: 8px;
  background: linear-gradient(90deg, #ffffff40 38%, #ffffff2b 100%);
  border: 1px solid #ffffff33;
}

.plus {
  position: absolute;
  top: -12px;
  left: 50%;
  transform:translateX(-50%);
  width: 25px;
  height: 25px;
  border-radius: 20px;
  background: var(--color-accent-pink);
  border: 1px solid #ffffff1a;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  font-weight: 700;
  color: #fff;
}

.gentei_white__description {
  margin-top: 12px;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: 0.1rem;
  line-height: 1.5;
  color: var(--color-accent-pink);
}


@media screen and (max-width: 1024px) {
  .gentei_white__description{
    font-size:clamp(1.4rem, 1.3vw, var(--size-ss));
  }
}

@media screen and (max-width: 768px) {
  .gentei_white__description{
    font-size:clamp(var(--size-s), 1.3vw, var(--size-sn));
  }
}

.gentei_white__note {
  margin-top: var(--size-t);
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 1rem;
  letter-spacing: 0.07rem;
  line-height: 1.5;
  color: var(--color-primary);
}

.gentei_white__divider {
  margin-top: var(--size-s);
  height: 0px;
  width: 100%;
  border-bottom: 1px dotted var(--color-accent-pink);
  opacity: 0.7;
}

.gentei_white__sticker-row {
  margin-top: 24px;
}

/* ========================================= */
/* LINER NOTES SECTION                       */
/* ========================================= */
.liner-section {
  position: relative;
  width: 100%;
  padding: var(--section-padding);
  display: flex;
  align-items: center;
  overflow: hidden;
}
.liner-section-column {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}
/* Mesh gradient overlay */
.liner-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: conic-gradient(from 120deg, #EC489920, #C4F82A20, #3B82F620, #7C3AED20, #FA541C20, #2DD4BF20);
  filter: blur(80px);
  opacity: 0.12;
  pointer-events: none;
}

.liner-section-back-color {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0.2;
  background: var(--gradient-rainbow-mesh);
}

.liner-section-back {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 38vw;
  opacity: 0.4;
  pointer-events: none;
  background: url('images/back_star.png') center / cover no-repeat;
  background-size:100%;
  /* Sparkles will be added via JS or SVG decoration */
}

.liner-back-btm{
  top:auto;
  bottom: 0;
  transform: scale(-1, -1);
}

.liner-section-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  z-index: 1;
}

.liner-illustration {
  margin-top: clamp(3.6rem, 3.6vw,4.2rem);
  position: relative;
  text-align: center;
  z-index: 1;
}
.liner-illustration img {
  position: relative;
  width: min(500px, 85%);
  height: auto;
  margin: 0 auto;
  object-fit: contain;
}

@media screen and (max-width: 450px) {
  .liner-illustration img {
    position: relative;
    width: min(350px, 96%);
  }
}

.liner-notes-grid {
  margin-top: var(--size-m);
  display: flex;
  gap: var(--size-n);
  width: min(1036px, 100%);
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 1024px) {
  .liner-notes-grid{
      gap: max(3%, 1.4rem);
  }
}

.liner-column-left,
.liner-column-right {
  display: flex;
  flex-direction: column;
  gap: var(--size-s);
  flex: 1;
  align-items: center;
}

/* Liner Card */
.liner-card {
  position: relative;
  width: min(500px, 100%);
}

.liner_title {
  width: 100%;
  display: flex;
  align-items: flex-end;
  gap: var(--size-st);
  position: absolute;
  top: -1px;
  left: 17px;
  z-index: 2;
  color: var(--color-primary);
}

@media screen and (max-width: 1024px) {
  .liner_title{
    top: calc((clamp(1.6rem, 2vw, 1.4rem) / 2) + 0.2rem);
    gap: 3%;
    left: 11px;
  }
}


.liner_title__num {
  font-family: 'Oswald', sans-serif;
  font-size: 6.8rem;
  font-weight: 400;
  letter-spacing: 0.4rem;
  line-height: 0.9;
  color: var(--color-primary);
  opacity: 0.85;
}

@media screen and (max-width: 1024px) {
  .liner_title__num {
    font-family: 'Oswald', sans-serif;
    font-size: calc((clamp(1.6rem, 2vw, 1.4rem) + 1.5rem)* 1.5);
    font-weight: 400;
    letter-spacing: 0.25rem;
    line-height: 0.9;
  }
}

.num_l{
    width: 62px;
    height: var(--size-sn);
}

.num_l_cd{
  width: 42px;
  height: var(--size-sn);
  font-size:1.2rem;
  line-height: 1em;
}

.liner_title__name {
  font-family: 'M PLUS 1p', sans-serif;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.05rem;
  line-height: 1;
  color: var(--color-primary);
}

@media screen and (max-width: 1024px) {
  .liner_title__name {
    font-size: clamp(1.6rem, 2vw, 1.4rem);
    font-weight: 700;
    letter-spacing: 0.05rem;
    line-height: 1;
  }
}

.liner_box {
  margin-top: 21.5px;
  display: flex;
  flex-direction: column;
  border-radius: var(--size-st);
  border: 1px solid var(--color-accent-purple);
  overflow: hidden;
}

.title-box {
  font-family: 'M PLUS 1p', sans-serif;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.05rem;
  padding: 2rem;
  background: #7c40fc2a;
  min-height: calc(2rem + 1.9rem * 2)
}

@media screen and (max-width: 1024px) {
  .title-box {
    padding: 1.6rem;
    background: #7c40fc2a;
    min-height: calc(clamp(1.6rem, 2vw, 1.4rem) + 1.4rem * 2);
  }
}

.rainbow_full {
  width: 100%;
  height: 1px;
  background: var(--gradient-rainbow);
}

.liner-box-come {
  padding: var(--size-s) 20px;
  background: linear-gradient(to bottom, #7c40fc10, #7c40fc06);
}

@media screen and (max-width: 1024px) {

  .liner-box-come {
    padding: var(--size-ss) var(--size-s);
    background: linear-gradient(to bottom, #7c40fc10, #7c40fc06);
  }
}


.liner-box-come p {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.8;
  color: var(--color-primary);
}


@media screen and (max-width: 1024px) {
  .liner-box-come p {
    font-family: 'Zen Maru Gothic', sans-serif;
    font-size: 1.2rem;
    font-weight: 400;
    line-height: 1.8;
  }
}

.liner-box-link{
    display: flex;
    gap: min(5%, var(--size-st));
    margin-top: var(--size-ss);
}


@media screen and (max-width: 768px) {
  .liner-box-link{
    margin-top: var(--size-st);
  }
}

.liner-box-link a{
  display: inline-flex;
      font-family: 'Zen Maru Gothic', sans-serif;
    font-size: 1.2rem;
    font-weight: 400;
    line-height: 1em;
  padding: 1rem var(--size-s);
  color: var(--color-accent);
  border: 1px solid var(--color-accent);
  border-radius: 200px;
  transition: all 0.3s;
}


@media screen and (max-width: 768px) {
  .liner-box-link a{
    display: inline-flex;
    font-size: 1.2rem;
    font-weight: 400;
    line-height: 1em;
    padding: 1rem var(--size-s);
    color: var(--color-accent);
    border: 1px solid var(--color-accent);
    border-radius: 200px;
  }
}

@media screen and (max-width: 450px) {
  .liner-box-link a{
    margin-bottom: 0.3rem;
  }
}


.liner-box-link a:hover{
  scale:1.07;
}
.kirakira {
  position: absolute;
  top: 3px;
  right: 0;
  width: 130px;
  height: 80px;
  opacity: 0.5;
  pointer-events: none;
}

/* ========================================= */
/* INFO / PROFILE SECTION                    */
/* ========================================= */
.info-section {
  position: relative;
  width: 100%;
  padding: var(--section-padding);
  display: flex;
  flex-direction: column;
  align-items: center;
  background: linear-gradient(180deg, #0A0A0F 0%, #0F0A1A 50%, #0A0A0F 100%);
  border-radius: 5px;
}

.info-section-title {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.profile-content {
  margin-top: var(--size-m);
  position: relative;
  display: flex;
  flex-direction: column;
  padding: var(--size-n);
  background: #ffffff0d;
  overflow: hidden;
}

/* Deco corners */
.deco-corner-tl,
.deco-corner-br {
  position: absolute;
  width: 42px;
  height: 42px;
  pointer-events: none;
}
.deco-corner-tl {
  top: 0;
  left: 0;
  border-top: 1px solid;
  border-left: 1px solid;
  border-image: conic-gradient(from 180deg, var(--color-accent-pink), #8c5cd9, var(--color-accent-aqua), var(--color-accent)) 1;
}
.deco-corner-br {
  bottom: 0;
  right: 0;
  border-bottom: 1px solid;
  border-right: 1px solid;
  border-image: conic-gradient(from 0deg, var(--color-accent-pink), #8c5cd9, var(--color-accent-aqua), var(--color-accent)) 1;
}

.deco-corner-back {
  position: absolute;
  right: -2%;
  bottom: -5%;
  opacity: 0.08;
  pointer-events: none;
}
.deco-corner-back img {
  width: 200px;
  height: auto;
}

.profile-card {
  display: flex;
  gap: 32px;
  align-items: center;
  position: relative;
  z-index: 1;
}

.profile-image {
  flex-shrink: 0;
  width: 25%;
  height: 25%;
  border-radius: var(--size-st);
  overflow: hidden;
}
.profile-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.profile-text {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: var(--size-s);
}

.profile-name-text {
  display: flex;
  align-items: center;
  gap: var(--size-st);
}

.profile-name span {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 2.6rem;
  font-weight: 500;
  letter-spacing: 0.3rem;
  line-height: 1em;
  color: var(--color-primary);
}

.fruits-icon {
  width: var(--size-n);
  height: var(--size-n);
  display: flex;
  align-items: center;
  justify-content: center;
}
.fruits-icon i, .fruits-icon svg {
  width: 100%;
  height: 100%;
  color: #ffffffcc;
}

.profile-bio p {
  display: block;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 1.4rem;
  font-weight: 400;
  letter-spacing:0.08rem;
  line-height: 1.8;
  color: var(--color-primary);
}

.footer-social {
  display: flex;
  font-family: 'Zen Maru Gothic', sans-serif;
  gap: 1.4rem;
}

.social-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--size-mn);
  height: var(--size-mn);
  padding: var(--size-st);
  border-radius: 100px;
  transition: transform 0.2s;
}


@media screen and (max-width: 1024px) {
  .social-icon {
    width: var(--size-n);
    height: var(--size-n);
    padding: var(--size-st);
    border-radius: 100px;
    transition: transform 0.2s;
  }
}


.social-icon:hover { transform: scale(1.1); }
.social-icon img { color: #ffffffcc; }

.social-icon--aqua  { background: #55e4f740; border: 1px solid #55e4f726; }
.social-icon--lime  { background: #b6eb2440; border: 1px solid #f4f45226; }
.social-icon--pink  { background: #ff6bbf40; border: 1px solid #ff6bbf26; }
.social-icon--blue  { background: #3c83f640; border: 1px solid #3b82f526; }
.social-icon--green { background: #1fc78440; border: 1px solid #1ec98526; }
.social-icon--orange{ background: #fa551e40; border: 1px solid #fa511926; }

/* ========================================= */
/* FOOTER                                    */
/* ========================================= */
.footer {
  width: 100%;
  padding: var(--size-m) var(--size-n);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--size-ss);
  text-align: center;
  position: relative;
  overflow: hidden;/*
  border-top: 2px solid;
  border-image: var(--gradient-rainbow) 1;*/
}
/* Background layers */
.footer::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--color-card);
  z-index: -2;
}
.footer::after {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--gradient-rainbow-mesh);
  opacity: 0.08;
  z-index: -1;
  pointer-events: none;
}

.footer-logo {
  font-family: var(--flatboldfont);
  font-size: 2.4rem;
  font-weight: 800;
  letter-spacing: 0.4rem;
  color: var(--color-primary);
}

.footer-copyright {
  font-family: 'Space Mono', monospace;
  font-size: 1rem;
  font-weight: 400;
  color: var(--color-text-muted);
}

/* ========================================= */
/* RESPONSIVE: ≤540px                        */
/* ========================================= */
@media (max-width: 540px) {
  .tracklist-section,
  .liner-section,
  .info-section {
    padding: var(--section-padding-sp);
  }

@media (max-width: 540px) {
  .tracklist-tracks, .bonus-tracks{
    gap: 0;
  }
}
  /* 縦カラム → 1列 */
  .purchase-cards-row,
  .liner-notes-grid,
  .profile-card {
    flex-direction: column;
  }

  .tracklist-tracks {
    flex-direction: column;
  }

  .bonus-tracks {
    flex-direction: column;
  }

  /* store-button-row は横のまま */
  .store-button-row {
    flex-direction: row;
  }

  .profile-image {
    width: 160px;
    height: 160px;
    align-self: center;
  }

  .profile-text {
    min-height: auto;
  }

  .template-label-s {
    font-size: clamp(2.4rem, 8vw, 3.6rem);
  }
}


