/* Basic VSF frontend styles (cards, grid, single, taxonomy) */

.vsf-archive-header, .vsf-tax-header { text-align:center; margin:2rem 0; }
.vsf-loop-grid { display:flex; flex-wrap:wrap; gap:20px; margin:1.2rem 0; }
.vsf-loop-item-wrap { box-sizing:border-box; width:100%; }
@media(min-width:900px){ .vsf-loop-item-wrap { width:calc(33.333% - 13.333px); } }
@media(min-width:600px) and (max-width:899px){ .vsf-loop-item-wrap { width:calc(50% - 10px); } }
.vsf-loop-item { display:flex; flex-direction:column; background:#fff; border-radius:8px; overflow:hidden; box-shadow:0 1px 6px rgba(0,0,0,.06); height:100%; }
.vsf-loop-thumb img { width:100%; height:auto; display:block; object-fit:cover; }
.vsf-loop-body { padding:16px; display:flex; flex-direction:column; gap:.6rem; flex:1 1 auto; }
.vsf-loop-title { margin:0 0 .3rem 0; font-size:1.05rem; }
.vsf-loop-excerpt { color:#444; line-height:1.45; font-size:.95rem; }

/* product links */
.vsf-links { margin:1.2rem 0; padding:12px; background:#fbfbfb; border-radius:8px; }
.vsf-links-title { margin:0 0 .5rem 0; font-size:1rem; display:flex; align-items:center; gap:.5rem; }
.vsf-links ul { margin:0; padding-left:1.2rem; }
.vsf-links li { margin-bottom:.4rem; }

/* taxonomy card */
.vsf-cat-card-link { text-decoration:none; color:inherit; display:block; }
.vsf-cat-media img { width:100%; height:auto; display:block; object-fit:cover; }
.vsf-cat-body { padding:12px; }

/* Archive portal styles */
.vsf-hero { background: linear-gradient(180deg,#fffef6 0,#fff 100%); padding:48px 0 28px; text-align:center; border-bottom:1px solid rgba(0,0,0,.03); }
.vsf-hero-title { margin:0; font-size:2.1rem; }
.vsf-hero-sub { margin:.6rem 0 0; color:#666; }

.vsf-archive-wrap { max-width:1200px; margin:2rem auto; padding:0 18px; }

.vsf-categories-grid { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:18px; justify-content:flex-start; }
.vsf-cat-tile { display:flex; align-items:center; gap:.8rem; padding:8px 12px; background:#fff; border-radius:8px; text-decoration:none; color:inherit; box-shadow:0 1px 6px rgba(0,0,0,.04); transition:transform .12s, box-shadow .12s; }
.vsf-cat-tile .vsf-cat-thumb { width:56px; height:40px; background-size:cover; background-position:center; border-radius:6px; flex-shrink:0; }
.vsf-cat-tile .vsf-cat-title { font-weight:600; }
.vsf-cat-tile:hover, .vsf-cat-tile.active { transform:translateY(-4px); box-shadow:0 10px 30px rgba(0,0,0,.06); }

.vsf-filterbar { margin:18px 0 22px; display:flex; justify-content:space-between; align-items:center; gap:12px; }
.vsf-filter-form { display:flex; width:100%; gap:12px; align-items:center; flex-wrap:wrap; }
.vsf-filter-left { display:flex; gap:8px; align-items:center; flex:1 1 320px; }
.vsf-search-input { padding:10px 12px; border-radius:8px; border:1px solid #e6e6e6; width:100%; }
.vsf-search-btn { padding:10px 14px; border-radius:8px; background:#ffde59; border:0; cursor:pointer; }

.vsf-filter-right { display:flex; gap:8px; align-items:center; }
.vsf-filter-select { padding:10px 12px; border-radius:8px; border:1px solid #e6e6e6; background:#fff; }

.vsf-loop-grid { display:flex; flex-wrap:wrap; gap:18px; margin-top:6px; }
.vsf-loop-item-wrap { width:100%; }
@media(min-width:900px){ .vsf-loop-item-wrap { width:calc(33.333% - 12px); } }
@media(min-width:600px) and (max-width:899px){ .vsf-loop-item-wrap { width:calc(50% - 9px); } }

.vsf-no-results { text-align:center; padding:40px 0; color:#666; }

/* pagination minor */
.vsf-pagination-wrap { margin-top:18px; display:flex; justify-content:center; }
