*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#15130f;--bg-soft:#1b1813;--text:#ece7dd;--text-body:#c2bbaf;--text-muted:#948d80;--text-dim:#6d6759;--border:#ffffff17;--border-strong:#ffffff29;--blue:#5aabe6;--blue-hover:#78bdef;--green:#7cc98f;--teal:#57bcae;--sans:"IBM Plex Sans", system-ui, sans-serif;--mono:"IBM Plex Mono", ui-monospace, monospace;--display:"Space Grotesk", system-ui, sans-serif}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;min-height:100vh;font-size:15px;line-height:1.65;overflow-x:hidden}a{color:var(--blue);text-decoration:none;transition:color .16s}a:hover{color:var(--blue-hover)}a:focus-visible{outline-offset:3px;border-radius:4px;outline:1px solid #5aabe699}.site-nav{z-index:50;backdrop-filter:blur(12px);border-bottom:1px solid var(--border);background:#15130fd1;position:sticky;top:0}.site-nav-inner{justify-content:space-between;align-items:center;gap:16px;max-width:1080px;margin:0 auto;padding:16px 32px;display:flex}.site-nav-logo{align-items:center;gap:10px;display:flex}.site-nav-badge{background:var(--blue);width:26px;height:26px;font:700 14px var(--display);color:var(--bg);border-radius:7px;justify-content:center;align-items:center;display:inline-flex}.site-nav-name{font:600 17px var(--display);letter-spacing:-.02em;color:var(--text)}.site-nav-links{font:500 13.5px var(--sans);flex-wrap:wrap;align-items:center;gap:8px;display:flex}.site-nav-link{color:var(--text-muted);border-radius:6px;padding:6px 10px;transition:color .16s,background .16s}.site-nav-link:hover,.site-nav-link.active{color:var(--text);background:#ffffff0d}.site-nav-github{color:var(--text);border:1px solid var(--border-strong);border-radius:6px;margin-left:6px;padding:8px 15px;font-size:12.5px;transition:border-color .16s,background .16s,color .16s}.site-nav-github:hover{border-color:var(--blue);color:var(--text);background:#5aabe614}.site-footer{border-top:1px solid var(--border);margin-top:72px}.site-footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;max-width:1080px;margin:0 auto;padding:30px 32px;display:flex}.site-footer-status{font:400 13px var(--mono);color:var(--text-muted);align-items:center;gap:10px;display:flex}.site-footer-dot{background:var(--green);border-radius:50%;width:7px;height:7px;box-shadow:0 0 8px #7cc98f99}.site-footer-links{font:400 12.5px var(--sans);flex-wrap:wrap;gap:18px;display:flex}.site-footer-links a{color:var(--text-muted)}.site-footer-links a:hover{color:var(--text)}.wrap{z-index:1;max-width:900px;margin:0 auto;padding:0 32px;position:relative}.back{font:600 11px var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);align-items:center;gap:8px;padding:34px 0 0;transition:color .2s;display:inline-flex}.back:before{content:"←";transition:transform .2s}.back:hover{color:var(--blue)}.back:hover:before{transform:translate(-3px)}.post-header{padding:40px 0 0;animation:.7s both fadeUp}.kicker{font:600 12px var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--blue);margin-bottom:18px}.post-title{font:700 clamp(2.2rem, 5.5vw, 3.6rem)/1.02 var(--display);letter-spacing:-.03em;color:var(--text);margin-bottom:16px}.post-subtitle{font:400 clamp(1.05rem, 2.2vw, 1.3rem)/1.5 var(--sans);color:var(--text-body);max-width:640px;margin-bottom:18px}.post-meta{font:400 12px var(--mono);color:var(--text-muted);letter-spacing:.04em;border-bottom:1px solid var(--border);margin-bottom:44px;padding-bottom:32px}.prose{animation:.7s .1s both fadeUp}.prose p{color:var(--text-body);max-width:680px;margin:1.3rem 0;font-size:15px;line-height:1.75}.prose a{color:var(--blue);border-bottom:1px solid #5aabe64d}.prose a:hover{color:var(--blue-hover);border-color:var(--blue)}.prose ul,.prose ol{color:var(--text-body);max-width:680px;margin:1.3rem 0 1.7rem 1.1rem;padding-left:1rem}.prose li{color:var(--text-body);margin:.5rem 0;font-size:14px;line-height:1.7}.prose h2{font:600 clamp(1.4rem, 3vw, 1.9rem) var(--display);letter-spacing:-.01em;color:var(--text);margin:2.6rem 0 .8rem}.prose h3{font:600 12px var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--blue);margin:1.8rem 0 8px}.prose code{font-family:var(--mono);color:var(--blue);border:1px solid var(--border);background:#ffffff0d;border-radius:5px;padding:.08rem .3rem;font-size:.9em}.prose pre{border:1px solid var(--border);color:var(--text-body);font-family:var(--mono);background:#ffffff08;border-radius:8px;margin:1.8rem 0;padding:18px 20px;font-size:12.5px;line-height:1.6;overflow-x:auto}.prose pre code{color:inherit;background:0 0;border:0;padding:0}.prose blockquote{border-left:2px solid var(--border-strong);color:var(--text);background:#ffffff05;border-radius:0 8px 8px 0;max-width:680px;margin:2rem 0;padding:18px 22px;font-size:15px;line-height:1.6}.prose blockquote.idea{border-left-color:var(--blue);font:500 clamp(1.1rem, 2.4vw, 1.4rem)/1.4 var(--display);color:var(--text);background:#5aabe60f;padding:22px 26px}.section-label{font:600 11px var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);align-items:center;gap:12px;margin:2.8rem 0 1.1rem;display:flex}.section-label:after{content:"";background:var(--border);flex:1;height:1px}.covered{border-top:1px solid var(--border);margin-top:56px;padding-top:28px}.covered h2{font:600 clamp(1.2rem, 2.6vw, 1.6rem) var(--display);color:var(--text);margin-bottom:16px}.covered ol{color:var(--text-body);margin-left:1.1rem}.covered li{margin:.5rem 0;font-size:14px}.devlog-list{margin-top:8px;list-style:none}.devlog-link{border-top:1px solid var(--border);border-radius:8px;grid-template-columns:52px 1fr auto;align-items:center;gap:0 20px;padding:17px 12px;transition:background .16s;display:grid}.devlog-link:hover{background:#ffffff08}.devlog-num{font:700 16px var(--display);color:var(--text-dim)}.devlog-title-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.devlog-title{font:600 15px var(--sans);color:var(--text);transition:color .16s}.devlog-project{font:600 9.5px var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);border:1px solid var(--border-strong);border-radius:4px;padding:2px 6px;line-height:1.4}.devlog-empty{border:1px dashed var(--border-strong);text-align:center;border-radius:12px;margin-top:8px;padding:40px 28px}.devlog-empty-title{font:600 clamp(1.1rem, 2.4vw, 1.4rem) var(--display);color:var(--text);margin-bottom:8px}.devlog-empty-sub{font:400 14px var(--sans);color:var(--text-muted);max-width:420px;margin:0 auto;line-height:1.6}.devlog-sub{font:400 13px var(--sans);color:var(--text-muted);margin-top:5px;line-height:1.5;display:block}.devlog-chevron{font:600 15px var(--sans);color:var(--teal);align-self:center;transition:transform .2s}.devlog-link:hover .devlog-chevron{transform:translate(3px)}.post-nav{grid-template-columns:1fr 1fr;gap:16px;margin-top:56px;display:grid}.nav-card{border:1px solid var(--border-strong);border-radius:12px;padding:20px;transition:border-color .18s,transform .18s}.nav-card:hover{border-color:#5aabe659;transform:translateY(-2px)}.nav-card span{font:600 10px var(--mono);color:var(--text-muted);letter-spacing:.14em;text-transform:uppercase;margin-bottom:8px;display:block}.nav-card strong{color:var(--text);font:600 15px var(--display)}.project-archive-header{margin-bottom:8px}.project-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:24px;display:grid}.project-grid.compact{margin-top:0}.project-card{border:1px solid var(--border-strong);background:0 0;border-radius:12px;min-height:100%;padding:26px;transition:border-color .18s,transform .18s;position:relative}.project-card.featured{background:#5aabe60a;border-color:#5aabe638;grid-column:1/-1}.project-card:hover{border-color:#5aabe659;transform:translateY(-2px)}.card-cover-link{z-index:1;color:inherit;border:0;position:absolute;inset:0}.card-cover-link:focus-visible{outline-offset:3px;outline:1px solid #5aabe68c}.project-card:focus-within{border-color:#5aabe647}.card-topline{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.status-pill,.featured-mark{width:fit-content;font:600 10px var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);border:1px solid var(--border-strong);border-radius:5px;align-items:center;padding:4px 8px;line-height:1;display:inline-flex}.featured-mark{color:var(--blue);border-color:#5aabe64d}.project-card h2{font:600 clamp(1.4rem, 3vw, 1.7rem) var(--display);color:var(--text);margin-bottom:10px;line-height:1.1}.project-card p{color:var(--text-body);font-size:14px;line-height:1.65}.project-subtitle{margin-bottom:10px;color:var(--text-muted)!important}.stack-list{flex-wrap:wrap;gap:6px;margin:18px 0 0;list-style:none;display:flex}.stack-list li{font:500 10.5px var(--mono);color:var(--text-muted);border:1px solid var(--border-strong);border-radius:5px;padding:3px 8px;line-height:1.2}.card-actions,.section-actions,.link-row,.project-meta-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.card-actions{margin-top:20px}.card-actions,.card-actions a{z-index:2;position:relative}.section-actions{margin-top:24px}.cta-link{min-height:36px;font:600 12.5px var(--sans);color:var(--bg);background:var(--blue);border:1px solid var(--blue);border-radius:8px;align-items:center;padding:8px 16px;transition:background .16s,border-color .16s,transform .16s,color .16s;display:inline-flex}.cta-link:hover{background:var(--blue-hover);border-color:var(--blue-hover);color:var(--bg);transform:translateY(-1px)}.cta-link.muted{color:var(--text);border-color:var(--border-strong);background:0 0}.cta-link.muted:hover{color:var(--text);background:#ffffff0a;border-color:#fff6}.project-hero{border-bottom:1px solid var(--border);padding:40px 0 32px;animation:.7s both fadeUp}.project-meta-row{margin-top:22px}.hero-stack{margin-top:20px}.project-page{animation:.7s 80ms both fadeUp}.project-copy{padding-top:20px}.project-copy h2{font:600 clamp(1.35rem, 3vw, 1.8rem) var(--display);color:var(--text);letter-spacing:-.01em;margin:2.4rem 0 .8rem}.project-panel{margin-top:44px}.highlight-list{gap:10px;list-style:none;display:grid}.highlight-list li{color:var(--text-body);border-left:2px solid var(--border-strong);background:#ffffff05;border-radius:0 8px 8px 0;padding:12px 14px;font-size:14px;line-height:1.6}.flow-diagram{gap:8px;max-width:560px;margin:2rem 0;display:grid}.flow-diagram span{color:var(--text-body);background:#5aabe60f;border:1px solid #5aabe638;border-radius:8px;padding:11px 13px;font-size:12.5px;line-height:1.4;display:block;position:relative}.flow-diagram span:not(:last-child):after{content:"↓";color:var(--blue);margin-top:9px;font-size:12px;line-height:1;display:block}.case-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:2rem 0;display:grid}.case-grid article{border:1px solid var(--border-strong);border-radius:12px;padding:18px;transition:border-color .18s}.case-grid article:hover{border-color:#5aabe647}.case-grid h3{font:600 12px var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--blue);margin:0 0 8px}.case-grid article p{color:var(--text-body);margin:0;font-size:13.5px;line-height:1.65}.journal-links{gap:10px;margin:2rem 0;display:grid}.journal-links a{border:1px solid var(--border-strong);border-radius:10px;grid-template-columns:52px 1fr;align-items:baseline;gap:12px;padding:13px 15px;display:grid}.journal-links a:hover{background:#5aabe60a;border-color:#5aabe659}.journal-links strong{color:var(--blue);font:600 12px var(--mono);letter-spacing:.08em}.journal-links span{color:var(--text-body);font-size:13px;line-height:1.55}.proof-list{flex-wrap:wrap;gap:8px;margin:2rem 0;display:flex}.proof-list span{color:var(--blue);font:500 11px var(--mono);letter-spacing:.04em;background:#5aabe60f;border:1px solid #5aabe640;border-radius:6px;padding:7px 10px}.architecture-card{background:#5aabe60a;border:1px solid #5aabe633;border-radius:12px;gap:8px;margin-top:18px;padding:16px;display:grid}.architecture-card span{border:1px solid var(--border-strong);color:var(--text-body);background:#ffffff05;border-radius:8px;padding:10px 12px;font-size:12.5px;line-height:1.45;display:block;position:relative}.architecture-card span:not(:last-child):after{content:"→";color:var(--blue);margin-top:9px;font-size:11px;line-height:1;display:block}.media-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:18px;display:grid}.media-card{border:1px solid var(--border-strong);border-radius:12px;overflow:hidden}.media-card.available{border-color:#5aabe638}.media-frame{aspect-ratio:16/9;border-bottom:1px solid var(--border);background:repeating-linear-gradient(45deg,#5aabe614 0 12px,#5aabe605 12px 24px);justify-content:center;align-items:center;display:flex}.media-frame img{object-fit:cover;width:100%;height:100%;display:block}.media-placeholder{align-content:center;place-items:center;gap:8px;width:100%;height:100%;min-height:154px;padding:18px;display:grid}.media-placeholder span{color:var(--text-dim);font:500 10px var(--mono);letter-spacing:.14em;text-transform:uppercase}.media-placeholder strong{color:var(--text-muted);font:600 1.1rem var(--display);text-align:center;line-height:1.2}.media-copy{padding:14px 16px}.media-topline{justify-content:space-between;align-items:start;gap:12px;margin-bottom:8px;display:flex}.media-topline h3{color:var(--blue);font:600 12px var(--mono);letter-spacing:.08em;text-transform:uppercase;margin:0;line-height:1.35}.media-copy p{color:var(--text-body);font-size:13px;line-height:1.6}.proof-status{border:1px solid var(--border-strong);color:var(--text-muted);font:500 9.5px var(--mono);letter-spacing:.1em;text-transform:uppercase;border-radius:5px;flex:none;padding:4px 7px;line-height:1}.proof-status.available{color:var(--blue);background:#5aabe60f;border-color:#5aabe64d}.proof-demo-links{margin-top:18px}.proof-note-list{gap:10px;margin-top:18px;list-style:none;display:grid}.proof-note-list li{color:var(--text-body);background:#ffffff05;border-left:2px solid #5aabe640;border-radius:0 8px 8px 0;padding:12px 14px;font-size:14px;line-height:1.6}.profile-page section{margin-top:44px}.resume-list{gap:10px;margin:1.1rem 0 0;padding:0;list-style:none;display:grid}.resume-list li{border-left:2px solid var(--border-strong);color:var(--text-body);background:#ffffff05;border-radius:0 8px 8px 0;margin:0;padding:12px 14px;font-size:14px;line-height:1.6}.contact-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:1.5rem 0 0;display:grid}.contact-card{border:1px solid var(--border-strong);border-radius:12px;padding:20px;transition:border-color .18s,transform .18s;display:block}.contact-card:hover{border-color:#5aabe659;transform:translateY(-2px)}.contact-card span{color:var(--text-muted);font:600 10px var(--mono);letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px;display:block}.contact-card strong{color:var(--text);font:600 20px var(--display);line-height:1.15;display:block}.contact-card p{color:var(--text-body);margin:10px 0 0;font-size:13px;line-height:1.6}@keyframes fadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@media (width<=820px){.site-nav-inner{padding:14px 20px}.site-footer-inner{padding:26px 20px}.project-grid,.case-grid,.media-grid,.contact-grid{grid-template-columns:1fr}.project-card.featured{grid-column:auto}.post-nav{grid-template-columns:1fr}.journal-links a{grid-template-columns:1fr;gap:4px}}@media (width<=620px){.site-nav-link{display:none}}@media (width<=560px){.wrap{padding:0 20px}.devlog-link{grid-template-columns:40px 1fr auto;gap:0 12px}.site-footer-inner{flex-direction:column;align-items:flex-start}.prose p{font-size:14px}}
