/* ─── pinock.io/matchbox — warm cream/red vintage matchbox theme ──────── */

:root {
  --mb-bg:        #fdf5e0;
  --mb-bg-card:   #ffffff;
  --mb-fg:        #2a1810;
  --mb-fg-dim:    #8a6a4e;
  --mb-accent:    #b22222;
  --mb-accent-2:  #d4a017;
  --mb-border:    rgba(42, 24, 16, 0.12);
  --mb-border-hot:rgba(178, 34, 34, 0.45);
  --mb-shadow:    0 1px 3px rgba(60,30,0,0.06), 0 6px 20px rgba(60,30,0,0.08);
  --mb-shadow-hot:0 4px 12px rgba(60,30,0,0.10), 0 12px 32px rgba(60,30,0,0.14);
}

body.matchbox-theme {
  background:
    radial-gradient(ellipse at top left, #fff5d6 0%, transparent 60%),
    radial-gradient(ellipse at bottom right, #f8e4c0 0%, transparent 60%),
    var(--mb-bg);
  color: var(--mb-fg);
  min-height: 100vh;
}

/* ─── Topbar ─── */
body.matchbox-theme .topbar {
  background: rgba(253, 245, 224, 0.94);
  border-bottom: 2px solid var(--mb-accent);
  backdrop-filter: blur(10px);
}
body.matchbox-theme .logo { color: var(--mb-fg); }
body.matchbox-theme .logo .dim {
  color: var(--mb-accent);
  font-weight: 700;
  margin-left: 2px;
  font-style: italic;
}

/* ─── Search ─── */
body.matchbox-theme .search input {
  background: var(--mb-bg-card);
  border: 1px solid var(--mb-border);
  color: var(--mb-fg);
}
body.matchbox-theme .search input::placeholder { color: var(--mb-fg-dim); }
body.matchbox-theme .search input:focus {
  border-color: var(--mb-accent);
  box-shadow: 0 0 0 3px rgba(178, 34, 34, 0.12);
  outline: none;
}
body.matchbox-theme .search button {
  background: var(--mb-accent);
  color: var(--mb-bg);
}

/* ─── Action buttons ─── */
body.matchbox-theme .ghost {
  color: var(--mb-fg);
  border: 1px solid var(--mb-border);
  background: var(--mb-bg-card);
}
body.matchbox-theme .ghost:hover {
  color: var(--mb-accent);
  background: var(--mb-bg);
  border-color: var(--mb-border-hot);
}

/* ─── Grid cards (labels look best on cream tile with subtle border) ─── */
body.matchbox-theme .grid > * {
  background: var(--mb-bg-card);
  border: 1px solid var(--mb-border);
  border-radius: 4px;
  overflow: hidden;
  transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s;
  box-shadow: var(--mb-shadow);
}
body.matchbox-theme .grid > *:hover {
  transform: translateY(-2px);
  border-color: var(--mb-border-hot);
  box-shadow: var(--mb-shadow-hot);
}

/* ─── Modal ─── */
body.matchbox-theme .modal-content {
  background: var(--mb-bg-card);
  border: 1px solid var(--mb-border);
  color: var(--mb-fg);
}
body.matchbox-theme .modal-content h2 { color: var(--mb-fg); }
body.matchbox-theme .caption { color: var(--mb-fg-dim); }
body.matchbox-theme .action {
  background: var(--mb-bg);
  border: 1px solid var(--mb-border);
  color: var(--mb-fg);
}
body.matchbox-theme .action:hover {
  background: var(--mb-bg-card);
  border-color: var(--mb-border-hot);
}
body.matchbox-theme .action.primary {
  background: var(--mb-accent);
  border: 0;
  color: var(--mb-bg);
}
body.matchbox-theme .action.primary:hover { background: #8b0000; }

/* ─── Footer ─── */
body.matchbox-theme .foot {
  color: var(--mb-fg-dim);
  border-top: 1px solid var(--mb-border);
}
body.matchbox-theme .foot a {
  color: var(--mb-accent);
  text-decoration: underline;
  text-decoration-color: var(--mb-border-hot);
  text-underline-offset: 3px;
}

/* ─── Status / load more ─── */
body.matchbox-theme .status { color: var(--mb-fg-dim); }
body.matchbox-theme .load-more-btn {
  background: var(--mb-bg-card);
  border: 1px solid var(--mb-border);
  color: var(--mb-fg);
}
body.matchbox-theme .load-more-btn:hover {
  background: var(--mb-bg);
  border-color: var(--mb-border-hot);
}

/* ─── /matchbox grid: medium cards (~280px) ─── */
body.matchbox-theme .grid {
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}
@media (max-width: 1800px) { body.matchbox-theme .grid { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); } }
@media (max-width: 1400px) { body.matchbox-theme .grid { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); } }
@media (max-width: 1100px) { body.matchbox-theme .grid { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); } }
@media (max-width: 800px)  { body.matchbox-theme .grid { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); } }
@media (max-width: 520px)  { body.matchbox-theme .grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); } }

/* ─── Tab-nav active red ring ─── */
body.matchbox-theme .tab-link.active img {
  filter: none;
  outline: 2px solid var(--mb-accent);
  outline-offset: 4px;
  border-radius: 12px;
}
body.matchbox-theme .tab-link:hover img {
  filter: brightness(0.95);
}
