/* ============================================
   ABOUT PAGE — concrete-jungle.jp
   Depends on: tokens.css, base.css
   ============================================ */

/* === MAGIC HOUR BACKGROUND === */
.about-bg {
  position: fixed;
  inset: 0;
  z-index: -2;
  background: linear-gradient(
    180deg,
    #0b0d1a 0%,        /* 夜空（上部） */
    #141833 15%,
    #1e2455 30%,        /* 深い藍色 */
    #3a2866 45%,        /* 紫がかった空 */
    #6b3a7a 55%,        /* マゼンタ・パープル */
    #c44e5e 68%,        /* 夕焼けのローズ */
    #e87a4f 78%,        /* オレンジ */
    #f5a64b 88%,        /* ゴールド */
    #f0c76e 100%        /* 地平線のアンバー */
  );
  pointer-events: none;
}

/* ABOUTページのbody背景を透過してマジックアワーを見せる */
body:has(.about-bg) {
  background-color: transparent;
}

/* 各セクションを半透明にしてグラデーションを透かす */
body:has(.about-bg) .section,
body:has(.about-bg) .main-content {
  background: transparent;
}

/* === PAGE HERO === */
.about-hero {
  padding: var(--space-xl) 0 var(--space-lg);
  text-align: center;
  position: relative;
}

.about-hero__concept {
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 3vw, 2rem);
  font-weight: 700;
  letter-spacing: var(--ls-wide);
  color: var(--color-neon-cyan);
  text-shadow: var(--color-glow-cyan);
  margin-bottom: var(--space-sm);
}

.about-hero__concept-sub {
  font-family: var(--font-mono);
  font-size: var(--fs-small);
  color: var(--color-text-muted);
  letter-spacing: var(--ls-ultra);
  text-transform: uppercase;
}

/* === SECTION COMMON === */
.about-section {
  padding: var(--space-xl) 0;
  position: relative;
}

.about-section + .about-section {
  border-top: 1px solid var(--color-border);
}

.about-section__label {
  display: block;
  font-family: var(--font-mono);
  font-size: var(--fs-small);
  letter-spacing: var(--ls-ultra);
  text-transform: uppercase;
  margin-bottom: var(--space-sm);
}

.about-section__title {
  font-family: var(--font-heading);
  font-size: clamp(1.5rem, 4vw, 2.5rem);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  line-height: var(--lh-tight);
  margin-bottom: var(--space-md);
}

.about-section__subtitle {
  font-family: var(--font-jp);
  font-size: var(--fs-subtitle);
  color: var(--color-text-muted);
  margin-bottom: var(--space-lg);
  line-height: var(--lh-relaxed);
}

.about-section__body {
  font-family: var(--font-jp);
  font-size: var(--fs-body);
  color: var(--color-text-muted);
  line-height: var(--lh-relaxed);
  max-width: 750px;
}

/* === NEWSPAPER GRID === */
.vmv-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
  gap: var(--space-xl);
  margin-top: var(--space-lg);
  perspective: 1200px;
}

/* === NEWSPAPER CARD (AMERICAN BROADSHEET) === */
.vmv-card {
  position: relative;
  background: #f5f0e8;
  background-image:
    /* 新聞紙のザラつき（ノイズ） */
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%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.06'/%3E%3C/svg%3E"),
    /* 薄い経年変化のグラデーション */
    linear-gradient(170deg, #f8f3eb 0%, #efe8d8 60%, #e8dcc8 100%);
  border: none;
  border-radius: 2px;
  padding: 0;
  overflow: visible;
  color: #1a1a1a;
  box-shadow:
    4px 6px 20px rgba(0, 0, 0, 0.25),
    1px 1px 3px rgba(0, 0, 0, 0.1);
  /* SVGフィルターで紙のうねりを適用 */
  filter: url(#paper-wave-1);
  transition: box-shadow var(--duration-normal), filter var(--duration-normal);
}

.vmv-card:nth-child(2) {
  filter: url(#paper-wave-2);
}

.vmv-card:hover {
  box-shadow:
    6px 10px 30px rgba(0, 0, 0, 0.35),
    2px 2px 6px rgba(0, 0, 0, 0.15);
  /* ホバー時は波が穏やかになる */
  filter: url(#paper-wave-calm);
}

/* カラーアクセントライン除去 */
.vmv-card::before {
  display: none;
}

/* 新聞紙の端の折れ・しわ（右下角） */
.vmv-card::after {
  content: '';
  position: absolute;
  bottom: 0;
  right: 0;
  width: 40px;
  height: 40px;
  background: linear-gradient(
    225deg,
    #ddd5c4 0%,
    #e8e0d0 45%,
    transparent 50%
  );
  box-shadow: -2px -2px 4px rgba(0, 0, 0, 0.06);
  pointer-events: none;
}

/* 新聞マストヘッド（タイトルエリア） */
.vmv-card__masthead {
  padding: 20px 24px 12px;
  border-bottom: 3px double #1a1a1a;
  text-align: center;
}

.vmv-card__edition {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-family: 'Georgia', 'Times New Roman', serif;
  font-size: 0.65rem;
  color: #666;
  margin-bottom: 6px;
  letter-spacing: 0.05em;
}

.vmv-card__icon {
  font-size: 1.4rem;
  margin-bottom: 4px;
}

.vmv-card__title {
  font-family: 'Georgia', 'Times New Roman', serif;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 700;
  color: #1a1a1a;
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin-bottom: 2px;
  text-shadow: none;
}

.vmv-card__title-en {
  font-family: 'Georgia', 'Times New Roman', serif;
  font-size: 0.7rem;
  font-style: italic;
  color: #888;
  margin-bottom: 0;
  letter-spacing: 0.08em;
}

/* 新聞の本文エリア（2カラム） */
.vmv-card__article {
  padding: 16px 24px 24px;
}

.vmv-card__headline {
  font-family: 'Georgia', 'Times New Roman', serif;
  font-size: clamp(0.95rem, 1.5vw, 1.15rem);
  font-weight: 700;
  color: #1a1a1a;
  line-height: 1.3;
  margin-bottom: 10px;
  border-bottom: 1px solid #ccc;
  padding-bottom: 8px;
}

.vmv-card__body {
  font-family: 'Georgia', 'Times New Roman', serif;
  font-size: 0.82rem;
  color: #333;
  line-height: 1.7;
  column-count: 2;
  column-gap: 20px;
  column-rule: 1px solid #ddd;
  text-align: justify;
  hyphens: auto;
}

.vmv-card__body .drop-cap:first-letter {
  float: left;
  font-size: 3em;
  line-height: 0.8;
  padding-right: 6px;
  padding-top: 4px;
  font-weight: 700;
  color: #1a1a1a;
}

/* === VALUES LIST === */
.values-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
  margin-top: var(--space-lg);
}

.values-item {
  display: flex;
  gap: var(--space-lg);
  align-items: flex-start;
  padding: var(--space-lg);
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  transition: border-color var(--duration-normal);
}

.values-item:hover {
  border-color: rgba(255, 255, 255, 0.15);
}

.values-item__number {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: var(--fw-black);
  color: var(--color-bg-elevated);
  line-height: 1;
  flex-shrink: 0;
  min-width: 50px;
  text-align: center;
  -webkit-text-stroke: 1px var(--color-neon-purple);
}

.values-item__content {
  flex: 1;
}

.values-item__title {
  font-family: var(--font-heading);
  font-size: clamp(1rem, 2vw, 1.2rem);
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-xs);
  color: var(--color-text-primary);
}

.values-item__title-en {
  font-family: var(--font-mono);
  font-size: var(--fs-small);
  color: var(--color-neon-purple);
  margin-bottom: var(--space-sm);
}

.values-item__body {
  font-family: var(--font-jp);
  font-size: var(--fs-body);
  color: var(--color-text-muted);
  line-height: var(--lh-relaxed);
}

/* === STORY SECTIONS (Origin / Philosophy / Identity) === */
.story-block {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: var(--space-lg);
  padding: var(--space-lg) 0;
}

.story-block + .story-block {
  border-top: 1px solid var(--color-border);
}

.story-block__tag {
  font-family: var(--font-display);
  font-size: 0.7rem;
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-ultra);
  text-transform: uppercase;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  color: var(--color-text-muted);
  justify-self: center;
  padding-top: var(--space-sm);
}

.story-block__content {
  /* inherit */
}

.story-block__title {
  font-family: var(--font-heading);
  font-size: clamp(1.2rem, 2.5vw, 1.6rem);
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-xs);
  color: var(--color-text-primary);
  line-height: var(--lh-tight);
}

.story-block__title-sub {
  font-family: var(--font-jp);
  font-size: var(--fs-body);
  color: var(--color-text-muted);
  margin-bottom: var(--space-lg);
}

.story-block__body {
  font-family: var(--font-jp);
  font-size: var(--fs-body);
  color: var(--color-text-muted);
  line-height: var(--lh-relaxed);
}

.story-block__body p + p {
  margin-top: var(--space-md);
}

/* === STUDIO INFO CARD === */
.studio-info {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
  margin-top: var(--space-lg);
  padding: var(--space-lg);
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}

.studio-info__item {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.studio-info__label {
  font-family: var(--font-mono);
  font-size: var(--fs-small);
  color: var(--color-text-muted);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}

.studio-info__value {
  font-family: var(--font-jp);
  font-size: var(--fs-body);
  color: var(--color-text-primary);
}

/* === RESPONSIVE === */
@media (max-width: 768px) {
  .story-block {
    grid-template-columns: 1fr;
    gap: var(--space-md);
  }

  .story-block__tag {
    writing-mode: horizontal-tb;
    justify-self: start;
  }

  .values-item {
    flex-direction: column;
    gap: var(--space-md);
  }

  .values-item__number {
    min-width: auto;
    text-align: left;
  }

  .studio-info {
    grid-template-columns: 1fr;
  }
}
