*,:before,:after,::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:MS Sans Serif,Microsoft Sans Serif,Arial,sans-serif;line-height:1.5}body{line-height:inherit;margin:0}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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:Courier New,Courier,monospace;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}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder{opacity:1;color:#9ca3af}textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.invisible{visibility:hidden}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.block{display:block}.inline{display:inline}.flex{display:flex}.grid{display:grid}.hidden{display:none}.resize{resize:both}.border{border-width:1px}.italic{font-style:italic}.underline{text-decoration-line:underline}.shadow{--tw-shadow:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.outline{outline-style:solid}.blur{--tw-blur:blur(8px);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)}.sepia{--tw-sepia:sepia(100%);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)}.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)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}:root{--color-desktop:teal;--color-desktop-light:#009a9a;--color-surface:silver;--color-text:#000;--color-text-disabled:gray;--color-text-inverted:#fff;--color-title-active:navy;--color-title-inactive:gray;--color-title-text:#fff;--color-highlight:navy;--color-highlight-text:#fff;--color-border-light:#fff;--color-border-dark:gray;--color-border-darker:#000;--color-scrollbar:silver;--font-pixel:"Press Start 2P", "MS Sans Serif", monospace;--font-sys:Tahoma, "MS Sans Serif", "Segoe UI", Arial, sans-serif;--font-mono:"Courier New", Courier, monospace;--text-sm:11px;--text-xs:10px;--text-lg:13px;--leading:1.45}*,:before,:after{box-sizing:border-box;border-radius:0!important}body{-webkit-user-select:none;user-select:none;font-family:var(--font-sys);font-size:var(--text-sm);line-height:var(--leading);background:var(--color-desktop);color:var(--color-text);-webkit-font-smoothing:antialiased;margin:0;overflow:hidden}#root{width:100vw;height:100vh;overflow:hidden}.font-pixel{font-family:var(--font-pixel);-webkit-font-smoothing:none;font-smooth:never;font-size:9px;line-height:1.5}.font-sys{font-family:var(--font-sys)}.text-prose{overflow-wrap:break-word;word-break:normal;-webkit-hyphens:auto;hyphens:auto}.win95-app{font-family:var(--font-sys);font-size:var(--text-sm);line-height:var(--leading)}.win95-app-toolbar{font-family:var(--font-pixel);font-size:9px;line-height:1.5}.win95-app-toolbar button{font-family:inherit;font-size:inherit}.win95-content{font-family:var(--font-sys);font-size:var(--text-sm);line-height:var(--leading);overflow-wrap:break-word;word-break:normal;-webkit-hyphens:auto;hyphens:auto}.desktop-wallpaper{background-color:var(--color-desktop);background-image:radial-gradient(ellipse 120px 80px at 15% 20%, #ffffff1f 0%, transparent 70%), radial-gradient(ellipse 160px 100px at 75% 15%, #ffffff1a 0%, transparent 70%), radial-gradient(ellipse 100px 70px at 85% 60%, #ffffff14 0%, transparent 70%), radial-gradient(ellipse 140px 90px at 30% 75%, #ffffff17 0%, transparent 70%), linear-gradient(160deg, var(--color-desktop-light) 0%, var(--color-desktop) 45%, #006868 100%)}img,canvas,svg,.pixel-art{image-rendering:pixelated;image-rendering:crisp-edges}.win95-raised{box-shadow:inset -1px -1px #000,inset 1px 1px #fff,inset -2px -2px gray,inset 2px 2px #dfdfdf}.win95-pressed{box-shadow:inset 1px 1px #000,inset -1px -1px #fff,inset 2px 2px gray,inset -2px -2px #dfdfdf}.win95-inset{box-shadow:inset 1px 1px gray,inset -1px -1px #fff,inset 2px 2px #000,inset -2px -2px #dfdfdf}.win95-inset-sm{box-shadow:inset 1px 1px gray,inset -1px -1px #fff}.win95-btn{background:var(--color-surface);color:var(--color-text);font-family:var(--font-sys);font-size:var(--text-xs);cursor:default;overflow-wrap:normal;word-break:normal;white-space:nowrap;border:none;justify-content:center;align-items:center;min-width:75px;padding:4px 14px 5px;line-height:1.3;display:inline-flex;box-shadow:inset -1px -1px #000,inset 1px 1px #fff,inset -2px -2px gray,inset 2px 2px #dfdfdf}.win95-btn:active,.win95-btn.active{padding:5px 13px 4px 15px;box-shadow:inset 1px 1px #000,inset -1px -1px #fff,inset 2px 2px gray,inset -2px -2px #dfdfdf}.win95-btn:focus{outline-offset:-4px;outline:1px dotted #000}.win95-input{color:#000;font-family:var(--font-sys);font-size:var(--text-sm);line-height:var(--leading);overflow-wrap:break-word;word-break:normal;background:#fff;border:none;padding:3px 6px;box-shadow:inset 1px 1px gray,inset -1px -1px #fff,inset 2px 2px #000,inset -2px -2px #dfdfdf}.win95-input:focus{outline:none}.os-scrollbar{scrollbar-width:auto;scrollbar-color:silver silver}.os-scrollbar::-webkit-scrollbar{width:16px;height:16px}.os-scrollbar::-webkit-scrollbar-track{background:silver;box-shadow:inset 1px 1px gray,inset -1px -1px #fff}.os-scrollbar::-webkit-scrollbar-thumb{background:silver;box-shadow:inset -1px -1px #000,inset 1px 1px #fff,inset -2px -2px gray,inset 2px 2px #dfdfdf}.os-scrollbar::-webkit-scrollbar-button{background:silver;width:16px;height:16px;display:block;box-shadow:inset -1px -1px #000,inset 1px 1px #fff,inset -2px -2px gray,inset 2px 2px #dfdfdf}.window-titlebar{cursor:default}.dragging *{pointer-events:none;-webkit-user-select:none!important;user-select:none!important}.window-enter{animation:.12s ease-out win95-appear}@keyframes win95-appear{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.terminal-cursor{animation:1s step-end infinite blink}@keyframes boot-progress{0%{width:0%}to{width:100%}}.mobile-tabs::-webkit-scrollbar{display:none}.win95-menu{background:var(--color-surface);border:1px solid var(--color-border-darker);font-family:var(--font-sys);font-size:var(--text-sm);box-shadow:2px 2px #000}.win95-menu-sep{border-top:1px solid var(--color-border-dark);border-bottom:1px solid var(--color-border-light);height:0;margin:3px 4px}.desktop-icon-grid{pointer-events:none;grid-template-rows:1fr auto;grid-template-columns:88px 1fr 88px;display:grid;position:absolute;inset:12px 12px 40px}.desktop-icon-col{pointer-events:auto;flex-direction:column;gap:6px;display:flex}.desktop-icon-col--right{align-items:flex-end}.desktop-icon-btn{cursor:default;background:0 0;border:none;flex-direction:column;align-items:center;gap:5px;width:88px;padding:6px 4px;transition:transform .15s;display:flex}.desktop-icon-btn:hover{transform:translateY(-2px)}.desktop-icon-btn:active{transform:translateY(0)}.win95-icon-label{color:#fff;font-family:var(--font-pixel);-webkit-font-smoothing:none;font-smooth:never;text-shadow:1px 1px #000,-1px 0 #000,0 -1px #000;text-align:center;overflow-wrap:normal;word-break:normal;white-space:normal;max-width:84px;font-size:8px;line-height:1.55}.sticky-note{pointer-events:auto;width:168px;font-family:"Comic Sans MS", "Segoe Print", cursive, var(--font-sys);color:#333;overflow-wrap:break-word;word-break:normal;background:#ffffa5;padding:12px 14px 14px;font-size:12px;line-height:1.4;animation:4s ease-in-out infinite sticky-wobble;position:absolute;bottom:48px;right:16px;transform:rotate(2deg);box-shadow:2px 3px 8px #00000059}.sticky-note:before{content:"";background:#ffffb4b3;width:40px;height:14px;position:absolute;top:-8px;left:50%;transform:translate(-50%);box-shadow:0 1px 2px #00000026}@keyframes sticky-wobble{0%,to{transform:rotate(2deg)}50%{transform:rotate(1deg)}}.win95-statusbar{background:var(--color-surface);border-top:1px solid var(--color-border-dark);font-family:var(--font-sys);font-size:var(--text-xs);align-items:center;gap:6px;padding:3px 6px;display:flex}.win95-statusbar-panel{text-overflow:ellipsis;white-space:nowrap;min-width:0;padding:2px 8px;overflow:hidden;box-shadow:inset 1px 1px gray,inset -1px -1px #fff}.snake-screen{-webkit-user-select:none;user-select:none;background:#0a0a12;flex-direction:column;height:100%;display:flex;position:relative}.snake-hud{font-family:var(--font-pixel);color:#00ff41;background:#1a1a2e;border-bottom:2px solid #00ff41;flex-shrink:0;justify-content:space-between;align-items:center;padding:6px 10px;font-size:8px;display:flex}.snake-canvas-wrap{flex:1;min-height:0;position:relative;overflow:hidden}.snake-canvas-wrap:after{content:"";pointer-events:none;z-index:5;background:repeating-linear-gradient(0deg,#0000,#0000 2px,#00000014 2px 4px);position:absolute;inset:0}.snake-overlay{z-index:10;font-family:var(--font-pixel);background:#000000d1;flex-direction:column;justify-content:center;align-items:center;gap:14px;display:flex;position:absolute;inset:0}.snake-overlay h2{margin:0;font-size:10px;font-weight:700}.snake-overlay p{font-family:var(--font-sys);font-size:var(--text-sm);margin:0}.mine-game{-webkit-user-select:none;user-select:none;background:silver;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:12px;display:flex}.mine-panel{background:silver;flex-direction:column;gap:8px;padding:8px;display:inline-flex;box-shadow:inset -1px -1px #000,inset 1px 1px #fff,inset -2px -2px gray,inset 2px 2px #dfdfdf}.mine-header{justify-content:space-between;align-items:center;gap:16px;padding:6px 10px;display:flex;box-shadow:inset 1px 1px gray,inset -1px -1px #fff,inset 2px 2px #000,inset -2px -2px #dfdfdf}.mine-seven-seg{color:red;font-family:var(--font-mono);letter-spacing:2px;text-align:center;background:#000;min-width:58px;padding:4px 10px;font-size:18px;font-weight:700;line-height:1;box-shadow:inset 1px 1px gray,inset -1px -1px #fff,inset 2px 2px #000}.mine-face-btn{cursor:default;background:silver;border:none;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex;box-shadow:inset -1px -1px #000,inset 1px 1px #fff,inset -2px -2px gray,inset 2px 2px #dfdfdf}.mine-face-btn:active{box-shadow:inset 1px 1px #000,inset -1px -1px #fff,inset 2px 2px gray,inset -2px -2px #dfdfdf}.mine-grid{padding:4px;display:grid;box-shadow:inset 1px 1px gray,inset -1px -1px #fff,inset 2px 2px #000,inset -2px -2px #dfdfdf}.mine-cell{width:30px;height:30px;font-family:var(--font-sys);cursor:default;border:none;justify-content:center;align-items:center;padding:0;font-size:14px;font-weight:700;display:flex}.mine-cell--hidden{background:silver;box-shadow:inset -1px -1px #000,inset 1px 1px #fff,inset -2px -2px gray,inset 2px 2px #dfdfdf}.mine-cell--revealed{background:#bdbdbd;border:1px solid gray;box-shadow:inset 1px 1px gray}.mine-cell--exploded{background:#f44}.mine-status-banner{text-align:center;font-family:var(--font-sys);font-size:var(--text-sm);padding:8px;font-weight:700}.c4-game{height:100%;font-family:var(--font-sys);font-size:var(--text-sm);-webkit-user-select:none;user-select:none;background:silver;flex-direction:column;display:flex;overflow:hidden}.c4-scorebar{border-bottom:1px solid gray;flex-shrink:0;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;padding:6px 12px;display:grid}.c4-scorebar-side{align-items:center;gap:8px;min-width:0;display:flex}.c4-scorebar-side--right{justify-content:flex-end}.c4-piece-dot{border:2px solid #000;flex-shrink:0;width:14px;height:14px;border-radius:50%!important}.c4-status{text-align:center;white-space:nowrap;text-overflow:ellipsis;font-weight:700;font-size:var(--text-xs);overflow:hidden}.c4-board-frame{background:linear-gradient(#0030a0 0%,navy 50%,#000060 100%);padding:6px;box-shadow:inset -2px -2px #000040,inset 2px 2px #4060c0,4px 4px #0000004d}.c4-hole{background:#000030;border:1px solid #000;border-radius:50%!important}.c4-disc{border:2px solid #00000080;box-shadow:inset -2px -2px 4px #0000004d,inset 2px 2px 4px #fff3;border-radius:50%!important}.c4-disc--win{border:2px solid #fff;animation:.6s ease-in-out infinite alternate c4-pulse;box-shadow:0 0 8px #fffc,inset -2px -2px 4px #0000004d}@keyframes c4-pulse{0%{transform:scale(1)}to{transform:scale(1.06)}}@keyframes c4-drop{0%{transform:translateY(var(--c4-from))}to{transform:translateY(0)}}.project-card{cursor:default;background:silver;flex-direction:column;gap:8px;padding:10px;transition:transform .12s;display:flex;box-shadow:inset -1px -1px #000,inset 1px 1px #fff,inset -2px -2px gray,inset 2px 2px #dfdfdf}.project-card:hover{transform:translateY(-1px)}.project-card-title{font-weight:700;font-size:var(--text-sm);overflow-wrap:break-word;word-break:normal;flex:1;min-width:0}.project-tag{font-size:var(--text-xs);color:#000;white-space:nowrap;background:#d4d4d4;padding:2px 7px;box-shadow:inset 1px 1px gray,inset -1px -1px #fff}.books-tabs{flex-shrink:0;align-items:flex-end;gap:2px;padding:4px 8px 0;display:flex}.books-tab{cursor:default;font-family:var(--font-sys);font-size:var(--text-xs);color:#000;background:#a8a8a8;border:1px solid gray;border-bottom:none;padding:4px 10px 3px;position:relative;top:1px}.books-tab--active{z-index:1;background:#fff;padding-bottom:4px;box-shadow:inset -1px 0 gray,inset 1px 0 #fff}.books-tab:focus{outline-offset:-4px;outline:1px dotted #000}.books-grid{grid-template-columns:repeat(auto-fill,minmax(108px,128px));justify-content:start;gap:8px;display:grid}.book-card{cursor:default;background:silver;flex-direction:column;width:100%;max-width:128px;display:flex;overflow:hidden;box-shadow:inset -1px -1px #000,inset 1px 1px #fff,inset -2px -2px gray,inset 2px 2px #dfdfdf}.book-card--link{cursor:pointer;color:inherit;text-decoration:none}.book-card--link:hover{background:#d4d4d4}.book-card--link:active{box-shadow:inset 1px 1px #000,inset -1px -1px #fff,inset 2px 2px gray,inset -2px -2px #dfdfdf}.book-card-cover{aspect-ratio:2/3;background:gray;flex-shrink:0;justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:hidden}.book-card-rank{z-index:1;color:#fff;text-align:center;background:navy;min-width:18px;padding:1px 4px;font-size:10px;font-weight:700;position:absolute;top:4px;left:4px;box-shadow:inset -1px -1px #000,inset 1px 1px #8080ff}.book-card-cover img{-o-object-fit:cover;object-fit:cover;-o-object-position:center top;object-position:center top;width:100%;height:100%;display:block}.book-card-cover-placeholder{color:#fff;width:100%;height:100%;font-size:var(--text-xs);justify-content:center;align-items:center;display:flex}.book-card-body{flex-direction:column;gap:4px;padding:6px;display:flex}.book-card-title{font-weight:700;font-size:var(--text-xs);overflow-wrap:break-word;line-height:1.25}.book-card-description{color:#222;font-size:var(--text-xs);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;line-height:1.3;display:-webkit-box;overflow:hidden}.book-card-meta{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.book-card-skeleton{background:#a8a8a8;animation:1.2s ease-in-out infinite book-pulse}.book-card-cover--loading{aspect-ratio:2/3;background:#a8a8a8;width:100%;animation:1.2s ease-in-out infinite book-pulse}@keyframes book-pulse{0%,to{opacity:1}50%{opacity:.55}}@media (prefers-reduced-motion:reduce){.window-enter,.sticky-note,.desktop-icon-btn,.project-card,.c4-disc--win{transition:none!important;animation:none!important}.desktop-icon-btn:hover,.project-card:hover{transform:none}}
