/* ============================================================
   GAL.CSS — Gallery Store
   Retro aesthetic, mobile-first, cyan/yellow/black palette
   ============================================================ */

/* ── Reset & base ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  background: #000;
  color: #FFFF55;
  font-family: 'Courier New', Courier, monospace;
  font-size: 16px;
  text-align: center;
  min-height: 100vh;
}

a { color: #FFFF55; text-decoration: none; }
a:hover { background: #FFFF55; color: #000; }

/* ── Page wrapper ── */
.gal-page {
  max-width: 720px;
  margin: 0 auto;
  padding: 16px 12px 40px;
}

/* ── Header ── */
.gal-header {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin: 12px 0 8px;
  flex-wrap: wrap;
}

.gal-title {
  font-size: clamp(18px, 5vw, 28px);
  color: #FFFF55;
  text-shadow:
    1px 1px 0 #000,
    2px 2px 0 #00FFFF,
    3px 3px 0 #005577;
  font-weight: bold;
  letter-spacing: 1px;
}

.flame-gif {
  width: 25px;
  height: 40px;
}

.rider-gif {
  width: min(24vw, 160px);
  height: auto;
  margin: 4px 0;
}

.gal-sub {
  color: #00FFFF;
  font-size: clamp(13px, 3vw, 16px);
  margin: 4px 0 12px;
}

/* ── Gallery / doom viewport ── */
.gallery {
  width: 100%;
  margin: 0 auto 16px;
}

.doom-viewport {
  position: relative;
  width: 100vw;
  left: 50%;
  transform: translateX(-50%);
  border: none;
  background: #111;
  overflow: hidden;
  margin: 8px 0;
}

.viewport-background {
  width: 100%;
  height: auto;
  display: block;
  cursor: crosshair;
}

.card-animation-container {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

/* ── Painting info table ── */
.gal-table {
  width: 100%;
  max-width: 672px;
  margin: 0 auto 16px;
  border-collapse: collapse;
  border: 1px solid #005577;
  font-size: clamp(14px, 3.5vw, 17px);
}

.gal-table td {
  padding: 8px 12px;
  vertical-align: top;
  border: 1px solid #005577;
}

.gal-gallery-name {
  color: #00FFFF;
  font-size: clamp(13px, 3vw, 16px);
  text-align: center;
  border-bottom: 1px solid #005577;
}

.gal-buy-cell {
  text-align: center;
  vertical-align: middle;
  min-width: 140px;
  color: #cc44cc;
  background: #1a001a;
  animation: cellShimmer 3s ease-in-out infinite alternate;
}

@keyframes cellShimmer {
  0%   { background: #1a001a; box-shadow: inset 0 0 8px rgba(204,68,204,0.15); }
  40%  { background: #200020; box-shadow: inset 0 0 14px rgba(0,255,255,0.1); }
  70%  { background: #1a0022; box-shadow: inset 0 0 18px rgba(204,68,204,0.25); }
  100% { background: #001422; box-shadow: inset 0 0 12px rgba(0,85,119,0.3); }
}

.gal-desc-cell {
  color: #ccc;
  text-align: left;
  line-height: 1.5;
}

/* ── Buy button ── */
.buy-painting-btn {
  margin-top: 10px;
  font-family: 'Courier New', Courier, monospace;
  font-size: clamp(15px, 4vw, 19px);
  font-weight: bold;
  color: #000;
  background: #FFFF55;
  border: 2px solid #00FFFF;
  padding: 6px 14px;
  cursor: pointer;
  letter-spacing: 0.5px;
  box-shadow: 2px 2px 0 #00FFFF, 0 0 8px rgba(255,255,85,0.3);
  transition: background 0.1s, color 0.1s;
  display: block;
  width: 100%;
  animation: btnPulse 2s ease-in-out infinite alternate;
}

.buy-painting-btn:hover {
  background: #00FFFF;
  color: #000;
  border-color: #FFFF55;
  box-shadow: 2px 2px 0 #FFFF55;
}

@keyframes btnPulse {
  0%   { box-shadow: 2px 2px 0 #00FFFF, 0 0 6px rgba(255,255,85,0.2); }
  100% { box-shadow: 2px 2px 0 #00FFFF, 0 0 16px rgba(255,255,85,0.5); }
}

/* ── Follow / social ── */
.gal-follow {
  font-size: clamp(13px, 3vw, 16px);
  margin: 8px 0;
  color: #aaa;
  letter-spacing: 0.5px;
}
.gal-follow a {
  color: #FFFF55;
  margin: 0 10px;
  display: inline-block;
}

/* ── Navbar ── */
.navbar {
  background: #000;
  padding: 6px 8px;
  text-align: center;
  max-width: 71%;
  margin: 12px auto;
  border-bottom: 2px solid cadetblue;
  box-shadow: 0 1px 0 #00FF00;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 2px 0;
}

.navbar a {
  color: #FFFF55;
  font-weight: bold;
  margin: 0 10px;
  text-decoration: none;
  font-size: clamp(14px, 3.5vw, 17px);
}
.navbar a:hover { background: #FFFF55; color: #000; }

/* ── Glow link animations ── */
#glow {
  color: #FFFF55;
  font-weight: bold;
  text-decoration: none;
  animation: glowPulseA 1.2s infinite alternate;
}
@keyframes glowPulseA {
  0%   { text-shadow: 1px 1px 0 #000, 2px 2px 0 #00FFFF, 3px 3px 0 #005577; }
  100% { text-shadow: 1px 1px 0 #000, 2px 2px 0 #005577, 3px 3px 0 #00FFFF; }
}
#glow:hover { color: #00FFFF; text-shadow: 1px 1px 0 #000, 2px 2px 0 #fff, 3px 3px 0 #00FFFF; }

#glow2 {
  color: #FFFF55;
  font-weight: bold;
  text-decoration: none;
  animation: glowPulseB 1.2s infinite alternate;
}
@keyframes glowPulseB {
  0%   { text-shadow: 1px 1px 0 #000, 2px 2px 0 #005577, 3px 3px 0 #00FFFF; }
  100% { text-shadow: 1px 1px 0 #000, 2px 2px 0 #00FFFF, 3px 3px 0 #005577; }
}
#glow2:hover { color: #00FFFF; text-shadow: 1px 1px 0 #000, 2px 2px 0 #00FFFF, 3px 3px 0 #fff; }

#glow3 {
  color: hotpink;
  font-weight: bold;
  text-decoration: none;
  animation: glowPulseC 0.65s infinite alternate;
}
@keyframes glowPulseC {
  0%   { text-shadow: 1px 1px 0 #000, 2px 2px 0 #FFFF55, 3px 3px 0 #00FFFF, 4px 4px 0 #660066; }
  50%  { text-shadow: 1px 1px 0 #000, 2px 2px 0 #fff,    3px 3px 0 #FFFF55, 4px 4px 0 #00FFFF; }
  100% { text-shadow: 1px 1px 0 #000, 2px 2px 0 #660066, 3px 3px 0 #FFFF55, 4px 4px 0 #00FFFF; }
}
#glow3:hover { color: #FFFF55; text-shadow: 1px 1px 0 #000, 2px 2px 0 hotpink, 3px 3px 0 #00FFFF, 4px 4px 0 #fff; }

/* ── Footer bits ── */
.gal-copyright {
  background: #000;
  color: #777;
  border: 1px solid #444;
  font-family: 'Courier New', Courier, monospace;
  font-size: 15px;
  resize: none;
  padding: 4px 8px;
  margin: 12px 0 6px;
  width: min(310px, 90vw);
}

.gal-counter {
  font-size: 1em;
  color: rgb(110,160,196);
  margin: 6px 0;
}

.web-gif {
  width: min(32vw, 173px);
  height: auto;
  margin: 10px 0;
}

.gal-statcount {
  font-size: 0.8em;
  color: rgb(110,160,196);
  margin: 4px 0;
}

/* ── Canvas (animation layer) ── */
#win-canvas {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9999;
}

/* ============================================================
   CHECKOUT POPUP — cyan/yellow/black terminal palette
   ============================================================ */

#checkout-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.88);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 50000;
  padding: 12px;
}

#checkout-overlay.hidden { display: none; }

#checkout-popup {
  position: relative;
  width: 500px;
  max-width: 98vw;
  max-height: 92vh;
  overflow-y: auto;
  background: #1a1a00;
  border: 2px solid #00FFFF;
  box-shadow:
    0 0 0 1px #000,
    3px 3px 0 #005577,
    0 0 30px rgba(0,255,255,0.2),
    0 0 60px rgba(255,255,85,0.06);
  font-family: 'Courier New', Courier, monospace;
}

/* Corner gems */
.checkout-gem {
  position: absolute;
  width: 14px;
  height: 14px;
  background: linear-gradient(135deg, #005577, #00FFFF);
  border: 1px solid #000;
  box-shadow: inset 1px 1px #00FFFF, 1px 1px #000;
}
.gem-tl { top: 5px; left: 5px; }
.gem-tr { top: 5px; right: 5px; }
.gem-bl { bottom: 5px; left: 5px; }
.gem-br { bottom: 5px; right: 5px; }

/* Topbar */
#checkout-topbar {
  background: #003344;
  border-bottom: 1px solid #00FFFF;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4px 32px;
  position: relative;
  min-height: 30px;
}

/* Decorative bars — ::before left, ::after right, vertical lines only, no horizontal overflow */
#checkout-topbar::before,
#checkout-topbar::after {
  content: '';
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 110px;
  height: 1px;
  background: #00FFFF;
  box-shadow:
    0 1px 0 #005577,
    0 4px 0 #00FFFF,
    0 5px 0 #005577,
    0 8px 0 #00FFFF,
    0 9px 0 #005577;
  opacity: 0.6;
}
#checkout-topbar::before { left: 28px; }
#checkout-topbar::after  { right: 85px; width: 80px; }

#checkout-topbar-title {
  font-size: 18px;
  color: #FFFF55;
  letter-spacing: 2px;
  text-shadow: 1px 1px 0 #000, 0 0 8px rgba(255,255,85,0.4);
  font-weight: bold;
}

#checkout-close-btn {
  position: absolute;
  right: 26px;
  font-family: 'Courier New', Courier, monospace;
  font-size: 14px;
  color: #00FFFF;
  background: #003344;
  border: 1px solid #00FFFF;
  padding: 0 5px;
  cursor: pointer;
  line-height: 1.5;
}
#checkout-close-btn:hover { background: #ff4444; color: #fff; border-color: #ff4444; }

/* Inner window */
#checkout-window {
  padding: 14px 16px 18px;
  color: #FFFF55;
  font-size: clamp(15px, 3.5vw, 18px);
  background: #0a0a00;
  line-height: 1.5;
}

/* Shared utility classes */
.gal-bright  { color: #00FFFF; }
.gal-dim     { color: #667744; }
.gal-blink   { animation: galBlink 1s step-end infinite; }
.hidden      { display: none !important; }

@keyframes galBlink {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0; }
}

.gal-rule {
  border: none;
  border-top: 1px solid #005577;
  margin: 10px 0;
  box-shadow: 0 1px 0 #003322;
}

/* Wallet row */
#wallet-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-bottom: 4px;
}

/* Generic terminal button */
.gal-btn {
  font-family: 'Courier New', Courier, monospace;
  font-size: clamp(14px, 3.5vw, 17px);
  color: #FFFF55;
  background: transparent;
  border: 1px solid #FFFF55;
  padding: 2px 10px;
  cursor: pointer;
  letter-spacing: 0.5px;
  text-decoration: none;
  display: inline-block;
  line-height: 1.5;
}
.gal-btn:hover   { background: #FFFF55; color: #000; }
.gal-btn:disabled { color: #445500; border-color: #445500; cursor: default; background: transparent; }

#buy-btn {
  color: #000;
  background: #FFFF55;
  border-color: #FFFF55;
}
#buy-btn:hover { background: #00FFFF; border-color: #00FFFF; }

/* Painting info rows */
#painting-info { margin: 6px 0; }

#painting-title {
  font-size: clamp(16px, 4vw, 20px);
  margin-bottom: 6px;
  text-shadow: 0 0 6px rgba(0,255,255,0.4);
}

#painting-price-row,
#painting-fee-row,
#painting-total-row {
  display: flex;
  justify-content: space-between;
  font-size: clamp(14px, 3.5vw, 17px);
  padding: 1px 0;
}

#painting-total-row {
  color: #00FFFF;
  font-size: clamp(15px, 4vw, 18px);
  border-top: 1px solid #005577;
  margin-top: 4px;
  padding-top: 4px;
}

#pay-status {
  font-size: 14px;
  min-height: 18px;
  margin: 4px 0;
}

/* Shipping form */
.gal-field-row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 5px 0;
}

.gal-field-row label {
  color: #667744;
  font-size: clamp(13px, 3vw, 15px);
  white-space: nowrap;
  min-width: 70px;
  text-align: right;
}

.gal-field-row input {
  flex: 1;
  font-family: 'Courier New', Courier, monospace;
  font-size: clamp(13px, 3vw, 15px);
  background: #000;
  color: #FFFF55;
  border: 1px solid #005577;
  padding: 3px 6px;
  outline: none;
  min-width: 0;
}

.gal-field-row input:focus {
  border-color: #00FFFF;
  box-shadow: 0 0 4px rgba(0,255,255,0.3);
}

/* Post-payment confirmation */
#gal-congrats-title {
  font-size: clamp(16px, 4.5vw, 21px);
  color: #fff;
  font-weight: bold;
  animation: galCongrats 0.8s infinite alternate;
  margin-bottom: 6px;
}

@keyframes galCongrats {
  0%   { text-shadow: 0 0 2px #fff, 0 0 4px #FFFF55, 0 0 10px rgba(0,255,255,0.6), 0 0 20px rgba(0,255,255,0.2); }
  50%  { text-shadow: 0 0 2px #fff, 0 0 6px #00FFFF,  0 0 14px rgba(255,255,85,0.7), 0 0 28px rgba(255,255,85,0.25); }
  100% { text-shadow: 0 0 2px #fff, 0 0 4px #FFFF55, 0 0 12px rgba(0,255,255,0.5), 0 0 22px rgba(0,255,255,0.15); }
}

#gal-post-msg {
  font-size: clamp(14px, 3.5vw, 16px);
  color: #667744;
  line-height: 1.6;
  margin: 6px 0;
}

#gal-post-msg a { color: #FFFF55; text-decoration: underline; }

#gal-post-paid, #gal-post-order {
  font-size: clamp(13px, 3vw, 15px);
  margin: 2px 0;
}

.gal-order-number { color: #00FFFF; letter-spacing: 1px; }

#gal-post-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 8px;
}

.gal-contact-btn {
  color: #FFFF55;
  border-color: #FFFF55;
}

/* ── Mobile ── */
@media (max-width: 480px) {
  .navbar { max-width: 95%; }

  .gal-table { font-size: 14px; }

  .gal-field-row { flex-direction: column; align-items: flex-start; }
  .gal-field-row label { text-align: left; min-width: unset; }
  .gal-field-row input { width: 100%; }

  #wallet-row { flex-direction: column; align-items: flex-start; }

  #checkout-topbar::before, #checkout-topbar::after { display: none; }

  #painting-price-row,
  #painting-fee-row,
  #painting-total-row { font-size: 14px; }

  #gal-post-actions { flex-direction: column; }
  .gal-btn { text-align: center; }
}
