*,*:before,*:after{box-sizing:border-box}:root,[data-theme=light]{--bg: #faf6f1;--bg-card: #ffffff;--bg-subtle: #f0ebe3;--bg-accent: #fef3e2;--border: #e0d5c7;--border-hover: #c9b9a5;--text: #2c1d13;--text-muted: #7a6555;--text-heading: #1a0f08;--accent: #c45d2c;--accent-hover: #a84a1f;--accent-glow: rgba(196, 93, 44, .15);--code-bg: #f5ede4;--code-text: #9a4a20;--shadow-sm: 0 1px 3px rgba(44, 29, 19, .06);--shadow-md: 0 4px 12px rgba(44, 29, 19, .08);--shadow-lg: 0 8px 30px rgba(44, 29, 19, .1);--grain-opacity: .03;--nav-bg: rgba(250, 246, 241, .85);--toggle-icon-sun: none;--toggle-icon-moon: block}[data-theme=dark]{--bg: #171310;--bg-card: #1e1a16;--bg-subtle: #242019;--bg-accent: #2a2218;--border: #3a3228;--border-hover: #504538;--text: #e8e0d6;--text-muted: #9a8b7a;--text-heading: #f5efe8;--accent: #e8854a;--accent-hover: #f0a06a;--accent-glow: rgba(232, 133, 74, .15);--code-bg: #242019;--code-text: #e8a76a;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .25);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .3);--grain-opacity: .04;--nav-bg: rgba(23, 19, 16, .85);--toggle-icon-sun: block;--toggle-icon-moon: none}html{font-family:Karla,system-ui,sans-serif;font-size:17px;line-height:1.7;color:var(--text);background:var(--bg);scroll-behavior:smooth;transition:background .4s ease,color .3s ease}body{margin:0;min-height:100vh;display:flex;flex-direction:column}::selection{background:var(--accent-glow);color:var(--text-heading)}.site-nav-wrap,.post-card,.project-card,.now-card,.site-footer,.tag,.post-card-tag,.social-pill,.theme-toggle{transition:background-color .3s ease,border-color .3s ease,box-shadow .3s ease,color .3s ease,transform .25s ease}.grain{position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:var(--grain-opacity);background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px}.site-nav{position:sticky;top:0;z-index:100;display:flex;justify-content:space-between;align-items:center;max-width:52rem;margin:0 auto;padding:.75rem 1.5rem;background:var(--nav-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:background .3s ease}.site-nav-wrap{position:sticky;top:0;z-index:100;background:var(--nav-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:background .3s ease}.site-nav-wrap .site-nav{position:static;background:none;backdrop-filter:none;-webkit-backdrop-filter:none;border-bottom:none}.nav-home{font-family:Fraunces,Georgia,serif;font-weight:700;font-size:1.25rem;color:var(--text-heading);text-decoration:none;letter-spacing:-.02em}.nav-home:hover{color:var(--accent);text-decoration:none}.theme-toggle{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--border);border-radius:10px;background:var(--bg-card);color:var(--text-muted);cursor:pointer;transition:all .2s ease}.theme-toggle:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.theme-toggle .icon-sun{display:var(--toggle-icon-sun);transition:transform .4s cubic-bezier(.34,1.56,.64,1)}.theme-toggle .icon-moon{display:var(--toggle-icon-moon);transition:transform .4s cubic-bezier(.34,1.56,.64,1)}.theme-toggle:hover .icon-sun{transform:rotate(45deg)}.theme-toggle:hover .icon-moon{transform:rotate(-15deg) scale(1.1)}.page{max-width:52rem;margin:0 auto;padding:2rem 1.5rem 4rem;flex:1;width:100%}.page-narrow{max-width:42rem}h1,h2,h3,h4{font-family:Fraunces,Georgia,serif;line-height:1.2;color:var(--text-heading);letter-spacing:-.02em}h1{font-size:2.5rem;font-weight:800;margin-top:0;margin-bottom:.5rem}h2{font-size:1.5rem;font-weight:700;margin-top:3rem;margin-bottom:.75rem}h3{font-size:1.2rem;font-weight:600;margin-top:2rem;margin-bottom:.5rem}p{margin:0 0 1rem}a{color:var(--accent);text-decoration:none;transition:color .2s ease}a:hover{color:var(--accent-hover);text-decoration:underline;text-underline-offset:3px}code{font-family:ui-monospace,Cascadia Code,Source Code Pro,monospace;font-size:.85em;background:var(--code-bg);color:var(--code-text);padding:.15em .4em;border-radius:5px}pre{background:var(--code-bg);border:1px solid var(--border);padding:1.25rem;border-radius:10px;overflow-x:auto;margin:1.5rem 0}pre code{background:none;padding:0;color:var(--text);font-size:.875em}blockquote{border-left:3px solid var(--accent);margin-left:0;padding-left:1.25rem;color:var(--text-muted);font-style:italic}hr{border:none;border-top:1px solid var(--border);margin:3rem 0}img{max-width:100%;height:auto;border-radius:8px}.section-label{font-family:Karla,system-ui,sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem;margin-top:0;display:flex;align-items:center;gap:.6rem}.section-label:before{content:"";width:20px;height:2px;background:var(--accent);border-radius:1px;flex-shrink:0}.section-divider{border:none;height:1px;background:linear-gradient(to right,transparent,var(--border),transparent);margin:3.5rem 0}.hero{padding:2.5rem 0 1rem;animation:fadeInUp .6s ease both}.hero-profile{display:flex;align-items:center;gap:1.75rem;margin-bottom:1.25rem}.avatar{width:120px;height:120px;border-radius:50%;object-fit:cover;flex-shrink:0;border:3px solid var(--bg-subtle);box-shadow:0 0 0 4px var(--accent-glow),var(--shadow-lg);transition:transform .4s cubic-bezier(.34,1.56,.64,1),box-shadow .3s ease}.avatar:hover{transform:scale(1.06) rotate(2deg);box-shadow:0 0 0 6px var(--accent-glow),var(--shadow-lg)}.hero-info h1{margin:0;font-size:2.2rem;position:relative;display:inline-block}.hero-info h1:after{content:"";position:absolute;bottom:-4px;left:0;width:60%;height:3px;background:linear-gradient(to right,var(--accent),transparent);border-radius:2px}.hero-tagline{color:var(--text-muted);font-size:1.05rem;margin:.25rem 0 0;font-style:italic;font-family:Fraunces,Georgia,serif;font-weight:400}.social-pills{display:flex;gap:.5rem;margin-top:.75rem}.social-pill{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;font-weight:600;color:var(--text-muted);background:var(--bg-subtle);border:1px solid var(--border);padding:.4em .85em;border-radius:999px;text-decoration:none;transition:all .25s ease}.social-pill:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-glow);text-decoration:none;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.social-pill svg{width:14px;height:14px}.about-section{animation:fadeInUp .6s ease .1s both}.about-text{color:var(--text);font-size:1rem;line-height:1.8}.about-text p:last-child{margin-bottom:0}.writing-section{animation:fadeInUp .6s ease .2s both}.writing-grid{display:grid;gap:1rem}.post-card{display:grid;grid-template-columns:1fr;background:var(--bg-card);border:1px solid var(--border);border-left:3px solid transparent;border-radius:12px;padding:1.25rem 1.5rem;text-decoration:none;color:var(--text);transition:all .25s ease;box-shadow:var(--shadow-sm)}.post-card:hover{border-color:var(--border-hover);border-left-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-2px);text-decoration:none;color:var(--text)}.post-card-with-cover{grid-template-columns:100px 1fr;gap:1.25rem;align-items:center}.post-card-cover{width:100px;height:70px;object-fit:cover;border-radius:8px;flex-shrink:0}.post-card-title{font-family:Fraunces,Georgia,serif;font-size:1.1rem;font-weight:600;color:var(--text-heading);margin:0 0 .3rem;line-height:1.35;transition:color .2s ease}.post-card:hover .post-card-title{color:var(--accent)}.post-card-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.post-card-date{color:var(--text-muted);font-size:.78rem;font-variant-numeric:tabular-nums}.post-card-tags{display:flex;gap:.35rem;flex-wrap:wrap}.post-card-tag{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:var(--bg-accent);color:var(--accent);padding:.15em .5em;border-radius:4px}.post-card-external{color:var(--text-muted);font-size:.8rem;margin-left:auto}.projects-section{animation:fadeInUp .6s ease .3s both}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.5rem;transition:all .25s ease;box-shadow:var(--shadow-sm)}.project-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.project-card-emoji{font-size:1.75rem;margin-bottom:.75rem;display:block}.project-card-title{font-family:Fraunces,Georgia,serif;font-size:1.05rem;font-weight:700;color:var(--text-heading);margin:0 0 .4rem}.project-card-desc{color:var(--text-muted);font-size:.88rem;line-height:1.6;margin:0}.project-card-link{display:inline-block;margin-top:.75rem;font-size:.82rem;font-weight:600}.now-section{animation:fadeInUp .6s ease .4s both}.now-card{background:var(--bg-accent);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:12px;padding:1.75rem}.now-card p{color:var(--text);line-height:1.8}.now-card p:last-child{margin-bottom:0}.now-date{color:var(--text-muted);font-size:.78rem;font-style:italic}.site-footer{border-top:1px solid var(--border);padding:2rem 1.5rem;margin-top:auto;transition:background .3s ease}.footer-inner{max-width:52rem;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.footer-name{font-family:Fraunces,Georgia,serif;font-size:.9rem;font-weight:600;color:var(--text-muted);margin:0}.footer-links{display:flex;gap:1rem}.footer-links a{font-size:.82rem;color:var(--text-muted)}.footer-links a:hover{color:var(--accent)}.cover-image{display:block;width:100%;max-height:340px;object-fit:cover;border-radius:12px;margin-bottom:2rem;box-shadow:var(--shadow-md)}.post-header{margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border);animation:fadeInUp .5s ease both}.post-header h1{font-size:2.2rem;margin-bottom:.5rem}.post-meta{color:var(--text-muted);font-size:.88rem;margin:0}.tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.75rem}.tag{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:var(--bg-accent);border:1px solid var(--border);color:var(--accent);padding:.2em .65em;border-radius:6px}.back-link{display:inline-block;margin-bottom:2rem;font-size:.88rem;font-weight:500;color:var(--text-muted);transition:color .2s ease}.back-link:hover{color:var(--accent)}.post-body{animation:fadeInUp .5s ease .15s both}.post-body p{margin-bottom:1.25rem}.post-body ul,.post-body ol{padding-left:1.5rem;margin-bottom:1.25rem}.post-body li{margin-bottom:.4rem}.post-body li::marker{color:var(--accent)}.post-body h2{margin-top:2.5rem}.post-body h3{margin-top:2rem}.post-body img{margin:1.5rem 0;box-shadow:var(--shadow-sm)}.post-body a{text-decoration:underline;text-decoration-color:var(--accent-glow);text-underline-offset:3px;text-decoration-thickness:2px}.post-body a:hover{text-decoration-color:var(--accent)}.post-origin{display:flex;align-items:center;gap:.85rem;background:var(--bg-accent);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:10px;padding:.9rem 1.25rem;margin:0 0 2rem;font-family:Fraunces,Georgia,serif;font-style:italic;font-size:.95rem;color:var(--text-muted);animation:fadeInUp .5s ease .08s both}.post-origin:before{content:"↗";flex-shrink:0;font-style:normal;font-size:1rem;color:var(--accent);line-height:1}.post-origin a{font-weight:600;color:var(--accent);text-decoration:underline;text-decoration-color:var(--accent-glow);text-underline-offset:3px;text-decoration-thickness:2px;transition:color .2s ease,text-decoration-color .2s ease,box-shadow .2s ease}.post-origin a:hover{color:var(--accent-hover);text-decoration-color:var(--accent);text-decoration:underline}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media(min-width:720px){.writing-grid{grid-template-columns:repeat(2,1fr)}.post-card-with-cover{grid-template-columns:1fr}.post-card-cover{width:100%;height:120px}}@media(max-width:719px){.page{padding:1.5rem 1.25rem 3rem}.section-divider{margin:2.5rem 0}h1{font-size:2rem}.hero{padding:1.5rem 0 .5rem}.hero-info h1{font-size:1.9rem}}@media(max-width:520px){html{font-size:16px}.page{padding:1.25rem 1rem 2.5rem}.hero-profile{flex-direction:column;text-align:center}.social-pills{justify-content:center}.hero-info h1{font-size:1.6rem}.hero-tagline{font-size:.95rem}h1,.post-header h1{font-size:1.6rem}.section-divider{margin:2rem 0}.post-card{padding:1rem 1.15rem}.post-card-with-cover{grid-template-columns:1fr}.post-card-cover{width:100%;height:140px}.projects-grid{grid-template-columns:1fr}.project-card,.now-card{padding:1.25rem}.footer-inner{flex-direction:column;gap:.75rem;text-align:center}.avatar{width:96px;height:96px}.site-nav{padding:.6rem 1rem}.cover-image{border-radius:8px;max-height:220px}}
