:root {
  --bg: #eef1f6;
  --card: #ffffff;
  --card-2: #f3f5f9;
  --line: #e2e7ee;
  --line-strong: #d3dae3;
  --text: #0f1623;
  --muted: #687686;
  --green: #15a34a;
  --accent: #16a34a;
  --accent-weak: #e7f6ec;
  --gold: #e8a700;
  --silver: #93a1b0;
  --bronze: #c07d3e;
  --shadow: 0 1px 2px rgba(16, 24, 40, .06), 0 1px 3px rgba(16, 24, 40, .08);
  --shadow-lift: 0 4px 14px rgba(16, 24, 40, .10);
}
* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0; background: var(--bg); color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -webkit-tap-highlight-color: transparent;
  overscroll-behavior-y: none;
  padding-bottom: calc(24px + env(safe-area-inset-bottom));
}

/* ---------- App bar / tabs ---------- */
.appbar {
  position: sticky; top: 0; z-index: 10;
  background: rgba(255, 255, 255, .85); backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--line);
  padding: calc(12px + env(safe-area-inset-top)) 12px 0;
}
.brand { text-align: center; font-size: 20px; font-weight: 800; letter-spacing: -.2px; }
.tabs { display: flex; gap: 4px; margin-top: 10px; }
.tab {
  flex: 1; padding: 12px 4px; border: none; background: none; color: var(--muted);
  font-size: 13px; font-weight: 700; cursor: pointer; border-bottom: 2.5px solid transparent;
  transition: color .15s;
}
.tab.active { color: var(--accent); border-bottom-color: var(--accent); }

#view { max-width: 560px; margin: 0 auto; padding: 8px 14px; }
.potline { text-align: center; color: var(--muted); font-size: 13px; font-weight: 500; margin: 10px 0 0; }

.card {
  background: var(--card); border: 1px solid var(--line); border-radius: 18px;
  padding: 16px; margin: 14px 0; box-shadow: var(--shadow);
}
.card-title { font-size: 12px; text-transform: uppercase; letter-spacing: .7px; color: var(--muted); font-weight: 700; margin: 0 0 12px; }
.muted { color: var(--muted); font-weight: 500; text-transform: none; letter-spacing: 0; }
.empty { text-align: center; color: var(--muted); padding: 16px 8px; font-size: 14px; }

/* ---------- Podium ---------- */
.podium { display: flex; align-items: flex-end; justify-content: center; gap: 10px; margin: 18px 0 0; }
.pod {
  background: var(--card); border: 1px solid var(--line); border-radius: 16px; width: 31%;
  text-align: center; padding: 12px 6px; box-shadow: var(--shadow);
}
.pod .rank { font-size: 22px; font-weight: 800; line-height: 1; }
.pod .name { font-size: 15px; font-weight: 700; margin: 6px 0 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pod .pts { font-size: 34px; font-weight: 800; line-height: 1.05; letter-spacing: -1.5px; }
.pod .prize { font-size: 14px; font-weight: 800; color: var(--green); margin-top: 4px; }
.pod.p1 { padding-top: 22px; border-top: 4px solid var(--gold); box-shadow: var(--shadow-lift); }
.pod.p2 { padding-top: 14px; border-top: 4px solid var(--silver); }
.pod.p3 { padding-top: 8px; border-top: 4px solid var(--bronze); }
.rank.g1 { color: var(--gold); } .rank.g2 { color: var(--silver); } .rank.g3 { color: var(--bronze); }

/* ---------- Overall table ---------- */
table.lb { width: 100%; border-collapse: collapse; }
table.lb th {
  color: var(--muted); font-weight: 700; font-size: 11px; text-transform: uppercase;
  letter-spacing: .5px; text-align: right; padding: 8px; border-bottom: 1.5px solid var(--line);
}
table.lb th.left, table.lb td.left { text-align: left; }
table.lb td { text-align: right; padding: 14px 8px; border-bottom: 1px solid var(--line); font-size: 17px; }
table.lb td.player { font-weight: 700; }
table.lb td.day { color: var(--muted); font-size: 16px; }
table.lb td.total { font-weight: 800; font-size: 21px; }
table.lb tr:last-child td { border-bottom: none; }
table.lb tr.top td { background: var(--accent-weak); }
table.lb tr.top td:first-child { border-top-left-radius: 10px; border-bottom-left-radius: 10px; }
table.lb tr.top td:last-child { border-top-right-radius: 10px; border-bottom-right-radius: 10px; }
table.lb td.rank { font-weight: 800; width: 30px; }
td.rank.g1 { color: var(--gold); } td.rank.g2 { color: var(--silver); } td.rank.g3 { color: var(--bronze); }
.pill { display: inline-block; margin-left: 6px; font-size: 11px; font-weight: 800; color: var(--green); background: var(--accent-weak); padding: 2px 7px; border-radius: 999px; }

/* ---------- Scorecard grid ---------- */
.grid-card { padding: 16px 10px; }
.grid-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; overscroll-behavior-x: contain; }
table.grid { border-collapse: separate; border-spacing: 0; width: max-content; }
.grid th, .grid td { text-align: center; }
.hcell {
  font-size: 11px; font-weight: 700; color: var(--muted);
  padding: 6px 0; min-width: 42px; border-bottom: 1.5px solid var(--line);
}
.gcell { padding: 14px 3px; border-bottom: 1px solid var(--line); }
.grid tr:last-child .gcell { border-bottom: none; }
.grid .name-col {
  position: sticky; left: 0; z-index: 2; background: var(--card);
  text-align: left; font-weight: 700; font-size: 16px; min-width: 84px;
  padding-left: 4px; padding-right: 10px; box-shadow: 1px 0 0 var(--line);
  white-space: nowrap;
}
.grid th.name-col { z-index: 3; }
.grid .tot-col {
  position: sticky; right: 0; z-index: 2; background: var(--card);
  font-weight: 800; font-size: 16px; min-width: 44px; color: var(--accent);
  box-shadow: -1px 0 0 var(--line);
}
.grid th.tot-col { z-index: 3; color: var(--muted); }
.grid .sub { color: var(--muted); font-weight: 700; font-size: 13px; min-width: 40px; background: var(--card-2); }

input.scorebox {
  width: 42px; height: 46px; padding: 0; text-align: center;
  font-size: 16px; font-weight: 700; color: var(--text);
  background: var(--card-2); border: 1.5px solid var(--line); border-radius: 10px;
  -moz-appearance: textfield;
}
input.scorebox::-webkit-outer-spin-button, input.scorebox::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
input.scorebox:focus { outline: none; border-color: var(--accent); background: #fff; box-shadow: 0 0 0 3px var(--accent-weak); }
input.scorebox::placeholder { color: #b6bfca; }
input.scorebox.err { border-color: #e5484d; }

/* ---------- CTP ---------- */
.ctp-grid { display: flex; gap: 8px; }
.ctp-card { flex: 1; background: var(--card-2); border: 1px solid var(--line); border-radius: 14px; padding: 12px 8px; text-align: center; }
.ctp-day { font-size: 12px; font-weight: 700; color: var(--muted); margin-bottom: 10px; }
.ctp-select {
  width: 100%; padding: 11px 6px; margin-bottom: 8px; text-align: center; font-size: 16px;
  font-weight: 700; border-radius: 10px; border: 1.5px solid var(--line);
  background: #fff; color: var(--text); -webkit-appearance: none; appearance: none;
}
.ctp-select:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-weak); }
.ctp-amt { font-size: 13px; font-weight: 800; color: var(--green); }
