:root{--bg: #0d0d0d;--surface: #181818;--card: #1e1e1e;--border: #2c2c2c;--text: #e5e5e5;--muted: #888;--accent: #4a8140;--nav-h: 60px;--max-w: 1100px;--radius: 10px;--font: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}[data-theme=light]{--bg: #f8f8f8;--surface: #ffffff;--card: #ffffff;--border: #e0e0e0;--text: #111111;--muted: #666666}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{background-color:var(--bg);color:var(--text);font-family:var(--font);line-height:1.6;min-height:100vh;transition:background-color .2s,color .2s}.nav{position:sticky;top:0;height:var(--nav-h);background:color-mix(in srgb,var(--bg) 85%,transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 2.5rem;z-index:100}.nav-logo{font-size:1rem;font-weight:600;letter-spacing:-.01em;color:var(--text);text-decoration:none}.nav-logo .bracket{color:var(--accent)}.nav-links{display:flex;align-items:center;gap:.15rem;list-style:none}.nav-links a{color:var(--muted);text-decoration:none;font-size:.875rem;padding:.4rem .7rem;border-radius:6px;transition:color .15s,background .15s}.nav-links a:hover{color:var(--text);background:var(--surface)}@media (max-width: 560px){.nav-links .nav-label{display:none}.nav{padding:0 1.25rem}}.theme-btn{background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--muted);cursor:pointer;padding:.4rem .55rem;font-size:.95rem;line-height:1;margin-left:.4rem;transition:color .15s,background .15s,border-color .15s}.theme-btn:hover{color:var(--text);border-color:var(--muted)}.section{max-width:var(--max-w);margin:0 auto;padding:90px 2rem}.section-label{font-size:1.1rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:2.5rem}.section-divider{border:none;border-top:1px solid var(--border);max-width:var(--max-w);margin:0 auto}.hero{min-height:calc(100vh - var(--nav-h));display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem;gap:0}.hero-avatar{width:200px;height:200px;image-rendering:pixelated;image-rendering:crisp-edges;margin-bottom:2rem;filter:drop-shadow(0 0 18px color-mix(in srgb,var(--accent) 70%,transparent)) drop-shadow(0 0 40px color-mix(in srgb,var(--accent) 40%,transparent))}.hero-divider{width:48px;height:3px;background:var(--accent);border-radius:2px;margin-bottom:2rem}.hero-content{display:flex;flex-direction:column;align-items:center}.hero-greeting{font-size:1.35rem;color:var(--muted);letter-spacing:.05em;margin-bottom:.5rem}.hero-name{font-size:clamp(3rem,8vw,5.5rem);font-weight:700;letter-spacing:-.04em;color:var(--text);line-height:1;margin-bottom:1rem}.hero-role{font-size:.95rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:.6rem}.hero-stats{font-size:1rem;color:var(--muted);margin-bottom:2.25rem}.hero-cta{display:flex;gap:.65rem;flex-wrap:wrap;align-items:center;justify-content:center}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.65rem 1.35rem;border-radius:var(--radius);font-size:.875rem;font-weight:500;text-decoration:none;cursor:pointer;border:1px solid transparent;transition:opacity .15s,color .15s,background .15s,border-color .15s;font-family:var(--font)}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{opacity:.85}.btn-ghost{background:transparent;color:var(--muted);border-color:var(--border)}.btn-ghost:hover{color:var(--text);border-color:var(--muted)}.about-grid{display:grid;grid-template-columns:1fr 260px;gap:4rem;align-items:start}.about-text p{color:var(--muted);font-size:1rem;line-height:1.85;margin-bottom:1.2rem}.about-text p:last-child{margin-bottom:0}.about-text strong{color:var(--text);font-weight:500}.about-photo{width:100%;aspect-ratio:1;object-fit:cover;border-radius:var(--radius);border:1px solid var(--border)}@media (max-width: 720px){.about-grid{grid-template-columns:1fr}.about-photo{max-width:220px;margin:0 auto;display:block}}.projects-controls{display:flex;flex-direction:row;gap:2.5rem;margin-bottom:2rem;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:.6rem}.filter-group-label{font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.filter-bar{display:flex;flex-wrap:wrap;gap:.5rem}.projects-empty{color:var(--muted);font-size:.9rem;padding:3rem 0;text-align:center}.filter-btn{padding:.4rem .9rem;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--muted);font-size:.82rem;font-weight:500;cursor:pointer;font-family:var(--font);transition:color .15s,background .15s,border-color .15s}.filter-btn:hover{color:var(--text);border-color:var(--muted)}.filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}.project-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:border-color .2s}.project-card:hover{border-color:color-mix(in srgb,var(--accent) 60%,transparent)}.img-viewer{position:relative;aspect-ratio:16 / 9;background:var(--surface);overflow:hidden}.img-viewer img{width:100%;height:100%;object-fit:cover;object-position:top;display:block}.img-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.55);border:none;color:#fff;width:26px;height:26px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.8rem;padding:0;transition:background .15s;line-height:1}.img-btn:hover{background:rgba(0,0,0,.8)}.img-btn-prev{left:8px}.img-btn-next{right:8px}.img-dots{position:absolute;bottom:8px;left:50%;transform:translate(-50%);display:flex;gap:4px;background:rgba(0,0,0,.35);padding:4px 6px;border-radius:10px}.img-dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.35);border:none;cursor:pointer;padding:0;transition:background .15s}.img-dot.active{background:rgba(255,255,255,.9)}.video-viewer{position:relative;aspect-ratio:16 / 9;background:#000}.video-viewer iframe,.video-viewer video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border:none}.project-body{padding:1.2rem;flex:1;display:flex;flex-direction:column}.project-meta{display:flex;align-items:center;margin-bottom:.4rem}.project-type{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:500}.project-year{font-size:.7rem;color:var(--accent);font-weight:600;margin-left:auto}.project-name{font-size:1.05rem;font-weight:600;color:var(--text);margin-bottom:.5rem}.project-desc{font-size:.85rem;color:var(--muted);line-height:1.65;flex:1;margin-bottom:1rem}.project-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.project-skills{display:flex;flex-wrap:wrap;gap:.3rem}.skill-tag{font-size:.68rem;font-weight:500;padding:.2rem .5rem;border-radius:4px;background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 28%,transparent)}.project-link{font-size:.78rem;color:var(--muted);text-decoration:none;display:inline-flex;align-items:center;gap:.25rem;transition:color .15s}.project-link:hover{color:var(--text)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.7);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:500;padding:1.5rem}.modal-box{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:660px;max-height:90vh;overflow-y:auto;position:relative}.modal-close{position:absolute;top:.7rem;right:.7rem;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--muted);cursor:pointer;padding:.3rem .5rem;font-size:.85rem;z-index:1;transition:color .15s,border-color .15s}.modal-close:hover{color:var(--text);border-color:var(--muted)}.modal-body{padding:1.5rem}.modal-name{font-size:1.4rem;font-weight:700;color:var(--text);letter-spacing:-.02em;margin-bottom:.75rem}.modal-desc{font-size:.95rem;color:var(--muted);line-height:1.8;margin-bottom:1.25rem}.resume-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.75rem}.resume-embed{width:100%;height:78vh;border:1px solid var(--border);border-radius:var(--radius)}.site-footer{border-top:1px solid var(--border);padding:1.75rem 2rem;display:flex;align-items:center;justify-content:center;gap:1.25rem;flex-wrap:wrap}.site-footer a{color:var(--muted);font-size:1.15rem;text-decoration:none;transition:color .15s}.site-footer a:hover{color:var(--text)}.footer-copy{font-size:.78rem;color:var(--muted);margin-left:.5rem}
