@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&family=Noto+Serif+SC:wght@400;500;700&display=swap";:root{--content-card-height: 252px;--layout-gutter: 1.5rem;--layout-wide-width: 80vw;--color-bg: #0a0a0f;--color-bg-2: #111118;--color-bg-3: #1a1a24;--color-surface: #16161f;--color-surface-2: #1e1e2e;--color-border: rgba(255, 255, 255, .08);--color-border-hover: rgba(255, 255, 255, .16);--color-text: #e8e8f0;--color-text-muted: #8888a8;--color-text-dim: #5a5a7a;--color-accent: #7c6af7;--color-accent-2: #a78bfa;--color-accent-glow: rgba(124, 106, 247, .3);--color-green: #4ade80;--color-blue: #60a5fa;--color-pink: #f472b6;--glass-panel: rgba(20, 20, 30, .72);--glass-panel-strong: rgba(28, 28, 40, .84);--glass-overlay: linear-gradient(180deg, rgba(255, 255, 255, .12), rgba(255, 255, 255, .03));--glass-outline: rgba(255, 255, 255, .08);--glass-outline-hover: rgba(255, 255, 255, .16);--glass-shadow: 0 16px 40px rgba(0, 0, 0, .36);--font-sans: "Inter", "Noto Serif SC", -apple-system, sans-serif;--font-mono: "JetBrains Mono", monospace;--font-serif: "Noto Serif SC", serif;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 18px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0,0,0,.4);--shadow-md: 0 4px 20px rgba(0,0,0,.5);--shadow-glow: 0 0 40px rgba(124, 106, 247, .15);--transition: .2s ease;--transition-slow: .4s cubic-bezier(.16, 1, .3, 1)}[data-theme=light]{--color-bg: #eef3f9;--color-bg-2: #e8eef7;--color-bg-3: #dde5f1;--color-surface: rgba(250, 252, 255, .86);--color-surface-2: #eef4fb;--color-border: rgba(70, 96, 132, .11);--color-border-hover: rgba(70, 96, 132, .2);--color-text: #1f2b3a;--color-text-muted: #546577;--color-text-dim: #8796a8;--color-accent: #4f6df5;--color-accent-2: #6f82ff;--color-accent-glow: rgba(79, 109, 245, .18);--color-green: #4aa48a;--color-blue: #5f9bd8;--color-pink: #b47ce6;--glass-panel: rgba(255, 255, 255, .72);--glass-panel-strong: rgba(250, 252, 255, .86);--glass-overlay: linear-gradient(180deg, rgba(255, 255, 255, .8), rgba(255, 255, 255, .22));--glass-outline: rgba(79, 109, 245, .12);--glass-outline-hover: rgba(79, 109, 245, .22);--glass-shadow: 0 18px 36px rgba(54, 76, 106, .12);--shadow-sm: 0 1px 3px rgba(54, 76, 106, .06);--shadow-md: 0 14px 34px rgba(54, 76, 106, .11);--shadow-glow: 0 0 40px rgba(79, 109, 245, .08)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:18px;background-color:var(--color-bg);color-scheme:dark}html[data-theme=light]{color-scheme:light}body{font-family:var(--font-sans);background-color:var(--color-bg);background-image:radial-gradient(circle at top,rgba(124,106,247,.16),transparent 34%),radial-gradient(circle at 82% 18%,rgba(96,165,250,.11),transparent 20%),linear-gradient(180deg,var(--color-bg),var(--color-bg-2));min-height:100vh;color:var(--color-text);line-height:1.7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s,color .3s}[data-theme=light] body{background-image:radial-gradient(circle at top,rgba(79,109,245,.09),transparent 34%),radial-gradient(circle at 82% 16%,rgba(95,155,216,.1),transparent 18%),linear-gradient(180deg,var(--color-bg),var(--color-bg-2));position:relative}[data-theme=light] body:before{content:"";position:fixed;inset:0;pointer-events:none;background-image:linear-gradient(rgba(79,109,245,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(79,109,245,.05) 1px,transparent 1px);background-size:42px 42px;mask-image:linear-gradient(180deg,rgba(0,0,0,.45),transparent 72%);opacity:.45}img,video{max-width:100%;height:auto;display:block}a{color:var(--color-accent-2);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--color-accent)}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.25;letter-spacing:-.02em;color:var(--color-text)}h1{font-size:clamp(1.8rem,4vw,2.8rem)}h2{font-size:clamp(1.4rem,3vw,2rem)}h3{font-size:clamp(1.1rem,2vw,1.4rem)}p{margin-bottom:1.2em;color:var(--color-text)}code{font-family:var(--font-mono);font-size:.88em;background:var(--color-surface-2);padding:.15em .45em;border-radius:var(--radius-sm);color:var(--color-accent-2)}pre{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.5rem;overflow-x:auto;margin:1.5rem 0}pre code{background:none;padding:0;color:var(--color-text);font-size:.9rem}blockquote{border-left:3px solid var(--color-accent);padding:.8rem 1.2rem;margin:1.5rem 0;background:var(--color-surface);border-radius:0 var(--radius-md) var(--radius-md) 0;font-style:italic;color:var(--color-text-muted)}hr{border:none;height:1px;background:var(--color-border);margin:2rem 0}.container{max-width:960px;margin:0 auto;padding:0 var(--layout-gutter)}.container-wide{max-width:var(--layout-wide-width);margin:0 auto;padding:0 var(--layout-gutter)}.container-detail{max-width:60vw;margin:0 auto;padding:0 var(--layout-gutter)}main{min-height:calc(100vh - 160px);padding-top:2rem;padding-bottom:4rem}.site-header{position:sticky;top:0;z-index:100;background:var(--glass-overlay),var(--glass-panel);backdrop-filter:blur(28px) saturate(180%);-webkit-backdrop-filter:blur(28px) saturate(180%);border-bottom:1px solid var(--glass-outline);box-shadow:inset 0 1px #ffffff14;transition:background .3s,border-color .3s}.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px;max-width:var(--layout-wide-width);margin:0 auto;padding:0 var(--layout-gutter);position:relative}.nav-logo{font-size:1.1rem;font-weight:700;color:var(--color-text)!important;display:flex;align-items:center;gap:8px;flex-shrink:0}.nav-logo-dot{width:8px;height:8px;border-radius:50%;background:var(--color-accent);box-shadow:0 0 10px var(--color-accent-glow)}.nav-links{display:flex;align-items:center;gap:2.5rem;list-style:none;position:absolute;left:50%;transform:translate(-50%)}.nav-links a{color:var(--color-text-muted);font-size:.95rem;font-weight:500;padding:.5rem .25rem;border-radius:var(--radius-full);transition:color var(--transition);position:relative}.nav-links a:hover,.nav-links a.active{color:var(--color-text)}.nav-links a.active:after{content:"";position:absolute;bottom:2px;left:50%;transform:translate(-50%);width:4px;height:4px;border-radius:50%;background:var(--color-accent);pointer-events:none}.theme-toggle{width:36px;height:36px;border-radius:50%;border:1px solid var(--glass-outline);background:var(--glass-overlay),var(--glass-panel);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all var(--transition);box-shadow:inset 0 1px #ffffff14;flex-shrink:0}.theme-toggle:hover{border-color:var(--glass-outline-hover);box-shadow:inset 0 1px #ffffff24,var(--glass-shadow)}.theme-toggle:focus-visible,.nav-links a:focus-visible,.btn-primary:focus-visible,.btn-secondary:focus-visible,.post-card:focus-visible,.section-link:focus-visible,.site-footer a:focus-visible{outline:2px solid var(--color-accent-2);outline-offset:3px}.site-footer{border-top:1px solid var(--color-border);padding:2rem 0;text-align:center;color:var(--color-text-dim);font-size:.85rem}.site-footer a{color:var(--color-text-muted)}.site-footer a:hover{color:var(--color-accent-2)}.hero{padding:5rem 0 4rem;position:relative}.hero-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(420px,.95fr);gap:2rem;align-items:stretch}.hero-copy{display:flex;flex-direction:column;justify-content:center;min-width:0}.hero-badge{display:inline-flex;align-items:center;gap:6px;background:var(--glass-overlay),var(--glass-panel);border:1px solid var(--glass-outline);border-radius:var(--radius-full);padding:.35rem .9rem;font-size:.8rem;color:var(--color-text-muted);margin-bottom:1.5rem;backdrop-filter:blur(18px) saturate(180%);-webkit-backdrop-filter:blur(18px) saturate(180%);box-shadow:inset 0 1px #ffffff14}.hero-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--color-blue);box-shadow:0 0 10px var(--color-blue);animation:pulse 2s ease infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.9)}}.hero-title{font-size:clamp(2.2rem,6vw,4rem);font-weight:800;letter-spacing:-.03em;line-height:1.1;margin-bottom:1.25rem}.hero-title-gradient{background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-blue) 52%,var(--color-pink) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:1.15rem;color:var(--color-text-muted);max-width:560px;line-height:1.8;margin-bottom:2.5rem}.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--color-accent);color:#fff!important;padding:.75rem 1.5rem;border-radius:var(--radius-full);font-weight:600;font-size:.95rem;transition:all var(--transition);box-shadow:0 0 0 0 var(--color-accent-glow)}.btn-primary:hover{background:var(--color-accent-2);transform:translateY(-1px);box-shadow:0 8px 25px var(--color-accent-glow)}.btn-secondary{display:inline-flex;align-items:center;gap:8px;background:var(--glass-overlay),var(--glass-panel);color:var(--color-text)!important;padding:.75rem 1.5rem;border-radius:var(--radius-full);font-weight:600;font-size:.95rem;border:1px solid var(--glass-outline);transition:all var(--transition);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);box-shadow:inset 0 1px #ffffff14}.btn-secondary:hover{border-color:var(--glass-outline-hover);transform:translateY(-1px);box-shadow:inset 0 1px #ffffff24,var(--glass-shadow)}.github-activity-card{display:flex;align-items:center;min-height:100%}.github-activity-chart-frame{width:100%}.github-activity-chart{width:100%;min-height:220px;object-fit:contain;object-position:center;opacity:.6;filter:contrast(1.05);transition:opacity .3s ease}.github-activity-chart:hover{opacity:.85}[data-theme=light] .github-activity-chart{opacity:1;filter:contrast(1.3) brightness(.95)}[data-theme=light] .github-activity-chart:hover{opacity:1}.github-activity-fallback{display:none;min-height:180px;place-items:center;text-align:center;color:var(--color-text-muted);font-size:.92rem;line-height:1.7;padding:1.5rem}.github-activity-card[data-chart-state=error] .github-activity-chart{display:none}.github-activity-card[data-chart-state=error] .github-activity-fallback{display:grid}.hero-aside{display:flex;flex-direction:column;gap:1rem}.hero-aside-actions{display:flex;justify-content:flex-end}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.section-title{font-size:1.3rem;font-weight:700}.section-link{font-size:.85rem;color:var(--color-text-muted);display:flex;align-items:center;gap:4px}.section-link:hover{color:var(--color-accent-2)}.post-grid{display:grid;gap:1rem}.content-card{display:grid;grid-template-columns:minmax(180px,.8fr) minmax(0,1.2fr);gap:1rem;padding:1rem;min-height:var(--content-card-height);height:var(--content-card-height);border:1px solid var(--color-border);border-radius:20px;background:linear-gradient(180deg,#ffffff05,#fff0);box-shadow:var(--shadow-md);color:inherit;position:relative;overflow:hidden;transition:transform var(--transition-slow),border-color var(--transition),background var(--transition),box-shadow var(--transition-slow)}.content-card:hover{border-color:var(--color-border-hover);transform:translateY(-2px);background:linear-gradient(180deg,#ffffff0a,#ffffff03);box-shadow:0 24px 48px #00000038}.content-card__visual{position:relative;height:100%;padding:1rem;border-radius:16px;overflow:hidden;background:radial-gradient(circle at 20% 20%,rgba(124,106,247,.28),transparent 28%),radial-gradient(circle at 80% 75%,rgba(96,165,250,.22),transparent 24%),linear-gradient(160deg,#171727,#10101a);border:1px solid rgba(255,255,255,.06)}.content-card__lines{position:absolute;inset:0;pointer-events:none}.content-card__lines span{position:absolute;height:1px;background:linear-gradient(90deg,#7c6af700,#7c6af78c,#7c6af700)}.content-card__lines span:nth-child(1){width:58%;top:28%;left:14%}.content-card__lines span:nth-child(2){width:46%;top:41%;right:10%}.content-card__lines span:nth-child(3){width:52%;bottom:29%;left:18%}.content-card__body{display:grid;gap:.8rem;align-content:start}.post-card-meta{display:flex;align-items:center;flex-wrap:wrap;gap:.75rem;font-size:.8rem;color:var(--color-text-muted);font-weight:600}.post-card-tags{position:absolute;bottom:1rem;left:1rem;right:1rem;display:flex;flex-wrap:wrap;gap:.55rem;z-index:2}.post-tag{display:inline-block;background:#ffffff0d;color:var(--color-text-muted);padding:.45rem .7rem;border-radius:var(--radius-full);font-size:.78rem;font-weight:600;border:1px solid var(--color-border);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.post-card-title{font-size:clamp(1.15rem,1.8vw,1.4rem);font-weight:700;color:var(--color-text);transition:color var(--transition);line-height:1.35}.content-card:hover .post-card-title{color:var(--color-accent-2)}.post-card-desc{font-size:.9rem;color:var(--color-text-muted);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}@media(max-width:640px){.hero{padding-top:3.75rem}.github-activity-chart-frame{min-height:170px}.github-activity-chart,.github-activity-fallback{min-height:130px}.content-card{grid-template-columns:1fr}.content-card__visual{min-height:200px}}.post-header{padding:3rem 0 2rem;border-bottom:1px solid var(--color-border);margin-bottom:2.5rem}.post-title{font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:1rem;line-height:1.2}.post-meta{display:flex;align-items:center;flex-wrap:wrap;gap:1rem;font-size:.875rem;color:var(--color-text-muted)}.post-meta-divider{width:4px;height:4px;border-radius:50%;background:var(--color-text-dim)}.post-content{max-width:820px;margin:0 auto}.post-content h2{margin-top:2.5rem;margin-bottom:1rem}.post-content h3{margin-top:2rem;margin-bottom:.75rem}.post-content ul,.post-content ol{padding-left:1.5rem;margin-bottom:1.2rem}.post-content li{margin-bottom:.4rem}.post-content img{border-radius:var(--radius-md);margin:1.5rem 0}.tags-list{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0}.tag-pill{background:var(--glass-overlay),var(--glass-panel);border:1px solid var(--glass-outline);color:var(--color-text-muted);padding:.3rem .8rem;border-radius:var(--radius-full);font-size:.8rem;transition:all var(--transition);backdrop-filter:blur(18px) saturate(180%);-webkit-backdrop-filter:blur(18px) saturate(180%)}.tag-pill:hover{border-color:var(--glass-outline-hover);color:var(--color-accent-2);box-shadow:var(--glass-shadow)}.about-hero{padding:4rem 0;text-align:center}.avatar{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,var(--color-accent),var(--color-blue));display:flex;align-items:center;justify-content:center;font-size:2.5rem;margin:0 auto 1.5rem;box-shadow:0 0 40px var(--color-accent-glow)}.skill-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem;margin:1rem 0}.skill-badge{background:var(--glass-overlay),var(--glass-panel);border:1px solid var(--glass-outline);border-radius:var(--radius-md);padding:.75rem .5rem;text-align:center;font-size:.8rem;font-weight:500;color:var(--color-text-muted);transition:all var(--transition);backdrop-filter:blur(18px) saturate(180%);-webkit-backdrop-filter:blur(18px) saturate(180%)}.skill-badge:hover{border-color:var(--glass-outline-hover);color:var(--color-text);box-shadow:var(--glass-shadow)}.divider{height:1px;background:linear-gradient(90deg,transparent,var(--color-border),transparent);margin:3rem 0}.reading-time{display:inline-flex;align-items:center;gap:4px}.pinned-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}.pinned-section{display:flex;flex-direction:column}.pinned-list{display:grid;gap:1rem}.pinned-section .content-card--post,.pinned-section .content-card--project{margin-bottom:0}@media(max-width:900px){.hero-grid{grid-template-columns:1fr}.pinned-grid{grid-template-columns:1fr;gap:2rem}}.content-card--project .content-card__body{min-height:0;overflow-y:auto;padding-right:.25rem;overscroll-behavior:contain;scrollbar-width:thin}.project-top{display:flex;align-items:center;justify-content:space-between;gap:1rem}.project-meta{display:inline-flex;align-items:center;gap:.45rem;color:var(--color-text-muted);font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--color-green);box-shadow:0 0 12px #4ade8073}.project-top h3{font-size:clamp(1.2rem,1.8vw,1.5rem)}.project-summary{color:var(--color-text-muted);margin:0}.tag-list{position:absolute;bottom:1rem;left:1rem;right:1rem;display:flex;flex-wrap:wrap;gap:.55rem;z-index:2}.tag{padding:.45rem .7rem;border-radius:var(--radius-full);background:#ffffff0d;border:1px solid var(--color-border);color:var(--color-text-muted);font-size:.82rem;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.highlight-list{display:grid;gap:.55rem;padding-left:1.1rem;margin:0;color:var(--color-text);font-size:.92rem}.highlight-list li{color:var(--color-text-muted)}@media(max-width:640px){.hero{padding:3rem 0 2.5rem}.nav-links{display:none}.section-header{flex-direction:column;align-items:flex-start;gap:.5rem}.content-card{grid-template-columns:1fr;min-height:auto;height:auto}.content-card__visual{height:auto}}
