:root{--bg: #0e1116;--bg-2: #161b22;--bg-3: #1c232d;--line: #2a3340;--text: #e6edf3;--muted: #97a3b3;--accent: #ff5b4a;--accent-2: #2ea043;--link: #6cb6ff;--radius: 12px;--max: 1100px;--chip-red: #ff4d4d;--chip-blue: #4d8bff;--chip-yellow: #ffd23d;--chip-white: #f5f7fa;--chip-black: #8b95a3;--chip-green: #3fd168}*{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;line-height:1.7;font-size:16px}a{color:var(--link);text-decoration:none}a:hover{text-decoration:underline}.site-header{position:sticky;top:0;z-index:20;background:linear-gradient(180deg,#11161d,#0e1116);border-bottom:1px solid var(--line);backdrop-filter:blur(6px)}.site-header .bar{max-width:var(--max);margin:0 auto;padding:12px 16px;display:flex;align-items:center;gap:12px}.brand{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--text)}.brand .dot{width:12px;height:12px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--accent);animation:pulse 1.6s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.brand small{color:var(--muted);font-weight:400}.layout{max-width:var(--max);margin:0 auto;padding:16px;display:grid;gap:24px}@media(min-width:860px){.layout.with-nav{grid-template-columns:220px 1fr;align-items:start}}.sidenav{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:12px;position:sticky;top:76px;max-height:calc(100vh - 96px);overflow:auto}.sidenav h4{margin:12px 8px 6px;font-size:12px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase}.sidenav a{display:block;padding:6px 8px;border-radius:8px;color:var(--text);font-size:14px}.sidenav a:hover{background:var(--bg-3);text-decoration:none}.sidenav a.active{background:var(--accent);color:#fff}.nav-toggle{display:none;margin-left:auto;background:var(--bg-3);color:var(--text);border:1px solid var(--line);border-radius:8px;padding:6px 12px;font-size:14px;cursor:pointer}@media(max-width:859px){.sidenav{display:none}.sidenav.open{display:block;position:fixed;inset:60px 12px auto;z-index:30;max-height:70vh;box-shadow:0 16px 48px #0009}.nav-toggle{display:inline-block}}.hero{padding:8px 4px 4px}.hero h1{margin:0 0 6px;font-size:clamp(24px,5vw,36px)}.hero p{color:var(--muted);margin:0;max-width:60ch}.chapter-title{margin:28px 4px 12px;font-size:14px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase;border-left:3px solid var(--accent);padding-left:10px}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.card{display:flex;flex-direction:column;gap:4px;padding:14px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);color:var(--text);transition:transform .12s,border-color .12s,background .12s}.card:hover{transform:translateY(-2px);border-color:var(--accent);background:var(--bg-3);text-decoration:none}.card .zh{font-weight:700;font-size:17px}.card .en{color:var(--muted);font-size:13px}.card .tag{margin-top:6px;align-self:flex-start;font-size:11px;padding:2px 8px;border-radius:999px;background:#ff5b4a24;color:var(--accent);border:1px solid rgba(255,91,74,.4)}.module{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px}.module .crumbs{font-size:13px;color:var(--muted);margin-bottom:6px}.module h1{margin:0 0 2px;font-size:clamp(22px,4vw,30px)}.module h1 .en{color:var(--muted);font-weight:400;font-size:.6em;margin-left:8px}.module .flavor{color:var(--muted);font-style:italic;border-left:3px solid var(--line);padding-left:12px;margin:14px 0 18px}.body h3{margin:22px 0 8px;font-size:17px;color:var(--accent)}.body ol,.body ul{padding-left:22px}.body li{margin:4px 0}.body .note{background:var(--bg-3);border:1px dashed var(--line);border-radius:8px;padding:8px 12px;color:var(--muted);font-size:14px}.body .codes{font-family:ui-monospace,Menlo,monospace;letter-spacing:.04em;background:var(--bg-3);padding:10px 12px;border-radius:8px}.body table{width:100%;border-collapse:collapse;margin:10px 0;font-size:14px}.body th,.body td{border:1px solid var(--line);padding:7px 9px;text-align:center}.body thead th{background:var(--bg-3)}.body tbody tr:nth-child(2n){background:#ffffff05}.body .wof td:first-child,.body .wof td:nth-child(3){font-weight:600}.body .wof-step2 th{background:var(--bg-3);white-space:nowrap}.body .wof-step2 td{text-align:left;font-size:13px}.three-col{display:grid;gap:12px}@media(min-width:720px){.three-col{grid-template-columns:repeat(3,1fr)}}.knobs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.knobs-grid figure{margin:0;background:var(--bg-3);border:1px solid var(--line);border-radius:8px;padding:10px;text-align:center}.knobs-grid figcaption{color:var(--accent);font-weight:600;margin-bottom:6px}.knobs-grid pre{margin:0;font-family:ui-monospace,Menlo,monospace;letter-spacing:.3em;line-height:1.5}.chip{display:inline-block;padding:1px 7px;border-radius:6px;font-size:.9em;font-weight:700;color:#11161d}.chip.red{background:var(--chip-red);color:#fff}.chip.blue{background:var(--chip-blue);color:#fff}.chip.yellow{background:var(--chip-yellow)}.chip.white{background:var(--chip-white)}.chip.black{background:var(--chip-black);color:#fff}.chip.green{background:var(--chip-green)}.keypad-cols{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin:8px 0}.keypad-col{background:var(--bg-3);border:1px solid var(--line);border-radius:10px;padding:8px 4px}.keypad-col .h{text-align:center;color:var(--muted);font-size:12px;margin-bottom:6px}.keypad-col img{display:block;width:100%;max-width:44px;margin:6px auto;background:#fff;border-radius:6px;padding:4px}@media(max-width:560px){.keypad-cols{grid-template-columns:repeat(3,1fr)}}.maze-img{width:100%;max-width:560px;display:block;margin:12px auto;background:#fff;border-radius:10px;padding:10px}.appendix-fig{display:block;width:100%;max-width:380px;margin:14px 0;background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px;box-shadow:0 2px 10px #0000004d}.solver{margin-top:18px;background:var(--bg-3);border:1px solid var(--line);border-radius:var(--radius);padding:16px}.solver h3{margin:0 0 12px;color:var(--accent-2);font-size:16px}.solver label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px}.solver input[type=text]{width:100%;background:var(--bg);color:var(--text);border:1px solid var(--line);border-radius:8px;padding:10px 12px;font-size:16px;font-family:ui-monospace,Menlo,monospace;letter-spacing:.1em}.solver input:focus{outline:2px solid var(--accent-2);border-color:var(--accent-2)}.btn-row{display:flex;flex-wrap:wrap;gap:6px;margin:10px 0}.btn{background:var(--bg-2);color:var(--text);border:1px solid var(--line);border-radius:8px;padding:8px 14px;font-size:15px;cursor:pointer}.btn:hover{border-color:var(--accent-2)}.btn.dot{min-width:44px;font-size:20px}.btn.ghost{color:var(--muted)}kbd{font-family:ui-monospace,Menlo,monospace;font-size:.85em;background:var(--bg-2);border:1px solid var(--line);border-bottom-width:2px;border-radius:5px;padding:1px 6px;color:var(--text)}.morse-current{font-family:ui-monospace,Menlo,monospace;font-size:22px;min-height:28px;letter-spacing:.15em;color:var(--chip-yellow)}.morse-decoded{font-size:18px;letter-spacing:.2em;margin:6px 0}.result-list{display:flex;flex-direction:column;gap:6px;margin-top:12px}.result-row{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--bg-2);border:1px solid var(--line);border-radius:8px}.result-row.hit{border-color:var(--accent-2);background:#2ea0431f}.result-row .w{font-weight:700;letter-spacing:.08em}.result-row .f{font-family:ui-monospace,Menlo,monospace;color:var(--accent-2)}.solver .empty{color:var(--muted);font-size:14px}.manual-fold{margin-top:22px;border-top:1px solid var(--line);padding-top:8px}.manual-fold>summary{cursor:pointer;list-style:none;color:var(--muted);font-size:15px;padding:8px 4px;display:flex;align-items:center;gap:6px}.manual-fold>summary::-webkit-details-marker{display:none}.manual-fold>summary:after{content:"▸";margin-left:auto;transition:transform .15s}.manual-fold[open]>summary:after{transform:rotate(90deg)}.manual-fold>summary:hover{color:var(--text)}.manual-fold .body{margin-top:8px}.ws-hint{color:var(--muted);font-size:14px;margin:0 0 12px}.ws-steppers{display:flex;flex-direction:column;gap:10px}.ws-stepper{display:grid;grid-template-columns:auto auto 2.2em auto 1fr;gap:10px;align-items:center;background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:10px 12px}.ws-stepper .step{min-width:42px;font-size:20px;padding:4px 0}.ws-stepper .ws-n{font-size:22px;text-align:center;font-variant-numeric:tabular-nums}.ws-cut{color:var(--muted);font-size:15px}.ws-cut.active{color:var(--accent)}.ws-cut.active b{font-size:18px}.kp-palette{display:grid;grid-template-columns:repeat(auto-fill,minmax(52px,1fr));gap:8px;margin:6px 0 12px}.kp-sym{background:#fff;border:2px solid var(--line);border-radius:10px;padding:6px;cursor:pointer;transition:border-color .12s,transform .08s}.kp-sym img{display:block;width:100%;aspect-ratio:1;object-fit:contain}.kp-sym:hover{border-color:var(--muted)}.kp-sym.on{border-color:var(--accent-2);box-shadow:0 0 0 3px #2ea04340}.kp-sym:disabled{opacity:.2;filter:grayscale(1);cursor:not-allowed}.kp-answer{display:flex;flex-wrap:wrap;gap:10px;align-items:center;min-height:56px;margin:4px 0}.kp-step{position:relative;background:#fff;border:1px solid var(--line);border-radius:10px;padding:6px;width:56px;height:56px}.kp-step img{width:100%;height:100%;object-fit:contain}.kp-step .badge{position:absolute;top:-8px;left:-8px;background:var(--accent-2);color:#fff;font-size:12px;font-weight:700;width:20px;height:20px;border-radius:50%;display:grid;place-items:center}.mz-modes{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0}.mz-mode{background:var(--bg-2);color:var(--text);border:1px solid var(--line);border-radius:999px;padding:7px 14px;font-size:14px;cursor:pointer}.mz-mode.on{background:var(--accent-2);color:#fff;border-color:var(--accent-2)}.mz-mode:disabled{opacity:.4;cursor:not-allowed}.mz-count{font-weight:700}.mz-hint{font-size:14px;color:var(--muted);margin:6px 0 10px}.mz-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(6,1fr);width:min(440px,100%);aspect-ratio:1;gap:4px;padding:10px;background:var(--bg-3);border:3px solid var(--line);border-radius:12px;box-shadow:inset 0 0 24px #00000073;margin:6px 0 14px}.mz-cell{position:relative;border:none;border-radius:7px;padding:0;cursor:pointer;background-color:var(--bg);background-image:radial-gradient(circle at center,#5b6b80 0 3.5px,transparent 4px);display:grid;place-items:center;line-height:1;min-width:0;min-height:0;overflow:visible;font-size:clamp(16px,5vw,26px);transition:background-color .1s,box-shadow .1s}.mz-cell:hover{background-color:var(--bg-2)}.mz-cell.on-path{background-color:#2ea04338;background-image:radial-gradient(circle at center,var(--accent-2) 0 3.5px,transparent 4px)}.mz-cell.wr:after{content:"";position:absolute;top:0;bottom:-4px;right:-4px;width:4px;background:#e6edf3;border-radius:2px;z-index:5}.mz-cell.wb:before{content:"";position:absolute;left:0;right:-4px;bottom:-4px;height:4px;background:#e6edf3;border-radius:2px;z-index:5}.mz-cell .g{position:relative;z-index:4;font-weight:800}.mz-cell.mk-circle{background-image:none;box-shadow:inset 0 0 0 2px #16a34a}.mz-cell.mk-start{background-color:#11233f;background-image:none;box-shadow:inset 0 0 0 2px #2563eb,0 0 14px #2563eb99}.mz-cell.mk-goal{background-color:#3a1414;background-image:none;box-shadow:inset 0 0 0 2px #dc2626,0 0 14px #dc262699}.mz-cell .g.circ{color:#22c55e}.mz-cell .g.start{color:#60a5fa}.mz-cell .g.goal{color:#f87171}.mz-answer{display:flex;flex-wrap:wrap;gap:6px;align-items:center;min-height:40px}.mz-step{display:inline-flex;align-items:baseline;gap:3px;background:var(--bg-2);border:1px solid var(--line);border-radius:8px;padding:5px 9px;font-size:14px}.mz-step b{font-size:18px;color:var(--accent-2)}.mz-arrow{color:var(--muted)}.toggle-row{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 14px}.toggle{display:inline-flex;align-items:center;gap:5px;background:var(--bg-2);color:var(--text);border:1px solid var(--line);border-radius:999px;padding:8px 14px;font-size:15px;cursor:pointer;user-select:none}.toggle:before{content:"○";color:var(--muted)}.toggle.on{border-color:var(--accent-2);background:#2ea04329}.toggle.on:before{content:"●";color:var(--accent-2)}.cw-result{font-size:28px;font-weight:800;text-align:center;margin:14px 0 4px;min-height:36px}.cw-result.cut{color:var(--accent)}.cw-result.keep{color:var(--accent-2)}.cw-reason{text-align:center;color:var(--muted);font-size:14px}.pw-wheels{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.pw-wheels .wheel label{text-align:center}.pw-wheels input{text-align:center;text-transform:lowercase}.pw-answer{margin-top:14px;font-size:24px;font-weight:800;letter-spacing:.2em;color:var(--accent-2);min-height:30px;text-align:center}.pw-answer.multi{font-size:16px;color:var(--chip-yellow);letter-spacing:normal}.morse-ref{display:grid;grid-template-columns:repeat(auto-fill,minmax(86px,1fr));gap:4px;margin-top:10px}.morse-ref span{font-family:ui-monospace,Menlo,monospace;font-size:13px;background:var(--bg-2);border:1px solid var(--line);border-radius:6px;padding:4px 6px}.morse-ref b{color:var(--chip-yellow)}.site-footer{max-width:var(--max);margin:24px auto;padding:16px;color:var(--muted);font-size:13px;border-top:1px solid var(--line);text-align:center}
