@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Outfit:wght@300;400;500;600;700;800&display=swap";
:root{--bg-primary:#f8f9fa;--bg-secondary:#f0f2f5;--bg-card:#fff;--bg-glass:#fffffff2;--border-glass:#e5e7eb;--border-hover:#d1d5db;--text-primary:#111827;--text-secondary:#4b5563;--text-muted:#6b7280;--accent-blue:#2563eb;--accent-emerald:#059669;--accent-amber:#d97706;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #0000000d;--shadow-lg:0 10px 15px -3px #0000000d}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,sans-serif;overflow-x:hidden}.header{z-index:100;background:var(--bg-card);border-bottom:1px solid var(--border-glass);box-shadow:var(--shadow-sm);padding:0 2rem;position:sticky;top:0}.header-inner{justify-content:space-between;align-items:center;max-width:1400px;height:64px;margin:0 auto;display:flex}.logo{align-items:center;gap:12px;font-family:Outfit,sans-serif;font-size:1.25rem;font-weight:700;display:flex}.logo-icon{background:var(--text-primary);color:#fff;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1rem;display:flex}.nav-pills{background:#f3f4f6;border-radius:100px;gap:4px;padding:4px;display:flex}.nav-pill{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:100px;padding:6px 16px;font-size:.85rem;font-weight:600;transition:all .2s}.nav-pill.active{color:var(--text-primary);box-shadow:var(--shadow-sm);background:#fff}.header-stats{color:var(--text-muted);gap:20px;font-size:.85rem;display:flex}.stat-value{color:var(--text-primary);font-weight:600}.layout-container{align-items:flex-start;gap:24px;max-width:1400px;margin:0 auto;padding:24px 2rem;display:flex}.sidebar{background:var(--bg-card);border:1px solid var(--border-glass);border-radius:var(--radius-md);flex-shrink:0;width:260px;height:calc(100vh - 110px);padding:20px;position:sticky;top:88px;overflow-y:auto}.filter-section{margin-bottom:24px}.filter-title{color:var(--text-primary);border-bottom:2px solid var(--bg-primary);margin-bottom:12px;padding-bottom:6px;font-family:Outfit,sans-serif;font-size:.95rem;font-weight:600}.filter-list{flex-direction:column;gap:8px;display:flex}.filter-item{color:var(--text-secondary);cursor:pointer;align-items:center;gap:8px;font-size:.85rem;display:flex}.filter-item input[type=radio],.filter-item input[type=checkbox]{accent-color:var(--text-primary);cursor:pointer;width:16px;height:16px}.filter-btn{background:var(--bg-primary);border:1px solid var(--border-glass);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);cursor:pointer;margin-top:10px;padding:10px;font-weight:600}.filter-btn:hover{background:#e5e7eb}.main-content{flex-grow:1;min-width:0}.hero{text-align:center;background:var(--bg-card);border:1px solid var(--border-glass);border-radius:var(--radius-md);margin-bottom:24px;padding:2.5rem 2rem}.hero h1{color:var(--text-primary);margin-bottom:.5rem;font-family:Outfit,sans-serif;font-size:2.2rem;font-weight:800}.hero p{color:var(--text-secondary);max-width:500px;margin:0 auto 1.5rem;font-size:1rem}.search-container{max-width:800px;margin:0 auto}.search-bar{background:var(--bg-primary);border:1px solid var(--border-glass);border-radius:100px;align-items:center;gap:12px;padding:8px 8px 8px 24px;transition:all .2s;display:flex}.search-bar:focus-within{border-color:var(--text-primary);box-shadow:var(--shadow-sm);background:#fff}.search-bar input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-size:1.05rem}.search-btn{background:var(--text-primary);color:#fff;cursor:pointer;border:none;border-radius:100px;padding:12px 28px;font-size:.95rem;font-weight:600}.search-btn:hover{background:var(--accent-blue)}.upload-btn{border:1px dashed var(--border-hover);color:var(--text-secondary);cursor:pointer;background:#fff;border-radius:100px;padding:10px 20px;font-size:.85rem}.upload-btn:hover{border-color:var(--text-primary);color:var(--text-primary)}.quick-tags{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:1rem;display:flex}.quick-tag{border:1px solid var(--border-glass);color:var(--text-secondary);cursor:pointer;background:#fff;border-radius:100px;padding:6px 14px;font-size:.8rem}.quick-tag:hover{border-color:var(--text-primary);color:var(--text-primary)}.results-header{border-bottom:2px solid var(--bg-secondary);justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:.5rem;display:flex}.results-count{color:var(--text-secondary);font-size:1.1rem}.results-count strong{color:var(--text-primary);font-weight:700}.results-time{color:var(--text-muted);margin-left:12px;font-size:.8rem}.results-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;display:grid}.fabric-card{background:var(--bg-card);border:1px solid var(--border-glass);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;overflow:hidden}.fabric-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.card-image-wrap{aspect-ratio:4/3;border-bottom:1px solid var(--border-glass);background:#e5e7eb;position:relative;overflow:hidden}.card-image-wrap img{object-fit:cover;width:100%;height:100%;transition:transform .4s}.fabric-card:hover .card-image-wrap img{transform:scale(1.05)}.similarity-badge{box-shadow:var(--shadow-sm);color:var(--text-primary);background:#fff;border-radius:4px;padding:4px 8px;font-size:.75rem;font-weight:700;position:absolute;top:10px;right:10px}.card-info{padding:14px}.card-title{white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:.95rem;font-weight:600;overflow:hidden}.card-subtitle{color:var(--text-secondary);margin-bottom:10px;font-size:.8rem}.badge-group{flex-wrap:wrap;gap:4px;display:flex}.badge{text-transform:uppercase;letter-spacing:.05em;border-radius:4px;padding:3px 6px;font-size:.65rem;font-weight:600}.badge.cat{color:#3730a3;background:#e0e7ff}.badge.weave{color:#166534;background:#dcfce7}.badge.market{color:#9a3412;background:#ffedd5}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:flex-end;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-card);flex-direction:column;width:600px;max-width:100%;height:100%;display:flex;overflow-y:auto;box-shadow:-10px 0 25px #0000001a}.modal-header{border-bottom:1px solid var(--border-glass);z-index:10;background:#fff;justify-content:space-between;align-items:center;padding:20px 24px;display:flex;position:sticky;top:0}.modal-title{font-family:Outfit,sans-serif;font-size:1.4rem;font-weight:700}.close-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;font-size:1.5rem}.modal-body{flex:1;padding:24px}.modal-image{object-fit:contain;border:1px solid var(--border-glass);border-radius:var(--radius-md);background:#f9fafb;width:100%;height:auto;max-height:400px;margin-bottom:24px}.meta-grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;display:grid}.meta-item{background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border-glass);padding:12px}.meta-label{color:var(--text-muted);text-transform:uppercase;margin-bottom:4px;font-size:.75rem;font-weight:600}.meta-value{color:var(--text-primary);font-size:1rem;font-weight:500}.section-title{border-bottom:1px solid var(--border-glass);margin:24px 0 12px;padding-bottom:8px;font-family:Outfit,sans-serif;font-size:1.2rem;font-weight:700}.skeleton{background:#e5e7eb;border-radius:4px;animation:1.5s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.skeleton-card{border:1px solid var(--border-glass);border-radius:var(--radius-md)}.skeleton-image{aspect-ratio:4/3}.skeleton-text{width:60%;height:16px;margin:16px 16px 8px}.skeleton-text-sm{width:40%;height:12px;margin:0 16px 16px}.empty-state{text-align:center;border-radius:var(--radius-md);border:1px solid var(--border-glass);background:#fff;padding:4rem}.empty-state-icon{opacity:.3;margin-bottom:1rem;font-size:3rem}.toast{background:var(--text-primary);color:#fff;z-index:2000;box-shadow:var(--shadow-lg);border-radius:8px;padding:14px 20px;font-size:.95rem;font-weight:500;position:fixed;bottom:24px;right:24px}@media (max-width:900px){.layout-container{flex-direction:column}.sidebar{width:100%;height:auto;position:static}}
