/* =========================================================================
   Design Tokens — AI-1 GRANDPRIX Podcast
   可愛い × モダンミニマル。外部依存なし (CSP self 遵守)。
   ========================================================================= */

:root {
  /* Canvas */
  --bg: #fbf7f2;
  --bg-soft: #f3ece2;
  --bg-panel: #ffffff;
  --bg-elevated: #fffdf9;

  /* Ink */
  --fg: #2a2438;
  --fg-soft: #3a3449;
  --muted: #6b6476;
  --muted-strong: #524c5e;
  --line: #e8dfd2;
  --line-soft: #f0e9dd;

  /* Accents */
  --pink: #ff8fa3;
  --pink-soft: #ffe1e7;
  --lav: #b9a7f0;
  --lav-soft: #e9e3fb;
  --mint: #88d8b0;
  --mint-soft: #dff5ea;
  --peach: #ffc3a0;
  --peach-soft: #ffe6d6;
  --yellow: #ffe066;
  --yellow-soft: #fff6cc;

  /* Semantic (defaults; genre variants override) */
  --accent: var(--pink);
  --accent-soft: var(--pink-soft);

  /* Radii */
  --r-xs: 6px;
  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 22px;
  --r-xl: 28px;
  --r-pill: 999px;

  /* Shadows */
  --shadow-soft: 0 10px 30px -16px rgba(42, 36, 56, 0.22);
  --shadow-card: 0 14px 36px -22px rgba(42, 36, 56, 0.28);
  --shadow-pop: 0 18px 40px -20px rgba(255, 143, 163, 0.35);
  --shadow-hero: 0 30px 80px -40px rgba(42, 36, 56, 0.35);

  /* Motion */
  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-squish: cubic-bezier(0.6, -0.05, 0.2, 1.3);
  --dur-fast: 180ms;
  --dur-med: 280ms;
  --dur-slow: 520ms;

  /* Fonts (self only; 日本語はシステム。欧文はシステムの丸っこい系を優先) */
  --font-jp: "Hiragino Maru Gothic ProN", "Hiragino Sans", "Yu Gothic UI",
    "Meiryo", "Segoe UI", system-ui, sans-serif;
  --font-body: var(--font-jp);
  --font-display: "Avenir Next Rounded", "Hiragino Maru Gothic ProN",
    "Yu Gothic UI", system-ui, sans-serif;

  /* Layout */
  --page-max: 1040px;
  --page-gutter: clamp(1rem, 4vw, 2.2rem);
}

/* Genre-specific accent overrides: put on any ancestor. */
[data-genre="manzai"] {
  --accent: var(--peach);
  --accent-soft: var(--peach-soft);
  --mimi-body: var(--peach);
  --mimi-body-soft: var(--peach-soft);
}
[data-genre="r1"] {
  --accent: var(--mint);
  --accent-soft: var(--mint-soft);
  --mimi-body: var(--mint);
  --mimi-body-soft: var(--mint-soft);
}
[data-genre="radio"] {
  --accent: var(--lav);
  --accent-soft: var(--lav-soft);
  --mimi-body: var(--lav);
  --mimi-body-soft: var(--lav-soft);
}
