/* ============================================================
   KAGVYA OFFICIAL SITE — Goddess MV 準拠デザインシステム v2
   ============================================================ */

/* -------- Design Tokens -------- */
:root {
  --bg-primary: #060807;
  --bg-secondary: #0c0d11;
  --bg-deeper: #000000;
  --bg-overlay: rgba(6, 8, 7, 0.85);

  --accent-red-deep: #340106;
  --accent-red: #6b0a14;
  --accent-red-bright: #c41a2e;
  --accent-red-glow: #ff2030;

  --lantern-warm: #d99458;
  --gold: #c9a35a;
  --gold-bright: #e6c477;
  --gold-deep: #8a6a2c;

  --text-primary: #f2efe8;
  --text-mute: #8a857a;
  --text-stone: #65645c;
  --text-faint: #3a3733;
  --text-deep: #1f1c18;

  --font-display: "Italiana", "Cormorant Garamond", "Shippori Mincho B1", "Noto Serif JP", serif;
  --font-body: "Albert Sans", "Inter", "Noto Sans JP", system-ui, -apple-system, sans-serif;
  --font-mono: "JetBrains Mono", "SF Mono", "Roboto Mono", monospace;
  --font-mincho: "Shippori Mincho B1", "Noto Serif JP", serif;

  --rhythm-1: 50px;
  --rhythm-2: 100px;
  --rhythm-3: 150px;
  --rhythm-hero: 170px;

  --gutter-mobile: 20px;
  --gutter-tablet: 40px;
  --gutter-desktop: 64px;
  --max-content: 1440px;

  --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-out-quart: cubic-bezier(0.25, 1, 0.5, 1);
  --ease-in-out-cubic: cubic-bezier(0.65, 0, 0.35, 1);

  --dur-fast: 0.25s;
  --dur-mid: 0.6s;
  --dur-slow: 1.2s;

  --z-cursor: 9999;
  --z-loader: 9000;
  --z-progress: 200;
  --z-header: 100;
  --z-iris: 8000;
  --z-ambient: 50;
}

/* -------- Reset / Base -------- */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  scroll-behavior: auto;
  background: var(--bg-primary);
}
body {
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.4em;
  letter-spacing: -0.01em;
  color: var(--text-primary);
  background: var(--bg-primary);
  overflow-x: hidden;
  cursor: none;
}
@media (max-width: 800px) { body { cursor: auto; } }

a { color: inherit; text-decoration: none; }
img, video { max-width: 100%; height: auto; display: block; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
::selection { background: var(--accent-red-deep); color: var(--text-primary); }

/* Ambient red bleed body wash */
body::before {
  content: ""; position: fixed; inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 80% 60% at 80% 10%, rgba(106, 10, 20, 0.08) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 10% 90%, rgba(52, 1, 6, 0.12) 0%, transparent 70%);
  z-index: 0;
  mix-blend-mode: screen;
}
body > * { position: relative; z-index: 1; }

/* -------- Type scale -------- */
.t-eyebrow {
  font-family: var(--font-mono); font-size: 12px;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--text-mute);
}
.t-label {
  font-family: var(--font-body); font-size: 14px; font-weight: 500;
  letter-spacing: 0.04em;
}
.t-body {
  font-family: var(--font-body); font-size: 16px; line-height: 1.6em;
}
.t-h3 {
  font-family: var(--font-display);
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 400; line-height: 1em;
  letter-spacing: -0.02em;
}
.t-h2 {
  font-family: var(--font-display);
  font-size: clamp(44px, 8vw, 92px);
  font-weight: 400; line-height: 0.92em;
  letter-spacing: -0.025em;
}
.t-h1 {
  font-family: var(--font-display);
  font-size: clamp(72px, 14vw, 167px);
  font-weight: 400; line-height: 0.85em;
  letter-spacing: -0.04em;
}
.t-mincho { font-family: var(--font-mincho); }
.t-vertical { writing-mode: vertical-rl; text-orientation: upright; font-feature-settings: "vrt2"; }

/* -------- Custom Cursor -------- */
.cursor {
  position: fixed; top: 0; left: 0; z-index: var(--z-cursor);
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--text-primary);
  pointer-events: none;
  mix-blend-mode: difference;
  transform: translate(-50%, -50%);
  transition: width 0.3s var(--ease-out-quart), height 0.3s var(--ease-out-quart), opacity 0.3s;
}
.cursor::after {
  content: ""; position: absolute; inset: -10px;
  border-radius: 50%;
  border: 1px solid rgba(255, 32, 48, 0);
  transition: inset 0.4s var(--ease-out-quart), border-color 0.4s;
}
.cursor.hover { width: 56px; height: 56px; }
.cursor.hover::after { inset: -16px; border-color: rgba(255, 32, 48, 0.3); }
.cursor.iris { width: 0; height: 0; opacity: 0; }

/* -------- Preloader -------- */
.preloader {
  position: fixed; inset: 0; z-index: var(--z-loader);
  background: var(--bg-deeper);
  display: flex; align-items: center; justify-content: center;
  flex-direction: column;
  transition: opacity 0.6s var(--ease-out-quart), visibility 0.6s;
}
.preloader.done { opacity: 0; visibility: hidden; pointer-events: none; }

.preloader__phase1, .preloader__phase2 {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  flex-direction: column;
  transition: opacity 0.5s var(--ease-out-quart);
}
.preloader__phase2 { opacity: 0; }
.preloader.phase2 .preloader__phase1 { opacity: 0; }
.preloader.phase2 .preloader__phase2 { opacity: 1; }

.preloader__counter {
  font-family: var(--font-display);
  font-size: clamp(80px, 18vw, 200px);
  line-height: 1;
  color: var(--gold);
  letter-spacing: -0.04em;
}
.preloader__bar {
  width: clamp(200px, 40vw, 480px);
  height: 1px;
  background: var(--text-faint);
  margin-top: 30px;
  position: relative;
  overflow: hidden;
}
.preloader__bar::after {
  content: "";
  position: absolute; top: 0; left: 0; bottom: 0;
  width: var(--w, 0%);
  background: linear-gradient(90deg, var(--accent-red-deep), var(--accent-red-bright), var(--gold));
  transition: width 0.1s linear;
}
.preloader__brand {
  font-family: var(--font-display);
  font-size: clamp(60px, 14vw, 200px);
  letter-spacing: 0.02em;
  color: var(--gold);
  text-shadow: 0 0 30px rgba(201, 163, 90, 0.4);
}
.preloader__sub {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.4em; text-transform: uppercase;
  color: var(--text-mute);
  margin-top: 24px;
}

/* -------- Header -------- */
.header {
  position: fixed; top: 0; left: 0; right: 0; z-index: var(--z-header);
  display: flex; align-items: center; justify-content: space-between;
  padding: 24px var(--gutter-desktop);
  pointer-events: none;
  mix-blend-mode: difference;
}
.header > * { pointer-events: auto; }
.header__logo {
  font-family: var(--font-display);
  font-size: 22px;
  letter-spacing: 0.1em;
  color: var(--text-primary);
}
.header__nav { display: flex; gap: 32px; }
.header__nav a {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-primary);
  position: relative;
}
.header__nav a::after {
  content: "";
  position: absolute; left: 0; right: 0; bottom: -4px;
  height: 1px; background: var(--text-primary);
  transform: scaleX(0); transform-origin: right;
  transition: transform 0.4s var(--ease-out-quart);
}
.header__nav a:hover::after { transform: scaleX(1); transform-origin: left; }

.header__right {
  display: flex; align-items: center; gap: 20px;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.12em; color: var(--text-mute);
}
.header__clock {
  font-variant-numeric: tabular-nums;
  color: var(--text-primary);
}
.header__lang { text-transform: uppercase; }

@media (max-width: 800px) {
  .header { padding: 16px var(--gutter-mobile); }
  .header__nav { display: none; }
  .header__clock { display: none; }
}

/* -------- Section progress (right edge) -------- */
.progress {
  position: fixed; top: 50%; right: 24px;
  transform: translateY(-50%);
  z-index: var(--z-progress);
  display: flex; flex-direction: column; gap: 14px;
  mix-blend-mode: difference;
}
@media (max-width: 800px) { .progress { display: none; } }
.progress__dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--text-faint);
  transition: background 0.4s, transform 0.4s var(--ease-out-quart);
  position: relative;
}
.progress__dot.active { background: var(--accent-red-bright); transform: scale(1.6); }
.progress__dot::after {
  content: attr(data-label);
  position: absolute; right: calc(100% + 14px); top: 50%;
  transform: translateY(-50%);
  font-family: var(--font-mono); font-size: 9px;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--text-primary);
  white-space: nowrap;
  opacity: 0;
  transition: opacity 0.3s, transform 0.3s var(--ease-out-quart);
}
.progress__dot:hover::after,
.progress__dot.active::after { opacity: 1; transform: translateY(-50%) translateX(-4px); }

/* -------- Hero -------- */
.hero {
  position: relative;
  width: 100vw;
  height: 100vh;
  height: 100svh;
  background: var(--bg-deeper);
  overflow: hidden;
}
.hero__frame {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  background:
    radial-gradient(ellipse 60% 80% at 50% 50%, rgba(106, 10, 20, 0.55) 0%, transparent 55%),
    radial-gradient(ellipse 40% 60% at 30% 70%, rgba(196, 26, 46, 0.25) 0%, transparent 60%),
    radial-gradient(ellipse 30% 40% at 70% 30%, rgba(217, 148, 88, 0.15) 0%, transparent 60%),
    linear-gradient(180deg, var(--bg-primary) 0%, var(--bg-deeper) 100%);
  animation: heroBreathe 9s var(--ease-in-out-cubic) infinite alternate;
}
@keyframes heroBreathe {
  0%   { transform: scale(1);    filter: brightness(0.95); }
  100% { transform: scale(1.05); filter: brightness(1.05); }
}
.hero__noise {
  position: absolute; inset: 0;
  pointer-events: none;
  opacity: 0.06;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240' viewBox='0 0 240 240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 1 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.7'/></svg>");
  mix-blend-mode: overlay;
}

.hero__overlay {
  position: absolute; inset: 0;
  display: grid; place-items: center;
  text-align: center;
  z-index: 2;
  padding: 0 var(--gutter-desktop);
}
.hero__title {
  font-family: var(--font-display);
  font-size: clamp(72px, 22vw, 280px);
  font-weight: 400;
  line-height: 0.9em;
  letter-spacing: -0.02em;
  color: var(--gold);
  text-shadow: 0 0 60px rgba(201, 163, 90, 0.35), 0 0 120px rgba(106, 10, 20, 0.2);
  user-select: none;
  display: flex; gap: 0.02em;
  position: relative;
}
.hero__title span {
  display: inline-block;
  opacity: 0;
  transform: translateY(60px) rotate(8deg);
  filter: blur(14px);
  transition: opacity 1s var(--ease-out-expo), transform 1.2s var(--ease-out-expo), filter 1s var(--ease-out-expo);
  transition-delay: var(--char-delay, 0s);
}
.hero__title.in span {
  opacity: 1; transform: translateY(0) rotate(0deg); filter: blur(0);
}
.hero__sub {
  font-family: var(--font-mincho);
  font-size: clamp(13px, 1.4vw, 17px);
  letter-spacing: 0.4em;
  color: var(--text-primary);
  margin-top: 28px;
  opacity: 0;
  transition: opacity 1.2s var(--ease-out-expo) 1.4s;
}
.hero__sub.in { opacity: 1; }
.hero__sub-en {
  display: block;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.36em;
  text-transform: uppercase;
  color: var(--text-mute);
  margin-top: 10px;
}

.hero__scroll {
  position: absolute; left: 50%; bottom: 32px;
  transform: translateX(-50%);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--text-mute);
  z-index: 3;
}
.hero__scroll::after {
  content: ""; display: block;
  width: 1px; height: 60px;
  margin: 12px auto 0;
  background: linear-gradient(180deg, var(--text-mute) 0%, transparent 100%);
  animation: scrollline 2.5s var(--ease-in-out-cubic) infinite;
}
@keyframes scrollline {
  0%   { transform: scaleY(0); transform-origin: top; }
  50%  { transform: scaleY(1); transform-origin: top; }
  50.1%{ transform-origin: bottom; }
  100% { transform: scaleY(0); transform-origin: bottom; }
}

/* Hero ambient layers */
.hero__vert {
  position: absolute;
  left: 32px; top: 50%;
  transform: translateY(-50%);
  font-family: var(--font-mincho);
  font-size: clamp(80px, 12vw, 160px);
  color: rgba(106, 10, 20, 0.18);
  writing-mode: vertical-rl;
  text-orientation: upright;
  letter-spacing: 0.1em;
  user-select: none;
  pointer-events: none;
  z-index: 1;
  font-weight: 400;
}
.hero__badge {
  position: absolute; top: 90px; right: var(--gutter-desktop);
  z-index: 3;
  display: flex; flex-direction: column; gap: 6px;
  text-align: right;
}
.hero__badge-tag {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--accent-red-bright);
  display: inline-flex; align-items: center; gap: 6px;
  align-self: flex-end;
}
.hero__badge-tag::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent-red-bright);
  box-shadow: 0 0 8px var(--accent-red-bright);
  animation: pulseDot 1.4s var(--ease-in-out-cubic) infinite;
}
@keyframes pulseDot {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}
.hero__badge-title {
  font-family: var(--font-display); font-size: 22px;
  letter-spacing: 0;
  color: var(--text-primary);
}
.hero__badge-date {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.2em;
  color: var(--text-mute);
}
.hero__corner {
  position: absolute;
  z-index: 2;
  font-family: var(--font-mono); font-size: 9px;
  letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--text-mute);
}
.hero__corner--bl { left: var(--gutter-desktop); bottom: 32px; }
.hero__corner--br { right: var(--gutter-desktop); bottom: 32px; text-align: right; }

@media (max-width: 800px) {
  .hero__vert { font-size: 64px; left: 12px; }
  .hero__badge { top: 70px; right: var(--gutter-mobile); }
  .hero__badge-title { font-size: 16px; }
  .hero__corner--bl { left: var(--gutter-mobile); }
  .hero__corner--br { right: var(--gutter-mobile); }
}

/* -------- Hero marquee -------- */
.hero__marquee {
  position: absolute; left: 0; right: 0; bottom: 0;
  height: 56px;
  display: flex; align-items: center;
  overflow: hidden;
  background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.6) 100%);
  z-index: 3;
  border-top: 1px solid var(--text-faint);
  pointer-events: none;
}
.hero__marquee-track {
  display: flex; gap: 60px;
  white-space: nowrap;
  animation: marquee 38s linear infinite;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--text-mute);
}
.hero__marquee-track span { display: inline-flex; align-items: center; gap: 60px; }
.hero__marquee-track span::after {
  content: "✦"; color: var(--accent-red-bright);
  font-size: 10px;
}
@keyframes marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* -------- Section Layout -------- */
.section {
  padding: var(--rhythm-2) var(--gutter-desktop);
  position: relative;
}
.section--lg { padding: var(--rhythm-3) var(--gutter-desktop); }
.section--xl { padding: 200px var(--gutter-desktop); }

@media (max-width: 800px) {
  .section, .section--lg, .section--xl {
    padding-left: var(--gutter-mobile);
    padding-right: var(--gutter-mobile);
  }
  .section { padding-top: 80px; padding-bottom: 80px; }
  .section--lg { padding-top: 100px; padding-bottom: 100px; }
  .section--xl { padding-top: 120px; padding-bottom: 120px; }
}

.section__head {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 80px;
  border-bottom: 1px solid var(--text-faint);
  padding-bottom: 28px;
  position: relative;
}
.section__head::before {
  content: ""; position: absolute;
  bottom: -1px; left: 0; height: 1px;
  width: 60px; background: var(--accent-red-bright);
}
.section__title { display: flex; align-items: baseline; gap: 28px; flex-wrap: wrap; }
.section__num {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.24em; color: var(--text-mute);
}
.section__more {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--text-primary);
  position: relative; padding-bottom: 4px;
}
.section__more::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0;
  height: 1px; background: currentColor;
  transform: scaleX(0); transform-origin: right;
  transition: transform 0.4s var(--ease-out-quart);
}
.section__more:hover::after { transform: scaleX(1); transform-origin: left; }

@media (max-width: 800px) {
  .section__head { margin-bottom: 40px; padding-bottom: 20px; }
}

/* Floating vertical kanji accent (decorative) */
.section__vk {
  position: absolute;
  font-family: var(--font-mincho);
  writing-mode: vertical-rl;
  text-orientation: upright;
  font-size: clamp(80px, 10vw, 140px);
  color: rgba(106, 10, 20, 0.08);
  user-select: none; pointer-events: none;
  letter-spacing: 0.05em;
}

/* -------- Marquee band -------- */
.band {
  height: 80px;
  display: flex; align-items: center;
  overflow: hidden;
  border-top: 1px solid var(--text-faint);
  border-bottom: 1px solid var(--text-faint);
  background: var(--bg-deeper);
  position: relative;
}
.band__track {
  display: flex; gap: 40px;
  white-space: nowrap;
  animation: marquee 28s linear infinite;
  font-family: var(--font-display); font-size: 38px;
  letter-spacing: -0.01em;
  color: var(--text-primary);
}
.band__track span { display: inline-flex; align-items: center; gap: 40px; }
.band__track span::after {
  content: "✦"; color: var(--accent-red-bright); font-size: 18px;
}
.band--reverse .band__track { animation-direction: reverse; }
@media (max-width: 800px) {
  .band { height: 60px; }
  .band__track { font-size: 26px; gap: 28px; }
  .band__track span { gap: 28px; }
}

/* -------- News -------- */
.news__list { list-style: none; padding: 0; margin: 0; }
.news__item {
  display: grid;
  grid-template-columns: 160px 110px 1fr auto;
  gap: 32px;
  padding: 28px 0;
  border-bottom: 1px solid var(--text-faint);
  align-items: baseline;
  position: relative;
  transition: padding-left 0.4s var(--ease-out-quart);
}
.news__item::before {
  content: ""; position: absolute;
  left: -24px; top: 28px; bottom: 28px;
  width: 2px; background: var(--accent-red-bright);
  transform: scaleY(0); transform-origin: top;
  transition: transform 0.4s var(--ease-out-quart);
}
.news__item:hover { padding-left: 16px; }
.news__item:hover::before { transform: scaleY(1); }
.news__date {
  font-family: var(--font-display);
  font-size: 28px;
  line-height: 1em;
  letter-spacing: -0.01em;
  color: var(--text-primary);
}
.news__cat {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--accent-red-bright);
  border: 1px solid var(--accent-red-bright);
  padding: 4px 10px;
  align-self: center; justify-self: start;
}
.news__title {
  font-family: var(--font-body); font-size: 16px; font-weight: 400;
  line-height: 1.5em;
}
.news__arrow {
  font-family: var(--font-mono); font-size: 14px;
  color: var(--text-mute);
  transition: transform 0.3s var(--ease-out-quart), color 0.3s;
}
.news__item:hover .news__arrow { transform: translateX(8px); color: var(--text-primary); }

@media (max-width: 800px) {
  .news__item { grid-template-columns: auto auto; row-gap: 8px; column-gap: 12px; padding: 20px 0; }
  .news__date { font-size: 20px; }
  .news__title { grid-column: 1 / -1; font-size: 14px; }
  .news__arrow { display: none; }
}

/* -------- Discography -------- */
.discog__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 60px 40px;
}
@media (max-width: 1100px) { .discog__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .discog__grid { grid-template-columns: 1fr; gap: 40px; } }

.discog__item { display: block; position: relative; }
.discog__cover {
  aspect-ratio: 1 / 1;
  background:
    radial-gradient(circle at 30% 30%, rgba(196, 26, 46, 0.18) 0%, transparent 60%),
    linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-deeper) 100%);
  position: relative;
  overflow: hidden;
  transition: transform 1s var(--ease-out-expo);
}
.discog__cover::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.7) 100%);
  z-index: 2; pointer-events: none;
}
.discog__cover::after {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(circle at 50% 60%, rgba(255, 32, 48, 0.08) 0%, transparent 50%);
  z-index: 1; pointer-events: none;
  opacity: 0; transition: opacity 0.6s;
}
.discog__item:hover .discog__cover { transform: translateY(-6px); }
.discog__item:hover .discog__cover::after { opacity: 1; }

.discog__cover-num {
  position: absolute; top: 24px; left: 24px;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.2em; color: var(--text-mute);
  z-index: 3;
}
.discog__cover-title {
  position: absolute; left: 24px; right: 24px; bottom: 24px;
  font-family: var(--font-display); font-size: 32px;
  line-height: 0.95em; letter-spacing: -0.01em;
  color: var(--gold);
  z-index: 3;
}
.discog__cover-format {
  position: absolute; top: 24px; right: 24px;
  font-family: var(--font-mono); font-size: 9px;
  letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--text-mute);
  z-index: 3;
}
.discog__out-now {
  position: absolute; top: -6px; right: -6px;
  z-index: 4;
  font-family: var(--font-mono); font-size: 9px;
  letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--text-primary);
  background: var(--accent-red-bright);
  padding: 6px 12px;
  transform: rotate(0deg);
  box-shadow: 0 0 20px rgba(196, 26, 46, 0.4);
}

.discog__meta { padding: 20px 0 0; }
.discog__date {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.16em; color: var(--text-mute);
}
.discog__title {
  font-family: var(--font-display); font-size: 32px;
  margin: 8px 0 4px;
  letter-spacing: -0.01em;
}
.discog__format {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--accent-red-bright);
}
.discog__listen {
  display: inline-flex; align-items: center; gap: 10px;
  margin-top: 16px;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--text-primary);
  border-bottom: 1px solid var(--text-faint);
  padding-bottom: 5px;
  transition: border-color 0.3s, color 0.3s, gap 0.3s var(--ease-out-quart);
}
.discog__listen:hover {
  color: var(--accent-red-bright);
  border-color: var(--accent-red-bright);
  gap: 16px;
}

/* -------- Members (asymmetric staggered grid) -------- */
.member__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
  align-items: start;
}
@media (max-width: 900px) { .member__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px) { .member__grid { grid-template-columns: 1fr; } }

.member__card {
  display: block;
  position: relative;
}
.member__card:nth-child(1) { transform: translateY(0); }
.member__card:nth-child(2) { transform: translateY(48px); }
.member__card:nth-child(3) { transform: translateY(16px); }
.member__card:nth-child(4) { transform: translateY(64px); }
@media (max-width: 900px) {
  .member__card:nth-child(n) { transform: none; }
  .member__card:nth-child(2) { transform: translateY(40px); }
  .member__card:nth-child(4) { transform: translateY(40px); }
}
@media (max-width: 500px) {
  .member__card:nth-child(n) { transform: none; }
}

.member__img {
  aspect-ratio: 3 / 4;
  background:
    radial-gradient(circle at 50% 30%, rgba(106, 10, 20, 0.25) 0%, transparent 60%),
    linear-gradient(180deg, var(--bg-secondary) 0%, var(--bg-deeper) 100%);
  position: relative;
  overflow: hidden;
}
.member__img::before {
  content: attr(data-vert);
  position: absolute; right: 12px; top: 12px;
  writing-mode: vertical-rl;
  text-orientation: upright;
  font-family: var(--font-mincho);
  font-size: clamp(40px, 5vw, 64px);
  color: rgba(201, 163, 90, 0.18);
  letter-spacing: 0.05em;
  user-select: none; pointer-events: none;
}
.member__img::after {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(circle at 50% 50%, rgba(196, 26, 46, 0.15) 0%, transparent 60%);
  opacity: 0; transition: opacity 0.5s;
}
.member__card:hover .member__img::after { opacity: 1; }
.member__img img {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  transition: opacity 0.6s var(--ease-out-quart), transform 1.4s var(--ease-out-expo);
}
.member__img img:nth-of-type(2) { opacity: 0; }
.member__card:hover .member__img img:nth-of-type(1) { opacity: 0; }
.member__card:hover .member__img img:nth-of-type(2) { opacity: 1; }
.member__card:hover .member__img img { transform: scale(1.04); }

.member__name {
  font-family: var(--font-display);
  font-size: 36px;
  letter-spacing: 0.04em;
  margin-top: 18px;
  transition: color 0.3s;
}
.member__card:hover .member__name { color: var(--gold); }
.member__role {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--text-mute);
  margin-top: 6px;
}
.member__num {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.2em;
  color: var(--text-faint);
  position: absolute; top: 12px; left: 12px;
  z-index: 2;
}

/* -------- Video / MV -------- */
.video__wrapper {
  position: relative;
  aspect-ratio: 16 / 9;
  background: var(--bg-deeper);
  border: 1px solid var(--text-faint);
}
.video__wrapper iframe {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  border: 0;
}
.video__caption {
  display: flex; justify-content: space-between;
  margin-top: 16px;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--text-mute);
}

/* -------- Live -------- */
.live__list { list-style: none; padding: 0; margin: 0; }
.live__item {
  display: grid;
  grid-template-columns: 160px 1fr 1fr auto;
  gap: 32px;
  padding: 32px 0;
  border-bottom: 1px solid var(--text-faint);
  align-items: baseline;
  transition: padding-left 0.4s var(--ease-out-quart);
}
.live__item:hover { padding-left: 16px; }
.live__date {
  font-family: var(--font-display);
  font-size: 22px;
  letter-spacing: -0.01em;
  color: var(--text-primary);
}
.live__name {
  font-family: var(--font-display); font-size: 26px;
  letter-spacing: -0.01em;
}
.live__venue {
  font-family: var(--font-body); font-size: 13px;
  color: var(--text-mute);
  font-family: var(--font-mincho);
}
.live__status {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--accent-red-bright);
  border: 1px solid var(--accent-red-bright);
  padding: 4px 10px;
}
.live__status--tba { color: var(--text-mute); border-color: var(--text-faint); }

@media (max-width: 800px) {
  .live__item { grid-template-columns: 1fr; gap: 6px; padding: 22px 0; }
  .live__date { font-size: 18px; }
  .live__name { font-size: 18px; }
}

/* -------- Producer (pull-quote) -------- */
.producer {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 80px;
  align-items: center;
  position: relative;
}
@media (max-width: 900px) { .producer { grid-template-columns: 1fr; gap: 40px; } }

.producer__img {
  aspect-ratio: 4 / 5;
  background:
    radial-gradient(circle at 30% 70%, rgba(196, 26, 46, 0.2) 0%, transparent 60%),
    linear-gradient(180deg, var(--bg-secondary) 0%, var(--bg-deeper) 100%);
}
.producer__text { padding: 20px 0; position: relative; }
.producer__text::before {
  content: "「";
  position: absolute; left: -8px; top: -40px;
  font-family: var(--font-mincho);
  font-size: 140px;
  line-height: 1;
  color: var(--accent-red-deep);
  user-select: none;
}
.producer__role {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--accent-red-bright);
  margin-bottom: 20px;
}
.producer__name {
  font-family: var(--font-display); font-size: clamp(56px, 8vw, 96px);
  letter-spacing: -0.02em;
  margin: 0 0 28px;
  line-height: 0.92em;
}
.producer__body {
  font-family: var(--font-mincho);
  font-size: 17px;
  line-height: 2em;
  color: var(--text-primary);
  max-width: 560px;
  border-left: 2px solid var(--accent-red-deep);
  padding-left: 28px;
}
.producer__cta {
  display: inline-flex; align-items: center; gap: 12px;
  margin-top: 28px;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--text-primary);
  border-bottom: 1px solid var(--text-faint);
  padding-bottom: 5px;
  transition: gap 0.3s var(--ease-out-quart), color 0.3s, border-color 0.3s;
}
.producer__cta:hover { gap: 18px; color: var(--accent-red-bright); border-color: var(--accent-red-bright); }

/* -------- Channels (with SVG) -------- */
.channels__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--text-faint);
  border-top: 1px solid var(--text-faint);
  border-bottom: 1px solid var(--text-faint);
}
@media (max-width: 700px) { .channels__grid { grid-template-columns: repeat(2, 1fr); } }

.channels__item {
  background: var(--bg-primary);
  padding: 48px 28px;
  display: flex; flex-direction: column;
  gap: 14px;
  transition: background 0.5s, padding 0.4s var(--ease-out-quart);
  position: relative;
  overflow: hidden;
}
.channels__item::before {
  content: ""; position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 0%;
  background: linear-gradient(90deg, var(--accent-red-deep) 0%, transparent 100%);
  transition: width 0.5s var(--ease-out-quart);
  z-index: 0;
}
.channels__item > * { position: relative; z-index: 1; }
.channels__item:hover { padding-left: 40px; }
.channels__item:hover::before { width: 100%; }

.channels__icon {
  width: 28px; height: 28px;
  color: var(--text-mute);
  transition: color 0.4s;
}
.channels__item:hover .channels__icon { color: var(--gold); }
.channels__platform {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--text-mute);
}
.channels__handle {
  font-family: var(--font-display); font-size: 26px;
  letter-spacing: 0;
}
.channels__arrow {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--text-mute);
  margin-top: auto;
  transition: transform 0.3s var(--ease-out-quart);
}
.channels__item:hover .channels__arrow { transform: translate(6px, -6px); color: var(--text-primary); }

/* -------- FC Coming Soon -------- */
.fc-soon {
  text-align: center;
  padding: var(--rhythm-3) 0;
  position: relative;
  border-top: 1px solid var(--text-faint);
  border-bottom: 1px solid var(--text-faint);
}
.fc-soon::before, .fc-soon::after {
  content: "";
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 80px; height: 1px;
  background: var(--accent-red-bright);
}
.fc-soon::before { left: 0; }
.fc-soon::after  { right: 0; }
.fc-soon__title {
  font-family: var(--font-display);
  font-size: clamp(48px, 9vw, 120px);
  letter-spacing: -0.02em;
  line-height: 1em;
}
.fc-soon__sub {
  font-family: var(--font-mono); font-size: 12px;
  letter-spacing: 0.4em; text-transform: uppercase;
  color: var(--accent-red-bright);
  margin-bottom: 20px;
}

/* -------- Footer -------- */
.footer {
  padding: 100px var(--gutter-desktop) 40px;
  background: var(--bg-deeper);
  border-top: 1px solid var(--text-faint);
  position: relative;
  overflow: hidden;
}
@media (max-width: 800px) { .footer { padding: 80px var(--gutter-mobile) 30px; } }

.footer__top {
  display: flex; flex-wrap: wrap; gap: 60px;
  justify-content: space-between;
  margin-bottom: 80px;
}
.footer__brand {
  font-family: var(--font-display);
  font-size: clamp(80px, 15vw, 220px);
  letter-spacing: -0.04em;
  line-height: 0.85em;
  color: var(--text-faint);
  user-select: none;
}
.footer__col { min-width: 160px; }
.footer__h {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--text-mute);
  margin-bottom: 22px;
}
.footer__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.footer__list a {
  font-family: var(--font-body); font-size: 13px;
  color: var(--text-primary);
  transition: color 0.3s, padding-left 0.3s var(--ease-out-quart);
}
.footer__list a:hover { color: var(--accent-red-bright); padding-left: 6px; }
.footer__bottom {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 30px;
  border-top: 1px solid var(--text-faint);
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.2em; color: var(--text-mute);
}

/* -------- Reveal animation -------- */
.reveal {
  opacity: 0; transform: translateY(40px);
  transition: opacity 1s var(--ease-out-expo), transform 1s var(--ease-out-expo);
  transition-delay: var(--reveal-delay, 0s);
}
.reveal.in { opacity: 1; transform: translateY(0); }

.split-char {
  display: inline-block;
  opacity: 0;
  transform: translateY(0.4em);
  transition: opacity 0.7s var(--ease-out-expo), transform 0.7s var(--ease-out-expo);
  transition-delay: var(--char-delay, 0s);
}
.split-char.in { opacity: 1; transform: translateY(0); }
.split-char.space { width: 0.3em; }

/* -------- Iris transition -------- */
.iris {
  position: fixed; inset: 0; z-index: var(--z-iris);
  pointer-events: none;
  background: var(--bg-deeper);
  clip-path: circle(0% at 50% 50%);
  transition: clip-path 0.9s var(--ease-out-expo);
}
.iris.opening { clip-path: circle(150% at 50% 50%); }

/* -------- Subpage common -------- */
.subpage-hero {
  padding: 220px var(--gutter-desktop) var(--rhythm-2);
  border-bottom: 1px solid var(--text-faint);
  position: relative;
  overflow: hidden;
}
.subpage-hero::after {
  content: "";
  position: absolute; right: -80px; top: 50%;
  transform: translateY(-50%);
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(106, 10, 20, 0.2) 0%, transparent 60%);
  pointer-events: none;
}
.subpage-hero__name {
  font-family: var(--font-display);
  font-size: clamp(80px, 18vw, 240px);
  line-height: 0.85em;
  letter-spacing: -0.04em;
  color: var(--gold);
  text-shadow: 0 0 60px rgba(201, 163, 90, 0.25);
}
.subpage-hero__role {
  font-family: var(--font-mono); font-size: 12px;
  letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--text-mute);
  margin-top: 24px;
}
.subpage-back {
  display: inline-flex; align-items: center; gap: 12px;
  margin-bottom: 40px;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--text-mute);
  transition: color 0.3s, gap 0.3s;
}
.subpage-back:hover { color: var(--text-primary); gap: 18px; }

.member-detail {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  padding: var(--rhythm-2) var(--gutter-desktop);
}
@media (max-width: 900px) { .member-detail { grid-template-columns: 1fr; gap: 40px; } }
.member-detail__img {
  aspect-ratio: 3 / 4;
  background:
    radial-gradient(circle at 50% 30%, rgba(106, 10, 20, 0.2) 0%, transparent 60%),
    linear-gradient(180deg, var(--bg-secondary) 0%, var(--bg-deeper) 100%);
}
.member-detail__data { display: grid; gap: 28px; align-content: start; }
.member-detail__row {
  display: grid; grid-template-columns: 100px 1fr; gap: 24px;
  padding-bottom: 22px;
  border-bottom: 1px solid var(--text-faint);
}
.member-detail__k {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--text-mute);
}
.member-detail__v {
  font-family: var(--font-body); font-size: 15px;
  color: var(--text-primary);
}
.member-detail__pending {
  color: var(--accent-red-bright);
  font-family: var(--font-mono); font-size: 12px;
  letter-spacing: 0.1em;
}
