.article{-webkit-text-size-adjust:100%;line-height:1.7;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-size:18px!important;max-width:100%;margin-bottom:0;padding:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.article-content,.article-content p{line-height:1.8;color:#374151}.article-content p{margin-bottom:1.5rem;font-size:1.125rem}.article-content p:first-of-type{font-size:1.25rem;font-weight:400;color:#1f2937;margin-bottom:2rem;padding:1.5rem;background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-left:4px solid #3b82f6;border-radius:0 8px 8px 0;box-shadow:0 1px 3px rgba(0,0,0,.1)}#table-of-contents-list{font-size:16px;width:100%;border:1px solid #ddd;padding-top:1em;padding-bottom:1em}.article a,.article-content a{color:#3b82f6;text-decoration:none;font-weight:500;border-bottom:1px solid transparent;transition:all .2s ease;padding:0 2px;border-radius:3px}.article a:hover,.article-content a:hover{color:#1d4ed8;background-color:#dbeafe;border-bottom-color:#3b82f6}.article ol,.article ul{padding-left:2em;margin-bottom:1rem}.article ol li,.article ul li{padding:3px 2px}.article ol p,.article ul p{margin:0;display:inline}.article ol{list-style-type:none;counter-reset:item}.article ol li{counter-increment:item}.article ol li:before{content:counters(item,".") ". "}.article ol li:marker{display:none}.article ul{list-style:disc}.article ul ul{list-style:circle}.article ul ul ul{list-style-type:square}.article h1,.article-content h1{font-size:2.5rem;font-weight:800;margin-top:3rem;margin-bottom:1.5rem;color:#1f2937;line-height:1.2;position:relative;padding-bottom:1rem}.article h1:after,.article-content h1:after{content:"";position:absolute;bottom:0;left:0;width:60px;height:4px;background:linear-gradient(90deg,#3b82f6,#1d4ed8);border-radius:2px}.article h2,.article-content h2{font-size:2rem;font-weight:700;margin-top:2.5rem;margin-bottom:1rem;color:#1e40af;line-height:1.3;position:relative;padding-left:1rem}.article h2:before,.article-content h2:before{content:"";position:absolute;left:0;top:.2rem;width:4px;height:1.5rem;background:linear-gradient(180deg,#3b82f6,#1d4ed8);border-radius:2px}.article h3,.article-content h3{font-size:1.5rem;font-weight:600;margin-top:2rem;margin-bottom:.75rem;color:#1e40af;line-height:1.4}.article h4,.article-content h4{font-size:1.25rem;font-weight:600;margin-top:1.75rem;margin-bottom:.5rem;color:#3b82f6;line-height:1.4}.article p{margin-bottom:1rem}.article img{max-width:100%;margin:1em auto}.article{position:relative}.article>.tags{display:flex;justify-content:start;flex-wrap:wrap;gap:10px;width:100%}.article .tags>a{color:black;background-color:#eee;border-radius:6px;padding:2px 8px;font-size:16px;font-weight:500}.article hr{margin-top:1.5rem;margin-bottom:1.5rem}.article pre{display:grid;overflow:hidden;border-radius:.5rem;font-size:16px;margin:1.5em 0}.article li>code,.article p>code{background-color:#444;border-radius:6px;padding:.1em .25em;font-size:18px}table{font-size:15px;border-collapse:collapse;width:100%}td,th{text-align:left;padding:8px;border:1px solid #ddd}th,tr:nth-child(2n){background-color:#f2f2f2}blockquote{background:#f1f1f1;border-left:10px solid #777;margin:1.5em 10px;padding:.5em 10px;quotes:"\201C" "\201D" "\2018" "\2019"}blockquote:before{color:#777;content:open-quote;font-size:4em;line-height:.1em;margin-right:.25em;vertical-align:-.4em}blockquote p{display:inline;font-style:italic}@media (max-width:768px){.article h1{font-size:1.6rem}.article h2{font-size:1.3rem}.article h3{font-size:1rem}}.article-content ul{list-style:none;padding-left:0;margin:1.5rem 0}.article-content ul li{position:relative;padding-left:2rem;margin-bottom:.75rem;line-height:1.7;color:#374151}.article-content ul li:before{content:"";position:absolute;left:.5rem;top:.7rem;width:6px;height:6px;background:#3b82f6;border-radius:50%;box-shadow:0 0 0 2px rgba(59,130,246,.2)}.article-content ol{counter-reset:item;padding-left:0;margin:1.5rem 0}.article-content ol li{position:relative;padding-left:3rem;margin-bottom:.75rem;line-height:1.7;color:#374151;counter-increment:item}.article-content ol li:before{content:counter(item);position:absolute;left:0;top:0;width:2rem;height:2rem;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;box-shadow:0 2px 4px rgba(59,130,246,.3)}.article-content blockquote{margin:2rem 0;padding:1.5rem 2rem;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-left:4px solid #0ea5e9;border-radius:0 12px 12px 0;font-style:italic;font-size:1.125rem;color:#0c4a6e;box-shadow:0 4px 6px rgba(0,0,0,.05);position:relative}.article-content blockquote:before{content:'"';position:absolute;top:-.5rem;left:1rem;font-size:4rem;color:#0ea5e9;opacity:.3;font-family:Georgia,serif}.article-content table{width:100%;margin:2rem 0;border-collapse:separate;border-spacing:0;background:white;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px rgba(0,0,0,.07)}.article-content table th{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:white;padding:1rem;text-align:left;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.article-content table td{padding:1rem;border-bottom:1px solid #e5e7eb;color:#374151;vertical-align:top}.article-content table tr:last-child td{border-bottom:none}.article-content table tr:nth-child(2n){background-color:#f9fafb}.article-content table tr:hover{background-color:#f3f4f6}.article-content pre{margin:2rem 0;padding:1.5rem;background:#1f2937;color:#f9fafb;border-radius:12px;overflow-x:auto;box-shadow:0 4px 6px rgba(0,0,0,.1);position:relative}.article-content pre:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#3b82f6,#1d4ed8,#7c3aed);border-radius:12px 12px 0 0}.article-content code{font-family:Fira Code,Monaco,Cascadia Code,Roboto Mono,monospace;font-size:.875rem;line-height:1.6}.article-content img{margin:2rem auto;border-radius:12px;box-shadow:0 8px 25px rgba(0,0,0,.15);transition:transform .3s ease,box-shadow .3s ease}.article-content img:hover{transform:translateY(-2px);box-shadow:0 12px 35px rgba(0,0,0,.2)}.article-content strong{color:#1f2937;font-weight:600;background:linear-gradient(120deg,transparent,rgba(59,130,246,.1) 50%,transparent);padding:0 2px;border-radius:3px}.article-content em{color:#4b5563;font-style:italic;position:relative}.article-content hr{margin:3rem 0;border:none;height:1px;background:linear-gradient(90deg,transparent,#3b82f6,transparent);position:relative}.article-content hr:after{content:"✦";position:absolute;top:-.5rem;left:50%;transform:translateX(-50%);background:white;color:#3b82f6;padding:0 1rem;font-size:1rem}.article-progress{position:fixed;top:0;left:0;width:100%;height:3px;background:rgba(59,130,246,.2);z-index:50}.article-progress-bar{height:100%;background:linear-gradient(90deg,#3b82f6,#1d4ed8);width:0;transition:width .3s ease}pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}.hljs{background:#1e1e1e;color:#dcdcdc}.hljs-keyword,.hljs-link,.hljs-literal,.hljs-name,.hljs-symbol{color:#569cd6}.hljs-link{text-decoration:underline}.hljs-built_in,.hljs-type{color:#4ec9b0}.hljs-class,.hljs-number{color:#b8d7a3}.hljs-meta .hljs-string,.hljs-string{color:#d69d85}.hljs-regexp,.hljs-template-tag{color:#9a5334}.hljs-formula,.hljs-function,.hljs-params,.hljs-subst,.hljs-title{color:#dcdcdc}.hljs-comment,.hljs-quote{color:#57a64a;font-style:italic}.hljs-doctag{color:#608b4e}.hljs-meta,.hljs-meta .hljs-keyword,.hljs-tag{color:#9b9b9b}.hljs-template-variable,.hljs-variable{color:#bd63c5}.hljs-attr,.hljs-attribute{color:#9cdcfe}.hljs-section{color:gold}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.hljs-bullet,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id,.hljs-selector-pseudo,.hljs-selector-tag{color:#d7ba7d}.hljs-addition{background-color:#144212}.hljs-addition,.hljs-deletion{display:inline-block;width:100%}.hljs-deletion{background-color:#600}