@import url("https://fonts.googleapis.com/css2?family=Zen+Maru+Gothic:wght@400;500;700&display=swap");
@import url(/assets/components-22eca725eb3577494ec7d5d4290e59b4f4086d605940ddd7b3143baabbd5849d.css);
@import url(/assets/components/_stat_card-908904f4d9cbbc059971fe5f189e1de1191821d97ebd52ff8240a70da4606e20.css);
@import url(/assets/components/_unit_stats-5af9f9d79cb965c385f56ddfed122e176b2b7a96449edfa9972ee294b4660a32.css);
@import url(/assets/components/_recent_records-dbdcf4de69ecf2f1b0b01cc8bb99936c62ac39feac452b566a2b3e3df57d95de.css);
@import url(/assets/components/_confetti-9b3fe85ab4fd35bd8f03066a587e2ef33dc41668811fb66bec4d6d2f07b4ca98.css);
@import url(/assets/login_page-fc2d7cb06943d4be845fa687026b015f0fec13ee87ffa10d26b94150b556f7b4.css);
@import url(/assets/big_button-9381d50a1791349b1e2184d238a00645b11aa4e4c75fb5589aa71fceb3660d4d.css);
@import url(/assets/home_page-ba2727aba1bcc45e5e720a689d012665bc2b17b75c9da5735da4a44a1e346af4.css);
@import url(/assets/subject_card-1f99f0f462091a6597ee5aa11c6450cc2b5654d54ed39be5259dbc8d6fbeadb4.css);
@import url(/assets/progress_bar-30a169e72b18f7a1201bca6baf007a306eb5016411b19c8aefb6caa39ca47c9d.css);
@import url(/assets/subject_page-8025fd1826ed23c313e38d85c0d76381d10d1f6769885f7af806dbec4c26b9de.css);
@import url(/assets/quiz_page-bb3e009b1b22e4ed3a5a83c198d29a447b9c2c6694befebc90d8fd83a460d1d6.css);
@import url(/assets/my_page-49cf2e5baaac1a9b7982f32a570cebec4f190c5e8417b7ec7969411635e2802e.css);
@import url(/assets/badge_icon-acce34812dbbef5a3ad2c3dfb00e2b2ba5453e892742daa8c7b6b073b81dcaee.css);
@import url(/assets/teacher_dashboard-276bf7bd45a5d19d73f6668a812b6f052cca78ae1df9f3c7a85883d9a296edbb.css);
@import url(/assets/dashboard_page-ab2ab7c06fc8898919427a8d9532706cc29feb51cf03b98a93f678fb400c627e.css);

/* ==============================================
   小学生向け学習アプリ - デザインシステム
   ============================================== */

/* --- CSS Custom Properties (デザイントークン) --- */
:root {
  /* 
   * カラースキーム: パステル & フレンドリー
   * 【設計意図】
   * 小学生が直感的に「安全・楽しい」と感じる彩度の高いパステルカラーを中心とし、
   * 「国語(赤系)」「算数(青系)」といった学校でよく使われる色分けを踏襲することで認知負荷を下げる。
   */
  --color-primary: #ff9f43; /* あたたかみのあるオレンジ */
  --color-primary-light: #feca57; /* 明るいイエロー */
  --color-primary-dark: #ee7b30;

  --color-kokugo: #ff6b81; /* 国語: ピンク系 */
  --color-kokugo-light: #ffb3c1;
  --color-kokugo-bg: #fff0f3;

  --color-sansu: #54a0ff; /* 算数: 水色系 */
  --color-sansu-light: #a3d5ff;
  --color-sansu-bg: #eff8ff;

  --color-success: #2ed573; /* 正解 */
  --color-success-light: #7bed9f;
  --color-error: #ff6b6b; /* 不正解 */
  --color-error-light: #ff9f9f;

  /*
   * フィードバックモーダル用のセマンティックカラー
   * 正解時は安心感のある緑系、不正解時は注意を促すアンバー系。
   * Tailwind の green-100/300/700, amber-100/300/700 相当。
   */
  --color-success-bg: #f0fdf4;
  --color-success-border: #bbf7d0;
  --color-success-fg: #166534;
  --color-warning-bg: #fffbeb;
  --color-warning-border: #fde68a;
  --color-warning-fg: #b45309;

  --color-bg: #fffdf7; /* 背景: やわらかいクリーム */
  --color-bg-card: #ffffff;
  --color-text: #2d3436;
  --color-text-light: #636e72;
  --color-border: #dfe6e9;

  --color-xp: #f9ca24;
  --color-badge: #6c5ce7;

  /* 
   * タイポグラフィ: 丸ゴシック系
   * 【設計意図】
   * 角張ったフォント（明朝体や角ゴシック）を避け、ひらがなが最も柔らかく自然に読める「丸ゴシック」を優先的に指定。
   */
  --font-family:
    "Zen Maru Gothic", "M PLUS Rounded 1c", "Hiragino Maru Gothic ProN",
    sans-serif;
  --font-size-xs: 0.75rem;
  --font-size-sm: 0.875rem;
  --font-size-base: 1rem;
  --font-size-lg: 1.25rem;
  --font-size-xl: 1.5rem;
  --font-size-2xl: 2rem;
  --font-size-3xl: 2.5rem;

  /* スペーシング */
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 32px;
  --space-2xl: 48px;

  /* ボーダー */
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 20px;
  --radius-full: 9999px;

  /* シャドウ */
  --shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.06);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.1);
  --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.12);

  /* 
   * タッチ操作: 最小タップ領域
   * 【設計意図】
   * iPadやChromebookなどの学校支給タブレットでのタッチ操作を前提としている。
   * 指で押し間違えないよう、標準タップ領域（44px）以上を確保し、推奨値（60px）をメインに使用。
   */
  --tap-min: 44px;
  --tap-recommended: 60px;

  /* アニメーション */
  --transition-fast: 150ms ease;
  --transition-normal: 250ms ease;
  --transition-slow: 400ms ease;
}

/* --- リセット & ベース --- */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-family);
  font-size: var(--font-size-lg);
  color: var(--color-text);
  background-color: var(--color-bg);
  line-height: 1.7;
  min-height: 100dvh;
  -webkit-tap-highlight-color: transparent;

  /* タブレットスクロール最適化 */
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

/* --- ルビ (ふりがな) スタイル --- */
ruby {
  ruby-align: center;
}

rt {
  font-size: var(--font-size-xs);
  color: var(--color-text-light);
}

/* --- ボタン基本スタイル --- */
button {
  font-family: var(--font-family);
  font-size: var(--font-size-lg);
  cursor: pointer;
  border: none;
  outline: none;
  min-height: var(--tap-recommended);
  min-width: var(--tap-recommended);
  padding: var(--space-sm) var(--space-lg);
  border-radius: var(--radius-md);
  transition:
    transform var(--transition-fast),
    box-shadow var(--transition-fast);
  -webkit-user-select: none;
  user-select: none;
}

button:active {
  transform: scale(0.95) translateY(2px);
}

/* --- リンク --- */
a {
  color: var(--color-primary);
  text-decoration: none;
}

:where(a, button, input, select, textarea, [tabindex]):focus-visible {
  outline: 4px solid var(--color-primary-dark);
  outline-offset: 4px;
  box-shadow: 0 0 0 6px rgba(254, 202, 87, 0.45);
}

/* --- カードベース --- */
.card {
  background: var(--color-bg-card);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  padding: var(--space-lg);
}

/* --- ユーティリティ --- */
.text-center {
  text-align: center;
}

.flex-center {
  display: flex;
  justify-content: center;
  align-items: center;
}

.gap-sm {
  gap: var(--space-sm);
}

.gap-md {
  gap: var(--space-md);
}

.gap-lg {
  gap: var(--space-lg);
}
