.highlight .err{color:#e3d2d2;background-color:#8c2121}.highlight .c{color:#8a8a8a}.highlight .c1{color:#8a8a8a}.highlight .cm{color:#8a8a8a}.highlight .cp{color:#8a8a8a}.highlight .cs{color:#8a8a8a;font-style:italic}.highlight .gd{color:#d85a5a}.highlight .gd .x{color:#d85a5a}.highlight .ge{font-style:italic}.highlight .gh{color:#999}.highlight .gi{color:#4ec64e}.highlight .gi .x{color:#4ec64e}.highlight .go{color:#888}.highlight .gp{color:#555}.highlight .gr{color:#f07178}.highlight .gs{font-weight:bold}.highlight .gt{color:#f07178}.highlight .gu{color:#aaa}.highlight .k{color:#d85a7b}.highlight .kc{color:#d85a7b}.highlight .kd{color:#d85a7b}.highlight .kp{color:#d85a7b}.highlight .kr{color:#d85a7b}.highlight .kt{color:#ffcb6b}.highlight .n{color:#c7d1d8}.highlight .na{color:#11a69f}.highlight .nb{color:#d85a7b}.highlight .bp{color:#999}.highlight .nc{color:#11a69f}.highlight .ne{color:#900}.highlight .nf{color:#5ab780}.highlight .ni{color:#11a69f}.highlight .nn{color:#11a69f}.highlight .no{color:#9d99e6}.highlight .nt{color:#de3581}.highlight .nv{color:#9680b1}.highlight .vc{color:#9680b1}.highlight .vg{color:#9680b1}.highlight .vi{color:#9680b1}.highlight .o{color:#bcd890}.highlight .ow{color:#bcd890}.highlight .m{color:#9d99e6}.highlight .mf{color:#9d99e6}.highlight .mh{color:#9d99e6}.highlight .mi{color:#9d99e6}.highlight .il{color:#9d99e6}.highlight .mo{color:#9d99e6}.highlight .s{color:#baa94a}.highlight .s1{color:#baa94a}.highlight .s2{color:#baa94a}.highlight .sb{color:#baa94a}.highlight .sc{color:#baa94a}.highlight .sd{color:#baa94a}.highlight .se{color:#baa94a}.highlight .sh{color:#baa94a}.highlight .si{color:#baa94a}.highlight .sr{color:#009926}.highlight .ss{color:#3c90f5}.highlight .sx{color:#baa94a}.highlight .w{color:#eff}.highlight .lineno,.highlight .gl{color:#8a8a8a}.highlight .hll{background-color:#373730}html{font-size:16px}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,system-ui,BlinkMacSystemFont,"Segoe UI","Segoe UI Emoji","Segoe UI Symbol","Apple Color Emoji",Roboto,Helvetica,Arial,sans-serif;color:#959595;background-color:#181818;-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;overflow-wrap:break-word}h1,h2,h3,h4,h5,h6,p,blockquote,pre,ul,ol,dl,figure,div.highlight,figure.highlight{margin-bottom:15px}hr{margin-top:30px;margin-bottom:30px}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{color:#bbb;font-weight:500}a{color:#5691cd;text-decoration:none}a:visited{color:#80bbff}a:hover{color:#959595;text-decoration:underline #999;text-underline-offset:3px}.social-media-list a:hover{text-decoration:none}.social-media-list a:hover .username{text-decoration:underline}blockquote{color:#999;border-left:4px solid #2b2b2b;padding-left:15px;font-size:1.05rem;font-style:italic}blockquote>:last-child{margin-bottom:0}blockquote i,blockquote em{font-style:normal}pre,code{font-family:"Menlo","Inconsolata","Consolas","Roboto Mono","Ubuntu Mono","Liberation Mono","Courier New",monospace;background-color:#222}@media screen and (max-width: 600px){pre,code{font-family:monospace}}pre{padding:8px 12px;font-size:15px;line-height:1.4;color:#bbb;overflow-x:auto}pre>code{display:inline-block;width:100%}div.highlight,figure.highlight{border:1px solid #2b2b2b;border-radius:3px}div.highlight pre,figure.highlight pre{margin:0}div.highlight table,div.highlight tbody,div.highlight th,div.highlight tr,div.highlight td,figure.highlight table,figure.highlight tbody,figure.highlight th,figure.highlight tr,figure.highlight td{margin:0;padding:0;border:0}div.highlight .lineno,div.highlight .gl,figure.highlight .lineno,figure.highlight .gl{text-align:right}figure.highlight table{margin:-8px -12px -14px}figure.highlight td.gutter{border-right:1px solid #2b2b2b}figure.highlight td.code{width:100%}code.highlighter-rouge{padding:1px 5px;font-size:14px;border:1px solid #2b2b2b;border-radius:3px}.wrapper{max-width:800px;margin:0 auto;padding:0 30px}@media screen and (max-width: 600px){.wrapper{padding-right:18px;padding-left:18px}}.wrapper:after{content:"";display:table;clear:both}.orange{color:#f66a0a}.grey{color:#828282}.svg-icon{width:1.25em;height:1.25em;display:inline-block;fill:currentColor;vertical-align:text-bottom;overflow:visible}table{margin-bottom:30px;width:100%;text-align:left;color:#959595;border-collapse:collapse;border:1px solid #2b2b2b}table tr:nth-child(even){background-color:#222}table th,table td{padding:10px 15px}table th{background-color:#323232;border:1px solid #3e3e3e}table td{border:1px solid #2b2b2b}@media screen and (max-width: 800px){table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}}.site-header{position:relative;width:100%;min-height:55.95px;line-height:54px;background-color:#181818;border-top:5px solid #999;border-bottom:1px solid #2b2b2b}.site-title{font-size:1.625rem;font-weight:300;letter-spacing:-1px;margin-bottom:0;float:left}@media screen and (max-width: 600px){.site-title{padding-right:45px}}.site-title,.site-title:visited{color:#a6a6a6}.site-nav{float:right;border:none;background-color:inherit}.site-nav label[for="nav-trigger"],.site-nav #nav-trigger{display:none}.site-nav .nav-item{color:#959595}.site-nav .nav-item:not(:last-child){margin-right:15px}@media screen and (max-width: 600px){.site-nav{position:absolute;top:9px;right:18px;background-color:#181818;border:1px solid #2b2b2b;border-radius:5px;text-align:right}.site-nav label[for="nav-trigger"]{display:block;float:right;width:36px;height:36px;cursor:pointer}.site-nav .menu-icon{float:right;width:36px;height:26px;line-height:0;padding-top:18px;text-align:center}.site-nav .menu-icon::before{font-family:"Font Awesome 7 Free";font-weight:900}.site-nav .menu-icon>svg path{fill:#999}.site-nav #nav-trigger ~ label[for=nav-trigger] .menu-icon::before{content:"\f0c9";font-size:1.25em}.site-nav #nav-trigger ~ .nav-items{clear:both;display:none}.site-nav #nav-trigger:checked ~ label[for=nav-trigger] .menu-icon::before{content:"\f00d";font-size:1.5em}.site-nav #nav-trigger:checked ~ .nav-items{display:block;padding-bottom:5px}.site-nav #nav-trigger:checked ~ .nav-items .nav-item{margin-left:20px;padding:5px 10px}.site-nav .nav-item{display:block;margin-right:15px;padding:5px 0;color:#959595;line-height:1.5}}.site-footer{border-top:1px solid #2b2b2b;padding:30px 0}.footer-heading{font-size:1.125rem;margin-bottom:15px}.feed-subscribe .svg-icon{padding:5px 5px 2px 0}.contact-list,.social-media-list{list-style:none;margin-left:0}.footer-col-wrapper,.social-links{font-size:.9375rem;color:#858585}.footer-col{margin-bottom:15px}.footer-col-1,.footer-col-2{width:calc(50% - (30px / 2))}.footer-col-3{width:calc(100% - (30px / 2))}@media screen and (min-width: 800px){.footer-col-1{width:calc(35% - (30px / 2))}.footer-col-2{width:calc(20% - (30px / 2))}.footer-col-3{width:calc(45% - (30px / 2))}}@media screen and (min-width: 600px){.footer-col-wrapper{display:flex}.footer-col{width:calc(100% - (30px / 2));padding:0 15px}.footer-col:first-child{padding-right:15px;padding-left:0}.footer-col:last-child{padding-right:0;padding-left:15px}}.page-content{padding:30px 0;flex:1 0 auto}.page-heading{font-size:2rem}.post-list-heading{font-size:1.75rem}.post-list{margin-left:0;list-style:none}.post-list>li{margin-bottom:30px}.post-meta{font-size:14px;color:#858585}.post-link{display:block;font-size:1.5rem}.post-header{margin-bottom:30px;padding-bottom:18px;text-align:center;border-bottom:1px solid #2b2b2b}.post-meta .bullet-divider{padding-inline:15px}.post-meta .meta-label{font-weight:600}.post-meta .force-inline{display:inline}.post-meta .force-inline::before{content:"•";padding-inline:5px}.post-meta .post-authors{margin-top:3px}.post-title,.post-content h1{margin-bottom:10px;font-size:2.625rem;font-weight:400;letter-spacing:-1px;line-height:1.15}@media screen and (min-width: 800px){.post-title,.post-content h1{font-size:2.625rem}}.post-content{margin-bottom:30px}.post-content h1,.post-content h2,.post-content h3,.post-content h4,.post-content h5,.post-content h6{margin-top:30px}.post-content h2{font-size:1.75rem}@media screen and (min-width: 800px){.post-content h2{font-size:2rem}}.post-content h3{font-size:1.375rem}@media screen and (min-width: 800px){.post-content h3{font-size:1.625rem}}.post-content h4{font-size:1.25rem}.post-content h5{font-size:1.125rem}.post-content h6{font-size:1.0625rem}.comments-disabled-message{text-align:center;font-weight:300}.social-media-list{display:table;margin:0 auto}.social-media-list li{float:left;min-width:45px;min-height:45px;text-align:center;margin:5px 10px 5px 0}.social-media-list li:last-of-type{margin-right:0}.social-media-list li a{display:block;padding:10px 12px;border:1px solid #2b2b2b}.social-media-list li a:hover{border-color:#a6a6a6}.pagination{display:table;margin:0 auto;list-style-type:none}.pagination li{float:left;margin:0 3px;min-width:45px;min-height:45px;text-align:center}.pagination li a{display:block;text-decoration:none;border:1px solid #2b2b2b}.pagination li a:hover{border-color:#a6a6a6}.pagination li a,.pagination li div{min-width:41px;padding:10px 12px;text-align:center;box-sizing:border-box}.pagination li div{border:1px solid transparent}.pagination li div.pager-edge{color:#2b2b2b;border:1px dashed}.pagination li div.current-page{font-weight:bold}.task-list{margin-left:0;padding-left:18px}.task-list-item{list-style-type:none}.task-list-item-checkbox{position:relative;margin-right:9px;margin-left:-15px;appearance:none;border:8px solid #2b2b2b;vertical-align:text-top;z-index:-1}.task-list-item-checkbox::after{position:absolute;top:-8px;left:-3px;width:4px;height:10px;content:"";border:solid transparent;border-width:0 2px 2px 0;transform:rotate(45deg)}.task-list-item-checkbox:checked::after{border-color:#999}@media screen and (min-width: 800px){.one-half{width:calc(50% - (30px / 2))}}:root{--bg: #0d0d0d;--bg-card: #1a1a1a;--bg-elevated: #2a2a2a;--bg-table-header: #1e1e1e;--bg-table-zebra: #151515;--text: #b0b0b0;--text-heading: #ffffff;--text-muted: #666;--text-secondary: #888;--text-description: #999;--text-code: #ccc;--text-line-number: #555;--brand: #9b7dff;--brand-hover: #b39bff;--border: #1a1a1a;--border-light: #2a2a2a;--border-medium: #3a3a3a;--overlay: rgba(0, 0, 0, 0.6)}[data-theme="light"]{--bg: #ffffff;--bg-card: #f5f5f5;--bg-elevated: #e8e8e8;--bg-table-header: #e8e8e8;--bg-table-zebra: #f0f0f0;--text: #333333;--text-heading: #111111;--text-muted: #999;--text-secondary: #666;--text-description: #666;--text-code: #333;--text-line-number: #999;--brand: #7c5ccc;--brand-hover: #9a7bdb;--border: #e0e0e0;--border-light: #d0d0d0;--border-medium: #c0c0c0;--overlay: rgba(0, 0, 0, 0.5)}@keyframes fade-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-content{animation:fade-in 0.4s ease}body{background-color:var(--bg);color:var(--text)}h1,h2,h3,h4,h5,h6{color:var(--text-heading)}a{color:var(--brand)}a:hover{color:var(--brand-hover)}hr{border-color:var(--border-light)}.wrapper{max-width:1600px;margin:0 auto;padding:0 30px}.site-header{background-color:var(--bg);border-bottom:1px solid var(--border);border-top:5px solid var(--brand)}.site-header .wrapper{display:flex;align-items:center;justify-content:center}.site-header .site-title{display:flex;align-items:center;gap:10px;color:var(--text-heading);font-weight:50;text-decoration:none}.site-header .site-title:hover{text-decoration:none}.site-header .site-title .header-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover}.site-header .site-nav{display:none}.site-header .site-nav .page-link{color:var(--text);font-weight:500}.site-header .site-nav .page-link:hover{color:var(--text-heading)}@media screen and (max-width: 600px){.site-header .site-nav{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:8px}.site-header .site-nav .trigger{background-color:var(--bg-card)}.site-header .site-nav .menu-icon>svg{fill:var(--text)}}.theme-toggle{position:absolute;right:30px;background:none;border:1px solid var(--border-light);border-radius:8px;padding:6px 8px;cursor:pointer;color:var(--text);display:flex;align-items:center;justify-content:center;transition:color 0.2s ease, border-color 0.2s ease}.theme-toggle:hover{color:var(--brand);border-color:var(--brand)}.theme-toggle svg{width:18px;height:18px;fill:currentColor}.theme-toggle .icon-moon{display:none}[data-theme="light"] .theme-toggle .icon-sun{display:none}[data-theme="light"] .theme-toggle .icon-moon{display:block}.site-footer{background-color:var(--bg);border-top:1px solid var(--border);color:var(--text-muted);padding:1.5rem 0;text-align:center}.site-footer .footer-copyright{margin:0;font-size:0.9rem;display:flex;align-items:center;justify-content:center;gap:0.4rem}.site-footer .footer-separator{color:var(--text-muted)}.site-footer .footer-rss{display:inline-flex;align-items:center;gap:0.3rem;color:var(--text-muted)}.site-footer .footer-rss:hover{color:var(--brand)}.site-footer a{color:var(--brand)}.hero-section{margin-bottom:2rem}.hero-section .hero-card{display:flex;background:var(--bg-card);border-radius:16px;overflow:hidden;text-decoration:none;color:inherit}.hero-section .hero-card:hover{text-decoration:none}.hero-section .hero-image{position:relative;width:50%;min-height:300px;overflow:hidden}.hero-section .hero-image>img{width:100%;height:100%;object-fit:cover;transition:transform 0.3s ease}.hero-section .hero-image .card-author-badge{position:absolute;top:12px;left:12px;background:var(--overlay);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#ffffff;font-size:0.75rem;font-weight:500;padding:4px 10px;border-radius:6px;display:flex;align-items:center;gap:6px}.hero-section .hero-image .card-author-badge img{width:20px;height:20px;border-radius:50%;object-fit:cover}.hero-section .hero-image .card-date-badge{position:absolute;top:12px;right:12px;background:var(--overlay);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#ffffff;font-size:0.75rem;font-weight:500;padding:4px 10px;border-radius:6px}.hero-section .hero-card:hover .hero-image img{transform:scale(1.03)}.hero-section .hero-content{width:50%;padding:2.5rem;display:flex;flex-direction:column;justify-content:center}.hero-section .hero-content .hero-title{font-size:1.8rem;font-weight:700;color:var(--text-heading);margin-bottom:0.75rem;line-height:1.3}.hero-section .hero-content .hero-description{color:var(--text-description);font-size:1rem;line-height:1.6;margin-bottom:1rem}.hero-section .hero-content .hero-date{color:var(--text-muted);font-size:0.85rem}.home-main{display:flex;gap:2.5rem}.post-grid{flex:1;display:grid;grid-template-columns:repeat(3, 1fr);gap:1.5rem}.post-card{background:var(--bg-card);border-radius:12px;overflow:hidden;text-decoration:none;color:inherit;transition:transform 0.2s ease, box-shadow 0.2s ease;display:flex;flex-direction:column}.post-card:hover{text-decoration:none}.post-card .card-image-wrapper{position:relative;overflow:hidden;aspect-ratio:16 / 10}.post-card .card-image-wrapper img{width:100%;height:100%;object-fit:cover;transition:transform 0.3s ease}.post-card .card-image-wrapper .card-author-badge{position:absolute;top:12px;left:12px;background:var(--overlay);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#ffffff;font-size:0.75rem;font-weight:500;padding:4px 10px;border-radius:6px;display:flex;align-items:center;gap:6px}.post-card .card-image-wrapper .card-author-badge img{width:20px;height:20px;border-radius:50%;object-fit:cover}.post-card .card-image-wrapper .card-date-badge{position:absolute;top:12px;right:12px;background:var(--overlay);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#ffffff;font-size:0.75rem;font-weight:500;padding:4px 10px;border-radius:6px}.post-card:hover .card-image-wrapper img{transform:scale(1.05)}.post-card .card-body{padding:1.2rem;flex:1;display:flex;flex-direction:column}.post-card .card-body .card-title{font-size:1.05rem;font-weight:600;color:var(--text-heading);margin-bottom:0.5rem;line-height:1.4}.post-card .card-body .card-description{color:var(--text-secondary);font-size:0.88rem;line-height:1.5;flex:1}.post-card .card-body .card-reading-time{color:var(--text-muted);font-size:0.78rem;margin-top:0.5rem}.author-sidebar{width:260px;flex-shrink:0;position:sticky;top:2rem;align-self:flex-start}.author-sidebar .sidebar-inner{background:var(--bg-card);border-radius:16px;padding:2rem 1.5rem;text-align:center}.author-sidebar .sidebar-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;margin-bottom:1rem}.author-sidebar .sidebar-name{color:var(--text-heading);font-size:1.1rem;font-weight:600;margin-bottom:0.3rem}.author-sidebar .sidebar-bio{color:var(--text-secondary);font-size:0.85rem;line-height:1.5;margin-bottom:1.2rem}.author-sidebar .sidebar-social{display:flex;justify-content:center;gap:1rem;margin-bottom:1.5rem}.author-sidebar .sidebar-social a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--bg-elevated);color:var(--text);transition:background 0.2s ease, color 0.2s ease}.author-sidebar .sidebar-social a:hover{background:var(--brand);color:#ffffff}.author-sidebar .sidebar-social a svg{width:18px;height:18px;fill:currentColor}.author-sidebar .sidebar-btn{display:inline-block;background:var(--brand);color:#ffffff;padding:10px 24px;border-radius:8px;font-weight:600;font-size:0.9rem;text-decoration:none;transition:background 0.2s ease}.author-sidebar .sidebar-btn:hover{background:var(--brand-hover);text-decoration:none;color:#ffffff}.post-cover{width:100%;border-radius:16px;overflow:hidden;margin-bottom:2rem}.post-cover img{width:100%;max-height:400px;object-fit:cover;display:block}.post-header{text-align:left}.post-header .post-title{color:var(--text-heading);font-weight:700}.post-meta{color:var(--text-muted);display:flex;align-items:center;justify-content:space-between}.post-meta-left{display:flex;align-items:center;gap:10px}.post-author-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}.post-author-name{display:block;font-weight:600;color:var(--text-heading)}.reading-time{color:var(--text-muted);font-size:0.85rem}.post-share-btn{background:none;cursor:pointer;padding:6px 14px;border:1px solid var(--border-light);border-radius:8px;color:var(--text);text-decoration:none;font-size:0.85rem;font-family:inherit}.post-share-btn:hover{color:var(--text-heading);border-color:var(--brand)}.post-tags{display:flex;flex-wrap:wrap;gap:0.5rem;margin-bottom:2rem}.post-tags .tag-badge{display:inline-block;background:var(--bg-card);color:var(--brand);padding:4px 12px;border-radius:20px;font-size:0.8rem;font-weight:500;text-decoration:none}.post-tags .tag-badge:hover{background:var(--bg-elevated);text-decoration:none}.post-toc{background:var(--bg-card);border-radius:12px;padding:1.2rem 1.5rem;margin-bottom:2rem}.post-toc ul{list-style:none;padding:0;margin:0}.post-toc ul li{padding:0.25rem 0}.post-toc ul li a{color:var(--text);text-decoration:none;font-size:0.9rem}.post-toc ul li a:hover{color:var(--brand)}.post-toc ul .toc-h3{padding-left:1rem}.post-content{color:var(--text);line-height:1.8}.post-content h1,.post-content h2,.post-content h3,.post-content h4,.post-content h5,.post-content h6{color:var(--text-heading)}.post-content a{color:var(--brand)}.post-content blockquote{border-left:3px solid var(--brand);color:var(--text-secondary);background:var(--bg-card);padding:1rem 1.5rem;border-radius:0 8px 8px 0}.post-content code{background:var(--bg-card);color:var(--text-code);padding:2px 6px;border-radius:4px;font-size:0.9em}.post-content pre{background:var(--bg-card);border:1px solid var(--border-light);border-radius:8px;padding:1rem;overflow-x:auto}.post-content pre code{padding:0;background:none}.post-content table{border-collapse:collapse;width:100%}.post-content table th{background:var(--bg-table-header);color:var(--text-heading);border:1px solid var(--border-light);padding:0.6rem 1rem}.post-content table td{border:1px solid var(--border-light);padding:0.6rem 1rem}.post-content table tr:nth-child(even){background:var(--bg-table-zebra)}.post-content img{border-radius:8px;max-width:100%;height:auto;display:block;margin:1.5rem auto}.post-content img.emoji{display:inline;margin:0;border-radius:0}.page-content{background:var(--bg)}.page-content .page-heading{color:var(--text-heading)}.page-content ul a{color:var(--brand)}.tag-sphere-wrapper{display:flex;justify-content:center;margin-bottom:2rem}.tag-sphere{position:relative;width:500px;height:500px}.tag-sphere-item{position:absolute;top:50%;left:50%;text-decoration:none;color:var(--text);white-space:nowrap;transition:color 0.2s ease, transform 0.2s ease;--ratio: calc((var(--i) + 0.5) / var(--total));--dist: calc(220px * sqrt(var(--ratio)));--angle: calc(var(--i) * 2.39996323);--x: calc(var(--dist) * cos(var(--angle)));--y: calc(var(--dist) * sin(var(--angle)));transform:translate(-50%, -50%) translate(var(--x), var(--y))}.tag-sphere-item:hover{color:var(--brand);text-decoration:none;transform:translate(-50%, -50%) translate(var(--x), var(--y)) scale(1.15)}.tag-sphere-1{font-size:0.85rem}.tag-sphere-2{font-size:1rem}.tag-sphere-3{font-size:1.2rem;font-weight:500}.tag-sphere-4{font-size:1.5rem;font-weight:600}.tag-sphere-5{font-size:1.8rem;font-weight:700;color:var(--brand)}@media screen and (max-width: 600px){.tag-sphere{width:320px;height:320px}.tag-sphere-item{--dist: calc(140px * sqrt(var(--ratio)));--x: calc(var(--dist) * cos(var(--angle)));--y: calc(var(--dist) * sin(var(--angle)))}}.tags-page h3{color:var(--brand);border-bottom:1px solid var(--border-light);padding-bottom:0.4rem}.tags-page ul{list-style:none;padding-left:0}.tags-page ul li{padding:0.3rem 0}.tags-page ul li a{color:var(--text);text-decoration:none}.tags-page ul li a:hover{color:var(--brand)}.post-nav{display:flex;justify-content:space-between;gap:1.5rem;margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border-light)}.post-nav-link{display:flex;flex-direction:column;gap:0.3rem;text-decoration:none;max-width:48%}.post-nav-link:hover{text-decoration:none}.post-nav-link:hover .post-nav-title{color:var(--brand)}.post-nav-prev{align-items:flex-start}.post-nav-next{align-items:flex-end;margin-left:auto;text-align:right}.post-nav-label{font-size:0.8rem;color:var(--text-muted)}.post-nav-title{font-size:0.95rem;font-weight:600;color:var(--text-heading);transition:color 0.2s ease}.code-copy-btn{position:absolute;top:8px;right:8px;background:var(--bg-elevated);color:var(--text);border:1px solid var(--border-medium);border-radius:6px;padding:4px 10px;font-size:0.75rem;font-family:inherit;cursor:pointer;opacity:0;transition:opacity 0.2s ease, background 0.2s ease, color 0.2s ease}.code-copy-btn:hover{background:var(--brand);color:#fff;border-color:var(--brand)}pre:hover .code-copy-btn{opacity:1}.back-to-top{position:fixed;bottom:2rem;right:2rem;width:44px;height:44px;border:1px solid var(--border-light);border-radius:50%;background:var(--bg-card);color:var(--text);font-size:1.3rem;cursor:pointer;opacity:0;visibility:hidden;transition:opacity 0.3s ease, visibility 0.3s ease, background 0.2s ease, color 0.2s ease;z-index:100}.back-to-top.visible{opacity:1;visibility:visible}.back-to-top:hover{background:var(--brand);color:#fff;border-color:var(--brand)}div.highlight,figure.highlight{border:none !important}pre{border:1px solid var(--border-light) !important;border-radius:8px !important;background:var(--bg-card) !important}pre a::before{background:var(--bg-table-zebra);color:var(--text-line-number)}@media screen and (max-width: 1200px){.post-grid{grid-template-columns:repeat(2, 1fr)}}@media screen and (max-width: 900px){.hero-section .hero-card{flex-direction:column}.hero-section .hero-image{width:100%;min-height:200px}.hero-section .hero-content{width:100%;padding:1.5rem}.home-main{flex-direction:column-reverse}.author-sidebar{width:100%;position:static}.author-sidebar .sidebar-inner{display:flex;align-items:center;gap:1.5rem;text-align:left;padding:1.5rem}.author-sidebar .sidebar-avatar{width:60px;height:60px;margin-bottom:0;flex-shrink:0}.author-sidebar .sidebar-info{flex:1}.author-sidebar .sidebar-name{margin-bottom:0.2rem}.author-sidebar .sidebar-bio{margin-bottom:0.8rem}.author-sidebar .sidebar-social{justify-content:flex-start;margin-bottom:0}.author-sidebar .sidebar-btn{display:none}.post-grid{grid-template-columns:repeat(2, 1fr)}}@media screen and (max-width: 600px){.hero-section .hero-content .hero-title{font-size:1.3rem}.post-grid{grid-template-columns:1fr}.author-sidebar .sidebar-inner{flex-direction:column;text-align:center}.author-sidebar .sidebar-social{justify-content:center}}
