/* VIRSAL LIGHT — variants table (per makieta product-warianty.html) */
.virsal-variants {
  --red: #E30613;
  --red-600: #C4050F;
  --red-50: #FFF2F3;
  --ink: #0B1B33;
  --ink-800: #16284A;
  --ink-500: #475772;
  --ink-300: #8A97AD;
  --line: #E6EAF2;
  --bg: #F5F7FB;
  --green: #1FA968;
  --r-sm: 2px;
  --r: 4px;
  font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color: var(--ink);
}

.virsal-variants .vv-loading,
.virsal-variants .vv-empty {
  padding: 32px;
  text-align: center;
  color: var(--ink-500);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--r);
}

/* Intro */
.virsal-variants .variants-intro {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 18px; margin: 0 0 16px; flex-wrap: wrap;
}
.virsal-variants .variants-intro h3 {
  margin: 0 0 4px; font-size: 18px; font-weight: 900;
  color: var(--ink); letter-spacing: -.015em;
}
.virsal-variants .variants-intro h3 b {
  color: var(--red); font-variant-numeric: tabular-nums;
}
.virsal-variants .variants-intro p {
  margin: 0; font-size: 13px; color: var(--ink-500); line-height: 1.5; max-width: 600px;
}

/* Filterbar */
.virsal-variants .variants-filterbar {
  display: flex; align-items: center; gap: 10px;
  background: #FAFBFD; border: 1px solid var(--line); border-radius: var(--r);
  padding: 10px 14px; margin: 0 0 14px; flex-wrap: wrap;
}
.virsal-variants .variants-filterbar .lbl {
  font-size: 11px; font-weight: 800; color: var(--ink-500);
  text-transform: uppercase; letter-spacing: .1em; margin-right: 4px;
  display: inline-flex; align-items: center; gap: 6px;
}
.virsal-variants .variants-filterbar .lbl svg { width: 14px; height: 14px; color: var(--ink-300); }
.virsal-variants .variants-filterbar .sel { position: relative; min-width: 200px; }
.virsal-variants .variants-filterbar select {
  width: 100%; appearance: none; -webkit-appearance: none;
  background: #fff; border: 1px solid var(--line); border-radius: var(--r-sm);
  padding: 8px 30px 8px 12px; font-family: inherit; font-size: 12.5px;
  color: var(--ink); font-weight: 600; cursor: pointer; outline: 0;
  transition: border-color .15s, box-shadow .15s;
}
.virsal-variants .variants-filterbar select:hover { border-color: var(--ink-300); }
.virsal-variants .variants-filterbar select:focus { border-color: var(--red); box-shadow: 0 0 0 2px var(--red-50); }
.virsal-variants .variants-filterbar .sel::after {
  content: ""; position: absolute; right: 10px; top: 50%;
  transform: translateY(-50%) rotate(45deg); width: 5px; height: 5px;
  border: 1.5px solid var(--ink-500); border-top: 0; border-left: 0; pointer-events: none;
}
.virsal-variants .variants-filterbar .reset-mini {
  display: inline-flex; align-items: center; gap: 5px;
  background: transparent; color: var(--ink-500);
  font-size: 12px; font-weight: 700; padding: 8px 4px;
  transition: color .15s; margin-left: auto; cursor: pointer; border: 0; font-family: inherit;
}
.virsal-variants .variants-filterbar .reset-mini:hover { color: var(--red); }
.virsal-variants .variants-filterbar .reset-mini svg { width: 13px; height: 13px; }
.virsal-variants .variants-filterbar .count-tag {
  font-size: 11.5px; color: var(--ink-500); font-weight: 700;
  background: #fff; border: 1px solid var(--line);
  padding: 6px 10px; border-radius: var(--r-sm); font-variant-numeric: tabular-nums;
}
.virsal-variants .variants-filterbar .count-tag b { color: var(--red); font-weight: 900; }

/* Bulk B2B info (per user request — bez checkboxow) */
.virsal-variants .variants-bulk {
  display: flex; align-items: center; gap: 14px;
  background: #FFF9E6; border: 1px solid #FFE099; border-radius: var(--r);
  padding: 12px 18px; margin: 0 0 14px; font-size: 13px; color: #8A6A00;
}
.virsal-variants .variants-bulk svg { width: 18px; height: 18px; color: #D97706; flex-shrink: 0; }
.virsal-variants .variants-bulk b { color: #5D4500; font-weight: 800; }

/* Table */
.virsal-variants .variants-table {
  border: 1px solid var(--line); border-radius: var(--r);
  overflow: hidden; background: #fff;
}
.virsal-variants .variants-thead,
.virsal-variants .variant-row {
  display: grid;
  grid-template-columns: minmax(0, 2.2fr) repeat(var(--vv-axes, 2), 0.85fr) 1fr 0.95fr 1.3fr 1.7fr 1fr;
  gap: 10px; align-items: center; padding: 13px 16px;
}
.virsal-variants .variants-thead {
  background: #F7F8FC; border-bottom: 1px solid var(--line);
  font-size: 10.5px; font-weight: 800; color: var(--ink-500);
  text-transform: uppercase; letter-spacing: .06em;
}
.virsal-variants .variants-thead .th { display: inline-flex; align-items: center; gap: 4px; }
.virsal-variants .variants-thead .th.right { justify-content: flex-end; text-align: right; }
.virsal-variants .variants-thead .th.center { justify-content: center; text-align: center; }

.virsal-variants .variant-row {
  border-bottom: 1px solid var(--line); transition: background .15s;
}
.virsal-variants .variant-row:last-child { border-bottom: 0; }
.virsal-variants .variant-row:hover { background: #FAFBFD; }

.virsal-variants .v-code b {
  display: block; font-size: 14px; font-weight: 800; color: var(--ink);
  letter-spacing: -.005em; font-variant-numeric: tabular-nums;
}
.virsal-variants .v-code small {
  display: -webkit-box; font-size: 11.5px; color: var(--ink-500);
  line-height: 1.4; margin-top: 3px; font-weight: 500;
  -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.virsal-variants .v-code .v-brand-tag {
  display: inline-block; font-size: 9.5px; font-weight: 800;
  background: var(--ink); color: #fff; padding: 1px 6px;
  border-radius: var(--r-sm); text-transform: uppercase; letter-spacing: .05em;
  margin-right: 6px; vertical-align: 1px;
}

.virsal-variants .v-attr {
  font-size: 13.5px; font-weight: 800; color: var(--ink-800);
  font-variant-numeric: tabular-nums; letter-spacing: -.005em; text-align: center;
}

.virsal-variants .v-stock,
.virsal-variants .v-ship {
  display: flex; flex-direction: column; align-items: center; gap: 3px; text-align: center;
}
.virsal-variants .v-stock svg,
.virsal-variants .v-ship svg { width: 22px; height: 22px; }
.virsal-variants .v-stock svg { color: var(--green); }
.virsal-variants .v-stock.out svg { color: #E2A100; }
.virsal-variants .v-ship svg { color: var(--green); }
.virsal-variants .v-stock b,
.virsal-variants .v-ship b {
  font-size: 11.5px; font-weight: 800; color: var(--ink);
  font-variant-numeric: tabular-nums; letter-spacing: -.005em;
}
.virsal-variants .v-ship b { color: var(--green); text-transform: lowercase; font-weight: 800; }
.virsal-variants .v-stock.out b { color: #E2A100; }
.virsal-variants .v-ship.out b { color: #E2A100; }

.virsal-variants .v-price {
  display: flex; flex-direction: column; gap: 2px; text-align: center;
  align-items: center; line-height: 1.15;
}
.virsal-variants .v-price b {
  font-size: 16px; font-weight: 900; color: var(--ink);
  letter-spacing: -.015em; font-variant-numeric: tabular-nums;
}
.virsal-variants .v-price b .net {
  font-size: 10.5px; color: var(--ink-500); font-weight: 600;
  margin-left: 3px; text-transform: lowercase; letter-spacing: 0;
}
.virsal-variants .v-price .gross {
  font-size: 11px; color: var(--ink-500); font-weight: 600;
  font-variant-numeric: tabular-nums;
}

.virsal-variants .v-buy {
  display: flex; align-items: center; gap: 6px; justify-content: flex-end;
}
.virsal-variants .v-buy .qty-mini {
  display: inline-flex; align-items: center;
  border: 1px solid var(--line); border-radius: var(--r-sm);
  height: 38px; background: #fff;
}
.virsal-variants .v-buy .qty-mini button {
  width: 28px; height: 38px; color: var(--ink-500); font-weight: 700; font-size: 15px;
  background: none; border: 0; cursor: pointer;
  transition: color .15s, background .15s;
  display: inline-flex; align-items: center; justify-content: center;
}
.virsal-variants .v-buy .qty-mini button:hover { color: var(--red); background: var(--bg); }
.virsal-variants .v-buy .qty-mini input {
  width: 36px; height: 38px; border: 0; text-align: center;
  font-weight: 800; font-family: inherit; color: var(--ink); font-size: 13px;
  outline: 0; background: transparent; font-variant-numeric: tabular-nums;
  -moz-appearance: textfield;
}
.virsal-variants .v-buy .qty-mini input::-webkit-inner-spin-button,
.virsal-variants .v-buy .qty-mini input::-webkit-outer-spin-button {
  -webkit-appearance: none; margin: 0;
}
.virsal-variants .v-buy .cart-mini {
  height: 38px; background: var(--red); color: #fff; border-radius: var(--r-sm);
  display: inline-flex; align-items: center; justify-content: center;
  transition: background .2s, transform .15s; flex-shrink: 0;
  padding: 0 12px; gap: 6px; font-weight: 800; font-size: 11.5px;
  text-transform: uppercase; letter-spacing: .04em; text-decoration: none;
  cursor: pointer; border: 0; font-family: inherit;
}
.virsal-variants .v-buy .cart-mini:hover { background: var(--red-600); transform: translateY(-1px); }
.virsal-variants .v-buy .cart-mini:disabled { opacity: .6; cursor: wait; transform: none; }
.virsal-variants .v-buy .cart-mini svg { width: 16px; height: 16px; }

.virsal-variants .v-more {
  display: flex; flex-direction: column; gap: 5px; align-items: flex-start;
}
.virsal-variants .v-more a {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11.5px; font-weight: 700; color: #1F4D9C;
  transition: color .15s; text-decoration: none;
}
.virsal-variants .v-more a:hover { color: var(--red); text-decoration: underline; }
.virsal-variants .v-more a svg { width: 13px; height: 13px; }

/* Feedback (cart add) */
.virsal-variants .vv-feedback {
  position: fixed; bottom: 24px; right: 24px;
  background: var(--ink); color: #fff;
  padding: 14px 20px; border-radius: var(--r);
  font-size: 13.5px; font-weight: 700;
  box-shadow: 0 8px 24px -10px rgba(11, 27, 51, .35);
  z-index: 9999; max-width: 320px;
}

/* Responsive: mobile stack */
@media (max-width: 1024px) {
  .virsal-variants .variants-thead { display: none; }
  .virsal-variants .variant-row {
    grid-template-columns: 1fr 1fr;
    gap: 10px 16px; padding: 16px;
    border-bottom: 1px solid var(--line);
    align-items: start;
  }
  .virsal-variants .v-code { grid-column: 1 / -1; }
  .virsal-variants .v-attr {
    justify-self: start; text-align: left;
    display: flex; align-items: center; gap: 8px;
  }
  .virsal-variants .v-attr[data-label]::before {
    content: attr(data-label) ":"; font-size: 10px; color: var(--ink-500);
    text-transform: uppercase; letter-spacing: .06em; font-weight: 800;
  }
  .virsal-variants .v-stock,
  .virsal-variants .v-ship {
    flex-direction: row; align-items: center; gap: 8px;
    justify-self: start; text-align: left;
  }
  .virsal-variants .v-stock::before {
    content: "Magazyn:"; font-size: 10px; color: var(--ink-500);
    text-transform: uppercase; letter-spacing: .06em; font-weight: 800;
  }
  .virsal-variants .v-ship::before {
    content: "Wysyłka:"; font-size: 10px; color: var(--ink-500);
    text-transform: uppercase; letter-spacing: .06em; font-weight: 800;
  }
  .virsal-variants .v-price {
    grid-column: 1 / -1; flex-direction: row; align-items: baseline;
    gap: 10px; text-align: left; padding-top: 8px;
    border-top: 1px dashed var(--line); margin-top: 4px;
  }
  .virsal-variants .v-buy { grid-column: 1 / -1; justify-content: flex-start; }
  .virsal-variants .v-buy .cart-mini { flex: 1; justify-content: center; height: 42px; font-size: 12.5px; }
  .virsal-variants .v-buy .qty-mini,
  .virsal-variants .v-buy .qty-mini button,
  .virsal-variants .v-buy .qty-mini input { height: 42px; }
  .virsal-variants .v-more { grid-column: 1 / -1; flex-direction: row; gap: 14px; padding-top: 6px; }
  .virsal-variants .variants-filterbar .sel { min-width: 160px; flex: 1; }
}
@media (max-width: 480px) {
  .virsal-variants .variants-filterbar .sel { min-width: 100%; }
}
