:root{--bg: #fdfdfd;--surface: #ffffff;--fg: #111111;--muted: #555555;--border: rgba(0, 0, 0, .12);--accent: #21a4b1;--accent-hover: #007481;--highlight: #f6b85a;--superindividual: #E77E47;--font-display: "Noto Sans TC", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-body: "Noto Sans TC", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Space Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace}*,*:before,*:after{box-sizing:border-box}body{margin:0;background-color:var(--bg);background-image:linear-gradient(rgba(0,0,0,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.035) 1px,transparent 1px);background-size:18px 18px;color:var(--fg);font:16px/1.7 var(--font-body);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}h1,h2,h3,p,figure{margin:0}h1,h2,h3{font-family:var(--font-display);line-height:1.22;letter-spacing:0}.article-shell{max-width:1160px;margin:0 auto;padding-inline:24px}.nav-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:6px 14px;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--fg);font-size:14px;font-weight:800}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn:hover{border-color:var(--fg)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.article-shell{display:grid;grid-template-columns:minmax(0,760px) 300px;gap:56px;padding-block:40px 80px;align-items:start}.article-header{grid-column:1 / -1;display:grid;gap:20px}.breadcrumb{color:var(--accent);font:800 12px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase}h1{font-size:30px;line-height:1.3}.dek{max-width:760px;color:var(--muted);font-size:16px;line-height:1.7}.meta-row,.tag-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;color:var(--muted);font-size:14px}.tag{display:inline-flex;align-items:center;min-height:26px;padding:3px 16px;border:1px solid color-mix(in oklab,var(--accent) 34%,rgba(0,0,0,.1));border-radius:999px;background:#ffffffc7;color:var(--accent-hover);font-size:13px;font-weight:800}.tag:nth-of-type(3n+2){background:color-mix(in oklab,var(--superindividual) 10%,white);border-color:color-mix(in oklab,var(--superindividual) 42%,white);color:color-mix(in oklab,var(--superindividual),black 20%)}.tag:nth-of-type(3n){background:color-mix(in oklab,var(--highlight) 14%,white);border-color:color-mix(in oklab,var(--highlight) 48%,white);color:color-mix(in oklab,var(--highlight),black 42%)}.hero-shot,.screenshot-card{border:1px solid var(--border);border-radius:18px;background:#fff;overflow:hidden;box-shadow:0 10px 30px #00000014,0 2px 8px #0000000a}.hero-shot img,.screenshot-card img{width:100%;display:block;object-fit:contain;object-position:center;background:#fff}.hero-shot img{max-height:620px}.screenshot-card{aspect-ratio:16 / 9}.screenshot-card img{height:100%}.article{display:grid;gap:28px}.article h2{font-size:20px;font-weight:800}.article h3{font-size:20px}.article p,.article li{font-size:16px;line-height:1.8}.article ul{display:grid;gap:8px;margin:0;padding-left:24px}.inline-link{color:var(--accent-hover);font-weight:700;text-decoration:underline;text-decoration-thickness:1.5px;text-underline-offset:4px;text-decoration-color:color-mix(in oklab,var(--accent) 45%,transparent)}.inline-link:hover{text-decoration-color:var(--accent-hover)}.inline-link svg{width:12px;height:12px;margin-left:3px;vertical-align:-1px}.pull-note{border-left:4px solid var(--accent);padding:16px 20px;border-radius:0 16px 16px 0;background:color-mix(in oklab,var(--accent) 8%,white);font-weight:800}.screenshot-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.screenshot-card:first-child{grid-column:1 / -1}.screenshot-card p{padding:12px 14px;color:var(--muted);font-size:14px;line-height:1.5}.sidebar{align-self:start}.sidebar-stick{position:sticky;top:96px;display:grid;gap:24px}.panel{display:grid;gap:10px;padding:20px;border:1px solid var(--border);border-radius:14px;background:#fff}.panel h2{display:flex;align-items:center;gap:8px;font-size:16px}.panel h2 svg{color:var(--accent);flex:none}.panel p{color:var(--muted);line-height:1.65}.related{grid-column:1 / -1;display:grid;gap:22px;margin-top:12px}.related h2{font-size:26px}.related-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.related-card{display:grid;overflow:hidden;border:1px solid var(--border);border-radius:22px;background:#ffffffdb;box-shadow:inset 0 1px #ffffffe0}.related-thumb{width:100%;aspect-ratio:16 / 9;display:block;object-fit:cover;background:#fff}.related-card-body{display:grid;gap:8px;padding:16px}.related-card:hover{border-color:color-mix(in oklab,var(--accent),black 12%);box-shadow:0 10px 30px #00000014}.related-label{color:var(--accent-hover);font:800 12px/1 var(--font-mono)}.related-card-body>strong{font-size:16px;line-height:1.4}.related-card p{color:var(--muted);line-height:1.6}.related-card .tag{min-height:22px;padding:0 12px;font-size:12px}.related-meta{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:auto}.related-author{color:var(--muted);font-size:14px;line-height:1.45}.related-author strong{color:var(--fg);font-weight:650;font-size:inherit}.related-views{font:12px/1 var(--font-mono);color:var(--muted)}.site-footer{border-top:1px solid var(--border);background:#ffffffe0}.footer-inner{max-width:1160px;margin:0 auto;padding:32px 24px;display:grid;grid-template-columns:minmax(0,1.2fr) minmax(220px,.8fr) minmax(220px,.8fr);gap:24px}.footer-brand,.footer-links{display:grid;gap:8px;align-content:start}.footer-brand strong,.footer-links strong{font-weight:900}.footer-brand p,.footer-links a,.footer-note{color:var(--muted);font-size:14px;line-height:1.65}.footer-links a:hover{color:var(--accent-hover)}@media(max-width:900px){.article-shell{padding-inline:20px}.article-shell{grid-template-columns:1fr;gap:28px;padding-block:28px 56px}h1{font-size:34px;max-width:none}.screenshot-grid,.related-grid,.footer-inner{grid-template-columns:1fr}.footer-inner{padding-inline:20px}}.back-link{grid-column:1 / -1;justify-self:start;color:var(--muted);font-size:14px;font-weight:700}.back-link:hover{color:var(--accent-hover)}.listing-head{display:grid}.listing-head-info{display:grid;gap:10px}.listing-meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px 14px;color:var(--muted);font-size:13px}.listing-meta .tag-row{gap:6px}.listing-meta .tag{min-height:22px;padding:0 12px;font-size:12px}.listing-meta-item strong{color:var(--fg);font-weight:700}.article{gap:20px}.card-article h2:not(:first-child){margin-top:14px;padding-top:26px;border-top:1px solid var(--border)}.article .card{display:grid;gap:14px;padding:24px 26px;border:1px solid var(--border);border-radius:14px;background:#fff}.hero-shot{border-radius:14px}.btn-block{width:100%;min-height:44px;font-size:15px}.cta-panel{gap:8px}.cta-note{text-align:center;color:var(--muted);font-size:13px}.author-panel .author-name{font-size:16px}.author-panel p,.author-panel .inline-link{font-size:14px}.details-panel{gap:8px}.detail-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-block:6px;border-bottom:1px solid color-mix(in oklab,var(--border) 55%,transparent);font-size:14px}.detail-row:last-child{border-bottom:0;padding-bottom:0}.detail-row span{color:var(--muted)}.detail-row strong{font-weight:700;text-align:right}@media(max-width:760px){h1{font-size:24px}.article .card{padding:20px}}.card-article .mermaid{margin:22px 0;padding:18px;text-align:center;background:color-mix(in oklab,var(--border) 18%,#fff);border:1px solid color-mix(in oklab,var(--border) 55%,transparent);border-radius:14px;overflow-x:auto}.card-article .mermaid svg{max-width:100%;height:auto}.card-article .mermaid:not([data-processed]){color:transparent;min-height:60px}.card-article pre.code-block{margin:22px 0;padding:16px 18px;background:#1e293b;color:#e2e8f0;border-radius:12px;overflow-x:auto;font-size:14px;line-height:1.6}.card-article pre.code-block code{font-family:ui-monospace,SF Mono,Menlo,monospace}.card-article .inline-image{display:block;max-width:100%;height:auto;margin:18px auto;border:1px solid color-mix(in oklab,var(--border) 60%,transparent);border-radius:12px}.card-article .inline-video{display:block;width:100%;max-height:720px;margin:18px auto;border:1px solid color-mix(in oklab,var(--border) 60%,transparent);border-radius:12px;background:#111;box-shadow:0 10px 28px #0000001a}.card-article .caption{margin:-6px auto 24px;max-width:92%;font-size:14px;font-style:italic;line-height:1.6;color:var(--muted);text-align:center}.card-article .mermaid span.edgeLabel:not(:empty),.card-article .mermaid span.edgeLabel:not(:empty) p{background:#37352f;color:#f4f2ec;font-size:13px;font-weight:600}.card-article .mermaid span.edgeLabel:not(:empty){display:inline-block;padding:2px 9px;border-radius:7px;box-shadow:0 0 0 2px #37352f}.card-article .mermaid .nodeLabel{font-weight:600}.card-article .inline-image.is-zoomable,.hero-shot img.is-zoomable,.screenshot-card img.is-zoomable{cursor:zoom-in}.lightbox-overlay{position:fixed;inset:0;z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:60px 24px 88px;background:#181715d1;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.lightbox-overlay[hidden]{display:none}.lightbox-caption{flex:0 0 auto;max-width:min(880px,88vw);margin:0;text-align:center;font-size:15px;font-weight:600;line-height:1.5;color:#f4f2ec}.lightbox-caption[hidden]{display:none}.lightbox-stage{flex:1 1 auto;width:100%;min-height:0;display:flex;align-items:center;justify-content:center;overflow:hidden}.lightbox-img{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 24px 60px #0006;transition:transform .12s ease-out;cursor:zoom-out;-webkit-user-select:none;user-select:none;touch-action:none}.lightbox-img.is-dragging{transition:none;cursor:grabbing}.lightbox-close{position:absolute;top:18px;right:22px;width:40px;height:40px;border:0;border-radius:999px;background:#ffffff1f;color:#fff;font-size:24px;line-height:1;cursor:pointer;transition:background .15s ease}.lightbox-close:hover{background:#ffffff3d}.lightbox-controls{position:absolute;bottom:22px;left:50%;transform:translate(-50%);display:flex;gap:8px;padding:6px;border-radius:999px;background:#ffffff1f}.lightbox-btn{width:38px;height:38px;border:0;border-radius:999px;background:transparent;color:#fff;font-size:18px;cursor:pointer;transition:background .15s ease}.lightbox-btn:hover{background:#fff3}.card-article mark.hl{background:#fcefc6;color:inherit;padding:.05em .18em;border-radius:3px;box-decoration-break:clone;-webkit-box-decoration-break:clone}
