/* ===== Keno GX Base ===== */
:root{
  --bg:#0b1224;
  --bg-2:#0f1732;
  --ink:#e9eefc;
  --muted:#9fb3ff;
  --card:#121a36;
  --line:#1d2b57;
  --accent:#5f75ff;
  --accent-2:#a9b7ff;
  --ok:#3ddc97;
  --err:#ff6b6b;
  --shadow:0 10px 40px rgba(0,0,0,.35);
  --radius:5px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font:15px/1.5 system-ui,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--bg);
  color:var(--ink);
}
a{color:var(--accent-2);text-decoration:none}
a:hover{opacity:.9}
img{max-width:100%;display:block}

/* ===== Container ===== */
.container{max-width:1100px;margin:0 auto;padding:0 16px}

/* ===== Top bar (GX) ===== */
.gx-top{position:sticky;top:0;z-index:60;background:rgba(11,18,36,.9);backdrop-filter:saturate(140%) blur(6px);border-bottom:1px solid var(--line)}
.gx-top__inner{display:flex;align-items:center;justify-content:space-between;height:56px}
.gx-top__title{font-weight:700;letter-spacing:.3px}
.gx-top__actions{display:flex;gap:8px;align-items:center}

/* Mobile nav */
.gx-nav__burger{display:none;align-items:center;gap:8px}
.gx-burger{
  width:36px;height:36px;border:1px solid var(--line);border-radius:var(--radius);
  background:transparent;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;cursor:pointer
}
.gx-burger:active{transform:translateY(1px)}
.gx-nav__dropdown{
  display:none;position:absolute;left:0;right:0;top:56px;
  background:var(--bg-2);border-bottom:1px solid var(--line);box-shadow:var(--shadow)
}
.gx-nav__list{display:flex;flex-direction:column;padding:8px}
.gx-nav__list a{padding:10px 14px;border-radius:var(--radius);border:1px solid transparent}
.gx-nav__list a:hover{background:var(--card);border-color:var(--line)}
/* Open state */
.gx-top.open .gx-nav__dropdown{display:block}

/* ===== Chips / buttons ===== */
.gx-chip{
  display:inline-block;padding:4px 8px;border:1px solid var(--line);
  border-radius:var(--radius);background:var(--bg-2);font-size:13px;color:var(--muted)
}
.gx-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:8px 12px;border:1px solid var(--line);border-radius:var(--radius);
  background:var(--bg-2);color:var(--ink);cursor:pointer;font-weight:600
}
.gx-btn--ghost{background:transparent}
.gx-btn--sm{padding:6px 10px;font-size:13px}

/* ===== Cards / grids ===== */
.card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px;box-shadow:var(--shadow)
}
.card h3{margin:0 0 10px 0}
.mt-20{margin-top:20px}
.mt-10{margin-top:10px}
.grid{display:grid;gap:16px}
.grid--2{grid-template-columns:1fr 1fr}
.grid--3{grid-template-columns:1fr 1fr 1fr}
.grid--4{grid-template-columns:repeat(4,1fr)}

@media (max-width:980px){
  .grid--4{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .gx-top__actions{display:none}
  .gx-nav__burger{display:flex}
  .grid--3,.grid--2,.grid--4{grid-template-columns:1fr}
}

/* ===== Forms ===== */
label{display:block;margin:.6rem 0 .2rem}
input[type=text],input[type=password],input[type=number],input[type=date],input[type=file],select,textarea{
  width:100%;padding:10px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);color:var(--ink)
}

/* ===== Alerts/foot ===== */
.gx-alert{padding:10px 12px;border-radius:var(--radius);border:1px solid var(--line);background:var(--bg-2)}
.gx-alert.ok{border-color:rgba(61,220,151,.4)}
.gx-alert.error{border-color:rgba(255,107,107,.4)}
.gx-info{color:var(--muted)}
.gx-foot{color:var(--muted);font-size:13px}

/* ===== Tables ===== */
.table-wrap{
  width:100%;
  overflow-x:auto; /* klucz: przewijanie na mobile */
  -webkit-overflow-scrolling:touch;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:linear-gradient(to right, rgba(255,255,255,0) 0, rgba(255,255,255,0) 10px), linear-gradient(to left, rgba(255,255,255,0) 0, rgba(255,255,255,0) 10px), var(--card);
}
table{width:100%;border-collapse:separate;border-spacing:0;min-width:960px}
table thead th{
  position:sticky;top:0;z-index:1;
  background:var(--bg-2);border-bottom:1px solid var(--line);text-align:left;padding:10px;white-space:nowrap
}
table td{padding:10px;border-bottom:1px solid var(--line);vertical-align:top;word-break:break-word}
table tr:hover td{background:rgba(255,255,255,.02)}
/* „Szerokie” tabele (Typy, Nauka, Wyniki/Moduły) */
.table--wide{min-width:1200px}
/* Wymuszone zawijanie i cięcie długich stringów */
.nowrap{white-space:nowrap}
.wrap{white-space:normal;word-break:break-word;overflow-wrap:break-word}

/* ===== Number chips (typy) ===== */
.num-chip{display:inline-block;min-width:32px;padding:4px 6px;margin:2px;border:1px solid var(--line);border-radius:var(--radius);text-align:center;font-weight:700;background:var(--bg-2)}
.num-chip.hit{border-color:var(--ok);box-shadow:0 0 0 1px var(--ok) inset}

/* ===== Pagination ===== */
.pagination{text-align:center;margin:16px 0}
.pagination .gx-chip{margin:2px 3px}
.pagination .active{background:#1b2550;color:#fff}

/* ===== Utility spacing ===== */
.mt8{margin-top:8px}.mt12{margin-top:12px}

/* ===== Buttons spacing (góra/dół min 20px jak prosiłeś) ===== */
.gx-btn{margin-top:20px;margin-bottom:20px}
.gx-btn--sm{margin-top:20px;margin-bottom:20px}

/* ===== Sticky footer spacing for dropdown under header ===== */
main{padding-top:14px}

/* ===== Scrollbar (lekko) ===== */
.table-wrap::-webkit-scrollbar{height:10px}
.table-wrap::-webkit-scrollbar-track{background:var(--bg-2)}
.table-wrap::-webkit-scrollbar-thumb{background:#263364;border-radius:6px}
