/* LINE Seed JP（Fontsource / jsDelivr 経由） */
@font-face{
  font-family:'LINE Seed JP';font-style:normal;font-weight:400;font-display:swap;
  src:url('https://cdn.jsdelivr.net/fontsource/fonts/line-seed-jp@latest/japanese-400-normal.woff2') format('woff2');
}
@font-face{
  font-family:'LINE Seed JP';font-style:normal;font-weight:700;font-display:swap;
  src:url('https://cdn.jsdelivr.net/fontsource/fonts/line-seed-jp@latest/japanese-700-normal.woff2') format('woff2');
}
@font-face{
  font-family:'LINE Seed JP';font-style:normal;font-weight:800;font-display:swap;
  src:url('https://cdn.jsdelivr.net/fontsource/fonts/line-seed-jp@latest/japanese-800-normal.woff2') format('woff2');
}

:root{
  --brand:#8B5A2B;
  --bg:#f8f5f1;
  --surface:#ffffff;
  --text:#2a2320;
  --muted:#7a6f66;
  --line:#e8e1d9;
  --ok:#1f9d6b;
  --ng:#d2453f;
  --radius:14px;
  --maxw:680px;
  --font:"LINE Seed JP","LINESeedJP",-apple-system,BlinkMacSystemFont,"Hiragino Sans","Noto Sans JP",sans-serif;
}
[data-theme="dark"]{
  --bg:#1a1613;
  --surface:#241e1a;
  --text:#efe8e2;
  --muted:#a89b90;
  --line:#3a302a;
}
*{box-sizing:border-box;}
html,body{overflow-x:hidden;}
body{
  margin:0;font-family:var(--font);
  background:var(--bg);color:var(--text);line-height:1.65;
  -webkit-font-smoothing:antialiased;
}

/* header */
.l-header{
  position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:8px;
  padding:12px 16px;background:var(--surface);border-bottom:1px solid var(--line);
}
.l-header__title{font-size:17px;font-weight:700;margin:0;flex:1;text-align:center;}
.c-back,.c-theme{
  border:0;background:transparent;color:var(--text);font-size:15px;cursor:pointer;
  padding:6px 10px;border-radius:8px;min-width:44px;
}
.c-back:hover,.c-theme:hover{background:var(--bg);}

.l-main{max-width:var(--maxw);margin:0 auto;padding:16px;}
.l-footer{max-width:var(--maxw);margin:24px auto;padding:16px;text-align:center;color:var(--muted);}
.c-loading{text-align:center;color:var(--muted);padding:40px;}

/* 分野タブ（トップ） */
.c-subjects{display:grid;gap:12px;}
.c-subject{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);cursor:pointer;text-align:left;width:100%;color:var(--text);
  transition:transform .08s,border-color .15s;
}
.c-subject:hover{border-color:var(--brand);transform:translateY(-1px);}
.c-subject__name{font-size:20px;font-weight:700;}
.c-subject__meta{font-size:13px;color:var(--muted);}
.c-subject__count{font-size:13px;color:var(--brand);font-weight:700;}

/* カテゴリー一覧 */
.c-group{margin-bottom:20px;}
.c-group__head{font-size:13px;font-weight:700;color:var(--muted);margin:0 0 8px;padding-left:4px;}
.c-cat{
  display:flex;align-items:center;justify-content:space-between;width:100%;
  padding:14px 16px;background:var(--surface);border:1px solid var(--line);
  border-radius:10px;cursor:pointer;color:var(--text);margin-bottom:8px;text-align:left;
}
.c-cat:hover{border-color:var(--brand);}
.c-cat__name{font-size:15px;font-weight:600;}
.c-cat__sub{font-size:12px;color:var(--muted);}
.c-cat__badge{font-size:11px;color:var(--brand);border:1px solid var(--brand);border-radius:20px;padding:2px 8px;white-space:nowrap;}
/* 正答率バッジ */
.c-cat__rate{font-size:11px;border:1px solid var(--line);color:var(--muted);border-radius:20px;padding:2px 9px;white-space:nowrap;font-weight:700;}
.c-cat__rate.is-good{color:var(--ok);border-color:var(--ok);}
.c-cat__rate.is-weak{color:var(--ng);border-color:var(--ng);}
.c-cat__rate.is-new{color:var(--muted);border-style:dashed;}

/* 今日の復習（忘却管理のヒーロー・トップ最上部） */
.c-review{
  display:block;width:100%;text-align:left;cursor:pointer;color:#fff;
  background:var(--brand);border:0;border-radius:var(--radius);
  padding:20px;margin-bottom:16px;
  transition:transform .08s;
}
.c-review:hover{transform:translateY(-1px);}
.c-review__label{
  display:inline-block;font-size:11px;font-weight:700;letter-spacing:.05em;
  background:rgba(255,255,255,.22);border-radius:20px;padding:3px 10px;margin-bottom:10px;
}
.c-review__name{display:block;font-size:20px;font-weight:800;margin-bottom:4px;}
.c-review__meta{display:block;font-size:12px;opacity:.85;margin-bottom:12px;}
.c-review__cta{display:block;font-size:15px;font-weight:700;}

/* 苦手な単元セクション（トップ） */
.c-weak{
  background:var(--surface);border:1px solid var(--ng);border-radius:var(--radius);
  padding:14px 16px;margin-bottom:16px;
}
.c-weak__head{font-size:13px;font-weight:700;color:var(--ng);margin:0 0 10px;}
.c-weak__item{
  display:flex;align-items:center;justify-content:space-between;width:100%;
  padding:10px 12px;background:transparent;border:0;border-top:1px solid var(--line);
  cursor:pointer;color:var(--text);font-size:14px;text-align:left;
}
.c-weak__item:first-of-type{border-top:0;}
.c-weak__rate{font-weight:700;color:var(--ng);}
.c-result__cum{font-size:14px;color:var(--muted);margin:4px 0 20px;}

/* クイズ */
.c-quiz__bar{height:6px;background:var(--line);border-radius:6px;overflow:hidden;margin-bottom:6px;}
.c-quiz__bar i{display:block;height:100%;background:var(--brand);transition:width .25s;}
.c-quiz__status{display:flex;justify-content:space-between;font-size:13px;color:var(--muted);margin-bottom:16px;}
.c-quiz__level{font-size:11px;border:1px solid var(--line);border-radius:6px;padding:1px 7px;color:var(--muted);}
.c-quiz__q{font-size:18px;font-weight:600;margin:0 0 16px;}
.c-figure{
  background:var(--surface);border:1px solid var(--line);border-radius:10px;
  padding:12px;margin-bottom:16px;color:var(--text);text-align:center;
}
.c-figure svg,.c-figure img{max-width:100%;height:auto;}

.c-choices{display:grid;gap:10px;}
.c-choice{
  display:flex;gap:12px;align-items:flex-start;width:100%;text-align:left;
  padding:14px 16px;background:var(--surface);border:1.5px solid var(--line);
  border-radius:10px;cursor:pointer;color:var(--text);font-size:15px;transition:border-color .12s;
}
.c-choice:hover:not(:disabled){border-color:var(--brand);}
.c-choice__mark{
  flex:none;width:26px;height:26px;border-radius:50%;border:1.5px solid var(--muted);
  display:grid;place-items:center;font-size:13px;font-weight:700;color:var(--muted);
}
.c-choice.is-correct{border-color:var(--ok);background:color-mix(in srgb,var(--ok) 8%,transparent);}
.c-choice.is-correct .c-choice__mark{border-color:var(--ok);color:#fff;background:var(--ok);}
.c-choice.is-wrong{border-color:var(--ng);background:color-mix(in srgb,var(--ng) 8%,transparent);}
.c-choice.is-wrong .c-choice__mark{border-color:var(--ng);color:#fff;background:var(--ng);}
.c-choice:disabled{cursor:default;}

.c-explain{
  margin-top:16px;padding:14px 16px;background:var(--surface);
  border:1px solid var(--line);border-left:3px solid var(--brand);border-radius:8px;font-size:14px;
}
.c-explain b{color:var(--brand);}
.c-next{
  margin-top:16px;width:100%;padding:15px;background:var(--brand);color:#fff;border:0;
  border-radius:10px;font-size:16px;font-weight:700;cursor:pointer;
}
.c-next:hover{opacity:.92;}

/* 結果 */
.c-result{text-align:center;padding:24px 0;}
.c-result__score{font-size:48px;font-weight:800;color:var(--brand);}
.c-result__total{font-size:20px;color:var(--muted);}
.c-result__msg{margin:12px 0 24px;font-size:16px;}
.c-result__actions{display:grid;gap:10px;max-width:320px;margin:0 auto;}
.c-btn{padding:14px;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;border:1.5px solid var(--brand);}
.c-btn--primary{background:var(--brand);color:#fff;border-color:var(--brand);}
.c-btn--ghost{background:transparent;color:var(--brand);}
