:root{--color-bg-primary: #ffffff;--color-bg-secondary: #fafafa;--color-bg-tertiary: #f3f4f6;--color-bg-inverse: #111827;--color-border: #e5e7eb;--color-border-light: #f3f4f6;--color-border-focus: #2563eb;--color-text-primary: #1f2937;--color-text-secondary: #4b5563;--color-text-tertiary: #6b7280;--color-text-muted: #9ca3af;--color-text-inverse: #f9fafb;--color-accent: #2563eb;--color-accent-hover: #1d4ed8;--color-accent-light: rgba(37, 99, 235, .1);--color-success: #059669;--color-warning: #d97706;--color-error: #dc2626;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-full: 9999px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 3rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.3;--line-height-normal: 1.6;--line-height-relaxed: 1.8;--container-sm: 640px;--container-md: 768px;--container-lg: 1024px;--container-xl: 1280px;--container-content: 65ch}[data-theme=dark]{--color-bg-primary: #111827;--color-bg-secondary: #1f2937;--color-bg-tertiary: #374151;--color-bg-inverse: #ffffff;--color-border: #374151;--color-border-light: #1f2937;--color-border-focus: #60a5fa;--color-text-primary: #f9fafb;--color-text-secondary: #d1d5db;--color-text-tertiary: #9ca3af;--color-text-muted: #6b7280;--color-text-inverse: #111827;--color-accent: #60a5fa;--color-accent-hover: #93c5fd;--color-accent-light: rgba(96, 165, 250, .15);--color-success: #34d399;--color-warning: #fbbf24;--color-error: #f87171;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:var(--color-bg-primary);color:var(--color-text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,Roboto,Helvetica Neue,Arial,sans-serif;font-size:var(--font-size-base);line-height:var(--line-height-normal);min-height:100vh;transition:background var(--transition-slow),color var(--transition-slow)}h1,h2,h3,h4,h5,h6{color:var(--color-text-primary);line-height:var(--line-height-tight);font-weight:var(--font-weight-semibold);margin-top:1.5em;margin-bottom:.5em}h1{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);margin-top:0;line-height:1.2}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}h5{font-size:var(--font-size-base)}h6{font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary)}p{margin-bottom:var(--space-6);color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}strong,b{color:var(--color-text-primary);font-weight:var(--font-weight-semibold)}em,i{font-style:italic}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast),text-decoration var(--transition-fast)}a:hover{color:var(--color-accent-hover);text-decoration:underline}a:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px;border-radius:var(--radius-sm)}::selection{background:var(--color-accent-light);color:var(--color-text-primary)}:where(a,button,input,textarea,select,summary):focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px;border-radius:var(--radius-sm)}.container{width:100%;max-width:var(--container-content);margin:0 auto;padding:var(--space-12) var(--space-6)}@media(max-width:768px){.container{padding:var(--space-8) var(--space-4)}}@media(max-width:640px){.container{padding:var(--space-6) var(--space-3)}}section{margin-bottom:var(--space-16)}@media(max-width:768px){section{margin-bottom:var(--space-12)}}.site-header{border-bottom:1px solid var(--color-border);background:var(--color-bg-primary);position:sticky;top:0;z-index:100}.site-header__inner{max-width:var(--container-xl);margin:0 auto;padding:0 var(--space-6);display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-4);padding-bottom:var(--space-4);gap:var(--space-6)}.site-header__logo{text-decoration:none;color:var(--color-text-primary);font-weight:var(--font-weight-semibold);letter-spacing:-.01em}.site-header__logo-text{display:inline-block;line-height:1.2;font-size:var(--font-size-lg)}.site-header__nav{display:flex;align-items:center;gap:var(--space-6);flex-wrap:wrap;justify-content:flex-end}.site-header__link{color:var(--color-text-secondary);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);transition:color var(--transition-fast)}.site-header__link:hover{color:var(--color-text-primary);text-decoration:none}.site-header__link--active{color:var(--color-text-primary);font-weight:var(--font-weight-semibold);text-decoration:underline;text-underline-offset:3px}.theme-toggle{background:transparent;border:1px solid transparent;color:var(--color-text-primary);cursor:pointer;font-size:var(--font-size-lg);padding:var(--space-2);display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-fast);min-height:40px;min-width:40px}.theme-toggle:hover{border-color:var(--color-border);background:var(--color-bg-secondary)}.theme-toggle:active{transform:scale(.95)}.theme-toggle__icon{display:inline-block;line-height:1}@media(max-width:640px){.site-header__inner{flex-direction:column;align-items:flex-start;gap:var(--space-4)}.site-header__nav{width:100%;justify-content:flex-start;gap:var(--space-4)}}.site-footer{border-top:1px solid var(--color-border);padding:var(--space-12) var(--space-6);margin-top:var(--space-24);background:var(--color-bg-primary);color:var(--color-text-muted)}.site-footer__inner{max-width:var(--container-xl);margin:0 auto}.site-footer__content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-4);font-size:var(--font-size-sm)}.site-footer__copy{color:var(--color-text-tertiary)}.site-footer__nav{display:flex;gap:var(--space-6);flex-wrap:wrap}.site-footer__link{color:var(--color-text-muted);font-size:var(--font-size-sm);transition:color var(--transition-fast)}.site-footer__link:hover{color:var(--color-text-primary);text-decoration:underline}@media(max-width:640px){.site-footer{padding:var(--space-8) var(--space-4)}.site-footer__content{flex-direction:column;text-align:center;gap:var(--space-4)}.site-footer__nav{justify-content:center}}.blog-article{max-width:100%}.blog-article__header{margin-bottom:var(--space-12);padding-bottom:var(--space-8);border-bottom:1px solid var(--color-border)}.blog-article__title{font-size:var(--font-size-4xl);margin:0 0 var(--space-6) 0;line-height:1.15;color:var(--color-text-primary)}.blog-article__meta{display:flex;gap:var(--space-5);flex-wrap:wrap;font-size:var(--font-size-sm);color:var(--color-text-muted);align-items:center}.blog-article__meta-item{display:flex;align-items:center;gap:var(--space-2)}.blog-article__meta-separator{color:var(--color-border)}.blog-article__updated{color:var(--color-text-tertiary)}.blog-article__content{line-height:var(--line-height-relaxed);max-width:var(--container-content);margin:0 auto}.blog-article__content h2,.blog-article__content h3,.blog-article__content h4{scroll-margin-top:var(--space-16)}.blog-article__content h2{margin-top:var(--space-16);margin-bottom:var(--space-6);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border-light)}.blog-article__content h3{margin-top:var(--space-12);margin-bottom:var(--space-5)}.blog-article__content h4{margin-top:var(--space-10);margin-bottom:var(--space-4)}.blog-article__content p{margin-bottom:var(--space-6);max-width:65ch}.prose{line-height:var(--line-height-relaxed)}.prose h1,.prose h2,.prose h3,.prose h4{margin-top:var(--space-12);margin-bottom:var(--space-5);line-height:var(--line-height-tight)}.prose h1{font-size:var(--font-size-3xl)}.prose h2{font-size:var(--font-size-2xl)}.prose h3{font-size:var(--font-size-xl)}.prose h4{font-size:var(--font-size-lg)}.prose p{margin-bottom:var(--space-6)}.prose ul,.prose ol{padding-left:var(--space-6);margin:var(--space-6) 0}.prose li{margin-bottom:var(--space-3);line-height:var(--line-height-relaxed)}.prose blockquote{border-left:4px solid var(--color-accent);padding:var(--space-6);margin:var(--space-10) 0;background:var(--color-bg-secondary);border-radius:0 var(--radius-lg) var(--radius-lg) 0;font-style:italic}.prose blockquote p{margin-bottom:0;color:var(--color-text-secondary)}.prose code{font-family:JetBrains Mono,Fira Code,ui-monospace,SF Mono,Menlo,Monaco,Consolas,monospace;font-size:.9em;background:var(--color-bg-secondary);padding:.15em .4em;border-radius:var(--radius-md);border:1px solid var(--color-border-light)}.prose pre{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);margin:var(--space-10) 0;overflow-x:auto;box-shadow:var(--shadow-sm)}.prose pre code{background:none;border:none;padding:0;font-size:var(--font-size-sm);border-radius:0}.prose img{border-radius:var(--radius-lg);margin:var(--space-8) 0;box-shadow:var(--shadow-md);max-width:100%;height:auto}.prose table{width:100%;border-collapse:collapse;margin:var(--space-10) 0;font-size:var(--font-size-sm);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.prose th,.prose td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);text-align:left}.prose th{background:var(--color-bg-secondary);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.prose tr:hover{background:var(--color-bg-secondary)}.prose tr:last-child td{border-bottom:none}.prose hr{border:none;border-top:1px solid var(--color-border);margin:var(--space-12) 0}.blog-article__content ul,.blog-article__content ol{padding-left:var(--space-6);margin:var(--space-6) 0;color:var(--color-text-secondary)}.blog-article__content li{margin-bottom:var(--space-3);line-height:var(--line-height-relaxed)}.blog-article__content blockquote{border-left:4px solid var(--color-accent);padding:var(--space-6);margin:var(--space-10) 0;background:var(--color-bg-secondary);border-radius:0 var(--radius-lg) var(--radius-lg) 0;font-style:italic}.blog-article__content blockquote p{margin-bottom:0;color:var(--color-text-secondary)}.blog-article__content code{font-family:JetBrains Mono,Fira Code,ui-monospace,SF Mono,Menlo,Monaco,Consolas,monospace;font-size:.9em;background:var(--color-bg-secondary);padding:.15em .4em;border-radius:var(--radius-md);border:1px solid var(--color-border-light)}.blog-article__content pre{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);margin:var(--space-10) 0;overflow-x:auto;box-shadow:var(--shadow-sm)}.blog-article__content pre code{background:none;border:none;padding:0;font-size:var(--font-size-sm);border-radius:0}.blog-article__content img{border-radius:var(--radius-lg);margin:var(--space-8) 0;box-shadow:var(--shadow-md);max-width:100%;height:auto}.blog-article__content table{width:100%;border-collapse:collapse;margin:var(--space-10) 0;font-size:var(--font-size-sm);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.blog-article__content th,.blog-article__content td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);text-align:left}.blog-article__content th{background:var(--color-bg-secondary);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.blog-article__content tr:hover{background:var(--color-bg-secondary)}.blog-article__content tr:last-child td{border-bottom:none}.blog-article__content hr{border:none;border-top:1px solid var(--color-border);margin:var(--space-12) 0}.blog-article__footer{margin-top:var(--space-16);padding-top:var(--space-8);border-top:1px solid var(--color-border)}.blog-article__back-link{color:var(--color-accent);text-decoration:none;font-weight:var(--font-weight-medium);display:inline-flex;align-items:center;gap:var(--space-2);transition:all var(--transition-fast)}.blog-article__back-link:hover{color:var(--color-accent-hover);text-decoration:underline}.blog-article__back-link:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px;border-radius:var(--radius-sm)}@media(max-width:640px){.blog-article__title{font-size:var(--font-size-2xl)}.blog-article__meta{font-size:var(--font-size-sm);gap:var(--space-3)}}.hero{margin-bottom:var(--space-16);padding-bottom:var(--space-8)}.hero__title{font-size:var(--font-size-5xl);margin:0 0 var(--space-4) 0;line-height:1.1;color:var(--color-text-primary);letter-spacing:-.02em}.hero__description{color:var(--color-text-secondary);font-size:var(--font-size-xl);margin:0;line-height:var(--line-height-relaxed);max-width:var(--container-content)}@media(max-width:768px){.hero__title{font-size:var(--font-size-4xl)}.hero__description{font-size:var(--font-size-lg)}}@media(max-width:640px){.hero{margin-bottom:var(--space-12)}.hero__title{font-size:var(--font-size-3xl)}}.section-title{font-size:var(--font-size-2xl);margin:0 0 var(--space-8) 0;padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border);color:var(--color-text-primary)}.post-list{display:flex;flex-direction:column;gap:var(--space-8)}.post-list__item{padding-bottom:var(--space-8);border-bottom:1px solid var(--color-border)}.post-list__item:last-child{border-bottom:none;padding-bottom:0}.post-list__title{font-size:var(--font-size-xl);margin:0 0 var(--space-2) 0;line-height:1.3}.post-list__title a{color:var(--color-text-primary);text-decoration:none;transition:color var(--transition-fast)}.post-list__title a:hover{color:var(--color-accent);text-decoration:underline}.post-list__description{color:var(--color-text-secondary);margin:0 0 var(--space-3) 0;font-size:var(--font-size-base);line-height:var(--line-height-normal)}.post-list__date{font-size:var(--font-size-sm);color:var(--color-text-muted)}.post-list__view-all{display:inline-block;margin-top:var(--space-8);color:var(--color-accent);font-weight:var(--font-weight-medium)}.post-list__view-all:hover{color:var(--color-accent-hover);text-decoration:underline}.page-title{font-size:var(--font-size-4xl);margin:0 0 var(--space-12) 0;line-height:1.2}.month-group{margin-bottom:var(--space-16)}.month-header{font-size:var(--font-size-xl);margin:0 0 var(--space-6) 0;padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border);color:var(--color-text-primary)}.month-group .post-list__item{padding:var(--space-4) 0;border-bottom:1px solid var(--color-border)}.month-group .post-list__item:last-child{border-bottom:none}.month-group .post-list__title{font-size:var(--font-size-lg)}.month-group .post-list__description{font-size:var(--font-size-sm);margin-bottom:var(--space-2)}.month-group .post-list__date{font-size:var(--font-size-sm)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--color-text-muted)}.text-secondary{color:var(--color-text-secondary)}.mt-0{margin-top:0}.mb-0{margin-bottom:0}.mt-4{margin-top:var(--space-4)}.mb-4{margin-bottom:var(--space-4)}.mt-8{margin-top:var(--space-8)}.mb-8{margin-bottom:var(--space-8)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full);border:2px solid var(--color-bg-secondary)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}*{scrollbar-width:thin;scrollbar-color:var(--color-border) var(--color-bg-secondary)}@media print{body{background:#fff;color:#000;font-size:12pt;line-height:1.5}.site-header,.site-footer,.theme-toggle,.blog-article__footer{display:none}.container{max-width:none;padding:0;margin:0}a{text-decoration:underline;color:#000}a[href^=http]:after{content:" (" attr(href) ")";font-size:10pt;color:#666}blockquote{border-left:3pt solid #666;background:none;font-style:italic}pre,code{background:#f5f5f5;border:1pt solid #ddd}img{max-width:100%;page-break-inside:avoid}h1,h2,h3,h4,h5,h6{page-break-after:avoid;break-after:avoid}p{orphans:3;widows:3}}
