:root{--paper: #F4F1E8;--card: #FDFCF8;--card-2: #F8F5EC;--ink: #23201A;--ink-2: #6B6353;--ink-3: #9B927E;--line: #E4DECD;--line-strong: #CFC7B0;--red: #BC3F22;--red-soft: #F4E2DA;--amber: #8F6A14;--amber-soft: #F0E6CB;--green: #3F6B4F;--green-soft: #DFE8DC;--plate: #20303E;--plate-fg: #FBFBF7;--surface: var(--paper);--surface-card: var(--card);--text-1: var(--ink);--text-2: var(--ink-2);--text-3: var(--ink-3);--grade-wrong: var(--red);--grade-acceptable: var(--amber);--grade-correct: var(--green)}[data-theme=dark]{--paper: #1C1A15;--card: #25221C;--card-2: #2B2820;--ink: #EAE4D6;--ink-2: #A89F8C;--ink-3: #7A7260;--line: #363228;--line-strong: #4A4536;--red: #D86A4E;--red-soft: #3D2A23;--amber: #C9A24A;--amber-soft: #38301D;--green: #7FA98C;--green-soft: #283228;--plate: #141E27}:root{--f-ui: "Hanken Grotesk", system-ui, sans-serif;--f-jp: "Noto Sans JP", sans-serif;--f-mono: "IBM Plex Mono", monospace;--jp-size: 30px;--t-screen-title: 26px;--t-prompt: 28px;--t-verdict: 21px;--t-body: 16px;--t-small: 14px;--t-label: 11px}:root{--r-xs: 5px;--r-sm: 8px;--r-md: 10px;--r-lg: 12px;--r-round: 999px;--border-hairline: 1px solid var(--line);--border-strong: 1px solid var(--line-strong);--shadow-pop: 0 8px 24px rgba(35, 32, 26, .1);--dur: .12s;--dur-pop: .19s;--ease: ease;--ease-soft: cubic-bezier(.22, 1, .36, 1)}.screen{width:100%;height:100%;background:var(--paper);color:var(--ink);font-family:var(--f-ui);font-size:16px;line-height:1.5;display:flex;flex-direction:column;-webkit-font-smoothing:antialiased}.screen *{box-sizing:border-box}.jp{font-family:var(--f-jp);font-size:var(--jp-size);line-height:1.9;font-weight:400}.jp rt{font-size:.42em;color:var(--ink-2);font-weight:400;letter-spacing:.05em}.jp-sm{font-family:var(--f-jp);font-size:calc(var(--jp-size) * .62);line-height:1.8}.jp-sm rt{font-size:.45em;color:var(--ink-2)}.mono{font-family:var(--f-mono);font-size:12px;letter-spacing:.04em}.label{font-family:var(--f-mono);font-size:var(--t-label);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);font-weight:500}.h-screen{font-size:var(--t-screen-title);font-weight:600;letter-spacing:-.01em;line-height:1.2}.quiet{color:var(--ink-2)}.quieter{color:var(--ink-3)}.btn{font-family:var(--f-ui);font-size:15px;font-weight:600;padding:11px 22px;border-radius:var(--r-sm);border:1px solid transparent;cursor:pointer;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease),color var(--dur) var(--ease);display:inline-flex;align-items:center;gap:8px;line-height:1;white-space:nowrap;text-decoration:none}.btn-primary{background:var(--ink);color:var(--paper)}.btn-primary:hover{background:#000}[data-theme=dark] .btn-primary:hover{background:#fff}.btn-secondary{background:transparent;color:var(--ink);border-color:var(--line-strong)}.btn-secondary:hover{border-color:var(--ink-2);background:var(--card)}.btn-quiet{background:none;border:none;color:var(--ink-2);font-family:var(--f-ui);font-size:14px;font-weight:500;cursor:pointer;padding:8px 4px;text-decoration:underline;text-decoration-color:var(--line-strong);text-underline-offset:3px;transition:color var(--dur) var(--ease);white-space:nowrap}.btn-quiet:hover{color:var(--ink)}.btn-lg{font-size:16px;padding:14px 30px}.tag{font-family:var(--f-mono);font-size:11.5px;letter-spacing:.03em;padding:3px 9px;border-radius:var(--r-xs);border:1px solid var(--line);color:var(--ink-2);background:var(--card);white-space:nowrap}.tag-filter{cursor:pointer;transition:all var(--dur) var(--ease);padding:5px 12px;font-size:12px}.tag-filter:hover{border-color:var(--ink-2);color:var(--ink)}.tag-filter.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}.status{font-family:var(--f-mono);font-size:11.5px;letter-spacing:.05em;padding:3px 10px;border-radius:var(--r-xs);white-space:nowrap}.status-failing{color:var(--red);background:var(--red-soft)}.status-fresh{color:var(--amber);background:var(--amber-soft)}.status-learning{color:var(--ink-2);background:var(--card-2);border:1px solid var(--line)}.status-solid{color:var(--green);background:var(--green-soft)}.verdict{font-size:var(--t-verdict);font-weight:700;letter-spacing:-.01em}.verdict-correct{color:var(--green)}.verdict-acceptable{color:var(--amber)}.verdict-wrong{color:var(--red)}.fix-line{font-size:16px;color:var(--ink)}.fix-line .jp-inline{font-family:var(--f-jp);font-size:17px}mark.diff-wrong{background:none;color:var(--red);text-decoration:underline wavy var(--red) 1.5px;text-underline-offset:6px}mark.diff-model{background:none;color:var(--ink);border-bottom:2px solid var(--green);padding-bottom:2px}ruby.redpen del{text-decoration:line-through 2px var(--red);text-decoration-skip-ink:none}ruby.redpen rt{color:var(--red);font-size:.55em;font-weight:500}ruby.redpen-alt>span{text-decoration:underline dotted 2px var(--amber);text-underline-offset:7px}ruby.redpen-alt rt{color:var(--amber);font-size:.55em;font-weight:500}.stamp{width:64px;height:64px;border-radius:50%;flex-shrink:0;opacity:.85;display:flex;align-items:center;justify-content:center;font-family:var(--f-jp);font-size:30px;font-weight:700;transform:rotate(-8deg);border:2.5px solid currentColor}.stamp-wrong{color:var(--red)}.stamp-acceptable{color:var(--amber)}.stamp-correct{color:var(--green)}.jp-input{font-family:var(--f-jp);font-size:var(--jp-size);line-height:1.7;background:var(--card);border:1px solid var(--line-strong);border-radius:var(--r-md);padding:20px 24px;color:var(--ink);width:100%;transition:border-color var(--dur) var(--ease-soft),box-shadow var(--dur) var(--ease-soft)}.jp-input:focus,.jp-input.focused{outline:none;border-color:var(--ink-2);box-shadow:0 0 0 3px #23201a0f}.jp-input::placeholder{color:var(--ink-3)}.panel{background:var(--card);border:var(--border-hairline);border-radius:var(--r-lg)}.session-bar{display:flex;align-items:center;justify-content:space-between;padding:18px 36px;border-bottom:1px solid var(--line)}.session-ticks{display:flex;gap:6px;align-items:center}.tick{width:18px;height:4px;border-radius:2px;background:var(--line-strong)}.tick.done-correct{background:var(--green)}.tick.done-acceptable{background:var(--amber)}.tick.done-wrong{background:var(--red)}.tick.now{background:var(--ink);height:6px}.hint-link{background:none;border:none;cursor:pointer;padding:6px 2px;font-family:var(--f-ui);font-size:13.5px;color:var(--ink-3);text-decoration:underline dotted var(--ink-3);text-underline-offset:3px;transition:color var(--dur) var(--ease)}.hint-link:hover{color:var(--amber);text-decoration-color:var(--amber)}.sign-plate{background:var(--plate);color:var(--plate-fg);border-radius:var(--r-sm);padding:34px 56px;display:inline-block;box-shadow:inset 0 0 0 3px #fbfbf7d9,inset 0 0 0 5px var(--plate)}.sign-plate .jp{font-weight:700;letter-spacing:.12em;font-size:calc(var(--jp-size) * 1.5);line-height:1.3;white-space:nowrap}.row-hover{transition:background var(--dur) var(--ease)}.row-hover:hover{background:var(--card-2)}.dot{width:8px;height:8px;border-radius:50%;display:inline-block}.dot-correct{background:var(--green)}.dot-acceptable{background:var(--amber)}.dot-wrong{background:var(--red)}.dot-none{background:var(--line-strong)}.app-nav{display:flex;align-items:center;gap:4px}.app-nav a{font-size:14px;font-weight:600;color:var(--ink-3);text-decoration:none;padding:7px 14px;border-radius:var(--r-xs);transition:color var(--dur) var(--ease),background var(--dur) var(--ease)}.app-nav a:hover{color:var(--ink);background:var(--card-2)}.app-nav a.on{color:var(--ink);background:var(--card);border:1px solid var(--line)}.study-main{margin:0 auto;flex:1;display:flex;flex-direction:column;justify-content:center;padding-bottom:70px}.study-actions{position:fixed;left:0;right:0;bottom:0;z-index:10;display:flex;flex-direction:column;align-items:stretch;gap:8px;background:var(--paper);border-top:1px solid var(--line);padding:12px 18px calc(16px + env(safe-area-inset-bottom))}.study-actions>.btn{width:100%;justify-content:center;padding:15px 0;font-size:16px}@media(max-width:480px){:root{--jp-size: 24px}html,body{height:100%}.screen{height:100dvh}.screen>main{flex:1;overflow-y:auto;min-height:0}.session-bar{padding:16px 20px}.session-ticks{gap:4px}.tick{width:12px}.study-main{width:100%!important;padding:28px 20px 100px}}.set-page{max-width:760px;margin:0 auto;padding:44px 40px 72px}.set-titlewrap{margin-bottom:14px}.set-title{font-size:28px;font-weight:600;letter-spacing:-.02em;margin:0;line-height:1.1}.set-sub{color:var(--ink-2);font-size:14px;line-height:1.55;margin:8px 0 0;max-width:52ch;text-wrap:pretty}.set-section{margin-top:34px}.set-shead{display:flex;align-items:center;justify-content:space-between;margin:0 0 12px 2px}.shead-l{display:flex;align-items:center;gap:8px}.shead-icon{color:var(--ink);display:block;flex:none}.set-snote{color:var(--green)}.set-rows{overflow:hidden}.set-row{display:flex;gap:36px;padding:20px 24px;align-items:flex-start}.set-row+.set-row{border-top:1px solid var(--line)}.rl{flex:1 1 auto;min-width:0}.rname{font-size:15px;font-weight:600;color:var(--ink);letter-spacing:-.003em;display:flex;align-items:center;gap:9px}.rhelp{font-size:13px;color:var(--ink-2);margin-top:5px;line-height:1.5;max-width:42ch;text-wrap:pretty}.rc{flex:0 0 300px;display:flex;flex-direction:column;align-items:flex-end;gap:10px}.tag-adv{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);border:1px solid var(--line-strong);border-radius:var(--r-xs);padding:2px 6px;font-weight:500}.stack{display:flex;flex-direction:column;align-items:flex-end;gap:9px;width:100%}.field{font-family:var(--f-mono);font-size:13px;line-height:1.3;background:var(--card);border:1px solid var(--line-strong);border-radius:var(--r-md);padding:10px 13px;color:var(--ink);width:100%;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}.field:focus{outline:none;border-color:var(--ink-2);box-shadow:0 0 0 3px #23201a0f}.field::placeholder{color:var(--ink-3)}.masked-row{display:flex;align-items:center;gap:14px;justify-content:flex-end;width:100%}.masked{font-family:var(--f-mono);font-size:15px;color:var(--ink-3);letter-spacing:.12em;line-height:1}.btnrow{display:flex;align-items:center;gap:12px}.btn-xs{font-size:13px;padding:8px 15px}.numfield{display:flex;align-items:center;gap:10px}.field.num{width:96px;text-align:right}.unit{font-family:var(--f-mono);font-size:12px;color:var(--ink-3)}.selectwrap{position:relative;width:100%}.field.select{width:100%;appearance:none;-webkit-appearance:none;padding-right:34px;cursor:pointer}.caret{position:absolute;right:13px;top:50%;transform:translateY(-50%);color:var(--ink-3);font-size:11px;pointer-events:none}.readstat{display:flex;align-items:center;gap:8px}.readstat .mono{color:var(--ink-2)}.tg{width:46px;height:26px;border-radius:999px;background:var(--line-strong);position:relative;cursor:pointer;transition:background var(--dur) var(--ease);border:none;padding:0;flex:none}.tg.on{background:var(--ink)}.tg:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:var(--card);transition:transform var(--dur) var(--ease);box-shadow:0 1px 2px #23201a2e}.tg.on:after{transform:translate(20px)}.seg{display:inline-flex;border:1px solid var(--line-strong);border-radius:var(--r-sm);overflow:hidden;background:var(--card)}.seg button{font-family:var(--f-ui);font-size:13px;font-weight:600;padding:8px 18px;border:none;background:none;color:var(--ink-2);cursor:pointer;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.seg button+button{border-left:1px solid var(--line-strong)}.seg button.on{background:var(--ink);color:var(--paper)}.is-playing{color:var(--ink-2)}.set-foot{margin-top:36px;text-align:center;color:var(--ink-3);letter-spacing:.06em}@media(max-width:480px){.set-page{padding:26px 18px 56px}.set-row{flex-direction:column;gap:14px;padding:18px}.rc{flex:none;width:100%;align-items:stretch}.stack{align-items:stretch}.masked-row{justify-content:space-between}.seg{width:100%}.seg button{flex:1}}html,body{height:100%;margin:0}body{background:var(--paper);color:var(--ink);font-family:var(--f-ui);-webkit-font-smoothing:antialiased}
