@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a0a;--bg-card:#111;--bg-hover:#161616;--border:#1c1c1c;--border-hover:#2a2a2a;--text:#ededed;--text-dim:#888;--text-muted:#555;--accent:#ededed;--tag-bg:#1a1a1a;--tag-text:#999;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono:"JetBrains Mono", "SF Mono", "Fira Code", monospace;--max-w:720px;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:32px;--space-xl:64px;--space-2xl:96px;--radius:8px;--transition:.2s cubic-bezier(.25, .46, .45, .94)}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);letter-spacing:-.01em;min-height:100vh;font-size:15px;line-height:1.6;overflow-x:hidden}::selection{color:#fff;background:#ffffff1f}a{color:inherit;text-decoration:none}.nav{z-index:100;padding:var(--space-md) var(--space-lg);max-width:var(--max-w);justify-content:space-between;align-items:center;margin:0 auto;display:flex;position:fixed;top:0;left:0;right:0}.nav:before{content:"";-webkit-backdrop-filter:blur(16px)saturate(180%);z-index:-1;border-bottom:1px solid var(--border);background:#0a0a0abf;height:56px;position:fixed;top:0;left:0;right:0}.nav-logo{font-family:var(--font-mono);letter-spacing:.05em;color:var(--text);transition:opacity var(--transition);font-size:14px;font-weight:600}.nav-logo:hover{opacity:.6}.nav-links{gap:var(--space-lg);display:flex}.nav-links a{color:var(--text-dim);transition:color var(--transition);letter-spacing:.01em;font-size:13px}.nav-links a:hover,.nav-links a.active{color:var(--text)}section{max-width:var(--max-w);padding:var(--space-2xl) var(--space-lg) 0;margin:0 auto}section h2{text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-bottom:var(--space-lg);font-size:12px;font-weight:500;font-family:var(--font-mono)}.section-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.section-header h2{margin-bottom:0}.view-all{font-family:var(--font-mono);color:var(--text-muted);transition:color var(--transition);font-size:12px}.view-all:hover{color:var(--text)}.section-note{color:var(--text-dim);margin-top:calc(-1 * var(--space-md));margin-bottom:var(--space-lg);font-size:14px}.hero{max-width:var(--max-w);padding:140px var(--space-lg) 0;flex-direction:column;justify-content:center;min-height:70vh;margin:0 auto;animation:.8s cubic-bezier(.25,.46,.45,.94) both fadeUp;display:flex}.hero-badge{align-items:center;gap:var(--space-sm);font-size:12px;font-family:var(--font-mono);color:#4ade80;width:fit-content;margin-bottom:var(--space-lg);background:#4ade800f;border:1px solid #4ade801f;border-radius:999px;padding:5px 14px;display:inline-flex}.pulse-dot{background:#4ade80;border-radius:50%;flex-shrink:0;width:6px;height:6px;animation:2s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.hero h1{letter-spacing:-.035em;margin-bottom:var(--space-md);font-size:clamp(36px,6vw,52px);font-weight:600;line-height:1.1}.hero-sub{color:var(--text-dim);max-width:480px;font-size:17px;line-height:1.5}.hero-now{margin-top:var(--space-xl);padding:12px var(--space-md);border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);align-items:center;gap:var(--space-md);color:var(--text-dim);width:fit-content;font-size:14px;display:flex}.now-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);background:var(--tag-bg);border-radius:4px;flex-shrink:0;padding:2px 8px;font-size:11px}.projects-grid{background:var(--border);border:1px solid var(--border);border-radius:var(--radius);grid-template-columns:repeat(2,1fr);gap:1px;display:grid;overflow:hidden}.project-card{padding:var(--space-lg);background:var(--bg-card);transition:background var(--transition);cursor:pointer;opacity:0;transition:opacity .6s cubic-bezier(.25, .46, .45, .94), transform .6s cubic-bezier(.25, .46, .45, .94), background var(--transition);flex-direction:column;display:flex;transform:translateY(20px)}.project-card.revealed{opacity:1;transform:translateY(0)}.project-card:hover{background:var(--bg-hover)}.project-meta{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.project-tag{font-family:var(--font-mono);color:var(--tag-text);background:var(--tag-bg);letter-spacing:.02em;border-radius:4px;padding:2px 8px;font-size:11px}.project-year{font-family:var(--font-mono);color:var(--text-muted);font-size:12px}.project-card h3{margin-bottom:var(--space-sm);letter-spacing:-.01em;font-size:16px;font-weight:500}.project-card p{color:var(--text-dim);flex:1;font-size:13px;line-height:1.5}.project-link{color:var(--text-muted);margin-top:var(--space-md);transition:color var(--transition);font-size:12px;font-family:var(--font-mono)}.project-card:hover .project-link{color:var(--text)}.exp-list{flex-direction:column;display:flex}.exp-item{gap:var(--space-lg);padding:var(--space-lg) 0;border-bottom:1px solid var(--border);opacity:0;transition:opacity .6s cubic-bezier(.25,.46,.45,.94),transform .6s cubic-bezier(.25,.46,.45,.94);display:flex;transform:translateY(20px)}.exp-item.revealed{opacity:1;transform:translateY(0)}.exp-item:first-child{padding-top:0}.exp-item:last-child{border-bottom:none}.exp-left{flex-shrink:0;width:140px}.exp-period{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.02em;font-size:12px}.exp-right h3{margin-bottom:var(--space-xs);font-size:15px;font-weight:500}.exp-company{color:var(--text-dim);margin-bottom:var(--space-sm);font-size:13px}.exp-desc{color:var(--text-muted);font-size:13px;line-height:1.5}.articles-list{flex-direction:column;display:flex}.article-item{align-items:flex-start;gap:var(--space-lg);padding:var(--space-md);margin:0 calc(-1 * var(--space-md));border-radius:var(--radius);transition:background var(--transition), opacity .6s cubic-bezier(.25, .46, .45, .94), transform .6s cubic-bezier(.25, .46, .45, .94);opacity:0;display:flex;transform:translateY(20px)}.article-item.revealed{opacity:1;transform:translateY(0)}.article-item+.article-item{border-top:1px solid var(--border);border-radius:0}.article-item:first-child{border-radius:var(--radius) var(--radius) 0 0}.article-item:last-child{border-radius:0 0 var(--radius) var(--radius)}.article-item:only-child{border-radius:var(--radius)}.article-item:hover{background:var(--bg-card)}.article-date{font-family:var(--font-mono);color:var(--text-muted);flex-shrink:0;width:80px;padding-top:2px;font-size:12px}.article-content{flex:1;min-width:0}.article-content h3{letter-spacing:-.01em;margin-bottom:2px;font-size:15px;font-weight:500}.article-content p{color:var(--text-dim);font-size:13px}.article-source{font-family:var(--font-mono);color:var(--text-muted);background:var(--tag-bg);border-radius:4px;flex-shrink:0;margin-top:2px;padding:2px 8px;font-size:11px}#connect{padding-bottom:var(--space-xl)}.connect-text{color:var(--text-dim);margin-bottom:var(--space-lg);margin-top:calc(-1 * var(--space-md));font-size:15px}.connect-links{gap:var(--space-sm);flex-wrap:wrap;display:flex}.connect-item{font-size:13px;font-family:var(--font-mono);color:var(--text-dim);padding:var(--space-sm) var(--space-md);border:1px solid var(--border);border-radius:var(--radius);transition:all var(--transition);background:var(--bg-card)}.connect-item:hover{color:var(--text);border-color:var(--border-hover);background:var(--bg-hover)}.page-header{max-width:var(--max-w);padding:120px var(--space-lg) 0;margin:0 auto;animation:.6s cubic-bezier(.25,.46,.45,.94) both fadeUp}.page-header h1{letter-spacing:-.03em;margin-bottom:var(--space-sm);font-size:clamp(28px,5vw,40px);font-weight:600;line-height:1.1}.page-subtitle{color:var(--text-dim);font-size:15px}.back-link{font-family:var(--font-mono);color:var(--text-muted);margin-bottom:var(--space-lg);transition:color var(--transition);font-size:13px;display:inline-block}.back-link:hover{color:var(--text)}.all-projects,.all-articles{max-width:var(--max-w);padding:var(--space-xl) var(--space-lg) var(--space-2xl);margin:0 auto}.footer{max-width:var(--max-w);padding:var(--space-lg);border-top:1px solid var(--border);color:var(--text-muted);font-size:12px;font-family:var(--font-mono);justify-content:space-between;align-items:center;margin:0 auto;display:flex}.project-detail{max-width:var(--max-w);padding:120px var(--space-lg) var(--space-2xl);margin:0 auto;animation:.6s cubic-bezier(.25,.46,.45,.94) both fadeUp}.pd-header{margin-bottom:var(--space-xl)}.pd-header .project-meta{margin-bottom:var(--space-md);justify-content:flex-start;gap:var(--space-md)}.pd-header h1{letter-spacing:-.03em;margin-bottom:var(--space-sm);font-size:clamp(28px,5vw,40px);font-weight:600;line-height:1.1}.pd-impact{color:var(--text-dim);font-size:16px;line-height:1.5}.pd-image{margin-bottom:var(--space-xl);border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);overflow:hidden}.pd-image img{width:100%;height:auto;display:block}.pd-context{gap:var(--space-lg);margin-bottom:var(--space-xl);padding:var(--space-lg);border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);flex-direction:column;display:flex}.pd-block h2{text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-bottom:var(--space-sm);font-size:12px;font-weight:500;font-family:var(--font-mono)}.pd-block p{color:var(--text-dim);font-size:14px;line-height:1.7}.pd-architecture{background:var(--bg);padding:var(--space-md);border:1px solid var(--border);white-space:pre-wrap;word-break:break-word;border-radius:6px;overflow-x:auto;font-family:var(--font-mono)!important;color:var(--tag-text)!important;font-size:13px!important}.pd-section{margin-bottom:var(--space-xl)}.pd-section h2{text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-bottom:var(--space-md);font-size:12px;font-weight:500;font-family:var(--font-mono)}.pd-section>p{color:var(--text-dim);font-size:14px;line-height:1.7}.pd-list{gap:var(--space-sm);flex-direction:column;list-style:none;display:flex}.pd-list li{color:var(--text-dim);padding-left:20px;font-size:14px;line-height:1.5;position:relative}.pd-list li:before{content:"—";color:var(--text-muted);position:absolute;left:0}.pd-metrics{background:var(--border);border:1px solid var(--border);border-radius:var(--radius);gap:1px;display:flex;overflow:hidden}.pd-metric{align-items:center;gap:var(--space-xs);padding:var(--space-lg) var(--space-md);background:var(--bg-card);text-align:center;flex-direction:column;flex:1;display:flex}.pd-metric-value{font-family:var(--font-mono);color:var(--text);letter-spacing:-.02em;font-size:24px;font-weight:600}.pd-metric-label{color:var(--text-muted);font-size:12px;font-family:var(--font-mono);letter-spacing:.02em}.tech-stack{gap:var(--space-sm);flex-wrap:wrap;display:flex}.tech-chip{font-family:var(--font-mono);color:var(--text-dim);background:var(--bg-card);border:1px solid var(--border);border-radius:999px;padding:4px 12px;font-size:12px}.pd-links{gap:var(--space-sm);padding-top:var(--space-lg);border-top:1px solid var(--border);display:flex}.detail-link{font-family:var(--font-mono);color:var(--text-dim);padding:var(--space-sm) var(--space-md);border:1px solid var(--border);border-radius:var(--radius);transition:all var(--transition);background:var(--bg-card);font-size:13px}.detail-link:hover{color:var(--text);border-color:var(--border-hover);background:var(--bg-hover)}.detail-link--primary{color:var(--text);background:var(--bg-hover);border-color:var(--border-hover)}.detail-link--primary:hover{background:#222}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}body:after{content:"";pointer-events:none;z-index:9999;opacity:.012;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px;width:100%;height:100%;position:fixed;top:0;left:0}@media (width<=640px){:root{--space-lg:24px;--space-xl:48px;--space-2xl:64px}.nav{padding:var(--space-md)}.nav-links{gap:var(--space-md)}.hero{min-height:60vh;padding-top:120px}.projects-grid{grid-template-columns:1fr}.exp-item{gap:var(--space-sm);flex-direction:column}.exp-left{width:auto}.article-item{gap:var(--space-sm);flex-direction:column}.article-date{width:auto}.article-source{display:none}.footer{gap:var(--space-sm);text-align:center;flex-direction:column}.section-header{align-items:flex-start;gap:var(--space-sm);flex-direction:column}.page-header{padding-top:100px}.hero-now{width:100%}.project-detail{padding-top:100px}.pd-context{padding:var(--space-md)}.pd-metrics,.pd-links{flex-direction:column}.detail-link{text-align:center}}
