:root{--bg:#0e1015;--surface:#181b22;--surface-2:#20242d;--ink:#eceef2;--muted:#939aa7;--faint:#626a77;--accent:#a78bfa;--green:#3cc68a;--line:#ffffff14;--radius:18px;--col:500px;--sans:"Inter", -apple-system, system-ui, sans-serif;--serif:"Source Serif 4", Georgia, serif;--mono:ui-monospace, "SF Mono", Menlo, Consolas, monospace}*{box-sizing:border-box}html{scrollbar-gutter:stable;background:var(--bg)}body{isolation:isolate;color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;background:var(--bg);min-height:100vh;margin:0;font-size:15px;line-height:1.6;position:relative}body:before{content:"";z-index:-1;pointer-events:none;background-image:radial-gradient(circle,#ffffff0a 1px,#0000 1.4px);background-size:22px 22px;position:fixed;inset:0}.pillbar{z-index:20;pointer-events:none;background:0 0;justify-content:center;padding:22px 16px 14px;display:flex;position:sticky;top:0}.pill{pointer-events:auto;-webkit-backdrop-filter:saturate(150%)blur(12px);backdrop-filter:saturate(150%)blur(12px);border:1px solid var(--line);background:#181b22d1;border-radius:999px;gap:4px;padding:4px 5px;display:inline-flex;box-shadow:0 8px 28px -10px #0009,0 1px 3px #0006}.pill-link{appearance:none;cursor:pointer;font-family:var(--sans);color:var(--muted);background:0 0;border:none;border-radius:999px;align-items:center;padding:8px 15px;font-size:14px;font-weight:500;text-decoration:none;transition:color .16s,background .16s;display:inline-flex}.pill-link:hover{background:#ffffff09}.pill-link.active{color:var(--ink);background:var(--surface-2)}.wrap{max-width:820px;margin:0 auto;padding:18px 22px 70px}.section:not(.detail-page){max-width:var(--col);margin-left:auto;margin-right:auto}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 14px 32px -24px #000c}.eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin:0 0 12px 2px;font-size:12px;font-weight:600}.block{margin-bottom:30px}.about{padding:23px 24px}.bio{font-family:var(--serif);color:#d7dbe2;margin:0;font-size:16.5px;line-height:1.55}.cursor{background:var(--accent);width:2px;height:1.05em;margin-left:2px;animation:1.1s step-end infinite blink;display:inline-block;transform:translateY(2px)}@keyframes blink{50%{opacity:0}}.detail-page{width:100%;max-width:var(--col);margin-left:auto;margin-right:auto}.detail-back{color:var(--muted);font:500 13px/1 var(--sans);cursor:pointer;background:0 0;border:0;align-items:center;gap:8px;margin:0 0 18px;padding:0;text-decoration:none;transition:color .16s,transform .16s;display:inline-flex}.detail-back:hover{color:var(--ink)}.detail-back:before{content:"←";font-size:15px}.article-shell{width:100%;max-width:var(--col);margin:0 auto}.article-head{border-bottom:1px solid var(--line);padding:8px 0 25px}.article-date{font-family:var(--mono);color:var(--faint);letter-spacing:.045em;font-size:12px}.article-title{letter-spacing:-.04em;margin:11px 0 13px;font-size:clamp(27px,5vw,36px);line-height:1.12}.article-deck{color:#c8cdd6;font-family:var(--serif);margin:0;font-size:19px;line-height:1.55}.article-body{padding:27px 0 8px}.article-body p{color:#b2b8c3;font-family:var(--serif);margin:0 0 19px;font-size:16.5px;line-height:1.78}.article-body p:first-child{color:#ccd1da}a:focus-visible,.pill-link:focus-visible{outline:2px solid var(--accent);outline-offset:3px}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:1ms!important;animation:none!important}}@media (width<=420px){.pill-link{padding:8px 12px}}.interests{--interest-art-width:112px;--interest-art-height:76px;--interest-outline:3px;--interest-edge:#fffffff0;grid-template-columns:1fr 1fr;gap:12px;display:grid}.tile{font-family:var(--sans);color:var(--ink);background:var(--surface);border:1px solid var(--line);border-radius:14px;flex-direction:column;justify-content:flex-end;min-height:156px;padding:14px;transition:border-color .18s,transform .18s;display:flex;position:relative;overflow:hidden}.tile-meta{z-index:3;position:relative}.tile-label{text-shadow:0 1px 4px #080a0e99;font-size:16px;font-weight:600;line-height:1.35;display:block}.tile-sub{color:var(--faint);text-shadow:0 1px 4px #080a0e99;margin-top:2px;font-size:13.5px;line-height:1.45;display:block}.water-art{width:var(--interest-art-width);height:var(--interest-art-height);margin-left:calc(var(--interest-art-width) / -2);filter:drop-shadow(0 7px 8px #00000047);position:absolute;top:13px;left:50%;overflow:visible}.paint-mark{fill:none;stroke:url(#paintStroke);stroke-width:22px;stroke-linecap:round;stroke-dasharray:150;stroke-dashoffset:48px;opacity:.9;transition:stroke-dashoffset .65s cubic-bezier(.2,.8,.3,1),opacity .3s}.paint-highlight{fill:none;stroke:#ffffff57;stroke-width:2.2px;stroke-linecap:round;stroke-dasharray:150;stroke-dashoffset:62px;transition:stroke-dashoffset .65s cubic-bezier(.2,.8,.3,1)}.water-art .brush-icon{transform-box:fill-box;transform-origin:50%;transition:transform .65s cubic-bezier(.2,.8,.3,1);transform:translate(3px,-2px)rotate(-28deg)}.water-art .brush-icon>*{stroke:var(--interest-edge)}.has-hover .water:hover .paint-mark,.has-hover .water:hover .paint-highlight{stroke-dashoffset:0}.has-hover .water:hover .brush-icon{transform:translate(17px,-8px)rotate(-20deg)}.stack{width:var(--interest-art-width);height:var(--interest-art-height);position:absolute;top:13px;left:50%;transform:translate(-50%)}.shot{border:var(--interest-outline) solid var(--interest-edge);border-radius:8px;width:72px;height:54px;margin-left:-36px;transition:transform .4s cubic-bezier(.2,.8,.3,1),box-shadow .4s;position:absolute;top:9px;left:50%;box-shadow:0 6px 12px #00000061}.s1{background:linear-gradient(135deg,#ff9a6b,#ff5f8d);transform:rotate(-8deg)translate(-3px)}.s2{background:linear-gradient(135deg,#5fd0ff,#3b7bff);transform:rotate(1deg)}.s3{background:linear-gradient(135deg,#7be0a8,#39b27b);transform:rotate(9deg)translate(3px)}.has-hover .photo:hover .s1{transform:rotate(-16deg)translate(-30px)translateY(3px)}.has-hover .photo:hover .s2{transform:rotate(0)translateY(-5px)}.has-hover .photo:hover .s3{transform:rotate(16deg)translate(30px)translateY(3px)}.has-hover .photo:hover .shot{box-shadow:0 10px 18px #0000006b}.dev .term{border:var(--interest-outline) solid var(--interest-edge);width:114px;height:70px;font-family:var(--mono);background:#0b0d12;border-radius:10px;font-size:8.2px;position:absolute;top:16px;left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 8px 18px #00000061}.term-bar{background:#151820;border-bottom:1px solid #ffffff12;gap:4px;padding:5px 7px;display:flex}.term-bar i{aspect-ratio:1;border:0;border-radius:50%;flex:0 0 6px;width:6px;height:6px;padding:0;display:block}.term-bar i:first-child{background:#ff6b63}.term-bar i:nth-child(2){background:#ffc94a}.term-bar i:nth-child(3){background:#45d45b}.term-body{min-height:38px;padding:8px 8px 7px;display:block}.line{color:#dfe4ea;white-space:nowrap}.line .pmt{color:#66d49d}.tcaret{background:var(--accent);vertical-align:-1px;opacity:0;width:4px;height:.95em;display:inline-block}.has-hover .dev:hover .tcaret{opacity:1;animation:1.1s step-end infinite blink}.out{color:var(--green);white-space:nowrap;opacity:0;margin-top:4px;transition:opacity .25s;display:block}.out.show{opacity:1}.book-art{width:var(--interest-art-width);height:var(--interest-art-height);margin-left:calc(var(--interest-art-width) / -2);filter:drop-shadow(0 8px 9px #0000004d);position:absolute;top:13px;left:50%}.kindle-svg{width:100%;height:100%;display:block;overflow:visible}.kdl-body{fill:#262a33;stroke:var(--interest-edge);stroke-width:var(--interest-outline)}.kdl-screen{fill:#f3efe6}.kdl-line{fill:none;stroke:#bcb5a6;stroke-width:2.4px;stroke-linecap:round}.kdl-page{transition:opacity .12s linear .19s}.kpage2,.has-hover .reading:hover .kpage1{opacity:0}.has-hover .reading:hover .kpage2{opacity:1}.eink-flash{fill:#20242c;opacity:0}.has-hover .reading:hover .eink-flash{animation:.58s eink}@keyframes eink{0%{opacity:0}26%{opacity:.88}52%{opacity:.88}to{opacity:0}}@media (prefers-reduced-motion:reduce){.kdl-page{transition:none}.has-hover .reading:hover .eink-flash{animation:none}}.contest-card{border:3px solid var(--interest-edge);width:122px;height:42px;font-family:var(--mono);--contest-color:#78efad;background:linear-gradient(145deg,#161922,#101218);border-radius:12px;position:absolute;top:31px;left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 8px 18px #00000057}.contest-dots{grid-template-columns:repeat(4,8px);align-items:center;column-gap:10px;display:grid;position:absolute;top:50%;left:13px;transform:translateY(-50%)}.contest-dot{background:#ffffff1c;border:1px solid #ffffff29;border-radius:999px;width:8px;height:8px;transition:background .34s,border-color .34s,transform .34s cubic-bezier(.2,.8,.3,1),box-shadow .34s;transform:scale(1);box-shadow:inset 0 1px 1px #ffffff08}.contest-verdict{text-align:center;letter-spacing:.08em;color:var(--contest-color);opacity:.42;font-size:10px;font-weight:700;transition:opacity .28s,color .26s,transform .34s cubic-bezier(.2,.8,.3,1);position:absolute;top:50%;left:84px;right:6px;transform:translateY(-50%)}.has-hover .contest:hover .contest-dot{background:#ffffff29;border-color:#ffffff38}.has-hover .contest:hover .contest-dot:first-child{background:var(--contest-color);border-color:var(--contest-color);box-shadow:0 0 0 3px color-mix(in srgb, var(--contest-color) 18%, transparent);transition-delay:20ms;transform:scale(1)}.has-hover .contest:hover .contest-dot:nth-child(2){background:var(--contest-color);border-color:var(--contest-color);box-shadow:0 0 0 3px color-mix(in srgb, var(--contest-color) 18%, transparent);transition-delay:.1s;transform:scale(1)}.has-hover .contest:hover .contest-dot:nth-child(3){background:var(--contest-color);border-color:var(--contest-color);box-shadow:0 0 0 3px color-mix(in srgb, var(--contest-color) 18%, transparent);transition-delay:.18s;transform:scale(1)}.has-hover .contest:hover .contest-dot:nth-child(4){background:var(--contest-color);border-color:var(--contest-color);box-shadow:0 0 0 3px color-mix(in srgb, var(--contest-color) 18%, transparent);transition-delay:.26s;transform:scale(1)}.has-hover .contest:hover .contest-verdict{opacity:.78;transition-delay:.26s;transform:translateY(-50%)}.contest-card.verdict-ac{--contest-color:#78efad}.contest-card.verdict-tle{--contest-color:#f4c96b}.contest-card.verdict-wa{--contest-color:#ff9aa0}.language-card{width:var(--interest-art-width);height:var(--interest-art-height);margin-left:calc(var(--interest-art-width) / -2);position:absolute;top:13px;left:50%}.lang-art{filter:drop-shadow(0 8px 12px #00000052);transform-box:fill-box;transform-origin:50%;width:100%;height:100%;transition:transform .6s cubic-bezier(.2,.8,.3,1),filter .6s;display:block;overflow:visible}.has-hover .langs:hover .lang-art{filter:drop-shadow(0 12px 16px #0006);transform:translateY(-2px)scale(1.05)}.bubble{stroke:var(--interest-edge);stroke-width:var(--interest-outline);stroke-linejoin:round}.bubble-back{fill:#6f63d6}.lang-dot{fill:#fff;opacity:.45}.has-hover .langs:hover .ld1{animation:1.1s ease-in-out infinite typing}.has-hover .langs:hover .ld2{animation:1.1s ease-in-out .18s infinite typing}.has-hover .langs:hover .ld3{animation:1.1s ease-in-out .36s infinite typing}@keyframes typing{0%,70%,to{opacity:.3}35%{opacity:1}}@media (prefers-reduced-motion:reduce){.has-hover .langs:hover .ld1,.has-hover .langs:hover .ld2,.has-hover .langs:hover .ld3{animation:none}}@media (width<=480px){.tile{min-height:188px}}#projects{max-width:700px}.pstack{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.pcard{color:inherit;background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:9px;display:block}.project-preview{aspect-ratio:3/2;background:var(--surface-2);border:0;border-radius:9px;width:100%;position:relative;overflow:hidden}.project-image{object-fit:contain;width:100%;height:100%;display:block;position:absolute;inset:0}.project-copy{grid-template-columns:minmax(0,1fr);gap:4px;padding:12px 4px 2px;display:grid}.project-copy h3{letter-spacing:-.01em;margin:0;font-size:16px;font-weight:600;line-height:1.35}.project-copy p{color:var(--muted);grid-column:1;margin:0;font-size:13.5px;line-height:1.45}.project-tech{width:fit-content;color:var(--faint);grid-column:1;align-items:center;gap:4px;margin-top:5px;font-size:11.5px;display:inline-flex}.project-tech-icon{object-fit:contain;flex:none;width:20px;height:20px;display:block}@media (width<=700px){#projects{max-width:var(--col)}.pstack{grid-template-columns:minmax(0,1fr);gap:12px}}.tstack{gap:12px;display:grid}.tcard{color:inherit;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);cursor:pointer;padding:17px 18px;text-decoration:none;transition:background .2s;display:block}.tcard:hover{background:#1b1e26}.tmeta{color:var(--faint);letter-spacing:.03em;font-size:12px}.tcard h3{letter-spacing:0;margin:5px 0 4px;font-size:16px;font-weight:600;line-height:1.35}.tdesc{color:var(--muted);margin:0;font-size:13.5px;line-height:1.45}.contact{padding:23px 24px 24px}.contact .bio{font-size:17.5px}.contact-actions{flex-wrap:wrap;gap:10px;margin-top:18px;display:flex}.email-btn{background:var(--accent);color:#1b1430;border-radius:11px;align-items:center;gap:8px;padding:10px 16px;font-size:14px;font-weight:600;text-decoration:none;transition:background .2s;display:inline-flex}.email-btn:hover{background:#b094fa}.ghost-btn{background:var(--surface-2);color:var(--ink);border:1px solid var(--line);border-radius:11px;align-items:center;gap:8px;padding:10px 15px;font-size:14px;font-weight:500;text-decoration:none;transition:background .2s;display:inline-flex}.ghost-btn:hover{background:#262a33}.btn-icon{width:18px;height:18px;-webkit-mask:var(--icon) center / contain no-repeat;-webkit-mask:var(--icon) center / contain no-repeat;mask:var(--icon) center / contain no-repeat;background:currentColor;flex:none}
