:root {
  --bg: #0e0f14;
  --panel: #181a22;
  --panel-2: #1f222c;
  --border: #2a2e3a;
  --txt: #e9ecf2;
  --muted: #9aa3b2;
  --red: #e23636;       /* Marvel red */
  --red-soft: #ff5a5a;
  --green: #2ecc71;
  --gold: #f1c40f;
  --hero: #4aa3ff;
  --villain: #c065ff;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  background: var(--bg);
  color: var(--txt);
  line-height: 1.5;
}

a { color: inherit; text-decoration: none; }

.site-header {
  display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap;
  padding: 18px 22px;
  background: linear-gradient(180deg, #15161d, #0e0f14);
  border-bottom: 2px solid var(--red);
  position: sticky; top: 0; z-index: 10;
}
.brand { font-size: 1.35rem; font-weight: 800; letter-spacing: .3px; }
.brand span { color: var(--red-soft); }
.brand em { color: var(--muted); font-style: normal; font-weight: 600; font-size: .9rem; }
.tagline { color: var(--muted); font-size: .85rem; }

main { max-width: 1200px; margin: 0 auto; padding: 22px; }

/* Stats */
.stats { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 22px; }
.stat {
  background: var(--panel); border: 1px solid var(--border); border-radius: 12px;
  padding: 12px 18px; min-width: 110px; display: flex; flex-direction: column;
}
.stat strong { font-size: 1.6rem; line-height: 1.1; }
.stat span { color: var(--muted); font-size: .78rem; text-transform: uppercase; letter-spacing: .4px; }
.stat.deal strong { color: var(--gold); }

/* Toolbar */
.toolbar { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; margin-bottom: 18px; }
#search {
  flex: 1; min-width: 220px;
  background: var(--panel); border: 1px solid var(--border); border-radius: 10px;
  color: var(--txt); padding: 10px 14px; font-size: .95rem;
}
#search:focus { outline: none; border-color: var(--red); }
.chk { color: var(--muted); font-size: .88rem; display: flex; align-items: center; gap: 6px; cursor: pointer; }

/* Grid */
.grid {
  display: grid; gap: 14px;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
}
.card {
  background: var(--panel); border: 1px solid var(--border); border-radius: 14px;
  padding: 14px; display: flex; flex-direction: column; gap: 8px;
  transition: transform .12s ease, border-color .12s ease, box-shadow .12s ease;
}
.card:hover { transform: translateY(-3px); border-color: var(--red); box-shadow: 0 8px 24px rgba(0,0,0,.35); }
.card.is-deal { border-color: var(--gold); box-shadow: 0 0 0 1px rgba(241,196,15,.25) inset; }
.card.owned { opacity: .68; }

.card-top { display: flex; justify-content: space-between; align-items: center; }
.num { color: var(--muted); font-size: .78rem; font-weight: 700; }
.camp { font-size: .68rem; text-transform: uppercase; letter-spacing: .5px; padding: 2px 8px; border-radius: 999px; font-weight: 700; }
.camp-h { background: rgba(74,163,255,.15); color: var(--hero); }
.camp-v { background: rgba(192,101,255,.15); color: var(--villain); }
.nom { margin: 0; font-size: 1.12rem; }
.type { color: var(--muted); font-size: .8rem; text-transform: capitalize; }

.prices { margin-top: 4px; border-top: 1px solid var(--border); padding-top: 8px; display: flex; flex-direction: column; gap: 4px; }
.price-row { display: flex; justify-content: space-between; font-size: .9rem; }
.price-row .lbl { color: var(--muted); }
.price-row.best .val { font-weight: 800; color: var(--green); }
.price-row.best em { color: var(--muted); font-weight: 400; font-style: italic; }

.card-foot { display: flex; gap: 6px; flex-wrap: wrap; margin-top: auto; }
.badge { font-size: .72rem; background: var(--panel-2); border: 1px solid var(--border); color: var(--muted); border-radius: 999px; padding: 2px 9px; }
.deal-badge { background: rgba(241,196,15,.16); border-color: var(--gold); color: var(--gold); font-weight: 700; }

.empty { color: var(--muted); text-align: center; padding: 40px 10px; }

/* Detail */
.back { color: var(--muted); font-size: .9rem; display: inline-block; margin-bottom: 16px; }
.back:hover { color: var(--red-soft); }
.detail-head { margin-bottom: 22px; }
.detail-id { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-bottom: 6px; }
.type-pill { font-size: .72rem; text-transform: capitalize; background: var(--panel-2); border: 1px solid var(--border); border-radius: 999px; padding: 2px 10px; color: var(--muted); }
.owned-pill { color: var(--gold); border-color: var(--gold); }
.detail-head h1 { margin: 4px 0; font-size: 2rem; }
.detail-cote { color: var(--txt); }
.detail-cote strong { color: var(--green); }
.muted { color: var(--muted); }

.offers h2 { font-size: 1.15rem; border-bottom: 1px solid var(--border); padding-bottom: 8px; }
.offers-table { width: 100%; border-collapse: collapse; font-size: .92rem; }
.offers-table th { text-align: left; color: var(--muted); font-weight: 600; font-size: .78rem; text-transform: uppercase; letter-spacing: .4px; padding: 8px 10px; border-bottom: 1px solid var(--border); }
.offers-table td { padding: 10px; border-bottom: 1px solid var(--border); vertical-align: top; }
.offers-table tr:hover td { background: var(--panel); }
.row-deal td { background: rgba(241,196,15,.06); }
.price-cell { font-weight: 800; white-space: nowrap; }
.title-cell { max-width: 360px; }
.plat { font-size: .72rem; text-transform: uppercase; letter-spacing: .4px; padding: 2px 8px; border-radius: 6px; font-weight: 700; }
.plat-ebay { background: rgba(46,204,113,.15); color: var(--green); }
.plat-vinted { background: rgba(0,178,196,.15); color: #2fd6e6; }
.plat-leboncoin { background: rgba(255,113,0,.15); color: #ff8a3d; }
.ext { color: var(--red-soft); font-weight: 600; white-space: nowrap; }

.site-footer { max-width: 1200px; margin: 30px auto 20px; padding: 16px 22px; color: var(--muted); font-size: .8rem; border-top: 1px solid var(--border); }

@media (max-width: 640px) {
  .offers-table thead { display: none; }
  .offers-table, .offers-table tbody, .offers-table tr, .offers-table td { display: block; width: 100%; }
  .offers-table tr { border: 1px solid var(--border); border-radius: 10px; margin-bottom: 10px; padding: 6px; }
  .offers-table td { border: none; padding: 4px 8px; }
  .title-cell { max-width: none; }
}
