pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}
/*!
  Theme: GitHub Dark
  Description: Dark theme as seen on github.com
  Author: github.com
  Maintainer: @Hirse
  Updated: 2021-05-15

  Outdated base version: https://github.com/primer/github-syntax-dark
  Current colors taken from GitHub's CSS
*/.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id,.hljs-variable{color:#79c0ff}.hljs-meta .hljs-string,.hljs-regexp,.hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-code,.hljs-comment,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-pseudo,.hljs-selector-tag{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}.blog-detail-main{min-height:100vh;background:var(--background-secondary);position:relative}.blog-hero{padding:4rem 0 1rem}.hero-container{max-width:900px;margin:0 auto;padding:0 2rem}.hero-image-container{width:100%;margin-top:3rem;text-align:center}.hero-image{width:100%;height:auto;border-radius:8px}.hero-content{max-width:100%}.hero-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.topic-badge{background:var(--navy-blue);cursor:pointer;color:white;padding:.5rem 1rem;border-radius:20px;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.hero-stats{display:flex;gap:1.5rem;color:var(--foreground-secondary);font-weight:300;font-size:.9rem}.stats-group{display:flex;align-items:center;gap:.5rem}.stats-group .dot{font-size:1.2rem;line-height:0}.stat{display:flex;align-items:center;gap:.5rem}.stat svg{font-size:1.2rem}.hero-title{font-size:3rem;font-weight:900;line-height:1.1;color:var(--foreground-primary);margin-bottom:3rem}.hero-subtitle{font-size:1.3rem;line-height:1.6;color:var(--foreground-secondary);margin-bottom:2rem;font-weight:400}.author-section{justify-content:space-between;padding:1.5rem 0;border-top:1px solid var(--action-primary);border-bottom:1px solid var(--action-primary);margin:3rem 0 2.5rem;gap:2rem}.author-info,.author-section{display:flex;align-items:center}.author-info{gap:1.25rem;flex:1}.author-avatar{width:56px;height:56px;border-radius:50%;object-fit:cover;border:2px solid var(--action-primary)}.author-details{flex:1;min-width:0}.author-name{font-size:1.1rem;font-weight:700;color:var(--foreground-primary);margin-bottom:.25rem;line-height:1.3}.post-date{color:var(--foreground-secondary);font-size:.9rem;margin:0;font-weight:500;opacity:.8}.author-actions{gap:.75rem}.author-actions,.icon-btn{display:flex;align-items:center}.icon-btn{background:var(--background-secondary);border:1px solid var(--action-primary);color:var(--foreground-secondary);font-size:1.3rem;padding:.6rem;border-radius:50%;cursor:pointer;transition:all .3s ease;justify-content:center;width:44px;height:44px;box-shadow:0 2px 4px rgba(0,0,0,.05)}.icon-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.15)}.icon-btn:active{transform:translateY(0);box-shadow:0 2px 6px rgba(0,0,0,.1)}.improved-hero-meta{display:flex;justify-content:space-between;align-items:center;gap:2.2rem;margin-bottom:2rem;background:var(--background-primary);border-radius:18px;box-shadow:0 2px 16px rgba(0,0,0,.07);padding:1.1rem 1.5rem 1.1rem 1.1rem;transition:box-shadow .2s}.improved-hero-meta:hover{box-shadow:0 4px 24px rgba(0,0,0,.13)}.meta-left{display:flex;align-items:center;gap:1.1rem}.meta-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid var(--action-primary);box-shadow:0 1px 4px rgba(0,0,0,.04)}.meta-author-details{display:flex;flex-direction:column;gap:.08rem}.meta-author-name{font-weight:700;color:var(--foreground-primary);font-size:1.01rem;line-height:1.2}.meta-date{color:var(--foreground-secondary);font-size:.89rem;opacity:.8}.improved-topic-badge{background:linear-gradient(90deg,var(--accent),var(--navy-blue));color:#fff;font-weight:600;font-size:.75rem;padding:.18rem .65rem;border-radius:11px;margin-left:.7rem;letter-spacing:.5px;box-shadow:none;border:none;text-transform:uppercase;transition:background .2s;display:inline-block;vertical-align:middle;line-height:1.2}.improved-topic-badge:hover{background:linear-gradient(90deg,var(--navy-blue),var(--accent))}.meta-stats{display:flex;align-items:center;gap:1.1rem;color:var(--foreground-secondary);font-weight:400;font-size:.98rem;border-left:1.5px solid var(--action-primary);padding-left:1.3rem;margin-left:1.3rem}@media (max-width:800px){.improved-hero-meta{flex-direction:column;align-items:flex-start;gap:1.1rem;padding:1rem}.meta-stats{border-left:none;padding-left:0;margin-left:0;border-top:1.5px solid var(--action-primary);padding-top:.7rem;margin-top:.7rem;width:100%;font-size:.97rem;gap:.8rem}.meta-left{gap:.7rem}.improved-topic-badge{margin-left:.5rem;font-size:.72rem;padding:.13rem .6rem}.meta-avatar{width:34px;height:34px}}.blog-content-wrapper{max-width:900px;margin:0 auto;padding:0 2rem}.article-content,.content-container{width:100%}.article-body{color:var(--content-primary);font-size:1.1rem;line-height:1.8}.article-body h1{font-size:2.2rem;margin:3rem 0 1.5rem;line-height:1.3}.article-body h1,.article-body h2{color:var(--foreground-primary);font-weight:700}.article-body h2{font-size:1.8rem;margin:2.5rem 0 1rem}.article-body h3{font-size:1.4rem;margin:2rem 0 1rem}.article-body h3,.article-body h4{color:var(--foreground-primary);font-weight:600}.article-body h4{font-size:1.2rem;margin:1.5rem 0 .5rem}.article-body h5{font-size:1.1rem;margin:1.25rem 0 .5rem}.article-body h5,.article-body h6{color:var(--foreground-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.article-body h6{font-size:1rem;margin:1rem 0 .5rem}.article-body p{margin-bottom:1.5rem}.article-body ol,.article-body ul{margin:1.5rem 0;padding-left:2rem}.article-body li{margin-bottom:.75rem;position:relative}.article-body li:before{content:"";position:absolute;left:-1.5rem;top:.75rem;width:6px;height:6px;border-radius:50%;background:var(--accent)}.article-body blockquote{border-left:4px solid var(--accent);padding-left:1.5rem;margin:2rem 0;font-style:italic;color:var(--foreground-secondary)}.article-body a{color:var(--accent);text-decoration:none;border-bottom:1px solid transparent;transition:all .2s ease;font-weight:500}.article-body a:hover{border-bottom-color:var(--accent);color:var(--navy-blue)}.article-body strong{font-weight:600;color:var(--foreground-primary)}.article-body em{font-style:italic;color:var(--foreground-secondary)}.article-body mark{background:linear-gradient(120deg,rgba(255,235,59,.3),rgba(255,235,59,.3));padding:.1rem .2rem;border-radius:3px}.article-body del{text-decoration:line-through;opacity:.7;color:var(--foreground-secondary)}.article-body ins{text-decoration:underline;text-decoration-color:var(--accent);text-decoration-thickness:2px}.article-body code{background:var(--action-secondary);color:var(--foreground-primary);padding:.2rem .4rem;border-radius:4px;font-size:.9em;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-weight:500}.article-body pre{background:#0d1117;border-radius:8px;padding:1rem;margin:1.5rem 0;overflow-x:auto}.article-body pre code{color:var(--background-tertiary);background:none;padding:0;font-size:.95rem;line-height:1.6}.dark-theme .article-body p code{background:var(--background-primary);color:var(--foreground-primary)}.article-body hr{border:none;height:1px;background:linear-gradient(90deg,transparent,var(--action-primary),transparent);margin:3rem 0}.ql-table-temporary{display:none}.article-body table{width:100%;border-collapse:collapse;margin:2rem 0;border-radius:8px;border-top:1px solid var(--action-primary);overflow:hidden}.article-body table p
.article-body th,.article-body td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--action-primary)}.article-body p.ql-table-block{margin-bottom:.5rem}.article-body th{background:var(--background-secondary);font-weight:600;color:var(--foreground-primary);font-size:.9rem}.article-body td{color:var(--content-primary);font-size:.9rem}.article-body img{max-width:100%;height:auto;border-radius:8px;margin:2rem 0;box-shadow:0 4px 12px rgba(0,0,0,.1);transition:transform .2s ease}.article-body img:hover{transform:scale(1.02)}.article-body figure{margin:2rem 0;text-align:center}.article-body figcaption{font-size:.85rem;color:var(--foreground-secondary);margin-top:.5rem;font-style:italic}.article-body kbd{border:1px solid var(--action-primary);font-size:.8em;box-shadow:0 1px 2px rgba(0,0,0,.1)}.article-body kbd,.article-body samp{background:var(--background-secondary);border-radius:4px;padding:.2rem .4rem;font-family:Monaco,Menlo,Ubuntu Mono,monospace;color:var(--foreground-primary)}.article-body samp{font-size:.9em}.article-body var{font-style:italic;color:var(--accent);font-weight:500}.article-body small{font-size:.85em;color:var(--foreground-secondary);opacity:.8}.article-body sub,.article-body sup{font-size:.75em;line-height:0;position:relative;vertical-align:baseline}.article-body sup{top:-.5em}.article-body sub{bottom:-.25em}.article-body dfn{font-style:italic;color:var(--accent);font-weight:500}.article-body abbr{border-bottom:1px dotted var(--action-primary);cursor:help;text-decoration:none}.article-body cite,.article-body q{font-style:italic;color:var(--foreground-secondary)}.article-body q:after,.article-body q:before{content:'"'}.article-footer{padding:2rem 0 3rem;border-top:1px solid var(--action-primary)}.article-tags{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:3rem}.tag{background:var(--action-secondary);color:var(--foreground-secondary);padding:.6rem 1.2rem;border-radius:25px;font-size:.9rem;font-weight:500;transition:all .2s ease;cursor:pointer}.tag:hover{background:var(--accent);color:white;transform:translateY(-1px)}.article-share{text-align:center}.article-share h4{font-size:1.2rem;font-weight:600;color:var(--foreground-primary);margin-bottom:1.5rem}.share-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.share-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:8px;font-weight:500;transition:all .2s ease;border:1px solid var(--action-primary);cursor:pointer}.share-btn.whatsapp{background-color:#289650;color:#fff;border-color:#16803d}.share-btn.whatsapp:hover{background-color:#16803d;transform:translateY(-1px)}.share-btn.xtwitter{background-color:#000;color:#fff;border-color:#000}.share-btn.xtwitter:hover{background-color:#111;transform:translateY(-1px)}.share-btn.linkedin{background:#0077B5;color:white;border-color:#0077B5}.share-btn.linkedin:hover{background:#005885;transform:translateY(-1px)}.share-btn.copy{background:var(--background-primary);color:var(--foreground-primary)}.share-btn.copy:hover{background:var(--action-secondary);transform:translateY(-1px)}.toc-sidebar{position:fixed;top:0;right:-400px;width:400px;height:100vh;background:var(--background-primary);border-left:1px solid var(--action-primary);z-index:1000;transition:right .3s ease;overflow-y:auto}.toc-sidebar.toc-open{right:0}.toc-header{display:flex;justify-content:space-between;align-items:center;padding:2rem;border-bottom:1px solid var(--action-primary);background:var(--background-primary);position:sticky;top:0;z-index:1}.toc-header h3{margin:0;color:var(--foreground-primary);font-size:1.2rem;font-weight:600}.toc-close-btn{background:none;border:none;color:var(--foreground-tertiary);font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:all .2s ease}.toc-close-btn:hover{background:var(--action-secondary);color:var(--foreground-primary)}.toc-nav{padding:2rem}.toc-link{display:block;color:var(--foreground-secondary);font-size:.95rem;line-height:1.5;padding:.75rem 0;border-bottom:1px solid transparent;transition:all .2s ease;text-decoration:none;cursor:pointer}.toc-link:hover{color:var(--accent);border-bottom-color:var(--accent);padding-left:.5rem}.toc-link-h3{padding-left:1.5rem;font-size:.9rem;color:var(--foreground-tertiary)}.toc-link-h3:hover{color:var(--accent)}.toc-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:999;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width:1024px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.2rem}.toc-sidebar{width:100%;right:-100%}.floating-toc-btn{right:1rem}}@media (max-width:768px){.blog-hero{padding-top:3rem}.hero-container{padding:0 1rem}.hero-title{font-size:2rem}.hero-subtitle{font-size:1.1rem}.hero-meta{flex-direction:column;gap:1rem;align-items:flex-start}.hero-stats{gap:1rem}.author-section{padding:1.5rem 0}.author-info,.author-section{flex-direction:column;align-items:flex-start;gap:1rem}.follow-btn{margin-left:0;margin-top:.5rem}.author-actions{margin-top:1rem}.blog-content-wrapper{padding:0 1rem 3rem}.article-body{font-size:1rem}.article-body h1{font-size:1.8rem}.article-body h2{font-size:1.5rem}.article-body h3{font-size:1.2rem}.article-body h4{font-size:1.1rem}.article-body h5{font-size:1rem}.article-body h6{font-size:.9rem}.share-buttons{flex-direction:column;align-items:center}.share-btn{width:200px;justify-content:center}.floating-toc-btn{top:80px;right:1rem;width:45px;height:45px;font-size:1.3rem}}@media (max-width:480px){.hero-title{font-size:1.75rem}.article-body,.hero-subtitle{font-size:1rem}.article-body h1{font-size:1.6rem}.article-body h2{font-size:1.4rem}.article-body h3{font-size:1.1rem}.article-body h4{font-size:1rem}.article-body h5{font-size:.95rem}.article-body h6{font-size:.85rem}.floating-toc-btn{top:70px;right:.5rem;width:40px;height:40px;font-size:1.2rem}}.dark-theme .tag{background:var(--action-primary);color:var(--foreground-primary)}.dark-theme .tag:hover{background:var(--accent);color:white}.dark-theme .share-btn.copy{background:var(--background-primary);color:var(--foreground-primary);border-color:var(--action-primary)}.dark-theme .share-btn.copy:hover{background:var(--action-primary)}