*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f0f2f5;--surface:#fff;--border:#e2e5ea;--text:#111827;--muted:#6b7280;--accent:#2563eb;--accent-h:#1d4ed8;--r:14px}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:system-ui,-apple-system,sans-serif}.app{max-width:1280px;margin:0 auto;padding:3rem 1.5rem 5rem}.header{text-align:center;margin-bottom:3rem}.header h1{letter-spacing:-.03em;background:linear-gradient(135deg,#111827 0%,#374151 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:clamp(2rem,5vw,3.25rem);font-weight:800}.header p{color:var(--muted);margin-top:.5rem;font-size:1rem}.controls{flex-direction:column;gap:.75rem;margin-bottom:2rem;display:flex}.search-wrap{position:relative}.search-icon{width:18px;height:18px;color:var(--muted);pointer-events:none;position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.search{border:1.5px solid var(--border);border-radius:var(--r);background:var(--surface);width:100%;color:var(--text);outline:none;padding:.8rem 2.5rem .8rem 2.75rem;font-size:.95rem;transition:border-color .15s,box-shadow .15s}.search::placeholder{color:var(--muted)}.search:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1f}.clear-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.25rem;font-size:.85rem;line-height:1;transition:color .15s;position:absolute;top:50%;right:.875rem;transform:translateY(-50%)}.clear-btn:hover{color:var(--text)}.controls-meta{justify-content:space-between;align-items:center;display:flex}.count,.page-info{color:var(--muted);font-size:.82rem}.grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem;margin-bottom:2.5rem;display:grid}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:1.25rem 1.5rem 1.5rem;transition:box-shadow .2s,transform .2s}.card:hover{transform:translateY(-2px);box-shadow:0 8px 28px #0000001a}.card-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.font-meta{flex:1;min-width:0}.font-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:600;display:block;overflow:hidden}.font-ext{color:var(--muted);background:var(--bg);border:1px solid var(--border);border-radius:4px;margin-top:3px;padding:1px 5px;font-family:monospace;font-size:.68rem;display:inline-block}.dl-btn{background:var(--accent);color:#fff;white-space:nowrap;border-radius:8px;flex-shrink:0;align-items:center;gap:.35rem;padding:.4rem .875rem;font-size:.78rem;font-weight:600;text-decoration:none;transition:background .15s,transform .1s;display:inline-flex}.dl-btn:hover{background:var(--accent-h);transform:translateY(-1px)}.dl-loading{color:var(--muted);flex-shrink:0;font-size:.75rem}.previews{border-top:1px solid var(--border);flex-direction:column;gap:.5rem;padding-top:1rem;display:flex}.prev-row{align-items:baseline;gap:.75rem;min-width:0;display:flex}.prev-label{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;flex-shrink:0;min-width:24px;font-family:system-ui,sans-serif;font-size:.6rem;font-weight:700}.prev-text{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:1rem;line-height:1.75;overflow:hidden}.num-text{letter-spacing:.06em;font-size:1.15rem}.empty{text-align:center;color:var(--muted);grid-column:1/-1;padding:5rem 0;font-size:1rem}.pager{flex-wrap:wrap;justify-content:center;align-items:center;gap:.375rem;display:flex}.page-btn{border:1.5px solid var(--border);background:var(--surface);min-width:38px;height:38px;color:var(--text);cursor:pointer;border-radius:9px;justify-content:center;align-items:center;padding:0 .4rem;font-size:.875rem;font-weight:500;transition:all .15s;display:inline-flex}.page-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.page-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.page-btn:disabled{opacity:.35;cursor:not-allowed}.page-ellipsis{color:var(--muted);-webkit-user-select:none;user-select:none;padding:0 .25rem;font-size:.9rem}@media (width<=680px){.grid{grid-template-columns:1fr}.prev-text{font-size:.9rem}.num-text{font-size:1rem}}
