:root {
  color-scheme: dark;
  --fg: #e8e6e0;
  --bg: #0f0f10;
  --accent: #c9b27e;
  --muted: rgba(232,230,224,0.55);
}

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
html, body {
  margin: 0; padding: 0;
  height: 100%; width: 100%;
  background: var(--bg); color: var(--fg);
  font-family: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  overflow: hidden; overscroll-behavior: none;
}

#gallery-canvas {
  display: block;
  width: 100vw; height: 100vh;
  width: 100dvw; height: 100dvh;
  cursor: url('./cursor-arrow.svg') 2 2, default;
  touch-action: none;
}

/* Custom cursor on the whole page so it sits consistently over any layer. */
html, body, #gallery-canvas, #hud, #overlay {
  cursor: url('./cursor-arrow.svg') 2 2, default;
}

/* Hover-over-artwork: swap to pointing-hand. */
body.contour-hover #gallery-canvas {
  cursor: url('./cursor-point.svg') 10 3, pointer;
}

/* Interactive elements still get their expected pointer. */
#hud button, #hud a, #overlay button, #overlay a {
  cursor: url('./cursor-point.svg') 10 3, pointer;
}

#hud {
  position: fixed;
  top: max(12px, env(safe-area-inset-top));
  right: max(12px, env(safe-area-inset-right));
  display: flex; gap: 10px; align-items: center;
  z-index: 10; pointer-events: auto;
}

#devpanel {
  position: fixed;
  top: max(12px, env(safe-area-inset-top));
  left: max(12px, env(safe-area-inset-left));
  z-index: 10;
  display: grid;
  grid-template-columns: auto auto;
  gap: 2px 12px;
  padding: 8px 12px;
  font: 11px/1.4 ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  color: var(--muted);
  background: rgba(0,0,0,0.45);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  pointer-events: auto;
  user-select: none;
}
#devpanel .k { color: rgba(232,230,224,0.45); text-transform: uppercase; letter-spacing: 0.08em; }
#devpanel .v { color: var(--fg); text-align: right; font-variant-numeric: tabular-nums; }
#devpanel.hidden { display: none; }
@media (pointer: coarse) {
  #devpanel { font-size: 10px; padding: 6px 10px; }
}

#hud button, #hud a {
  appearance: none;
  font: inherit;
  color: var(--fg);
  background: rgba(0,0,0,0.45);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 999px;
  padding: 8px 14px;
  text-decoration: none;
  cursor: pointer;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transition: background 0.15s;
}
#hud button:hover, #hud a:hover {
  background: rgba(0,0,0,0.7);
  border-color: var(--accent);
}

#loader {
  position: fixed; inset: 0;
  display: grid; place-items: center;
  background: var(--bg);
  z-index: 100;
  transition: opacity 0.4s;
}
.loader-inner { text-align: center; opacity: 0.95; }
.loader-title { font-size: 28px; letter-spacing: 0.03em; }
.loader-sub { margin-top: 8px; color: var(--muted); font-size: 14px; }

#tap-hint {
  position: fixed;
  bottom: max(16px, env(safe-area-inset-bottom));
  left: 50%;
  transform: translateX(-50%);
  padding: 8px 14px;
  background: rgba(0,0,0,0.55);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 999px;
  color: var(--muted);
  font-size: 12px;
  pointer-events: none;
  z-index: 10;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

@media (pointer: coarse) {
  #tap-hint::before { content: "tap artwork · drag to look · left thumbstick walks"; }
  #tap-hint { font-size: 0; }
  #tap-hint::before { font-size: 12px; }
  /* Hide custom cursor on touch devices — it's visual clutter. */
  html, body, #gallery-canvas, #hud, #overlay { cursor: auto; }
}

/* ---- Work-detail overlay ---- */
#overlay {
  position: fixed; inset: 0; z-index: 50;
  display: none;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  align-items: center; justify-content: center;
  padding: 24px;
  color: var(--fg);
}
#overlay.open { display: flex; }
#overlay-card {
  background: #1a1a1b;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 14px;
  max-width: 960px; width: 100%;
  max-height: 90vh; overflow: hidden;
  display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  box-shadow: 0 10px 60px rgba(0,0,0,0.6);
}
#overlay-card .art {
  background: #0b0b0c center/contain no-repeat;
  min-height: 320px;
}
#overlay-card .details {
  padding: 28px 28px 22px; display: flex; flex-direction: column; gap: 10px;
  overflow-y: auto;
}
#overlay-card h2 { margin: 0; font-weight: 500; font-size: 24px; letter-spacing: 0.01em; }
#overlay-card .sub { color: var(--muted); font-size: 13px; }
#overlay-card .meta {
  display: grid; grid-template-columns: max-content 1fr; gap: 6px 14px;
  font-size: 13px; margin-top: 8px;
}
#overlay-card .meta dt { color: var(--muted); font-weight: normal; }
#overlay-card .meta dd { margin: 0; }
#overlay-card .desc { color: rgba(232,230,224,0.85); font-size: 14px; line-height: 1.55; margin-top: 8px; }
#overlay-card .actions { display: flex; gap: 10px; margin-top: 14px; flex-wrap: wrap; }
#overlay-card .actions .primary {
  background: var(--accent); color: #0f0f10; border: none; padding: 10px 18px;
  border-radius: 8px; font: inherit; text-decoration: none;
}
#overlay-card .actions .ghost {
  background: transparent; color: var(--fg);
  border: 1px solid rgba(255,255,255,0.15); padding: 10px 16px;
  border-radius: 8px; font: inherit;
}
#overlay-card .status-chip {
  display: inline-block; padding: 2px 10px; border-radius: 999px; font-size: 11px;
  background: rgba(120,120,120,0.2); color: var(--muted); letter-spacing: 0.04em;
  text-transform: uppercase;
}
#overlay-card .status-chip.available { background: rgba(120, 180, 130, 0.25); color: #bfe4c8; }
#overlay-card .status-chip.reserved { background: rgba(210, 170, 60, 0.25); color: #e7d295; }
#overlay-card .status-chip.sold { background: rgba(160, 80, 80, 0.3); color: #d9a4a4; }
#overlay-card .status-chip.draft { background: rgba(180, 120, 200, 0.3); color: #e1bef0; }

/* Preview-mode banner */
body.preview-mode::before {
  content: "PREVIEW MODE — drafts visible";
  position: fixed;
  top: 0; left: 0; right: 0;
  padding: 6px 12px;
  background: rgba(180, 120, 200, 0.75);
  color: #0f0f10;
  font: 11px/1.4 ui-monospace, monospace;
  text-align: center;
  z-index: 20;
  letter-spacing: 0.1em;
  pointer-events: none;
}
body.preview-mode #hud { top: calc(max(12px, env(safe-area-inset-top)) + 26px); }
body.preview-mode #devpanel { top: calc(max(12px, env(safe-area-inset-top)) + 26px); }
@media (max-width: 760px) {
  #overlay-card { grid-template-columns: 1fr; max-height: 92vh; }
  #overlay-card .art { min-height: 220px; max-height: 46vh; }
}
