:root{--bg: #0e1116;--panel: #161a21;--ink: #e8eaed;--muted: #9098a3;--ring: #232a33;--accent: #4fb6ac;--accent-soft: rgba(79,182,172,.07);--radius: 18px;--sidebar-w: min(320px, 36vw);--maxw: 1100px;--mast-h: 56px}:root.light{--bg: #f5f7f5;--panel: #ffffff;--ink: #14171a;--muted: #5b6168;--ring: #e2e6e3;--accent: #2f8f86;--accent-soft: rgba(47, 143, 134, .06)}*{box-sizing:border-box}html{scroll-behavior:smooth}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--ink);font-family:ui-sans-serif,system-ui,Inter,Segoe UI,Roboto,sans-serif;line-height:1.6}a{color:inherit;text-decoration:underline;text-underline-offset:2px}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}.masthead{position:sticky;top:0;z-index:900;background:color-mix(in srgb,var(--bg) 85%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--ring)}.masthead-inner{max-width:var(--maxw);margin:0 auto;height:var(--mast-h);padding:0 min(5vw,32px);display:flex;align-items:center;gap:18px}.brand{font-weight:800;letter-spacing:-.01em;text-decoration:none;color:var(--ink)}.nav{margin-left:auto;display:flex;align-items:center;gap:20px;flex-wrap:wrap}.nav a{color:var(--muted);text-decoration:none;font-size:.95rem;transition:color .15s ease}.nav a:hover{color:var(--accent)}.layout{display:grid;grid-template-columns:var(--sidebar-w) 1fr;gap:40px;max-width:var(--maxw);margin:0 auto;padding:44px min(5vw,32px) 96px;min-height:100vh}@media(max-width:900px){.layout{grid-template-columns:1fr;gap:28px}}.content{gap:48px;display:grid;align-content:start}.sidebar{background:transparent}.card{position:sticky;top:calc(var(--mast-h) + 24px);padding:28px 24px;border:1px solid var(--ring);border-radius:var(--radius);background:radial-gradient(1200px 1200px at -100px -100px,rgba(124,58,237,.06),transparent 50%),radial-gradient(1200px 1200px at 100% 120%,rgba(124,58,237,.05),transparent 50%);display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px}.avatar{width:160px;height:160px;object-fit:cover;border-radius:50%;border:3px solid var(--ring);display:block}.identity{margin-top:2px}.name{margin:0;font-size:1.5rem;line-height:1.2;font-weight:900;letter-spacing:-.01em}.accent{color:var(--accent)}.role{margin:4px 0 0;color:var(--muted);font-size:.95rem}.tagline{margin:6px 0 0;font-size:.9rem;opacity:.9;max-width:32ch}.meta{display:grid;gap:6px;width:100%;justify-items:center}.meta-row{display:inline-flex;align-items:center;gap:8px;color:var(--muted);text-decoration:none;font-size:.9rem}.links{display:flex;gap:10px;justify-content:center}.icon-link{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:999px;background:var(--panel);border:1px solid var(--ring);color:var(--ink);text-decoration:none;transition:border-color .15s ease,transform .12s ease}.icon-link:hover{border-color:var(--accent);transform:translateY(-1px)}.actions{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.section{scroll-margin-top:calc(var(--mast-h) + 20px)}.section-title{margin:0 0 18px;padding-bottom:10px;border-bottom:1px solid var(--ring)}.section-pill{font-size:clamp(1.3rem,2.4vw,1.7rem);font-weight:800;letter-spacing:-.01em}.hero{margin:0 0 10px;font-size:clamp(1.5rem,2.6vw,2.1rem);font-weight:900;letter-spacing:-.015em;line-height:1.1}.lede{color:var(--muted);margin:6px 0 0;max-width:66ch}.lede a,.about a{color:var(--accent)}.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-top:4px}.project-card{position:relative;z-index:0;background:var(--panel);background-clip:padding-box;border:2px solid var(--ring);border-radius:var(--radius);padding:16px 16px 18px;text-decoration:none;color:inherit;transition:transform .12s ease,filter .12s ease}a.project-card:hover,a.project-card:focus-visible{transform:translateY(-1px);z-index:2;filter:drop-shadow(7px 7px 0 var(--accent))}.project-card.feature{grid-column:1 / -1}.project-title{font-weight:800;margin:0 0 6px}.card-meta{margin:0 0 8px;font-size:.8rem;font-weight:600;color:var(--accent)}.card-links{display:flex;flex-wrap:wrap;gap:16px;margin-top:14px}.card-links a{display:inline-flex;align-items:center;gap:4px;color:var(--ink);text-decoration:none;font-size:.9rem;border-bottom:1px solid var(--accent);padding-bottom:1px;transition:color .15s ease}.card-links a:hover{color:var(--accent)}.status{margin-left:8px;padding:2px 8px;border-radius:999px;font-size:.7rem;font-weight:600;vertical-align:middle;color:var(--accent);border:1px solid var(--accent)}.project-desc{color:var(--muted);margin:0;font-size:.95rem}.project-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}.chip{border:1px solid var(--ring);border-radius:999px;padding:2px 8px;font-size:.75rem;color:var(--muted)}.more-link{display:inline-flex;align-items:center;gap:4px;margin-top:18px;color:var(--muted);text-decoration:none;font-size:.9rem;transition:color .15s ease}.more-link:hover{color:var(--accent)}.tool-root{z-index:1000}.tool-root.masthead{position:relative;display:inline-flex}.tool-root.masthead .tool-popover{left:auto;right:0}.tool-trigger{display:grid;place-items:center;width:32px;height:32px;border-radius:999px;background:#fff;border:2px solid var(--ring);cursor:pointer;transition:border-color .15s ease,transform .12s ease}.tool-trigger:hover{border-color:var(--accent);transform:translateY(-1px)}.tool-trigger img{width:16px;height:16px;display:block}.tool-popover{position:absolute;top:42px;background:var(--panel);border:1px solid var(--ring);border-radius:12px;padding:10px 12px;min-width:160px;box-shadow:0 12px 28px #00000059}.tool-group{display:grid;gap:8px}.tool-title{font-weight:700;font-size:.85rem;color:var(--muted);margin-bottom:2px}.radio{display:flex;align-items:center;gap:8px;font-size:.95rem}.radio input{accent-color:var(--accent)}
