:root{--bg: #090A18;--bg2: #0E1126;--panel: #141838;--panel-2: #1A1F47;--violet: #8B5CF6;--violet-br: #A78BFA;--indigo: #6366F1;--dotnet: #512BD4;--cyan: #38BDF8;--ink: #ECEAFB;--body: #A6ABD4;--faint: #6B7099;--ok: #6ee7b7;--ok-line: #34d399;--line: rgba(139,92,246,.18);--line-2: rgba(255,255,255,.07);--code-bg: #0B0E20;--code-ink: #d6d8f5;--dot: rgba(167,139,250,.18);--halo: radial-gradient(ellipse at center, rgba(139,92,246,.22), rgba(99,102,241,.1) 40%, transparent 70%);--radius: 18px;--shadow: 0 16px 44px rgba(4,6,20,.55);--glow: 0 0 0 1px rgba(139,92,246,.4), 0 18px 54px rgba(139,92,246,.26);--maxw: 1180px;--read: 720px;--font: "Manrope", system-ui, -apple-system, sans-serif;--mono: "IBM Plex Mono", ui-monospace, monospace}[data-theme=light]{--bg: #F6F5FC;--bg2: #EEEBFA;--panel: #FFFFFF;--panel-2: #F3F1FE;--violet: #6D28D9;--violet-br: #7C3AED;--indigo: #4F46E5;--cyan: #0EA5E9;--ink: #191436;--body: #4E4A6B;--faint: #6E6A86;--ok: #047857;--ok-line: #059669;--line: rgba(109,40,217,.18);--line-2: rgba(25,20,54,.09);--code-bg: #14112B;--code-ink: #e6e7fb;--dot: rgba(109,40,217,.16);--halo: radial-gradient(ellipse at center, rgba(124,58,237,.16), rgba(99,102,241,.08) 40%, transparent 70%);--shadow: 0 16px 40px rgba(60,40,120,.12);--glow: 0 0 0 1px rgba(109,40,217,.28), 0 18px 48px rgba(109,40,217,.18)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:var(--font);color:var(--body);background:var(--bg);-webkit-font-smoothing:antialiased;font-size:18px;line-height:1.6;position:relative;overflow-x:hidden;transition:background .4s ease,color .4s ease}body:before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background-image:radial-gradient(var(--dot) 1px,transparent 1.6px);background-size:40px 40px;opacity:.5;-webkit-mask-image:linear-gradient(180deg,#000,transparent 70%);mask-image:linear-gradient(180deg,#000,transparent 70%)}body:after{content:"";position:fixed;top:-300px;left:50%;transform:translate(-50%);width:1100px;height:760px;z-index:0;pointer-events:none;background:var(--halo)}body>*{position:relative;z-index:1}h1,h2,h3,h4{color:var(--ink);margin:0;line-height:1.12;letter-spacing:-.02em;font-weight:800}a{color:inherit;text-decoration:none}.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}.mono{font-family:var(--mono)}.eyebrow{font-family:var(--mono);font-size:12.5px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--violet-br);margin:0 0 16px;display:inline-flex;align-items:center;gap:10px}.eyebrow:before{content:"";width:22px;height:2px;background:var(--violet);display:inline-block;box-shadow:0 0 8px var(--violet)}.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:15px;padding:12px 22px;border-radius:999px;cursor:pointer;border:none;transition:all .2s ease;white-space:nowrap;font-family:var(--font)}.btn-primary{background:linear-gradient(120deg,color-mix(in srgb,var(--violet) 86%,transparent),color-mix(in srgb,var(--indigo) 86%,transparent));color:#fff;border:1px solid rgba(255,255,255,.18);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 10px 26px #8b5cf657,inset 0 1px #ffffff47}.btn-primary:hover{transform:translateY(-2px)}.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}.btn-ghost:hover{border-color:var(--violet);color:var(--violet-br)}.arrow{display:inline-flex;align-items:center;gap:8px;color:var(--violet-br);font-weight:700;transition:gap .2s;white-space:nowrap}.arrow:hover{gap:13px}header.nav{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 78%,transparent);backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid transparent;transition:border-color .25s,box-shadow .25s,background .4s}header.nav.scrolled{border-bottom-color:var(--line);box-shadow:0 6px 28px #04061466}.nav-inner{display:flex;align-items:center;gap:30px;height:72px}.brand-mark{display:flex;align-items:center;gap:12px;font-weight:800;color:var(--ink);font-size:19px;letter-spacing:-.02em}.brand-dot{width:13px;height:13px;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--violet-br),var(--violet));box-shadow:0 0 0 4px #8b5cf629,0 0 14px #8b5cf6b3}nav.links{display:flex;gap:26px;margin-left:4px}nav.links a{font-weight:600;font-size:15px;color:var(--body);position:relative;padding:4px 0;white-space:nowrap;transition:color .15s}nav.links a:hover,nav.links a.active{color:var(--violet-br)}.nav-cta{margin-left:auto;display:flex;align-items:center;gap:12px}.iconbtn{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);background:transparent;color:var(--body);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .18s}.iconbtn:hover{color:var(--violet-br);border-color:var(--violet)}.iconbtn svg{width:18px;height:18px}.lang{display:inline-flex;align-items:center;gap:2px;font-family:var(--mono)}.lang button{background:transparent;border:none;color:var(--faint);font-family:var(--mono);font-size:12px;font-weight:500;padding:4px 5px;cursor:pointer;transition:color .18s;letter-spacing:.04em;opacity:.85}.lang button:hover{color:var(--violet-br)}.lang button.on{color:var(--violet-br);font-weight:600;opacity:1}.page{padding:56px 0 40px}.crumbs{font-family:var(--mono);font-size:12.5px;color:var(--faint);margin-bottom:22px;display:flex;gap:8px;align-items:center}.crumbs a:hover{color:var(--violet-br)}.read{max-width:var(--read);margin:0 auto}.art-head{max-width:var(--read);margin:0 auto 30px}.art-head h1{font-size:46px;line-height:1.08;margin:14px 0 16px}.lede{font-size:21px;color:var(--body);line-height:1.55;margin:0 0 22px}.byline{display:flex;align-items:center;gap:14px;font-family:var(--mono);font-size:13px;color:var(--faint);flex-wrap:wrap}.byline .who{color:var(--ink);font-weight:600;white-space:nowrap}.byline>span{white-space:nowrap}.avatar{width:28px;height:28px;border-radius:50%;flex:0 0 auto;background:linear-gradient(135deg,color-mix(in srgb,var(--violet) 62%,transparent),color-mix(in srgb,var(--cyan) 52%,transparent));border:1px solid rgba(255,255,255,.22);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:inset 0 1px #ffffff4d,0 2px 8px #8b5cf647}.tags{display:flex;flex-wrap:wrap;gap:8px}.tag{font-family:var(--mono);font-size:12px;font-weight:500;color:var(--violet-br);background:color-mix(in srgb,var(--violet) 14%,transparent);border:1px solid var(--line);padding:4px 11px;border-radius:999px;transition:all .15s}.tag:before{content:"#";opacity:.6}.tag:hover{border-color:var(--violet);color:var(--violet)}.hero-img{max-width:var(--maxw);margin:0 auto 44px;border-radius:22px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);aspect-ratio:21/9;position:relative;background:radial-gradient(120% 120% at 30% 10%,rgba(139,92,246,.25),transparent 55%),repeating-linear-gradient(135deg,#11142e 0 18px,#161a3a 18px 36px);display:flex;align-items:flex-end;padding:18px}.hero-img span{font:500 12px/1 var(--mono);color:var(--faint);background:color-mix(in srgb,var(--bg) 70%,transparent);padding:6px 10px;border-radius:7px;border:1px solid var(--line-2)}.article-body{font-size:18.5px;line-height:1.78;color:var(--body)}.article-body>section{margin-bottom:8px}.article-body h2{font-size:30px;margin:48px 0 14px;scroll-margin-top:90px}.article-body h3{font-size:22px;margin:34px 0 10px;color:var(--violet-br)}.article-body p{margin:0 0 20px}.article-body a:not(.tag):not(.btn){color:var(--violet-br);border-bottom:1px solid var(--line)}.article-body a:not(.tag):not(.btn):hover{border-color:var(--violet-br)}.article-body strong{color:var(--ink)}.article-body ul,.article-body ol{margin:0 0 20px;padding-left:22px}.article-body li{margin:6px 0}.article-body hr{border:none;border-top:1px solid var(--line-2);margin:40px 0}blockquote{margin:28px 0;padding:6px 0 6px 26px;border-left:3px solid var(--violet);font-size:22px;line-height:1.5;color:var(--ink);font-weight:500;font-style:italic}blockquote cite{display:block;margin-top:12px;font-size:14px;font-style:normal;font-family:var(--mono);color:var(--faint)}blockquote cite:before{content:"— "}.code{margin:26px 0;border-radius:14px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:var(--code-bg)}.code-bar{display:flex;align-items:center;gap:8px;padding:10px 16px;border-bottom:1px solid rgba(255,255,255,.07);font-family:var(--mono);font-size:12px;color:#8b8fc0}.code-bar .dots{display:flex;gap:6px;margin-right:6px}.code-bar .dots i{width:10px;height:10px;border-radius:50%;background:#2c2f55;display:block}.code-bar .fname{margin-left:auto}.code pre{margin:0;padding:18px 20px;overflow:auto;font-family:var(--mono);font-size:14px;line-height:1.65;color:var(--code-ink)}.code pre code{font-family:var(--mono);background:none;padding:0}.code pre .cline{display:block;min-height:1.65em}.code pre[data-ln] code{counter-reset:ln}.code pre[data-ln] .cline{position:relative;padding-left:3.1em}.code pre[data-ln] .cline:before{counter-increment:ln;content:counter(ln);position:absolute;left:0;width:2.2em;text-align:right;color:color-mix(in srgb,var(--code-ink) 36%,transparent);user-select:none}.code pre .cline.hl{background:color-mix(in srgb,var(--violet) 17%,transparent);box-shadow:inset 3px 0 0 var(--violet-br)}code:not(.hljs){font-family:var(--mono);font-size:.88em;background:color-mix(in srgb,var(--violet) 14%,transparent);color:var(--violet-br);padding:2px 6px;border-radius:6px}.math-block{margin:26px 0;padding:18px;text-align:center;overflow-x:auto;border:1px dashed var(--line);border-radius:12px;background:color-mix(in srgb,var(--violet) 5%,transparent)}.katex{color:var(--ink)}.diagram{margin:28px 0;padding:22px;border-radius:14px;border:1px solid var(--line);background:var(--panel);box-shadow:var(--shadow);text-align:center}.diagram .puml-src{display:none}.diagram img.puml-img{max-width:100%;height:auto;transition:opacity .3s ease}.diagram .puml-loading{font-family:var(--mono);font-size:12px;color:var(--faint);padding:28px}.diagram .cap{margin-top:12px;font-family:var(--mono);font-size:12px;color:var(--faint)}.diagram .cap:before{content:"UML · ";color:var(--violet-br)}figure.table-fig{--tbl-label: "TABLE · ";margin:28px 0;border-radius:14px;border:1px solid var(--line);background:var(--panel);box-shadow:var(--shadow);overflow:hidden}figure.table-fig .table-scroll{overflow-x:auto}figure.table-fig table{width:100%;border-collapse:collapse;font-size:15.5px;line-height:1.5;font-variant-numeric:tabular-nums}figure.table-fig th,figure.table-fig td{text-align:left;padding:12px 16px}figure.table-fig td.right,figure.table-fig th.right{text-align:right}figure.table-fig thead th{font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--violet-br);white-space:nowrap;background:color-mix(in srgb,var(--violet) 9%,transparent);border-bottom:1px solid var(--line)}figure.table-fig td{color:var(--body)}figure.table-fig td:first-child,figure.table-fig tbody th{color:var(--ink);font-weight:600;text-align:left}figure.table-fig tbody tr:nth-child(2n) td,figure.table-fig tbody tr:nth-child(2n) th{background:color-mix(in srgb,var(--violet) 4%,transparent)}figure.table-fig tbody tr+tr td,figure.table-fig tbody tr+tr th{border-top:1px solid var(--line-2)}figure.table-fig td .mono{font-family:var(--mono)}figure.table-fig figcaption{font-family:var(--mono);font-size:12px;color:var(--faint);padding:13px 16px;border-top:1px solid var(--line);text-align:center}figure.table-fig figcaption:before{content:var(--tbl-label);color:var(--violet-br);font-weight:600}figure.table-fig .pill{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:999px;border:1px solid var(--line)}figure.table-fig .pill.yes{color:var(--ok);background:color-mix(in srgb,var(--ok-line) 14%,transparent);border-color:color-mix(in srgb,var(--ok-line) 32%,transparent)}figure.table-fig .pill.no{color:var(--faint);background:color-mix(in srgb,var(--faint) 12%,transparent)}.article-body table:not(.table-fig table){width:100%;border-collapse:collapse;margin:28px 0;font-size:15.5px;line-height:1.5;font-variant-numeric:tabular-nums;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.article-body table:not(.table-fig table) th,.article-body table:not(.table-fig table) td{text-align:left;padding:12px 16px}.article-body table:not(.table-fig table) thead th{font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--violet-br);white-space:nowrap;background:color-mix(in srgb,var(--violet) 9%,transparent);border-bottom:1px solid var(--line)}.article-body table:not(.table-fig table) td{color:var(--body)}.article-body table:not(.table-fig table) td:first-child{color:var(--ink);font-weight:600}.article-body table:not(.table-fig table) tbody tr:nth-child(2n) td{background:color-mix(in srgb,var(--violet) 4%,transparent)}.article-body table:not(.table-fig table) tbody tr+tr td{border-top:1px solid var(--line-2)}.feat-rail{max-width:var(--maxw);margin:0 auto}.rail-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:22px;gap:20px}.rail-head h2{font-size:28px}.mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.mini{background:var(--panel);border:1px solid var(--line-2);border-radius:16px;padding:22px;transition:transform .2s,box-shadow .2s,border-color .2s;display:block}.mini:hover{transform:translateY(-4px);border-color:var(--line);box-shadow:var(--glow)}.mini .kind{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--violet-br)}.mini h3{font-size:19px;line-height:1.25;margin:10px 0 8px}.mini p{font-size:14.5px;margin:0;color:var(--body)}.mini .m{margin-top:14px;font-family:var(--mono);font-size:12px;color:var(--faint)}@media(max-width:820px){.mini-grid{grid-template-columns:1fr}}#searchOverlay{position:fixed;inset:0;z-index:200;display:none;align-items:flex-start;justify-content:center;padding-top:12vh;background:color-mix(in srgb,var(--bg) 60%,rgba(0,0,0,.5));backdrop-filter:blur(8px)}#searchOverlay.open{display:flex}.search-box{width:min(640px,92vw);background:var(--panel);border:1px solid var(--line);border-radius:18px;box-shadow:var(--glow);overflow:hidden}.search-top{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line-2)}.search-top svg{width:20px;height:20px;color:var(--violet-br);flex:0 0 auto}.search-top input{flex:1;background:transparent;border:none;outline:none;color:var(--ink);font-family:var(--font);font-size:18px}.search-top kbd{font-family:var(--mono);font-size:11px;color:var(--faint);border:1px solid var(--line);border-radius:6px;padding:3px 7px}.search-results{max-height:56vh;overflow:auto;padding:8px}.sresult{display:block;padding:13px 14px;border-radius:11px;cursor:pointer}.sresult:hover,.sresult.sel{background:color-mix(in srgb,var(--violet) 12%,transparent)}.sresult .st{display:flex;align-items:center;gap:10px}.sresult .kind{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:#fff;background:linear-gradient(120deg,var(--violet),var(--indigo));padding:3px 8px;border-radius:999px}.sresult h4{font-size:16px;margin:0;color:var(--ink)}.sresult p{font-size:13.5px;margin:5px 0 0;color:var(--faint)}.sresult .stags{font-family:var(--mono);font-size:11.5px;color:var(--violet-br);margin-top:5px}.search-empty{padding:30px;text-align:center;color:var(--faint);font-family:var(--mono);font-size:14px}.search-foot{padding:10px 16px;border-top:1px solid var(--line-2);font-family:var(--mono);font-size:11.5px;color:var(--faint);display:flex;gap:16px}.search-filter{display:flex;align-items:center;gap:6px;padding:10px 16px;border-bottom:1px solid var(--line-2);font-family:var(--mono);font-size:12px}.search-filter .sf-label{color:var(--faint);margin-right:4px}.search-filter button{font-family:var(--mono);font-size:12px;color:var(--faint);background:transparent;border:1px solid var(--line);border-radius:999px;padding:4px 12px;cursor:pointer;transition:all .15s}.search-filter button:hover{color:var(--violet-br);border-color:var(--violet)}.search-filter button.on{background:linear-gradient(120deg,var(--violet),var(--indigo));color:#fff;border-color:transparent}.sresult .slang{margin-left:auto;font-family:var(--mono);font-size:10.5px;color:var(--faint);border:1px solid var(--line);border-radius:6px;padding:2px 7px;flex:0 0 auto}.handson{margin:30px 0;border-radius:14px;border:1px solid var(--line);background:color-mix(in srgb,var(--violet) 8%,transparent);padding:22px 24px;position:relative}.handson:before{content:"⚡ HANDS-ON";font-family:var(--mono);font-size:11.5px;font-weight:600;letter-spacing:.12em;color:#fff;background:linear-gradient(120deg,var(--violet),var(--indigo));padding:5px 12px;border-radius:999px;position:absolute;top:-13px;left:22px;box-shadow:0 6px 16px #8b5cf666}.handson h3{margin:10px 0 8px!important;color:var(--ink)!important}.handson p:last-child{margin-bottom:0}.video{margin:28px 0;border-radius:14px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);position:relative;aspect-ratio:16/9}.video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}#cbtn{position:absolute;width:30px;height:30px;border-radius:50%;border:1px solid var(--line);background:var(--panel);color:var(--violet-br);display:none;align-items:center;justify-content:center;cursor:pointer;z-index:30;box-shadow:var(--shadow);transition:transform .15s}#cbtn:hover{transform:scale(1.12)}#cbtn svg{width:15px;height:15px}.cmark{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;margin-left:8px;font-family:var(--mono);font-size:11px;font-weight:600;color:#fff;background:var(--violet);border-radius:999px;vertical-align:middle}.composer{margin:10px 0 22px;border:1px solid var(--line);border-radius:12px;background:var(--panel);padding:12px}.composer textarea{width:100%;min-height:64px;resize:vertical;background:transparent;border:none;outline:none;color:var(--ink);font-family:var(--font);font-size:15px}.composer .row{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:8px}.composer .hint{font-family:var(--mono);font-size:11.5px;color:var(--faint)}.section-comments{margin:18px 0 8px;display:grid;gap:12px}.section-comments:empty{display:none}.scom-title{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}.comment{border:1px solid var(--line-2);border-left:3px solid var(--violet);border-radius:10px;padding:12px 14px;background:color-mix(in srgb,var(--panel) 60%,transparent)}.comment .ref{font-family:var(--mono);font-size:11px;color:var(--violet-br)}.comment .txt{color:var(--ink);font-size:15.5px;margin-top:4px;line-height:1.5}.comment .meta{font-family:var(--mono);font-size:11px;color:var(--faint);margin-top:6px}.engage{max-width:var(--read);margin:44px auto 0;padding:22px 0;border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);display:flex;align-items:center;gap:14px;flex-wrap:wrap}.engage .spacer{flex:1}.likebtn,.sharebtn,.rssbtn{display:inline-flex;align-items:center;gap:9px;padding:11px 18px;border-radius:999px;border:1px solid var(--line);background:transparent;color:var(--ink);font-family:var(--font);font-weight:700;font-size:14.5px;cursor:pointer;transition:all .18s}.likebtn:hover,.sharebtn:hover,.rssbtn:hover{border-color:var(--violet);color:var(--violet-br)}.likebtn svg,.sharebtn svg,.rssbtn svg{width:17px;height:17px}.likebtn.liked{background:linear-gradient(120deg,var(--violet),var(--indigo));color:#fff;border-color:transparent}.likebtn.liked svg{fill:#fff}.share-menu{position:relative}.share-pop{position:absolute;bottom:calc(100% + 10px);left:0;background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:8px;display:none;min-width:200px;z-index:40}.share-pop.open{display:block}.share-pop a,.share-pop button{display:flex;width:100%;align-items:center;gap:11px;padding:10px 12px;border-radius:9px;background:none;border:none;color:var(--ink);font-family:var(--font);font-size:14.5px;font-weight:600;cursor:pointer;text-align:left}.share-pop a:hover,.share-pop button:hover{background:color-mix(in srgb,var(--violet) 12%,transparent);color:var(--violet-br)}#toast{position:fixed;bottom:26px;left:50%;transform:translate(-50%) translateY(20px);opacity:0;pointer-events:none;background:var(--panel);border:1px solid var(--line);color:var(--ink);padding:12px 20px;border-radius:999px;box-shadow:var(--glow);font-size:14.5px;font-weight:600;z-index:100;transition:opacity .25s,transform .25s}#toast.show{opacity:1;transform:translate(-50%) translateY(0)}.toc{max-width:var(--read);margin:0 auto 36px;border:1px solid var(--line-2);border-radius:14px;padding:18px 22px;background:color-mix(in srgb,var(--panel) 55%,transparent)}.toc h4{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin:0 0 12px;font-weight:600}.toc ol{margin:0;padding-left:18px;counter-reset:t;list-style:none}.toc li{margin:7px 0;counter-increment:t}.toc li:before{content:counter(t,decimal-leading-zero) "  ";font-family:var(--mono);color:var(--violet-br);font-size:13px}.toc a{font-weight:600;color:var(--body)}.toc a:hover{color:var(--violet-br)}footer.site{background:var(--bg);border-top:1px solid var(--line-2);padding:64px 0 36px;margin-top:80px}.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}.foot-brand .brand-mark{margin-bottom:16px}.foot-brand p{font-size:15px;max-width:280px;margin:0}.foot-col h5{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--faint);margin:0 0 16px;font-weight:600}.foot-col a{display:block;font-size:15px;font-weight:600;color:var(--body);margin-bottom:11px}.foot-col a:hover{color:var(--violet-br)}.foot-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:50px;padding-top:26px;border-top:1px solid var(--line-2);font-family:var(--mono);font-size:13px;color:var(--faint);flex-wrap:wrap;gap:12px}.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}.reveal.in{opacity:1;transform:none}html:not(.js) .reveal{opacity:1;transform:none}.cat-hero{padding:8px 0 4px}.cat-hero h1{font-size:44px}.cat-hero .sub{font-size:18px;color:var(--body);margin:12px 0 0;max-width:560px}.selbar{display:flex;gap:4px;flex-wrap:wrap;margin:26px 0 30px;border-bottom:1px solid var(--line-2)}.selbar button{font-family:var(--font);font-weight:700;font-size:14.5px;color:var(--faint);background:transparent;border:none;cursor:pointer;padding:12px 16px;position:relative;transition:color .15s;white-space:nowrap}.selbar button .c{font-family:var(--mono);font-size:11px;color:var(--faint);margin-left:6px}.selbar button.on{color:var(--violet-br)}.selbar button.on .c{color:var(--violet)}.selbar button.on:after{content:"";position:absolute;left:12px;right:12px;bottom:-1px;height:2px;background:var(--violet);box-shadow:0 0 8px var(--violet)}.cat-featured{display:grid;grid-template-columns:1.5fr 1fr;grid-auto-rows:1fr;gap:18px;margin-bottom:28px}.fcard{position:relative;overflow:hidden;border-radius:18px;border:1px solid var(--line-2);background:var(--panel);padding:24px;display:flex;flex-direction:column;justify-content:flex-end;min-height:176px;transition:transform .2s,box-shadow .2s,border-color .2s}.fcard:hover{transform:translateY(-4px);border-color:var(--line);box-shadow:var(--glow)}.fcard.lead{grid-row:span 2;min-height:372px}.fcard.cover{color:#fff;border-color:transparent}.fcard.cover:before{content:"";position:absolute;inset:0;background:var(--cover, #1e2147);background-size:cover;background-position:center}.fcard.cover:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#0708141f,#070814db)}.fcard>*{position:relative;z-index:1}.fcard .kind{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--violet-br)}.fcard.cover .kind{color:#cbb8ff}.fcard h3{font-size:21px;margin:10px 0 8px;line-height:1.22;color:var(--ink)}.fcard.cover h3{color:#fff}.fcard.lead h3{font-size:30px}.fcard p{font-size:14.5px;color:var(--body);margin:0}.fcard.cover p{color:#ffffffdb}.fcard .fmeta{margin-top:16px;font-family:var(--mono);font-size:12px;color:var(--faint);display:flex;gap:14px;flex-wrap:wrap}.fcard.cover .fmeta{color:#ffffffb8}.fcard .star{color:var(--violet-br)}.fcard.cover .star{color:#cbb8ff}.cat-list{display:grid;gap:12px}.lrow{display:grid;grid-template-columns:104px 1fr auto;gap:20px;align-items:flex-start;padding:16px;border:1px solid var(--line-2);border-radius:14px;background:var(--panel);transition:transform .18s,box-shadow .18s,border-color .18s}.lrow:hover{transform:translate(4px);border-color:var(--line);box-shadow:var(--glow)}.lrow .thumb{width:104px;height:92px;border-radius:10px;background:var(--cover, linear-gradient(135deg, #1e2147, #12152e));background-size:cover;background-position:center;border:1px solid var(--line-2)}.lrow .lmain h3{font-size:17.5px;margin:0 0 4px;color:var(--ink)}.lrow .lmain p{font-size:14.5px;color:var(--body);margin:0;line-height:1.55}.lrow .lmain .ltags{font-family:var(--mono);font-size:11.5px;color:var(--violet-br);margin-top:8px}.lrow .lmain .lstats{font-family:var(--mono);font-size:11px;color:var(--faint);opacity:.68;margin-top:7px;display:flex;flex-wrap:wrap;gap:7px;align-items:center}.lrow .lmain .lstats .dot{opacity:.45}.lrow .lmeta{text-align:right;font-family:var(--mono);font-size:12px;color:var(--faint);white-space:nowrap;line-height:1.7}.lrow .lmeta .stat{color:var(--violet-br)}.pager{display:flex;justify-content:center;align-items:center;gap:8px;margin:36px 0 0}.pager button{font-family:var(--mono);font-size:13px;min-width:38px;height:38px;border-radius:10px;border:1px solid var(--line-2);background:transparent;color:var(--body);cursor:pointer;transition:all .15s;padding:0 10px}.pager button:hover:not(:disabled){border-color:var(--violet);color:var(--violet-br)}.pager button.on{background:linear-gradient(120deg,var(--violet),var(--indigo));color:#fff;border-color:transparent}.pager button:disabled{opacity:.4;cursor:default}@media(max-width:760px){.cat-featured{grid-template-columns:1fr}.fcard.lead{grid-row:auto;min-height:220px}.lrow{grid-template-columns:72px 1fr}.lrow .lmeta{display:none}}@media print{.reveal{opacity:1!important;transform:none!important}#cbtn,.engage{display:none!important}}@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;transition:none!important}}.comments-thread{max-width:var(--read);margin:56px auto 0}.ct-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:20px}.ct-head h3{font-size:22px}.ct-head .sort{font-family:var(--mono);font-size:12px;color:var(--faint)}.cav{width:38px;height:38px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:15px;flex:0 0 auto;box-shadow:inset 0 1px #ffffff4d}.ct-composer{display:flex;gap:12px;margin-bottom:26px}.ct-composer .cbox{flex:1}.ct-composer textarea{width:100%;min-height:54px;resize:vertical;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px 14px;color:var(--ink);font-family:var(--font);font-size:15px;outline:none}.ct-composer textarea:focus{border-color:var(--violet);box-shadow:0 0 0 3px #8b5cf629}.ct-composer .crow{display:flex;justify-content:space-between;align-items:center;margin-top:8px;gap:12px}.ct-composer .who2{font-family:var(--mono);font-size:11.5px;color:var(--faint)}.citem{display:flex;gap:12px;padding:16px 0;border-top:1px solid var(--line-2)}.citem .cbody{flex:1;min-width:0}.citem .cmeta{display:flex;align-items:center;gap:9px;margin-bottom:5px;flex-wrap:wrap}.citem .cname{font-weight:700;color:var(--ink);font-size:14.5px}.citem .cbadge{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:#fff;background:linear-gradient(120deg,var(--violet),var(--indigo));padding:2px 7px;border-radius:999px}.citem .ctime{font-family:var(--mono);font-size:11.5px;color:var(--faint)}.citem .ctext{font-size:15px;color:var(--body);line-height:1.6}.citem .cact{display:flex;gap:16px;margin-top:8px}.citem .cact button{background:none;border:none;color:var(--faint);cursor:pointer;font-family:var(--mono);font-size:12px;padding:0;transition:color .15s}.citem .cact button:hover,.citem .cact button.liked{color:var(--violet-br)}.creplies{margin-top:10px;padding-left:16px;border-left:2px solid var(--line-2)}.creplies .citem{border-top:none;padding:10px 0}.replybox textarea{width:100%;min-height:44px;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:10px;color:var(--ink);font-family:var(--font);font-size:14px;outline:none}@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr}nav.links{display:none}.art-head h1{font-size:34px}#cbtn{display:none!important}}
