.proj-card.svelte-oviq8z{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:transform .3s var(--ease), border-color .3s, box-shadow .3s;flex-direction:column;min-height:280px;padding:clamp(22px,2.2vw,28px);display:flex}.proj-card.svelte-oviq8z:hover{border-color:var(--border-strong);transform:translateY(-4px);box-shadow:0 16px 40px -24px oklch(0% 0 0/.35)}.proj-top.svelte-oviq8z{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.proj-num.svelte-oviq8z{font-family:var(--font-mono);color:var(--faint);font-size:12px}.proj-cat.svelte-oviq8z{font-family:var(--font-mono);letter-spacing:.05em;text-transform:uppercase;color:var(--muted);border:1px solid var(--border);border-radius:6px;padding:4px 9px;font-size:10.5px}.proj-card.svelte-oviq8z h3:where(.svelte-oviq8z){font-size:clamp(18px,2vw,21px)}.desc.svelte-oviq8z{color:var(--muted);flex-grow:1;margin-top:12px;font-size:14px}.proj-tech.svelte-oviq8z{flex-wrap:wrap;gap:5px;margin-top:18px;display:flex}.proj-tech.svelte-oviq8z span:where(.svelte-oviq8z){font-family:var(--font-mono);color:var(--muted);background:color-mix(in oklab, var(--fg) 5%, transparent);border-radius:5px;padding:3px 7px;font-size:10.5px}.proj-foot.svelte-oviq8z{border-top:1px solid var(--border);font-family:var(--font-mono);color:var(--faint);flex-wrap:wrap;gap:6px 12px;margin-top:18px;padding-top:16px;font-size:11px;display:flex}.proj-foot.svelte-oviq8z .stat:where(.svelte-oviq8z){color:var(--muted);align-items:center;gap:5px;display:inline-flex}.proj-foot.svelte-oviq8z .stat:where(.svelte-oviq8z):before{content:"·";color:var(--faint)}.proj-foot.svelte-oviq8z .stat:where(.svelte-oviq8z):first-child:before{display:none}.proj-link.svelte-oviq8z{font-family:var(--font-mono);letter-spacing:.03em;color:var(--fg);transition:gap .2s var(--ease);align-items:center;gap:7px;margin-top:16px;font-size:12px;display:inline-flex}.proj-link.svelte-oviq8z svg:where(.svelte-oviq8z){width:14px;height:14px}.proj-card.svelte-oviq8z:hover .proj-link:where(.svelte-oviq8z){gap:11px}.projects-page.svelte-rqn88j{min-height:70vh;padding-top:clamp(40px,6vw,80px);padding-bottom:clamp(60px,8vw,120px)}.projects-page.svelte-rqn88j h1:where(.svelte-rqn88j){font-size:clamp(34px,6vw,60px)}.filters.svelte-rqn88j{flex-wrap:wrap;gap:8px;margin-bottom:36px;display:flex}.filter-btn.svelte-rqn88j{font-family:var(--font-mono);letter-spacing:.03em;color:var(--muted);border:1px solid var(--border);cursor:pointer;transition:all .2s var(--ease);background:0 0;border-radius:999px;padding:9px 16px;font-size:12px}.filter-btn.svelte-rqn88j:hover{color:var(--fg);border-color:var(--border-strong)}.filter-btn[aria-pressed=true].svelte-rqn88j{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.proj-grid.svelte-rqn88j{grid-template-columns:repeat(3,1fr);gap:18px;display:grid}.proj-empty.svelte-rqn88j{text-align:center;color:var(--muted);font-family:var(--font-mono);grid-column:1/-1;padding:40px 0;font-size:13px}@media (width<=1024px){.proj-grid.svelte-rqn88j{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.proj-grid.svelte-rqn88j{grid-template-columns:1fr}}
