@charset "UTF-8";

/* ===========================================================
   soraru official site - Static HTML reproduction (balanced v2)
   =========================================================== */

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{
  width:100%;
  scrollbar-gutter: stable;          /* スクロールバー有無で横にずれないように */
  overflow-x: hidden;
}
html,body{ width:100%; }
img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; }
ul,ol{ list-style:none; }
button{ background:none; border:0; color:inherit; cursor:pointer; font:inherit; }

/* ---------- Variables ---------- */
:root{
  --c-bg-top:        #0b0a1d;
  --c-bg-mid:        #1c1448;
  --c-bg-deep:       #2a1d5c;
  --c-bg-purple:     #3a2870;
  --c-bg-night:      #0e1530;
  --c-text:          #f4f1ea;            /* 純白を避けた温かみのあるオフホワイト */
  --c-text-sub:      #b9b1d2;
  --c-text-mute:     rgba(244,241,234,.45);
  --c-accent:        #e8d8a8;            /* 上品なシャンパンゴールド */
  --c-accent-soft:   rgba(232,216,168,.5);
  --c-line:          rgba(244,241,234,.42);
  --c-line-soft:     rgba(244,241,234,.16);
  --c-card:          rgba(255,255,255,.025);
  --c-card-hover:    rgba(232,216,168,.07);
  --c-btn-border:    rgba(244,241,234,.85);

  --ff-jp: "Hiragino Kaku Gothic ProN","Noto Sans JP","Yu Gothic UI","Yu Gothic","Meiryo",sans-serif;
  --ff-jp-sans: "Hiragino Kaku Gothic ProN","Noto Sans JP","Yu Gothic UI","Yu Gothic","Meiryo",sans-serif;
  --ff-en: "Avenir Next","Helvetica Neue","Segoe UI",Arial,sans-serif;
  --ff-en-sans: "Avenir Next","Helvetica Neue","Segoe UI",Arial,sans-serif;

  --header-h:   76px;
  --max-w-nav:  1320px;
  --max-w-page: 1120px;
  --pad-x:      28px;

  --gap-section-y: 96px;
  --gap-title-y:   56px;

  --ease:       cubic-bezier(.2,.7,.2,1);
  --t-base:     .55s var(--ease);
  --t-fast:     .25s var(--ease);
}

/* ---------- Body / Background ---------- */
body{
  font-family: var(--ff-jp-sans);
  color: var(--c-text);
  background:
    radial-gradient(ellipse 120% 80% at 50% -20%, rgba(80,50,140,.55) 0%, transparent 60%),
    radial-gradient(ellipse 90% 60% at 80% 30%, rgba(120,60,150,.18) 0%, transparent 55%),
    radial-gradient(ellipse 70% 50% at 10% 70%, rgba(40,80,150,.18) 0%, transparent 60%),
    linear-gradient(180deg, #0a0820 0%, #0d0a26 35%, #0a0a1f 70%, #060614 100%);
  min-height: 100vh;
  line-height: 1.85;
  font-weight: 300;
  letter-spacing: .02em;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  overflow-x: hidden;
}
body::before,body::after{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:0;
  background-repeat:repeat;
}
body::before{
  background-image:
    radial-gradient(1.5px 1.5px at 20px 30px, #fff, transparent),
    radial-gradient(1px 1px at 80px 110px, rgba(255,255,255,.7), transparent),
    radial-gradient(1.5px 1.5px at 160px 200px, #fff, transparent),
    radial-gradient(1px 1px at 240px 60px, rgba(255,255,255,.6), transparent),
    radial-gradient(1px 1px at 300px 280px, rgba(255,255,255,.5), transparent),
    radial-gradient(1.5px 1.5px at 420px 160px, #fff, transparent);
  background-size: 480px 320px;
  opacity:.55;
}
body::after{
  background-image:
    radial-gradient(1px 1px at 50px 220px, rgba(255,255,255,.4), transparent),
    radial-gradient(2px 2px at 200px 90px, rgba(255,255,255,.85), transparent),
    radial-gradient(1px 1px at 380px 260px, rgba(255,255,255,.4), transparent);
  background-size: 460px 360px;
  opacity:.6;
}

/* ===========================================================
   Header / Navigation
   =========================================================== */
.site-header{
  position:fixed; top:0; left:0; right:0;
  height:var(--header-h);
  z-index:100;
  background: linear-gradient(180deg, rgba(10,8,28,.85) 0%, rgba(20,12,46,.55) 70%, transparent 100%);
  backdrop-filter: blur(12px) saturate(140%);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
  display:flex; align-items:center;
  padding: 0 32px;
  transition: background var(--t-base);
}
body.admin-bar .site-header{
  top: 0;
}
.site-header::after{
  content:""; position:absolute; left:0; right:0; bottom:0;
  height:1px;
  background: linear-gradient(90deg, transparent 0%, rgba(232,216,168,.25) 50%, transparent 100%);
}
/* スクロール時は色だけ変える（高さ変えるとガタつくので固定） */
.site-header.is-scrolled{
  background: rgba(10,8,28,.92);
}
.site-header__inner{
  width:100%;
  max-width: var(--max-w-nav);
  margin: 0 auto;
  display:flex; align-items:center; justify-content:space-between;
  gap: 24px;
}

/* Logo */
.brand{
  display:inline-flex; align-items:center; gap: 12px;
  color: var(--c-text);
  position: relative;
  text-decoration: none;
}
.brand__name{
  font-family: var(--ff-en);
  font-style: normal;
  font-size: 22px;
  letter-spacing: .42em;
  font-weight: 300;
  color: var(--c-text);
  line-height: 1;
  padding-right: .42em; /* tracking 補正 */
  transition: color var(--t-fast);
}
.brand:hover .brand__name{ color: var(--c-accent); }
.brand__star{
  position: relative;
  width:12px; height:12px;
  background:
    radial-gradient(circle, var(--c-accent) 0 1px, transparent 2px),
    linear-gradient(0deg, transparent 45%, var(--c-accent) 49% 51%, transparent 55%),
    linear-gradient(90deg, transparent 45%, var(--c-accent) 49% 51%, transparent 55%);
  background-size:100% 100%;
  filter: drop-shadow(0 0 6px rgba(232,216,168,.7));
  animation: twinkle 4s ease-in-out infinite;
  flex: 0 0 auto;
}
@keyframes twinkle{
  0%,100%{ opacity:.85; transform: scale(1); }
  50%   { opacity:1;  transform: scale(1.15); }
}

/* Nav */
.gnav{ flex:1; }
.gnav__list{
  display:flex; align-items:center; justify-content:flex-end;
  gap:32px;
  font-family: var(--ff-en-sans);
  font-size:12px;
  letter-spacing:.28em;
  font-weight: 400;
}
.gnav__list a{
  color: var(--c-text); padding:8px 0;
  position: relative;
  transition: color var(--t-fast);
}
.gnav__list a::after{
  content:""; position:absolute; left:50%; bottom:2px;
  width:0; height:1px; background: var(--c-accent);
  transform: translateX(-50%);
  transition: width var(--t-base);
}
.gnav__list a:hover{ color: var(--c-accent); }
.gnav__list a:hover::after{ width: 100%; }
.gnav__cart{ font-size:17px; display:inline-flex; align-items:center; }
.gnav__cart a::after{ display:none; }

/* Contact link — 他ナビと統一感のある最小限の装飾 */
.gnav__list a.btn-contact{
  display:inline-flex; align-items:center;
  gap: 10px;
  padding: 8px 0 8px 22px;
  margin-left: 6px;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--c-text);
  font-family: var(--ff-en-sans);
  font-size: 12px;
  letter-spacing: .28em;
  position: relative;
  overflow: visible;
  transition: color var(--t-fast);
}
.gnav__list a.btn-contact::before{
  content:"";
  position: absolute;
  left: 0; top: 50%;
  width: 12px; height: 1px;
  background: var(--c-accent);
  transform: translateY(-50%);
  transition: width var(--t-base), background var(--t-base);
}
.gnav__list a.btn-contact::after{
  content:""; position:absolute; left:50%; bottom:2px;
  width:0; height:1px; background: var(--c-accent);
  transform: translateX(-50%);
  transition: width var(--t-base);
  display: block;
}
.gnav__list a.btn-contact:hover{ color: var(--c-accent); }
.gnav__list a.btn-contact:hover::before{ width: 18px; }
.gnav__list a.btn-contact:hover::after{ width: calc(100% - 22px); left: 22px; transform: none; }

/* ===========================================================
   Layout
   =========================================================== */
main{ position:relative; z-index:1; padding-top: var(--header-h); }
/* TOPページのみ Hero がヘッダーの裏に回り込むため打ち消す */
body.is-top main{ padding-top: 0; }
.container{
  max-width: var(--max-w-page);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}

/* ===========================================================
   Hero — 画像のアスペクト比を維持して全体表示（頭が切れない）
   =========================================================== */
.hero{
  position: relative;
  width: 100%;
  background: #0a0a1a;
  overflow: hidden;
  line-height: 0; /* 画像下の余白を消す */
}
.hero__image{
  display: block;
  width: 100%;
  height: auto;            /* 画像本来のアスペクト比を維持 */
  object-fit: contain;     /* トリミングせず全体を表示 */
  animation: heroZoom 12s ease-out forwards;
  transform-origin: center;
}
.hero::after{
  content:"";
  position:absolute; left:0; right:0; bottom:0; height: 18%;
  background: linear-gradient(180deg, transparent 0%, rgba(10,8,32,.55) 100%);
  pointer-events: none;
  z-index: 1;
}
@keyframes heroZoom{
  from{ transform: scale(1.04); }
  to  { transform: scale(1); }
}

/* ===========================================================
   Slides (Hero下のバナーカルーセル) — 16:9 × 3並び
   =========================================================== */
.slides{
  position: relative;
  padding: 64px 0 64px;
}
.slides__viewport{
  display: flex;
  gap: 16px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  padding: 0 72px;
}
.slides__viewport::-webkit-scrollbar{ display: none; }
.slides__item{
  flex: 0 0 calc((100% - 32px) / 3);
  scroll-snap-align: start;
  aspect-ratio: 16 / 9;
  background-color: #2a1d5c;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: block;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: transform var(--t-base);
}
.slides__item::after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 60%, rgba(10,8,28,.4) 100%);
  opacity: .8;
  transition: opacity var(--t-base);
}
.slides__item:hover{ transform: translateY(-4px); }
.slides__item:hover::after{ opacity: .4; }
.slides__arrow{
  position: absolute;
  top: 50%;
  width: 52px; height: 52px;
  border-radius: 50%;
  background: rgba(244,241,234,.08);
  color: var(--c-text);
  border: 1px solid var(--c-line);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px;
  font-family: var(--ff-en-sans);
  transform: translateY(-50%);
  transition: background var(--t-base), transform var(--t-base), border-color var(--t-base), color var(--t-base);
  z-index: 2;
}
.slides__arrow:hover{
  background: var(--c-accent);
  color: #1a0d40;
  border-color: var(--c-accent);
  transform: translateY(-50%) scale(1.06);
}
.slides__arrow--prev{ left: 24px; }
.slides__arrow--next{ right: 24px; }

/* ===========================================================
   Section common
   =========================================================== */
.section{
  position:relative;
  padding: var(--gap-section-y) 0;
  z-index:1;
}

/* TOP page section title — 中央配置・大きめ・上に小さなジャパンタイトル */
.section__title{
  font-family: var(--ff-en);
  font-size: 56px;
  letter-spacing: .18em;
  font-weight: 300;
  font-style: normal;
  color: var(--c-text);
  text-align: center;
  margin: 0 auto 56px;
  max-width: var(--max-w-page);
  padding: 0 var(--pad-x);
  line-height: 1;
  position: relative;
}
.section__title__text{
  display: inline-block;
  position: relative;
  padding: 18px 0;
}
.section__title__text::before{
  content: attr(data-jp);
  display: block;
  font-family: var(--ff-jp-sans);
  font-style: normal;
  font-size: 11px;
  letter-spacing: .55em;
  color: var(--c-accent);
  margin-bottom: 14px;
  opacity: .9;
}
.section__title__text::after{
  content:"";
  position: absolute;
  left: 50%; bottom: -10px;
  transform: translateX(-50%);
  width: 36px; height: 1px;
  background: var(--c-accent);
}

/* Page title (下層共通) */
.page-title{
  text-align:center;
  padding: 80px 0 0;
  margin-bottom: var(--gap-title-y);
}
.page-title__en{
  font-family: var(--ff-en);
  font-style: normal;
  font-size: 56px;
  letter-spacing: .14em;
  font-weight: 300;
  line-height: 1;
  color: var(--c-text);
}
.page-title__jp{
  display: block;
  font-family: var(--ff-jp-sans);
  font-size: 11px;
  letter-spacing: .55em;
  color: var(--c-accent);
  margin-top: 18px;
}
.page-title::after{
  content:""; display:block;
  width: 40px; height: 1px;
  background: var(--c-accent);
  margin: 28px auto 0;
}

/* ===========================================================
   Filter tabs (pill buttons)
   =========================================================== */
.filter-tabs{
  display:flex; flex-wrap:wrap; justify-content:center;
  gap:8px;
  margin-bottom: 48px;
}
.filter-tabs__btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:8px 28px; min-width:108px;
  border:1px solid rgba(244,241,234,.42);
  border-radius:999px;
  background: rgba(8,8,24,.24);
  color: rgba(244,241,234,.84);
  font-family: var(--ff-jp-sans);
  font-size:12px; letter-spacing:.16em;
  font-weight: 500;
  transition: background var(--t-base), color var(--t-base), border-color var(--t-base);
}
.filter-tabs__btn--en{ font-family: var(--ff-en-sans); letter-spacing:.28em; font-size: 11px; }
.filter-tabs__btn:hover{
  border-color: var(--c-accent);
  color: var(--c-accent);
}
.filter-tabs__btn.is-active{
  background: var(--c-accent);
  color: #1a0d40;
  border-color: var(--c-accent);
}

/* ===========================================================
   Bordered box
   =========================================================== */
.bordered-box{
  border:1px solid var(--c-line-soft);
  border-radius:2px;
  max-width: var(--max-w-page);
  margin: 0 auto;
  background: linear-gradient(180deg, rgba(255,255,255,.025) 0%, rgba(255,255,255,.01) 100%);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  position: relative;
}
.bordered-box::before{
  content:""; position:absolute; top:-1px; left:30%; right:30%; height:1px;
  background: linear-gradient(90deg, transparent, var(--c-accent-soft), transparent);
}

/* Category pill */
.cat-pill{
  display:inline-flex; align-items:center; justify-content:center;
  padding:4px 14px;
  border-radius:0;
  background: transparent;
  color: var(--c-accent);
  border: 1px solid var(--c-accent-soft);
  font-family: var(--ff-jp-sans);
  font-size:10px; letter-spacing:.18em;
  min-width:84px;
  font-weight: 400;
}
.cat-pill--en{ font-family: var(--ff-en-sans); letter-spacing:.25em; }

/* ===========================================================
   News
   =========================================================== */
.news-list{ /* top page used */
  max-width: var(--max-w-page);
  margin:0 auto;
  border-top:1px solid var(--c-line-soft);
}
.news-item{
  display:grid;
  grid-template-columns: 140px 1fr 16px;
  align-items:center; gap:18px;
  padding:18px 12px;
  border-bottom:1px solid var(--c-line-soft);
  font-size:14px;
  transition: background .2s;
}
.news-item:hover{ background: rgba(255,255,255,.04); }
.news-item__date{
  font-family:var(--ff-en); letter-spacing:.08em;
  color: var(--c-text-sub); white-space:nowrap;
}
.news-item__title{ color:#fff; line-height:1.6; }
.news-item__more{ color: rgba(255,255,255,.5); font-size:14px; text-align:right; }

/* TOP page NEWS — bordered-box + Read more pill button */
.top-news{
  padding: 80px 0 32px;
  position: relative;
}
.top-news .bordered-box{
  padding: 8px 0;
}
.top-news .news-row{
  padding: 22px 36px;
}
.read-more-pill{
  display: inline-flex;
  align-items: center; justify-content: center;
  gap: 18px;
  padding: 13px 44px;
  border: 1px solid var(--c-line);
  border-radius: 999px;
  background: transparent;
  color: var(--c-text);
  font-family: var(--ff-en-sans);
  font-size: 11px;
  letter-spacing: .35em;
  margin: 48px auto 0;
  position: relative;
  overflow: hidden;
  transition: color var(--t-base), border-color var(--t-base);
}
.read-more-pill::before{
  content:""; position:absolute; inset:0;
  background: var(--c-accent);
  transform: translateX(-101%);
  transition: transform .5s var(--ease);
  z-index: -1;
}
.read-more-pill:hover{
  color: #1a0d40;
  border-color: var(--c-accent);
}
.read-more-pill:hover::before{ transform: translateX(0); }
.read-more-pill .arrow{
  display: inline-flex; align-items: center; justify-content: center;
  width: 24px; height: 24px; border-radius: 50%;
  border: 1px solid currentColor;
  font-size: 10px;
  transition: transform var(--t-base);
}
.read-more-pill:hover .arrow{ transform: translateX(4px); }

/* TOP page: SCHEDULE + DISCOGRAPHY 2カラムラッパー */
.top-two-col{
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 40px;
  max-width: var(--max-w-page);
  margin: 0 auto;
  padding: 56px var(--pad-x) 72px;
  align-items: stretch;
}
.top-two-col > section{
  padding: 0; min-width: 0;
  display: flex;
  flex-direction: column;
}
.top-two-col .container{
  padding: 0;
  display: flex;
  flex-direction: column;
  flex: 1;
  width: 100%;       /* flex itemとして親（section）の cross-axis 幅にstretch */
  min-width: 0;
}
.top-two-col > section{ align-self: stretch; }

/* 2カラム内の section__title — boxのすぐ上に小さくミニマルに */
.top-two-col .section__title{
  font-size: 22px;
  letter-spacing: .28em;
  text-align: left;
  margin: 0 0 18px;
  padding: 0;
  max-width: none;
  font-weight: 300;
}
.top-two-col .section__title__text{
  padding: 0;
  display: inline-flex;
  align-items: center;
  gap: 14px;
}
.top-two-col .section__title__text::before{
  display: inline-block;
  font-size: 10px;
  letter-spacing: .4em;
  margin: 0;
  color: var(--c-accent);
  position: static;
}
.top-two-col .section__title__text::after{
  display: none;       /* 短い下線は省略してミニマル化 */
}

/* セクション本体（box）— 高さを揃える */
.top-two-col .top-schedule .bordered-box,
.top-two-col .top-discog .bordered-box{
  display: flex;
  flex-direction: column;
  max-width: none;            /* 親カラム幅いっぱいに */
  width: 100%;
  margin: 0;
  flex: 1;                    /* 親（container/section）の高さに合わせて伸びる */
}
.top-two-col .bordered-box__body{ flex: 1; }
.top-two-col .discog-feature__link{ flex: 1; display: flex; flex-direction: column; }
.top-two-col .bordered-box__body{ display: flex; flex-direction: column; }
.top-two-col .bordered-box__foot{
  display: flex;
  justify-content: center;
  padding: 16px 20px 20px;
  border-top: 1px solid var(--c-line-soft);
}

/* 2カラム内の Read more — 中央＋small */
.top-two-col .read-more-pill{
  margin: 0;
  padding: 9px 24px;
  font-size: 10px;
  letter-spacing: .3em;
  gap: 12px;
}
.top-two-col .read-more-pill .arrow{ width: 20px; height: 20px; font-size: 9px; }

/* 2カラム内の Schedule は密度を上げる */
.top-two-col .schedule-row{ padding: 16px 22px; }
.top-two-col .schedule-row__head{ gap: 14px; margin-bottom: 6px; }
.top-two-col .schedule-row__year{ min-width: 60px; padding: 3px 10px; font-size: 10px; }
.top-two-col .schedule-row__date{ font-size: 11.5px; }
.top-two-col .schedule-row__title{ font-size: 13.5px; line-height: 1.55; }
.top-two-col .schedule-row::after{ right: 22px; }

/* TOP page DISCOGRAPHY (latest 1) — bordered-box 内に画像＋メタ情報 */
.top-discog{ padding: 0; }
.discog-feature{ /* flex column は .top-two-col 側で適用済み */ }
.discog-feature__link{
  display: flex;
  flex-direction: column;
  width: 100%;
  padding: 28px 28px 24px;
  color: var(--c-text);
  transition: opacity var(--t-fast);
}
.discog-feature__link:hover{ opacity: .92; }
.discog-feature__cover{
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 18px;
  overflow: hidden;
  min-height: 0;
}
.discog-feature__cover img{
  display: block;
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;     /* 元のアスペクト比を維持 */
  box-shadow: 0 12px 40px -16px rgba(0,0,0,.7);
  transition: box-shadow var(--t-base), transform var(--t-base);
}
.discog-feature__link:hover .discog-feature__cover img{
  box-shadow: 0 20px 50px -12px rgba(232,216,168,.18);
  transform: translateY(-2px);
}
.discog-feature__info{
  text-align: center;
}
.discog-feature__cat{ margin-bottom: 10px; }
.discog-feature__date{
  font-family: var(--ff-en-sans);
  font-size: 12px;
  letter-spacing: .06em;
  color: var(--c-accent);
  font-weight: 500;
  margin-bottom: 8px;
}
.discog-feature__title{
  font-size: 15px;
  letter-spacing: .08em;
  color: var(--c-text);
  font-weight: 400;
  line-height: 1.5;
}

/* TOP page SCHEDULE */
.top-schedule{ padding: 0; }
.top-schedule .container{ max-width: none; padding: 0; }

/* TOP page LISTEN (Spotify) */
.top-listen{
  padding: 48px 0 32px;
}
.listen-frame{
  max-width: var(--max-w-page);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}
.listen-frame iframe{
  display: block;
  width: 100%;
  border: 0;
  box-shadow: 0 12px 40px -16px rgba(0,0,0,.6);
}

/* TOP page MOVIE */
.top-movie{
  padding: 32px 0 56px;
}

/* TOP page SHOP banner */
.top-shop{
  padding: 32px 0 32px;
}
.shop-banner{
  display: block;
  max-width: var(--max-w-page);
  margin: 0 auto;
  padding: 0 var(--pad-x);
  color: var(--c-text);
}
.shop-banner__inner{
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  padding: 56px 56px;
  border: 1px solid rgba(244,241,234,.32);
  border-radius: 4px;
  background:
    linear-gradient(90deg, rgba(8,8,24,.78) 0%, rgba(16,14,34,.62) 44%, rgba(16,14,34,.34) 100%),
    linear-gradient(135deg, rgba(232,216,168,.14) 0%, rgba(232,216,168,0) 60%),
    linear-gradient(180deg, rgba(255,255,255,.055) 0%, rgba(255,255,255,.018) 100%);
  box-shadow: 0 18px 60px -28px rgba(0,0,0,.85);
  overflow: hidden;
  transition: border-color var(--t-base), background var(--t-base), transform var(--t-base);
}
.shop-banner__inner::before{
  content:""; position:absolute; top:-1px; left:30%; right:30%; height:1px;
  background: linear-gradient(90deg, transparent, var(--c-accent-soft), transparent);
}
.shop-banner__inner::after{
  content:"";
  position: absolute;
  right: -40px; top: 50%;
  transform: translateY(-50%);
  width: 280px; height: 280px;
  background:
    radial-gradient(circle at center, rgba(232,216,168,.18) 0%, rgba(232,216,168,0) 65%);
  pointer-events: none;
}
.shop-banner:hover .shop-banner__inner{
  border-color: var(--c-accent-soft);
  transform: translateY(-2px);
}
.shop-banner__sub{
  font-family: var(--ff-en-sans);
  font-size: 12px;
  letter-spacing: .32em;
  color: var(--c-accent);
  font-weight: 500;
  text-shadow: 0 1px 14px rgba(0,0,0,.65);
}
.shop-banner__main{
  font-family: var(--ff-en);
  font-size: 36px;
  letter-spacing: .12em;
  font-weight: 400;
  color: var(--c-text);
  line-height: 1.1;
  margin: 4px 0 6px;
  text-shadow: 0 2px 22px rgba(0,0,0,.75);
}
.shop-banner__desc{
  font-size: 14px;
  letter-spacing: .04em;
  color: rgba(244,241,234,.88);
  font-weight: 400;
  text-shadow: 0 1px 14px rgba(0,0,0,.65);
}
.shop-banner__cta{
  display: inline-flex;
  align-items: center;
  gap: 14px;
  margin-top: 18px;
  padding: 11px 28px;
  border: 1px solid rgba(244,241,234,.72);
  border-radius: 999px;
  font-family: var(--ff-en-sans);
  font-size: 11px;
  letter-spacing: .28em;
  color: rgba(244,241,234,.95);
  background: rgba(8,8,24,.24);
  font-weight: 500;
  transition: color var(--t-base), border-color var(--t-base), background var(--t-base);
}
.shop-banner__cta .arrow{
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px; border-radius: 50%;
  border: 1px solid currentColor;
  font-size: 10px;
  transition: transform var(--t-base);
}
.shop-banner:hover .shop-banner__cta{
  color: #1a0d40;
  background: var(--c-accent);
  border-color: var(--c-accent);
}
.shop-banner:hover .shop-banner__cta .arrow{ transform: translateX(3px); }

/* TOP page SNS */
.top-sns{
  padding: 48px 0 96px;
}
.top-sns .section__title__text::before{ display: none; }
.sns-list{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 28px 36px;
  max-width: var(--max-w-page);
  margin: 0 auto;
  padding: 0 var(--pad-x);
  list-style: none;
}
.sns-list a{
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 96px;
  padding: 18px 8px;
  color: var(--c-text);
  border: 1px solid var(--c-line-soft);
  border-radius: 4px;
  background: rgba(8,8,24,.28);
  transition: color var(--t-base), border-color var(--t-base), background var(--t-base), transform var(--t-base);
}
.sns-list a svg{
  width: 24px;
  height: 24px;
  display: block;
  transition: transform var(--t-base);
}
.sns-list a span{
  font-family: var(--ff-en-sans);
  font-size: 11px;
  letter-spacing: .16em;
  color: rgba(244,241,234,.82);
  font-weight: 500;
  text-shadow: 0 1px 12px rgba(0,0,0,.7);
  transition: color var(--t-base);
}
.sns-list a:hover{
  color: var(--c-accent);
  border-color: var(--c-accent-soft);
  background: var(--c-card-hover);
  transform: translateY(-3px);
}
.sns-list a:hover span{ color: var(--c-accent); }
.sns-list a:hover svg{ transform: scale(1.08); }

/* News rows in bordered box (news.html) */
.news-rows{ display:flex; flex-direction:column; }
.news-row{
  display:block;
  padding: 24px 32px;
  padding-right: 64px;
  border-bottom: 1px solid var(--c-line-soft);
  position: relative;
  transition: background var(--t-base);
}
.news-row:last-of-type{ border-bottom:0; }
.news-row::after{
  content: "→";
  position: absolute;
  right: 32px; top: 50%;
  transform: translateY(-50%) translateX(-8px);
  color: var(--c-accent);
  opacity: 0;
  font-family: var(--ff-en-sans);
  font-size: 14px;
  transition: opacity var(--t-base), transform var(--t-base);
}
.news-row:hover{ background: var(--c-card-hover); }
.news-row:hover::after{
  opacity: 1;
  transform: translateY(-50%) translateX(0);
}
.news-row__meta{
  display:flex; align-items:center; flex-wrap: wrap; gap:8px 16px; margin-bottom:8px;
}
.news-row__date{
  font-family: var(--ff-en-sans);
  font-size:12px;
  color: var(--c-accent);
  letter-spacing:.06em;
  line-height: 1.5;
  font-weight: 500;
}
.news-row__title{
  font-size:14.5px;
  color: var(--c-text);
  letter-spacing:.04em;
  line-height:1.6;
  font-weight: 300;
}

/* ===========================================================
   Movie / Embed
   =========================================================== */
.movie-frame{
  max-width: var(--max-w-page);
  margin:0 auto;
  background: var(--c-card);
  border-radius:2px;
  padding:24px;
}
.embed-16x9{
  position:relative; width:100%; padding-top:56.25%;
  background:#000; overflow:hidden; border-radius:2px;
}
.embed-16x9 > *{ position:absolute; inset:0; width:100%; height:100%; }
.embed-placeholder{
  display:flex; align-items:center; justify-content:center;
  background: linear-gradient(135deg, #111 0%, #1a1340 100%);
  color: rgba(255,255,255,.5);
  font-family:var(--ff-en); letter-spacing:.2em; font-size:12px;
}

/* ===========================================================
   Profile
   =========================================================== */
.profile-card{
  padding: 64px 64px 72px;
  text-align:center;
}
.profile-card__photo{
  width:100%;
  max-width: 560px;
  aspect-ratio: 3 / 2;
  margin: 0 auto 36px;
  background: linear-gradient(160deg, #1c1448 0%, #4a3690 100%);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display:flex; align-items:center; justify-content:center;
  color: rgba(255,255,255,.4);
  font-family: var(--ff-en); letter-spacing:.25em; font-size:12px;
  box-shadow: 0 16px 48px -16px rgba(0,0,0,.6);
}
.profile-card__name{
  font-family: var(--ff-en);
  font-style: normal;
  font-size: 32px;
  letter-spacing: .14em;
  margin-bottom: 36px;
  color: var(--c-text);
  font-weight: 300;
}
.profile-card__name span{
  font-family: var(--ff-jp-sans);
  font-style: normal;
  font-size: 13px;
  letter-spacing: .35em;
  display: block;
  color: var(--c-accent);
  margin-top: 10px;
}
.profile-card__bio{
  text-align:left;
  max-width: 720px;
  margin: 0 auto;
  font-size: 13.5px;
  line-height: 2.05;
  color: var(--c-text);
  font-weight: 300;
}
.profile-card__bio p{ margin-bottom: 1.6em; }
.profile-card__bio h3{
  font-family: var(--ff-en);
  font-style: normal;
  font-size: 18px;
  letter-spacing: .14em;
  font-weight: 400;
  color: var(--c-accent);
  margin: 2em 0 .8em;
  position: relative;
  padding-left: 18px;
}
.profile-card__bio h3::before{
  content:""; position:absolute; left:0; top:.7em;
  width:8px; height:1px;
  background: var(--c-accent);
}

/* ===========================================================
   Discography
   =========================================================== */
.discog-box{ padding: 64px 64px 72px; }
.discog-grid-2{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 64px 56px;
}
.discog-item{
  text-align:center; display:block; color: var(--c-text);
  transition: transform var(--t-base);
}
.discog-item__cover{
  width:100%; aspect-ratio:1/1;
  background-color: #2a1d5c;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  margin-bottom: 22px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 12px 40px -16px rgba(0,0,0,.7);
  transition: box-shadow var(--t-base), transform var(--t-base);
}
.discog-item__cover::after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(135deg, transparent 50%, rgba(232,216,168,.1) 100%);
  opacity: 0;
  transition: opacity var(--t-base);
}
.discog-item:hover{ transform: translateY(-4px); }
.discog-item:hover .discog-item__cover{
  box-shadow: 0 20px 50px -12px rgba(232,216,168,.18);
}
.discog-item:hover .discog-item__cover::after{ opacity: 1; }
.discog-item__cat{ margin-bottom: 12px; }
.discog-item__date{
  font-family: var(--ff-en-sans);
  font-size: 13px;
  letter-spacing: .04em;
  margin-bottom: 10px;
  color: var(--c-accent);
  font-weight: 500;
}
.discog-item__title{
  font-size: 15px;
  letter-spacing: .08em;
  color: var(--c-text);
  font-weight: 400;
  line-height: 1.5;
}

/* ===========================================================
   Schedule
   =========================================================== */
.schedule-row{
  display:block;
  padding: 24px 32px;
  border-bottom: 1px solid var(--c-line-soft);
  position: relative;
  transition: background var(--t-base);
}
.schedule-row:last-of-type{ border-bottom:0; }
.schedule-row::after{
  content:"→";
  position:absolute; right:32px; top:50%;
  transform: translateY(-50%) translateX(-8px);
  color: var(--c-accent);
  opacity: 0;
  font-family: var(--ff-en-sans); font-size:14px;
  transition: opacity var(--t-base), transform var(--t-base);
}
.schedule-row:hover{ background: var(--c-card-hover); }
.schedule-row:hover::after{ opacity:1; transform: translateY(-50%) translateX(0); }
.schedule-row__head{
  display:flex; align-items:center; gap:18px; margin-bottom:8px;
}
.schedule-row__year{
  display:inline-flex; align-items:center; justify-content:center;
  padding: 4px 14px;
  border-radius: 0;
  background: transparent;
  color: var(--c-accent);
  border: 1px solid var(--c-accent-soft);
  font-family: var(--ff-en-sans);
  font-style: normal;
  font-size: 11px;
  letter-spacing: .25em;
  min-width: 72px;
  font-weight: 400;
}
.schedule-row__date{
  font-family: var(--ff-en-sans);
  font-size:12px;
  letter-spacing:.06em;
  color: var(--c-accent);
  font-weight: 500;
}
.schedule-row__title{
  font-size:14.5px;
  color: var(--c-text);
  letter-spacing:.04em;
  line-height:1.6;
  font-weight: 300;
}

.load-more{
  display:block; width:100%;
  text-align:center;
  padding:24px 0;
  border-top:1px solid var(--c-line-soft);
  font-family: var(--ff-en-sans);
  font-size:11px; letter-spacing:.35em;
  color: var(--c-text);
  background: transparent;
  cursor: pointer;
  transition: background var(--t-base), color var(--t-base);
}
.load-more:hover{
  background: var(--c-card-hover);
  color: var(--c-accent);
}

/* ===========================================================
   Movie page
   =========================================================== */
.movie-box{ padding: 48px 56px 56px; }
.movie-section{
  margin: 0 0 72px;
}
.movie-section__head{
  width: 70%;
  margin: 0 auto 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}
.movie-section__head h2{
  color: var(--c-accent);
  font-family: var(--ff-jp);
  font-size: 22px;
  font-weight: 500;
  letter-spacing: .12em;
  line-height: 1.4;
}
.movie-section__head a{
  color: var(--c-text);
  border: 1px solid rgba(232,216,168,.56);
  border-radius: 999px;
  padding: 11px 24px;
  background: rgba(8,8,24,.38);
  box-shadow: 0 12px 34px -24px rgba(0,0,0,.9);
  font-family: var(--ff-en-sans);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: .06em;
  transition: color var(--t-base), border-color var(--t-base), background var(--t-base), box-shadow var(--t-base);
}
.movie-section__head a:hover{
  color: #08081a;
  border-color: var(--c-accent);
  background: var(--c-accent);
  box-shadow: 0 16px 40px -22px rgba(232,216,168,.52);
}
.movie-grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 28px 24px;
  max-width: none;
  margin: 0;
}
.movie-card{
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(244,241,234,.1);
  padding: 12px 12px 16px;
  border-radius: 4px;
  box-shadow: 0 18px 46px -32px rgba(0,0,0,.88);
}
.movie-card__play{
  width: 54px;
  height: 54px;
  border: 1px solid rgba(255,255,255,.76);
  border-radius: 999px;
  background: rgba(8,8,26,.48);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform var(--t-base), background var(--t-base);
}
.movie-card__play::before{
  content: "";
  display: block;
  width: 0;
  height: 0;
  margin-left: 4px;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  border-left: 15px solid #fff;
}
.movie-card:hover .movie-card__play{
  transform: scale(1.06);
  background: rgba(224,207,152,.86);
}
.movie-card__title{
  font-size: 15px;
  padding: 12px 4px 4px;
  letter-spacing: .03em;
  line-height: 1.55;
  color: var(--c-text);
  font-weight: 500;
  text-shadow: 0 1px 14px rgba(0,0,0,.65);
}
.movie-card__date{
  font-size: 12px;
  color: var(--c-accent);
  font-family: var(--ff-en-sans);
  font-weight: 500;
  letter-spacing: .08em;
  padding: 0 4px 4px;
}
.movie-empty{
  grid-column: 1 / -1;
  text-align: center;
  padding: 32px;
  color: rgba(255,255,255,.72);
}

/* ===========================================================
   News article
   =========================================================== */
.article{
  max-width: 780px; margin:0 auto;
  color: var(--c-text);
  padding-top: 24px;
}
.article__head{ text-align:center; margin-bottom: 56px; }
.article__date{
  font-family: var(--ff-en-sans);
  font-size:11px; letter-spacing:.25em;
  color: var(--c-text-sub);
  display: inline-flex; align-items: center; gap: 12px;
  margin-bottom: 24px;
}
.article__title{
  font-size: 28px;
  line-height: 1.55;
  letter-spacing: .04em;
  font-weight: 400;
  margin-bottom: 0;
  color: var(--c-text);
}
.article__title::after{
  content:""; display:block;
  width:36px; height:1px;
  background: var(--c-accent);
  margin: 32px auto 0;
}
.article__body{
  font-size: 14.5px;
  line-height: 2.05;
  color: var(--c-text);
  font-weight: 300;
}
.article__body p{ margin-bottom: 1.6em; }
.article__body h2{
  font-size: 16px;
  letter-spacing: .12em;
  font-weight: 400;
  padding-left: 16px;
  position: relative;
  margin: 2.2em 0 1em;
}
.article__body h2::before{
  content:""; position:absolute; left:0; top:.4em;
  width:4px; height:1em;
  background: var(--c-accent);
}
.article__body a{
  color: var(--c-accent);
  border-bottom: 1px solid var(--c-accent-soft);
  transition: opacity var(--t-fast);
}
.article__body a:hover{ opacity: .7; }
.article__body img{
  width:100%; height:auto;
  background-color: #1a1340;
  border-radius:2px;
  margin: 28px 0;
  box-shadow: 0 16px 48px -20px rgba(0,0,0,.6);
}
.article__back{
  display:flex; justify-content:center; margin-top: 64px;
}
.article__back a{
  display:inline-flex; align-items:center; gap: 12px;
  padding: 12px 34px;
  border: 1px solid rgba(244,241,234,.62);
  border-radius: 999px;
  font-family: var(--ff-en-sans);
  font-size: 12px;
  letter-spacing: .18em;
  color: rgba(244,241,234,.9);
  font-weight: 500;
  background: rgba(8,8,24,.24);
  position: relative; overflow: hidden;
  transition: color var(--t-base), border-color var(--t-base), background var(--t-base);
}
.article__back a::before{
  content:""; position:absolute; inset:0;
  background: var(--c-accent);
  transform: translateX(-101%);
  transition: transform .5s var(--ease);
  z-index: -1;
}
.article__back a:hover{ color: #1a0d40; border-color: var(--c-accent); }
.article__back a:hover::before{ transform: translateX(0); }

/* ===========================================================
   Contact form
   =========================================================== */
.contact-form{
  max-width: 640px; margin:0 auto;
  display:grid; gap: 24px;
}
.contact-form .field{ display:grid; gap: 8px; }
.contact-form label{
  font-family: var(--ff-en-sans);
  font-size:11px; letter-spacing:.25em;
  color: var(--c-text-sub);
}
.contact-form input,
.contact-form textarea{
  width:100%; padding: 14px 16px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--c-line-soft);
  border-radius:0;
  color: var(--c-text);
  font: inherit;
  font-weight: 300;
  transition: border-color var(--t-base), background var(--t-base);
}
.contact-form input:focus,
.contact-form textarea:focus{
  outline: none;
  border-color: var(--c-accent);
  background: rgba(255,255,255,.06);
}
.contact-form textarea{ min-height: 160px; resize:vertical; }
.contact-form .submit{
  display:inline-flex; align-items:center; justify-content:center;
  padding: 13px 44px;
  border: 1px solid var(--c-line);
  border-radius: 999px;
  font-family: var(--ff-en-sans);
  letter-spacing: .35em;
  font-size: 11px;
  background: transparent;
  color: var(--c-text);
  margin: 16px auto 0;
  position: relative; overflow: hidden;
  transition: color var(--t-base), border-color var(--t-base);
}
.contact-form .submit::before{
  content:""; position:absolute; inset:0;
  background: var(--c-accent);
  transform: translateX(-101%);
  transition: transform .5s var(--ease);
  z-index:-1;
}
.contact-form .submit:hover{
  color: #1a0d40;
  border-color: var(--c-accent);
}
.contact-form .submit:hover::before{ transform: translateX(0); }

/* ===========================================================
   Footer
   =========================================================== */
.site-footer{
  position:relative; z-index:1;
  padding: 56px 0 48px;
  text-align:center;
  font-family: var(--ff-en);
  font-style: normal;
  font-size:13px; letter-spacing:.4em;
  color: var(--c-text-sub);
  margin-top: 64px;
  border-top: 1px solid var(--c-line-soft);
}
.site-footer::before{
  content:"";
  display: block;
  width: 32px; height: 1px;
  background: var(--c-accent);
  margin: 0 auto 32px;
}

/* ===========================================================
   Scroll reveal
   =========================================================== */
/* JS有効時のみ非表示→表示のアニメーション。JS無効時は最初から表示 */
.js .reveal{
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .9s var(--ease), transform .9s var(--ease);
}
.js .reveal.is-in{
  opacity: 1;
  transform: translateY(0);
}
/* 保険: 何らかの理由でJSがis-inを付けない場合は3秒後に強制表示 */
@keyframes soraru-reveal-fallback {
  to { opacity: 1; transform: translateY(0); }
}
.js .reveal:not(.is-in){
  animation: soraru-reveal-fallback 0s linear 3s forwards;
}

/* ===========================================================
   Responsive
   =========================================================== */
/* ===========================================================
   Page-level lead text
   =========================================================== */
.lead-text{
  text-align: center;
  max-width: 720px;
  margin: 0 auto 56px;
  color: var(--c-text-sub);
  font-size: 14px;
  line-height: 1.9;
}
.lead-text a{
  color: var(--c-accent);
  border-bottom: 1px solid var(--c-accent-soft);
}
.lead-text a:hover{ border-bottom-color: var(--c-accent); }

/* ===========================================================
   Cat-pill 色分け
   =========================================================== */
.cat-pill--event{
  color: #e8c468;
  border-color: rgba(232,196,104,.55);
}
.cat-pill--music{
  color: #b8a4ff;
  border-color: rgba(184,164,255,.5);
}
.cat-pill--goods{
  color: #ffb8c4;
  border-color: rgba(255,184,196,.5);
}
.cat-pill--info{
  color: var(--c-text);
  border-color: var(--c-line-soft);
}

/* ===========================================================
   FAQ (contact.html)
   =========================================================== */
.faq{
  max-width: 760px;
  margin: 0 auto 80px;
}
.faq__heading{
  font-family: var(--ff-en);
  font-size: 22px;
  letter-spacing: .22em;
  font-weight: 300;
  color: var(--c-text);
  text-align: center;
  margin-bottom: 28px;
  position: relative;
  padding-bottom: 14px;
}
.faq__heading::after{
  content:""; position: absolute;
  left: 50%; bottom: 0;
  transform: translateX(-50%);
  width: 28px; height: 1px;
  background: var(--c-accent);
}
.faq__list{
  display: flex; flex-direction: column;
  gap: 8px;
}
.faq-item{
  border: 1px solid var(--c-line-soft);
  border-radius: 2px;
  background: rgba(255,255,255,.02);
  transition: border-color var(--t-base);
}
.faq-item[open]{ border-color: var(--c-accent-soft); }
.faq-item summary{
  list-style: none;
  cursor: pointer;
  padding: 18px 48px 18px 22px;
  font-size: 14px;
  letter-spacing: .04em;
  color: var(--c-text);
  position: relative;
  font-weight: 300;
  transition: color var(--t-fast);
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{
  content: "＋";
  position: absolute;
  right: 22px; top: 50%;
  transform: translateY(-50%);
  color: var(--c-accent);
  font-family: var(--ff-en-sans);
  transition: transform var(--t-base);
}
.faq-item[open] summary::after{ content: "－"; }
.faq-item summary:hover{ color: var(--c-accent); }
.faq-item__body{
  padding: 0 22px 20px;
  font-size: 13px;
  line-height: 1.95;
  color: var(--c-text-sub);
  font-weight: 300;
}
.faq-item__body a{
  color: var(--c-accent);
  border-bottom: 1px solid var(--c-accent-soft);
  display: inline-block;
  margin-top: 6px;
}

/* ===========================================================
   Contact form 拡張（select / required / agree）
   =========================================================== */
.contact-section{
  max-width: 720px;
  margin: 0 auto 80px;
}
.form-note{
  font-size: 12px;
  color: var(--c-text-mute);
  text-align: center;
  margin-bottom: 28px;
  line-height: 1.8;
}
.contact-form .field select{
  width: 100%;
  padding: 14px 18px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--c-line-soft);
  border-radius: 2px;
  color: var(--c-text);
  font-family: inherit;
  font-size: 14px;
  letter-spacing: .04em;
  transition: border-color var(--t-base), background var(--t-base);
  appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, var(--c-accent) 50%),
                    linear-gradient(135deg, var(--c-accent) 50%, transparent 50%);
  background-position: calc(100% - 22px) calc(50% - 2px),
                       calc(100% - 16px) calc(50% - 2px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
}
.contact-form .field select:focus{
  border-color: var(--c-accent);
  outline: none;
  background-color: rgba(232,216,168,.04);
}
.contact-form .req{
  display: inline-block;
  margin-left: 8px;
  padding: 1px 8px;
  font-size: 10px;
  letter-spacing: .15em;
  color: #f4c0a8;
  border: 1px solid rgba(244,192,168,.5);
  border-radius: 2px;
  vertical-align: middle;
}
.contact-form .field--check{
  margin: 8px 0 24px;
  font-size: 13px;
  color: var(--c-text-sub);
}
.contact-form .field--check label{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
}
.contact-form .field--check input[type="checkbox"]{
  width: 16px; height: 16px;
  accent-color: var(--c-accent);
  cursor: pointer;
}
.contact-form .field--check a{
  color: var(--c-accent);
  border-bottom: 1px solid var(--c-accent-soft);
}
.contact-form .submit{
  display: inline-flex;
  align-items: center;
  gap: 14px;
}
.contact-form .submit .arrow{
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px;
  border: 1px solid currentColor;
  border-radius: 50%;
  font-size: 10px;
  transition: transform var(--t-base);
}
.contact-form .submit:hover .arrow{ transform: translateX(3px); }

/* ===========================================================
   SCHEDULE (schedule.html) — カード化
   =========================================================== */
.schedule-section{
  margin-bottom: 72px;
}
.schedule-section--past{ margin-top: 32px; }
.schedule-section__head{
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 24px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--c-line-soft);
  position: relative;
}
.schedule-section__head::after{
  content:""; position: absolute;
  left: 0; bottom: -1px;
  width: 64px; height: 1px;
  background: var(--c-accent);
}
.schedule-section__title{
  font-family: var(--ff-en);
  font-style: normal;
  font-size: 28px;
  letter-spacing: .14em;
  font-weight: 300;
  color: var(--c-text);
  margin: 0;
}
.schedule-section__count{
  font-family: var(--ff-en-sans);
  font-size: 11px;
  letter-spacing: .3em;
  color: var(--c-text-mute);
}

/* 年タブ */
.year-tabs{ margin-bottom: 28px; }

/* 年ブロック */
.year-block{
  margin-bottom: 36px;
}
.year-block.is-hidden{ display: none; }
.year-block__head{
  display: flex;
  align-items: center;
  gap: 18px;
  margin-bottom: 14px;
}
.year-block__num{
  font-family: var(--ff-en);
  font-size: 18px;
  letter-spacing: .25em;
  color: var(--c-accent);
  font-weight: 300;
}
.year-block__line{
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, var(--c-accent-soft) 0%, transparent 100%);
}
.schedule-card{
  display: block;
  padding: 28px 32px;
  border-bottom: 1px solid var(--c-line-soft);
  position: relative;
  transition: background var(--t-base);
}
.schedule-card:last-of-type{ border-bottom: 0; }
.schedule-card:hover{ background: var(--c-card-hover); }
.schedule-card--linked{
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px 24px;
  align-items: center;
}
.schedule-card__main{
  display: block;
  min-width: 0;
  color: inherit;
  text-decoration: none;
}
.schedule-card__main::after{
  content: "→";
  position: absolute;
  top: 50%;
  right: 32px;
  transform: translateY(-50%) translateX(-8px);
  color: var(--c-accent);
  font-family: var(--ff-en-sans);
  font-size: 18px;
  opacity: 0;
  transition: opacity var(--t-base), transform var(--t-base);
}
.schedule-card--has-cta .schedule-card__main::after{ display: none; }
.schedule-card--linked:hover .schedule-card__main::after{
  opacity: 1;
  transform: translateY(-50%) translateX(0);
}
.schedule-card__head{
  display: flex; align-items: center;
  gap: 16px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.schedule-card__date{
  font-family: var(--ff-en-sans);
  font-size: 14px;
  letter-spacing: .14em;
  color: var(--c-accent);
  font-weight: 400;
}
.schedule-card__date small{
  font-size: 11px;
  letter-spacing: .2em;
  color: var(--c-text-sub);
  margin-left: 4px;
}
.schedule-card__title{
  font-size: 18px;
  font-weight: 300;
  letter-spacing: .04em;
  color: var(--c-text);
  margin-bottom: 0;
  line-height: 1.5;
  transition: color var(--t-base);
}
.schedule-card--linked:hover .schedule-card__title{ color: var(--c-accent); }
.schedule-card__meta{
  display: flex;
  flex-wrap: wrap;
  gap: 8px 32px;
  font-size: 13px;
  margin-bottom: 20px;
  color: var(--c-text-sub);
}
.schedule-card__meta div{ display: flex; gap: 12px; }
.schedule-card__meta dt{
  font-family: var(--ff-en-sans);
  font-size: 10px;
  letter-spacing: .25em;
  color: var(--c-text-mute);
  min-width: 86px;
  padding-top: 2px;
}
.schedule-card__meta dd{
  font-size: 13px;
  color: var(--c-text-sub);
  line-height: 1.7;
}
.schedule-card__cta{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  justify-content: flex-end;
  position: relative;
  z-index: 2;
}
.btn-ticket{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 11px 26px;
  border: 1px solid var(--c-accent);
  border-radius: 999px;
  background: var(--c-accent);
  color: #1a0d40;
  font-family: var(--ff-en-sans);
  font-size: 11px;
  letter-spacing: .3em;
  position: relative;
  overflow: hidden;
  transition: background var(--t-base), color var(--t-base);
}
.btn-ticket .arrow{
  display: inline-flex; align-items: center; justify-content: center;
  width: 20px; height: 20px;
  border: 1px solid currentColor;
  border-radius: 50%;
  font-size: 10px;
  transition: transform var(--t-base);
}
.btn-ticket:hover{
  background: transparent;
  color: var(--c-accent);
}
.btn-ticket:hover .arrow{ transform: translateX(3px); }
.btn-detail{
  display: inline-flex;
  align-items: center;
  padding: 10px 20px;
  border: 1px solid var(--c-line-soft);
  border-radius: 999px;
  font-family: var(--ff-en-sans);
  font-size: 11px;
  letter-spacing: .25em;
  color: var(--c-text-sub);
  transition: color var(--t-base), border-color var(--t-base);
}
.btn-detail:hover{ color: var(--c-accent); border-color: var(--c-accent-soft); }
.schedule-card--past{ opacity: .8; }
.schedule-card--past .schedule-card__date{ color: var(--c-text-sub); }
.schedule-card--past.schedule-card--linked{ grid-template-columns: minmax(0, 1fr); padding-right: 72px; }

/* ===========================================================
   DISCOGRAPHY — Listen on bar / per-card listen icons
   =========================================================== */
.listen-bar{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 14px 20px;
  max-width: var(--max-w-page);
  margin: 0 auto 40px;
  padding: 22px var(--pad-x);
  border: 1px solid rgba(244,241,234,.3);
  border-radius: 999px;
  background: rgba(8,8,24,.34);
  box-shadow: 0 16px 54px -28px rgba(0,0,0,.75);
}
.listen-bar__label{
  font-family: var(--ff-en-sans);
  font-size: 12px;
  letter-spacing: .24em;
  color: rgba(244,241,234,.82);
  font-weight: 500;
  margin-right: 6px;
}
.listen-bar__btn{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 18px;
  border: 1px solid rgba(244,241,234,.36);
  border-radius: 999px;
  font-family: var(--ff-en-sans);
  font-size: 12px;
  letter-spacing: .08em;
  color: rgba(244,241,234,.9);
  background: rgba(255,255,255,.03);
  font-weight: 500;
  transition: color var(--t-fast), border-color var(--t-fast), background var(--t-fast);
}
.listen-bar__btn svg{
  width: 16px; height: 16px;
}
.listen-bar__btn:hover{
  color: var(--c-accent);
  border-color: var(--c-accent-soft);
  background: var(--c-card-hover);
}

.discog-card{
  display: flex;
  flex-direction: column;
}
.discog-card.is-hidden{
  display: none;
}
.discog-card .discog-item{ flex: 1; }
.discog-card__listen{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--c-line-soft);
}
.discog-card__listen a{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px; height: 32px;
  border-radius: 50%;
  border: 1px solid var(--c-line-soft);
  color: var(--c-text-sub);
  transition: color var(--t-fast), border-color var(--t-fast), background var(--t-fast);
}
.discog-card__listen a svg{ width: 14px; height: 14px; }
.discog-card__listen a:hover{
  color: var(--c-accent);
  border-color: var(--c-accent-soft);
  background: var(--c-card-hover);
}

/* ===========================================================
   NEWS pickup
   =========================================================== */
.news-pickup{
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr;
  gap: 16px;
  max-width: var(--max-w-page);
  margin: 0 auto 48px;
}
.pickup-card{
  position: relative;
  display: block;
  border-radius: 4px;
  overflow: hidden;
  aspect-ratio: 16/10;
  border: 1px solid var(--c-line-soft);
  transition: transform var(--t-base), border-color var(--t-base);
}
.pickup-card--lg{ aspect-ratio: 16/9; grid-row: span 2; }
.pickup-card__bg{
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  transition: transform var(--t-base), filter var(--t-base);
  filter: brightness(.7);
}
.pickup-card::after{
  content:"";
  position: absolute; left:0; right:0; bottom:0; height: 70%;
  background: linear-gradient(180deg, transparent 0%, rgba(10,8,32,.95) 100%);
  pointer-events: none;
}
.pickup-card__body{
  position: absolute;
  left: 0; right: 0; bottom: 0;
  padding: 22px 24px;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
}
.pickup-card__date{
  font-family: var(--ff-en-sans);
  font-size: 12px;
  letter-spacing: .08em;
  color: var(--c-accent);
  font-weight: 500;
}
.pickup-card__title{
  font-size: 14px;
  font-weight: 300;
  line-height: 1.55;
  letter-spacing: .04em;
  color: var(--c-text);
  margin: 0;
}
.pickup-card--lg .pickup-card__title{ font-size: 18px; }
.pickup-card:hover{
  border-color: var(--c-accent-soft);
  transform: translateY(-3px);
}
.pickup-card:hover .pickup-card__bg{
  transform: scale(1.04);
  filter: brightness(.85);
}

/* ===========================================================
   Show detail (schedule/show-*.html)
   =========================================================== */
.show-detail{
  max-width: 1040px;
  margin: 0 auto;
  padding: 36px 0 0;
}
.show-detail-section{ padding-top: 56px; }
.show-detail__head{
  text-align: center;
  max-width: 820px;
  margin: 0 auto 48px;
  padding-bottom: 36px;
  border-bottom: 1px solid var(--c-line-soft);
  position: relative;
}
.show-detail__head::after{
  content:""; position: absolute;
  left: 50%; bottom: -1px;
  transform: translateX(-50%);
  width: 48px; height: 1px;
  background: var(--c-accent);
}
.show-detail__meta{
  display: inline-flex;
  align-items: center;
  gap: 18px;
  margin-bottom: 18px;
  flex-wrap: wrap;
  justify-content: center;
}
.show-detail__date{
  font-family: var(--ff-en-sans);
  font-size: 14px;
  letter-spacing: .06em;
  color: var(--c-accent);
  font-weight: 500;
}
.show-detail__date small{
  font-size: 11px;
  color: var(--c-text-sub);
  margin-left: 4px;
}
.show-detail__title{
  font-size: 30px;
  letter-spacing: .04em;
  font-weight: 400;
  line-height: 1.5;
  color: var(--c-text);
  margin-bottom: 0;
}
.show-detail__lead{
  max-width: 640px;
  margin: 0 auto;
  font-size: 14px;
  line-height: 2;
  color: var(--c-text-sub);
}
.show-detail__body{
  display: flex;
  flex-direction: column;
  gap: 40px;
  max-width: 960px;
  margin: 0 auto;
}
.show-detail__section{
  padding: 32px 36px;
  border: 1px solid rgba(244,241,234,.18);
  border-radius: 4px;
  background:
    linear-gradient(180deg, rgba(8,8,24,.34) 0%, rgba(8,8,24,.16) 100%),
    rgba(255,255,255,.018);
}
.show-detail__h2{
  font-family: var(--ff-en);
  font-style: normal;
  font-size: 20px;
  letter-spacing: .12em;
  font-weight: 500;
  color: var(--c-accent);
  margin-bottom: 24px;
  padding-left: 18px;
  position: relative;
}
.show-detail__h2::before{
  content:""; position: absolute;
  left: 0; top: .7em;
  width: 10px; height: 1px;
  background: var(--c-accent);
}
.show-detail__info{
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  border: 1px solid var(--c-line-soft);
  border-radius: 2px;
  padding: 22px 28px;
  background: rgba(255,255,255,.02);
}
.show-detail__info > div{
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 16px;
  align-items: baseline;
  padding-bottom: 14px;
  border-bottom: 1px dashed var(--c-line-soft);
}
.show-detail__info > div:last-child{ padding-bottom: 0; border-bottom: 0; }
.show-detail__info dt{
  font-family: var(--ff-en-sans);
  font-size: 11px;
  letter-spacing: .25em;
  color: var(--c-text-mute);
}
.show-detail__info dd{
  font-size: 14px;
  color: var(--c-text);
  line-height: 1.7;
}
.show-detail__ticket-list,
.show-detail__notes{
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 14px;
  line-height: 2;
  color: var(--c-text-sub);
}
.show-detail__ticket-list li{
  padding: 12px 0;
  border-bottom: 1px dashed var(--c-line-soft);
}
.show-detail__ticket-list li:last-child{ border-bottom: 0; }
.show-detail__ticket-list strong{
  display: inline-block;
  min-width: 140px;
  color: var(--c-accent);
  font-weight: 400;
  font-family: var(--ff-en-sans);
  letter-spacing: .15em;
  font-size: 12px;
  margin-right: 16px;
}
.show-detail__notes li{ position: relative; padding-left: 18px; }
.show-detail__notes li::before{
  content:""; position: absolute;
  left: 0; top: .85em;
  width: 8px; height: 1px;
  background: var(--c-accent-soft);
}
.show-detail__note{
  font-size: 12px;
  color: var(--c-text-mute);
  margin-top: 12px;
  line-height: 1.8;
}
.show-detail__detail-html{
  font-size: 16px;
  line-height: 1.95;
  color: rgba(244,241,234,.9);
  letter-spacing: .02em;
}
.show-detail__detail-html p{
  margin: 0 0 18px;
}
.show-detail__detail-html p:last-child{
  margin-bottom: 0;
}
.show-detail__detail-html strong{
  color: var(--c-accent);
  font-weight: 600;
}
.show-detail__detail-html a{
  color: var(--c-accent);
  border-bottom: 1px solid var(--c-accent-soft);
}
.show-detail__cta{
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
  margin-top: 56px;
  padding-top: 40px;
  border-top: 1px solid var(--c-line-soft);
}

/* ツアー日程リスト */
.show-detail__tour-list{ padding: 0; }
.show-detail__tour-row{
  display: grid;
  grid-template-columns: 220px 1fr;
  align-items: center;
  gap: 16px;
  padding: 18px 28px;
  border-bottom: 1px solid var(--c-line-soft);
}
.show-detail__tour-row:last-child{ border-bottom: 0; }
.show-detail__tour-date{
  font-family: var(--ff-en-sans);
  font-size: 14px;
  letter-spacing: .12em;
  color: var(--c-accent);
}
.show-detail__tour-date small{
  font-size: 11px;
  color: var(--c-text-sub);
  margin-left: 4px;
}
.show-detail__tour-venue{
  font-size: 13px;
  color: var(--c-text-sub);
}

/* ===========================================================
   Release detail (discography/*.html)
   =========================================================== */
.release-detail{
  max-width: 980px;
  margin: 0 auto;
  padding: 80px 0 0;
}
.release-detail__hero{
  display: grid;
  grid-template-columns: minmax(280px, 380px) 1fr;
  gap: 56px;
  align-items: start;
  margin-bottom: 64px;
  padding-bottom: 48px;
  border-bottom: 1px solid var(--c-line-soft);
}
.release-detail__cover img{
  display: block;
  width: 100%;
  height: auto;
  box-shadow: 0 16px 48px -16px rgba(0,0,0,.7);
}
.release-detail__info{
  display: flex;
  flex-direction: column;
  gap: 14px;
  align-items: flex-start;
}
.release-detail__title{
  font-size: 30px;
  letter-spacing: .06em;
  font-weight: 300;
  line-height: 1.4;
  color: var(--c-text);
  margin: 6px 0 0;
}
.release-detail__date{
  font-family: var(--ff-en-sans);
  font-size: 14px;
  letter-spacing: .08em;
  color: var(--c-accent);
  font-weight: 500;
  margin: 0;
}
.release-detail__lead{
  font-size: 14px;
  line-height: 1.95;
  color: var(--c-text-sub);
  margin: 4px 0 8px;
}
.release-detail__listen{
  margin-top: 14px;
  width: 100%;
}
.release-detail__listen-label{
  display: block;
  font-family: var(--ff-en-sans);
  font-size: 10px;
  letter-spacing: .35em;
  color: var(--c-text-mute);
  margin-bottom: 10px;
}
.release-detail__listen-btns{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.release-detail__body{
  display: flex;
  flex-direction: column;
  gap: 48px;
}
.release-detail__tracks{
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
}
.release-detail__tracks li{
  display: flex;
  align-items: baseline;
  gap: 22px;
  padding: 14px 0;
  border-bottom: 1px solid var(--c-line-soft);
}
.release-detail__tracks li:last-child{ border-bottom: 0; }
.release-detail__track-num{
  font-family: var(--ff-en-sans);
  font-size: 13px;
  letter-spacing: .08em;
  color: var(--c-accent);
  font-weight: 500;
  min-width: 28px;
}
.release-detail__track-title{
  font-size: 14px;
  color: var(--c-text);
  letter-spacing: .04em;
}

/* 特典情報 */
.release-detail__bonus-list{
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
.release-detail__bonus-item{
  position: relative;
  padding: 24px 28px;
  border: 1px solid var(--c-line-soft);
  border-radius: 2px;
  background:
    linear-gradient(135deg, rgba(232,216,168,.05) 0%, rgba(232,216,168,0) 50%),
    linear-gradient(180deg, rgba(255,255,255,.025) 0%, rgba(255,255,255,.01) 100%);
}
.release-detail__bonus-item::before{
  content:""; position: absolute;
  top: -1px; left: 24px;
  width: 32px; height: 1px;
  background: var(--c-accent);
}
.release-detail__bonus-label{
  display: inline-block;
  font-family: var(--ff-en-sans);
  font-size: 10px;
  letter-spacing: .3em;
  color: var(--c-accent);
  margin-bottom: 8px;
}
.release-detail__bonus-name{
  font-size: 16px;
  letter-spacing: .04em;
  color: var(--c-text);
  margin-bottom: 10px;
  font-weight: 400;
}
.release-detail__bonus-desc{
  font-size: 13px;
  line-height: 1.95;
  color: var(--c-text-sub);
  margin: 0;
}
.release-detail__bonus-desc a{
  color: var(--c-accent);
  border-bottom: 1px solid var(--c-accent-soft);
}
.release-detail__bonus-note{
  font-size: 11px;
  color: var(--c-text-mute);
  line-height: 1.8;
  margin-top: 16px;
}

@media (max-width: 720px){
  .release-detail__hero{ grid-template-columns: 1fr; gap: 28px; }
  .show-detail-section{ padding-top: 32px; }
  .show-detail{ padding-top: 24px; }
  .show-detail__head{ margin-bottom: 32px; padding-bottom: 28px; }
  .show-detail__title{ font-size: 24px; }
  .show-detail__section{ padding: 24px 20px; }
  .show-detail__detail-html{ font-size: 15px; line-height: 1.85; }
  .show-detail__info > div{ grid-template-columns: 1fr; gap: 4px; }
  .show-detail__tour-row{ grid-template-columns: 1fr; gap: 4px; padding: 14px 20px; }
}

@media (max-width: 980px){
  :root{ --gap-section-y: 56px; --gap-title-y: 32px; }
  .gnav__list{ gap:16px; font-size:11px; letter-spacing:.12em; }
  .btn-contact{ display:none; }
  .profile-card{ padding: 36px 24px 40px; }
  .profile-card__photo{ aspect-ratio: 4/3; }
  .discog-box{ padding: 36px 24px 40px; }
  .discog-grid-2{ gap: 32px 24px; }
  .movie-box{ padding: 32px 20px 36px; }
  .news-row{ padding: 14px 18px; }
  .news-row{ padding-right: 48px; }
  .schedule-row{ padding: 14px 18px; }
  .top-two-col{ grid-template-columns: 1fr; gap: 24px; padding: 32px var(--pad-x); align-items: stretch; }
  .top-two-col > section{ display: block; }
  .top-two-col .container{ display: block; }
  .discog-feature__link{ padding: 24px 24px 20px; }
  .discog-feature__cover{ min-height: 240px; }
  .top-two-col .bordered-box__foot{ padding: 16px 20px 18px; }
}
@media (max-width: 720px){
  .news-item{ grid-template-columns: 1fr; gap:2px; padding:14px 8px; }
  .news-item__more{ display:none; }
  .discog-grid-2{ grid-template-columns: 1fr; gap: 28px 0; }
  .schedule-row__head{ flex-wrap:wrap; }
  .page-title__en{ font-size:18px; letter-spacing:.3em; }
  .page-title__jp{ font-size:12px; letter-spacing:.45em; }
  .sns-list{ gap: 16px; }
  .sns-list a{ width: 76px; padding: 14px 6px; gap: 8px; }
  .sns-list a svg{ width: 20px; height: 20px; }
  .shop-banner__inner{ padding: 36px 28px; }
  .shop-banner__main{ font-size: 26px; letter-spacing: .1em; }
  .shop-banner__desc{ font-size: 12px; }
  .listen-frame iframe{ height: 352px; }
  .news-pickup{ grid-template-columns: 1fr 1fr; }
  .pickup-card--lg{ grid-column: span 2; grid-row: auto; aspect-ratio: 16/9; }
  .schedule-card{ padding: 22px 22px; }
  .schedule-card--past.schedule-card--linked{ padding-right: 56px; }
  .listen-bar{ padding: 18px 18px; gap: 10px 14px; }
  .listen-bar__btn{ font-size: 11px; padding: 7px 14px; }
}
@media (max-width: 560px){
  .news-pickup{ grid-template-columns: 1fr; }
  .pickup-card--lg{ grid-column: auto; }
  .listen-bar{ flex-direction: column; border-radius: 12px; }
  .listen-bar__label{ margin-right: 0; }
  .schedule-card__cta{ flex-direction: column; align-items: flex-start; }
  .schedule-card--linked{ grid-template-columns: 1fr; align-items: stretch; }
  .schedule-card__main::after{ display: none; }
  .schedule-card__cta{ justify-content: flex-start; }
  .schedule-card--past.schedule-card--linked{ padding-right: 22px; }
  .btn-ticket, .btn-detail{ width: 100%; justify-content: center; }
}
@media (max-width: 560px){
  .site-header{ padding:0 14px; }
  .brand{ gap: 8px; }
  .brand__name{ font-size: 16px; letter-spacing: .36em; }
  .brand__star{ width:10px; height:10px; }
  .gnav__list{ gap:8px; font-size:10px; letter-spacing:.06em; }
  .hero__arrow{ width:34px; height:34px; }
  .filter-tabs__btn{ min-width:76px; padding:5px 14px; font-size:11px; }
}

/* ===========================================================
   MOVIE archive (WP)
   =========================================================== */
.movie-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px 24px;
  padding: 32px;
}
.movie-card{
  display: block;
  color: var(--c-text);
  transition: transform var(--t-base), border-color var(--t-base), background var(--t-base), box-shadow var(--t-base);
}
.movie-card:hover{
  transform: translateY(-3px);
  border-color: rgba(232,216,168,.3);
  background: rgba(255,255,255,.09);
  box-shadow: 0 24px 56px -32px rgba(232,216,168,.22);
}
.movie-card__thumb{
  width: 100%;
  aspect-ratio: 16/9;
  background-size: cover;
  background-position: center;
  background-color: #1a1340;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 14px;
  border-radius: 3px;
  box-shadow: 0 12px 36px -16px rgba(0,0,0,.7);
}
.movie-card__title{
  font-size: 15px;
  letter-spacing: .03em;
  margin-bottom: 6px;
  line-height: 1.5;
  font-weight: 500;
  color: var(--c-text);
  text-shadow: 0 1px 14px rgba(0,0,0,.65);
}
.movie-card__date{
  font-family: var(--ff-en-sans);
  font-size: 12px;
  letter-spacing: .08em;
  color: var(--c-accent);
  font-weight: 500;
}
@media (max-width: 980px){
  .movie-section__head{ width: 90%; }
  .movie-grid{ grid-template-columns: repeat(2, 1fr); padding: 24px; }
}
@media (max-width: 560px){
  .movie-section{ margin-bottom: 52px; }
  .movie-section__head{
    width: 90%;
    align-items: flex-start;
    flex-direction: column;
  }
  .movie-section__head h2{ font-size: 18px; }
  .movie-grid{ grid-template-columns: 1fr; padding: 18px; }
  .movie-card__title{ font-size: 14px; }
  .movie-card__date{ font-size: 11px; }
}

/* 固定ページ（PROFILE / CONTACT）用 */
.page-content{
  max-width: 880px;
  margin: 0 auto;
  font-size: 14px;
  line-height: 2;
  color: var(--c-text);
}
.page-content p{ margin-bottom: 1.4em; }
.page-content h2{
  font-family: var(--ff-en);
  font-size: 22px;
  letter-spacing: .14em;
  color: var(--c-accent);
  margin: 2em 0 .8em;
  font-weight: 400;
}

.page-content--contact{
  max-width: 760px;
  padding: 42px 52px 48px;
  border: 1px solid rgba(244,241,234,.22);
  border-radius: 4px;
  background:
    linear-gradient(180deg, rgba(8,8,24,.42) 0%, rgba(8,8,24,.2) 100%),
    rgba(255,255,255,.018);
  box-shadow: 0 20px 70px -36px rgba(0,0,0,.8);
}
.page-content--contact p{
  color: rgba(244,241,234,.86);
  font-size: 14px;
  line-height: 1.9;
}
.page-content--contact form{
  display: grid;
  gap: 22px;
  margin-top: 30px;
}
.page-content--contact label,
.page-content--contact .label{
  display: block;
  margin-bottom: 8px;
  color: var(--c-accent);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: .06em;
}
.page-content--contact input[type="text"],
.page-content--contact input[type="email"],
.page-content--contact input[type="tel"],
.page-content--contact select,
.page-content--contact textarea{
  width: 100%;
  min-height: 46px;
  padding: 12px 15px;
  border: 1px solid rgba(244,241,234,.28);
  border-radius: 3px;
  background: rgba(8,8,24,.48);
  color: var(--c-text);
  font: inherit;
  font-size: 15px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
  transition: border-color var(--t-fast), background var(--t-fast), box-shadow var(--t-fast);
}
.page-content--contact select{
  color: rgba(244,241,234,.92);
}
.page-content--contact textarea{
  min-height: 180px;
  resize: vertical;
}
.page-content--contact input:focus,
.page-content--contact select:focus,
.page-content--contact textarea:focus{
  outline: none;
  border-color: var(--c-accent);
  background: rgba(8,8,24,.62);
  box-shadow: 0 0 0 3px rgba(232,216,168,.08);
}
.page-content--contact input[type="checkbox"]{
  width: 16px;
  height: 16px;
  accent-color: var(--c-accent);
  vertical-align: -2px;
}
.page-content--contact input[type="submit"],
.page-content--contact button[type="submit"]{
  display: inline-flex;
  justify-content: center;
  justify-self: start;
  min-width: 144px;
  padding: 12px 30px;
  border: 1px solid rgba(244,241,234,.62);
  border-radius: 999px;
  background: rgba(8,8,24,.24);
  color: rgba(244,241,234,.92);
  font-family: var(--ff-en-sans);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: .18em;
  cursor: pointer;
}
.page-content--contact input[type="submit"]:hover,
.page-content--contact button[type="submit"]:hover{
  background: var(--c-accent);
  border-color: var(--c-accent);
  color: #1a0d40;
}
.page-content--contact input[type="submit"]:disabled,
.page-content--contact button[type="submit"]:disabled{
  opacity: .45;
  cursor: not-allowed;
}
@media (max-width: 720px){
  .page-content--contact{
    padding: 28px 20px 32px;
  }
}

/* WP標準のページネーション */
.pagination, .nav-links{
  display: inline-flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
}
.page-numbers{
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 36px; height: 36px;
  padding: 0 10px;
  border: 1px solid var(--c-line-soft);
  border-radius: 999px;
  font-family: var(--ff-en-sans);
  font-size: 12px;
  letter-spacing: .15em;
  color: var(--c-text-sub);
  transition: color var(--t-base), border-color var(--t-base), background var(--t-base);
}
.page-numbers.current{
  background: var(--c-accent);
  color: #1a0d40;
  border-color: var(--c-accent);
}
.page-numbers:hover:not(.current){
  color: var(--c-accent);
  border-color: var(--c-accent-soft);
}

/* 記事ギャラリー (NEWS 詳細の画像複数表示) */
.article__gallery{
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 28px;
}
.article__gallery img{
  width: 100%;
  height: auto;
  display: block;
  border-radius: 2px;
}


/* === TOP page balance adjustments (added) === */
/* HERO — 横幅100%、高さは画像のアスペクト比で決定。見切れなし */
.hero{
  background: #0a0a1a;
  line-height: 0;
  width: 100%;
}
.hero__image{
  display: block;
  width: 100% !important;
  height: auto !important;
  max-width: none !important;
  max-height: none !important;
  margin: 0;
  animation: none !important;
  transform: none !important;
}

/* HEROとスライダーの繋ぎ:HERO直下に紫がかったグラデーション帯 */
.hero::after{
  height: 18%;
  background: linear-gradient(180deg, transparent 0%, rgba(11,10,29,.85) 100%);
}

/* スライダー帯の上下余白を詰める */
.slides{
  padding: 40px 0 48px;
}

.slides + .top-news{
  padding-top: 40px;
}

/* スライダーが無い場合 (条件分岐で出力されない) ためHEROとNEWSの間を詰める */
.hero + .top-news{
  padding-top: 56px;
}

/* NEWSセクションの上下padding適正化 */
.top-news{
  padding: 64px 0 24px;
}

/* SCHEDULE+DISCOGRAPHY 2カラムの上余白を詰める */
.top-two-col{
  padding-top: 32px;
  padding-bottom: 56px;
}

/* DISCOGRAPHYカバー画像のサイズ抑制（高さ揃え重視） */
.top-two-col .discog-feature__cover{
  max-height: 280px;
  margin-bottom: 16px;
}
.top-two-col .discog-feature__cover img{
  max-height: 260px;
}
.top-two-col .discog-feature__link{
  padding: 24px 24px 16px;
}

/* LISTEN(Spotify)の上余白も詰める */
.top-listen{
  padding: 32px 0 24px !important;
}

/* MOVIEセクション上余白詰め */
.top-movie{
  padding: 32px 0 48px;
}

/* SHOPバナー周辺 */
.top-shop{
  padding: 24px 0 32px;
}

/* SNSフォロー周辺 */
.top-sns{
  padding: 24px 0 80px;
}

/* セクション間のz-index/オーバーレイ問題を防ぐ */
.top-news, .top-two-col, .top-listen, .top-movie, .top-shop, .top-sns{
  position: relative;
  z-index: 1;
}


/* === SCHEDULE pickup style === */
.schedule-pickup{
  display: block;
  padding: 28px 24px 26px;
  border-bottom: 1px solid var(--c-line-soft);
  color: var(--c-text);
  transition: background var(--t-base);
  position: relative;
}
.schedule-pickup:hover{
  background: var(--c-card-hover);
}
.schedule-pickup__date{
  font-family: var(--ff-en-sans);
  font-size: 13px;
  letter-spacing: .18em;
  color: var(--c-accent);
  margin-bottom: 10px;
}
.schedule-pickup__date small{
  font-size: 11px;
  margin-left: 4px;
  color: var(--c-text-sub);
}
.schedule-pickup__title{
  font-size: 17px;
  line-height: 1.55;
  letter-spacing: .04em;
  color: var(--c-text);
  margin-bottom: 8px;
  font-weight: 400;
}
.schedule-pickup__venue{
  font-size: 12px;
  color: var(--c-text-sub);
  letter-spacing: .04em;
}

/* SCHEDULE空状態 */
.schedule-empty{
  padding: 60px 24px;
  text-align: center;
  color: var(--c-text-mute);
  font-size: 13px;
  letter-spacing: .08em;
}


/* === SCHEDULE Coming Soon === */
.schedule-coming-soon{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 60px 24px;
  min-height: 200px;
  gap: 16px;
}
.schedule-coming-soon__label{
  font-family: var(--ff-en-sans);
  font-size: 22px;
  letter-spacing: .42em;
  color: var(--c-accent);
  font-weight: 300;
  position: relative;
  padding-bottom: 14px;
}
.schedule-coming-soon__label::after{
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: 36px;
  height: 1px;
  background: var(--c-accent-soft);
}
.schedule-coming-soon__sub{
  font-size: 12px;
  letter-spacing: .2em;
  color: var(--c-text-sub);
}


/* === SHOW tour dates list === */
.show-detail__tour-count{
  font-size: 11px;
  letter-spacing: .25em;
  color: var(--c-accent);
  margin-left: 14px;
  font-weight: 400;
  vertical-align: middle;
}
.show-detail__tour-list{
  padding: 0;
}
.show-detail__tour-row{
  display: grid;
  grid-template-columns: 80px 1fr 1.6fr;
  align-items: center;
  gap: 24px;
  padding: 18px 28px;
  border-bottom: 1px solid var(--c-line-soft);
}
.show-detail__tour-row:last-child{ border-bottom: 0; }
.show-detail__tour-day{
  font-family: var(--ff-en-sans);
  font-size: 11px;
  letter-spacing: .2em;
  color: var(--c-accent);
  padding: 4px 10px;
  border: 1px solid var(--c-accent-soft);
  border-radius: 999px;
  text-align: center;
  display: inline-block;
}
.show-detail__tour-date{
  font-family: var(--ff-en-sans);
  font-size: 14px;
  letter-spacing: .08em;
  color: var(--c-text);
}
.show-detail__tour-date small{
  font-size: 11px;
  color: var(--c-text-sub);
  margin-left: 4px;
}
.show-detail__tour-venue{
  font-size: 13.5px;
  letter-spacing: .04em;
  color: var(--c-text);
}
@media (max-width: 640px){
  .show-detail__tour-row{
    grid-template-columns: 64px 1fr;
    gap: 12px;
    padding: 14px 18px;
  }
  .show-detail__tour-venue{
    grid-column: 1 / -1;
    padding-left: 76px;
    font-size: 12px;
    color: var(--c-text-sub);
  }
}

/* ===========================================================
   Responsive foundation
   =========================================================== */
.screen-reader-text{
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

.menu-toggle{
  display: none;
}

@media (max-width: 980px){
  :root{
    --header-h: 64px;
    --pad-x: 20px;
    --gap-section-y: 48px;
    --gap-title-y: 28px;
  }

  body.is-menu-open{
    overflow: hidden;
  }

  .site-header{
    height: var(--header-h);
    padding: 0 20px;
    background: rgba(10,8,28,.94);
  }
  .site-header__inner{
    gap: 16px;
  }
  .brand__name{
    font-size: 18px;
    letter-spacing: .34em;
  }

  .menu-toggle{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    margin-left: auto;
    border: 1px solid rgba(244,241,234,.28);
    border-radius: 999px;
    color: var(--c-text);
    position: relative;
    z-index: 102;
  }
  .menu-toggle__line,
  .menu-toggle__line::before,
  .menu-toggle__line::after{
    content: "";
    display: block;
    width: 18px;
    height: 1px;
    background: currentColor;
    position: absolute;
    transition: transform var(--t-fast), opacity var(--t-fast), top var(--t-fast);
  }
  .menu-toggle__line::before{ top: -6px; }
  .menu-toggle__line::after{ top: 6px; }
  .site-header.is-menu-open .menu-toggle__line{ background: transparent; }
  .site-header.is-menu-open .menu-toggle__line::before{
    top: 0;
    transform: rotate(45deg);
    background: var(--c-accent);
  }
  .site-header.is-menu-open .menu-toggle__line::after{
    top: 0;
    transform: rotate(-45deg);
    background: var(--c-accent);
  }

  .gnav{
    position: fixed;
    inset: 0;
    z-index: 101;
    min-height: 100dvh;
    overflow-y: auto;
    overscroll-behavior: contain;
    padding: calc(var(--header-h) + 28px) 28px 40px;
    background: #070714;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-8px);
    transition: opacity var(--t-fast), visibility var(--t-fast), transform var(--t-fast);
  }
  body.admin-bar .site-header{
    top: 0;
  }
  body.admin-bar .gnav{
    top: 0;
    min-height: 100dvh;
  }
  .site-header.is-menu-open .gnav{
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
  }
  .gnav__list{
    width: min(420px, 100%);
    margin: 0 auto;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 0;
    font-size: 16px;
    letter-spacing: .22em;
  }
  .gnav__list li{
    border-bottom: 1px solid var(--c-line-soft);
  }
  .gnav__list a,
  .gnav__list a.btn-contact{
    display: flex;
    justify-content: space-between;
    align-items: center;
    min-height: 58px;
    padding: 0;
    margin: 0;
    font-size: 15px;
    letter-spacing: .24em;
  }
  .gnav__list a::after,
  .gnav__list a.btn-contact::after{
    content: "→";
    position: static;
    width: auto;
    height: auto;
    background: transparent;
    transform: none;
    color: var(--c-accent);
    opacity: .75;
  }
  .gnav__list a.btn-contact::before{
    display: none;
  }

  .page-title{
    padding-top: 56px;
    margin-bottom: 32px;
  }
  .page-title__en{
    font-size: clamp(34px, 11vw, 48px);
    letter-spacing: .1em;
  }
  .page-title__jp{
    font-size: 11px;
    letter-spacing: .28em;
  }

  .section__title{
    margin-bottom: 34px;
  }
  .section__title__text{
    font-size: clamp(30px, 10vw, 48px);
    letter-spacing: .14em;
  }

  .bordered-box{
    width: 100%;
  }
  .top-news,
  .top-listen,
  .top-movie,
  .top-shop,
  .top-sns{
    padding-left: 0;
    padding-right: 0;
  }
  .slides{
    padding: 28px 0 36px;
  }
  .top-two-col{
    padding: 28px var(--pad-x) 48px;
  }
  .top-two-col .section__title{
    text-align: center;
  }
  .top-two-col .section__title__text{
    justify-content: center;
  }
  .top-two-col .section__title__text::before{
    display: block;
    margin-bottom: 8px;
  }

  .news-row{
    padding: 18px 22px;
    padding-right: 42px;
  }
  .news-row::after{
    right: 20px;
    opacity: .65;
    transform: translateY(-50%);
  }
  .news-row__meta{
    gap: 8px 12px;
  }

  .filter-tabs{
    gap: 10px;
    margin-bottom: 32px;
    padding: 0 4px;
  }
  .filter-tabs__btn{
    min-width: 0;
    flex: 1 1 calc(50% - 10px);
    padding: 9px 12px;
  }
}

@media (max-width: 720px){
  body{
    line-height: 1.75;
    letter-spacing: .01em;
  }

  .container{
    padding: 0 18px;
  }
  .hero__image{
    min-height: 420px;
    object-fit: cover;
    object-position: center top;
  }
  .read-more-pill{
    width: min(100%, 320px);
    padding: 12px 22px;
    letter-spacing: .22em;
  }

  .top-news .bordered-box{
    margin: 0 18px;
    width: auto;
  }
  .top-news .news-row{
    padding: 18px 20px;
    padding-right: 34px;
  }
  .top-two-col{
    gap: 34px;
  }
  .discog-feature__link{
    padding: 22px 18px 20px;
  }
  .discog-feature__cover{
    min-height: 0;
    max-height: none;
  }
  .top-two-col .discog-feature__cover img{
    max-height: 260px;
  }

  .movie-frame{
    padding: 12px;
    margin: 0 18px;
  }
  .shop-banner{
    padding: 0 18px;
  }
  .shop-banner__inner{
    padding: 34px 24px;
    min-height: 220px;
  }
  .shop-banner__main{
    font-size: clamp(28px, 10vw, 36px);
    line-height: 1.18;
  }
  .shop-banner__cta{
    width: 100%;
    justify-content: center;
    padding: 11px 18px;
  }
  .sns-list{
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    padding: 0 18px;
  }
  .sns-list a{
    width: 100%;
    min-height: 108px;
  }

  .discog-box,
  .movie-box,
  .profile-card{
    padding: 24px 18px 30px;
  }
  .discog-grid-2{
    gap: 34px;
  }
  .discog-item__cover{
    margin-bottom: 18px;
  }
  .discog-item__title{
    font-size: 14px;
  }
  .listen-bar{
    margin-bottom: 30px;
    border-radius: 18px;
    padding: 18px;
  }
  .listen-bar__btn{
    width: 100%;
    justify-content: center;
  }

  .schedule-section__head{
    align-items: flex-start;
    flex-direction: column;
    gap: 8px;
  }
  .schedule-section__title{
    font-size: 23px;
  }
  .schedule-card,
  .schedule-card--past.schedule-card--linked{
    padding: 22px 18px;
  }
  .schedule-card__title{
    font-size: 16px;
  }
  .schedule-card__meta{
    display: grid;
    gap: 10px;
  }
  .schedule-card__meta div{
    display: grid;
    gap: 3px;
  }
  .schedule-card__meta dt{
    min-width: 0;
  }

  .release-detail{
    padding-top: 42px;
  }
  .release-detail__title{
    font-size: 24px;
  }
  .release-detail__tracks{
    padding: 0;
  }
  .release-detail__track{
    grid-template-columns: 52px 1fr;
    padding: 16px 0;
  }
  .release-detail__track-title{
    font-size: 15px;
  }

  .show-detail__meta{
    flex-direction: column;
    gap: 10px;
  }
  .show-detail__section{
    margin-left: -2px;
    margin-right: -2px;
  }
  .show-detail__cta .read-more-pill{
    width: 100%;
  }

  .page-content{
    font-size: 14px;
  }
  .page-content--contact{
    margin: 0 18px;
  }
}

@media (max-width: 480px){
  :root{
    --pad-x: 16px;
  }
  .site-header{
    padding: 0 14px;
  }
  .brand__name{
    font-size: 16px;
    letter-spacing: .28em;
  }
  .menu-toggle{
    width: 40px;
    height: 40px;
  }
  .gnav{
    padding-left: 22px;
    padding-right: 22px;
  }
  .gnav__list a,
  .gnav__list a.btn-contact{
    min-height: 54px;
    font-size: 14px;
    letter-spacing: .18em;
  }

  .page-title{
    padding-top: 44px;
  }
  .page-title__en{
    font-size: clamp(28px, 13vw, 38px);
    letter-spacing: .08em;
  }
  .page-title__jp{
    letter-spacing: .2em;
  }
  .section__title__text{
    font-size: clamp(28px, 12vw, 40px);
    letter-spacing: .1em;
  }
  .section__title__text::before{
    letter-spacing: .28em;
  }

  .filter-tabs__btn{
    flex-basis: 100%;
    min-height: 42px;
  }
  .cat-pill{
    min-width: 0;
    padding: 4px 10px;
  }
  .news-row__title,
  .schedule-row__title{
    font-size: 14px;
  }
  .schedule-row__head,
  .schedule-card__head{
    gap: 8px;
  }
  .schedule-row__year{
    min-width: 62px;
  }
  .movie-section__head{
    width: calc(100% - 36px);
    gap: 12px;
  }
  .movie-section__head a{
    width: 100%;
    justify-content: center;
    text-align: center;
  }
  .movie-grid{
    padding: 14px;
  }
  .movie-card{
    padding: 8px;
  }
  .movie-card__play{
    width: 46px;
    height: 46px;
  }
  .profile-card__name{
    font-size: 26px;
  }
  .article__title{
    font-size: 22px;
  }
  .article__body,
  .show-detail__detail-html{
    font-size: 15px;
  }
}
