/* =================================================================
 * NetChai 子供向け（小学生）中国語教材 ― 共有スタイル
 * Design: X6a（Kawaii × スカイブルー水色 × 星きらきらヘッダー）
 *   ・成人版デザイン候補 X6a を、子供向け教材用に独立CSS化したもの
 *   ・全レッスン・はじめにページが共通で読み込む
 * 方針: 全漢字ふりがな（rt.jp）／中国語はピンインのみ（カタカナ読み禁止）
 * ================================================================= */

:root{
  --Xp:#cfe9ff;   /* 水色（吹き出し・帯） */
  --Xpd:#4a90e2;  /* スカイブルー（メイン） */
  --Xy:#fffae0;   /* 淡い黄 */
  --Xb:#ffd6e7;   /* ピンク */
  --Xv:#e0f4ff;   /* 薄水色 */
  --Xk:#1e3a8a;   /* ネイビー（文字） */
  --Xpink:#ff85a2;/* 濃いピンク（アクセント） */
  --Xpaper:#f3f9ff;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:linear-gradient(180deg,#eaf4ff 0%,#fafdff 100%);min-height:100vh;-webkit-font-smoothing:antialiased}

body{
  font-family:"Hiragino Maru Gothic ProN","Kosugi Maru","Hiragino Kaku Gothic ProN","Meiryo",sans-serif;
  color:var(--Xk);line-height:1.85;
}

/* ── ページの台紙 ── */
.page{
  max-width:880px;margin:28px auto;background:#fff;
  border-radius:24px;overflow:hidden;
  box-shadow:0 14px 40px rgba(74,144,226,.18);
  border:2px solid var(--Xv);
}

/* ── ふりがな（日本語ルビ）と ピンイン（中国語ルビ）の区別 ── */
/* 日本語の漢字につける ふりがな：黒・小さめ */
ruby rt.jp{font-size:.52em;color:#555;font-weight:600;letter-spacing:.02em}
/* 中国語につける ピンイン：スカイブルー・少し大きめ（各セクションで上書き） */
.zh ruby rt,.bubble ruby rt,.k-zh ruby rt,.k-dia .who ruby rt{color:var(--Xpd);font-weight:800;letter-spacing:.01em}
.k-dia .who ruby rt{font-size:13px}

/* ============================ ヘッダー ============================ */
.k-head{
  padding:34px 32px 30px;text-align:center;position:relative;
  border-bottom:4px solid var(--Xpd);
  background:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23ffffff' d='M12 2 L14.4 9.4 L22 9.4 L15.8 13.9 L18.2 21.2 L12 16.6 L5.8 21.2 L8.2 13.9 L2 9.4 L9.6 9.4 Z'/></svg>") 9% 26% / 22px no-repeat,
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23fff4b8' d='M12 2 L14.4 9.4 L22 9.4 L15.8 13.9 L18.2 21.2 L12 16.6 L5.8 21.2 L8.2 13.9 L2 9.4 L9.6 9.4 Z'/></svg>") 17% 78% / 14px no-repeat,
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23ffffff' d='M12 2 L14.4 9.4 L22 9.4 L15.8 13.9 L18.2 21.2 L12 16.6 L5.8 21.2 L8.2 13.9 L2 9.4 L9.6 9.4 Z'/></svg>") 87% 28% / 18px no-repeat,
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23fff4b8' d='M12 2 L14.4 9.4 L22 9.4 L15.8 13.9 L18.2 21.2 L12 16.6 L5.8 21.2 L8.2 13.9 L2 9.4 L9.6 9.4 Z'/></svg>") 78% 74% / 12px no-repeat,
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23ffffff' d='M12 2 L14.4 9.4 L22 9.4 L15.8 13.9 L18.2 21.2 L12 16.6 L5.8 21.2 L8.2 13.9 L2 9.4 L9.6 9.4 Z'/></svg>") 50% 14% / 10px no-repeat,
    linear-gradient(180deg,#bedbf5 0%,#dcecf9 60%,#f0f7fd 100%);
}
.k-head__inner{
  background:#fff;border:3px solid var(--Xpd);border-radius:24px;
  padding:18px 26px;display:inline-block;min-width:62%;position:relative;
  box-shadow:0 6px 16px rgba(74,144,226,.22);
}
.k-head__inner::before,.k-head__inner::after{
  content:"\2661";color:var(--Xpink);font-size:26px;position:absolute;top:-14px;font-weight:900;
}
.k-head__inner::before{left:-12px;transform:rotate(-12deg)}
.k-head__inner::after{right:-12px;transform:rotate(12deg)}
.k-head__label{color:var(--Xpd);font-weight:900;letter-spacing:.22em;font-size:14px}
.k-head__title{margin:8px 0 4px;font-size:34px;font-weight:900;color:var(--Xk);letter-spacing:.08em}
.k-head__title ruby rt.jp{font-size:.4em}
.k-head__cn{font-size:27px;color:var(--Xpd);font-weight:900;letter-spacing:.04em;margin-top:6px}
.k-head__cn ruby rt{font-size:.62em}

/* ============================ 本文エリア ============================ */
.k-body{padding:24px 32px 34px}

/* ── セクション見出し ── */
h2.k-h{
  margin:30px 0 16px;display:flex;align-items:center;gap:14px;
  font-size:21px;font-weight:900;color:var(--Xk);
}
h2.k-h .emoji{font-size:26px}
h2.k-h .label{background:var(--Xy);padding:5px 18px;border-radius:999px;border:2px solid var(--Xk);font-size:16px}

/* ── やさしい説明文 ── */
.k-lead{font-size:17px;line-height:1.95;margin:8px 0 16px;color:#27407a}
.k-lead strong{color:var(--Xpink)}

/* ============================ 01 あたらしいことば ============================ */
.k-tbl{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.k-tbl .w{
  padding:14px 18px;background:#fff;border:3px solid var(--Xpd);border-radius:18px;
  display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:center;position:relative;
  box-shadow:3px 4px 0 #fff5d4;
}
.k-tbl .w:nth-child(4n+2){border-color:#7cc9e8;box-shadow:3px 4px 0 var(--Xp)}
.k-tbl .w:nth-child(4n+3){border-color:#ffae5e;box-shadow:3px 4px 0 var(--Xb)}
.k-tbl .w:nth-child(4n+4){border-color:#5aa0e8;box-shadow:3px 4px 0 var(--Xv)}
.k-tbl .w .n{background:var(--Xpd);color:#fff;width:26px;height:26px;border-radius:8px;text-align:center;line-height:26px;font-weight:900;font-size:13px}
.k-tbl .w .emoji{font-size:24px}
.k-tbl .w .body{display:block}
.k-tbl .w .zh{font-size:28px;font-weight:900;color:var(--Xk);line-height:1.2}
.k-tbl .w .pinyin{display:block;font-weight:900;color:var(--Xpd);font-size:17px;margin:2px 0}
.k-tbl .w .ja{font-size:15px;font-weight:700;color:#33508c}
.k-tbl .w .ja ruby rt.jp{font-size:.5em}

/* ============================ 02 いえるかな？（文型） ============================ */
.k-ex{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.k-ex li{
  padding:18px 22px;background:#fff;border:3px solid var(--Xpd);border-radius:20px;
  display:grid;grid-template-columns:34px 1fr;gap:16px;align-items:center;position:relative;
  box-shadow:3px 4px 0 var(--Xv);
}
.k-ex li::before{content:"\1F4AC";position:absolute;left:-14px;top:50%;transform:translateY(-50%);background:#fff;padding:0 4px;font-size:18px}
.k-ex .n{background:var(--Xy);color:var(--Xk);width:30px;height:30px;border-radius:50%;text-align:center;line-height:30px;font-weight:900;border:2px solid var(--Xk);font-size:15px}
.k-ex .zh{font-size:28px;font-weight:900;color:var(--Xk);line-height:1.9}
.k-ex .zh ruby rt{font-size:16px}
.k-ex .ja{font-size:16px;font-weight:700;color:#33508c;margin-top:4px}
.k-ex .ja ruby rt.jp{font-size:.5em}

/* ============================ 03 おはなし（本文・吹き出し） ============================ */
.k-dia{background:#fff;border:3px dotted var(--Xpd);border-radius:22px;padding:20px 24px;position:relative;margin:14px 0}
.k-dia::before{content:"\1F4D6";position:absolute;top:-16px;left:18px;background:#fff;font-size:22px;padding:0 6px}
.k-scene{display:inline-block;background:var(--Xpd);color:#fff;font-weight:900;font-size:14px;letter-spacing:.1em;padding:4px 16px;border-radius:999px;margin-bottom:8px}
.k-dia .turn{display:flex;gap:12px;align-items:flex-start;padding:10px 0}
.k-dia .avatar{width:50px;height:50px;border-radius:50%;background:var(--Xy);display:flex;align-items:center;justify-content:center;font-size:28px;border:2px solid var(--Xk);flex-shrink:0}
.k-dia .speech{flex:1}
.k-dia .who{font-size:20px;font-weight:900;color:var(--Xpd);margin:0 0 5px 6px}
.k-dia .who ruby rt.jp{font-size:.6em}
.k-dia .bubble{background:var(--Xp);border:2px solid var(--Xpd);border-radius:18px;padding:10px 20px;font-size:26px;font-weight:800;color:var(--Xk);line-height:1.9;display:inline-block}
.k-dia .bubble ruby rt{color:var(--Xpd);font-size:15px;font-weight:800}
/* セリフ＋訳。1行に収まれば横並び、収まらなければ訳が自動で下へ折り返す（短文=横／長文=下） */
.k-dia .line{display:flex;flex-wrap:wrap;align-items:center;gap:10px}
.k-dia .trans{font-size:14.5px;color:#5a6a82;font-weight:700;background:#f4f6fb;border:1px solid #e1e8f2;border-radius:12px;padding:4px 13px;line-height:1.65}
.k-dia .trans::before{content:"＝ ";color:#9ab2cd;font-weight:900}
.k-dia .trans ruby rt.jp{font-size:.5em}

/* ============================ 04 ことばのきまり（文法） ============================ */
.k-gr{background:#fff;border:3px solid var(--Xpd);border-radius:22px;padding:26px 26px 22px;margin-top:24px;position:relative;box-shadow:4px 5px 0 var(--Xv)}
.k-gr::before{content:"\2728 Point \2728";position:absolute;top:-16px;left:50%;transform:translateX(-50%);background:var(--Xpd);color:#fff;font-weight:900;padding:6px 20px;border-radius:999px;font-size:14px;letter-spacing:.12em;white-space:nowrap}
.k-gr h3{margin:6px 0 10px;color:var(--Xpd);font-size:19px;font-weight:900;text-align:center}
.k-gr h3 ruby rt{font-size:.6em}
.k-gr p{font-size:16px;line-height:1.95;margin:0 0 8px;color:#27407a}
.k-gr .k-eg{list-style:none;margin:12px 0 0;padding:0;display:grid;gap:8px}
.k-gr .k-eg li{background:var(--Xpaper);border-radius:12px;padding:10px 14px;font-size:22px;font-weight:800;color:var(--Xk)}
.k-gr .k-eg li ruby rt{color:var(--Xpd);font-size:14px;font-weight:800}
.k-gr .k-eg li .num{color:var(--Xpink);font-weight:900;margin-right:8px}

/* ============================ 05 やってみよう（練習・ゲーム） ============================ */
.k-game{background:linear-gradient(135deg,#fff6fb,#eef7ff);border:3px dashed var(--Xpink);border-radius:22px;padding:22px 24px;margin:14px 0}
.k-game h3{margin:0 0 10px;color:var(--Xpink);font-size:18px;font-weight:900;display:flex;align-items:center;gap:8px}
.k-game p{font-size:16px;margin:0 0 10px;color:#27407a}
.k-game .k-quiz{display:grid;gap:10px;margin-top:6px}
.k-game .k-quiz .q{background:#fff;border:2px solid var(--Xpd);border-radius:14px;padding:12px 16px;font-size:18px;font-weight:700;color:var(--Xk)}
.k-game .k-quiz .q .zh{font-size:24px;font-weight:900}
.k-game .k-quiz .q .zh ruby rt{color:var(--Xpd);font-size:14px}
/* 生徒が見て答える図・絵は大きく表示する */
.k-quiz .k-fig{font-size:64px;line-height:1;vertical-align:middle;margin-right:14px;display:inline-block}
.k-fig{font-size:64px;line-height:1;display:inline-block}
.k-game .k-quiz .q{display:flex;align-items:center;gap:10px;flex-wrap:wrap}

/* ── おうちの人・先生へ ── */
.k-adult{background:#f4f6fb;border-left:5px solid #9ab2cd;border-radius:10px;padding:12px 16px;margin:18px 0 0;font-size:13px;color:#5a6a82;line-height:1.7}
.k-adult b{color:#3a4a64}
.k-adult .who{font-weight:900;color:#5a6a82}

/* ── マスコットのひとこと ── */
.k-mascot{display:flex;align-items:center;gap:14px;background:#fffef5;border:2px solid var(--Xy);border-radius:18px;padding:14px 18px;margin:14px 0}
.k-mascot .face{font-size:40px;flex-shrink:0;width:58px;height:58px;border-radius:50%;background:var(--Xv);display:flex;align-items:center;justify-content:center;border:2px solid var(--Xpd)}
.k-mascot .say{font-size:16px;font-weight:700;color:#27407a;line-height:1.8}
.k-mascot .say .name{color:var(--Xpink);font-weight:900;margin-right:6px}

/* ============================ はじめに（発音）専用パーツ ============================ */
/* 四声カード（声調4つ） */
.k-tone-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin:14px 0}
.k-tone{background:#fff;border:3px solid var(--Xpd);border-radius:18px;padding:16px 18px;box-shadow:3px 4px 0 var(--Xv);text-align:center}
.k-tone:nth-child(4n+2){border-color:#7cc9e8;box-shadow:3px 4px 0 var(--Xp)}
.k-tone:nth-child(4n+3){border-color:#ffae5e;box-shadow:3px 4px 0 var(--Xb)}
.k-tone:nth-child(4n+4){border-color:#5aa0e8;box-shadow:3px 4px 0 #fff5d4}
.k-tone .tname{display:inline-block;background:var(--Xy);border:2px solid var(--Xk);border-radius:999px;padding:3px 14px;font-size:14px;font-weight:900;margin-bottom:8px}
.k-tone .py{font-size:40px;font-weight:900;color:var(--Xpd);line-height:1.1}
.k-tone .hz{font-size:30px;font-weight:900;color:var(--Xk);margin:4px 0}
.k-tone .img{font-size:30px;margin:4px 0}
.k-tone .mean{font-size:15px;font-weight:700;color:#33508c}
.k-tone .mean ruby rt.jp{font-size:.5em}

/* ピンインのしくみ（音節分解） */
.k-syl{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;background:#fff;border:3px solid var(--Xpd);border-radius:18px;padding:22px;margin:14px 0;box-shadow:3px 4px 0 var(--Xv)}
.k-syl .part{text-align:center}
.k-syl .part .big{font-size:46px;font-weight:900;color:var(--Xpd);line-height:1}
.k-syl .part .big .tone{color:var(--Xpink)}
.k-syl .part .tag{display:block;margin-top:6px;font-size:13px;font-weight:900;color:#fff;background:var(--Xpd);border-radius:999px;padding:3px 10px}
.k-syl .part.vowel .tag{background:#2e9e6a}
.k-syl .part.tone .tag{background:var(--Xpink)}
.k-syl .plus{font-size:30px;font-weight:900;color:#9ab2cd}
.k-syl .arrow{font-size:30px;font-weight:900;color:#9ab2cd}
.k-syl .result{text-align:center}
.k-syl .result .hz{font-size:46px;font-weight:900;color:var(--Xk);line-height:1}
.k-syl .result .mean{font-size:14px;font-weight:700;color:#33508c;margin-top:4px}

/* ── フッター ── */
.k-foot{
  padding:16px 32px;background:var(--Xpd);color:#fff;font-weight:900;
  font-size:13.5px;letter-spacing:.12em;text-align:center;
}
.k-foot small{display:block;font-weight:700;font-size:11px;letter-spacing:.06em;opacity:.9;margin-top:4px}

/* ── 印刷用 ── */
@media print{
  @page{margin:10mm}
  *{-webkit-print-color-adjust:exact;print-color-adjust:exact}
  html,body{background:#fff}
  .page{margin:0;box-shadow:none;border-radius:0;max-width:none;border:none}
  /* 印刷可能幅がモバイル境界(760px)を下回っても2列を保ち、1列化による冗長な改ページを防ぐ */
  .k-tbl,.k-tone-grid{grid-template-columns:repeat(2,1fr)}
  .k-gr,.k-game,.k-tone,.k-syl,.k-ex li,.k-tbl .w,.k-mascot,.k-dia .turn{break-inside:avoid}
}

/* ── スマホ（画面表示のみ。印刷には適用しない） ── */
@media screen and (max-width:760px){
  .page{margin:0;border-radius:0}
  .k-body{padding:18px 16px 26px}
  .k-tbl,.k-tone-grid{grid-template-columns:1fr}
  .k-head__title{font-size:28px}
}

/* ── 目次に戻る／前後の課／上へ ナビ（2026-05-29 追加） ── */
html{scroll-behavior:smooth}
.k-back{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--Xpd);color:#fff;font-weight:900;font-size:14px;
  text-decoration:none;padding:8px 20px;border-radius:999px;
  border:2px solid #fff;box-shadow:0 3px 0 rgba(74,144,226,.35);
  transition:transform .12s,background .12s;
}
.k-back:hover{background:#3b7bc4;transform:translateY(-1px)}
.k-back.k-disabled{background:#c3ccd8;box-shadow:0 3px 0 rgba(0,0,0,.06);cursor:default;pointer-events:none;opacity:.7}
.k-nav-top{display:flex;justify-content:center;align-items:center;gap:10px;flex-wrap:wrap;padding:16px 16px 6px}
.k-nav-bottom{display:flex;justify-content:center;align-items:center;gap:10px;flex-wrap:wrap;padding:18px 16px 30px}
.k-totop{
  position:fixed;bottom:18px;z-index:50;left:calc(50% + 446px);right:auto;
  display:inline-flex;flex-direction:column;align-items:center;justify-content:center;
  width:54px;height:54px;border-radius:50%;
  background:var(--Xpink);color:#fff;font-weight:900;font-size:20px;line-height:1;
  text-decoration:none;border:2px solid #fff;box-shadow:0 4px 10px rgba(0,0,0,.2);
  transition:transform .12s,background .12s;
}
.k-totop span{font-size:9px;margin-top:1px;letter-spacing:.02em}
.k-totop:hover{background:#ff6b8e;transform:translateY(-2px)}
/* 画面幅が狭くカード横の余白が取れない場合は右端に寄せる */
@media (max-width:1024px){ .k-totop{left:auto;right:14px} }
@media print{ .k-nav-top,.k-nav-bottom,.k-totop{display:none} }
