#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;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}}:root{--bg: #f5f5f7;--bg-alt: #ffffff;--bg-soft: #f9fafb;--text: #111827;--text-strong: #0b1120;--muted: #6b7280;--border: #e5e7eb;--accent: #2563eb;--accent-soft: #dbeafe;--radius-lg: 18px;--radius-full: 999px;--shadow-soft: 0 18px 40px rgba(15, 23, 42, .08)}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,SF Pro Text,Inter,sans-serif;color:var(--text);background:var(--bg);min-height:100%}body{-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none;transition:color .16s ease,opacity .16s ease}a:hover{text-decoration:underline}.container{width:100%;max-width:1040px;margin:0 auto;padding:0 16px}.site-header{position:sticky;top:0;z-index:10;padding:12px 0;background:#f5f5f7e6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid rgba(229,231,235,.9)}.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}.logo{width:38px;height:38px;border-radius:var(--radius-full);background:var(--accent-soft);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;color:var(--accent)}.nav{display:flex;align-items:center;gap:8px;padding:3px;border-radius:999px;background:#e5e7eb}.nav-link{font-size:.9rem;color:#4b5563;padding:6px 14px;border-radius:999px;transition:background .16s ease,color .16s ease}.nav-link:hover{background:#e5e7eb;color:var(--text-strong)}.nav-link.active{background:#fff;color:var(--accent)}.hero{padding:40px 0 64px}.hero-inner{display:grid;grid-template-columns:minmax(0,2fr) minmax(260px,1fr);gap:32px;align-items:flex-start}.hero-main{max-width:640px}.hero-eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.7rem;color:var(--muted);margin:0 0 8px}.hero-title{font-size:clamp(2.4rem,4vw,3.1rem);margin:0;color:var(--text-strong)}.hero-title span{color:var(--accent)}.hero-subtitle{margin:10px 0 8px;font-weight:600;font-size:1rem;color:#374151}.hero-text{margin:0 0 18px;color:var(--muted);line-height:1.6}.hero-actions{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:9px 18px;border-radius:var(--radius-full);border:1px solid transparent;font-size:.92rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .16s ease,color .16s ease,border-color .16s ease,box-shadow .16s ease,transform .1s ease}.btn.primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-soft)}.btn.primary:hover{background:#1d4ed8;transform:translateY(-1px)}.btn.secondary{background:#fff;color:var(--text);border-color:#d1d5db}.btn.secondary:hover{border-color:#9ca3af}.hero-meta{display:flex;flex-wrap:wrap;gap:18px;margin:0 0 8px}.hero-meta dt{font-size:.75rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}.hero-meta dd{margin:2px 0 0;font-size:.9rem;color:#111827}.hero-links{font-size:.9rem;color:var(--muted);display:flex;align-items:center;gap:6px}.hero-card{background:var(--bg-alt);border-radius:var(--radius-lg);padding:18px 18px 16px;border:1px solid var(--border);box-shadow:var(--shadow-soft)}.hero-card h2{margin-top:0;font-size:1.05rem}.hero-card h3{margin-bottom:4px;margin-top:12px;font-size:.95rem}.small{font-size:.85rem;color:var(--muted)}.pill-list{list-style:none;padding:0;margin:8px 0 0;display:flex;flex-wrap:wrap;gap:6px}.pill-list li{font-size:.78rem;padding:4px 10px;border-radius:999px;background:var(--accent-soft);color:#1d4ed8}.page-header{padding:36px 0 14px}.page-header h1{margin-bottom:4px;color:var(--text-strong)}.page-intro{margin:0 0 10px;color:var(--muted)}.projects{padding:8px 0 52px}.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}.card{background:var(--bg-alt);border-radius:var(--radius-lg);padding:18px 18px 16px;border:1px solid var(--border);box-shadow:var(--shadow-soft);transition:box-shadow .16s ease,transform .12s ease,border-color .16s ease}.card:hover{transform:translateY(-3px);box-shadow:0 20px 40px #0f172a1f;border-color:#d1d5db}.card h2{margin-top:0;font-size:1.02rem}.badge{display:inline-block;font-size:.8rem;margin:4px 0 8px;padding:3px 9px;border-radius:999px;background:var(--accent-soft);color:#1d4ed8}.card-list{padding-left:18px;margin:8px 0;font-size:.9rem;color:var(--muted)}.tech{margin-top:6px;font-size:.84rem;color:#4b5563}.cv-embed{padding-bottom:28px}.cv-object{width:100%;height:80vh;border-radius:12px;border:1px solid var(--border);background:#fff;box-shadow:var(--shadow-soft)}.cv-summary{padding-bottom:52px}.cv-summary h2{color:var(--text-strong)}.two-col{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}.two-col ul{padding-left:18px;color:var(--muted)}.site-footer{padding:18px 0 24px;border-top:1px solid rgba(209,213,219,.9);background:#f3f4f6}.footer-inner{display:flex;justify-content:center;font-size:.85rem;color:var(--muted)}@media(max-width:900px){.hero-inner{grid-template-columns:1fr}.hero-card{order:-1}.nav{gap:4px}.nav-link{padding-inline:10px}}@media(max-width:640px){.site-header{position:static}.hero{padding-top:28px}.hero-meta{flex-direction:column;gap:10px}}
