@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;600;800&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.nav-root{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-height);background:#ffffffd1;-webkit-backdrop-filter:saturate(140%) blur(8px);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--border)}.nav-inner{height:100%;display:flex;align-items:center;justify-content:space-between}.brand{display:inline-flex;align-items:center;gap:10px;color:var(--text);text-decoration:none;font-weight:800;letter-spacing:.3px}.brand .dot{width:10px;height:10px;background:var(--accent);border-radius:50%}.nav-links{display:flex;gap:18px}.nav-links a{text-decoration:none;color:var(--muted);padding:8px 10px;border-radius:8px}.nav-links a.active,.nav-links a:hover{color:var(--accent);background:var(--accent-weak)}.hamburger{display:none;width:42px;height:42px;border:1px solid var(--border);border-radius:12px;background:#fff;align-items:center;justify-content:center;gap:4px}.hamburger span{width:18px;height:2px;background:var(--text);display:block}@media (max-width: 800px){.hamburger{display:inline-flex}.nav-links{position:absolute;top:calc(var(--nav-height) + 8px);right:20px;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:10px;flex-direction:column;width:180px;display:none}.nav-links.open{display:flex}}.about-root{padding:56px 0 40px}.about-grid{display:grid;grid-template-columns:1.2fr .8fr;align-items:center;gap:24px;min-height:calc(100vh - var(--nav-height))}.about-title{margin:10px 0 8px;font-size:clamp(28px,5vw,48px);line-height:1.05}.about-sub{margin:0 0 16px;color:var(--muted);max-width:56ch}.about-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:12px}.about-social{display:flex;gap:16px;flex-wrap:wrap}.about-social a{font-size:14px;color:var(--muted);text-decoration:none;font-weight:500;transition:color .16s ease}.about-social a:hover{color:var(--accent)}.headshot{width:100%;aspect-ratio:2 / 3;border-radius:var(--radius);border:1px solid var(--border);background:radial-gradient(120px 120px at 70% 30%,#e7f1ff,transparent 60%),linear-gradient(135deg,#eef2ff,#f8fafc);box-shadow:var(--shadow)}@media (max-width: 900px){.about-grid{grid-template-columns:1fr;padding:12px 0 0}}.exp-root{padding:72px 0 8px;border-top:1px solid var(--border)}.exp-title{font-size:clamp(22px,3.5vw,32px);margin:0 0 18px}.exp-list{display:grid;gap:16px}.exp-card{border:1px solid var(--border);border-radius:var(--radius);padding:18px 18px 10px;background:#fff;box-shadow:var(--shadow)}.exp-head{display:grid;gap:6px;margin-bottom:8px}.exp-head h3{margin:0;font-size:18px}.company{color:var(--accent);font-weight:600}.period{color:var(--muted);font-size:14px}.exp-card ul{margin:10px 0 6px 18px;color:var(--muted)}.proj-root{padding:72px 0 8px;border-top:1px solid var(--border);background:#fff}.proj-title{font-size:clamp(22px,3.5vw,32px);margin:0 0 18px}.proj-grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.project-card{display:grid;grid-template-rows:auto 1fr auto;gap:12px;border:1px solid var(--border);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow);overflow:hidden;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.project-card:hover{transform:translateY(-4px);box-shadow:0 10px 34px #0206171f;border-color:#2563eb59}.pc-media{position:relative;width:100%;background:#f8fafc;border-bottom:1px solid var(--border)}.pc-image{display:block;width:100%;height:auto;object-fit:contain}.pc-content{padding:14px 16px 0}.pc-title{margin:0 0 8px;font-size:18px;line-height:1.25}.pc-skills{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 10px}.pc-skill{font-size:12px;line-height:1;padding:5px 10px}.pc-skill.more{background:#f1f5f9;color:var(--muted);border:1px solid var(--border)}.pc-desc{margin:0 0 6px;color:var(--muted)}.pc-actions{display:flex;gap:10px;padding:0 16px 16px;flex-wrap:wrap}.contact-root{padding:72px 0 8px;border-top:1px solid var(--border);background:#fff}.contact-title{font-size:clamp(22px,3.5vw,32px);margin:0 0 18px}.contact-form{border:1px solid var(--border);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow);padding:20px;display:grid;gap:14px}.hp{position:absolute;left:-10000px;width:1px;height:1px;overflow:hidden}.row{display:grid;gap:14px;grid-template-columns:1fr 1fr}.field{display:grid;gap:6px}label{font-weight:600}input[type=text],input[type=email],textarea{width:100%;border:1px solid var(--border);border-radius:10px;background:#fff;padding:10px 12px;font:inherit;color:var(--text);transition:border-color .16s ease,box-shadow .16s ease}textarea{resize:vertical}input:focus,textarea:focus{outline:none;border-color:#2563eba6;box-shadow:0 0 0 4px #2563eb1f}[aria-invalid=true]{border-color:#ef4444;box-shadow:0 0 0 4px #ef44441f}.err{color:#b91c1c;font-size:12px}.actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:4px}.status{min-height:1.2em;font-size:14px;color:var(--muted)}.status.success{color:#15803d}.status.error{color:#b91c1c}@media (max-width: 800px){.row{grid-template-columns:1fr}}.footer-root{margin-top:64px;border-top:1px solid var(--border);background:#fff}.footer-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 0;gap:12px}.copy{margin:0;color:var(--muted);font-size:14px}.footer-links{display:flex;gap:14px}.footer-links a{color:var(--muted);text-decoration:none}.footer-links a:hover{color:var(--accent)}:root{--bg: #ffffff;--text: #0f172a;--muted: #475569;--accent: #2563eb;--accent-weak: #e0ecff;--border: #e2e8f0;--nav-height: 64px;--maxw: 1100px;--radius: 14px;--shadow: 0 6px 28px rgba(2, 6, 23, .08)}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;background:var(--bg)}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:var(--bg)}.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}section{scroll-margin-top:var(--nav-height)}.reveal{opacity:0;transform:translateY(12px);transition:opacity .42s ease,transform .42s ease}.reveal.in-view{opacity:1;transform:translateY(0)}.btn{display:inline-flex;gap:8px;align-items:center;padding:10px 14px;border-radius:999px;border:1px solid var(--border);text-decoration:none;color:var(--text);background:#fff;box-shadow:var(--shadow)}.btn.primary{border-color:transparent;background:var(--accent);color:#fff}.tag{display:inline-block;padding:4px 10px;border-radius:999px;background:var(--accent-weak);color:var(--accent);font-weight:600;font-size:12px}
