/* DRUŻYNIADA — design system: studio TV lat 90. + wielka tablica dot-matrix */
:root {
  --bg: #03060f;
  --bg2: #081024;
  --panel: rgba(13, 22, 48, .74);
  --panel-edge: rgba(86, 118, 196, .28);
  --amber: #ffb52e;          /* znaki tablicy */
  --amber-dim: #4a350e;      /* zgaszone lampki */
  --board: #0a0c14;          /* tło matrycy */
  --bezel: #1b2c5e;          /* rama tablicy */
  --teamA: #2de2ff;
  --teamB: #ff7849;
  --gold: #ffd34d;
  --red: #ff4d6d;
  --green: #3dffa0;
  --text: #eef1ff;
  --muted: #8b93b8;
  --font-head: 'Archivo Black', 'Segoe UI', system-ui, sans-serif;
  --font-body: 'Inter', 'Segoe UI', system-ui, sans-serif;
  --font-board: 'Doto', 'Courier New', monospace;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html, body { height: 100%; }
body {
  background:
    radial-gradient(ellipse 90% 60% at 50% -10%, #14245c 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 10% 110%, rgba(45, 226, 255, .12) 0%, transparent 70%),
    radial-gradient(ellipse 50% 40% at 90% 110%, rgba(255, 120, 73, .12) 0%, transparent 70%),
    var(--bg);
  color: var(--text);
  font-family: var(--font-body);
  overflow-x: hidden;
}
/* kurtyna studia w tle: pionowe pasy */
body::before {
  content: ''; position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background-image: repeating-linear-gradient(90deg, rgba(86, 118, 196, .055) 0 2px, transparent 2px 64px);
  mask-image: radial-gradient(ellipse 85% 75% at 50% 35%, #000 30%, transparent 78%);
}
body > * { position: relative; z-index: 1; }

.logo {
  font-family: var(--font-head);
  font-weight: 400;
  letter-spacing: .12em;
  background: linear-gradient(92deg, var(--teamA) 5%, #7cc6ff 30%, var(--gold) 60%, var(--teamB) 95%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-transform: uppercase;
  filter: drop-shadow(0 0 16px rgba(255, 181, 46, .35));
}

.btn {
  display: inline-block;
  border: 0; cursor: pointer;
  padding: .8em 1.6em;
  border-radius: 13px;
  font-size: 1rem; font-weight: 800;
  font-family: var(--font-body);
  letter-spacing: .02em;
  color: #1c1303;
  background: linear-gradient(160deg, #ffe9b0 0%, var(--amber) 45%, #f08c00 100%);
  box-shadow: 0 4px 20px rgba(255, 181, 46, .35), inset 0 1px 0 rgba(255, 255, 255, .55);
  transition: transform .13s, box-shadow .13s, filter .13s;
  text-decoration: none;
}
.btn:hover { transform: translateY(-2px); filter: brightness(1.08); }
.btn:active { transform: translateY(1px); }
.btn:disabled { filter: grayscale(.85); opacity: .45; cursor: not-allowed; transform: none; }
.btn.cyan   { background: linear-gradient(160deg, #b8f4ff 0%, var(--teamA) 45%, #0e9cc9 100%); color: #04202b; }
.btn.orange { background: linear-gradient(160deg, #ffd2bd 0%, var(--teamB) 45%, #e04e16 100%); color: #2b1204; }
.btn.green  { background: linear-gradient(160deg, #b8ffd9 0%, #19e58c 45%, #0bbf6f 100%); color: #042b18; }
.btn.red    { background: linear-gradient(160deg, #ffb6c4 0%, var(--red) 45%, #e2274d 100%); color: #fff; box-shadow: 0 4px 20px rgba(255, 77, 109, .4), inset 0 1px 0 rgba(255, 255, 255, .35); }
.btn.ghost  { background: rgba(10, 15, 40, .6); border: 1px solid var(--panel-edge); color: var(--text); box-shadow: none; }
.btn.ghost:hover { border-color: var(--amber); box-shadow: 0 0 14px rgba(255, 181, 46, .2); }
.btn.big { font-size: 1.25rem; padding: 1em 2em; }

.panel {
  background: linear-gradient(168deg, rgba(22, 34, 76, .78), rgba(9, 14, 36, .88));
  border: 1px solid var(--panel-edge);
  border-radius: 20px;
  padding: 22px;
  box-shadow: 0 16px 48px rgba(0, 0, 0, .5), inset 0 1px 0 rgba(255, 255, 255, .06);
  backdrop-filter: blur(10px);
}

input[type=text], input[type=password], input[type=number], select, textarea {
  width: 100%;
  background: rgba(5, 9, 26, .85);
  color: var(--text);
  border: 1px solid var(--panel-edge);
  border-radius: 11px;
  padding: .75em 1em;
  font-size: 1rem;
  font-family: var(--font-body);
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
input:focus, select:focus, textarea:focus { border-color: var(--amber); box-shadow: 0 0 0 3px rgba(255, 181, 46, .14); }
.muted { color: var(--muted); }

/* matryca dot — wspólny wygląd "lampek" */
.dotty {
  font-family: var(--font-board);
  font-weight: 900;
  color: var(--amber);
  text-shadow: 0 0 6px rgba(255, 181, 46, .85), 0 0 22px rgba(255, 181, 46, .35);
}

.toast {
  position: fixed; left: 50%; bottom: 26px; transform: translateX(-50%);
  background: rgba(26, 33, 72, .95); border: 1px solid var(--red); color: #ffd2db;
  padding: .7em 1.4em; border-radius: 13px; z-index: 99; font-weight: 600;
  box-shadow: 0 10px 30px rgba(0, 0, 0, .5);
  opacity: 0; pointer-events: none; transition: opacity .3s;
  backdrop-filter: blur(8px);
}
.toast.show { opacity: 1; }

::-webkit-scrollbar { width: 9px; }
::-webkit-scrollbar-thumb { background: #2b3563; border-radius: 6px; }
::selection { background: rgba(255, 181, 46, .3); }

@keyframes pulse { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.06); } }
@keyframes flashIn { from { opacity: 0; transform: scale(.7); } to { opacity: 1; transform: scale(1); } }
@keyframes shake { 0%, 100% { transform: translateX(0) } 20% { transform: translateX(-9px) } 40% { transform: translateX(8px) } 60% { transform: translateX(-6px) } 80% { transform: translateX(4px) } }
@keyframes floatY { 0%, 100% { transform: translateY(0) } 50% { transform: translateY(-7px) } }
