/*! tailwindcss v4.2.4 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:"Nunito", system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--spacing:.25rem;--text-3xl:1.875rem;--text-3xl--line-height:calc(2.25 / 1.875);--text-5xl:3rem;--text-5xl--line-height:1;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-coral:var(--coral)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.visible{visibility:visible}.fixed{position:fixed}.static{position:static}.sticky{position:sticky}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.block{display:block}.contents{display:contents}.hidden{display:none}.inline{display:inline}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.bg-coral{background-color:var(--color-coral)}.p-4{padding:calc(var(--spacing) * 4)}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}.lowercase{text-transform:lowercase}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}}:root{--ink:#1f1b16;--ink-soft:#3a342c;--paper:#faf6ec;--paper-2:#f3ecd8;--paper-3:#ece4cc;--rule:#2b2620;--coral:#e26d5c;--mustard:#e3a72f;--teal:#2a9d8f;--lavender:#8a7fbf;--sticky:#fff27a;--sticky-shd:#0000002e;--terminal-bg:#1f1b16;--terminal-fg:#faf6ec;--terminal-accent:#e3a72f}[data-theme=dark]{--ink:#ece7d7;--ink-soft:#c9c4b3;--paper:#1c2a2a;--paper-2:#243433;--paper-3:#2c3d3c;--rule:#ece7d7;--coral:#d97a6c;--mustard:#d4a85a;--teal:#5fb3a8;--lavender:#a99fcf;--sticky:#f7e572;--sticky-shd:#0000008c;--terminal-bg:#0c1414;--terminal-fg:#ece7d7;--terminal-accent:#d4a85a}html{font-size:18px}body{background:var(--paper);color:var(--ink);background-image:radial-gradient(#2b262009 1px,#0000 1px),radial-gradient(#2b262006 1px,#0000 1px);background-position:0 0,11px 7px;background-size:22px 22px,14px 14px;min-height:100dvh;font-family:Nunito,system-ui,sans-serif;line-height:1.65}html[lang=zh] body{font-family:LXGW WenKai,Nunito,system-ui,sans-serif}html[lang=zh] h1,html[lang=zh] h2,html[lang=zh] h3,html[lang=zh] .marker,html[lang=zh] .sticky{font-family:LXGW WenKai,Patrick Hand,cursive}h1,h2,h3,h4,.marker{color:var(--ink);letter-spacing:.01em;font-family:Patrick Hand,LXGW WenKai,cursive;line-height:1.15}h1{font-size:3rem}h2{font-size:2rem}h3{font-size:1.5rem}p{margin:0 0 1rem}a{color:var(--coral);text-underline-offset:3px;-webkit-text-decoration:underline #e26d5c8c;text-decoration:underline #e26d5c8c;text-decoration-thickness:2px}a:hover{-webkit-text-decoration-color:var(--coral);-webkit-text-decoration-color:var(--coral);text-decoration-color:var(--coral)}::selection{background:var(--mustard);color:var(--ink)}.shell{max-width:64rem;margin:0 auto;padding:0 1.25rem 4rem}@media (min-width:768px){.shell{padding:0 2rem 6rem}}.sketch-card{background:var(--paper-2);border:2.5px solid var(--rule);box-shadow:3px 3px 0 var(--rule), 6px 6px 18px #00000014;border-radius:14px 18px 12px 20px/16px 12px 20px 14px;padding:1.5rem;position:relative}.sketch-card:after{content:"";border:1.5px solid var(--rule);border-radius:inherit;opacity:.35;pointer-events:none;position:absolute;inset:4px}[data-theme=dark] .sketch-card{box-shadow:3px 3px 0 var(--rule), 6px 6px 18px #00000059}.lean-1{transform:rotate(-1.5deg)}.lean-2{transform:rotate(1deg)}.lean-3{transform:rotate(-.8deg)}.lean-4{transform:rotate(1.4deg)}.sticky{background:var(--sticky);color:#2a2a1a;box-shadow:4px 6px 12px var(--sticky-shd);border-radius:2px;max-width:22rem;padding:1rem 1.1rem;font-family:Patrick Hand,LXGW WenKai,cursive;font-size:1.15rem;display:inline-block;position:relative;transform:rotate(-1.4deg)}.sticky:nth-of-type(2n){transform:rotate(1.1deg)}.sticky--lean-r{transform:rotate(2.2deg)}.sticky--lean-l{transform:rotate(-2.4deg)}.terminal{background:var(--terminal-bg);color:var(--terminal-fg);-webkit-overflow-scrolling:touch;white-space:pre;box-shadow:4px 4px 0 var(--rule);border:0;border-radius:6px;padding:1.1rem 1.25rem;font-family:JetBrains Mono,ui-monospace,monospace;font-size:.95rem;line-height:1.55;position:relative;overflow-x:auto}.terminal-header{background:var(--terminal-bg);color:var(--terminal-fg);opacity:.85;border-radius:6px 6px 0 0;align-items:center;gap:.4rem;padding:.55rem .9rem .15rem;font-family:JetBrains Mono,monospace;font-size:.8rem;display:flex}.terminal-header+.terminal{border-radius:0 0 6px 6px}.terminal-dot{border-radius:50%;width:10px;height:10px}.terminal-dot-r{background:#ff605c}.terminal-dot-y{background:#ffbd44}.terminal-dot-g{background:#00ca4e}.terminal-label{opacity:.7;margin-left:.5rem}.terminal .prompt{color:var(--terminal-accent);-webkit-user-select:none;user-select:none}.terminal .comment{color:#9aa39a}.terminal .var{color:#f7e572}.terminal .str{color:#80d8c0}.btn{background:var(--paper);color:var(--ink);border:2.5px solid var(--rule);cursor:pointer;box-shadow:2px 2px 0 var(--rule);border-radius:12px 16px 10px 14px/14px 10px 16px 12px;align-items:center;gap:.4rem;min-height:44px;padding:.55rem 1.1rem;font-family:Patrick Hand,LXGW WenKai,cursive;font-size:1.1rem;transition:transform .12s,box-shadow .12s,background .15s;display:inline-flex}.btn:hover{box-shadow:4px 4px 0 var(--rule);transform:translate(-1px,-1px)}.btn:active{box-shadow:1px 1px 0 var(--rule);transform:translate(1px,1px)}.btn--primary{background:var(--coral);color:#fff}.btn--accent{background:var(--mustard)}.btn--ghost{background:0 0}.chip{border:1.5px solid var(--rule);background:var(--paper);color:var(--ink);border-radius:999px;align-items:center;gap:.3rem;padding:.15rem .65rem;font-family:Patrick Hand,cursive;font-size:.95rem;display:inline-flex}.chip--coral{border-color:var(--coral);background:#e26d5c26}.chip--teal{border-color:var(--teal);background:#2a9d8f26}.chip--mustard{border-color:var(--mustard);background:#e3a72f2e}.brand{font-family:JetBrains Mono,monospace;font-weight:600}.scribble-under{display:inline-block;position:relative}.scribble-under:after{content:"";background:var(--mustard);opacity:.55;z-index:-1;filter:url(#wobble);border-radius:4px;height:8px;position:absolute;bottom:-6px;left:-4px;right:-4px}.coffee-stain{pointer-events:none;background:radial-gradient(circle,#78461e24 50%,#78461e0a 70%,#0000 80%);border-radius:50%;width:90px;height:90px;position:absolute}.checkmark{border:2.5px solid var(--rule);background:var(--paper-2);width:28px;height:28px;color:var(--ink);border-radius:50% 48% 52% 50%/48% 52% 50% 50%;justify-content:center;align-items:center;font-family:Patrick Hand,cursive;font-size:1.2rem;display:inline-flex}.checkmark--done{background:var(--mustard)}.dnd-bin{border:2.5px dashed var(--rule);background:var(--paper-2);border-radius:14px 18px 12px 16px/16px 12px 18px 14px;min-height:8rem;padding:1rem}.dnd-bin[data-over=true]{background:#e3a72f40}.dnd-bin[data-correct=true]{border-color:var(--teal)}.dnd-bin[data-wrong=true]{border-color:var(--coral)}.dnd-chip{background:var(--paper);border:2px solid var(--rule);cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;border-radius:8px 12px 6px 10px/10px 6px 12px 8px;margin:.25rem;padding:.4rem .85rem;font-family:Patrick Hand,cursive;font-size:1rem;display:inline-block}.dnd-chip[data-selected=true]{background:var(--mustard);transform:rotate(-2deg)}.dnd-chip[data-placed=true]{opacity:.6;cursor:default}.empty-slot{background:var(--sticky);color:#2a2a1a;box-shadow:4px 6px 12px var(--sticky-shd);border-left:6px solid var(--coral);border-radius:2px;max-width:32rem;padding:1.25rem 1.4rem;font-family:Patrick Hand,LXGW WenKai,cursive;font-size:1.05rem;transform:rotate(-1deg)}.empty-slot strong{color:var(--coral);margin-bottom:.25rem;font-size:1.15rem;display:block}.skip-link{background:var(--ink);color:var(--paper);z-index:100;padding:.5rem 1rem;font-family:JetBrains Mono,monospace;position:absolute;top:-100%;left:0}.skip-link:focus{top:0}:focus-visible{outline:3px solid var(--coral);outline-offset:3px;border-radius:4px}[tabindex="-1"]:focus{outline:none}@media (pointer:coarse){button,a,.dnd-chip,[role=button]{min-height:44px}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.lean-1,.lean-2,.lean-3,.lean-4,.sticky,.sticky--lean-l,.sticky--lean-r{transform:none}}@media (max-width:480px){html{font-size:17px}h1{font-size:2.2rem}h2{font-size:1.6rem}body{overflow-x:hidden}.terminal{padding:.9rem 1rem;font-size:.82rem}.sketch-card{padding:1.2rem 1.1rem}}*{scrollbar-width:thin;scrollbar-color:var(--rule) transparent}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--rule);opacity:.4;border-radius:4px}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.site-header{border-bottom:1.5px dashed var(--rule);justify-content:space-between;align-items:center;max-width:64rem;margin:0 auto;padding:1rem 1.25rem;display:flex}.site-header .brand-mark{color:var(--ink);align-items:baseline;gap:.4rem;font-family:Patrick Hand,LXGW WenKai,cursive;font-size:1.6rem;text-decoration:none;display:inline-flex}.site-header .brand-mark .zh{opacity:.7;font-size:1.2rem}.site-header .controls{gap:.5rem;display:flex}.site-footer{border-top:1.5px dashed var(--rule);max-width:64rem;color:var(--ink-soft);text-align:center;margin:4rem auto 0;padding:1.5rem 1.25rem;font-family:Patrick Hand,LXGW WenKai,cursive;font-size:1rem}.asymmetric-arrow{pointer-events:none;filter:url(#wobble);position:absolute}.quiz-option{text-align:left;background:var(--paper-2);border:2.5px solid var(--rule);width:100%;color:var(--ink);cursor:pointer;border-radius:12px 16px 10px 14px/14px 10px 16px 12px;margin:.5rem 0;padding:.9rem 1.1rem;font-family:Patrick Hand,LXGW WenKai,cursive;font-size:1.15rem;transition:background .12s,transform .12s;display:block}.quiz-option:hover{background:var(--paper-3);transform:translate(-1px,-1px)}.quiz-option[data-state=right]{border-color:var(--teal);background:#2a9d8f40}.quiz-option[data-state=wrong]{border-color:var(--coral);background:#e26d5c2e}.prose ul{margin:0 0 1rem;padding-left:1.4rem}.prose ul li{margin-bottom:.35rem}.prose ul li::marker{color:var(--coral)}.prose code{background:var(--paper-3);border-radius:4px;padding:.1rem .4rem;font-family:JetBrains Mono,monospace;font-size:.92em}.prose strong{color:var(--coral)}.hotspot{cursor:pointer;transition:filter .15s}.hotspot:hover,.hotspot[data-active=true]{filter:drop-shadow(0 0 6px var(--mustard))}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}