:root{--bg: #ffffff;--bg-soft: #f6f7f9;--bg-card: #ffffff;--border: #e6e8eb;--text: #1a1d21;--text-soft: #5c636e;--accent: #088395;--accent-soft: #ebf4f6;--radius: 14px;--maxw: 760px;--font: "Inter Variable", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--mono: "JetBrains Mono", "Fira Code", ui-monospace, SFMono-Regular, Menlo, monospace}:root.dark{--bg: #0d1117;--bg-soft: #161b22;--bg-card: #161b22;--border: #21262d;--text: #e6edf3;--text-soft: #8b949e;--accent: #7ab2b2;--accent-soft: #0f2e35}*{box-sizing:border-box}html{font-family:var(--font);background:var(--bg);color:var(--text);scroll-behavior:smooth}body{margin:0;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}.container-wide{max-width:1100px}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}a:focus-visible,button:focus-visible{outline:3px solid color-mix(in srgb,var(--accent) 28%,transparent);outline-offset:3px}.icon{width:var(--icon-size, 20px);height:var(--icon-size, 20px);display:inline-grid;place-items:center;flex:0 0 auto}.icon svg{display:block;width:100%;height:100%;stroke-width:1.9}.site-header{border-bottom:1px solid var(--border);position:sticky;top:0;background:color-mix(in srgb,var(--bg) 85%,transparent);backdrop-filter:blur(10px);z-index:50}.nav{display:flex;align-items:center;justify-content:space-between;height:64px}.nav-brand{display:flex;align-items:center;gap:8px;font-weight:700;font-size:1.1rem;color:var(--text)}.nav-logo{width:28px;height:28px;border-radius:8px}:root.dark .nav-logo{filter:invert(1)}.nav-links{display:flex;gap:16px;align-items:center}.nav-links a{color:var(--text-soft);font-weight:500;font-size:.95rem;display:inline-flex;align-items:center;gap:6px}.nav-links a:hover{color:var(--text);text-decoration:none}.theme-toggle{background:var(--bg-soft);border:1px solid var(--border);color:var(--text);width:38px;height:38px;border-radius:10px;cursor:pointer;display:grid;place-items:center;font-size:1rem}.theme-toggle .theme-icon{grid-area:1 / 1}.theme-icon-sun,:root.dark .theme-icon-moon{opacity:0;transform:scale(.85)}:root.dark .theme-icon-sun{opacity:1;transform:scale(1)}.card{display:block;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px 22px;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}.card:hover{transform:translateY(-2px);border-color:var(--accent);text-decoration:none;box-shadow:0 8px 24px #0000000f}:root.dark .card:hover{box-shadow:0 12px 28px #0000003d}.card-title{margin:0 0 6px;font-size:1.15rem;line-height:1.28;color:var(--text)}.card-desc{margin:0;color:var(--text-soft);font-size:.95rem;line-height:1.55}.card-grid{display:grid;gap:18px}.repo-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.post-card{overflow:hidden;padding:0}.post-card-cover{aspect-ratio:16 / 9;background:var(--bg-soft);border-bottom:1px solid var(--border);overflow:hidden}.post-card-cover img{display:block;width:100%;height:100%;object-fit:cover;transition:transform .25s ease}.post-card:hover .post-card-cover img{transform:scale(1.025)}.post-card-body{padding:18px 20px 20px}.post-card .meta{margin-top:14px}.meta{color:var(--text-soft);font-size:.85rem;display:flex;gap:12px;flex-wrap:wrap;align-items:center}.tag{background:var(--accent-soft);color:var(--accent);padding:2px 10px;border-radius:999px;font-size:.78rem;font-weight:500}.repo-stats{display:flex;gap:14px;color:var(--text-soft);font-size:.85rem;margin-top:10px}.hero{padding:72px 0 40px}.hero h1{font-size:2.6rem;margin:0 0 12px;letter-spacing:-.02em}.hero p{font-size:1.15rem;color:var(--text-soft);margin:0}.section-title{font-size:1.4rem;margin:48px 0 18px;letter-spacing:-.01em}.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.section-head .section-title{margin-bottom:18px}.section-link{font-size:.9rem;font-weight:500;white-space:nowrap}.prose{padding:40px 0 80px}.prose h1{font-size:2.2rem;letter-spacing:-.02em;margin:0 0 8px}.prose h2{margin-top:2em;letter-spacing:-.01em}.prose img{max-width:100%;border-radius:var(--radius)}.prose .post-cover{display:block;width:100%;aspect-ratio:16 / 9;object-fit:cover;border:1px solid var(--border);margin:24px 0 32px;background:var(--bg-soft);box-shadow:0 14px 36px #00000014}:root.dark .prose .post-cover{box-shadow:0 18px 42px #00000042}.prose blockquote{border-left:3px solid var(--accent);margin:1.5em 0;padding:.2em 1.2em;color:var(--text-soft);background:var(--bg-soft);border-radius:0 8px 8px 0}.prose :not(pre)>code{background:var(--bg-soft);border:1px solid var(--border);padding:.15em .4em;border-radius:6px;font-family:var(--mono);font-size:.88em}.prose pre{padding:18px 20px;border-radius:var(--radius);overflow-x:auto;border:1px solid var(--border);font-size:.9rem;line-height:1.5;font-family:var(--mono)}.prose pre code{font-family:var(--mono)}.prose .code-block{position:relative;margin:1.5em 0}.prose .code-block pre{margin:0;padding-top:52px}.code-copy{position:absolute;top:10px;right:10px;z-index:2;display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 10px;border:1px solid var(--border);border-radius:8px;background:color-mix(in srgb,var(--bg-card) 88%,transparent);color:var(--text-soft);font:inherit;font-size:.78rem;line-height:1;cursor:pointer;backdrop-filter:blur(8px);transition:border-color .15s ease,color .15s ease,background-color .15s ease}.code-copy svg{width:16px;height:16px;stroke-width:2}.code-copy:hover{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 40%,var(--border))}.code-copy.is-copied{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 52%,var(--border));background:var(--accent-soft)}.code-copy.is-error{color:#b42318;border-color:#f2b8b5}:root.dark .code-copy{background:color-mix(in srgb,var(--bg-card) 82%,transparent)}:root.dark .astro-code,:root.dark .astro-code span{color:var(--shiki-dark)!important;background-color:var(--shiki-dark-bg)!important;font-style:var(--shiki-dark-font-style)!important;font-weight:var(--shiki-dark-font-weight)!important;text-decoration:var(--shiki-dark-text-decoration)!important}.site-footer{border-top:1px solid var(--border);padding:34px 0 36px;margin-top:60px;color:var(--text-soft);font-size:.9rem;text-align:center}.footer-inner{display:flex;flex-direction:column;align-items:center;gap:14px}.footer-logo{width:64px;height:64px;border:0;border-radius:0;display:grid;place-items:center;background:transparent;transition:transform .15s ease}.footer-logo:hover{text-decoration:none;transform:translateY(-1px)}.footer-logo img{width:48px;height:48px;border-radius:10px}:root.dark .footer-logo img{filter:invert(1)}.footer-socials{display:flex;gap:10px}.footer-socials a{width:38px;height:38px;border:1px solid var(--border);border-radius:12px;color:var(--text-soft);background:var(--bg-soft);display:grid;place-items:center}.footer-socials a:hover{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 42%,var(--border));text-decoration:none}.site-footer p{margin:0}.back-link{display:inline-block;margin-bottom:24px;color:var(--text-soft);font-size:.9rem}.cv-section{margin:40px 0}.cv-section-title{font-size:1.3rem;letter-spacing:-.01em;margin:0 0 18px;padding-bottom:8px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:9px}.cv-entry{margin-bottom:18px;display:grid;grid-template-columns:38px minmax(0,1fr);gap:12px}.cv-entry-icon{width:38px;height:38px;border:1px solid var(--border);border-radius:12px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center}.cv-entry-content{min-width:0}.cv-entry-head{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:6px 16px}.cv-org{font-weight:600;color:var(--text);font-size:1.02rem}.cv-role{color:var(--text-soft);font-size:.92rem;margin:2px 0 0}.cv-period{color:var(--text-soft);font-size:.85rem;white-space:nowrap}.skill-category{margin-bottom:30px}.skill-category h3{font-size:1rem;margin:0 0 10px;color:var(--text)}.skill-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(94px,1fr));gap:12px}.skill-item{min-height:108px;padding:13px 8px 10px;border:1px solid var(--border);border-radius:12px;background:color-mix(in srgb,var(--bg-card) 86%,var(--bg-soft));display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:9px;text-align:center}.skill-logo{width:50px;height:50px;border-radius:13px;border:1px solid color-mix(in srgb,var(--accent) 18%,var(--border));background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;flex:0 0 auto}.skill-logo .icon,.skill-mark{grid-area:1 / 1}.skill-logo .icon{--icon-size: 29px}.skill-mark{display:none;font-size:.82rem;line-height:1;font-weight:750}.skill-name{color:var(--text);font-size:.78rem;line-height:1.24;overflow-wrap:anywhere}@media(max-width:520px){.skill-grid{grid-template-columns:repeat(auto-fill,minmax(78px,1fr));gap:10px}.skill-item{min-height:104px;padding:10px 6px 9px}}@media(max-width:700px){.nav{height:auto;padding-top:12px;padding-bottom:12px;align-items:flex-start;gap:12px}.nav-links{justify-content:flex-end;flex-wrap:wrap;gap:8px 12px}.nav-links a{font-size:.86rem}}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_astro/inter-cyrillic-ext-wght-normal.BOeWTOD4.woff2) format("woff2-variations");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_astro/inter-cyrillic-wght-normal.DqGufNeO.woff2) format("woff2-variations");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_astro/inter-greek-ext-wght-normal.DlzME5K_.woff2) format("woff2-variations");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_astro/inter-greek-wght-normal.CkhJZR-_.woff2) format("woff2-variations");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_astro/inter-vietnamese-wght-normal.CBcvBZtf.woff2) format("woff2-variations");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_astro/inter-latin-ext-wght-normal.DO1Apj_S.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_astro/inter-latin-wght-normal.Dx4kXJAl.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
