@import url(https://fonts.googleapis.com/css2?family=Afacad+Flux:wght@100..1000&display=swap);@import url(https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&display=swap);body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}html{overflow-y:scroll}body{background-color:#f0f0f0;font-family:"DM Serif Display",serif;margin:0;padding:0}p{font-family:Afacad Flux,sans-serif}button{font-family:"DM Serif Display",serif}.app-container{flex-direction:column;text-align:center}.app-container,.navbar{align-items:center;display:flex}.navbar{background-color:#333;justify-content:center;max-width:100%;padding:20px 0;position:relative;width:1200px}.logo-link{color:inherit;text-decoration:none}.logo,.logo-link{align-items:center;display:flex}.logo{color:#fff;font-size:1.5rem;font-weight:300;left:20px;position:absolute}.logo-icon{display:none;height:24px;margin-right:8px;width:24px}.navbar ul{display:flex;list-style-type:none;margin:0;padding:0}.navbar li{font-size:1.2rem;margin:0 15px}.navbar a{color:#fff;text-decoration:none}.navbar a:hover{color:#ddd}@media (max-width:800px){.logo-text{display:none}.logo-icon{display:block}}.landing-page{align-items:center;background-color:#fff;display:flex;flex-direction:column;height:100vh;justify-content:center;padding:0 20px;text-align:center;width:100%}.intro h1{color:#333;font-size:3rem;margin-bottom:.5em}.intro p{color:#666;font-size:1.5rem;margin-bottom:1.5em}.social-links{display:flex;gap:20px;margin-top:20px}.social-icon{color:#333;font-size:2rem;transition:color .3s ease}.social-icon:hover{color:#0077b5}.project-page{background-color:#fff;box-sizing:border-box;color:#333;padding:40px;width:100%}.project-page h2{font-size:2rem;margin-bottom:20px;text-align:center}.experience-container{margin:0 auto;max-width:800px}.row.experience{align-items:flex-start;display:flex;margin-bottom:20px}.timeline-col{width:150px}.timeline-col,.timeline-marker{align-items:center;display:flex;flex-direction:column;position:relative}.timeline-date{color:#325ea8;font-size:.9rem;font-weight:700;margin-bottom:4px}.timeline-dot{background-color:#325ea8;border-radius:50%;display:inline-block;height:10px;margin-bottom:4px;position:relative;width:10px;z-index:1}.experience-details{flex:1 1;padding-left:10px}.card{background-color:#f8f9fa;border:1px solid #ddd;border-radius:4px;box-shadow:none}.card-body{padding:15px}.exp-title{font-size:1.2rem;margin-bottom:5px}.exp-company{font-size:1rem;margin-bottom:5px}.exp-company a{color:#325ea8;text-decoration:none}.exp-meta{color:#777;font-size:.9rem;margin-bottom:10px}.middot-divider{margin:0 5px}@media (max-width:576px){.row.experience{flex-direction:column}.timeline-col{display:none}.experience-details{padding-left:0;width:100%}.card{width:100%}}.blog-page,.blog-post{align-items:center;display:flex;flex-direction:column;justify-content:start;max-width:800px;padding:0 10%;width:80%}.blog-page h2{font-size:2rem;margin-bottom:20px}.landing-page h1{color:#333;font-size:2.5rem}.landing-page p{color:#666;font-size:1.2rem;margin:20px 0}.cta-button{background-color:#333;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1.2rem;margin:20px 5px;padding:10px 20px;transition:background-color .5s ease,opacity .5s ease;width:200px}.cta-button:hover{opacity:.8}.blog-categories-wrapper{display:flex;justify-content:space-evenly;max-height:10%;max-width:800px;width:100%}.blog-preview-container{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin:20px auto;max-height:80%;max-width:1200px}.blog-preview-link{color:inherit;text-decoration:none}.blog-preview-card{background-color:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;min-height:200px;padding:20px;text-align:left;transition:transform .3s ease;width:300px}.blog-preview-card h2{-webkit-hyphens:auto;hyphens:auto;word-break:break-word}.blog-preview-card span{margin-top:auto}@media (max-width:800px){.blog-preview-card{width:inherit}.blog-preview-container{flex-direction:column}}.blog-preview-card h2{color:#333;font-size:1.8rem;margin-bottom:10px}.blog-preview-card p{color:#666;font-size:1rem;margin-bottom:10px}.blog-preview-card span{color:#888;font-size:.9rem}.blog-preview-card:hover{transform:translateY(-5px)}.blog-post h1{color:#333;font-size:2.5rem;margin-bottom:20px}.blog-post p{color:#666;font-size:1.2rem;line-height:1.6;margin-bottom:20px}.blog-post img{border-radius:8px;display:block;margin:20px auto;max-width:100%}.blog-post h2,.blog-post h3,.blog-post h4{color:#333;margin:20px 0 10px}.blog-post ol,.blog-post ul{margin-bottom:20px;margin-left:20px}.blog-post blockquote{border-left:4px solid #ddd;color:#555;font-style:italic;margin:20px 0;padding-left:16px}.pagination{align-items:center;display:flex;gap:10px;justify-content:center;margin:20px 0;max-height:10%}.pagination button{background-color:#333;border:none;border-radius:5px;color:#fff;cursor:pointer;padding:8px 12px;transition:background-color .3s ease}.pagination button:hover:not(:disabled){background-color:#555}.pagination button:disabled{cursor:not-allowed;opacity:.5}.pagination-button.active{background-color:#325ea8}.code-block-wrapper{margin:20px 0;position:relative}.copy-button{background-color:#325ea8;border:none;border-radius:4px;color:#fff;cursor:pointer;font-family:Afacad Flux,sans-serif;font-size:.8rem;opacity:.8;padding:5px 10px;position:absolute;right:10px;top:10px;transition:opacity .3s ease;z-index:2}.copy-button:hover{opacity:1}pre{border-radius:4px;max-width:90%;overflow:auto}.contact-page{background-color:#fff;color:#333;padding:40px;text-align:left;width:100%}.contact-page h2{font-size:2rem;margin-bottom:20px}.contact-form{display:flex;flex-direction:column}.contact-form label{margin:10px 0 5px}.contact-form input,.contact-form textarea{border:1px solid #ddd;border-radius:4px;font-size:1rem;margin-bottom:15px;padding:10px}.contact-form button{background-color:#333;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1.2rem;margin:20px 0;padding:10px 20px;transition:background-color .3s ease}.contact-form button:hover{background-color:#555}html{scroll-behavior:smooth}.main-page{flex-direction:column;height:100vh}.main-page,.section{align-items:center;display:flex;max-width:100%}.section{background-color:#fff;justify-content:center;scroll-snap-align:start;width:1200px}.viz-post{--paper:#faf8f4;--ink:#1a1a1a;--ink-soft:#4a4a4a;--ink-faint:#7a7a7a;--rule:#e4dfd3;--accent-h:218;--accent:hsl(var(--accent-h),48%,44%);--accent-soft:hsl(var(--accent-h),48%,92%);--neg:#c64c39;--serif:"Iowan Old Style","Source Serif Pro",Georgia,"Times New Roman",serif;--sans:-apple-system,BlinkMacSystemFont,"Inter","Segoe UI",Roboto,sans-serif;--mono:"JetBrains Mono","SF Mono",Menlo,Consolas,monospace;background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:17px;line-height:1.7;margin:0 auto;max-width:1200px;min-height:100vh;overflow-x:hidden;padding:48px 24px 96px;width:100%}.viz-post,.viz-post *,.viz-post :after,.viz-post :before{box-sizing:border-box}.viz-post .viz-container{margin:0 auto;max-width:880px}.viz-post .viz-wide{margin:0 auto;max-width:1040px}.viz-post h1,.viz-post h2,.viz-post h3{color:var(--ink);font-family:var(--serif);font-weight:600;line-height:1.25}.viz-post h1{font-size:2.4rem;letter-spacing:-.01em;margin:0 0 12px}.viz-post h2{font-size:1.65rem;letter-spacing:-.005em;margin:56px 0 16px}.viz-post h3{font-size:1.2rem;margin:32px 0 12px}.viz-post p{color:var(--ink);margin:0 0 18px}.viz-post .viz-lede{color:var(--ink-soft);font-size:1.18rem;line-height:1.6;margin:0 0 8px}.viz-post .viz-byline{border-bottom:1px solid var(--rule);color:var(--ink-faint);font-size:.92rem;margin-bottom:36px;padding-bottom:24px}.viz-post .viz-byline a{border-bottom:1px solid #0000;color:var(--accent);text-decoration:none}.viz-post .viz-byline a:hover{border-bottom-color:var(--accent)}.viz-post .viz-series-tag{color:var(--accent);display:inline-block;font-family:var(--sans);font-size:.78rem;font-weight:600;letter-spacing:.12em;margin-bottom:12px;text-transform:uppercase}.viz-post a.viz-link{border-bottom:1px solid var(--accent-soft);color:var(--accent);text-decoration:none}.viz-post a.viz-link:hover{border-bottom-color:var(--accent)}.viz-panel{background:#fff;border:1px solid var(--rule);border-radius:10px;margin:24px 0 28px;max-width:100%;min-width:0;padding:20px}.viz-controls{align-items:center;display:flex;flex-wrap:wrap;font-size:.92rem;gap:12px;margin-bottom:18px}.viz-controls label{align-items:center;color:var(--ink-soft);display:inline-flex;gap:8px}.viz-controls button,.viz-controls select{background:#fff;border:1px solid var(--rule);border-radius:6px;color:var(--ink);cursor:pointer;font-family:var(--sans);font-size:.9rem;padding:6px 12px}.viz-controls button.active{background:var(--accent);border-color:var(--accent);color:#fff}.viz-controls input[type=range]{accent-color:var(--accent)}.viz-mat{display:inline-block;margin:8px 14px 8px 0;vertical-align:top}.viz-mat-label{color:var(--ink-faint);font-family:var(--mono);font-size:.78rem;letter-spacing:.04em;margin-bottom:6px}.viz-mat-grid{grid-gap:2px;background:var(--rule);border-radius:4px;display:grid;gap:2px;padding:2px}.viz-cell{background:#fff;color:var(--ink);cursor:default;font-family:var(--mono);font-size:.72rem;min-width:0;overflow:hidden;padding:4px 6px;text-align:right;transition:background .15s ease,color .15s ease;-webkit-user-select:none;user-select:none}.viz-cell.viz-cell-tappable{cursor:pointer}.viz-cell.viz-col-label,.viz-cell.viz-row-label{background:#0000;color:var(--ink-faint);font-size:.7rem;font-style:italic;text-align:center}.viz-cell.viz-col-hi,.viz-cell.viz-row-hi{outline:2px solid var(--accent);outline-offset:-1px;z-index:1}.viz-cell.viz-focus{background:var(--accent);color:#fff}.viz-cell.viz-trace-x{background:hsl(var(--accent-h),60%,90%)}.viz-cell.viz-trace-w{background:hsl(var(--accent-h),60%,82%)}.viz-cell.viz-heat,.viz-explain{color:var(--ink)}.viz-explain{background:var(--accent-soft);border-radius:6px;font-family:var(--mono);font-size:.85rem;margin-top:14px;overflow-x:auto;padding:10px 14px;white-space:nowrap}.viz-explain-empty{color:var(--ink-faint);font-style:italic}.viz-math-block{font-size:1.05rem;margin:14px 0 18px;overflow-x:auto}.viz-math-inline{font-size:1em}.viz-code{background:#1a1f2c;border-radius:8px;color:#e6e9f0;font-family:var(--mono);font-size:.85rem;line-height:1.55;margin:16px 0 24px;max-width:100%;overflow-x:auto;padding:14px 16px;white-space:pre}.viz-code .viz-code-comment{color:#8290a5}.viz-code .viz-code-kw{color:#d8a0ff}.viz-code .viz-code-str{color:#9bd49b}.viz-matrix-row{align-items:flex-start;display:flex;flex-wrap:nowrap;gap:0;max-width:100%;min-width:0;overflow-x:auto;overflow-y:hidden;padding-bottom:6px}.viz-matrix-row .viz-mat{flex:0 0 auto}.viz-matrix-op{align-self:center;color:var(--ink-soft);font-family:var(--serif);font-size:1.4rem;margin:0 6px;padding-top:16px}.viz-footer{border-top:1px solid var(--rule);color:var(--ink-soft);font-size:.95rem;margin-top:64px;padding-top:24px}.viz-footer strong{color:var(--ink)}.viz-caption{color:var(--ink-faint);font-size:.88rem;font-style:italic;margin-top:10px}.viz-row-meta{color:var(--ink-faint);font-family:var(--mono);font-size:.78rem;margin-top:12px;min-height:1.6em}.viz-row-meta strong{color:var(--ink);font-weight:600}.viz-head-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-top:18px}.viz-head-card{background:#fff;border:1px solid var(--rule);border-radius:8px;padding:12px}.viz-head-title{color:var(--ink-faint);font-family:var(--mono);font-size:.78rem;letter-spacing:.04em;margin-bottom:8px}.viz-head-desc{color:var(--ink-soft);font-size:.85rem;line-height:1.45;margin-top:8px}.viz-toggle{align-items:center;cursor:pointer;display:inline-flex;gap:8px;-webkit-user-select:none;user-select:none}.viz-toggle input{accent-color:var(--accent)}.viz-mix-stage{background:#fbfaf6;border:1px dashed var(--rule);border-radius:8px;margin-top:16px;padding:16px}.viz-mix-row{align-items:center;color:var(--ink-soft);display:flex;font-family:var(--mono);font-size:.78rem;gap:8px;margin:4px 0;opacity:0;transform:translateY(4px);transition:opacity .4s ease,transform .4s ease}.viz-mix-row.viz-mix-active{opacity:1;transform:translateY(0)}.viz-mix-row.viz-mix-output{border-top:1px solid var(--rule);color:var(--ink);font-weight:600;margin-top:8px;padding-top:8px}.viz-mix-weight{font-feature-settings:"tnum";display:inline-block;font-variant-numeric:tabular-nums;min-width:60px}.viz-mix-bar{background:var(--accent);border-radius:3px;height:6px;transition:width .5s ease}.viz-subsection{background:hsl(var(--accent-h),30%,98%);border:1px solid hsl(var(--accent-h),30%,92%);border-radius:10px;margin:0 -8px 20px;padding:14px 16px 18px}.viz-subsection+.viz-subsection{margin-top:10px}.viz-subhead{align-items:center;color:var(--ink);display:flex;flex-wrap:wrap;font-family:var(--serif);font-size:1.05rem;font-weight:600;gap:10px;line-height:1.35;margin:0 0 6px}.viz-subhead em{color:var(--ink-soft);font-style:italic;font-weight:400}.viz-subhead-prose{color:var(--ink-soft);font-size:.94rem;line-height:1.55;margin:0 0 10px}.viz-sub-tag{align-items:center;border-radius:6px;color:#fff;display:inline-flex;flex:0 0 auto;font-family:var(--mono);font-size:.82rem;font-weight:700;height:26px;justify-content:center;width:26px}.viz-sub-tag-q{background:#396dc6}.viz-sub-tag-k{background:#3b9b78}.viz-sub-tag-v{background:#ce803b}.viz-sub-tag-step{background:var(--ink)}.viz-sub-tag-star{background:#f0a919;color:#1a1a1a}.viz-softmax-demo{background:#fff;border:1px solid var(--rule);border-radius:8px;margin:16px 0 24px;padding:14px 16px 18px}.viz-softmax-tabs{background:var(--accent-soft);border-radius:8px;display:inline-flex;gap:2px;margin-bottom:14px;padding:3px}.viz-softmax-row{align-items:center;display:flex;flex-wrap:wrap;gap:18px}.viz-softmax-side{flex:1 1 220px;min-width:220px}.viz-softmax-side-label{color:var(--ink-faint);font-family:var(--mono);font-size:.74rem;letter-spacing:.04em;margin-bottom:8px}.viz-softmax-bar-row{align-items:center;display:flex;gap:10px;margin:6px 0}.viz-softmax-num{font-feature-settings:"tnum";color:var(--ink);font-family:var(--mono);font-size:.84rem;font-variant-numeric:tabular-nums;min-width:56px;text-align:right}.viz-softmax-bar{border-radius:3px;display:inline-block;height:14px;transition:width .4s ease}.viz-softmax-bar-in{background:hsl(var(--accent-h),30%,75%)}.viz-softmax-bar-out{background:var(--accent)}.viz-softmax-arrow{color:var(--ink-soft);font-family:var(--mono);font-size:.95rem;padding:0 6px}.viz-tabs{background:var(--accent-soft);border-radius:8px;display:inline-flex;gap:2px;padding:3px}.viz-tab{background:#0000;border:none;border-radius:6px;color:var(--ink-soft);cursor:pointer;font-family:var(--sans);font-size:.85rem;font-weight:500;letter-spacing:.02em;padding:5px 12px;text-transform:lowercase}.viz-tab.active{background:var(--accent);color:#fff}.viz-token-source{color:var(--ink-soft);font-family:var(--serif);font-size:1.1rem;font-style:italic;margin:8px 0 14px}.viz-token-row{display:flex;flex-wrap:wrap;gap:6px;padding:6px 0}.viz-token-pill{align-items:center;background:hsl(var(--accent-h),45%,94%);border:1px solid hsl(var(--accent-h),35%,85%);border-radius:8px;display:inline-flex;flex-direction:column;min-width:32px;padding:6px 10px}.viz-token-text{color:var(--ink);font-family:var(--mono);font-size:.88rem;white-space:pre}.viz-token-id{color:var(--ink-faint);font-family:var(--mono);font-size:.66rem;margin-top:2px}.viz-token-pill-button{cursor:pointer;font-family:inherit;transition:transform .1s ease,background .15s ease}.viz-token-pill-button:hover{transform:translateY(-1px)}.viz-token-pill-active{background:var(--accent);border-color:var(--accent)}.viz-token-pill-active .viz-token-id,.viz-token-pill-active .viz-token-text{color:#fff}.viz-arch-stage{background:#fbfaf6;border:1px dashed var(--rule);border-radius:8px;padding:18px 16px}.viz-arch-label{color:var(--ink-faint);font-family:var(--mono);font-size:.78rem;letter-spacing:.04em;margin-bottom:8px}.viz-arch-row{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.viz-arch-node{background:#fff;border:1px solid var(--rule);border-radius:8px;color:var(--ink);cursor:pointer;font-family:var(--mono);font-size:.85rem;height:44px;transition:background .2s ease,color .2s ease,transform .1s ease;width:56px}.viz-arch-node:hover{transform:translateY(-1px)}.viz-arch-focus{outline:2px solid var(--accent);outline-offset:2px}.viz-arch-step{align-items:center;background:hsl(var(--accent-h),35%,92%);border:1px solid var(--rule);border-radius:18px;color:var(--ink);display:inline-flex;font-family:var(--mono);font-size:.82rem;height:36px;justify-content:center;width:36px}.viz-arch-arrow{font-family:var(--mono);font-size:1rem;font-weight:700}.viz-arch-arrow-on{color:var(--accent)}.viz-arch-arrow-off{color:var(--rule)}.viz-arch-clock{color:var(--ink-soft);font-size:.92rem;margin-top:12px}.viz-arch-clock strong{color:var(--accent);font-family:var(--mono)}@media (max-width:720px){.viz-post{font-size:16px;padding:28px 14px 64px}.viz-post h1{font-size:1.8rem}.viz-post h2{font-size:1.35rem}.viz-cell{font-size:.66rem;min-width:32px;padding:3px 4px}.viz-matrix-op{font-size:1.1rem;padding-top:12px}.viz-panel{padding:14px}}
/*# sourceMappingURL=main.a3a34049.css.map*/