/* =============================================
   Tech Shop Plugin - CSS
   Matches design from dbdsitro_pl.html exactly
   ============================================= */

:root {
  --ts-green:       #2bd34f;
  --ts-green-2:     #18b43a;
  --ts-ink:         #0f172a;
  --ts-muted:       #475569;
  --ts-muted-2:     #64748b;
  --ts-bg:          #ffffff;
  --ts-bg-soft:     #f6f7fb;
  --ts-line:        #e6e8ef;
  --ts-shadow-sm:   0 6px 18px rgba(15,23,42,.06);
  --ts-shadow-md:   0 14px 40px rgba(15,23,42,.10);
  --ts-radius-sm:   10px;
  --ts-radius-md:   14px;
  --ts-radius-lg:   18px;
}

/* Reset scoped to plugin */
.ts-shop-wrap *,
.ts-shop-wrap *::before,
.ts-shop-wrap *::after { box-sizing: border-box; }
.ts-shop-wrap { font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color: var(--ts-ink); line-height: 1.45; }
.ts-shop-wrap a { color: inherit; text-decoration: none; }
.ts-shop-wrap img { max-width: 100%; display: block; }

/* ===== Page Head ===== */
.ts-pagehead { padding: 18px 0 12px; text-align: center; }
.ts-pagehead h1 { margin: 0; font-size: clamp(1.6rem, 2.2vw, 2.2rem); letter-spacing: -.02em; }
.ts-crumbs { margin-top: 8px; display: flex; justify-content: center; flex-wrap: wrap; gap: 8px; align-items: center; color: var(--ts-muted); font-size: .9rem; }
.ts-crumbs a { color: var(--ts-muted); font-weight: 700; }
.ts-crumbs a:hover { color: var(--ts-ink); }
.ts-sep { opacity: .5; }

/* ===== Shop Grid ===== */
.ts-shopgrid { margin-top: 1rem; display: grid; grid-template-columns: 320px 1fr; gap: 1.5rem; align-items: start; }

/* ===== Card ===== */
.ts-card { background: #fff; border: 1px solid var(--ts-line); border-radius: var(--ts-radius-lg); box-shadow: var(--ts-shadow-sm); overflow: hidden; }
.ts-card__head { padding: 14px 16px; border-bottom: 1px solid var(--ts-line); background: linear-gradient(180deg, #fff, #fbfbfd); display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.ts-card__head strong { font-size: 1rem; }

/* ===== Pill ===== */
.ts-pill { display: inline-flex; align-items: center; justify-content: center; padding: 6px 10px; border-radius: 999px; border: 1px solid var(--ts-line); background: var(--ts-bg-soft); font-weight: 700; font-size: .75rem; color: var(--ts-ink); white-space: nowrap; }
.ts-pill--btn { cursor: pointer; transition: .15s; }
.ts-pill--btn:hover { box-shadow: var(--ts-shadow-sm); }

/* ===== Buttons ===== */
.btn { height: 40px; border-radius: 999px; padding: 0 14px; font-weight: 700; cursor: pointer; border: 1px solid var(--ts-line); background: #fff; display: inline-flex; align-items: center; justify-content: center; gap: 8px; transition: .15s; white-space: nowrap; font-size: .9rem; font-family: inherit; }
.btn:hover { box-shadow: var(--ts-shadow-sm); }
.btn-primary { border: 0; background: linear-gradient(180deg, var(--ts-green), var(--ts-green-2)); color: #052e12; box-shadow: 0 12px 26px rgba(43,211,79,.22); font-weight: 800; }
.btn-primary:hover { box-shadow: 0 16px 34px rgba(43,211,79,.28); }
.btn-ghost { background: var(--ts-bg-soft); }
.btn-block { width: 100%; }

/* ===== Select ===== */
.ts-select { height: 40px; border-radius: 999px; border: 1px solid var(--ts-line); background: #fff; padding: 0 14px; font-weight: 700; color: var(--ts-ink); outline: none; cursor: pointer; font-size: .9rem; font-family: inherit; transition: .15s; }
.ts-select:focus { border-color: rgba(43,211,79,.55); box-shadow: 0 0 0 6px rgba(43,211,79,.14); }

/* ===== Filters Sidebar ===== */
.ts-filters { position: sticky; top: 80px; max-height: calc(100vh - 100px); overflow-y: auto; scrollbar-width: thin; scrollbar-color: var(--ts-line) transparent; }
.ts-filters::-webkit-scrollbar { width: 4px; }
.ts-filters::-webkit-scrollbar-thumb { background: var(--ts-line); border-radius: 4px; }

.ts-filterblock { padding: 14px 16px; border-bottom: 1px solid var(--ts-line); }
.ts-filterblock:last-child { border-bottom: 0; }

.ts-ftitle { display: flex; align-items: center; justify-content: space-between; font-weight: 800; font-size: .92rem; color: var(--ts-ink); margin-bottom: 10px; }

/* ===== Category List (nested) ===== */
.ts-flist { display: grid; gap: 6px; }
.ts-cat-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 4px; }
.ts-cat-list--sub { padding-left: 14px; margin-top: 4px; }

/* Sub-wrap hidden by default, shown when parent has is-open */
.ts-sub-wrap { display: none; overflow: hidden; }
.ts-cat-item.is-open > .ts-sub-wrap { display: block; }

.ts-cat-item { }

.ts-flink {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 12px;
  border-radius: var(--ts-radius-md);
  border: 1px solid var(--ts-line);
  background: #fff;
  color: var(--ts-muted);
  font-weight: 700;
  font-size: .88rem;
  cursor: pointer;
  transition: .15s;
  position: relative;
}
.ts-flink:hover { box-shadow: var(--ts-shadow-sm); color: var(--ts-ink); border-color: rgba(15,23,42,.18); }
.ts-flink.is-active {
  background: rgba(43,211,79,.10);
  border-color: rgba(43,211,79,.35);
  color: #0b3d1a;
  box-shadow: 0 0 0 6px rgba(43,211,79,.10);
}

.ts-flink__name { flex: 1; }
.ts-flink__count { font-size: .76rem; font-weight: 800; color: var(--ts-muted-2); border: 1px solid var(--ts-line); background: var(--ts-bg-soft); padding: 4px 8px; border-radius: 999px; white-space: nowrap; }

/* Toggle button (+/−) */
.ts-toggle-btn {
  border: 1px solid var(--ts-line);
  background: #fff;
  cursor: pointer;
  padding: 0;
  min-width: 28px;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  color: var(--ts-muted);
  flex-shrink: 0;
  transition: .2s;
  line-height: 1;
}
.ts-toggle-btn svg {
  display: block;
  width: 12px;
  height: 12px;
  margin: auto;
}
.ts-toggle-btn:hover { background: var(--ts-bg-soft); color: var(--ts-ink); border-color: rgba(43,211,79,.4); }
.ts-flink.is-active .ts-toggle-btn { border-color: rgba(43,211,79,.4); color: #0b3d1a; }

/* Hide vertical line of + when open (becomes −) */
.ts-plus-h { transition: opacity .2s; }
.ts-cat-item.is-open > .ts-flink > .ts-toggle-btn .ts-plus-h { opacity: 0; }

.ts-sub-wrap { overflow: hidden; }

/* ===== Price Range ===== */
.ts-range-wrap { display: grid; gap: 10px; }

.ts-range-track {
  position: relative; height: 6px; background: var(--ts-line); border-radius: 3px; margin: 16px 0 8px;
}
.ts-range-fill { position: absolute; height: 100%; background: var(--ts-green); border-radius: 3px; pointer-events: none; }

.ts-range-track input[type="range"] {
  position: absolute; width: 100%; top: 50%; transform: translateY(-50%);
  -webkit-appearance: none; appearance: none; background: transparent; pointer-events: none; height: 20px; margin: 0;
}
.ts-range-track input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none; width: 18px; height: 18px; border-radius: 50%; background: #fff;
  border: 2px solid var(--ts-green); box-shadow: 0 2px 6px rgba(43,211,79,.3); cursor: pointer; pointer-events: all;
}
.ts-range-track input[type="range"]::-moz-range-thumb {
  width: 18px; height: 18px; border-radius: 50%; background: #fff;
  border: 2px solid var(--ts-green); cursor: pointer; pointer-events: all;
}
.ts-range-labels { display: flex; justify-content: space-between; color: var(--ts-muted); font-weight: 700; font-size: .88rem; }

/* ===== Checkboxes / Radios ===== */
.ts-checks { display: grid; gap: 8px; }
.ts-check { display: flex; align-items: center; gap: 10px; color: var(--ts-muted); font-weight: 700; font-size: .88rem; cursor: pointer; }
.ts-check input { accent-color: var(--ts-green); width: 16px; height: 16px; cursor: pointer; }
.ts-stars { color: #f59e0b; letter-spacing: 1px; font-size: .85rem; }

/* ===== Products Panel ===== */
.ts-products-panel { position: relative; }

.ts-panelhead { padding: 14px 16px; border-bottom: 1px solid var(--ts-line); background: linear-gradient(180deg, #fff, #fbfbfd); display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.ts-panelhead__left { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; color: var(--ts-muted); font-weight: 700; font-size: .9rem; }
.ts-panelhead__left strong { color: var(--ts-ink); font-size: 1rem; }
.ts-panelhead__right { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.ts-mobile-filter-btn { display: none; }

/* ===== Loader ===== */
.ts-loader {
  position: absolute; inset: 0; z-index: 10;
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(4px);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px;
  opacity: 0; pointer-events: none;
  transition: opacity .2s;
  border-radius: var(--ts-radius-lg);
}
.ts-loader.is-visible { opacity: 1; pointer-events: all; }
.ts-loader__spinner {
  width: 40px; height: 40px; border-radius: 50%;
  border: 3px solid var(--ts-line);
  border-top-color: var(--ts-green);
  animation: ts-spin .7s linear infinite;
}
.ts-loader span { font-weight: 700; color: var(--ts-muted); font-size: .9rem; }
@keyframes ts-spin { to { transform: rotate(360deg); } }

/* ===== Products Grid ===== */
.ts-grid {
  padding: 16px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  min-height: 200px;
}

/* ===== Product Card ===== */
.pcard {
  border: 1px solid var(--ts-line);
  border-radius: var(--ts-radius-lg);
  background: #fff;
  box-shadow: var(--ts-shadow-sm);
  overflow: hidden;
  transition: transform .12s ease, box-shadow .15s ease;
  display: flex; flex-direction: column;
}
.pcard:hover { transform: translateY(-2px); box-shadow: var(--ts-shadow-md); }

.pcard__imgwrap { display: block; }
.pimg { aspect-ratio: 1/1; background: var(--ts-bg-soft); display: grid; place-items: center; padding: 14px; position: relative; overflow: hidden; }
.ts-badge { position: absolute; left: 12px; top: 12px; padding: 5px 10px; border-radius: 999px; font-weight: 800; font-size: .73rem; }
.ts-badge--instock { border: 1px solid rgba(43,211,79,.25); background: rgba(43,211,79,.10); color: #0b3d1a; }
.ts-badge--outofstock { border: 1px solid rgba(239,68,68,.25); background: rgba(239,68,68,.10); color: #7f1d1d; }
.pimg img { width: 100%; max-width: 200px; border-radius: 12px; box-shadow: 0 10px 24px rgba(15,23,42,.12); object-fit: contain; transition: transform .2s; }
.pcard:hover .pimg img { transform: scale(1.03); }

.pbody { padding: 14px; display: grid; gap: 6px; flex: 1; }
.pname { font-weight: 800; font-size: .9rem; line-height: 1.3; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; color: var(--ts-ink); }
.pname:hover { color: var(--ts-green-2); }
.pprice { font-weight: 800; font-size: 1rem; color: var(--ts-ink); }
.pprice small { color: var(--ts-muted); font-weight: 700; }
.pprice del { color: var(--ts-muted); font-size: .85rem; margin-left: 4px; }
.pmeta { color: var(--ts-muted); font-weight: 700; font-size: .8rem; }

.qtyadd { padding: 0 14px 14px; display: grid; gap: 8px; }
.qty { display: grid; grid-template-columns: 40px 1fr 40px; border: 1px solid var(--ts-line); border-radius: 999px; overflow: hidden; background: #fff; height: 38px; }
.qty-btn { border: 0; background: var(--ts-bg-soft); cursor: pointer; font-size: 16px; font-weight: 800; transition: .12s; display: flex; align-items: center; justify-content: center; }
.qty-btn:hover { background: var(--ts-line); }
.qty-input { border: 0; outline: none; text-align: center; font-weight: 800; font-size: .9rem; width: 100%; font-family: inherit; }

/* ===== No products ===== */
.ts-no-products { grid-column: 1/-1; text-align: center; padding: 60px 20px; color: var(--ts-muted); display: flex; flex-direction: column; align-items: center; gap: 16px; }
.ts-no-products p { font-weight: 700; font-size: 1rem; margin: 0; }
.ts-no-products button { all: unset; cursor: pointer; font-weight: 700; color: var(--ts-green-2); text-decoration: underline; }

/* ===== Pagination ===== */
.ts-pager { padding: 0 16px 18px; display: flex; justify-content: center; gap: 8px; flex-wrap: wrap; margin-top: 8px; }
.ts-pagebtn {
  min-width: 40px; height: 40px; border-radius: 999px; border: 1px solid var(--ts-line);
  background: #fff; display: inline-flex; align-items: center; justify-content: center; padding: 0 8px;
  font-weight: 800; font-size: .88rem; cursor: pointer; transition: .15s; font-family: inherit;
}
.ts-pagebtn:hover { box-shadow: var(--ts-shadow-sm); }
.ts-pagebtn.is-active { background: rgba(43,211,79,.10); border-color: rgba(43,211,79,.35); color: #0b3d1a; box-shadow: 0 0 0 6px rgba(43,211,79,.10); }
.ts-pagebtn--wide { padding: 0 16px; }
.ts-pagebtn--dots { cursor: default; border-color: transparent; background: transparent; box-shadow: none; }

/* ===== Add to cart feedback ===== */
.ts-add-to-cart.is-loading { opacity: .7; pointer-events: none; }
.ts-add-to-cart.is-added { background: linear-gradient(180deg, #0b3d1a, #0a3016) !important; }

/* ===== Fade-in animation for new cards ===== */
@keyframes ts-fadein { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.pcard { animation: ts-fadein .25s ease both; }

/* ===== Responsive ===== */
@media (max-width: 1200px) {
  .ts-grid { grid-template-columns: repeat(3, 1fr); }
  .ts-shopgrid { grid-template-columns: 280px 1fr; }
}
@media (max-width: 980px) {
  .ts-shopgrid { grid-template-columns: 1fr; }
  .ts-filters { position: static; top: auto; max-height: none; display: none; }
  .ts-filters.ts-filters--mobile-open { display: block; }
  .ts-grid { grid-template-columns: repeat(2, 1fr); }
  .ts-mobile-filter-btn { display: inline-flex; }
}
@media (max-width: 600px) {
  .ts-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .ts-panelhead__right { width: 100%; }
  .ts-panelhead__right .ts-select, .ts-panelhead__right .btn { width: 100%; }
}
@media (max-width: 400px) {
  .ts-grid { grid-template-columns: 1fr; }
}

/* ===== Stock count label above qty ===== */
.ts-stock-label {
  display: flex;
  justify-content: center;
  margin-bottom: 2px;
}
.ts-stock-count {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  border-radius: 999px;
  border: 1px solid rgba(43,211,79,.35);
  background: rgba(43,211,79,.08);
  color: #0b3d1a;
  font-weight: 800;
  font-size: .78rem;
}

/* ===== Login to see prices button ===== */
.ts-login-btn {
  background: #111827 !important;
  border-color: #111827 !important;
  color: #fff !important;
  font-weight: 700;
  border-radius: 999px;
  font-size: .88rem;
}
.ts-login-btn strong { font-weight: 900; }
.ts-login-btn:hover {
  background: #1f2937 !important;
  box-shadow: 0 8px 20px rgba(0,0,0,.18) !important;
}

/* ===== Hide mobile filters button (removed from panelhead) ===== */
.ts-mobile-filter-btn { display: none !important; }

/* ===== SweetAlert2 Toast Custom Style ===== */
.ts-swal-toast {
  font-family: Inter, system-ui, sans-serif !important;
  border-radius: 14px !important;
  border: 1px solid rgba(43,211,79,.25) !important;
  box-shadow: 0 14px 40px rgba(15,23,42,.12) !important;
  padding: 12px 16px !important;
}
.ts-swal-title {
  font-size: .95rem !important;
  font-weight: 800 !important;
  color: #0b3d1a !important;
}
.ts-swal-progress {
  background: var(--ts-green) !important;
}
.swal2-success-circular-line-left,
.swal2-success-circular-line-right,
.swal2-success-fix {
  background: transparent !important;
}