/* ─── collection.css v2 ─────────────────────────────────────────────────── */

/* Access denied */
.coll-access-denied {
  text-align: center;
  padding: 60px 20px;
  color: var(--text);
}
.coll-lock-icon { font-size: 3rem; margin-bottom: 12px; }
.coll-access-denied h2 { font-size: 1.4rem; margin-bottom: 8px; }
.coll-access-denied p  { color: var(--muted); margin-bottom: 20px; }
.coll-btn-vip {
  display: inline-block;
  padding: 10px 28px;
  background: var(--gold);
  color: #000;
  border-radius: 6px;
  font-weight: 700;
  text-decoration: none;
  transition: opacity .15s;
}
.coll-btn-vip:hover { opacity: .85; }

/* Loading */
.coll-loading {
  position: fixed;
  top: calc(50% + 80px);
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  color: var(--muted);
  font-size: 1rem;
  z-index: 100;
}

/* Header */
.coll-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
  flex-wrap: wrap;
}
.coll-header h1 { font-size: 1.5rem; margin: 0 0 4px; color: var(--text); }
.coll-subtitle   { color: var(--muted); margin: 0; font-size: .9rem; }
.coll-header-actions { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }

.coll-save-badge {
  font-size: .8rem;
  color: #4ade80;
  background: rgba(74,222,128,.12);
  border: 1px solid rgba(74,222,128,.3);
  padding: 4px 10px;
  border-radius: 20px;
}
.coll-btn-share {
  padding: 7px 16px;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text);
  cursor: pointer;
  font-size: .85rem;
  transition: background .15s;
}
.coll-btn-share:hover { background: var(--border); }

/* View-only badge */
.coll-view-badge-wrap {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.2);
  color: #fff;
  border-radius: 5px;
  padding: 3px 9px;
  font-size: 0.74rem;
  font-weight: 400;
}
.coll-view-badge-wrap strong {
  font-weight: 700;
  color: #fff;
}

/* Tabs */
.coll-tabs {
  display: flex;
  gap: 4px;
  border-bottom: 2px solid var(--border);
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.coll-tab {
  padding: 9px 18px;
  border: none;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  font-size: .9rem;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  border-radius: 4px 4px 0 0;
  transition: color .15s, border-color .15s;
  display: flex;
  align-items: center;
  gap: 6px;
}
.coll-tab:hover { color: var(--text); }
.coll-tab.active { color: var(--gold); border-bottom-color: var(--gold); }
.coll-tab-count {
  background: var(--card-bg);
  border: 1px solid var(--border);
  padding: 1px 7px;
  border-radius: 12px;
  font-size: .75rem;
  color: var(--text);
}
.coll-tab.active .coll-tab-count { background: rgba(212,163,88,.15); border-color: rgba(212,163,88,.4); color: var(--gold); }

/* Tab content */
.coll-tab-content { display: none; }
.coll-tab-content.active { display: block; }

/* Search */
.coll-search-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
}
.coll-search-wrap input {
  flex: 1;
  padding: 9px 14px;
  background: var(--input-bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text);
  font-size: .9rem;
}
.coll-search-wrap input:focus { outline: none; border-color: var(--gold); }
.coll-search-count { color: var(--muted); font-size: .82rem; white-space: nowrap; }

/* ── Cards grid */
.coll-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 8px;
}
.coll-card-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  cursor: pointer;
  transition: border-color .15s, background .15s;
  user-select: none;
}
.coll-card-item:hover { border-color: var(--gold); background: rgba(212,163,88,.05); }
.coll-card-item.checked { border-color: #4ade80; background: rgba(74,222,128,.07); }
.coll-card-item img {
  width: 28px;
  height: 28px;
  object-fit: contain;
  flex-shrink: 0;
  border-radius: 3px;
}
.coll-card-name {
  font-size: .78rem;
  color: var(--text);
  line-height: 1.2;
  flex: 1;
  overflow: hidden;
}
.coll-card-effect {
  font-size: .7rem;
  color: #4ade80;
  margin-top: 1px;
}
.coll-card-check {
  width: 16px;
  height: 16px;
  border: 1px solid var(--border);
  border-radius: 3px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .7rem;
  color: #4ade80;
}
.coll-card-item.checked .coll-card-check { background: rgba(74,222,128,.2); border-color: #4ade80; }

/* ── Pets grid */
.coll-pets-grid { display: flex; flex-direction: column; gap: 20px; }
.coll-pets-tier { }
.coll-pets-tier-title {
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  padding: 6px 10px;
  border-radius: 4px;
  margin-bottom: 10px;
  display: inline-block;
}
.tier-UC .coll-pets-tier-title { color: #4ade80; background: rgba(74,222,128,.1); }
.tier-R  .coll-pets-tier-title { color: #60a5fa; background: rgba(96,165,250,.1); }
.tier-E  .coll-pets-tier-title { color: #a78bfa; background: rgba(167,139,250,.1); }
.coll-pets-tier-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 8px;
}
.coll-pet-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 8px;
  cursor: pointer;
  transition: border-color .15s, background .15s;
  user-select: none;
}
.coll-pet-item:hover { border-color: var(--gold); }
.tier-UC .coll-pet-item.checked { border-color: #4ade80; background: rgba(74,222,128,.07); }
.tier-R  .coll-pet-item.checked { border-color: #60a5fa; background: rgba(96,165,250,.07); }
.tier-E  .coll-pet-item.checked { border-color: #a78bfa; background: rgba(167,139,250,.07); }
.coll-pet-item img {
  width: 36px;
  height: 36px;
  object-fit: contain;
  flex-shrink: 0;
}
.coll-pet-info { flex: 1; overflow: hidden; }
.coll-pet-name   { font-size: .85rem; color: var(--text); }
.coll-pet-effect { font-size: .75rem; color: var(--muted); margin-top: 2px; }
.coll-pet-check {
  width: 18px;
  height: 18px;
  border: 1px solid var(--border);
  border-radius: 4px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .75rem;
}
.tier-UC .coll-pet-item.checked .coll-pet-check { background: rgba(74,222,128,.2); border-color: #4ade80; color: #4ade80; }
.tier-R  .coll-pet-item.checked .coll-pet-check { background: rgba(96,165,250,.2); border-color: #60a5fa; color: #60a5fa; }
.tier-E  .coll-pet-item.checked .coll-pet-check { background: rgba(167,139,250,.2); border-color: #a78bfa; color: #a78bfa; }

/* ── Costumes grid */
.coll-costumes-grid { display: flex; flex-direction: column; gap: 20px; }
.coll-slot-title {
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--gold);
  padding: 6px 0 8px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 10px;
}
.coll-costume-section-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 8px;
}
.coll-costume-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  cursor: pointer;
  transition: border-color .15s, background .15s;
  user-select: none;
}
.coll-costume-item:hover { border-color: var(--gold); }
.coll-costume-item.checked { border-color: #e879f9; background: rgba(232,121,249,.06); }
.coll-costume-item img {
  width: 30px;
  height: 30px;
  object-fit: contain;
  flex-shrink: 0;
}
.coll-costume-name   { font-size: .78rem; color: var(--text); flex: 1; overflow: hidden; line-height: 1.2; }
.coll-costume-effect { font-size: .7rem; color: #e879f9; margin-top: 1px; }
.coll-costume-check {
  width: 16px;
  height: 16px;
  border: 1px solid var(--border);
  border-radius: 3px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .7rem;
  color: #e879f9;
}
.coll-costume-item.checked .coll-costume-check { background: rgba(232,121,249,.2); border-color: #e879f9; }

/* ── Union */
.coll-union-info {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 16px;
  margin-bottom: 20px;
  color: var(--muted);
  font-size: .85rem;
  line-height: 1.5;
  display: flex;
  align-items: center;
  gap: 16px;
}
.coll-union-info p { margin: 0; flex: 1; }
.coll-union-info strong { color: var(--text); }
.coll-union-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 10px;
  margin-bottom: 24px;
}
.coll-union-class {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 14px;
}
.coll-union-class-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.coll-union-class-name { font-size: .9rem; font-weight: 600; color: var(--text); }
.coll-union-class-bonus { font-size: .75rem; color: var(--gold); }
.coll-union-levels {
  display: flex;
  gap: 4px;
}
.coll-union-lvl-btn {
  flex: 1;
  padding: 5px 2px;
  text-align: center;
  font-size: .72rem;
  background: var(--input-bg);
  border: 1px solid var(--border);
  border-radius: 4px;
  cursor: pointer;
  color: var(--muted);
  transition: all .12s;
}
.coll-union-lvl-btn:hover { border-color: var(--gold); color: var(--text); }
.coll-union-lvl-btn.active { background: rgba(212,163,88,.15); border-color: var(--gold); color: var(--gold); font-weight: 700; }

/* Account Level box */
.coll-union-acclvl {
  background: var(--card-bg);
  border: 1px solid var(--gold);
  border-radius: 10px;
  padding: 16px 20px;
  text-align: center;
  margin-bottom: 20px;
}
.coll-union-acclvl-title { font-size: .8rem; color: var(--muted); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 6px; }
.coll-union-acclvl-val   { font-size: 2.5rem; font-weight: 800; color: var(--gold); margin-bottom: 10px; }
.coll-union-acclvl-bonuses {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  font-size: .8rem;
}
.coll-acclvl-bonus {
  background: rgba(212,163,88,.1);
  border: 1px solid rgba(212,163,88,.3);
  color: var(--gold);
  padding: 3px 10px;
  border-radius: 12px;
}

/* ── Totals bar */
.coll-totals-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--nav-bg, #161b22);
  border-top: 1px solid var(--border);
  z-index: 200;
  transition: transform .2s;
}
.coll-totals-bar.collapsed { transform: translateY(calc(100% - 38px)); }
.coll-totals-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 8px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.coll-totals-title { font-size: .85rem; font-weight: 700; color: var(--gold); white-space: nowrap; }
.coll-totals-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  flex: 1;
}
.coll-total-chip {
  font-size: .75rem;
  padding: 2px 9px;
  border-radius: 12px;
  background: rgba(74,222,128,.1);
  border: 1px solid rgba(74,222,128,.25);
  color: #4ade80;
  white-space: nowrap;
}
/* ── All Buffs tab */
.coll-buffs-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 4px 0;
}
.coll-buffs-empty {
  color: var(--muted);
  font-size: .85rem;
  padding: 24px 16px;
  text-align: center;
}
/* Secoes colapsaveis */
.coll-buff-section {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
}
.coll-buff-section-hdr {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  cursor: pointer;
  user-select: none;
  border-bottom: 1px solid var(--border);
  transition: background .15s;
}
.coll-buff-section-hdr:hover { background: rgba(255,255,255,.04); }
.coll-buff-section-title { font-size: .85rem; font-weight: 600; color: var(--text); flex: 1; }
.coll-buff-section-count {
  font-size: .72rem;
  background: rgba(255,255,255,.08);
  border-radius: 10px;
  padding: 1px 7px;
  color: var(--muted);
}
.coll-buff-section-arrow { font-size: .75rem; color: var(--muted); transition: transform .2s; }
.coll-buff-section.collapsed .coll-buff-section-arrow { transform: rotate(-90deg); }
.coll-buff-section.collapsed .coll-buff-section-body { display: none; }
.coll-buff-section-body {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 12px 14px;
}
/* Total Geral */
.coll-buff-grand-total {
  border: 1px solid var(--gold);
  border-radius: 8px;
  overflow: hidden;
  margin-top: 4px;
}
.coll-buff-grand-title {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  font-size: .85rem;
  font-weight: 700;
  color: var(--gold);
  border-bottom: 1px solid rgba(212,163,88,.25);
}
.coll-buff-grand-body {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 12px 14px;
}
.coll-total-chip-grand {
  background: rgba(212,163,88,.12);
  border-color: rgba(212,163,88,.35);
  color: var(--gold);
}
.coll-totals-toggle {
  background: transparent;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: .85rem;
  padding: 4px 8px;
  flex-shrink: 0;
}


@media (max-width: 600px) {
  .coll-tabs { gap: 2px; }
  .coll-tab  { padding: 8px 10px; font-size: .8rem; }
  .coll-cards-grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); }
  .coll-union-grid { grid-template-columns: 1fr; }
}

/* ── Botões Limpar aba/total */
.coll-btn-clear-tab {
  background: rgba(239,68,68,.12);
  color: #f87171;
  border: 1px solid rgba(239,68,68,.3);
  border-radius: 6px;
  padding: 4px 12px;
  font-size: .78rem;
  cursor: pointer;
  transition: background .15s, border-color .15s;
  white-space: nowrap;
  flex-shrink: 0;
}
.coll-btn-clear-tab:hover {
  background: rgba(239,68,68,.22);
  border-color: rgba(239,68,68,.55);
}
.coll-btn-clear-all {
  background: rgba(239,68,68,.15);
  color: #f87171;
  border: 1px solid rgba(239,68,68,.4);
  border-radius: 6px;
  padding: 4px 14px;
  font-size: .8rem;
  cursor: pointer;
  transition: background .15s;
  white-space: nowrap;
  flex-shrink: 0;
}
.coll-btn-clear-all:hover {
  background: rgba(239,68,68,.28);
}
