/*
  PaperMod v8+
  License: MIT https://github.com/adityatelange/hugo-PaperMod/blob/master/LICENSE
  Copyright (c) 2020 nanxiaobei and adityatelange
  Copyright (c) 2021-2025 adityatelange
*/
:root{--gap:24px;--content-gap:20px;--nav-width:1024px;--main-width:720px;--header-height:60px;--footer-height:60px;--radius:8px;--theme:rgb(255, 255, 255);--entry:rgb(255, 255, 255);--primary:rgb(30, 30, 30);--secondary:rgb(108, 108, 108);--tertiary:rgb(214, 214, 214);--content:rgb(31, 31, 31);--code-block-bg:rgb(28, 29, 33);--code-bg:rgb(245, 245, 245);--border:rgb(238, 238, 238)}.dark{--theme:rgb(29, 30, 32);--entry:rgb(46, 46, 51);--primary:rgb(218, 218, 219);--secondary:rgb(155, 156, 157);--tertiary:rgb(65, 66, 68);--content:rgb(196, 196, 197);--code-block-bg:rgb(46, 46, 51);--code-bg:rgb(55, 56, 62);--border:rgb(51, 51, 51)}.list{background:var(--code-bg)}.dark.list{background:var(--theme)}*,::after,::before{box-sizing:border-box}html{-webkit-tap-highlight-color:transparent;overflow-y:scroll;-webkit-text-size-adjust:100%;text-size-adjust:100%}a,button,body,h1,h2,h3,h4,h5,h6{color:var(--primary)}body{font-family:-apple-system,BlinkMacSystemFont,segoe ui,Roboto,Oxygen,Ubuntu,Cantarell,open sans,helvetica neue,sans-serif;font-size:18px;line-height:2;word-break:break-word;background:var(--theme)}article,aside,figcaption,figure,footer,header,hgroup,main,nav,section,table{display:block}h1,h2,h3,h4,h5,h6{line-height:1}h1,h2,h3,h4,h5,h6,p{margin-top:0;margin-bottom:0}ul{padding:0}a{text-decoration:none}body,figure,ul{margin:0}table{width:100%;border-collapse:collapse;border-spacing:0;overflow-x:auto;word-break:keep-all}button,input,textarea{padding:0;font:inherit;background:0 0;border:0}input,textarea{outline:0}button,input[type=button],input[type=submit]{cursor:pointer}input:-webkit-autofill,textarea:-webkit-autofill{box-shadow:0 0 0 50px var(--theme)inset}img{display:block;max-width:100%}.not-found{position:absolute;left:0;right:0;display:flex;align-items:center;justify-content:center;height:80%;font-size:160px;font-weight:700}.archive-posts{width:100%;font-size:16px}.archive-year{margin-top:40px}.archive-year:not(:last-of-type){border-bottom:2px solid var(--border)}.archive-month{display:flex;align-items:flex-start;padding:10px 0}.archive-month-header{margin:25px 0;width:200px}.archive-month:not(:last-of-type){border-bottom:1px solid var(--border)}.archive-entry{position:relative;padding:5px;margin:10px 0}.archive-entry-title{margin:5px 0;font-weight:400}.archive-count,.archive-meta{color:var(--secondary);font-size:14px}.footer,.top-link{font-size:12px;color:var(--secondary)}.footer{max-width:calc(var(--main-width) + var(--gap) * 2);margin:auto;padding:calc((var(--footer-height) - var(--gap))/2)var(--gap);text-align:center;line-height:24px}.footer span{margin-inline-start:1px;margin-inline-end:1px}.footer span:last-child{white-space:nowrap}.footer a{color:inherit;border-bottom:1px solid var(--secondary)}.footer a:hover{border-bottom:1px solid var(--primary)}.top-link{visibility:hidden;position:fixed;bottom:60px;right:30px;z-index:99;background:var(--tertiary);width:42px;height:42px;padding:12px;border-radius:64px;transition:visibility .5s,opacity .8s linear}.top-link,.top-link svg{filter:drop-shadow(0 0 0 var(--theme))}.footer a:hover,.top-link:hover{color:var(--primary)}.top-link:focus,#theme-toggle:focus{outline:0}.nav{display:flex;flex-wrap:wrap;justify-content:space-between;max-width:calc(var(--nav-width) + var(--gap) * 2);margin-inline-start:auto;margin-inline-end:auto;line-height:var(--header-height)}.nav a{display:block}.logo,#menu{display:flex;margin:auto var(--gap)}.logo{flex-wrap:inherit}.logo a{font-size:24px;font-weight:700}.logo a img,.logo a svg{display:inline;vertical-align:middle;pointer-events:none;transform:translate(0,-10%);border-radius:6px;margin-inline-end:8px}button#theme-toggle{font-size:26px;margin:auto 4px}body.dark #moon{vertical-align:middle;display:none}body:not(.dark) #sun{display:none}#menu{list-style:none;word-break:keep-all;overflow-x:auto;white-space:nowrap}#menu li+li{margin-inline-start:var(--gap)}#menu a{font-size:16px}#menu .active{font-weight:500;border-bottom:2px solid}.lang-switch li,.lang-switch ul,.logo-switches{display:inline-flex;margin:auto 4px}.lang-switch{display:flex;flex-wrap:inherit}.lang-switch a{margin:auto 3px;font-size:16px;font-weight:500}.logo-switches{flex-wrap:inherit}.main{position:relative;min-height:calc(100vh - var(--header-height) - var(--footer-height));max-width:calc(var(--main-width) + var(--gap) * 2);margin:auto;padding:var(--gap)}.page-header h1{font-size:40px}.pagination{display:flex}.pagination a{color:var(--theme);font-size:13px;line-height:36px;background:var(--primary);border-radius:calc(36px/2);padding:0 16px}.pagination .next{margin-inline-start:auto}.social-icons a{display:inline-flex;padding:10px}.social-icons a svg{height:26px;width:26px}code{direction:ltr}div.highlight,pre{position:relative}.copy-code{display:none;position:absolute;top:4px;right:4px;color:rgba(255,255,255,.8);background:rgba(78,78,78,.8);border-radius:var(--radius);padding:0 5px;font-size:14px;user-select:none}div.highlight:hover .copy-code,pre:hover .copy-code{display:block}.first-entry{position:relative;display:flex;flex-direction:column;justify-content:center;min-height:320px;margin:var(--gap)0 calc(var(--gap) * 2)}.first-entry .entry-header{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3}.first-entry .entry-header h1{font-size:34px;line-height:1}.first-entry .entry-content{margin:14px 0;font-size:16px;-webkit-line-clamp:3}.first-entry .entry-footer{font-size:14px}.home-info .entry-content{-webkit-line-clamp:unset}.post-entry{position:relative;margin-bottom:var(--gap);padding:var(--gap);background:var(--entry);border-radius:var(--radius);transition:transform .1s;border:1px solid var(--border)}.post-entry:active{transform:scale(1)}.tag-entry .entry-cover{display:none}.entry-header h2{font-size:24px;line-height:1}.entry-content{margin:8px 0;color:var(--secondary);font-size:14px;line-height:2;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.entry-footer{color:var(--secondary);font-size:13px}.entry-link{position:absolute;left:0;right:0;top:0;bottom:0}.entry-hint{color:var(--secondary)}.entry-hint-parent{display:flex;justify-content:space-between}.entry-cover{font-size:14px;margin-bottom:var(--gap);text-align:center}.entry-cover img{border-radius:var(--radius);width:100%;height:auto}.entry-cover a{color:var(--secondary);box-shadow:0 1px 0 var(--primary)}.page-header,.post-header{margin:24px auto var(--content-gap)}.post-title{margin-bottom:2px;font-size:40px}.post-description{margin-top:10px;margin-bottom:5px}.post-meta,.breadcrumbs{color:var(--secondary);font-size:14px;display:flex;flex-wrap:wrap;align-items:center}.post-meta .i18n_list li{display:inline-flex;list-style:none;margin:auto 3px;box-shadow:0 1px 0 var(--secondary)}.breadcrumbs a{font-size:16px}.post-content{color:var(--content)}.post-content h3,.post-content h4,.post-content h5,.post-content h6{margin:24px 0 16px}.post-content h1{margin:40px auto 32px;font-size:40px}.post-content h2{margin:32px auto 24px;font-size:32px}.post-content h3{font-size:24px}.post-content h4{font-size:16px}.post-content h5{font-size:14px}.post-content h6{font-size:12px}.post-content a,.toc a:hover{box-shadow:0 1px;box-decoration-break:clone;-webkit-box-decoration-break:clone}.post-content a code{margin:auto 0;border-radius:0;box-shadow:0 -1px 0 var(--primary)inset}.post-content del{text-decoration:line-through}.post-content dl,.post-content ol,.post-content p,.post-content figure,.post-content ul{margin-bottom:var(--content-gap)}.post-content ol,.post-content ul{padding-inline-start:20px}.post-content li{margin-top:5px}.post-content li p{margin-bottom:0}.post-content dl{display:flex;flex-wrap:wrap;margin:0}.post-content dt{width:25%;font-weight:700}.post-content dd{width:75%;margin-inline-start:0;padding-inline-start:10px}.post-content dd~dd,.post-content dt~dt{margin-top:10px}.post-content table{margin-bottom:var(--content-gap)}.post-content table th,.post-content table:not(.highlighttable,.highlight table,.gist .highlight) td{min-width:80px;padding:8px 5px;line-height:2;border-bottom:1px solid var(--border)}.post-content table th{text-align:start}.post-content table:not(.highlighttable) td code:only-child{margin:auto 0}.post-content .highlight table{border-radius:var(--radius)}.post-content .highlight:not(table){margin:10px auto;background:var(--code-block-bg) !important;border-radius:var(--radius);direction:ltr}.post-content li>.highlight{margin-inline-end:0}.post-content ul pre{margin-inline-start:calc(var(--gap) * -2)}.post-content .highlight pre{margin:0}.post-content .highlighttable{table-layout:fixed}.post-content .highlighttable td:first-child{width:40px}.post-content .highlighttable td .linenodiv{padding-inline-end:0 !important}.post-content .highlighttable td .highlight,.post-content .highlighttable td .linenodiv pre{margin-bottom:0}.post-content code{margin:auto 4px;padding:4px 6px;font-size:.8em;line-height:2;background:var(--code-bg);border-radius:2px}.post-content pre code{display:grid;margin:auto 0;padding:10px;color:#d5d5d6;background:var(--code-block-bg) !important;border-radius:var(--radius);overflow-x:auto;word-break:break-all}.post-content blockquote{margin:20px 0;padding:0 14px;border-inline-start:3px solid var(--primary)}.post-content hr{margin:30px 0;height:2px;background:var(--tertiary);border:0}.post-content iframe{max-width:100%}.post-content img{border-radius:4px;margin:1rem 0}.post-content img[src*="#center"]{margin:1rem auto}.post-content figure.align-center{text-align:center}.post-content figure>figcaption{color:var(--primary);font-size:16px;font-weight:700;margin:8px 0 16px}.post-content figure>figcaption>p{color:var(--secondary);font-size:14px;font-weight:400}.toc{margin:0 2px 40px;border:1px solid var(--border);background:var(--code-bg);border-radius:var(--radius);padding:.4em}.dark .toc{background:var(--entry)}.toc details summary{cursor:zoom-in;margin-inline-start:10px;user-select:none}.toc details[open] summary{cursor:zoom-out}.toc .details{display:inline;font-weight:500}.toc .inner{margin:5px 20px 0;padding:0 10px;opacity:.9}.toc li ul{margin-inline-start:var(--gap)}.toc summary:focus{outline:0}.post-footer{margin-top:56px}.post-footer>*{margin-bottom:10px}.post-tags{display:flex;flex-wrap:wrap;gap:10px}.post-tags li{display:inline-block}.post-tags a,.share-buttons,.paginav{border-radius:var(--radius);background:var(--code-bg);border:1px solid var(--border)}.post-tags a{display:block;padding:0 14px;color:var(--secondary);font-size:14px;line-height:34px;background:var(--code-bg)}.post-tags a:hover,.paginav a:hover{background:var(--border)}.share-buttons{padding:10px;display:flex;justify-content:center;overflow-x:auto;gap:10px}.share-buttons li,.share-buttons a{display:inline-flex}.share-buttons a:not(:last-of-type){margin-inline-end:12px}h1:hover .anchor,h2:hover .anchor,h3:hover .anchor,h4:hover .anchor,h5:hover .anchor,h6:hover .anchor{display:inline-flex;color:var(--secondary);margin-inline-start:8px;font-weight:500;user-select:none}.paginav{display:flex;line-height:30px}.paginav a{padding-inline-start:14px;padding-inline-end:14px;border-radius:var(--radius)}.paginav .title{letter-spacing:1px;text-transform:uppercase;font-size:small;color:var(--secondary)}.paginav .prev,.paginav .next{width:50%}.paginav span:hover:not(.title){box-shadow:0 1px}.paginav .next{margin-inline-start:auto;text-align:right}[dir=rtl] .paginav .next{text-align:left}h1>a>svg{display:inline}img.in-text{display:inline;margin:auto}.buttons,.main .profile{display:flex;justify-content:center}.main .profile{align-items:center;min-height:calc(100vh - var(--header-height) - var(--footer-height) - (var(--gap) * 2));text-align:center}.profile .profile_inner{display:flex;flex-direction:column;align-items:center;gap:10px}.profile img{border-radius:50%}.buttons{flex-wrap:wrap;max-width:400px}.button{background:var(--tertiary);border-radius:var(--radius);margin:8px;padding:6px;transition:transform .1s}.button-inner{padding:0 8px}.button:active{transform:scale(1)}#searchbox input{padding:4px 10px;width:100%;color:var(--primary);font-weight:700;border:2px solid var(--tertiary);border-radius:var(--radius)}#searchbox input:focus{border-color:var(--secondary)}#searchResults li{list-style:none;border-radius:var(--radius);padding:10px;margin:10px 0;position:relative;font-weight:500}#searchResults{margin:10px 0;width:100%}#searchResults li:active{transition:transform .1s;transform:scale(1)}#searchResults a{position:absolute;width:100%;height:100%;top:0;left:0;outline:none}#searchResults .focus{transform:scale(1);border:2px solid var(--tertiary)}.terms-tags li{display:inline-block;margin:10px;font-weight:500}.terms-tags a{display:block;padding:3px 10px;background:var(--tertiary);border-radius:6px;transition:transform .1s}.terms-tags a:active{background:var(--tertiary);transform:scale(1)}.bg{color:#cad3f5;background-color:#24273a}.chroma{color:#cad3f5;background-color:#24273a}.chroma .x{}.chroma .err{color:#ed8796}.chroma .cl{}.chroma .lnlinks{outline:none;text-decoration:none;color:inherit}.chroma .lntd{vertical-align:top;padding:0;margin:0;border:0}.chroma .lntable{border-spacing:0;padding:0;margin:0;border:0}.chroma .hl{background-color:#474733}.chroma .lnt{white-space:pre;-webkit-user-select:none;user-select:none;margin-right:.4em;padding:0 .4em;color:#8087a2}.chroma .ln{white-space:pre;-webkit-user-select:none;user-select:none;margin-right:.4em;padding:0 .4em;color:#8087a2}.chroma .line{display:flex}.chroma .k{color:#c6a0f6}.chroma .kc{color:#f5a97f}.chroma .kd{color:#ed8796}.chroma .kn{color:#8bd5ca}.chroma .kp{color:#c6a0f6}.chroma .kr{color:#c6a0f6}.chroma .kt{color:#ed8796}.chroma .n{}.chroma .na{color:#8aadf4}.chroma .nb{color:#91d7e3}.chroma .bp{color:#91d7e3}.chroma .nc{color:#eed49f}.chroma .no{color:#eed49f}.chroma .nd{color:#8aadf4;font-weight:700}.chroma .ni{color:#8bd5ca}.chroma .ne{color:#f5a97f}.chroma .nf{color:#8aadf4}.chroma .fm{color:#8aadf4}.chroma .nl{color:#91d7e3}.chroma .nn{color:#f5a97f}.chroma .nx{}.chroma .py{color:#f5a97f}.chroma .nt{color:#c6a0f6}.chroma .nv{color:#f4dbd6}.chroma .vc{color:#f4dbd6}.chroma .vg{color:#f4dbd6}.chroma .vi{color:#f4dbd6}.chroma .vm{color:#f4dbd6}.chroma .l{}.chroma .ld{}.chroma .s{color:#a6da95}.chroma .sa{color:#ed8796}.chroma .sb{color:#a6da95}.chroma .sc{color:#a6da95}.chroma .dl{color:#8aadf4}.chroma .sd{color:#6e738d}.chroma .s2{color:#a6da95}.chroma .se{color:#8aadf4}.chroma .sh{color:#6e738d}.chroma .si{color:#a6da95}.chroma .sx{color:#a6da95}.chroma .sr{color:#8bd5ca}.chroma .s1{color:#a6da95}.chroma .ss{color:#a6da95}.chroma .m{color:#f5a97f}.chroma .mb{color:#f5a97f}.chroma .mf{color:#f5a97f}.chroma .mh{color:#f5a97f}.chroma .mi{color:#f5a97f}.chroma .il{color:#f5a97f}.chroma .mo{color:#f5a97f}.chroma .o{color:#91d7e3;font-weight:700}.chroma .ow{color:#91d7e3;font-weight:700}.chroma .p{}.chroma .c{color:#6e738d;font-style:italic}.chroma .ch{color:#6e738d;font-style:italic}.chroma .cm{color:#6e738d;font-style:italic}.chroma .c1{color:#6e738d;font-style:italic}.chroma .cs{color:#6e738d;font-style:italic}.chroma .cp{color:#6e738d;font-style:italic}.chroma .cpf{color:#6e738d;font-weight:700;font-style:italic}.chroma .g{}.chroma .gd{color:#ed8796;background-color:#363a4f}.chroma .ge{font-style:italic}.chroma .gr{color:#ed8796}.chroma .gh{color:#f5a97f;font-weight:700}.chroma .gi{color:#a6da95;background-color:#363a4f}.chroma .go{}.chroma .gp{}.chroma .gs{font-weight:700}.chroma .gu{color:#f5a97f;font-weight:700}.chroma .gt{color:#ed8796}.chroma .gl{text-decoration:underline}.chroma .w{}.chroma{background-color:unset !important}.chroma .hl{display:flex}.chroma .lnt{padding:0 0 0 12px}.highlight pre.chroma code{padding:8px 0}.highlight pre.chroma .line .cl,.chroma .ln{padding:0 10px}.chroma .lntd:last-of-type{width:100%}::-webkit-scrollbar-track{background:0 0}.list:not(.dark)::-webkit-scrollbar-track{background:var(--code-bg)}::-webkit-scrollbar-thumb{background:var(--tertiary);border:5px solid var(--theme);border-radius:var(--radius)}.list:not(.dark)::-webkit-scrollbar-thumb{border:5px solid var(--code-bg)}::-webkit-scrollbar-thumb:hover{background:var(--secondary)}::-webkit-scrollbar:not(.highlighttable,.highlight table,.gist .highlight){background:var(--theme)}.post-content .highlighttable td .highlight pre code::-webkit-scrollbar{display:none}.post-content :not(table) ::-webkit-scrollbar-thumb{border:2px solid var(--code-block-bg);background:#717175}.post-content :not(table) ::-webkit-scrollbar-thumb:hover{background:#a3a3a5}.gist table::-webkit-scrollbar-thumb{border:2px solid #fff;background:#adadad}.gist table::-webkit-scrollbar-thumb:hover{background:#707070}.post-content table::-webkit-scrollbar-thumb{border-width:2px}@media screen and (min-width:768px){::-webkit-scrollbar{width:19px;height:11px}}@media screen and (max-width:768px){:root{--gap:14px}.profile img{transform:scale(.9)}.first-entry{min-height:260px}.archive-month{flex-direction:column}.archive-year{margin-top:20px}.footer{padding:calc((var(--footer-height) - var(--gap) - 10px)/2)var(--gap)}}@media screen and (max-width:900px){.list .top-link{transform:translateY(-5rem)}}@media screen and (max-width:340px){.share-buttons{justify-content:unset}}@media(prefers-reduced-motion){.terms-tags a:active,.button:active,.post-entry:active,.top-link,#searchResults .focus,#searchResults li:active{transform:none}}.highlight{background:#fff !important;border:1px solid #e2e8f0 !important;border-radius:8px !important;margin:2rem 0 !important;overflow:hidden !important;position:relative !important;box-shadow:0 1px 3px rgba(0,0,0,.1) !important}.highlight pre{background:#fff !important;color:#1f2937 !important;border:none !important;border-radius:0 !important;padding:1rem !important;overflow-x:auto !important;margin:0 !important;line-height:2 !important;font-size:.9rem !important;font-family:jetbrains mono,fira code,sf mono,monaco,inconsolata,roboto mono,cascadia code,consolas,liberation mono,courier new,monospace !important;font-weight:400 !important}.highlight pre code{background:0 0 !important;color:#1f2937 !important;border:none !important;padding:0 !important;font-size:inherit !important;font-family:inherit !important;white-space:pre !important;font-weight:inherit !important}body.dark .highlight{background:#161b22 !important;border:1px solid #30363d !important;box-shadow:0 2px 4px rgba(0,0,0,.2) !important}body.dark .highlight pre{background:#161b22 !important;color:#e6edf3 !important;font-family:jetbrains mono,fira code,sf mono,monaco,inconsolata,roboto mono,cascadia code,consolas,liberation mono,courier new,monospace !important}body.dark .highlight pre code{background:0 0 !important;color:#e6edf3 !important}.highlight .c,.highlight .c1,.highlight .cm,.highlight .cp{color:#6b7280 !important;font-style:italic !important}.highlight .s,.highlight .s1,.highlight .s2,.highlight .se,.highlight .sa{color:#059669 !important;font-weight:500 !important}.highlight .k,.highlight .kd,.highlight .kn,.highlight .kt,.highlight .kc,.highlight .kr{color:#dc2626 !important;font-weight:600 !important}.highlight .nf,.highlight .fm,.highlight .nb{color:#2563eb !important;font-weight:600 !important}.highlight .n,.highlight .nv,.highlight .nc,.highlight .nx{color:#ea580c !important}.highlight .m,.highlight .mi,.highlight .mf,.highlight .mo{color:#7c3aed !important}.highlight .o,.highlight .ow{color:#1f2937 !important;font-weight:500 !important}.highlight .p{color:#374151 !important}body.dark .highlight .c,body.dark .highlight .c1,body.dark .highlight .cm,body.dark .highlight .cp{color:#7d8590 !important;font-style:italic !important}body.dark .highlight .s,body.dark .highlight .s1,body.dark .highlight .s2,body.dark .highlight .se,body.dark .highlight .sa{color:#a5d6ff !important}body.dark .highlight .k,body.dark .highlight .kd,body.dark .highlight .kn,body.dark .highlight .kt,body.dark .highlight .kc,body.dark .highlight .kr{color:#ff7b72 !important;font-weight:600 !important}body.dark .highlight .nf,body.dark .highlight .fm,body.dark .highlight .nb{color:#d2a8ff !important;font-weight:600 !important}body.dark .highlight .n,body.dark .highlight .nv,body.dark .highlight .nc,body.dark .highlight .nx{color:#ffa657 !important}body.dark .highlight .m,body.dark .highlight .mi,body.dark .highlight .mf,body.dark .highlight .mo{color:#79c0ff !important}body.dark .highlight .o,body.dark .highlight .ow{color:#ff7b72 !important}body.dark .highlight .p{color:#e6edf3 !important}.highlight .lnt,.highlight .lnl,.lnt,.lnl,span.lnt,span.lnl,td.lnt,td.lnl,.highlight table .lnt,.highlight table .lnl,.chroma .lnt,.chroma .lnl{position:absolute !important;left:-99999px !important;top:-99999px !important;width:0 !important;height:0 !important;opacity:0 !important;visibility:hidden !important;display:none !important;user-select:none !important;-webkit-user-select:none !important;-moz-user-select:none !important;-ms-user-select:none !important;pointer-events:none !important;font-size:0 !important;line-height:0 !important;margin:0 !important;padding:0 !important;border:none !important;background:0 0 !important;color:transparent !important}.copy-code{position:absolute !important;top:.8rem !important;right:.8rem !important;border-radius:6px !important;padding:.5rem .8rem !important;font-size:.8rem !important;font-weight:500 !important;cursor:pointer !important;z-index:10 !important;transition:all .2s ease-in-out !important;font-family:system-ui,-apple-system,segoe ui,sans-serif !important;border:1px solid #d1d5db !important;background:#fff !important;color:#374151 !important;opacity:.8 !important;backdrop-filter:blur(4px) !important}.copy-code:hover{opacity:1 !important;transform:translateY(-1px) !important;background:#fff !important;box-shadow:0 4px 8px rgba(0,0,0,.1) !important}.copy-code.copied{background:#10b981 !important;color:#fff !important;border-color:#10b981 !important}.copy-code.error{background:#ef4444 !important;color:#fff !important;border-color:#ef4444 !important}body.dark .copy-code{background:#21262d !important;color:#e6edf3 !important;border:1px solid #30363d !important}body.dark .copy-code:hover{background:#21262d !important;box-shadow:0 4px 8px rgba(0,0,0,.3) !important}@media(max-width:768px){.highlight{margin:1rem 0 !important;border-radius:6px !important}.highlight pre{font-size:.8rem !important;padding:.9rem 1rem !important}.copy-code{top:.5rem !important;right:.5rem !important;padding:.4rem .5rem !important;font-size:.7rem !important}}@media(max-width:480px){.highlight pre{font-size:.8rem !important;padding:.8rem .9rem !important}.copy-code{font-size:.7rem !important;padding:.3rem .4rem !important}}.highlight .nb,.highlight .nf,.highlight .fm{color:#2563eb !important;font-weight:600 !important}body.dark .highlight .nb,body.dark .highlight .nf,body.dark .highlight .fm{color:#79c0ff !important;font-weight:600 !important}.highlight.hugo-paper-light{background:#fafafa !important;border:1px solid #e1e5e9 !important;border-radius:6px !important;margin:2rem 0 !important;overflow:hidden !important;position:relative !important;box-shadow:0 1px 3px rgba(0,0,0,8%) !important;font-family:sf mono,Monaco,cascadia code,roboto mono,Consolas,courier new,monospace !important}.highlight.hugo-paper-light pre{background:#fafafa !important;color:#24292f !important;border:none !important;border-radius:0 !important;padding:1rem !important;overflow-x:auto !important;margin:0 !important;line-height:2 !important;font-size:.9rem !important;font-weight:400 !important}.highlight.hugo-paper-light pre code{background:0 0 !important;color:#24292f !important;border:none !important;padding:0 !important;font-size:inherit !important;font-family:inherit !important;white-space:pre !important;font-weight:inherit !important}.highlight.hugo-paper-light .c,.highlight.hugo-paper-light .c1,.highlight.hugo-paper-light .cm,.highlight.hugo-paper-light .cp{color:#6a737d !important;font-style:italic !important}.highlight.hugo-paper-light .s,.highlight.hugo-paper-light .s1,.highlight.hugo-paper-light .s2,.highlight.hugo-paper-light .se,.highlight.hugo-paper-light .sa{color:#032f62 !important}.highlight.hugo-paper-light .k,.highlight.hugo-paper-light .kd,.highlight.hugo-paper-light .kn,.highlight.hugo-paper-light .kt,.highlight.hugo-paper-light .kc{color:#d73a49 !important;font-weight:600 !important}.highlight.hugo-paper-light .nf,.highlight.hugo-paper-light .fm,.highlight.hugo-paper-light .nb{color:#6f42c1 !important;font-weight:500 !important}.highlight.hugo-paper-light .n,.highlight.hugo-paper-light .nv,.highlight.hugo-paper-light .nc{color:#24292f !important}.highlight.hugo-paper-light .m,.highlight.hugo-paper-light .mi,.highlight.hugo-paper-light .mf,.highlight.hugo-paper-light .mo{color:#005cc5 !important}.highlight.hugo-paper-light .o,.highlight.hugo-paper-light .ow{color:#d73a49 !important}.highlight.hugo-paper-light .p{color:#24292f !important}.highlight.hugo-paper-light .nt{color:#22863a !important;font-weight:600 !important}.highlight.hugo-paper-light .na{color:#6f42c1 !important}body:not(.dark) .highlight{background:#fafafa !important;border:1px solid #e1e5e9 !important;border-radius:6px !important;box-shadow:0 1px 3px rgba(0,0,0,8%) !important}body:not(.dark) .highlight pre{background:#fafafa !important;color:#24292f !important}body:not(.dark) .highlight pre code{background:0 0 !important;color:#24292f !important}body:not(.dark) .highlight .c,body:not(.dark) .highlight .c1,body:not(.dark) .highlight .cm,body:not(.dark) .highlight .cp{color:#6a737d !important;font-style:italic !important}body:not(.dark) .highlight .s,body:not(.dark) .highlight .s1,body:not(.dark) .highlight .s2,body:not(.dark) .highlight .se,body:not(.dark) .highlight .sa{color:#032f62 !important}body:not(.dark) .highlight .k,body:not(.dark) .highlight .kd,body:not(.dark) .highlight .kn,body:not(.dark) .highlight .kt,body:not(.dark) .highlight .kc{color:#d73a49 !important;font-weight:600 !important}body:not(.dark) .highlight .nf,body:not(.dark) .highlight .fm,body:not(.dark) .highlight .nb{color:#6f42c1 !important;font-weight:500 !important}body:not(.dark) .highlight .n,body:not(.dark) .highlight .nv,body:not(.dark) .highlight .nc{color:#24292f !important}body:not(.dark) .highlight .m,body:not(.dark) .highlight .mi,body:not(.dark) .highlight .mf,body:not(.dark) .highlight .mo{color:#005cc5 !important}body:not(.dark) .highlight .o,body:not(.dark) .highlight .ow{color:#d73a49 !important}body:not(.dark) .highlight .p{color:#24292f !important}body:not(.dark) .highlight .nt{color:#22863a !important;font-weight:600 !important}body:not(.dark) .highlight .na{color:#6f42c1 !important}body:not(.dark) .copy-code{background:#fff !important;color:#586069 !important;border:1px solid #e1e5e9 !important;font-size:.8rem !important;font-weight:500 !important;border-radius:4px !important}body:not(.dark) .copy-code:hover{background:#fff !important;color:#24292f !important;border-color:#d0d7de !important;transform:translateY(-1px) !important;box-shadow:0 2px 4px rgba(0,0,0,.1) !important}body:not(.dark) .highlight pre{scrollbar-width:thin !important;scrollbar-color:#d0d7de #fafafa !important}body:not(.dark) .highlight pre::-webkit-scrollbar{height:8px !important}body:not(.dark) .highlight pre::-webkit-scrollbar-track{background:#fafafa !important}body:not(.dark) .highlight pre::-webkit-scrollbar-thumb{background:#d0d7de !important;border-radius:4px !important}body:not(.dark) .highlight pre::-webkit-scrollbar-thumb:hover{background:#bcc3ce !important}body:not(.dark) .highlight pre::selection,body:not(.dark) .highlight pre code::selection{background:#c8e1ff !important;color:inherit !important}@media(max-width:768px){body:not(.dark) .highlight{margin:1rem -.5rem !important;border-radius:0 !important;border-left:none !important;border-right:none !important;box-shadow:none !important}body:not(.dark) .highlight pre{font-size:.8rem !important;padding:.9rem 1rem !important;line-height:1 !important}body:not(.dark) .copy-code{top:.5rem !important;right:.8rem !important;padding:.3rem .5rem !important;font-size:.7rem !important}}body:not(.dark) .highlight .language-bash .nb,body:not(.dark) .highlight .language-sh .nb{color:#22863a !important;font-weight:600 !important}body:not(.dark) .highlight .language-json .nt{color:#032f62 !important;font-weight:500 !important}body:not(.dark) .highlight .language-css .nt{color:#22863a !important;font-weight:600 !important}body:not(.dark) .highlight .language-css .k{color:#005cc5 !important;font-weight:500 !important}body:not(.dark) .highlight .language-yaml .nt,body:not(.dark) .highlight .language-yml .nt{color:#22863a !important;font-weight:600 !important}.expand-container{margin:2rem 0;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,8%);transition:all .3s ease;font-family:inherit}.expand-container:hover{box-shadow:0 4px 12px rgba(0,0,0,.1);border-color:#3b82f6;transform:translateY(-1px)}.expand-header{padding:16px 20px;background:#f8fafc;cursor:pointer;font-weight:600;font-size:1rem;list-style:none;user-select:none;display:flex;align-items:center;justify-content:space-between;transition:all .2s ease;border:none;outline:none;color:#1e293b}.expand-header:hover{background:#f1f5f9;color:#3b82f6}.expand-header::-webkit-details-marker{display:none}.expand-title{flex:1;display:flex;align-items:center}.expand-icon{margin-right:12px;font-size:1rem;transition:all .3s ease}.expand-chevron{font-size:1rem;transition:transform .3s ease;color:#6b7280;font-weight:600;margin-left:8px}.expand-container[open] .expand-chevron{transform:rotate(180deg);color:#3b82f6}.expand-content{padding:24px;background:#fff;border-top:1px solid #f1f5f9;animation:expandFadeIn .3s ease-out}@keyframes expandFadeIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.expand-info{border-color:#3b82f6;background:#eff6ff}.expand-info .expand-header{background:#dbeafe;color:#1e40af}.expand-info .expand-content{background:#eff6ff}.expand-warning{border-color:#f59e0b;background:#fffbeb}.expand-warning .expand-header{background:#fef3c7;color:#92400e}.expand-warning .expand-content{background:#fffbeb}.expand-success{border-color:#10b981;background:#ecfdf5}.expand-success .expand-header{background:#d1fae5;color:#065f46}.expand-success .expand-content{background:#ecfdf5}.expand-danger{border-color:#ef4444;background:#fef2f2}.expand-danger .expand-header{background:#fecaca;color:#991b1b}.expand-danger .expand-content{background:#fef2f2}.dark .expand-container,[data-theme=dark] .expand-container{background:#1e293b;border-color:#334155;color:#f1f5f9}.dark .expand-container:hover,[data-theme=dark] .expand-container:hover{border-color:#60a5fa}.dark .expand-header,[data-theme=dark] .expand-header{background:#334155;color:#f1f5f9}.dark .expand-header:hover,[data-theme=dark] .expand-header:hover{background:#475569;color:#60a5fa}.dark .expand-content,[data-theme=dark] .expand-content{background:#1e293b;border-color:#334155}.dark .expand-chevron,[data-theme=dark] .expand-chevron{color:#94a3b8}.dark .expand-container[open] .expand-chevron,[data-theme=dark] .expand-container[open] .expand-chevron{color:#60a5fa}@media(max-width:768px){.expand-container{margin:1rem -.5rem;border-radius:0;border-left:none;border-right:none}.expand-header{padding:14px 16px;font-size:.9rem}.expand-content{padding:20px 16px}}@media(max-width:768px){.post-title,.post-header .post-title,.entry-header .post-title,h1.post-title{font-size:1rem !important;line-height:1 !important;margin:1rem 0 !important}.post-description,.post-summary,.entry-summary{font-size:1rem !important;line-height:2 !important;margin:.8rem 0 !important}.post-meta,.entry-meta,.post-footer{font-size:.8rem !important;line-height:1 !important;margin:.5rem 0 !important}.post-content h1,.entry-content h1{font-size:2rem !important;line-height:1 !important;margin:2rem 0 1rem !important}.post-content h2,.entry-content h2{font-size:1rem !important;line-height:1 !important;margin:1rem 0 .8rem !important}.post-content h3,.entry-content h3{font-size:1rem !important;line-height:1 !important;margin:1rem 0 .5rem !important}.post-content h4,.entry-content h4{font-size:1rem !important;line-height:1 !important;margin:.8rem 0 .5rem !important}.post-content p,.entry-content p{font-size:1rem !important;line-height:2 !important;margin:.8rem 0 !important}.post-content ul,.post-content ol,.entry-content ul,.entry-content ol{font-size:1rem !important;line-height:2 !important;margin:.8rem 0 !important;padding-left:2rem !important}.post-content li,.entry-content li{margin:.3rem 0 !important}}@media(max-width:480px){.post-title,.post-header .post-title,.entry-header .post-title,h1.post-title{font-size:1rem !important;line-height:1 !important;margin:.8rem 0 !important}.post-description,.post-summary,.entry-summary{font-size:.9rem !important;line-height:1 !important;margin:.5rem 0 !important}.post-meta,.entry-meta,.post-footer{font-size:.8rem !important;line-height:1 !important;margin:.3rem 0 !important}.post-content h1,.entry-content h1{font-size:1rem !important;line-height:1 !important;margin:1rem 0 .8rem !important}.post-content h2,.entry-content h2{font-size:1rem !important;line-height:1 !important;margin:1rem 0 .5rem !important}.post-content h3,.entry-content h3{font-size:1rem !important;line-height:1 !important;margin:.8rem 0 .5rem !important}.post-content h4,.entry-content h4{font-size:1rem !important;line-height:1 !important;margin:.5rem 0 .3rem !important}.post-content p,.entry-content p{font-size:.9rem !important;line-height:2 !important;margin:.5rem 0 !important}.post-content ul,.post-content ol,.entry-content ul,.entry-content ol{font-size:.9rem !important;line-height:2 !important;margin:.5rem 0 !important;padding-left:1rem !important}}@media(max-width:768px){.toc,.table-of-contents,#TableOfContents{font-size:.9rem !important;line-height:1 !important;margin:1rem 0 !important;padding:1rem !important;background:var(--code-bg,#f8f9fa) !important;border-radius:8px !important;border:1px solid var(--border,#e2e8f0) !important}.toc ul,.table-of-contents ul,#TableOfContents ul{font-size:.9rem !important;line-height:1 !important;margin:.3rem 0 !important;padding-left:1rem !important}.toc a,.table-of-contents a,#TableOfContents a{font-size:.9rem !important;text-decoration:none !important;color:var(--primary,#3b82f6) !important}}@media(max-width:480px){.toc,.table-of-contents,#TableOfContents{font-size:.8rem !important;line-height:1 !important;margin:.8rem 0 !important;padding:.8rem !important}.toc ul,.table-of-contents ul,#TableOfContents ul{font-size:.8rem !important;line-height:1 !important;padding-left:.8rem !important}.toc a,.table-of-contents a,#TableOfContents a{font-size:.8rem !important}}:root{--h1-desktop:2.25rem;--h2-desktop:2rem;--h3-desktop:1.5rem;--h1-tablet:2rem;--h2-tablet:1.75rem;--h3-tablet:1.375rem;--h1-mobile:1.5rem;--h2-mobile:1.375rem;--h3-mobile:1.25rem;--h1-small:1.25rem;--h2-small:1.125rem;--h3-small:1rem}.post-title,.assessment-intro h2,h1{font-size:var(--h1-desktop);line-height:1;letter-spacing:-.02em;max-width:32ch;text-wrap:balance}.section-header,.level-header,h2{font-size:var(--h2-desktop);line-height:1;letter-spacing:-.01em}.skills-group h4,h3{font-size:var(--h3-desktop);line-height:1}@media screen and (max-width:1199px) and (min-width:768px){.post-title,.assessment-intro h2,h1{font-size:var(--h1-tablet)}.section-header,.level-header,h2{font-size:var(--h2-tablet)}.skills-group h4,h3{font-size:var(--h3-tablet)}}@media screen and (max-width:767px) and (min-width:481px){.post-title,.assessment-intro h2,h1{font-size:var(--h1-mobile);line-height:1;margin-bottom:.8rem}.section-header,.level-header,h2{font-size:var(--h2-mobile)}.skills-group h4,h3{font-size:var(--h3-mobile)}}@media screen and (max-width:480px){.post-title,.assessment-intro h2,h1{font-size:var(--h1-small);line-height:1;word-break:break-word;hyphens:auto}.section-header,.level-header,h2{font-size:var(--h2-small);padding:.8rem 1rem}.skills-group h4,h3{font-size:var(--h3-small)}}.post-title,.assessment-intro h2,h1,h2,h3,h4{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}.mobile-title{display:none}@media screen and (max-width:767px){.desktop-title{display:none}.mobile-title{display:block}}:root{--bg-primary:#ffffff;--bg-secondary:#f8fafc;--bg-tertiary:#f1f5f9;--text-primary:#1a202c;--text-secondary:#4a5568;--text-muted:#718096;--border-primary:#e2e8f0;--border-secondary:#cbd5e0;--accent-primary:#3b82f6;--accent-secondary:#10b981;--accent-warning:#f59e0b;--accent-error:#ef4444;--code-bg:#f8fafc;--code-border:#e2e8f0;--code-text:#2d3748;--inline-code-bg:#f1f5f9;--inline-code-text:#1e293b;--inline-code-border:#cbd5e0}[data-theme=dark],.dark{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--text-primary:#f1f5f9;--text-secondary:#cbd5e0;--text-muted:#94a3b8;--border-primary:#334155;--border-secondary:#475569;--accent-primary:#60a5fa;--accent-secondary:#34d399;--accent-warning:#fbbf24;--accent-error:#f87171;--code-bg:#0d1117;--code-border:#30363d;--code-text:#f0f6fc;--inline-code-bg:#161b22;--inline-code-text:#f0f6fc;--inline-code-border:#30363d}.highlight{background:var(--code-bg) !important;border:1px solid var(--code-border) !important;border-radius:12px !important;margin:2rem 0 !important;overflow:hidden !important;position:relative !important;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,6%) !important}[data-theme=dark] .highlight,.dark .highlight{box-shadow:0 4px 6px -1px rgba(0,0,0,.3),0 2px 4px -1px rgba(0,0,0,.2) !important}pre{background:var(--code-bg) !important;color:var(--code-text) !important;border:none !important;border-radius:0 !important;padding:2rem !important;overflow-x:auto !important;margin:0 !important;line-height:2 !important;font-size:.9rem !important;font-family:jetbrains mono,sf mono,Monaco,cascadia code,roboto mono,Consolas,courier new,monospace !important;font-weight:400 !important}pre code{background:0 0 !important;color:var(--code-text) !important;border:none !important;padding:0 !important;font-size:inherit !important;font-family:inherit !important;white-space:pre !important;word-break:normal !important;word-wrap:normal !important}code:not(pre code){background:var(--inline-code-bg) !important;color:var(--inline-code-text) !important;border:1px solid var(--inline-code-border) !important;border-radius:6px !important;padding:3px 8px !important;font-size:.9rem !important;font-weight:600 !important;font-family:jetbrains mono,sf mono,Monaco,cascadia code,roboto mono,Consolas,courier new,monospace !important;word-break:break-word !important;box-shadow:0 1px 2px rgba(0,0,0,5%) !important}[data-theme=dark] code:not(pre code),.dark code:not(pre code){box-shadow:0 1px 2px rgba(0,0,0,.3) !important}[data-theme=dark] .highlight .c,[data-theme=dark] .highlight .c1,[data-theme=dark] .highlight .cm,.dark .highlight .c,.dark .highlight .c1,.dark .highlight .cm{color:#8b949e !important;font-style:italic !important}[data-theme=dark] .highlight .s,[data-theme=dark] .highlight .s1,[data-theme=dark] .highlight .s2,[data-theme=dark] .highlight .se,.dark .highlight .s,.dark .highlight .s1,.dark .highlight .s2,.dark .highlight .se{color:#a5d6ff !important;font-weight:500 !important}[data-theme=dark] .highlight .k,[data-theme=dark] .highlight .kd,[data-theme=dark] .highlight .kn,[data-theme=dark] .highlight .kt,.dark .highlight .k,.dark .highlight .kd,.dark .highlight .kn,.dark .highlight .kt{color:#ff7b72 !important;font-weight:600 !important}[data-theme=dark] .highlight .m,[data-theme=dark] .highlight .mi,[data-theme=dark] .highlight .mf,.dark .highlight .m,.dark .highlight .mi,.dark .highlight .mf{color:#79c0ff !important;font-weight:500 !important}[data-theme=dark] .highlight .n,[data-theme=dark] .highlight .nv,[data-theme=dark] .highlight .nb,.dark .highlight .n,.dark .highlight .nv,.dark .highlight .nb{color:#f0f6fc !important}[data-theme=dark] .highlight .nf,.dark .highlight .nf{color:#d2a8ff !important;font-weight:500 !important}[data-theme=dark] .highlight .o,[data-theme=dark] .highlight .ow,.dark .highlight .o,.dark .highlight .ow{color:#ff7b72 !important}[data-theme=dark] .highlight .p,.dark .highlight .p{color:#f0f6fc !important}.highlight{position:relative}.highlight .copy-code{position:absolute !important;top:12px !important;right:12px !important;background:rgba(255,255,255,.9) !important;color:#374151 !important;border:1px solid rgba(0,0,0,.1) !important;border-radius:8px !important;padding:6px 12px !important;font-size:.8rem !important;font-weight:600 !important;cursor:pointer !important;opacity:0 !important;transition:all .2s cubic-bezier(.4,0,.2,1) !important;z-index:10 !important;backdrop-filter:blur(8px) !important;user-select:none !important}.highlight:hover .copy-code{opacity:1 !important}.highlight .copy-code:hover{background:#fff !important;transform:translateY(-1px) !important;box-shadow:0 4px 8px rgba(0,0,0,.2) !important}[data-theme=dark] .highlight .copy-code,.dark .highlight .copy-code{background:rgba(13,17,23,.9) !important;color:#f0f6fc !important;border:1px solid rgba(48,54,61,.8) !important}[data-theme=dark] .highlight .copy-code:hover,.dark .highlight .copy-code:hover{background:#0d1117 !important;box-shadow:0 4px 8px rgba(0,0,0,.4) !important}.highlight[data-lang]::before{content:attr(data-lang) !important;display:block !important;background:var(--bg-tertiary) !important;color:var(--text-secondary) !important;padding:8px 16px !important;font-size:.8rem !important;font-weight:700 !important;text-transform:uppercase !important;letter-spacing:.05em !important;border-bottom:1px solid var(--border-primary) !important;font-family:-apple-system,BlinkMacSystemFont,segoe ui,Roboto,sans-serif !important}.language-bash .highlight,.language-shell .highlight,.language-cmd .highlight,.language-terminal .highlight{background:#1a1a1a !important;border:1px solid #404040 !important}.language-bash pre,.language-shell pre,.language-cmd pre,.language-terminal pre{background:#1a1a1a !important;color:#fff !important}.language-bash pre code,.language-shell pre code,.language-cmd pre code,.language-terminal pre code{color:#fff !important}@media screen and (max-width:768px){.highlight{margin:1rem -.5rem !important;border-radius:8px !important;border-left:none !important;border-right:none !important}pre{font-size:.8rem !important;padding:1rem !important;line-height:2 !important;overflow-x:auto !important;-webkit-overflow-scrolling:touch !important}code:not(pre code){font-size:.8rem !important;padding:2px 6px !important;font-weight:700 !important}.highlight .copy-code{top:8px !important;right:8px !important;padding:4px 8px !important;font-size:.7rem !important}}@media screen and (max-width:480px){pre{font-size:.8rem !important;padding:.8rem !important}code:not(pre code){font-size:.8rem !important;font-weight:800 !important}}pre::-webkit-scrollbar{height:8px !important}pre::-webkit-scrollbar-track{background:rgba(0,0,0,.1) !important;border-radius:4px !important}pre::-webkit-scrollbar-thumb{background:var(--border-secondary) !important;border-radius:4px !important}pre::-webkit-scrollbar-thumb:hover{background:var(--text-muted) !important}[data-theme=dark] pre::-webkit-scrollbar-track,.dark pre::-webkit-scrollbar-track{background:rgba(255,255,255,.1) !important}pre code::selection{background:rgba(59,130,246,.3) !important;color:inherit !important}pre code::-moz-selection{background:rgba(59,130,246,.3) !important;color:inherit !important}[data-theme=dark] pre code::selection,.dark pre code::selection{background:rgba(96,165,250,.4) !important}[data-theme=dark] pre code::-moz-selection,.dark pre code::-moz-selection{background:rgba(96,165,250,.4) !important}pre,pre code,code{-webkit-font-smoothing:antialiased !important;-moz-osx-font-smoothing:grayscale !important;text-rendering:optimizeLegibility !important}.diagram-wrapper{margin:2rem 0;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--theme);box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,6%);transition:all .3s ease}.diagram-wrapper:hover{box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,5%)}.diagram-controls{display:flex;justify-content:center;gap:.5rem;padding:1rem;background:var(--code-bg);border-bottom:1px solid var(--border);flex-wrap:wrap}.diagram-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--primary);color:var(--primary-text,white);border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.diagram-btn:hover{background:var(--primary-hover,#3b82f6);transform:translateY(-1px);box-shadow:0 4px 8px rgba(0,0,0,.2)}.diagram-btn:active{transform:translateY(0);box-shadow:0 2px 4px rgba(0,0,0,.1)}.diagram-btn:focus{outline:2px solid var(--primary);outline-offset:2px}.diagram-container-inner{position:relative;background:var(--theme);min-height:400px}.diagram-svg{width:100%;height:500px;display:block;cursor:grab;background:0 0}.diagram-svg:active{cursor:grabbing}.node{cursor:pointer;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));transition:all .3s ease}.node:hover{filter:drop-shadow(0 4px 8px rgba(0,0,0,.2));transform:scale(1)}.node rect{transition:all .3s ease}.node text{font-family:var(--font-mono,'Fira Code','Monaco','Cascadia Code',monospace);font-size:11px;font-weight:600;fill:#fff;text-anchor:middle;dominant-baseline:middle;pointer-events:none;user-select:none}.node.gateway rect{fill:#667eea;stroke:#5a67d8;stroke-width:2}.node.service rect{fill:#48bb78;stroke:#38a169;stroke-width:2}.node.database rect{fill:#ed8936;stroke:#dd6b20;stroke-width:2}.node.cache rect{fill:#38b2ac;stroke:#319795;stroke-width:2}.node.queue rect{fill:#9f7aea;stroke:#805ad5;stroke-width:2}.node.external rect{fill:#e53e3e;stroke:#c53030;stroke-width:2}.node.frontend rect{fill:#4299e1;stroke:#3182ce;stroke-width:2}.node.backend rect{fill:#48bb78;stroke:#38a169;stroke-width:2}.node.network rect{fill:#805ad5;stroke:#6b46c1;stroke-width:2}.node.server rect{fill:#38a169;stroke:#2f855a;stroke-width:2}.link{fill:none;stroke:var(--tertiary,#a0aec0);stroke-width:2;opacity:.8;transition:all .3s ease}.link:hover{stroke:var(--primary,#4299e1);stroke-width:3;opacity:1}.link.critical{stroke:#e53e3e;stroke-width:3;stroke-dasharray:5,5;animation:dash 1s linear infinite}@keyframes dash{to{stroke-dashoffset:-10}}.link.normal{stroke:var(--tertiary,#a0aec0);stroke-width:2}.diagram-info{position:absolute;top:1rem;right:1rem;background:var(--theme);border:1px solid var(--border);border-radius:8px;padding:1rem;max-width:280px;box-shadow:0 4px 6px -1px rgba(0,0,0,.1);z-index:10;animation:fadeIn .3s ease}.diagram-info h4{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:var(--primary)}.diagram-info p{margin:0;font-size:.9rem;line-height:1;color:var(--content)}@keyframes fadeIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.zoom-indicator{position:absolute;bottom:1rem;left:1rem;background:rgba(0,0,0,.8);color:#fff;padding:.5rem .8rem;border-radius:6px;font-family:var(--font-mono,monospace);font-size:.8rem;font-weight:500;z-index:10;pointer-events:none;user-select:none}.diagram-shortcode-wrapper{margin:2rem 0;border-radius:8px;overflow:hidden}.diagram-header{text-align:center;margin-bottom:1rem}.diagram-title{font-size:2rem;font-weight:700;margin:0 0 .5rem;color:var(--primary)}.diagram-description{font-size:1rem;color:var(--tertiary);margin:0;line-height:2}.diagram-noscript{padding:2rem;text-align:center;background:var(--code-bg);border:1px solid var(--border);border-radius:8px;color:var(--content)}.diagram-legend{margin-top:1rem;padding:1rem;background:var(--code-bg);border-radius:8px;border:1px solid var(--border)}.diagram-legend h4{margin:0 0 .8rem;font-size:1rem;color:var(--primary)}.legend-items{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--content)}.legend-color{width:16px;height:16px;border-radius:3px;border:1px solid var(--border);display:inline-block}.diagram-help{margin-top:1rem;border:1px solid var(--border);border-radius:8px;overflow:hidden}.diagram-help summary{padding:.8rem 1rem;background:var(--code-bg);cursor:pointer;font-weight:500;color:var(--primary);user-select:none}.diagram-help summary:hover{background:var(--tertiary)}.diagram-help-content{padding:1rem;background:var(--theme)}.diagram-help-content ul{margin:0;padding-left:2rem}.diagram-help-content li{margin-bottom:.5rem;line-height:1}.diagram-help-content strong{color:var(--primary)}.diagram-loading{display:flex;align-items:center;justify-content:center;height:400px;color:var(--tertiary);font-size:1rem}.diagram-loading::after{content:'';width:20px;height:20px;border:2px solid var(--tertiary);border-top:2px solid var(--primary);border-radius:50%;animation:spin 1s linear infinite;margin-left:.5rem}@keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}[data-theme=dark] .diagram-wrapper,.dark .diagram-wrapper{border-color:var(--border);background:var(--theme)}[data-theme=dark] .diagram-controls,.dark .diagram-controls{background:var(--code-bg);border-color:var(--border)}[data-theme=dark] .diagram-svg,.dark .diagram-svg{background:0 0}[data-theme=dark] .diagram-info,.dark .diagram-info{background:var(--theme);border-color:var(--border)}[data-theme=dark] .link,.dark .link{stroke:#718096}[data-theme=dark] .link:hover,.dark .link:hover{stroke:#63b3ed}[data-theme=dark] .diagram-legend,[data-theme=dark] .diagram-help summary,[data-theme=dark] .diagram-noscript,.dark .diagram-legend,.dark .diagram-help summary,.dark .diagram-noscript{background:var(--code-bg);border-color:var(--border)}[data-theme=dark] .diagram-help-content,.dark .diagram-help-content{background:var(--theme)}@media(max-width:768px){.diagram-wrapper{margin:1rem -1rem;border-radius:0;border-left:none;border-right:none}.diagram-controls{padding:.8rem;gap:.3rem}.diagram-btn{padding:.4rem .8rem;font-size:.8rem}.diagram-svg{height:350px}.diagram-info{position:relative;top:auto;right:auto;margin:1rem;max-width:none}.zoom-indicator{bottom:.5rem;left:.5rem;font-size:.7rem;padding:.4rem .5rem}.legend-items{gap:.8rem}.legend-item{font-size:.8rem}.diagram-title{font-size:1rem}}@media(max-width:480px){.diagram-controls{flex-direction:column;align-items:stretch}.diagram-btn{justify-content:center;width:100%}.diagram-svg{height:300px}.node text{font-size:10px}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}.node.highlighted{animation:pulse 1s ease-in-out infinite}.link.highlighted{animation:pulse 1s ease-in-out infinite}.diagram-wrapper{animation:slideUp .5s ease-out}@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.diagram-btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.node:focus{outline:2px solid var(--primary);outline-offset:2px}@media(prefers-reduced-motion:reduce){.diagram-wrapper,.node,.link,.diagram-btn{animation:none;transition:none}.link.critical{animation:none}}@media print{.diagram-controls{display:none}.diagram-info{position:static;margin:1rem 0;box-shadow:none;border:1px solid #000}.zoom-indicator{display:none}.diagram-wrapper{break-inside:avoid;box-shadow:none;border:1px solid #000}}.diagram-hidden{display:none !important}.diagram-fade{opacity:.5;transition:opacity .3s ease}.diagram-highlight{filter:drop-shadow(0 0 10px var(--primary)) !important}.diagram-blur{filter:blur(2px);transition:filter .3s ease}.MathJax{font-size:1em !important;line-height:1 !important}.MathJax_Display{margin:20px 0 !important;padding:16px 20px !important;background:var(--code-bg,#f8f9fa) !important;border-radius:8px !important;border-left:4px solid var(--theme,#007bff) !important;box-shadow:0 2px 10px rgba(0,0,0,5%) !important;overflow-x:auto !important}[data-theme=dark] .MathJax_Display,.dark .MathJax_Display{background:rgba(255,255,255,5%) !important;border-left-color:var(--theme,#6366f1) !important;box-shadow:0 2px 10px rgba(0,0,0,.2) !important}.MathJax_Preview{color:var(--primary,#1f2937) !important;font-style:italic !important}[data-theme=dark] .MathJax_Preview,.dark .MathJax_Preview{color:var(--primary,#f9fafb) !important}mjx-container[jax=CHTML]{line-height:1 !important;display:inline-block !important}mjx-container[jax=CHTML][display=true]{display:block !important;text-align:center !important;margin:1em 0 !important}mjx-math{font-variant:normal !important}.MathJax_Error{color:#dc2626 !important;background:#fef2f2 !important;padding:4px 8px !important;border-radius:4px !important;border:1px solid #fca5a5 !important;font-family:monospace !important}[data-theme=dark] .MathJax_Error,.dark .MathJax_Error{color:#fca5a5 !important;background:rgba(220,38,38,.1) !important;border-color:#dc2626 !important}@media(max-width:768px){.MathJax{font-size:1em !important}.MathJax_Display{margin:15px -10px !important;padding:12px 15px !important;border-radius:0 !important;border-left:4px solid var(--theme,#007bff) !important;border-right:none !important}mjx-container[jax=CHTML][display=true]{overflow-x:auto !important;overflow-y:hidden !important;max-width:100% !important;padding-bottom:5px !important}}@media(max-width:480px){.MathJax{font-size:.9em !important}.MathJax_Display{padding:10px 12px !important;margin:12px -15px !important}}.MathJax_Display{opacity:0;animation:mathFadeIn .3s ease-in-out forwards}@keyframes mathFadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.MathJax_Processing{position:relative !important}.MathJax_Processing::after{content:"Загружается..." !important;position:absolute !important;top:0 !important;left:0 !important;background:var(--theme,#007bff) !important;color:#fff !important;padding:2px 6px !important;border-radius:3px !important;font-size:.7em !important;font-weight:600 !important;z-index:1000 !important}@media print{.MathJax_Display{background:0 0 !important;box-shadow:none !important;border:1px solid #000 !important;border-radius:0 !important;page-break-inside:avoid !important}.MathJax{font-size:12pt !important}}@media(prefers-contrast:high){.MathJax_Display{border-width:3px !important;box-shadow:none !important}.MathJax{font-weight:600 !important}}@media(prefers-reduced-motion:reduce){.MathJax_Display{animation:none !important}@keyframes mathFadeIn{from,to{opacity:1;transform:none}}}