.navbar{z-index:100;padding:1.25rem 1.5rem;transition:all .4s cubic-bezier(.16,1,.3,1);position:fixed;top:0;left:0;right:0}.navbar.scrolled{background:var(--navbar-bg);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:.75rem 1.5rem}.navbar-inner{justify-content:space-between;align-items:center;max-width:1100px;margin:0 auto;display:flex}.navbar-logo{font-family:var(--font-mono);color:var(--text-primary);font-size:1.25rem;font-weight:500;text-decoration:none;transition:transform .3s}.navbar-logo:hover{color:var(--text-primary);transform:scale(1.05)}.logo-bracket{color:var(--accent);transition:color .3s}.logo-text{margin:0 .15rem}.navbar-links{align-items:center;gap:2.25rem;display:flex}.navbar-link{color:var(--text-secondary);font-size:.85rem;font-weight:400;text-decoration:none;transition:color .25s;position:relative}.navbar-link:after{content:"";background:var(--accent);width:0;height:1px;transition:width .3s cubic-bezier(.16,1,.3,1);position:absolute;bottom:-4px;left:0}.navbar-link:hover{color:var(--accent)}.navbar-link:hover:after{width:100%}.navbar-actions{align-items:center;gap:.5rem;display:flex}.theme-toggle{border:1px solid var(--border);width:36px;height:36px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex}.theme-toggle:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-glow);transform:scale(1.08)}.navbar-toggle{color:var(--text-primary);cursor:pointer;background:0 0;border:none;padding:.25rem;display:none}@media (width<=768px){.navbar-toggle{z-index:110;display:block}.navbar-links{background:var(--bg-secondary);border-left:1px solid var(--border);z-index:105;flex-direction:column;justify-content:center;gap:2.25rem;width:280px;transition:transform .4s cubic-bezier(.16,1,.3,1);position:fixed;top:0;bottom:0;right:0;transform:translate(100%)}.navbar-links.open{transform:translate(0)}.navbar-link{font-size:1.05rem}}.hero{justify-content:center;align-items:center;max-width:1100px;min-height:100vh;margin:0 auto;padding:6rem 1.5rem 4rem;display:flex;position:relative;overflow:hidden}.hero-glow{background:radial-gradient(circle, var(--accent-glow-strong) 0%, transparent 70%);filter:blur(80px);pointer-events:none;border-radius:50%;width:450px;height:450px;animation:6s ease-in-out infinite alternate glowPulse;position:absolute;top:-10%;left:-5%}@keyframes glowPulse{0%{opacity:.35;transform:translate(0)scale(1)}to{opacity:.6;transform:translate(20px,15px)scale(1.08)}}.hero-inner{z-index:1;grid-template-columns:1fr 1.15fr;align-items:center;gap:4rem;width:100%;display:grid;position:relative}.hero-content{flex-direction:column;display:flex}.anim-stagger-1,.anim-stagger-2,.anim-stagger-3,.anim-stagger-4,.anim-stagger-5{opacity:0;animation:.8s cubic-bezier(.16,1,.3,1) forwards heroFadeUp;transform:translateY(28px)}.anim-stagger-1{animation-delay:.1s}.anim-stagger-2{animation-delay:.3s}.anim-stagger-3{animation-delay:.5s}.anim-stagger-4{animation-delay:.7s}.anim-stagger-5{animation-delay:.9s}@keyframes heroFadeUp{to{opacity:1;transform:translateY(0)}}.hero-intro{align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.intro-line{background:linear-gradient(90deg, transparent, var(--accent));width:2rem;height:1px;animation:1s cubic-bezier(.16,1,.3,1) .4s both lineGrow;display:block}@keyframes lineGrow{0%{opacity:0;width:0}to{opacity:1;width:2rem}}.intro-text{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.04em;font-size:.88rem}.hero-name{color:var(--text-primary);letter-spacing:-.025em;margin-bottom:1rem;font-size:3.4rem;font-weight:700;line-height:1.1}.name-highlight{background:linear-gradient(135deg, var(--accent) 0%, #a882ff 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-roles{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.role{font-family:var(--font-mono);color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:.3rem .7rem;font-size:.85rem;font-weight:500;transition:all .3s cubic-bezier(.16,1,.3,1)}.role:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow);transform:translateY(-1px)}.role-sep{font-family:var(--font-mono);color:var(--text-muted);opacity:.4;-webkit-user-select:none;user-select:none;font-size:.9rem}.hero-subtitle{color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:2.25rem;font-size:1.5rem;font-weight:300}.hero-socials{gap:.85rem;margin-bottom:2.5rem;display:flex}.social-link{border:1px solid var(--border);width:44px;height:44px;color:var(--text-muted);border-radius:10px;justify-content:center;align-items:center;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex}.social-link:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-glow);box-shadow:var(--shadow-sm);transform:translateY(-3px)}.hero-scroll{width:fit-content;color:var(--text-muted);opacity:0;align-items:center;text-decoration:none;transition:color .25s;animation:.8s cubic-bezier(.16,1,.3,1) .9s forwards heroFadeUp,2.5s ease-in-out 2s infinite scrollFloat;display:inline-flex}.hero-scroll:hover{color:var(--accent)}@keyframes scrollFloat{0%,to{transform:translateY(0)}50%{transform:translateY(6px)}}.hero-visual{width:100%}@media (width<=860px){.hero-inner{grid-template-columns:1fr;gap:2.5rem}.hero-name{font-size:2.75rem}.hero-visual{max-width:520px}}@media (width<=480px){.hero-name{font-size:2.2rem}.role{padding:.25rem .55rem;font-size:.75rem}.hero-subtitle{font-size:1.15rem}}.about-layout{grid-template-columns:1.2fr 1fr;gap:3.5rem;display:grid}.about-text p{color:var(--text-secondary);margin-bottom:1.25rem;font-size:.95rem;line-height:1.85}.about-text p:last-child{margin-bottom:0}.about-text a{color:var(--accent);border-bottom:1px solid #0000;text-decoration:none;transition:border-color .25s}.about-text a:hover{border-color:var(--accent)}.about-skills{flex-direction:column;gap:1.5rem;display:flex}.skill-category{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;margin-bottom:.6rem;font-size:.72rem;font-weight:500}.skill-tags{flex-wrap:wrap;gap:.5rem;display:flex}.skill-tag{font-family:var(--font-mono);background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);cursor:default;border-radius:6px;padding:.4rem .9rem;font-size:.78rem;transition:all .3s cubic-bezier(.16,1,.3,1)}.skill-tag:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow);box-shadow:var(--shadow-sm);transform:translateY(-2px)}@media (width<=768px){.about-layout{grid-template-columns:1fr;gap:2.5rem}}.os-section{position:relative}.os-projects{flex-direction:column;gap:3rem;display:flex}.os-project{position:relative}.os-project-header{align-items:center;gap:1rem;margin-bottom:1.25rem;display:flex}.os-project-badge{background:var(--green);width:10px;height:10px;box-shadow:0 0 12px var(--green-glow);border-radius:50%;flex-shrink:0;animation:3s ease-in-out infinite badgePulse}@keyframes badgePulse{0%,to{box-shadow:0 0 8px var(--green-glow)}50%{box-shadow:0 0 20px var(--green-glow), 0 0 40px #34d39914}}.os-project-name{color:var(--text-primary);font-size:1.2rem;font-weight:600}.os-project-desc{color:var(--text-muted);margin-top:.15rem;font-size:.82rem}.os-prs{border-left:1px solid var(--border);flex-direction:column;gap:.85rem;margin-left:4px;padding-left:1.25rem;display:flex}.os-pr-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;gap:1rem;padding:1.35rem 1.5rem;text-decoration:none;transition:all .35s cubic-bezier(.16,1,.3,1);display:flex;position:relative;overflow:hidden}.os-pr-card:before{content:"";background:linear-gradient(135deg, var(--green), transparent 60%);-webkit-mask-composite:xor;opacity:0;border-radius:12px;padding:1px;transition:opacity .35s;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;mask-position:0 0,0 0;-webkit-mask-size:auto,auto;mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.os-pr-card:hover{background:var(--bg-card-hover);box-shadow:var(--shadow-card);border-color:#0000;transform:translateY(-2px)}.os-pr-card:hover:before{opacity:1}.os-pr-icon{background:var(--green-dim);width:36px;height:36px;color:var(--green);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;transition:transform .3s;display:flex}.os-pr-card:hover .os-pr-icon{transform:scale(1.08)}.os-pr-content{flex:1;min-width:0}.os-pr-title{color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:.4rem;font-size:.92rem;font-weight:500;display:flex}.os-pr-ext{color:var(--text-muted);opacity:0;flex-shrink:0;transition:all .25s;transform:translate(-4px)}.os-pr-card:hover .os-pr-ext{opacity:1;transform:translate(0)}.os-pr-impact{color:var(--text-muted);font-size:.85rem;line-height:1.65}.os-pr-merged{font-family:var(--font-mono);color:var(--green);background:var(--green-dim);letter-spacing:.03em;border-radius:20px;flex-shrink:0;align-self:flex-start;padding:.3rem .7rem;font-size:.7rem;font-weight:500}@media (width<=640px){.os-pr-card{flex-direction:column;gap:.75rem;padding:1.15rem}.os-pr-merged{align-self:flex-start}.os-prs{padding-left:.75rem}}.contact-content{max-width:520px}.contact-text{color:var(--text-secondary);margin-bottom:2.25rem;font-size:1rem;line-height:1.8}.contact-links{flex-direction:column;gap:1rem;margin-bottom:2.75rem;display:flex}.contact-item{color:var(--text-secondary);align-items:center;gap:.85rem;font-size:.9rem;text-decoration:none;transition:all .25s;display:flex}a.contact-item:hover{color:var(--accent);transform:translate(4px)}.contact-item svg{color:var(--text-muted);flex-shrink:0;transition:color .25s}a.contact-item:hover svg{color:var(--accent)}.contact-item-static{cursor:default}.contact-cta{font-family:var(--font-mono);border:1px solid var(--accent);color:var(--accent);border-radius:10px;align-items:center;gap:.5rem;padding:.9rem 2rem;font-size:.88rem;text-decoration:none;transition:all .35s cubic-bezier(.16,1,.3,1);display:inline-flex}.cta-arrow{transition:transform .3s}.contact-cta:hover{background:var(--accent-glow);color:var(--accent);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.contact-cta:hover .cta-arrow{transform:translate(4px)}.footer{border-top:1px solid var(--border);padding:3rem 1.5rem}.footer-inner{text-align:center;max-width:920px;margin:0 auto}.footer-text{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.02em;font-size:.72rem}.app{flex-direction:column;min-height:100vh;display:flex}main{flex:1}section{max-width:920px;margin:0 auto;padding:7rem 1.5rem}@media (width<=640px){section{padding:4.5rem 1.25rem}}.section-label{font-family:var(--font-mono);color:var(--accent);text-transform:uppercase;letter-spacing:.18em;align-items:center;gap:.75rem;margin-bottom:.75rem;font-size:.78rem;font-weight:500;display:flex}.section-label:before{content:"";background:linear-gradient(90deg, transparent, var(--accent));width:2.5rem;height:1px;display:inline-block}.section-title{color:var(--text-primary);margin-bottom:1rem;font-size:2.1rem;font-weight:700;line-height:1.2}.section-subtitle{color:var(--text-muted);max-width:560px;margin-bottom:2.75rem;font-size:1rem;line-height:1.7}@media (width<=640px){.section-title{font-size:1.65rem}}:root,[data-theme=dark]{--bg-primary:#0a0a0f;--bg-secondary:#111119;--bg-card:#16161f;--bg-card-hover:#1c1c2a;--border:#252535;--border-hover:#3a3a55;--text-primary:#e8e8ec;--text-secondary:#a0a0b0;--text-muted:#65657a;--accent:#6d9fff;--accent-dim:#4a7bdb;--accent-glow:#6d9fff1f;--accent-glow-strong:#6d9fff40;--green:#34d399;--green-dim:#34d3991a;--green-glow:#34d39933;--shadow-card:0 12px 40px #0003;--shadow-sm:0 4px 12px #0000001f;--navbar-bg:#0a0a0fcc;--canvas-bg:#0a0a10a6;--canvas-grid:#2a2a3a2e;--canvas-legend-text:#777;--canvas-event-text:#a0a0b0;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace}[data-theme=light]{--bg-primary:#f8f9fb;--bg-secondary:#f0f1f4;--bg-card:#fff;--bg-card-hover:#f5f6f8;--border:#dde0e6;--border-hover:#c0c4cc;--text-primary:#1a1a2e;--text-secondary:#4a4a60;--text-muted:#8888a0;--accent:#3b6ee8;--accent-dim:#2d5bc7;--accent-glow:#3b6ee814;--accent-glow-strong:#3b6ee826;--green:#16a368;--green-dim:#16a36814;--green-glow:#16a3681f;--shadow-card:0 12px 40px #0000000f;--shadow-sm:0 4px 12px #0000000a;--navbar-bg:#f8f9fbd9;--canvas-bg:#f0f1f4cc;--canvas-grid:#b4b9c82e;--canvas-legend-text:#888;--canvas-event-text:#555}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.7;transition:background .35s,color .35s;overflow-x:hidden}a{color:var(--accent);text-decoration:none;transition:color .25s}a:hover{color:var(--accent-dim)}::selection{background:var(--accent);color:#fff}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.reveal{opacity:0;transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);transform:translateY(32px)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}.reveal-delay-5{transition-delay:.5s}.reveal-delay-6{transition-delay:.6s}.reveal-left{opacity:0;transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);transform:translate(-32px)}.reveal-left.visible{opacity:1;transform:translate(0)}.reveal-scale{opacity:0;transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1);transform:scale(.92)}.reveal-scale.visible{opacity:1;transform:scale(1)}
