:root{--primary-color: #2563eb;--text-color: #1f2937;--bg-color: #ffffff;--border-color: #e5e7eb;--code-bg: #f3f4f6}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;color:var(--text-color);background:var(--bg-color);line-height:1.7}header{border-bottom:1px solid var(--border-color);padding:1rem 2rem}header nav{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}header nav .site-title{font-size:1.5rem;font-weight:bold;color:var(--text-color);text-decoration:none}header nav ul{list-style:none;display:flex;gap:2rem}header nav ul a{color:var(--text-color);text-decoration:none}header nav ul a:hover{color:var(--primary-color)}main{max-width:800px;margin:0 auto;padding:2rem}footer{border-top:1px solid var(--border-color);padding:2rem;text-align:center;color:#6b7280}.hero{text-align:center;padding:3rem 0}.hero h1{font-size:2.5rem;margin-bottom:1rem}.hero p{font-size:1.25rem;color:#6b7280}.recent-posts,.section-header{margin-bottom:2rem}.recent-posts h2,.section-header h2{font-size:1.5rem;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px solid var(--primary-color)}.post-list{list-style:none}.post-list li{padding:1.5rem 0;border-bottom:1px solid var(--border-color)}.post-list li:last-child{border-bottom:none}.post-list article h2,.post-list article h3{margin-bottom:.5rem}.post-list article h2 a,.post-list article h3 a{color:var(--text-color);text-decoration:none}.post-list article h2 a:hover,.post-list article h3 a:hover{color:var(--primary-color)}.post-list article time{color:#6b7280;font-size:.875rem}.post-list article p{margin-top:.5rem;color:#4b5563}.view-all{display:inline-block;margin-top:1rem;color:var(--primary-color);text-decoration:none}.view-all:hover{text-decoration:underline}.tags{margin-top:.5rem}.tags .tag{display:inline-block;background:var(--code-bg);padding:.25rem .75rem;border-radius:1rem;font-size:.75rem;margin-right:.5rem}.post .post-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.post .post-header h1{font-size:2rem;margin-bottom:.5rem}.post .post-header time{color:#6b7280}.post .post-content h2{font-size:1.5rem;margin:2rem 0 1rem}.post .post-content h3{font-size:1.25rem;margin:1.5rem 0 .75rem}.post .post-content p{margin-bottom:1rem}.post .post-content ul,.post .post-content ol{margin:1rem 0 1rem 2rem}.post .post-content code{background:var(--code-bg);padding:.2rem .4rem;border-radius:.25rem;font-size:.875em}.post .post-content pre{background:var(--code-bg);padding:1rem;border-radius:.5rem;overflow-x:auto;margin:1rem 0}.post .post-content pre code{background:none;padding:0}.post .post-content table{width:100%;border-collapse:collapse;margin:1rem 0}.post .post-content table th,.post .post-content table td{border:1px solid var(--border-color);padding:.75rem;text-align:left}.post .post-content table th{background:var(--code-bg)}.post .post-content a{color:var(--primary-color)}.marimo-embed{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border-color)}.marimo-embed h2{margin-bottom:1rem}.marimo-embed iframe{border:1px solid var(--border-color);border-radius:.5rem}.post-nav{display:flex;justify-content:space-between;margin-top:3rem;padding-top:1rem;border-top:1px solid var(--border-color)}.post-nav a{color:var(--primary-color);text-decoration:none}.post-nav a:hover{text-decoration:underline}