:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#1a1a1a;font-family:Inter,system-ui,-apple-system,sans-serif;font-weight:400;line-height:1.6}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}a{color:inherit;text-decoration:none}h1{margin-top:0;font-size:2rem;font-weight:600;line-height:1.2}h2{margin-top:2rem;font-size:1.4rem;font-weight:600}h3{font-size:1.1rem;font-weight:600}img{border-radius:6px;max-width:100%;height:auto}@media (prefers-color-scheme:light){:root{color:#1a1a1a;background-color:#fafafa}}.markdown-body{line-height:1.7}.markdown-body p{margin:1rem 0}.markdown-body ul,.markdown-body ol{padding-left:1.5rem}.markdown-body li{margin:.35rem 0}.markdown-body code{background:#ffffff14;border-radius:4px;padding:.15em .4em;font-size:.9em}.markdown-body pre{background:#ffffff0d;border-radius:6px;padding:1rem;overflow-x:auto}.markdown-body pre code{background:0 0;padding:0}.markdown-body strong{font-weight:600}.markdown-body a{color:#6ab0f3;text-underline-offset:2px;text-decoration:underline}.markdown-body a:hover{opacity:.8}.markdown-body blockquote{background:#ffffff0a;border-left:3px solid #ffffff4d;border-radius:0 6px 6px 0;margin:1.25rem 0;padding:.75rem 1.25rem}.markdown-body blockquote p{opacity:.85;margin:0;font-style:italic}.markdown-body table{border-collapse:collapse;width:100%;margin:1rem 0;font-size:.9rem}.markdown-body th,.markdown-body td{text-align:left;border-bottom:1px solid #ffffff1a;padding:.6rem .9rem}.markdown-body th{opacity:.7;text-transform:uppercase;letter-spacing:.03em;font-size:.8rem;font-weight:600}.markdown-body tr:last-child td{border-bottom:none}@media (prefers-color-scheme:light){.markdown-body code{background:#0000000f}.markdown-body pre{background:#0000000a}.markdown-body a{color:#2563eb}.markdown-body blockquote{background:#00000008;border-left-color:#0003}.markdown-body th,.markdown-body td{border-bottom-color:#00000014}}.search-bar{width:30%;color:inherit;background:#ffffff0a;border:1px solid #ffffff26;border-radius:6px;outline:none;margin-bottom:1.5rem;padding:.6rem .9rem;font-family:inherit;font-size:.9rem;transition:border-color .2s}.search-bar::placeholder{opacity:.4}.search-bar:focus{border-color:#ffffff59}@media (prefers-color-scheme:light){.search-bar{background:#00000005;border-color:#0000001f}.search-bar:focus{border-color:#0000004d}}.projects-page h1{margin-bottom:2rem}.project-list{flex-direction:column;gap:1.5rem;display:flex}.project-card{height:6rem;color:inherit;background:#ffffff0a;border-radius:8px;align-items:center;gap:1.25rem;padding:1rem 1.25rem;text-decoration:none;transition:background .2s;display:flex;position:relative}.project-card:hover{background:#ffffff14}@media (prefers-color-scheme:light){.project-card{background:#00000008}.project-card:hover{background:#0000000f}}.project-card-image{border-radius:6px;flex-shrink:0;width:120px;height:90px;overflow:hidden}.project-card-image img{object-fit:cover;border-radius:0;width:100%;height:100%}.project-card-body{flex-direction:column;flex:1;gap:.25rem;min-width:0;display:flex;overflow:hidden}.project-card-body h2{margin:0;font-size:1.1rem;font-weight:600}.project-card-right{flex-direction:column;flex-shrink:0;align-self:flex-start;align-items:flex-end;gap:.75rem;margin-left:auto;display:flex}.project-card-date{opacity:.5;font-size:.8rem}.project-card-link{width:28px;height:28px;color:inherit;opacity:.6;background:#ffffff14;border-radius:6px;justify-content:center;align-items:center;transition:opacity .2s,background .2s;display:inline-flex}.project-card-link:hover{opacity:1;background:#ffffff24}@media (prefers-color-scheme:light){.project-card-link{background:#0000000d}.project-card-link:hover{background:#0000001a}}.project-card-summary{opacity:.7;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.9rem;line-height:1.5;overflow:hidden}.writing-page h1{margin-bottom:2rem}.writing-list{flex-direction:column;gap:1.5rem;display:flex}.writing-card{height:5.5rem;color:inherit;background:#ffffff0a;border-radius:8px;align-items:center;gap:1.25rem;padding:1rem 1.25rem;text-decoration:none;transition:background .2s;display:flex;position:relative}.writing-card:hover{background:#ffffff14}@media (prefers-color-scheme:light){.writing-card{background:#00000008}.writing-card:hover{background:#0000000f}}.writing-card-image{border-radius:6px;flex-shrink:0;width:120px;height:90px;overflow:hidden}.writing-card-image img{object-fit:cover;border-radius:0;width:100%;height:100%}.writing-card-body{flex-direction:column;flex:1;gap:.25rem;min-width:0;display:flex;overflow:hidden}.writing-card-body h2{margin:0;font-size:1.1rem;font-weight:600}.writing-card-right{flex-direction:column;flex-shrink:0;align-self:flex-start;align-items:flex-end;gap:.25rem;margin-top:.35rem;margin-left:auto;display:flex}.writing-card-date{opacity:.5;font-size:.8rem}.writing-card-summary{opacity:.7;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.9rem;line-height:1.5;overflow:hidden}.writing-detail{max-width:700px}.writing-header{justify-content:space-between;align-items:flex-start;gap:1.5rem;margin-bottom:2rem;display:flex}.writing-header-left h1{margin:0}.writing-date{opacity:.6;margin-top:.4rem;font-size:.85rem;display:inline-block}.writing-summary{opacity:.7;margin:.5rem 0 0;font-size:.95rem;line-height:1.5}.writing-header-right{flex-direction:column;flex-shrink:0;align-items:flex-end;padding-top:.25rem;display:flex}.project-detail{max-width:700px}.back-link{opacity:.5;margin-bottom:1.5rem;font-size:.9rem;transition:opacity .2s;display:inline-block}.back-link:hover{opacity:.8}.project-header{justify-content:space-between;align-items:flex-start;gap:1.5rem;margin-bottom:2rem;display:flex}.project-header-left{align-items:center;gap:1rem;display:flex}.project-header-left h1{margin:0}.project-header-icon{object-fit:contain;border-radius:8px;flex-shrink:0;width:44px;height:44px}.project-date{opacity:.6;margin-top:.4rem;font-size:.85rem;display:inline-block}.project-summary{opacity:.7;margin:.5rem 0 0;font-size:.95rem;line-height:1.5}.project-header-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:.5rem;padding-top:.25rem;display:flex}.project-website-link{color:inherit;background:#ffffff1f;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.85rem;font-weight:500;text-decoration:none;transition:opacity .2s;display:inline-block}.project-website-link:hover{opacity:.8}@media (prefers-color-scheme:light){.project-website-link{color:inherit;background:#0000000f}}.placeholder-page{opacity:.6}.placeholder-page p{font-style:italic}.photography-page h1{margin-bottom:2rem}.photography-loading,.photography-error{opacity:.6;font-style:italic}.photo-loader{flex-direction:column;justify-content:center;align-items:center;gap:1.2rem;padding:5rem 0;display:flex}.photo-loader-icon{width:60px;height:60px}.photo-loader-icon.spinning{animation:.6s linear infinite photo-spin}.photo-loader-text{letter-spacing:.12em;opacity:.45;text-transform:uppercase;font-size:.85rem}@keyframes photo-spin{to{transform:rotate(360deg)}}.photography-grid{width:auto;margin-left:-1rem;display:flex}.photography-grid-column{background-clip:padding-box;padding-left:1rem}.photography-grid-column>.photography-item{margin-bottom:1rem}.photography-item{background:#ffffff0a;border-radius:8px;overflow:hidden}.photography-item img{width:100%;height:auto;transition:filter .5s;display:block}.photography-item img.photo-thumb{filter:blur(12px);transform:scale(1.08)}.photography-item img.photo-upgraded{filter:none}.photography-item{cursor:pointer;transition:opacity .2s ease-out}.photography-item:hover{opacity:.85}@media (prefers-color-scheme:light){.photography-item{background:#00000008}}.lightbox-overlay{z-index:1000;cursor:pointer;background:#000000d9;justify-content:center;align-items:center;animation:.2s ease-out lightbox-fade-in;display:flex;position:fixed;inset:0}@keyframes lightbox-fade-in{0%{opacity:0}to{opacity:1}}.lightbox-image{object-fit:contain;cursor:default;border-radius:4px;max-width:90vw;max-height:90vh}.home-page{max-width:800px}.not-found{text-align:center;padding-top:4rem}.not-found a{opacity:.6;margin-top:1rem;text-decoration:underline;display:inline-block}.site-layout{width:100%;min-height:100vh;display:flex}.site-nav{box-sizing:border-box;justify-content:flex-end;align-items:center;width:20%;height:100vh;padding-right:2rem;display:flex;position:fixed;top:0;left:0}.site-nav ul{flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none;display:flex}.site-nav a{color:inherit;opacity:.5;white-space:nowrap;font-size:.9rem;font-weight:400;text-decoration:none;transition:opacity .2s}.site-nav a:hover{opacity:.8;color:inherit}.site-nav a.active{opacity:1;font-weight:600}.site-content{box-sizing:border-box;width:60%;min-height:100vh;margin-left:20%;padding:3rem 2rem}@media (max-width:900px){.site-layout{flex-direction:column}.site-nav{justify-content:center;width:100%;height:auto;padding:1rem;position:static}.site-nav ul{flex-flow:wrap;justify-content:center;gap:1.25rem}.site-content{width:100%;margin-left:0;padding:2rem 1.5rem}}
