:root{--bg:#0a0e14;--bg-soft:#0f141d;--bg-card:#121826;--border:#1e2738;--border-soft:#19202e;--fg:#e6edf3;--fg-dim:#9aa7b8;--fg-faint:#5b6878;--accent:#4ade80;--accent-dim:#2ea968;--accent-glow:rgba(74,222,128,.15);--cyan:#38bdf8;--mono:"JetBrains Mono","SFMono-Regular",ui-monospace,"Cascadia Code",Menlo,Consolas,monospace;--sans:"Sora",-apple-system,BlinkMacSystemFont,sans-serif}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--fg);font-family:var(--sans);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;background-image:radial-gradient(circle at 15% 5%,rgba(74,222,128,.06),transparent 40%),radial-gradient(circle at 85% 0,rgba(56,189,248,.05),transparent 35%);background-attachment:fixed}body:before{content:"";position:fixed;inset:0;background-image:linear-gradient(var(--border-soft) 1px,transparent 1px),linear-gradient(90deg,var(--border-soft) 1px,transparent 1px);background-size:64px 64px;opacity:.25;pointer-events:none;z-index:0;-webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 0,#000 20%,transparent 75%);mask-image:radial-gradient(ellipse 80% 60% at 50% 0,#000 20%,transparent 75%)}a{color:inherit;text-decoration:none}.container{max-width:1080px;margin:0 auto;padding:0 24px;position:relative;z-index:1}.nav{position:-webkit-sticky;position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:rgba(10,14,20,.7);border-bottom:1px solid var(--border-soft)}.nav-inner{justify-content:space-between;height:64px}.nav-brand,.nav-inner{display:flex;align-items:center}.nav-brand{font-family:var(--mono);font-weight:700;font-size:15px;letter-spacing:-.02em;gap:8px}.nav-links{display:flex;align-items:center;gap:4px}.nav-links a{font-size:14px;color:var(--fg-dim);padding:8px 14px;border-radius:8px;transition:color .2s,background .2s}.nav-links a:hover{color:var(--fg);background:var(--bg-card)}.lang-toggle{font-family:var(--mono);font-size:12px;border:1px solid var(--border);background:var(--bg-card);color:var(--fg-dim);padding:6px 12px;border-radius:8px;cursor:pointer;margin-left:8px;transition:all .2s}.lang-toggle:hover{border-color:var(--accent-dim);color:var(--accent)}.hero{position:relative}.hero-tag{font-family:var(--mono);font-size:13px;color:var(--accent);display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border:1px solid var(--border);border-radius:999px;background:var(--bg-card);margin-bottom:28px}.hero-tag .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.hero h1{font-size:clamp(40px,7vw,72px);line-height:1;letter-spacing:-.04em;font-weight:700;margin-bottom:20px}.hero h1 .name{display:block;color:var(--fg)}.hero-headline{font-size:clamp(20px,3vw,30px);line-height:1.25;font-weight:600;letter-spacing:-.02em;color:var(--fg);max-width:22ch;margin-bottom:22px}.hero-headline:before{content:"// ";color:var(--accent);font-family:var(--mono);font-weight:400}.hero p:not(.hero-headline){font-size:clamp(16px,2vw,19px);color:var(--fg-dim);max-width:56ch;margin-bottom:36px}.hero-cta{display:flex;gap:14px;flex-wrap:wrap}.btn{font-family:var(--mono);font-size:14px;padding:13px 22px;border-radius:10px;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px;border:1px solid transparent}.btn-primary{background:var(--accent);color:#06120a;font-weight:600}.btn-primary:hover{background:#5eea90;transform:translateY(-2px);box-shadow:0 8px 24px var(--accent-glow)}.btn-ghost{background:var(--bg-card);border-color:var(--border);color:var(--fg)}.btn-ghost:hover{border-color:var(--accent-dim);color:var(--accent)}.section{padding:70px 0;scroll-margin-top:80px}.section-head{margin-bottom:40px}.section-label{font-family:var(--mono);font-size:13px;color:var(--accent);letter-spacing:.05em}.section h2{font-size:clamp(26px,4vw,36px);letter-spacing:-.02em;margin:8px 0 10px;font-weight:700}.section-sub{color:var(--fg-dim);font-size:16px;max-width:60ch}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:18px;gap:18px}.card{background:var(--bg-card);border:1px solid var(--border);padding:24px;transition:all .25s;display:flex;flex-direction:column;gap:12px;position:relative;overflow:hidden}.card,.card:after{border-radius:14px}.card:after{content:"";position:absolute;inset:0;padding:1px;background:linear-gradient(135deg,var(--accent),transparent 50%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .25s}.card:hover{transform:translateY(-4px);border-color:var(--border)}.card:hover:after{opacity:1}.card-head{justify-content:space-between;gap:12px}.card-head,.card-title{display:flex;align-items:center}.card-title{font-family:var(--mono);font-size:16px;font-weight:600;color:var(--fg);gap:8px}.card-title .hash{color:var(--accent)}.card-desc{color:var(--fg-dim);font-size:14.5px;flex:1 1}.card-meta{display:flex;align-items:center;gap:14px;font-size:13px;color:var(--fg-faint);font-family:var(--mono)}.card-meta .lang-dot{width:9px;height:9px;border-radius:50%;display:inline-block;margin-right:6px}.tags{display:flex;flex-wrap:wrap;gap:7px}.tag{font-family:var(--mono);font-size:11.5px;color:var(--fg-dim);background:var(--bg-soft);border:1px solid var(--border-soft);padding:3px 9px;border-radius:6px}.about-grid{display:grid;grid-template-columns:1.4fr 1fr;grid-gap:40px;gap:40px;align-items:start}.about-body p{color:var(--fg-dim);margin-bottom:18px;font-size:16px}.focus-box{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:24px}.focus-box h3{font-family:var(--mono);font-size:14px;color:var(--accent);margin-bottom:16px}.focus-list{list-style:none;display:flex;flex-direction:column;gap:12px}.focus-list li{display:flex;align-items:flex-start;gap:10px;font-size:14.5px;color:var(--fg)}.focus-list li:before{content:"▹";color:var(--accent);flex-shrink:0}.note{font-family:var(--mono);font-size:14px;color:var(--fg-faint);border:1px dashed var(--border);border-radius:12px;padding:28px;text-align:center}.skeleton{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;height:150px;position:relative;overflow:hidden}.skeleton:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.03),transparent);animation:shimmer 1.4s infinite}@keyframes shimmer{to{transform:translateX(100%)}}.footer{border-top:1px solid var(--border-soft);padding:40px 0;margin-top:40px}.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}.footer-links{display:flex;gap:18px}.footer-links a{color:var(--fg-dim);font-size:14px;transition:color .2s;font-family:var(--mono)}.footer-links a:hover{color:var(--accent)}.footer-copy{font-family:var(--mono);font-size:13px;color:var(--fg-faint)}.reveal{opacity:0;transform:translateY(20px);animation:reveal .6s forwards}@keyframes reveal{to{opacity:1;transform:translateY(0)}}@media (max-width:760px){.nav-links{display:none}.about-grid{grid-template-columns:1fr}.hero{padding:80px 0 60px}}.nav-brand{gap:10px}.nav-brand span{color:var(--fg)}.nav-brand .prompt{color:var(--accent)}.nav-links a.active{color:var(--accent);background:var(--bg-card)}.page{padding-top:120px}.hero{padding:120px 0 90px}.article-list{display:flex;flex-direction:column;gap:2px}.article-row{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;padding:22px;border:1px solid transparent;border-radius:12px;transition:all .2s}.article-row:hover{background:var(--bg-card);border-color:var(--border)}.article-row-main{display:flex;flex-direction:column;gap:8px}.article-row-title{font-size:18px;font-weight:600;color:var(--fg);letter-spacing:-.01em}.article-row:hover .article-row-title{color:var(--accent)}.article-row-excerpt{color:var(--fg-dim);font-size:14.5px;max-width:65ch}.article-row-date{font-family:var(--mono);font-size:13px;color:var(--fg-faint);white-space:nowrap;padding-top:4px}.article-container{max-width:760px}.back-link{font-family:var(--mono);font-size:13px;color:var(--fg-dim);transition:color .2s;display:inline-block;margin-bottom:28px}.back-link:hover{color:var(--accent)}.article-title{font-size:clamp(28px,5vw,42px);letter-spacing:-.03em;line-height:1.1;margin-bottom:18px}.article-meta{display:flex;align-items:center;gap:16px;margin-bottom:40px;padding-bottom:24px;border-bottom:1px solid var(--border);font-family:var(--mono);font-size:13px;color:var(--fg-faint);flex-wrap:wrap}.article-body{color:var(--fg-dim);font-size:16.5px;line-height:1.75}.article-body h2{color:var(--fg);font-size:24px;letter-spacing:-.02em;margin:42px 0 16px;padding-top:8px}.article-body h3{color:var(--fg);font-size:19px;margin:32px 0 12px}.article-body p{margin-bottom:20px}.article-body a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}.article-body ol,.article-body ul{margin:0 0 20px 22px;display:flex;flex-direction:column;gap:8px}.article-body li{padding-left:4px}.article-body strong{color:var(--fg)}.article-body code{font-family:var(--mono);font-size:13.5px;background:var(--bg-card);border:1px solid var(--border);padding:2px 7px;border-radius:6px;color:var(--accent)}.article-body pre{background:#0d1117;border:1px solid var(--border);border-radius:12px;padding:20px;overflow-x:auto;margin:0 0 24px}.article-body pre code{background:none;border:none;padding:0;color:var(--fg);font-size:13.5px;line-height:1.6}.article-body blockquote{border-left:3px solid var(--accent);padding:4px 0 4px 20px;margin:0 0 24px;color:var(--fg-faint);font-style:italic}.article-body img{max-width:100%;border-radius:12px}.article-body table{width:100%;border-collapse:collapse;margin-bottom:24px;font-size:14.5px}.article-body td,.article-body th{border:1px solid var(--border);padding:10px 14px;text-align:left}.article-body th{background:var(--bg-card);color:var(--fg);font-family:var(--mono);font-size:13px}@media (max-width:760px){.article-row{flex-direction:column;gap:12px}}pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}
/*!
  Theme: GitHub Dark
  Description: Dark theme as seen on github.com
  Author: github.com
  Maintainer: @Hirse
  Updated: 2021-05-15

  Outdated base version: https://github.com/primer/github-syntax-dark
  Current colors taken from GitHub's CSS
*/.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id,.hljs-variable{color:#79c0ff}.hljs-meta .hljs-string,.hljs-regexp,.hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-code,.hljs-comment,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-pseudo,.hljs-selector-tag{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}