@import url("https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@300;400;500;600&family=Source+Serif+4:wght@400;600;700&family=Noto+Serif+SC:wght@400;600&display=swap");:root{color-scheme:dark;--bg:#010d12;--line-color-1:rgba(126,162,172,.4);--line-color-2:rgba(68,172,191,.25);--bg-strong:#001016;--bg-card:#001822;--ink:#e8f6fa;--ink-soft:#a9c7cf;--ink-light:#7ea2ac;--border:rgba(68,172,191,.26);--accent:#44acbf;--accent-strong:#77cfdf;--shadow:0 24px 50px rgba(0,6,10,.65);--radius:18px}*{box-sizing:border-box}body,html{margin:0;padding:0;font-family:IBM Plex Sans,"Noto Serif SC",sans-serif;color:var(--ink);background:transparent}body{position:relative}a{color:inherit;text-decoration:none}a:hover{color:var(--accent-strong)}.page-background{position:fixed;inset:0;pointer-events:none;background-color:var(--bg);background-image:radial-gradient(circle at 50% 46%,rgba(14,46,56,.26) 0,rgba(1,13,18,.08) 40%,var(--bg) 78%),radial-gradient(circle at 0 0,rgba(9,33,41,.22) 0,transparent 45%),radial-gradient(circle at 100% 0,rgba(8,30,38,.2) 0,transparent 42%);z-index:0}.topo-svg path{mix-blend-mode:screen;stroke-linecap:round;stroke-linejoin:round;shape-rendering:geometricPrecision;vector-effect:non-scaling-stroke}.topo-svg{transform:translateY(64px)}.page{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:42px 24px 80px}.site-header{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;border-bottom:1px solid var(--border);padding-bottom:22px}.logo-title{font-family:"Source Serif 4","Noto Serif SC",serif;font-size:30px;letter-spacing:1px}.logo-subtitle{margin:6px 0 0;font-size:14px;color:var(--ink-soft)}.site-nav{display:flex;gap:16px;flex-wrap:wrap;font-size:14px}.nav-link{padding:6px 10px;border-radius:999px;border:1px solid transparent}.nav-link:hover{border-color:var(--border);background:var(--bg-card)}.page-body{display:grid;grid-template-columns:minmax(0,1fr) 280px;grid-gap:40px;gap:40px;margin-top:40px;align-items:start}.content{min-width:0}.mobile-profile-top{display:none}.section-header h1{font-family:"Source Serif 4","Noto Serif SC",serif;font-size:32px;margin:0 0 8px}.section-header p{margin:0;color:var(--ink-soft)}.post-list{display:grid;grid-gap:24px;gap:24px;margin-top:32px}.post-card{display:grid;grid-template-columns:260px 1fr;grid-gap:22px;gap:22px;background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);padding:18px;box-shadow:var(--shadow);transition:border-color .18s ease,box-shadow .18s ease}.post-card:hover{border-color:rgba(119,207,223,.5);box-shadow:0 0 0 1px rgba(119,207,223,.2),var(--shadow)}.post-card-cover img{display:block;width:100%;height:100%;object-fit:cover;box-shadow:0 0 18px rgba(68,172,191,.28)}.post-card-cover{position:relative;display:block;aspect-ratio:16/9;overflow:hidden;border-radius:14px;border:1px solid rgba(119,207,223,.36);filter:drop-shadow(-7px 0 7px rgba(119,207,223,.12)) drop-shadow(7px 0 7px rgba(119,207,223,.12))}.post-card-body h2{font-family:"Source Serif 4","Noto Serif SC",serif;font-size:24px;margin:8px 0 10px}.post-card-body p{margin:0 0 14px;color:var(--ink-soft)}.post-meta{gap:14px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-light)}.post-meta,.post-tags{display:flex;font-size:12px}.post-tags{flex-wrap:wrap;gap:8px}.post-tags span{background:rgba(68,172,191,.2);color:var(--accent-strong);padding:4px 10px;border-radius:999px}.sidebar{position:-webkit-sticky;position:sticky;top:36px;display:flex;flex-direction:column;gap:22px}.sidebar-profile-desktop{display:block}.profile-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);padding:18px;box-shadow:var(--shadow);display:grid;grid-gap:12px;gap:12px}.profile-avatar{width:52px;height:52px;border-radius:14px;overflow:hidden;padding:3px;border:1px solid var(--border);background:var(--bg-strong);box-shadow:0 0 0 1px rgba(119,207,223,.42),0 0 14px rgba(68,172,191,.34)}.profile-avatar img{display:block;width:100%;height:100%;object-fit:contain}.profile-name{font-weight:600;margin:0}.profile-role{margin:2px 0 0}.profile-bio,.profile-role{color:var(--ink-soft);font-size:13px}.profile-bio{margin:0;line-height:1.6}.profile-links{display:flex;gap:12px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-light)}.sidebar-section{padding:16px 18px;border:1px solid var(--border);border-radius:var(--radius);background:rgba(0,24,34,.8)}.sidebar-section h3{margin:0 0 12px;font-size:13px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-light)}.simple-list{list-style:none;padding:0;margin:0;display:grid;grid-gap:8px;gap:8px;font-size:14px}.sidebar-tags{display:flex;flex-wrap:wrap;gap:8px;font-size:12px}.sidebar-tags a{background:rgba(68,172,191,.2);padding:4px 10px;border-radius:999px}.site-footer{margin-top:60px;border-top:1px solid var(--border);padding-top:24px;display:flex;justify-content:space-between;align-items:flex-start;gap:24px;color:var(--ink-soft);font-size:13px}.footer-left,.footer-right{display:grid;grid-gap:6px;gap:6px}.footer-right{text-align:right;justify-items:end;align-content:end;align-self:end}.footer-meta{margin:0;line-height:1.45}.footer-title{font-family:"Source Serif 4","Noto Serif SC",serif;font-size:18px;margin:0;color:var(--ink)}.archive-list{margin-top:28px;display:grid;grid-gap:26px;gap:26px}.archive-year h2{font-family:"Source Serif 4","Noto Serif SC",serif;margin-bottom:12px}.archive-year ul{list-style:none;padding:0;margin:0;display:grid;grid-gap:10px;gap:10px}.archive-year li{display:flex;gap:12px;align-items:center;color:var(--ink-soft)}.category-list,.tag-cloud{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}.category-list a,.tag-cloud a{padding:8px 14px;border-radius:999px;background:rgba(68,172,191,.2);color:var(--accent-strong);font-size:13px}.simple-post-list{margin-top:24px;display:grid;grid-gap:18px;gap:18px}.simple-post-list h2{margin:0 0 6px;font-family:"Source Serif 4","Noto Serif SC",serif}.prose{margin-top:24px;color:var(--ink-soft);line-height:1.8}.links-grid{margin-top:24px;display:grid;grid-gap:14px;gap:14px}.links-grid a{border:1px solid var(--border);border-radius:16px;padding:16px;background:var(--bg-card);display:grid;grid-gap:6px;gap:6px}.links-grid span{color:var(--ink-soft);font-size:13px}.post-layout{display:grid;grid-template-columns:200px minmax(0,1fr) 240px;grid-gap:32px;gap:32px;margin-top:40px}.post-layout>*{min-width:0}.post-toc-desktop{display:block}.post{background:var(--bg-card);border-radius:24px;border:1px solid var(--border);padding:28px;box-shadow:var(--shadow);min-width:0}.post-hero img{width:100%;height:auto;border-radius:18px;box-shadow:0 0 0 1px rgba(119,207,223,.38),0 0 24px rgba(68,172,191,.24)}.post-hero-meta{display:flex;gap:16px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-light);margin-top:16px}.post-hero h1{font-family:"Source Serif 4","Noto Serif SC",serif;font-size:32px;margin:12px 0 10px}.post-summary{color:var(--ink-soft);margin:0 0 20px}.post-pending{margin-top:40px;padding:28px;border:1px solid var(--border);border-radius:24px;background:linear-gradient(180deg,rgba(0,24,34,.92),rgba(0,16,24,.82)),radial-gradient(circle at top right,rgba(119,207,223,.12),transparent 45%);box-shadow:var(--shadow)}.post-pending-kicker{margin:0 0 10px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-strong)}.post-pending h1{margin:0;font-family:"Source Serif 4","Noto Serif SC",serif;font-size:32px}.post-pending-copy{margin:14px 0 0;max-width:62ch;line-height:1.8;color:var(--ink-soft)}.post-pending-slug{display:inline-flex;align-items:center;gap:10px;margin-top:18px;padding:10px 12px;border-radius:14px;border:1px solid rgba(119,207,223,.22);background:rgba(0,16,24,.72);font-size:13px}.post-pending-slug span{color:var(--ink-light);text-transform:uppercase;letter-spacing:.08em}.post-pending-slug code{font-family:JetBrains Mono,Fira Code,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;color:#d7eef5}.post-pending-status{margin:18px 0 0;color:var(--ink-soft)}.post-pending-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.post-pending-actions button{border:1px solid rgba(119,207,223,.35);border-radius:999px;padding:10px 16px;background:rgba(0,16,24,.84);color:#e8f6fa;font-size:13px;cursor:pointer}.post-pending-actions button:hover{border-color:rgba(119,207,223,.56);background:rgba(0,20,30,.92)}.post-content{line-height:1.9;color:var(--ink-soft);min-width:0}.post-content h2{font-family:"Source Serif 4","Noto Serif SC",serif;color:var(--ink);margin-top:28px}.post-content p{margin:12px 0}.post-content table{width:100%;margin:22px 0;border-collapse:collapse;border-spacing:0;border:1px solid rgba(119,207,223,.48);border-radius:16px;overflow:hidden;background:rgba(3,18,27,.74);box-shadow:0 0 0 1px rgba(119,207,223,.2),0 14px 28px rgba(0,6,10,.2)}.post-content thead th{background:rgba(68,172,191,.2);color:var(--ink);font-weight:600}.post-content td,.post-content th{padding:12px 14px;text-align:left;color:rgba(211,232,238,.82);border-right:1px solid rgba(119,207,223,.48);border-bottom:1px solid rgba(119,207,223,.48)}.post-content tr>:last-child{border-right:0}.post-content tbody tr:last-child td{border-bottom:0}.post-content tbody tr:nth-child(2n) td{background:rgba(68,172,191,.05)}.code-block{margin:18px 0;width:100%;max-width:100%;border:1px solid rgba(119,207,223,.28);border-radius:14px;background:rgba(0,16,24,.86);overflow-x:auto;overflow-y:hidden;box-shadow:0 0 0 1px rgba(119,207,223,.12),0 0 18px rgba(68,172,191,.15)}.code-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border-bottom:1px solid rgba(119,207,223,.2);background:rgba(2,20,30,.7)}.code-lang{letter-spacing:.08em;color:var(--ink-light)}.code-copy-btn,.code-lang{font-size:11px;text-transform:uppercase}.code-copy-btn{border:1px solid rgba(119,207,223,.35);border-radius:999px;padding:4px 10px;letter-spacing:.05em;color:#d9eff7;background:rgba(0,18,28,.8);cursor:pointer}.code-copy-btn:hover{border-color:rgba(119,207,223,.56);color:#f2fbff}.post-content pre{margin:0;padding:14px 16px;width:100%;min-width:0;overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;white-space:pre}.post-content code{font-family:JetBrains Mono,Fira Code,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:13px;line-height:1.6;color:#d7eef5}.post-content pre code{display:inline-block;min-width:100%;white-space:pre}.post-content li code,.post-content p code{padding:2px 6px;border-radius:8px;background:rgba(68,172,191,.18)}.post-content img{display:block;max-width:100%!important;width:auto;height:auto;margin:18px auto;border-radius:14px;box-shadow:0 0 0 1px rgba(119,207,223,.3),0 0 22px rgba(68,172,191,.22);cursor:zoom-in}.post-content figure{margin:18px 0}.post-content figure img{margin:0 auto}.image-lightbox{position:fixed;inset:0;z-index:2000;display:grid;place-items:center;background:rgba(1,8,13,.88);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);padding:3vh 3vw}.image-lightbox img{max-width:94vw;max-height:92vh;width:auto;height:auto;border-radius:14px;box-shadow:0 0 0 1px rgba(119,207,223,.3),0 0 30px rgba(68,172,191,.25);cursor:zoom-out}.image-lightbox-close{position:absolute;top:18px;right:18px;width:38px;height:38px;border:1px solid rgba(119,207,223,.35);border-radius:999px;background:rgba(0,16,24,.78);color:#d9eff7;font-size:24px;line-height:1;cursor:pointer}.post-side{display:flex;flex-direction:column;gap:16px;position:-webkit-sticky;position:sticky;top:32px;align-self:start}.post-side-section{border:1px solid var(--border);background:rgba(0,24,34,.82);border-radius:16px;padding:14px;font-size:13px}.post-side-section ul{list-style:none;padding:0;margin:10px 0 0;display:grid;grid-gap:8px;gap:8px}.side-title{margin:0;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-light)}.side-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.side-tags a{background:rgba(68,172,191,.2);padding:4px 10px;border-radius:999px}.toc{border:1px solid var(--border);border-radius:16px;background:rgba(0,24,34,.86);padding:16px;font-size:13px}.toc-title{margin:0 0 12px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-light)}.toc ul{list-style:none;padding:0;margin:0;display:grid;grid-gap:8px;gap:8px}.toc-level-3{padding-left:12px}.floating-actions{position:fixed;right:max(16px,env(safe-area-inset-right));bottom:calc(16px + env(safe-area-inset-bottom));z-index:1200;display:flex;flex-direction:column;gap:10px;align-items:flex-end;pointer-events:none}.floating-actions button{pointer-events:auto}.back-top-btn,.toc-fab-btn{border:1px solid rgba(119,207,223,.45);border-radius:12px;width:44px;height:44px;padding:0;display:grid;place-items:center;background:rgba(0,18,28,.92);color:#e8f6fa;font-size:24px;line-height:1;cursor:pointer;box-shadow:0 0 0 1px rgba(119,207,223,.18),0 10px 24px rgba(0,6,10,.45);transition:transform .12s ease,box-shadow .12s ease,border-color .16s ease,background .16s ease}.toc-fab-btn{width:44px;min-width:44px;padding:0;font-size:20px}.toc-fab-hamburger{width:16px;display:grid;grid-gap:4px;gap:4px}.toc-fab-hamburger>span{display:block;width:16px;height:2px;border-radius:999px;background:#e8f6fa}.back-top-btn:hover,.toc-fab-btn:hover{border-color:rgba(119,207,223,.62);background:rgba(0,22,34,.96)}.back-top-btn:active,.toc-fab-btn:active{transform:translateY(1px) scale(.94);box-shadow:0 0 0 1px rgba(119,207,223,.15),0 5px 14px rgba(0,6,10,.4)}.toc-fab{display:none}@media (max-width:1100px){.page-body{grid-template-columns:1fr}.sidebar{position:static}.post-layout{grid-template-columns:1fr}.post-side{position:static}.post-side-left{order:1}.post{order:2}.post-side-right{order:3}.post-toc-desktop{display:none}.toc-fab{display:block}.toc-fab-backdrop{position:fixed;inset:0;z-index:1198;border:0;background:rgba(0,8,12,.46);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.toc-fab-panel{position:fixed;right:max(12px,env(safe-area-inset-right));left:max(12px,env(safe-area-inset-left));bottom:calc(124px + env(safe-area-inset-bottom));z-index:1199;max-height:min(62vh,460px);overflow-y:auto;border:1px solid rgba(119,207,223,.35);border-radius:18px;background:rgba(0,24,34,.96);box-shadow:0 16px 40px rgba(0,6,10,.55);transform:translateY(8px);opacity:0;pointer-events:none;transition:opacity .16s ease,transform .16s ease}.toc-fab.is-open .toc-fab-panel{transform:translateY(0);opacity:1;pointer-events:auto}.toc-fab-header{position:-webkit-sticky;position:sticky;top:0;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;border-bottom:1px solid rgba(119,207,223,.22);background:rgba(0,22,32,.98)}.toc-fab-header p{margin:0;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-light)}.toc-fab-header button{border:1px solid rgba(119,207,223,.36);border-radius:999px;padding:4px 10px;background:rgba(0,16,24,.86);color:#d9eff7;font-size:11px;letter-spacing:.05em;text-transform:uppercase;cursor:pointer}.toc-fab-panel ul{list-style:none;padding:12px 14px 16px;margin:0;display:grid;grid-gap:8px;gap:8px;font-size:13px}.post-side-left .post-side-section:not(.post-nav-section){display:none}.post-card{grid-template-columns:1fr}}@media (max-width:720px){.site-header{flex-direction:column;align-items:flex-start}.site-nav{gap:10px}.page{padding:28px 18px 60px}.mobile-profile-top{display:block}.sidebar-profile-desktop{display:none}.post{padding:20px}.post-pending{margin-top:24px;padding:22px}.post-pending h1{font-size:28px}.post-content{overflow-x:hidden}.post-content table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap}.code-block{overflow-x:hidden}.code-toolbar{padding:7px 8px}.post-content pre{padding:12px;overflow-x:hidden;white-space:pre-wrap}.post-content code{font-size:12px}.post-content pre code{display:block;min-width:0;white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere;-moz-tab-size:2;tab-size:2}.site-footer{flex-direction:column;gap:14px}.footer-right{text-align:left;justify-items:start}}@media (prefers-reduced-motion:reduce){.post-card{transition:none}}