*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}:root,[data-theme=dark]{--bg:#020208;--fg:#e2e8f0;--muted:#94a3b8;--accent-1:#60a5fa;--accent-2:#818cf8;--accent-gradient:linear-gradient(90deg, var(--accent-1), var(--accent-2));--card-bg:rgba(15, 23, 42, 0.4);--card-border:rgba(71, 85, 105, 0.15);--card-shadow:0 1px 3px rgba(0, 0, 0, 0.4);--navbar-bg:rgba(2, 2, 8, 0.6);--nav-border:rgba(71, 85, 105, 0.1);--input-bg:rgba(15, 23, 42, 0.6);--input-border:rgba(71, 85, 105, 0.2);--tag-bg:rgba(96, 165, 250, 0.08);--tag-fg:#60a5fa;--timeline-line:rgba(96, 165, 250, 0.15);--footer-color:#334155}[data-theme=light]{--bg:#f5f5f7;--fg:#1d1d1f;--muted:#6e6e73;--accent-1:#007aff;--accent-2:#5856d6;--accent-gradient:linear-gradient(90deg, var(--accent-1), var(--accent-2));--card-bg:rgba(0, 0, 0, 0.03);--card-border:rgba(0, 0, 0, 0.08);--card-shadow:0 1px 3px rgba(0, 0, 0, 0.04);--navbar-bg:rgba(245, 245, 247, 0.8);--nav-border:rgba(0, 0, 0, 0.06);--input-bg:rgba(0, 0, 0, 0.04);--input-border:rgba(0, 0, 0, 0.1);--tag-bg:rgba(0, 122, 255, 0.08);--tag-fg:#007aff;--timeline-line:rgba(0, 122, 255, 0.15);--footer-color:#8e8e93}html{scroll-behavior:smooth;font-size:16px}body{background:var(--bg);color:var(--fg);font-family:inter,system-ui,-apple-system,sans-serif;line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;transition:background-color .3s ease,color .3s ease}a{color:inherit;text-decoration:none}#audio-canvas{position:fixed;inset:0;z-index:0;pointer-events:none;width:100%;height:100%}.site-wrapper{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column}.navbar{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:.85rem 2rem;background:var(--navbar-bg);border-bottom:1px solid var(--nav-border)}.navbar-brand{display:flex;align-items:center;gap:.6rem;font-weight:700;font-size:1.15rem;letter-spacing:-.02em}.navbar-brand svg{width:24px;height:24px;color:var(--accent-1)}.navbar-links{display:flex;align-items:center;gap:1.75rem;list-style:none;font-size:.9rem;font-weight:500}.navbar-links a,.navbar-links button{color:var(--muted);transition:color .2s ease,background-color .2s ease;background:0 0;border:none;cursor:pointer;font-size:inherit;font-weight:inherit;font-family:inherit;display:flex;align-items:center;gap:.3rem}.navbar-links a:hover,.navbar-links button:hover{color:var(--fg)}.hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem 2rem 3rem;text-align:center;max-width:800px;margin:0 auto}.hero-photo{width:120px;height:120px;border-radius:50%;object-fit:cover;margin-bottom:1.5rem;border:3px solid var(--card-border);box-shadow:0 4px 20px rgba(0,0,0,.3)}.hero h1{font-size:clamp(2.2rem,5vw,3.4rem);font-weight:800;letter-spacing:-.04em;line-height:1.15;margin-bottom:.5rem}.gradient-text{background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero .tagline{font-size:clamp(.85rem,2vw,1rem);color:var(--accent-3);letter-spacing:.06em;text-transform:uppercase;font-weight:600;margin-bottom:1rem}.hero .subtitle{font-size:clamp(1rem,2.5vw,1.2rem);color:var(--muted);max-width:580px;margin:0 auto .6rem;line-height:1.7}.hero .fine-print{font-size:.82rem;color:var(--muted);max-width:520px;margin:0 auto 2rem;font-style:italic}[data-theme=light] .hero .fine-print{color:#94a3b8}.btn-group{display:flex;gap:.85rem;flex-wrap:wrap;justify-content:center}.btn{display:inline-flex;align-items:center;gap:.45rem;padding:.65rem 1.45rem;border-radius:8px;font-size:.92rem;font-weight:600;cursor:pointer;border:none;transition:transform .15s ease,box-shadow .2s ease,background-color .3s ease}.btn:hover{transform:translateY(-1px)}.btn-primary{background:var(--accent-gradient);color:#fff}[data-theme=dark] .btn-primary:hover{box-shadow:0 4px 24px rgba(96,165,250,.25)}.btn-secondary{background:var(--card-bg);color:var(--fg);border:1px solid var(--card-border)}[data-theme=dark] .btn-secondary{box-shadow:0 4px 24px rgba(59,130,246,8%)}[data-theme=dark] .btn-secondary:hover{box-shadow:0 4px 24px rgba(96,165,250,8%)}.projects-section{max-width:900px;margin:0 auto;padding:3rem 2rem 4rem}.projects-section>h2{font-size:1.6rem;font-weight:700;letter-spacing:-.03em;margin-bottom:.5rem}.projects-section>p.subtitle{color:var(--muted);margin-bottom:2.5rem;font-size:.95rem}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem}.project-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;padding:1.5rem;transition:transform .15s ease,box-shadow .2s ease,background-color .3s ease;display:flex;flex-direction:column}.project-card:hover{transform:translateY(-2px);box-shadow:var(--card-shadow)}[data-theme=dark] .project-card:hover{box-shadow:0 8px 32px rgba(0,0,0,.4)}.project-card-date{font-size:.75rem;color:var(--muted);margin-bottom:.6rem}.project-card h3{font-size:1.15rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.5rem}.project-card h3 a:hover{color:var(--accent-2)}.project-card-desc{color:var(--muted);font-size:.88rem;line-height:1.65;margin-bottom:1rem;flex:1}.project-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem}.project-tag{background:var(--tag-bg);color:var(--tag-fg);font-size:.72rem;font-weight:600;padding:.2rem .55rem;border-radius:4px;letter-spacing:.03em}.project-links{display:flex;gap:.8rem;flex-wrap:wrap}.project-link{font-size:.82rem;font-weight:600;color:var(--accent-1);text-decoration:underline;text-decoration-color:rgba(96,165,250,.3);text-underline-offset:3px;transition:text-decoration-color .2s ease}.project-link:hover{text-decoration-color:var(--accent-1)}.about-header{display:flex;align-items:center;gap:2rem;margin-bottom:2.5rem;flex-wrap:wrap}.about-photo{width:140px;height:140px;border-radius:50%;object-fit:cover;border:3px solid var(--card-border);box-shadow:0 4px 20px rgba(0,0,0,.3);flex-shrink:0}.about-info h1{margin-bottom:.3rem}.about-bio{color:var(--muted);font-size:.95rem;line-height:1.7}.contact-section{max-width:680px;margin:0 auto;padding:3rem 2rem}.contact-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.2rem;margin-top:1.5rem}.contact-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;padding:1.5rem;text-align:center;transition:transform .15s ease,box-shadow .2s ease,background-color .3s ease}.contact-card:hover{transform:translateY(-2px);box-shadow:var(--card-shadow)}[data-theme=dark] .contact-card:hover{box-shadow:0 8px 32px rgba(0,0,0,.4)}.contact-card-icon{width:40px;height:40px;margin:0 auto .8rem;color:var(--accent-2)}.contact-card h3{font-size:.95rem;font-weight:600;margin-bottom:.4rem}.contact-card p{font-size:.85rem;color:var(--muted);margin-bottom:1rem}.copy-btn{background:var(--input-bg);border:1px solid var(--input-border);color:var(--fg);font-size:.78rem;font-weight:600;padding:.4rem 1rem;border-radius:6px;cursor:pointer;transition:background-color .2s ease,transform .15s ease}.copy-btn:hover{background:rgba(96,165,250,.1);border-color:var(--accent-1);color:var(--accent-1)}.copy-btn.copied{background:rgba(34,197,94,.15);border-color:#22c55e;color:#22c55e}.content-page{max-width:720px;margin:0 auto;padding:3rem 2rem 4rem}.content-page h1,.content-page h2,.content-page h3{letter-spacing:-.03em;margin-top:1.8rem;margin-bottom:.5rem}.content-page h1{font-size:1.8rem}.content-page h2{font-size:1.4rem}.content-page p{color:var(--muted);line-height:1.75;margin-bottom:1rem}.content-page a{color:var(--accent-1);text-decoration:underline;text-decoration-color:rgba(96,165,250,.3);text-underline-offset:3px;transition:text-decoration-color .2s ease}.content-page a:hover{text-decoration-color:var(--accent-1)}.content-page code{font-family:jetbrains mono,ui-monospace,monospace;background:rgba(96,165,250,4%);padding:.15em .45em;border-radius:4px;font-size:.88em}.content-page pre{background:rgba(96,165,250,3%);border:1px solid var(--card-border);padding:1rem 1.25rem;border-radius:8px;overflow-x:auto;margin-bottom:1rem}.content-page pre code{background:0 0;padding:0;font-size:.85rem}.content-page blockquote{border-left:3px solid var(--accent-3);padding-left:1rem;color:#a1a1aa;margin:1rem 0}.content-page hr{border:none;border-top:1px solid var(--card-border);margin:2rem 0}.error-page{min-height:calc(100vh - 80px);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:3rem 2rem}.error-page .error-code{font-size:clamp(4rem,12vw,8rem);font-weight:900;letter-spacing:-.06em;line-height:1;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.error-page h2{font-size:1.4rem;font-weight:700;letter-spacing:-.03em;margin-bottom:.8rem}.error-page p{color:var(--muted);max-width:480px;line-height:1.7;margin-bottom:2rem}.footer{text-align:center;padding:2rem;font-size:.78rem;color:var(--footer-color);border-top:1px solid rgba(71,85,105,8%)}[data-theme=light] .footer{border-top:1px solid rgba(15,23,42,6%)}.footer-links{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}.footer-links a{color:var(--muted);transition:color .2s ease}.footer-links a:hover{color:var(--accent-1)}.footer-links svg{width:16px;height:16px}.error-body{display:flex;flex-direction:column}.error-wrapper{flex:1;display:flex;align-items:center;justify-content:center}.error-signal{font-family:jetbrains mono,ui-monospace,monospace;font-size:clamp(.8rem,2vw,1rem);color:var(--muted);letter-spacing:.15em;margin-bottom:.3rem;opacity:.6}.error-desc{max-width:480px;font-size:.95rem;line-height:1.7;margin-bottom:2rem}.timeline{position:relative;padding-left:2rem;margin:1.5rem 0}.timeline::before{content:"";position:absolute;left:6px;top:4px;bottom:4px;width:2px;background:var(--timeline-line);border-radius:1px}.timeline-item{position:relative;margin-bottom:2rem;padding-left:1.5rem}.timeline-item::before{content:"";position:absolute;left:-2rem;top:7px;width:14px;height:14px;border-radius:50%;background:var(--accent-gradient);border:2px solid var(--bg)}.timeline-item .time{font-size:.78rem;color:var(--muted);margin-bottom:.2rem}.timeline-item h3{font-size:1.05rem;font-weight:700;letter-spacing:-.02em}.timeline-item .org{color:var(--accent-3);font-size:.88rem;font-weight:500;margin-bottom:.4rem}.timeline-item p{color:var(--muted);font-size:.88rem;line-height:1.65}@media(max-width:768px){.navbar{padding:.8rem 1.25rem}.navbar-links{gap:1rem;font-size:.82rem}.hero{padding:3rem 1.25rem 2rem}.about-header{flex-direction:column;text-align:center}.project-grid{grid-template-columns:1fr}.contact-cards{grid-template-columns:1fr}}@media(max-width:480px){.navbar-links a span{display:none}.btn-group{flex-direction:column;width:100%;max-width:260px}.btn{justify-content:center}}.hero>*{animation:fadeUp .6s ease both}.hero svg{animation-delay:.05s}.hero h1{animation-delay:.12s}.hero .tagline{animation-delay:.18s}.hero .subtitle{animation-delay:.24s}.hero .fine-print{animation-delay:.3s}.hero .btn-group{animation-delay:.36s}@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.08s}.reveal-delay-2{transition-delay:.16s}.reveal-delay-3{transition-delay:.24s}.reveal-delay-4{transition-delay:.32s}