*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #080b12;--border: #1a2035;--text: #e4eaf8;--text-muted: #4a5470}html{scroll-behavior:smooth}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative;z-index:0}.stars-canvas{position:fixed;inset:0;pointer-events:none;z-index:-1}.rocket{position:fixed;pointer-events:none;z-index:50;line-height:0;-webkit-user-select:none;user-select:none;filter:drop-shadow(0 0 8px rgba(167,139,250,.5));transition:opacity .15s ease}#root{display:block}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border)}.c-violet{color:#a78bfa}.c-blue{color:#5b9cf6}.c-teal{color:#4ecdc4}.c-slate{color:#8896b8}.u-line{position:relative;display:inline-block}.u-line:after{content:"";position:absolute;bottom:-1px;left:0;width:100%;height:1px;background:linear-gradient(90deg,#a78bfa,#5b9cf6,#4ecdc4);transform:scaleX(0);transform-origin:left;transition:transform .5s cubic-bezier(.16,1,.3,1)}.u-line:hover:after{transform:scaleX(1)}.u-reveal:after{transition-delay:var(--d, .25s)}.u-reveal.revealed:after{transform:scaleX(1)}@keyframes fadeUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.route-wrapper{animation:fadeIn .35s ease both}[data-reveal]{opacity:0;transform:translateY(20px);transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1);transition-delay:calc(var(--i, 0) * 80ms)}[data-reveal].revealed{opacity:1;transform:none}.nav-desktop{position:fixed;top:0;left:0;bottom:0;width:160px;z-index:100;border-right:1px solid var(--border);display:flex;flex-direction:column;align-items:center;padding:36px 0;transition:transform .35s cubic-bezier(.16,1,.3,1)}.nav-desktop.nav-collapsed{transform:translate(-180px)}.nav-logo{font-size:14px;font-weight:700;letter-spacing:-.03em}.nav-logo-toggle{background:none;border:none;cursor:pointer;padding:0;position:relative;display:flex;align-items:center;justify-content:center}.nav-logo-text{font-size:14px;font-weight:700;letter-spacing:-.03em;color:var(--text);transition:opacity .2s}.nav-logo-arrow{position:absolute;font-size:22px;font-weight:300;color:var(--text);opacity:0;transform:scaleX(1);transition:opacity .2s;line-height:1;margin-top:-2px}nav.nav-collapsed .nav-logo-arrow{transform:scaleX(-1)}.nav-logo-toggle:hover .nav-logo-text{opacity:0}.nav-logo-toggle:hover .nav-logo-arrow{opacity:1}.nav-ghost-toggle{position:fixed;top:0;left:0;bottom:0;width:48px;z-index:101;background:none;border:none;border-right:1px solid var(--border);cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center}.nav-ghost-toggle:after{content:"›";font-size:18px;font-weight:300;color:var(--text-muted);transition:color .15s,transform .2s}.nav-ghost-toggle:hover:after{color:var(--text);transform:translate(2px)}.nav-links{display:flex;flex-direction:column;align-items:center;gap:24px;margin-top:auto}.nav-links a{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);transition:color .15s}.nav-link{position:relative}.nav-link:after{content:"";position:absolute;bottom:-2px;left:0;width:100%;height:1px;background:linear-gradient(90deg,#a78bfa,#5b9cf6);transform:scaleX(0);transform-origin:left;transition:transform .3s cubic-bezier(.16,1,.3,1)}.nav-link:hover:after,.nav-active:after{transform:scaleX(1)}.nav-links a:hover{color:var(--text)}main,footer,.page{margin-left:180px;transition:margin-left .35s cubic-bezier(.16,1,.3,1)}body.nav-collapsed main,body.nav-collapsed footer,body.nav-collapsed .page{margin-left:48px}.hero{min-height:100vh;padding:64px 64px 48px;display:flex;flex-direction:column}.hero-top{flex-shrink:0;animation:fadeUp .55s .05s cubic-bezier(.16,1,.3,1) both}.hero-header{display:flex;justify-content:space-between;align-items:center;font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding-bottom:20px}.hero-rule{height:1px;background:var(--border)}.hero-headline{flex:1;font-size:clamp(64px,10.5vw,148px);font-weight:800;letter-spacing:-.045em;line-height:.93;padding:48px 0;display:flex;flex-direction:column;justify-content:center}.hero-line-wrap{display:block}.hero-char{opacity:.15;transition:opacity .2s ease}.hero-char.char-typed{opacity:1}.hero-line-accent .hero-char{color:#a78bfa;opacity:.12}.hero-line-accent .hero-char.char-typed{color:#a78bfa;opacity:1}.hero-line-accent .hero-cursor{background:#a78bfa}.hero-cursor{display:inline-block;width:.055em;height:.8em;background:var(--text);vertical-align:baseline;margin:0 .03em;animation:blink 1s step-end infinite}.hero-bottom{flex-shrink:0;animation:fadeUp .55s .35s cubic-bezier(.16,1,.3,1) both}.hero-footer{display:flex;justify-content:space-between;align-items:center;padding-top:20px;font-size:12px;color:var(--text-muted);letter-spacing:.02em}.hero-cta{font-size:13px;font-weight:600;color:var(--text);transition:opacity .15s}.hero-cta:hover{opacity:.5}.work-section{padding:64px 48px;border-top:1px solid var(--border)}.about-section,.others-section{padding:96px 48px;border-top:1px solid var(--border)}.section-label{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:40px}.project-list{display:flex;flex-direction:column}.project-row{display:grid;grid-template-columns:44px minmax(0,1fr) auto auto 20px;align-items:center;gap:24px;padding:24px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:opacity .15s}.project-row:first-child{border-top:1px solid var(--border)}.project-row:hover .project-num,.project-row:hover .project-meta{opacity:.3}.project-row:hover .project-arrow{transform:translate(5px);color:var(--text)}.project-num{font-size:11px;color:var(--text-muted);font-variant-numeric:tabular-nums;letter-spacing:.04em;transition:opacity .2s}.project-title{font-size:17px;font-weight:600;letter-spacing:-.025em;position:relative;display:inline-block;min-width:0;overflow-wrap:anywhere}.project-title:after{content:"";position:absolute;bottom:-1px;left:0;width:100%;height:1px;background:linear-gradient(90deg,#a78bfa,#5b9cf6);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.16,1,.3,1)}.project-row:hover .project-title:after{transform:scaleX(1)}.project-meta{font-size:12px;color:var(--text-muted);letter-spacing:.02em;transition:opacity .2s}.project-arrow{font-size:13px;color:var(--text-muted);transition:transform .25s cubic-bezier(.16,1,.3,1),color .2s;justify-self:end}.dtree{display:grid;grid-template-columns:auto auto auto;column-gap:clamp(48px,6vw,96px);grid-template-rows:repeat(6,56px);align-items:center;justify-content:start;position:relative;padding:16px 0 32px;overflow:visible;flex-shrink:0}.dtree-svg{position:absolute;top:0;left:0;pointer-events:none;z-index:0;overflow:visible}.dtree-root{font-size:13px;font-weight:600;color:var(--text);letter-spacing:-.01em;line-height:1.55;position:relative;z-index:1;background:var(--bg);padding-right:8px}.dtree-node{background:var(--bg);border:none;padding:0 6px;font-family:inherit;cursor:pointer;text-align:left;position:relative;z-index:1;transition:opacity .3s ease;display:flex;align-items:center}.dtree-node:disabled{cursor:default}.dtree-branch{font-size:15px;font-weight:600;letter-spacing:-.02em;color:var(--text)}.dtree-branch.is-active{color:var(--text)}.dtree-leaf{font-size:13px;font-weight:500;color:var(--text-muted);white-space:nowrap}.dtree-leaf.is-active,.dtree-leaf:not(:disabled):hover{color:var(--text)}.dtree-wrapper{display:flex;gap:80px;align-items:flex-start}.dtree-results{flex:1;min-width:0;padding-top:16px;opacity:0;pointer-events:none;transform:translateY(12px);transition:opacity .45s cubic-bezier(.16,1,.3,1),transform .45s cubic-bezier(.16,1,.3,1)}.dtree-results.is-visible{opacity:1;pointer-events:auto;transform:none}.dtree-results-label{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:8px}.dtree-reset{display:inline-block;margin-top:28px;background:none;border:none;font-family:inherit;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);cursor:pointer;padding:0;transition:color .15s}.dtree-reset:hover{color:var(--text)}.work-preview{position:fixed;top:0;left:0;width:380px;aspect-ratio:16 / 10;pointer-events:none;z-index:200;opacity:0;transition:opacity .2s ease;will-change:transform}.work-preview.is-visible{opacity:1}.work-preview-img{width:100%;height:100%;border:1px solid var(--border)}.about-ticker{overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-top:56px;margin-bottom:48px;mask-image:linear-gradient(90deg,transparent,black 8%,black 92%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,black 8%,black 92%,transparent)}.about-ticker-track{display:flex;gap:0;width:max-content;animation:ticker-scroll 22s linear infinite}.about-ticker-item{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);padding:14px 32px;border-right:1px solid var(--border);white-space:nowrap;flex-shrink:0}@keyframes ticker-scroll{0%{transform:translate(0)}to{transform:translate(calc(-100% / 3))}}.about-grid{display:grid;grid-template-columns:320px 1fr;gap:64px;align-items:stretch}.about-photo{height:100%;overflow:hidden;border:1px solid var(--border)}.about-photo img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(20%)}.about-photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--border);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);min-height:320px}.stat-label{font-size:11px;color:var(--text-muted);margin-top:5px;text-transform:uppercase;letter-spacing:.07em}.about-content p{font-size:15px;color:var(--text-muted);line-height:1.8;margin-bottom:40px}.exp-subsection{margin-top:28px}.about-grid .about-content .exp-subsection:first-child{margin-top:0}.exp-subsection-label{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:4px}.exp-company-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.experience-list{display:flex;flex-direction:column;border-top:1px solid var(--border)}.exp-row{display:flex;justify-content:space-between;align-items:flex-start;padding:18px 0;border-bottom:1px solid var(--border)}.exp-company{display:inline-block;font-size:13px;font-weight:600;letter-spacing:-.01em}.exp-role{display:block;font-size:12px;color:var(--text-muted);margin-top:3px}.exp-period{font-size:11px;color:var(--text-muted);white-space:nowrap;padding-top:1px;letter-spacing:.02em}.exp-tag{display:inline-flex;align-items:center;justify-content:center;padding:2px 8px;border-radius:999px;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;border:1px solid color-mix(in srgb,var(--border) 65%,transparent);color:var(--text-muted);background:color-mix(in srgb,var(--bg) 82%,var(--border) 18%)}.exp-tag-current{color:#4ecdc4;border-color:color-mix(in srgb,#4ecdc4 55%,var(--border));background:color-mix(in srgb,#4ecdc4 14%,var(--bg))}.exp-tag-incoming{color:#a78bfa;border-color:color-mix(in srgb,#a78bfa 55%,var(--border));background:color-mix(in srgb,#a78bfa 14%,var(--bg))}.exp-details{display:block;font-size:12px;color:var(--text-muted);line-height:1.65;margin-top:6px;max-width:520px;max-height:0;overflow:hidden;opacity:0;transition:max-height .35s cubic-bezier(.16,1,.3,1),opacity .3s ease,margin-top .35s cubic-bezier(.16,1,.3,1)}.exp-row-hoverable{cursor:default;transition:background .15s}.exp-row-hoverable:hover .exp-details{max-height:80px;opacity:1}.exp-row-hoverable:hover .exp-company{color:var(--text)}.wg-note{font-size:13px;color:var(--text-muted);line-height:1.7;max-width:560px;margin-bottom:32px}.wg-note-link{color:var(--text-muted);border-bottom:1px solid var(--border);transition:color .15s,border-color .15s}.wg-note-link:hover{color:var(--text);border-color:var(--text-muted)}.wg-layout{display:flex;gap:48px;align-items:flex-start}.wg-graph-col{flex:.9;min-width:0}.wg-results-col{width:380px;flex-shrink:0;padding-top:4px}@media(max-width:900px){.wg-layout{flex-direction:column;gap:32px}.wg-results-col{width:100%}}.wg-hint{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:20px;display:flex;align-items:center;gap:16px}.wg-clear{background:none;border:none;font-family:inherit;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);cursor:pointer;padding:0;transition:color .15s;text-decoration:underline;text-underline-offset:3px}.wg-clear:hover{color:var(--text)}.wg-presets{display:flex;flex-direction:column;gap:2px;margin-top:20px;margin-bottom:4px}.wg-preset{display:flex;align-items:center;gap:10px;background:none;border:none;font-family:inherit;font-size:12px;font-weight:500;color:var(--text-muted);cursor:pointer;padding:9px 12px;text-align:left;border-radius:2px;transition:color .15s,background .15s;letter-spacing:.01em}.wg-preset:hover{color:var(--text);background:#ffffff0a}.wg-preset.is-active{color:var(--text);background:#ffffff0f}.wg-preset-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.wg-results{margin-top:28px;padding-top:24px;border-top:1px solid var(--border);animation:fadeUp .45s cubic-bezier(.16,1,.3,1) both}.skills-section{padding:96px 48px}.skills-canvas{display:block;width:100%;border:1px solid var(--border);margin-top:32px}.skills-legend{display:flex;gap:28px;margin-top:20px}.skills-legend-item{display:flex;align-items:center;gap:7px;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.skills-legend-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.me-section{padding:96px 48px;border-top:1px solid var(--border)}.me-block-label{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:20px}.me-top-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-bottom:64px}.me-right-col{display:flex;flex-direction:column;gap:28px}.me-currents-list{display:flex;flex-direction:column;gap:0}.me-current-row{display:grid;grid-template-columns:80px 1fr;gap:20px;padding:14px 0;border-bottom:1px solid var(--border);align-items:baseline}.me-current-row:first-child{border-top:1px solid var(--border)}.me-current-key{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);white-space:nowrap}.me-current-val{font-size:13px;color:var(--text);line-height:1.55}.me-spotify-block{display:flex;flex-direction:column}.me-spotify-card{display:flex;gap:20px;align-items:center;padding:20px;border:1px solid var(--border);color:inherit;text-decoration:none;transition:border-color .2s}.me-spotify-card:hover{border-color:var(--text-muted)}.me-spotify-art{width:80px;height:80px;flex-shrink:0;overflow:hidden;background:var(--border)}.me-spotify-art img{width:100%;height:100%;object-fit:cover;display:block}.me-spotify-art-empty{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);opacity:.3}.me-spotify-art-empty svg{width:32px;height:32px}.me-spotify-meta{display:flex;flex-direction:column;gap:5px;min-width:0}.me-spotify-title{font-size:14px;font-weight:600;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.me-spotify-offline{font-weight:500;color:var(--text-muted)}.me-spotify-artist{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.me-spotify-bars{display:flex;align-items:flex-end;gap:2px;height:14px;margin-top:6px}.me-spotify-bars span{display:block;width:2px;background:#1db954;border-radius:1px;animation-duration:1s;animation-iteration-count:infinite;animation-timing-function:ease-in-out}.me-spotify-bars span:nth-child(1){animation-name:bar1;height:5px}.me-spotify-bars span:nth-child(2){animation-name:bar2;height:10px}.me-spotify-bars span:nth-child(3){animation-name:bar3;height:7px}.me-spotify-bars span:nth-child(4){animation-name:bar1;height:4px;animation-delay:.3s}.me-playlists{margin-bottom:64px}.me-playlist-grid{display:flex;flex-direction:column;border:1px solid var(--border)}.me-playlist-item{display:flex;align-items:center;gap:16px;padding:20px 24px;background:var(--bg);color:inherit;text-decoration:none;transition:background .15s}.me-playlist-item:hover{background:var(--border)}.me-playlist-icon{width:16px;height:16px;flex-shrink:0;color:#1db954;opacity:.7}.me-playlist-icon svg{width:100%;height:100%}.me-playlist-info{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0}.me-playlist-name{font-size:13px;font-weight:600;letter-spacing:-.01em}.me-playlist-mood{font-size:11px;color:var(--text-muted);letter-spacing:.02em}.me-playlist-arrow{font-size:12px;color:var(--text-muted);transition:transform .2s,color .15s}.me-playlist-item:hover .me-playlist-arrow{transform:translate(4px);color:var(--text)}.me-bio-rest-scroll{height:200vh;position:relative}.me-bio-rest-sticky{position:sticky;top:0;padding-top:8px}.me-bio{width:100%;max-width:none;display:flex;flex-direction:column;gap:16px;margin-bottom:64px}.me-bio-p,.me-bio p{font-size:15px;color:var(--text-muted);line-height:1.85}.me-bio-markdown h1,.me-bio-markdown h2,.me-bio-markdown h3,.me-bio-markdown h4,.me-bio-markdown h5,.me-bio-markdown h6,.post-markdown h1,.post-markdown h2,.post-markdown h3,.post-markdown h4,.post-markdown h5,.post-markdown h6{margin-top:1.6em;margin-bottom:.7em;line-height:1.2;color:var(--text)}.me-bio-markdown>h1:first-child,.me-bio-markdown>h2:first-child,.me-bio-markdown>h3:first-child,.post-markdown>h1:first-child,.post-markdown>h2:first-child,.post-markdown>h3:first-child{margin-top:0}.me-bio p+p{margin-top:20px}.me-bio a{color:var(--text);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}.me-bio hr{border:none;border-top:1px solid var(--text-muted);margin:20px 0}.me-bio blockquote{border-left:2px solid var(--border);margin:16px 0;padding:8px 16px;color:var(--text-muted);font-style:italic}.me-bio blockquote p:last-child{margin-bottom:0}.me-bio code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.9em;background:color-mix(in srgb,var(--bg) 70%,var(--border) 30%);padding:.15em .35em;border-radius:3px}.me-bio pre{margin:20px 0;padding:14px 16px;background:color-mix(in srgb,var(--bg) 70%,var(--border) 30%);border:1px solid var(--border);border-radius:4px;overflow-x:auto}.me-bio pre code{background:none;padding:0;font-size:.9em}.markdown-list{margin:18px 0;padding-left:1.4rem;max-width:60ch;font-size:15px;color:var(--text-muted)}.markdown-list-unordered{list-style:none}.markdown-list-ordered{list-style:decimal}.markdown-list-item{position:relative;line-height:1.85;padding-left:.3rem}.markdown-list-item+.markdown-list-item{margin-top:6px}.markdown-list-unordered>.markdown-list-item:before{content:"";position:absolute;left:-1.1rem;top:.75em;width:7px;height:7px;border-radius:999px;background:linear-gradient(135deg,#a78bfa,#5b9cf6);box-shadow:0 0 0 1px #0a0c188c}.markdown-list-unordered>.markdown-list-item,.markdown-list-ordered>.markdown-list-item{text-indent:0}.markdown-list .markdown-list{margin-top:6px;margin-bottom:6px;padding-left:1.1rem}.markdown-list .markdown-list-unordered>.markdown-list-item:before{width:5px;height:5px;opacity:.75}.post-body .markdown-list{font-size:16px}.me-bio .markdown-list{font-size:15px}.me-bio-markdown p:has(>img),.me-bio-photo{display:flex;align-items:center;justify-content:space-between;gap:20px;margin:32px 0}.me-bio-markdown p:has(>img) img,.me-bio-photo img{display:block;max-width:320px;width:100%;height:auto;border-radius:10px;border:1px solid var(--border);object-fit:cover}.me-bio-markdown p:has(>img) em,.me-bio-photo-caption{display:block;font-size:13px;color:var(--text-muted);line-height:1.6;max-width:380px}.me-bio-markdown p:has(>img):nth-of-type(odd),.me-bio-photo-right{flex-direction:row-reverse}.me-bio-markdown p:has(>img):nth-of-type(2n),.me-bio-photo-left{flex-direction:row}.me-bio-photo-left-text{text-align:left}.me-bio-photo-right-text{text-align:right}.me-interests-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}.me-interest-card{display:flex;flex-direction:column;background:var(--bg);overflow:hidden;transition:background .15s}.me-interest-card:hover{background:color-mix(in srgb,var(--border) 60%,var(--bg))}.me-interest-img{width:100%;aspect-ratio:4 / 3;overflow:hidden;background:var(--border);flex-shrink:0}.me-interest-img img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(15%);transition:transform .5s cubic-bezier(.16,1,.3,1)}.me-interest-card:hover .me-interest-img img{transform:scale(1.04)}.me-interest-img-placeholder{display:block;width:100%;height:100%;background:repeating-linear-gradient(45deg,transparent,transparent 4px,color-mix(in srgb,var(--text-muted) 8%,transparent) 4px,color-mix(in srgb,var(--text-muted) 8%,transparent) 5px)}.me-interest-body{display:flex;flex-direction:column;gap:6px;padding:16px 20px 20px}.me-interest-name{font-size:13px;font-weight:600;letter-spacing:-.01em}.me-interest-note{font-size:12px;color:var(--text-muted);line-height:1.65}.projects-section{padding:80px 48px 96px}.projects-controls{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.projects-search-wrap{position:relative;flex:1;min-width:180px;max-width:360px}.projects-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:13px;height:13px;color:var(--text-muted);pointer-events:none}.projects-search{width:100%;background:transparent;border:1px solid var(--border);color:var(--text);font-family:inherit;font-size:13px;padding:9px 36px 9px 34px;outline:none;transition:border-color .15s}.projects-search::placeholder{color:var(--text-muted)}.projects-search:focus{border-color:#a78bfa66}.projects-search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);font-size:16px;cursor:pointer;line-height:1;padding:0 2px;transition:color .15s}.projects-search-clear:hover{color:var(--text)}.projects-sort-wrap{position:relative;flex-shrink:0}.projects-sort-btn{display:flex;align-items:center;gap:7px;background:transparent;border:1px solid var(--border);color:var(--text-muted);font-family:inherit;font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:9px 13px;cursor:pointer;transition:border-color .15s,color .15s;white-space:nowrap}.projects-sort-btn:hover{border-color:#a78bfa66;color:var(--text)}.projects-sort-chevron{display:inline-block;transform:rotate(-90deg);transition:transform .2s;font-size:13px;line-height:1}.projects-sort-chevron.open{transform:rotate(90deg)}.projects-sort-dropdown{position:absolute;top:calc(100% + 6px);right:0;z-index:50;background:#0e1220;border:1px solid var(--border);display:flex;flex-direction:column;min-width:170px;box-shadow:0 8px 32px #00000080}.projects-sort-option{background:none;border:none;color:var(--text-muted);font-family:inherit;font-size:12px;font-weight:500;text-align:left;padding:10px 14px;cursor:pointer;transition:background .1s,color .1s}.projects-sort-option:hover{background:#ffffff0a;color:var(--text)}.projects-sort-option.is-active{color:#a78bfa}.projects-filter-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}.projects-filter-pill{background:transparent;border:1px solid var(--border);color:var(--text-muted);font-family:inherit;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:5px 12px;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.projects-filter-pill:hover{border-color:#a78bfa59;color:var(--text)}.projects-filter-pill.is-active{border-color:#a78bfa80;color:#a78bfa;background:#a78bfa12}.projects-count{font-size:11px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:0}.projects-empty{padding:48px 0;color:var(--text-muted);font-size:14px}.all-projects-list{display:flex;flex-direction:column;border-top:1px solid var(--border)}.all-project-row{display:grid;grid-template-columns:200px 1fr 24px;gap:32px;align-items:start;padding:32px 0;border-bottom:1px solid var(--border);transition:opacity .2s}.all-project-row:hover{opacity:.75}.all-project-image{width:100%;aspect-ratio:16 / 10;border:1px solid var(--border);flex-shrink:0}.all-project-info{display:flex;flex-direction:column;gap:8px}.all-project-meta{display:flex;flex-wrap:wrap;gap:16px;font-size:11px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.all-project-pill{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text);border:1px solid var(--border);background:#a78bfa14;padding:2px 8px;border-radius:999px}.all-project-title{font-size:20px;font-weight:700;letter-spacing:-.03em}.all-project-desc{font-size:13px;color:var(--text-muted);line-height:1.7;max-width:560px}.all-project-stack{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.all-project-tag{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);border:1px solid var(--border);padding:3px 8px}.all-project-arrow{font-size:16px;color:var(--text-muted);padding-top:4px}.contact-section{padding:120px 48px 96px;border-top:1px solid var(--border)}.contact-heading{font-size:clamp(52px,9vw,112px);font-weight:800;letter-spacing:-.045em;line-height:.95;margin-bottom:36px}.contact-email{font-size:15px;color:var(--text-muted);border-bottom:1px solid var(--border);padding-bottom:3px;transition:color .15s,border-color .15s}.contact-email:hover{color:var(--text);border-color:var(--text-muted)}.contact-phone{display:block;font-size:13px;color:var(--text-muted);margin-top:12px;transition:color .15s}.contact-phone:hover{color:var(--text)}.nav-active{color:var(--text)!important}.page{min-height:100vh}.blog-section{padding:64px 64px 96px;border-top:1px solid var(--border)}.blog-list{display:flex;flex-direction:column}.blog-row{display:grid;grid-template-columns:44px 1fr auto;align-items:start;gap:32px;padding:28px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:opacity .15s;text-decoration:none;color:inherit}.blog-row:first-child{border-top:1px solid var(--border)}.blog-row:hover .blog-num,.blog-row:hover .blog-summary,.blog-row:hover .blog-right{opacity:.35}.blog-num{font-size:11px;color:var(--text-muted);font-variant-numeric:tabular-nums;letter-spacing:.04em;padding-top:3px;transition:opacity .2s}.blog-body{display:flex;flex-direction:column;gap:8px}.blog-title{font-size:18px;font-weight:600;letter-spacing:-.02em;position:relative;display:inline-block}.blog-title:after{content:"";position:absolute;bottom:-1px;left:0;width:100%;height:1px;background:linear-gradient(90deg,#a78bfa,#5b9cf6);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.16,1,.3,1)}.blog-row:hover .blog-title:after{transform:scaleX(1)}.blog-summary{font-size:13px;color:var(--text-muted);line-height:1.65;max-width:560px;transition:opacity .2s}.blog-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;padding-top:3px;flex-shrink:0;transition:opacity .2s}.blog-category{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.blog-date{font-size:11px;color:var(--text-muted);white-space:nowrap}.post-section{padding:64px 64px 96px}.post-back{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:56px;transition:color .15s}.post-back:hover{color:var(--text)}.post-header{margin-bottom:32px}.post-meta{display:flex;gap:20px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:20px}.post-title{font-size:clamp(28px,4vw,44px);font-weight:800;letter-spacing:-.04em;line-height:1.05}.post-rule{height:1px;background:var(--border);margin-bottom:40px}.post-body{display:flex;flex-direction:column;gap:24px}.post-body p{font-size:16px;color:var(--text-muted);line-height:1.85}.post-body p+p{margin-top:18px}.post-markdown>p:first-of-type:first-letter{float:left;font-size:3.1rem;line-height:.9;font-weight:700;padding-right:8px;padding-top:4px}.post-body blockquote{border-left:2px solid var(--border);margin:16px 0;padding:8px 16px;color:var(--text-muted);font-style:italic}.post-body blockquote p:last-child{margin-bottom:0}.post-body code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.9em;background:color-mix(in srgb,var(--bg) 70%,var(--border) 30%);padding:.15em .35em;border-radius:3px}.post-body pre{margin:20px 0;padding:14px 16px;background:color-mix(in srgb,var(--bg) 70%,var(--border) 30%);border:1px solid var(--border);border-radius:4px;overflow-x:auto}.post-body pre code{background:none;padding:0;font-size:.9em}.post-not-found{font-size:14px;color:var(--text-muted);margin-bottom:24px}.project-page{padding:64px 64px 96px}.project-page-header{margin-bottom:32px}.project-page-body{display:grid;grid-template-columns:1fr 240px;gap:80px;align-items:start}.project-page-description{display:flex;flex-direction:column;gap:24px}.project-page-description p{font-size:16px;color:var(--text-muted);line-height:1.85}.project-page-sidebar{display:flex;flex-direction:column;gap:40px;position:sticky;top:32px}.project-page-meta-label{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:14px}.project-tech-list{list-style:none;display:flex;flex-direction:column;gap:8px}.project-tech-list li{font-size:13px;font-weight:500;letter-spacing:-.01em;padding-bottom:8px;border-bottom:1px solid var(--border)}.project-links{display:flex;flex-direction:column;gap:10px}.project-link{font-size:13px;font-weight:500;color:var(--text-muted);transition:color .15s;letter-spacing:-.01em}.project-link:hover{color:var(--text)}@media(max-width:900px){.project-page{padding:64px 28px 80px}.project-page-body{grid-template-columns:1fr;gap:48px}.project-page-sidebar{position:static;flex-direction:row;flex-wrap:wrap;gap:32px}}footer{padding:24px 48px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--text-muted);letter-spacing:.03em}.footer-links{display:flex;gap:24px}.footer-links a{transition:color .15s}.footer-links a:hover{color:var(--text)}.spotify-widget{display:flex;flex-direction:column;align-items:center;gap:10px;padding:16px 12px;margin-top:32px;border-top:1px solid var(--border);width:100%;color:var(--text-muted);transition:color .15s;text-decoration:none}.spotify-widget:hover{color:var(--text)}.spotify-icon{width:14px;height:14px;flex-shrink:0;opacity:.4;transition:opacity .15s}.spotify-widget.spotify-playing .spotify-icon{color:#1db954;opacity:1}.spotify-widget:hover .spotify-icon{opacity:1}.spotify-track{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%}.spotify-art{width:52px;height:52px;object-fit:cover;border:1px solid var(--border)}.spotify-info{display:flex;flex-direction:column;align-items:center;gap:3px;width:100%;overflow:hidden}.spotify-title{font-size:10px;font-weight:600;letter-spacing:-.01em;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.spotify-artist{font-size:9px;color:var(--text-muted);letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.spotify-idle{font-size:9px;letter-spacing:.08em;text-transform:uppercase}@keyframes bar1{0%,to{height:4px}50%{height:10px}}@keyframes bar2{0%,to{height:8px}33%{height:3px}66%{height:10px}}@keyframes bar3{0%,to{height:6px}40%{height:11px}80%{height:3px}}.spotify-bars{display:flex;align-items:flex-end;gap:2px;height:12px}.spotify-bars span{display:block;width:2px;background:#1db954;border-radius:1px;animation-duration:1s;animation-iteration-count:infinite;animation-timing-function:ease-in-out}.spotify-bars span:nth-child(1){animation-name:bar1;height:4px}.spotify-bars span:nth-child(2){animation-name:bar2;height:8px}.spotify-bars span:nth-child(3){animation-name:bar3;height:6px}@media(max-width:900px){.spotify-widget{display:none}.nav-mobile{position:fixed;top:0;left:0;right:0;height:52px;z-index:100;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 20px;background:#0a0908f0;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.nav-burger{width:32px;height:32px;border-radius:999px;border:1px solid var(--border);background:color-mix(in srgb,var(--bg) 80%,#101320 20%);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.nav-burger span{position:relative;display:block;width:14px;height:1px;background:var(--text)}.nav-burger span:before,.nav-burger span:after{content:"";position:absolute;left:0;width:14px;height:1px;background:var(--text)}.nav-burger span:before{top:-4px}.nav-burger span:after{top:4px}.nav-drawer-overlay{position:fixed;inset:0;background:#0006;opacity:0;pointer-events:none;transition:opacity .25s ease;z-index:120}.nav-drawer-overlay.is-open{opacity:1;pointer-events:auto}.nav-drawer{position:fixed;top:0;right:0;bottom:0;width:min(260px,80vw);border-left:1px solid var(--border);background:#0a0908f7;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);transform:translate(100%);transition:transform .3s cubic-bezier(.16,1,.3,1);z-index:130;display:flex;flex-direction:column;padding:20px 22px 28px}.nav-drawer.is-open{transform:translate(0)}.nav-drawer-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.nav-drawer-close{background:none;border:none;color:var(--text-muted);font-size:20px;line-height:1;cursor:pointer}.nav-drawer-links{display:flex;flex-direction:column;gap:18px;font-size:12px;letter-spacing:.08em;text-transform:uppercase}main,footer,.page{margin-left:0}.hero{padding:88px 28px 36px}.work-section,.services-section,.about-section,.others-section,.contact-section,.blog-section,.post-section{padding-left:28px;padding-right:28px}footer{padding-left:28px;padding-right:28px}.me-top-grid{grid-template-columns:1fr;gap:40px}.me-interests-grid{grid-template-columns:repeat(2,1fr)}.me-bio-markdown p:has(>img),.me-bio-photo,.me-bio-photo-right,.me-bio-photo-left{flex-direction:column;align-items:center}.me-bio-markdown p:has(>img) em,.me-bio-photo-caption{max-width:100%;text-align:center;margin-top:8px}.about-grid{grid-template-columns:1fr;gap:40px}.about-photo{max-width:240px}.dtree-wrapper{flex-direction:column;gap:32px}.project-row{grid-template-columns:40px 1fr auto 20px}.project-row .project-meta:last-of-type{display:none}}@media(max-width:600px){nav{padding:0 20px}.hero{padding:84px 20px 28px}.work-section,.services-section,.about-section,.contact-section,.blog-section,.post-section{padding:72px 20px}footer{padding:20px}.project-row{grid-template-columns:36px 1fr 20px}.project-row .project-meta{display:none}.about-stats{gap:28px}.stat-num{font-size:30px}.me-interests-grid{grid-template-columns:1fr}}@media(max-width:640px){.route-wrapper{padding-top:52px}.me-bio-rest-sticky{top:52px}.me-bio-photo,.me-bio-photo-caption{display:block}.me-bio-photo-caption{margin-top:8px;font-size:13px;color:var(--text-muted);text-align:center}.all-project-row{grid-template-columns:1fr;gap:20px}.all-project-arrow{justify-self:flex-end}}
