:root{--color-bg: #fafafa;--color-bg-secondary: #ffffff;--color-text: #171717;--color-text-secondary: #525252;--color-text-muted: #a3a3a3;--color-border: #e5e5e5;--color-accent: #171717;--color-accent-hover: #404040;--color-link: #171717;--color-link-hover: #525252;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", Consolas, monospace;--text-xs: clamp(.75rem, .7rem + .25vw, .875rem);--text-sm: clamp(.875rem, .8rem + .375vw, 1rem);--text-base: clamp(1rem, .9rem + .5vw, 1.125rem);--text-lg: clamp(1.125rem, 1rem + .625vw, 1.25rem);--text-xl: clamp(1.25rem, 1.1rem + .75vw, 1.5rem);--text-2xl: clamp(1.5rem, 1.25rem + 1.25vw, 2rem);--text-3xl: clamp(1.875rem, 1.5rem + 1.875vw, 2.5rem);--text-4xl: clamp(2.25rem, 1.75rem + 2.5vw, 3rem);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--space-4xl: 6rem;--max-width: 680px;--header-height: 64px;--transition-fast: .15s ease;--transition-base: .25s ease;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:1.7;color:var(--color-text);background-color:var(--color-bg);min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;letter-spacing:-.02em;color:var(--color-text)}h1{font-size:var(--text-3xl);margin-bottom:var(--space-lg)}h2{font-size:var(--text-2xl);margin-top:var(--space-2xl);margin-bottom:var(--space-md)}h3{font-size:var(--text-xl);margin-top:var(--space-xl);margin-bottom:var(--space-sm)}h4{font-size:var(--text-lg);margin-top:var(--space-lg);margin-bottom:var(--space-sm)}p{margin-bottom:var(--space-md);color:var(--color-text-secondary)}a{color:var(--color-link);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px;transition:color var(--transition-fast)}a:hover{color:var(--color-link-hover)}strong,b{font-weight:600;color:var(--color-text)}em,i{font-style:italic}blockquote{margin:var(--space-xl) 0;padding-left:var(--space-lg);border-left:2px solid var(--color-border);color:var(--color-text-secondary);font-style:italic}ul,ol{margin:var(--space-md) 0;padding-left:var(--space-lg);color:var(--color-text-secondary)}li{margin-bottom:var(--space-xs)}li::marker{color:var(--color-text-muted)}hr{border:none;border-top:1px solid var(--color-border);margin:var(--space-2xl) 0}code{font-family:var(--font-mono);font-size:.9em;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);padding:.15em .4em;border-radius:var(--radius-sm)}pre{font-family:var(--font-mono);font-size:var(--text-sm);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);overflow-x:auto;margin:var(--space-lg) 0}pre code{background:none;border:none;padding:0;font-size:inherit}.astro-code{background-color:var(--color-bg-secondary)!important;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md)!important}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg)}.page{min-height:100vh;display:flex;flex-direction:column}main{flex:1;padding:var(--space-3xl) 0}.header{position:sticky;top:0;z-index:100;background-color:var(--color-bg);border-bottom:1px solid var(--color-border)}.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-height)}.logo{font-size:var(--text-lg);font-weight:600;color:var(--color-text);text-decoration:none;letter-spacing:-.02em}.logo:hover{color:var(--color-text)}.nav{display:flex;gap:var(--space-xl)}.nav-link{font-size:var(--text-sm);color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition-fast)}.nav-link:hover,.nav-link.active{color:var(--color-text)}.footer{padding:var(--space-2xl) 0;border-top:1px solid var(--color-border)}.footer-inner{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);text-align:center}.footer-links{display:flex;gap:var(--space-lg)}.footer-link{font-size:var(--text-sm);color:var(--color-text-muted);text-decoration:none;transition:color var(--transition-fast)}.footer-link:hover{color:var(--color-text)}.footer-text{font-size:var(--text-xs);color:var(--color-text-muted);margin:0}.hero{padding:var(--space-4xl) 0 var(--space-3xl)}.hero-title{font-size:var(--text-4xl);font-weight:700;margin-bottom:var(--space-md);letter-spacing:-.03em}.hero-subtitle{font-size:var(--text-lg);color:var(--color-text-secondary);max-width:540px;margin-bottom:var(--space-xl)}.hero-links{display:flex;gap:var(--space-lg)}.hero-link{font-size:var(--text-sm);color:var(--color-text-muted);text-decoration:none;display:flex;align-items:center;gap:var(--space-xs);transition:color var(--transition-fast)}.hero-link:hover{color:var(--color-text)}.section{margin-bottom:var(--space-3xl)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.section-title{font-size:var(--text-sm);font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin:0}.section-link{font-size:var(--text-sm);color:var(--color-text-muted);text-decoration:none}.section-link:hover{color:var(--color-text)}.post-list{display:flex;flex-direction:column;gap:var(--space-lg)}.post-item{display:flex;flex-direction:column;gap:var(--space-xs)}.post-link{font-size:var(--text-base);font-weight:500;color:var(--color-text);text-decoration:none;transition:color var(--transition-fast)}.post-link:hover{color:var(--color-text-secondary)}.post-meta{font-size:var(--text-sm);color:var(--color-text-muted)}.post-date{font-family:var(--font-mono);font-size:var(--text-xs)}.project-list{display:flex;flex-direction:column;gap:var(--space-lg)}.project-item{display:flex;flex-direction:column;gap:var(--space-xs)}.project-name{font-weight:500;color:var(--color-text);text-decoration:none}.project-name:hover{color:var(--color-text-secondary)}.project-description{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0}.post-header{margin-bottom:var(--space-2xl)}.post-title{font-size:var(--text-3xl);font-weight:700;margin-bottom:var(--space-sm);letter-spacing:-.03em}.post-header .post-meta{font-size:var(--text-sm);color:var(--color-text-muted)}.post-content{margin-bottom:var(--space-3xl)}.post-content h2:first-child{margin-top:0}.post-content img{max-width:100%;height:auto;border-radius:var(--radius-md);margin:var(--space-lg) 0}.experience-list{display:flex;flex-direction:column;gap:var(--space-2xl)}.experience-item{padding-bottom:var(--space-xl);border-bottom:1px solid var(--color-border)}.experience-item:last-child{border-bottom:none}.experience-header{margin-bottom:var(--space-md)}.experience-role{font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-xs)}.experience-company{color:var(--color-text-secondary)}.experience-meta{font-size:var(--text-sm);color:var(--color-text-muted);font-family:var(--font-mono)}.experience-details{margin-top:var(--space-md)}.experience-details li{margin-bottom:var(--space-sm)}.skills-grid{display:grid;gap:var(--space-lg)}.skills-category h4{font-size:var(--text-sm);font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin:0 0 var(--space-sm) 0}.skills-category p{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0}@media(max-width:640px){.hero{padding:var(--space-2xl) 0}.hero-links{flex-direction:column;gap:var(--space-sm)}.nav{gap:var(--space-md)}.section-header{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fadeIn .5s ease forwards}
