:root{--bg-color:#0d0d0d;--text-color:#e5e5e5;--text-muted:#888;--accent-color:#fff;--border-color:#333;--font-family:"Inter", sans-serif;--max-width:2280px}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-color);font-family:var(--font-family);-webkit-font-smoothing:antialiased;line-height:1.6}a{color:var(--text-color);text-decoration:none;transition:color .3s}a:hover{color:var(--text-muted)}#app{min-height:100vh;max-width:var(--max-width);flex-direction:column;margin:0 auto;padding:0 4vw;display:flex}#navbar{justify-content:space-between;align-items:center;padding:3rem 0;display:flex}.nav-brand{letter-spacing:-.02em;cursor:pointer;font-size:1.25rem;font-weight:600}.nav-links{gap:1.5rem;list-style:none;display:flex}.nav-link{color:var(--text-muted);cursor:pointer;font-size:.95rem;font-weight:400;transition:color .3s;display:block}.nav-link:hover,.nav-link.active{color:var(--accent-color)}.nav-item{position:relative}.has-dropdown:hover .nav-dropdown{opacity:1;pointer-events:auto;display:flex;transform:translateY(0)}.nav-dropdown{background-color:var(--bg-color);border:1px solid var(--border-color);opacity:0;pointer-events:none;z-index:100;border-radius:4px;flex-direction:column;min-width:200px;padding:.5rem 0;list-style:none;transition:all .3s;display:flex;position:absolute;top:100%;left:0;transform:translateY(-10px);box-shadow:0 10px 30px #00000080}.dropdown-toggle{display:none}.dropdown-link{color:var(--text-muted);padding:.5rem 1rem;font-size:.9rem;transition:color .2s,background-color .2s;display:block}.dropdown-link:hover{color:var(--accent-color);background-color:#ffffff0d}#main-content{opacity:0;flex-direction:column;flex:1;padding-bottom:4rem;transition:opacity .3s,transform .3s;display:flex;transform:translateY(10px)}#main-content.page-visible{opacity:1;transform:translateY(0)}#main-content.page-hidden{opacity:0;transform:translateY(-10px)}.home-blurb{max-width:680px;margin-bottom:4rem}.projects-grid{column-width:400px;column-gap:3rem}.project-card{cursor:pointer;break-inside:avoid;margin-bottom:3rem}.project-card-image{opacity:0;border-radius:4px;width:100%;height:auto;margin-bottom:1rem;transition:transform .5s,opacity .5s;display:block}.project-card-image.loaded{opacity:.9}.project-card:hover .project-card-image.loaded{opacity:1;transform:scale(1.05)}.placeholder-image{color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;background-color:#1a1a1a;justify-content:center;align-items:center;font-weight:600;display:flex}.project-image-wrapper{border-radius:4px;margin-bottom:1rem;position:relative;overflow:hidden}.image-loader{background-color:#1a1a1a;position:relative}.image-loader:before{content:"";border:2px solid #333;border-top-color:var(--accent-color);z-index:0;border-radius:50%;width:24px;height:24px;margin-top:-12px;margin-left:-12px;animation:1s linear infinite spin;position:absolute;top:50%;left:50%}@keyframes spin{to{transform:rotate(360deg)}}.project-image-wrapper .project-card-image{z-index:1;margin-bottom:0;display:block;position:relative}.interactive-overlay{width:100%;color:var(--text-color);letter-spacing:.15em;text-transform:uppercase;pointer-events:none;z-index:2;background:linear-gradient(#0000 0%,#000000e6 100%);padding:1rem 1.2rem;font-size:.8rem;font-weight:600;position:absolute;bottom:0;left:0}.project-card-info{justify-content:space-between;align-items:center;display:flex}.project-title{font-size:1.1rem;font-weight:600}.project-date{color:var(--text-muted);font-size:.85rem}.page-content,.project-detail{width:100%}.project-detail{grid-template-columns:1fr;align-items:start;gap:3rem;display:grid}@media (width>=1024px){.project-detail{grid-template-columns:1fr 2fr;gap:4rem}.project-detail .markdown-body{position:sticky;top:2rem}}.markdown-body{width:100%;max-width:680px;font-size:1.05rem}.markdown-body h1,.markdown-body h2,.markdown-body h3{letter-spacing:-.02em;margin-top:2rem;margin-bottom:1rem;font-weight:600}.markdown-body h1{font-size:2.2rem}.markdown-body h2{font-size:1.6rem}.markdown-body p{color:#ccc;margin-bottom:1.5rem}.markdown-body ul,.markdown-body ol{color:#ccc;margin-bottom:1.5rem;padding-left:1.5rem}.markdown-body li{margin-bottom:.5rem}.markdown-body a{color:var(--text-color);text-decoration:none;transition:all .3s}.markdown-body a:before{content:"[";color:var(--text-muted);margin-right:.15rem;transition:color .3s}.markdown-body a:after{content:"]";color:var(--text-muted);margin-left:.15rem;transition:color .3s}.markdown-body a:hover,.markdown-body a:hover:before,.markdown-body a:hover:after{color:var(--accent-color)}.project-interactive-container{background-color:#000;border-radius:4px;width:100%;position:relative;overflow:hidden;box-shadow:0 8px 24px #0006}.interactive-layout .project-interactive-container{width:100%;height:75vh;min-height:500px}.interactive-layout .project-interactive-container.fullscreen{z-index:9999;border-radius:0;width:100%;height:100%;min-height:100%;margin:0;position:fixed;inset:0}.fullscreen-toggle{z-index:10;color:var(--text-color);border:1px solid var(--border-color);cursor:pointer;letter-spacing:.1em;text-transform:uppercase;opacity:.5;background:#00000080;border-radius:4px;padding:.5rem .75rem;font-family:inherit;font-size:.75rem;transition:background .3s,opacity .3s,border-color .3s;position:absolute;top:1rem;right:1rem}.fullscreen-toggle:after{content:"Expand"}.project-interactive-container.fullscreen .fullscreen-toggle:after{content:"Collapse"}.project-interactive-container:hover .fullscreen-toggle,.fullscreen-toggle:hover{opacity:1}.fullscreen-toggle:hover{border-color:var(--text-muted);background:#000000e6}.project-interactive-frame{border:none;width:100%;height:100%;display:block;position:absolute;top:0;left:0}.interactive-caption{color:var(--text-color);letter-spacing:.05em;text-align:center;margin-top:1.5rem;font-size:1rem}.project-images-gallery{column-width:250px;column-gap:1.5rem}.project-interactive-container+.interactive-caption+.project-images-gallery,.project-interactive-container+.project-images-gallery{margin-top:3rem}.project-thumbnail-wrapper{cursor:pointer;break-inside:avoid;border-radius:4px;margin-bottom:1.5rem;overflow:hidden;box-shadow:0 4px 12px #0000004d}.project-thumbnail{opacity:0;z-index:1;width:100%;height:auto;transition:opacity .3s,transform .3s;display:block;position:relative}img[src$=\.svg]{background-color:#fff}.project-thumbnail.loaded{opacity:.9}.project-thumbnail-wrapper:hover .project-thumbnail.loaded{opacity:1;transform:scale(1.05)}#lightbox{z-index:1000;cursor:zoom-out;opacity:0;background:#000000e6;width:100vw;height:100vh;transition:opacity .3s;display:flex;position:fixed;top:0;left:0;overflow:auto}#lightbox.active{opacity:1}#lightbox:before{content:"";border:3px solid #333;border-top-color:var(--accent-color);z-index:-1;border-radius:50%;width:32px;height:32px;margin-top:-16px;margin-left:-16px;animation:1s linear infinite spin;position:fixed;top:50%;left:50%}#lightbox.image-loaded:before{display:none}.lightbox-content{flex-direction:column;align-items:center;margin:auto;padding:2rem;display:flex}#lightbox img{object-fit:contain;cursor:zoom-in;opacity:0;border-radius:4px;max-width:90vw;max-height:85vh;transition:opacity .4s;box-shadow:0 10px 40px #000c}#lightbox img[src$=\.svg]{width:auto;height:85vh}#lightbox img.loaded{opacity:1}#lightbox img.zoomed{cursor:zoom-out;max-width:none;max-height:none}.lightbox-caption{color:var(--text-color);letter-spacing:.05em;text-align:center;margin-top:1.5rem;font-size:1rem}.lightbox-link{text-decoration:underline;-webkit-text-decoration-color:var(--border-color);text-decoration-color:var(--border-color);text-underline-offset:4px;color:var(--text-color);cursor:pointer;transition:color .2s,text-decoration-color .2s}.lightbox-link:hover{color:var(--accent-color);-webkit-text-decoration-color:var(--accent-color);text-decoration-color:var(--accent-color)}#footer{text-align:center;color:var(--text-muted);padding:1rem 0;font-size:.85rem}.lightbox-nav{color:#fff6;cursor:pointer;-webkit-user-select:none;user-select:none;z-index:1001;padding:1rem 2rem;font-size:4rem;font-weight:300;transition:color .3s,transform .3s;position:absolute;top:50%;transform:translateY(-50%)}.lightbox-nav:hover{color:#ffffffe6;transform:translateY(-50%)scale(1.1)}.lightbox-prev{transform-origin:0;left:0}.lightbox-next{transform-origin:100%;right:0}@media (width<=600px){#navbar{flex-direction:column;align-items:flex-start;gap:1.5rem;padding:2rem 0}.dropdown-toggle{cursor:pointer;padding-left:.5rem;display:inline-block}.nav-dropdown{opacity:0;pointer-events:none;max-height:0;box-shadow:none;background-color:#0000;border:none;padding-top:0;padding-bottom:0;padding-left:1rem;transition:max-height .3s,opacity .3s,padding .3s;position:static;overflow:hidden;transform:none}.has-dropdown.open .nav-dropdown{opacity:1;pointer-events:auto;max-height:500px;padding-top:.5rem;padding-bottom:.5rem}.projects-grid{grid-template-columns:1fr}}
