:root{--bg: #05060d;--fg: #e7edf7;--muted: #8a97ad;--accent: #9d4edd;--accent-2: #78c8ff;--border: rgba(157, 78, 221, .22);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang TC,Microsoft JhengHei,sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}html{scroll-behavior:smooth}body{background:radial-gradient(1100px 700px at 75% -10%,#1a1033 0%,transparent 60%),radial-gradient(900px 600px at 5% 110%,#0b1530 0%,transparent 55%),var(--bg);background-repeat:no-repeat;background-attachment:fixed;color:var(--fg);-webkit-font-smoothing:antialiased;overflow:hidden}.app{position:relative;width:100vw;height:100vh;overflow:hidden}.game-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block}.hud-top{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:18px clamp(16px,4vw,36px);pointer-events:none;z-index:5}.hud-brand{font-weight:800;letter-spacing:2px;font-size:1.05rem}.dotc{color:var(--accent)}.hud-hint{color:var(--muted);font-size:.82rem;font-family:ui-monospace,monospace}.enter-prompt{position:absolute;bottom:38px;left:50%;transform:translate(-50%);padding:12px 22px;border-radius:999px;background:#080a14cc;border:1px solid var(--c, var(--accent));box-shadow:0 0 26px color-mix(in srgb,var(--c, var(--accent)) 45%,transparent);font-size:.95rem;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:5;animation:rise .18s ease}@keyframes rise{0%{opacity:0;transform:translate(-50%,8px)}}.enter-prompt b{color:var(--c, var(--accent))}.key{display:inline-grid;place-items:center;width:26px;height:26px;margin-right:8px;border-radius:6px;border:1px solid var(--c, var(--accent));font-family:ui-monospace,monospace;font-weight:700;font-size:.85rem;vertical-align:middle}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:24px;background:#04050cb8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:20;animation:fade .2s ease}@keyframes fade{0%{opacity:0}}.intro{max-width:560px;text-align:center}.intro-kicker{font-family:ui-monospace,monospace;color:var(--accent-2);letter-spacing:3px;font-size:.82rem;margin-bottom:14px}.intro-title{font-size:clamp(2.2rem,7vw,3.6rem);font-weight:800}.glow{color:var(--accent);text-shadow:0 0 28px rgba(157,78,221,.65)}.intro-desc{margin:20px auto 24px;color:var(--muted);line-height:1.8;max-width:460px}.intro-keys{list-style:none;display:flex;flex-direction:column;gap:8px;color:var(--muted);font-size:.9rem;margin-bottom:30px}kbd{display:inline-block;min-width:22px;padding:2px 7px;margin:0 2px;border:1px solid var(--border);border-bottom-width:2px;border-radius:5px;background:#9d4edd1a;font-family:ui-monospace,monospace;font-size:.82rem;color:var(--fg)}.btn{display:inline-block;padding:12px 26px;border-radius:999px;font-weight:600;font-size:.95rem;text-decoration:none;border:1px solid transparent;cursor:pointer;transition:transform .16s,box-shadow .2s,border-color .2s}.btn:hover{transform:translateY(-2px)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{box-shadow:0 8px 30px #9d4edd80}.btn-ghost{color:var(--fg);border-color:var(--border);background:#9d4edd14}.btn-ghost:hover{border-color:var(--accent)}.panel{position:relative;width:min(640px,92vw);max-height:82vh;overflow-y:auto;padding:34px;border-radius:18px;border:1px solid var(--border);background:linear-gradient(160deg,#16102aeb,#080a16eb);box-shadow:0 30px 80px #0009;animation:pop .2s ease}@keyframes pop{0%{opacity:0;transform:scale(.96) translateY(10px)}}.panel-close,.terminal-close{position:absolute;top:16px;right:18px;width:30px;height:30px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;transition:color .2s,border-color .2s}.panel-close:hover,.terminal-close:hover{color:var(--fg);border-color:var(--accent)}.panel-head{display:flex;align-items:baseline;gap:12px;margin-bottom:22px}.panel-head h2{font-size:1.9rem;letter-spacing:1px}.panel-head span{color:var(--muted);letter-spacing:2px}.panel-p{color:var(--muted);line-height:1.85;margin-bottom:12px}.panel-foot{margin-top:22px;color:var(--muted);font-size:.8rem;font-family:ui-monospace,monospace}.tags{display:flex;flex-wrap:wrap;gap:9px;margin-top:16px}.tag{padding:6px 13px;border:1px solid var(--border);border-radius:8px;font-size:.85rem;background:#9d4edd12}.cards{display:grid;grid-template-columns:1fr;gap:14px}.card{padding:20px;border:1px solid var(--border);border-radius:14px;background:#9d4edd0d;transition:border-color .2s,transform .2s}.card:hover{border-color:var(--accent);transform:translate(4px)}.card-top{display:flex;justify-content:space-between;margin-bottom:12px}.card-tag{font-family:ui-monospace,monospace;font-size:.7rem;letter-spacing:2px;color:var(--accent-2);border:1px solid var(--border);padding:3px 8px;border-radius:6px}.card-year{color:var(--muted);font-size:.8rem}.card-thumb{margin:-20px -20px 16px;border-radius:14px 14px 0 0;overflow:hidden;aspect-ratio:4 / 3;background:#9d4edd14;border-bottom:1px solid var(--border)}.card-thumb img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;transition:transform .35s ease}a.card-link:hover .card-thumb img{transform:scale(1.04)}.card h3{margin-bottom:6px}.card-desc{color:var(--muted);font-size:.92rem;line-height:1.5}a.card-link{display:block;text-decoration:none;color:inherit}a.card-link:hover{box-shadow:0 0 18px #9d4edd40}.card-go{display:inline-block;margin-top:12px;font-size:.82rem;font-weight:600;color:var(--accent-2);opacity:.85;transition:opacity .2s,transform .2s}a.card-link:hover .card-go{opacity:1;transform:translate(3px)}.contact-links{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}.terminal-wrap{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:24px;background:#04050cc7;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:60;animation:fade .2s ease}.terminal{width:min(760px,94vw);height:min(560px,80vh);display:flex;flex-direction:column;border-radius:12px;overflow:hidden;border:1px solid rgba(157,78,221,.4);box-shadow:0 30px 90px #000000b3,0 0 60px #9d4edd2e;animation:pop .2s ease}.terminal-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#12101f;border-bottom:1px solid rgba(157,78,221,.25)}.terminal-bar .dot{width:12px;height:12px;border-radius:50%}.dot.red{background:#ff5f57}.dot.yellow{background:#febc2e}.dot.green{background:#28c840}.terminal-title{margin-left:10px;color:var(--muted);font-size:.8rem;font-family:ui-monospace,monospace}.terminal-close{position:static;margin-left:auto}.terminal-body{flex:1;overflow-y:auto;padding:16px 18px;background:#0a0812;font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:.9rem;line-height:1.55}.tline{white-space:pre-wrap;word-break:break-word}.tline.sys{color:var(--accent)}.tline.cmd{color:var(--fg)}.tline.out{color:#b9c6da}.tline.err{color:#ff7a90}.tinput-row{display:flex;gap:8px;align-items:center;margin-top:4px}.prompt{color:#5ad1a5;white-space:nowrap}.tinput{flex:1;background:transparent;border:none;outline:none;color:var(--fg);font-family:inherit;font-size:inherit;caret-color:var(--accent)}@media(max-width:640px){.hud-hint{display:none}}.mode-toggle{position:fixed;top:16px;right:18px;z-index:50;padding:9px 16px;border-radius:999px;border:1px solid var(--border);background:#0c0a18d1;color:var(--fg);font-size:.85rem;font-weight:600;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:border-color .2s,box-shadow .2s,transform .16s}.mode-toggle:hover{border-color:var(--accent);box-shadow:0 0 22px #9d4edd66;transform:translateY(-1px)}.term-btn{position:fixed;bottom:22px;right:22px;z-index:50;display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border-radius:12px;border:1px solid rgba(157,78,221,.5);background:#0c0a18d9;color:var(--fg);font-size:.9rem;font-weight:600;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 0 22px #9d4edd47;transition:border-color .2s,box-shadow .2s,transform .16s}.term-btn:hover{transform:translateY(-2px);box-shadow:0 0 30px #9d4edd80}.term-btn.is-open{border-color:var(--accent);background:#281846eb}.term-glyph{font-family:ui-monospace,monospace;font-weight:800;color:#5ad1a5;letter-spacing:-1px}.intro-note{margin:-10px auto 26px;max-width:440px;padding:12px 16px;border:1px dashed var(--border);border-radius:12px;color:var(--muted);font-size:.88rem;line-height:1.6}.intro-note b{color:var(--accent)}body.mode-classic{overflow-y:auto}body.mode-classic .app{height:auto;min-height:100vh;overflow:visible}.particle-canvas{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}.classic{position:relative;z-index:1}.classic main,.c-nav,.c-footer{position:relative;z-index:1}.c-nav{position:sticky;top:0;z-index:50;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:18px clamp(20px,5vw,48px);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(180deg,rgba(5,6,13,.78),transparent)}.c-brand{justify-self:start;font-weight:800;letter-spacing:2px;color:var(--fg);text-decoration:none}.c-links{justify-self:center;display:flex;gap:clamp(14px,3vw,32px)}.c-links a{color:var(--muted);text-decoration:none;font-size:.9rem;position:relative;transition:color .2s}.c-links a:hover{color:var(--fg)}.c-links a.is-active{color:var(--accent)}.c-links a.is-active:after{content:"";position:absolute;left:0;bottom:-6px;width:100%;height:2px;background:var(--accent);box-shadow:0 0 8px var(--accent)}.c-mode-toggle{justify-self:end;padding:9px 16px;border-radius:999px;border:1px solid var(--border);background:#9d4edd1f;color:var(--fg);font-size:.85rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .2s,border-color .2s,transform .1s}.c-mode-toggle:hover{background:#9d4edd3d;border-color:var(--accent);transform:translateY(-1px)}.c-section{max-width:1100px;margin:0 auto;padding:clamp(70px,12vh,140px) clamp(20px,5vw,48px);scroll-margin-top:80px}.c-head{display:flex;align-items:baseline;gap:14px;margin-bottom:40px}.c-head h2{font-size:clamp(1.6rem,4vw,2.4rem)}.c-head span{color:var(--muted);letter-spacing:2px;font-size:.95rem}.c-hero{min-height:92vh;display:flex;flex-direction:column;justify-content:center}.c-kicker{color:var(--accent-2);font-family:ui-monospace,monospace;letter-spacing:3px;font-size:.85rem;margin-bottom:20px}.c-hero-title{font-size:clamp(2.4rem,8vw,5rem);line-height:1.05;font-weight:800;letter-spacing:-1px}.c-hero-sub{font-size:clamp(1.2rem,3.5vw,2rem);color:var(--muted);font-weight:600}.c-hero-desc{margin-top:26px;max-width:560px;color:var(--muted);line-height:1.7}.c-actions{margin-top:38px;display:flex;gap:16px;flex-wrap:wrap}.c-about{display:grid;grid-template-columns:1.6fr 1fr;gap:48px}.c-about-p{color:var(--muted);line-height:1.9;margin-bottom:12px}.c-skills-label{font-family:ui-monospace,monospace;color:var(--accent-2);font-size:.8rem;letter-spacing:2px;margin-bottom:16px}.c-skills ul{list-style:none;display:flex;flex-wrap:wrap;gap:10px}.c-skills li{padding:7px 14px;border:1px solid var(--border);border-radius:8px;font-size:.88rem;background:#9d4edd0f}.c-head-row{display:flex;align-items:baseline;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:40px}.c-head-row .c-head{margin-bottom:0}.c-head-link{color:var(--accent-2);text-decoration:none;font-size:.9rem;font-weight:600;white-space:nowrap;transition:transform .2s}.c-head-link:hover{text-decoration:underline;transform:translate(2px)}.c-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px}.c-cards .card{padding:26px;border-radius:16px}.c-cards .card:hover{transform:translateY(-6px)}.c-cards .card-thumb{margin:-26px -26px 18px;border-radius:16px 16px 0 0}.c-footer{max-width:1100px;margin:0 auto;padding:30px clamp(20px,5vw,48px) 60px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:var(--muted);font-size:.85rem;border-top:1px solid var(--border)}.blog-index{min-height:70vh;max-width:1040px}.blog-list{display:grid;gap:18px}.blog-card{display:block;padding:24px 26px;border:1px solid var(--border);border-radius:16px;background:#9d4edd0d;text-decoration:none;color:inherit;transition:border-color .2s,transform .2s,box-shadow .2s}.blog-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 0 22px #9d4edd38}.blog-date{font-family:ui-monospace,monospace;font-size:.8rem;letter-spacing:1px;color:var(--accent-2)}.blog-card h3{margin:8px 0 6px;font-size:1.3rem}.blog-excerpt{color:var(--muted);line-height:1.6;font-size:.95rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.blog-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}.blog-readmore{display:inline-block;margin-top:14px;font-size:.85rem;font-weight:600;color:var(--accent-2)}.blog-card:hover .blog-readmore{text-decoration:underline}.blog-card.has-thumb{padding:0;overflow:hidden;display:grid;grid-template-columns:220px 1fr;align-items:stretch}.blog-card.has-thumb .blog-card-body{padding:22px 24px}.blog-card-thumb{position:relative;background:#0000000d;overflow:hidden}.blog-card-thumb img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}.blog-card.has-thumb:hover .blog-card-thumb img{transform:scale(1.04)}@media(max-width:560px){.blog-card.has-thumb{grid-template-columns:1fr}.blog-card-thumb{aspect-ratio:16 / 9}}.post-hero{margin:22px 0 10px;border-radius:16px;overflow:hidden;line-height:0}.post-hero img{width:100%;max-height:420px;object-fit:cover;display:block}.pagination{display:flex;flex-wrap:wrap;gap:8px;margin-top:32px;align-items:center}.page-btn{min-width:38px;padding:8px 14px;border:1px solid var(--border);border-radius:10px;background:#fff;color:var(--muted);font-size:.9rem;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.page-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.page-btn:disabled{opacity:.4;cursor:default}.page-num{padding:8px 0;text-align:center}.page-btn.is-active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.page-ellipsis{padding:0 4px;color:var(--muted);align-self:flex-end}.archive-head{display:flex;align-items:baseline;justify-content:space-between}.archive-all{font-size:.78rem;color:var(--accent-2);text-decoration:none}.archive-all:hover{text-decoration:underline}.archive-filters{display:flex;flex-wrap:wrap;align-items:flex-start;gap:14px;margin-bottom:6px}.archive-tag-select{height:38px;padding:0 16px;border:1px solid var(--border);border-radius:999px;background:#fff;color:var(--fg);font-size:.9rem;line-height:1;cursor:pointer}.archive-tag-select:hover{border-color:var(--accent)}.about-page{max-width:760px}.about-name{font-size:clamp(1.8rem,5vw,2.6rem);font-weight:800;margin-bottom:8px}.about-pronouns{display:inline-block;padding:6px 16px;border-radius:999px;background:#7b2cbf1a;color:var(--accent);font-weight:600;letter-spacing:1px;margin-bottom:26px}.about-body p{color:#2c3340;line-height:1.9;margin-bottom:14px;font-size:1.02rem}.about-contact{margin-top:34px;padding-top:26px;border-top:1px solid var(--border)}.about-contact .side-label{margin-bottom:8px}.about-contact a{font-size:1.1rem;font-weight:600;color:var(--accent-2);text-decoration:none}.about-contact a:hover{text-decoration:underline}.archive-page{max-width:820px}.archive-count{color:var(--muted);font-size:.9rem;margin:-20px 0 24px}.archive-table{list-style:none;margin:0;padding:0}.archive-row{display:grid;grid-template-columns:56px 1fr auto;align-items:baseline;gap:16px;padding:14px 8px;border-bottom:1px solid var(--border)}.archive-row:first-child{border-top:1px solid var(--border)}.archive-no{font-family:ui-monospace,monospace;font-size:.85rem;font-weight:700;color:var(--accent)}.archive-title{color:var(--fg);text-decoration:none;font-weight:600;line-height:1.5}.archive-title:hover{color:var(--accent)}.archive-rdate{color:var(--muted);font-size:.85rem;font-family:ui-monospace,monospace;white-space:nowrap}@media(max-width:560px){.archive-row{grid-template-columns:44px 1fr}.archive-rdate{grid-column:2;font-size:.78rem}}.blog-post{max-width:760px}.blog-back{display:inline-block;margin-bottom:24px;color:var(--muted);text-decoration:none;font-size:.9rem}.blog-back:hover{color:var(--accent-2)}.blog-title{font-size:clamp(1.8rem,5vw,2.8rem);line-height:1.15;margin:10px 0 14px}.markdown{margin-top:32px;color:#c4cfe0;line-height:1.85;font-size:1.02rem}.markdown h2{font-size:1.5rem;margin:38px 0 14px;color:var(--fg)}.markdown h3{font-size:1.2rem;margin:28px 0 10px;color:var(--fg)}.markdown p{margin:14px 0}.markdown a{color:var(--accent-2);text-decoration:underline;text-underline-offset:2px}.markdown ul,.markdown ol{margin:14px 0 14px 24px}.markdown li{margin:6px 0}.markdown blockquote{margin:20px 0;padding:8px 18px;border-left:3px solid var(--accent);background:#9d4edd12;color:var(--muted);border-radius:0 8px 8px 0}.markdown code{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:.88em;background:#9d4edd24;padding:2px 6px;border-radius:5px}.markdown pre{margin:20px 0;padding:18px;background:#0a0812;border:1px solid var(--border);border-radius:12px;overflow-x:auto}.markdown pre code{background:none;padding:0;font-size:.85rem;line-height:1.6}.markdown table{width:100%;border-collapse:collapse;margin:20px 0;font-size:.95rem}.markdown th,.markdown td{border:1px solid var(--border);padding:8px 12px;text-align:left}.markdown th{background:#9d4edd1a}.markdown img{max-width:100%;border-radius:12px}.markdown h2,.markdown h3{scroll-margin-top:90px}body.blog-page{background:#eef1f8}body.blog-page{height:auto;min-height:100%;overflow-y:visible}body.blog-page #root{height:auto;min-height:100vh}.blog-theme{--fg: #1c1830;--muted: #586074;--accent: #7b2cbf;--accent-2: #2563eb;--border: rgba(28, 24, 48, .12);color:var(--fg);min-height:100vh}.blog-theme .c-nav{background:linear-gradient(180deg,#ffffffeb,#fff0);border-bottom:1px solid rgba(28,24,48,.06)}.blog-theme .c-mode-toggle{background:#7b2cbf1a}.blog-theme .c-mode-toggle:hover{background:#7b2cbf2e}.blog-theme .c-footer{color:var(--muted)}.cat-tabs{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:22px}.cat-tab{display:inline-flex;align-items:center;gap:4px;height:38px;padding:0 16px;border:1px solid var(--border);border-radius:999px;background:#fff;color:var(--muted);font-size:.9rem;cursor:pointer;transition:all .18s}.cat-tab:hover{border-color:var(--accent);color:var(--fg)}.cat-tab.is-active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.cat-count{opacity:.65;font-size:.8em;margin-left:2px}.blog-search{display:flex;align-items:center;gap:8px;padding:0 14px;height:46px;margin-bottom:18px;background:#fff;border:1px solid var(--border);border-radius:12px;transition:border-color .15s,box-shadow .15s}.blog-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #7b2cbf1f}.blog-search-icon{font-size:.95rem;opacity:.7}.blog-search-input{flex:1;border:none;outline:none;background:none;font-size:.95rem;color:var(--fg);min-width:0}.blog-search-input::placeholder{color:var(--muted)}.blog-search-clear{border:none;background:#7b2cbf1a;color:var(--accent);width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:.8rem;line-height:1}.blog-search-clear:hover{background:#7b2cbf33}.side-label{display:block;font-family:ui-monospace,monospace;font-size:.78rem;letter-spacing:1px;color:var(--accent);margin-bottom:10px}.tag-cloud{padding:14px 16px;margin-bottom:18px;background:#fff;border:1px solid var(--border);border-radius:14px}.tag-cloud-tags{display:flex;flex-wrap:wrap;align-items:baseline;gap:6px 9px}.cloud-tag{border:none;background:none;padding:1px 3px;cursor:pointer;color:#6b5a86;line-height:1.15;transition:color .15s,transform .15s}.cloud-tag:hover{color:var(--accent);transform:translateY(-1px)}.cloud-tag.is-active{color:var(--accent);font-weight:800;text-decoration:underline}.archive{padding:14px 16px;background:#fff;border:1px solid var(--border);border-radius:14px}.arc-year+.arc-year{border-top:1px solid var(--border)}.arc-year-btn{display:flex;align-items:center;gap:8px;width:100%;padding:9px 2px;border:none;background:none;cursor:pointer;color:var(--fg);font-size:.95rem;font-weight:600}.arc-caret{color:var(--accent);transition:transform .18s;font-size:.8rem}.arc-year-btn.is-open .arc-caret{transform:rotate(90deg)}.arc-year-label{flex:1;text-align:left}.arc-count{font-size:.75rem;font-weight:600;color:var(--accent);background:#7b2cbf1a;border-radius:999px;padding:1px 8px}.arc-months{padding:2px 0 8px 14px;border-left:1px solid var(--border);margin-left:6px}.arc-month{margin-bottom:10px}.arc-month-label{font-size:.8rem;color:var(--muted);margin-bottom:4px}.arc-month-label span{opacity:.75}.arc-month ul{list-style:none;margin:0;padding:0}.arc-month li{margin:3px 0}.arc-month li a{color:#4a4763;text-decoration:none;font-size:.86rem;line-height:1.4;display:block;transition:color .15s}.arc-month li a:hover{color:var(--accent)}.filter-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;padding:12px 16px;margin-bottom:22px;background:#7b2cbf12;border:1px solid var(--border);border-radius:12px;font-size:.9rem;color:var(--muted)}.filter-chip{color:var(--accent);margin:0 4px}.filter-count{margin-left:6px;opacity:.8}.filter-clear{border:1px solid var(--border);background:#fff;border-radius:999px;padding:5px 12px;font-size:.85rem;color:var(--muted);cursor:pointer}.filter-clear:hover{color:var(--accent);border-color:var(--accent)}.blog-theme .blog-card{background:#fff;border-color:var(--border);box-shadow:0 1px 2px #1c18300a}.blog-theme .blog-card:hover{border-color:var(--accent);box-shadow:0 12px 30px #7b2cbf24}.blog-card-top{display:flex;align-items:center;gap:12px;margin-bottom:4px}.blog-cat{display:inline-block;padding:3px 10px;border-radius:999px;background:#7b2cbf1f;color:var(--accent);font-size:.78rem;font-weight:600;text-decoration:none}a.blog-cat:hover{background:#7b2cbf38}.blog-theme .tag{background:#7b2cbf14;border-color:var(--border)}.blog-theme a.tag:hover{background:#7b2cbf2e;color:var(--accent)}.blog-layout{display:grid;grid-template-columns:minmax(0,1fr) 230px;gap:54px;align-items:start}.blog-side{position:sticky;top:90px;display:flex;flex-direction:column;gap:20px}.blog-side .tag-cloud{margin-bottom:0}@media(max-width:900px){.blog-layout{grid-template-columns:1fr;gap:0}.blog-side{display:contents}.blog-side .tag-cloud{order:-1;margin-bottom:24px}.blog-side .archive{order:1;margin-top:32px}}.blog-post-wrap{max-width:1040px;margin:0 auto;display:grid;grid-template-columns:minmax(0,1fr) 230px;gap:54px;align-items:start}.blog-theme .blog-post{max-width:100%}.blog-theme .markdown{color:#2c3340}.blog-theme .markdown h2,.blog-theme .markdown h3{color:var(--fg)}.blog-theme .markdown a{color:var(--accent-2)}.blog-theme .markdown code{background:#7b2cbf1a;color:#6d28a8}.blog-theme .markdown pre{background:#1b1830;border-color:#0000001a;color:#e7edf7}.blog-theme .markdown pre code{color:#e7edf7}.blog-theme .markdown blockquote{background:#7b2cbf0f;border-left-color:var(--accent);color:var(--muted)}.blog-theme .markdown th{background:#7b2cbf14}.toc{position:sticky;top:90px;align-self:start}.toc-title{font-family:ui-monospace,monospace;font-size:.78rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);margin-bottom:12px}.toc-nav{display:flex;flex-direction:column;border-left:1px solid var(--border);max-height:calc(100vh - 160px);overflow-y:auto;scrollbar-width:thin}.toc-link{padding:6px 0 6px 14px;margin-left:-1px;border-left:2px solid transparent;color:var(--muted);text-decoration:none;font-size:.88rem;line-height:1.45;transition:color .15s,border-color .15s}.toc-link.lv3{padding-left:28px;font-size:.82rem}.toc-link:hover{color:var(--fg)}.toc-link.is-active{color:var(--accent);border-left-color:var(--accent);font-weight:600}.post-extras{margin-top:48px;padding-top:28px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:14px}.collapse{background:#fff;border:1px solid var(--border);border-radius:14px;overflow:hidden}.collapse-head{display:flex;align-items:center;gap:10px;width:100%;padding:14px 18px;border:none;background:none;cursor:pointer;color:var(--fg);font-size:1rem;font-weight:600}.collapse-icon{font-size:1.05rem}.collapse-title{flex:1;text-align:left}.collapse-count{font-size:.75rem;font-weight:600;color:var(--accent);background:#7b2cbf1a;border-radius:999px;padding:1px 9px}.collapse-caret{color:var(--accent);transition:transform .18s}.collapse.is-open .collapse-caret{transform:rotate(90deg)}.collapse-body{padding:4px 18px 18px}.extra-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.extra-list li a{display:flex;flex-direction:column;gap:2px;padding:9px 12px;border-radius:10px;text-decoration:none;transition:background .15s}.extra-list li a:hover{background:#7b2cbf12}.extra-title{color:var(--fg);font-weight:600;font-size:.95rem}.extra-meta{color:var(--muted);font-size:.8rem}.extra-empty{color:var(--muted);font-size:.9rem;padding:4px 2px}@media(max-width:900px){.blog-post-wrap{grid-template-columns:1fr;gap:0}.toc{display:none}}@media(max-width:720px){.c-about{grid-template-columns:1fr;gap:28px}.c-links{display:none}}
