.index-head{padding:0 0 32px}.index-head h1{font-family:var(--f-display);font-weight:600;font-size:clamp(36px,5vw,48px);line-height:1.05;letter-spacing:-.022em;margin:0 0 16px}.index-head .lede{font-family:var(--f-body);font-size:16.5px;line-height:1.55;color:var(--fg-mu);margin:0;max-width:600px;text-wrap:pretty}.proj-cards{display:flex;flex-direction:column;width:100%;gap:6px}.proj-card{position:relative;display:grid;grid-template-columns:140px 1fr;background-color:var(--bg-box);background-image:linear-gradient(transparent,transparent);border:1px solid var(--box-line);border-radius:6px;overflow:hidden;transition:background-image .18s}.proj-card:hover{background-image:linear-gradient(var(--hover-bg),var(--hover-bg))}.proj-card .illus{display:flex;align-items:center;justify-content:center;background:var(--bg-2);border-right:1px solid var(--box-line);padding:16px}.proj-card .illus svg{width:88px;height:88px;opacity:.7;transition:opacity .2s}.proj-card:hover .illus svg{opacity:1}.proj-card .content{padding:18px 22px;display:flex;flex-direction:column;justify-content:center;gap:6px}.proj-card .card-link{text-decoration:none;color:inherit}.proj-card .card-link:before{content:"";position:absolute;inset:0;z-index:1}.proj-card .title{font-family:var(--f-display);font-weight:600;font-size:16px;color:var(--fg);margin:0;line-height:1.3;transition:color .15s}.proj-card:hover .title{color:var(--accent)}.proj-card .desc{font-family:var(--f-body);font-size:13.5px;color:var(--fg-mu);margin:0;line-height:1.45}.proj-card .card-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:4px}.proj-card .row-tags{display:flex;gap:6px;flex-wrap:wrap}.proj-card .row-tags .tag{font-family:var(--f-mono);font-size:10px;letter-spacing:.04em;border:1px solid var(--rule-line);border-radius:3px;padding:2px 7px;color:var(--fg-fa);transition:color .15s,border-color .15s}.proj-card:hover .row-tags .tag{color:var(--fg-mu);border-color:var(--box-line)}.proj-card .repo-link{position:relative;z-index:2;display:inline-flex;align-items:center;gap:5px;color:var(--fg-mu);text-decoration:none;font-family:var(--f-mono);font-size:10.5px;letter-spacing:.03em;padding:3px 8px;border:1px solid var(--rule-line);border-radius:4px;flex-shrink:0;cursor:pointer;transition:color .15s,background .15s,border-color .15s}.proj-card .repo-link:hover{color:var(--fg);background:var(--bg-2);border-color:var(--fg-fa)}.proj-card .repo-link svg{width:14px;height:14px}@media(max-width:560px){.proj-card{grid-template-columns:1fr}.proj-card .illus{border-right:0;border-bottom:1px solid var(--box-line);padding:16px}}.blog-list{display:flex;flex-direction:column;width:100%;gap:6px}.blog-row{display:flex;flex-direction:column;justify-content:center;padding:18px 22px;text-decoration:none;color:inherit;background-color:var(--bg-box);background-image:linear-gradient(transparent,transparent);border:1px solid var(--box-line);border-radius:6px;transition:background-image .18s}.blog-row:hover{background-image:linear-gradient(var(--hover-bg),var(--hover-bg))}.blog-row .row-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:4px}.blog-row .title{font-family:var(--f-display);font-weight:600;font-size:16px;color:var(--fg);margin:0;line-height:1.3;transition:color .15s}.blog-row:hover .title{color:var(--accent)}.blog-row .meta{font-family:var(--f-mono);font-size:11.5px;color:var(--fg-fa);letter-spacing:.02em;white-space:nowrap;margin:0}.blog-row .meta .sep{margin:0 6px;opacity:.5}.blog-row .desc{font-family:var(--f-body);font-size:13.5px;color:var(--fg-mu);margin:0;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.blog-row .row-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}.blog-row .row-tags .tag{font-family:var(--f-mono);font-size:10px;letter-spacing:.04em;border:1px solid var(--rule-line);border-radius:3px;padding:2px 7px;color:var(--fg-fa);transition:color .15s,border-color .15s}.blog-row:hover .row-tags .tag{color:var(--fg-mu);border-color:var(--box-line)}.draft-tag{display:inline-block;font-family:var(--f-mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-fa);border:1px solid var(--rule-line);border-radius:3px;padding:2px 6px;margin-left:8px;vertical-align:2px}@media(max-width:640px){.blog-row .row-head{flex-direction:column;gap:4px;align-items:flex-start}.blog-row .meta{white-space:normal}}
