@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--color-primary: #197AA9;--color-primary-light: #2A9ED4;--color-primary-dark: #125A80;--color-surface: #F8FAFC;--color-surface-2: #FFFFFF;--color-border: #E2E8F0;--color-text: #1A202C;--color-text-muted: #64748B;--color-code-bg: #F1F5F9;--cat-ai: #7C3AED;--cat-backend: #059669;--cat-architecture: #D97706;--cat-security: #DC2626;--cat-notes: #6B7280;--radius: 8px;--radius-lg: 14px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 16px rgba(0,0,0,.08);--transition: .2s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased}body{font-family:Inter,system-ui,sans-serif;background:var(--color-surface);color:var(--color-text);line-height:1.7;min-height:100vh}.container{max-width:1100px;margin:0 auto;padding:0 1.5rem}.container--narrow{max-width:720px;margin:0 auto;padding:0 1.5rem}nav{position:sticky;top:0;z-index:100;background:#f8fafceb;backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border)}.nav-inner{max-width:1100px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:60px}.nav-logo{font-size:1rem;font-weight:600;color:var(--color-text);text-decoration:none;letter-spacing:-.02em}.nav-logo span{color:var(--color-primary)}.nav-links{display:flex;align-items:center;gap:.25rem;list-style:none}.nav-links a{font-size:.875rem;font-weight:500;color:var(--color-text-muted);text-decoration:none;padding:.375rem .75rem;border-radius:var(--radius);transition:color var(--transition),background var(--transition)}.nav-links a:hover{color:var(--color-text);background:var(--color-border)}.nav-links a.active{color:var(--color-primary)}.nav-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}.nav-hamburger span{display:block;width:22px;height:2px;background:var(--color-text);border-radius:2px;transition:var(--transition)}.hero{padding:6rem 0 4rem;border-bottom:1px solid var(--color-border)}.hero-label{display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.08em;color:var(--color-primary);text-transform:uppercase;margin-bottom:1.25rem}.hero h1{font-size:clamp(2rem,5vw,3.25rem);font-weight:700;letter-spacing:-.03em;line-height:1.15;margin-bottom:1.25rem;color:var(--color-text)}.hero-bio{font-size:1.125rem;color:var(--color-text-muted);max-width:560px;line-height:1.75;margin-bottom:2rem}.hero-links{display:flex;gap:.75rem;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;font-size:.875rem;font-weight:500;border-radius:var(--radius);text-decoration:none;transition:all var(--transition);cursor:pointer;border:none}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.btn-outline{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.btn-outline:hover{border-color:var(--color-primary);color:var(--color-primary);background:#197aa90a}.section-header{margin-bottom:2rem}.section-title{font-size:1.375rem;font-weight:600;letter-spacing:-.02em;color:var(--color-text)}.section-title+.section-sub{margin-top:.375rem;font-size:.9rem;color:var(--color-text-muted)}.section-link{font-size:.8rem;font-weight:500;color:var(--color-primary);text-decoration:none}.section-link:hover{text-decoration:underline}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.category-card{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem 1.25rem;text-decoration:none;display:block;transition:all var(--transition);position:relative;overflow:hidden}.category-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--cat-color, var(--color-primary));transform:scaleX(0);transform-origin:left;transition:transform var(--transition)}.category-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:transparent}.category-card:hover:before{transform:scaleX(1)}.category-card-name{font-size:.9rem;font-weight:600;color:var(--cat-color, var(--color-primary));margin-bottom:.375rem}.category-card-desc{font-size:.825rem;color:var(--color-text-muted);line-height:1.5}.category-card-count{font-size:.75rem;color:var(--color-text-muted);margin-top:.75rem}.posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.25rem}.post-card{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;text-decoration:none;display:flex;flex-direction:column;transition:all var(--transition)}.post-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:#197aa933}.post-card-meta{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.post-card-cat{font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--cat-color, var(--color-primary))}.post-card-date{font-size:.775rem;color:var(--color-text-muted)}.post-card-dot{width:3px;height:3px;border-radius:50%;background:var(--color-border)}.post-card h3{font-size:1rem;font-weight:600;letter-spacing:-.01em;color:var(--color-text);line-height:1.45;margin-bottom:.625rem}.post-card p{font-size:.875rem;color:var(--color-text-muted);line-height:1.65;flex:1}.post-card-tags{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:1rem}.tag{font-size:.7rem;font-weight:500;padding:.25rem .625rem;background:var(--color-code-bg);border:1px solid var(--color-border);border-radius:100px;color:var(--color-text-muted);text-decoration:none;transition:all var(--transition)}.tag:hover{border-color:var(--color-primary);color:var(--color-primary)}.reading-meta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;font-size:.8rem;color:var(--color-text-muted)}.reading-meta-dot{width:3px;height:3px;border-radius:50%;background:var(--color-border)}.cat-header{padding:4rem 0 3rem;border-bottom:1px solid var(--color-border)}.cat-breadcrumb{font-size:.8rem;color:var(--color-text-muted);margin-bottom:1rem}.cat-breadcrumb a{color:var(--color-primary);text-decoration:none}.cat-breadcrumb a:hover{text-decoration:underline}.cat-header h1{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;letter-spacing:-.025em;color:var(--color-text);margin-bottom:.75rem}.cat-desc{font-size:1rem;color:var(--color-text-muted);max-width:540px}.cat-accent{display:inline-block;width:40px;height:3px;border-radius:2px;margin-bottom:1.25rem}.post-list{list-style:none}.post-list-item{display:block;text-decoration:none;padding:1.5rem 0;border-bottom:1px solid var(--color-border);transition:var(--transition)}.post-list-item:hover .post-list-title{color:var(--color-primary)}.post-list-meta{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.775rem;color:var(--color-text-muted)}.post-list-title{font-size:1.1rem;font-weight:600;color:var(--color-text);letter-spacing:-.01em;margin-bottom:.5rem;line-height:1.4;transition:color var(--transition)}.post-list-desc{font-size:.875rem;color:var(--color-text-muted);line-height:1.65}.article-header{padding:4rem 0 2.5rem;border-bottom:1px solid var(--color-border)}.article-header h1{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;letter-spacing:-.025em;color:var(--color-text);margin-bottom:1rem;line-height:1.25}.article-header-desc{font-size:1.0625rem;color:var(--color-text-muted);line-height:1.75;margin-bottom:1.5rem}.prose{padding:2.5rem 0 4rem}.prose h2{font-size:1.375rem;font-weight:600;letter-spacing:-.02em;color:var(--color-text);margin:2.5rem 0 1rem}.prose h3{font-size:1.1rem;font-weight:600;margin:2rem 0 .75rem;color:var(--color-text)}.prose p{margin-bottom:1.25rem;line-height:1.8;font-size:1rem}.prose ul,.prose ol{padding-left:1.5rem;margin-bottom:1.25rem}.prose li{margin-bottom:.4rem;line-height:1.75}.prose a{color:var(--color-primary);text-decoration:underline;text-decoration-thickness:1px}.prose a:hover{text-decoration-thickness:2px}.prose strong{font-weight:600}.prose code{font-family:JetBrains Mono,monospace;font-size:.85em;background:var(--color-code-bg);border:1px solid var(--color-border);padding:.15em .4em;border-radius:4px}.prose pre{background:#0f172a;border-radius:var(--radius-lg);padding:1.5rem;overflow-x:auto;margin:1.5rem 0;border:1px solid #1E293B}.prose pre code{background:none;border:none;padding:0;font-size:.875rem;color:#e2e8f0;line-height:1.75}.prose blockquote{border-left:3px solid var(--color-primary);padding:.75rem 1.25rem;margin:1.5rem 0;background:#197aa90a;border-radius:0 var(--radius) var(--radius) 0;color:var(--color-text-muted)}.about-hero{padding:5rem 0 3rem;border-bottom:1px solid var(--color-border)}.about-hero h1{font-size:clamp(1.75rem,4vw,2.75rem);font-weight:700;letter-spacing:-.03em;margin-bottom:1.25rem;line-height:1.2}.about-hero p{font-size:1.0625rem;color:var(--color-text-muted);line-height:1.8;max-width:600px}.about-section{padding:3rem 0;border-bottom:1px solid var(--color-border)}.about-section h2{font-size:1.125rem;font-weight:600;letter-spacing:-.01em;margin-bottom:1.25rem}.skill-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.skill-group h3{font-size:.75rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-primary);margin-bottom:.625rem}.skill-list{list-style:none}.skill-list li{font-size:.875rem;color:var(--color-text-muted);padding:.2rem 0;border-bottom:1px solid var(--color-border)}.connect-links{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1rem}.projects-hero{padding:4.5rem 0 3rem;border-bottom:1px solid var(--color-border)}.projects-hero h1{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;letter-spacing:-.025em;margin-bottom:.75rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.25rem;padding:3rem 0}.project-card{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.75rem;transition:all var(--transition)}.project-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:#197aa933}.project-card-label{font-size:.7rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--color-primary);margin-bottom:.75rem}.project-card h3{font-size:1.0625rem;font-weight:600;letter-spacing:-.01em;margin-bottom:.625rem}.project-card p{font-size:.875rem;color:var(--color-text-muted);line-height:1.7}.project-stack{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:1.25rem}.project-card-links{display:flex;gap:.75rem;margin-top:1.25rem}.project-link{font-size:.8rem;font-weight:500;color:var(--color-primary);text-decoration:none}.project-link:hover{text-decoration:underline}footer{border-top:1px solid var(--color-border);padding:2.5rem 0;margin-top:auto}.footer-inner{max-width:1100px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.footer-copy{font-size:.8rem;color:var(--color-text-muted)}.footer-links{display:flex;gap:1.25rem}.footer-links a{font-size:.8rem;color:var(--color-text-muted);text-decoration:none}.footer-links a:hover{color:var(--color-primary)}.home-section{padding:4rem 0;border-bottom:1px solid var(--color-border)}.home-section:last-child{border-bottom:none}.section-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:2rem}@media(max-width:768px){.nav-links{display:none}.nav-links.open{display:flex;flex-direction:column;position:absolute;top:60px;left:0;right:0;background:var(--color-surface-2);border-bottom:1px solid var(--color-border);padding:1rem 1.5rem;gap:.25rem;box-shadow:var(--shadow-md)}.nav-hamburger{display:flex}.hero{padding:3.5rem 0 3rem}.categories-grid{grid-template-columns:1fr 1fr}.posts-grid,.projects-grid{grid-template-columns:1fr}.skill-grid{grid-template-columns:1fr 1fr}.footer-inner{flex-direction:column;gap:.75rem}}@media(max-width:480px){.categories-grid,.skill-grid{grid-template-columns:1fr}}
