:root{--plat-white: #ffffff;--plat-lightest: #f0f0f0;--plat-light: #dddddd;--plat: #cccccc;--plat-mid: #aaaaaa;--plat-dark: #808080;--plat-darkest: #555555;--plat-black: #000000;--sel-blue: #3875d7;--sel-blue-hi: #a8c3ef;--fg: #000;--font-ui: "Silkscreen", sans-serif;--font-body: "Silkscreen", sans-serif;--font-pixel: "Silkscreen", sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0;overflow:hidden}body{font-family:var(--font-body);font-size:12px;color:var(--fg);background:var(--plat-mid);user-select:none;-webkit-user-select:none;-webkit-font-smoothing:none;-moz-osx-font-smoothing:auto;font-smooth:never;text-rendering:optimizeSpeed}.desktop-bg{background-color:#6fb6e8;background-image:url(/assets/background-seaview-BDS-h5sk.png);background-position:center;background-size:cover;background-repeat:no-repeat}.desktop-bg[data-pattern=seaview]{background-color:#6fb6e8;background-image:url(/assets/background-seaview-BDS-h5sk.png);background-position:center;background-size:cover;background-repeat:no-repeat}.desktop-bg[data-pattern=lighttower]{background-color:#6fb6e8;background-image:url(/assets/background-lighttower-BPTkqNmw.png);background-position:center;background-size:cover;background-repeat:no-repeat}.desktop-bg[data-pattern=alps]{background-color:#6fb6e8;background-image:linear-gradient(#00000047,#00000047),url(/assets/background-alps-Mm5wCVEZ.png);background-position:center;background-size:cover;background-repeat:no-repeat}.desktop-bg[data-pattern=platinum]{background-color:#b8b8b8;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.05) 1px,transparent 1px);background-size:2px 2px,2px 2px}.desktop-bg[data-pattern=teal]{background-color:#4a8a8a;background-image:none}.desktop-bg[data-pattern=purple]{background-color:#8a6fb8;background-image:none}.desktop-bg[data-pattern=white]{background:#fff;background-image:none}.menubar{position:fixed;top:0;left:0;right:0;height:26px;background:linear-gradient(180deg,#fefefe,#e6e6e6,#c8c8c8);border-bottom:1px solid #555;box-shadow:0 1px #00000014;display:flex;align-items:center;padding:0 12px;font-family:var(--font-ui);font-size:12px;font-weight:400;z-index:1000;gap:18px}.menubar .apple{display:inline-flex;align-items:center;cursor:pointer;padding:0 2px}.menubar .apple svg{display:block}.menubar .menu-item{cursor:pointer;padding:2px 6px;border-radius:0;font-weight:400}.menubar .menu-item:hover{background:var(--sel-blue);color:#fff}.menubar .clock{margin-left:auto;font-family:var(--font-ui);font-size:12px;color:#222}.dropdown{position:absolute;top:100%;left:-6px;margin-top:2px;min-width:158px;padding:0;font-family:var(--font-ui);font-size:12px;z-index:1001;color:#222;background:#d8d8d8;border:1px solid #000;overflow:hidden;box-shadow:inset 1px 1px #fff,inset -1px -1px #8e8e8e,1px 1px #00000059}.dropdown-label{padding:7px 10px 6px;color:#333;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;border-bottom:1px solid #8c8c8c;box-shadow:inset 0 1px #ffffffbf}.dropdown-item{position:relative;display:flex;align-items:center;justify-content:flex-start;min-height:24px;padding:4px 10px 4px 26px;cursor:pointer;color:#222;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:2px;transition:background-color .12s ease,color .12s ease}.dropdown-item:hover{background:var(--sel-blue);color:#fff}.dropdown-item.disabled,.dropdown-item.disabled:hover{cursor:default;color:#777;background:transparent}.dropdown-item.checked{color:#111}.dropdown-item.checked:hover{color:#fff}.dropdown-check{position:absolute;left:8px;top:50%;width:12px;transform:translateY(-52%);font-size:14px;line-height:1;letter-spacing:0;text-align:center;color:#000;text-shadow:none}.dropdown-item.checked .dropdown-check{color:currentColor}.dropdown-text{display:block;width:100%;text-align:left;white-space:nowrap}.dropdown-separator{height:1px;margin:3px 0;background:#8c8c8c;box-shadow:0 1px #ffffffb3}.desktop{position:absolute;top:26px;right:0;bottom:0;left:0;overflow:hidden}.desktop-selection{position:absolute;z-index:5;pointer-events:none;border:1px dotted #000;background:#3875d72e;box-shadow:inset 0 0 0 1px #ffffff73}.desktop-icons{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none}.icon{position:absolute;width:84px;display:flex;flex-direction:column;align-items:center;cursor:pointer;pointer-events:auto;text-align:center;font-family:var(--font-body);font-size:11px;line-height:1.1;color:#fff;text-shadow:1px 1px 0 rgba(0,0,0,.6);touch-action:none;transition:transform .12s ease,filter .12s ease}.icon .icon-glyph{width:44px;height:44px;display:grid;place-items:center;margin-bottom:4px;filter:drop-shadow(1px 1px 1px rgba(0,0,0,.35))}.icon .icon-glyph svg{width:44px;height:44px;display:block}.icon .icon-label{background:transparent;padding:1px 5px;border-radius:0;max-width:84px;word-break:break-word}.icon.selected .icon-label{background:var(--sel-blue);color:#fff;text-shadow:none}.icon.selected .icon-glyph{filter:drop-shadow(1px 1px 1px rgba(0,0,0,.35)) brightness(.75)}.icon.is-trash-target{transform:scale(1.08);z-index:7}.icon.is-trash-target .icon-glyph{animation:trash-ready .42s steps(2,end) infinite;filter:drop-shadow(2px 2px 0 rgba(0,0,0,.45))}.icon.is-trash-target .icon-label{background:var(--sel-blue);color:#fff;text-shadow:none}.icon.is-trashing{z-index:8;pointer-events:none;animation:trash-suck .28s ease-in forwards}.desktop-restore-drag{z-index:900;pointer-events:none;opacity:.92;transform:scale(1.04);filter:drop-shadow(2px 2px 0 rgba(0,0,0,.45))}.desktop-restore-drag .icon-label{background:var(--sel-blue);color:#fff;text-shadow:none}@keyframes trash-ready{0%{transform:translateY(0)}50%{transform:translateY(-2px)}to{transform:translateY(0)}}@keyframes trash-suck{0%{transform:scale(1) rotate(0);opacity:1}60%{transform:scale(.55) rotate(-7deg);opacity:.75}to{transform:scale(.12) rotate(10deg);opacity:0}}.finder-view{display:flex;flex-direction:column;height:100%;min-height:0;background:#d4d4d4}.finder-header{display:flex;align-items:center;gap:10px;padding:4px 6px 7px;border-bottom:1px solid #8f8f8f}.finder-folder-stamp{width:28px;height:24px;display:grid;place-items:center}.finder-folder-stamp svg{width:24px;height:24px;display:block}.finder-folder-copy{min-width:0}.finder-folder-name{font-family:var(--font-pixel);font-size:11px;color:#111}.finder-folder-meta{margin-top:2px;font-size:11px;color:#555}.finder-canvas{flex:1;min-height:0;margin-top:1px;background:#efefef;border:1px solid #000;box-shadow:inset 1px 1px #fff,inset -1px -1px #9a9a9a}.finder-grid{display:grid;grid-template-columns:repeat(auto-fill,74px);align-content:start;justify-content:start;gap:12px 10px;min-height:100%;padding:10px}.finder-item{display:flex;flex-direction:column;align-items:center;gap:4px;width:74px;padding:2px 0;cursor:grab;-webkit-user-select:none;user-select:none}.finder-item:active{cursor:grabbing}.finder-item-glyph{width:44px;height:44px;display:grid;place-items:center;filter:drop-shadow(1px 1px 1px rgba(0,0,0,.18))}.finder-item-glyph svg{width:32px;height:32px;display:block}.finder-item-label{max-width:72px;padding:1px 4px;font-family:var(--font-pixel);font-size:11px;line-height:1.2;text-align:center;color:#111;word-break:break-word}.finder-item.selected .finder-item-label{background:var(--sel-blue);color:#fff}.finder-status{padding:3px 8px 4px;margin-top:1px;border-top:1px solid #8f8f8f;box-shadow:inset 0 1px #fff;font-family:var(--font-ui);font-size:11px;color:#333;background:#d6d6d6}.project-card{display:flex;flex-direction:column;min-height:100%;gap:10px}.project-card-header{display:flex;align-items:center;gap:10px}.project-card-icon{width:36px;height:36px;display:grid;place-items:center}.project-card-icon svg{width:32px;height:32px;display:block}.project-card-title{min-width:0}.project-sheet-kicker{margin-bottom:3px;font-size:11px;font-weight:700;text-transform:uppercase;color:#555}.project-card-box{display:flex;flex-direction:column;gap:8px;padding:10px 12px;background:#efefef;border:1px solid #000;box-shadow:inset 1px 1px #fff,inset -1px -1px #9a9a9a}.project-sheet-row{display:grid;grid-template-columns:70px minmax(0,1fr);column-gap:10px;align-items:baseline}.project-sheet-label{font-weight:700}.project-sheet-value{min-width:0;overflow-wrap:anywhere}.project-card-note{padding:0 1px;font-size:11px;line-height:1.45;color:#333}.about-site-card{justify-content:flex-start;min-height:0}.about-site-card .project-card-header{flex:0 0 auto}.about-site-card .project-card-box{gap:7px;padding:11px 12px}.about-site-card .project-sheet-row{grid-template-columns:78px minmax(0,1fr)}.contact-card{display:flex;flex-direction:column;gap:12px;width:100%;min-height:100%}.contact-field{display:flex;flex:1;min-height:0;flex-direction:column;gap:6px}.contact-subject-field{flex:0 0 auto}.contact-label{font-weight:700}.contact-input,.contact-textarea{padding:8px 10px;font-family:var(--font-pixel);font-size:12px;line-height:1.45;color:#111;background:#fff;border:1px solid #000;border-radius:0;outline:none;box-shadow:inset 1px 1px #8b8b8b,inset -1px -1px #fff}.contact-input{height:34px}.contact-textarea{flex:1;min-height:110px;resize:none}.contact-notice{padding:7px 9px;font-size:11px;line-height:1.35;color:#1c1c1c;background:#fff8c8;border:1px solid #000;box-shadow:inset 1px 1px #fff,inset -1px -1px #c4b55a}.contact-input:focus,.contact-textarea:focus{box-shadow:inset 1px 1px #000,inset -1px -1px #fff,0 0 0 1px var(--sel-blue)}.window{position:absolute;background:#bfbfbf;border:1px solid #000;box-shadow:1px 1px #00000073;min-width:240px;min-height:0;display:flex;flex-direction:column}.window:not(.is-collapsed){min-height:180px}.window .window-frame{display:flex;flex:1;flex-direction:column;min-height:0;margin:2px;background:#d6d6d6;border:1px solid #7b7b7b;box-shadow:inset 1px 1px #fff,inset -1px -1px #b0b0b0}.window .titlebar{min-height:24px;padding:2px 5px 2px 4px;background:#d7d7d7;border-bottom:1px solid #000;box-shadow:inset 0 1px #fff,inset 0 -1px #9d9d9d;display:grid;grid-template-columns:auto minmax(10px,1fr) auto minmax(10px,1fr) auto;align-items:center;gap:6px;cursor:grab;-webkit-user-select:none;user-select:none}.window .titlebar:active{cursor:grabbing}.window .titlebar .titlebar-lines{height:14px;border-top:1px solid #fbfbfb;border-bottom:1px solid #7f7f7f;background:repeating-linear-gradient(to bottom,#f4f4f4 0,#f4f4f4 1px,#bcbcbc 1px,#bcbcbc 2px,#f6f6f6 2px,#f6f6f6 3px,#bababa 3px,#bababa 4px)}.window .titlebar .title{font-family:var(--font-pixel);font-size:11px;font-weight:700;font-kerning:none;font-variant-ligatures:none;line-height:1;padding:0 4px 1px;white-space:nowrap;color:#000;text-align:center}.window .titlebar .tb-btn{width:16px;height:16px;border:1px solid #000;border-radius:0;background:#d9d9d9;cursor:pointer;flex-shrink:0;box-shadow:inset 1px 1px #fff,inset -1px -1px #7b7b7b;position:relative;padding:0}.window .titlebar .tb-btn:hover{background:#e6e6e6}.window .titlebar .tb-btn:active{background:#b9b9b9;box-shadow:inset 1px 1px #7b7b7b,inset -1px -1px #fff}.window .titlebar .close-box:before,.window .titlebar .close-box:after{content:"";position:absolute;left:50%;top:50%;width:8px;height:2px;background:#000;transform-origin:center}.window .titlebar .close-box:before{transform:translate(-50%,-50%) rotate(45deg)}.window .titlebar .close-box:after{transform:translate(-50%,-50%) rotate(-45deg)}.window .titlebar .zoom-box:before,.window .titlebar .collapse-box:before{content:"";position:absolute;left:3px;right:3px}.window .titlebar .zoom-box:before{top:3px;bottom:3px;border:1px solid #000;background:#efefef}.window .titlebar .collapse-box:before{top:7px;height:2px;background:#000}.window .titlebar .right-controls{display:flex;gap:4px}.window .window-body{position:relative;display:flex;flex-direction:column;flex:1;min-height:0;padding:8px 10px 12px;overflow:hidden;background:#d4d4d4;box-shadow:inset 1px 1px #fff}.window .resize-grip{position:absolute;right:1px;bottom:1px;width:16px;height:16px;background:linear-gradient(135deg,transparent 0 43%,#7a7a7a 43% 49%,transparent 49% 59%,#7a7a7a 59% 65%,transparent 65% 75%,#7a7a7a 75% 81%,transparent 81%),#d4d4d4;border-left:1px solid #000;border-top:1px solid #000;box-shadow:inset 1px 1px #fff;cursor:nwse-resize;pointer-events:auto;touch-action:none}.window .content{display:flex;flex-direction:column;flex:1;min-height:0;padding:14px 16px 16px;overflow:auto;font-family:var(--font-pixel);font-size:12px;font-kerning:none;font-variant-ligatures:none;letter-spacing:0;line-height:1.5;color:#111;background:#efefef;border:1px solid #000;box-shadow:inset 1px 1px #fff,inset -1px -1px #8b8b8b}.window .content-inner{display:flex;flex:1 1 auto;width:100%;height:100%;min-height:0}.window .content-page{display:flex;flex:1 1 auto;flex-direction:column;width:100%;min-height:100%}.window .content h1,.window .content h2,.window .content h3{font-family:var(--font-pixel);font-weight:700;margin:0 0 8px;color:#000}.window .content h1{font-size:14px;margin-bottom:10px}.window .content h2{font-size:12px;margin-top:12px;margin-bottom:6px}.window .content p{margin:0 0 10px}.window .content ul{padding-left:20px;margin:0 0 10px}.window .content a{color:var(--sel-blue)}.cv-page{display:flex;flex-direction:column;gap:9px;width:100%;min-width:0}.cv-section{display:flex;flex-direction:column;gap:5px;min-width:0}.window .content .cv-section h2{margin:0;padding-bottom:2px;border-bottom:1px solid #000}.cv-entry{display:grid;grid-template-columns:minmax(0,1fr) 118px;column-gap:12px;align-items:start;min-width:0}.cv-entry-main{min-width:0}.window .content .cv-entry-main p{margin:0}.window .content .cv-entry-main ul{margin:0;padding-left:18px}.cv-entry-date{justify-self:end;width:118px;color:#333;white-space:nowrap;text-align:left}.cv-info-row{display:grid;grid-template-columns:112px minmax(0,1fr);column-gap:12px;align-items:baseline;min-width:0}.cv-info-row span{min-width:0;overflow-wrap:anywhere}.cv-info-row span:first-child{font-weight:700}.about-me-card{display:flex;flex-direction:column;width:100%;min-width:0;min-height:0;margin:0;background:#d4d4d4}.about-me-hero{display:flex;align-items:center;justify-content:flex-start;gap:30px;flex:0 0 104px;width:100%;padding:8px 12px 4px;margin:0;background:#fff;border:1px solid #000;box-shadow:inset 1px 1px #fff,inset -1px -1px #9a9a9a}.about-me-hero-photo{display:block;max-width:118px;max-height:100%;width:auto;height:auto;object-fit:contain}.about-me-hero-photo-placeholder{width:118px;height:96px;background:#efefef;border:1px solid #000;box-shadow:inset 1px 1px #fff,inset -1px -1px #9a9a9a}.about-me-hero-copy{font-family:var(--font-pixel);font-size:26px;line-height:1.1;color:#111;white-space:nowrap}.about-me-meta{padding:14px 14px 18px}.about-me-specs{display:flex;flex-direction:column;gap:6px;min-width:0}.about-me-spec-row{display:grid;grid-template-columns:96px minmax(0,1fr);column-gap:10px;align-items:baseline}.about-me-spec-label{font-weight:700}.about-me-spec-value{min-width:0;overflow-wrap:anywhere;white-space:normal}.about-me-note{margin-top:12px;width:100%;padding:8px 10px;font-size:11px;line-height:1.4;background:#efefef;border:1px solid #000;box-shadow:inset 1px 1px #fff,inset -1px -1px #9a9a9a}.window .content::-webkit-scrollbar{width:16px;height:16px;background:#d4d4d4}.window .content::-webkit-scrollbar-track{background:linear-gradient(180deg,#f5f5f5,#cecece);border-left:1px solid #000;box-shadow:inset 1px 0 #fff}.window .content::-webkit-scrollbar-track:horizontal{border-left:0;border-top:1px solid #000;box-shadow:inset 0 1px #fff}.window .content::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#86edff,#24c8f7 40%,#00a7e6);border:1px solid #000;border-radius:0;box-shadow:inset 1px 1px #d8fbff,inset -1px -1px #0a6b9d}.window .content::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#95f0ff,#34cff9 40%,#10afea)}.window .content::-webkit-scrollbar-button:single-button{display:block;width:16px;height:16px;background-color:#d6d6d6;background-position:center;background-repeat:no-repeat;border-left:1px solid #000;border-top:1px solid #000;box-shadow:inset 1px 1px #fff,inset -1px -1px #7b7b7b}.window .content::-webkit-scrollbar-button:vertical:decrement{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='7' height='4' viewBox='0 0 7 4'><path d='M3.5 0L7 4H0z' fill='%23000'/></svg>")}.window .content::-webkit-scrollbar-button:vertical:increment{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='7' height='4' viewBox='0 0 7 4'><path d='M0 0h7L3.5 4z' fill='%23000'/></svg>")}.window .content::-webkit-scrollbar-button:horizontal:decrement{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='4' height='7' viewBox='0 0 4 7'><path d='M0 3.5L4 0v7z' fill='%23000'/></svg>")}.window .content::-webkit-scrollbar-button:horizontal:increment{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='4' height='7' viewBox='0 0 4 7'><path d='M4 3.5L0 0v7z' fill='%23000'/></svg>")}.window .content::-webkit-scrollbar-corner{background:#d4d4d4;border-left:1px solid #000;border-top:1px solid #000;box-shadow:inset 1px 1px #fff}button{font-family:var(--font-ui);font-size:12px;font-weight:400;background:linear-gradient(180deg,#fdfdfd,#e6e6e6,#c8c8c8);color:#000;border:1px solid #555;border-radius:0;padding:4px 18px;cursor:pointer;box-shadow:0 1px #fffc inset,0 1px 2px #0003}button:hover{background:linear-gradient(180deg,#fff,#ededed,#d2d2d2)}button:active{background:linear-gradient(180deg,#b8b8b8,#9a9a9a);box-shadow:0 1px 2px #0000004d inset}button.default{background:linear-gradient(180deg,#7ba7e0,#4a78b8,#3a62a0);color:#fff;border-color:#2c4a7a;text-shadow:0 -1px 0 rgba(0,0,0,.3)}button.default:hover{background:linear-gradient(180deg,#8cb4e8,#5a88c8,#4272b0)}.boot-screen{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:20px;font-family:var(--font-body);color:#111;background-color:#b8b8b8;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.05) 1px,transparent 1px);background-size:2px 2px,2px 2px}.boot-box{width:min(420px,90vw);overflow:hidden;background:var(--plat-light);border:1px solid #444;border-radius:0;box-shadow:2px 2px 14px #00000059}.boot-titlebar{height:20px;display:flex;align-items:center;justify-content:center;background:repeating-linear-gradient(to bottom,#e8e8e8 0,#e8e8e8 1px,#c2c2c2 1px,#c2c2c2 2px);border-bottom:1px solid #666}.boot-title{padding:0 10px;font-family:var(--font-pixel);font-size:11px;font-weight:700;background:var(--plat-light)}.boot-body{padding:28px 26px 30px;text-align:center;background:#fff}.boot-mac{display:block;margin:0 auto 16px}.boot-heading{margin-bottom:5px;font-family:var(--font-pixel);font-size:15px;font-weight:700}.boot-status{min-height:18px;margin-bottom:14px;font-size:12px;color:#555}.boot-progress{height:16px;padding:2px;background:#d7d7d7;border:1px solid #000;box-shadow:inset 1px 1px #8b8b8b,inset -1px -1px #fff}.boot-progress-fill{width:20%;height:100%;background:var(--sel-blue);animation:boot-progress 1.3s steps(8,end) infinite}@keyframes boot-progress{0%{width:12%}to{width:92%}}.login{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center}.login-box{border:1px solid #444;border-radius:0;box-shadow:2px 2px 14px #0006;background:var(--plat-light);width:min(460px,90vw);overflow:hidden}.login-box .titlebar{height:20px;background:repeating-linear-gradient(to bottom,#e8e8e8 0,#e8e8e8 1px,#c2c2c2 1px,#c2c2c2 2px);border-bottom:1px solid #666;display:flex;align-items:center;justify-content:center}.login-box .titlebar .title{background:var(--plat-light);padding:0 10px;font-family:var(--font-pixel);font-size:11px;font-weight:700}.login-box .body{padding:28px 24px;text-align:center;font-family:var(--font-body);font-size:14px;background:#fff}.login-box .happy-mac{margin:0 auto 14px;display:block}.login-box .welcome{font-family:var(--font-pixel);font-size:16px;font-weight:700;margin-bottom:4px}.login-box .sub{font-size:13px;color:#555;margin-bottom:20px}@media (max-width: 720px){.desktop-icons{top:0;right:0;bottom:0;left:0}.window{left:8px!important;right:8px;width:auto!important;max-width:calc(100vw - 16px)}.about-me-card{width:100%;min-width:0}.menubar{gap:10px;padding:0 8px;font-size:12px}}
