:root {
  color-scheme: dark;
}

.cards-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 36px 24px 80px;
}

.cards-panel {
  background: linear-gradient(160deg, rgba(30,41,59,0.88), rgba(15,23,42,0.94));
  border: 1px solid rgba(148,163,184,0.22);
  border-radius: 10px;
  padding: 18px 20px;
  margin-bottom: 20px;
  box-shadow: 0 18px 40px rgba(2,6,23,0.35), inset 0 1px 0 rgba(148,163,184,0.12);
  backdrop-filter: blur(10px);
}

.inventory-panel {
  margin-bottom: 16px;
}

.inventory-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}

.inventory-hint {
  font-size: 11px;
  color: var(--muted);
}

.inventory-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 12px;
}

.panel-title {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 12px;
}

.filters-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  align-items: stretch;
  grid-auto-rows: minmax(92px, auto);
}

.filter-group label {
  display: block;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 6px;
}

.filter-group {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 12px 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-height: 92px;
}

.filter-group .domain-checklist,
.filter-group .filter-select,
.filter-group .filter-input {
  flex: 1 1 auto;
}

.domain-checklist {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  background: rgba(15,23,42,0.35);
  border: 1px solid rgba(148,163,184,0.2);
  border-radius: 8px;
  padding: 10px;
  min-height: 44px;
}

.domain-pill {
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 6px 12px;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 1px;
  text-transform: uppercase;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  transition: transform .12s, border-color .12s, color .12s, background .12s;
}

.domain-pill:hover {
  transform: translateY(-1px);
  color: var(--text);
  border-color: rgba(148,163,184,0.5);
}

.domain-pill.active {
  color: #0b0f17;
  font-weight: 700;
}

.domain-pill.tipo-subclasse.active {
  background: #22d3ee;
  border-color: #22d3ee;
}
.domain-pill.tipo-classe.active {
  background: #f97316;
  border-color: #f97316;
}
.domain-pill.tipo-ancestralidade.active {
  background: #a78bfa;
  border-color: #a78bfa;
}
.domain-pill.tipo-comunidade.active {
  background: #34d399;
  border-color: #34d399;
}
.domain-pill.tipo-dominio.active {
  background: #f59e0b;
  border-color: #f59e0b;
}
.domain-pill.subtipo-talento.active {
  background: #e879f9;
  border-color: #e879f9;
}
.domain-pill.subtipo-feitico.active {
  background: #60a5fa;
  border-color: #60a5fa;
}

.domain-pill.domain-arcano.active {
  background: #c084fc;
  border-color: #c084fc;
}
.domain-pill.domain-sabedoria.active {
  background: #22c55e;
  border-color: #22c55e;
}
.domain-pill.domain-lamina.active {
  background: #ef4444;
  border-color: #ef4444;
}
.domain-pill.domain-falange.active {
  background: #f8fafc;
  border-color: #f8fafc;
  color: #0f172a;
}
.domain-pill.domain-valor.active {
  background: #fb923c;
  border-color: #fb923c;
}
.domain-pill.domain-graca.active {
  background: #f9a8d4;
  border-color: #f9a8d4;
}
.domain-pill.domain-codice.active {
  background: #38bdf8;
  border-color: #38bdf8;
}
.domain-pill.domain-meia-noite.active {
  background: #0f172a;
  border-color: #0f172a;
  color: #e2e8f0;
}
.domain-pill.domain-esplendor.active {
  background: #facc15;
  border-color: #facc15;
}

.filter-input,
.filter-select {
  width: 100%;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 8px 12px;
  color: var(--text);
  font-family: var(--sans);
  font-size: 13px;
  outline: none;
  transition: border-color .2s;
}

.filter-select {
  appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, var(--muted) 50%),
    linear-gradient(135deg, var(--muted) 50%, transparent 50%);
  background-position: calc(100% - 18px) 50%, calc(100% - 12px) 50%;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-right: 28px;
}

.filter-select:focus {
  background-image: linear-gradient(45deg, transparent 50%, var(--accent) 50%),
    linear-gradient(135deg, var(--accent) 50%, transparent 50%);
}

.filter-input:focus,
.filter-select:focus {
  border-color: var(--accent);
}

.filter-row {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 14px;
}

.filter-actions {
  margin-left: auto;
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.results-count {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--muted);
}

.cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
}

.card-item {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 220px;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.card-item:hover {
  transform: translateY(-3px) scale(1.02);
  border-color: rgba(148,163,184,0.45);
  box-shadow: 0 16px 28px rgba(2,6,23,0.35);
}

.card-zoom:hover {
  transform: none;
  box-shadow: none;
}

.card-header {
  padding: 12px 14px;
  border-bottom: 1px solid var(--border);
  background: var(--surface2);
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.card-number {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 1px;
  color: var(--muted);
}

.card-chip {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 2px 6px;
  border-radius: 4px;
  border: 1px solid var(--border);
  color: var(--text);
  background: rgba(0,229,255,0.08);
}

.card-chip.domain {
  color: var(--accent);
  border-color: rgba(0,229,255,0.3);
}

.card-chip.tipo {
  color: var(--accent2);
  border-color: rgba(255,107,53,0.35);
  background: rgba(255,107,53,0.08);
}

.card-chip.subtipo {
  color: var(--accent3);
  border-color: rgba(168,85,247,0.35);
  background: rgba(168,85,247,0.08);
}

.card-chip.domain-arcano {
  color: #c084fc;
  border-color: rgba(192,132,252,0.4);
  background: rgba(192,132,252,0.12);
}
.card-chip.domain-sabedoria {
  color: #22c55e;
  border-color: rgba(34,197,94,0.35);
  background: rgba(34,197,94,0.12);
}
.card-chip.domain-lamina {
  color: #ef4444;
  border-color: rgba(239,68,68,0.4);
  background: rgba(239,68,68,0.12);
}
.card-chip.domain-falange {
  color: #f8fafc;
  border-color: rgba(248,250,252,0.45);
  background: rgba(248,250,252,0.08);
}
.card-chip.domain-valor {
  color: #fb923c;
  border-color: rgba(251,146,60,0.4);
  background: rgba(251,146,60,0.12);
}
.card-chip.domain-graca {
  color: #f9a8d4;
  border-color: rgba(249,168,212,0.4);
  background: rgba(249,168,212,0.12);
}
.card-chip.domain-codice {
  color: #38bdf8;
  border-color: rgba(56,189,248,0.4);
  background: rgba(56,189,248,0.12);
}
.card-chip.domain-meia-noite {
  color: #94a3b8;
  border-color: rgba(15,23,42,0.8);
  background: rgba(15,23,42,0.6);
}
.card-chip.domain-esplendor {
  color: #facc15;
  border-color: rgba(250,204,21,0.45);
  background: rgba(250,204,21,0.12);
}

.card-chip.tipo-subclasse {
  color: #22d3ee;
  border-color: rgba(34,211,238,0.4);
  background: rgba(34,211,238,0.12);
}
.card-chip.tipo-classe {
  color: #f97316;
  border-color: rgba(249,115,22,0.4);
  background: rgba(249,115,22,0.12);
}
.card-chip.tipo-ancestralidade {
  color: #a78bfa;
  border-color: rgba(167,139,250,0.4);
  background: rgba(167,139,250,0.12);
}
.card-chip.tipo-comunidade {
  color: #34d399;
  border-color: rgba(52,211,153,0.4);
  background: rgba(52,211,153,0.12);
}
.card-chip.tipo-dominio {
  color: #f59e0b;
  border-color: rgba(245,158,11,0.4);
  background: rgba(245,158,11,0.12);
}
.card-chip.subtipo-talento {
  color: #e879f9;
  border-color: rgba(232,121,249,0.4);
  background: rgba(232,121,249,0.12);
}
.card-chip.subtipo-feitico {
  color: #60a5fa;
  border-color: rgba(96,165,250,0.4);
  background: rgba(96,165,250,0.12);
}

.card-body {
  padding: 14px 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.card-actions {
  display: flex;
  justify-content: flex-end;
}

.card-action {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: none;
  font-size: 18px;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: transform .12s ease, box-shadow .12s ease, background .12s ease;
}

.card-action.is-add {
  background: #22c55e;
  color: #0b0f17;
  box-shadow: 0 8px 14px rgba(34,197,94,0.35);
}

.card-action.is-remove {
  background: #ef4444;
  color: #0b0f17;
  box-shadow: 0 8px 14px rgba(239,68,68,0.3);
}

.card-action:hover {
  transform: scale(1.08);
}

.inventory-badge {
  color: #22c55e;
  border-color: rgba(34,197,94,0.4);
  background: rgba(34,197,94,0.12);
}

.card-title {
  font-family: var(--mono);
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
}

.card-meta {
  font-size: 11px;
  color: var(--muted);
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px 12px;
}

.card-text {
  font-size: 12px;
  color: var(--text);
  line-height: 1.6;
  white-space: pre-wrap;
}

.card-richtext {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.card-richtext p {
  margin: 0;
}

.card-richtext ul {
  margin: 0;
  padding-left: 18px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.card-richtext li {
  margin: 0;
}

.rt-key {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--accent);
}

.grimorio-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.grimorio-spell {
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid rgba(148,163,184,0.2);
  background: rgba(15,23,42,0.35);
}

.grimorio-title {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--accent2);
  margin-bottom: 4px;
}

.grimorio-desc {
  color: var(--text);
  font-size: 12px;
  line-height: 1.6;
}

.grimorio-desc p,
.grimorio-desc li {
  font-size: 12px;
  line-height: 1.6;
}

.card-footer {
  margin-top: auto;
  padding: 12px 16px;
  border-top: 1px solid var(--border);
  font-size: 11px;
  color: var(--muted);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.zoom-overlay {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(2,6,23,0.75);
  z-index: 9999;
  padding: 24px;
}

.zoom-dialog {
  max-width: 820px;
  width: min(90vw, 820px);
  max-height: 90vh;
  overflow: auto;
  background: var(--surface);
  border: 1px solid rgba(148,163,184,0.25);
  border-radius: 12px;
  padding: 18px;
  position: relative;
  box-shadow: 0 20px 50px rgba(2,6,23,0.5);
}

.zoom-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,0.3);
  background: rgba(15,23,42,0.8);
  color: var(--text);
  font-size: 18px;
  cursor: pointer;
}

.zoom-content .card-item {
  min-height: unset;
}

.empty-state {
  text-align: center;
  padding: 40px 12px;
  color: var(--muted);
  font-size: 13px;
}

.card-float {
  position: fixed;
  z-index: 9999;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(34,197,94,0.9);
  color: #0b0f17;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 1px;
  text-transform: uppercase;
  transform: translate(0, 0) scale(1);
  opacity: 1;
  pointer-events: none;
  transition: transform .45s ease, opacity .45s ease;
}

@media (max-width: 900px) {
  .filters-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-auto-rows: minmax(120px, auto);
  }
  .filter-group {
    min-height: 120px;
  }
  .inventory-grid {
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  }
}

@media (max-width: 600px) {
  .filters-grid {
    grid-template-columns: 1fr;
  }
  .filter-group[style] {
    grid-column: auto !important;
  }
  .card-meta {
    grid-template-columns: 1fr;
  }
  .filter-actions {
    margin-left: 0;
    width: 100%;
    justify-content: flex-start;
  }
}
