:root {
  --bg: #0d1620;
  --bg-elev: #15212e;
  --bg-card: #1b2a3a;
  --border: #2a3d52;
  --text: #e6f0f7;
  --text-dim: #93a8bd;
  --frost: #5ec8f0;
  --frost-deep: #2b7fb0;
  --danger: #e25c5c;
  --ok: #5ed18a;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font: 16px/1.4 system-ui, -apple-system, "Segoe UI", sans-serif;
  -webkit-text-size-adjust: 100%;
}

/* ---------- Filter header ---------- */
#filters {
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--bg-elev);
  border-bottom: 1px solid var(--border);
  padding: .5rem;
  display: flex;
  flex-direction: column;
  gap: .5rem;
}

.filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: center;
}

.filter-row.selects label {
  display: inline-flex;
  flex-direction: column;
  font-size: .7rem;
  color: var(--text-dim);
  gap: .15rem;
}

.filter-row.selects label.toggle {
  flex-direction: row;
  align-items: center;
  gap: .35rem;
  font-size: .8rem;
  color: var(--text);
  align-self: flex-end;
}

#f-text {
  flex: 1 1 12rem;
  min-width: 0;
}

input, select, button {
  font: inherit;
  color: var(--text);
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: .4rem;
  padding: .4rem .55rem;
}

button { cursor: pointer; }
button:hover { border-color: var(--frost); }

#manage-party { border-color: var(--frost-deep); }

.chips { display: flex; flex-wrap: wrap; gap: .35rem; }
.chip {
  padding: .25rem .6rem;
  border-radius: 1rem;
  font-size: .8rem;
  background: var(--bg-card);
}
.chip[aria-pressed="true"] {
  background: var(--frost-deep);
  border-color: var(--frost);
  color: #fff;
}

.count { font-size: .75rem; color: var(--text-dim); }

/* ---------- Grid ---------- */
#grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: .5rem;
  padding: .5rem;
}

.card {
  position: relative;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: .5rem;
  overflow: hidden;
  cursor: pointer;
  text-align: left;
  padding: 0;
  color: inherit;
}
.card:hover { border-color: var(--frost); }
.card img { width: 100%; height: auto; display: block; }

.card .label {
  padding: .35rem .5rem;
  font-size: .8rem;
}
.card .label .id { color: var(--text-dim); font-size: .7rem; }

.badges {
  position: absolute;
  top: .3rem;
  left: .3rem;
  right: .3rem;
  display: flex;
  flex-wrap: wrap;
  gap: .25rem;
  pointer-events: none;
}
.pill {
  font-size: .7rem;
  line-height: 1;
  padding: .2rem .4rem;
  border-radius: 1rem;
  background: rgba(0, 0, 0, .65);
  color: #fff;
  backdrop-filter: blur(2px);
}
.pill.qty { background: var(--frost-deep); margin-left: auto; }
.pill.crafted { background: rgba(94, 209, 138, .85); color: #06210f; }
.pill.owners { background: rgba(94, 200, 240, .85); color: #06212b; }
.card.locked img { filter: grayscale(.6) brightness(.7); }

/* ---------- Detail slide-over ---------- */
#detail {
  position: fixed;
  top: 0;
  right: 0;
  height: 100vh;
  width: min(480px, 100%);
  background: var(--bg-elev);
  border-left: 1px solid var(--border);
  box-shadow: -8px 0 24px rgba(0, 0, 0, .5);
  z-index: 20;
  overflow-y: auto;
  padding: 1rem;
}
#detail[hidden] { display: none; }

#detail .detail-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: .5rem;
}
#detail h2 { margin: 0 0 .25rem; font-size: 1.1rem; }
#detail .close { font-size: 1.2rem; line-height: 1; padding: .2rem .55rem; }

#detail .img-wrap { position: relative; margin: .75rem 0; text-align: center; }
#detail .img-wrap img { max-width: 100%; height: auto; border-radius: .5rem; }
#detail .flip { margin-top: .5rem; }

#detail fieldset {
  border: 1px solid var(--border);
  border-radius: .5rem;
  margin: .75rem 0;
  padding: .6rem .75rem;
}
#detail legend { color: var(--frost); font-size: .8rem; padding: 0 .35rem; }
#detail .state-row label { display: flex; align-items: center; gap: .5rem; margin: .3rem 0; }

.owner-row {
  display: flex;
  align-items: center;
  gap: .5rem;
  margin: .35rem 0;
}
.owner-row .name { flex: 1; }
.owner-row input[type="number"] { width: 4.5rem; }
.owner-total { font-size: .8rem; color: var(--text-dim); margin-top: .4rem; }

/* ---------- Members dialog ---------- */
#members {
  background: var(--bg-elev);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: .6rem;
  width: min(420px, 92vw);
  padding: 1rem;
}
#members::backdrop { background: rgba(0, 0, 0, .6); }
#members h2 { margin: 0 0 .5rem; }
#members .member-row, #members .add-row {
  display: flex;
  gap: .4rem;
  align-items: center;
  margin: .35rem 0;
}
#members .member-row input,
#members .add-row input { flex: 1; min-width: 0; }
#members .add-row { margin-top: .75rem; border-top: 1px solid var(--border); padding-top: .75rem; }
#members .add-row button { flex: 0 0 auto; background: var(--frost-deep); border-color: var(--frost-deep); color: var(--text); }
#members .remove { border-color: var(--danger); color: var(--danger); }
#members .dialog-foot { margin-top: .75rem; text-align: right; }

/* ---------- Toast ---------- */
#toast {
  position: fixed;
  bottom: 1rem;
  left: 50%;
  transform: translateX(-50%);
  background: var(--danger);
  color: #fff;
  padding: .6rem 1rem;
  border-radius: .5rem;
  box-shadow: 0 4px 16px rgba(0, 0, 0, .5);
  z-index: 50;
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s;
}
#toast.show { opacity: 1; }
#toast.success { background: var(--ok); color: #06210f; }

/* ---------- Grid status / retry ---------- */
.grid-message {
  grid-column: 1 / -1;
  text-align: center;
  color: var(--text-dim);
  padding: 2rem 1rem;
}
.grid-message button { margin-top: .75rem; }

/* ---------- Mobile detail = full sheet ---------- */
@media (max-width: 600px) {
  #detail {
    width: 100%;
    height: 100vh;
    border-left: none;
  }
}
