:root {
  --green: #0a7d3c;
  --green-d: #075f2d;
  --bg: #f4f6f5;
  --card: #ffffff;
  --line: #e2e6e4;
  --ink: #1b211e;
  --mut: #6b756f;
  --gold: #f4b400;
  --gray: #9aa3a0;
  --r: 12px;
}
* { box-sizing: border-box; }
html, body { margin: 0; }
body {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  background: var(--bg); color: var(--ink); line-height: 1.45;
  -webkit-text-size-adjust: 100%;
}

/* Topbar */
.topbar {
  position: sticky; top: 0; z-index: 10;
  display: flex; align-items: center; gap: .5rem; flex-wrap: wrap;
  background: var(--green); color: #fff;
  padding: .55rem .8rem; padding-top: max(.55rem, env(safe-area-inset-top));
}
.brand { color: #fff; text-decoration: none; font-weight: 800; font-size: 1.05rem; white-space: nowrap; }
.brand span { vertical-align: middle; }
.nav { display: flex; gap: .25rem; margin-left: auto; flex-wrap: wrap; }
.nav a, .nav button {
  color: #fff; background: rgba(255,255,255,.12); border: 0; cursor: pointer;
  padding: .35rem .6rem; border-radius: 999px; font-size: .85rem; text-decoration: none;
}
.nav a.active { background: #fff; color: var(--green-d); font-weight: 700; }
.navname { color: #fff; font-weight: 700; font-size: .85rem; padding: .35rem .4rem; opacity: .95; }

@media (max-width: 600px) {
  .topbar { gap: .35rem; padding: .5rem .6rem; padding-top: max(.5rem, env(safe-area-inset-top)); }
  .brand { flex: 1 1 100%; font-size: 1.02rem; }
  .nav { margin-left: 0; width: 100%; justify-content: flex-start; gap: .3rem; }
  .nav a, .nav button { padding: .3rem .6rem; font-size: .82rem; }
  .navname { padding: .3rem .25rem; }
}

.app { max-width: 760px; margin: 0 auto; padding: .8rem .7rem 2rem; }
.foot { text-align: center; color: var(--mut); font-size: .75rem; padding: 1rem; }
.loading { text-align: center; color: var(--mut); padding: 3rem 0; }

h2 { font-size: 1.25rem; margin: .2rem 0 .8rem; }
h3 { font-size: .95rem; }
.muted { color: var(--mut); }
.center { text-align: center; }

/* Cards */
.card {
  background: var(--card); border: 1px solid var(--line); border-radius: var(--r);
  padding: 1rem; margin-bottom: .8rem;
}

/* Forms */
label { display: block; font-size: .85rem; color: var(--mut); margin: .6rem 0 .2rem; }
input, select, button { font: inherit; }
input[type=text], input[type=password], input[type=number], select {
  width: 100%; padding: .6rem .7rem; border: 1px solid var(--line);
  border-radius: 10px; background: #fff;
}
.btn {
  display: inline-block; background: var(--green); color: #fff; border: 0;
  padding: .65rem 1rem; border-radius: 10px; cursor: pointer; font-weight: 700;
}
.btn:hover { background: var(--green-d); }
.btn.sec { background: #eef1ef; color: var(--ink); }
.btn.block { width: 100%; }
.btn:disabled { opacity: .5; cursor: not-allowed; }
.row { display: flex; gap: .5rem; flex-wrap: wrap; }

/* Tabs */
.tabs { display: flex; gap: .3rem; margin-bottom: 1rem; }
.tabs button { flex: 1; padding: .55rem; border: 1px solid var(--line); background: #fff; border-radius: 10px; cursor: pointer; }
.tabs button.active { background: var(--green); color: #fff; border-color: var(--green); font-weight: 700; }

/* Day section */
.day-h { margin: .8rem .1rem .3rem; font-size: .74rem; font-weight: 700; color: var(--green-d); text-transform: uppercase; letter-spacing: .03em; }

/* Match row */
.match {
  background: var(--card); border: 1px solid var(--line); border-radius: 10px;
  padding: .4rem .55rem; margin-bottom: .35rem;
}
.match .meta { display: flex; justify-content: space-between; font-size: .68rem; color: var(--mut); margin-bottom: .2rem; gap: .5rem; }
.match .badge { font-weight: 700; }
.match .teams {
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center;
  gap: .55rem; max-width: 440px; margin: 0 auto;
}
.match .t1, .match .t2 { display: flex; align-items: center; gap: .4rem; min-width: 0; }
.match .t1 { justify-content: flex-end; }
.match .t2 { justify-content: flex-start; }
.match .tname { font-weight: 600; font-size: .9rem; line-height: 1.15; }
.match .tname.slot { font-weight: 500; color: var(--mut); font-size: .82rem; }
.flag {
  width: 24px; height: 18px; border-radius: 3px; object-fit: cover; flex: none;
  box-shadow: 0 0 0 1px rgba(0,0,0,.1);
}
.sc { display: flex; align-items: center; justify-content: center; gap: .3rem; }
/* hoehere Spezifitaet als input[type=number]{width:100%} */
input.score-in { width: 2.7rem; }
.score-in {
  text-align: center; font-weight: 700; font-size: 1.05rem;
  padding: .35rem .2rem; -moz-appearance: textfield;
}
.score-in::-webkit-outer-spin-button, .score-in::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.colon { font-weight: 800; color: var(--mut); }
.ht-row { display: flex; align-items: center; justify-content: center; gap: .3rem; margin-top: .4rem; font-size: .78rem; color: var(--mut); }
input.ht-in { width: 2.2rem; text-align: center; padding: .25rem .15rem; }
.match.locked { opacity: .85; background: #fafbfa; }
.match.locked .score-in { background: #f0f2f1; pointer-events: none; }
.result-line { text-align: center; font-size: .8rem; margin-top: .4rem; }
.save-state { font-size: .75rem; font-weight: 600; }
.save-state.ok { color: var(--green-d); }
.save-state.pending { color: var(--mut); }
.save-state.muted { color: var(--gray); font-weight: 500; }
.save-state.err { color: #a12626; }
.pill { display: inline-block; padding: .12rem .5rem; border-radius: 999px; font-size: .72rem; font-weight: 700; }
.pill.p3 { background: #dff5e6; color: var(--green-d); }
.pill.p2 { background: #fff2cf; color: #8a6400; }
.pill.p1 { background: #eef1ef; color: #4a544f; }
.pill.p0 { background: #fde7e7; color: #a12626; }
.pill.open { background: #eef1ef; color: var(--mut); }
.flag-lock { color: var(--gray); font-size: .72rem; }

/* Table */
table { width: 100%; border-collapse: collapse; }
th, td { padding: .5rem .4rem; text-align: left; border-bottom: 1px solid var(--line); font-size: .9rem; }
th { color: var(--mut); font-weight: 600; font-size: .78rem; }
td.num, th.num { text-align: right; font-variant-numeric: tabular-nums; }
tr.me { background: #eafaf0; }
.rank { font-weight: 800; }

/* Gruppentabellen */
.grp-card { padding: .5rem .65rem; margin-bottom: .6rem; }
.grp-title { margin: .1rem 0 .4rem; color: var(--green-d); font-size: 1rem; }
table.grp td, table.grp th { padding: .35rem .3rem; font-size: .85rem; }
table.grp .grank { font-weight: 800; color: var(--mut); width: 1.1rem; text-align: center; }
table.grp .tcell { display: flex; align-items: center; gap: .4rem; font-weight: 600; }
table.grp tr.pos1 td, table.grp tr.pos2 td { background: #eafaf0; }
table.grp tr.pos1 .grank, table.grp tr.pos2 .grank { color: var(--green-d); }
table.grp tr.pos3 td { background: #fff8e6; }
table.grp tr.pos3 .grank { color: #8a6400; }

/* Regel-Block unter der Rangliste */
.rules-card { margin-top: .6rem; }
.rules-pts { display: flex; flex-wrap: wrap; gap: .4rem .9rem; }
.rules-pts > span { display: flex; align-items: center; gap: .4rem; font-size: .88rem; }
.rules-pts .pill { min-width: 1.5rem; text-align: center; }
.rules-example { margin-top: .7rem; }
.ex-head { font-size: .9rem; margin-bottom: .35rem; }
.ex-row { display: flex; align-items: center; gap: .5rem; padding: .18rem 0; font-size: .88rem; flex-wrap: wrap; }
.ex-tip { min-width: 6.5rem; }
.ex-row .pill { min-width: 1.5rem; text-align: center; }

/* Verlauf */
.hist-row { font-size: .85rem; padding: .12rem 0; }
.hist .up { color: var(--green-d); font-weight: 800; }
.hist .down { color: #a12626; font-weight: 800; }

/* Sonderpreise */
.award-list { display: flex; flex-direction: column; gap: .4rem; }
.award { display: flex; align-items: center; gap: .6rem; padding: .45rem .5rem; border: 1px solid var(--line); border-radius: 10px; }
.aw-emoji { font-size: 1.5rem; flex: none; line-height: 1; }
.aw-text { flex: 1; font-size: .85rem; line-height: 1.25; min-width: 0; }
.aw-win { text-align: right; font-weight: 700; font-size: .85rem; flex: none; }
.aw-win .muted { font-weight: 400; }

/* Toast */
.toast {
  position: fixed; left: 50%; bottom: 1rem; transform: translateX(-50%);
  background: #222; color: #fff; padding: .6rem 1rem; border-radius: 999px;
  font-size: .85rem; z-index: 50; box-shadow: 0 4px 16px rgba(0,0,0,.25);
}
.toast.err { background: #a12626; }
.err-msg { color: #a12626; font-size: .85rem; margin-top: .5rem; }
.ok-msg { color: var(--green-d); font-size: .85rem; margin-top: .5rem; }

.stat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: .5rem; margin-bottom: 1rem; }
.stat { background: var(--card); border: 1px solid var(--line); border-radius: var(--r); padding: .7rem; text-align: center; }
.stat b { display: block; font-size: 1.4rem; }
.stat span { font-size: .72rem; color: var(--mut); }
