:root{--xp-blue: #245DDA;--xp-green: #3C8D0D;--xp-desktop-bg: #004E98;--xp-window-bg: #ECE9D8;--xp-title-start: #0058EE;--xp-title-end: #3593FF;--xp-font: "Tahoma", "Segoe UI", sans-serif;--taskbar-height: 30px}*{box-sizing:border-box;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}html,body{margin:0;padding:0;font-family:var(--xp-font);background-color:#5a8fcc;overflow:hidden;height:100%;width:100%;height:100dvh;width:100vw}#app{width:100%;height:100%;position:relative;overflow:hidden}.window-body,.window-body *{user-select:text;-webkit-user-select:text}#desktop{width:100%;height:calc(100% - var(--taskbar-height));position:relative;overflow:hidden;background-color:#5a8fcc;background-image:url(/assets/desktop/bliss.png);background-size:cover;background-position:center center;background-repeat:no-repeat}#desktop-icons{display:flex;flex-direction:column;flex-wrap:wrap;height:100%;align-content:flex-start;padding:10px;gap:10px}.hidden{display:none!important}:focus-visible{outline:1px dotted #000;outline-offset:-1px}.boot-screen{display:flex;flex-direction:column;align-items:center;gap:50px}.loading-bar-container{border:1px solid #555;border-radius:4px;padding:2px;width:200px;height:16px;display:flex;align-items:center;justify-content:center;background:#000}.loading-bar{width:100%;height:100%;object-fit:cover}.login-screen{display:flex;width:100%;max-width:800px;justify-content:center;align-items:center;color:#fff}.login-left{flex:1;text-align:right;padding-right:20px;border-right:1px solid rgba(255,255,255,.3);display:flex;flex-direction:column;align-items:flex-end;justify-content:center}.login-right{flex:1;padding-left:20px;display:flex;flex-direction:column;justify-content:center}.user-account{display:flex;align-items:center;gap:10px;padding:10px;border-radius:4px;cursor:pointer;width:fit-content;transition:background .2s;border:1px solid transparent}.user-account:hover,.user-account:focus{background-color:#ffffff1a;border-color:#ffffff4d}.user-icon-frame{width:56px;height:56px;border:2px solid white;border-radius:4px;overflow:hidden;background:#1a4fb8;box-shadow:0 0 0 1px #0000004d}.user-icon{width:100%;height:100%;object-fit:cover;object-position:center 28%}.user-details{display:flex;flex-direction:column}.user-name{font-size:1.2rem;font-weight:700}.user-status{font-size:.9rem;opacity:.8}.login-footer{position:absolute;bottom:20px;left:20px;color:#fff;font-size:.9rem}.footer-action{display:flex;align-items:center;gap:8px;cursor:pointer;opacity:.8}.footer-action:hover{opacity:1}.desktop-icon{width:70px;display:flex;flex-direction:column;align-items:center;text-align:center;color:#fff;text-shadow:1px 1px 1px black;cursor:default;padding:5px;border:1px solid transparent;border-radius:2px;margin-bottom:15px}.desktop-icon img{width:32px;height:32px;margin-bottom:5px}.desktop-icon span{font-size:11px;line-height:1.2}.desktop-icon.selected{background-color:#0b61ff80;border:1px dotted rgba(255,255,255,.5);text-shadow:none}.desktop-icon.selected img{opacity:.8}.xp-window{position:absolute;width:400px;min-height:200px;background-color:var(--xp-window-bg);border:1px solid #0055EA;border-radius:5px 5px 0 0;box-shadow:2px 2px 10px #0006;display:flex;flex-direction:column;padding:3px;overflow:hidden;resize:both}#window-resume-window{width:640px;height:560px}#window-projects-window{width:600px;height:420px}#window-fun-window{width:640px;height:520px}#window-about-window{width:480px;height:320px}#window-contact-window{width:460px;height:460px}.xp-window.maximized{top:0!important;left:0!important;width:100%!important;height:100%!important;border-radius:0;resize:none}.title-bar{height:30px;background:linear-gradient(to right,var(--xp-title-start),var(--xp-title-end));display:flex;align-items:center;justify-content:space-between;padding:0 5px;border-radius:3px 3px 0 0;color:#fff;font-weight:700;font-size:13px;text-shadow:1px 1px #000;cursor:default;touch-action:none;-webkit-user-select:none;user-select:none}.xp-window:not(.active) .title-bar{background:linear-gradient(to right,#7697ce,#7c9fce);border-color:#7697ce}.title-bar-text{display:flex;align-items:center;gap:5px;pointer-events:none}.title-icon{width:16px;height:16px}.title-bar-controls{display:flex;gap:2px}.control-btn{width:21px;height:21px;border:1px solid white;border-radius:3px;background:linear-gradient(to bottom,#fff,#ddd);color:#000;font-weight:700;font-family:sans-serif;font-size:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;text-shadow:none;opacity:.8}.control-btn:hover{opacity:1}.control-btn.close{background:#e04343;color:#fff;border-color:#fff}.control-btn.close:hover{background:#f55}.window-body{flex:1;background:#fff;margin-top:2px;border:1px solid #999;padding:10px;overflow:auto;font-size:14px;color:#000}#taskbar{position:absolute;left:0;right:0;bottom:0;height:var(--taskbar-height);width:100%;display:flex;align-items:stretch;z-index:9999;background:linear-gradient(to bottom,#2d64c8,#1e4fa8 8%,#2057b0 50%,#1a488e);border-top:1px solid #3E80ED;box-shadow:inset 0 1px #ffffff40}#taskbar .taskbar-windows{flex:1;display:flex;align-items:center;gap:2px;padding:0 5px;min-width:0}#taskbar .system-tray{display:flex;align-items:center;padding:0 10px;height:100%;color:#fff;font-size:11px;background:#0b77e9;border-left:1px solid #11468F;flex-shrink:0}.start-button{position:relative;flex-shrink:0;height:100%;padding:0;margin:0;border:0;background:transparent;cursor:pointer;outline:none;display:flex;align-items:stretch;overflow:hidden;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.start-button-image{height:100%;width:auto;display:block;pointer-events:none;-webkit-user-drag:none;-webkit-user-select:none;user-select:none}.start-button:hover .start-button-image{filter:brightness(1.08)}.start-button:active .start-button-image,body.start-open .start-button .start-button-image{filter:brightness(.85) saturate(1.1);transform:translateY(1px)}.start-button:focus-visible{outline:2px dotted rgba(255,255,255,.8);outline-offset:-3px}.user-account.logging-in{background-color:#ffffff2e;border-color:#ffffff8c}.taskbar-item{width:150px;height:22px;background:#3c81f3;border-radius:2px;display:flex;align-items:center;padding:0 5px;gap:5px;color:#fff;font-size:11px;cursor:pointer;box-shadow:inset 0 1px #ffffff4d}.taskbar-item:hover{background:#5392f7}.taskbar-item.active{background:#1e52b7;box-shadow:inset 1px 1px 2px #00000080;color:#ddd}.taskbar-item img{width:16px;height:16px}#start-menu{position:absolute;bottom:30px;left:0;width:380px;height:480px;background:#fff;border-radius:5px 5px 0 0;box-shadow:2px -2px 10px #00000080;display:flex;flex-direction:column;overflow:hidden;border:1px solid #0055EA;z-index:10000}.start-header{height:60px;background:linear-gradient(to bottom,#1868ce,#0e60cb);display:flex;align-items:center;padding:0 10px;gap:10px;color:#fff;font-weight:700;font-size:16px;text-shadow:1px 1px 1px #000;border-bottom:2px solid #E57916}.start-header .user-frame{width:42px;height:42px;border:2px solid white;border-radius:3px;overflow:hidden;background:#1a4fb8}.start-header .user-frame img{width:100%;height:100%;object-fit:cover;object-position:center 28%}.start-body{flex:1;display:flex}.start-left{flex:1;background:#fff;padding:5px;display:flex;flex-direction:column;gap:2px}.start-right{flex:1;background:#d3e5fa;padding:5px;border-left:1px solid #95BDE9;display:flex;flex-direction:column;gap:2px}.start-item{padding:5px;font-size:12px;color:#333;cursor:default;display:flex;align-items:center}.start-left .start-item{height:36px}.start-right .start-item{font-weight:700;color:#00136b}.start-item:hover{background-color:#316ac5;color:#fff}.separator{height:1px;background:linear-gradient(to right,transparent,#ccc,transparent);margin:5px 0}.start-footer{height:40px;background:linear-gradient(to bottom,#1868ce,#0e60cb);display:flex;align-items:center;justify-content:flex-end;padding:0 10px;gap:15px;border-top:2px solid #E57916}.footer-btn{color:#fff;font-size:11px;display:flex;align-items:center;gap:5px;cursor:pointer;padding:5px}.footer-btn:hover{opacity:.8}.window-content-inner{padding:10px}.window-content-inner h2{margin-top:0;color:#039}.window-content-inner h3{border-bottom:1px solid #ccc;padding-bottom:5px;color:#039}.window-content-inner ul{padding-left:20px}.xp-button{background:linear-gradient(to bottom,#f9f9f9,#e3e3e3);border:1px solid #707070;border-radius:3px;padding:4px 12px;color:#000;font-family:var(--xp-font);font-size:11px;cursor:pointer;text-decoration:none;display:inline-block}.xp-button:active{background:#e3e3e3;box-shadow:inset 1px 1px 2px #0003}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:15px}.project-card{text-align:center;cursor:default;padding:10px;border:1px solid transparent;border-radius:4px;background:#fafafa}.project-card:hover{background-color:#eaf1fb;border-color:#b6d0f0}.project-icon{font-size:32px}.project-card h4{margin:6px 0 4px;font-size:12px;color:#039}.project-card p{margin:0;font-size:11px;color:#555;line-height:1.35}.project-card .tech{margin-top:6px;font-size:10px;color:#888;font-style:italic}.window-content-inner.resume{font-size:12px;line-height:1.45;color:#222}.resume-header{text-align:center;margin-bottom:12px}.resume-header h2{margin:0;color:#039;font-size:22px}.resume-tagline{margin:4px 0;font-weight:700;color:#444}.resume-contact{margin:4px 0 8px;font-size:11px;color:#555}.resume-contact a{color:#1a4fb8;text-decoration:none}.resume-contact a:hover{text-decoration:underline}.resume-section{margin-top:14px}.resume-section h3{font-size:13px;color:#039;border-bottom:1px solid #b9c8df;padding-bottom:3px;margin:0 0 8px;letter-spacing:.5px;text-transform:uppercase}.resume-section .job{margin-bottom:10px}.resume-section .job h4{margin:0;font-size:12px;color:#1a1a1a;display:flex;justify-content:space-between;flex-wrap:wrap;gap:6px}.resume-section .job h4 .loc{font-weight:400;font-style:italic;color:#666;font-size:11px}.resume-section .job .meta{margin:2px 0 4px;font-size:11px;color:#555;font-style:italic}.resume-section .job ul{margin:4px 0 0;padding-left:18px}.resume-section .job li{margin-bottom:2px}.resume-section .muted{color:#555;font-size:11px;margin:2px 0 0}.resume-section ul.skills{padding-left:18px;margin:0}.resume-section ul.skills li{margin-bottom:3px}.resume-actions{margin-top:18px;display:flex;gap:8px;justify-content:center}.contact-list{padding-left:18px}.contact-list li{margin-bottom:4px}.contact-list a{color:#1a4fb8;text-decoration:none}.contact-list a:hover{text-decoration:underline}.contact-form{display:flex;flex-direction:column;gap:8px;max-width:320px;margin-top:12px}.contact-form input,.contact-form textarea{padding:5px;border:1px solid #7f9db9;font-family:var(--xp-font);font-size:12px}.window-content-inner.fun{padding:0}.fun-toolbar{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:linear-gradient(to bottom,#f4f4f4,#e1e1e1);border-bottom:1px solid #B5B5B5;font-size:11px;color:#333}.fun-blurb{margin:10px 12px 4px;font-size:12px;color:#444}.dog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px;padding:10px 14px 16px}.dog-tile{display:flex;flex-direction:column;align-items:center;gap:6px;padding:6px;border:1px solid transparent;border-radius:3px;cursor:pointer;text-align:center;-webkit-user-select:none;user-select:none}.dog-tile:hover{background:#eaf1fb;border-color:#b6d0f0}.dog-tile:focus{outline:1px dotted #003399}.dog-tile span{font-size:11px;color:#333;word-break:break-all}.dog-thumb{width:130px;height:130px;border:1px solid #B5B5B5;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:1px 1px 2px #00000026}.dog-thumb img{width:100%;height:100%;object-fit:cover;display:block}.dog-lightbox{position:fixed;inset:0;background:#000000c7;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;z-index:20000;padding:20px}.dog-lightbox img{max-width:90%;max-height:80%;border:3px solid white;box-shadow:0 4px 14px #0009;object-fit:contain}.start-left .start-item img{width:22px;height:22px;margin-right:8px;object-fit:contain}.start-left .start-item[data-app]{cursor:pointer}.start-right .start-item a{color:inherit;text-decoration:none;width:100%;display:block}.start-right .start-item:hover a{color:#fff}.about-hero{display:flex;gap:20px;align-items:flex-start}.about-photo{width:110px;height:140px;object-fit:cover;object-position:center 28%;border:3px solid white;outline:1px solid #999;box-shadow:1px 2px 4px #00000040;flex-shrink:0}@media(max-width:1024px){#window-resume-window{width:min(720px,92vw);height:min(620px,80vh)}#window-projects-window{width:min(640px,92vw);height:min(480px,80vh)}#window-fun-window{width:min(720px,92vw);height:min(560px,80vh)}#window-about-window{width:min(520px,92vw);height:min(360px,70vh)}#window-contact-window{width:min(500px,92vw);height:min(500px,80vh)}}@media(max-width:760px){:root{--taskbar-height: 38px}body{font-size:14px}.xp-window,#window-resume-window,#window-projects-window,#window-fun-window,#window-about-window,#window-contact-window{top:0!important;left:0!important;width:100vw!important;height:calc(100dvh - var(--taskbar-height))!important;border-radius:0;resize:none;box-shadow:none}.title-bar{height:36px;font-size:14px}.control-btn{width:28px;height:28px;font-size:14px}#desktop-icons{flex-direction:row;align-content:flex-start;height:auto;width:100%;gap:8px 14px;padding:12px}.desktop-icon{width:76px;padding:6px 4px;margin-bottom:6px}.desktop-icon img{width:40px;height:40px}.desktop-icon span{font-size:12px}.login-screen{flex-direction:column;gap:24px;text-align:center;padding:0 16px}.login-left,.login-right{flex:none;width:100%;border:none;padding:0;align-items:center;text-align:center}.login-left img.login-logo{max-width:60vw;height:auto}.user-account{margin:0 auto}#start-menu{width:100vw;height:calc(100dvh - var(--taskbar-height));border-radius:0;bottom:var(--taskbar-height);left:0}.start-body{flex-direction:column}.start-left,.start-right{flex:none;width:100%;border-left:none}.start-right{border-top:1px solid #95BDE9}.taskbar-windows{overflow-x:auto;scrollbar-width:none}.taskbar-windows::-webkit-scrollbar{display:none}.taskbar-item{width:auto;min-width:36px;max-width:140px;height:28px;padding:0 6px;flex-shrink:0}.taskbar-item span{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}#clock{font-size:12px}.about-hero{flex-direction:column;align-items:center;text-align:center}.about-photo{width:140px;height:180px}.window-content-inner.resume{font-size:13px}.resume-section .job h4{flex-direction:column;align-items:flex-start;gap:2px}.resume-section .job h4 .loc{font-size:12px}.resume-actions{flex-direction:column;align-items:stretch}.resume-actions .xp-button{text-align:center;padding:10px 12px;font-size:13px}.projects-grid{grid-template-columns:1fr}.contact-form{max-width:100%}.contact-form input,.contact-form textarea{font-size:16px}.dog-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px;padding:8px 10px 14px}.dog-thumb{width:100%;height:110px}.dog-tile span{font-size:10px}.xp-button{padding:8px 14px;font-size:13px}}@media(max-width:760px)and (orientation:landscape){.desktop-icon{width:70px}.desktop-icon img{width:34px;height:34px}}@media(pointer:coarse){.xp-window{resize:none}}
