:root {
  --ok: #0a7d26;
  --bad: #b30000;
  --bg: #f6f7fb;
  --card: #ffffff;
  --border: #e2e8f0;
}
* { box-sizing: border-box; }
body {
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  margin: 0; padding: 0; background: var(--bg); color: #1a202c;
}
.container { max-width: 900px; margin: 24px auto; padding: 0 16px; }
.card { background: var(--card); border: 1px solid var(--border); border-radius: 12px; padding: 16px 18px; box-shadow: 0 1px 2px rgba(0,0,0,.04); }
h1,h2,h3 { margin: 0 0 12px; }
.nav { display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap;}
.nav a, .btn {
  display: inline-block; padding: 10px 14px; border-radius: 10px; border: 1px solid var(--border);
  background: #fff; text-decoration: none; color: #111; font-weight: 600; cursor: pointer;
}
div.active a {
  background-color: #000;
  color: #fff;
}
.btn.primary { background: #111; color: #fff; }
.btn.small { padding: 10px 10px; font-size: 14px; text-align: center;}
.grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; }
.stat { padding: 12px; border-radius: 10px; border: 1px dashed var(--border); background: #fafafa; }
.balance { font-size: 28px; font-weight: 800; }
.balance.positive { color: var(--ok); }
.balance.negative { color: var(--bad); }
table { width: 100%; border-collapse: collapse; background: #fff; border-radius: 10px; overflow: hidden; }
th, td { padding: 10px 12px; border-bottom: 1px solid var(--border); text-align: left; padding-right: 0px; }
tr:last-child td { border-bottom: none; }
form.inline { display: inline-block; margin: 0; }
input[type="text"], input[type="password"], input[type="number"], input[type="email"], select {
  padding: 10px 12px; border: 1px solid var(--border); border-radius: 10px; width: 100%;
}
label { display: block; font-size: 14px; margin-bottom: 6px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
hr { border: none; height: 1px; background: var(--border); margin: 18px 0; }
.alert { padding: 10px 12px; border-radius: 8px; background: #fff3cd; border: 1px solid #ffe69c; }
.badge { padding: 3px 8px; border-radius: 999px; font-size: 12px; border: 1px solid var(--border); }
.badge.red { background: #ffe5e5; color: var(--bad); border-color: #ffc0c0; }
.badge.gray { background: #f1f5f9; color: #334155; }
footer { margin-top: 24px; font-size: 12px; color: #475569; }

.login-pic {
  text-align: center;
}

/* =============== PODIUM (schoon) =============== */

.podium .podium-wrap{
  display:flex;
  align-items:flex-end;
  justify-content:center;
  gap:32px;
  padding:16px 12px;
}

.podium .podium-col{
  display:flex;
  flex-direction:column;
  align-items:center;
  width:140px;
  text-align:center;
}

/* Naam boven de balk + hoeveelheid erachter */
.podium .podium-name{
  order:0;
  margin:0 0 10px;
  font-weight:700;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.podium .podium-name .podium-qty{
  margin-left:8px;
  color:#64748b;
  font-weight:600;
  white-space:nowrap;
}

/* Het blok zelf (hoogte inline via style="height: Npx") + visueel iets korter */
.podium .podium-block{
  position:relative;
  width:100%;
  min-height:50px;
  border-radius:14px 14px 0 0;
  box-shadow:
    0 8px 16px rgba(0,0,0,.08) inset,
    0 6px 14px rgba(0,0,0,.06);
  transform:scaleY(.85);
  transform-origin:bottom;
}

/* Kleurovergangen */
.podium .podium-block.gold   { background:linear-gradient(180deg,#fef08a,#facc15); }
.podium .podium-block.silver { background:linear-gradient(180deg,#e5e7eb,#c0c0c0); }
.podium .podium-block.bronze { background:linear-gradient(180deg,#f4b183,#cd7f32); }

/* Grote 1/2/3 ON the block (onderaan gecentreerd) */
.podium .podium-block::after{
  position:absolute;
  left:50%; bottom:12px;
  transform:translateX(-50%);
  font-weight:800;
  font-size:36px;
  line-height:1;
  opacity:.9;
  content:"";
}
.podium .place-1 .podium-block::after{ content:"1"; color:#a16207; } /* goud */
.podium .place-2 .podium-block::after{ content:"2"; color:#475569; } /* zilver */
.podium .place-3 .podium-block::after{ content:"3"; color:#7c3e0a; } /* brons */

/* Visuele trap (2e iets lager, 3e nog iets lager) */
.podium .place-1 { transform:translateY(0); }
.podium .place-2 { transform:translateY(10px); }
.podium .place-3 { transform:translateY(16px); }

/* Hidden for screenreaders helper */
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* Ranking lijst onder het podium */
.mt{ margin-top:22px; }
.podium .podium-ranking{ list-style:none; padding:0; margin:0; }
.podium .podium-ranking li{
  display:grid;
  grid-template-columns:60px 1fr auto;
  align-items:center;
  padding:10px 12px;
  border-top:1px solid #eef2f7;
}
.podium .podium-ranking li:first-child{ border-top:none; }
.podium .podium-ranking .rk{ color:#64748b; font-weight:700; }
.podium .podium-ranking .nm{ font-weight:600; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.podium .podium-ranking .qt{ font-variant-numeric:tabular-nums; white-space:nowrap; }






/* GSM */
/* Basistekst */
html { font-size: 16px; }
body { line-height: 1.4; }

/* Knoppen makkelijk te raken */
button, .btn { min-height: 44px; }

/* ---------- Layout helpers ---------- */
.table-wrap { overflow-x: auto; }

/* Forms/kaarten op mobiel in 1 kolom; knoppen makkelijk tikbaar */
@media (max-width: 640px) {
  .form-row { display: grid; grid-template-columns: 1fr; gap: 10px; }
  .grid { display: grid; grid-template-columns: 1fr; gap: 12px; }
  .btn, button { width: 100%; }
}

/* Breedtes voor tabellen alleen op grotere schermen */
@media (min-width: 641px) {
  .table-wrap table { min-width: 600px; }
}

/* ---------- Transacties tabel (desktop) ---------- */
table.transactions { width: 100%; border-collapse: collapse; table-layout: auto; }
table.transactions th, 
table.transactions td { padding: 10px 12px; }
table.transactions th { text-align: left; white-space: nowrap; }
table.transactions td.col-amount { text-align: right; font-variant-numeric: tabular-nums; white-space: nowrap; }
table.transactions td.when { white-space: nowrap; }
table.transactions tbody tr + tr td { border-top: 1px solid #eef2f7; }

/* Basis (desktop/laptop) */
table.transactions { width:100%; border-collapse:collapse; table-layout:auto; }
table.transactions th, table.transactions td { padding:10px 12px; }
table.transactions th { text-align:left; white-space:nowrap; }
table.transactions td.col-amount { text-align:right; font-variant-numeric:tabular-nums; white-space:nowrap; }
.table-wrap { overflow-x:auto; }   /* laat horizontaal scrollen indien nodig */

/* Alleen op gsm: verberg de kolom “Type” */
@media (max-width: 640px) {
  .transactions th.col-type,
  .transactions td.col-type { display:none; }
}

/* bedrag schaalt met schermgrootte */
td.balance {
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  font-size: clamp(14px, 2.6vw, 28px); /* min 14px, groeit met 2.6vw, max 28px */
  white-space: nowrap;                 /* euro + bedrag op één lijn */
}

@media (max-width:640px){
  .podium .podium-wrap{ gap:22px; }
  .podium .podium-col{ width:110px; }
  .podium .podium-block{ transform:scaleY(.80); }
  .podium .podium-block::after{ font-size:30px; bottom:10px; }
  .podium .podium-name{ font-size:14px; }
}