:root{--primary:#2563eb;--primary-light:#3b82f6;--primary-dark:#1d4ed8;--accent:#10b981;--accent-light:#34d399;--text:#1e293b;--text-secondary:#64748b;--bg:#f8fafc;--bg-card:#ffffff;--bg-header:#0f172a;--bg-footer:#0f172a;--border:#e2e8f0;--code-bg:#1e293b;--code-text:#e2e8f0;--shadow-sm:0 1px 2px rgba(0,0,0,0.05);--shadow:0 4px 6px -1px rgba(0,0,0,0.07), 0 2px 4px -2px rgba(0,0,0,0.05);--shadow-lg:0 10px 15px -3px rgba(0,0,0,0.08), 0 4px 6px -4px rgba(0,0,0,0.04);--glow-primary:rgba(37, 99, 235, 0.15);--radius:8px;--max-width:1200px;--font-sans:-apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;--font-mono:'SF Mono', 'Fira Code', 'Consolas', monospace}@font-face{font-family:system ui;font-display:swap}@media(prefers-color-scheme:dark){:root{--text:#e2e8f0;--text-secondary:#94a3b8;--bg:#0f172a;--bg-card:#1e293b;--bg-header:#020617;--bg-footer:#020617;--border:#334155;--code-bg:#020617;--code-text:#e2e8f0;--shadow-sm:0 1px 2px rgba(0,0,0,0.3);--shadow:0 4px 6px -1px rgba(0,0,0,0.4), 0 2px 4px -2px rgba(0,0,0,0.3);--shadow-lg:0 10px 15px -3px rgba(0,0,0,0.5), 0 4px 6px -4px rgba(0,0,0,0.3);--glow-primary:rgba(59, 130, 246, 0.25)}body{background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,5%) 1px,transparent 0)}}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}.skip-link{position:absolute;top:-40px;left:0;background:var(--primary);color:#fff;padding:.5rem 1rem;z-index:1000;transition:top .2s}.skip-link:focus{top:0}.reading-progress{position:fixed;top:0;left:0;width:0%;height:3px;background:linear-gradient(90deg,var(--primary),var(--accent));z-index:1001;transition:width .1s}a:focus-visible,button:focus-visible{outline:2px solid var(--primary);outline-offset:2px}html{scroll-behavior:smooth}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--text-secondary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}body{font-family:var(--font-sans);font-size:16px;line-height:1.7;color:var(--text);background:var(--bg);background-image:radial-gradient(circle at 1px 1px,var(--border) .5px,transparent 0);background-size:24px 24px;min-height:100vh;display:flex;flex-direction:column}a{color:var(--primary);text-decoration:none;transition:color .2s,border-color .2s,background .2s}a:hover{color:var(--primary-dark)}.post-content a:not([class]){padding:.15rem .5rem;border-radius:4px;background:rgba(37,99,235,5%)}.post-content a:not([class]):hover{background:rgba(37,99,235,.12)}img{max-width:100%;height:auto;loading:lazy}.site-header{background:var(--bg-header);color:#fff;position:sticky;top:0;z-index:100;border-bottom:3px solid var(--accent)}.site-header ul,.site-header ol,.site-header li,.site-header button{list-style:none;margin:0;padding:0}.header-right{display:flex;align-items:center;gap:.75rem;list-style:none;padding:0;margin:0;margin-left:auto}.theme-toggle{background:0 0;border:none;font-size:1.25rem;cursor:pointer;padding:.25rem;border-radius:4px;transition:background .2s;line-height:1;display:inline-flex;align-items:center;justify-content:center}.theme-toggle::-webkit-details-marker,.theme-toggle::marker{display:none!important}.theme-icon{display:inline-block;unicode-bidi:bidi-override}.theme-icon::before,.theme-icon::after,.theme-toggle::before,.theme-toggle::after{display:none!important;content:none!important}.theme-toggle:hover{background:rgba(255,255,255,.1)}.search-toggle{background:0 0;border:none;font-size:1.1rem;cursor:pointer;padding:.25rem;border-radius:4px;transition:background .2s;line-height:1;display:inline-flex;align-items:center;justify-content:center}.search-toggle:hover{background:rgba(255,255,255,.1)}.search-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);z-index:1000;display:none;align-items:flex-start;justify-content:center;padding-top:10vh}.search-overlay.active{display:flex}.search-modal{background:var(--bg-card);border-radius:var(--radius);width:90%;max-width:600px;max-height:80vh;overflow:hidden;box-shadow:var(--shadow-lg)}.search-input{width:100%;padding:1rem;font-size:1.1rem;border:none;border-bottom:1px solid var(--border);background:var(--bg-card);color:var(--text);outline:none}.search-input::placeholder{color:var(--text-secondary)}.search-results{max-height:60vh;overflow-y:auto;padding:.5rem}.search-result{padding:.75rem;border-radius:var(--radius);cursor:pointer;transition:background .2s}.search-result:hover{background:var(--bg)}.search-result-title{font-weight:600;color:var(--text);margin-bottom:.25rem}.search-result-excerpt{font-size:.9rem;color:var(--text-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.search-close{position:absolute;top:1rem;right:1rem;background:0 0;border:none;color:#fff;font-size:2rem;cursor:pointer;padding:.5rem}.nav-toggle{display:none;background:0 0;border:none;cursor:pointer;padding:0}.nav-toggle span{display:block!important;width:20px!important;height:2px!important;background:#fff!important;margin:2px 0!important;transition:all .3s ease;list-style:none!important}.header-container{display:flex;justify-content:space-between;align-items:center;max-width:var(--max-width);margin:0 auto;padding:.75rem 2rem;gap:1rem}nav{flex:1;display:flex;justify-content:flex-end}.logo a{font-size:1.25rem;font-weight:700;color:#fff;letter-spacing:-.02em;display:flex;align-items:center;gap:.5rem}.logo a:hover{color:var(--accent-light)}.nav-menu{display:flex;list-style:none;gap:1.5rem}.nav-menu a{color:rgba(255,255,255,.75);font-weight:500;font-size:.9rem;padding:.25rem 0;border-bottom:2px solid transparent;transition:color .2s,border-color .2s}.nav-menu a.active{color:#fff;border-bottom:2px solid var(--accent);font-weight:600}.main-content{flex:1;max-width:var(--max-width);margin:0 auto;padding:2rem;width:100%;animation:pageFadeIn .4s ease-out}@keyframes pageFadeIn{from{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.hero{display:flex;flex-direction:column;align-items:center;text-align:center;padding:4rem 1rem 3rem;position:relative}.hero-content h1{font-size:2.75rem;font-weight:800;letter-spacing:-.03em;line-height:1.1;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-content p{font-size:1.15rem;color:var(--text-secondary);max-width:640px;margin-top:1rem}.tech-symbols{display:flex;gap:.75rem;font-size:1.5rem;margin-top:1.5rem;opacity:.7}.section-header{margin-bottom:2rem}.section-header h1,.section-header h2{font-size:1.75rem;font-weight:700;letter-spacing:-.02em;padding-bottom:.5rem;border-bottom:3px solid var(--accent);display:inline-block}.section-description{color:var(--text-secondary);margin-top:.5rem}.recent-posts{margin-top:1rem}.recent-posts h2{font-size:1.75rem;font-weight:700;letter-spacing:-.02em;border-bottom:3px solid var(--accent);padding-bottom:.5rem;margin-bottom:2rem;display:inline-block}.post-summary,.post-preview{background:var(--bg-card);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow);border-left:4px solid var(--primary);transition:transform .2s,box-shadow .2s}.post-summary:hover,.post-preview:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),0 0 20px var(--glow-primary);border-left-color:var(--accent)}.post-summary h3,.post-preview-header h2{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;letter-spacing:-.01em}.post-summary h3 a,.post-preview-header h2 a{color:var(--text)}.post-summary h3 a:hover,.post-preview-header h2 a:hover{color:var(--primary)}.post-meta,.post-preview-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;font-size:.85rem;color:var(--text-secondary);margin-bottom:.75rem}.post-summary p,.post-preview p{color:var(--text-secondary);line-height:1.6;margin-bottom:.75rem}.post-summary ul,.post-preview ul{margin:.5rem 0 .75rem 1.25rem;color:var(--text-secondary)}.post-summary li,.post-preview li{margin-bottom:.35rem;line-height:1.5}.post-meta time,.post-preview-meta time{font-weight:500}.tags{display:inline-flex;flex-wrap:wrap;gap:.35rem}.tags a{background:rgba(37,99,235,8%);color:var(--primary);padding:.15rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500}.tags a:hover{background:rgba(37,99,235,.15)}.categories a{background:rgba(16,185,129,8%);color:var(--accent);padding:.15rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500}.categories a:hover{background:rgba(16,185,129,.15)}.reading-time{font-weight:500}.read-more{display:inline-block;font-weight:600;color:var(--primary);font-size:.9rem;margin-top:.5rem}.read-more:hover{color:var(--primary-dark)}.post{max-width:800px;margin:0 auto}.post-header{margin-bottom:2rem}.post-header h1{font-size:2.25rem;font-weight:800;letter-spacing:-.03em;line-height:1.2;margin-bottom:.75rem}.post-content{line-height:1.8;font-size:1.05rem}.toc{background:var(--bg-card);border-radius:var(--radius);padding:1rem 1.5rem;margin-bottom:2rem;border:1px solid var(--border);box-shadow:var(--shadow-sm)}.toc h2{font-size:1.1rem;font-weight:600;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:2px solid var(--accent)}.toc nav ul{list-style:none;padding:0;margin:0}.toc nav ul ul{padding-left:1rem;margin-top:.5rem}.toc nav li{margin:.35rem 0}.toc nav a{color:var(--text-secondary);font-size:.95rem;transition:color .2s}.toc nav a:hover{color:var(--primary)}.post-content h1{font-size:2.5rem;font-weight:800;letter-spacing:-.03em;margin:2.5rem 0 1rem;color:var(--text);line-height:1.2}.post-content h2{font-size:1.8rem;font-weight:700;margin:2rem 0 1rem;padding-bottom:.3rem;border-bottom:2px solid var(--accent);letter-spacing:-.02em}.post-content h3{font-size:1.4rem;font-weight:600;margin:1.5rem 0 .75rem;color:var(--primary-dark);letter-spacing:-.01em}.post-content h4{font-size:1.2rem;font-weight:600;margin:1.25rem 0 .5rem;color:var(--text)}.post-content h5{font-size:1.1rem;font-weight:600;margin:1rem 0 .5rem;color:var(--text-secondary)}.post-content h6{font-size:1rem;font-weight:600;margin:1rem 0 .5rem;color:var(--text-secondary);font-style:italic}.post-content p{margin-bottom:1.25rem}.post-content ul,.post-content ol{margin-bottom:1.25rem;padding-left:1.5rem}.post-content li{margin-bottom:.35rem}.post-content strong{font-weight:600}.post-content code{font-family:var(--font-mono);background:var(--code-bg);color:var(--code-text);padding:.15rem .4rem;border-radius:4px;font-size:.9em;font-weight:400}.post-content pre{background:var(--code-bg);color:var(--code-text);padding:1.25rem;border-radius:var(--radius);overflow-x:auto;margin-bottom:1.5rem;border:1px solid var(--border);font-size:.9rem;line-height:1.5;box-shadow:inset 0 1px 3px rgba(0,0,0,.3),0 0 0 1px rgba(37,99,235,5%);position:relative}.post-content pre::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:var(--radius)var(--radius)0 0}.post-content pre code{background:0 0;padding:0;font-size:.9rem;font-weight:400}.post-content blockquote{border-left:4px solid var(--accent);padding:.5rem 1rem;margin-bottom:1.25rem;color:var(--text-secondary);font-style:italic;background:rgba(16,185,129,5%);border-radius:0 var(--radius)var(--radius)0}.post-content hr{border:none;height:2px;background:var(--border);margin:2rem 0}.post-content a{border-bottom:1px solid var(--primary-light)}.post-content a:hover{border-bottom-color:var(--primary)}.post-content img{border-radius:var(--radius);margin:1.5rem 0;box-shadow:var(--shadow)}.post-content table{width:100%;border-collapse:collapse;margin-bottom:1.5rem}.post-content th,.post-content td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}.post-content th{font-weight:600;background:rgba(37,99,235,5%)}.post-nav{display:flex;justify-content:space-between;gap:1rem;margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--border);max-width:800px}.post-nav-item{display:flex;flex-direction:column;padding:1rem;border-radius:var(--radius);background:var(--bg-card);box-shadow:var(--shadow-sm);border:1px solid var(--border);max-width:45%;transition:box-shadow .2s}.post-nav-item:hover{box-shadow:var(--shadow)}.post-nav-item span{font-size:.8rem;color:var(--text-secondary);margin-bottom:.25rem}.post-nav-item strong{font-size:.95rem;color:var(--text)}.post-nav-next{text-align:right;margin-left:auto}.taxonomy-page{max-width:800px;margin:0 auto}.taxonomy-terms{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;margin-top:1.5rem}.taxonomy-term{background:var(--bg-card);padding:1.25rem;border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:box-shadow .2s}.taxonomy-term:hover{box-shadow:var(--shadow)}.taxonomy-term h3{font-size:1.1rem;margin-bottom:.5rem}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:2rem;padding:1rem 0}.pagination-item{padding:.5rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);font-weight:500;font-size:.9rem}.pagination-item:hover{border-color:var(--primary);color:var(--primary)}.pagination-info{color:var(--text-secondary);font-size:.9rem}.related-posts{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border)}.related-posts h3{font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;color:var(--text)}.related-posts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.related-posts-grid .post-preview{margin-bottom:0}.related-posts-grid .post-preview h4{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.related-posts-grid .post-preview h4 a{color:var(--text)}.related-posts-grid .post-preview h4 a:hover{color:var(--primary)}.site-footer{background:var(--bg-footer);color:rgba(255,255,255,.7);margin-top:auto}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));max-width:var(--max-width);margin:0 auto;padding:3rem 2rem 2rem;gap:2rem}.footer-section h3{color:#fff;font-size:1.1rem;margin-bottom:.75rem;font-weight:600}.footer-section p{margin-bottom:.5rem;font-size:.9rem}.footer-section a{color:rgba(255,255,255,.7)}.footer-section a:hover{color:var(--accent-light)}.footer-bottom{text-align:center;padding:1.5rem 2rem;border-top:1px solid rgba(255,255,255,8%);font-size:.85rem}.footer-bottom a{color:rgba(255,255,255,.7)}@media(max-width:768px){.header-container{flex-direction:row;justify-content:space-between;position:relative}.header-right{flex-direction:row;gap:.5rem}.nav-toggle{display:flex;flex-direction:column;justify-content:center;align-items:center;width:32px;height:32px;background:0 0;border:none;cursor:pointer;padding:0;list-style:none}.nav-toggle span{display:block;width:20px;height:2px;background:#fff;margin:2px 0;transition:all .3s ease}.nav-toggle.active span:nth-child(1){transform:rotate(45deg)translate(4px,4px)}.nav-toggle.active span:nth-child(2){opacity:0}.nav-toggle.active span:nth-child(3){transform:rotate(-45deg)translate(4px,-4px)}.nav-menu{display:none;position:absolute;top:100%;left:0;right:0;background:var(--bg-header);flex-direction:column;padding:1rem;gap:.5rem;border-top:1px solid var(--border);list-style:none}.nav-menu.active{display:flex}.nav-menu li{text-align:center;list-style:none}.nav-menu a{display:block;padding:.5rem;border-bottom:none}.nav-menu a.active{border-bottom:none;color:var(--accent-light)}.nav-menu{gap:0}.hero-content h1{font-size:2rem}.hero-content p{font-size:1rem}.post-header h1{font-size:1.75rem}.post-nav{flex-direction:column}.post-nav-item{max-width:100%}.post-nav-next{text-align:left}.main-content{padding:1rem}}@media(max-width:480px){.hero-content h1{font-size:1.5rem}.nav-menu{flex-wrap:wrap;justify-content:center}.post-content{font-size:1rem}}.fade-in{animation:fadeIn .3s ease-in}@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.card-hover{transition:all .3s ease}.card-hover:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}.error-page{text-align:center;padding:4rem 1rem}.error-page h1{font-size:6rem;font-weight:800;color:var(--primary);margin-bottom:1rem}.error-page p{font-size:1.25rem;color:var(--text-secondary);margin-bottom:2rem}.back-to-top{position:fixed;bottom:2rem;right:2rem;width:48px;height:48px;background:var(--primary);color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);opacity:0;visibility:hidden;transition:all .3s ease;z-index:99}.back-to-top.visible{opacity:1;visibility:visible}.back-to-top:hover{background:var(--primary-dark);transform:translateY(-3px)}.back-to-top svg{width:24px;height:24px}