:root{--bg:#000;--fg:#fff;--fg-muted:#888;--border:#fff;--font-mono:"IBM Plex Mono", ui-monospace, monospace;--transition-fast:.15s ease;--transition-window:.22s ease;--window-shadow:none;--taskbar-height:28px;--titlebar-height:24px}.app-shell{background:var(--bg);width:100%;height:100%;position:relative;overflow:hidden}.desktop{padding-bottom:var(--taskbar-offset,0);position:absolute;inset:0;overflow:hidden}.desktop-selection-marquee{z-index:2;border:1px solid var(--fg);pointer-events:none;box-sizing:border-box;background:#ffffff0f;position:absolute}.desktop-surface{z-index:0;touch-action:none;position:absolute;inset:0}.desktop--explorer-drop-target .desktop-surface--drop-target{outline-offset:-1px;outline:1px dashed #ffffff59}.desktop-icons-layer{z-index:1;pointer-events:none;position:absolute;inset:0}.desktop-icons-layer>*{pointer-events:auto}.app-shell--with-taskbar,.desktop--with-taskbar{--taskbar-offset:var(--taskbar-height)}.desktop-extra-icons{pointer-events:auto;flex-direction:column;gap:8px;display:flex;position:absolute;top:16px;left:16px}.desktop-icon-slot{touch-action:none;z-index:1;position:absolute}.desktop-drag-portal{z-index:1500;pointer-events:none;padding-bottom:var(--taskbar-offset,0);position:fixed;inset:0}.desktop-drag-portal>*{pointer-events:auto}.desktop-icon-slot--dragging{z-index:1}.desktop-icon-slot .zip-icon{pointer-events:auto}.window-layer{pointer-events:none;padding-bottom:var(--taskbar-offset,0);position:absolute;inset:0}.window-layer>*{pointer-events:auto}.window-frame{border:1px solid var(--border);background:var(--bg);color:var(--fg);font-family:var(--font-mono);transform-origin:50%;flex-direction:column;display:flex;position:fixed}.window-frame--positioned.window-frame--visible{opacity:1}.window-frame--positioned.window-frame--hidden{opacity:0}.window-frame--resizable{position:fixed}.window-resize-handle{cursor:nwse-resize;touch-action:none;width:14px;height:14px;position:absolute;bottom:0;right:0}.window-resize-handle:before{content:"";border-right:1px solid var(--fg-muted);border-bottom:1px solid var(--fg-muted);width:8px;height:8px;position:absolute;bottom:3px;right:3px}.window-titlebar{height:var(--titlebar-height);border-bottom:1px solid var(--border);-webkit-user-select:none;user-select:none;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 8px;display:flex}.window-titlebar--draggable{cursor:grab}.window-titlebar--draggable:active{cursor:grabbing}.window-title{letter-spacing:.02em;text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.window-controls{gap:4px;display:flex}.window-control-btn{border:1px solid var(--border);background:var(--bg);width:18px;height:18px;color:var(--fg);justify-content:center;align-items:center;padding:0;line-height:1;display:flex}.window-control-btn:hover{background:var(--fg);color:var(--bg)}.window-body{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.window-frame--explorer .window-body{padding:0}.zip-icon{color:var(--fg);text-align:center;background:0 0;border:1px solid #0000;flex-direction:column;align-items:center;gap:6px;padding:4px;display:flex}.zip-icon:hover,.zip-icon:focus-visible{border-color:var(--border);outline:none}.zip-icon--selected{border-color:var(--border);background:#ffffff0f}.zip-icon-graphic{width:48px;height:48px;display:block}.zip-icon-label{text-overflow:ellipsis;white-space:nowrap;max-width:80px;font-size:11px;overflow:hidden}.desktop-file-icon{color:var(--fg);background:0 0;border:1px solid #0000;flex-direction:column;align-items:center;gap:4px;width:72px;padding:4px;display:flex}.desktop-file-icon:hover,.desktop-file-icon:focus-visible{border-color:var(--border);outline:none}.desktop-file-icon--selected{border-color:var(--border);background:#ffffff0f}.desktop-file-icon--drop-target{border-color:var(--fg);background:#ffffff1a}.desktop-folder-icon{color:var(--fg);text-align:center;background:0 0;border:1px solid #0000;flex-direction:column;align-items:center;gap:6px;padding:4px;display:flex}.desktop-folder-icon:hover,.desktop-folder-icon:focus-visible{border-color:var(--border);outline:none}.desktop-folder-icon--selected{border-color:var(--border);background:#ffffff0f}.desktop-folder-icon--drop-target{border-color:var(--fg);background:#ffffff1a}.desktop-folder-graphic{width:48px;height:40px;display:block}.desktop-icon-rename-input{border:1px solid var(--border);background:var(--bg);width:72px;max-width:100%;color:var(--fg);font:inherit;text-align:center;box-sizing:border-box;margin:0;padding:1px 2px;font-size:11px}.desktop-icon-rename-input:focus{border-color:var(--fg);outline:none}.decompress-body{box-sizing:border-box;height:100%;padding:16px}.decompress-label{margin:0 0 12px;font-size:11px}.progress-track{border:1px solid var(--border);background:var(--bg);box-sizing:border-box;width:100%;height:8px}.progress-fill{background:var(--fg);min-width:0;max-width:100%;height:100%;transition:width 80ms linear;display:block}.explorer-layout{flex:1;width:100%;height:100%;min-height:0;display:flex}.explorer-pane{flex-direction:column;flex:1;min-width:0;min-height:0;display:flex}.explorer-pathbar{border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:0;padding:6px 8px;font-size:10px;display:flex}.explorer-pathbar-segment{align-items:center;display:inline-flex}.explorer-pathbar-sep{color:var(--fg-muted);margin:0 2px}.explorer-pathbar-btn{color:var(--fg);font-family:inherit;font-size:inherit;cursor:pointer;background:0 0;border:none;padding:2px 4px}.explorer-pathbar-btn:hover{text-decoration:underline}.explorer-pathbar-btn--static{cursor:default}.explorer-pathbar-btn--static:hover{text-decoration:none}.explorer-file-header{border-bottom:1px solid var(--border);flex-direction:column;gap:2px;margin-bottom:16px;padding-bottom:12px;display:flex}.explorer-file-name{font-size:11px;font-weight:500}.explorer-file-meta{color:var(--fg-muted);font-size:10px}.explorer-sidebar{border-right:1px solid var(--border);flex-shrink:0;width:140px;padding:8px;font-size:11px}.explorer-tree-item{color:var(--fg-muted);text-align:left;cursor:pointer;width:100%;font-family:inherit;font-size:inherit;background:0 0;border:none;padding:2px 0;display:block}.explorer-tree-item--active{color:var(--fg)}.explorer-tree-item--nested{padding-left:12px;font-size:10px}.explorer-tree-item:hover{color:var(--fg)}.explorer-tree-item--draggable{cursor:grab}.explorer-tree-item--draggable:active{cursor:grabbing}.explorer-tree-item--droppable{cursor:copy}.explorer-tree-item--drop-hover{color:var(--fg);outline-offset:1px;outline:1px dashed #ffffff80}.explorer-layout--desktop-drop .explorer-pane--droppable{outline-offset:-1px;outline:1px dashed #fff3}.explorer-empty-hint{color:var(--fg-muted);font-size:10px;font-family:var(--font-mono,ui-monospace, monospace);margin:8px 0 0}.explorer-listing{margin:0;padding:0;list-style:none}.explorer-listing-item{color:var(--fg);font-family:inherit;font-size:inherit;text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:4px 0;display:flex}.explorer-listing-item:hover{text-decoration:underline}.explorer-listing-icon{color:var(--fg-muted);font-size:10px}.explorer-hint{margin:16px 0 0}.explorer-inline-link{color:var(--fg);font-family:inherit;font-size:inherit;cursor:pointer;background:0 0;border:none;padding:0;text-decoration:underline}.explorer-inline-link:hover{color:var(--fg-muted)}.project-github{margin:0 0 16px}.project-github dt{color:var(--fg-muted);margin-bottom:4px}.project-github dd{margin:0}.project-github-hint{color:var(--fg-muted)}.explorer-main{flex:1;min-height:0;padding:16px;overflow:auto}.profile-name{margin:0 0 4px;font-size:14px;font-weight:500}.profile-tagline{color:var(--fg-muted);margin:0 0 16px}.profile-bio{margin:0 0 16px}.profile-bio p{margin:0 0 8px}.profile-skills{margin:0 0 16px}.profile-skills dt{color:var(--fg-muted);margin-bottom:4px}.profile-skills dd{margin:0}.profile-links{margin:0;padding:0;list-style:none}.profile-links li{margin-bottom:4px}.taskbar{height:var(--taskbar-height);border-top:1px solid var(--border);background:var(--bg);z-index:1000;justify-content:space-between;align-items:center;padding:0 8px;display:flex;position:fixed;bottom:0;left:0;right:0}.taskbar-brand{letter-spacing:.05em;font-size:11px}.taskbar-clock{color:var(--fg-muted);font-size:11px}.context-menu-backdrop{z-index:1999;position:fixed;inset:0}.context-menu{z-index:2000;border:1px solid var(--border);background:var(--bg);min-width:160px;margin:0;padding:4px 0;list-style:none;position:fixed}.context-menu-separator{border-top:1px solid var(--border);height:0;margin:4px 8px;padding:0}.context-menu-item{width:100%;color:var(--fg);text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;padding:4px 12px;display:flex}.context-menu-item-label{flex:1}.context-menu-submenu-arrow{opacity:.75;margin-left:16px;font-size:8px;line-height:1}.context-menu-submenu{z-index:2001}.context-menu-item:hover{background:var(--fg);color:var(--bg)}.context-menu-item:disabled{color:var(--fg-muted);cursor:default;pointer-events:none}.context-menu-item:disabled:hover{color:var(--fg-muted);background:0 0}.window-frame--notepad .window-body{flex-direction:column;padding:0;display:flex}.notepad-chrome{flex-direction:column;flex:1;height:100%;min-height:0;display:flex}.notepad-menubar{border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0;gap:0;padding:0 4px;display:flex}.notepad-menu-root{position:relative}.notepad-menu-trigger{color:var(--fg);cursor:pointer;background:0 0;border:none;padding:4px 10px;font-family:inherit;font-size:11px}.notepad-menu-trigger:hover,.notepad-menu-trigger--active{background:var(--fg);color:var(--bg)}.notepad-menu-dropdown{z-index:10;border:1px solid var(--border);background:var(--bg);min-width:200px;margin:0;padding:4px 0;list-style:none;position:absolute;top:100%;left:0}.notepad-menu-item{width:100%;color:var(--fg);text-align:left;cursor:pointer;background:0 0;border:none;justify-content:space-between;gap:24px;padding:4px 12px;font-family:inherit;font-size:11px;display:flex}.notepad-menu-item:hover:not(:disabled){background:var(--fg);color:var(--bg)}.notepad-menu-item:disabled{color:var(--fg-muted);cursor:default}.notepad-menu-shortcut{color:var(--fg-muted);font-size:10px}.notepad-menu-item:hover:not(:disabled) .notepad-menu-shortcut{color:var(--bg)}.notepad-menu-separator{border-top:1px solid var(--border);height:0;margin:4px 0;list-style:none}.notepad-editor{resize:none;background:var(--bg);width:100%;min-height:0;color:var(--fg);font-family:var(--font-mono);box-sizing:border-box;border:none;outline:none;flex:1;padding:8px;font-size:13px;line-height:1.5}.notepad-statusbar{border-top:1px solid var(--border);color:var(--fg-muted);flex-shrink:0;gap:16px;padding:2px 8px;font-size:10px;display:flex}.properties-sheet{flex-direction:column;height:100%;min-height:0;font-size:11px;display:flex}.properties-tabs{border-bottom:1px solid var(--border);gap:2px;padding:6px 8px 0;display:flex}.properties-tab{color:var(--fg-muted);border:1px solid #0000;border-bottom:none;margin-bottom:-1px;padding:4px 10px}.properties-tab--active{color:var(--fg);border-color:var(--border);background:var(--bg)}.properties-panel{flex:1;min-height:0;padding:12px;overflow:auto}.properties-header{border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:12px;padding-bottom:10px;display:flex}.properties-icon{color:var(--fg-muted);flex-shrink:0;font-size:10px}.properties-name{word-break:break-all;font-size:12px}.properties-fields{margin:0}.properties-field{grid-template-columns:96px 1fr;gap:8px;margin-bottom:8px;display:grid}.properties-field dt{color:var(--fg-muted);margin:0}.properties-field dd{word-break:break-all;margin:0}.properties-actions{border-top:1px solid var(--border);flex-shrink:0;justify-content:flex-end;padding:8px 12px;display:flex}.properties-ok-btn{min-width:72px;color:var(--fg);background:var(--bg);border:1px solid var(--border);cursor:pointer;padding:4px 12px;font-family:inherit;font-size:11px}.properties-ok-btn:hover{background:#ffffff0f}@media (width<=520px){.explorer-layout{flex-direction:column}.explorer-sidebar{border-right:none;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:12px;width:100%;display:flex}}*,:before,:after{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--fg);font-family:var(--font-mono);-webkit-font-smoothing:antialiased;font-size:12px;line-height:1.5}button{font-family:inherit;font-size:inherit;cursor:pointer}a{color:var(--fg)}a:hover{text-decoration:underline}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
