/* ============================================================
   AKE Katalog (Yedek Parça / Spare Parts) — Enterprise-Redesign
   Eigenes CSS-Grid statt Bootstrap-3-Float. Marke: Navy + Rot.
   ============================================================ */
.ake-catalog {
  --navy: #16223f;
  --navy-700: #233d94;
  --red: #e32726;
  --ink: #1c2433;
  --muted: #6b7689;
  --line: #e7ecf3;
  --surface: #f6f8fb;
  --card: #ffffff;
  --img-bg: #f3f6fb;
  background: var(--surface);
  padding: 56px 0 80px;
  font-family: 'Poppins', sans-serif;
}
.ake-catalog .ake-wrap { max-width: 1240px; margin: 0 auto; padding: 0 24px; }

/* ---- Toolbar (Suche + Anzahl) ---- */
.ake-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 20px; flex-wrap: wrap; margin-bottom: 22px;
}
.ake-count { color: var(--muted); font-size: 14px; font-weight: 500; }
.ake-count b { color: var(--navy); font-weight: 700; }
.ake-search { position: relative; flex: 0 1 340px; min-width: 220px; }
.ake-search svg { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); width: 18px; height: 18px; color: var(--muted); pointer-events: none; }
.ake-search input {
  width: 100%; height: 46px; padding: 0 16px 0 42px;
  border: 1px solid var(--line); border-radius: 10px; background: #fff;
  font-size: 14px; color: var(--ink); transition: border-color .2s, box-shadow .2s;
}
.ake-search input::placeholder { color: #9aa3b2; }
.ake-search input:focus { outline: none; border-color: var(--navy); box-shadow: 0 0 0 3px rgba(22,34,63,.10); }

/* ---- Kategorie-Filter (Chips) ---- */
.ake-filters { display: flex; flex-wrap: wrap; gap: 9px; margin-bottom: 30px; }
.ake-chip {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 15px; border: 1px solid var(--line); border-radius: 999px;
  background: #fff; color: var(--navy); font-size: 13px; font-weight: 500;
  line-height: 1; text-decoration: none; cursor: pointer;
  transition: background .18s, border-color .18s, color .18s, transform .18s;
}
.ake-chip:hover { border-color: var(--navy); background: #eef2f8; color: var(--navy); }
.ake-chip .n { font-size: 11px; color: var(--muted); font-weight: 600; }
.ake-chip.is-active { background: var(--navy); border-color: var(--navy); color: #fff; }
.ake-chip.is-active .n { color: rgba(255,255,255,.7); }

/* ---- Produkt-Grid ---- */
.ake-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(236px, 1fr));
  gap: 22px;
}
.ake-card {
  position: relative; display: flex; flex-direction: column;
  background: var(--card); border: 1px solid var(--line); border-radius: 12px;
  overflow: hidden; transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.ake-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--red); transform: scaleX(0); transform-origin: left;
  transition: transform .25s ease; z-index: 2;
}
.ake-card:hover { transform: translateY(-5px); box-shadow: 0 16px 36px rgba(22,34,63,.13); border-color: #d4dce8; }
.ake-card:hover::before { transform: scaleX(1); }

.ake-card-media { display: block; aspect-ratio: 1 / 1; background: var(--img-bg); border-bottom: 1px solid var(--line); overflow: hidden; }
.ake-card-media img { width: 100%; height: 100%; object-fit: contain; padding: 14px; transition: transform .35s ease; }
.ake-card:hover .ake-card-media img { transform: scale(1.045); }

.ake-card-body { display: flex; flex-direction: column; flex: 1; padding: 16px 16px 18px; }
.ake-eyebrow { font-size: 10.5px; font-weight: 600; letter-spacing: .09em; text-transform: uppercase; color: var(--red); margin-bottom: 7px; }
.ake-card-title { margin: 0 0 14px; font-size: 14.5px; line-height: 1.4; font-weight: 600; color: var(--navy);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; min-height: 2.8em; }
.ake-card-title a { color: inherit; text-decoration: none; }
.ake-card-foot { margin-top: auto; display: flex; align-items: center; gap: 10px; }
.ake-quote {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 9px 14px; border-radius: 8px; font-size: 12.5px; font-weight: 600;
  background: #0f7d3b; color: #fff; text-decoration: none; line-height: 1;
  transition: background .18s, transform .12s;
}
.ake-quote:hover { background: #0b6630; color: #fff; }
.ake-quote:active { transform: scale(.97); }
.ake-quote svg { width: 15px; height: 15px; }
.ake-detaillink { margin-left: auto; display: inline-flex; align-items: center; color: var(--navy); opacity: .55; transition: opacity .18s, transform .18s; }
.ake-card:hover .ake-detaillink { opacity: 1; transform: translateX(2px); }
.ake-detaillink svg { width: 18px; height: 18px; }

.ake-card a:focus-visible, .ake-chip:focus-visible, .ake-quote:focus-visible, .ake-search input:focus-visible { outline: 2px solid var(--navy); outline-offset: 2px; }

/* leeres Suchergebnis */
.ake-empty { display: none; text-align: center; padding: 60px 0; color: var(--muted); }

/* ============================================================
   Produkt-Detail
   ============================================================ */
.ake-detail { --navy:#16223f; --red:#e32726; --muted:#6b7689; --line:#e7ecf3;
  background:#fff; padding: 50px 0 80px; font-family:'Poppins',sans-serif; }
.ake-detail .ake-wrap { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.ake-detail-grid { display: grid; grid-template-columns: minmax(0,1.05fr) minmax(0,1fr); gap: 48px; align-items: start; }
.ake-gallery-main { border: 1px solid var(--line); border-radius: 14px; background: #f3f6fb; aspect-ratio: 4/3; overflow: hidden; display: flex; }
.ake-gallery-main img { width: 100%; height: 100%; object-fit: contain; padding: 26px; }
.ake-thumbs { display: grid; grid-template-columns: repeat(5, 1fr); gap: 10px; margin-top: 12px; }
.ake-thumb { border: 1px solid var(--line); border-radius: 9px; background:#f3f6fb; aspect-ratio: 1/1; overflow: hidden; cursor: pointer; transition: border-color .18s; }
.ake-thumb:hover { border-color: var(--navy); }
.ake-thumb img { width: 100%; height: 100%; object-fit: contain; padding: 8px; }

.ake-detail-info { position: sticky; top: 100px; }
.ake-detail-cat { font-size: 11.5px; font-weight: 600; letter-spacing: .09em; text-transform: uppercase; color: var(--red); }
.ake-detail-title { font-size: 30px; line-height: 1.18; font-weight: 700; color: var(--navy); margin: 10px 0 8px; }
.ake-sku { color: var(--muted); font-size: 13.5px; margin-bottom: 20px; }
.ake-sku b { color: var(--navy); }
.ake-detail-desc { color: #3a4456; font-size: 15px; line-height: 1.75; }
.ake-detail-desc p { margin: 0 0 12px; }
.ake-detail-desc ul { margin: 0 0 14px; padding-left: 20px; }
.ake-detail-desc li { margin-bottom: 6px; }
.ake-quote-card { margin-top: 26px; padding: 22px; border: 1px solid var(--line); border-radius: 14px; background: #f6f8fb; }
.ake-quote-note { color: var(--muted); font-size: 13.5px; margin: 0 0 14px; }
.ake-quote-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px; width: 100%;
  padding: 15px 22px; border-radius: 11px; background: #0f7d3b; color: #fff;
  font-size: 15px; font-weight: 600; text-decoration: none; line-height: 1;
  transition: background .18s, transform .12s; box-shadow: 0 8px 20px rgba(37,165,90,.28);
}
.ake-quote-btn:hover { background: #0b6630; color: #fff; }
.ake-quote-btn:active { transform: translateY(1px); }
.ake-quote-btn svg { width: 19px; height: 19px; }

@media (max-width: 860px) {
  .ake-detail-grid { grid-template-columns: 1fr; gap: 28px; }
  .ake-detail-info { position: static; }
  .ake-detail-title { font-size: 24px; }
}
@media (max-width: 575px) {
  .ake-catalog { padding: 36px 0 56px; }
  .ake-grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 14px; }
  .ake-card-body { padding: 13px; }
}

@media (prefers-reduced-motion: reduce) {
  .ake-card, .ake-card::before, .ake-card-media img, .ake-quote, .ake-detaillink { transition: none; }
}
