/* ── TCG Vault Visual Picker v3 ── */
.vp-wrap{max-width:100%;position:relative;border:1px solid rgba(201,168,76,0.25);border-radius:12px;padding:16px;background:linear-gradient(135deg,rgba(201,168,76,0.03),rgba(201,168,76,0.06))}
.vp-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.vp-header-icon{font-size:1.25rem}
.vp-header-text{flex:1}
.vp-header-title{font-size:0.875rem;font-weight:800;color:#C9A84C}
.vp-header-desc{font-size:0.6875rem;color:rgba(255,255,255,0.45);margin-top:1px}
.vp-col-sel{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.vp-col-label{font-size:0.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,0.35)}
.vp-col-dd{padding:6px 10px;border:1px solid var(--border);border-radius:6px;background:var(--bg-raised,#1a1a1a);color:var(--gold);font-size:0.8125rem;font-weight:700;font-family:inherit;cursor:pointer}
.vp-search-row{margin-bottom:8px}
.vp-search{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--bg-surface);color:var(--text-primary,#eee);font-size:0.875rem;font-family:inherit;outline:none;transition:border-color 0.15s}
.vp-search:focus{border-color:var(--gold)}
.vp-search::placeholder{color:rgba(255,255,255,0.3)}
.vp-chips{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}
.vp-chips::-webkit-scrollbar{display:none}
.vp-chip{padding:5px 11px;border-radius:16px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:0.6875rem;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap;-webkit-tap-highlight-color:transparent;transition:all 0.15s}
.vp-chip.active{border-color:var(--gold);background:rgba(201,168,76,0.12);color:var(--gold)}
.vp-type-chips{display:flex;gap:5px;margin-bottom:8px}
.vp-type-chip{padding:5px 11px;border-radius:16px;border:1px solid rgba(255,255,255,0.06);background:rgba(255,255,255,0.03);color:var(--text-muted);font-size:0.6875rem;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap;transition:all 0.15s}
.vp-type-chip.active{border-color:rgba(255,255,255,0.2);background:rgba(255,255,255,0.08);color:var(--text-primary,#eee)}
.vp-results{border:1px solid var(--border);border-radius:8px;background:var(--bg-surface);max-height:65vh;overflow-y:auto;-webkit-overflow-scrolling:touch}
.vp-loading{padding:1.5rem;text-align:center;color:rgba(255,255,255,0.4);font-size:0.8125rem}
.vp-empty{padding:1.5rem;text-align:center;color:rgba(255,255,255,0.4);font-size:0.8125rem}
.vp-section-label{padding:6px 10px;font-size:0.5625rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,0.3);border-bottom:1px solid rgba(255,255,255,0.04);position:sticky;top:0;background:var(--bg-surface);z-index:1}

/* Set list rows */
.vp-set-list{border-bottom:1px solid rgba(255,255,255,0.06)}
.vp-set-item{display:flex;align-items:center;gap:8px;padding:7px 10px;text-decoration:none;color:inherit;border-bottom:1px solid rgba(255,255,255,0.03)}
.vp-set-img{width:40px;height:26px;object-fit:cover;border-radius:3px;flex-shrink:0;background:var(--bg-raised)}
.vp-set-info{flex:1;min-width:0}
.vp-set-name{font-size:0.75rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.vp-set-arrow{color:rgba(255,255,255,0.2);font-size:0.625rem;flex-shrink:0}

/* Card grid — 3 columns base, scales up */
.vp-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:6px}
.vp-card-tile{background:var(--bg-raised,#1a1a1a);border:1px solid rgba(255,255,255,0.06);border-radius:6px;overflow:hidden;position:relative;transition:border-color 0.15s}
.vp-card-tile:hover,.vp-card-tile:active{border-color:rgba(201,168,76,0.3)}
.vp-card-tile.sealed{border-color:rgba(96,165,250,0.2)}
.vp-card-img{width:100%;aspect-ratio:0.72;object-fit:cover;display:block;background:rgba(255,255,255,0.02)}
.vp-card-tile.sealed .vp-card-img{object-fit:contain;aspect-ratio:1;padding:4px;background:rgba(255,255,255,0.04)}
.vp-card-placeholder{display:flex;align-items:center;justify-content:center;font-size:1.25rem;opacity:0.2;aspect-ratio:0.72}
.vp-card-body{padding:4px 5px 5px}
.vp-card-name{font-size:0.625rem;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}
.vp-card-meta{font-size:0.5rem;font-weight:600;color:rgba(255,255,255,0.45);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:1px}
.vp-card-variant{font-size:0.4375rem;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:0.5px;margin-top:1px}
.vp-card-price{font-size:0.625rem;font-weight:800;color:#4ade80;margin-top:2px}
.vp-btn-group{position:absolute;bottom:4px;right:4px;display:flex;align-items:center;gap:3px}
.vp-add-btn{width:26px;height:26px;border-radius:50%;border:none;background:var(--gold);color:#0a0a0a;font-size:0.875rem;font-weight:900;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;box-shadow:0 2px 6px rgba(0,0,0,0.3);transition:transform 0.1s}
.vp-add-btn:active{transform:scale(0.9)}
.vp-minus-btn{width:22px;height:22px;border-radius:50%;border:none;background:rgba(248,113,113,0.9);color:#fff;font-size:0.8125rem;font-weight:900;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;box-shadow:0 2px 4px rgba(0,0,0,0.3);transition:transform 0.1s}
.vp-minus-btn:active{transform:scale(0.9)}

/* Toast */
.vp-toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(20px);background:#1a1a1a;border:1px solid #4ade80;color:#4ade80;padding:8px 20px;border-radius:8px;font-size:0.8125rem;font-weight:700;opacity:0;transition:all 0.3s;pointer-events:none;z-index:9999;white-space:nowrap}
.vp-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* Responsive — mobile-first 3 columns, scale up on wider screens */
@media(max-width:768px){
  .vp-search{font-size:16px;padding:10px 12px}
  .vp-card-grid{grid-template-columns:repeat(3,1fr);gap:4px;padding:4px}
  .vp-card-name{font-size:0.5625rem}
  .vp-card-meta{font-size:0.4375rem}
  .vp-card-body{padding:3px 4px 4px}
  .vp-card-price{font-size:0.5625rem}
  .vp-add-btn{width:24px;height:24px;font-size:0.8125rem}
  .vp-minus-btn{width:20px;height:20px;font-size:0.75rem}
  .vp-btn-group{bottom:3px;right:3px;gap:2px}
  .vp-col-dd{font-size:16px}
  .vp-results{max-height:55vh}
  .vp-chips{flex-wrap:nowrap;overflow-x:auto}
}
@media(min-width:600px){
  .vp-card-grid{grid-template-columns:repeat(4,1fr)}
}
@media(min-width:900px){
  .vp-card-grid{grid-template-columns:repeat(5,1fr)}
}

/* Card tile links */
.vp-card-link{display:block;text-decoration:none;color:inherit}
.vp-card-name-link{display:block;font-size:0.625rem;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3;color:inherit;text-decoration:none}
.vp-card-name-link:hover{color:var(--gold)}

/* Qty input in picker */
.vp-qty-input{width:32px;height:26px;border:none;border-radius:4px;background:rgba(255,255,255,0.08);color:#f2f2f2;font-size:0.6875rem;font-weight:800;text-align:center;font-family:inherit;-moz-appearance:textfield;padding:0}
.vp-qty-input::-webkit-inner-spin-button,.vp-qty-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}

/* Mobile optimization */
@media(max-width:640px){
  .vp-wrap{padding:12px}
  .vp-header-title{font-size:0.8125rem}
  .vp-header-desc{font-size:0.625rem}
  .vp-search{font-size:16px!important;padding:10px}
  .vp-chips{gap:4px}
  .vp-chip{padding:4px 8px;font-size:0.625rem}
  .vp-type-chips{gap:4px}
  .vp-type-chip{padding:4px 8px;font-size:0.625rem}
  .vp-col-sel{gap:6px}
  .vp-col-dd{font-size:0.75rem;padding:5px 8px}
  .vp-col-label{font-size:0.625rem}
  .vp-card-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))!important;gap:6px!important}
  .vp-card-name{font-size:0.5625rem}
  .vp-card-meta{font-size:0.5rem}
  .vp-card-price{font-size:0.5625rem}
  .vp-btn-group{gap:2px}
  .vp-add-btn,.vp-minus-btn{width:24px;height:24px;font-size:0.6875rem}
  .vp-qty-input{width:28px;height:24px;font-size:0.625rem}
}

/* iOS mobile header fix */
@media(max-width:480px){
  .vp-header{flex-direction:column;align-items:flex-start;gap:4px}
  .vp-col-sel{flex-wrap:wrap}
  .vp-header-desc{display:none}
}
