/* ================================
   Custom Properties (Life Span)
   ================================ */

:root {
  /* Life Span 基本カラー（Color.kt 準拠） */
  --ls-color-dark-gray: #333;
  --ls-color-light-gray: #e6e6e6;
  --ls-color-coral-red: #ff8066;
  --ls-color-white: #fff;
  --ls-color-error: #f00;

  /* Life Span セマンティックトークン（Light テーマ既定） */
  --ls-bg-primary: var(--ls-color-light-gray);
  --ls-surface: var(--ls-color-light-gray);
  --ls-fg-primary: var(--ls-color-dark-gray);
  --ls-fg-dim: #6b6b6b;
  --ls-primary: var(--ls-color-dark-gray);
  --ls-on-primary: var(--ls-color-white);
  --ls-accent: var(--ls-color-coral-red);
  --ls-on-accent: var(--ls-color-white);
  --ls-border: #c8c0b0;

  /* Life Span スペーシング（4px グリッド） */
  --ls-space-xs: 4px;
  --ls-space-sm: 8px;
  --ls-space-md: 16px;
  --ls-space-lg: 24px;
  --ls-space-xl: 32px;
  --ls-screen-padding: 16px;

  /* Life Span 形状（角丸） */
  --ls-radius-sm: 4px;
  --ls-radius-md: 8px;
  --ls-radius-lg: 16px;

  /* Life Span フォント */
  --ls-font-numeric: 'Bitcount Single', system-ui, sans-serif;
  --ls-font-ui: 'Noto Sans', system-ui, sans-serif;

  /* サイト共通トークンの上書き（Life Span 値に置換） */
  --bg-primary: var(--ls-bg-primary);
  --fg-primary: var(--ls-fg-primary);
  --fg-dim: var(--ls-fg-dim);
  --accent: var(--ls-accent);
  --bd-primary: var(--ls-border);
  --bd-accent: var(--ls-accent);
  --font-primary: var(--ls-font-ui);
}

/* OS Dark 連動（手動 Light 上書き時は除外） */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme='light']) {
    --ls-bg-primary: var(--ls-color-dark-gray);
    --ls-surface: var(--ls-color-dark-gray);
    --ls-fg-primary: var(--ls-color-light-gray);
    --ls-fg-dim: #a09882;
    --ls-primary: var(--ls-color-light-gray);
    --ls-on-primary: var(--ls-color-dark-gray);
    --ls-border: #4a4a4a;
    --bg-primary: var(--ls-bg-primary);
    --fg-primary: var(--ls-fg-primary);
    --fg-dim: var(--ls-fg-dim);
    --bd-primary: var(--ls-border);
  }
}

/* 手動 Dark 上書き */
[data-theme='dark'] {
  --ls-bg-primary: var(--ls-color-dark-gray);
  --ls-surface: var(--ls-color-dark-gray);
  --ls-fg-primary: var(--ls-color-light-gray);
  --ls-fg-dim: #a09882;
  --ls-primary: var(--ls-color-light-gray);
  --ls-on-primary: var(--ls-color-dark-gray);
  --ls-border: #4a4a4a;
  --bg-primary: var(--ls-bg-primary);
  --fg-primary: var(--ls-fg-primary);
  --fg-dim: var(--ls-fg-dim);
  --bd-primary: var(--ls-border);
}

/* 手動 Light 上書き（OS Dark 時の強制 Light 用） */
[data-theme='light'] {
  --ls-bg-primary: var(--ls-color-light-gray);
  --ls-surface: var(--ls-color-light-gray);
  --ls-fg-primary: var(--ls-color-dark-gray);
  --ls-fg-dim: #6b6b6b;
  --ls-primary: var(--ls-color-dark-gray);
  --ls-on-primary: var(--ls-color-white);
  --ls-border: #c8c0b0;
  --bg-primary: var(--ls-bg-primary);
  --fg-primary: var(--ls-fg-primary);
  --fg-dim: var(--ls-fg-dim);
  --bd-primary: var(--ls-border);
}

/* ================================
   ロケール別フォント切替
   ================================ */

:lang(en) {
  --ls-font-ui: 'Noto Sans', system-ui, sans-serif;
  --font-primary: var(--ls-font-ui);
}

:lang(ja) {
  --ls-font-ui: 'Noto Sans JP', 'Noto Sans', system-ui, sans-serif;
  --font-primary: var(--ls-font-ui);
}

:lang(ko) {
  --ls-font-ui: 'Noto Sans KR', 'Noto Sans', system-ui, sans-serif;
  --font-primary: var(--ls-font-ui);
}

:lang(zh) {
  --ls-font-ui: 'Noto Sans SC', 'Noto Sans', system-ui, sans-serif;
  --font-primary: var(--ls-font-ui);
}

:lang(zh-TW) {
  --ls-font-ui: 'Noto Sans TC', 'Noto Sans', system-ui, sans-serif;
  --font-primary: var(--ls-font-ui);
}

/* ================================
   Component Override: Select
   ================================ */

/* セレクトの下矢印を Life Span アクセント（コーラルレッド）に変更 */
.c-select__control {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5'%3E%3Cpath fill='%23FF8066' d='M0 0l4 5 4-5z'/%3E%3C/svg%3E");
}

/* ================================
   Component Override: Brand
   ================================ */

/* Noto Sans に合わせて letter-spacing を緩める */
.c-brand__text {
  letter-spacing: 0;
}

/* ================================
   Project: Life Span Privacy
   ================================ */

.p-life-span-privacy {
  max-width: 720px;
  padding: var(--ls-space-lg) var(--ls-screen-padding);
  margin: 0 auto;
  color: var(--ls-fg-primary);
}

@media (width >= 960px) {
  .p-life-span-privacy {
    padding-right: var(--ls-space-lg);
    padding-left: var(--ls-space-lg);
  }
}

/* 各セクションを Life Span ニューモーフィックカードとして表現（B案） */
.p-life-span-privacy__intro,
.p-life-span-privacy__section,
.p-life-span-privacy__meta {
  padding: clamp(20px, 3vw, 32px);
  margin-bottom: var(--ls-space-lg);
  background: var(--ls-surface);
  border-radius: var(--ls-radius-md);
  box-shadow:
    6px 6px 16px rgb(0 0 0 / 20%),
    -6px -6px 16px rgb(255 255 255 / 70%);
}

.p-life-span-privacy > *:last-child {
  margin-bottom: 0;
}

/* OS Dark 連動時のカード影調整 */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme='light']) .p-life-span-privacy__intro,
  :root:not([data-theme='light']) .p-life-span-privacy__section,
  :root:not([data-theme='light']) .p-life-span-privacy__meta {
    box-shadow:
      6px 6px 16px rgb(0 0 0 / 40%),
      -6px -6px 16px rgb(255 255 255 / 10%);
  }
}

/* 手動 Dark 時のカード影 */
[data-theme='dark'] .p-life-span-privacy__intro,
[data-theme='dark'] .p-life-span-privacy__section,
[data-theme='dark'] .p-life-span-privacy__meta {
  box-shadow:
    6px 6px 16px rgb(0 0 0 / 40%),
    -6px -6px 16px rgb(255 255 255 / 10%);
}

.p-life-span-privacy__title {
  margin-bottom: var(--ls-space-md);
  font-family: var(--ls-font-ui);
  font-size: clamp(28px, 4vw, 36px);
  font-weight: 700;
  line-height: 1.3;
  color: var(--ls-fg-primary);
}

.p-life-span-privacy__lead {
  margin-bottom: var(--ls-space-sm);
  font-family: var(--ls-font-ui);
  font-size: 16px;
  font-weight: 700;
  line-height: 1.7;
  color: var(--ls-fg-primary);
}

.p-life-span-privacy__heading {
  margin-bottom: var(--ls-space-md);
  font-family: var(--ls-font-ui);
  font-size: 20px;
  font-weight: 700;
  line-height: 1.4;
  color: var(--ls-fg-primary);
}

.p-life-span-privacy__subheading {
  margin-top: var(--ls-space-md);
  margin-bottom: var(--ls-space-sm);
  font-family: var(--ls-font-ui);
  font-size: 17px;
  font-weight: 700;
  line-height: 1.5;
  color: var(--ls-fg-primary);
}

.p-life-span-privacy__text {
  margin-bottom: var(--ls-space-sm);
  font-family: var(--ls-font-ui);
  font-size: 16px;
  font-weight: 700;
  line-height: 1.7;
  color: var(--ls-fg-primary);
}

.p-life-span-privacy__list {
  padding-left: 1.5em;
  margin-bottom: var(--ls-space-sm);
  list-style: disc;
}

.p-life-span-privacy__list li {
  margin-bottom: var(--ls-space-xs);
  font-family: var(--ls-font-ui);
  font-size: 16px;
  font-weight: 700;
  line-height: 1.7;
  color: var(--ls-fg-primary);
}

.p-life-span-privacy__link {
  color: var(--ls-accent);
  text-decoration: underline;
  transition: opacity var(--transition-base);
}

.p-life-span-privacy__link:hover {
  opacity: 0.85;
}

.p-life-span-privacy__link:focus-visible {
  outline: 2px solid var(--ls-accent);
  outline-offset: 2px;
}

.p-life-span-privacy__effective {
  margin-bottom: var(--ls-space-md);
  font-family: var(--ls-font-ui);
  font-size: 14px;
  font-weight: 700;
  color: var(--ls-fg-dim);
}

.p-life-span-privacy__copyright {
  font-family: var(--ls-font-ui);
  font-size: 14px;
  font-weight: 700;
  color: var(--ls-fg-dim);
}

/* ================================
   Footer Override: l-footer__copy 内のリンク色を Life Span アクセントに揃える
   （既存ロジックを踏襲しつつ、テキスト・リンクの可読性を確保）
   ================================ */

.l-footer__copy {
  font-family: var(--ls-font-ui);
}
