/* ============================================================
   Teleskoplastare till salu — GENERALAGENTEN-temat på den delade motorn
   Token-driven: vi sätter bara --ts-* + ett par bespoke-överstyrningar.
   engine.js orörd. Endast #AE171A · #2F383C · #FFFFFF (+ neutrala linjer).
   ============================================================ */

/* ---- Sid-skal: ärver generalagentens primitiver via styles.css ---- */
.ts-page {
  max-width: calc(var(--maxw) + var(--rail-w));
  margin: 0 auto;
  padding: var(--s5) var(--gut) var(--s8);
}
@media (min-width: 1024px) {
  .ts-page { padding-left: calc(var(--gut) + var(--rail-w)); }
}

/* ---- Hero/rubrikstrip i sajtens ton ---- */
.ts-hero {
  max-width: var(--maxw);
  padding-bottom: var(--s5);
  margin-bottom: var(--s5);
  border-bottom: 1px solid var(--ink-14);
}
.ts-hero__title {
  font-weight: 800;
  letter-spacing: -0.015em;
  line-height: 1.04;
  font-size: clamp(2rem, 4.6vw, 3.6rem);
  max-width: 16ch;
  color: var(--ink);
}
.ts-hero__intro {
  margin-top: var(--s3);
  font-size: clamp(1.02rem, 1.5vw, 1.22rem);
  color: var(--ink-60);
  max-width: 54ch;
}
/* måttlinje-DNA: tunn röd markör + mono-rad under rubriken */
.ts-hero__meta {
  margin-top: var(--s4);
  display: flex; flex-wrap: wrap; align-items: center; gap: 0.6em;
  font-family: var(--ff-mono);
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  color: var(--ink-60);
}
.ts-hero__meta b { color: var(--ink); font-weight: 600; }
.ts-hero__meta::before {
  content: ""; width: 28px; height: 2px; background: var(--red);
  display: inline-block; flex: 0 0 auto;
}

/* ============================================================
   MOTORNS TOKENS → generalagentens värden
   ============================================================ */
.ts {
  --ts-red:     var(--red);
  --ts-fg:      var(--ink);
  --ts-bg:      var(--paper);
  --ts-muted:   var(--ink-60);
  --ts-line:    var(--ink-14);
  --ts-card-bg: var(--paper);
  --ts-radius:  4px;                       /* rena raka linjer, som knapparna */
  --ts-font:    var(--ff-sans);
  --ts-mono:    var(--ff-mono);
  --ts-gap:     var(--s3);
}

/* ============================================================
   BESPOKE-ÖVERSTYRNINGAR — så listan känns som DENNA sajt
   ============================================================ */

/* Toolbar: tunn underlinje precis som sektionernas rytm */
.ts .ts-toolbar {
  padding-bottom: var(--s3);
  margin-bottom: var(--s4);
  border-bottom: 1px solid var(--ink-14);
  gap: var(--s2);
}
.ts .ts-search,
.ts .ts-brand,
.ts .ts-cat,
.ts .ts-sort {
  border-radius: 4px;
  border-color: var(--ink-14);
  transition: border-color .2s var(--ease);
}
.ts .ts-search:hover,
.ts .ts-brand:hover,
.ts .ts-cat:hover,
.ts .ts-sort:hover { border-color: var(--ink-40); }

/* Räknaren i mono — måttlinje-känsla, röd siffra */
.ts .ts-count {
  margin-left: auto;
  font-family: var(--ff-mono);
  font-size: 0.82rem;
  letter-spacing: 0.04em;
  color: var(--ink-60);
  white-space: nowrap;
}

/* Grid: tre per rad på desktop, ren luft */
.ts .ts-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s4) var(--s4);
}
@media (max-width: 980px) { .ts .ts-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .ts .ts-grid { grid-template-columns: 1fr; gap: var(--s3); } }

/* Kort: vit yta, hårfin linje, röd kant vid hover (ingen skugga-slop) */
.ts .ts-card {
  background: var(--paper);
  border: 1px solid var(--ink-14);
  border-radius: 4px;
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: border-color .25s var(--ease), transform .25s var(--ease);
}
.ts .ts-card:hover {
  border-color: var(--red);
  transform: translateY(-2px);
}
.ts .ts-card__media {
  position: relative;
  display: block;
  aspect-ratio: 4 / 3;
  background: var(--ink-08);
  overflow: hidden;
}
.ts .ts-card__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .4s var(--ease);
}
.ts .ts-card:hover .ts-card__media img { transform: scale(1.03); }

/* Badge: röd = begagnad, ink = demo. Mono, versal, raka hörn. */
.ts .ts-badge {
  position: absolute; top: var(--s2); left: var(--s2);
  font-family: var(--ff-mono);
  font-size: 0.62rem; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  padding: 5px 9px;
  color: #fff;
  border-radius: 2px;
}
.ts .ts-badge--used { background: var(--red); }
.ts .ts-badge--demo { background: var(--ink); }

.ts .ts-card__body {
  padding: var(--s3);
  display: flex; flex-direction: column; gap: var(--s2);
  flex: 1;
}
.ts .ts-card__title {
  font-weight: 700;
  font-size: 1.02rem;
  line-height: 1.25;
  color: var(--ink);
}

/* Spec som mätrad: mono-värden, tunna delningslinjer */
.ts .ts-card__spec {
  display: grid; gap: 0;
  margin: 0;
  border-top: 1px solid var(--ink-08);
}
.ts .ts-card__spec > div {
  display: flex; justify-content: space-between; align-items: baseline; gap: var(--s2);
  padding: 7px 0;
  border-bottom: 1px solid var(--ink-08);
}
.ts .ts-card__spec dt {
  font-size: 0.74rem;
  letter-spacing: 0.02em;
  color: var(--ink-60);
}
.ts .ts-card__spec dd {
  font-family: var(--ff-mono);
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--ink);
  text-align: right;
}

/* Kort-CTA: primär röd, ghost mono — speglar sajtens .btn-språk */
.ts .ts-card__cta {
  margin-top: auto;
  display: flex; gap: var(--s2);
  padding-top: var(--s1);
}
.ts .ts-btn {
  font-weight: 700;
  font-size: 0.9rem;
  padding: 10px 14px;
  border-radius: 4px;
  border: 1px solid transparent;
  transition: background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease), transform .25s var(--ease);
  white-space: nowrap;
}
.ts .ts-btn--primary { background: var(--red); color: #fff; }
.ts .ts-btn--primary:hover { background: var(--red-dim); transform: translateY(-1px); }
.ts .ts-btn--ghost {
  background: transparent; color: var(--ink);
  border-color: var(--ink-14);
  font-family: var(--ff-mono);
  font-size: 0.82rem;
}
.ts .ts-btn--ghost:hover { border-color: var(--red); color: var(--red); }

/* Pager: aktiv = röd, mono-siffror (motorn ger detta — vi finputsar) */
.ts .ts-page-btn {
  border-radius: 4px;
  border-color: var(--ink-14);
  transition: border-color .2s var(--ease), background .2s var(--ease);
}
.ts .ts-page-btn:hover:not([disabled]):not(.is-active) { border-color: var(--ink-40); }
.ts .ts-page-btn.is-active { background: var(--red); border-color: var(--red); }

/* Källrad nere — diskret, röd länk */
.ts .ts-source {
  margin-top: var(--s4);
  padding-top: var(--s3);
  border-top: 1px solid var(--ink-08);
  font-family: var(--ff-mono);
  font-size: 0.76rem;
  letter-spacing: 0.02em;
  color: var(--ink-60);
}
.ts .ts-source a { color: var(--red); font-weight: 600; }

.ts .ts-empty { color: var(--ink-60); }

/* Mobil: räknaren får egen rad, toolbar staplas snyggt */
@media (max-width: 640px) {
  .ts .ts-count { margin-left: 0; width: 100%; order: 99; }
}

/* Reduced-motion: motorn + base.css respekterar redan; nollställ våra hovers */
@media (prefers-reduced-motion: reduce) {
  .ts .ts-card,
  .ts .ts-card__media img,
  .ts .ts-btn,
  .ts .ts-page-btn { transition: none; }
  .ts .ts-card:hover { transform: none; }
  .ts .ts-card:hover .ts-card__media img { transform: none; }
}
