:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}html{scroll-behavior:smooth}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.navbar{z-index:10;background:var(--bg);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex;position:sticky;top:0}.nav-logo{font-family:var(--mono);color:var(--text-h);font-size:15px;font-weight:500;text-decoration:none}.nav-links{gap:24px;display:flex}.nav-links a{color:var(--text);border-bottom:2px solid #0000;padding:4px 0;font-size:15px;text-decoration:none;transition:color .15s,border-color .15s}.nav-links a:hover{color:var(--text-h)}.nav-links a.active{color:var(--text-h);border-bottom-color:var(--accent)}.hero{max-width:720px;margin:0 auto;padding:64px 24px 56px}.hero-tagline{font-family:var(--mono);color:var(--accent);background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:4px;margin-bottom:24px;padding:4px 10px;font-size:14px;display:inline-block}.hero-description{max-width:560px;margin:0 auto 32px;font-size:19px;line-height:155%}.cta-group{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.btn{font-family:var(--sans);border-radius:6px;padding:10px 20px;font-size:15px;font-weight:500;text-decoration:none;transition:opacity .15s,background .15s;display:inline-block}.btn-primary{background:var(--accent);color:var(--bg)}.btn-primary:hover{opacity:.88}.btn-secondary{color:var(--text-h);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--accent-border)}.home-section{text-align:left;max-width:900px;margin:0 auto;padding:48px 24px}.home-section>h2{text-align:center;margin-bottom:24px}.home-divider{border:none;border-top:1px solid var(--border);margin:0}.skills-list{flex-wrap:wrap;justify-content:center;gap:8px;margin:0;padding:0;list-style:none;display:flex}.skills-list li{font-family:var(--mono);color:var(--text-h);background:var(--code-bg);border-radius:4px;padding:5px 10px;font-size:14px}.contact-list{flex-direction:column;align-items:center;gap:8px;margin:0;padding:0;list-style:none;display:flex}.contact-list a{color:var(--accent);text-decoration:none}.contact-list a:hover{text-decoration:underline}.projects-header{text-align:center;padding:48px 0 8px}.projects-header h1{letter-spacing:-.9px;margin:0 0 12px;font-size:36px}.projects-intro{color:var(--text);max-width:480px;margin:0 auto;line-height:150%}.projects{text-align:left;max-width:900px;margin:0 auto;padding:0 24px 64px}.projects>h1{text-align:center}.project-grid{grid-template-columns:repeat(2,1fr);gap:24px;margin-top:32px;display:grid}@media (width<=720px){.project-grid{grid-template-columns:1fr}}.project-card{border:1px solid var(--border);border-radius:8px;flex-direction:column;padding:24px;transition:box-shadow .15s,border-color .15s;display:flex}.project-card-image-wrapper{position:relative}.project-card-image-button{cursor:pointer;background:0 0;border:none;width:100%;padding:0;display:block}.project-card-image{aspect-ratio:16/9;object-fit:cover;border:1px solid var(--accent-border);border-radius:8px;width:100%;margin-bottom:16px;display:block}.project-card-image-dots{justify-content:center;gap:6px;display:flex;position:absolute;bottom:24px;left:0;right:0}.project-card-image-dot{border:1px solid var(--accent-border);cursor:pointer;background:#ffffff80;border-radius:50%;width:8px;height:8px;padding:0}.project-card-image-dot.active{background:var(--accent)}.image-lightbox-arrow{border:1px solid var(--border);background:var(--bg);width:48px;height:48px;color:var(--text-h);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:28px;line-height:1;display:flex;position:fixed;top:50%;transform:translateY(-50%)}.image-lightbox-arrow:hover{border-color:var(--accent-border);color:var(--accent)}.image-lightbox-arrow-left{left:24px}.image-lightbox-arrow-right{right:24px}.image-lightbox-dots{justify-content:center;gap:8px;display:flex;position:fixed;bottom:24px;left:0;right:0}.image-lightbox-dot{border:1px solid var(--accent-border);cursor:pointer;background:#ffffff4d;border-radius:50%;width:10px;height:10px;padding:0}.image-lightbox-dot.active{background:var(--accent)}.image-lightbox-overlay{z-index:1000;box-sizing:border-box;background:#000000d9;justify-content:center;align-items:center;padding:40px;display:flex;position:fixed;inset:0}.image-lightbox-image{border:1px solid var(--accent-border);max-width:100%;max-height:100%;box-shadow:var(--shadow);border-radius:8px}.image-lightbox-close{border:1px solid var(--border);background:var(--bg);width:40px;height:40px;color:var(--text-h);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:24px;line-height:1;display:flex;position:fixed;top:24px;right:24px}.image-lightbox-close:hover{border-color:var(--accent-border);color:var(--accent)}.project-card:hover{box-shadow:var(--shadow);border-color:var(--accent-border)}.project-card.featured{border-left:2px solid var(--accent)}.project-card h2{margin:0 0 8px;font-size:19px}.project-description{flex-grow:1;margin-bottom:16px;line-height:150%}.project-meta{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;font-size:13px;display:flex}.project-status{font-family:var(--mono);border:1px solid;border-radius:4px;padding:2px 8px}.status-completed{color:#15803d;background:#15803d1a;border-color:#15803d59}.status-in-progress{color:#1d4ed8;background:#1d4ed81a;border-color:#1d4ed859}.status-archived{color:var(--text);background:var(--code-bg);border-color:var(--border)}@media (prefers-color-scheme:dark){.status-completed{color:#4ade80;background:#4ade801f;border-color:#4ade8059}.status-in-progress{color:#60a5fa;background:#60a5fa1f;border-color:#60a5fa59}}.project-year{font-family:var(--mono);color:var(--text)}.project-tech{flex-wrap:wrap;gap:6px;margin:0 0 16px;padding:0;list-style:none;display:flex}.project-tech li{font-family:var(--mono);color:var(--text-h);background:var(--code-bg);border-radius:4px;padding:3px 8px;font-size:13px}.project-links{align-items:center;gap:6px;margin-top:auto;font-size:14px;display:flex}.project-links a{color:var(--accent);text-decoration:none}.project-links a:hover{text-decoration:underline}.project-link-separator{color:var(--border)}.about{text-align:left;max-width:680px;margin:0 auto;padding:0 24px 64px}.about-header{text-align:center}.about-role{color:var(--text);margin:-16px 0 40px;font-size:18px}.about-summary p{margin-bottom:16px;line-height:160%}.about-summary p:last-child{margin-bottom:0}.about-section{border-top:1px solid var(--border);margin-top:56px;padding-top:40px}.skill-groups{grid-template-columns:repeat(2,1fr);gap:24px 32px;margin-top:24px;display:grid}@media (width<=640px){.skill-groups{grid-template-columns:1fr}}.skill-group h3{font-family:var(--heading);letter-spacing:.02em;text-transform:uppercase;color:var(--text);margin:0 0 10px;font-size:14px;font-weight:500}.skill-tags{flex-wrap:wrap;gap:6px;margin:0;padding:0;list-style:none;display:flex}.skill-tags li{font-family:var(--mono);color:var(--text-h);background:var(--code-bg);border-radius:4px;padding:3px 8px;font-size:13px}.experience-list{flex-direction:column;gap:32px;margin-top:24px;display:flex}.experience-item{border-left:2px solid var(--accent-border);padding-left:20px}.experience-header{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:4px;display:flex}.experience-header h3{font-family:var(--heading);color:var(--text-h);margin:0;font-size:17px;font-weight:500}.experience-header h3 span{color:var(--text);font-weight:400}.experience-period{font-family:var(--mono);color:var(--text);white-space:nowrap;font-size:13px}.experience-points{margin:8px 0 0;padding-left:20px}.experience-points li{margin-bottom:6px;line-height:150%}.experience-points li:last-child{margin-bottom:0}.about-education{margin-top:24px}
