@import"https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=JetBrains+Mono:wght@400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #fafafa;--color-surface: #ffffff;--color-surface-alt: #f4f4f5;--color-surface-raised: #ffffff;--color-text: #18181b;--color-text-muted: #71717a;--color-text-subtle: #a1a1aa;--color-accent: #6366f1;--color-accent-hover: #4f46e5;--color-accent-soft: rgba(99, 102, 241, .08);--color-accent-glow: rgba(99, 102, 241, .15);--color-accent-2: #a855f7;--color-accent-3: #ec4899;--color-border: #e4e4e7;--color-border-subtle: #f4f4f5;--color-tag-bg: #eef2ff;--color-tag-text: #4338ca;--color-code-bg: #f4f4f5;--color-code-text: #18181b;--color-card-shadow: rgba(0, 0, 0, .04);--color-card-shadow-hover: rgba(99, 102, 241, .14);--color-hero-gradient: linear-gradient(135deg, #6366f1 0%, #a855f7 50%, #ec4899 100%);--color-header-bg: rgba(250, 250, 250, .8);--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "Cascadia Code", monospace;--max-width: 740px;--header-height: 64px;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--space-4xl: 6rem;--radius-sm: 6px;--radius: 10px;--radius-lg: 16px;--radius-xl: 24px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--ease-spring: cubic-bezier(.16, 1, .3, 1);color-scheme:light dark}@media(prefers-color-scheme:dark){:root{--color-bg: #09090b;--color-surface: #111113;--color-surface-alt: #1c1c1f;--color-surface-raised: #18181b;--color-text: #fafafa;--color-text-muted: #a1a1aa;--color-text-subtle: #71717a;--color-accent: #818cf8;--color-accent-hover: #a5b4fc;--color-accent-soft: rgba(129, 140, 248, .1);--color-accent-glow: rgba(129, 140, 248, .2);--color-border: #27272a;--color-border-subtle: #1e1e21;--color-tag-bg: rgba(99, 102, 241, .15);--color-tag-text: #a5b4fc;--color-code-bg: #1c1c1f;--color-code-text: #e4e4e7;--color-card-shadow: rgba(0, 0, 0, .3);--color-card-shadow-hover: rgba(129, 140, 248, .18);--color-header-bg: rgba(9, 9, 11, .8)}}html{font-family:var(--font-sans);color:var(--color-text);background-color:var(--color-bg);line-height:1.7;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden;background-image:radial-gradient(ellipse 70% 50% at 10% -10%,rgba(99,102,241,.13) 0%,transparent 100%),radial-gradient(ellipse 60% 45% at 90% -5%,rgba(168,85,247,.1) 0%,transparent 100%)}@media(prefers-color-scheme:dark){body{background-image:radial-gradient(ellipse 70% 50% at 10% -10%,rgba(99,102,241,.22) 0%,transparent 100%),radial-gradient(ellipse 60% 45% at 90% -5%,rgba(168,85,247,.16) 0%,transparent 100%)}}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-hover)}img{max-width:100%;height:auto;display:block}::selection{background:var(--color-accent);color:#fff}#reading-progress{position:fixed;top:0;left:0;height:2px;background:linear-gradient(90deg,#6366f1,#a855f7,#ec4899);z-index:200;width:0%;transition:width 80ms linear;border-radius:0 2px 2px 0;box-shadow:0 0 10px #6366f199,0 0 20px #a855f74d}.site-header{position:sticky;top:0;z-index:100;background:var(--color-header-bg);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--color-border);height:var(--header-height);transition:background var(--transition-base),border-color var(--transition-base)}.header-inner{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg);display:flex;align-items:center;justify-content:space-between;height:100%}.site-title{font-size:1.05rem;font-weight:800;letter-spacing:-.02em;text-decoration:none;background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent-2) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transition:opacity var(--transition-fast),transform var(--transition-fast)}.site-title:hover{opacity:.8;transform:scale(1.03)}.site-nav{display:flex;gap:var(--space-xs)}.site-nav a{font-size:.875rem;font-weight:500;color:var(--color-text-muted);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);transition:all var(--transition-fast);position:relative}.site-nav a:after{content:"";position:absolute;bottom:4px;left:50%;transform:translate(-50%) scaleX(0);width:calc(100% - 1.5rem);height:2px;background:linear-gradient(90deg,var(--color-accent),var(--color-accent-2));border-radius:2px;transition:transform var(--transition-fast)}.site-nav a:hover{color:var(--color-text);background:var(--color-accent-soft)}.site-nav a.active{color:var(--color-accent);background:var(--color-accent-soft);font-weight:600}.site-nav a.active:after,.site-nav a:hover:after{transform:translate(-50%) scaleX(1)}.site-main{flex:1;max-width:var(--max-width);width:100%;margin:0 auto;padding:var(--space-3xl) var(--space-lg)}.site-footer{border-top:1px solid var(--color-border);text-align:center;padding:var(--space-xl) var(--space-lg);font-size:.8rem;color:var(--color-text-subtle);letter-spacing:.01em}.site-footer a{color:var(--color-text-muted);font-weight:500;transition:color var(--transition-fast)}.site-footer a:hover{color:var(--color-accent)}.hero{min-height:calc(92vh - var(--header-height));display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-4xl) var(--space-lg) var(--space-3xl);text-align:center;position:relative;width:100vw;margin-left:calc(50% - 50vw);--hero-x: 50%;--hero-y: 30%}.hero:before{content:"";position:absolute;inset:-200px;background:radial-gradient(35% 40% at var(--hero-x) var(--hero-y),rgba(99,102,241,.14) 0%,rgba(168,85,247,.04) 40%,transparent 100%);pointer-events:none;transition:background .15s ease}.hero:after{content:"";position:absolute;bottom:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(99,102,241,.25),rgba(168,85,247,.2),rgba(236,72,153,.15),transparent);z-index:1}.hero>*{position:relative;z-index:1}.hero-stats{display:flex;align-items:center;gap:var(--space-2xl);margin-top:var(--space-xl)}.stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.stat-number{font-size:1.6rem;font-weight:900;letter-spacing:-.04em;line-height:1;background:linear-gradient(135deg,#6366f1,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 12px rgba(99,102,241,.2))}.stat-label{font-size:.7rem;color:var(--color-text-subtle);font-weight:500;letter-spacing:.02em;white-space:nowrap}.stat-sep{color:var(--color-border);font-size:1.4rem;line-height:1;user-select:none}.hero-badge{display:inline-flex;align-items:center;gap:var(--space-sm);padding:.35rem 1rem;background:var(--color-accent-soft);border:1px solid var(--color-accent-glow);color:var(--color-accent);font-size:.75rem;font-weight:600;border-radius:9999px;margin-bottom:var(--space-xl);letter-spacing:.06em;text-transform:uppercase;backdrop-filter:blur(12px) saturate(150%);box-shadow:0 0 20px #6366f114,inset 0 0 20px #6366f10d}.hero-badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor;box-shadow:0 0 8px currentColor;animation:pulse-dot 2s ease-in-out infinite}.hero h1{font-size:clamp(2.5rem,6vw,3.75rem);font-weight:900;letter-spacing:-.04em;line-height:1.05;margin-bottom:var(--space-lg)}.hero-gradient-text{background:linear-gradient(135deg,#6366f1,#818cf8,#a855f7,#c084fc,#ec4899 60%,#f472b6 70%,#a855f7,#6366f1);background-size:300% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 4s linear infinite;filter:drop-shadow(0 0 28px rgba(168,85,247,.25))}.hero p{font-size:1.1rem;color:var(--color-text-muted);max-width:520px;margin:0 auto;line-height:1.7}.hero-links{display:flex;gap:var(--space-md);justify-content:center;margin-top:var(--space-xl);flex-wrap:wrap}.hero-skills{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-sm);margin-top:var(--space-xl);padding-bottom:var(--space-sm)}.skill-chip{font-size:.72rem;font-weight:600;padding:.28rem .85rem;border-radius:9999px;background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-muted);font-family:var(--font-mono);transition:all var(--transition-fast);cursor:default;box-shadow:0 1px 3px var(--color-card-shadow)}.skill-chip:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-soft);transform:translateY(-2px);box-shadow:0 4px 12px var(--color-accent-glow)}.btn-primary{display:inline-flex;align-items:center;gap:var(--space-sm);padding:.7rem 1.6rem;background:linear-gradient(135deg,#6366f1,#a855f7);color:#fff;font-size:.9rem;font-weight:600;border-radius:var(--radius);transition:all var(--transition-base);border:none;position:relative;overflow:hidden}.btn-primary:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.18),transparent 60%);opacity:0;transition:opacity var(--transition-fast)}.btn-primary:hover:before{opacity:1}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px #6366f173,0 2px 8px #6366f133;color:#fff}.btn-primary:active{transform:translateY(0)}.btn-ghost{display:inline-flex;align-items:center;gap:var(--space-sm);padding:.7rem 1.6rem;background:transparent;color:var(--color-text-muted);font-size:.9rem;font-weight:500;border-radius:var(--radius);border:1px solid var(--color-border);transition:all var(--transition-base)}.btn-ghost:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-soft);transform:translateY(-1px)}.section-label{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-xl)}.section-label h2{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-subtle);white-space:nowrap;font-family:var(--font-mono)}.section-label:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--color-border),transparent)}.post-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-md)}.post-card{padding:var(--space-lg) var(--space-xl);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);transition:all var(--transition-base);position:relative}.post-card:before{content:"";position:absolute;inset:0;border-radius:var(--radius-lg);padding:1px;background:linear-gradient(135deg,#6366f1,#a855f7,#ec4899);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity var(--transition-base);pointer-events:none}.post-card:after{content:"";position:absolute;inset:0;border-radius:var(--radius-lg);background:radial-gradient(ellipse at top left,var(--color-accent-soft),transparent 60%);opacity:0;transition:opacity var(--transition-base);pointer-events:none}.post-card:hover:before{opacity:1}.post-card:hover:after{opacity:1}.post-card:hover{border-color:transparent;box-shadow:0 8px 32px var(--color-card-shadow-hover),0 2px 8px #0000000a;transform:translateY(-3px)}.post-card h2{font-size:1.1rem;font-weight:700;letter-spacing:-.02em;margin-bottom:var(--space-xs);line-height:1.3}.post-card h2 a{color:var(--color-text);transition:color var(--transition-fast)}.post-card h2 a:hover{color:var(--color-accent)}.post-meta{font-size:.75rem;color:var(--color-text-subtle);margin-bottom:var(--space-sm);font-weight:500;font-family:var(--font-mono);letter-spacing:.02em}.post-description{color:var(--color-text-muted);font-size:.9rem;line-height:1.65}.post-tags{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-sm)}.tag{display:inline-block;padding:.15rem .6rem;background:var(--color-tag-bg);color:var(--color-tag-text);font-size:.68rem;font-weight:600;border-radius:9999px;letter-spacing:.04em;text-transform:uppercase;font-family:var(--font-mono);transition:all var(--transition-fast)}.tag:hover{background:var(--color-accent-soft);color:var(--color-accent)}.carousel-viewport{overflow:hidden;position:relative;margin:0 calc(-1 * var(--space-sm));padding:0 var(--space-sm)}.carousel-track{display:flex;gap:var(--space-lg);scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;padding-bottom:var(--space-sm)}.carousel-nav{display:flex;gap:var(--space-xs);margin-left:auto;flex-shrink:0}.carousel-arrow{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.carousel-arrow:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-soft);box-shadow:0 4px 12px var(--color-accent-glow);transform:scale(1.08)}.carousel-arrow:active:not(:disabled){transform:scale(.95)}.carousel-arrow:disabled{opacity:.3;cursor:not-allowed}.featured-post-card{scroll-snap-align:start;display:flex;flex-direction:column;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden;text-decoration:none;color:inherit;position:relative;transition:all var(--transition-base);cursor:pointer;min-width:280px;max-width:320px;flex-shrink:0}.featured-post-card:before{content:"";position:absolute;inset:0;border-radius:var(--radius-xl);padding:1px;background:linear-gradient(135deg,#6366f1,#a855f7,#ec4899);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity var(--transition-base);pointer-events:none;z-index:2}.featured-post-card:hover:before{opacity:1}.featured-post-card:hover{border-color:transparent;box-shadow:0 20px 60px var(--color-card-shadow-hover),0 4px 12px #0000000f;transform:translateY(-6px)}.featured-post-img{position:relative;height:200px;overflow:hidden;flex-shrink:0}.featured-post-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease-spring)}.featured-post-card:hover .featured-post-img img{transform:scale(1.08)}.featured-post-img--1{background:linear-gradient(135deg,#6366f1,#818cf8 40%,#a78bfa)}.featured-post-img--2{background:linear-gradient(135deg,#a855f7,#c084fc 40%,#e879f9)}.featured-post-img--3{background:linear-gradient(135deg,#ec4899,#f472b6 40%,#fb7185)}.featured-post-pattern{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.featured-post-pattern svg{width:100%;height:100%;opacity:.9;transition:transform .5s var(--ease-spring)}.featured-post-card:hover .featured-post-pattern svg{transform:scale(1.1) rotate(3deg)}.featured-post-img:after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.12) 45%,rgba(255,255,255,.18) 50%,rgba(255,255,255,.12) 55%,transparent 60%);background-size:250% 100%;background-position:200% 0;transition:background-position .8s ease;pointer-events:none}.featured-post-card:hover .featured-post-img:after{background-position:-50% 0}.featured-post-body{padding:var(--space-lg) var(--space-xl) var(--space-xl);display:flex;flex-direction:column;flex:1}.featured-post-top{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);margin-bottom:var(--space-sm)}.featured-post-top .post-meta{margin-bottom:0}.featured-post-top .post-tags{margin-top:0}.featured-post-title{font-size:1.1rem;font-weight:700;letter-spacing:-.02em;line-height:1.35;color:var(--color-text);margin-bottom:var(--space-sm);transition:color var(--transition-fast)}.featured-post-card:hover .featured-post-title{color:var(--color-accent)}.featured-post-desc{font-size:.875rem;color:var(--color-text-muted);line-height:1.65;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.featured-post-readmore{display:inline-flex;align-items:center;gap:.4rem;margin-top:var(--space-md);font-size:.85rem;font-weight:600;color:var(--color-accent);transition:gap var(--transition-fast),color var(--transition-fast)}.featured-post-readmore .arrow{transition:transform var(--transition-fast);font-size:1.1em}.featured-post-card:hover .featured-post-readmore{gap:.7rem;color:var(--color-accent-hover)}.featured-post-card:hover .featured-post-readmore .arrow{transform:translate(4px)}.post-featured{padding:var(--space-xl);border:1px solid var(--color-border);border-radius:var(--radius-xl);background:var(--color-surface);transition:all var(--transition-base);position:relative}.post-featured:before{content:"";position:absolute;inset:0;border-radius:var(--radius-xl);padding:1px;background:linear-gradient(90deg,#6366f1,#a855f7,#ec4899,#a855f7,#6366f1);background-size:300% 100%;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.35;transition:opacity var(--transition-base);pointer-events:none}.post-featured:after{content:"";position:absolute;inset:0;border-radius:var(--radius-xl);background:radial-gradient(ellipse at top left,rgba(99,102,241,.06),transparent 60%);pointer-events:none}.post-featured:hover:before{opacity:1;animation:gradient-border-flow 2.5s linear infinite}.post-featured:hover{border-color:transparent;box-shadow:0 12px 40px var(--color-card-shadow-hover);transform:translateY(-3px)}.post-featured-label{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-accent);font-family:var(--font-mono);margin-bottom:var(--space-md);position:relative;z-index:1}.post-featured-label:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--color-accent);box-shadow:0 0 6px var(--color-accent);animation:pulse-dot 2s ease-in-out infinite}.post-featured .post-meta{position:relative;z-index:1}.post-featured h2{font-size:1.35rem;font-weight:800;letter-spacing:-.03em;line-height:1.25;margin-bottom:var(--space-sm);position:relative;z-index:1}.post-featured h2 a{color:var(--color-text);transition:color var(--transition-fast)}.post-featured h2 a:hover{color:var(--color-accent)}.post-featured .post-description,.post-featured .post-tags{position:relative;z-index:1}.post-read-more{display:inline-flex;align-items:center;gap:.4rem;margin-top:var(--space-md);font-size:.85rem;font-weight:600;color:var(--color-accent);transition:all var(--transition-fast);position:relative;z-index:1}.post-read-more:hover{gap:.65rem;color:var(--color-accent-hover)}.view-all{display:inline-flex;align-items:center;gap:.4rem;margin-top:var(--space-xl);font-size:.875rem;font-weight:600;color:var(--color-accent);transition:gap var(--transition-fast)}.view-all:hover{gap:.7rem}.view-all .arrow{transition:transform var(--transition-fast);font-size:1.1em}.view-all:hover .arrow{transform:translate(3px)}.page-header{margin-bottom:var(--space-2xl);padding-bottom:var(--space-xl);border-bottom:1px solid var(--color-border)}.page-header h1{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:900;letter-spacing:-.04em;line-height:1.15;margin-bottom:var(--space-sm)}.page-header .post-meta{margin-bottom:var(--space-sm)}.back-link{display:inline-flex;align-items:center;gap:.4rem;margin-top:var(--space-2xl);padding-top:var(--space-xl);border-top:1px solid var(--color-border);font-size:.875rem;font-weight:600;color:var(--color-text-muted);transition:all var(--transition-fast)}.back-link:hover{color:var(--color-accent);gap:.15rem}.back-link .arrow{transition:transform var(--transition-fast)}.back-link:hover .arrow{transform:translate(-3px)}.hero-image{width:100%;border-radius:var(--radius-lg);margin-bottom:var(--space-xl);border:1px solid var(--color-border);box-shadow:0 4px 24px var(--color-card-shadow)}.prose{font-size:1rem;line-height:1.85}.prose h1{font-size:2rem;font-weight:800;letter-spacing:-.03em;margin-bottom:var(--space-md);line-height:1.2}.prose h2{font-size:1.4rem;font-weight:700;letter-spacing:-.02em;margin-top:var(--space-2xl);margin-bottom:var(--space-md);line-height:1.3}.prose h3{font-size:1.15rem;font-weight:700;letter-spacing:-.01em;margin-top:var(--space-xl);margin-bottom:var(--space-sm)}.prose p{margin-bottom:var(--space-md)}.prose ul,.prose ol{margin-bottom:var(--space-md);padding-left:var(--space-xl)}.prose li{margin-bottom:var(--space-xs)}.prose li::marker{color:var(--color-accent)}.prose blockquote{border-left:2px solid var(--color-accent);padding:var(--space-md) var(--space-lg);background:var(--color-accent-soft);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--color-text-muted);margin-bottom:var(--space-md);font-style:italic}.prose code{font-family:var(--font-mono);background:var(--color-code-bg);color:var(--color-accent);padding:.15em .45em;border-radius:var(--radius-sm);font-size:.85em;font-weight:500;border:1px solid var(--color-border)}.prose pre{background:var(--color-surface-alt);border:1px solid var(--color-border);padding:var(--space-lg);border-radius:var(--radius);overflow-x:auto;margin-bottom:var(--space-md);line-height:1.6}.prose pre code{background:none;padding:0;border-radius:0;border:none;font-size:.85rem;color:var(--color-code-text)}.prose hr{border:none;border-top:1px solid var(--color-border);margin:var(--space-2xl) 0}.prose img{border-radius:var(--radius);margin:var(--space-lg) 0;border:1px solid var(--color-border);box-shadow:0 4px 16px var(--color-card-shadow)}.prose strong{font-weight:700;color:var(--color-text)}.prose a{text-decoration:underline;text-decoration-color:var(--color-accent-glow);text-underline-offset:3px;transition:text-decoration-color var(--transition-fast)}.prose a:hover{text-decoration-color:var(--color-accent)}@keyframes fade-in-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:0% center}to{background-position:200% center}}@keyframes blob-float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(25px,-35px) scale(1.06)}66%{transform:translate(-20px,18px) scale(.96)}}@keyframes pulse-dot{0%,to{opacity:1;box-shadow:0 0 0 0 currentColor}50%{opacity:.7;box-shadow:0 0 0 4px transparent}}@keyframes float-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fade-in-up .6s var(--ease-spring) both}.animate-in-delay-1{animation-delay:80ms}.animate-in-delay-2{animation-delay:.16s}.animate-in-delay-3{animation-delay:.24s}.animate-in-delay-4{animation-delay:.32s}[data-scroll]{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease-spring),transform .7s var(--ease-spring)}[data-scroll].in-view{opacity:1;transform:translateY(0)}[data-scroll][data-scroll-delay="1"]{transition-delay:80ms}[data-scroll][data-scroll-delay="2"]{transition-delay:.16s}[data-scroll][data-scroll-delay="3"]{transition-delay:.24s}[data-scroll][data-scroll-delay="4"]{transition-delay:.32s}.section-label[data-scroll]{transform:translate(-20px)}.section-label[data-scroll].in-view{transform:none}.services-grid [data-scroll]{transform:perspective(900px) rotateX(-28deg) translateY(40px)}.services-grid [data-scroll].in-view{transform:perspective(900px) rotateX(0) translateY(0)}.skills-grid [data-scroll]:nth-child(odd){transform:perspective(700px) rotateY(-14deg) translate(-24px)}.skills-grid [data-scroll]:nth-child(2n){transform:perspective(700px) rotateY(14deg) translate(24px)}.skills-grid [data-scroll].in-view{transform:none}.projects-grid [data-scroll]:nth-child(odd){transform:perspective(800px) rotateY(16deg) translate(-32px)}.projects-grid [data-scroll]:nth-child(2n){transform:perspective(800px) rotateY(-16deg) translate(32px)}.projects-grid [data-scroll].in-view{transform:none}.post-list [data-scroll]{transform:perspective(700px) rotateX(10deg) translateY(28px)}.post-list [data-scroll].in-view{transform:none}.contact-section[data-scroll]{transform:perspective(1400px) rotateX(8deg) scale(.96) translateY(28px)}.contact-section.in-view{transform:none}.about-content [data-scroll]:nth-child(odd){transform:translate(-18px)}.about-content [data-scroll]:nth-child(2n){transform:translate(18px)}.about-content [data-scroll].in-view{transform:none}@keyframes gradient-border-flow{0%{background-position:0% 50%}to{background-position:300% 50%}}@keyframes gradient-border-pulse{0%,to{background-position:0% 50%}50%{background-position:150% 50%}}.empty-state{text-align:center;padding:var(--space-4xl) var(--space-lg);color:var(--color-text-muted)}.empty-state p{font-size:.95rem}.site-main--wide{max-width:920px;padding-top:0}[data-scroll][data-anim=left]{transform:translate(-28px)}[data-scroll][data-anim=right]{transform:translate(28px)}[data-scroll][data-anim=left].in-view,[data-scroll][data-anim=right].in-view{transform:none}.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none}.hero-orb{position:absolute;border-radius:50%;pointer-events:none;will-change:transform}.hero-orb-1{width:800px;height:800px;background:radial-gradient(circle,rgba(99,102,241,.22) 0%,transparent 55%);top:-300px;left:-250px;animation:orb-drift-1 18s ease-in-out infinite}.hero-orb-2{width:650px;height:650px;background:radial-gradient(circle,rgba(168,85,247,.18) 0%,transparent 55%);top:5%;right:-200px;animation:orb-drift-2 22s ease-in-out infinite 3s}.hero-orb-3{width:450px;height:450px;background:radial-gradient(circle,rgba(236,72,153,.16) 0%,transparent 55%);bottom:-120px;left:25%;animation:orb-drift-3 15s ease-in-out infinite 7s}@keyframes orb-drift-1{0%,to{transform:translate(0)}33%{transform:translate(50px,-40px)}66%{transform:translate(-30px,50px)}}@keyframes orb-drift-2{0%,to{transform:translate(0)}33%{transform:translate(-40px,50px)}66%{transform:translate(25px,-30px)}}@keyframes orb-drift-3{0%,to{transform:translate(0) scale(1)}50%{transform:translate(20px,-30px) scale(1.12)}}.scroll-indicator{display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:var(--space-2xl);position:relative;z-index:1}.scroll-mouse{width:22px;height:36px;border:2px solid var(--color-text-subtle);border-radius:12px;position:relative;opacity:.4;transition:opacity var(--transition-base)}.scroll-indicator:hover .scroll-mouse{opacity:.7}.scroll-mouse-wheel{width:3px;height:8px;border-radius:2px;background:var(--color-accent);position:absolute;left:50%;top:7px;transform:translate(-50%);animation:scroll-wheel 2s ease-in-out infinite;box-shadow:0 0 6px var(--color-accent)}@keyframes scroll-wheel{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(14px)}}.scroll-label{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.16em;color:var(--color-text-subtle);font-family:var(--font-mono);opacity:.4}.hero-tagline{font-size:1.1rem;color:var(--color-text-muted);max-width:540px;margin:0 auto;line-height:1.75}.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}.service-card{padding:var(--space-xl);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);position:relative;transition:all var(--transition-base);display:flex;flex-direction:column;gap:var(--space-md);overflow:hidden;cursor:default}.service-card:before{content:"";position:absolute;inset:0;border-radius:var(--radius-xl);padding:1px;background:linear-gradient(90deg,#6366f1,#a855f7,#ec4899,#a855f7,#6366f1);background-size:300% 100%;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity var(--transition-base);pointer-events:none}.service-card:after{content:"";position:absolute;top:0;left:0;right:0;height:100px;background:linear-gradient(160deg,var(--color-accent-soft),transparent 70%);opacity:0;transition:opacity var(--transition-slow);pointer-events:none}.service-card:hover:before{opacity:1;animation:gradient-border-flow 2.5s linear infinite}.service-card:hover:after{opacity:1}.service-card:hover{border-color:transparent;box-shadow:0 16px 48px var(--color-card-shadow-hover)}.service-icon{font-size:2.2rem;line-height:1;position:relative;z-index:1;transition:transform var(--transition-base);display:inline-block}.service-card:hover .service-icon{transform:scale(1.2) rotate(-8deg)}.service-title{font-size:1rem;font-weight:700;letter-spacing:-.02em;line-height:1.3;position:relative;z-index:1}.service-desc{font-size:.875rem;color:var(--color-text-muted);line-height:1.7;flex:1;position:relative;z-index:1}.service-tags{display:flex;flex-wrap:wrap;gap:var(--space-xs);position:relative;z-index:1}.about-callout{display:flex;gap:var(--space-md);align-items:flex-start;padding:var(--space-lg);background:var(--color-accent-soft);border:1px solid var(--color-accent-glow);border-radius:var(--radius-lg);margin:var(--space-xl) 0}.about-callout-icon{font-size:1.5rem;flex-shrink:0;line-height:1.4}.about-callout p{font-size:.9rem;color:var(--color-text-muted);line-height:1.75;font-style:italic;margin:0;max-width:none}.marquee-section{border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-lg) 0;background:var(--color-surface);overflow:hidden;display:flex;flex-direction:column;gap:var(--space-sm)}.marquee-label{text-align:center;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--color-text-subtle);font-family:var(--font-mono);margin-bottom:var(--space-xs)}.marquee-track{overflow:hidden}.marquee-inner{display:flex;gap:var(--space-md);width:max-content;animation:marquee-scroll 28s linear infinite}.marquee-inner--reverse{animation-name:marquee-scroll-reverse;animation-duration:22s}.marquee-item{font-size:.78rem;font-weight:600;font-family:var(--font-mono);color:var(--color-text-subtle);white-space:nowrap;padding:.3rem .9rem;border:1px solid var(--color-border);border-radius:9999px;background:var(--color-surface-alt);cursor:default;transition:color var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast)}.marquee-item:hover{color:var(--color-accent);border-color:var(--color-accent-glow);background:var(--color-accent-soft)}@keyframes marquee-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes marquee-scroll-reverse{0%{transform:translate(-50%)}to{transform:translate(0)}}.skill-group .skill-pill{opacity:0;transform:translateY(8px);transition:opacity .38s ease calc(var(--i, 0) * 48ms + .28s),transform .38s ease calc(var(--i, 0) * 48ms + .28s),border-color var(--transition-fast),color var(--transition-fast),background var(--transition-fast)}.skill-group.in-view .skill-pill{opacity:1;transform:translateY(0)}.project-year{display:inline-block;font-size:.62rem;font-weight:700;font-family:var(--font-mono);color:var(--color-text-subtle);letter-spacing:.06em;background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:9999px;padding:.12rem .5rem;margin-bottom:.4rem}.contact-inner{position:relative;overflow:hidden}.contact-orb{position:absolute;border-radius:50%;pointer-events:none;z-index:0}.contact-orb-1{width:350px;height:350px;background:radial-gradient(circle,rgba(99,102,241,.1) 0%,transparent 65%);top:-120px;left:-80px;animation:contact-orb-pulse 6s ease-in-out infinite}.contact-orb-2{width:280px;height:280px;background:radial-gradient(circle,rgba(168,85,247,.1) 0%,transparent 65%);bottom:-100px;right:-60px;animation:contact-orb-pulse 8s ease-in-out infinite 3s}.contact-inner>*:not(.contact-orb){position:relative;z-index:1}@keyframes contact-orb-pulse{0%,to{transform:scale(1);opacity:.7}50%{transform:scale(1.15);opacity:1}}.lp-section{margin-bottom:var(--space-4xl)}.about-content p{color:var(--color-text-muted);font-size:1rem;line-height:1.8;margin-bottom:var(--space-md);max-width:600px}.about-link{display:inline-flex;align-items:center;gap:.4rem;margin-top:var(--space-sm);font-size:.875rem;font-weight:600;color:var(--color-accent);transition:gap var(--transition-fast),color var(--transition-fast)}.about-link:hover{gap:.7rem;color:var(--color-accent-hover)}.skills-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xl)}.skill-group{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:border-color var(--transition-base),box-shadow var(--transition-base)}.skill-group:hover{border-color:var(--color-accent-glow);box-shadow:0 4px 20px var(--color-card-shadow)}.skill-group-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-accent);font-family:var(--font-mono);margin-bottom:var(--space-md)}.skill-pills{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.skill-pill{font-size:.75rem;font-weight:500;padding:.3rem .75rem;border-radius:9999px;background:var(--color-surface-alt);border:1px solid var(--color-border);color:var(--color-text-muted);font-family:var(--font-mono);transition:all var(--transition-fast);cursor:default}.skill-pill:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-soft)}.projects-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg)}.project-card{padding:var(--space-lg);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);position:relative;transition:all var(--transition-base);display:flex;flex-direction:column;gap:var(--space-sm)}.project-card:before{content:"";position:absolute;inset:0;border-radius:var(--radius-lg);padding:1px;background:linear-gradient(90deg,#6366f1,#a855f7,#ec4899,#a855f7,#6366f1);background-size:300% 100%;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity var(--transition-base);pointer-events:none}.project-card:hover:before{opacity:1;animation:gradient-border-flow 2.5s linear infinite}.project-card:hover{border-color:transparent;box-shadow:0 8px 32px var(--color-card-shadow-hover)}.project-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-sm)}.project-name{font-size:1rem;font-weight:700;letter-spacing:-.02em;color:var(--color-text);line-height:1.3}.project-links{display:flex;align-items:center;gap:var(--space-xs);flex-shrink:0}.project-link{display:inline-flex;align-items:center;gap:.3rem;font-size:.72rem;font-weight:600;padding:.25rem .65rem;border-radius:var(--radius-sm);border:1px solid var(--color-border);color:var(--color-text-muted);background:var(--color-surface-alt);transition:all var(--transition-fast);white-space:nowrap;font-family:var(--font-mono)}.project-link:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-soft)}.project-link-live{border-color:var(--color-accent-glow);color:var(--color-accent);background:var(--color-accent-soft)}.project-link-live:hover{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.project-desc{font-size:.875rem;color:var(--color-text-muted);line-height:1.65;flex:1}.project-tech{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-xs)}.tech-badge{font-size:.65rem;font-weight:600;padding:.15rem .55rem;border-radius:9999px;background:var(--color-tag-bg);color:var(--color-tag-text);font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase}.contact-section{margin-bottom:var(--space-2xl)}.contact-inner{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-3xl) var(--space-2xl);text-align:center;position:relative;overflow:hidden}.contact-inner:before{content:"";position:absolute;inset:0;border-radius:var(--radius-xl);padding:1px;background:linear-gradient(90deg,#6366f1,#a855f7,#ec4899,#a855f7,#6366f1);background-size:300% 100%;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.55;animation:gradient-border-pulse 5s ease-in-out infinite;pointer-events:none}.contact-inner:after{content:"";position:absolute;top:-60px;left:50%;transform:translate(-50%);width:400px;height:300px;background:radial-gradient(ellipse,rgba(99,102,241,.08) 0%,transparent 70%);pointer-events:none}.contact-headline{font-size:clamp(1.5rem,3.5vw,2.2rem);font-weight:900;letter-spacing:-.04em;line-height:1.15;margin-bottom:var(--space-md);position:relative;z-index:1}.contact-text{color:var(--color-text-muted);font-size:.95rem;line-height:1.7;max-width:420px;margin:0 auto var(--space-xl);position:relative;z-index:1}.contact-email{display:inline-flex;align-items:center;gap:var(--space-sm);padding:.85rem 2rem;background:linear-gradient(135deg,#6366f1,#a855f7);color:#fff;font-size:.95rem;font-weight:600;border-radius:var(--radius);transition:all var(--transition-base);position:relative;z-index:1;margin-bottom:var(--space-xl);font-family:var(--font-mono);letter-spacing:.01em}.contact-email:hover{transform:translateY(-2px);box-shadow:0 8px 28px #6366f173;color:#fff}.social-links{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);position:relative;z-index:1}.social-link{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);font-size:.8rem;font-weight:500;background:var(--color-surface-alt);transition:all var(--transition-fast)}.social-link:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-soft);transform:translateY(-2px)}.hero-particles{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}.hero-grid{position:absolute;inset:0;z-index:0;pointer-events:none;background-image:radial-gradient(circle,rgba(99,102,241,.15) 1px,transparent 1px);background-size:32px 32px;-webkit-mask-image:radial-gradient(ellipse 30% 35% at var(--hero-x, 50%) var(--hero-y, 30%),rgba(0,0,0,.6) 0%,transparent 100%),radial-gradient(ellipse 60% 50% at 50% 40%,rgba(0,0,0,.08) 0%,transparent 70%);mask-image:radial-gradient(ellipse 30% 35% at var(--hero-x, 50%) var(--hero-y, 30%),rgba(0,0,0,.6) 0%,transparent 100%),radial-gradient(ellipse 60% 50% at 50% 40%,rgba(0,0,0,.08) 0%,transparent 70%);opacity:0;animation:hero-grid-in 2s ease .6s forwards}@media(prefers-color-scheme:dark){.hero-grid{background-image:radial-gradient(circle,rgba(129,140,248,.15) 1px,transparent 1px)}}@keyframes hero-grid-in{to{opacity:1}}.hero-noise{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px 200px;mix-blend-mode:overlay}.btn-magnetic{will-change:transform}@media(prefers-color-scheme:dark){.hero:before{background:radial-gradient(35% 40% at var(--hero-x) var(--hero-y),rgba(129,140,248,.18) 0%,rgba(168,85,247,.06) 40%,transparent 100%)}.hero h1{text-shadow:0 0 80px rgba(129,140,248,.12)}.hero:after{background:linear-gradient(90deg,transparent,rgba(129,140,248,.3),rgba(168,85,247,.25),rgba(236,72,153,.2),transparent)}}@media(max-width:520px){.projects-grid{grid-template-columns:1fr}}@media(max-width:640px){.header-inner{padding:0 var(--space-md)}.site-main{padding:var(--space-xl) var(--space-md)}.hero{padding:var(--space-2xl) 0 var(--space-xl)}.hero h1{font-size:2.1rem}.hero-links{flex-direction:column;align-items:stretch}.btn-primary,.btn-ghost{justify-content:center}.post-card{padding:var(--space-md) var(--space-lg)}.prose h1{font-size:1.5rem}.prose h2{font-size:1.25rem}.site-nav{gap:0}.site-nav a{padding:var(--space-sm) var(--space-sm);font-size:.8rem}.hero-skills{gap:var(--space-xs)}.skills-grid{grid-template-columns:1fr;gap:var(--space-md)}.projects-grid,.services-grid{grid-template-columns:1fr}.featured-post-card{min-width:240px;max-width:280px}.featured-post-img{height:160px}.featured-post-body{padding:var(--space-md) var(--space-lg) var(--space-lg)}.carousel-arrow{width:32px;height:32px}.contact-inner{padding:var(--space-2xl) var(--space-lg)}.social-links{flex-direction:column;align-items:stretch}.social-link{justify-content:center}.scroll-indicator{display:none}}@media(max-width:860px){.services-grid{grid-template-columns:1fr 1fr}}
