body,h1,h2,h3,h4,h5,h6,p,blockquote,pre,hr,dl,dd,ol,ul,figure{margin:0;padding:0}body{font:400 16px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol";color:#111;background-color:#fdfdfd;-webkit-text-size-adjust:100%;-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;display:flex;min-height:100vh;flex-direction:column}h1,h2,h3,h4,h5,h6,p,blockquote,pre,ul,ol,dl,figure,.highlight{margin-bottom:15px}main{display:block}img{max-width:100%;vertical-align:middle}figure>img{display:block}figcaption{font-size:14px}ul,ol{margin-left:30px}li>ul,li>ol{margin-bottom:0}h1,h2,h3,h4,h5,h6{font-weight:400}a{color:#2a7ae2;text-decoration:none}a:visited{color:#1756a9}a:hover{color:#111;text-decoration:underline}.social-media-list a:hover{text-decoration:none}.social-media-list a:hover .username{text-decoration:underline}blockquote{color:#828282;border-left:4px solid #e8e8e8;padding-left:15px;font-size:18px;letter-spacing:-1px;font-style:italic}blockquote>:last-child{margin-bottom:0}pre,code{font-size:15px;border:1px solid #e8e8e8;border-radius:3px;background-color:#eef}code{padding:1px 5px}pre{padding:8px 12px;overflow-x:auto}pre>code{border:0;padding-right:0;padding-left:0}.wrapper{max-width:-webkit-calc(800px - (30px * 2));max-width:calc(800px - (30px * 2));margin-right:auto;margin-left:auto;padding-right:30px;padding-left:30px}@media screen and (max-width: 800px){.wrapper{max-width:-webkit-calc(800px - (30px));max-width:calc(800px - (30px));padding-right:15px;padding-left:15px}}.wrapper:after,.footer-col-wrapper:after{content:"";display:table;clear:both}.svg-icon{width:16px;height:16px;display:inline-block;fill:#828282;padding-right:5px;vertical-align:text-top}.social-media-list li+li{padding-top:5px}table{margin-bottom:30px;width:100%;text-align:left;color:#3f3f3f;border-collapse:collapse;border:1px solid #e8e8e8}table tr:nth-child(even){background-color:#f7f7f7}table th,table td{padding:10px 15px}table th{background-color:#f0f0f0;border:1px solid #dedede;border-bottom-color:#c9c9c9}table td{border:1px solid #e8e8e8}.site-header{border-top:5px solid #424242;border-bottom:1px solid #e8e8e8;min-height:55.95px;position:relative}.site-title{font-size:26px;font-weight:300;line-height:54px;letter-spacing:-1px;margin-bottom:0;float:left}.site-title,.site-title:visited{color:#424242}.site-nav{float:right;line-height:54px}.site-nav .nav-trigger{display:none}.site-nav .menu-icon{display:none}.site-nav .page-link{color:#111;line-height:1.5}.site-nav .page-link:not(:last-child){margin-right:20px}@media screen and (max-width: 600px){.site-nav{position:absolute;top:9px;right:15px;background-color:#fdfdfd;border:1px solid #e8e8e8;border-radius:5px;text-align:right}.site-nav label[for="nav-trigger"]{display:block;float:right;width:36px;height:36px;z-index:2;cursor:pointer}.site-nav .menu-icon{display:block;float:right;width:36px;height:26px;line-height:0;padding-top:10px;text-align:center}.site-nav .menu-icon>svg{fill:#424242}.site-nav input ~ .trigger{clear:both;display:none}.site-nav input:checked ~ .trigger{display:block;padding-bottom:5px}.site-nav .page-link{display:block;padding:5px 10px;margin-left:20px}.site-nav .page-link:not(:last-child){margin-right:0}}.site-footer{border-top:1px solid #e8e8e8;padding:30px 0}.footer-heading{font-size:18px;margin-bottom:15px}.contact-list,.social-media-list{list-style:none;margin-left:0}.footer-col-wrapper{font-size:15px;color:#828282;margin-left:-15px}.footer-col{float:left;margin-bottom:15px;padding-left:15px}.footer-col-1{width:-webkit-calc(35% - (30px / 2));width:calc(35% - (30px / 2))}.footer-col-2{width:-webkit-calc(20% - (30px / 2));width:calc(20% - (30px / 2))}.footer-col-3{width:-webkit-calc(45% - (30px / 2));width:calc(45% - (30px / 2))}@media screen and (max-width: 800px){.footer-col-1,.footer-col-2{width:-webkit-calc(50% - (30px / 2));width:calc(50% - (30px / 2))}.footer-col-3{width:-webkit-calc(100% - (30px / 2));width:calc(100% - (30px / 2))}}@media screen and (max-width: 600px){.footer-col{float:none;width:-webkit-calc(100% - (30px / 2));width:calc(100% - (30px / 2))}}.page-content{padding:30px 0;flex:1}.page-heading{font-size:32px}.post-list-heading{font-size:28px}.post-list{margin-left:0;list-style:none}.post-list>li{margin-bottom:30px}.post-meta{font-size:14px;color:#828282}.post-link{display:block;font-size:24px}.post-header{margin-bottom:30px}.post-title{font-size:42px;letter-spacing:-1px;line-height:1}@media screen and (max-width: 800px){.post-title{font-size:36px}}.post-content{margin-bottom:30px}.post-content h2{font-size:32px}@media screen and (max-width: 800px){.post-content h2{font-size:28px}}.post-content h3{font-size:26px}@media screen and (max-width: 800px){.post-content h3{font-size:22px}}.post-content h4{font-size:20px}@media screen and (max-width: 800px){.post-content h4{font-size:18px}}.highlight{background:#fff}.highlighter-rouge .highlight{background:#eef}.highlight .c{color:#998;font-style:italic}.highlight .err{color:#a61717;background-color:#e3d2d2}.highlight .k{font-weight:bold}.highlight .o{font-weight:bold}.highlight .cm{color:#998;font-style:italic}.highlight .cp{color:#999;font-weight:bold}.highlight .c1{color:#998;font-style:italic}.highlight .cs{color:#999;font-weight:bold;font-style:italic}.highlight .gd{color:#000;background-color:#fdd}.highlight .gd .x{color:#000;background-color:#faa}.highlight .ge{font-style:italic}.highlight .gr{color:#a00}.highlight .gh{color:#999}.highlight .gi{color:#000;background-color:#dfd}.highlight .gi .x{color:#000;background-color:#afa}.highlight .go{color:#888}.highlight .gp{color:#555}.highlight .gs{font-weight:bold}.highlight .gu{color:#aaa}.highlight .gt{color:#a00}.highlight .kc{font-weight:bold}.highlight .kd{font-weight:bold}.highlight .kp{font-weight:bold}.highlight .kr{font-weight:bold}.highlight .kt{color:#458;font-weight:bold}.highlight .m{color:#099}.highlight .s{color:#d14}.highlight .na{color:teal}.highlight .nb{color:#0086B3}.highlight .nc{color:#458;font-weight:bold}.highlight .no{color:teal}.highlight .ni{color:purple}.highlight .ne{color:#900;font-weight:bold}.highlight .nf{color:#900;font-weight:bold}.highlight .nn{color:#555}.highlight .nt{color:navy}.highlight .nv{color:teal}.highlight .ow{font-weight:bold}.highlight .w{color:#bbb}.highlight .mf{color:#099}.highlight .mh{color:#099}.highlight .mi{color:#099}.highlight .mo{color:#099}.highlight .sb{color:#d14}.highlight .sc{color:#d14}.highlight .sd{color:#d14}.highlight .s2{color:#d14}.highlight .se{color:#d14}.highlight .sh{color:#d14}.highlight .si{color:#d14}.highlight .sx{color:#d14}.highlight .sr{color:#009926}.highlight .s1{color:#d14}.highlight .ss{color:#990073}.highlight .bp{color:#999}.highlight .vc{color:teal}.highlight .vg{color:teal}.highlight .vi{color:teal}.highlight .il{color:#099}:root{--content-w: 680px}.post-content,.page-content{max-width:var(--content-w);margin:0 auto}@media (min-width: 1250px){.post-content{padding-bottom:20vh}}body{line-height:1.6;border-top:none !important}@media (min-width: 1024px){.site-header,.site-nav{position:fixed;left:calc((100vw - var(--content-w)) / 2 - 180px);top:40px;width:80px;height:calc(100vh - 40px);z-index:100;background:#fdfdfd;border-right:none;border-bottom:none;box-shadow:none;padding:0 1.5rem;display:flex;flex-direction:column}.site-header{border-top:none !important}.site-title{display:none}.nav-list{list-style:none;display:flex;flex-direction:column;gap:0;padding:0;padding-top:1.15rem;margin:0;line-height:1.8}.nav-item a{text-decoration:none;display:block;padding:0;color:#666;transition:color 0.2s}.nav-item a:hover{color:#111}.nav-item a.active,.nav-item a[href="/assets/main.css"]{color:#111;font-weight:600}}@media (max-width: 1023px){.site-header,.site-nav{position:sticky;top:0;z-index:100;background:white;border-bottom:1px solid #e8e8e8;box-shadow:0 2px 4px rgba(0,0,0,0.05)}.site-header{border-top:none !important}.site-nav{margin:0 !important;padding:0.5rem 1rem;line-height:normal !important;display:flex;align-items:center}.site-title{display:none}.nav-list{list-style:none;display:flex;gap:1rem;padding:0;margin:0;align-items:center}.nav-item a{text-decoration:none}}.project-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(300px, 1fr));gap:2rem;margin:2rem 0}.project-card{background:white;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,0.1);transition:transform 0.2s, box-shadow 0.2s}.project-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px rgba(0,0,0,0.15)}.card-link{text-decoration:none;color:inherit;display:block}.card-link:hover{text-decoration:none}.card-image,.card-image-placeholder{width:100%;aspect-ratio:3 / 2;object-fit:cover;display:block}.card-image-placeholder{background:linear-gradient(135deg, #667eea 0%, #764ba2 100%)}.card-content{padding:1.5rem}.card-title{font-size:1.25rem;font-weight:600;margin:0 0 0.5rem 0;color:#111}.card-excerpt{color:#666;font-size:0.9rem;line-height:1.5;margin:0 0 1rem 0}.card-date{color:#999;font-size:0.85rem;font-style:italic}@media (max-width: 600px){.project-grid{grid-template-columns:1fr;gap:1.5rem}}@media (min-width: 1024px){.page-heading{display:none}.home{padding-top:0}.page-content{padding-top:2rem}.post-header{margin-top:0}.post-title{margin-top:1.5rem}}.page-heading,.post-title{font-size:42px !important;letter-spacing:-1px !important;line-height:1 !important}.page-content{width:820px !important;max-width:100% !important;margin:0 auto !important}.wrapper{width:760px !important;max-width:100% !important;padding-left:30px !important;padding-right:30px !important}@media (min-width: 1024px){.wrapper{padding-left:0 !important;padding-right:0 !important}}@media screen and (max-width: 800px){.page-heading,.post-title{font-size:36px !important}}.post-container{position:relative;max-width:var(--content-w);margin:0 auto}@media (min-width: 1024px){.post-header{max-width:var(--content-w);margin-left:auto;margin-right:auto}}.toc-sidebar{display:none}@media (min-width: 1250px){.toc-sidebar{display:block;position:fixed;right:calc((100vw - var(--content-w)) / 2 - 280px);top:calc(40px + 1.15rem);width:240px;max-height:calc(100vh - 60px);overflow-y:auto}}.toc-sticky{padding:1rem;background:#f9f9f9;border-radius:8px;border:1px solid #e8e8e8}.toc-title{font-size:0.85rem;font-weight:600;text-transform:uppercase;letter-spacing:0.05em;color:#666;margin:0 0 0.75rem 0}.toc-nav{font-size:0.9rem}.toc-nav ul{list-style:none;margin:0;padding:0}.toc-nav li{margin:0}.toc-nav a{display:block;padding:0.25rem 0;color:#666;text-decoration:none;transition:color 0.2s;line-height:1.4}.toc-nav a:hover{color:#111}.toc-nav a.active{color:#111;font-weight:600}.toc-nav ul ul{padding-left:1rem;margin-top:0.25rem}.toc-nav ul ul a{font-size:0.85rem;color:#888}.toc-nav ul ul a:hover,.toc-nav ul ul a.active{color:#111}.lightbox{display:none;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background-color:rgba(0,0,0,0.9);opacity:0;transition:opacity 0.3s ease}.lightbox.active{display:flex;align-items:center;justify-content:center;opacity:1}.lightbox-content{position:relative;max-width:90%;max-height:90%;display:flex;align-items:center;justify-content:center}.lightbox-image{max-width:100%;max-height:90vh;object-fit:contain;border-radius:4px;box-shadow:0 4px 20px rgba(0,0,0,0.5)}.lightbox-close{position:absolute;top:-40px;right:0;color:#fff;font-size:40px;font-weight:bold;cursor:pointer;transition:color 0.2s;user-select:none}.lightbox-close:hover{color:#ccc}.post-content img{cursor:pointer;transition:opacity 0.2s}.post-content img:hover{opacity:0.9}.writing-list{list-style:none;padding:0;margin:0;padding-top:1.15rem;max-width:var(--content-w);margin-left:auto;margin-right:auto}.writing-item{display:flex;justify-content:space-between;align-items:baseline;padding:0.5rem 0}.writing-link{flex:1;text-decoration:none;color:#111;font-size:1rem;font-weight:normal;line-height:1.4;margin-right:1rem}.writing-link:hover{text-decoration:underline}.writing-date{color:#999;font-size:0.9rem;white-space:nowrap;flex-shrink:0}.breadcrumb{font-size:0.85rem;color:#666;margin-bottom:0.5rem;max-width:var(--content-w);margin-left:auto;margin-right:auto}@media (min-width: 1024px){.breadcrumb{margin-top:-1rem}}.breadcrumb a{color:#666;text-decoration:none;transition:color 0.2s}.breadcrumb a:hover{color:#111;text-decoration:underline}.breadcrumb-separator{margin:0 0.5rem;color:#999}.breadcrumb-current{color:#111}.landing{max-width:var(--content-w);margin:0 auto;padding-top:2rem}.landing-intro{margin-bottom:3rem}.landing-intro p{font-size:1.25rem;line-height:1.6;color:#333;margin:0}.landing-section{margin-bottom:3rem}.landing-section-title{font-size:0.85rem;font-weight:600;text-transform:uppercase;letter-spacing:0.05em;color:#666;margin:0 0 1rem 0}.featured-card{display:block;text-decoration:none;color:inherit;background:white;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,0.1);transition:transform 0.2s, box-shadow 0.2s}.featured-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px rgba(0,0,0,0.15);text-decoration:none}.featured-image,.featured-image-placeholder{width:100%;aspect-ratio:3 / 2;object-fit:cover;display:block}.featured-image-placeholder{background:linear-gradient(135deg, #667eea 0%, #764ba2 100%)}.featured-content{padding:1.5rem}.featured-title{font-size:1.5rem;font-weight:600;margin:0 0 0.75rem 0;color:#111}.featured-excerpt{color:#666;font-size:1rem;line-height:1.6;margin:0 0 1rem 0}.featured-meta{display:flex;justify-content:space-between;align-items:center}.featured-date{color:#999;font-size:0.9rem}.featured-link{color:#111;font-weight:500;font-size:0.95rem}.featured-card:hover .featured-link{text-decoration:underline}.featured-card--writing{border:1px solid #e8e8e8;box-shadow:none}.featured-card--writing:hover{box-shadow:0 4px 16px rgba(0,0,0,0.1)}@media (min-width: 1024px){.landing{padding-top:2.5rem}}.profile-photo{display:block;width:200px;height:200px;border-radius:50%;object-fit:cover;margin:0 auto 2rem auto}.social-links{display:flex;justify-content:center;gap:1.5rem;margin-top:2rem}.social-links a{display:block;width:24px;height:24px}.social-links svg{width:24px;height:24px;fill:#666;transition:fill 0.2s}.social-links a:hover svg{fill:#111}
