/* ================================================================
   NOBATASU GYM Brand トークン — "放課後の遊び場"
   ----------------------------------------------------------------
   variables.css（Foundation）の直後・base.css の前に読み込むこと。
   各ゲーム CSS は --gym-* 経由で色・装飾・タイポを参照する。

   設計原則:
     - Foundation（--primary-color 等）は再定義しない
     - Brand 層は完全に gym 独自・tools と同期しない
     - 視覚予算は「色」「装飾アクセント」「タイポ」の3軸に集中
   ================================================================ */

/* ----- Section 1: Brand Tokens ----- */
:root {
  /* === Color tokens === */
  /* Foundation 継承（参照用エイリアス） */
  --gym-color-primary:   var(--primary-color);     /* #006064 */
  --gym-color-secondary: var(--secondary-color);   /* #00838F */
  --gym-color-success:   var(--success-color);
  --gym-color-error:     var(--danger-color);
  --gym-color-text-strong: #1A1A1A;

  /* Brand 独立色 — "放課後の遊び場" */
  --gym-color-accent-warm:  #FF8A65;   /* 夕焼けオレンジ — 祝祭・NEW・ハイライト */
  --gym-color-accent-warm-2: #FFAB40;  /* 夕焼けオレンジ（明） — グラデ用相方 */
  --gym-color-accent-pop:   #FFD54F;   /* 駄菓子屋イエロー — コンボ・フィーバー */
  --gym-color-accent-pop-2: #FFEE58;   /* 駄菓子屋イエロー（明） */
  --gym-color-accent-fresh:  #80DEEA;  /* プールサイドのシアン — 既存 alphabet-touch 流用 */
  --gym-color-accent-fresh-2: #B2EBF2; /* プールサイドのシアン（淡） */
  --gym-color-accent-fresh-3: #E0F7FA; /* プールサイドのシアン（最淡・面） */

  --gym-color-text-soft: #6D5D4B;      /* セピア — "黒" より温度を上げる */

  /* 背景 */
  --gym-color-bg-base: #FFF8E7;        /* 紙質ベージュ（variables.css の --background-color と同値） */
  --gym-color-bg-playground:
    linear-gradient(160deg, #FFF8E7 0%, #FFE0B2 50%, #FFCCBC 100%);  /* 夕焼けグラデ */
  --gym-color-bg-fresh:
    linear-gradient(160deg, #E0F7FA 0%, #B2EBF2 60%, #80DEEA 100%);  /* プールサイドグラデ */

  /* === Typography tokens === */
  --gym-font-display: 'Fredoka', 'Nunito', 'Quicksand',
                      'Hiragino Maru Gothic ProN', 'Hiragino Kaku Gothic ProN',
                      'Noto Sans JP', sans-serif;
  --gym-font-numeric: 'Nunito', 'Segoe UI', sans-serif;  /* tabular-nums と相性良 */

  /* === Shadow tokens === */
  --gym-shadow-sticker:
    2px 3px 0 rgba(0, 0, 0, 0.18),
    0 4px 12px rgba(0, 0, 0, 0.08);   /* オフセット強めのコミック調 */
  --gym-shadow-sticker-soft:
    1px 2px 0 rgba(0, 0, 0, 0.12),
    0 2px 6px rgba(0, 0, 0, 0.06);    /* カード等の控えめ版 */

  /* === Radius tokens === */
  --gym-radius: var(--border-radius);                /* 8px — Foundation 継承 */
  --gym-radius-large: var(--border-radius-large);    /* 12px */
  --gym-radius-pill: 999px;                          /* バッジ・ピル形状 */

  /* === Motion tokens === */
  --gym-motion-fast:   120ms cubic-bezier(0.4, 0, 0.2, 1);
  --gym-motion-medium: 300ms cubic-bezier(0.34, 1.56, 0.64, 1);   /* オーバーシュート */
  --gym-motion-pop:    500ms cubic-bezier(0.34, 1.56, 0.64, 1);   /* リザルト・New Best */
  --gym-motion-idle:   2.4s ease-in-out infinite alternate;       /* "場の生気" */
}

/* ----- Section 2: Brand Utility Classes ----- */

/* ステッカー風影 — どんな要素にも貼れば "シールっぽい" 質感が出る */
.gym-sticker {
  box-shadow: var(--gym-shadow-sticker);
}

.gym-sticker--soft {
  box-shadow: var(--gym-shadow-sticker-soft);
}

/* ディスプレイテキスト — タイトルや大見出し */
.gym-pop-text {
  font-family: var(--gym-font-display);
  font-weight: 800;
  letter-spacing: 0.5px;
}

/* 夕焼けグラデ背景 */
.gym-bg-playground {
  background: var(--gym-color-bg-playground);
}

/* プールサイドグラデ背景 */
.gym-bg-fresh {
  background: var(--gym-color-bg-fresh);
}

/* "NEW!" 等のポップバッジ */
.gym-pop-badge {
  display: inline-block;
  padding: 4px 12px;
  background: linear-gradient(135deg, var(--gym-color-accent-pop), var(--gym-color-accent-warm));
  color: var(--white);
  font-family: var(--gym-font-display);
  font-weight: 800;
  font-size: 14px;
  letter-spacing: 1px;
  border-radius: var(--gym-radius-pill);
  box-shadow: var(--gym-shadow-sticker-soft);
}

/* ----- Section 3: Reduced Motion 配慮 ----- */
@media (prefers-reduced-motion: reduce) {
  :root {
    --gym-motion-fast:   0.01ms linear;
    --gym-motion-medium: 0.01ms linear;
    --gym-motion-pop:    0.01ms linear;
    --gym-motion-idle:   0.01ms linear;
  }
}
