@charset "UTF-8";.wrapper:after{content:"";display:table;clear:both}*,*:before,*:after{box-sizing:border-box;-webkit-transition:background-color 75ms ease-in,border-color 75ms ease-in;-moz-transition:background-color 75ms ease-in,border-color 75ms ease-in;-ms-transition:background-color 75ms ease-in,border-color 75ms ease-in;-o-transition:background-color 75ms ease-in,border-color 75ms ease-in;transition:background-color 75ms ease-in,border-color 75ms ease-in}.notransition{-webkit-transition:none;-moz-transition:none;-ms-transition:none;-o-transition:none;transition:none}html{overflow-x:hidden;width:100%}body,h1,h2,h3,h4,h5,h6,p,blockquote,pre,hr,dl,dd,ol,ul,figure{margin:0;padding:0}body{min-height:100vh;overflow-x:hidden;position:relative;display:flex;flex-direction:column;color:#434648;background-color:#f3f4f6;font:400 16px/1.85 Nunito Sans,sans-serif;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-webkit-font-feature-settings:"kern" 1;-moz-font-feature-settings:"kern" 1;-o-font-feature-settings:"kern" 1;font-feature-settings:"kern" 1;font-kerning:normal;box-sizing:border-box}body:before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background-image:radial-gradient(circle,rgba(200,200,200,.15) 1px,transparent 1px),radial-gradient(circle,rgba(200,200,200,.1) 1px,transparent 1px);background-size:50px 50px,80px 80px;background-position:0 0,25px 25px;opacity:.4}body:after{display:none}h1,h2,h3,h4,h5,h6,p,blockquote,pre,ul,ol,dl,figure{margin-top:10px;margin-bottom:.8rem}strong,b{font-weight:700;color:#0d122b}hr{border-bottom:0;border-style:solid;border-color:#ececec}img{max-width:100%;height:auto;vertical-align:middle;-webkit-user-drag:none;margin:0 auto;text-align:center}figure{position:relative}figure>img{display:block;position:relative}figcaption{font-size:13px;text-align:center}ul li{display:list-item;text-align:-webkit-match-parent}ol li{position:relative}ul,ol{margin-top:0;margin-left:30px}li{padding-bottom:1px;padding-top:1px}li:before{color:#0d122b}li>ul,li>ol{margin-bottom:2px;margin-top:0}h1,h2,h3,h4,h5,h6{color:#0d122b;font-family:Lora,serif;font-weight:700}h1+ul,h1+ol,h2+ul,h2+ol,h3+ul,h3+ol,h4+ul,h4+ol,h5+ul,h5+ol,h6+ul,h6+ol{margin-top:10px}@media screen and (max-width:768px){h1,h2,h3,h4,h5,h6{scroll-margin-top:65px}}h1>a,h2>a,h3>a,h4>a,h5>a,h6>a{text-decoration:none;border:none}h1>a:hover,h2>a:hover,h3>a:hover,h4>a:hover,h5>a:hover,h6>a:hover{text-decoration:none;border:none}a{color:inherit;text-decoration-color:#d2c7c7}a:hover{color:#003fff}a:focus{outline:3px solid rgba(0,54,199,.6);outline-offset:2px}del,em{color:inherit}blockquote{color:#525b66;font-family:Lora,serif;opacity:.9;border-left:5px solid #c4c8cc;padding:0 0 0 1rem;margin-left:.3rem;margin-right:.3rem;font-size:1em}blockquote>:last-child{margin-bottom:0;margin-top:0}.wrapper{max-width:-webkit-calc(864px - (30px * 2));max-width:804px;position:relative;margin-right:auto;margin-left:auto;padding-right:30px;padding-left:30px}@media screen and (max-width:768px){.wrapper{max-width:-webkit-calc(864px - (30px));max-width:834px;padding-right:20px;padding-left:20px}.wrapper.blurry{animation:.2s ease-in forwards blur;-webkit-animation:.2s ease-in forwards blur}}u{text-decoration-color:#d2c7c7}small{font-size:14px}sup{border-radius:10%;top:-3px;left:2px;font-size:small;position:relative;margin-right:2px}.overflow-table{overflow-x:auto}table{width:100%;margin-top:15px;border-collapse:collapse;font-size:14px}table thead{font-weight:700;color:#0d122b;border-bottom:1px solid #ececec}table th,table td,table tr{border:1px solid #ececec;padding:2px 7px}mark,::selection{background:#fffba0;color:#0d122b}.gist table,.gist table tr,.gist table td{border:0}.navbar{width:100%;max-width:80rem;margin:0 auto;padding:1rem;display:flex;justify-content:space-between;align-items:center;position:relative;z-index:100;border-bottom:none;box-sizing:border-box}@media(min-width:769px){.navbar{padding:2rem 1.5rem}}.navbar .mobile-menu-toggle{display:flex;align-items:center;justify-content:center;padding:.5rem;border-radius:.5rem;background:#e5e7eb;border:none;cursor:pointer;transition:all .3s;z-index:1001;position:relative}@media(min-width:769px){.navbar .mobile-menu-toggle{display:none}}.navbar .mobile-menu-toggle:hover{box-shadow:0 0 0 2px #10b981}.navbar .mobile-menu-toggle .material-icons{font-size:1.25rem;color:#374151}.navbar .logo{float:none;margin:0;color:#4b5563;transition:color .3s;padding:.5rem;border-radius:9999px;position:relative;z-index:1001}.navbar .logo:hover{color:#10b981;background:#0000000d}.navbar .logo:hover>svg{opacity:1}.navbar .logo .material-icons{font-size:1.5rem;vertical-align:middle}.navbar .menu{float:none;position:relative;z-index:1001}@media(max-width:768px){.navbar .menu{position:fixed;inset:0;width:100vw;height:100vh;background:#0f172afa;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .3s ease-in-out,visibility .3s ease-in-out;z-index:1000}.navbar .menu.menu--open{opacity:1;visibility:visible;pointer-events:auto}}.navbar .menu .trigger{display:flex;align-items:center;gap:1.5rem;float:none}@media(max-width:768px){.navbar .menu .trigger{flex-direction:column;gap:2rem}}@media(min-width:769px){.navbar .menu .trigger{gap:2rem}}.navbar .menu .trigger-container{display:flex;align-items:center;gap:1.5rem;margin:0;list-style:none}@media(max-width:768px){.navbar .menu .trigger-container{flex-direction:column;gap:2rem}}@media(min-width:769px){.navbar .menu .trigger-container{gap:2rem}}.navbar .menu .trigger-container li{display:inline-block;margin:0}.navbar .menu .menu-link{color:#4b5563;font-size:.875rem;font-weight:500;text-decoration:none;transition:color .3s;opacity:1;padding:0}@media(max-width:768px){.navbar .menu .menu-link{font-size:1.5rem;padding:.75rem 1.5rem;color:#e5e7eb;font-weight:600}}.navbar .menu .menu-link:hover{color:#10b981}.navbar .menu .menu-link.active{color:#10b981;font-weight:600}.navbar .menu .menu-separator{display:none}.navbar .menu #theme-btn{display:flex;align-items:center;justify-content:center;padding:.5rem;border-radius:.5rem;background:#e5e7eb;border:none;cursor:pointer;transition:all .3s;position:relative;z-index:1002}@media(max-width:768px){.navbar .menu #theme-btn{padding:.75rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2)}}.navbar .menu #theme-btn:hover{box-shadow:0 0 0 2px #10b981}.navbar .menu #theme-btn .material-icons{font-size:.875rem}@media(max-width:768px){.navbar .menu #theme-btn .material-icons{font-size:1.25rem}}.navbar .menu #theme-btn .mode-sunny{display:block;color:#d97706}.navbar .menu #theme-btn .mode-moon{display:none;color:#9ca3af}.footer{border-top:1px solid #10b981;margin-top:auto;padding:3rem 0;position:relative;z-index:10}.footer .footer-container{max-width:56rem;margin:0 auto;padding:0 1.5rem;display:flex;flex-direction:column;align-items:center}.footer .footer_social-icons{display:flex;gap:1.5rem;margin-bottom:1.5rem}.footer .footer_social-icons a{color:#9ca3af;transition:all .3s;text-decoration:none}.footer .footer_social-icons a:hover{color:#10b981;transform:translateY(-2px)}.footer .footer_social-icons a svg{width:1.25rem;height:1.25rem}.footer .footer_copyright{font-size:.75rem;color:#374151;text-align:center;opacity:1;margin:0;padding:0}.footer .footer_copyright br{display:none}@media(min-width:769px){.footer .footer_copyright br{display:block}}.footer .footer_copyright .heart{color:#c82c2c}main{flex-grow:1;width:100%;max-width:67.2rem;margin:0 auto;padding:1.5rem 1rem 4rem;position:relative;z-index:10}@media(min-width:769px){main{padding:2rem 1.5rem 5rem}}@media(min-width:1024px){main{padding:3rem 1.5rem 5rem}}.wrapper{max-width:none;padding:0}.author{margin-top:6.3rem;margin-bottom:7.2rem;text-align:center}@media screen and (max-width:768px){.author{margin-bottom:3em}}.author .author-avatar{width:70px;height:70px;border-radius:100%;user-select:none;-ms-user-select:none;-webkit-user-select:none;-webkit-animation:.5s ease-in forwards fadein;animation:.5s ease-in forwards fadein;opacity:1;object-fit:cover}.author .author-name{font-size:1.7em;margin-bottom:2px}.author .author-bio{margin:0 auto;opacity:.9;max-width:393px;line-height:1.688}.posts-item-note{padding-bottom:.3rem;font-weight:500;color:#0d122b}.post-item{display:flex;padding-top:5px;padding-bottom:6px;justify-content:space-between;flex-direction:row;align-items:center}.post-item:not(:first-child){border-top:1px solid #ececec}.post-item .post-item-date{min-width:96px;color:#0d122b}@media screen and (max-width:768px){.post-item .post-item-date{font-size:16px}}.post-item .post-item-title{margin:0;border:0;padding:0;font-size:16px;font-weight:400;letter-spacing:.1px}@media screen and (max-width:768px){.post-item .post-item-title{max-width:15rem}}.post-item .post-item-title a{color:#434648;transition:all .15s ease-in 0s}.post-item .post-item-title a:hover,.post-item .post-item-title afocus{color:#0d122b}.footer{margin-top:8em;margin-bottom:2em;text-align:center}@media screen and (max-width:768px){.footer{margin-top:3em}}.footer span.footer_item{opacity:.8;font-weight:700;font-size:14px}.footer a.footer_item{opacity:.8;text-decoration:none}.footer a.footer_item:not(:last-child){margin-right:10px}.footer a.footer_item:not(:last-child):hover{opacity:1}.footer_copyright{font-size:13px;display:block;color:#6b7886;opacity:.8;margin-top:.7rem;padding:.3rem .95rem}.footer_social-icons a{text-decoration:none;margin-right:.31rem}.footer_social-icons svg{color:#888a90;height:24px;width:24px}.footer_social-icons svg:hover{color:#ddd}.not-found{text-align:center;display:flex;justify-content:center;flex-direction:column;height:75vh}.not-found .title{font-size:5em;font-weight:700;line-height:1.1;color:#0d122b;text-shadow:1px 0px 0px #003fff}.not-found .phrase{color:#434648}.not-found .solution{color:#003fff;letter-spacing:.5px}.not-found .solution:hover{color:#0036c7}.search-article{position:relative;margin-bottom:50px}.search-article label[for=search-input]{position:relative;top:10px;left:11px}.search-article input[type=search]{top:0;left:0;border:0;width:100%;height:40px;outline:none;position:absolute;border-radius:5px;padding:10px 10px 10px 35px;color:#434648;-webkit-appearance:none;font-size:16px;background-color:#8080801a;border:1px solid rgba(128,128,128,.1)}.search-article input[type=search]::-webkit-input-placeholder{color:gray}.search-article input[type=search]::-webkit-search-decoration,.search-article input[type=search]::-webkit-search-results-decoration{display:none}#search-results{text-align:center}#search-results li{text-align:left}.archive-tags{height:auto}.archive-tags .tag-item{padding:1px 3px;border-radius:2px;border:1px solid rgba(128,128,128,.1);background-color:#8080801a}sub,sup{font-size:79%;line-height:0;position:relative;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}kbd{font-size:85%;border-radius:3px;color:#333638;background:#d8dbe2;display:inline-block;font-family:Consolas,monaco,monospace;line-height:1;padding:2px 4px;white-space:nowrap}mark{background:#ff0;color:#000;border-radius:3px}@media screen and (max-width:768px){.wrapper.post{padding-left:15px;padding-right:15px}}.header{margin-top:7.8em}.header .header-title{font-size:2em;line-height:1.2;margin-top:10px;margin-bottom:20px}.header .header-title.center{text-align:center}@media screen and (max-width:768px){.header .header-title{font-size:1.9em}}.post-meta{padding-top:3px;line-height:1.3;color:#6b7886}.post-meta time{position:relative;margin-right:1.5em}.post-meta span[itemprop=author]{border-bottom:1px dotted #ececec}.page-content{padding-top:8px}.page-content iframe{text-align:center}.page-content figure img{border-radius:2px}.page-content figure figcaption{margin-top:5px;font-style:italic;font-size:14px}.page-content a{color:#003fff;text-decoration:none}.page-content a[target=_blank]:after{content:" ↗";font-size:14px;line-height:0;position:relative;bottom:5px;vertical-align:baseline}.page-content a:hover{color:#0036c7}.page-content a:focus{color:#003fff}.page-content>p{margin:0;margin-bottom:.8rem;padding-top:2px;padding-bottom:2px}.page-content ul.task-list{list-style:none;margin:0}.page-content ul.task-list li:before{content:""}.page-content ul.task-list li input[type=checkbox]{margin-right:10px}.page-content dl dt{font-weight:700}.page-content h1,.page-content h2,.page-content h3,.page-content h4,.page-content h5,.page-content h6{color:#0d122b;font-weight:700;margin-top:30px;margin-bottom:0;letter-spacing:.03rem}.page-content h1:hover .anchor-head,.page-content h2:hover .anchor-head,.page-content h3:hover .anchor-head,.page-content h4:hover .anchor-head,.page-content h5:hover .anchor-head,.page-content h6:hover .anchor-head{color:#003fff;opacity:1}.page-content h1 .anchor-head,.page-content h2 .anchor-head,.page-content h3 .anchor-head,.page-content h4 .anchor-head,.page-content h5 .anchor-head,.page-content h6 .anchor-head{position:relative;opacity:0;outline:none}.page-content h1 .anchor-head:before,.page-content h2 .anchor-head:before,.page-content h3 .anchor-head:before,.page-content h4 .anchor-head:before,.page-content h5 .anchor-head:before,.page-content h6 .anchor-head:before{content:"#";position:absolute;right:-3px;width:1em;font-weight:700}.page-content h1{font-size:24px}.page-content h2{font-size:22px}.page-content h3,.page-content h4{font-size:20px}.page-content h5{font-size:16px}.page-content h6{font-size:14px}.post-nav{display:flex;position:relative;margin-top:5em;border-top:1px solid #ececec;line-height:1.4}.post-nav .post-nav-item{border-bottom:0;font-weight:700;padding-bottom:10px}.post-nav .post-nav-item .post-title{color:#0d122b}.post-nav .post-nav-item:hover .post-title,.post-nav .post-nav-item:focus .post-title{color:#0036c7;opacity:.9}.post-nav .post-nav-item .nav-arrow{font-weight:400;font-size:14px;color:#6b7886;margin-bottom:3px}.post-nav .post-nav-item{width:50%;padding-top:10px;text-decoration:none;box-sizing:border-box}.post-nav .post-nav-item:nth-child(odd){padding-left:0;padding-right:20px}.post-nav .post-nav-item:nth-child(2n){text-align:right;padding-right:0;padding-left:20px}@media screen and (max-width:768px){.post-nav{display:block;font-size:14px}.post-nav .post-nav-item{display:block;width:100%}.post-nav .post-nav-item:nth-child(2n){border-left:0;padding-left:0;border-top:1px solid #ececec}}.post-updated-at{font-family:Ubuntu mono,"monospace"}code{font-family:Roboto Mono,Consolas,monospace;text-rendering:optimizeLegibility;font-feature-settings:"calt" 1;font-variant-ligatures:normal;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;font-size:inherit}li>code,p>code{white-space:pre-wrap;font-size:.9em;padding:1px 3px;position:relative;top:-1px;color:#333638;background-color:#d8dbe2;border-radius:2px;border:1px solid rgba(128,128,128,.1)}pre{background-color:#eff1f5;border-radius:.3rem;padding:.5rem 1rem;display:block;overflow-x:auto}@media screen and (max-width:768px){pre{margin:0 calc(51% - 51vw)}}pre::-webkit-scrollbar{height:.5rem}pre::-webkit-scrollbar-track{background:#606071;border-radius:.1rem}pre::-webkit-scrollbar-thumb{background:#999ea2;border-radius:.3rem}pre::-webkit-scrollbar-thumb:hover{background:#424546}pre>code{max-width:50rem;margin-left:auto;margin-right:auto;line-height:1.5;display:block;border:0;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word}.highlight table td{padding:5px}.highlight table pre{margin:0}.highlight,.highlight .w{color:#fbf1c7}.highlight .err{color:#fb4934;font-weight:700}.highlight .c,.highlight .cd,.highlight .cm,.highlight .c1,.highlight .cs{color:#928374;font-style:italic}.highlight .cp{color:#8ec07c}.highlight .nt{color:#fb4934}.highlight .o,.highlight .ow,.highlight .p,.highlight .pi{color:#fbf1c7}.highlight .gi{color:#b8bb26;background-color:#282828}.highlight .gd{color:#fb4934;background-color:#282828}.highlight .gh{color:#b8bb26;font-weight:700}.highlight .k,.highlight .kn,.highlight .kp,.highlight .kr,.highlight .kv{color:#fb4934}.highlight .kc{color:#d3869b}.highlight .kt{color:#fabd2f}.highlight .kd{color:#fe8019}.highlight .s,.highlight .sb,.highlight .sc,.highlight .sd,.highlight .s2,.highlight .sh,.highlight .sx,.highlight .s1,.highlight .si,.highlight .sr{color:#b8bb26;font-style:italic}.highlight .se{color:#fe8019}.highlight .nn,.highlight .nc{color:#8ec07c}.highlight .no{color:#d3869b}.highlight .na{color:#b8bb26}.highlight .m,.highlight .mf,.highlight .mh,.highlight .mi,.highlight .il,.highlight .mo,.highlight .mb,.highlight .mx{color:#d3869b}.highlight .ss{color:#83a598}html.light pre{background-color:#eff1f5}html.dark pre{background-color:#1e1e1e}html.light .astro-code,html.light .astro-code span{color:var(--shiki-light)!important;background-color:var(--shiki-light-bg, transparent)!important;font-style:var(--shiki-light-font-style, inherit)!important;font-weight:var(--shiki-light-font-weight, inherit)!important;text-decoration:var(--shiki-light-text-decoration, none)!important}html.dark .astro-code,html.dark .astro-code span{color:var(--shiki-dark)!important;background-color:var(--shiki-dark-bg, transparent)!important;font-style:var(--shiki-dark-font-style, inherit)!important;font-weight:var(--shiki-dark-font-weight, inherit)!important;text-decoration:var(--shiki-dark-text-decoration, none)!important}details{cursor:pointer}.toc{margin:1.1rem 0 1rem;padding:.5rem 1rem;border-radius:.3rem;background-color:#edecec}.toc ul{padding-top:1rem;margin-left:1rem;padding-left:1rem}.toc ul li{margin-bottom:.5em;line-height:1.4}@keyframes fadein{0%{opacity:.2}to{opacity:1}}@keyframes blur{0%{filter:blur(0px)}to{filter:blur(4px)}}.embed-responsive{height:0;max-width:100%;overflow:hidden;position:relative;padding-bottom:56.25%;margin-top:20px}.embed-responsive iframe,.embed-responsive object,.embed-responsive embed{top:0;left:0;width:100%;height:100%;position:absolute}.main-404{padding:9rem 0;text-align:center}@media(prefers-color-scheme:dark){html:not(.light) body{color:#babdc4;background-color:#131418}html:not(.light) h1,html:not(.light) h2,html:not(.light) h3,html:not(.light) h4,html:not(.light) h5,html:not(.light) h6{color:#c8c8c8}html:not(.light) table thead{color:#c8c8c8;border-color:#1b1d25}html:not(.light) table th,html:not(.light) table td,html:not(.light) table tr{border-color:#1b1d25}html:not(.light) .page-content a{color:#77a8fd}html:not(.light) .page-content a:hover,html:not(.light) .page-content a:active,html:not(.light) .page-content a:focus{color:#5292ff}html:not(.light) .page-content h3{border-color:#1b1d25}html:not(.light) .page-content h1 .anchor-head,html:not(.light) .page-content h2 .anchor-head,html:not(.light) .page-content h3 .anchor-head,html:not(.light) .page-content h4 .anchor-head,html:not(.light) .page-content h5 .anchor-head,html:not(.light) .page-content h6 .anchor-head{color:#77a8fd}html:not(.light) .toc{background-color:#323232}html:not(.light) #totop{color:#babdc4;background-color:#676767b3}html:not(.light) #totop:hover{background-color:#676767}html:not(.light) li>code,html:not(.light) p>code{font-size:.9em;padding:1px 3px;position:relative;top:-1px;color:#c2c4ca;background-color:#2d2d2d;border-radius:2px;border:1px solid rgba(128,128,128,.1)}html:not(.light) kbd{color:#c2c4ca;background-color:#2d2d2d}html:not(.light) hr{border-color:#1b1d25}html:not(.light) .post-meta{color:#767f87}html:not(.light) .post-meta time:after{background-color:#1b1d25}html:not(.light) .post-meta span[itemprop=author]{border-color:#1b1d25}html:not(.light) a{color:inherit;text-decoration-color:#4a4d56}html:not(.light) a:hover{color:#77a8fd}html:not(.light) a:focus{outline-color:#2c76f699}html:not(.light) li:before{color:#c8c8c8}html:not(.light) blockquote{color:#9b9ba3;border-color:#4a4d56}html:not(.light) strong,html:not(.light) b{color:#c8c8c8}html:not(.light) .navbar{border-color:#1b1d25}html:not(.light) .navbar .logo{color:#9ca3af}html:not(.light) .navbar .logo:hover{color:#10b981;background:#ffffff0d}html:not(.light) .navbar .menu .menu-link{color:#9ca3af}html:not(.light) .navbar .menu .menu-link:hover{color:#10b981}html:not(.light) .navbar .menu .menu-link.active{color:#10b981}html:not(.light) .navbar .menu #theme-btn{background:#1f2937}html:not(.light) .navbar .menu #theme-btn:hover{box-shadow:0 0 0 2px #10b981}html:not(.light) .navbar .menu #theme-btn .mode-sunny{display:none}html:not(.light) .navbar .menu #theme-btn .mode-moon{display:block;color:#fbbf24}html:not(.light) .post-item:not(:first-child){border-color:#1b1d25}html:not(.light) .post-item .post-item-date{color:#c8c8c8}html:not(.light) .post-item .post-item-title a{color:#babdc4}html:not(.light) .post-item .post-item-title a:hover,html:not(.light) .post-item .post-item-title afocus{color:#c8c8c8}html:not(.light) .post-nav{border-color:#1b1d25}html:not(.light) .post-nav .post-nav-item{font-weight:700}html:not(.light) .post-nav .post-nav-item .post-title{color:#c8c8c8;opacity:.9}html:not(.light) .post-nav .post-nav-item:hover .post-title,html:not(.light) .post-nav .post-nav-item:focus .post-title{color:#5292ff}html:not(.light) .post-nav .post-nav-item .nav-arrow{color:#767f87}}@media screen and (prefers-color-scheme:dark)and (max-width:768px){html:not(.light) .post-nav .post-nav-item:nth-child(2n){border-color:#1b1d25}}@media(prefers-color-scheme:dark){html:not(.light) .footer span.footer_item{color:#c8c8c8}html:not(.light) .footer a.footer_item:not(:last-child){color:#c8c8c8}html:not(.light) .footer .footer_copyright{color:#767f87;opacity:1}html:not(.light) .footer .footer_copyright .heart{color:#c82c2c}html:not(.light) .not-found .title{color:#c8c8c8;text-shadow:1px 0px 0px #77a8fd}html:not(.light) .not-found .phrase{color:#babdc4}html:not(.light) .not-found .solution{color:#77a8fd}html:not(.light) .not-found .solution:hover{color:#5292ff}html:not(.light) .search-article input[type=search]{color:#babdc4}html:not(.light) .search-article input[type=search]::-webkit-input-placeholder{color:#808080cc}html:not(.light) body{background-color:#020617;color:#d1d5db}html:not(.light) body:before{background-image:radial-gradient(circle,rgba(255,255,255,.08) 1px,transparent 1px),radial-gradient(circle,rgba(255,255,255,.05) 1px,transparent 1px);background-size:60px 60px,100px 100px;background-position:0 0,30px 30px;opacity:.5}html:not(.light) .post .header .header-title{color:#c8c8c8}html:not(.light) .post .header .post-meta{color:#9ca3af}html:not(.light) .post .page-content{color:#d1d5db}html:not(.light) .post .page-content h2,html:not(.light) .post .page-content h3,html:not(.light) .post .page-content h4,html:not(.light) .post .page-content h5,html:not(.light) .post .page-content h6{color:#c8c8c8}html:not(.light) .post .page-content h2{border-color:#1f2937}html:not(.light) .post .page-content blockquote{background:#10b9811a;color:#9ca3af}html:not(.light) .post .page-content a{color:#77a8fd}html:not(.light) .post .page-content a:hover{color:#5292ff}html:not(.light) .author .author-avatar-wrapper:before{background:linear-gradient(135deg,#10b981,#06b6d4)}html:not(.light) .author .author-avatar{border-color:#020617}html:not(.light) .author .author-name{color:#6b7886}html:not(.light) .author .author-name .name-highlight{color:#10b981}html:not(.light) .author .author-bio{color:#ececec}html:not(.light) .author .author-bio .highlight{color:#10b981}html:not(.light) .post-item{background:#0f172acc;border-color:#1f2937;box-shadow:none}html:not(.light) .post-item:hover{background:#1f2937e6;border-color:#10b9814d}html:not(.light) .post-item .post-item-title a{color:#d1d5db}html:not(.light) .posts-item-note{color:#c8c8c8;border-color:#1f2937}html:not(.light) .sidebar-widget{background:#0f172acc;border-color:#1f2937}html:not(.light) .sidebar-widget.daily-inspiration .quote-text{color:#d1d5db}html:not(.light) .sidebar-widget.daily-inspiration .quote-author{color:#10b981}html:not(.light) .sidebar-widget.daily-puzzle .puzzle-image-wrapper{background:#0006}html:not(.light) .sidebar-widget.daily-puzzle .puzzle-description{color:#9ca3af}html:not(.light) .sidebar-widget.daily-puzzle .solve-button{background:#1f2937;color:#d1d5db;border-color:#374151}html:not(.light) .sidebar-widget.daily-puzzle .solve-button:hover{background:#10b981;color:#fff}html:not(.light) .sidebar-widget.daily-puzzle h3 .difficulty-badge{background:#22c55e66;color:#4ade80;border-color:#22c55e99}}html.light body{color:#434648!important;background-color:#f3f4f6!important}html.light body:before{background-image:radial-gradient(circle,rgba(200,200,200,.15) 1px,transparent 1px),radial-gradient(circle,rgba(200,200,200,.1) 1px,transparent 1px)!important;opacity:.4!important}html.dark body{color:#babdc4;background-color:#131418}html.dark h1,html.dark h2,html.dark h3,html.dark h4,html.dark h5,html.dark h6{color:#c8c8c8}html.dark table thead{color:#c8c8c8;border-color:#1b1d25}html.dark table th,html.dark table td,html.dark table tr{border-color:#1b1d25}html.dark .page-content a{color:#77a8fd}html.dark .page-content a:hover,html.dark .page-content a:active,html.dark .page-content a:focus{color:#5292ff}html.dark .page-content h3{border-color:#1b1d25}html.dark .page-content h1 .anchor-head,html.dark .page-content h2 .anchor-head,html.dark .page-content h3 .anchor-head,html.dark .page-content h4 .anchor-head,html.dark .page-content h5 .anchor-head,html.dark .page-content h6 .anchor-head{color:#77a8fd}html.dark .toc{background-color:#323232}html.dark #totop{color:#babdc4;background-color:#676767b3}html.dark #totop:hover{background-color:#676767}html.dark li>code,html.dark p>code{font-size:.9em;padding:1px 3px;position:relative;top:-1px;color:#c2c4ca;background-color:#2d2d2d;border-radius:2px;border:1px solid rgba(128,128,128,.1)}html.dark kbd{color:#c2c4ca;background-color:#2d2d2d}html.dark hr{border-color:#1b1d25}html.dark .post-meta{color:#767f87}html.dark .post-meta time:after{background-color:#1b1d25}html.dark .post-meta span[itemprop=author]{border-color:#1b1d25}html.dark a{color:inherit;text-decoration-color:#4a4d56}html.dark a:hover{color:#77a8fd}html.dark a:focus{outline-color:#2c76f699}html.dark li:before{color:#c8c8c8}html.dark blockquote{color:#9b9ba3;border-color:#4a4d56}html.dark strong,html.dark b{color:#c8c8c8}html.dark .navbar{border-color:#1b1d25}html.dark .navbar .logo{color:#9ca3af}html.dark .navbar .logo:hover{color:#10b981;background:#ffffff0d}html.dark .navbar .menu .menu-link{color:#9ca3af}html.dark .navbar .menu .menu-link:hover,html.dark .navbar .menu .menu-link.active{color:#10b981}html.dark .navbar .menu #theme-btn{background:#1f2937}html.dark .navbar .menu #theme-btn:hover{box-shadow:0 0 0 2px #10b981}html.dark .navbar .menu #theme-btn .mode-sunny{display:none}html.dark .navbar .menu #theme-btn .mode-moon{display:block;color:#fbbf24}html.dark .post-item:not(:first-child){border-color:#1b1d25}html.dark .post-item .post-item-date{color:#c8c8c8}html.dark .post-item .post-item-title a{color:#babdc4}html.dark .post-item .post-item-title a:hover,html.dark .post-item .post-item-title afocus{color:#c8c8c8}html.dark .post-nav{border-color:#1b1d25}html.dark .post-nav .post-nav-item{font-weight:700}html.dark .post-nav .post-nav-item .post-title{color:#c8c8c8;opacity:.9}html.dark .post-nav .post-nav-item:hover .post-title,html.dark .post-nav .post-nav-item:focus .post-title{color:#5292ff}html.dark .post-nav .post-nav-item .nav-arrow{color:#767f87}@media screen and (max-width:768px){html.dark .post-nav .post-nav-item:nth-child(2n){border-color:#1b1d25}}html.dark .footer span.footer_item{color:#c8c8c8}html.dark .footer a.footer_item:not(:last-child){color:#c8c8c8}html.dark .footer .footer_copyright{color:#767f87;opacity:1}html.dark .footer .footer_copyright .heart{color:#c82c2c}html.dark .not-found .title{color:#c8c8c8;text-shadow:1px 0px 0px #77a8fd}html.dark .not-found .phrase{color:#babdc4}html.dark .not-found .solution{color:#77a8fd}html.dark .not-found .solution:hover{color:#5292ff}html.dark .search-article input[type=search]{color:#babdc4}html.dark .search-article input[type=search]::-webkit-input-placeholder{color:#808080cc}html.dark body{background-color:#020617;color:#d1d5db}html.dark body:before{background-image:radial-gradient(circle,rgba(255,255,255,.08) 1px,transparent 1px),radial-gradient(circle,rgba(255,255,255,.05) 1px,transparent 1px);background-size:60px 60px,100px 100px;background-position:0 0,30px 30px;opacity:.5}html.dark .post .header .header-title{color:#c8c8c8}html.dark .post .header .post-meta{color:#9ca3af}html.dark .post .page-content{color:#d1d5db}html.dark .post .page-content h2,html.dark .post .page-content h3,html.dark .post .page-content h4,html.dark .post .page-content h5,html.dark .post .page-content h6{color:#c8c8c8}html.dark .post .page-content h2{border-color:#1f2937}html.dark .post .page-content blockquote{background:#10b9811a;color:#9ca3af}html.dark .post .page-content a{color:#77a8fd}html.dark .post .page-content a:hover{color:#5292ff}html.dark .author .author-avatar-wrapper:before{background:linear-gradient(135deg,#10b981,#06b6d4)}html.dark .author .author-avatar{border-color:#020617}html.dark .author .author-name{color:#6b7886}html.dark .author .author-name .name-highlight{color:#10b981}html.dark .author .author-bio{color:#ececec}html.dark .author .author-bio .highlight{color:#10b981}html.dark .post-item{background:#0f172acc;border-color:#1f2937;box-shadow:none}html.dark .post-item:hover{background:#1f2937e6;border-color:#10b9814d}html.dark .post-item .post-item-title a{color:#d1d5db}html.dark .posts-item-note{color:#c8c8c8;border-color:#1f2937}html.dark .sidebar-widget{background:#0f172acc;border-color:#1f2937}html.dark .sidebar-widget.daily-inspiration .quote-text{color:#d1d5db}html.dark .sidebar-widget.daily-inspiration .quote-author{color:#10b981}html.dark .sidebar-widget.daily-puzzle .puzzle-image-wrapper{background:#0006}html.dark .sidebar-widget.daily-puzzle .puzzle-description{color:#9ca3af}html.dark .sidebar-widget.daily-puzzle .solve-button{background:#1f2937;color:#d1d5db;border-color:#374151}html.dark .sidebar-widget.daily-puzzle .solve-button:hover{background:#10b981;color:#fff}html.dark .sidebar-widget.daily-puzzle h3 .difficulty-badge{background:#22c55e66;color:#4ade80;border-color:#22c55e99}.list-page .post-year{padding-bottom:.5rem}.icon-star{color:orange;height:16px;margin-right:1rem;width:16px;display:block}.post-item-right{margin-left:auto;margin-right:0}.author{margin-top:1.5rem;margin-bottom:4rem;display:grid;grid-template-columns:1fr;gap:2rem;animation:fadeInDown .8s ease-out}@media(min-width:769px){.author{gap:2.5rem;margin-bottom:4rem}}@media(min-width:1024px){.author{grid-template-columns:2fr 1fr;gap:3rem;margin-bottom:5rem;align-items:center}}@media screen and (max-width:768px){.author{margin-bottom:2.5rem;gap:2rem}}.author .author-content{min-width:0;text-align:left}.author .author-image{display:flex;justify-content:center}@media(min-width:1024px){.author .author-image{justify-content:flex-end}}.author .status-badge{display:inline-flex;align-items:center;gap:.5rem;font-family:Roboto Mono,Consolas,monospace;font-size:.75rem;font-weight:600;letter-spacing:.05em;color:#10b981;background:#10b98126;padding:.5rem 1rem;border-radius:1.5rem;border:1px solid rgba(16,185,129,.3);margin-bottom:1.5rem}.author .status-badge .status-dot{width:8px;height:8px;border-radius:50%;background:#10b981;animation:pulse 2s infinite}.author .author-name{font-size:4rem;font-weight:700;margin:0;margin-bottom:.75rem;color:#6b7886;letter-spacing:-.025em;line-height:1.1}@media screen and (max-width:768px){.author .author-name{font-size:2.5rem}}.author .author-name .name-highlight{color:#10b981}.author .author-subtitle{font-family:Roboto Mono,Consolas,monospace;font-size:.9rem;color:#6b7886;margin:0 0 2rem;display:flex;align-items:center;gap:.5rem}.author .author-subtitle .terminal-icon{color:#6b7280}.author .author-bio{border-left:3px solid #10b981;padding-left:1.5rem;margin:0 0 2rem}.author .author-bio p{line-height:1.75;font-size:1rem;color:#6b7886;margin:0}@media(min-width:769px){.author .author-bio p{font-size:1.05rem}}.author .author-bio p .highlight{color:#10b981;font-weight:500}.author .author-tags{display:flex;flex-wrap:wrap;gap:.75rem}.author .author-tags .tag{font-family:Roboto Mono,Consolas,monospace;font-size:.875rem;color:#9ca3af;background:#ffffff0d;padding:.5rem 1rem;border-radius:.375rem;border:1px solid rgba(255,255,255,.1);transition:all .2s}.author .author-tags .tag:hover{background:#10b9811a;border-color:#10b9814d;color:#10b981}.author .author-avatar-wrapper{position:relative;display:inline-block}.author .author-avatar-wrapper:before{content:"";position:absolute;inset:-6px;background:linear-gradient(135deg,#10b981,#7c3aed);border-radius:1.5rem;opacity:.4;filter:blur(20px);transition:opacity .3s}.author .author-avatar-wrapper:hover:before{opacity:.6}.author .author-avatar-wrapper:hover .author-avatar{transform:scale(1.01)}.author .author-avatar{position:relative;width:100%;height:auto;max-width:320px;border-radius:1.5rem;border:3px solid rgba(16,185,129,.3);object-fit:cover;box-shadow:0 0 30px #10b98133,0 25px 50px -12px #00000080;transition:transform .3s;user-select:none;-webkit-user-select:none}.author .compiling-badge{position:absolute;bottom:1.5rem;left:1.5rem;font-family:Roboto Mono,Consolas,monospace;font-size:.75rem;font-weight:600;letter-spacing:.05em;color:#10b981;background:#000000d9;padding:.5rem 1rem;border-radius:.5rem;border:1px solid rgba(16,185,129,.3);backdrop-filter:blur(10px);display:flex;align-items:center;gap:.5rem;z-index:10}.author .compiling-badge .compiling-dot{width:6px;height:6px;border-radius:50%;background:#10b981;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}:global(.light) .author .status-badge{color:#059669;background:#05966926;border-color:#0596694d}:global(.light) .author .status-badge .status-dot{background:#059669}:global(.light) .author .author-name{color:#4a4d56}:global(.light) .author .author-name .name-highlight{color:#10b981}:global(.light) .author .author-subtitle{color:#374151}:global(.light) .author .author-bio{border-color:#10b981}:global(.light) .author .author-bio p{color:#6b7886}:global(.light) .author .author-bio p .highlight{color:#10b981}:global(.light) .author .author-tags .tag{color:#1f2937;background:#0000000d;border-color:#0000001a}:global(.light) .author .author-tags .tag:hover{background:#10b9811a;border-color:#10b9814d;color:#10b981}:global(.light) .author .author-avatar{border-color:#0596694d;box-shadow:0 0 30px #05966926,0 25px 50px -12px #00000040}:global(.light) .author .compiling-badge{background:#fffffff2;border-color:#0596694d;color:#059669}:global(.light) .author .compiling-badge .compiling-dot{background:#059669}.post-item{position:relative;background:#fffc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid #e5e7eb;border-radius:1rem;padding:1.25rem;transition:all .3s;box-shadow:0 1px 2px #0000000d;display:flex;flex-direction:column;align-items:flex-start;gap:.75rem;margin-bottom:1rem;box-sizing:border-box;width:100%}@media(min-width:769px){.post-item{flex-direction:row;align-items:center;justify-content:space-between}}.post-item:hover{background:#f9fafbe6;border-color:#10b9814d;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.post-item:hover .post-item-title a{color:#10b981}.post-item .post-item-title{margin:0;font-size:1.125rem;font-weight:500;letter-spacing:0;text-align:left;width:100%}.post-item .post-item-title a{color:#374151;text-decoration:none;transition:color .3s}.post-item .post-item-title a:hover{color:#10b981}.post-item .post-item-meta{font-size:.75rem;white-space:nowrap;font-family:Roboto Mono,Consolas,monospace;text-align:left;align-self:flex-start}.posts-item-note{font-size:1.25rem;font-weight:600;color:#0d122b;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem;border-bottom:1px solid #e5e7eb;padding-bottom:.75rem}.posts-item-note .material-icons{color:#10b981;font-size:1rem}.sidebar-widget{background:#fffc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:1rem;padding:1.5rem;box-shadow:0 1px 2px #0000000d;border:1px solid #e5e7eb;position:relative;overflow:hidden;box-sizing:border-box;width:100%}.sidebar-widget.daily-inspiration .quote-icon{position:absolute;top:1rem;right:1rem;opacity:.1;transition:opacity .3s}.sidebar-widget.daily-inspiration .quote-icon .material-icons{font-size:4rem;color:#10b981}.sidebar-widget.daily-inspiration:hover .quote-icon{opacity:.2}.sidebar-widget.daily-inspiration h3{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#4b5563;margin-bottom:1rem}.sidebar-widget.daily-inspiration .quote-text{color:#111827;font-style:italic;font-family:Georgia,serif;font-size:1.125rem;line-height:1.75;position:relative;z-index:10}.sidebar-widget.daily-inspiration .quote-author{margin-top:1rem;font-size:.875rem;font-weight:500;color:#10b981;text-align:right;position:relative;z-index:10}.sidebar-widget.daily-puzzle h3{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#4b5563;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center}.sidebar-widget.daily-puzzle h3 .difficulty-badge{font-size:.625rem;background:#22c55e1a;color:#15803d;padding:.25rem .5rem;border-radius:.375rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border:1px solid rgba(34,197,94,.2)}.sidebar-widget.daily-puzzle .puzzle-image-wrapper{aspect-ratio:1;background:#e5e7eb;border-radius:.75rem;overflow:hidden;position:relative;margin-bottom:1rem;cursor:pointer;border:2px solid transparent;transition:border-color .3s}.sidebar-widget.daily-puzzle .puzzle-image-wrapper:hover{border-color:#10b981}.sidebar-widget.daily-puzzle .puzzle-image-wrapper:hover img{opacity:1}.sidebar-widget.daily-puzzle .puzzle-image-wrapper:hover .play-overlay{background:transparent}.sidebar-widget.daily-puzzle .puzzle-image-wrapper:hover .play-overlay .material-icons{display:none}.sidebar-widget.daily-puzzle .puzzle-image-wrapper img{width:100%;height:100%;object-fit:cover;opacity:.8;transition:opacity .3s}.sidebar-widget.daily-puzzle .puzzle-image-wrapper .play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0000004d;transition:background .3s}.sidebar-widget.daily-puzzle .puzzle-image-wrapper .play-overlay .material-icons{color:#fff;font-size:2.5rem;filter:drop-shadow(0 4px 6px rgba(0,0,0,.3))}.sidebar-widget.daily-puzzle .puzzle-description{font-size:.75rem;color:#374151;margin-bottom:1rem}.sidebar-widget.daily-puzzle .solve-button{width:100%;padding:.625rem;background:#f3f4f6;color:#1f2937;border-radius:.5rem;font-size:.875rem;font-weight:500;border:1px solid #d1d5db;cursor:pointer;transition:all .3s}.sidebar-widget.daily-puzzle .solve-button:hover{background:#10b981;color:#fff;border-color:transparent}.homepage-grid{display:grid;grid-template-columns:1fr;gap:2rem;margin-top:1.5rem}@media(min-width:769px){.homepage-grid{gap:2.5rem;margin-top:2rem}}@media(min-width:1024px){.homepage-grid{grid-template-columns:2fr 1fr;gap:3rem}}.homepage-grid .main-content{position:relative;z-index:10}.homepage-grid .sidebar{display:flex;flex-direction:column;gap:1.5rem;position:relative;z-index:10}@media(min-width:769px){.homepage-grid .sidebar{gap:2rem}}.view-all-link{margin-top:2rem}.view-all-link a{font-size:.875rem;font-weight:500;color:#10b981;text-decoration:none;display:inline-flex;align-items:center;gap:.25rem;transition:color .3s}.view-all-link a:hover{color:#059669}.view-all-link a .material-icons{font-size:.75rem}.post .header{margin-bottom:3rem;text-align:left}.post .header .header-title{font-size:2.5rem;font-weight:800;color:#4a4d56;margin-bottom:1rem;line-height:1.2;letter-spacing:-.025em}@media(min-width:769px){.post .header .header-title{font-size:3.5rem}}.post .header .post-meta{font-size:.875rem;color:#9ca3af;font-family:Roboto Mono,Consolas,monospace;display:flex;align-items:center;gap:.5rem}.post .header .post-meta:before{content:"schedule";font-family:Material Icons;font-size:1rem;color:#10b981}.post .page-content{color:#374151;font-size:1.125rem;line-height:1.8}.post .page-content h2,.post .page-content h3,.post .page-content h4{margin-top:2.5rem;margin-bottom:1.25rem;color:#4a4d56;font-weight:700;letter-spacing:-.025em}.post .page-content h2{font-size:1.875rem;border-bottom:1px solid #e5e7eb;padding-bottom:.5rem}.post .page-content h3{font-size:1.5rem}.post .page-content h4{font-size:1.25rem}.post .page-content p{margin-bottom:1.5rem}.post .page-content ul,.post .page-content ol{margin-bottom:1.5rem;padding-left:1.5rem}.post .page-content ul li,.post .page-content ol li{margin-bottom:.5rem}.post .page-content blockquote{background:#10b9810d;border-left:4px solid #10b981;padding:1.5rem;margin:2rem 0;font-style:italic;border-radius:.5rem;color:#4b5563}.post .page-content blockquote p{margin-bottom:0}.post .page-content pre{background:#1e293b;padding:1.5rem;border-radius:1rem;margin:2rem 0;border:1px solid rgba(255,255,255,.1);overflow-x:auto}.post .page-content code{font-family:Roboto Mono,Consolas,monospace;font-size:.875rem}.post .page-content img{border-radius:1rem;box-shadow:0 10px 15px -3px #0000001a;margin:2rem auto}.toc{background:#ffffff80;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid #e5e7eb;border-radius:1rem;padding:1.5rem;margin:2rem 0}.toc summary{font-weight:600;color:#0d122b;font-size:1rem;display:flex;align-items:center;gap:.5rem;user-select:none}.toc summary:before{content:"list";font-family:Material Icons;font-size:1.25rem;color:#10b981}.toc ul{margin-top:1rem!important;padding-left:1rem!important;border-left:2px solid #e5e7eb;list-style:none}.toc ul li{margin-bottom:.75rem}.toc ul li a{color:#6b7280;text-decoration:none;font-size:.875rem;transition:all .2s}.toc ul li a:hover{color:#10b981;padding-left:.25rem}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}main,nav,footer{position:relative;z-index:10}.terminal-prompt{font-family:Roboto Mono,Consolas,monospace;font-size:.875rem;color:#10b981;display:inline-block;padding:.25rem .75rem;background:#10b9811a;border-radius:.375rem;border:1px solid rgba(16,185,129,.2)}.terminal-prompt:before{content:"$ ";color:#10b981;font-weight:600}.terminal-badge{font-family:Roboto Mono,Consolas,monospace;background:#10b9811a;color:#10b981;border:1px solid rgba(16,185,129,.2);padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;white-space:nowrap}.terminal-badge:hover{background:#10b98126;border-color:#10b9814d}:global(.light) .terminal-prompt{color:#10b981;background:#10b9811a;border-color:#10b98133}:global(.light) .terminal-prompt:before{color:#10b981}:global(.light) .terminal-badge{color:#10b981;background:#10b9811a;border-color:#10b98133}:global(.light) .terminal-badge:hover{background:#10b98126;border-color:#10b9814d}.chess-puzzle{background:var(--color-card-bg, #1a1f2e);border-radius:16px;padding:1.25rem;max-width:350px;width:100%}.chess-puzzle__loading{text-align:center;padding:2rem;color:var(--color-text, #e5e7eb)}.chess-puzzle__header{display:flex;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:1rem}.chess-puzzle__title{font-size:.75rem;font-weight:600;letter-spacing:.05em;color:var(--color-text-muted, #8b95a5);flex-shrink:0}.chess-puzzle__badge{padding:.25rem .75rem;border-radius:4px;font-size:.75rem;font-weight:600}.chess-puzzle__badge--green{background:#22c55e;color:#fff}.chess-puzzle__badge--yellow{background:#eab308;color:#000}.chess-puzzle__badge--red{background:#ef4444;color:#fff}.chess-puzzle__board{border-radius:8px;overflow:hidden;transition:box-shadow .3s ease;width:100%;max-width:100%}.chess-puzzle__board--correct{box-shadow:0 0 0 3px #22c55e}.chess-puzzle__board--wrong{box-shadow:0 0 0 3px #ef4444}.chess-puzzle__attempts{display:flex;gap:.25rem;justify-content:center;align-items:center;margin-bottom:.75rem;flex-wrap:wrap;min-height:1.5rem}.chess-puzzle__attempt-icon{font-size:1.25rem;line-height:1;animation:scaleIn .2s ease-out;font-weight:700}.chess-puzzle__attempt-icon--correct{color:#22c55e}.chess-puzzle__attempt-icon--wrong{color:#eab308}.chess-puzzle__info{margin:1rem 0;text-align:center;min-height:3rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem}.chess-puzzle__turn{font-size:.75rem;font-weight:500;color:var(--color-text, #e5e7eb);white-space:nowrap;flex-shrink:0}.chess-puzzle__feedback{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:500;animation:fadeIn .3s ease-in-out}.chess-puzzle__feedback--correct{background:#22c55e26;color:#22c55e;border:1px solid rgba(34,197,94,.3)}.chess-puzzle__feedback--wrong{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.chess-puzzle__feedback--solved{background:#3b82f626;color:#3b82f6;border:1px solid rgba(59,130,246,.3)}.chess-puzzle__feedback-icon{font-size:1.25rem;font-weight:700;line-height:1}.chess-puzzle__solution{font-size:.85rem;color:var(--color-text-muted);margin-top:.5rem;font-family:monospace}.chess-puzzle__actions{display:flex;gap:.5rem}.chess-puzzle__btn{flex:1;padding:.75rem 1rem;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:opacity .2s}.chess-puzzle__btn:hover{opacity:.9}.chess-puzzle__btn--primary{background:var(--color-primary, #3b82f6);color:#fff}.chess-puzzle__btn--secondary{background:var(--color-secondary-bg, #2d3548);color:var(--color-text)}.chess-puzzle__btn--disabled{opacity:.5;cursor:not-allowed}.chess-puzzle__btn--disabled:hover{opacity:.5}.custom-chessboard{display:grid;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);width:100%;max-width:100%;aspect-ratio:1;border-radius:8px;overflow:visible;box-sizing:border-box;padding:2px}.chess-square{display:flex;align-items:center;justify-content:center;user-select:none;position:relative;width:100%;height:100%;min-width:0;min-height:0}.chess-square.light{background:#eeeed2}.chess-square.dark{background:#769656}.chess-square--selected{position:relative;box-shadow:0 0 0 3px #22c55e;transition:box-shadow .2s ease-in-out;z-index:10}.chess-square--invalid{position:relative;box-shadow:0 0 0 3px #ef4444;transition:box-shadow .2s ease-in-out;z-index:10;animation:shake .3s ease-in-out}.chess-square--highlighted{position:relative}.chess-square--highlighted:after{content:"";position:absolute;inset:0;background-color:#ffff0059;pointer-events:none;z-index:1}.chess-square--selectable{cursor:pointer;transition:all .15s ease}.chess-square--selectable:hover{position:relative}.chess-square--selectable:hover:after{content:"";position:absolute;inset:0;background-color:#ffffff26;pointer-events:none;z-index:1}.chess-square--selectable .chess-piece{position:relative;z-index:2}.chess-piece{width:90%;height:90%;max-width:100%;max-height:100%;object-fit:contain;pointer-events:none;user-select:none;display:block;margin:auto}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}@media(max-width:480px){.chess-piece{width:80%;height:80%}.chess-square{min-width:44px;min-height:44px}.chess-square--selected{box-shadow:0 0 0 2px #22c55e}.chess-square--invalid{box-shadow:0 0 0 2px #ef4444}.chess-puzzle{max-width:100%;padding:1rem}}lite-youtube{display:block;position:relative;width:100%;max-width:720px;margin:1.5rem auto;aspect-ratio:16/9;background-color:#000;background-size:cover;background-position:center;border-radius:8px;overflow:hidden;cursor:pointer}lite-youtube:focus-visible{outline:2px solid var(--color-primary, #3b82f6);outline-offset:2px}lite-youtube:before{content:"";display:block;position:absolute;top:50%;left:50%;width:68px;height:48px;transform:translate(-50%,-50%);background-color:#000c;border-radius:14px;transition:background-color .2s ease;z-index:1}lite-youtube:hover:before{background-color:red}lite-youtube:after{content:"";display:block;position:absolute;top:50%;left:50%;transform:translate(-35%,-50%);border-style:solid;border-width:11px 0 11px 19px;border-color:transparent transparent transparent #fff;z-index:2}lite-youtube.lyt-activated:before,lite-youtube.lyt-activated:after{display:none}lite-youtube>button{display:none}lite-youtube>iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}@media(max-width:768px){lite-youtube{margin:1rem 0;border-radius:4px}}x-video{display:block;width:100%;max-width:550px;margin:1.5rem auto}x-video .twitter-tweet{margin:0 auto!important}x-video .twitter-tweet-rendered+.twitter-tweet{display:none}x-video iframe{max-width:100%!important}@media(max-width:768px){x-video{margin:1rem 0}}html{scroll-behavior:smooth}#totop{visibility:hidden;color:#434648;position:fixed;bottom:60px;right:30px;z-index:1;border-radius:10%;background-color:#dfe0e397;transition:visibility .5s,opacity .8s linear}#totop:hover{background-color:#dfe0e3}#totop svg{margin:auto;display:block;height:40px;width:40px}body{font-family:Nunito Sans,sans-serif}h1,h2,h3,h4,h5,h6,.header-title,.post-item-title,.site-title,blockquote,.quote-text{font-family:Lora,serif}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#020617}::-webkit-scrollbar-thumb{background:#334155;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#475569}.bg-grid{mask-image:linear-gradient(to bottom,transparent,10%,white,90%,transparent);-webkit-mask-image:linear-gradient(to bottom,transparent,5%,white,95%,transparent)}
