/* ═══════════════════════════════════════════════════════════════════
   CLAIRO — Buscador de preço (página /precos)
   Reusa tokens.css + topbar/footer de games-page.css. Aqui só o que é
   exclusivo da busca: barra de busca, tabela de preços, cards de loja.
   ═══════════════════════════════════════════════════════════════════ */

.precos-wrap { max-width: 1080px; margin: 0 auto; padding: 0 32px 64px; }

/* ───── barra de busca ───── */
.search-panel {
  background: var(--s1);
  border: 1px solid var(--b1);
  border-radius: var(--r3);
  padding: 20px;
  margin: 8px auto 0;
  max-width: 1080px;
}
.search-row { display: flex; gap: 10px; flex-wrap: wrap; }
.search-box { flex: 1; min-width: 240px; position: relative; display: flex; align-items: center; }
.search-box svg { position: absolute; left: 16px; opacity: .45; pointer-events: none; }
#q {
  width: 100%; background: var(--bg); color: var(--t1);
  border: 1.5px solid var(--b2); border-radius: var(--r2);
  padding: 14px 16px 14px 46px; font-size: 16px; font-family: var(--font-body);
  transition: border-color .18s, box-shadow .18s;
}
#q:focus { outline: none; border-color: var(--ac); box-shadow: 0 0 0 4px var(--acg); }
.search-btn {
  cursor: pointer; border: 0; border-radius: var(--r2); padding: 14px 28px;
  font-size: 15px; font-weight: 600; font-family: var(--font-body);
  color: #fff; background: var(--ac); transition: filter .15s, transform .1s;
}
.search-btn:hover { filter: brightness(1.08); }
.search-btn:active { transform: translateY(1px); }
.cc-pill {
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--s3); border: 1px solid var(--b1); border-radius: var(--r2);
  padding: 0 14px; font-size: 13px; font-weight: 600; color: var(--t2);
}
.cc-pill .flag { font-size: 16px; }
.cc-note { margin-top: 12px; font-size: 12px; color: var(--t3); line-height: 1.5; }

/* ───── grupos / seções de resultado ───── */
.grp {
  display: flex; align-items: center; gap: 10px;
  margin: 30px 0 12px; font-family: var(--font-tech);
  font-size: 13px; font-weight: 600; letter-spacing: .06em;
  color: var(--t2); text-transform: uppercase;
}
.grp::after { content: ""; flex: 1; height: 1px; background: linear-gradient(90deg, var(--b2), transparent); }
.tag { font-size: 10px; font-weight: 700; padding: 3px 9px; border-radius: 999px; text-transform: none; letter-spacing: 0; }
.tag.live { background: var(--grg); color: #6fd897; border: 1px solid rgba(58,158,88,.4); }
.tag.reg  { background: var(--steam-g); color: #9fd6ff; border: 1px solid rgba(76,188,255,.4); }
.tag.lnk  { background: var(--acg); color: #ffb677; border: 1px solid rgba(224,92,48,.4); }
.tag.muted{ background: var(--s3); color: var(--t3); border: 1px solid var(--b1); }

/* ───── filtros ───── */
.filters { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; margin-bottom: 14px; }
.filters select, .filters input[type=number], .filters input[type=text] {
  background: var(--bg); color: var(--t1); border: 1px solid var(--b1);
  border-radius: var(--r1); padding: 9px 11px; font-size: 13px; font-family: var(--font-body);
}
.filters input[type=number] { width: 120px; }
.filters input[type=text] { min-width: 150px; flex: 1; }
.filters select:focus, .filters input:focus { outline: none; border-color: var(--ac); }
.ck {
  display: inline-flex; align-items: center; gap: 7px; font-size: 13px; color: var(--t2);
  background: var(--s2); border: 1px solid var(--b1); border-radius: 999px;
  padding: 8px 13px; cursor: pointer; user-select: none;
}
.ck input { width: 15px; height: 15px; accent-color: var(--ac); cursor: pointer; }
.fcount { font-size: 12px; color: var(--t3); margin-left: auto; }

/* ───── tabela ───── */
.ptable { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; font-size: 14px; }
th, td { text-align: left; padding: 11px 8px; }
th {
  font-size: 11px; color: var(--t3); text-transform: uppercase; letter-spacing: .05em;
  border-bottom: 1px solid var(--b1); font-family: var(--font-tech); font-weight: 600;
}
th.sortable { cursor: pointer; user-select: none; white-space: nowrap; transition: color .15s; }
th.sortable:hover { color: var(--ac); }
th.act { color: var(--ac); }
tr.deal { border-bottom: 1px solid var(--b1); }
tr.deal:hover { background: var(--s1); }
.game { font-weight: 600; color: var(--t1); }
.store { display: flex; align-items: center; gap: 8px; color: var(--t2); }
.store img { width: 18px; height: 18px; border-radius: 4px; }
.price { font-weight: 700; color: var(--t1); white-space: nowrap; }
.normal { color: var(--t3); text-decoration: line-through; font-size: 12px; margin-left: 6px; }
tr.deal.free td { background: var(--grg); }
.freebadge {
  display: inline-block; background: var(--gr); color: #04140b; font-weight: 800;
  border-radius: 6px; padding: 3px 10px; font-size: 12px; letter-spacing: .02em;
}
.off { background: var(--acg); color: #ffb677; border-radius: 6px; padding: 2px 7px; font-size: 11px; font-weight: 700; white-space: nowrap; }
.buy {
  background: var(--ac); color: #fff; font-weight: 600; text-decoration: none;
  padding: 7px 13px; border-radius: var(--r1); font-size: 13px; white-space: nowrap; transition: filter .15s;
}
.buy:hover { filter: brightness(1.1); }

/* ───── cards de loja (links externos) ───── */
.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: 10px; }
.card {
  display: flex; align-items: center; gap: 10px; background: var(--s1);
  border: 1px solid var(--b1); border-radius: var(--r2); padding: 13px;
  position: relative; overflow: hidden; transition: border-color .15s;
}
.card::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--c, var(--ac)); }
.card:hover { border-color: var(--c, var(--ac)); }
.card a { flex: 1; color: var(--t1); text-decoration: none; font-weight: 600; font-size: 14px; }
.card a .d { display: block; font-size: 11px; color: var(--t3); font-weight: 400; margin-top: 3px; }
.card a:hover { color: var(--c, var(--ac)); }
.card .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--c, var(--ac)); flex: none; }
.card .arr { color: var(--t3); font-size: 12px; }

/* ───── estados ───── */
.state { padding: 36px 6px; color: var(--t3); text-align: center; }
.state .big { font-size: 40px; display: block; margin-bottom: 10px; opacity: .5; }
.spin {
  display: inline-block; width: 18px; height: 18px; border: 3px solid var(--b2);
  border-top-color: var(--ac); border-radius: 50%; animation: spin .7s linear infinite;
  vertical-align: -4px; margin-right: 8px;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ───── nota de rodapé do resultado ───── */
.precos-note {
  margin-top: 28px; font-size: 12px; color: var(--t3); line-height: 1.65;
  border-top: 1px solid var(--b1); padding-top: 16px;
}
.precos-note b { color: var(--t2); }

@media (max-width: 640px) {
  .precos-wrap { padding: 0 16px 48px; }
  .normal { display: none; }
  th.h, td.h { display: none; }
}
