:root{--bg: #fafaf9;--fg: #18181b;--muted: #6b7280;--rule: #e5e7eb;--tag-bg: #ffffff;--accent: #4f46e5;--status: #16a34a;--max-width: 680px;--font-serif: "Newsreader", ui-serif, Georgia, "Times New Roman", serif;--font-sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;--font-mono: ui-monospace, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace}:root[data-theme=dark]{--bg: #0b0b0c;--fg: #f4f4f5;--muted: #9ca3af;--rule: #27272a;--tag-bg: #131316;--accent: #a5b4fc;--status: #4ade80}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--fg);font-family:var(--font-sans);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}main{max-width:var(--max-width);margin:0 auto;padding:5rem 1.5rem 6rem}h1{font-family:var(--font-serif);font-size:2.25rem;font-weight:500;margin:0 0 .4rem;letter-spacing:-.02em;line-height:1.1}h2{font-family:var(--font-serif);font-style:italic;font-size:1.05rem;font-weight:400;color:var(--muted);margin:0 0 1.25rem;letter-spacing:0}p{margin:0 0 .75rem}a{color:inherit;text-decoration:none;border-bottom:1px solid var(--rule);transition:border-color .15s ease,color .15s ease}a:hover{border-bottom-color:var(--accent);color:var(--accent)}a:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}.arrow{display:inline-block;transition:transform .15s ease;margin-left:.2rem;font-size:.95em}a:hover .arrow.ext{transform:translate(2px,-2px)}a:hover .arrow.fwd{transform:translate(3px)}.intro .role{color:var(--muted);margin-bottom:.5rem;font-size:.95rem}.intro .status{display:inline-flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--muted);margin:0 0 1.75rem}.dot{width:.5rem;height:.5rem;border-radius:50%;background:var(--status);display:inline-block;box-shadow:0 0 0 3px color-mix(in srgb,var(--status) 18%,transparent)}.intro .bio p:last-child{margin-bottom:0}.intro .bio p{color:var(--fg)}.section{margin-top:4rem}.projects,.experience,.links{list-style:none;padding:0;margin:0}.project{padding:1.25rem 0;border-top:1px solid var(--rule)}.project:last-child{border-bottom:1px solid var(--rule)}.project-head{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:.4rem}.project-name{font-weight:500;font-size:1rem;border:none}.project-name:hover{border:none;color:var(--accent)}.project-year{color:var(--muted);font-family:var(--font-mono);font-size:.78rem;font-variant-numeric:tabular-nums;flex-shrink:0}.project-desc{margin:0 0 .65rem}.project-tags{margin-top:.5rem}.experience li{padding:1.25rem 0;border-top:1px solid var(--rule)}.experience li:last-child{border-bottom:1px solid var(--rule)}.exp-head{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:.25rem}.exp-role{font-weight:500}.exp-company{color:var(--muted);font-weight:400}.exp-period{color:var(--muted);font-family:var(--font-mono);font-size:.78rem;font-variant-numeric:tabular-nums;flex-shrink:0}.experience p{margin:0;color:var(--muted)}.tags{display:flex;flex-wrap:wrap;gap:.4rem;margin:0;padding:0;list-style:none}.tag{display:inline-flex;align-items:center;font-family:var(--font-mono);font-size:.72rem;padding:.2rem .55rem;border:1px solid var(--rule);border-radius:999px;color:var(--muted);background:var(--tag-bg);letter-spacing:.01em;line-height:1.4}.achievements{list-style:none;padding:0;margin:0}.achievements li{padding:.85rem 0;border-top:1px solid var(--rule)}.achievements li:last-child{border-bottom:1px solid var(--rule)}.links li{margin-bottom:.5rem}.links li:last-child{margin-bottom:0}.theme-toggle{position:fixed;top:1.25rem;right:1.25rem;width:2.25rem;height:2.25rem;display:inline-flex;align-items:center;justify-content:center;background:var(--bg);color:var(--muted);border:1px solid var(--rule);border-radius:999px;cursor:pointer;transition:color .15s ease,border-color .15s ease,transform .15s ease;z-index:10}.theme-toggle:hover{color:var(--fg);border-color:var(--fg)}.theme-toggle:active{transform:scale(.96)}.theme-toggle svg{width:16px;height:16px}:root[data-theme=dark] .theme-toggle .icon-moon{display:none}:root[data-theme=light] .theme-toggle .icon-sun,:root:not([data-theme=dark]) .theme-toggle .icon-sun{display:none}@media(max-width:480px){main{padding:3.5rem 1.25rem 4rem}h1{font-size:1.85rem}.project-head,.exp-head{flex-direction:column;gap:.15rem}.theme-toggle{top:1rem;right:1rem}}
