/* GufGames — retro arcade theme. */

:root {
  --bg:      #06000f;
  --bg-2:    #0a0419;
  --bg-3:    #15082b;
  --magenta: #ff2bd6;
  --cyan:    #00ffe1;
  --yellow:  #ffe600;
  --dim:     rgba(255,255,255,0.45);

  --pixel: 'Press Start 2P', 'Courier New', monospace;
  --term:  'VT323', 'Courier New', monospace;
}

* { box-sizing: border-box; }

html, body {
  margin: 0; padding: 0;
  background: var(--bg);
  color: #fff;
  font-family: var(--term);
  font-size: 18px;
  min-height: 100%;
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: none; cursor: pointer; }

[hidden] { display: none !important; }

/* CRT overlays (whole-page) */
.crt-vignette {
  position: fixed; inset: 0; pointer-events: none; z-index: 5;
  background: radial-gradient(ellipse at center, transparent 55%, rgba(0,0,0,0.7) 100%);
}
.crt-scanlines {
  position: fixed; inset: 0; pointer-events: none; z-index: 6;
  background: repeating-linear-gradient(0deg,
    rgba(255,255,255,0.05) 0 1px,
    transparent 1px 3px);
}

/* ---- Gallery view ---- */

.view { position: relative; z-index: 1; }

.arcade-header {
  text-align: center;
  padding: 36px 24px 18px;
  border-bottom: 1px dashed rgba(255,43,214,0.3);
}
.arcade-logo {
  font-family: var(--pixel);
  font-size: clamp(28px, 6vw, 48px);
  margin: 0;
  color: var(--magenta);
  letter-spacing: 4px;
  text-shadow:
    0 0 8px var(--magenta),
    0 0 18px var(--magenta),
    0 0 36px rgba(255,43,214,0.55);
}
.arcade-tag {
  margin-top: 12px;
  color: var(--cyan);
  font-size: 22px;
  letter-spacing: 3px;
  text-shadow: 0 0 4px var(--cyan);
}
.arcade-marquee {
  display: flex; justify-content: space-between; align-items: center;
  margin: 18px auto 0; padding: 0 8px;
  max-width: 1200px;
  font-size: 16px; color: var(--yellow); letter-spacing: 1px;
  text-shadow: 0 0 4px rgba(255,230,0,0.6);
  flex-wrap: wrap; gap: 8px;
}
.marquee-link {
  color: var(--yellow);
  border-bottom: 1px dashed var(--yellow);
  padding-bottom: 2px;
}
.marquee-link:hover { color: var(--magenta); border-color: var(--magenta); }

.blink { animation: blink-anim 1.1s steps(2,start) infinite; }
@keyframes blink-anim { to { visibility: hidden; } }

.arcade-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 1200px;
  margin: 0 auto;
  padding: 32px 24px;
}
@media (max-width: 900px) { .arcade-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .arcade-grid { grid-template-columns: 1fr; } }

.loading, .empty {
  grid-column: 1 / -1;
  text-align: center;
  font-family: var(--pixel);
  font-size: 14px;
  color: var(--cyan);
  letter-spacing: 2px;
  padding: 60px 0;
  text-shadow: 0 0 4px var(--cyan);
}

.cabinet {
  display: block;
  background: linear-gradient(180deg, var(--bg-3) 0%, var(--bg-2) 100%);
  border: 2px solid var(--cyan);
  border-radius: 4px;
  overflow: hidden;
  cursor: pointer;
  box-shadow:
    0 0 12px rgba(0,255,225,0.35),
    inset 0 0 18px rgba(0,255,225,0.06);
  transition: transform .12s ease, box-shadow .12s ease;
}
.cabinet:hover {
  transform: translateY(-4px);
  box-shadow:
    0 0 22px rgba(0,255,225,0.7),
    0 0 40px rgba(255,43,214,0.25),
    inset 0 0 18px rgba(0,255,225,0.06);
}

.screen {
  background: #000;
  aspect-ratio: 1 / 1;
  display: flex; align-items: center; justify-content: center;
  font-size: 64px;
  border-bottom: 2px solid var(--cyan);
  position: relative;
  overflow: hidden;
}
.screen::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: repeating-linear-gradient(0deg,
    rgba(255,255,255,0.05) 0 1px,
    transparent 1px 2px);
}
.screen.has-shot { font-size: 0; padding: 0; }
.screen.has-shot img {
  width: 100%; height: 100%; display: block;
  object-fit: cover; image-rendering: pixelated;
}

.cabinet-meta { padding: 12px 14px 14px; }
.cabinet-title {
  font-family: var(--pixel);
  font-size: 11px;
  line-height: 1.5;
  color: #fff;
  text-shadow: 0 0 4px rgba(255,255,255,0.3);
  margin-bottom: 10px;
  min-height: 32px;
  word-break: break-word;
}
.cabinet-by {
  font-size: 16px;
  color: var(--yellow);
  letter-spacing: 1px;
}
.cabinet-date {
  font-size: 14px;
  color: var(--dim);
  letter-spacing: 1px;
  margin-top: 2px;
}
.play-strip {
  margin-top: 10px;
  padding: 5px 8px;
  background: rgba(255,43,214,0.15);
  border: 1px solid var(--magenta);
  text-align: center;
  font-size: 14px;
  color: var(--magenta);
  letter-spacing: 2px;
  text-shadow: 0 0 4px rgba(255,43,214,0.6);
}

.arcade-foot {
  text-align: center;
  padding: 18px 24px 28px;
  font-size: 14px;
  color: rgba(0,255,225,0.55);
  letter-spacing: 1px;
  border-top: 1px dashed rgba(0,255,225,0.2);
}

/* ---- Player view ---- */

#player-view {
  position: fixed; inset: 0;
  display: flex; flex-direction: column;
  background: var(--bg);
  z-index: 2;
}

.player-bar {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 18px;
  padding: 10px 16px;
  background: linear-gradient(180deg, var(--bg-3), var(--bg-2));
  border-bottom: 2px solid var(--magenta);
  box-shadow: 0 0 10px rgba(255,43,214,0.3);
  position: relative;
}
.player-bar::after {
  content:""; position:absolute; left:0; right:0; bottom:-2px; height:2px;
  background: repeating-linear-gradient(90deg,
    var(--magenta) 0 8px, transparent 8px 14px);
}

.back-btn, .restart-btn {
  font-family: var(--pixel);
  font-size: 10px;
  letter-spacing: 1px;
  padding: 7px 11px;
  background: transparent;
  cursor: pointer;
}
.back-btn {
  color: var(--cyan);
  border: 1px solid var(--cyan);
  text-shadow: 0 0 4px var(--cyan);
  box-shadow: 0 0 6px rgba(0,255,225,0.4);
}
.back-btn:hover { background: rgba(0,255,225,0.12); }

.player-title {
  text-align: center;
  font-family: var(--pixel);
  font-size: 13px;
  color: var(--magenta);
  text-shadow: 0 0 6px var(--magenta), 0 0 14px rgba(255,43,214,0.6);
  letter-spacing: 2px;
}

.player-meta {
  display: flex; align-items: center; gap: 10px;
  font-size: 16px; color: var(--yellow); letter-spacing: 1px;
  text-shadow: 0 0 4px rgba(255,230,0,0.5);
  text-align: right;
}
.restart-btn {
  color: var(--yellow);
  border: 1px solid var(--yellow);
  font-size: 9px;
  text-shadow: 0 0 4px var(--yellow);
  box-shadow: 0 0 6px rgba(255,230,0,0.3);
}
.restart-btn:hover { background: rgba(255,230,0,0.1); }

.player-frame {
  flex: 1 1 auto;
  background: #000;
  position: relative;
}
#game-iframe {
  width: 100%; height: 100%;
  border: 0; display: block;
}

@media (max-width: 540px) {
  .player-meta span { display: none; }   /* hide BY · DATE on small screens */
  .player-title { font-size: 11px; letter-spacing: 1px; }
}
