/* STAR TRADERS 64 — play.startraders64.com — C64 retro look
   Paletta megegyezik a www/index.html-lel. */

:root {
  --c64-bg: #352879;
  --c64-bg-dark: #241b54;
  --c64-border: #6c5eb5;
  --c64-light: #a59ae0;
  --c64-white: #ffffff;
  --c64-yellow: #d5df7c;
  --c64-green: #9ad284;
  --c64-red: #e08884;
  --c64-cyan: #86d6dd;
}

* { box-sizing: border-box; }

body {
  background: var(--c64-border);
  color: var(--c64-light);
  font-family: "Courier New", Courier, monospace;
  margin: 0;
  padding: 24px 12px;
}

.screen {
  max-width: 1100px;
  margin: 0 auto;
  background: var(--c64-bg);
  border: 24px solid var(--c64-border);
  border-radius: 8px;
  padding: 24px 28px 36px;
}

h1 {
  color: var(--c64-white);
  text-align: center;
  letter-spacing: .35em;
  font-size: 1.5em;
  margin: 0 0 4px;
}

.subtitle { text-align: center; color: var(--c64-cyan); margin-bottom: 20px; }

h2 {
  color: var(--c64-yellow);
  border-bottom: 2px solid var(--c64-border);
  padding-bottom: 4px;
  margin: 0 0 12px;
  font-size: 1.0em;
  letter-spacing: .1em;
}

code {
  background: var(--c64-bg-dark);
  color: var(--c64-green);
  border-radius: 4px;
  padding: 1px 5px;
}

.hidden { display: none !important; }
.dim { color: var(--c64-border); font-size: .85em; }

/* ----- státuszsor (hibák/visszajelzés) ----- */
.status-line {
  border: 2px solid var(--c64-border);
  border-radius: 6px;
  padding: 8px 12px;
  margin-bottom: 16px;
  min-height: 2.4em;
  color: var(--c64-light);
  word-break: break-word;
}
.status-line.ok { border-color: var(--c64-green); color: var(--c64-green); }
.status-line.err { border-color: var(--c64-red); color: var(--c64-red); }

/* ----- panelek, rács ----- */
.panel {
  border: 2px solid var(--c64-border);
  border-radius: 6px;
  padding: 14px 16px;
  margin-bottom: 16px;
}

.auth-grid, .game-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 800px) {
  .auth-grid, .game-grid { grid-template-columns: 1fr; }
  .statusbar { flex-wrap: wrap; }
}

.server-note { text-align: center; }

/* ----- űrlapok, gombok ----- */
label { display: block; margin: 8px 0 4px; }

input[type="text"], input[type="password"], input[type="number"], textarea {
  background: var(--c64-bg-dark);
  color: var(--c64-white);
  border: 2px solid var(--c64-border);
  border-radius: 4px;
  font-family: inherit;
  font-size: 1em;
  padding: 6px 8px;
  width: 100%;
}
input[type="number"] { width: 5.5em; }
textarea { width: 100%; color: var(--c64-green); }

button {
  background: var(--c64-bg-dark);
  color: var(--c64-cyan);
  border: 2px solid var(--c64-cyan);
  border-radius: 4px;
  font-family: inherit;
  font-size: .95em;
  padding: 6px 12px;
  margin-top: 8px;
  cursor: pointer;
  letter-spacing: .05em;
}
button:hover:not(:disabled) { background: var(--c64-cyan); color: var(--c64-bg-dark); }
button:disabled { opacity: .4; cursor: not-allowed; }
button.primary { color: var(--c64-yellow); border-color: var(--c64-yellow); }
button.primary:hover:not(:disabled) { background: var(--c64-yellow); color: var(--c64-bg-dark); }
button.danger { color: var(--c64-red); border-color: var(--c64-red); }
button.danger:hover:not(:disabled) { background: var(--c64-red); color: var(--c64-bg-dark); }

/* ----- token-képernyő ----- */
.token-panel { border-color: var(--c64-yellow); text-align: center; }
.warn-text {
  color: var(--c64-red);
  font-weight: bold;
  font-size: 1.1em;
}
.token-box {
  background: var(--c64-bg-dark);
  color: var(--c64-yellow);
  border: 3px dashed var(--c64-yellow);
  border-radius: 6px;
  font-size: 1.3em;
  font-weight: bold;
  letter-spacing: .08em;
  padding: 18px 12px;
  margin: 16px 0;
  word-break: break-all;
  user-select: all;
  cursor: pointer;
}
.token-actions button { margin: 0 8px; }

/* ----- státuszbár ----- */
.statusbar {
  display: flex;
  gap: 18px;
  border: 2px solid var(--c64-green);
  border-radius: 6px;
  padding: 8px 14px;
  margin-bottom: 16px;
  color: var(--c64-light);
}
.statusbar b { color: var(--c64-white); }

/* ----- bannerek ----- */
.banner {
  border-radius: 6px;
  padding: 12px 16px;
  margin-bottom: 16px;
  text-align: center;
  font-weight: bold;
  font-size: 1.1em;
}
.banner-winner { border: 3px solid var(--c64-yellow); color: var(--c64-yellow); }
.banner-goal { border: 3px solid var(--c64-green); color: var(--c64-green); }
.banner-ended { border: 2px solid var(--c64-border); color: var(--c64-light); font-weight: normal; }

/* END TURN highlight when it is the only sensible next step */
button.attention {
  border-color: var(--c64-yellow);
  color: var(--c64-yellow);
  animation: attention-pulse 1.2s ease-in-out infinite;
}
@keyframes attention-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(213, 223, 124, .0); }
  50% { box-shadow: 0 0 10px 2px rgba(213, 223, 124, .45); }
}
@media (prefers-reduced-motion: reduce) {
  button.attention { animation: none; }
}

/* ----- térkép ----- */
.map-panel svg { width: 100%; height: auto; display: block; }
#map .edge { stroke: var(--c64-border); stroke-width: 2; }
#map .edge-label { fill: var(--c64-light); font-size: 14px; font-family: inherit;
  paint-order: stroke; stroke: var(--c64-bg); stroke-width: 6; }
#map .planet rect {
  fill: var(--c64-bg-dark);
  stroke: var(--c64-border);
  stroke-width: 2;
}
#map .planet text { fill: var(--c64-light); font-size: 15px; font-family: inherit; }
#map .planet .yard { fill: var(--c64-green); font-size: 12px; }
#map .planet.here rect { stroke: var(--c64-yellow); stroke-width: 3; }
#map .planet.here text { fill: var(--c64-yellow); }
#map .planet.reachable { cursor: pointer; }
#map .planet.reachable rect { stroke: var(--c64-cyan); stroke-width: 3; }
#map .planet.reachable:hover rect { fill: var(--c64-cyan); }
#map .planet.reachable:hover text { fill: var(--c64-bg-dark); }
.map-legend { margin: 8px 0 0; }

/* ----- piac ----- */
table { border-collapse: collapse; width: 100%; }
td, th { border: 1px solid var(--c64-border); padding: 5px 8px; text-align: left; }
th { color: var(--c64-white); font-size: .85em; }
.market-table td button { margin: 1px 1px; padding: 3px 7px; font-size: .8em; }
.market-table input { padding: 3px 5px; width: 4.5em; }
.tag { font-size: .75em; font-weight: bold; }
.tag.produces { color: var(--c64-green); }
.tag.needs { color: var(--c64-red); }

.action-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 10px;
  flex-wrap: wrap;
}
.action-row label { margin: 0; }
.action-row input { width: 5.5em; }
.action-row button { margin-top: 0; }
.footer-row { margin-top: 8px; }

/* ----- játékosok, események ----- */
.players-table .auto-mark { color: var(--c64-cyan); font-weight: bold; }
.players-table .you-mark { color: var(--c64-yellow); }

.events-list {
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: .9em;
  max-height: 16em;
  overflow-y: auto;
}
.events-list li { padding: 2px 0; border-bottom: 1px dotted var(--c64-bg-dark); }
.events-list .ev-turn { color: var(--c64-cyan); }

footer { margin-top: 28px; text-align: center; color: var(--c64-border); font-size: .85em; }
