:root{
    --paper:#EBEDEF; --card:#F6F7F8; --ink:#16202C; --muted:#5C6670; --line:#CBD0D6;
    --accent:#E5462E; --accent-soft:#FBE7E2; --verify:#157767; --verify-soft:#DDEFEA;
    --disp:"Space Grotesk",ui-sans-serif,system-ui,sans-serif;
    --jp:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;
  }
  *{box-sizing:border-box} html,body{margin:0;padding:0}
  body{background:var(--paper);color:var(--ink);font-family:var(--jp);line-height:1.7;-webkit-font-smoothing:antialiased;
    background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
    background-size:34px 34px;background-position:center top;background-attachment:fixed;}
  body::before{content:"";position:fixed;inset:0;pointer-events:none;background:radial-gradient(ellipse at 50% 30%,transparent 0%,var(--paper) 78%);}
  .wrap{position:relative;max-width:720px;margin:0 auto;padding:0 22px 96px}
  sub{font-size:.7em;letter-spacing:0}

  header{padding:54px 0 26px}
  .eyebrow{font-family:var(--disp);font-weight:600;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:10px}
  .eyebrow::after{content:"";flex:1;height:1px;background:var(--line)}
  h1{font-family:var(--jp);font-weight:700;font-size:clamp(28px,6vw,40px);line-height:1.25;margin:18px 0 0;letter-spacing:.01em}
  h1 .x{font-family:var(--disp);color:var(--accent);font-style:normal;padding:0 .06em}
  .lede{color:var(--muted);font-size:15px;margin:14px 0 0;max-width:46ch} .lede b{color:var(--ink);font-weight:700}
  .hero{display:flex;gap:22px;align-items:center;margin:30px 0 0;padding:20px 22px;background:var(--card);border:1px solid var(--line);border-radius:4px}
  .hero svg{flex:0 0 116px;width:116px;height:116px}
  .hero .cap{font-size:13px;color:var(--muted)}
  .hero .cap code{font-family:var(--disp);font-weight:600;color:var(--ink);background:var(--paper);border:1px solid var(--line);border-radius:3px;padding:1px 7px;font-size:13px}
  .spin{transform-origin:60px 64px;animation:rot 9s linear infinite}
  @keyframes rot{to{transform:rotate(360deg)}}
  @media (prefers-reduced-motion:reduce){.spin{animation:none;transform:rotate(28deg)}}

  .start{margin-top:26px}
  .start .lab{font-family:var(--disp);font-weight:600;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
  .tiers{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  @media(max-width:520px){.tiers{grid-template-columns:1fr}}
  .tier{text-align:left;background:var(--card);border:1px solid var(--line);border-radius:6px;padding:18px 18px 16px;cursor:pointer;transition:border-color .12s,transform .06s;font-family:var(--jp)}
  .tier:hover{border-color:var(--ink);transform:translateY(-2px)} .tier:focus-visible{outline:2px solid var(--ink);outline-offset:2px}
  .tier .tn{font-weight:700;font-size:17px;display:flex;align-items:center;gap:9px}
  .tier .tn .dot{width:10px;height:10px;border-radius:50%}
  .tier.q .tn .dot{background:var(--accent)} .tier.d .tn .dot{background:var(--verify)}
  .tier .td{font-size:13px;color:var(--muted);margin-top:8px;line-height:1.6}
  .tier .tm{font-family:var(--disp);font-size:12px;font-weight:600;color:var(--ink);margin-top:11px;letter-spacing:.02em}

  .rail{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:26px 0 8px}
  .rail .c{border:1px solid var(--line);border-radius:4px;background:var(--card);padding:10px 10px 11px}
  .rail .c .n{font-family:var(--disp);font-size:11px;font-weight:600;color:var(--muted);letter-spacing:.1em}
  .rail .c .t{font-size:12px;font-weight:500;margin-top:3px;line-height:1.35;min-height:2.7em}
  .rail .c .dots{display:flex;gap:4px;margin-top:8px}
  .rail .c .dots i{width:9px;height:9px;border-radius:50%;border:1.5px solid var(--line);background:transparent;display:inline-block}
  .rail .c .dots i.ok{background:var(--verify);border-color:var(--verify)}
  .rail .c .dots i.no{background:var(--accent);border-color:var(--accent)}
  .rail .c.active{border-color:var(--ink)}

  .deck{margin-top:18px}
  .meta{display:flex;justify-content:space-between;align-items:baseline;margin:0 2px 10px}
  .meta .pos{font-family:var(--disp);font-weight:600;font-size:13px;letter-spacing:.08em}
  .meta .pos b{color:var(--accent);font-size:22px}
  .meta .topic{font-size:12px;color:var(--muted)}
  .qcard{background:var(--card);border:1px solid var(--line);border-radius:6px;padding:24px 22px 22px}
  .q{font-size:17px;font-weight:500;line-height:1.65}
  .q .vec{font-family:var(--disp);font-weight:700;font-style:normal}
  .opts{display:flex;flex-direction:column;gap:9px;margin-top:18px}
  .opt{display:flex;align-items:center;gap:12px;width:100%;text-align:left;font-family:var(--jp);font-size:15px;color:var(--ink);background:var(--paper);border:1px solid var(--line);border-radius:5px;padding:13px 14px;cursor:pointer;transition:border-color .12s,background .12s,transform .06s}
  .opt:hover:not(:disabled){border-color:var(--ink);transform:translateX(2px)} .opt:focus-visible{outline:2px solid var(--ink);outline-offset:2px}
  .opt .k{font-family:var(--disp);font-weight:600;font-size:12px;color:var(--muted);border:1px solid var(--line);border-radius:3px;width:22px;height:22px;display:grid;place-items:center;flex:0 0 22px}
  .opt .val{font-family:var(--disp);font-weight:500;letter-spacing:.01em}
  .opt:disabled{cursor:default}
  .opt.is-correct{border-color:var(--verify);background:var(--verify-soft)} .opt.is-correct .k{border-color:var(--verify);color:var(--verify)}
  .opt.is-wrong{border-color:var(--accent);background:var(--accent-soft)} .opt.is-wrong .k{border-color:var(--accent);color:var(--accent)}
  .opt.dim{opacity:.5}

  .reveal{margin-top:16px;display:none} .reveal.show{display:block;animation:fade .22s ease}
  @keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
  .panel{border-radius:6px;padding:15px 16px;border:1px solid;font-size:14px;line-height:1.65}
  .panel .plab{font-family:var(--disp);font-weight:700;font-size:11px;letter-spacing:.16em;text-transform:uppercase;display:flex;align-items:center;gap:7px;margin-bottom:7px}
  .panel .plab::before{content:"";width:7px;height:7px;border-radius:50%}
  .panel.snag{background:var(--accent-soft);border-color:#F0BCB0;color:#7d2417} .panel.snag .plab{color:var(--accent)} .panel.snag .plab::before{background:var(--accent)} .panel.snag b{color:#7d2417}
  .panel.good{background:var(--verify-soft);border-color:#B7DAD1;color:#0e4d42} .panel.good .plab{color:var(--verify)} .panel.good .plab::before{background:var(--verify)}
  .principle{margin-top:10px;font-size:13px;color:var(--muted);border-top:1px dashed var(--line);padding-top:10px}
  .principle .src{font-family:var(--disp);font-weight:600;color:var(--ink);font-size:12px}
  .principle code,.deep code,.deepbody code{font-family:var(--disp);font-weight:600;color:var(--ink)}

  details.deep{margin-top:10px;border-top:1px dashed var(--line);padding-top:8px}
  details.deep>summary{list-style:none;cursor:pointer;font-family:var(--disp);font-weight:600;font-size:12px;letter-spacing:.04em;color:var(--ink);display:flex;align-items:center;gap:7px;padding:3px 0}
  details.deep>summary::-webkit-details-marker{display:none}
  details.deep>summary .tw{transition:transform .15s} details.deep[open]>summary .tw{transform:rotate(90deg)}
  .deepbody{font-size:13px;color:var(--ink);line-height:1.7;margin-top:8px;background:var(--paper);border:1px solid var(--line);border-radius:5px;padding:12px 14px}
  .deepbody h4{font-family:var(--disp);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:0 0 5px;font-weight:700}
  .deepbody .blk+.blk{margin-top:11px}
  .deepbody .step{font-family:var(--disp);font-size:13px;background:var(--card);border:1px solid var(--line);border-radius:4px;padding:7px 10px;margin-top:6px;letter-spacing:.01em;line-height:1.5}
  .deepbody .step b{color:var(--accent);font-weight:700;margin-right:6px}
  .terms-h{font-family:var(--disp);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:13px 0 4px;font-weight:700}
  details.term{margin-top:7px;border:1px solid var(--line);border-radius:4px;background:var(--card)}
  details.term>summary{list-style:none;cursor:pointer;font-size:12.5px;font-weight:500;color:var(--ink);padding:8px 11px;display:flex;align-items:center;gap:8px}
  details.term>summary::-webkit-details-marker{display:none}
  details.term>summary .tw2{font-family:var(--disp);font-weight:700;color:var(--accent);transition:transform .15s;flex:0 0 auto}
  details.term[open]>summary .tw2{transform:rotate(45deg)}
  .termbody{font-size:12.5px;color:var(--muted);line-height:1.7;padding:0 11px 11px}
  .prereq{margin-top:12px;font-size:12px;color:var(--muted);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
  .prereq .chip{font-family:var(--disp);font-weight:600;font-size:11px;color:var(--ink);background:var(--card);border:1px solid var(--line);border-radius:999px;padding:3px 11px}
  .prereq .soon{font-size:10.5px;color:var(--muted);opacity:.8}

  .nav{display:flex;justify-content:flex-end;margin-top:16px}
  .next{font-family:var(--jp);font-weight:700;font-size:14px;color:var(--paper);background:var(--ink);border:none;border-radius:5px;padding:12px 22px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:background .12s,transform .06s}
  .next:hover{background:#0b131c;transform:translateX(2px)} .next:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
  .next .ar{font-family:var(--disp);font-weight:600}

  .simwrap{margin-top:12px}
  .simbtn{font-family:var(--jp);font-weight:700;font-size:13px;color:var(--accent);background:transparent;border:1px solid var(--accent);border-radius:5px;padding:9px 14px;cursor:pointer;display:inline-flex;align-items:center;gap:7px}
  .simbtn:hover{background:var(--accent-soft)}
  .simcard{margin-top:12px;border:1px solid var(--accent);border-left-width:3px;border-radius:6px;padding:15px 16px;background:var(--card);display:none}
  .simcard.show{display:block;animation:fade .2s ease}
  .simcard .stag{font-family:var(--disp);font-weight:700;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}
  .simcard .sq{font-size:15px;font-weight:500;line-height:1.6}
  .simcard .sopts{display:flex;flex-direction:column;gap:7px;margin-top:13px}
  .simcard .sout{margin-top:12px;font-size:13px;line-height:1.6;display:none} .simcard .sout.show{display:block}
  .simcard .sout.ok{color:#0e4d42} .simcard .sout.no{color:#7d2417}

  .summary{display:none} .summary.show{display:block}
  .score{background:var(--card);border:1px solid var(--line);border-radius:6px;padding:26px 24px;text-align:center}
  .score .big{font-family:var(--disp);font-weight:700;font-size:52px;line-height:1;color:var(--ink)} .score .big span{color:var(--muted);font-size:26px}
  .score .sub{color:var(--muted);font-size:14px;margin-top:8px}
  .map{margin-top:14px;display:flex;flex-direction:column;gap:9px}
  .map .row{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:5px;padding:11px 14px}
  .map .row .nm{font-size:13px;font-weight:500;flex:1}
  .map .row .bar{flex:0 0 116px;height:7px;border-radius:4px;background:var(--paper);border:1px solid var(--line);overflow:hidden;position:relative}
  .map .row .bar i{position:absolute;inset:0;width:0;background:var(--verify);transition:width .5s ease}
  .map .row .frac{font-family:var(--disp);font-weight:600;font-size:12px;color:var(--muted);flex:0 0 34px;text-align:right}
  .map .row.weak{border-color:#F0BCB0} .map .row.weak .bar i{background:var(--accent)} .map .row.weak .frac{color:var(--accent)}
  .tag{font-family:var(--disp);font-size:11px;font-weight:600;letter-spacing:.08em;color:var(--accent);margin-left:8px}
  .reviewwrap{margin-top:16px;text-align:center}
  .reviewwrap .allok{font-size:13px;color:var(--muted)}
  .restart{margin-top:16px;text-align:center;display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
  .restart button{font-family:var(--jp);font-weight:500;font-size:13px;color:var(--muted);background:transparent;border:1px solid var(--line);border-radius:5px;padding:9px 16px;cursor:pointer}
  .restart button:hover{border-color:var(--ink);color:var(--ink)}

  footer{margin-top:36px;text-align:center;font-size:11px;color:var(--muted);line-height:1.6}
  footer .src{font-family:var(--disp);letter-spacing:.04em}
  .hidden{display:none !important}

/* === 追加機能: 中断・途中結果・前回結果 === */
#deck .meta{align-items:center}
.exitbtn{margin-left:auto;background:none;border:1px solid var(--line);color:var(--muted);
  font-family:var(--jp);font-size:12px;padding:5px 12px;border-radius:6px;cursor:pointer;line-height:1}
.exitbtn:hover{border-color:var(--ink);color:var(--ink)}
.snote{display:none}
.snote.show{display:block;background:var(--card);border:1px solid var(--line);border-left:3px solid var(--accent);
  border-radius:0 6px 6px 0;padding:10px 14px;margin-bottom:16px;font-size:13px;color:var(--ink)}
.prevresult{background:var(--card);border:1px solid var(--line);border-radius:6px;
  padding:8px 14px;margin-bottom:14px;font-size:13px;color:var(--muted)}
.prevresult b{color:var(--ink);font-family:var(--disp)}
.next.ghost{background:none;border:1px solid var(--line);color:var(--ink)}
.next.ghost:hover{border-color:var(--ink)}
