@import 'https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;1,400&family=Noto+Serif+SC:wght@400;600&family=Outfit:wght@300;400;500&display=swap';:root{--bg:#F8F6F1;--bg-alt:#F0EDE6;--border:#E5E1D8;--border-light:#EDEAE3;--border-faint:#F3F0EA;--ink:#2A2824;--ink-secondary:#7A7468;--ink-muted:#9E978A;--accent:#C45D3E;--accent-soft:rgba(196, 93, 62, 0.07);--font-display:'Playfair Display', 'Noto Serif SC', Georgia, serif;--font-body:'Outfit', 'Noto Serif SC', system-ui, sans-serif;--font-mono:'JetBrains Mono', 'Fira Code', monospace;--content-width:700px;--site-width:1100px}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{font-size:17px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{font-family:var(--font-body);font-weight:300;background:var(--bg);color:var(--ink);line-height:1.75;min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden}body::after{content:'';position:fixed;inset:0;opacity:.018;pointer-events:none;z-index:999;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)'/%3E%3C/svg%3E");background-size:200px}::selection{background:var(--accent);color:#fff}a{color:var(--ink);text-decoration:none;transition:color .3s ease}a:hover{color:var(--accent)}img{max-width:100%;height:auto;display:block}.site-header{position:sticky;top:0;z-index:100;height:60px;padding:0 clamp(1.5rem,4vw,3rem);display:flex;justify-content:space-between;align-items:center;background:rgba(248,246,241,.88);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:.5px solid var(--border)}.site-logo{font-family:var(--font-display);font-size:.82rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);text-decoration:none}.site-nav{display:flex;align-items:center;gap:1.8rem}.site-nav a{font-size:.7rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-muted);transition:color .3s}.site-nav a:hover{color:var(--ink)}.lang-switch{font-size:.72rem;font-weight:400;padding:.3em .9em;border:1px solid var(--border);border-radius:50px;color:var(--ink-secondary);transition:all .3s}.lang-switch:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.hero{max-width:var(--site-width);margin:0 auto;padding:12vh clamp(1.5rem,4vw,3rem)8vh;width:100%;position:relative}.hero::before{content:'';position:absolute;left:clamp(1.5rem,4vw,3rem);top:8vh;width:1.5px;height:90px;background:linear-gradient(to bottom,var(--accent),transparent)}.hero-inner{padding-left:24px}.hero h1{font-family:var(--font-display);font-size:clamp(3rem,6.5vw,4.8rem);font-weight:400;line-height:1.05;letter-spacing:-.03em;color:var(--ink)}.hero .subtitle{font-family:var(--font-display);font-size:clamp(1rem,2vw,1.15rem);font-weight:400;color:var(--accent);margin-top:.4rem;letter-spacing:.06em}.hero .divider{width:28px;height:1px;background:var(--border);margin:1.8rem 0}.hero .tagline{font-size:.82rem;font-weight:300;color:var(--ink-secondary);line-height:1.7;letter-spacing:.015em}.post-list{max-width:var(--site-width);margin:0 auto;padding:0 clamp(1.5rem,4vw,3rem)5rem;width:100%}.post-list-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.8rem;font-size:.65rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-muted)}.post-list-header::after{content:'';flex:1;height:.5px;background:var(--border)}.post-item{display:grid;grid-template-columns:110px 1fr;gap:2rem;padding:1.6rem 0;border-bottom:.5px solid var(--border-faint);text-decoration:none;position:relative;transition:all .35s ease}.post-item::before{content:'';position:absolute;left:-24px;top:1.6rem;width:1.5px;height:0;background:var(--accent);transition:height .4s ease}.post-item:hover::before{height:calc(100% - 3.2rem)}.post-item:hover{padding-left:8px}.post-date{font-size:.78rem;font-weight:300;color:var(--ink-muted);padding-top:.4em;font-variant-numeric:tabular-nums;letter-spacing:.02em}.post-title{font-family:var(--font-display);font-size:1.45rem;font-weight:400;line-height:1.3;letter-spacing:-.01em;color:var(--ink);margin-bottom:.25rem}.post-excerpt{font-size:.82rem;font-weight:300;color:var(--ink-secondary);line-height:1.65;max-width:50ch}.post-category{display:inline-flex;align-items:center;gap:.4em;font-size:.62rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-top:.6rem}.post-category::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--accent)}.post-header{max-width:var(--content-width);margin:5rem auto 2.5rem;padding:0 clamp(1.5rem,4vw,3rem);position:relative}.post-header::before{content:'';position:absolute;left:clamp(1.5rem,4vw,3rem);top:-1rem;width:1.5px;height:60px;background:linear-gradient(to bottom,var(--accent),transparent)}.post-header .back-link{font-size:.7rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-muted);display:inline-block;margin-bottom:2rem;margin-left:24px;transition:color .3s}.post-header .back-link:hover{color:var(--accent)}.post-header h1{font-family:var(--font-display);font-size:clamp(2rem,4.5vw,2.8rem);font-weight:400;line-height:1.2;letter-spacing:-.02em;color:var(--ink);padding-left:24px}.post-meta{display:flex;gap:.8rem;align-items:center;margin-top:1.2rem;padding-left:24px;font-size:.75rem;font-weight:300;color:var(--ink-muted)}.post-meta .sep{width:3px;height:3px;border-radius:50%;background:var(--border);display:inline-block}.post-content{max-width:var(--content-width);margin:0 auto;padding:0 clamp(1.5rem,4vw,3rem)5rem}.post-content p{margin-bottom:1.5em;font-weight:300}.post-content h2{font-family:var(--font-display);font-size:1.6rem;font-weight:400;margin:3em 0 .8em;letter-spacing:-.01em;color:var(--ink);position:relative;padding-left:18px}.post-content h2::before{content:'';position:absolute;left:0;top:0;width:1.5px;height:100%;background:var(--accent);opacity:.6}.post-content h3{font-size:1rem;font-weight:500;margin:2em 0 .5em;letter-spacing:.02em;color:var(--ink)}.post-content ul,.post-content ol{padding-left:1.4em;margin-bottom:1.5em}.post-content li{margin-bottom:.45em;font-weight:300}.post-content blockquote{border-left:1.5px solid var(--accent);padding:.6rem 1.4rem;margin:2rem 0;font-family:var(--font-display);font-size:1.1rem;font-style:italic;font-weight:400;color:var(--ink-secondary);line-height:1.6}.post-content strong{font-weight:500;color:var(--ink)}.post-content code{font-family:var(--font-mono);font-size:.82em;background:var(--bg-alt);padding:.15em .45em;border-radius:3px;border:.5px solid var(--border-light)}.post-content pre{background:var(--bg-alt);padding:1.2rem 1.4rem;border-radius:6px;overflow-x:auto;margin-bottom:1.5em;border:.5px solid var(--border-light)}.post-content pre code{background:0 0;padding:0;border:none}.post-content hr{border:none;margin:3rem 0;text-align:center;line-height:0}.post-content hr::before{content:'· · ·';color:var(--ink-muted);font-size:.85rem;letter-spacing:.4em}.post-tags{max-width:var(--content-width);margin:0 auto;padding:0 clamp(1.5rem,4vw,3rem)4rem;display:flex;flex-wrap:wrap;gap:.5rem}.tag{font-size:.72rem;font-weight:400;letter-spacing:.02em;color:var(--ink-muted);padding:.3em .8em;border:.5px solid var(--border);border-radius:50px;transition:all .3s;text-decoration:none}.tag:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}.site-footer{margin-top:auto;padding:2.5rem clamp(1.5rem,4vw,3rem);text-align:center;font-size:.72rem;font-weight:300;color:var(--ink-muted);letter-spacing:.04em;border-top:.5px solid var(--border-light)}.about-content{max-width:var(--content-width);margin:5rem auto;padding:0 clamp(1.5rem,4vw,3rem)}.about-content h1,.about-content h2{font-family:var(--font-display);font-weight:400;color:var(--ink)}@media(max-width:768px){html{font-size:16px}.hero{padding:8vh 1.5rem 6vh}.hero::before{left:1.5rem}.post-item{grid-template-columns:1fr;gap:.2rem}.post-item::before{display:none}.post-date{padding-top:0}.site-header{padding:0 1rem}.site-nav{gap:1.2rem}.post-header::before{left:1.5rem}}@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes lineGrow{from{height:0}to{height:90px}}@keyframes fadeIn{from{opacity:0}to{opacity:1}}.hero::before{animation:lineGrow .8s cubic-bezier(.22,1,.36,1).2s both}.hero h1{animation:fadeUp .7s cubic-bezier(.22,1,.36,1).1s both}.hero .subtitle{animation:fadeUp .7s cubic-bezier(.22,1,.36,1).2s both}.hero .tagline{animation:fadeUp .7s cubic-bezier(.22,1,.36,1).35s both}.post-item{animation:fadeUp .5s cubic-bezier(.22,1,.36,1)both}.post-item:nth-child(2){animation-delay:.05s}.post-item:nth-child(3){animation-delay:.1s}.post-item:nth-child(4){animation-delay:.15s}.post-header{animation:fadeUp .6s cubic-bezier(.22,1,.36,1)both}.post-content{animation:fadeIn .7s ease .15s both}