/* Bas-CSS för listnings-motorn. Token-driven: varje sajt sätter --ts-* och kan lägga egna
 * överstyrningar ovanpå. Strukturen är semantisk; temat lever i variablerna. */
.ts {
  --ts-red: #AE171A;
  --ts-fg: #2F383C;
  --ts-bg: #FFFFFF;
  --ts-muted: #6b7378;
  --ts-line: #e4e6e7;
  --ts-card-bg: #ffffff;
  --ts-radius: 10px;
  --ts-font: "Open Sans", system-ui, sans-serif;
  --ts-mono: "IBM Plex Mono", ui-monospace, monospace;
  --ts-gap: 20px;
  color: var(--ts-fg);
  font-family: var(--ts-font);
}
.ts *, .ts *::before, .ts *::after { box-sizing: border-box; }

/* Toolbar */
.ts-toolbar {
  display: flex; flex-wrap: wrap; gap: 12px; align-items: center;
  padding-bottom: 18px; margin-bottom: 22px; border-bottom: 1px solid var(--ts-line);
}
.ts-search, .ts-brand, .ts-cat, .ts-sort {
  font: inherit; font-size: 14px; color: var(--ts-fg); background: var(--ts-bg);
  border: 1px solid var(--ts-line); border-radius: calc(var(--ts-radius) - 4px);
  padding: 9px 12px; min-height: 40px;
}
.ts-search { flex: 1 1 240px; min-width: 180px; }
.ts-brand, .ts-cat, .ts-sort { flex: 0 0 auto; cursor: pointer; }
.ts-search:focus-visible, .ts-brand:focus-visible, .ts-cat:focus-visible, .ts-sort:focus-visible,
.ts-page-btn:focus-visible, .ts-btn:focus-visible, .ts-card__media:focus-visible {
  outline: 2px solid var(--ts-red); outline-offset: 2px;
}
.ts-count { margin-left: auto; font-family: var(--ts-mono); font-size: 13px; color: var(--ts-muted); font-variant-numeric: tabular-nums; }

/* Grid */
.ts-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--ts-gap); }
.ts-card { display: flex; flex-direction: column; background: var(--ts-card-bg); border: 1px solid var(--ts-line); border-radius: var(--ts-radius); overflow: hidden; }
.ts-card__media { position: relative; display: block; aspect-ratio: 4 / 3; background: #f2f3f4; overflow: hidden; }
.ts-card__media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s ease; }
.ts-card__media:hover img { transform: scale(1.03); }
.ts-badge {
  position: absolute; top: 10px; left: 10px; font-family: var(--ts-mono); font-size: 11px;
  letter-spacing: .04em; text-transform: uppercase; padding: 3px 8px; border-radius: 99px; color: #fff;
}
.ts-badge--demo { background: var(--ts-red); }
.ts-badge--used { background: var(--ts-fg); }
.ts-card__body { display: flex; flex-direction: column; gap: 12px; padding: 16px; flex: 1; }
.ts-card__title { margin: 0; font-size: 16px; font-weight: 700; line-height: 1.25; }
.ts-card__spec { display: grid; gap: 6px; margin: 0; }
.ts-card__spec > div { display: flex; justify-content: space-between; gap: 12px; font-size: 13px; border-bottom: 1px dotted var(--ts-line); padding-bottom: 4px; }
.ts-card__spec dt { color: var(--ts-muted); margin: 0; }
.ts-card__spec dd { margin: 0; font-family: var(--ts-mono); font-variant-numeric: tabular-nums; text-align: right; }
.ts-card__cta { display: flex; gap: 8px; margin-top: auto; padding-top: 4px; }
.ts-btn { font: inherit; font-size: 13px; font-weight: 600; text-decoration: none; padding: 9px 12px; border-radius: calc(var(--ts-radius) - 4px); text-align: center; }
.ts-btn--primary { background: var(--ts-red); color: #fff; flex: 1; }
.ts-btn--ghost { color: var(--ts-fg); border: 1px solid var(--ts-line); }
.ts-btn:hover { opacity: .9; }

/* Pager */
.ts-pager { display: flex; flex-wrap: wrap; gap: 6px; justify-content: center; margin-top: 28px; }
.ts-page-btn { font: inherit; font-family: var(--ts-mono); font-size: 14px; min-width: 38px; height: 38px; padding: 0 8px; background: var(--ts-bg); color: var(--ts-fg); border: 1px solid var(--ts-line); border-radius: calc(var(--ts-radius) - 4px); cursor: pointer; }
.ts-page-btn.is-active { background: var(--ts-red); color: #fff; border-color: var(--ts-red); }
.ts-page-btn[disabled] { opacity: .4; cursor: default; }
.ts-gap { align-self: center; color: var(--ts-muted); padding: 0 2px; }

.ts-empty { padding: 40px 0; text-align: center; color: var(--ts-muted); }
.ts-source { margin-top: 24px; font-size: 12.5px; color: var(--ts-muted); }
.ts-source a { color: var(--ts-red); }

@media (max-width: 640px) {
  .ts-count { margin-left: 0; width: 100%; }
  .ts-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .ts-card__title { font-size: 14px; }
  .ts-card__cta { flex-direction: column; }
}
@media (prefers-reduced-motion: reduce) {
  .ts-card__media img { transition: none; }
  .ts { scroll-behavior: auto; }
}
