:root{--bg-color:#FFFFFF;--text-color:#1A1A1A;--link-color:#007BFF;--link-hover-color:#0056B3;--code-bg:#F0F0F0;--border-color:#1A1A1A;--blockquote-bg:#F5F5F5;--button-color:#2962FF;--box-shadow:4px 4px 0px 0px rgba(26,26,26,1);--text-main:#1A1A1A;--links:#007BFF;--text-aux:#555;--nav-border:rgba(0, 0, 0, 0.1);--zebra-bg:rgba(0, 0, 0, 0.02)}[data-theme=dark]{--bg-color:#121214;--text-color:#E4E4E7;--link-color:#3B82F6;--link-hover-color:#60A5FA;--code-bg:#1F1F23;--border-color:#E4E4E7;--blockquote-bg:#1A1A1E;--button-color:#2563EB;--box-shadow:4px 4px 0px 0px rgba(228,228,231,1);--text-main:#E4E4E7;--links:#3B82F6;--text-aux:#A1A1AA;--nav-border:rgba(255, 255, 255, 0.15);--zebra-bg:rgba(255, 255, 255, 0.02)}*,:after,:before{box-sizing:border-box;background-color:inherit;color:inherit;margin:0;padding:0}html{background-color:var(--bg-color);transition:background-color .25s ease,color .25s ease}body{font-family:jetbrains mono,courier new,monospace;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;line-height:1.6;font-size:.95rem;color:var(--text-color);background-color:var(--bg-color);text-align:justify}main{display:flex;flex-wrap:wrap;max-width:60rem;margin:1rem auto;padding:.75rem;background-color:var(--bg-color);width:calc(100% - 2rem)}header{flex-basis:10rem;flex-grow:1;position:relative;padding:1rem}header a{text-decoration:none;border-bottom:none}header li{margin-bottom:1rem;text-align:right;margin-right:2rem;font-weight:700}header a.active{font-weight:800;position:relative}nav ul{list-style:none;border-right:1px solid var(--nav-border)}section{flex-basis:0;flex-grow:999;min-width:70%;display:flex;flex-direction:column;width:100%;padding:1rem}a{color:var(--link-color);text-decoration-skip-ink:auto;text-decoration:none;font-weight:600;border-bottom:1px solid transparent;padding-bottom:2px;transition:all .2s ease}a:hover{color:var(--link-hover-color);background-color:rgba(0,102,204,8%)}pre{margin:1.5rem 0;padding:1rem;background-color:#1e1e24!important;border:2px solid var(--border-color);box-shadow:var(--box-shadow);overflow-x:auto}.post p{margin:1rem 0;text-align:justify}.post h1,.post h2,.post h3,.post h4{margin:1.8rem 0 1rem;font-weight:700}.post h2:first-child,.project h2:first-child,.photo h2:first-child{margin-top:0}.post ul,.post ol,.project ul{margin-left:2rem;margin-bottom:1.5rem}.post li{margin-bottom:.5rem}.post li ul{margin-top:.5rem;margin-bottom:.5rem}.meta{margin:2rem 0;padding:1rem;background-color:var(--code-bg);border:2px solid var(--border-color);border-radius:4px;display:inline-block}code{background-color:var(--code-bg);padding:.1rem .3rem;border:1px solid var(--nav-border);font-size:.9em;border-radius:4px}pre code{background-color:initial!important;color:#e4e4e7!important;border:none;padding:0;font-size:inherit}pre span{background-color:initial!important}img{max-width:100%;border:2px solid var(--border-color)}hr{background:var(--border-color);height:2px;border:0;margin:2rem 0}blockquote{font-style:italic;border:2px solid var(--border-color);padding:1rem;margin:1.5rem 0;background-color:var(--blockquote-bg);border-radius:4px;text-align:justify}h1,h2,h3,h4,h5{line-height:1.2;margin:1rem 0;font-weight:700}section h1:first-child{margin-top:0}strong,b{font-weight:700}.posts ul{list-style:none}.posts li{align-items:center;display:flex;justify-content:space-between;margin-bottom:.3rem;padding:.3rem}.posts li a,.posts li div,.projects li a{overflow:hidden;text-overflow:ellipsis;text-decoration:none;font-weight:600;border-bottom:none;transition:color .2s ease}@media screen and (min-width:45rem){.posts li a,.posts li div,.projects li a{white-space:nowrap}}.posts li a:hover{background:0 0;color:var(--link-hover-color)}.posts li time,.projects li time{padding-left:1rem;white-space:nowrap;font-variant-numeric:tabular-nums;color:var(--text-aux);font-size:.9rem}@media screen and (max-width:45rem){.posts li{padding:.3rem;margin-bottom:.5rem}.posts li time{font-size:.85rem}}table{width:100%;border-collapse:separate;border-spacing:0;margin:1.5rem 0;border:2px solid var(--border-color);background-color:var(--bg-color)}th,td{padding:.75rem;text-align:left;border:1px solid var(--border-color)}th{background-color:var(--code-bg);font-weight:700}tr:nth-child(even){background-color:var(--zebra-bg)}.post table{margin:1rem 0}.post td{padding:1px;text-align:center;border:1px solid var(--border-color);transition:all .1s ease}.post td:hover{transform:translate(-2px,-2px);box-shadow:3px 3px 0 0 var(--border-color);background-color:rgba(0,102,204,5%)}.post table a{display:block;font-weight:700;padding:8px;border-bottom:none;transition:all .2s ease}.post table a:hover{color:var(--link-hover-color);transform:scale(1.05);background:0 0}.category-filter{width:100%;border-collapse:separate;border-spacing:0;margin:5px 0 1.5rem;border:2px solid var(--border-color);background-color:var(--bg-color);display:flex;flex-wrap:wrap}.filter-btn{text-align:center;border:none;border-right:2px solid var(--border-color);border-bottom:1px solid var(--border-color);font-family:inherit;font-weight:700;padding:8px 12px 11px;background:0 0;color:var(--text-color);cursor:pointer;flex:1;min-width:100px;transition:all .15s ease-in-out}.filter-btn:hover{border-bottom:4px solid var(--border-color);padding:8px 12px;transform:translate(-2px,-2px);box-shadow:2px 2px 0 0 var(--border-color);background-color:rgba(0,102,204,5%);color:var(--link-hover-color)}.filter-btn.active{border-bottom:4px solid var(--border-color);padding:8px 12px;transform:translate(-2px,-2px);box-shadow:2px 2px 0 0 var(--border-color);background-color:rgba(0,102,204,.1);color:var(--link-hover-color)}.post-item.hidden{display:none!important}.button{display:inline-block;padding:.5rem 1rem;background-color:var(--button-color);color:#fff;font-weight:700;border:2px solid var(--border-color);border-radius:4px;box-shadow:var(--box-shadow);transition:all .1s ease;cursor:pointer;text-decoration:none}.button:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 0 var(--border-color);background-color:var(--button-color)}.button:active{transform:translate(0,0);box-shadow:2px 2px 0 0 var(--border-color)}.theme-toggle-container{display:flex;justify-content:flex-end;padding-right:2rem;margin-top:1rem}.theme-toggle-btn{background:var(--code-bg);border:2px solid var(--border-color);box-shadow:2px 2px 0 0 var(--border-color);color:var(--text-color);cursor:pointer;padding:6px 10px;font-size:.8rem;font-family:inherit;font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:all .1s ease}.theme-toggle-btn:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 0 var(--border-color)}.theme-toggle-btn:active{transform:translate(1px,1px);box-shadow:1px 1px 0 0 var(--border-color)}.theme-toggle-btn svg{width:14px;height:14px;fill:currentColor}[data-theme=dark] .sun-icon{display:inline-block}[data-theme=dark] .moon-icon{display:none}[data-theme=light] .sun-icon{display:none}[data-theme=light] .moon-icon{display:inline-block}.site-footer{margin-top:2rem;padding:1.5rem 0;border-top:1px solid var(--border-color);width:100%}.site-footer .footer-content{max-width:60rem;margin:0 auto;text-align:center}.site-footer .social-links{display:flex;justify-content:center;gap:1.5rem;margin-bottom:.75rem}.site-footer .social-link{color:var(--text-color);transition:transform .2s,color .2s;display:inline-flex;align-items:center;justify-content:center}.site-footer .social-link:hover{color:var(--link-hover-color);transform:scale(1.15);background:0 0}.site-footer .social-link svg{width:20px;height:20px}.site-footer .footer-text{font-size:.85rem;color:var(--text-aux)}@media screen and (max-width:45rem){main{margin:.5rem auto;padding:.5rem;width:calc(100% - 1rem)}header{flex-basis:100%;padding:.5rem .5rem 1rem}header li{display:inline-block;margin-right:1.5rem;margin-bottom:.5rem}header ul{border-bottom:2px solid var(--border-color);padding-bottom:1rem;margin-bottom:1rem;border-right:none;text-align:center}nav ul{border-right:0}section{padding:.5rem}.posts li{flex-direction:column;align-items:flex-start}.posts li time{padding-left:0;margin-top:.25rem}.theme-toggle-container{justify-content:center;padding-right:0;margin-top:.5rem;margin-bottom:1rem}}@media screen and (max-width:30rem){main{margin:.25rem auto;border-radius:4px}header,section{padding:.75rem}}@media print{.no-print,.no-print *{display:none!important}}