@import url("https://fonts.googleapis.com/css2?family=JetBrains+Mono:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&family=IBM+Plex+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&family=Source+Serif+4:ital,opsz,wght@0,8..60,400;0,8..60,600;0,8..60,700;1,8..60,400&display=swap");*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);font-size:var(--text-base);font-weight:var(--weight-normal);line-height:var(--leading-relaxed);background:var(--surface-base);color:var(--text-body);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background var(--duration-slow) var(--ease-smooth),color var(--duration-slow) var(--ease-smooth)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-ghost)}::selection{background:var(--selection-bg);color:var(--selection-text)}:focus-visible{outline:2px solid var(--accent-400);outline-offset:2px;border-radius:var(--radius-sm)}.container{max-width:var(--container-max)}.container,.container--narrow{margin:0 auto;padding:0 var(--container-padding)}.container--narrow{max-width:var(--container-narrow)}.container--wide{max-width:var(--container-wide);margin:0 auto;padding:0 var(--container-padding)}.font-mono{font-family:var(--font-mono)}.font-serif{font-family:var(--font-serif)}.accent-dot{display:inline-block;width:7px;height:7px;border-radius:var(--radius-full);background:var(--accent-500);margin-right:var(--space-2);vertical-align:middle}.tag-badge{display:inline-flex;align-items:center;gap:var(--space-1);font-family:var(--font-mono);font-size:var(--text-2xs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:var(--tracking-wider);padding:.2em .6em;border-radius:var(--radius-sm);text-decoration:none;border:1px solid;white-space:nowrap;line-height:1.5;transition:all var(--duration-fast) var(--ease-smooth)}.tag-badge--cyan{background:var(--tag-cyan-bg);color:var(--tag-cyan-text);border-color:var(--tag-cyan-border)}.tag-badge--amber{background:var(--tag-amber-bg);color:var(--tag-amber-text);border-color:var(--tag-amber-border)}.tag-badge--red{background:var(--tag-red-bg);color:var(--tag-red-text);border-color:var(--tag-red-border)}.tag-badge--blue{background:var(--tag-blue-bg);color:var(--tag-blue-text);border-color:var(--tag-blue-border)}.tag-badge--violet{background:var(--tag-violet-bg);color:var(--tag-violet-text);border-color:var(--tag-violet-border)}.tag-badge--slate{background:var(--tag-slate-bg);color:var(--tag-slate-text);border-color:var(--tag-slate-border)}.tag-badge--emerald{background:var(--tag-emerald-bg);color:var(--tag-emerald-text);border-color:var(--tag-emerald-border)}.tag-badge:hover{opacity:.85}.divider{border:none;border-top:1px solid var(--border-default);margin:0;transition:border-color var(--duration-normal) var(--ease-smooth)}.section-label{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:var(--tracking-widest);color:var(--accent-500);display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-5);transition:color var(--duration-normal) var(--ease-smooth)}.section-label:after{content:"";flex:1 1;height:1px;background:var(--border-subtle)}.post-card{background:var(--surface-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden;transition:border-color var(--duration-normal) var(--ease-smooth),box-shadow var(--duration-normal) var(--ease-smooth),transform var(--duration-normal) var(--ease-smooth),background var(--duration-normal) var(--ease-smooth)}.post-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-4);transform:translateY(-3px)}.prose{font-family:var(--font-sans);font-size:var(--text-md);line-height:var(--leading-loose);color:var(--text-body)}.prose h1,.prose h2,.prose h3,.prose h4{font-family:var(--font-mono);font-weight:var(--weight-bold);color:var(--prose-heading);margin:var(--space-6) 0 var(--space-3);line-height:var(--leading-snug);transition:color var(--duration-normal) var(--ease-smooth)}.prose h1{font-size:var(--text-3xl);letter-spacing:var(--tracking-tight);margin-top:0}.prose h2{font-size:var(--text-xl);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-subtle);transition:border-color var(--duration-normal) var(--ease-smooth)}.prose h3{font-size:var(--text-lg)}.prose h4{font-size:var(--text-base);color:var(--text-secondary);font-weight:var(--weight-semibold);font-family:var(--font-sans)}.prose p{margin-bottom:var(--space-5)}.prose a{color:var(--prose-link);text-decoration:none;border-bottom:1px solid var(--border-accent);transition:border-color var(--duration-fast) var(--ease-smooth),color var(--duration-fast) var(--ease-smooth)}.prose a:hover{border-color:var(--accent-400)}.prose strong{color:var(--prose-strong);font-weight:var(--weight-semibold)}.prose em{font-style:italic}.prose ol,.prose ul{padding-left:var(--space-5);margin-bottom:var(--space-5)}.prose ul{list-style:none}.prose ul li:before{content:"›";color:var(--accent-400);font-weight:var(--weight-bold);display:inline-block;width:var(--space-4);margin-left:calc(-1 * var(--space-4))}.prose ol{list-style:decimal}.prose li{margin-bottom:var(--space-2)}.prose code{font-family:var(--font-mono);font-size:.85em;color:var(--code-text);background:var(--code-bg);padding:.15em .4em;border-radius:var(--radius-sm);border:1px solid var(--code-border);transition:background var(--duration-normal) var(--ease-smooth),color var(--duration-normal) var(--ease-smooth),border-color var(--duration-normal) var(--ease-smooth)}.prose pre code{background:transparent;border:none;padding:0;font-size:1em;color:inherit}.prose img{width:100%;border-radius:var(--radius-md);margin:var(--space-5) 0;border:1px solid var(--border-subtle);transition:border-color var(--duration-normal) var(--ease-smooth)}.prose blockquote{border-left:3px solid var(--accent-400);padding:var(--space-4) var(--space-5);margin:var(--space-6) 0;background:var(--blockquote-bg);border-radius:0 var(--radius-md) var(--radius-md) 0;color:var(--text-secondary);font-style:italic;font-family:var(--font-serif);transition:background var(--duration-normal) var(--ease-smooth),border-color var(--duration-normal) var(--ease-smooth)}.prose blockquote p:last-child{margin-bottom:0}.prose hr{border:0;border-top:1px solid var(--border-default);margin:var(--space-7) 0;transition:border-color var(--duration-normal) var(--ease-smooth)}.prose table{width:100%;margin-bottom:var(--space-5);border-collapse:collapse;font-size:var(--text-sm);border-radius:var(--radius-md);overflow:hidden}.prose table,.prose td,.prose th{border:1px solid var(--border-default);transition:border-color var(--duration-normal) var(--ease-smooth)}.prose td,.prose th{padding:var(--space-2) var(--space-4);text-align:left}.prose th{background:var(--surface-elevated);color:var(--prose-strong);font-weight:var(--weight-semibold);font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.prose td{color:var(--text-body)}.dot-grid{background-image:radial-gradient(circle,var(--border-subtle) 1px,transparent 1px);background-size:var(--space-7) var(--space-7)}.hover-accent:hover{color:var(--accent-500)!important}.hover-card:hover{border-color:var(--border-accent)!important;background:var(--hover-bg)!important}.hover-link:hover{color:var(--accent-500)!important}.reading-progress{position:fixed;top:0;left:0;width:100%;height:2px;background:transparent;z-index:var(--z-sticky);pointer-events:none}.reading-progress__bar{height:100%;background:linear-gradient(90deg,var(--accent-400),var(--accent-500));transform-origin:left;transition:transform .1s linear}.code-toolbar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-4);background:var(--surface-sunken);border-bottom:1px solid var(--border-subtle);font-family:var(--font-mono);font-size:var(--text-2xs)}.code-toolbar__lang{color:var(--accent-500);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:var(--tracking-widest)}.code-toolbar__filename{color:var(--text-ghost)}.code-toolbar__copy{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--surface-elevated);color:var(--text-muted);font-family:var(--font-mono);font-size:var(--text-2xs);cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth)}.code-toolbar__copy:hover{color:var(--accent-500);border-color:var(--border-accent);background:var(--tag-cyan-bg)}--card-bg:var(--surface-elevated);--card-border:var(--border-subtle);--card-radius:var(--radius-md);--card-shadow:var(--shadow-2);--card-padding:var(--space-4);--card-hover-border:var(--border-accent);--card-hover-shadow:var(--shadow-4);--card-hover-transform:translateY(-3px);--section-padding-y:var(--space-7);.terminal-prompt{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--accent-500);display:flex;align-items:center;gap:var(--space-2);transition:color var(--duration-normal) var(--ease-smooth)}.terminal-prompt__symbol{color:var(--text-ghost);-webkit-user-select:none;-moz-user-select:none;user-select:none}.terminal-prompt__command{color:var(--text-primary);font-weight:var(--weight-medium)}.terminal-prompt__cursor{display:inline-block;width:2px;height:1em;background:var(--accent-500);animation:cursor-blink .8s var(--ease-smooth) infinite;vertical-align:text-bottom;margin-left:2px}:root{--accent-50:#ecfdf5;--accent-100:#d1fae5;--accent-200:#a7f3d0;--accent-300:#6ee7b7;--accent-400:#34d399;--accent-500:#10b981;--accent-600:#059669;--amber-50:#fffbeb;--amber-100:#fef3c7;--amber-200:#fde68a;--amber-300:#fcd34d;--amber-400:#fbbf24;--amber-500:#d97706;--amber-600:#b45309;--success-50:#f0fdf4;--success-500:#22c55e;--success-600:#16a34a;--warning-50:#fffbeb;--warning-500:#f59e0b;--warning-600:#d97706;--info-50:#eff6ff;--info-500:#3b82f6;--info-600:#2563eb;--danger-50:#fef2f2;--danger-500:#ef4444;--danger-600:#dc2626;--surface-base:#fafaf8;--surface-elevated:#ffffff;--surface-sunken:#f0f0ee;--surface-overlay:rgba(255,255,255,0.95);--text-primary:#0f0f12;--text-body:#2a2a35;--text-secondary:#3a3a44;--text-muted:#5c5c6b;--text-ghost:#8a8a96;--border-subtle:#ecece8;--border-default:#e4e4e0;--border-strong:#d4d4ce;--border-accent:rgba(0,122,100,0.25);--code-bg:rgba(0,122,100,0.06);--code-text:#059669;--code-border:rgba(0,122,100,0.20);--blockquote-bg:rgba(0,122,100,0.04);--blockquote-border:rgba(0,122,100,0.20);--prose-link:#059669;--prose-strong:#0f0f12;--prose-heading:#111114;--header-bg:rgba(250,250,248,0.92);--header-border:#e4e4e0;--tag-cyan-bg:rgba(0,122,100,0.08);--tag-cyan-text:#059669;--tag-cyan-border:rgba(0,122,100,0.25);--tag-amber-bg:rgba(251,191,36,0.10);--tag-amber-text:#d97706;--tag-amber-border:rgba(251,191,36,0.30);--tag-red-bg:rgba(239,68,68,0.08);--tag-red-text:#dc2626;--tag-red-border:rgba(239,68,68,0.25);--tag-blue-bg:rgba(59,130,246,0.08);--tag-blue-text:#2563eb;--tag-blue-border:rgba(59,130,246,0.25);--tag-violet-bg:rgba(139,92,246,0.08);--tag-violet-text:#7c3aed;--tag-violet-border:rgba(139,92,246,0.25);--tag-slate-bg:rgba(100,116,139,0.08);--tag-slate-text:#475569;--tag-slate-border:rgba(100,116,139,0.20);--tag-emerald-bg:rgba(16,185,129,0.08);--tag-emerald-text:#059669;--tag-emerald-border:rgba(16,185,129,0.25);--shadow-1:0 1px 2px rgba(0,0,0,0.04);--shadow-2:0 2px 8px rgba(0,0,0,0.06);--shadow-3:0 4px 16px rgba(0,0,0,0.08);--shadow-4:0 8px 32px rgba(0,0,0,0.12);--shadow-glow:0 0 20px rgba(0,122,100,0.15);--shadow-glow-lg:0 0 40px rgba(0,122,100,0.20);--nav-link:#4a4a52;--nav-link-hover:#0f0f12;--nav-active:#059669;--nav-active-bg:rgba(0,122,100,0.08);--scrollbar-track:#f4f4f2;--scrollbar-thumb:#d0d0cc;--selection-bg:rgba(0,122,100,0.18);--selection-text:#0f0f12;--hover-bg:#f0f0ee;--hover-bg-light:#ecece6}html.dark{--accent-50:#ecfdf5;--accent-100:#064e3b;--accent-200:#065f46;--accent-300:#047857;--accent-400:#10b981;--accent-500:#34d399;--accent-600:#6ee7b7;--amber-50:#451a03;--amber-100:#451a03;--amber-200:#78350f;--amber-300:#92400e;--amber-400:#fbbf24;--amber-500:#f59e0b;--amber-600:#d97706;--success-50:#052e16;--success-500:#4ade80;--success-600:#22c55e;--warning-50:#451a03;--warning-500:#fbbf24;--warning-600:#f59e0b;--info-50:#172554;--info-500:#60a5fa;--info-600:#3b82f6;--danger-50:#450a0a;--danger-500:#f87171;--danger-600:#ef4444;--surface-base:#0a0f14;--surface-elevated:#111820;--surface-sunken:#070a0e;--surface-overlay:rgba(17,24,32,0.95);--text-primary:#f0f4f8;--text-body:#c8d0d8;--text-secondary:#8896a8;--text-muted:#8896a8;--text-ghost:#5a6878;--border-subtle:#141e2a;--border-default:#21262d;--border-strong:#30363d;--border-accent:rgba(0,212,170,0.30);--code-bg:rgba(0,212,170,0.07);--code-text:#6ee7b7;--code-border:rgba(0,212,170,0.15);--blockquote-bg:rgba(0,212,170,0.04);--blockquote-border:rgba(0,212,170,0.15);--prose-link:#6ee7b7;--prose-strong:#e8edf3;--prose-heading:#f0f4f8;--header-bg:rgba(8,12,16,0.92);--header-border:#141e2a;--tag-cyan-bg:rgba(0,212,170,0.10);--tag-cyan-text:#6ee7b7;--tag-cyan-border:rgba(0,212,170,0.30);--tag-amber-bg:rgba(251,191,36,0.10);--tag-amber-text:#fbbf24;--tag-amber-border:rgba(251,191,36,0.30);--tag-red-bg:rgba(239,68,68,0.10);--tag-red-text:#f87171;--tag-red-border:rgba(239,68,68,0.30);--tag-blue-bg:rgba(59,130,246,0.10);--tag-blue-text:#60a5fa;--tag-blue-border:rgba(59,130,246,0.30);--tag-violet-bg:rgba(139,92,246,0.10);--tag-violet-text:#a78bfa;--tag-violet-border:rgba(139,92,246,0.30);--tag-slate-bg:rgba(148,163,184,0.08);--tag-slate-text:#94a3b8;--tag-slate-border:rgba(148,163,184,0.20);--tag-emerald-bg:rgba(16,185,129,0.10);--tag-emerald-text:#34d399;--tag-emerald-border:rgba(16,185,129,0.30);--shadow-1:0 1px 2px rgba(0,0,0,0.20);--shadow-2:0 2px 8px rgba(0,0,0,0.30);--shadow-3:0 4px 16px rgba(0,0,0,0.40);--shadow-4:0 8px 32px rgba(0,0,0,0.50);--shadow-glow:0 0 20px rgba(0,212,170,0.12);--shadow-glow-lg:0 0 40px rgba(0,212,170,0.18);--nav-link:#64748b;--nav-link-hover:#e2e8f0;--nav-active:#34d399;--nav-active-bg:rgba(0,212,170,0.08);--scrollbar-track:#0d1117;--scrollbar-thumb:#21262d;--selection-bg:rgba(0,212,170,0.20);--selection-text:#e6edf3;--hover-bg:#1c2128;--hover-bg-light:#161b22}:root{--font-mono:"JetBrains Mono","IBM Plex Mono",ui-monospace,monospace;--font-sans:"IBM Plex Sans",ui-sans-serif,system-ui,sans-serif;--font-serif:"Source Serif 4","Merriweather",Georgia,serif;--text-2xs:0.625rem;--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-md:1.125rem;--text-lg:1.25rem;--text-xl:1.5rem;--text-2xl:1.875rem;--text-3xl:2.25rem;--text-4xl:3rem;--leading-none:1.0;--leading-tight:1.2;--leading-snug:1.3;--leading-normal:1.5;--leading-relaxed:1.7;--leading-loose:1.9;--weight-normal:400;--weight-medium:500;--weight-semibold:600;--weight-bold:700;--weight-extrabold:800;--tracking-tight:-0.03em;--tracking-normal:0;--tracking-wide:0.05em;--tracking-wider:0.08em;--tracking-widest:0.12em;--space-0:0;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.5rem;--space-6:2rem;--space-7:3rem;--space-8:4rem;--space-9:6rem;--space-10:8rem;--space-content-xs:0.5rem;--space-content-sm:0.75rem;--space-content-md:1.25rem;--space-content-lg:2rem;--space-content-xl:3rem;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-2xl:28px;--radius-full:999px;--ease-smooth:cubic-bezier(0.4,0,0.2,1);--ease-bounce:cubic-bezier(0.34,1.56,0.64,1);--ease-out:cubic-bezier(0,0,0.2,1);--ease-in:cubic-bezier(0.4,0,1,1);--ease-in-out:cubic-bezier(0.4,0,0.2,1);--duration-instant:50ms;--duration-fast:100ms;--duration-normal:200ms;--duration-slow:300ms;--duration-slower:500ms;--duration-slowest:800ms;--z-base:0;--z-raised:10;--z-dropdown:100;--z-sticky:200;--z-overlay:300;--z-modal:400;--z-toast:500;--container-max:1200px;--container-narrow:720px;--container-wide:1000px;--container-padding:1.5rem;--bp-xs:0px;--bp-sm:480px;--bp-md:768px;--bp-lg:1024px;--bp-xl:1280px}@keyframes cursor-blink{0%,to{opacity:1}50%{opacity:0}}@keyframes stagger-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes checkmark-draw{0%{stroke-dashoffset:24}to{stroke-dashoffset:0}}@keyframes pulse-dot{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes glow-pulse{0%,to{box-shadow:0 0 12px rgba(0,122,100,.15)}50%{box-shadow:0 0 24px rgba(0,122,100,.25)}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes progress-fill{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.stagger-in{animation:stagger-in .4s var(--ease-out) both}.stagger-children>:first-child{animation-delay:0s}.stagger-children>:nth-child(2){animation-delay:60ms}.stagger-children>:nth-child(3){animation-delay:.12s}.stagger-children>:nth-child(4){animation-delay:.18s}.stagger-children>:nth-child(5){animation-delay:.24s}.stagger-children>:nth-child(6){animation-delay:.3s}.stagger-children>:nth-child(7){animation-delay:.36s}.stagger-children>:nth-child(8){animation-delay:.42s}.stagger-children-sm>:first-child{animation-delay:0s}.stagger-children-sm>:nth-child(2){animation-delay:50ms}.stagger-children-sm>:nth-child(3){animation-delay:.1s}.stagger-children-sm>:nth-child(4){animation-delay:.15s}.cursor-blink{display:inline-block;animation:cursor-blink .8s var(--ease-smooth) infinite;color:var(--accent-500)}.pulse-dot{animation:pulse-dot 1.5s ease-in-out infinite}.skeleton{background:linear-gradient(90deg,var(--surface-sunken) 25%,var(--surface-elevated) 50%,var(--surface-sunken) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}.fade-in{animation:fade-in .3s var(--ease-out) both}.scale-in{animation:scale-in .2s var(--ease-bounce) both}.spin{animation:spin .8s linear infinite}.float{animation:float 3s ease-in-out infinite}.glow-pulse{animation:glow-pulse 2s ease-in-out infinite}.transition-all{transition:all var(--duration-normal) var(--ease-smooth)}.transition-colors{transition:background-color var(--duration-normal) var(--ease-smooth),border-color var(--duration-normal) var(--ease-smooth),color var(--duration-fast) var(--ease-smooth)}.transition-transform{transition:transform var(--duration-normal) var(--ease-smooth)}.transition-shadow{transition:box-shadow var(--duration-normal) var(--ease-smooth)}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.cursor-blink{opacity:1}.cursor-blink,.float,.glow-pulse,.pulse-dot,.skeleton{animation:none}.skeleton{background:var(--surface-sunken)}.stagger-in{animation:none;opacity:1;transform:none}}