*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#0a0a0f;--bg-secondary:#111118;--bg-tertiary:#1a1a25;--bg-card:#12121e;--surface:#181825;--text-primary:#e4e4ec;--text-secondary:#9494a8;--text-muted:#5c5c72;--accent:#2563eb;--accent-hover:#3b82f6;--accent-glow:#2563eb26;--accent-subtle:#2563eb14;--border:#1e1e30;--border-accent:#2563eb;--success:#22c55e;--danger:#ef4444;--warning:#eab308;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--font-mono:"JetBrains Mono", monospace;--nav-height:64px;--max-width:1200px;--shadow-card:0 4px 24px #0000004d;--shadow-glow:0 0 40px #2563eb14;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s cubic-bezier(.16, 1, .3, 1)}[data-theme=light]{--bg-primary:#f5f5f8;--bg-secondary:#eaeaef;--bg-tertiary:#dddde5;--bg-card:#fff;--surface:#fff;--text-primary:#0a0a0f;--text-secondary:#5c5c72;--text-muted:#9494a8;--border:#d4d4dd;--accent:#2563eb;--accent-hover:#1d4ed8;--accent-glow:#2563eb1a;--accent-subtle:#2563eb0f;--shadow-card:0 4px 24px #0000000f;--shadow-glow:0 0 40px #2563eb0d}html{scroll-behavior:smooth;scroll-padding-top:var(--nav-height)}body{font-family:var(--font-mono);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;transition:background var(--transition-base), color var(--transition-base);line-height:1.6;overflow-x:hidden}img{max-width:100%;height:auto;display:block}a{color:var(--accent);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-hover)}#three-canvas{z-index:0;pointer-events:none;opacity:.5;width:100%;height:100%;position:fixed;top:0;left:0}#particle-canvas{z-index:0;pointer-events:none;opacity:.4;width:100%;height:100%;position:fixed;top:0;left:0}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 24px}.navbar{height:var(--nav-height);z-index:100;-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);transition:background var(--transition-base), border-color var(--transition-base);background:#0a0a0fcc;position:fixed;top:0;left:0;right:0}[data-theme=light] .navbar{background:#f5f5f8d9}.nav-inner{height:100%;max-width:var(--max-width);justify-content:space-between;align-items:center;margin:0 auto;padding:0 24px;display:flex}.nav-logo{color:var(--text-primary);letter-spacing:-.02em;align-items:center;gap:2px;font-size:.85rem;font-weight:500;display:flex}.nav-logo:hover,.logo-prompt{color:var(--accent)}.logo-path{color:var(--text-muted)}.nav-links{gap:4px;list-style:none;display:flex}.nav-link{color:var(--text-secondary);border-radius:var(--radius-sm);transition:all var(--transition-fast);padding:8px 14px;font-size:.82rem;position:relative}.nav-link:hover{color:var(--accent);background:var(--accent-subtle)}.nav-actions{align-items:center;gap:8px;display:flex}.theme-toggle{border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;width:38px;height:38px;transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;display:flex}.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}.theme-toggle .sun-icon{display:none}.theme-toggle .moon-icon,[data-theme=light] .theme-toggle .sun-icon{display:block}[data-theme=light] .theme-toggle .moon-icon{display:none}.menu-toggle{color:var(--text-primary);cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:38px;height:38px;display:none}.menu-toggle span{background:var(--text-primary);width:20px;height:2px;transition:all var(--transition-fast);border-radius:2px;display:block}.section{z-index:1;padding:100px 0;position:relative}.section-header{text-align:center;margin-bottom:60px}.section-tag{color:var(--accent);background:var(--accent-subtle);letter-spacing:.05em;border-radius:4px;margin-bottom:16px;padding:4px 12px;font-size:.75rem;display:inline-block}.section-title{letter-spacing:-.03em;color:var(--text-primary);margin-bottom:16px;font-size:2rem;font-weight:600}.section-divider{background:var(--accent);border-radius:2px;width:60px;height:3px;margin:0 auto}.hero-section{min-height:100dvh;padding-top:var(--nav-height);align-items:center;display:flex;position:relative;overflow:hidden}.hero-grid{max-width:var(--max-width);grid-template-columns:1fr 1fr;align-items:center;gap:60px;width:100%;margin:0 auto;padding:0 24px;display:grid}.hero-content{flex-direction:column;gap:16px;display:flex}.terminal-badge{color:var(--text-muted);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;align-items:center;gap:8px;width:fit-content;padding:6px 14px;font-size:.75rem;display:inline-flex}.terminal-dot{background:var(--success);border-radius:50%;width:8px;height:8px}.hero-greeting{color:var(--text-secondary);font-size:1rem}.hero-name{letter-spacing:-.04em;font-size:3.5rem;font-weight:700;line-height:1.1}.hero-name .accent{color:var(--accent)}.hero-typing{color:var(--text-secondary);align-items:center;gap:4px;min-height:1.6em;font-size:1.1rem;display:flex}.typing-prefix{color:var(--accent)}.typing-cursor{color:var(--accent);font-weight:300;animation:1s step-end infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-desc{color:var(--text-secondary);max-width:480px;font-size:.92rem;line-height:1.7}.hero-cta{gap:12px;margin-top:8px;display:flex}.hero-status{color:var(--text-muted);align-items:center;gap:8px;font-size:.82rem;display:flex}.status-dot{background:var(--success);border-radius:50%;width:7px;height:7px;animation:2s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1;box-shadow:0 0 #22c55e66}50%{opacity:.8;box-shadow:0 0 0 6px #22c55e00}}.hero-visual{flex-direction:column;align-items:center;gap:24px;display:flex}.photo-frame{border-radius:var(--radius-lg);width:240px;height:320px;position:relative;overflow:hidden}.photo-glow{background:radial-gradient(circle at 50% 50%, var(--accent-glow), transparent 70%);z-index:0;animation:4s ease-in-out infinite glow-pulse;position:absolute;inset:-20px}@keyframes glow-pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.profile-photo{z-index:1;object-fit:cover;border-radius:var(--radius-lg);width:100%;height:100%;position:relative}.photo-frame-border{border-radius:calc(var(--radius-lg) + 2px);border:1px solid var(--border-accent);opacity:.4;z-index:2;pointer-events:none;position:absolute;inset:-2px}.hero-stats{gap:24px;display:flex}.stat{text-align:center}.stat-value{color:var(--accent);font-size:1rem;font-weight:600;display:block}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:2px;font-size:.7rem;display:block}.scroll-indicator{flex-direction:column;align-items:center;gap:8px;display:flex;position:absolute;bottom:40px;left:50%;transform:translate(-50%)}.scroll-text{color:var(--text-muted);text-transform:uppercase;letter-spacing:.15em;font-size:.7rem}.scroll-line{background:linear-gradient(to bottom, var(--accent), transparent);width:1px;height:32px;animation:2s ease-in-out infinite scroll-pulse}@keyframes scroll-pulse{0%{opacity:.3;transform:scaleY(.3)}50%{opacity:1;transform:scaleY(1)}to{opacity:.3;transform:scaleY(.3)}}.btn{font-family:var(--font-mono);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base);border:none;align-items:center;gap:8px;padding:12px 24px;font-size:.85rem;font-weight:500;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.btn-primary{background:var(--accent);color:#fff;border:1px solid var(--accent)}.btn-primary:hover{background:var(--accent-hover);color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px #2563eb40}.btn-secondary{color:var(--text-primary);border:1px solid var(--border);background:0 0}.btn-secondary:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.about-section{background:var(--bg-secondary);transition:background var(--transition-base)}.about-grid{grid-template-columns:1fr 1fr;align-items:start;gap:60px;display:grid}.about-text{flex-direction:column;gap:16px;display:flex}.about-text p{color:var(--text-secondary);font-size:.88rem;line-height:1.8}.term-window{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-primary);box-shadow:var(--shadow-card);overflow:hidden}.term-header{background:var(--bg-tertiary);border-bottom:1px solid var(--border);align-items:center;gap:6px;padding:10px 14px;display:flex}.term-dot{border-radius:50%;width:10px;height:10px}.term-dot.red{background:var(--danger)}.term-dot.yellow{background:var(--warning)}.term-dot.green{background:var(--success)}.term-title{color:var(--text-muted);margin-left:auto;font-size:.72rem}.term-body{padding:16px;font-size:.82rem;line-height:1.9}.term-line{color:var(--text-primary)}.term-line .prompt{color:var(--accent)}.term-line.output{color:var(--text-secondary);padding-left:12px}.cursor-block{color:var(--accent);animation:1s step-end infinite blink}.skills-section{background:var(--bg-primary);transition:background var(--transition-base)}.skills-filter{flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:40px;display:flex}.filter-btn{font-family:var(--font-mono);color:var(--text-secondary);background:var(--bg-tertiary);border:1px solid var(--border);cursor:pointer;transition:all var(--transition-fast);border-radius:6px;padding:8px 18px;font-size:.8rem}.filter-btn:hover{border-color:var(--accent);color:var(--accent)}.filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;display:grid}.skill-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);transition:all var(--transition-base);cursor:default;align-items:center;gap:10px;padding:12px 14px;display:flex}.skill-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 20px #2563eb1a}.skill-card.hidden{display:none}.skill-icon{width:20px;height:20px;color:var(--accent);flex-shrink:0}.skill-name{color:var(--text-primary);word-break:break-word;-webkit-hyphens:auto;hyphens:auto;font-size:.78rem;line-height:1.3}.projects-section{background:var(--bg-secondary);transition:background var(--transition-base)}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px;display:grid}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);transition:all var(--transition-slow);cursor:pointer;position:relative;overflow:hidden}.project-card:hover{border-color:var(--accent);box-shadow:var(--shadow-glow), var(--shadow-card);transform:translateY(-4px)}.project-card-inner{flex-direction:column;height:100%;padding:28px;display:flex}.project-tag{color:var(--accent);background:var(--accent-subtle);border-radius:4px;width:fit-content;margin-bottom:14px;padding:3px 8px;font-size:.7rem;display:inline-block}.project-title{letter-spacing:-.02em;margin-bottom:10px;font-size:1.15rem;font-weight:600}.project-desc{color:var(--text-secondary);flex:1;margin-bottom:16px;font-size:.82rem;line-height:1.7}.project-tech{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.tech-tag{color:var(--text-muted);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:4px;padding:3px 8px;font-size:.7rem}.project-links{gap:12px;margin-top:auto;display:flex}.project-link{color:var(--accent);transition:gap var(--transition-fast);align-items:center;gap:4px;font-size:.78rem;display:inline-flex}.project-link:hover{gap:8px}.experience-section{background:var(--bg-primary);transition:background var(--transition-base)}.timeline{max-width:700px;margin:0 auto;position:relative}.timeline:before{content:"";background:var(--border);width:1px;position:absolute;top:0;bottom:0;left:20px}.timeline-item{padding-bottom:40px;padding-left:52px;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-dot{background:var(--bg-primary);border:2px solid var(--accent);z-index:1;border-radius:50%;width:13px;height:13px;position:absolute;top:6px;left:14px}.timeline-date{color:var(--accent);letter-spacing:.02em;margin-bottom:4px;font-size:.75rem}.timeline-title{margin-bottom:4px;font-size:1rem;font-weight:600}.timeline-subtitle{color:var(--text-secondary);margin-bottom:8px;font-size:.82rem}.timeline-desc{color:var(--text-muted);font-size:.82rem;line-height:1.7}.timeline-desc ul{padding:0;list-style:none}.timeline-desc li{margin-bottom:4px;padding-left:16px;position:relative}.timeline-desc li:before{content:">";color:var(--accent);position:absolute;left:0}.contact-section{background:var(--bg-secondary);transition:background var(--transition-base)}.contact-grid{grid-template-columns:1fr 1fr;align-items:start;gap:60px;display:grid}.contact-desc{color:var(--text-secondary);margin-bottom:32px;font-size:.88rem;line-height:1.7}.contact-links{flex-direction:column;gap:16px;display:flex}.contact-link{color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);transition:all var(--transition-fast);align-items:center;gap:12px;padding:10px 16px;font-size:.85rem;display:inline-flex}.contact-link:hover{color:var(--accent);border-color:var(--accent);transform:translate(4px)}.contact-link svg{flex-shrink:0}.contact-form{flex-direction:column;gap:18px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-secondary);font-size:.78rem;font-weight:500}.form-input{font-family:var(--font-mono);color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);transition:all var(--transition-fast);outline:none;padding:12px 16px;font-size:.85rem}.form-input::placeholder{color:var(--text-muted);font-size:.8rem}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-textarea{resize:vertical;min-height:100px}.input-error{border-color:var(--danger)!important;box-shadow:0 0 0 2px #ef444426!important}.field-error{color:var(--danger);margin-top:2px;font-size:.72rem;display:block}.form-submit{justify-content:center;width:100%;margin-top:4px}.form-submit.loading .btn-text:after{content:"..."}.form-submit .btn-icon{transition:transform var(--transition-fast);align-items:center;display:flex}.form-submit:hover .btn-icon{transform:translate(4px)translateY(-2px)}.form-success{text-align:center;color:var(--success);padding:40px 20px;display:none}.form-success.show{display:block}.form-success svg{margin:0 auto 16px}.form-success h3{margin-bottom:8px}.form-success p{color:var(--text-secondary);font-size:.85rem}.footer{z-index:1;border-top:1px solid var(--border);background:var(--bg-primary);transition:background var(--transition-base), border-color var(--transition-base);padding:32px 0;position:relative}.footer-inner{justify-content:space-between;align-items:center;display:flex}.footer-copy{color:var(--text-muted);font-size:.78rem}.footer-tag{color:var(--text-muted);align-items:center;gap:6px;font-size:.78rem;display:flex}.footer-prompt{color:var(--accent)}.footer-heart{color:var(--danger)}.reveal-up{opacity:0;transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);transform:translateY(30px)}.reveal-up.revealed{opacity:1;transform:translateY(0)}.reveal-scale{opacity:0;transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);transform:scale(.9)}.reveal-scale.revealed{opacity:1;transform:scale(1)}@media (width<=1024px){.hero-grid{text-align:center;grid-template-columns:1fr;gap:40px}.hero-content{align-items:center}.hero-desc{max-width:100%}.hero-cta{justify-content:center}.hero-visual{order:-1}.about-grid,.contact-grid{grid-template-columns:1fr;gap:40px}.hero-name{font-size:2.8rem}}@media (width<=768px){.nav-links{display:none}.nav-links.open{top:var(--nav-height);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);background:#0a0a0ff2;flex-direction:column;gap:4px;padding:16px;display:flex;position:absolute;left:0;right:0}[data-theme=light] .nav-links.open{background:#f5f5f8f2}.menu-toggle{display:flex}.hero-name{font-size:2.2rem}.hero-typing{font-size:.95rem}.section-title{font-size:1.6rem}.section{padding:64px 0}.projects-grid{grid-template-columns:1fr}.skills-grid{grid-template-columns:repeat(2,1fr)}.photo-frame{width:180px;height:240px}.hero-stats{gap:16px}.footer-inner{text-align:center;flex-direction:column;gap:8px}}@media (width<=480px){.hero-name{font-size:1.8rem}.hero-cta{flex-direction:column}.btn{justify-content:center;width:100%}.skills-grid{grid-template-columns:1fr 1fr}.container{padding:0 16px}.section{padding:48px 0}.photo-frame{width:150px;height:200px}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}#three-canvas,#particle-canvas{display:none}.reveal-up,.reveal-scale{opacity:1;transform:none}}
