:root{--bg:#0e1116;--bg-elev:#161b22;--bg-elev2:#1c2230;--border:#2a313c;--text:#e6edf3;--text-dim:#9aa7b4;--accent:#0a84ff;--ok:#2ea043;--warn:#d29922;--bad:#f85149;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}*{box-sizing:border-box}html,body,#root{background:var(--bg);min-height:100vh;color:var(--text);margin:0}button{cursor:pointer;font-family:inherit}code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.btn{border:1px solid var(--border);background:var(--bg-elev2);color:var(--text);border-radius:10px;padding:10px 18px;font-size:15px;font-weight:600;transition:transform 60ms,background .15s,opacity .15s}.btn:hover{background:#232b3a}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn--primary{background:var(--accent);color:#fff;border-color:#0000}.btn--primary:hover{filter:brightness(1.08);background:var(--accent)}.btn--ghost{background:0 0}.btn--link{color:var(--text-dim);background:0 0;border:none;padding:6px 0;font-weight:600}.btn--link:hover{color:var(--text)}.keycaps,.keycaps__group{align-items:center;gap:4px;display:inline-flex}.keycaps__plus{color:var(--text-dim);font-weight:600}.keycap{color:#11151c;text-align:center;background:#f5f6f8;border:1px solid #c7ccd4;border-bottom-width:3px;border-radius:7px;font-family:ui-monospace,monospace;font-weight:700;line-height:1;display:inline-block}.keycaps--sm .keycap{min-width:14px;padding:4px 7px;font-size:12px}.keycaps--md .keycap{min-width:18px;padding:6px 10px;font-size:15px}.keycaps--lg .keycap{min-width:24px;padding:10px 14px;font-size:20px}.keycaps--leader{flex-wrap:wrap;gap:8px}.keycaps__step{align-items:center;gap:8px;display:inline-flex}.keycaps__then{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;font-size:.7em;font-weight:600}.answer-keys{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;display:inline-flex}.answer-keys__alts{opacity:.8;flex-wrap:wrap;align-items:center;gap:8px;display:inline-flex}.answer-keys__or{color:var(--text-dim);font-size:13px;font-weight:600}.menu{max-width:980px;margin:0 auto;padding:64px 24px}.menu__head{text-align:center;margin-bottom:48px}.menu__logo{font-size:56px}.menu__head h1{letter-spacing:-.5px;margin:8px 0 6px;font-size:40px}.menu__head p{color:var(--text-dim);margin:0;font-size:17px}.menu__grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px;display:grid}.dojo-card{text-align:left;background:var(--bg-elev);border:1px solid var(--border);border-radius:14px;padding:22px;transition:transform 80ms,border-color .15s}.dojo-card:hover{border-color:var(--accent);transform:translateY(-3px)}.dojo-card h2{margin:0 0 6px;font-size:22px}.dojo-card p{color:var(--text-dim);margin:0 0 16px;font-size:14px;line-height:1.5}.dojo-card__meta{color:var(--accent);font-size:12px;font-weight:600}.overview{max-width:820px;margin:0 auto;padding:40px 24px 80px}.overview__head h1{margin:14px 0 6px;font-size:34px}.overview__head p{color:var(--text-dim);margin:0}.overview__mode{color:var(--accent);border:1px solid var(--accent);border-radius:999px;margin-top:14px;padding:4px 12px;font-size:12px;font-weight:700;display:inline-block}.overview__lessons{flex-direction:column;gap:18px;margin-top:28px;display:flex}.lesson-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:14px;padding:22px}.lesson-card__head{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.lesson-card__head h2{margin:0 0 4px;font-size:20px}.lesson-card__head p{color:var(--text-dim);margin:0;font-size:14px}.lesson-card__num{background:var(--accent);color:#fff;vertical-align:middle;border-radius:8px;place-items:center;width:26px;height:26px;margin-right:8px;font-size:14px;display:inline-grid}.lesson-card__list{grid-template-columns:1fr 1fr;gap:8px 24px;margin:18px 0 0;padding:0;list-style:none;display:grid}.lesson-card__list li{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:10px;padding:6px 0;display:flex}.lesson-card__name{font-size:14px}.lesson{max-width:820px;margin:0 auto;padding:14px 24px 32px}.lesson__bar{align-items:center;gap:14px;margin-bottom:16px;display:flex}.lesson__progressbar{background:var(--bg-elev2);border-radius:999px;flex:1;height:6px;overflow:hidden}.lesson__progressbar>div{background:var(--ok);height:100%;transition:width .3s}.toggle{border:1px solid var(--border);background:var(--bg-elev2);color:var(--text-dim);white-space:nowrap;border-radius:999px;padding:7px 12px;font-size:13px;font-weight:600}.toggle:hover{color:var(--text)}.toggle--on{border-color:var(--accent);color:#cfe5ff;background:#0a84ff2e}.slide{background:var(--bg-elev);border:1px solid var(--border);border-radius:16px;padding:22px}.slide__progress{color:var(--text-dim);justify-content:space-between;margin-bottom:14px;font-size:13px;font-weight:600;display:flex}.slide__count{font-variant-numeric:tabular-nums}.slide__title{margin:18px 0 8px;font-size:26px}.slide__desc{color:var(--text-dim);margin:0;font-size:15px;line-height:1.6}.clip{border:1px solid var(--border);aspect-ratio:16/9;background:#000;border-radius:12px;max-height:44vh;margin:0 auto;position:relative;overflow:hidden}.clip__video{object-fit:contain;width:100%;height:100%;display:block}.clip__missing{color:var(--text-dim);flex-direction:column;justify-content:center;align-items:center;gap:8px;display:flex;position:absolute;inset:0}.clip__missing code{color:var(--warn);font-size:12px}.clip--drawing{cursor:crosshair}.clip__draw{z-index:2;cursor:crosshair;touch-action:none;position:absolute;inset:0}.clip__sel{pointer-events:none;background:#ffffff1f;border:2px dashed #fff;position:absolute;box-shadow:0 0 0 9999px #00000059}.clip__hint{color:#fff;pointer-events:none;background:#000000a6;border-radius:8px;padding:4px 10px;font-size:12px;position:absolute;top:12px;left:50%;transform:translate(-50%)}.clip__tools{z-index:3;gap:6px;display:flex;position:absolute;bottom:10px;right:10px}.clip__btn{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;border:1px solid #ffffff40;border-radius:8px;padding:5px 10px;font-size:12px}.clip__btn--on{background:var(--accent,#2f81f7);border-color:#0000}.practice{border:1px dashed var(--border);text-align:center;border-radius:12px;justify-content:center;align-items:center;min-height:168px;margin-top:18px;padding:16px 20px;transition:border-color .15s,background .15s;display:flex}.practice--solved{border-style:solid;border-color:var(--ok);background:#2ea04314}.practice--wrong{border-color:var(--bad);animation:.3s shake}@keyframes shake{25%{transform:translate(-5px)}75%{transform:translate(5px)}}.practice__prompt{flex-direction:column;gap:12px;display:flex}.practice__cta{font-size:16px;font-weight:600}.practice__pressed{color:var(--text-dim);font-size:14px}.practice__pressed-keys{color:var(--text);font-family:ui-monospace,monospace;font-weight:700}.practice__x{color:var(--bad);font-weight:700}.practice__result{flex-direction:column;align-items:center;gap:12px;display:flex}.practice__result--ok{color:var(--ok);font-size:18px;font-weight:700}.practice__check{font-size:32px}.practice__hint{color:var(--text-dim);font-size:14px}.slide__actions{justify-content:space-between;align-items:center;gap:12px;margin-top:18px;display:flex}.slide__hints{color:var(--text-dim);font-size:13px}.slide__actions-btns{gap:12px;display:flex}.hintkey{background:var(--bg-elev2);border:1px solid var(--border);color:var(--text);border-bottom-width:2px;border-radius:5px;margin:0 1px;padding:1px 6px;font-family:ui-monospace,monospace;font-size:12px;display:inline-block}.lesson-card__cmd{color:var(--text-dim);background:var(--bg-elev2);border:1px solid var(--border);letter-spacing:1px;border-radius:6px;padding:3px 8px;font-family:ui-monospace,monospace;font-size:12px}.practice.cmd{text-align:left;display:block}.cmd__prompt{flex-direction:column;align-items:center;gap:12px;display:flex}.cmd__cta{font-size:16px;font-weight:600}.cmd__line{border:1px solid var(--border);background:#0b0e14;border-radius:10px;align-items:center;gap:10px;width:100%;max-width:460px;padding:12px 14px;font-family:ui-monospace,monospace;font-size:17px;display:flex}.practice--wrong .cmd__line{border-color:var(--bad)}.cmd__sigil{color:var(--accent);-webkit-user-select:none;user-select:none;font-weight:700}.cmd__input{color:var(--text);font:inherit;caret-color:var(--accent);background:0 0;border:none;outline:none;flex:1}.cmd__input::placeholder{color:var(--text-dim);opacity:.6}.cmd__feedback--wrong{color:var(--bad);font-size:13px}.cmd__reveal{flex-direction:column;gap:14px;width:100%;display:flex}.cmd__reveal-head{flex-wrap:wrap;justify-content:center;align-items:center;gap:14px;display:flex}.cmd__answer{border:1px solid var(--border);color:var(--text);background:#0b0e14;border-radius:10px;padding:10px 16px;font-family:ui-monospace,monospace;font-size:19px}.cmd__answer .cmd__sigil{margin-right:6px}.cmd__flags{flex-direction:column;gap:8px;width:100%;max-width:560px;margin:0 auto;padding:0;list-style:none;display:flex}.cmd__flags li{align-items:baseline;gap:12px;font-size:14px;display:flex}.cmd__flag{color:var(--accent);min-width:44px;font-family:ui-monospace,monospace;font-weight:700}.cmd__flag-note{color:var(--text-dim);line-height:1.5}.cmd__flag-row--shared .cmd__flag-note{color:var(--text)}.lesson-done{text-align:center;background:var(--bg-elev);border:1px solid var(--border);border-radius:16px;max-width:520px;margin:80px auto;padding:48px 32px}.lesson-done__badge{font-size:64px}.lesson-done h2{margin:12px 0 6px}.lesson-done p{color:var(--text-dim);margin:0 0 24px}.lesson-done__actions{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;display:flex}
