:root{--bg-primary:#f5f2eb;--bg-secondary:#ece8df;--bg-tertiary:#e2ddd4;--text-primary:#1a1a1a;--text-secondary:#4a4a4a;--text-muted:#8a8a8a;--accent:#2563eb;--accent-hover:#1d4ed8;--border:#d4d0c8;--card-bg:#ffffff;--card-hover-bg:#faf9f7;--code-bg:#f0ede6;--shadow:rgba(0, 0, 0, 0.1);--font-heading:'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;--font-body:'Outfit', system-ui, -apple-system, sans-serif;--font-mono:'JetBrains Mono', 'Fira Code', monospace;--space-1:0.5rem;--space-2:1rem;--space-3:1.5rem;--space-4:2rem;--space-5:2.5rem;--space-6:3rem;--space-8:4rem;--space-10:5rem;--space-12:6rem;--transition:0.3s cubic-bezier(0.4, 0, 0.2, 1);--transition-fast:0.15s cubic-bezier(0.4, 0, 0.2, 1);--radius-sm:4px;--radius:8px;--radius-lg:12px;--radius-xl:16px;--max-width:1200px;--content-width:720px}[data-theme=dark]{--bg-primary:#0a0a0a;--bg-secondary:#141414;--bg-tertiary:#1e1e1e;--text-primary:#e8e6e3;--text-secondary:#a0a0a0;--text-muted:#6b6b6b;--accent:#3b82f6;--accent-hover:#60a5fa;--border:#2a2a2a;--card-bg:#161616;--card-hover-bg:#1c1c1c;--code-bg:#1a1a2e;--shadow:rgba(0, 0, 0, 0.4)}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.7;transition:background-color var(--transition),color var(--transition);min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:1.2;color:var(--text-primary)}h1{font-size:clamp(2rem,5vw,3.5rem)}h2{font-size:clamp(1.5rem,3vw,2.25rem)}h3{font-size:clamp(1.25rem,2.5vw,1.75rem)}h4{font-size:1.25rem}p{margin-bottom:var(--space-2);color:var(--text-secondary)}a{color:var(--accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-hover)}.link-hover{position:relative;display:inline-block}.link-hover::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--accent);transition:width var(--transition)}.link-hover:hover::after{width:100%}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-3)}.section{padding:var(--space-10)0}.section-title{margin-bottom:var(--space-6);text-align:center;position:relative}.section-title::after{content:'';display:block;width:60px;height:3px;background:var(--accent);margin:var(--space-2)auto 0;border-radius:2px}.site-header{position:fixed;top:0;left:0;right:0;z-index:100;padding:var(--space-2)0;background:0 0;transition:background-color var(--transition),box-shadow var(--transition)}.site-header.scrolled{background:var(--bg-primary);box-shadow:0 1px 0 var(--border)}.nav{display:flex;justify-content:space-between;align-items:center}.nav-brand{font-family:var(--font-heading);font-weight:600;font-size:1.25rem;color:var(--text-primary);text-decoration:none;transition:color var(--transition-fast)}.nav-brand:hover{color:var(--accent)}.nav-links{display:flex;gap:var(--space-3);align-items:center;list-style:none}.nav-links a{color:var(--text-secondary);font-size:1.05rem;font-weight:500;text-decoration:none;transition:color var(--transition-fast);position:relative}.nav-links a:hover,.nav-links a.active{color:var(--text-primary)}.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--accent);transition:width var(--transition)}.nav-links a:hover::after,.nav-links a.active::after{width:100%}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:var(--space-8)var(--space-3);position:relative;overflow:hidden}.hero::before{content:'';position:absolute;inset:0;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.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");background-repeat:repeat;pointer-events:none;z-index:0}.hero::after{content:'';position:absolute;top:-20%;right:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(59,130,246,8%) 0%,transparent 70%);pointer-events:none;z-index:0}.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);align-items:center;max-width:var(--max-width);margin:0 auto;width:100%;padding:0 var(--space-4);position:relative;z-index:1}.hero-text{display:flex;flex-direction:column;gap:var(--space-3)}.hero-label{display:flex;align-items:center;gap:var(--space-2);animation:fadeSlideUp .8s ease both}.hero-label-line{display:block;width:40px;height:1px;background:var(--accent)}.hero-label-text{font-family:var(--font-mono);font-size:.95rem;color:var(--accent);text-transform:uppercase;letter-spacing:.18em;font-weight:500}.hero-name{font-size:clamp(3.2rem,7.5vw,6rem);font-weight:600;line-height:1.15;letter-spacing:-.025em;animation:fadeSlideUp .8s ease .1s both;color:var(--text-primary);background:linear-gradient(135deg,var(--text-primary) 0%,var(--text-primary) 60%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;-webkit-box-decoration-break:clone;box-decoration-break:clone;padding-bottom:.15em}.hero-tagline{font-size:clamp(1.05rem,2vw,1.3rem);color:var(--text-secondary);font-weight:300;letter-spacing:.01em;max-width:380px;animation:fadeSlideUp .8s ease .2s both}.hero-social{display:flex;gap:var(--space-2);margin-top:var(--space-2);animation:fadeSlideUp .8s ease .3s both}.social-link{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:var(--radius);color:var(--text-muted);background:0 0;border:1px solid var(--border);transition:all var(--transition);position:relative;overflow:hidden}.social-link svg{width:18px;height:18px;fill:currentColor;position:relative;z-index:1}.social-link::before{content:'';position:absolute;inset:0;background:var(--accent);opacity:0;transition:opacity var(--transition)}.social-link:hover{color:#fff;border-color:var(--accent);transform:translateY(-2px)}.social-link:hover::before{opacity:1}.hero-photo-wrapper{display:flex;justify-content:center;align-items:center;animation:fadeSlideUp .8s ease .15s both}.hero-photo-frame{position:relative;width:100%;max-width:380px;aspect-ratio:3/4;border-radius:var(--radius-xl);overflow:hidden}.hero-photo-frame::after{content:'';position:absolute;inset:0;border-radius:var(--radius-xl);border:1px solid rgba(59,130,246,.2);pointer-events:none;z-index:2}.hero-photo{width:100%;height:100%;object-fit:cover;object-position:top center;border-radius:var(--radius-xl);filter:grayscale(15%)contrast(1.05);transition:filter var(--transition),transform .6s cubic-bezier(.4,0,.2,1)}.hero-photo:hover{filter:grayscale(0%)contrast(1.08);transform:scale(1.03)}.hero-scroll-hint{position:absolute;bottom:var(--space-4);left:50%;transform:translateX(-50%);color:var(--text-muted);animation:fadeSlideUp .8s ease .6s both;z-index:1}.hero-scroll-hint .scroll-dot{animation:scrollBounce 2s ease-in-out infinite}@keyframes fadeSlideUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes scrollBounce{0%,100%{cy:10;opacity:1}50%{cy:22;opacity:.3}}.post-list{max-width:var(--content-width);margin:0 auto;padding:var(--space-8)var(--space-3)}.post-list-title{margin-bottom:var(--space-6)}.post-card{display:block;padding:var(--space-3);margin-bottom:var(--space-2);border-radius:var(--radius);background:var(--card-bg);border:1px solid var(--border);transition:all var(--transition);text-decoration:none}.post-card:hover{background:var(--card-hover-bg);border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 20px var(--shadow)}.post-card-title{font-size:1.25rem;margin-bottom:var(--space-1);color:var(--text-primary)}.post-card-meta{font-size:.85rem;color:var(--text-muted)}.post-card-excerpt{margin-top:var(--space-1);font-size:.9rem;color:var(--text-secondary)}.post{max-width:var(--content-width);margin:0 auto;padding:var(--space-8)var(--space-3)}.post-header{margin-bottom:var(--space-6)}.post-title{margin-bottom:var(--space-2)}.post-meta{color:var(--text-muted);font-size:.9rem;display:flex;gap:var(--space-2);flex-wrap:wrap}.post-tag{display:inline-block;padding:2px 8px;font-size:.75rem;border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-secondary);text-decoration:none;transition:all var(--transition-fast)}.post-tag:hover{background:var(--accent);color:#fff}.post-content h2{margin-top:var(--space-6);margin-bottom:var(--space-3)}.post-content h3{margin-top:var(--space-4);margin-bottom:var(--space-2)}.post-content p{font-size:1.05rem;line-height:1.8}.post-content img{max-width:100%;height:auto;border-radius:var(--radius);margin:var(--space-3)0}.post-content ul,.post-content ol{margin:var(--space-2)0;padding-left:var(--space-3);color:var(--text-secondary)}.post-content ul li,.post-content ol li{margin-bottom:var(--space-1);line-height:1.7}.post-content blockquote{border-left:3px solid var(--accent);padding-left:var(--space-3);margin:var(--space-3)0;color:var(--text-secondary);font-style:italic}.post-content pre{background:var(--code-bg);border-radius:var(--radius);padding:var(--space-3);overflow-x:auto;margin:var(--space-3)0;border:1px solid var(--border);font-family:var(--font-mono);font-size:.9rem;line-height:1.6}.post-content code{font-family:var(--font-mono);font-size:.9em}.post-content p code,.post-content li code{background:var(--code-bg);padding:2px 6px;border-radius:var(--radius-sm);border:1px solid var(--border)}.post-content table{width:100%;border-collapse:collapse;margin:var(--space-3)0}.post-content table th,.post-content table td{padding:var(--space-1)var(--space-2);border:1px solid var(--border);text-align:left}.post-content table th{background:var(--bg-secondary);font-weight:600}.post-nav{display:flex;justify-content:space-between;gap:var(--space-3);margin-top:var(--space-8);padding-top:var(--space-4);border-top:1px solid var(--border)}.post-nav-link{font-size:.9rem;color:var(--text-secondary);text-decoration:none}.post-nav-link:hover{color:var(--accent)}.site-footer{padding:var(--space-6)0;border-top:1px solid var(--border);text-align:center}.footer-social{display:flex;gap:var(--space-2);justify-content:center;margin-bottom:var(--space-3)}.footer-text{font-size:.85rem;color:var(--text-muted)}.theme-toggle{background:0 0;border:1px solid var(--border);cursor:pointer;width:40px;height:40px;border-radius:var(--radius);display:inline-flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all var(--transition-fast)}.theme-toggle:hover{color:var(--accent);border-color:var(--accent)}.theme-toggle svg{width:18px;height:18px;transition:transform var(--transition)}.theme-toggle .icon-sun{display:block}.theme-toggle .icon-moon{display:none}[data-theme=dark] .theme-toggle .icon-sun{display:none}[data-theme=dark] .theme-toggle .icon-moon{display:block}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}#bg-canvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}main{position:relative;z-index:1}.resume-section{padding:var(--space-10)0;position:relative;z-index:1}.resume-header{margin-bottom:var(--space-8)}.resume-title{font-size:clamp(1.8rem,4vw,2.5rem);margin-top:var(--space-2);margin-bottom:var(--space-1)}.resume-subtitle{color:var(--text-muted);font-size:1.05rem}.timeline{position:relative;max-width:900px;margin:0 auto}.timeline-entry{display:grid;grid-template-columns:80px 1fr;gap:var(--space-3);margin-bottom:var(--space-4);opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}.timeline-entry.is-visible{opacity:1;transform:translateY(0)}.timeline-marker{display:flex;flex-direction:column;align-items:center;padding-top:var(--space-3)}.timeline-dot{display:block;width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--bg-primary),0 0 0 5px var(--accent);flex-shrink:0;transition:box-shadow var(--transition),background var(--transition)}.timeline-line{display:block;width:1px;flex-grow:1;background:var(--border);margin-top:var(--space-1)}.timeline-entry--last .timeline-line{display:none}.timeline-content{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition)}.timeline-content:hover{border-color:var(--accent);transform:translateX(4px);box-shadow:0 4px 20px var(--shadow)}.timeline-date{font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.timeline-role{font-family:var(--font-heading);font-size:1.25rem;font-weight:600;margin-top:var(--space-1)}.timeline-company{color:var(--accent);font-weight:500;margin-bottom:var(--space-1)}.timeline-desc{color:var(--text-secondary);font-size:.95rem;margin-bottom:0}@media(min-width:769px){.timeline-entry:nth-child(even){grid-template-columns:1fr 80px}.timeline-entry:nth-child(even) .timeline-marker{order:2}.timeline-entry:nth-child(even) .timeline-content{order:1;text-align:right}.timeline-entry:nth-child(even) .timeline-content:hover{transform:translateX(-4px)}}@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}#bg-canvas{display:none}.timeline-entry{opacity:1;transform:none}}@media(max-width:768px){.nav-links{gap:var(--space-2)}.hero-grid{grid-template-columns:1fr;gap:var(--space-4);text-align:center;padding:0}.hero-text{align-items:center;order:2}.hero-label{justify-content:center}.hero-tagline{max-width:100%}.hero-social{justify-content:center}.hero-photo-wrapper{order:1}.hero-photo-frame{max-width:280px;aspect-ratio:3/4}.hero-name{font-size:clamp(2.4rem,10vw,3.8rem)}.section{padding:var(--space-6)0}.resume-section{padding:var(--space-6)0}.timeline-entry,.timeline-entry:nth-child(even){grid-template-columns:40px 1fr}.timeline-entry:nth-child(even) .timeline-marker{order:unset}.timeline-entry:nth-child(even) .timeline-content{order:unset;text-align:left}.timeline-content{padding:var(--space-3)}}@media(max-width:480px){.hero-social{flex-wrap:wrap;justify-content:center}.hero-photo-frame{max-width:240px}}