:root {
  --bg: #0b0b0c;
  --card: #141417;
  --text: #f2f2f2;
  --muted: #b7b7b7;
  --link: #7db7ff;
  --border: #2a2a31;
  --accent: #2f8cff;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  background: var(--bg);
  color: var(--text);
}

.container {
  width: min(1200px, 100%);
  margin: 0 auto;
  padding: 24px 24px 110px;
}

.header h1 {
  margin: 0 0 6px;
  font-size: 28px;
}

.sub { margin: 0; color: var(--muted); }
.status { margin: 18px 0; color: var(--muted); }

.list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

.card {
  padding: 14px;
  background: var(--card);
  border: 2px solid var(--border);
  border-radius: 12px;
  cursor: pointer;
  transition: border-color 120ms ease, background 120ms ease;
  overflow: hidden;
}

.card:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.card.selected {
  border-color: var(--accent);
  background: #162234;
}

.rail {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 2px 2px 8px;
  margin: -2px -2px 0;
  scrollbar-width: thin;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
}

.rail::-webkit-scrollbar {
  height: 8px;
}

.rail::-webkit-scrollbar-thumb {
  background: #3a3f49;
  border-radius: 999px;
}

.photo-wrap {
  flex: 0 0 auto;
  scroll-snap-align: start;
}

.tile {
  width: clamp(160px, 36vw, 260px);
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: #0f0f12;
}

.photo-wrap.is-missing { display: none; }

.meta-row {
  margin-top: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.meta-block {
  min-width: 0;
}

.product-title {
  margin: 0 0 4px;
  font-size: 19px;
  font-weight: 700;
  line-height: 1.3;
  color: var(--text);
}

.meta {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
}

.meta a {
  color: var(--link);
  text-decoration: none;
}

.meta a:hover { text-decoration: underline; }

.select-btn {
  flex: 0 0 auto;
  min-width: 110px;
  padding: 10px 14px;
  border-radius: 10px;
  border: 1px solid #4b5b77;
  background: #1d2a3f;
  color: #fff;
  font-weight: 700;
  cursor: pointer;
}

.card.selected .select-btn {
  background: var(--accent);
  border-color: #7fb8ff;
}

.select-btn.will-exceed {
  background: #4a1f24;
  border-color: #ff6b6b;
  color: #ffd7d7;
}

.summary-bar {
  position: sticky;
  bottom: 0;
  z-index: 50;
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
  padding: 12px 16px;
  background: rgba(16, 20, 26, 0.96);
  border-top: 1px solid var(--border);
  backdrop-filter: blur(4px);
}

.summary-count,
.summary-total {
  font-weight: 600;
}

.summary-total { color: #b8d9ff; }

.summary-total.over-budget {
  color: #ff6b6b;
}

.clear-btn {
  padding: 8px 12px;
  border-radius: 8px;
  border: 1px solid #555;
  background: #2a2a2a;
  color: #fff;
  cursor: pointer;
}

.clear-btn:disabled {
  opacity: 0.55;
  cursor: default;
}

.named-controls {
  display: inline-flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.saved-name-input,
.saved-select {
  height: 36px;
  border-radius: 8px;
  border: 1px solid #555;
  background: #181818;
  color: #fff;
  padding: 0 10px;
}

.saved-msg {
  color: var(--muted);
  font-size: 12px;
}

@media (max-width: 900px) {
  .container {
    padding: 18px 16px 120px;
  }

  .meta-row {
    align-items: stretch;
    flex-direction: column;
  }

  .product-title {
    font-size: 18px;
  }

  .select-btn {
    width: 100%;
  }
}

@media (max-width: 560px) {
  .header h1 {
    font-size: 24px;
  }

  .rail {
    gap: 10px;
  }

  .tile {
    width: min(75vw, 240px);
  }

  .summary-bar {
    justify-content: flex-start;
    padding: 10px 12px;
  }

  .named-controls {
    width: 100%;
  }

  .saved-name-input,
  .saved-select {
    width: 100%;
  }
}
