:root{--bg: #e9e9e9;--bg-card: #f4f2ee;--text: #1a1a1a;--text-muted: #3c3c3c;--text-dim: #444444;--border: #707070;--font: "Inter", sans-serif}[data-theme=dark]{--bg: #1a1a1a;--bg-card: #2a2929;--text: #ebebeb;--text-muted: #929292;--text-dim: #aaa;--border: #303030;--font: "Inter", sans-serif}.loader{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#080808;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .8s ease}.loader.fade-out{opacity:0;pointer-events:none}.spinner{width:60px;height:60px;border:6px solid #444;border-top:6px solid #ffffff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.loader-text{color:#ccc;font-size:1.2rem;font-family:Inter,sans-serif;animation:fadeInText 1.5s ease-in-out infinite alternate}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.theme-toggle{background:none;border:1px solid var(--border);color:var(--text-muted);width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;transition:border-color .2s,color .2s,background .2s;flex-shrink:0;position:relative;overflow:hidden}.theme-toggle:hover{color:var(--text);border-color:var(--text-dim);background:var(--bg-card)}.theme-toggle .icon-sun,.theme-toggle .icon-moon{position:absolute;transition:transform .4s cubic-bezier(.34,1.56,.64,1),opacity .3s ease;font-style:normal}.theme-toggle .icon-sun{transform:translateY(0);opacity:1}.theme-toggle .icon-moon{transform:translateY(120%);opacity:0}[data-theme=dark] .theme-toggle .icon-sun{transform:translateY(-120%);opacity:0}[data-theme=dark] .theme-toggle .icon-moon{transform:translateY(0);opacity:1}.table-of-contents{position:fixed;top:75px;width:200px;height:calc(100vh - 150px);padding:0;font-size:.9em;background:var(--bg);color:var(--text);border-right:2px solid var(--border);z-index:10;opacity:1;display:flex;flex-direction:column;overflow:hidden}.table-of-contents::-webkit-scrollbar{display:none}.table-of-contents::-webkit-scrollbar-track{background:transparent}.table-of-contents::-webkit-scrollbar-thumb{background-color:var(--border);border-radius:2px}.toc-header{padding:1rem .8rem .5rem 1rem;margin-bottom:0;border-bottom:1px solid var(--border);flex:0 0 auto}.toc-header h3{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--text);margin:0;opacity:.7}.toc-nav{flex:1;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;padding:.5rem .8rem 1.5rem 1rem}.toc-nav ul{list-style:none;padding:0;margin:0}.toc-item{padding-left:0}.toc-level-2{padding-left:0;margin-bottom:.3rem}.toc-level-3{padding-left:1rem;font-size:.88rem;color:var(--text-muted);margin-bottom:.2rem}.toc-link{display:block;color:var(--text-dim);text-decoration:none;border-left:3px solid transparent;padding:.25rem .3rem .25rem .8rem;border-radius:0;transition:all .12s ease-out;line-height:1.5;font-size:.95em}.toc-link:hover{color:var(--text);border-left-color:var(--text-dim);background:var(--bg-card);padding-left:1rem}.toc-link.active{color:var(--text);border-left-color:var(--text);font-weight:600;background:var(--bg-card);padding-left:1rem}@media(max-width:1100px){.table-of-contents{display:none}}#nav{position:fixed;top:0;left:0;right:0;z-index:99;background:var(--bg);border-bottom:1px solid var(--border);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:rgba(var(--bg-rgb, 233, 233, 233),.9)}[data-theme=dark] #nav{background:rgba(var(--bg-rgb, 26, 26, 26),.9)}.nav-content{max-width:1000px;margin:0 auto;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}.nav-left{flex:0 0 auto}.nav-name{font-size:1.1rem;font-weight:400;color:var(--text);transition:opacity .15s;letter-spacing:-.02em;white-space:nowrap}.nav-name:hover{opacity:.7}.nav-links{flex:1;display:flex;gap:2rem;margin:0;padding:0;list-style:none}.nav-link{font-size:.9rem;color:var(--text-dim);transition:color .15s;border-bottom:1px solid transparent}.nav-link:hover{color:var(--text);border-bottom-color:var(--border)}.nav-top{display:none}.nav-back{display:none;position:absolute;left:1.5rem;top:50%;transform:translateY(-50%);align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-dim);cursor:pointer;transition:all .15s;padding:.3rem .5rem;border-radius:2px;border:1px solid transparent}.nav-back.visible{display:inline-flex}.nav-back:hover{color:var(--text);border-color:var(--border);background:var(--bg-card)}.nav-back svg{transition:transform .15s;flex-shrink:0;width:13px;height:13px}.nav-back:hover svg{transform:translate(-2px)}@media(max-width:768px){.nav-links{display:none}.nav-content{gap:1rem}.nav-name{font-size:2rem}}@media(max-width:560px){#nav{position:static}.nav-content{padding:1rem 1.25rem}}footer{width:90%;margin:0 auto;padding:1.5rem;display:flex;justify-content:space-between;font-size:.9rem;color:var(--text-muted);border-top:1px solid var(--border);letter-spacing:.04em;position:relative;z-index:20}.footer-links{display:flex;gap:1.5rem}footer a{transition:color .15s}footer a:hover{color:var(--text)}@media(max-width:480px){footer{width:100%}.footer-links{gap:.5rem}}@media(max-width:410px){footer{font-size:.7rem}}.rule{margin:0 auto;width:60%;padding:0 1.5rem}.rule hr{border:none;border-top:1px solid var(--border)}main{flex:1;max-width:700px;width:100%;margin:0 auto;padding:5.5rem 1.5rem 8rem}.hero{margin-bottom:3rem;margin-top:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border)}.hero h1{font-size:2rem;font-weight:400;margin-bottom:1rem;letter-spacing:-.02em;color:var(--text)}.hero p{font-size:1rem;color:var(--text-dim);line-height:1.7;margin:0}.page-header{margin-bottom:3rem}.page-header h1{font-size:1.75rem;font-weight:400;margin-bottom:.4rem}.page-header p{font-size:.78rem;color:var(--text-muted);letter-spacing:.04em}.post-list{display:flex;flex-direction:column}.post-item{display:grid;grid-template-columns:1fr auto;gap:1.5rem;align-items:start;padding:1.75rem 0;border-bottom:1px solid var(--border);cursor:pointer}.post-item:first-child{border-top:1px solid var(--border)}.post-item:hover .post-title{text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--border)}.post-info{display:flex;flex-direction:column;gap:.5rem}.post-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;font-size:.72rem;color:var(--text-muted);letter-spacing:.04em}.post-tags{display:flex;gap:.35rem}.tag{font-size:.65rem;color:var(--text-muted);border:1px solid var(--border);padding:.1rem .45rem;border-radius:2px;letter-spacing:.06em;text-transform:uppercase}.post-title{font-size:1.05rem;font-weight:400;line-height:1.45;color:var(--text)}.post-excerpt{font-size:.85rem;color:var(--text-dim);line-height:1.65;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.post-thumb{width:86px;height:62px;overflow:hidden;flex-shrink:0;background:var(--border)}.post-thumb img{width:100%;height:100%;object-fit:cover;opacity:.85}.post-thumb-empty{width:86px;height:62px;flex-shrink:0;background:none}.state{padding:4rem 0;font-size:.8rem;color:var(--text-muted);text-align:center}.post.active{display:block}.list-view.hidden{display:none}.post-cover{width:100%;height:100%;overflow:hidden;margin-bottom:2.5rem;background:var(--bg-card);border:1px solid var(--border)}.post-header{margin-bottom:2.5rem;padding-bottom:2rem;border-bottom:1px solid var(--border)}.post-header-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;font-size:.72rem;color:var(--text-muted);letter-spacing:.04em;margin-bottom:1rem}.post-header h1{font-size:clamp(1.5rem,5vw,2rem);font-weight:400;line-height:1.25;letter-spacing:-.015em;margin-bottom:.75rem}.post-lead{font-size:1rem;color:var(--text-dim);line-height:1.7}.post-content{font-size:1rem;line-height:1.85}.post-content h2{font-size:1.2rem;font-weight:400;margin:2.5rem 0 .8rem;color:var(--text)}.post-content h3{font-size:1rem;font-weight:400;margin:2rem 0 .6rem;color:var(--text-dim)}.post-content p{color:var(--text-dim);margin-bottom:1.3rem}.post-content strong{color:var(--text);font-weight:500}.post-content a{color:var(--text);border-bottom:1px solid var(--border);transition:border-color .15s}.post-content a:hover{border-color:var(--text-dim)}.post-content ul,.post-content ol{padding-left:1.4rem;margin-bottom:1.3rem;color:var(--text-dim)}.post-content blockquote{border-left:2px solid var(--border);padding-left:1.2rem;margin:1.5rem 0;color:var(--text-muted);font-style:italic}.post-content code{font-family:SFMono-Regular,Consolas,monospace;font-size:.83em;background:var(--bg-card);border:1px solid var(--border);padding:.15em .4em;border-radius:2px;color:var(--text)}.post-content pre{background:var(--bg-card);border:1px solid var(--border);padding:1.4rem;overflow-x:auto;margin:1.5rem 0}.post-content pre code{background:none;border:none;padding:0;font-size:.82rem}.post-content hr{border:none;border-top:1px solid var(--border);margin:2.5rem 0}.post-content img{width:100%;margin:1.5rem 0}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.post-item{animation:fadeUp .3s ease both}.post-item:nth-child(1){animation-delay:.04s}.post-item:nth-child(2){animation-delay:.08s}.post-item:nth-child(3){animation-delay:.12s}.post-item:nth-child(n+4){animation-delay:.16s}.search-wrap{position:relative;margin-bottom:2rem}.search-icon{position:absolute;left:.9rem;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-input{width:100%;background:var(--bg-card);border:1px solid var(--border);border-radius:2px;padding:.65rem .9rem .65rem 2.4rem;font-family:var(--font);font-size:.85rem;font-weight:300;color:var(--text);outline:none;transition:border-color .15s}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{border-color:var(--text-muted)}@media(max-width:560px){.post-thumb,.post-thumb-empty{display:none}.post-item{grid-template-columns:1fr}main{padding:4.5rem 1.25rem 5rem}nav{position:static}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font);font-weight:300;min-height:100vh;display:flex;flex-direction:column;transition:opacity .2s ease}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}
