@import"https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,400;0,6..72,500;0,6..72,600;1,6..72,400;1,6..72,500&family=Source+Code+Pro:wght@400;500&family=DM+Sans:wght@400;500;600&display=swap";.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}@keyframes astroFadeInOut{0%{opacity:1}to{opacity:0}}@keyframes astroFadeIn{0%{opacity:0;mix-blend-mode:plus-lighter}to{opacity:1;mix-blend-mode:plus-lighter}}@keyframes astroFadeOut{0%{opacity:1;mix-blend-mode:plus-lighter}to{opacity:0;mix-blend-mode:plus-lighter}}@keyframes astroSlideFromRight{0%{transform:translate(100%)}}@keyframes astroSlideFromLeft{0%{transform:translate(-100%)}}@keyframes astroSlideToRight{to{transform:translate(100%)}}@keyframes astroSlideToLeft{to{transform:translate(-100%)}}@media(prefers-reduced-motion){::view-transition-group(*),::view-transition-old(*),::view-transition-new(*){animation:none!important}[data-astro-transition-scope]{animation:none!important}}:root{--font-heading: "Newsreader", Georgia, serif;--font-body: "DM Sans", -apple-system, sans-serif;--font-mono: "Source Code Pro", monospace;--color-bg: #FAFAF8;--color-surface: #FFFFFF;--color-text: #1A1A1A;--color-text-secondary: #6B6B6B;--color-text-tertiary: #9B9B9B;--color-accent: #2D5A27;--color-accent-hover: #1E3D1A;--color-border: #E8E8E4;--color-border-light: #F0F0EC;--color-tag-bg: #F0EDE8;--color-tag-text: #5A5345;--color-code-bg: #F5F3EF;--color-link: #2D5A27;--color-link-hover: #1E3D1A;--color-search-bg: #F5F3EF;--color-github-empty: #EBEDF0;--color-github-l1: #9BE9A8;--color-github-l2: #40C463;--color-github-l3: #30A14E;--color-github-l4: #216E39;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 2px 8px rgba(0,0,0,.06);--radius: 6px;--max-width: 680px;--transition: .2s ease}[data-theme=dark]{--color-bg: #141413;--color-surface: #1C1C1A;--color-text: #E8E8E4;--color-text-secondary: #9B9B9B;--color-text-tertiary: #6B6B6B;--color-accent: #7BC47F;--color-accent-hover: #9BD49E;--color-border: #2A2A28;--color-border-light: #222220;--color-tag-bg: #2A2A28;--color-tag-text: #B5AFA5;--color-code-bg: #1E1E1C;--color-link: #7BC47F;--color-link-hover: #9BD49E;--color-search-bg: #1E1E1C;--color-github-empty: #2A2A28;--color-github-l1: #0E4429;--color-github-l2: #006D32;--color-github-l3: #26A641;--color-github-l4: #39D353;--shadow-sm: 0 1px 2px rgba(0,0,0,.2);--shadow-md: 0 2px 8px rgba(0,0,0,.3)}*,*: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-body);font-size:15px;line-height:1.7;color:var(--color-text);background:var(--color-bg);transition:background var(--transition),color var(--transition)}a{color:var(--color-link);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--color-link-hover)}::selection{background:var(--color-accent);color:#fff}img{max-width:100%;height:auto}.container{max-width:var(--max-width);margin:0 auto;padding:0 24px}header{padding:15px 0 0;position:sticky;top:0;z-index:100;background:var(--color-bg);transition:background var(--transition)}.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--color-border)}.nav-logo{font-family:var(--font-heading);font-size:25px;font-weight:600;color:var(--color-text);letter-spacing:.03em;text-decoration:none}.nav-logo:hover{color:var(--color-accent)}.nav-toggle{display:none;background:none;border:none;cursor:pointer;font-size:34px;font-weight:200;line-height:1;color:var(--color-text);padding:4px;transition:transform .3s ease}.nav-inner[data-menu-open] .nav-toggle{transform:rotate(45deg)}.nav-links{display:flex;align-items:center;gap:24px;list-style:none}.nav-links a{font-size:16px;font-weight:500;color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition);letter-spacing:.01em}.nav-links a:hover,.nav-links a[aria-current=page]{color:var(--color-text)}.nav-search-icon{display:flex;align-items:center}.nav-search-icon svg{width:16px;height:16px;vertical-align:middle}.theme-toggle{background:none;border:none;cursor:pointer;padding:4px;color:var(--color-text-secondary);transition:color var(--transition);display:flex;align-items:center}.theme-toggle:hover{color:var(--color-text)}.theme-toggle svg{width:18px;height:18px}[data-theme=dark] .icon-sun{display:block}[data-theme=dark] .icon-moon,[data-theme=light] .icon-sun{display:none}[data-theme=light] .icon-moon{display:block}.hero{padding:50px 0 10px}.hero-intro{display:flex;align-items:center;gap:20px;margin-bottom:24px}.avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;background:linear-gradient(135deg,var(--color-accent),#4A9B4E)}.avatar--sm{width:64px;height:64px}.avatar--lg{width:115px;height:115px}.avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.avatar-letter{font-family:var(--font-heading);font-weight:600;color:#fff}.avatar--sm .avatar-letter{font-size:24px}.avatar--lg .avatar-letter{font-size:36px}.hero h1{font-family:var(--font-heading);font-size:32px;font-weight:600;line-height:1.25;letter-spacing:-.025em;color:var(--color-text)}.hero-tagline{font-size:16px;color:var(--color-text-secondary);line-height:1.6;max-width:520px;margin-top:4px}.hero-tagline strong{color:var(--color-text);font-weight:500}.social-links{display:flex;justify-content:flex-end;gap:16px;margin-top:24px}.social-links a{color:var(--color-text-tertiary);transition:color var(--transition)}.social-links a:hover{color:var(--color-accent)}.social-links svg{width:23px;height:23px}.divider{border:none;border-top:1px solid var(--color-border);margin:0}.posts-section{padding:24px 0 56px}.post-list{list-style:none}.post-item{border-bottom:1px solid var(--color-border-light);position:relative}.post-link{display:block;padding:20px 0;text-decoration:none;transition:opacity var(--transition)}.post-link:has(+.post-tags){padding-bottom:0}.post-link:after{content:"";position:absolute;inset:0}.post-item:hover .post-link{opacity:.75}.post-link h3{font-family:var(--font-heading);font-size:20px;font-weight:500;color:var(--color-text);line-height:1.35;letter-spacing:-.01em;margin-bottom:8px}.post-excerpt{font-size:14px;color:var(--color-text-secondary);line-height:1.6;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.post-meta{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--color-text-tertiary)}.post-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--color-text-tertiary);display:inline-block}.post-tags{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:6px;margin-top:10px;margin-bottom:20px;position:relative;z-index:2}.tag{font-size:11px;font-weight:500;padding:2px 8px;border-radius:3px;background:var(--color-tag-bg);color:var(--color-tag-text);letter-spacing:.02em;display:inline-block;line-height:1.4;vertical-align:middle}.post-detail{padding:30px 0}.post-detail-header{margin-bottom:48px}.post-detail-header .tag-back{margin-bottom:24px}.post-detail-header h1{font-family:var(--font-heading);font-size:36px;font-weight:600;line-height:1.2;letter-spacing:-.03em;margin-bottom:16px}.post-detail-meta{font-size:14px;color:var(--color-text-tertiary);display:flex;align-items:center;gap:12px}.prose h2{font-family:var(--font-heading);font-size:24px;font-weight:500;margin:40px 0 16px;letter-spacing:-.015em}.prose h3{font-family:var(--font-heading);font-size:20px;font-weight:500;margin:32px 0 12px}.prose p{color:var(--color-text-secondary);margin-bottom:20px;line-height:1.8}.prose a{color:var(--color-link);text-decoration:underline;text-underline-offset:3px}.prose code{font-family:var(--font-mono);font-size:13px;background:var(--color-code-bg);padding:2px 6px;border-radius:3px;color:var(--color-text)}.prose pre{background:var(--color-code-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:20px;overflow-x:auto;margin-bottom:24px;font-size:13px;line-height:1.7}.prose pre code{background:none;padding:0;border-radius:0;font-size:inherit;color:inherit}.prose blockquote{border-left:3px solid var(--color-accent);padding-left:20px;margin:24px 0;color:var(--color-text-secondary);font-style:italic;font-family:var(--font-heading);font-size:17px;line-height:1.6}.prose ul,.prose ol{padding-left:24px;margin-bottom:20px;color:var(--color-text-secondary)}.prose li{margin-bottom:8px;line-height:1.7}.prose img{border-radius:var(--radius);margin:24px 0}.prose hr{border:none;border-top:1px solid var(--color-border);margin:40px 0}.about-section{padding:30px 0 32px}.about-header{display:flex;align-items:center;gap:24px;margin-bottom:48px}.about-header-text h1{font-family:var(--font-heading);font-size:36px;font-weight:600;letter-spacing:-.025em;margin-bottom:4px}.about-header-text .subtitle{font-size:17px;color:var(--color-text-secondary);line-height:1.6}.about-block{margin-bottom:40px}.about-block h2{font-family:var(--font-heading);font-size:22px;font-weight:500;letter-spacing:-.015em;margin-bottom:16px;color:var(--color-text)}.about-block p{color:var(--color-text-secondary);line-height:1.75;margin-bottom:12px}.about-block p strong{color:var(--color-text);font-weight:500}.github-graph{margin-top:32px;padding:24px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.github-graph-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.github-graph-header h3{font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--color-text-secondary)}.github-graph-header a{font-size:12px;color:var(--color-text-tertiary)}.contribution-grid{display:flex;gap:3px;overflow-x:auto;padding-bottom:8px}.contribution-week{display:flex;flex-direction:column;gap:3px}.contribution-day{width:11px;height:11px;border-radius:2px;background:var(--color-github-empty)}.contribution-day.l1{background:var(--color-github-l1)}.contribution-day.l2{background:var(--color-github-l2)}.contribution-day.l3{background:var(--color-github-l3)}.contribution-day.l4{background:var(--color-github-l4)}.contribution-legend{display:flex;align-items:center;gap:4px;justify-content:flex-end;margin-top:8px;font-size:11px;color:var(--color-text-tertiary)}.contribution-legend .contribution-day{width:10px;height:10px}.search-section{padding:30px 0 12px}.search-section h1{font-family:var(--font-heading);font-size:32px;font-weight:600;letter-spacing:-.025em;margin-bottom:19px}.search-input-wrap{position:relative;margin-bottom:27px}.search-input-wrap svg{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--color-text-tertiary);pointer-events:none}.search-input{width:100%;padding:14px 16px 14px 44px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-search-bg);font-family:var(--font-body);font-size:15px;color:var(--color-text);outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.search-input::placeholder{color:var(--color-text-tertiary)}.search-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #2d5a271a}[data-theme=dark] .search-input:focus{box-shadow:0 0 0 3px #7bc47f26}.search-results-count{font-size:13px;color:var(--color-text-tertiary);margin-bottom:16px}footer{padding:32px 0;border-top:1px solid var(--color-border);margin-top:32px}.footer-inner{display:flex;align-items:center;justify-content:space-between;font-size:13px;color:var(--color-text-tertiary)}.footer-inner a{color:var(--color-text-tertiary)}.footer-inner a:hover{color:var(--color-text-secondary)}.archive-section{padding:30px 0 12px}.archive-header{margin-bottom:32px}.archive-header h1{font-family:var(--font-heading);font-size:32px;font-weight:600;letter-spacing:-.025em;margin-bottom:4px}.archive-subtitle{font-size:15px;color:var(--color-text-secondary)}.archive-year{margin-bottom:16px}.year-heading{font-family:var(--font-heading);font-size:26px;font-weight:600;letter-spacing:-.02em;color:var(--color-text);display:flex;align-items:baseline;gap:10px;padding-top:32px;border-top:1px solid var(--color-border);margin-bottom:8px}.year-count{font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--color-text-tertiary)}.archive-month{margin-bottom:8px}.month-heading{font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--color-text-tertiary);display:flex;align-items:baseline;gap:8px;padding:16px 0 4px;text-transform:uppercase;letter-spacing:.06em}.month-count{font-size:12px;font-weight:500;color:var(--color-text-tertiary);opacity:.7}.all-posts-link{padding:24px 0;text-align:center}.all-posts-link a{font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--color-text-secondary);transition:color var(--transition)}.all-posts-link a:hover{color:var(--color-accent)}.tag--clickable{text-decoration:none;cursor:pointer;transition:background var(--transition),color var(--transition);position:relative;z-index:2}.tag--clickable:hover,.tag--active{background:var(--color-accent);color:#fff}.tag--large{font-size:14px;padding:4px 12px;border-radius:4px}.tag-section{padding:30px 0 12px}.tag-header{margin-bottom:32px}.tag-back{font-size:13px;color:var(--color-text-tertiary);display:inline-block;margin-bottom:16px;transition:color var(--transition)}.tag-back:hover{color:var(--color-accent)}.tag-header h1{margin-bottom:8px}.tag-count{font-size:14px;color:var(--color-text-secondary)}.post-detail-tags{display:flex;gap:6px;margin-top:12px}.search-empty{list-style:none;padding:48px 0;text-align:center;color:var(--color-text-tertiary);font-size:14px}::view-transition-old(root),::view-transition-new(root){animation-duration:.25s}@media(prefers-reduced-motion:reduce){::view-transition-old(root),::view-transition-new(root){animation:none}}@media(max-width:600px){.hero-intro{flex-direction:column;text-align:center}.hero h1{font-size:26px}.avatar--sm{width:52px;height:52px}.avatar--sm .avatar-letter{font-size:20px}.avatar--lg{width:144px;height:144px}.avatar--lg .avatar-letter{font-size:44px}.social-links{justify-content:center}.post-link h3{font-size:18px}.about-header-text h1,.post-detail-header h1{font-size:28px}.nav-toggle{display:flex;align-items:center;justify-content:center}.nav-links{display:none;flex-direction:column;align-items:center;gap:20px;width:100%;padding:20px 0}.nav-inner[data-menu-open] .nav-links{display:flex}.nav-inner{flex-wrap:wrap}.nav-links a{font-size:16px}.nav-search-icon svg{width:18px;height:18px}.theme-toggle svg{width:21px;height:21px}.contribution-day{width:9px;height:9px}.post-tags{display:none}.about-header{flex-direction:column;text-align:center}}
