/* ==========================================================================
   Child Pages — Common Styles
   Page hero, archive grids, prose content, filters, pagination
   ========================================================================== */

/* ── Child Page Layout: Full-Width (hide sidebars, show header like top page) ── */
body:not(.home) .sidebar {
  display: none !important;
}

body:not(.home) .layout__main {
  max-width: 100%;
  padding-top: 0 !important;
}

/* Header always visible (including desktop 1280px+) */
body:not(.home) .header {
  display: block;
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border-bottom: none;
}

/* Scrolled state: keep transparent */
body:not(.home) .header.header--scrolled {
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border-bottom: none;
  box-shadow: none;
}

/* Full-width header inner — match top page style */
body:not(.home) .header__inner {
  max-width: 100%;
  padding: 0 var(--space-8);
}

@media (min-width: 840px) {
  body:not(.home) .header__inner {
    padding: 0 var(--space-12);
  }
}

@media (min-width: 1280px) {
  body:not(.home) .header__inner {
    padding: 0 var(--space-16);
  }
}

/* ── Page Hero ── */
.page-hero {
  position: relative;
  /* ヘッダー裏から始まるので、padding-topにヘッダー分(80px)＋余白を含む */
  padding: calc(var(--header-height) + var(--space-10)) var(--space-4) var(--space-12);
  text-align: center;
  overflow: hidden;
  background: linear-gradient(160deg, #f0ecff 0%, #fff5fb 40%, #e8f6f8 100%);
}

/* Page hero & content mobile */
@media (max-width: 839px) {
  .page-hero {
    padding: calc(var(--header-height) + var(--space-6)) var(--space-4) var(--space-8);
  }
}

@media (max-width: 479px) {
  .page-hero {
    padding: calc(var(--header-height) + var(--space-4)) var(--space-3) var(--space-6);
  }

  .page-hero__en {
    font-size: clamp(2rem, 10vw, 3rem);
  }

  .page-hero__ja {
    font-size: var(--text-sm);
  }

  .page-content {
    padding: var(--space-8) var(--space-3);
  }
}

/* Animated gradient shimmer overlay */
.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 600px 300px at 20% 50%, rgba(200, 160, 230, 0.1) 0%, transparent 100%),
    radial-gradient(ellipse 500px 250px at 80% 30%, rgba(232, 123, 197, 0.08) 0%, transparent 100%),
    radial-gradient(ellipse 400px 200px at 50% 80%, rgba(94, 208, 213, 0.06) 0%, transparent 100%);
  animation: heroGradientShift 10s ease-in-out infinite;
  pointer-events: none;
}

/* Noise texture overlay for depth */
.page-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.02'/%3E%3C/svg%3E");
  pointer-events: none;
  opacity: 0.4;
}

@keyframes heroGradientShift {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.6; transform: scale(1.08); }
}

/* Background text watermark */
.page-hero__bg-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-family: var(--font-display);
  font-size: clamp(6rem, 18vw, 16rem);
  font-weight: 900;
  letter-spacing: 0.1em;
  color: transparent;
  -webkit-text-stroke: 1px rgba(200, 160, 230, 0.06);
  white-space: nowrap;
  pointer-events: none;
  user-select: none;
  animation: bgTextFloat 8s ease-in-out infinite;
}

@keyframes bgTextFloat {
  0%, 100% { transform: translate(-50%, -50%) scale(1); }
  50% { transform: translate(-50%, -52%) scale(1.02); }
}

/* Gradient mesh (animated blobs) */
.page-hero__mesh {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle 200px at 15% 25%, rgba(200, 160, 230, 0.12) 0%, transparent 100%),
    radial-gradient(circle 180px at 85% 35%, rgba(232, 123, 197, 0.08) 0%, transparent 100%),
    radial-gradient(circle 150px at 50% 75%, rgba(94, 208, 213, 0.07) 0%, transparent 100%),
    radial-gradient(circle 120px at 75% 80%, rgba(129, 140, 248, 0.06) 0%, transparent 100%);
  animation: meshShift 15s ease-in-out infinite;
}

@keyframes meshShift {
  0%, 100% { transform: scale(1) rotate(0deg); }
  33% { transform: scale(1.05) rotate(1deg); }
  66% { transform: scale(0.98) rotate(-1deg); }
}

/* Floating orbs (5 animated) */
.page-hero__orb {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  filter: blur(60px);
}

.page-hero__orb--1 {
  width: 350px;
  height: 350px;
  top: -120px;
  right: -80px;
  background: rgba(200, 160, 230, 0.18);
  animation: pageOrbFloat1 8s ease-in-out infinite;
}

.page-hero__orb--2 {
  width: 280px;
  height: 280px;
  bottom: -80px;
  left: -60px;
  background: rgba(94, 208, 213, 0.14);
  animation: pageOrbFloat2 10s ease-in-out infinite;
}

.page-hero__orb--3 {
  width: 200px;
  height: 200px;
  top: 30%;
  left: 60%;
  background: rgba(232, 123, 197, 0.1);
  animation: pageOrbFloat3 12s ease-in-out infinite;
}

.page-hero__orb--4 {
  width: 160px;
  height: 160px;
  top: 10%;
  left: 20%;
  background: rgba(129, 140, 248, 0.08);
  animation: pageOrbFloat4 14s ease-in-out infinite;
}

.page-hero__orb--5 {
  width: 120px;
  height: 120px;
  bottom: 15%;
  right: 25%;
  background: rgba(232, 123, 197, 0.07);
  animation: pageOrbFloat5 9s ease-in-out infinite;
}

@keyframes pageOrbFloat1 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(-30px, 20px) scale(1.1); }
}

@keyframes pageOrbFloat2 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(20px, -15px) scale(1.12); }
}

@keyframes pageOrbFloat3 {
  0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.1; }
  50% { transform: translate(-20px, -25px) scale(1.15); opacity: 0.18; }
}

@keyframes pageOrbFloat4 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33% { transform: translate(15px, -20px) scale(1.1); }
  66% { transform: translate(-10px, 10px) scale(0.95); }
}

@keyframes pageOrbFloat5 {
  0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.07; }
  50% { transform: translate(-15px, -10px) scale(1.2); opacity: 0.12; }
}

/* Geometric decos (8 floating shapes) */
.page-hero__deco {
  position: absolute;
  pointer-events: none;
}

.page-hero__deco--1 {
  width: 60px;
  height: 60px;
  top: 18%;
  left: 8%;
  border-radius: 50%;
  border: 2px solid rgba(200, 160, 230, 0.2);
  animation: decoRotate1 15s linear infinite;
}

.page-hero__deco--2 {
  width: 40px;
  height: 40px;
  bottom: 20%;
  right: 12%;
  border-radius: 8px;
  border: 2px solid rgba(232, 123, 197, 0.18);
  animation: decoRotate2 12s linear infinite;
}

.page-hero__deco--3 {
  width: 24px;
  height: 24px;
  top: 35%;
  right: 20%;
  border-radius: 50%;
  background: rgba(94, 208, 213, 0.12);
  animation: decoFloat1 7s ease-in-out infinite;
}

.page-hero__deco--4 {
  width: 16px;
  height: 16px;
  bottom: 30%;
  left: 15%;
  border-radius: 3px;
  background: rgba(200, 160, 230, 0.1);
  animation: decoFloat2 9s ease-in-out infinite;
}

.page-hero__deco--5 {
  width: 50px;
  height: 50px;
  top: 12%;
  right: 8%;
  border-radius: 50%;
  border: 1.5px solid rgba(94, 208, 213, 0.15);
  animation: decoRotate1 20s linear infinite reverse;
}

.page-hero__deco--6 {
  width: 30px;
  height: 30px;
  bottom: 15%;
  left: 25%;
  border-radius: 6px;
  border: 1.5px solid rgba(200, 160, 230, 0.12);
  animation: decoRotate2 18s linear infinite reverse;
}

.page-hero__deco--7 {
  width: 12px;
  height: 12px;
  top: 50%;
  left: 5%;
  border-radius: 50%;
  background: rgba(232, 123, 197, 0.1);
  animation: decoFloat1 6s ease-in-out infinite 1s;
}

.page-hero__deco--8 {
  width: 20px;
  height: 20px;
  top: 25%;
  right: 35%;
  border-radius: 4px;
  background: rgba(129, 140, 248, 0.07);
  animation: decoFloat2 8s ease-in-out infinite 2s;
}

@keyframes decoRotate1 {
  0% { transform: rotate(0deg) translateY(0); }
  50% { transform: rotate(180deg) translateY(-10px); }
  100% { transform: rotate(360deg) translateY(0); }
}

@keyframes decoRotate2 {
  0% { transform: rotate(0deg) translateX(0); }
  50% { transform: rotate(-180deg) translateX(8px); }
  100% { transform: rotate(-360deg) translateX(0); }
}

@keyframes decoFloat1 {
  0%, 100% { transform: translateY(0) scale(1); }
  50% { transform: translateY(-12px) scale(1.2); }
}

@keyframes decoFloat2 {
  0%, 100% { transform: translate(0, 0) rotate(0deg); }
  50% { transform: translate(6px, -8px) rotate(45deg); }
}

/* Sparkle particles (16) */
.page-hero__sparkles {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
}

.page-hero__sparkle {
  position: absolute;
  font-size: 6px;
  animation: pageSparkle 3s ease-in-out infinite;
  opacity: 0;
}

.page-hero__sparkle--1  { top: 15%; left: 8%;  color: rgba(232, 123, 197, 0.6); animation-delay: 0s;   font-size: 9px; }
.page-hero__sparkle--2  { top: 25%; right: 12%; color: rgba(200, 160, 230, 0.5); animation-delay: 0.35s; font-size: 7px; }
.page-hero__sparkle--3  { bottom: 25%; left: 18%; color: rgba(94, 208, 213, 0.5); animation-delay: 0.7s;  font-size: 8px; }
.page-hero__sparkle--4  { top: 12%; right: 22%; color: rgba(232, 123, 197, 0.4); animation-delay: 1.05s; font-size: 5px; }
.page-hero__sparkle--5  { bottom: 30%; right: 7%; color: rgba(200, 160, 230, 0.55); animation-delay: 1.4s;  font-size: 10px; }
.page-hero__sparkle--6  { top: 45%; left: 28%;  color: rgba(129, 212, 224, 0.4); animation-delay: 1.75s; font-size: 6px; }
.page-hero__sparkle--7  { bottom: 18%; right: 28%; color: rgba(232, 123, 197, 0.5); animation-delay: 2.1s;  font-size: 8px; }
.page-hero__sparkle--8  { top: 22%; left: 42%;  color: rgba(200, 160, 230, 0.35); animation-delay: 2.45s; font-size: 5px; }
.page-hero__sparkle--9  { top: 55%; right: 18%; color: rgba(94, 208, 213, 0.45); animation-delay: 0.2s;  font-size: 7px; }
.page-hero__sparkle--10 { bottom: 40%; left: 6%; color: rgba(129, 140, 248, 0.4); animation-delay: 0.55s; font-size: 6px; }
.page-hero__sparkle--11 { top: 35%; right: 5%;  color: rgba(232, 123, 197, 0.5); animation-delay: 0.9s;  font-size: 8px; }
.page-hero__sparkle--12 { bottom: 12%; left: 35%; color: rgba(200, 160, 230, 0.45); animation-delay: 1.25s; font-size: 7px; }
.page-hero__sparkle--13 { top: 8%;  left: 55%;  color: rgba(94, 208, 213, 0.35); animation-delay: 1.6s;  font-size: 9px; }
.page-hero__sparkle--14 { bottom: 22%; right: 40%; color: rgba(232, 123, 197, 0.3); animation-delay: 1.95s; font-size: 5px; }
.page-hero__sparkle--15 { top: 40%; left: 15%;  color: rgba(200, 160, 230, 0.5); animation-delay: 2.3s;  font-size: 6px; }
.page-hero__sparkle--16 { bottom: 35%; right: 15%; color: rgba(129, 140, 248, 0.4); animation-delay: 2.65s; font-size: 8px; }

@keyframes pageSparkle {
  0%, 100% { opacity: 0; transform: scale(0.3) rotate(0deg); }
  50% { opacity: 1; transform: scale(1.3) rotate(180deg); }
}

/* Horizontal light sweep lines */
.page-hero__line {
  position: absolute;
  height: 1px;
  pointer-events: none;
  background: linear-gradient(90deg, transparent 0%, rgba(200, 160, 230, 0.15) 30%, rgba(232, 123, 197, 0.1) 70%, transparent 100%);
}

.page-hero__line--1 {
  width: 60%;
  top: 30%;
  left: -10%;
  animation: lineSweep1 8s ease-in-out infinite;
}

.page-hero__line--2 {
  width: 50%;
  bottom: 25%;
  right: -10%;
  animation: lineSweep2 10s ease-in-out infinite 2s;
}

@keyframes lineSweep1 {
  0%, 100% { transform: translateX(0); opacity: 0; }
  20% { opacity: 0.6; }
  80% { opacity: 0.6; }
  50% { transform: translateX(30%); opacity: 1; }
}

@keyframes lineSweep2 {
  0%, 100% { transform: translateX(0); opacity: 0; }
  20% { opacity: 0.5; }
  80% { opacity: 0.5; }
  50% { transform: translateX(-25%); opacity: 0.8; }
}

/* Decorative divider under title */
.page-hero__divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.page-hero__divider-line {
  display: block;
  width: 40px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(200, 160, 230, 0.4), transparent);
}

.page-hero__divider-dot {
  font-size: 8px;
  color: rgba(200, 160, 230, 0.5);
  animation: pageSparkle 4s ease-in-out infinite;
}

.page-hero .container {
  position: relative;
  z-index: 2;
  max-width: var(--container-xl);
  margin: 0 auto;
}

/* ── Page Background Floating Orbs + Sparkles (content area) ── */
.page-bg-orbs {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
  overflow: hidden;
}

.page-bg-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(100px);
  opacity: 0.07;
}

.page-bg-orb--1 {
  width: 500px;
  height: 500px;
  top: 10%;
  right: -150px;
  background: var(--color-primary);
  animation: pageBgOrb1 20s ease-in-out infinite;
}

.page-bg-orb--2 {
  width: 400px;
  height: 400px;
  top: 40%;
  left: -120px;
  background: var(--color-accent-pink);
  animation: pageBgOrb2 25s ease-in-out infinite;
}

.page-bg-orb--3 {
  width: 350px;
  height: 350px;
  bottom: 5%;
  right: 10%;
  background: var(--color-accent-cyan);
  animation: pageBgOrb3 18s ease-in-out infinite;
}

.page-bg-orb--4 {
  width: 250px;
  height: 250px;
  top: 60%;
  left: 40%;
  background: var(--color-primary-light);
  animation: pageBgOrb4 22s ease-in-out infinite;
}

.page-bg-orb--5 {
  width: 300px;
  height: 300px;
  top: 25%;
  left: 10%;
  background: var(--color-accent-blue);
  animation: pageBgOrb5 28s ease-in-out infinite;
}

.page-bg-orb--6 {
  width: 200px;
  height: 200px;
  bottom: 30%;
  right: 30%;
  background: var(--color-accent-pink);
  animation: pageBgOrb6 16s ease-in-out infinite;
}

@keyframes pageBgOrb1 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33% { transform: translate(-60px, 40px) scale(1.1); }
  66% { transform: translate(30px, -20px) scale(0.95); }
}

@keyframes pageBgOrb2 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33% { transform: translate(50px, -30px) scale(1.08); }
  66% { transform: translate(-20px, 50px) scale(1.15); }
}

@keyframes pageBgOrb3 {
  0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.07; }
  50% { transform: translate(-40px, -30px) scale(1.12); opacity: 0.1; }
}

@keyframes pageBgOrb4 {
  0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.05; }
  50% { transform: translate(30px, -40px) scale(1.2); opacity: 0.09; }
}

@keyframes pageBgOrb5 {
  0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.04; }
  33% { transform: translate(40px, 20px) scale(1.1); opacity: 0.07; }
  66% { transform: translate(-30px, -40px) scale(0.95); opacity: 0.05; }
}

@keyframes pageBgOrb6 {
  0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.05; }
  50% { transform: translate(-25px, 30px) scale(1.15); opacity: 0.08; }
}

/* Floating sparkles in content background */
.page-bg-sparkle {
  position: absolute;
  pointer-events: none;
  font-size: 6px;
  opacity: 0;
  animation: bgSparkleFloat linear infinite;
}

.page-bg-sparkle--1 { left: 5%;  color: rgba(232, 123, 197, 0.3); font-size: 8px;  animation-duration: 18s; animation-delay: 0s; }
.page-bg-sparkle--2 { left: 15%; color: rgba(200, 160, 230, 0.25); font-size: 6px;  animation-duration: 22s; animation-delay: 2s; }
.page-bg-sparkle--3 { left: 30%; color: rgba(94, 208, 213, 0.3);  font-size: 7px;  animation-duration: 20s; animation-delay: 4s; }
.page-bg-sparkle--4 { left: 50%; color: rgba(200, 160, 230, 0.2); font-size: 9px;  animation-duration: 25s; animation-delay: 1s; }
.page-bg-sparkle--5 { left: 65%; color: rgba(232, 123, 197, 0.25); font-size: 6px;  animation-duration: 19s; animation-delay: 3s; }
.page-bg-sparkle--6 { left: 78%; color: rgba(129, 140, 248, 0.2);  font-size: 8px;  animation-duration: 24s; animation-delay: 5s; }
.page-bg-sparkle--7 { left: 88%; color: rgba(94, 208, 213, 0.25);  font-size: 5px;  animation-duration: 17s; animation-delay: 2.5s; }
.page-bg-sparkle--8 { left: 42%; color: rgba(232, 123, 197, 0.2);  font-size: 7px;  animation-duration: 21s; animation-delay: 6s; }

@keyframes bgSparkleFloat {
  0% {
    bottom: -20px;
    transform: translateX(0) rotate(0deg) scale(0.5);
    opacity: 0;
  }
  5% {
    opacity: 0.6;
  }
  50% {
    transform: translateX(20px) rotate(180deg) scale(1);
    opacity: 0.4;
  }
  95% {
    opacity: 0;
  }
  100% {
    bottom: 110vh;
    transform: translateX(-10px) rotate(360deg) scale(0.3);
    opacity: 0;
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .page-hero__orb,
  .page-hero__deco,
  .page-hero__sparkle,
  .page-hero__line,
  .page-hero__mesh,
  .page-hero__bg-text,
  .page-bg-orb,
  .page-bg-sparkle,
  .page-hero::before {
    animation: none !important;
  }
  .page-hero__sparkle,
  .page-bg-sparkle {
    opacity: 0.2;
    transform: none;
  }
  .page-bg-orb {
    opacity: 0.04;
  }
}

/* ── Header: actions wrapper (TOP btn + hamburger) ── */
.header__actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

/* ── Header: TOP button (child pages only) ── */
.header__top-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1) var(--space-3);
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--color-text-muted);
  background: rgba(255, 255, 255, 0.6);
  border: 1px solid rgba(200, 160, 230, 0.25);
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: all var(--duration-normal) var(--ease-out);
  letter-spacing: 0.05em;
}

.header__top-btn:hover {
  background: rgba(255, 255, 255, 0.95);
  color: var(--color-primary-dark);
  border-color: var(--color-primary-light);
  box-shadow: 0 2px 8px rgba(200, 160, 230, 0.2);
  opacity: 1;
}

.header__top-btn svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

.page-hero__en {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 2rem + 4vw, 5rem);
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
  color: var(--color-text);
  background: var(--gradient-hero);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin: 0;
}

.page-hero__ja {
  font-family: var(--font-heading);
  font-size: var(--text-base);
  color: var(--color-text-muted);
  margin-top: var(--space-2);
  letter-spacing: 0.15em;
}

/* ── Page Content Container ── */
.page-content {
  max-width: var(--container-xl);
  margin: 0 auto;
  padding: var(--space-12) var(--space-4);
  overflow-x: hidden;
}

.page-content--narrow {
  max-width: var(--container-lg);
}

/* ── Section within Page ── */
.page-section {
  margin-bottom: var(--space-16);
}

.page-section__heading {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--color-text);
  text-align: center;
  margin-bottom: var(--space-8);
}

/* ── Interview Grid fix for child pages (prevent image overflow) ── */
.page-content .interview__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
  max-width: var(--container-lg);
  margin: 0 auto;
}

.page-content .interview__card {
  min-width: 0;
}

.page-content .interview__card-image {
  min-width: 0;
}

.page-content .interview__card-image img {
  max-width: 100%;
  height: auto;
}

/* ── Archive Grid Layouts ── */
.archive-grid {
  display: grid;
  gap: var(--space-5);
}

.archive-grid--2 {
  grid-template-columns: 1fr;
}

.archive-grid--3 {
  grid-template-columns: repeat(2, 1fr);
}

.archive-grid--4 {
  grid-template-columns: repeat(2, 1fr);
}

@media (min-width: 480px) {
  .archive-grid--2 {
    grid-template-columns: repeat(2, 1fr);
  }

  .archive-grid--3 {
    grid-template-columns: repeat(2, 1fr);
  }

  .archive-grid--4 {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 840px) {
  .archive-grid--3 {
    grid-template-columns: repeat(3, 1fr);
  }

  .archive-grid--4 {
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-6);
  }
}

@media (min-width: 1280px) {
  .archive-grid {
    gap: var(--space-6);
  }
}

/* ── Filter Tabs (Archive pages) ── */
.archive-tabs {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-2);
  margin-bottom: var(--space-8);
}

.archive-tab {
  display: inline-flex;
  align-items: center;
  padding: var(--space-2) var(--space-4);
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text-muted);
  background: var(--color-surface);
  border: 1.5px solid var(--color-border-light);
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-out);
  letter-spacing: 0.03em;
}

.archive-tab:hover {
  border-color: var(--color-primary-light);
  color: var(--color-primary-dark);
  background: var(--color-primary-50, #f5eeff);
}

.archive-tab.is-active {
  background: var(--gradient-primary);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 2px 10px rgba(200, 160, 230, 0.3);
}

/* ── Load More Button ── */
.loadmore-wrap {
  text-align: center;
  margin-top: var(--space-10);
}

.loadmore {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-8);
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-primary-dark);
  background: transparent;
  border: 2px solid var(--color-primary-light);
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-out);
  letter-spacing: 0.05em;
}

.loadmore:hover {
  background: var(--color-primary-50, #f5eeff);
  border-color: var(--color-primary);
  transform: translateY(-2px);
}

.loadmore.is-loading {
  pointer-events: none;
  opacity: 0.6;
}

/* ── Talent Search ── */
.talent-search {
  max-width: 400px;
  margin: 0 auto var(--space-6);
}

.talent-search__form {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  background: #fff;
  border: 2px solid var(--color-primary-light, #d4c5f0);
  border-radius: var(--radius-full);
  padding: var(--space-2) var(--space-4);
  transition: border-color var(--duration-normal) var(--ease-out);
}

.talent-search__form:focus-within {
  border-color: var(--color-primary, #a78bfa);
  box-shadow: 0 0 0 3px rgba(167, 139, 250, 0.15);
}

.talent-search__input {
  flex: 1;
  border: none;
  outline: none;
  font-size: var(--text-sm);
  background: transparent;
  color: var(--color-text);
  min-width: 0;
}

.talent-search__input::placeholder {
  color: var(--color-text-muted);
}

.talent-search__btn {
  background: none;
  border: none;
  cursor: pointer;
  font-size: var(--text-base);
  padding: 0;
  line-height: 1;
}

.talent-search__clear {
  background: none;
  border: none;
  cursor: pointer;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  text-decoration: none;
  padding: 0 var(--space-1);
  line-height: 1;
}

.talent-search__clear:hover {
  color: var(--color-text);
}

/* ── Number Pagination ── */
.pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-10);
  flex-wrap: wrap;
}

.pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text-muted);
  background: var(--color-bg-section);
  text-decoration: none;
  transition: all var(--duration-normal) var(--ease-out);
}

.pagination .page-numbers:hover {
  background: var(--color-primary-50, #f5eeff);
  color: var(--color-primary-dark);
  transform: translateY(-2px);
}

.pagination .page-numbers.current {
  background: var(--color-primary, #a78bfa);
  color: #fff;
}

.pagination .page-numbers.dots {
  background: transparent;
  pointer-events: none;
}

.pagination .page-numbers.prev,
.pagination .page-numbers.next {
  font-size: var(--text-lg);
}

/* ── Empty State ── */
.archive-empty {
  text-align: center;
  padding: var(--space-16) var(--space-4);
  color: var(--color-text-light);
  font-size: var(--text-lg);
}

/* ── Prose Content (for static pages) ── */
.prose {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--color-text);
  max-width: 800px;
  margin: 0 auto;
}

.prose h2 {
  font-size: var(--text-xl);
  font-weight: 700;
  margin-top: var(--space-10);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-2);
  border-bottom: 2px solid var(--color-primary-light);
}

.prose h3 {
  font-size: var(--text-lg);
  font-weight: 700;
  margin-top: var(--space-8);
  margin-bottom: var(--space-3);
}

.prose h4 {
  font-size: var(--text-base);
  font-weight: 700;
  margin-top: var(--space-6);
  margin-bottom: var(--space-2);
}

.prose p {
  margin-bottom: var(--space-4);
}

.prose ul,
.prose ol {
  margin-bottom: var(--space-4);
  padding-left: var(--space-6);
}

.prose li {
  margin-bottom: var(--space-1);
}

.prose a {
  color: var(--color-primary-dark);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.prose a:hover {
  color: var(--color-primary);
}

.prose blockquote {
  margin: var(--space-6) 0;
  padding: var(--space-4) var(--space-6);
  border-left: 4px solid var(--color-primary-light);
  background: var(--color-bg-section);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  font-style: italic;
  color: var(--color-text-muted);
}

.prose img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-lg);
  margin: var(--space-4) 0;
}

.prose table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--space-6) 0;
}

.prose th,
.prose td {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  border-bottom: 1px solid var(--color-border-light);
}

.prose th {
  font-weight: 700;
  background: var(--color-bg-section);
  white-space: nowrap;
  width: 30%;
}

/* ── Article Detail (Single pages) ── */
.article-detail {
  max-width: 800px;
  margin: 0 auto;
}

.article-detail__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.article-detail__cats {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}

.article-detail__cat {
  display: inline-block;
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs);
  font-weight: 600;
  background: var(--gradient-primary);
  color: #fff;
  border-radius: var(--radius-full);
}

/* Per-category colors (single) */
.article-detail__cat--iriam {
  background: #ff6ba1;
}

.article-detail__cat--17live {
  background: #ff3d3d;
}

.article-detail__cat--event,
.article-detail__cat--eventinfo,
.article-detail__cat--event-info {
  background: #7ab6ff;
}

.article-detail__cat--press,
.article-detail__cat--pressrelease {
  background: #b08fd4;
}

.article-detail__cat--media {
  background: #5fc9a3;
}

.article-detail__date {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--color-text-light);
}

.article-detail__title {
  font-size: var(--text-2xl);
  font-weight: 800;
  line-height: 1.3;
  margin-bottom: var(--space-6);
}

.article-detail__thumbnail {
  width: 100%;
  border-radius: var(--radius-xl);
  overflow: hidden;
  margin-bottom: var(--space-8);
}

.article-detail__thumbnail img {
  width: 100%;
  height: auto;
  display: block;
}

.article-detail__content {
  /* prose styling applies inside */
}

/* ── Post Navigation ── */
.post-nav {
  display: flex;
  justify-content: space-between;
  gap: var(--space-4);
  margin-top: var(--space-12);
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-border-light);
}

.post-nav__link {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-primary-dark);
  text-decoration: none;
  transition: color var(--duration-normal) var(--ease-out);
}

.post-nav__link:hover {
  color: var(--color-primary);
}

.post-nav__link--next {
  margin-left: auto;
}

/* ── Related Posts Section ── */
.related-posts {
  margin-top: var(--space-16);
}

.related-posts__heading {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 700;
  text-align: center;
  margin-bottom: var(--space-8);
  color: var(--color-text);
}

/* ── Talent Profile (Single) ── */
.talent-profile {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
  max-width: 1000px;
  margin: 0 auto;
}

.talent-profile__visual {
  position: relative;
  text-align: center;
  width: 100%;
  min-width: 0;
  overflow: hidden;
}

.talent-profile__standing {
  max-width: 400px;
  width: 100%;
  height: auto;
  margin: 0 auto;
  border-radius: var(--radius-xl);
}

/* Talent Slider */
.talent-slider {
  width: 100%;
  max-width: 480px;
  margin: 0 auto;
  border-radius: var(--radius-xl);
  overflow: hidden;
}

.talent-slider__img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--radius-xl);
}

.talent-slider .swiper-button-prev,
.talent-slider .swiper-button-next {
  color: #fff;
  width: 36px;
  height: 36px;
  background: rgba(0, 0, 0, 0.35);
  border-radius: 50%;
  transition: background 0.2s;
}

.talent-slider .swiper-button-prev:hover,
.talent-slider .swiper-button-next:hover {
  background: rgba(0, 0, 0, 0.55);
}

.talent-slider .swiper-button-prev::after,
.talent-slider .swiper-button-next::after {
  font-size: 14px;
  font-weight: 700;
}

.talent-slider .swiper-pagination-bullet {
  background: #fff;
  opacity: 0.5;
}

.talent-slider .swiper-pagination-bullet-active {
  opacity: 1;
  background: var(--color-primary, #a78bfa);
}

/* SD Image — 立ち絵の右下に重ねて配置 */
.talent-profile__sd {
  position: absolute;
  right: -20%;
  bottom: 5%;
  z-index: 2;
}

.talent-profile__sd-img {
  width: 180px;
  height: auto;
  filter: drop-shadow(2px 4px 8px rgba(0, 0, 0, 0.15));
  transition: transform 0.3s ease;
}

.talent-profile__sd-img:hover {
  transform: scale(1.1) rotate(-3deg);
}

@media (min-width: 640px) {
  .talent-profile__sd-img {
    width: 220px;
  }
}

@media (min-width: 1024px) {
  .talent-profile__sd-img {
    width: 270px;
  }
}

.talent-profile__info {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.talent-profile__name {
  font-size: var(--text-3xl);
  font-weight: 800;
  line-height: 1.2;
}

.talent-profile__name-en {
  display: inline-block;
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text-muted);
  letter-spacing: 0.1em;
  padding: var(--space-1) var(--space-3);
  background: var(--color-bg-section);
  border-radius: var(--radius-full);
}

.talent-profile__badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.talent-profile__badge {
  display: inline-flex;
  align-items: center;
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs);
  font-weight: 600;
  border-radius: var(--radius-full);
  background: var(--gradient-primary);
  color: #fff;
}

/* Meta info — birthday, debut date */
.talent-profile__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin: 0;
}

.talent-profile__meta-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  background: var(--color-bg-section);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border-light);
}

.talent-profile__meta-item dt {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--color-text-muted);
  white-space: nowrap;
}

.talent-profile__meta-item dt svg {
  color: var(--color-primary);
  flex-shrink: 0;
}

.talent-profile__meta-item dd {
  margin: 0;
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--color-text);
}

.talent-profile__desc {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--color-text-muted);
}

.talent-profile__sns {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.talent-profile__sns-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  background: var(--color-surface);
  border: 1.5px solid var(--color-border-light);
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: all var(--duration-normal) var(--ease-out);
}

.talent-profile__sns-link:hover {
  border-color: var(--color-primary-light);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.talent-profile__sns-icon {
  width: 20px;
  height: 20px;
  object-fit: contain;
  border-radius: 4px;
}

.talent-profile__sns-link--iriam {
  background: linear-gradient(135deg, #f0e8ff, #e8f0ff);
  border-color: rgba(155, 111, 204, 0.2);
}

.talent-profile__sns-link--iriam:hover {
  border-color: var(--color-primary);
  background: linear-gradient(135deg, #e8deff, #dde8ff);
}

@media (min-width: 840px) {
  .talent-profile {
    flex-direction: row-reverse;
    align-items: flex-start;
  }

  .talent-profile__visual {
    flex: 0 0 45%;
    position: sticky;
    top: var(--space-8);
  }

  .talent-profile__info {
    flex: 1;
  }

  .page-hero {
    padding: var(--space-24) var(--space-4) var(--space-16);
  }
}

/* ── FAQ Accordion ── */
.faq-list {
  max-width: 800px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.faq-item {
  background: var(--color-surface);
  border-radius: var(--radius-xl);
  border: 1px solid var(--color-border-light);
  overflow: hidden;
  transition: box-shadow var(--duration-normal) var(--ease-out);
}

.faq-item:hover {
  box-shadow: var(--shadow-md);
}

/* Q/A Badge */
.faq-item__badge {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: var(--radius-md);
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 800;
  line-height: 1;
}

.faq-item__badge--q {
  background: var(--gradient-primary);
  color: #fff;
}

.faq-item__badge--a {
  background: var(--color-primary);
  color: #fff;
  margin-top: 2px;
}

/* Question Button */
.faq-item__question {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-5) var(--space-5);
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-text);
  background: none;
  border: none;
  width: 100%;
  text-align: left;
  cursor: pointer;
  transition: background var(--duration-normal) var(--ease-out);
}

.faq-item__question-text {
  flex: 1;
}

.faq-item__question:hover {
  background: rgba(200, 160, 230, 0.04);
}

/* +/- Icon */
.faq-item__icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  position: relative;
  border-radius: 50%;
  background: rgba(200, 160, 230, 0.1);
  transition: all var(--duration-normal) var(--ease-out);
}

.faq-item__icon::before,
.faq-item__icon::after {
  content: '';
  position: absolute;
  background: var(--color-primary);
  border-radius: 2px;
}

.faq-item__icon::before {
  width: 14px;
  height: 2px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.faq-item__icon::after {
  width: 2px;
  height: 14px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: transform var(--duration-normal) var(--ease-out);
}

.faq-item.is-open .faq-item__icon {
  background: var(--gradient-primary);
}

.faq-item.is-open .faq-item__icon::before,
.faq-item.is-open .faq-item__icon::after {
  background: #fff;
}

.faq-item.is-open .faq-item__icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

/* Answer */
.faq-item__answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s var(--ease-out);
}

.faq-item__answer-inner {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: 0 var(--space-5) var(--space-6);
  margin-left: 0;
  border-top: 1px solid var(--color-border-light);
  padding-top: var(--space-5);
  margin-top: 0;
}

.faq-item__answer-text {
  flex: 1;
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--color-text-muted);
}

.faq-item__answer-text p {
  margin: 0;
}

.faq-item.is-open .faq-item__answer {
  max-height: 600px;
}

/* FAQ Small Mobile */
@media (max-width: 479px) {
  .faq-list {
    gap: var(--space-3);
  }

  .faq-item__badge {
    width: 26px;
    height: 26px;
    font-size: var(--text-sm);
    border-radius: 6px;
  }

  .faq-item__question {
    padding: var(--space-3) var(--space-4);
    font-size: var(--text-sm);
    gap: var(--space-2);
  }

  .faq-item__icon {
    width: 24px;
    height: 24px;
  }

  .faq-item__answer-inner {
    padding: 0 var(--space-4) var(--space-4);
    padding-top: var(--space-3);
    gap: var(--space-2);
  }

  .faq-item__answer-text {
    font-size: var(--text-xs);
  }
}

@media (min-width: 840px) {
  .faq-item__badge {
    width: 36px;
    height: 36px;
    font-size: var(--text-lg);
  }

  .faq-item__question {
    padding: var(--space-6);
    font-size: var(--text-lg);
    gap: var(--space-4);
  }

  .faq-item__answer-inner {
    padding: 0 var(--space-6) var(--space-6);
    padding-top: var(--space-5);
    gap: var(--space-4);
  }

  .faq-item__answer-text {
    font-size: var(--text-base);
  }
}

/* ── Benefits — Rich Animated Cards ── */

/* Intro Section */
.benefits-intro {
  text-align: center;
  max-width: 700px;
  margin: 0 auto var(--space-16);
}

.benefits-intro__title {
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  font-weight: 800;
  line-height: 1.5;
  margin-bottom: var(--space-4);
}

.benefits-intro__title em {
  font-style: normal;
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.benefits-intro__desc {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
}

/* Benefits Section */
.benefits-section {
  max-width: 900px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-12);
}

/* Single Benefit Block */
.benefit-rich {
  position: relative;
  content-visibility: auto;
  contain-intrinsic-size: 0 400px;
}

/* Number Badge */
.benefit-rich__number {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
  position: relative;
}

.benefit-rich__number-label {
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--color-accent-pink);
  background: rgba(232, 123, 197, 0.1);
  padding: 2px 10px;
  border-radius: var(--radius-full);
  letter-spacing: 0.05em;
}

.benefit-rich__number-value {
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.5rem + 2vw, 3rem);
  font-weight: 800;
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
}

.benefit-rich__number-deco {
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, var(--color-accent-pink) 0%, transparent 100%);
  opacity: 0.3;
}

/* Card */
.benefit-rich__card {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  padding: var(--space-6);
  background: var(--color-surface);
  border-radius: var(--radius-2xl);
  border: 1px solid var(--color-border-light);
  box-shadow: var(--shadow-sm);
  transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
  position: relative;
  overflow: hidden;
}

/* Subtle gradient border glow on hover */
.benefit-rich__card::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(232, 123, 197, 0.3), rgba(200, 160, 230, 0.3), rgba(94, 208, 213, 0.3));
  z-index: -1;
  opacity: 0;
  transition: opacity 0.4s ease;
}

.benefit-rich__card:hover::before {
  opacity: 1;
}

.benefit-rich__card:hover {
  transform: translateY(-4px);
  box-shadow:
    0 12px 40px rgba(200, 160, 230, 0.15),
    0 4px 12px rgba(232, 123, 197, 0.08);
  border-color: transparent;
}

/* Mobile: disable ALL hover/transform effects for smooth touch scroll */
@media (hover: none) and (pointer: coarse) {
  .benefit-rich__card,
  .faq-card,
  .benefit-rich__card *,
  .faq-card *,
  .faq-item,
  .faq-item * {
    touch-action: pan-y !important;
    -webkit-touch-callout: none;
  }

  .benefit-rich__card,
  .faq-card,
  .faq-item {
    overflow: visible;
    transition: none !important;
    transform: none !important;
  }

  .benefit-rich__card::before,
  .benefit-rich__card::after {
    display: none !important;
  }

  .benefit-rich__card:hover,
  .faq-card:hover,
  .faq-item:hover {
    transform: none !important;
    box-shadow: var(--shadow-sm);
    border-color: var(--color-border-light);
  }

  .benefit-rich__card:hover .benefit-rich__img-wrap {
    transform: none !important;
  }

  .benefit-rich__card:hover .benefit-rich__title-accent::after {
    transform: scaleX(0) !important;
  }
}

/* Content */
.benefit-rich__content {
  flex: 1;
}

.benefit-rich__title {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: 800;
  line-height: 1.6;
  margin-bottom: var(--space-3);
}

.benefit-rich__title-accent {
  color: var(--color-accent-pink);
  position: relative;
}

.benefit-rich__title-accent::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2px;
  background: var(--gradient-primary);
  border-radius: 1px;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.benefit-rich__card:hover .benefit-rich__title-accent::after {
  transform: scaleX(1);
}

.benefit-rich__desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
}

.benefit-rich__list {
  list-style: none;
  padding: 0;
  margin: var(--space-4) 0 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.benefit-rich__list li {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  padding: 6px 14px;
  background: linear-gradient(135deg, rgba(155, 111, 204, 0.08), rgba(232, 123, 197, 0.08));
  border-radius: var(--radius-full);
  border: 1px solid rgba(155, 111, 204, 0.15);
}

.benefit-rich__list li::before {
  content: '\2714';
  color: var(--color-primary);
  font-size: 12px;
}

/* Visual / Image */
.benefit-rich__visual {
  display: flex;
  justify-content: center;
}

.benefit-rich__img-wrap {
  width: 100%;
  max-width: 280px;
  aspect-ratio: 4 / 3;
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: linear-gradient(135deg, var(--color-bg-section) 0%, var(--color-bg-section-alt) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.benefit-rich__card:hover .benefit-rich__img-wrap {
  transform: scale(1.03);
}

.benefit-rich__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.benefit-rich__img-placeholder {
  color: var(--color-primary);
  opacity: 0.4;
}

/* Tablet: side-by-side layout */
@media (min-width: 640px) {
  .benefit-rich__card {
    flex-direction: row;
    align-items: center;
    gap: var(--space-8);
    padding: var(--space-8);
  }

  .benefit-rich__card--reverse {
    flex-direction: row-reverse;
  }

  .benefit-rich__visual {
    flex-shrink: 0;
    width: 220px;
  }

  .benefit-rich__img-wrap {
    max-width: 100%;
  }
}

/* Desktop */
@media (min-width: 1024px) {
  .benefit-rich__card {
    padding: var(--space-10);
    gap: var(--space-10);
  }

  .benefit-rich__visual {
    width: 280px;
  }

  .benefit-rich__title {
    font-size: var(--text-xl);
  }
}

/* ── Benefits CTA ── */
.benefits-cta {
  margin-top: var(--space-16);
  text-align: center;
}

.benefits-cta__inner {
  padding: var(--space-12) var(--space-6);
  background: linear-gradient(135deg, rgba(200, 160, 230, 0.1) 0%, rgba(232, 123, 197, 0.08) 50%, rgba(94, 208, 213, 0.06) 100%);
  border-radius: var(--radius-2xl);
  border: 1px solid rgba(200, 160, 230, 0.15);
}

.benefits-cta__text {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: 800;
  margin-bottom: var(--space-6);
  line-height: 1.6;
}

.benefits-cta__btn {
  display: inline-flex;
  gap: var(--space-2);
}

/* sp-only helper */
@media (min-width: 640px) {
  .sp-only { display: none; }
}

/* ==========================================================================
   Legal Pages (Privacy, Guidelines)
   ========================================================================== */

.legal-content {
  max-width: 800px;
  margin: 0 auto;
}

/* Table of Contents */
.legal-toc {
  background: var(--color-surface);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-2xl);
  padding: var(--space-6) var(--space-8);
  margin-bottom: var(--space-12);
}

.legal-toc__title {
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-border-light);
}

.legal-toc__list {
  list-style: none;
  padding: 0;
  margin: 0;
  counter-reset: toc-counter;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.legal-toc__list li {
  counter-increment: toc-counter;
}

.legal-toc__list li a {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  color: var(--color-text);
  text-decoration: none;
  font-size: var(--text-sm);
  font-weight: 500;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  transition: all var(--duration-normal) var(--ease-out);
}

.legal-toc__list li a::before {
  content: counter(toc-counter);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: var(--radius-full);
  background: var(--gradient-primary);
  color: #fff;
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 700;
  flex-shrink: 0;
}

.legal-toc__list li a:hover {
  background: var(--color-bg-section);
  color: var(--color-primary-dark);
  opacity: 1;
}

/* ── Partner Voices ── */
.partner-voices {
  max-width: 1000px;
  margin: 0 auto;
  padding: var(--space-12) var(--space-4);
}

.partner-voices__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

@media (min-width: 768px) {
  .partner-voices__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.partner-voice-card {
  background: var(--color-surface);
  border-radius: var(--radius-2xl);
  border: 1px solid var(--color-border-light);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.partner-voice-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(200, 160, 230, 0.15);
}

.partner-voice-card__header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}


.partner-voice-card__icon-wrap {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
}

.partner-voice-card__avatar {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.partner-voice-card__icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--gradient-primary);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-lg);
  flex-shrink: 0;
}

.partner-voice-card__name {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-text);
  margin: 0;
}

.partner-voice-card__type {
  font-size: var(--text-xs);
  color: var(--color-primary);
  font-weight: 600;
}

.partner-voice-card__revenue {
  background: linear-gradient(135deg, rgba(200, 160, 230, 0.08), rgba(232, 123, 197, 0.06));
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  text-align: center;
  margin-bottom: var(--space-4);
}

.partner-voice-card__revenue-label {
  display: block;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-bottom: var(--space-1);
}

.partner-voice-card__revenue-value {
  display: block;
  font-family: var(--font-display);
  font-size: 2.5rem;
  font-weight: 800;
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1.2;
}

.partner-voice-card__revenue-value small {
  font-size: var(--text-base);
  -webkit-text-fill-color: var(--color-text-muted);
}

.partner-voice-card__revenue-period {
  display: block;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: var(--space-1);
}

.partner-voice-card__desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.7;
  margin: 0;
}

/* Section */
.legal-section {
  margin-bottom: var(--space-16);
  scroll-margin-top: 100px;
}

.legal-section:last-child {
  margin-bottom: 0;
}

.legal-section__title {
  font-family: var(--font-heading);
  font-size: clamp(1.25rem, 2.5vw, 1.6rem);
  font-weight: 700;
  color: var(--color-text);
  padding-bottom: var(--space-4);
  border-bottom: 2px solid transparent;
  border-image: var(--gradient-primary) 1;
  margin-bottom: var(--space-8);
}

.legal-section__intro {
  font-size: var(--text-base);
  color: var(--color-text);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-8);
}

/* Block */
.legal-block {
  margin-bottom: var(--space-8);
}

.legal-block:last-child {
  margin-bottom: 0;
}

.legal-block__heading {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-text);
  padding-left: var(--space-4);
  border-left: 3px solid var(--color-primary);
  margin-bottom: var(--space-4);
  line-height: var(--leading-normal);
}

.legal-block p {
  font-size: var(--text-sm);
  color: var(--color-text);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-3);
}

.legal-block p:last-child {
  margin-bottom: 0;
}

.legal-block ul {
  list-style: none;
  padding: 0;
  margin: var(--space-3) 0 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.legal-block ul li {
  position: relative;
  padding-left: var(--space-5);
  font-size: var(--text-sm);
  color: var(--color-text);
  line-height: var(--leading-relaxed);
}

.legal-block ul li::before {
  content: '';
  position: absolute;
  left: 6px;
  top: 10px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-primary);
}

/* Nested list */
.legal-block ul ul {
  margin-top: var(--space-2);
  margin-left: var(--space-2);
  gap: var(--space-2);
}

.legal-block ul ul li::before {
  width: 4px;
  height: 4px;
  background: var(--color-primary-light);
  top: 11px;
}

/* Note */
.legal-note {
  font-size: var(--text-xs) !important;
  color: var(--color-text-light) !important;
  background: var(--color-bg-section);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  border-left: 3px solid var(--color-primary-light);
}

/* Example box */
.legal-example {
  background: var(--color-bg-section);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-5);
  margin: var(--space-3) 0;
}

.legal-example__label {
  font-size: var(--text-xs) !important;
  font-weight: 700;
  color: var(--color-primary) !important;
  margin-bottom: var(--space-2) !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.legal-example p:last-child {
  margin-bottom: 0;
}

/* Mobile */
@media (max-width: 479px) {
  .legal-toc {
    padding: var(--space-4) var(--space-5);
  }

  .legal-section__title {
    font-size: 1.15rem;
  }

  .legal-block__heading {
    font-size: var(--text-sm);
  }

  .legal-block p,
  .legal-block ul li {
    font-size: var(--text-xs);
  }
}

/* ── Contact Navigation ── */
.contact-nav {
  max-width: var(--container-lg);
  margin: 0 auto var(--space-16);
  text-align: center;
}

.contact-nav__lead {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  margin-bottom: var(--space-8);
  line-height: var(--leading-relaxed);
}

.contact-nav__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}

@media (min-width: 768px) {
  .contact-nav__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-5);
  }
}

.contact-nav__card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--space-6) var(--space-5);
  background: var(--color-surface);
  border: 1.5px solid var(--color-border-light);
  border-radius: var(--radius-2xl);
  text-decoration: none;
  color: var(--color-text);
  transition: all var(--duration-normal) var(--ease-out);
}

.contact-nav__card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md), var(--shadow-glow-primary);
  border-color: var(--color-primary-light);
  opacity: 1;
}

.contact-nav__card--active {
  border-color: var(--color-primary);
  background: linear-gradient(135deg, rgba(200, 160, 230, 0.06), rgba(232, 123, 197, 0.04));
}

.contact-nav__card-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  border-radius: var(--radius-xl);
  background: var(--color-bg-section);
  color: var(--color-primary);
  margin-bottom: var(--space-4);
  transition: transform var(--duration-normal) var(--ease-out),
              background var(--duration-normal) var(--ease-out);
}

.contact-nav__card:hover .contact-nav__card-icon {
  transform: scale(1.08);
  background: var(--color-primary-50);
}

.contact-nav__card-title {
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: var(--space-2);
  line-height: var(--leading-normal);
}

.contact-nav__card-desc {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-3);
}

.contact-nav__card-arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: var(--radius-full);
  background: var(--color-bg-section);
  color: var(--color-primary);
  transition: all var(--duration-normal) var(--ease-out);
}

.contact-nav__card:hover .contact-nav__card-arrow {
  background: var(--gradient-primary);
  color: #fff;
}

/* ── Contact Section ── */
.contact-section {
  max-width: var(--container-md);
  margin: 0 auto;
}

.contact-section__heading {
  font-family: var(--font-heading);
  font-size: clamp(1.25rem, 2.5vw, 1.75rem);
  font-weight: 700;
  text-align: center;
  color: var(--color-text);
  margin-bottom: var(--space-10);
}

.contact-section__heading .page-section__heading-en {
  margin-bottom: var(--space-2);
}

/* ── Contact Form ── */
.contact-form-wrap {
  max-width: 700px;
  margin: 0 auto;
  background: var(--color-surface);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-2xl);
  padding: var(--space-8) var(--space-6);
}

@media (min-width: 768px) {
  .contact-form-wrap {
    padding: var(--space-10) var(--space-10);
  }
}

.contact-form-wrap .wpcf7-form,
.contact-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.contact-form__group {
  display: flex;
  flex-direction: column;
}

.contact-form-wrap label,
.contact-form__label {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: 700;
  margin-bottom: var(--space-2);
  color: var(--color-text);
}

.contact-form__required {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  color: #fff;
  background: var(--gradient-primary);
  padding: 1px var(--space-2);
  border-radius: var(--radius-sm);
  line-height: 1.6;
  letter-spacing: 0.05em;
}

.contact-form__optional {
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  color: var(--color-text-light);
  background: var(--color-bg-section);
  padding: 1px var(--space-2);
  border-radius: var(--radius-sm);
  line-height: 1.6;
  letter-spacing: 0.05em;
}

.contact-form-wrap input[type="text"],
.contact-form-wrap input[type="email"],
.contact-form-wrap input[type="tel"],
.contact-form-wrap input[type="url"],
.contact-form-wrap textarea,
.contact-form-wrap select {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-base);
  border: 1.5px solid var(--color-border-light);
  border-radius: var(--radius-md);
  background: var(--color-bg);
  transition: border-color var(--duration-normal) var(--ease-out),
              box-shadow var(--duration-normal) var(--ease-out);
}

.contact-form-wrap input[type="text"]::placeholder,
.contact-form-wrap input[type="email"]::placeholder,
.contact-form-wrap input[type="tel"]::placeholder,
.contact-form-wrap input[type="url"]::placeholder,
.contact-form-wrap textarea::placeholder {
  color: var(--color-text-light);
  opacity: 0.5;
}

.contact-form-wrap input:focus,
.contact-form-wrap textarea:focus,
.contact-form-wrap select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(200, 160, 230, 0.15);
}

.contact-form-wrap textarea {
  min-height: 180px;
  resize: vertical;
}

.contact-form__privacy {
  text-align: center;
  font-size: var(--text-xs);
  color: var(--color-text-light);
  line-height: var(--leading-relaxed);
}

.contact-form__privacy a {
  color: var(--color-primary);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.contact-form__privacy a:hover {
  color: var(--color-primary-dark);
  opacity: 1;
}

.contact-form__submit {
  text-align: center;
  margin-top: var(--space-3);
}

.contact-form-wrap input[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4) var(--space-12);
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 700;
  color: #fff;
  background: var(--gradient-primary);
  border: none;
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-out);
  letter-spacing: 0.05em;
}

.contact-form-wrap input[type="submit"]:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 20px rgba(200, 160, 230, 0.4);
}

/* ── CF7 Form Overrides (matches .contact-form design) ── */
.contact-form-wrap .form_wrap {
  display: flex;
  flex-direction: column;
  margin-bottom: var(--space-5);
}

.contact-form-wrap .form_wrap:last-of-type {
  margin-bottom: 0;
}

.contact-form-wrap .form_label {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: 700;
  margin-bottom: var(--space-2);
  color: var(--color-text);
}

.contact-form-wrap .form_label span {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  color: #fff;
  background: var(--gradient-primary);
  padding: 1px var(--space-2);
  border-radius: var(--radius-sm);
  line-height: 1.6;
  letter-spacing: 0.05em;
}

/* CF7 radio buttons — horizontal layout */
.contact-form-wrap .wpcf7-radio,
.contact-form-wrap .wpcf7-list-item {
  display: inline-flex;
  align-items: center;
  margin: 0;
}

.contact-form-wrap .wpcf7-radio {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-5);
  padding: var(--space-2) 0;
}

.contact-form-wrap .wpcf7-list-item {
  margin: 0;
  gap: var(--space-2);
  cursor: pointer;
}

.contact-form-wrap .wpcf7-list-item label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
  font-size: var(--text-sm);
  margin: 0;
}

.contact-form-wrap .wpcf7-list-item input[type="radio"] {
  width: 18px;
  height: 18px;
  accent-color: var(--color-primary, #c8a0e6);
  cursor: pointer;
}

/* Privacy text block (plain div without form_wrap class) */
.contact-form-wrap > form > div:not(.form_wrap) {
  text-align: center;
  font-size: var(--text-xs);
  color: var(--color-text-light);
  line-height: var(--leading-relaxed);
  margin: var(--space-6) 0 var(--space-3);
}

.contact-form-wrap > form > div:not(.form_wrap) a {
  color: var(--color-primary);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* CF7 submit wrapper */
.contact-form-wrap .wpcf7-form > p:last-of-type,
.contact-form-wrap .wpcf7-submit {
  text-align: center;
}

/* CF7 response / validation messages */
.contact-form-wrap .wpcf7-response-output {
  margin: var(--space-6) 0 0;
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
}

.contact-form-wrap .wpcf7-not-valid-tip {
  color: #e11d48;
  font-size: var(--text-xs);
  margin-top: var(--space-1);
}

/* Contact Mobile */
@media (max-width: 479px) {
  .contact-nav {
    margin-bottom: var(--space-10);
  }

  .contact-nav__card {
    padding: var(--space-4);
    flex-direction: row;
    text-align: left;
    gap: var(--space-4);
  }

  .contact-nav__card-icon {
    width: 56px;
    height: 56px;
    margin-bottom: 0;
    flex-shrink: 0;
  }

  .contact-nav__card-desc {
    margin-bottom: 0;
  }

  .contact-nav__card-arrow {
    position: absolute;
    right: var(--space-4);
    top: 50%;
    transform: translateY(-50%);
  }

  .contact-form-wrap {
    padding: var(--space-5) var(--space-4);
  }
}

/* ── Memory Filter (Year-Month dropdown) ── */
.memory-filter {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-8);
  max-width: var(--container-lg);
  margin-left: auto;
  margin-right: auto;
}

.memory-filter__select-wrap {
  position: relative;
  flex-shrink: 0;
}

.memory-filter__select {
  appearance: none;
  -webkit-appearance: none;
  padding: var(--space-3) var(--space-10) var(--space-3) var(--space-5);
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: 500;
  color: var(--color-primary-dark);
  background: var(--color-surface);
  border: 2px solid var(--color-primary-light);
  border-radius: var(--radius-full);
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23a78bba' stroke-width='2'%3E%3Cpath d='m4 6 4 4 4-4'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 16px center;
  transition: all var(--duration-normal) var(--ease-out);
  min-width: 180px;
}

.memory-filter__select:hover,
.memory-filter__select:focus {
  border-color: var(--color-primary);
  outline: none;
  box-shadow: 0 0 0 3px rgba(200, 160, 230, 0.15);
}

.memory-filter__reset {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text-muted);
  background: var(--color-bg-section);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-out);
}

.memory-filter__reset:hover {
  background: var(--color-surface);
  color: var(--color-text);
  border-color: var(--color-primary-light);
}

/* ── Memory Grid (2-column) ── */
.memory-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  max-width: var(--container-lg);
  margin: 0 auto;
}

@media (min-width: 480px) {
  .memory-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.memory-card {
  display: block;
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border-light);
  overflow: hidden;
  text-decoration: none;
  color: var(--color-text);
  transition: all var(--duration-normal) var(--ease-out);
}

.memory-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  opacity: 1;
}

.memory-card__image {
  aspect-ratio: 16 / 9;
  overflow: hidden;
}

.memory-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--duration-slow) var(--ease-out);
}

.memory-card:hover .memory-card__image img {
  transform: scale(1.03);
}

.memory-card__body {
  padding: var(--space-3) var(--space-4);
}

.memory-card__date {
  display: block;
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--color-text-muted);
  margin-bottom: var(--space-1);
}

.memory-card__title {
  font-size: var(--text-base);
  font-weight: 700;
  line-height: 1.5;
}

/* ── Timeline (Legacy — kept for single-memory if used) ── */
.timeline {
  position: relative;
  max-width: 800px;
  margin: 0 auto;
  padding-left: var(--space-8);
}

.timeline::before {
  content: '';
  position: absolute;
  left: 12px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: var(--color-primary-light);
}

.timeline__item {
  position: relative;
  margin-bottom: var(--space-8);
}

.timeline__dot {
  position: absolute;
  left: calc(-1 * var(--space-8) + 4px);
  top: var(--space-1);
  width: 18px;
  height: 18px;
  background: var(--gradient-primary);
  border-radius: 50%;
  border: 3px solid var(--color-bg);
  box-shadow: 0 0 0 2px var(--color-primary-light);
}

.timeline__date {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-primary-dark);
  margin-bottom: var(--space-2);
}

.timeline__card {
  display: block;
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border-light);
  overflow: hidden;
  text-decoration: none;
  color: var(--color-text);
  transition: all var(--duration-normal) var(--ease-out);
}

.timeline__card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}

.timeline__card-image {
  aspect-ratio: 16 / 9;
  overflow: hidden;
}

.timeline__card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.timeline__card-body {
  padding: var(--space-3) var(--space-4);
}

.timeline__card-title {
  font-size: var(--text-base);
  font-weight: 700;
}

/* ── Fan Art Submit CTA ── */
.fanart-submit {
  text-align: center;
  margin-bottom: var(--space-10);
}

.fanart-submit__heading {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: 800;
  margin-bottom: var(--space-4);
}

.fanart-submit__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  width: 100%;
  max-width: 400px;
  padding: var(--space-4) var(--space-8);
  background: var(--gradient-primary);
  color: var(--color-text-inverse);
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: 700;
  letter-spacing: 0.05em;
  border-radius: var(--radius-full);
  text-decoration: none;
  box-shadow: var(--shadow-md);
  transition: all var(--duration-normal) var(--ease-out);
  position: relative;
  overflow: hidden;
}

.fanart-submit__btn::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: var(--gradient-shine);
  transition: left var(--duration-slower) var(--ease-out);
}

.fanart-submit__btn:hover::after {
  left: 100%;
}

.fanart-submit__btn:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg), var(--shadow-glow-pink);
  opacity: 1;
}

.fanart-submit__btn-text {
  position: relative;
  z-index: 1;
}

.fanart-submit__btn-icon {
  position: relative;
  z-index: 1;
  transition: transform var(--duration-normal) var(--ease-out);
}

.fanart-submit__btn:hover .fanart-submit__btn-icon {
  transform: translateX(4px);
}

.fanart-submit__note {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: var(--space-3);
}

/* ── Fan Art Gallery ── */
.fanart-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3);
}

.fanart-card {
  display: flex;
  flex-direction: column;
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: #fff;
  border: 1px solid #eee;
  text-decoration: none;
  cursor: pointer;
}

.fanart-card img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  display: block;
  transition: transform var(--duration-slow) var(--ease-out);
}

.fanart-card:hover img {
  transform: scale(1.05);
}

.fanart-card__info {
  padding: var(--space-3);
  text-align: center;
}

.fanart-card__talent {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  margin: 0;
}

.fanart-card__divider {
  width: 24px;
  height: 1px;
  background: #ddd;
  margin: var(--space-1) auto;
}

.fanart-card__submitter {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin: 0;
}

.fanart-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(transparent 60%, rgba(26, 26, 46, 0.7));
  opacity: 0;
  transition: opacity var(--duration-normal) var(--ease-out);
  display: flex;
  align-items: flex-end;
  padding: var(--space-3);
}

.fanart-card:hover .fanart-card__overlay {
  opacity: 1;
}

.fanart-card__title {
  font-size: var(--text-xs);
  color: #fff;
  font-weight: 600;
}

@media (min-width: 480px) {
  .fanart-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 840px) {
  .fanart-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-4);
  }
}

/* ── Audition / CTA Section ── */
.audition-section {
  text-align: center;
  padding: var(--space-12) var(--space-4);
  max-width: 800px;
  margin: 0 auto;
}

.audition-section__text {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--color-text-muted);
  margin-bottom: var(--space-8);
}

.audition-section__steps {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  margin-bottom: var(--space-10);
  text-align: left;
}

.audition-step {
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
  padding: var(--space-4);
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border-light);
}

.audition-step__num {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 800;
  background: var(--gradient-primary);
  color: #fff;
  border-radius: 50%;
}

.audition-step__content h3 {
  font-size: var(--text-base);
  font-weight: 700;
  margin-bottom: var(--space-1);
}

.audition-step__content p {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

@media (min-width: 480px) {
  .audition-section__steps {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ── CTA Button (reusable) ── */
.page-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-4) var(--space-10);
  font-family: var(--font-display);
  font-size: clamp(0.85rem, 3.5vw, var(--text-lg));
  font-weight: 700;
  color: #fff;
  background: var(--gradient-primary);
  border: none;
  border-radius: var(--radius-full);
  text-decoration: none;
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-out);
  box-shadow: 0 4px 15px rgba(200, 160, 230, 0.3);
  white-space: nowrap;
}

.page-cta:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 25px rgba(200, 160, 230, 0.45);
}

/* ── About Page ── */
.about-video {
  max-width: 800px;
  margin: 0 auto var(--space-10);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}

.about-video__iframe-wrap {
  position: relative;
  padding-bottom: 56.25%; /* 16:9 */
  height: 0;
}

.about-video__iframe-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: none;
}

.about-table {
  max-width: 700px;
  margin: 0 auto;
}

.about-table table {
  width: 100%;
  border-collapse: collapse;
}

.about-table th,
.about-table td {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  border-bottom: 1px solid var(--color-border-light);
  font-size: var(--text-sm);
}

.about-table th {
  font-weight: 700;
  color: var(--color-text);
  white-space: nowrap;
  width: 30%;
  background: var(--color-bg-section);
}

/* ── Responsive ── */
@media (max-width: 479px) {
  .page-hero {
    padding: calc(var(--header-height) + var(--space-4)) var(--space-3) var(--space-6);
  }

  .page-content {
    padding: var(--space-8) var(--space-4);
  }

  .timeline {
    padding-left: var(--space-6);
  }

  .timeline::before {
    left: 8px;
  }

  .timeline__dot {
    left: calc(-1 * var(--space-6) + 0px);
    width: 14px;
    height: 14px;
  }
}

/* ==========================================================================
   Audition Page
   ========================================================================== */

/* ── Audition KV (Key Visual) ── */
.aud-kv {
  max-width: var(--container-xl);
  margin: 0 auto;
  padding: 0 var(--space-4);
}

.aud-kv__inner {
  position: relative;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  aspect-ratio: 21 / 9;
  max-height: 480px;
}

.aud-kv__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 20%;
  display: block;
}

.aud-kv__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(26, 26, 46, 0.6) 0%, rgba(26, 26, 46, 0.2) 60%, transparent 100%);
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: var(--space-8) var(--space-10);
}

.aud-kv__catch {
  font-family: var(--font-heading);
  font-size: clamp(1.5rem, 4vw, 3rem);
  font-weight: 800;
  color: #fff;
  line-height: 1.3;
  margin: 0 0 var(--space-2);
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.aud-kv__sub {
  font-size: clamp(0.85rem, 1.5vw, 1.2rem);
  color: rgba(255, 255, 255, 0.85);
  margin: 0;
  font-weight: 500;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
}

@media (max-width: 639px) {
  .aud-kv__inner {
    aspect-ratio: 16 / 9;
    max-height: 300px;
  }

  .aud-kv__overlay {
    padding: var(--space-5) var(--space-6);
    background: linear-gradient(to top, rgba(26, 26, 46, 0.65) 0%, rgba(26, 26, 46, 0.15) 100%);
    justify-content: flex-end;
  }
}

@media (min-width: 1280px) {
  .aud-kv {
    padding: 0 var(--space-8);
  }

  .aud-kv__inner {
    max-height: 520px;
  }

  .aud-kv__overlay {
    padding: var(--space-12) var(--space-16);
  }
}

/* ── Intro ── */
.aud-intro {
  text-align: center;
  max-width: var(--container-md);
  margin: 0 auto var(--space-16);
  padding: var(--space-8) var(--space-4);
}

.aud-intro__catch {
  font-family: var(--font-heading);
  font-size: clamp(1.5rem, 3vw, 2.5rem);
  font-weight: 700;
  color: var(--color-text);
  line-height: var(--leading-tight);
  margin-bottom: var(--space-5);
}

.aud-intro__catch-accent {
  background: var(--gradient-hero);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.aud-intro__sub {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
  max-width: 600px;
  margin: 0 auto var(--space-6);
}

.aud-intro__divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  margin-top: var(--space-6);
}

.aud-intro__divider-line {
  display: block;
  width: 60px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--color-primary-light), transparent);
}

.aud-intro__divider-dot {
  color: var(--color-primary);
  font-size: var(--text-sm);
  opacity: 0.6;
}

.sp-only { display: inline; }
@media (min-width: 640px) {
  .sp-only { display: none; }
}

/* ── Section heading EN sub ── */
.page-section__heading-en {
  display: block;
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: var(--tracking-wider);
  color: var(--color-primary);
  text-transform: uppercase;
  margin-bottom: var(--space-2);
}

/* ── Support Cards ── */
.aud-supports__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
  max-width: var(--container-xl);
  margin: 0 auto;
}

@media (min-width: 640px) {
  .aud-supports__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-6);
  }
}

@media (min-width: 1024px) {
  .aud-supports__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.aud-support-card {
  position: relative;
  background: var(--color-surface);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-2xl);
  padding: var(--space-8) var(--space-6) var(--space-6);
  text-align: center;
  transition: transform var(--duration-normal) var(--ease-out),
              box-shadow var(--duration-normal) var(--ease-out);
  overflow: hidden;
}

.aud-support-card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--radius-2xl);
  background: linear-gradient(135deg, rgba(200,160,230,0.04), rgba(232,123,197,0.04));
  opacity: 0;
  transition: opacity var(--duration-normal) var(--ease-out);
}

.aud-support-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md), var(--shadow-glow-primary);
}

.aud-support-card:hover::before {
  opacity: 1;
}

.aud-support-card__number {
  position: absolute;
  top: var(--space-3);
  right: var(--space-4);
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 700;
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  opacity: 0.2;
  line-height: 1;
}

.aud-support-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  border-radius: var(--radius-xl);
  background: var(--color-bg-section);
  color: var(--color-primary);
  margin-bottom: var(--space-4);
  transition: transform var(--duration-normal) var(--ease-out),
              background var(--duration-normal) var(--ease-out);
}

.aud-support-card:hover .aud-support-card__icon {
  transform: scale(1.08);
  background: var(--color-primary-50);
}

.aud-support-card__title {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-text);
  line-height: var(--leading-normal);
  margin-bottom: var(--space-3);
}

.aud-support-card__title-accent {
  color: var(--color-primary-dark);
}

.aud-support-card__desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
}

/* ── Requirements Card ── */
.aud-req-card {
  max-width: 800px;
  margin: 0 auto;
  background: var(--color-surface);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-2xl);
  padding: var(--space-8) var(--space-6);
}

.aud-req-card__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.aud-req-card__item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--text-base);
  color: var(--color-text);
  line-height: var(--leading-normal);
}

.aud-req-card__check {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: var(--radius-full);
  background: var(--color-primary-50);
  color: var(--color-primary);
  margin-top: 1px;
}

.aud-req-card__item strong {
  color: var(--color-primary-dark);
}

.aud-req-card__note {
  margin-top: var(--space-5);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border-light);
  font-size: var(--text-sm);
  color: var(--color-text-light);
  line-height: var(--leading-relaxed);
}

/* ── Application Flow Timeline ── */
.aud-flow__timeline {
  position: relative;
  max-width: 640px;
  margin: 0 auto;
  padding-left: var(--space-10);
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

/* Vertical line */
.aud-flow__timeline::before {
  display: none;
}

.aud-flow-step {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: var(--space-5);
}

.aud-flow-step__number {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-full);
  background: var(--gradient-primary);
  color: #fff;
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 700;
  position: relative;
  z-index: 1;
  box-shadow: 0 2px 8px rgba(200, 160, 230, 0.3);
  /* Offset left to sit on the line */
  margin-left: calc(-1 * var(--space-10));
}

.aud-flow-step__content {
  padding-top: var(--space-1);
}

.aud-flow-step__title {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: var(--space-1);
}

.aud-flow-step__desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
}

/* ── CTA Section ── */
.aud-cta-section {
  position: relative;
  text-align: center;
  background: linear-gradient(160deg, var(--color-bg-section) 0%, #fff5fb 50%, #e8f6f8 100%);
  border-radius: var(--radius-2xl);
  padding: var(--space-16) var(--space-6);
  margin-top: var(--space-8);
  overflow: hidden;
}

.aud-cta-section__orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  pointer-events: none;
}

.aud-cta-section__orb--1 {
  width: 200px;
  height: 200px;
  top: -60px;
  right: -40px;
  background: rgba(200, 160, 230, 0.15);
}

.aud-cta-section__orb--2 {
  width: 160px;
  height: 160px;
  bottom: -40px;
  left: -30px;
  background: rgba(232, 123, 197, 0.12);
}

.aud-cta-section__catch {
  font-family: var(--font-heading);
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: var(--space-3);
  position: relative;
  z-index: 1;
}

.aud-cta-section__sub {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  margin-bottom: var(--space-8);
  position: relative;
  z-index: 1;
}

.aud-cta-section .page-cta {
  position: relative;
  z-index: 1;
}

/* ── Audition Small Mobile ── */
@media (max-width: 479px) {
  .aud-intro {
    margin-bottom: var(--space-8);
  }

  .aud-intro__catch {
    font-size: clamp(1.2rem, 5vw, 1.5rem);
  }

  .aud-intro__sub {
    font-size: var(--text-sm);
  }

  .aud-supports__grid {
    gap: var(--space-3);
  }

  .aud-support-card {
    padding: var(--space-4);
  }

  .aud-support-card__title {
    font-size: var(--text-sm);
  }

  .aud-support-card__desc {
    font-size: var(--text-xs);
  }

  .aud-req-card {
    padding: var(--space-5);
  }

  .aud-flow-step {
    padding: var(--space-4);
  }

  .aud-flow-step__num {
    width: 32px;
    height: 32px;
    font-size: var(--text-sm);
  }

  .aud-flow-step__title {
    font-size: var(--text-base);
  }

  .aud-flow-step__desc {
    font-size: var(--text-xs);
  }

  .aud-cta-section {
    padding: var(--space-10) var(--space-4);
  }

  .aud-cta-section__heading {
    font-size: clamp(1.2rem, 5vw, 1.5rem);
  }
}

/* ── Audition Responsive ── */
@media (min-width: 1024px) {
  .aud-intro {
    margin-bottom: var(--space-20);
  }

  .aud-flow__timeline {
    padding-left: var(--space-16);
    gap: var(--space-10);
  }

  .aud-flow__timeline::before {
    display: none;
  }

  .aud-flow-step__number {
    width: 56px;
    height: 56px;
    margin-left: calc(-1 * var(--space-16));
  }

  .aud-req-card {
    padding: var(--space-10) var(--space-10);
  }

  .aud-cta-section {
    padding: var(--space-20) var(--space-10);
  }
}

/* ── Audition: Reduced Motion ── */
@media (prefers-reduced-motion: reduce) {
  .aud-support-card:hover {
    transform: none;
  }
  .aud-support-card:hover .aud-support-card__icon {
    transform: none;
  }
}

/* ── Audition: LINE CTA Button ── */
.aud-line-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-8);
  background: #06C755;
  color: #fff;
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: 700;
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: all var(--duration-normal) var(--ease-out);
  box-shadow: 0 4px 15px rgba(6, 199, 85, 0.3);
  letter-spacing: 0.03em;
}

.aud-line-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 25px rgba(6, 199, 85, 0.45);
  opacity: 1;
}

.aud-line-btn--large {
  padding: var(--space-4) var(--space-10);
  font-size: clamp(0.85rem, 3.5vw, var(--text-lg));
  min-width: 280px;
}

/* CTA buttons size unification */
.aud-cta-section__buttons .page-cta,
.aud-cta-section__buttons .aud-line-btn--large {
  min-width: 280px;
  padding: var(--space-4) var(--space-10);
  font-size: clamp(0.85rem, 3.5vw, var(--text-lg));
}

.aud-line-btn__icon {
  flex-shrink: 0;
}

/* ── Audition: Mid CTA ── */
.aud-mid-cta {
  text-align: center;
  margin-top: var(--space-8);
}

.aud-mid-cta--wide {
  margin: var(--space-8) 0 var(--space-12);
  padding: var(--space-10) var(--space-6);
  background: linear-gradient(135deg, rgba(6, 199, 85, 0.04) 0%, rgba(200, 160, 230, 0.06) 100%);
  border-radius: var(--radius-2xl);
  border: 1px solid rgba(6, 199, 85, 0.1);
}

.aud-mid-cta__text {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: var(--space-5);
}

/* ── Audition: Compare Table ── */
.aud-compare__table-wrap {
  max-width: 900px;
  margin: 0 auto;
  background: var(--color-surface);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-2xl);
  overflow: hidden;
  overflow-x: auto;
}

.aud-compare__table {
  width: 100%;
  border-collapse: collapse;
  min-width: 500px;
}

.aud-compare__table thead {
  background: var(--color-bg-section);
}

.aud-compare__table th,
.aud-compare__table td {
  padding: var(--space-4) var(--space-5);
  text-align: center;
  border-bottom: 1px solid var(--color-border-light);
  font-size: var(--text-sm);
  vertical-align: middle;
}

.aud-compare__table th:first-child,
.aud-compare__table td:first-child {
  text-align: left;
}

.aud-compare__table thead th {
  font-weight: 700;
  font-size: var(--text-base);
  color: var(--color-text);
  padding: var(--space-4) var(--space-5);
}

.aud-compare__th--linear {
  background: var(--gradient-primary) !important;
  color: #fff !important;
  font-size: var(--text-lg) !important;
}

.aud-compare__label {
  font-weight: 600;
  color: var(--color-text);
  white-space: nowrap;
}

.aud-compare__td--linear {
  color: var(--color-primary-dark);
  font-weight: 700;
  background: rgba(200, 160, 230, 0.04);
}

.aud-compare__table tr:last-child td,
.aud-compare__table tr:last-child th {
  border-bottom: none;
}

.aud-compare__table tbody td:not(:first-child):not(.aud-compare__td--linear) {
  color: var(--color-text-light);
}

/* ── Audition: CTA Section Buttons ── */
.aud-cta-section__buttons {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  position: relative;
  z-index: 1;
}

@media (min-width: 640px) {
  .aud-cta-section__buttons {
    flex-direction: row;
    justify-content: center;
    gap: var(--space-5);
  }
}

/* ── Audition Compare Mobile ── */
@media (max-width: 479px) {
  .aud-compare__table th,
  .aud-compare__table td {
    padding: var(--space-3);
    font-size: var(--text-xs);
  }

  .aud-compare__table thead th {
    font-size: var(--text-sm);
  }

  .aud-compare__th--linear {
    font-size: var(--text-base) !important;
  }

  .aud-line-btn {
    padding: var(--space-3) var(--space-6);
    font-size: var(--text-sm);
  }

  .aud-line-btn--large {
    padding: var(--space-3) var(--space-8);
    font-size: var(--text-base);
  }
}

/* ==========================================================================
   Partner Page — Work Section
   ========================================================================== */

.ptn-work__note {
  text-align: center;
  font-size: var(--text-sm);
  color: var(--color-primary-dark);
  font-weight: 600;
  background: var(--color-primary-50);
  display: block;
  padding: var(--space-2) var(--space-5);
  border-radius: var(--radius-xl);
  margin: var(--space-4) auto 0;
  max-width: max-content;
}

.ptn-work__steps {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-6);
  max-width: 900px;
  margin: var(--space-10) auto 0;
}

@media (min-width: 768px) {
  .ptn-work__steps {
    flex-direction: row;
    align-items: stretch;
    gap: var(--space-5);
  }
}

.ptn-work-step {
  flex: 1;
  position: relative;
  background: var(--color-surface);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-2xl);
  padding: var(--space-8) var(--space-6) var(--space-6);
  text-align: center;
  transition: transform var(--duration-normal) var(--ease-out),
              box-shadow var(--duration-normal) var(--ease-out);
  overflow: hidden;
}

.ptn-work-step::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--radius-2xl);
  background: linear-gradient(135deg, rgba(200,160,230,0.04), rgba(232,123,197,0.04));
  opacity: 0;
  transition: opacity var(--duration-normal) var(--ease-out);
}

.ptn-work-step:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md), var(--shadow-glow-primary);
}

.ptn-work-step:hover::before {
  opacity: 1;
}

.ptn-work-step__badge {
  display: inline-block;
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: var(--tracking-wider);
  color: #fff;
  background: var(--gradient-primary);
  padding: var(--space-1) var(--space-4);
  border-radius: var(--radius-full);
  margin-bottom: var(--space-4);
  position: relative;
  z-index: 1;
}

.ptn-work-step__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 80px;
  height: 80px;
  border-radius: var(--radius-xl);
  background: var(--color-bg-section);
  color: var(--color-primary);
  margin-bottom: var(--space-5);
  position: relative;
  z-index: 1;
  transition: transform var(--duration-normal) var(--ease-out),
              background var(--duration-normal) var(--ease-out);
}

.ptn-work-step:hover .ptn-work-step__icon {
  transform: scale(1.08);
  background: var(--color-primary-50);
}

.ptn-work-step__title {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-text);
  line-height: var(--leading-normal);
  margin-bottom: var(--space-3);
  position: relative;
  z-index: 1;
}

.ptn-work-step__title-accent {
  color: var(--color-primary-dark);
  font-size: var(--text-lg);
}

.ptn-work-step__desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
  position: relative;
  z-index: 1;
}

/* Arrow between steps */
.ptn-work-step__arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary-light);
  flex-shrink: 0;
  /* rotate for vertical on mobile */
  transform: rotate(90deg);
}

@media (min-width: 768px) {
  .ptn-work-step__arrow {
    transform: rotate(0deg);
  }
}

/* Mobile adjustments */
@media (max-width: 479px) {
  .ptn-work-step {
    padding: var(--space-6) var(--space-4) var(--space-4);
  }

  .ptn-work-step__icon {
    width: 64px;
    height: 64px;
  }

  .ptn-work-step__title {
    font-size: var(--text-sm);
  }

  .ptn-work-step__title-accent {
    font-size: var(--text-base);
  }

  .ptn-work-step__desc {
    font-size: var(--text-xs);
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .ptn-work-step:hover {
    transform: none;
  }
  .ptn-work-step:hover .ptn-work-step__icon {
    transform: none;
  }
}

/* ==========================================================================
   About Page
   ========================================================================== */

/* ── Intro ── */
.abt-intro {
  max-width: 1200px;
  margin: 0 auto var(--space-4);
  padding: var(--space-8) var(--space-6);
}

/* 左画像・右テキスト グリッド */
.abt-intro__grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
  align-items: center;
}

/* 画像 */
.abt-intro__visual {
  width: 100%;
}

.abt-intro__visual-img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--radius-xl);
  object-fit: cover;
}

/* テキスト */
.abt-intro__content {
  text-align: left;
}

.abt-intro__catch {
  font-family: var(--font-heading);
  font-size: clamp(1.5rem, 3vw, 2.5rem);
  font-weight: 700;
  color: var(--color-text);
  line-height: var(--leading-tight);
  margin-bottom: var(--space-5);
}

.abt-intro__catch-accent {
  background: var(--gradient-hero);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.abt-intro__sub {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  line-height: var(--leading-loose);
  margin: 0 0 var(--space-6);
}

/* タブレット以上: 左画像・右テキスト横並び */
@media (min-width: 840px) {
  .abt-intro__grid {
    flex-direction: row;
    gap: var(--space-12);
    align-items: center;
  }

  .abt-intro__visual {
    flex: 1;
    min-width: 0;
  }

  .abt-intro__content {
    flex: 1;
    min-width: 0;
  }

  .abt-intro__sub {
    font-size: var(--text-lg);
    line-height: 2;
  }
}

@media (min-width: 1280px) {
  .abt-intro {
    padding: var(--space-12) var(--space-16);
  }

  .abt-intro__grid {
    gap: var(--space-16);
  }

  .abt-intro__sub {
    font-size: var(--text-lg);
  }
}

.abt-intro__divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  margin-top: var(--space-6);
}

.abt-intro__divider-line {
  display: block;
  width: 60px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--color-primary-light), transparent);
}

.abt-intro__divider-dot {
  color: var(--color-primary);
  font-size: var(--text-sm);
  opacity: 0.6;
}

.pc-only { display: none; }
@media (min-width: 1024px) {
  .pc-only { display: inline; }
}

/* ── YouTube Video ── */
.abt-video__wrap {
  position: relative;
  max-width: 800px;
  margin: 0 auto;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  aspect-ratio: 16 / 9;
}

.abt-video__wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: none;
}

/* ── Numbers Grid ── */
.abt-numbers__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-5);
  max-width: 1100px;
  margin: 0 auto;
  overflow: hidden;
}

@media (min-width: 640px) {
  .abt-numbers__grid {
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-6);
  }
}

@media (min-width: 1024px) {
  .abt-numbers__grid {
    gap: var(--space-8);
  }
}

.abt-number-card {
  text-align: center;
  background: var(--color-surface);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-2xl);
  padding: var(--space-8) var(--space-5);
  overflow: hidden;
  min-width: 0;
  transition: transform var(--duration-normal) var(--ease-out),
              box-shadow var(--duration-normal) var(--ease-out);
}

.abt-number-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md), var(--shadow-glow-primary);
}

.abt-number-card__value {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 5vw, 3.5rem);
  font-weight: 800;
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1.1;
  margin-bottom: var(--space-3);
  word-break: keep-all;
}

.abt-number-card__unit {
  font-size: 0.5em;
  font-weight: 700;
}

.abt-number-card__label {
  display: block;
  font-size: var(--text-base);
  color: var(--color-text);
  font-weight: 700;
  margin-bottom: var(--space-2);
}

.abt-number-card__note {
  display: block;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
  opacity: 0.75;
}

/* PC以上のみnowrap */
@media (min-width: 640px) {
  .abt-number-card__label {
    white-space: nowrap;
  }
  .abt-number-card__note {
    white-space: nowrap;
  }
}

.abt-number-card__note--sub {
  margin-top: var(--space-1);
  font-size: 10px;
  opacity: 0.55;
}

/* ── Points / Strengths (3 Grid Cards) ── */
.abt-points__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
  max-width: 1100px;
  margin: var(--space-12) auto 0;
}

@media (min-width: 640px) {
  .abt-points__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .abt-points__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
    margin-top: var(--space-16);
  }
}

.abt-point-card {
  position: relative;
  background: var(--color-surface);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-2xl);
  padding: var(--space-8) var(--space-6) var(--space-6);
  text-align: center;
  transition: transform var(--duration-normal) var(--ease-out),
              box-shadow var(--duration-normal) var(--ease-out);
  overflow: hidden;
}

.abt-point-card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--radius-2xl);
  background: linear-gradient(135deg, rgba(200,160,230,0.04), rgba(232,123,197,0.04));
  opacity: 0;
  transition: opacity var(--duration-normal) var(--ease-out);
}

.abt-point-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md), var(--shadow-glow-primary);
}

.abt-point-card:hover::before {
  opacity: 1;
}

.abt-point-card__number {
  position: absolute;
  top: var(--space-3);
  right: var(--space-4);
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 700;
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  opacity: 0.2;
  line-height: 1;
}

.abt-point-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  border-radius: var(--radius-xl);
  background: var(--color-bg-section);
  color: var(--color-primary);
  margin-bottom: var(--space-4);
  transition: transform var(--duration-normal) var(--ease-out),
              background var(--duration-normal) var(--ease-out);
}

.abt-point-card:hover .abt-point-card__icon {
  transform: scale(1.08);
  background: var(--color-primary-50);
}

.abt-point-card__title {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-text);
  line-height: var(--leading-normal);
  margin-bottom: var(--space-3);
}

.abt-point-card__desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
  text-align: left;
}

/* ── Company Table ── */
.abt-company__table-wrap {
  max-width: 800px;
  margin: 0 auto;
  background: var(--color-surface);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-2xl);
  overflow: hidden;
}

.abt-company__table {
  width: 100%;
  border-collapse: collapse;
}

.abt-company__table th,
.abt-company__table td {
  padding: var(--space-4) var(--space-5);
  text-align: left;
  border-bottom: 1px solid var(--color-border-light);
  font-size: var(--text-base);
  vertical-align: top;
}

.abt-company__table tr:last-child th,
.abt-company__table tr:last-child td {
  border-bottom: none;
}

.abt-company__table th {
  font-weight: 700;
  color: var(--color-text);
  white-space: nowrap;
  width: 30%;
  background: var(--color-bg-section);
}

.abt-company__table td {
  color: var(--color-text-muted);
}

.abt-company__table td a {
  color: var(--color-primary-dark);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.abt-company__table td a:hover {
  color: var(--color-primary);
}

/* ── Voice Section (所属ライバーの声) ── */
.abt-voice__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  max-width: 1000px;
  margin: 0 auto;
}

.abt-voice__card {
  display: flex;
  flex-direction: column;
  background: var(--color-surface);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-2xl);
  padding: var(--space-6);
  transition: transform var(--duration-normal) var(--ease-out),
              box-shadow var(--duration-normal) var(--ease-out);
}

.abt-voice__card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}

.abt-voice__card-header {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

.abt-voice__card-avatar {
  width: 72px;
  height: 72px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  flex-shrink: 0;
  background: linear-gradient(135deg, #f0ecff 0%, #fff5fb 100%);
}

.abt-voice__card-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

.abt-voice__card-name {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-text);
}

.abt-voice__card-question {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-primary-dark);
  margin-bottom: var(--space-3);
  line-height: var(--leading-relaxed);
}

.abt-voice__card-text {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: var(--leading-loose);
}

/* Voice responsive */
@media (min-width: 640px) {
  .abt-voice__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .abt-voice__grid {
    gap: var(--space-8);
  }

  .abt-voice__card {
    padding: var(--space-8);
  }

  .abt-voice__card-avatar {
    width: 88px;
    height: 88px;
  }

  .abt-voice__card-question {
    font-size: var(--text-lg);
  }

  .abt-voice__card-text {
    font-size: var(--text-base);
  }
}

@media (max-width: 479px) {
  .abt-voice__card {
    padding: var(--space-4);
  }

  .abt-voice__card-avatar {
    width: 56px;
    height: 56px;
  }

  .abt-voice__card-name {
    font-size: var(--text-sm);
  }

  .abt-voice__card-question {
    font-size: var(--text-sm);
  }

  .abt-voice__card-text {
    font-size: var(--text-xs);
  }
}

/* ── About CTA Section (reuse audition CTA pattern) ── */
.abt-cta-section {
  position: relative;
  text-align: center;
  background: linear-gradient(160deg, var(--color-bg-section) 0%, #fff5fb 50%, #e8f6f8 100%);
  border-radius: var(--radius-2xl);
  padding: var(--space-16) var(--space-6);
  margin-top: var(--space-8);
  overflow: hidden;
}

.abt-cta-section__orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  pointer-events: none;
}

.abt-cta-section__orb--1 {
  width: 200px;
  height: 200px;
  top: -60px;
  right: -40px;
  background: rgba(200, 160, 230, 0.15);
}

.abt-cta-section__orb--2 {
  width: 160px;
  height: 160px;
  bottom: -40px;
  left: -30px;
  background: rgba(232, 123, 197, 0.12);
}

.abt-cta-section__catch {
  font-family: var(--font-heading);
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: var(--space-3);
  position: relative;
  z-index: 1;
}

.abt-cta-section__sub {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  margin-bottom: var(--space-8);
  position: relative;
  z-index: 1;
}

.abt-cta-section .page-cta {
  position: relative;
  z-index: 1;
}

/* ── SD キャラ装飾（カード外側に配置・ボタン非干渉） ── */
.abt-cta-section {
  /* overflow を visible にしてキャラがカード外にはみ出して見えるように */
  overflow: visible;
}

.abt-cta-section__char {
  position: absolute;
  z-index: 2;
  pointer-events: none;
  width: clamp(80px, 11vw, 130px);
}

.abt-cta-section__char img {
  width: 100%;
  height: auto;
  display: block;
  filter: drop-shadow(0 6px 14px rgba(37, 99, 235, 0.18));
}

/* 左: カード上端の左外側から少しだけ覗き込む */
.abt-cta-section__char--left {
  top: -36px;
  left: 12px;
  transform: scaleX(-1);
  animation: abtCtaCharFloatLeft 4.5s ease-in-out infinite;
}

/* 右: カード上端の右外側から少しだけ覗き込む */
.abt-cta-section__char--right {
  top: -36px;
  right: 12px;
  animation: abtCtaCharFloat 4.5s ease-in-out infinite 0.5s;
}

@keyframes abtCtaCharFloat {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}

@keyframes abtCtaCharFloatLeft {
  0%, 100% { transform: scaleX(-1) translateY(0); }
  50%      { transform: scaleX(-1) translateY(-6px); }
}

/* スマホ: SD キャラは非表示（カードが狭くて文字と必ず干渉するため） */
@media (max-width: 840px) {
  .abt-cta-section__char--left,
  .abt-cta-section__char--right {
    display: none;
  }
}

/* ── About Page Small Mobile ── */
@media (max-width: 479px) {
  .abt-intro {
    margin-bottom: var(--space-2);
  }

  .abt-intro__catch {
    font-size: clamp(1.2rem, 5vw, 1.5rem);
  }

  .abt-numbers__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-3);
  }

  .abt-number-card {
    padding: var(--space-4) var(--space-3);
  }

  .abt-number-card__value {
    font-size: 1.5rem;
  }

  .abt-number-card__label {
    font-size: var(--text-xs);
    white-space: normal;
  }

  .abt-number-card__note {
    white-space: normal;
    font-size: 0.7rem;
  }

  .abt-point-card {
    padding: var(--space-5) var(--space-4) var(--space-4);
  }

  .abt-point-card__icon {
    width: 56px;
    height: 56px;
  }

  .abt-point-card__icon svg {
    width: 22px;
    height: 22px;
  }

  .abt-point-card__title {
    font-size: var(--text-sm);
  }

  .abt-point-card__desc {
    font-size: var(--text-xs);
  }

  .abt-company__table th,
  .abt-company__table td {
    padding: var(--space-3);
    font-size: var(--text-sm);
  }

  .abt-cta-section {
    padding: var(--space-10) var(--space-4);
  }
}

/* ── About Responsive ── */
@media (min-width: 1024px) {
  .abt-intro {
    margin-bottom: var(--space-6);
  }

  .abt-point-card__title {
    font-size: var(--text-lg);
  }

  .abt-cta-section {
    padding: var(--space-20) var(--space-10);
  }
}

/* ── About: Reduced Motion ── */
@media (prefers-reduced-motion: reduce) {
  .abt-number-card:hover {
    transform: none;
  }
}


/* ==========================================================================
   Talent Archive — Rich Design
   ========================================================================== */

/* ── Archive Section ── */
.talent-archive {
  position: relative;
  background: var(--color-bg);
  padding: var(--space-10) 0 var(--space-16);
  min-height: 60vh;
}

.talent-archive__container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 var(--space-6);
}

/* ── Filter Tabs ── */
.talent-tabs {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-2);
  margin-bottom: var(--space-10);
}

.talent-tabs__btn {
  padding: var(--space-2) var(--space-5);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text-light);
  background: transparent;
  border: 1.5px solid var(--color-border-light);
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: all 0.25s var(--ease-out);
}

.talent-tabs__btn:hover {
  color: var(--color-primary-dark);
  border-color: var(--color-primary-light);
  background: var(--color-primary-50, #f5eeff);
}

.talent-tabs__btn.is-active {
  color: #fff;
  background: var(--gradient-primary);
  border-color: transparent;
  box-shadow: 0 2px 12px rgba(200, 160, 230, 0.3);
}

/* Reset Button */
.talent-tabs__btn--reset {
  color: var(--color-text-muted);
  background: var(--color-bg-section);
  border-color: var(--color-text-muted);
  font-size: var(--text-xs);
}
.talent-tabs__btn--reset:hover {
  color: #fff;
  background: #999;
  border-color: #999;
}

/* Sort Button */
.talent-sort-btn {
  margin-left: var(--space-2);
  border-style: dashed !important;
}

.talent-sort-btn__arrow {
  font-size: 10px;
  margin-left: 2px;
  display: inline-block;
  transition: transform 0.2s;
}

.talent-sort-btn.is-desc .talent-sort-btn__arrow {
  transform: rotate(180deg);
}

/* ── Grid ── */
/* Small Mobile talent grid */
@media (max-width: 479px) {
  .talent-archive .talent-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4) var(--space-3);
  }

  .talent-card__name {
    font-size: var(--text-base);
  }

  .talent-card__name-en {
    font-size: 10px;
  }

  .talent-card__info {
    padding: var(--space-2) 0;
  }

  .talent-card__badge {
    font-size: 10px;
    padding: 2px 6px;
  }

  .talent-card__raynel {
    width: 26px;
    height: 26px;
    top: 6px;
    left: 6px;
    padding: 2px;
  }
}

.talent-archive .talent-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-6) var(--space-4);
  align-items: start;
}

.talent-archive .talent-grid .talent-card {
  width: 100%;
  min-width: 0;
  overflow: hidden;
}

/* ── Talent Card (cozopro style) ── */
.talent-card {
  display: block;
  text-decoration: none;
  transition: all 0.35s var(--ease-out);
  position: relative;
}

.talent-card:hover {
  transform: translateY(-4px);
}

.talent-card__visual {
  position: relative;
  width: 100%;
  padding-top: 100%; /* 1:1 aspect ratio */
  overflow: hidden;
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-3);
  background: #f8f6fa;
}

.talent-card__img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  transition: transform 0.5s var(--ease-out);
}

.talent-card__img--empty {
  background-color: #eee;
}

.talent-card:hover .talent-card__img {
  transform: scale(1.04);
}

.talent-card__badge {
  position: absolute;
  top: var(--space-2);
  right: var(--space-2);
  padding: 3px 10px;
  font-size: 0.65rem;
  font-weight: 700;
  color: #fff;
  background: var(--gradient-primary);
  border-radius: var(--radius-full);
  letter-spacing: 0.05em;
  z-index: 2;
}

.talent-card__shine {
  display: none;
}

.talent-card__info {
  text-align: left;
}

.talent-card__name {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-text);
  margin: 0 0 2px;
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.talent-card__name-en {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--color-primary);
  letter-spacing: 0.04em;
  margin: 0;
  text-transform: capitalize;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.talent-card__platform {
  display: none;
}

/* ── Tags (期生 / Platform) ── */
.talent-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

.talent-card__tag {
  display: inline-block;
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 4px;
  line-height: 1.4;
  letter-spacing: 0.02em;
}

.talent-card__tag--platform {
  background: transparent;
  border: 1.5px solid var(--color-primary);
  color: var(--color-primary);
}

.talent-card__tag--gen {
  background: linear-gradient(135deg, #e8607c, #f06292);
  color: #fff;
  border: none;
}

.talent-card__tag--unit {
  background: linear-gradient(135deg, #7c4dff, #b388ff);
  color: #fff;
  border: none;
}

/* ── Unit Group ── */
.talent-unit-group {
  margin-bottom: var(--space-12);
}

.talent-unit-group__title {
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-primary);
  display: inline-block;
}

.talent-units .anim-fade-up {
  opacity: 1 !important;
  transform: none !important;
}

/* ── Contact LINE CTA ── */
.contact-line-cta {
  text-align: center;
  margin-bottom: var(--space-8);
  padding: var(--space-6);
  background: rgba(6, 199, 85, 0.05);
  border-radius: var(--radius-xl);
  border: 1px solid rgba(6, 199, 85, 0.15);
}

.contact-line-cta__text {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  margin-bottom: var(--space-4);
}

/* ── Gender Hover Colors ── */
.talent-card[data-gender="female"]:hover .talent-card__visual {
  box-shadow: 0 8px 30px rgba(255, 105, 180, 0.3);
}
.talent-card[data-gender="female"]:hover .talent-card__visual::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255, 105, 180, 0.12);
  border-radius: var(--radius-lg);
  z-index: 1;
  pointer-events: none;
}

.talent-card[data-gender="male"]:hover .talent-card__visual {
  box-shadow: 0 8px 30px rgba(100, 180, 255, 0.3);
}
.talent-card[data-gender="male"]:hover .talent-card__visual::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(100, 180, 255, 0.12);
  border-radius: var(--radius-lg);
  z-index: 1;
  pointer-events: none;
}

.talent-card[data-gender="neutral"]:hover .talent-card__visual {
  box-shadow: 0 8px 30px rgba(155, 111, 204, 0.3);
}
.talent-card[data-gender="neutral"]:hover .talent-card__visual::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(155, 111, 204, 0.12);
  border-radius: var(--radius-lg);
  z-index: 1;
  pointer-events: none;
}

/* ── Empty State ── */
.talent-empty {
  text-align: center;
  padding: var(--space-16);
  color: var(--color-text-light);
  font-size: var(--text-lg);
}

/* ── Responsive ── */
@media (min-width: 480px) {
  .talent-archive .talent-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-8) var(--space-5);
  }

  .talent-card__name {
    font-size: var(--text-xl);
  }

  .talent-card__name-en {
    font-size: var(--text-sm);
  }
}

@media (min-width: 840px) {
  .talent-archive .talent-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-10) var(--space-6);
  }

  .talent-card__name {
    font-size: var(--text-xl);
  }
}

@media (min-width: 1280px) {
  .talent-archive .talent-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-12) var(--space-8);
  }

  .talent-card__name {
    font-size: var(--text-2xl, 1.5rem);
  }

  .talent-card__name-en {
    font-size: var(--text-base);
  }
}

@media (prefers-reduced-motion: reduce) {
  .talent-card:hover { transform: none; }
  .talent-card:hover .talent-card__img { transform: none; }
}

/* ==========================================================================
   Share Buttons
   ========================================================================== */
.share-buttons {
  margin-top: var(--space-8, 2rem);
  padding-top: var(--space-6, 1.5rem);
  border-top: 1px solid var(--color-border-light, rgba(255,255,255,0.1));
}

.share-buttons__label {
  display: block;
  font-family: var(--font-en);
  font-size: var(--text-xs, 0.75rem);
  letter-spacing: 0.1em;
  color: var(--color-text-muted, #888);
  margin-bottom: var(--space-3, 0.75rem);
}

.share-buttons__list {
  display: flex;
  gap: var(--space-3, 0.75rem);
}

.share-buttons__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  padding: 0.5em 1.2em;
  font-size: var(--text-sm, 0.875rem);
  font-family: var(--font-en);
  border: 1px solid var(--color-border-light, rgba(255,255,255,0.2));
  background: transparent;
  color: var(--color-text, #fff);
  text-decoration: none;
  cursor: pointer;
  transition: background 0.3s, border-color 0.3s;
}

.share-buttons__btn:hover {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.4);
}

.share-buttons__btn--line {
  background: #06C755;
  border-color: #06C755;
  color: #fff;
  font-weight: 700;
}

.share-buttons__btn--line:hover {
  background: #05b04c;
}

.share-buttons__btn--copy.copied {
  border-color: #06C755;
  color: #06C755;
}

/* ============================================================
   FOUNDER MESSAGE - Aboutページ専用
   ============================================================ */
.abt-founder {
  position: relative;
  padding: var(--space-16) 0;
  background: linear-gradient(180deg, var(--color-bg-section) 0%, var(--color-bg) 100%);
}

.abt-founder__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--space-6);
}

.abt-founder__grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
  align-items: center;
}

.abt-founder__visual {
  width: 100%;
  max-width: 320px;
  display: flex;
  justify-content: center;
  flex-shrink: 0;
}

.abt-founder__visual-img {
  width: 100%;
  height: auto;
  display: block;
  filter: drop-shadow(0 12px 30px rgba(37, 99, 235, 0.15));
}

/* スマホでアバターをコンパクトに */
@media (max-width: 640px) {
  .abt-founder__visual {
    max-width: 240px;
  }
}

@media (max-width: 479px) {
  .abt-founder__visual {
    max-width: 200px;
  }
}

.abt-founder__content {
  text-align: left;
  width: 100%;
}

.abt-founder__label {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  letter-spacing: var(--tracking-wider);
  font-weight: 600;
  color: var(--color-primary);
  text-transform: uppercase;
  margin: 0 0 var(--space-3);
}

.abt-founder__catch {
  font-family: var(--font-heading);
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: 700;
  color: var(--color-text);
  line-height: var(--leading-tight);
  margin: 0 0 var(--space-6);
}

.abt-founder__text p {
  font-size: var(--text-base);
  color: var(--color-text);
  line-height: var(--leading-loose);
  margin: 0 0 var(--space-4);
}

.abt-founder__text p:last-child {
  margin-bottom: 0;
}

.abt-founder__signature {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  letter-spacing: var(--tracking-wide);
  margin: var(--space-8) 0 0;
}

/* タブレット以上: 左画像・右テキスト */
@media (min-width: 840px) {
  .abt-founder__grid {
    flex-direction: row;
    gap: var(--space-12);
    align-items: center;
  }

  .abt-founder__visual {
    flex: 0 0 38%;
    max-width: 460px;
  }

  .abt-founder__content {
    flex: 1;
    min-width: 0;
  }

  .abt-founder__text p {
    font-size: var(--text-lg);
    line-height: 2;
  }
}

@media (min-width: 1280px) {
  .abt-founder {
    padding: var(--space-20) 0;
  }
}

/* ============================================================
   MEMBERS V2 - 縦長カードグリッド (front-page)
   ============================================================ */
.section--members-v2 {
  position: relative;
  padding: var(--space-20) 0;
  background-color: #f3f8fd;
  background-image: radial-gradient(circle, rgba(93, 160, 232, 0.20) 1.5px, transparent 1.5px);
  background-size: 22px 22px;
  background-position: 0 0;
  overflow: hidden;
}

.members-v2__container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--space-6);
}

.members-v2__header {
  margin-bottom: var(--space-10);
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.members-v2__heading {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 5vw, 4rem);
  font-weight: 800;
  color: var(--color-primary);
  letter-spacing: 0.04em;
  margin: 0;
  line-height: 1;
  position: relative;
  padding-left: var(--space-3);
}

.members-v2__heading::before {
  content: '';
  position: absolute;
  left: 0;
  top: 10%;
  bottom: 10%;
  width: 4px;
  background: var(--color-primary);
}

.members-v2__sub {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  margin: 0;
  font-weight: 500;
}

.members-v2__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--space-5);
}

@media (min-width: 768px) {
  .members-v2__grid {
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: var(--space-6);
  }
}

.member-card {
  position: relative;
  display: block;
  aspect-ratio: 3 / 4.2;
  overflow: hidden;
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, #d8e7f6 0%, #b0cee9 100%);
  text-decoration: none;
  color: inherit;
  box-shadow: var(--shadow-md);
  transition: transform var(--duration-normal) var(--ease-out),
              box-shadow var(--duration-normal) var(--ease-out);
}

.member-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.member-card__visual {
  position: relative;
  width: 100%;
  height: 100%;
}

.member-card__img {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 105%;
  height: 100%;
  object-fit: contain;
  object-position: bottom center;
  pointer-events: none;
}

.member-card__logo {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 90px;
  height: auto;
  z-index: 2;
  opacity: 0.95;
  pointer-events: none;
}

.member-card__info {
  position: absolute;
  bottom: 16px;
  left: 18px;
  right: 18px;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.member-card__name-en {
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: 800;
  line-height: 1;
  color: white;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.4);
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.member-card__name-ja {
  font-size: var(--text-sm);
  color: rgba(255, 255, 255, 0.95);
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.35);
  font-weight: 500;
}

.members-v2__action {
  margin-top: var(--space-12);
  text-align: center;
}

.members-v2__btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-8);
  background: white;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  color: var(--color-text);
  text-decoration: none;
  font-size: var(--text-base);
  font-weight: 500;
  box-shadow: var(--shadow-sm);
  transition: all var(--duration-normal) var(--ease-out);
}

.members-v2__btn:hover {
  background: var(--color-primary);
  color: white;
  border-color: var(--color-primary);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

/* Founder バッジ (member-card 1枚目) */
.member-card__badge {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 3;
  padding: 4px 10px;
  background: linear-gradient(135deg, var(--color-primary-dark), var(--color-primary));
  color: #fff;
  font-family: var(--font-display);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  border-radius: var(--radius-full);
  box-shadow: 0 2px 8px rgba(37, 99, 235, 0.35);
  text-transform: uppercase;
  pointer-events: none;
}

.member-card--founder {
  position: relative;
}

.member-card--founder::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--radius-lg);
  border: 2px solid rgba(255, 255, 255, 0.6);
  pointer-events: none;
  z-index: 1;
}

/* Founder 独立表示行（grid 1列分の幅・横は空白） */
.members-v2__featured {
  margin-bottom: var(--space-10);
  display: grid;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: var(--space-6);
}

.members-v2__featured .member-card {
  width: 100%;
  grid-column: 1 / 2; /* 1列目だけ占有・横2-3列は空白 */
}

/* MEMBER グリッドを3列固定（PC）→ レスポンシブで2列 / 1列 */
.members-v2__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: var(--space-6);
}

@media (max-width: 900px) {
  .members-v2__featured,
  .members-v2__grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 520px) {
  .members-v2__featured,
  .members-v2__grid {
    grid-template-columns: 1fr !important;
  }
}

/* ============================================================
   STICKY CTA - ENTRY カプセル型ボタン (footer.php)
   ============================================================ */

/* 既存の sticky-cta スタイルを完全リセット */
.sticky-cta {
  position: fixed !important;
  right: 24px;
  bottom: 24px;
  z-index: 200;
  display: flex;
  align-items: center;
  width: 290px;
  height: 92px;
  padding: 0 110px 0 26px;
  border-radius: 18px;
  background: transparent;
  text-decoration: none;
  overflow: visible;
  box-shadow:
    0 14px 36px rgba(37, 99, 235, 0.38),
    0 4px 12px rgba(0, 0, 0, 0.18);
  transition: transform 0.35s var(--ease-out), box-shadow 0.35s var(--ease-out);
}

.sticky-cta::before,
.sticky-cta__ring,
.sticky-cta__glow,
.sticky-cta__inner,
.sticky-cta__link {
  display: none !important;
}

.sticky-cta:hover {
  transform: translateY(-4px) scale(1.02);
  box-shadow:
    0 22px 46px rgba(37, 99, 235, 0.52),
    0 6px 18px rgba(0, 0, 0, 0.22);
}

/* 背景（紫→ブルー→シアンのグラデーション） */
.sticky-cta__bg {
  position: absolute;
  inset: 0;
  border-radius: 18px;
  background: linear-gradient(115deg, #7c6cd6 0%, #5DA0E8 45%, #67d8f0 100%);
  overflow: hidden;
}

.sticky-cta__bg::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(255,255,255,0.18) 1px, transparent 1.5px);
  background-size: 12px 12px;
  opacity: 0.6;
}

.sticky-cta__bg::after {
  content: '';
  position: absolute;
  top: 0;
  left: -50%;
  width: 60%;
  height: 100%;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,0.4) 50%, transparent 70%);
  animation: ctaShine 4s ease-in-out infinite;
}

@keyframes ctaShine {
  0%, 100% { transform: translateX(-100%); }
  50%      { transform: translateX(280%);  }
}

/* テキストブロック */
.sticky-cta__text {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.sticky-cta__title {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 800;
  color: #ffffff;
  letter-spacing: 0.05em;
  line-height: 0.95;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.28);
}

.sticky-cta__sub {
  font-size: 11px;
  color: #ffffff;
  font-weight: 600;
  letter-spacing: 0.08em;
  white-space: nowrap;
  opacity: 0.96;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
}

/* キャラクター画像（右側にはみ出し配置） */
.sticky-cta__char {
  position: absolute;
  right: -8px;
  bottom: 0;
  width: 130px;
  height: 130%;
  z-index: 3;
  pointer-events: none;
  overflow: visible;
}

.sticky-cta__char-img {
  position: absolute;
  right: 0;
  bottom: -8px;
  height: 100%;
  width: auto;
  object-fit: contain;
  object-position: right bottom;
  pointer-events: none;
  filter: drop-shadow(0 6px 12px rgba(37, 99, 235, 0.35));
}

/* キラキラ装飾 */
.sticky-cta__sparkle {
  position: absolute;
  background: radial-gradient(circle, #fff 0%, rgba(255,255,255,0.6) 50%, transparent 100%);
  border-radius: 50%;
  z-index: 4;
  pointer-events: none;
  box-shadow: 0 0 8px rgba(255,255,255,0.8);
  animation: ctaSparkle 2.5s ease-in-out infinite;
}

.sticky-cta__sparkle--1 { top: 14px; right: 86px; width: 8px;  height: 8px;  animation-delay: 0s; }
.sticky-cta__sparkle--2 { top: 50px; right: 60px; width: 5px;  height: 5px;  animation-delay: 0.8s; }
.sticky-cta__sparkle--3 { top: 22px; right: 36px; width: 6px;  height: 6px;  animation-delay: 1.6s; }

@keyframes ctaSparkle {
  0%, 100% { transform: scale(0.6); opacity: 0; }
  50%      { transform: scale(1.2); opacity: 1; }
}

/* SP（スマホ） */
@media (max-width: 640px) {
  .sticky-cta {
    right: 12px;
    bottom: 12px;
    width: 240px;
    height: 76px;
    padding: 0 88px 0 18px;
    border-radius: 14px;
  }
  .sticky-cta__bg { border-radius: 14px; }
  .sticky-cta__title { font-size: 26px; }
  .sticky-cta__sub   { font-size: 10px; }
  .sticky-cta__char  { width: 100px; }
}

/* ============================================================
   AUDITION FORM - 応募フォーム (page-audition-form.php)
   ============================================================ */
.audform {
  padding: var(--space-12) 0 var(--space-20);
  background: linear-gradient(180deg, var(--color-bg) 0%, #ffffff 100%);
}

.audform__inner {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 var(--space-6);
}

.audform__intro {
  margin: 0 0 var(--space-6);
  padding: var(--space-3) var(--space-5);
  background: var(--color-primary-50);
  border: 1px solid rgba(37, 99, 235, 0.12);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--color-text);
  text-align: center;
  /* CF7 wpautop が冒頭に挿入する <br> を非表示にして上下中央に */
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
}

.audform__intro > br {
  display: none;
}

.audform__intro-note {
  display: block;
  margin-top: var(--space-2);
  font-size: 12px;
  color: var(--color-text-muted);
}

.audform__intro em {
  color: #e11d48;
  font-style: normal;
  font-weight: 700;
}

.audform__form {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

/* ============================================================
   AUDITION FORM (audform) fieldset/legend
   audform 側のみ白カード + legend 中タイトル化
   contact-simple は元々の下線フィールドデザインのため適用しない
   ============================================================ */
.audform__group,
.audform fieldset {
  display: flex !important;
  flex-direction: column;
  margin: 0;
  padding: var(--space-7) var(--space-6) !important;
  border: 0 !important;
  border-radius: var(--radius-lg);
  background: #ffffff;
  box-shadow: 0 2px 12px rgba(37, 99, 235, 0.08);
  min-inline-size: auto;
  min-width: 0;
}

/* CF7 が hidden input を入れる不可視 fieldset を白カードとして表示させない */
.audform fieldset.hidden-fields-container,
.audform fieldset:not(:has(input:not([type="hidden"]), textarea, select, .audform__field, .audform__radios, .audform__checkboxes)) {
  display: none !important;
}
/* 念のため、空の グループ / 段落も隠す */
.audform__group:empty,
.audform p:empty {
  display: none !important;
}
/* legend だけのfieldset対策 */
.audform fieldset > legend:only-child {
  display: none;
}

.audform__legend,
.audform fieldset > legend {
  display: block !important;
  float: none !important;
  width: 100% !important;
  max-width: 100%;
  margin: 0 0 var(--space-6) !important;
  padding: 0 0 0 var(--space-4) !important;
  border: 0 !important;
  background: transparent !important;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.5;
  letter-spacing: 0.02em;
  position: relative;
  inset-inline-start: auto;
  order: -1;
}

/* 見出しの左に縦のブルーアクセント */
.audform__legend::before,
.audform fieldset > legend::before {
  content: '';
  position: absolute;
  left: 0;
  top: 4px;
  bottom: 4px;
  width: 4px;
  border-radius: 2px;
  background: linear-gradient(180deg, var(--color-primary), var(--color-accent-cyan));
}

/* contact-simple 内に万一 fieldset がある場合は装飾を完全リセット */
.contact-simple fieldset {
  border: 0;
  padding: 0;
  margin: 0;
  background: transparent;
  box-shadow: none;
  min-inline-size: auto;
  min-width: 0;
}

.contact-simple fieldset > legend {
  display: none;
}

/* 見出しの左に縦のブルーアクセント */
.audform__legend::before {
  content: '';
  position: absolute;
  left: 0;
  top: 4px;
  bottom: 4px;
  width: 4px;
  border-radius: 2px;
  background: linear-gradient(180deg, var(--color-primary), var(--color-accent-cyan));
}

.audform__note {
  margin: 0 0 var(--space-4);
  padding: var(--space-3) var(--space-4);
  background: #f1f5f9;
  border-radius: var(--radius-sm);
  font-size: 12px;
  line-height: var(--leading-relaxed);
  color: var(--color-text-muted);
}

.audform__field {
  margin-bottom: var(--space-4);
}

.audform__field:last-child {
  margin-bottom: 0;
}

.audform__field-row {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

@media (max-width: 600px) {
  .audform__field-row {
    grid-template-columns: 1fr;
  }
}

.audform__label {
  display: block;
  margin: 0 0 6px;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
}

.audform__required {
  color: #e11d48;
  font-weight: 700;
  margin-left: 4px;
}

.audform__input,
.audform__textarea {
  width: 100%;
  padding: 10px 14px;
  font-size: var(--text-base);
  font-family: inherit;
  color: var(--color-text);
  background: #f8fafc;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
}

.audform__input:focus,
.audform__textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  background: #ffffff;
  box-shadow: 0 0 0 3px rgba(93, 160, 232, 0.18);
}

.audform__textarea {
  resize: vertical;
  min-height: 100px;
  line-height: var(--leading-relaxed);
}

.audform__radios {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.audform__radios--grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--space-2);
}

.audform__radio {
  position: relative;
  display: inline-flex;
  align-items: center;
  padding: 8px 14px;
  background: #f8fafc;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  cursor: pointer;
  font-size: var(--text-sm);
  color: var(--color-text);
  transition: all 0.2s;
}

.audform__radio:hover {
  border-color: var(--color-primary-light);
  background: var(--color-primary-50);
}

.audform__radio input[type="radio"] {
  width: 16px;
  height: 16px;
  margin-right: 8px;
  accent-color: var(--color-primary);
}

.audform__radio:has(input[type="radio"]:checked) {
  background: var(--color-primary);
  color: #ffffff;
  border-color: var(--color-primary);
  font-weight: 600;
}

.audform__file {
  display: block;
  width: 100%;
  padding: 10px;
  font-size: var(--text-sm);
  background: #f8fafc;
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-md);
  cursor: pointer;
}

.audform__file::file-selector-button {
  margin-right: 12px;
  padding: 6px 14px;
  font-size: var(--text-sm);
  background: var(--color-primary);
  color: white;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background 0.2s;
}

.audform__file::file-selector-button:hover {
  background: var(--color-primary-dark);
}

.audform__group--submit {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
  background: var(--color-primary-50);
  border-color: var(--color-primary-200);
}

.audform__check {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: var(--text-sm);
  color: var(--color-text);
  cursor: pointer;
}

.audform__check input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--color-primary);
}

.audform__check a {
  color: var(--color-primary);
  text-decoration: underline;
}

.audform__submit {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 56px;
  font-size: var(--text-lg);
  font-weight: 700;
  color: #ffffff;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent-cyan) 100%);
  border: none;
  border-radius: var(--radius-full);
  cursor: pointer;
  box-shadow: 0 8px 20px rgba(37, 99, 235, 0.32);
  transition: transform 0.25s var(--ease-out), box-shadow 0.25s var(--ease-out);
}

.audform__submit:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(37, 99, 235, 0.42);
}

.audform__submit-note {
  margin: 0;
  font-size: 11px;
  color: var(--color-text-muted);
  text-align: center;
}

/* ============================================================
   AUDITION FORM - CF7 出力構造への追加調整
   ============================================================ */
.audform .wpcf7-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

/* CF7 のラジオ・チェックボックスのリスト構造 */
.audform .wpcf7-list-item {
  display: inline-flex;
  margin: 0;
}

.audform .wpcf7-list-item label {
  display: inline-flex;
  align-items: center;
  padding: 8px 14px;
  background: #f8fafc;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  cursor: pointer;
  font-size: var(--text-sm);
  color: var(--color-text);
  transition: all 0.2s;
  margin: 0;
}

.audform .wpcf7-list-item label:hover {
  border-color: var(--color-primary-light);
  background: var(--color-primary-50);
}

.audform .wpcf7-list-item input[type="radio"],
.audform .wpcf7-list-item input[type="checkbox"] {
  width: 16px;
  height: 16px;
  margin-right: 8px;
  accent-color: var(--color-primary);
}

.audform .wpcf7-list-item label:has(input[type="radio"]:checked),
.audform .wpcf7-list-item label:has(input[type="checkbox"]:checked) {
  background: var(--color-primary);
  color: #ffffff;
  border-color: var(--color-primary);
  font-weight: 600;
}

.audform .wpcf7-list-item-label {
  margin-left: 0;
}

/* CF7 の radio コンテナ */
.audform .wpcf7-radio,
.audform .wpcf7-checkbox {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.audform .wpcf7-radio.audform__radios--grid,
.audform .wpcf7-checkbox.audform__radios--grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--space-2);
}

/* CF7 の acceptance（プライバシーポリシー同意）構造調整 */
.audform .wpcf7-acceptance .wpcf7-list-item {
  display: inline-flex;
  margin: 0;
}

.audform .wpcf7-acceptance .wpcf7-list-item label {
  background: transparent;
  border: none;
  padding: 0;
  border-radius: 0;
  font-weight: 400;
}

.audform .wpcf7-acceptance .wpcf7-list-item label:hover,
.audform .wpcf7-acceptance .wpcf7-list-item label:has(input:checked) {
  background: transparent;
  color: var(--color-text);
  border: none;
}

/* CF7 のファイル入力 */
.audform .wpcf7-file {
  width: 100%;
  padding: 10px;
  font-size: var(--text-sm);
  background: #f8fafc;
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-md);
  cursor: pointer;
}

/* CF7 の送信ボタン */
.audform .wpcf7-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 56px;
  font-size: var(--text-lg);
  font-weight: 700;
  color: #ffffff;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent-cyan) 100%);
  border: none;
  border-radius: var(--radius-full);
  cursor: pointer;
  box-shadow: 0 8px 20px rgba(37, 99, 235, 0.32);
  transition: transform 0.25s var(--ease-out), box-shadow 0.25s var(--ease-out);
}

.audform .wpcf7-submit:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(37, 99, 235, 0.42);
}

.audform .wpcf7-spinner {
  margin-left: var(--space-3);
}

/* CF7 のバリデーションメッセージ */
.audform .wpcf7-not-valid-tip {
  display: block;
  margin-top: 6px;
  font-size: 12px;
  color: #e11d48;
}

.audform .wpcf7-response-output {
  margin: var(--space-6) 0 0;
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border-width: 1px;
  border-style: solid;
  font-size: var(--text-sm);
}

.audform form.invalid .wpcf7-response-output,
.audform form.unaccepted .wpcf7-response-output,
.audform form.payment-required .wpcf7-response-output {
  background: #fef2f2;
  border-color: #fecaca;
  color: #b91c1c;
}

.audform form.sent .wpcf7-response-output {
  background: #f0f9ff;
  border-color: var(--color-primary-200);
  color: var(--color-primary-dark);
}

/* number 入力（CF7） */
.audform .wpcf7-number {
  composes: audform__input;
}

/* CF7 input/textarea の上書き */
.audform .wpcf7-form input[type="text"],
.audform .wpcf7-form input[type="email"],
.audform .wpcf7-form input[type="number"],
.audform .wpcf7-form input[type="url"],
.audform .wpcf7-form textarea {
  width: 100%;
  padding: 10px 14px;
  font-size: var(--text-base);
  font-family: inherit;
  color: var(--color-text);
  background: #f8fafc;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
}

.audform .wpcf7-form input[type="text"]:focus,
.audform .wpcf7-form input[type="email"]:focus,
.audform .wpcf7-form input[type="number"]:focus,
.audform .wpcf7-form input[type="url"]:focus,
.audform .wpcf7-form textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  background: #ffffff;
  box-shadow: 0 0 0 3px rgba(93, 160, 232, 0.18);
}

.audform .wpcf7-form textarea {
  resize: vertical;
  min-height: 100px;
  line-height: var(--leading-relaxed);
}

/* ============================================================
   COMING SOON - LIVE STREAMS セクション一時表示
   ============================================================ */
.section--coming-soon {
  position: relative;
  padding: var(--space-24) 0;
  background: linear-gradient(180deg, #f8fafc 0%, #eff6ff 50%, #f8fafc 100%);
  overflow: hidden;
}

.coming-soon__inner {
  position: relative;
  z-index: 2;
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
  padding: 0 var(--space-6);
}

.coming-soon__label {
  margin: 0 0 var(--space-4);
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.3em;
  color: var(--color-primary);
  text-transform: uppercase;
}

.coming-soon__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  margin: 0 0 var(--space-5);
  font-family: var(--font-display);
  font-weight: 800;
  line-height: 0.95;
  letter-spacing: 0.04em;
}

.coming-soon__title-main {
  font-size: clamp(3rem, 8vw, 5.5rem);
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 50%, var(--color-accent-cyan) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

.coming-soon__title-accent {
  font-size: clamp(3rem, 8vw, 5.5rem);
  color: var(--color-primary-dark);
  position: relative;
}

.coming-soon__title-accent::after {
  content: '...';
  position: absolute;
  right: -1.2ch;
  bottom: 0;
  color: var(--color-accent-cyan);
  animation: cs-dots 1.6s ease-in-out infinite;
}

@keyframes cs-dots {
  0%, 20%   { opacity: 0; transform: translateY(8px); }
  50%       { opacity: 1; transform: translateY(0); }
  100%      { opacity: 0; transform: translateY(8px); }
}

.coming-soon__sub {
  margin: 0 0 var(--space-8);
  font-size: var(--text-base);
  color: var(--color-text-muted);
  font-weight: 500;
}

.coming-soon__divider {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin: 0 0 var(--space-8);
}

.coming-soon__divider span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-primary-200);
  animation: cs-dot-pulse 2s ease-in-out infinite;
}

.coming-soon__divider span:nth-child(2) { animation-delay: 0.3s; }
.coming-soon__divider span:nth-child(3) { animation-delay: 0.6s; }

@keyframes cs-dot-pulse {
  0%, 100% { transform: scale(0.7); opacity: 0.5; }
  50%      { transform: scale(1.2); opacity: 1; background: var(--color-primary); }
}

.coming-soon__desc {
  margin: 0 0 var(--space-10);
  font-size: var(--text-base);
  line-height: var(--leading-loose);
  color: var(--color-text);
}

.coming-soon__cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 40px;
  font-size: var(--text-base);
  font-weight: 700;
  color: white;
  background: linear-gradient(135deg, #5DA0E8 0%, #67D8F0 100%);
  border-radius: 9999px;
  text-decoration: none;
  box-shadow: 0 8px 24px rgba(93, 160, 232, 0.4);
  transition: transform 0.25s var(--ease-out), box-shadow 0.25s var(--ease-out);
}

.coming-soon__cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(93, 160, 232, 0.55);
}

.coming-soon__pulse {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: -1;
}

.coming-soon__pulse span {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 200px;
  height: 200px;
  border: 2px solid rgba(93, 160, 232, 0.18);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  animation: cs-ring 3.2s ease-out infinite;
}

.coming-soon__pulse span:nth-child(2) { animation-delay: 1s; }
.coming-soon__pulse span:nth-child(3) { animation-delay: 2s; }

@keyframes cs-ring {
  0%   { width: 100px;  height: 100px;  opacity: 0.9; }
  100% { width: 800px;  height: 800px;  opacity: 0; }
}

/* ============================================================
   CURSOR PETAL - カーソル追従の桜散りエフェクト
   ============================================================ */
.cursor-petal {
  position: fixed;
  pointer-events: none;
  z-index: 9999;
  background: radial-gradient(ellipse at 30% 30%, #ffe4ec 0%, #f8bbd0 55%, rgba(248,187,208,0) 100%);
  border-radius: 50% 10% 50% 50%;
  opacity: 0.95;
  animation: cursorPetalFall var(--duration, 2s) cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
  filter: drop-shadow(0 1px 2px rgba(244, 143, 177, 0.4));
  will-change: transform, opacity;
}

.cursor-petal--white {
  background: radial-gradient(ellipse at 30% 30%, #ffffff 0%, #ffe4ec 60%, rgba(255,228,236,0) 100%);
  filter: drop-shadow(0 1px 3px rgba(255, 255, 255, 0.6));
}

@keyframes cursorPetalFall {
  0%   {
    transform: translate(0, 0) rotate(0deg);
    opacity: 0.95;
  }
  60%  { opacity: 0.85; }
  100% {
    transform: translate(var(--drift-x), var(--drift-y)) rotate(var(--rotation));
    opacity: 0;
  }
}

/* ============================================================
   CONTACT SIMPLE - シンプルお問い合わせフォーム
   ============================================================ */
.contact-simple-page {
  /* page-hero を非表示にしたいため独自スタイル */
}

.contact-simple {
  position: relative;
  min-height: 80vh;
  padding: var(--space-20) var(--space-6) var(--space-24);
  background: linear-gradient(135deg, #5DA0E8 0%, #7AB7F0 50%, #67D8F0 100%);
  overflow: hidden;
}

.contact-simple::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(255,255,255,0.16) 1.5px, transparent 1.5px);
  background-size: 22px 22px;
  pointer-events: none;
}

.contact-simple__inner {
  position: relative;
  z-index: 2;
  max-width: 720px;
  margin: 0 auto;
}

.contact-simple__title {
  font-family: var(--font-display);
  font-size: clamp(3rem, 8vw, 5.5rem);
  font-weight: 800;
  color: transparent;
  -webkit-text-stroke: 2px #ffffff;
  text-stroke: 2px #ffffff;
  letter-spacing: 0.04em;
  margin: 0 0 var(--space-12);
  line-height: 1;
  text-align: left;
}

.contact-simple__form-wrap {
  margin-top: var(--space-8);
}

.contact-simple .wpcf7-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-7);
}

.contact-simple__field {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  border-bottom: 1px solid rgba(255, 255, 255, 0.55);
  padding-bottom: var(--space-3);
}

.contact-simple__field:has(.contact-simple__textarea) {
  border-bottom: none;
  gap: var(--space-2);
}

.contact-simple__label {
  font-size: var(--text-sm);
  font-weight: 700;
  color: #ffffff;
  letter-spacing: 0.05em;
}

/* テキスト入力（border-bottom 線スタイル） */
.contact-simple .contact-simple__input,
.contact-simple input[type="text"],
.contact-simple input[type="email"] {
  width: 100%;
  padding: 8px 4px;
  font-size: var(--text-base);
  font-family: inherit;
  color: #ffffff;
  background: transparent;
  border: none;
  outline: none;
}

.contact-simple input::placeholder,
.contact-simple textarea::placeholder {
  color: rgba(255, 255, 255, 0.65);
}

.contact-simple input:focus,
.contact-simple textarea:focus {
  outline: none;
}

/* テキストエリア（白枠） */
.contact-simple .contact-simple__textarea,
.contact-simple textarea {
  width: 100%;
  padding: var(--space-4);
  font-size: var(--text-base);
  font-family: inherit;
  color: #ffffff;
  background: transparent;
  border: 1.5px solid rgba(255, 255, 255, 0.8);
  border-radius: var(--radius-md);
  resize: vertical;
  min-height: 140px;
  line-height: var(--leading-relaxed);
  margin-top: 6px;
}

.contact-simple textarea:focus {
  border-color: #ffffff;
  background: rgba(255, 255, 255, 0.05);
}

/* SEND ボタン */
.contact-simple__submit-wrap {
  margin-top: var(--space-5);
}

.contact-simple .contact-simple__submit,
.contact-simple .wpcf7-submit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: var(--space-5) var(--space-8);
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 800;
  letter-spacing: 0.2em;
  color: var(--color-primary);
  background: #ffffff;
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
  transition: transform 0.25s var(--ease-out), box-shadow 0.25s var(--ease-out);
  position: relative;
}

.contact-simple .wpcf7-submit:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.18);
}

.contact-simple__submit-wrap::after {
  content: '';
  position: absolute;
  right: var(--space-8);
  top: 50%;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  pointer-events: none;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235DA0E8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m22 2-7 20-4-9-9-4Z'/%3E%3Cpath d='M22 2 11 13'/%3E%3C/svg%3E") no-repeat center / contain;
}

.contact-simple__submit-wrap {
  position: relative;
}

/* CF7 のレスポンス・バリデーション */
.contact-simple .wpcf7-not-valid-tip {
  display: block;
  margin-top: 6px;
  font-size: 12px;
  color: #fff5f5;
  background: rgba(225, 29, 72, 0.4);
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  display: inline-block;
}

.contact-simple .wpcf7-response-output {
  margin-top: var(--space-6);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid rgba(255,255,255,0.6);
  background: rgba(255,255,255,0.18);
  color: #ffffff;
  font-size: var(--text-sm);
  text-align: center;
}

.contact-simple form.sent .wpcf7-response-output {
  background: rgba(255,255,255,0.95);
  color: var(--color-primary-dark);
}

/* SP 調整 */
@media (max-width: 640px) {
  .contact-simple {
    padding: var(--space-12) var(--space-5) var(--space-16);
  }
  .contact-simple__title {
    font-size: clamp(2.4rem, 12vw, 3.5rem);
    margin-bottom: var(--space-8);
  }
  .contact-simple .wpcf7-submit {
    font-size: var(--text-xl);
    padding: var(--space-4) var(--space-6);
  }
  .contact-simple__submit-wrap::after {
    right: var(--space-5);
    width: 20px;
    height: 20px;
  }
}

/* ============================================================
   CONTACT (フロントページ末尾の簡易お問い合わせ)
   ============================================================ */
.section--contact-front {
  /* contact-simple のベーススタイルを流用、上下マージン微調整 */
  padding-top: var(--space-20);
  padding-bottom: var(--space-24);
}

.contact-simple__lead {
  margin: calc(-1 * var(--space-8)) 0 var(--space-10);
  font-size: var(--text-base);
  color: rgba(255, 255, 255, 0.9);
  font-weight: 500;
}

/* ============================================================
   PAGE HERO - ブルー基調へ全面上書き (re;ALIZE)
   ============================================================ */

.page-hero {
  background: linear-gradient(160deg, #eff6ff 0%, #dbeafe 40%, #e0f2fe 100%) !important;
}

.page-hero::before {
  background:
    radial-gradient(ellipse 600px 300px at 20% 50%, rgba(93, 160, 232, 0.16) 0%, transparent 100%),
    radial-gradient(ellipse 500px 250px at 80% 30%, rgba(103, 216, 240, 0.12) 0%, transparent 100%),
    radial-gradient(ellipse 400px 200px at 50% 80%, rgba(122, 183, 240, 0.10) 0%, transparent 100%) !important;
}

.page-hero__bg-text {
  -webkit-text-stroke: 1px rgba(37, 99, 235, 0.10) !important;
}

.page-hero__mesh {
  background:
    radial-gradient(circle 200px at 15% 25%, rgba(93, 160, 232, 0.18) 0%, transparent 100%),
    radial-gradient(circle 180px at 85% 35%, rgba(103, 216, 240, 0.14) 0%, transparent 100%),
    radial-gradient(circle 150px at 50% 75%, rgba(122, 183, 240, 0.12) 0%, transparent 100%),
    radial-gradient(circle 120px at 75% 80%, rgba(147, 197, 253, 0.10) 0%, transparent 100%) !important;
}

/* Orbs */
.page-hero__orb--1 { background: rgba(93, 160, 232, 0.22) !important; }
.page-hero__orb--2 { background: rgba(103, 216, 240, 0.18) !important; }
.page-hero__orb--3 { background: rgba(122, 183, 240, 0.14) !important; }
.page-hero__orb--4 { background: rgba(147, 197, 253, 0.12) !important; }
.page-hero__orb--5 { background: rgba(186, 230, 253, 0.12) !important; }

/* Geometric decos - すべてブルー系へ */
.page-hero__deco--1 { border-color: rgba(93, 160, 232, 0.25) !important; }
.page-hero__deco--2 { border-color: rgba(103, 216, 240, 0.25) !important; }
.page-hero__deco--3 { background: rgba(122, 183, 240, 0.18) !important; }
.page-hero__deco--4 { background: rgba(93, 160, 232, 0.14) !important; }
.page-hero__deco--5 { border-color: rgba(103, 216, 240, 0.20) !important; }
.page-hero__deco--6,
.page-hero__deco--7,
.page-hero__deco--8 {
  border-color: rgba(93, 160, 232, 0.22) !important;
  background: rgba(186, 230, 253, 0.14) !important;
}

/* Sparkles */
.page-hero__sparkle,
.page-bg-sparkle {
  color: rgba(93, 160, 232, 0.55) !important;
  text-shadow: 0 0 6px rgba(93, 160, 232, 0.35) !important;
}

/* page-bg-orbs (コンテンツエリアの浮遊オーブ) */
.page-bg-orb--1,
.page-bg-orb--3,
.page-bg-orb--5 { background: rgba(93, 160, 232, 0.10) !important; }

.page-bg-orb--2,
.page-bg-orb--4,
.page-bg-orb--6 { background: rgba(103, 216, 240, 0.10) !important; }

/* page-hero タイトル (英) のテキスト色も念のためブルーに */
.page-hero__en {
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 50%, var(--color-accent-cyan) 100%) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  color: transparent !important;
}

.page-hero__ja {
  color: var(--color-primary-dark) !important;
  font-weight: 600 !important;
}

.page-hero__divider-dot {
  color: var(--color-primary) !important;
}

.page-hero__divider-line {
  background: linear-gradient(90deg, transparent 0%, var(--color-primary-light) 50%, transparent 100%) !important;
}

/* 背景の大文字ウォーターマーク (ABOUT 等) を非表示 */
.page-hero__bg-text {
  display: none !important;
}

/* ============================================================
   ABOUT: re;ALIZEが選ばれる理由（3カード・シンプル版）
   ============================================================ */
.reasons-3 {
  max-width: 1100px;
  margin: 0 auto;
  padding: var(--space-16) var(--space-6);
}

.reasons-3__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  margin-top: var(--space-10);
}

@media (min-width: 840px) {
  .reasons-3__grid {
    grid-template-columns: repeat(6, 1fr);
    gap: var(--space-6);
  }
  /* 上段: 3カード × 2col = 6col */
  .reasons-3__grid > .reason-card {
    grid-column: span 2;
  }
  /* 下段（4・5）: 2カード × 3col = 6col */
  .reasons-3__grid > .reason-card--wide {
    grid-column: span 3;
  }
}

/* ── カード（フラット・シンプル） ── */
.reason-card {
  position: relative;
  background: #ffffff;
  border: 1px solid var(--color-border-light);
  border-radius: 12px;
  padding: var(--space-10) var(--space-6) var(--space-8);
  display: flex;
  flex-direction: column;
  text-align: left;
  transition: border-color 0.3s var(--ease-out), transform 0.3s var(--ease-out);
}

.reason-card:hover {
  border-color: var(--color-primary-light);
  transform: translateY(-3px);
}

.reason-card__num {
  font-family: var(--font-display);
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-primary);
  letter-spacing: 0.2em;
  margin: 0 0 var(--space-3);
}

.reason-card__title {
  font-family: var(--font-heading);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--color-text);
  margin: 0 0 var(--space-6);
  line-height: 1.5;
  letter-spacing: 0.01em;
}

.reason-card__desc {
  margin: auto 0 0;
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-border-light);
  font-size: 0.85rem;
  color: var(--color-text-muted);
  line-height: 1.85;
}

/* ── ピラミッド（シンプル） ── */
.reason-pyramid {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--space-2);
  margin: var(--space-2) 0 var(--space-4);
}

.reason-pyramid__tier {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  border-radius: 8px;
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: 0.04em;
}

.reason-pyramid__tier--top {
  width: 70%;
  margin: 0 auto;
  background: var(--color-primary-dark);
  color: #ffffff;
  font-size: 1.1rem;
}

.reason-pyramid__tier--bottom {
  background: var(--color-primary-50);
  color: var(--color-primary-dark);
  border: 1px solid var(--color-primary-200);
  font-size: 1rem;
}

.reason-pyramid__divider {
  display: block;
  text-align: center;
  font-size: 0.7rem;
  font-weight: 600;
  color: var(--color-text-muted);
  letter-spacing: 0.1em;
  padding: 2px 0;
  position: relative;
}

.reason-pyramid__divider::before {
  content: '↑';
  display: block;
  font-size: 0.95rem;
  color: var(--color-primary);
  margin-bottom: 2px;
  line-height: 1;
}

/* ── ZERO ── */
.reason-card__zero-wrap {
  margin: var(--space-2) 0 var(--space-4);
  text-align: left;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-2);
}

.reason-card__zero {
  font-family: var(--font-display);
  font-size: clamp(3rem, 6vw, 4.2rem);
  font-weight: 800;
  color: var(--color-primary-dark);
  line-height: 1;
  letter-spacing: -0.02em;
}

.reason-card__zero-sub {
  display: inline-block;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--color-primary);
  background: var(--color-primary-50, rgba(37, 99, 235, 0.08));
  padding: 4px 12px;
  border-radius: 9999px;
  white-space: nowrap;
  letter-spacing: 0.04em;
}

/* ── 0円で受けられるサポート一覧 ── */
.zero-list {
  list-style: none;
  padding: 0;
  margin: var(--space-2) 0 var(--space-4);
  display: flex;
  flex-direction: column;
  gap: 0;
}

.zero-list li {
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-border-light);
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--color-text);
  position: relative;
  padding-left: var(--space-6);
}

.zero-list li:last-child {
  border-bottom: none;
}

.zero-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  background: var(--color-primary);
  border-radius: 50%;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><path d='M20 6 9 17l-5-5'/></svg>");
  background-size: 11px 11px;
  background-position: center;
  background-repeat: no-repeat;
}

/* ── Founder面談カード ── */
.reason-meet {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  margin: var(--space-2) 0 var(--space-4);
}

.reason-meet__visual {
  position: relative;
  flex: 0 0 auto;
  width: 150px;
  height: 150px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 35%, var(--color-primary-50), rgba(255, 255, 255, 0));
  display: flex;
  align-items: flex-end;
  justify-content: center;
  overflow: visible;
  margin: var(--space-2) auto 0;
}

.reason-meet__visual img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: bottom center;
}

.reason-meet__badge {
  position: absolute;
  top: -6px;
  right: -10px;
  font-family: var(--font-display);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: #ffffff;
  background: var(--color-primary-dark);
  padding: 4px 10px;
  border-radius: 9999px;
  box-shadow: 0 4px 12px rgba(37, 99, 235, 0.25);
}

.reason-meet__list {
  list-style: none;
  padding: 0;
  margin: 0;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.reason-meet__list li {
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-border-light);
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--color-text);
  position: relative;
  padding-left: var(--space-6);
}

.reason-meet__list li:last-child {
  border-bottom: none;
}

.reason-meet__list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  background: var(--color-primary);
  border-radius: 50%;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><path d='M20 6 9 17l-5-5'/></svg>");
  background-size: 11px 11px;
  background-position: center;
  background-repeat: no-repeat;
}

/* ── イベント露出カード（Zepp画像ヒーロー版） ── */
.reason-event-hero {
  position: relative;
  margin: var(--space-2) 0 var(--space-5);
  border-radius: 12px;
  overflow: hidden;
  background: linear-gradient(180deg, var(--color-primary-50) 0%, #ffffff 100%);
  border: 1px solid var(--color-primary-200);
  box-shadow: 0 6px 20px rgba(37, 99, 235, 0.12);
  transition: transform 0.4s var(--ease-out), box-shadow 0.4s var(--ease-out);
}

.reason-event-hero:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(37, 99, 235, 0.18);
}

.reason-event-hero img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.reason-event-hero__caption {
  position: absolute;
  left: 12px;
  bottom: 12px;
  right: 12px;
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: 8px 12px;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border-radius: 8px;
}

.reason-event-hero__tag {
  font-family: var(--font-display);
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  color: #ffffff;
  background: var(--color-primary);
  padding: 4px 10px;
  border-radius: 4px;
  flex-shrink: 0;
}

.reason-event-hero__title {
  font-size: 0.85rem;
  font-weight: 600;
  color: #ffffff;
  line-height: 1.4;
}

.reason-event__list {
  list-style: none;
  padding: 0;
  margin: 0;
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.reason-event__list--compact {
  margin: 0 0 var(--space-4);
}

.reason-event__list li {
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-border-light);
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--color-text);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.reason-event__list li:last-child {
  border-bottom: none;
}

.reason-event__list li strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 56px;
  font-family: var(--font-display);
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  color: #ffffff;
  background: var(--color-primary);
  padding: 4px 8px;
  border-radius: 4px;
}

/* ── 配信アプリ一覧（テキストのみ） ── */
.apps-list {
  list-style: none;
  padding: 0;
  margin: var(--space-2) 0 var(--space-4);
  display: flex;
  flex-direction: column;
  gap: 0;
}

.apps-list li {
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-border-light);
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--color-text);
  position: relative;
  padding-left: var(--space-4);
}

.apps-list li:last-child {
  border-bottom: none;
}

.apps-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  background: var(--color-primary);
  border-radius: 50%;
}

/* ============================================================
   AUDITION PAGE v2 - re;BON 構成準拠
   ============================================================ */
.aud-page-v2 {
  position: relative;
  background: #ffffff;
  overflow: hidden;
}

/* 共通コンテナ */
.aud2-container {
  max-width: 960px;
  margin: 0 auto;
  padding: 0 var(--space-6);
}

/* 共通セクション */
.aud2-section {
  padding: var(--space-20) 0;
  position: relative;
}

/* セクションタイトル */
.aud2-section-title {
  text-align: center;
  margin: 0 0 var(--space-12);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
}

.aud2-section-title__en {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 800;
  letter-spacing: 0.08em;
  background: linear-gradient(135deg, var(--color-primary-dark), var(--color-primary), var(--color-accent-cyan));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 1;
}

.aud2-section-title__ja {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-text-muted);
  letter-spacing: 0.08em;
}

/* ── ① HERO ── */
.aud2-hero {
  position: relative;
  height: clamp(420px, 70vh, 720px);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.aud2-hero__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 1;
}

.aud2-hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.25) 0%, rgba(15, 23, 42, 0.55) 100%);
}

.aud2-hero__inner {
  position: relative;
  z-index: 3;
  text-align: center;
  padding: var(--space-6);
  color: #ffffff;
}

.aud2-hero__label {
  font-family: var(--font-display);
  font-size: clamp(0.85rem, 2vw, 1.1rem);
  font-weight: 600;
  letter-spacing: 0.15em;
  margin: 0 0 var(--space-4);
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
}

.aud2-hero__title {
  font-size: clamp(2.5rem, 8vw, 5rem);
  font-weight: 900;
  margin: 0 0 var(--space-4);
  letter-spacing: 0.04em;
  text-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
}

.aud2-hero__sub {
  font-size: clamp(1rem, 2.2vw, 1.3rem);
  font-weight: 500;
  letter-spacing: 0.08em;
  margin: 0;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.35);
}

/* ── ② ABOUT ── */
.aud2-about {
  background: #ffffff;
}

.aud2-about__body {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
  font-size: 1rem;
  line-height: 2;
  color: var(--color-text);
}

.aud2-about__body p {
  margin: 0 0 var(--space-5);
}

.aud2-about__body p:last-child {
  margin-bottom: 0;
}

.aud2-about__body strong {
  color: var(--color-primary-dark);
  font-weight: 700;
}

/* ── ③ MESSAGE ── */
.aud2-message {
  background: linear-gradient(180deg, #f0f9ff 0%, #dbeafe 100%);
}

.aud2-message__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}

@media (min-width: 768px) {
  .aud2-message__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-6);
  }
}

.aud2-message-card {
  background: #ffffff;
  border-radius: 12px;
  padding: var(--space-8) var(--space-6);
  box-shadow: 0 4px 16px rgba(37, 99, 235, 0.08);
  transition: transform 0.3s var(--ease-out), box-shadow 0.3s var(--ease-out);
}

.aud2-message-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 28px rgba(37, 99, 235, 0.14);
}

.aud2-message-card__num {
  display: block;
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  color: var(--color-primary);
  margin-bottom: var(--space-3);
}

.aud2-message-card__title {
  margin: 0 0 var(--space-4);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.45;
}

.aud2-message-card__desc {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.9;
  color: var(--color-text-muted);
}

/* ── ④ RECRUITMENT ── */
.aud2-recruit {
  background: #ffffff;
}

.aud2-recruit__list {
  max-width: 760px;
  margin: 0 auto;
  background: #ffffff;
  border: 1px solid var(--color-border);
  border-radius: 12px;
  overflow: hidden;
}

.aud2-recruit__row {
  display: grid;
  grid-template-columns: 180px 1fr;
  border-bottom: 1px solid var(--color-border-light);
}

.aud2-recruit__row:last-child {
  border-bottom: none;
}

.aud2-recruit__row dt {
  padding: var(--space-5) var(--space-6);
  background: var(--color-primary-50);
  color: var(--color-primary-dark);
  font-weight: 700;
  font-size: 0.95rem;
  letter-spacing: 0.04em;
  display: flex;
  align-items: center;
}

.aud2-recruit__row dd {
  margin: 0;
  padding: var(--space-5) var(--space-6);
  color: var(--color-text);
  font-size: 0.95rem;
  line-height: 1.85;
}

@media (max-width: 600px) {
  .aud2-recruit__row {
    grid-template-columns: 1fr;
  }
  .aud2-recruit__row dt {
    padding: var(--space-3) var(--space-5);
    font-size: 0.85rem;
  }
}

/* ── ⑤ WELCOME ── */
.aud2-welcome {
  background: linear-gradient(180deg, #dbeafe 0%, #e0f2fe 100%);
}

.aud2-welcome__wrap {
  max-width: 960px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  align-items: center;
}

@media (min-width: 840px) {
  .aud2-welcome__wrap {
    grid-template-columns: 1fr auto;
  }
}

.aud2-welcome__list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.aud2-welcome__item {
  position: relative;
  background: #ffffff;
  padding: var(--space-5) var(--space-6) var(--space-5) var(--space-16);
  border-radius: 9999px;
  font-weight: 600;
  color: var(--color-text);
  box-shadow: 0 2px 10px rgba(37, 99, 235, 0.08);
}

.aud2-welcome__item::before {
  content: '✓';
  position: absolute;
  left: var(--space-5);
  top: 50%;
  transform: translateY(-50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent-cyan));
  color: #ffffff;
  border-radius: 50%;
  font-size: 0.85rem;
  font-weight: 700;
}

.aud2-welcome__char {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  pointer-events: none;
}

.aud2-welcome__char img {
  width: clamp(140px, 22vw, 220px);
  height: auto;
  display: block;
  filter: drop-shadow(0 8px 18px rgba(37, 99, 235, 0.18));
  animation: aud2WelcomeFloat 4s ease-in-out infinite;
}

@keyframes aud2WelcomeFloat {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-8px); }
}

/* ── WELCOME features (FOR GAMERS / FOR ARTISTS) ── */
.aud2-welcome__features {
  max-width: 1200px;
  margin: var(--space-12) auto 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  padding: 0 var(--space-6);
  box-sizing: border-box;
}

@media (min-width: 768px) {
  .aud2-welcome__features {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-8);
  }
}

.aud2-welcome-feature {
  margin: 0;
  text-align: center;
}

.aud2-welcome-feature__img-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: 12px;
  background: #0f172a;
  box-shadow: 0 8px 24px rgba(37, 99, 235, 0.12);
  transition: transform 0.3s var(--ease-out), box-shadow 0.3s var(--ease-out);
}

.aud2-welcome-feature:hover .aud2-welcome-feature__img-wrap {
  transform: translateY(-4px);
  box-shadow: 0 14px 34px rgba(37, 99, 235, 0.18);
}

.aud2-welcome-feature__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.aud2-welcome-feature__caption {
  margin-top: var(--space-4);
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--color-text);
  letter-spacing: 0.02em;
}

/* ── ⑥ SCHEDULE ── */
.aud2-schedule {
  background: #ffffff;
}

.aud2-schedule__steps {
  max-width: 720px;
  margin: 0 auto;
  padding: 0;
  list-style: none;
  position: relative;
}

.aud2-schedule__steps::before {
  content: '';
  position: absolute;
  left: 32px;
  top: 24px;
  bottom: 24px;
  width: 2px;
  background: linear-gradient(180deg, var(--color-primary), var(--color-accent-cyan));
  opacity: 0.35;
}

.aud2-schedule-step {
  position: relative;
  padding-left: var(--space-16);
  margin-bottom: var(--space-8);
}

.aud2-schedule-step:last-child {
  margin-bottom: 0;
}

.aud2-schedule-step::before {
  content: '';
  position: absolute;
  left: 21px;
  top: 8px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #ffffff;
  border: 4px solid var(--color-primary);
  box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.12);
}

.aud2-schedule-step__num {
  font-family: var(--font-display);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  color: var(--color-primary);
}

.aud2-schedule-step__title {
  margin: var(--space-2) 0 var(--space-2);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--color-text);
}

.aud2-schedule-step__desc {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.85;
  color: var(--color-text-muted);
}

/* ── ⑦ FAQ ── */
.aud2-faq {
  background: linear-gradient(180deg, #f0f9ff 0%, #ffffff 100%);
}

.aud2-faq__list {
  max-width: 760px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.aud2-faq__item {
  background: #ffffff;
  border: 1px solid var(--color-border);
  border-radius: 10px;
  overflow: hidden;
  transition: border-color 0.3s;
}

.aud2-faq__item[open] {
  border-color: var(--color-primary-light);
}

.aud2-faq__q {
  position: relative;
  display: block;
  padding: var(--space-5) var(--space-12) var(--space-5) var(--space-6);
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--color-text);
  cursor: pointer;
  user-select: none;
  list-style: none;
  line-height: 1.6;
}

.aud2-faq__q::-webkit-details-marker {
  display: none;
}

.aud2-faq__q::before {
  content: 'Q';
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  margin-right: var(--space-3);
  background: var(--color-primary);
  color: #ffffff;
  border-radius: 50%;
  font-family: var(--font-display);
  font-size: 0.8rem;
  font-weight: 700;
  vertical-align: middle;
}

.aud2-faq__q::after {
  content: '+';
  position: absolute;
  right: var(--space-5);
  top: 50%;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  font-size: 1.4rem;
  font-weight: 400;
  transition: transform 0.3s var(--ease-out);
}

.aud2-faq__item[open] .aud2-faq__q::after {
  transform: translateY(-50%) rotate(45deg);
}

.aud2-faq__a {
  padding: 0 var(--space-6) var(--space-5);
  font-size: 0.9rem;
  line-height: 1.85;
  color: var(--color-text-muted);
  position: relative;
  padding-left: calc(var(--space-6) + 24px + var(--space-3));
}

.aud2-faq__a::before {
  content: 'A';
  position: absolute;
  left: var(--space-6);
  top: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  background: var(--color-accent-cyan);
  color: #ffffff;
  border-radius: 50%;
  font-family: var(--font-display);
  font-size: 0.8rem;
  font-weight: 700;
}

/* ── ⑧ ENTRY ── */
.aud2-entry {
  position: relative;
  padding: var(--space-20) 0;
  overflow: hidden;
  text-align: center;
}

.aud2-entry__bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, #1E3A8A 0%, #2C6AB6 50%, #5DA0E8 100%);
}

.aud2-entry__bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(255,255,255,0.14) 1.5px, transparent 1.5px);
  background-size: 22px 22px;
}

.aud2-entry__inner {
  position: relative;
  z-index: 2;
}

.aud2-entry__label {
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.3em;
  color: rgba(255, 255, 255, 0.85);
  margin: 0 0 var(--space-4);
}

.aud2-entry__title {
  margin: 0 0 var(--space-3);
  font-size: clamp(1.8rem, 5vw, 2.8rem);
  font-weight: 800;
  color: #ffffff;
  letter-spacing: 0.04em;
  text-shadow: 0 2px 14px rgba(0, 0, 0, 0.22);
}

.aud2-entry__sub {
  margin: 0 0 var(--space-10);
  font-size: 1rem;
  color: rgba(255, 255, 255, 0.92);
}

.aud2-entry__btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-5) var(--space-10);
  background: #ffffff;
  color: var(--color-primary-dark);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.05rem;
  letter-spacing: 0.06em;
  border-radius: 9999px;
  text-decoration: none;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.22);
  transition: transform 0.3s var(--ease-out), box-shadow 0.3s var(--ease-out);
}

.aud2-entry__btn:hover {
  transform: translateY(-3px);
  background: var(--color-primary-50);
  box-shadow: 0 14px 36px rgba(0, 0, 0, 0.3);
}

/* ============================================================
   AUDITION v2 - TOP CTA バナー（ページ上部の応募導線）
   ============================================================ */
.aud2-top-cta {
  margin: var(--space-10) 0 var(--space-6);
}

.aud2-top-cta__btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  width: 100%;
  padding: var(--space-6) var(--space-8);
  background: linear-gradient(135deg, #1E3A8A 0%, #2C6AB6 50%, #5DA0E8 100%);
  color: #ffffff;
  text-decoration: none;
  border-radius: 14px;
  box-shadow: 0 10px 28px rgba(37, 99, 235, 0.22);
  overflow: hidden;
  transition: transform 0.3s var(--ease-out), box-shadow 0.3s var(--ease-out);
}

.aud2-top-cta__btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(255,255,255,0.12) 1.2px, transparent 1.2px);
  background-size: 18px 18px;
  opacity: 0.7;
  pointer-events: none;
}

.aud2-top-cta__btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 36px rgba(37, 99, 235, 0.32);
}

.aud2-top-cta__text {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 4px;
  z-index: 1;
}

.aud2-top-cta__label {
  font-family: var(--font-display);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.3em;
  color: rgba(255, 255, 255, 0.85);
}

.aud2-top-cta__catch {
  font-size: 1.25rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  color: #ffffff;
}

.aud2-top-cta__arrow {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: rgba(255, 255, 255, 0.15);
  border-radius: 50%;
  transition: background 0.3s var(--ease-out), transform 0.3s var(--ease-out);
}

.aud2-top-cta__btn:hover .aud2-top-cta__arrow {
  background: rgba(255, 255, 255, 0.28);
  transform: translateX(4px);
}

@media (max-width: 640px) {
  .aud2-top-cta {
    margin: var(--space-6) 0 var(--space-4);
  }
  .aud2-top-cta__btn {
    padding: var(--space-5) var(--space-5);
    border-radius: 12px;
  }
  .aud2-top-cta__catch {
    font-size: 1.05rem;
  }
  .aud2-top-cta__label {
    font-size: 0.65rem;
  }
  .aud2-top-cta__arrow {
    width: 36px;
    height: 36px;
  }
}

/* ============================================================
   AUDITION v2 - MESSAGE 動画埋め込み
   ============================================================ */
.aud2-message__video {
  max-width: 880px;
  margin: 0 auto;
}

.aud2-message__video-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #0f172a;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 16px 40px rgba(37, 99, 235, 0.22), 0 6px 14px rgba(0, 0, 0, 0.12);
}

.aud2-message__video-wrap iframe,
.aud2-message__video-wrap video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

/* 動画未設定時のプレースホルダ */
.aud2-message__placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: linear-gradient(135deg, #dbeafe 0%, #e0f2fe 100%);
  border: 2px dashed var(--color-primary-200);
  border-radius: 12px;
  color: var(--color-primary-dark);
  padding: var(--space-6);
}

.aud2-message__placeholder svg {
  color: var(--color-primary);
  margin-bottom: var(--space-3);
}

.aud2-message__placeholder p {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  margin: 0 0 var(--space-3);
}

.aud2-message__placeholder span {
  font-size: 0.8rem;
  color: var(--color-text-muted);
  line-height: 1.7;
}

/* AUDITION v2 - RECRUITMENT 応募条件リスト */
.aud2-recruit__items {
  max-width: 760px;
  margin: 0 auto;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.aud2-recruit__item {
  display: flex;
  align-items: center;
  gap: var(--space-5);
  padding: var(--space-5) var(--space-6);
  background: #ffffff;
  border: 1px solid var(--color-border);
  border-radius: 10px;
  box-shadow: 0 2px 8px rgba(37, 99, 235, 0.06);
  transition: transform 0.3s var(--ease-out), border-color 0.3s, box-shadow 0.3s;
}

.aud2-recruit__item:hover {
  border-color: var(--color-primary-light);
  transform: translateX(4px);
  box-shadow: 0 6px 18px rgba(37, 99, 235, 0.12);
}

.aud2-recruit__num {
  flex-shrink: 0;
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  background: linear-gradient(135deg, var(--color-primary-dark), var(--color-primary), var(--color-accent-cyan));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  min-width: 32px;
}

.aud2-recruit__text {
  flex: 1;
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--color-text);
  line-height: 1.7;
}

@media (max-width: 600px) {
  .aud2-recruit__item {
    padding: var(--space-4) var(--space-5);
    gap: var(--space-4);
  }
  .aud2-recruit__num {
    font-size: 1rem;
    min-width: 28px;
  }
  .aud2-recruit__text {
    font-size: 0.9rem;
  }
}

/* ============================================================
   AUDITION v2 - KV カード（Linear風）
   ============================================================ */
.aud2-kv-section {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 var(--space-6) var(--space-12);
}

.aud2-kv-card {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 7;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow:
    0 24px 60px rgba(37, 99, 235, 0.24),
    0 8px 18px rgba(37, 99, 235, 0.10);
}

.aud2-kv-card__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.aud2-kv-card__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: var(--space-12) var(--space-12);
  color: #ffffff;
  background: linear-gradient(90deg, rgba(15, 23, 42, 0.55) 0%, rgba(15, 23, 42, 0.18) 50%, rgba(15, 23, 42, 0) 100%);
}

.aud2-kv-card__label {
  font-family: var(--font-display);
  font-size: clamp(0.75rem, 1.4vw, 0.95rem);
  font-weight: 600;
  letter-spacing: 0.16em;
  color: rgba(255, 255, 255, 0.92);
  margin: 0 0 var(--space-3);
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
}

.aud2-kv-card__catch {
  margin: 0 0 var(--space-3);
  font-size: clamp(1.8rem, 4.5vw, 3rem);
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: 0.04em;
  color: #ffffff;
  text-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
}

.aud2-kv-card__sub {
  margin: 0;
  font-size: clamp(0.85rem, 1.5vw, 1.05rem);
  letter-spacing: 0.06em;
  color: rgba(255, 255, 255, 0.92);
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.35);
}

/* SP 調整 */
@media (max-width: 640px) {
  .aud2-kv-section {
    padding: 0 var(--space-4) var(--space-8);
  }
  .aud2-kv-card {
    aspect-ratio: 4 / 5;
    border-radius: var(--radius-lg);
  }
  .aud2-kv-card__overlay {
    padding: var(--space-6) var(--space-6);
    justify-content: flex-end;
    background: linear-gradient(180deg, rgba(15, 23, 42, 0) 0%, rgba(15, 23, 42, 0.2) 40%, rgba(15, 23, 42, 0.7) 100%);
  }
}

/* 旧 aud2-hero 全画面背景は無効化（既存スタイル残骸対策） */
.aud-page-v2 .aud2-hero { display: none; }

/* ============================================================
   RESPONSIVE REFINEMENTS — Tablet / Smartphone polish
   レスポンシブパターンに合わせて全体調整
   ============================================================ */

/* ---- TABLET（≤1024px）---- */
@media (max-width: 1024px) {
  .aud2-section {
    padding: var(--space-16) 0;
  }
  .reasons-3 {
    padding: var(--space-12) var(--space-5);
  }
  .aud2-entry {
    padding: var(--space-16) 0;
  }
}

/* ---- TABLET PORTRAIT（≤840px）---- */
@media (max-width: 840px) {
  /* Audition v2 共通セクション */
  .aud2-section {
    padding: var(--space-14) 0;
  }
  .aud2-section-title {
    margin: 0 0 var(--space-10);
  }
  .aud2-container {
    padding: 0 var(--space-5);
  }

  /* KV カード — タブレットでも横長維持しつつ高さ控えめに */
  .aud2-kv-card {
    aspect-ratio: 16 / 9;
  }
  .aud2-kv-card__overlay {
    padding: var(--space-10) var(--space-8);
  }

  /* WELCOME — ミニキャラを少し小さく */
  .aud2-welcome__char img {
    width: clamp(120px, 26vw, 180px);
  }

  /* WELCOME features — 1カラムにスタック */
  .aud2-welcome__features {
    padding: 0 var(--space-5);
    gap: var(--space-5);
  }
  .aud2-welcome-feature__img-wrap {
    aspect-ratio: 16 / 9;
  }

  /* Schedule タイムライン — 左パディング/インジケータ位置を詰める */
  .aud2-schedule__steps::before {
    left: 24px;
  }
  .aud2-schedule-step {
    padding-left: var(--space-14);
  }
  .aud2-schedule-step::before {
    left: 13px;
    width: 20px;
    height: 20px;
    border-width: 3px;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
  }

  /* FAQ — Q/A の左右余白を縮小 */
  .aud2-faq__q {
    padding: var(--space-4) var(--space-10) var(--space-4) var(--space-5);
    font-size: 0.92rem;
  }
  .aud2-faq__a {
    padding: 0 var(--space-5) var(--space-4);
    padding-left: calc(var(--space-5) + 24px + var(--space-3));
    font-size: 0.88rem;
  }
  .aud2-faq__a::before {
    left: var(--space-5);
  }

  /* Entry CTA */
  .aud2-entry {
    padding: var(--space-14) 0;
  }
  .aud2-entry__title {
    letter-spacing: 0.02em;
  }
}

/* ---- SMARTPHONE LANDSCAPE / 大型スマホ（≤640px）---- */
@media (max-width: 640px) {
  /* Audition v2 共通 */
  .aud2-section {
    padding: var(--space-12) 0;
  }
  .aud2-section-title {
    margin: 0 0 var(--space-8);
    gap: var(--space-1);
  }
  .aud2-section-title__ja {
    font-size: 0.85rem;
  }

  /* About */
  .aud2-about__body {
    font-size: 0.95rem;
    line-height: 1.85;
  }
  .aud2-about__body p {
    margin: 0 0 var(--space-4);
  }

  /* Recruitment 応募条件 */
  .aud2-recruit__items {
    gap: var(--space-2);
  }

  /* WELCOME ピル */
  .aud2-welcome__wrap {
    gap: var(--space-5);
  }
  .aud2-welcome__item {
    padding: var(--space-4) var(--space-5) var(--space-4) var(--space-14);
    font-size: 0.92rem;
  }
  .aud2-welcome__item::before {
    left: var(--space-3);
    width: 24px;
    height: 24px;
    font-size: 0.75rem;
  }
  .aud2-welcome__char img {
    width: clamp(100px, 32vw, 150px);
  }

  /* WELCOME features — モバイルでは画像をやや縦長に */
  .aud2-welcome__features {
    margin-top: var(--space-8);
    padding: 0 var(--space-4);
  }
  .aud2-welcome-feature__img-wrap {
    aspect-ratio: 4 / 3;
  }
  .aud2-welcome-feature__caption {
    margin-top: var(--space-3);
    font-size: 0.85rem;
  }

  /* Schedule */
  .aud2-schedule__steps::before {
    left: 18px;
  }
  .aud2-schedule-step {
    padding-left: var(--space-12);
    margin-bottom: var(--space-6);
  }
  .aud2-schedule-step::before {
    left: 9px;
  }
  .aud2-schedule-step__title {
    font-size: 1.05rem;
  }
  .aud2-schedule-step__desc {
    font-size: 0.88rem;
  }

  /* FAQ */
  .aud2-faq__q {
    padding: var(--space-4) var(--space-8) var(--space-4) var(--space-4);
    font-size: 0.9rem;
  }
  .aud2-faq__a {
    padding: 0 var(--space-4) var(--space-4);
    padding-left: calc(var(--space-4) + 24px + var(--space-2));
    font-size: 0.85rem;
  }
  .aud2-faq__a::before {
    left: var(--space-4);
  }

  /* Entry CTA */
  .aud2-entry {
    padding: var(--space-12) 0;
  }
  .aud2-entry__inner {
    padding: 0 var(--space-5);
  }
  .aud2-entry__sub {
    margin-bottom: var(--space-7);
  }

  /* About — reasons-3 */
  .reasons-3 {
    padding: var(--space-10) var(--space-4);
  }
  .reason-card {
    padding: var(--space-8) var(--space-5) var(--space-6);
  }
  .reason-card__title {
    font-size: 1.05rem;
    margin: 0 0 var(--space-5);
  }
  .reason-card__zero {
    font-size: clamp(2.4rem, 14vw, 3.4rem);
  }

  /* Contact simple */
  .contact-simple {
    padding: var(--space-14) var(--space-5) var(--space-16);
    min-height: auto;
  }
  .contact-simple__title {
    margin-bottom: var(--space-8);
    -webkit-text-stroke-width: 1.5px;
            text-stroke-width: 1.5px;
  }
  .contact-simple__form-wrap {
    margin-top: var(--space-6);
  }
}

/* ---- SMALL PHONE（≤479px）---- */
@media (max-width: 479px) {
  .aud2-container {
    padding: 0 var(--space-4);
  }
  .aud2-section {
    padding: var(--space-10) 0;
  }
  .aud2-section-title__en {
    font-size: clamp(1.6rem, 8vw, 2rem);
  }

  /* KV カード — モバイル縦長 4:5 */
  .aud2-kv-section {
    padding: 0 var(--space-3) var(--space-6);
  }
  .aud2-kv-card__overlay {
    padding: var(--space-5) var(--space-5);
  }

  /* WELCOME 各ピル — タイトル長文回り込み調整 */
  .aud2-welcome__item {
    font-size: 0.88rem;
    line-height: 1.5;
    border-radius: 16px;
  }
  .aud2-welcome__char {
    margin-top: var(--space-2);
  }

  /* Recruitment 番号配置のコンパクト化（既存 600px も維持） */
  .aud2-recruit__items {
    gap: var(--space-2);
  }
  .aud2-recruit__item {
    padding: var(--space-3) var(--space-4);
  }
  .aud2-recruit__num {
    min-width: 26px;
    font-size: 0.95rem;
  }
  .aud2-recruit__text {
    font-size: 0.85rem;
    line-height: 1.6;
  }

  /* Schedule タイムライン縦線をさらに左寄せ */
  .aud2-schedule__steps::before {
    left: 14px;
  }
  .aud2-schedule-step {
    padding-left: var(--space-10);
  }
  .aud2-schedule-step::before {
    left: 5px;
    width: 18px;
    height: 18px;
    border-width: 3px;
  }

  /* Entry */
  .aud2-entry__label {
    font-size: 0.75rem;
    letter-spacing: 0.22em;
  }
  .aud2-entry__title {
    font-size: clamp(1.55rem, 7vw, 2rem);
  }
  .aud2-entry__sub {
    font-size: 0.9rem;
  }

  /* About reasons-3 */
  .reasons-3 {
    padding: var(--space-8) var(--space-3);
  }
  .reasons-3__grid {
    gap: var(--space-5);
  }
  .reason-card {
    padding: var(--space-7) var(--space-5) var(--space-5);
  }
  .reason-pyramid__tier--top {
    width: 80%;
    font-size: 1rem;
  }
  /* 面談カード: モバイルでサイズ調整 */
  .reason-meet__visual {
    width: 120px;
    height: 120px;
  }
  .reason-event__list li strong {
    min-width: 50px;
    font-size: 0.6rem;
  }

  /* Contact simple */
  .contact-simple {
    padding: var(--space-12) var(--space-4) var(--space-14);
  }
  .contact-simple__title {
    font-size: clamp(2.4rem, 14vw, 3.5rem);
  }
}

/* ---- Contact simple: 下部の白余白を埋める（背景連続） ---- */
.contact-simple-page {
  background: linear-gradient(135deg, #5DA0E8 0%, #7AB7F0 50%, #67D8F0 100%);
  min-height: 100%;
}
body.page-template-page-contact .layout__main {
  background: linear-gradient(135deg, #5DA0E8 0%, #7AB7F0 50%, #67D8F0 100%);
}

/* ============================================================
   GLOBAL HORIZONTAL OVERFLOW GUARD
   モバイルで装飾要素・絶対配置による横はみ出しを防止
   ============================================================ */
html,
body {
  overflow-x: clip;
  max-width: 100%;
}

.site-wrapper,
.layout,
.layout__main,
.main {
  max-width: 100%;
  overflow-x: clip;
}

/* ============================================================
   STICKY CTA — モバイルでのコンテンツ被り対策
   フローティング ENTRY ボタンの高さ分、コンテンツが隠れないよう
   フォーム/CTAセクションなど"末尾コンテンツ"のあるページのみ余白追加
   （.main 全体に余白を付けると footer 前に白いギャップが発生するため避ける）
   ============================================================ */
@media (max-width: 840px) {
  /* CONTACT 独立ページ：見出しが header に潜らないよう padding-top 増 */
  .contact-simple-page .contact-simple {
    padding-top: calc(var(--header-height, 60px) + var(--space-12));
    padding-bottom: calc(var(--space-16) + 90px);
  }

  /* CONTACT トップページ埋め込みセクションも下余白追加 */
  .section--contact-front {
    padding-bottom: calc(var(--space-16) + 90px);
  }

  /* About reasons-3 最終カードが CTA に被らないよう */
  .reasons-3 {
    padding-bottom: calc(var(--space-12) + 90px);
  }
}

@media (max-width: 640px) {
  /* CONTACT 見出し位置をさらに調整 */
  .contact-simple-page .contact-simple {
    padding-top: calc(var(--header-height, 60px) + var(--space-10));
  }

  /* セクション末尾の CTA 用余白 */
  .section--contact-front,
  .contact-simple-page .contact-simple {
    padding-bottom: calc(var(--space-14) + 100px);
  }
}

/* ============================================================
   CONTACT — header との被り防止（z-index + bg 強化）
   ============================================================ */
body.page-template-page-contact .header {
  background: rgba(255, 255, 255, 0.96);
  border-bottom: 1px solid var(--color-border-light);
}

/* ============================================================
   FRONT PAGE - Mobile fine-tuning
   ============================================================ */
@media (max-width: 840px) {
  .section--members-v2 {
    padding: var(--space-14) 0;
  }
  .members-v2__container {
    padding: 0 var(--space-5);
  }
  .members-v2__heading {
    font-size: clamp(2rem, 7vw, 3rem);
  }
  .section--banners {
    padding-top: var(--space-12);
    padding-bottom: var(--space-12);
  }
  .section--banners .container {
    padding: 0 var(--space-5);
  }
  .section--streams {
    padding: var(--space-14) 0;
  }
}

@media (max-width: 640px) {
  .section--members-v2 {
    padding: var(--space-12) 0;
  }
  .members-v2__container {
    padding: 0 var(--space-4);
  }
  .members-v2__header {
    margin-bottom: var(--space-6);
    gap: var(--space-2);
  }
  .members-v2__heading {
    font-size: clamp(1.8rem, 9vw, 2.6rem);
  }
  .members-v2__sub {
    font-size: 0.85rem;
  }
  .members-v2__action {
    margin-top: var(--space-8);
  }
  .members-v2__btn {
    padding: var(--space-3) var(--space-6);
    font-size: 0.9rem;
  }

  /* Banners (Career Path) */
  .section--banners {
    padding-top: var(--space-10);
    padding-bottom: var(--space-10);
  }
  .section--banners .container {
    padding: 0 var(--space-4);
  }
}

@media (max-width: 479px) {
  .section--members-v2 {
    padding: var(--space-10) 0;
  }
  .members-v2__container {
    padding: 0 var(--space-3);
  }
  .members-v2__heading {
    font-size: clamp(1.6rem, 10vw, 2.2rem);
  }
}
