/* ============================================================
   脳トレ道場 — デザインシステム
   ============================================================ */
:root{
  --bg:#0b0e1a; --bg2:#0f1424; --surface:#151b30; --surface2:#1c2440;
  --line:#2b3454; --text:#eef2ff; --muted:#a8b2d8; --faint:#828cb4;
  --brand:#7b8cff; --brand2:#36e0c0; --danger:#ff6b81; --gold:#ffd35c;
  /* カテゴリ別アクセントカラー */
  --c-test:#c084fc; --c-calc:#fb923c; --c-memory:#f472b6;
  --c-focus:#34d399; --c-reaction:#facc15; --c-spatial:#60a5fa;
  --grad:linear-gradient(135deg,#7b8cff 0%,#9d7bff 45%,#36e0c0 100%);
  --grad-warm:linear-gradient(135deg,#fb923c,#f472b6);
  --grad-soft:linear-gradient(135deg,rgba(123,140,255,.18),rgba(54,224,192,.18));
  --shadow:0 18px 50px -22px rgba(0,0,0,.75);
  --radius:18px; --maxw:1120px;
  /* 本文は可読性重視の Noto Sans JP、見出し・数字・ボタンは丸ゴシック */
  --font:"Noto Sans JP","Hiragino Kaku Gothic ProN",Meiryo,"Segoe UI",sans-serif;
  --font-disp:"M PLUS Rounded 1c","Hiragino Kaku Gothic ProN",Meiryo,"Segoe UI",sans-serif;
}
[data-theme="light"]{
  --bg:#eef1fb; --bg2:#f5f7ff; --surface:#ffffff; --surface2:#f1f4ff;
  --line:#d6ddf2; --text:#181f36; --muted:#4c5678; --faint:#7c86ab;
  --shadow:0 18px 50px -26px rgba(60,80,160,.35);
}
/* カテゴリ色をカード・セクションに配る（.card/.sectionの既定--accより詳細度を上げる） */
.card.cat-test,.section.cat-test{--acc:var(--c-test)}
.card.cat-calc,.section.cat-calc{--acc:var(--c-calc)}
.card.cat-memory,.section.cat-memory{--acc:var(--c-memory)}
.card.cat-focus,.section.cat-focus{--acc:var(--c-focus)}
.card.cat-reaction,.section.cat-reaction{--acc:var(--c-reaction)}
.card.cat-spatial,.section.cat-spatial{--acc:var(--c-spatial)}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font);color:var(--text);min-height:100vh;line-height:1.7;font-size:15.5px;
  background:
    radial-gradient(900px 500px at 12% -8%,rgba(123,140,255,.22),transparent 60%),
    radial-gradient(900px 500px at 92% 0%,rgba(54,224,192,.16),transparent 55%),
    radial-gradient(800px 500px at 50% 115%,rgba(244,114,182,.12),transparent 60%),
    radial-gradient(600px 400px at -5% 70%,rgba(251,146,60,.08),transparent 55%),
    var(--bg);
  background-attachment:fixed;
}
h1,h2,h3,h4,.logo,.btn,.diffbtn,.chip,.stat b,.statbar .s .v,.question,.flashnum,.bigword,.rscore,.rankbadge,.tile,.scell,.ocell,.ans{font-family:var(--font-disp)}
button,input{font-family:inherit}
/* タップ操作の最適化（300ms遅延・ダブルタップ拡大を防ぐ） */
.ans,.tile,.scell,.ocell,.pcard,.btn,.iconbtn,.diffbtn,.reaction-zone,.gng-zone,.dpad button,.card{touch-action:manipulation}
.ans,.tile,.scell,.ocell,.pcard,.reaction-zone,.gng-zone,.card{-webkit-tap-highlight-color:transparent}
a{color:inherit}
img{max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 18px}
.hidden{display:none !important}

/* ---------- ナビ ---------- */
.nav{
  position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);
  background:color-mix(in srgb,var(--bg) 78%,transparent);
  border-bottom:1px solid var(--line);
}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:12px 18px;display:flex;align-items:center;gap:14px}
.logo{display:flex;align-items:center;gap:10px;cursor:pointer;font-weight:800;font-size:20px;letter-spacing:.5px}
.logo .mark{font-size:26px;filter:drop-shadow(0 4px 10px rgba(123,140,255,.5))}
.logo .grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.nav-spacer{flex:1}
.chip{
  display:inline-flex;align-items:center;gap:6px;background:var(--surface);
  border:1px solid var(--line);border-radius:999px;padding:6px 12px;font-size:13px;font-weight:700;
}
.chip b{color:var(--brand2)}
.iconbtn{
  width:40px;height:40px;display:grid;place-items:center;border-radius:12px;cursor:pointer;
  background:var(--surface);border:1px solid var(--line);font-size:18px;transition:.15s;
}
.iconbtn:hover{border-color:var(--brand);transform:translateY(-1px)}

/* ---------- 広告枠 ---------- */
.adslot{max-width:var(--maxw);margin:18px auto;padding:0 18px}
.ad-inner{
  position:relative;border:1px dashed var(--line);border-radius:14px;
  background:var(--grad-soft);min-height:90px;display:grid;place-items:center;
  color:var(--faint);font-size:13px;text-align:center;overflow:hidden;
}
.ad-inner::before{content:"スポンサー";position:absolute;top:6px;left:10px;font-size:10px;color:var(--faint);letter-spacing:1px}
.ad-feed .ad-inner{min-height:120px}

/* ---------- ヒーロー ---------- */
.hero{
  margin-top:22px;border:1px solid var(--line);border-radius:24px;overflow:hidden;position:relative;
  background:
    radial-gradient(700px 300px at 80% -20%,rgba(157,123,255,.30),transparent 60%),
    linear-gradient(160deg,var(--surface),var(--surface2));
  box-shadow:var(--shadow);
}
.hero-in{padding:34px 30px;display:flex;flex-wrap:wrap;gap:26px;align-items:center;justify-content:space-between}
.hero h1{font-size:34px;line-height:1.25;letter-spacing:.5px}
.hero h1 .grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{color:var(--muted);margin-top:8px;max-width:460px}
.hero-cta{display:flex;gap:12px;margin-top:18px;flex-wrap:wrap}
.daily-card{
  min-width:230px;background:var(--bg2);border:1px solid var(--line);border-radius:18px;padding:18px 20px;
}
.daily-card .lbl{font-size:12px;color:var(--brand2);font-weight:800;letter-spacing:1px}
.daily-card .gm{font-size:20px;font-weight:800;margin:6px 0 2px}
.daily-card .df{font-size:13px;color:var(--muted)}
.daily-done{color:var(--brand2);font-weight:800;margin-top:8px}

/* ---------- 統計バー ---------- */
.statbar{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;margin-top:18px}
.statbar .s{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:16px;text-align:center}
.statbar .s .v{font-size:26px;font-weight:800;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.statbar .s .k{font-size:12px;color:var(--muted);margin-top:2px}

/* ---------- 難易度バー ---------- */
.diffbar{display:flex;gap:8px;justify-content:center;align-items:center;flex-wrap:wrap;margin:26px 0 6px}
.diffbar .lab{color:var(--muted);font-size:13px;font-weight:700}
.diffbtn{
  background:var(--surface);border:1px solid var(--line);color:var(--muted);
  border-radius:999px;padding:8px 16px;font-size:13px;cursor:pointer;transition:.15s;font-weight:800;font-family:inherit;
}
.diffbtn:hover{border-color:var(--brand);color:var(--text)}
.diffbtn.active{background:var(--grad);color:#0b0e1a;border-color:transparent}
/* 難易度ごとの色（やさしい=緑 → 鬼=赤紫） */
.diffbtn.d-easy.active{background:#4ade80}
.diffbtn.d-normal.active{background:#36e0c0}
.diffbtn.d-hard.active{background:#facc15}
.diffbtn.d-expert.active{background:#fb923c}
.diffbtn.d-oni.active{background:linear-gradient(135deg,#ff5b6e,#c026d3);color:#fff}

/* ---------- セクション ---------- */
.section{margin-top:30px;--acc:var(--brand)}
.section-h{display:flex;align-items:baseline;gap:12px;margin-bottom:14px;border-left:4px solid var(--acc);padding-left:12px}
.section-h h2{font-size:20px}
.section-h .cnt{color:var(--faint);font-size:13px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px}

/* ---------- ゲームカード ---------- */
.card{
  position:relative;background:linear-gradient(160deg,var(--surface),var(--surface2));
  border:1px solid var(--line);border-radius:var(--radius);padding:20px;cursor:pointer;
  transition:.2s;overflow:hidden;--acc:var(--brand);
}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--acc),transparent 75%)}
.card::after{content:"";position:absolute;inset:0;background:var(--grad);opacity:0;transition:.2s;pointer-events:none;mix-blend-mode:overlay}
.card:hover{transform:translateY(-5px);border-color:var(--acc);box-shadow:var(--shadow)}
.card:hover::after{opacity:.08}
.card .row{display:flex;justify-content:space-between;align-items:flex-start}
.card .ico{
  font-size:30px;line-height:1;width:56px;height:56px;display:grid;place-items:center;
  border-radius:15px;background:color-mix(in srgb,var(--acc) 16%,transparent);
  border:1px solid color-mix(in srgb,var(--acc) 30%,transparent);
}
.card .tag{
  font-size:11px;font-weight:800;color:var(--acc);
  background:color-mix(in srgb,var(--acc) 10%,transparent);
  border:1px solid color-mix(in srgb,var(--acc) 35%,var(--line));padding:3px 9px;border-radius:999px;
}
.card h3{margin:12px 0 4px;font-size:18px}
.card small{color:var(--muted);display:block;line-height:1.55;min-height:42px}
.card .best{margin-top:12px;font-size:12px;color:var(--gold);font-weight:800;display:flex;align-items:center;gap:6px}

/* ---------- ボタン ---------- */
.btn{
  background:var(--grad);color:#0b0e1a;border:none;border-radius:12px;padding:12px 22px;
  font-size:15px;cursor:pointer;font-weight:800;font-family:inherit;transition:.15s;
}
.btn:hover{filter:brightness(1.08);transform:translateY(-1px)}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--text)}
.btn.ghost:hover{border-color:var(--brand)}
.btn.big{font-size:17px;padding:14px 30px}

/* ---------- ゲーム画面 ---------- */
.screen{
  margin-top:22px;background:linear-gradient(160deg,var(--surface),var(--surface2));
  border:1px solid var(--line);border-radius:24px;padding:26px;min-height:460px;
  display:flex;flex-direction:column;box-shadow:var(--shadow);
}
.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;gap:10px}
.topbar h2{font-size:21px;text-align:center;flex:1}
.topbar .dlabel{font-size:12px;color:var(--muted);min-width:84px;text-align:right;line-height:1.3}
.topbar .dlabel b{color:var(--text)}
.stat{display:flex;gap:26px;color:var(--muted);font-size:13px;justify-content:center;flex-wrap:wrap}
.stat b{color:var(--text);font-size:22px;display:block;font-weight:800}
.center{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;text-align:center}
.question{font-size:54px;font-weight:800;letter-spacing:2px}
.answers{display:grid;grid-template-columns:repeat(2,1fr);gap:13px;width:100%;max-width:460px}
.ans{
  background:var(--surface);border:1px solid var(--line);color:var(--text);font-family:inherit;
  font-size:25px;padding:18px;border-radius:14px;cursor:pointer;transition:.12s;font-weight:800;
}
.ans:hover{border-color:var(--brand);transform:translateY(-2px)}
.ans.ok{background:var(--brand2);border-color:var(--brand2);color:#04261d}
.ans.ng{background:var(--danger);border-color:var(--danger);color:#fff}
.msg{font-size:19px;color:var(--muted)}
.bigword{font-size:66px;font-weight:900}
.flashnum{font-size:62px;font-weight:900;letter-spacing:10px}
.hint{color:var(--muted);font-size:14px;max-width:520px}

/* タイル系（数字記憶・パターン記憶） */
.memgrid{display:grid;gap:10px;justify-content:center}
.tile{
  width:72px;height:72px;border-radius:14px;background:var(--surface);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;font-size:28px;cursor:pointer;
  transition:.12s;user-select:none;font-weight:800;
}
.tile.lit{background:var(--grad);border-color:transparent;box-shadow:0 0 22px rgba(123,140,255,.7)}
.tile.good{background:var(--brand2);border-color:var(--brand2)}
.tile.bad{background:var(--danger);border-color:var(--danger)}
.tile.sel{background:var(--brand);border-color:var(--brand);color:#fff}

/* シュルテ */
.schulte{display:grid;gap:8px;justify-content:center}
.scell{
  background:var(--surface);border:1px solid var(--line);border-radius:12px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-weight:800;user-select:none;transition:.1s;
}
.scell:hover{border-color:var(--brand)}
.scell.done{background:var(--brand2);border-color:var(--brand2);color:#04261d;cursor:default}
.scell.miss{background:var(--danger);border-color:var(--danger)}

/* 反応・Go/NoGo */
.reaction-zone{
  flex:1;border-radius:18px;display:flex;align-items:center;justify-content:center;
  font-size:28px;cursor:pointer;font-weight:900;min-height:300px;transition:.08s;user-select:none;
}
.rz-wait{background:linear-gradient(160deg,#3a2330,#2a1a26);color:#ffb4b4}
.rz-go{background:var(--brand2);color:#04261d}
.rz-idle{background:var(--surface2);color:var(--muted)}
.gng-zone{flex:1;min-height:300px;border-radius:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;background:var(--surface2);transition:.05s}
.gng-dot{width:140px;height:140px;border-radius:50%;display:grid;place-items:center;font-size:40px;font-weight:900;color:#04261d}

/* 神経衰弱 */
.cardgrid{display:grid;gap:10px;justify-content:center}
.pcard{
  border-radius:12px;background:linear-gradient(150deg,#3a4486,#2b3358);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.2s;user-select:none;
}
.pcard .back{color:#fff;opacity:.55;font-weight:900}
.pcard.face{background:var(--surface)}
.pcard.matched{background:var(--brand2);border-color:var(--brand2);cursor:default;opacity:.85}

/* 図形回転 */
.rotwrap{display:flex;gap:34px;align-items:center;justify-content:center;flex-wrap:wrap}
.shape{display:grid;gap:3px;background:var(--bg2);padding:10px;border-radius:14px;border:1px solid var(--line)}
.scellr{width:30px;height:30px;border-radius:6px;background:transparent}
.scellr.on{background:var(--grad)}
.rotvs{font-size:24px;color:var(--faint);font-weight:800}

/* 入力 */
.input-num{
  font-size:32px;text-align:center;width:260px;padding:12px;border-radius:12px;letter-spacing:6px;
  border:1px solid var(--line);background:var(--surface);color:var(--text);font-family:inherit;
}
.input-num:focus{outline:none;border-color:var(--brand)}

/* 詳細画面 */
.detail{display:flex;flex-direction:column;gap:14px}
.detail .dhow{font-size:16px;line-height:1.8}
.detail .dtips{color:var(--brand2);font-size:14px;font-weight:700}
.dmeta{display:flex;gap:10px;flex-wrap:wrap}
.pill{display:inline-block;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:5px 13px;font-size:12px;color:var(--muted);font-weight:700}
.dh{font-size:16px;margin-top:6px}
.dtable{width:100%;border-collapse:collapse;font-size:14px;overflow:hidden;border-radius:12px}
.dtable th,.dtable td{border:1px solid var(--line);padding:10px 13px;text-align:left;vertical-align:top}
.dtable th{background:var(--surface2);color:var(--muted);font-weight:800}
.dtable td{line-height:1.6}
.dtable .dname{white-space:nowrap;font-weight:800}
.drow-active{background:var(--grad-soft)}
.drow-active td{border-color:var(--brand)}
.now{color:var(--brand);font-size:12px;font-weight:800}
.dpick{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:4px}
.dpick span{color:var(--muted);font-size:14px;font-weight:700}
.dstart{display:flex;justify-content:center;margin-top:10px}

/* 仲間はずれ探し */
.oddgrid{display:grid;gap:5px;justify-content:center}
.ocell{
  background:var(--surface);border:1px solid var(--line);border-radius:10px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-weight:800;user-select:none;transition:.1s;color:var(--text);
}
.ocell:hover{border-color:var(--brand)}
.ocell.miss{background:var(--danger);border-color:var(--danger)}

/* 迷路 */
.mazegrid{display:grid;justify-content:center;background:var(--bg2);border:2px solid var(--muted);border-radius:4px}
.mcell{box-sizing:border-box}
.mcell.wt{border-top:2px solid var(--muted)}
.mcell.wl{border-left:2px solid var(--muted)}
.mcell.goal{background:var(--brand2)}
.mcell.me{background:var(--brand);border-radius:4px}
.dpad{display:flex;flex-direction:column;align-items:center;gap:6px}
.dpad>div{display:flex;gap:6px}
.dpad button{width:58px;padding:10px 0;font-size:16px}

/* ランク判定バッジ */
.rankline{display:flex;align-items:center;gap:10px;font-weight:800;color:var(--muted)}
.rankbadge{
  display:inline-grid;place-items:center;width:44px;height:44px;border-radius:12px;
  font-size:24px;font-weight:900;color:#0b0e1a;
}
.rk-S{background:linear-gradient(135deg,#ffd35c,#ff9f43);box-shadow:0 0 18px rgba(255,211,92,.5)}
.rk-A{background:var(--brand2)}
.rk-B{background:var(--brand)}
.rk-C{background:var(--surface2);color:var(--muted);border:1px solid var(--line)}

/* 文字サイズ大きめモード */
[data-big="1"] body{font-size:17.5px}
[data-big="1"] .ans{font-size:29px;padding:22px}
[data-big="1"] .hint{font-size:17px}
[data-big="1"] .msg{font-size:23px}
[data-big="1"] .card small{font-size:15px}
[data-big="1"] .card h3{font-size:20px}
[data-big="1"] .question{font-size:62px}
[data-big="1"] .btn{font-size:17px}
[data-big="1"] .btn.big{font-size:19px}
[data-big="1"] .detail .dhow{font-size:18px}
[data-big="1"] .dtable{font-size:16px}
[data-big="1"] .stat{font-size:15px}
[data-big="1"] .foot-in{font-size:15px}
[data-big="1"] .about p,[data-big="1"] .faq summary{font-size:16px}
[data-big="1"] .faq details p{font-size:15px}
.iconbtn.active{border-color:var(--brand);background:var(--grad-soft)}

/* 結果画面 */
.result .emoji{font-size:64px;animation:pop .4s ease}
@keyframes pop{0%{transform:scale(.4);opacity:0}70%{transform:scale(1.15)}100%{transform:scale(1)}}
.result .rscore{font-size:52px;font-weight:900;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.rankbasis{font-size:12px;color:var(--faint);line-height:1.6}
.agepill{
  background:color-mix(in srgb,var(--c-test) 10%,transparent);
  border:1px solid color-mix(in srgb,var(--c-test) 35%,var(--line));
  border-radius:12px;padding:8px 14px;font-size:13.5px;color:var(--muted);
}
.agepill b{color:var(--c-test);font-size:17px}
.agepill small{display:block;font-size:11px;color:var(--faint)}

/* 脳年齢テストの判定内訳 */
.agebreak{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:16px 18px;margin-bottom:12px}
.agebreak .ab-h{font-weight:800;font-size:14px;margin-bottom:8px;color:var(--text)}
.agebreak .ab-row{display:flex;justify-content:space-between;gap:12px;font-size:13.5px;color:var(--muted);padding:5px 0;border-bottom:1px dashed var(--line)}
.agebreak .ab-row b{color:var(--c-calc);white-space:nowrap}
.agebreak .ab-note{font-size:12px;color:var(--faint);margin-top:8px;line-height:1.7}
.result .newbest{color:var(--brand2);border-color:var(--brand2)}
.result .btns{display:flex;gap:12px;margin-top:8px;flex-wrap:wrap;justify-content:center}

/* 進捗バー */
.progress{height:8px;background:var(--surface2);border-radius:6px;overflow:hidden;width:100%;max-width:480px}
.progress>div{height:100%;background:var(--grad);width:0;transition:.2s}

/* トースト */
.toast-wrap{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);z-index:100;display:flex;flex-direction:column;gap:8px;align-items:center}
.toast{
  background:var(--surface);border:1px solid var(--brand);border-radius:14px;padding:12px 18px;
  font-weight:800;box-shadow:var(--shadow);animation:slideup .3s ease;display:flex;align-items:center;gap:10px;
}
.toast .ti{font-size:22px}
@keyframes slideup{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}

/* バッジ */
.badges{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.badge{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:16px;text-align:center;opacity:.45;transition:.2s}
.badge.on{opacity:1;border-color:var(--brand)}
.badge .bi{font-size:34px}
.badge .bn{font-weight:800;margin-top:6px;font-size:14px}
.badge .bd{font-size:11px;color:var(--muted);margin-top:2px}

/* プレイ記録グラフ（ホーム） */
.chart{
  display:flex;gap:6px;align-items:flex-end;
  background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:14px 16px 10px;
}
.chart .cb{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:3px;min-width:0}
.chart .cv{font-size:10px;color:var(--brand2);font-weight:800;height:14px}
.chart .cbar{width:100%;max-width:26px;border-radius:5px 5px 0 0;background:var(--grad)}
.chart .cb.zero .cbar{background:var(--surface2)}
.chart .cl{font-size:10px;color:var(--faint);height:14px;white-space:nowrap}

/* スコア推移（詳細画面） */
.trend{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:14px 16px}
.trend-h{font-size:13px;color:var(--muted);font-weight:700;display:flex;justify-content:space-between;flex-wrap:wrap;gap:6px}
.trend-best{color:var(--gold)}
.trendbars{display:flex;gap:5px;align-items:flex-end;height:70px;margin-top:10px}
.tb-col{flex:1;max-width:30px;height:100%;display:flex;align-items:flex-end}
.tbar{width:100%;border-radius:4px 4px 0 0;background:var(--brand);opacity:.55}
.tbar.tb-best{background:var(--brand2);opacity:1}

/* サイト説明・FAQ */
.about{margin-top:44px;border-top:1px solid var(--line);padding-top:28px}
.about h2{font-size:20px;margin-bottom:10px}
.about p{color:var(--muted);font-size:14px;max-width:760px}
.faq{margin-top:16px;display:flex;flex-direction:column;gap:10px}
.faq details{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:14px 18px}
.gamelinks{display:flex;flex-wrap:wrap;gap:8px}
.gamelinks a{
  color:var(--muted);text-decoration:none;font-size:13px;font-weight:700;
  background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:6px 12px;
}
.gamelinks a:hover{color:var(--text);border-color:var(--brand)}
.faq summary{cursor:pointer;font-weight:800;font-size:14px}
.faq details p{margin-top:8px;font-size:13px}

/* キーボード操作時のフォーカス可視化 */
.iconbtn:focus-visible,.btn:focus-visible,.ans:focus-visible,.diffbtn:focus-visible,.logo:focus-visible,.faq summary:focus-visible{
  outline:2px solid var(--brand);outline-offset:2px;
}

/* フッター */
footer{margin-top:50px;border-top:1px solid var(--line);background:color-mix(in srgb,var(--bg) 60%,transparent)}
.foot-in{max-width:var(--maxw);margin:0 auto;padding:30px 18px;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;color:var(--muted);font-size:13px}
.foot-in a{color:var(--muted);text-decoration:none;margin-right:14px}
.foot-in a:hover{color:var(--brand)}
.floadl{cursor:pointer;color:var(--muted);margin-right:14px}
.floadl:hover{color:var(--brand)}

/* レスポンシブ */
@media(max-width:720px){
  .hero h1{font-size:27px}
  .statbar{grid-template-columns:repeat(2,1fr)}
  .question{font-size:42px}
  .bigword{font-size:54px}
  .screen{padding:18px}
  .nav .chip .lbl-txt{display:none}
}
@media(max-width:480px){
  .nav-inner{padding:10px 12px;gap:7px}
  .iconbtn{width:35px;height:35px;font-size:16px;border-radius:10px}
  .logo{font-size:17px;gap:7px} .logo .mark{font-size:22px}
  .chip{padding:5px 9px;font-size:12px}
  .wrap{padding:0 12px}
  .screen{padding:14px;border-radius:18px;min-height:420px}
  .topbar h2{font-size:17px}
  .topbar .dlabel{min-width:64px;font-size:11px}
  .question{font-size:34px;letter-spacing:1px}
  .flashnum{font-size:46px;letter-spacing:6px}
  .bigword{font-size:44px}
  .ans{font-size:21px;padding:14px}
  .answers{gap:9px}
  .hero-in{padding:24px 18px}
  .hero h1{font-size:24px}
  .btn.big{font-size:15px;padding:12px 20px}
  .reaction-zone,.gng-zone{min-height:240px}
  .result .rscore{font-size:42px}
  .statbar .s{padding:10px} .statbar .s .v{font-size:20px}
  .memgrid{gap:7px}
  .foot-in{font-size:12px}
}
@media(max-width:420px){
  .answers{grid-template-columns:1fr}
}
@media(max-width:380px){
  .nav .chip{display:none}
}

/* ---------- 幼児用モード（🧒ボタン） ---------- */
[data-kids="1"] .about,
[data-kids="1"] .rankbasis,
[data-kids="1"] .agepill,
[data-kids="1"] .nav .chip{display:none!important}
[data-kids="1"] .logo{white-space:nowrap}
[data-kids="1"] .msg{font-size:22px}
[data-kids="1"] .hint{font-size:16px}
[data-kids="1"] .ans{font-size:28px;padding:20px}
[data-kids="1"] .card small{font-size:14px}
.kids-grid{margin-top:22px;grid-template-columns:repeat(auto-fill,minmax(190px,1fr))}
.kids-grid .card h3{font-size:19px}

/* ---------- スマホ表示モード（📱ボタンで固定） ----------
   PCでもスマホ幅のコンパクトレイアウトに切り替えられる */
[data-view="mobile"] .wrap,
[data-view="mobile"] .nav-inner,
[data-view="mobile"] .adslot,
[data-view="mobile"] .foot-in{max-width:440px}
[data-view="mobile"] .hero-in{flex-direction:column;align-items:stretch;padding:26px 20px}
[data-view="mobile"] .hero h1{font-size:25px}
[data-view="mobile"] .daily-card{min-width:0}
[data-view="mobile"] .statbar{grid-template-columns:repeat(2,1fr)}
[data-view="mobile"] .grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
[data-view="mobile"] .screen{padding:16px}
[data-view="mobile"] .question{font-size:38px}
[data-view="mobile"] .bigword{font-size:48px}
[data-view="mobile"] .nav .chip .lbl-txt{display:none}
