:root{--sys-gray: #d4d0c8;--sys-gray-dark: #c0bdb4;--sys-white: #ffffff;--sys-black: #000000;--sys-text: #000000;--sys-muted: #444444;--b-light: #ffffff;--b-mid-light: #dfdfdf;--b-mid: #aca899;--b-dark: #808080;--b-darker: #404040;--title-start: #000082;--title-end: #1084d0;--title-text: #ffffff;--aol-blue: #003580;--aol-blue-hover: #0050b3;--aol-gold: #f0a500;--link-color: #0000cc;--link-visited: #be6aff;--font-main: "OCR A Extended", "OCR A", "Courier New", monospace;--font-mono: "OCR A Extended", "OCR A", "Courier New", monospace;--nav-height: 30px;--max-width: 1100px;--desktop-bg: #008080}:root.dark-mode{--sys-gray: #3c3c3c;--sys-gray-dark: #2a2a2a;--sys-white: #1e1e1e;--sys-black: #f0f0f0;--sys-text: #d8d8d8;--sys-muted: #909090;--b-light: #606060;--b-mid-light: #505050;--b-mid: #3a3a3a;--b-dark: #181818;--b-darker: #000000;--aol-blue: #5590e0;--aol-blue-hover: #70a8f0;--link-color: #88aaff;--link-visited: #cc88ff;--desktop-bg: #1a1a1a}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-main);font-size:14px;background:var(--desktop-bg);color:var(--sys-text);min-height:100vh;display:flex;align-items:flex-start;justify-content:center;padding:12px}a{color:var(--link-color);text-decoration:underline}a:hover{color:var(--aol-blue-hover)}a:visited{color:var(--link-visited)}img{max-width:100%;display:block}main{flex:1;background:#787878;display:flex;align-items:flex-start;justify-content:center;padding:8px;overflow:visible}:root.dark-mode main{background:#2a2a2a}.desktop{position:relative;width:916px;height:530px;flex-shrink:0}.page-home,.page-projects,.page-about,.page-contact{position:relative;width:100%;height:100%}.win-panel{position:absolute;display:flex;flex-direction:column;background:var(--sys-gray);border-top:2px solid var(--b-light);border-left:2px solid var(--b-light);border-bottom:2px solid var(--b-darker);border-right:2px solid var(--b-darker);box-shadow:2px 2px 0 var(--b-mid)}.win-titlebar{display:flex;align-items:center;padding:3px 8px;background:linear-gradient(to right,var(--title-start),var(--title-end));color:var(--title-text);font-size:14px;font-weight:700;cursor:move;-webkit-user-select:none;user-select:none;flex-shrink:0}.win-panel.is-dragging .win-titlebar{cursor:grabbing}.win-title-text{pointer-events:none}.win-body{flex:1;overflow:auto;background:var(--sys-white);color:var(--sys-text);border-top:2px solid var(--b-dark);border-left:2px solid var(--b-dark);border-bottom:2px solid var(--b-light);border-right:2px solid var(--b-light);margin:3px;padding:8px}.page-home .card-grid,.page-about .skills-grid{grid-template-columns:1fr}.page-about .about-photo img{width:120px}.page-about .experience-list{display:flex;flex-direction:column;gap:8px}.page-about .experience-item{margin:0}.project-window{display:grid;grid-template-columns:190px 1fr;height:100%;gap:0}.project-window .project-image{border-right:1px solid var(--b-mid-light);overflow:hidden}.project-window .project-image img{width:100%;height:100%;object-fit:cover;image-rendering:pixelated;image-rendering:crisp-edges}.img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--sys-gray);color:var(--sys-muted);font-size:14px;font-family:var(--font-main);border-right:1px solid var(--b-mid-light);text-align:center;padding:8px}.project-window .project-info{padding:8px 10px;display:flex;flex-direction:column;gap:6px}.project-desc{color:var(--sys-muted);font-size:14px;line-height:1.5;flex:1}.projects-intro{color:var(--sys-muted);font-size:14px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--b-mid-light)}.projects-list{display:flex;flex-direction:column;gap:10px}.contact-blurb{color:var(--sys-muted);font-size:14px;line-height:1.6;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--b-mid-light)}.page-contact .contact-form{padding:0;gap:10px}.app-window{width:100%;max-width:1124px;min-height:calc(100vh - 24px);background:var(--sys-gray);display:flex;flex-direction:column;border-top:2px solid var(--b-light);border-left:2px solid var(--b-light);border-bottom:2px solid var(--b-darker);border-right:2px solid var(--b-darker);box-shadow:1px 1px 0 var(--b-mid),-1px -1px 0 var(--b-mid)}.title-bar{display:flex;align-items:center;justify-content:space-between;padding:3px 4px;background:linear-gradient(to right,var(--title-start),var(--title-end));-webkit-user-select:none;user-select:none}.title-bar-text{color:var(--title-text);font-size:16px;font-weight:700;letter-spacing:.01em}.title-bar-controls{display:flex;gap:2px}.title-btn{width:16px;height:14px;font-size:12px;line-height:1;cursor:pointer;background:var(--sys-gray);color:var(--sys-black);border-top:1px solid var(--b-light);border-left:1px solid var(--b-light);border-bottom:1px solid var(--b-darker);border-right:1px solid var(--b-darker);padding:0;display:flex;align-items:center;justify-content:center}.title-btn:active{border-top:1px solid var(--b-darker);border-left:1px solid var(--b-darker);border-bottom:1px solid var(--b-light);border-right:1px solid var(--b-light)}.title-btn-close:hover{background:#c00;color:#fff}.menubar{display:flex;align-items:center;gap:4px;padding:2px 4px;background:var(--sys-gray);border-bottom:1px solid var(--b-dark)}.nav-logo{font-size:16px;font-weight:700;color:var(--aol-blue);text-decoration:none;padding:2px 8px;margin-right:8px;border-right:1px solid var(--b-dark)}.nav-links{list-style:none;display:flex;gap:1px}.nav-links a{display:block;padding:3px 10px;font-size:14px;color:var(--sys-text);text-decoration:none;transition:background .1s}.nav-links a:hover{background:var(--aol-blue);color:#fff}.nav-links a.router-link-active{border-top:1px solid var(--b-dark);border-left:1px solid var(--b-dark);border-bottom:1px solid var(--b-light);border-right:1px solid var(--b-light);background:var(--sys-gray-dark);color:var(--sys-text)}.darkmode-toggle{margin-left:auto;font-size:16px;padding:2px 8px;cursor:pointer;background:var(--sys-gray);color:var(--sys-text);border-top:1px solid var(--b-light);border-left:1px solid var(--b-light);border-bottom:1px solid var(--b-darker);border-right:1px solid var(--b-darker);line-height:1}.darkmode-toggle:active{border-top:1px solid var(--b-darker);border-left:1px solid var(--b-darker);border-bottom:1px solid var(--b-light);border-right:1px solid var(--b-light)}.status-bar{display:flex;gap:4px;padding:2px 4px;background:var(--sys-gray);border-top:1px solid var(--b-dark)}.status-pane{flex:1;font-size:14px;color:var(--sys-muted);padding:2px 6px;border-top:1px solid var(--b-dark);border-left:1px solid var(--b-dark);border-bottom:1px solid var(--b-light);border-right:1px solid var(--b-light)}.btn{display:inline-block;padding:4px 16px;font-family:var(--font-main);font-size:12px;cursor:pointer;background:var(--sys-gray);color:var(--sys-black);text-decoration:none;min-width:75px;text-align:center;border-top:2px solid var(--b-light);border-left:2px solid var(--b-light);border-bottom:2px solid var(--b-darker);border-right:2px solid var(--b-darker);box-shadow:inset 1px 1px 0 var(--b-mid-light),inset -1px -1px 0 var(--b-mid);transition:none}.btn:hover{color:var(--sys-black);text-decoration:none}.btn:active,.btn-primary:active{border-top:2px solid var(--b-darker);border-left:2px solid var(--b-darker);border-bottom:2px solid var(--b-light);border-right:2px solid var(--b-light);box-shadow:inset 1px 1px 0 var(--b-mid),inset -1px -1px 0 var(--b-mid-light)}.btn-primary{background:var(--aol-blue);color:#fff;border-top:2px solid #4488cc;border-left:2px solid #4488cc;border-bottom:2px solid #001a40;border-right:2px solid #001a40;box-shadow:none;font-weight:700}.btn-primary:hover{background:var(--aol-blue-hover);color:#fff}.btn-outline{background:var(--sys-gray);color:var(--aol-blue)}.btn:disabled{opacity:.5;cursor:default}.panel{background:var(--sys-white);border-top:1px solid var(--b-dark);border-left:1px solid var(--b-dark);border-bottom:1px solid var(--b-light);border-right:1px solid var(--b-light)}.hero{padding:32px 24px 24px;background:var(--sys-gray)}.hero-banner{background:linear-gradient(to right,var(--aol-blue),#0066cc);color:var(--title-text);padding:12px 20px;margin-bottom:20px;display:flex;align-items:center;gap:12px;border-top:2px solid #4488cc;border-left:2px solid #4488cc;border-bottom:2px solid #001a40;border-right:2px solid #001a40}.hero-content{background:var(--sys-white);border-top:2px solid var(--b-dark);border-left:2px solid var(--b-dark);border-bottom:2px solid var(--b-light);border-right:2px solid var(--b-light);padding:20px;max-width:680px;margin:0 auto;text-align:center}.hero-greeting{font-size:12px;color:var(--sys-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}.hero-name{font-size:clamp(22px,4vw,40px);font-weight:700;color:var(--aol-blue);margin-bottom:6px}.hero-title{font-size:16px;color:var(--aol-blue-hover);margin-bottom:12px;font-weight:700}.hero-tagline{font-size:14px;color:var(--sys-muted);max-width:500px;margin:0 auto 20px;line-height:1.6}.hero-actions{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.highlights{padding:16px 24px 24px;background:var(--sys-gray)}.highlights h2{font-size:14px;font-weight:700;color:var(--sys-text);margin-bottom:12px;padding-bottom:4px;border-bottom:2px solid var(--aol-blue)}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}.card{background:var(--sys-white);border-top:2px solid var(--b-dark);border-left:2px solid var(--b-dark);border-bottom:2px solid var(--b-light);border-right:2px solid var(--b-light);overflow:hidden}.card-icon{font-size:1.5rem;padding:10px 12px 0}.card h3{background:linear-gradient(to right,var(--title-start),var(--title-end));color:var(--title-text);font-size:12px;font-weight:700;padding:3px 8px;margin-bottom:0}.card p{padding:8px 12px 12px;color:var(--sys-muted);font-size:12px;line-height:1.5}.page-header{padding:16px 24px 8px;background:linear-gradient(to right,var(--title-start),var(--title-end))}.page-header h1{font-size:16px;color:var(--title-text);font-weight:700;margin-bottom:4px}.page-header p{color:#b0c8e8;font-size:12px}.projects-grid{max-width:var(--max-width);margin:0 auto;padding:16px 24px;display:flex;flex-direction:column;gap:16px}.project-card{display:grid;grid-template-columns:280px 1fr;background:var(--sys-white);border-top:2px solid var(--b-dark);border-left:2px solid var(--b-dark);border-bottom:2px solid var(--b-light);border-right:2px solid var(--b-light);overflow:hidden}.project-image img{width:100%;height:100%;object-fit:cover;min-height:180px;background:var(--b-mid-light);border-right:1px solid var(--b-dark);image-rendering:crisp-edges}.project-info{display:flex;flex-direction:column;gap:0}.project-info h2{background:linear-gradient(to right,var(--title-start),var(--title-end));color:var(--title-text);font-size:14px;font-weight:700;padding:3px 8px}.project-info>p,.project-info>.project-tags{padding:0 12px}.project-info>p:nth-of-type(1){padding-top:10px}.project-tags{color:var(--aol-blue);font-size:12px;font-weight:700;padding-top:6px}.project-info>p:not(.project-tags){color:var(--sys-muted);font-size:12px;line-height:1.5;padding-bottom:8px}.project-links{display:flex;gap:6px;padding:8px 12px 12px;border-top:1px solid var(--b-mid-light);margin-top:auto}@media(max-width:800px){.project-card{grid-template-columns:1fr}.project-image img{border-right:none;border-bottom:1px solid var(--b-dark)}}.about-section{max-width:var(--max-width);margin:0 auto;padding:16px 24px;display:grid;grid-template-columns:220px 1fr;gap:16px;align-items:start}.about-photo img{width:100%;aspect-ratio:1;object-fit:cover;border-top:2px solid var(--b-dark);border-left:2px solid var(--b-dark);border-bottom:2px solid var(--b-light);border-right:2px solid var(--b-light)}.about-text{background:var(--sys-white);border-top:2px solid var(--b-dark);border-left:2px solid var(--b-dark);border-bottom:2px solid var(--b-light);border-right:2px solid var(--b-light);overflow:hidden}.about-text h1{background:linear-gradient(to right,var(--title-start),var(--title-end));color:var(--title-text);font-size:14px;font-weight:700;padding:3px 8px;margin-bottom:0}.about-text p{color:var(--sys-muted);margin-bottom:8px;font-size:12px;line-height:1.6;padding:0 12px}.about-text p:first-of-type{padding-top:10px}.about-text .btn{margin:4px 12px 12px}.skills-section{max-width:var(--max-width);margin:0 auto;padding:0 24px 16px}.skills-section h2{font-size:14px;font-weight:700;color:var(--sys-text);margin-bottom:10px;padding-bottom:4px;border-bottom:2px solid var(--aol-blue)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}.skill-group{background:var(--sys-white);border-top:2px solid var(--b-dark);border-left:2px solid var(--b-dark);border-bottom:2px solid var(--b-light);border-right:2px solid var(--b-light);overflow:hidden}.skill-group h3{background:var(--sys-gray-dark);color:var(--sys-text);font-size:14px;font-weight:700;padding:3px 8px;border-bottom:1px solid var(--b-dark)}.skill-group ul{list-style:none;padding:6px 10px 8px}.skill-group li{color:var(--sys-muted);font-size:12px;padding:1px 0}.skill-group li:before{content:"• ";color:var(--aol-blue)}.experience-section{max-width:var(--max-width);margin:0 auto;padding:0 24px 24px}.experience-section h2{font-size:14px;font-weight:700;color:var(--sys-text);margin-bottom:10px;padding-bottom:4px;border-bottom:2px solid var(--aol-blue)}.experience-item{background:var(--sys-white);border-top:2px solid var(--b-dark);border-left:2px solid var(--b-dark);border-bottom:2px solid var(--b-light);border-right:2px solid var(--b-light);overflow:hidden;margin-bottom:10px}.experience-meta{background:linear-gradient(to right,var(--title-start),var(--title-end));display:flex;justify-content:space-between;align-items:center;padding:3px 8px}.experience-date{color:#b0c8e8;font-size:12px}.experience-company{color:var(--title-text);font-size:12px;font-weight:700}.experience-item h3{font-size:14px;font-weight:700;color:var(--aol-blue);padding:8px 12px 4px}.experience-item p{color:var(--sys-muted);font-size:12px;line-height:1.5;padding:0 12px 10px}@media(max-width:700px){.about-section{grid-template-columns:1fr}.about-photo img{width:160px;margin:0 auto}}.contact-section{max-width:900px;margin:0 auto;padding:16px 24px 24px;display:grid;grid-template-columns:1fr 1.5fr;gap:16px;align-items:start}.contact-intro{background:var(--sys-white);border-top:2px solid var(--b-dark);border-left:2px solid var(--b-dark);border-bottom:2px solid var(--b-light);border-right:2px solid var(--b-light);overflow:hidden}.contact-intro h1{background:linear-gradient(to right,var(--title-start),var(--title-end));color:var(--title-text);font-size:14px;font-weight:700;padding:3px 8px}.contact-intro>p{color:var(--sys-muted);font-size:12px;line-height:1.6;padding:10px 12px 8px}.contact-details{list-style:none;padding:0 12px 12px}.contact-details li{font-size:12px;color:var(--sys-muted);padding:3px 0;border-bottom:1px solid var(--b-mid-light)}.contact-details strong{color:var(--sys-text);margin-right:4px}.contact-details a{font-size:12px}.contact-form{background:var(--sys-white);border-top:2px solid var(--b-dark);border-left:2px solid var(--b-dark);border-bottom:2px solid var(--b-light);border-right:2px solid var(--b-light);padding:12px;display:flex;flex-direction:column;gap:10px}.form-group{display:flex;flex-direction:column;gap:3px}.form-group label{font-size:12px;font-weight:700;color:var(--sys-text)}.form-group input,.form-group textarea{font-family:var(--font-main);font-size:12px;background:var(--sys-white);color:var(--sys-text);padding:3px 6px;resize:vertical;border-top:2px solid var(--b-dark);border-left:2px solid var(--b-dark);border-bottom:2px solid var(--b-light);border-right:2px solid var(--b-light);box-shadow:inset 1px 1px 0 var(--b-mid);outline:none}.form-group input:focus,.form-group textarea:focus{outline:1px dotted var(--sys-black);outline-offset:-2px}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--b-dark)}@media(max-width:700px){.contact-section{grid-template-columns:1fr}}@media(max-width:600px){body{padding:4px}.menubar{flex-wrap:wrap}}
