/* ============================================
   ParTrack Marshal — Mobile CSS
   ============================================ */

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; -webkit-tap-highlight-color:transparent; }

:root {
  --gold:#C9A84C; --gold-l:#E8C96B;
  --forest:#0F1D12; --forest-m:#1A2F1E; --forest-l:#243828;
  --cream:#F0EBE0; --cream-m:#D8D0BE; --cream-d:#A89880;
  --ink:#080F09; --gray:#6A7A6E;
  --green:#4CAF72; --red:#D85A3A;
  --radius:12px; --radius-sm:8px;
}

html, body {
  height:100%; width:100%; overflow:hidden;
  touch-action:manipulation;
  background:var(--forest);
  font-family:'Cormorant Garamond', Georgia, serif;
  color:var(--cream);
  -webkit-font-smoothing:antialiased;
  -webkit-text-size-adjust:100%;
}

/* ── SCREENS ──────────────────────────────── */
.screen {
  display:none; flex-direction:column;
  position:fixed; inset:0;
  overflow-y:auto; overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
}
.screen.active { display:flex; }

/* ── S1 LOGIN ─────────────────────────────── */
#s-login {
  background:linear-gradient(180deg,var(--ink) 0%,var(--forest) 50%,var(--forest-m) 100%);
  align-items:center; justify-content:center;
  padding:env(safe-area-inset-top,20px) 2rem 2rem;
  min-height:100%;
}
.login-wrap { width:100%; max-width:400px; text-align:center; }

.login-logo { margin-bottom:2.5rem; }
.login-logo-mark {
  width:64px; height:64px; border-radius:50%;
  border:1px solid rgba(201,168,76,0.35);
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 1rem;
}
.login-logo-mark svg { width:28px; height:28px; stroke:var(--gold); }
.login-brand {
  font-size:1.6rem; font-weight:600; letter-spacing:0.18em;
  color:var(--gold); text-transform:uppercase;
}
.login-brand span { color:var(--cream); font-weight:300; }
.login-role {
  font-family:'DM Mono',monospace; font-size:0.62rem; font-weight:300;
  letter-spacing:0.2em; text-transform:uppercase; color:var(--gray); margin-top:0.3rem;
}

.login-divider { width:40px; height:1px; background:rgba(201,168,76,0.3); margin:2rem auto; }

.login-field { margin-bottom:1rem; text-align:left; }
.login-label {
  font-family:'DM Mono',monospace; font-size:0.6rem; font-weight:300;
  letter-spacing:0.18em; text-transform:uppercase; color:var(--gray);
  display:block; margin-bottom:0.45rem;
}
.login-input {
  width:100%; padding:0.9rem 1rem;
  background:rgba(240,235,224,0.06);
  border:1px solid rgba(201,168,76,0.2);
  color:var(--cream); font-family:'Cormorant Garamond',serif; font-size:1.05rem;
  border-radius:var(--radius-sm); outline:none;
  transition:border-color 0.25s, background 0.25s;
  -webkit-appearance:none; appearance:none;
}
.login-input:focus { border-color:rgba(201,168,76,0.6); background:rgba(240,235,224,0.09); }
.login-input::placeholder { color:rgba(240,235,224,0.25); }

.login-btn {
  width:100%; margin-top:1.5rem; padding:1rem;
  font-family:'DM Mono',monospace; font-size:0.72rem; font-weight:400;
  letter-spacing:0.14em; text-transform:uppercase;
  background:var(--gold); color:var(--ink);
  border:none; border-radius:var(--radius-sm); cursor:pointer;
  transition:background 0.2s, transform 0.1s;
  -webkit-appearance:none;
}
.login-btn:active { transform:scale(0.98); background:var(--gold-l); }

.login-error {
  font-family:'DM Mono',monospace; font-size:0.65rem; letter-spacing:0.08em;
  color:var(--red); text-align:center; margin-top:0.75rem; min-height:1.2rem;
}
.login-hint {
  font-family:'DM Mono',monospace; font-size:0.6rem; font-weight:300;
  letter-spacing:0.08em; color:rgba(106,122,110,0.7);
  text-align:center; margin-top:2rem; line-height:1.8;
}
.login-hint strong { color:var(--gold); font-weight:400; }

/* PIN */
.pin-title {
  font-family:'DM Mono',monospace; font-size:0.62rem; letter-spacing:0.15em;
  text-transform:uppercase; color:var(--gold); text-align:center; margin-bottom:1.5rem;
}
.pin-row { display:flex; gap:0.6rem; justify-content:center; margin:1rem 0; }
.pin-dot {
  width:52px; height:60px; border-radius:var(--radius-sm);
  border:1px solid rgba(201,168,76,0.2);
  background:rgba(240,235,224,0.05);
  display:flex; align-items:center; justify-content:center;
  font-family:'DM Mono',monospace; font-size:1.5rem; color:var(--gold);
  transition:border-color 0.2s, background 0.2s;
}
.pin-dot.filled { border-color:rgba(201,168,76,0.5); background:rgba(201,168,76,0.1); }

.numpad {
  display:grid; grid-template-columns:repeat(3,1fr); gap:0.6rem; margin-top:1rem;
}
.num-key {
  padding:1.1rem 0; border-radius:var(--radius-sm);
  border:1px solid rgba(201,168,76,0.12);
  background:rgba(240,235,224,0.04);
  font-family:'DM Mono',monospace; font-size:1.4rem; font-weight:300;
  color:var(--cream); cursor:pointer; text-align:center;
  transition:background 0.15s, transform 0.1s; user-select:none;
  -webkit-appearance:none;
}
.num-key:active { background:rgba(201,168,76,0.15); transform:scale(0.96); }
.num-empty { border:none !important; background:transparent !important; cursor:default !important; }
.num-del { font-size:1rem; color:var(--gray); }

.back-text-btn {
  display:block; margin:1.5rem auto 0; background:none; border:none;
  font-family:'DM Mono',monospace; font-size:0.65rem; color:var(--gray);
  letter-spacing:0.1em; cursor:pointer; text-align:center;
}

/* ── S2 HOME ──────────────────────────────── */
#s-home { background:var(--forest); }
.home-header {
  padding:calc(env(safe-area-inset-top,16px) + 1rem) 1.5rem 1rem;
  border-bottom:1px solid rgba(201,168,76,0.1);
  display:flex; align-items:center; justify-content:space-between;
  background:var(--ink);
}
.home-greeting { font-size:0.85rem; color:var(--gray); margin-bottom:0.2rem; }
.home-name { font-size:1.4rem; font-weight:400; }
.home-avatar {
  width:42px; height:42px; border-radius:50%;
  background:rgba(201,168,76,0.15); border:1px solid rgba(201,168,76,0.3);
  display:flex; align-items:center; justify-content:center;
  font-family:'DM Mono',monospace; font-size:0.72rem; color:var(--gold);
  cursor:pointer; flex-shrink:0;
}

.status-bar {
  margin:1rem 1.5rem; padding:0.85rem 1rem;
  background:rgba(201,168,76,0.07); border:1px solid rgba(201,168,76,0.18);
  border-radius:var(--radius-sm);
  display:flex; align-items:center; justify-content:space-between;
}
.live-badge {
  display:flex; align-items:center; gap:0.5rem;
  font-family:'DM Mono',monospace; font-size:0.65rem;
  letter-spacing:0.12em; text-transform:uppercase; color:var(--gold);
}
.pulse-dot {
  width:7px; height:7px; border-radius:50%; background:var(--gold);
  animation:pulse 1.8s ease-in-out infinite;
}
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:0.3} }
.round-name { font-family:'DM Mono',monospace; font-size:0.65rem; color:var(--cream-m); }

.section-title-sm {
  font-family:'DM Mono',monospace; font-size:0.62rem; font-weight:300;
  letter-spacing:0.18em; text-transform:uppercase; color:var(--gray);
  padding:0 1.5rem; margin:1.2rem 0 0.75rem;
}

.group-cards { padding:0 1.5rem; display:flex; flex-direction:column; gap:0.75rem; }
.group-card {
  padding:1rem 1.1rem; background:var(--forest-m);
  border:1px solid rgba(201,168,76,0.12); border-radius:var(--radius);
  display:flex; align-items:center; justify-content:space-between;
  cursor:pointer; transition:border-color 0.2s, background 0.2s;
}
.group-card:active { border-color:rgba(201,168,76,0.35); background:rgba(201,168,76,0.04); }
.gc-hole {
  font-family:'DM Mono',monospace; font-size:0.6rem; font-weight:300;
  letter-spacing:0.15em; text-transform:uppercase; color:var(--gold); margin-bottom:0.3rem;
}
.gc-players { font-size:1.05rem; font-weight:400; margin-bottom:0.2rem; }
.gc-sub { font-family:'DM Mono',monospace; font-size:0.62rem; color:var(--gray); }
.gc-right { text-align:right; flex-shrink:0; margin-left:1rem; }
.gc-status {
  font-family:'DM Mono',monospace; font-size:0.6rem; font-weight:400;
  letter-spacing:0.08em; padding:0.25rem 0.6rem; border-radius:4px;
  margin-bottom:0.5rem; display:inline-block;
}
.gc-status.playing { background:rgba(76,175,114,0.15); color:var(--green); }
.gc-status.waiting { background:rgba(201,168,76,0.12); color:var(--gold); }
.gc-status.done    { background:rgba(240,235,224,0.08); color:var(--gray); }
.gc-holes-left { font-family:'DM Mono',monospace; font-size:0.7rem; color:var(--gray); }

.bottom-nav {
  display:flex; border-top:1px solid rgba(201,168,76,0.1);
  background:var(--ink);
  padding-bottom:env(safe-area-inset-bottom,12px);
  margin-top:auto;
}
.nav-item {
  flex:1; padding:0.85rem 0 0.65rem;
  display:flex; flex-direction:column; align-items:center; gap:0.35rem;
  cursor:pointer; color:var(--gray); transition:color 0.2s;
}
.nav-item.active { color:var(--gold); }
.nav-item svg { width:20px; height:20px; stroke:currentColor; fill:none; stroke-width:1.4; }
.nav-item span {
  font-family:'DM Mono',monospace; font-size:0.55rem;
  letter-spacing:0.1em; text-transform:uppercase;
}

/* ── S3 ENTRY ─────────────────────────────── */
#s-entry { background:var(--forest); }
.entry-header {
  padding:calc(env(safe-area-inset-top,16px) + 0.75rem) 1.25rem 0.75rem;
  border-bottom:1px solid rgba(201,168,76,0.1);
  display:flex; align-items:center; gap:1rem;
  background:var(--ink); flex-shrink:0;
}
.back-btn {
  width:38px; height:38px; border-radius:50%;
  border:1px solid rgba(201,168,76,0.2);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; background:transparent; color:var(--cream); flex-shrink:0;
  -webkit-appearance:none;
}
.back-btn svg { width:16px; height:16px; }
.entry-header-info { flex:1; min-width:0; }
.entry-round {
  font-family:'DM Mono',monospace; font-size:0.6rem; font-weight:300;
  letter-spacing:0.15em; text-transform:uppercase; color:var(--gold); margin-bottom:0.15rem;
}
.entry-group { font-size:1rem; font-weight:400; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.entry-progress-label { font-family:'DM Mono',monospace; font-size:0.72rem; color:var(--gray); flex-shrink:0; }

/* Players strip */
.players-strip {
  display:flex; border-bottom:1px solid rgba(201,168,76,0.1);
  background:var(--forest-m); overflow-x:auto; scrollbar-width:none; flex-shrink:0;
}
.players-strip::-webkit-scrollbar { display:none; }
.player-tab {
  flex:1; min-width:80px; padding:0.75rem 0.5rem;
  text-align:center; cursor:pointer;
  border-bottom:2px solid transparent;
  transition:border-color 0.2s, background 0.2s;
}
.player-tab.active { border-bottom-color:var(--gold); background:rgba(201,168,76,0.04); }
.player-tab-name { font-size:0.9rem; font-weight:400; line-height:1.2; }
.player-tab-hcp { font-family:'DM Mono',monospace; font-size:0.58rem; color:var(--gray); margin-top:2px; }
.player-tab-score { font-family:'DM Mono',monospace; font-size:0.75rem; margin-top:3px; }
.score-under { color:var(--green); }
.score-over  { color:var(--red); }
.score-even  { color:var(--gray); }

/* Hole stepper */
.hole-stepper {
  padding:1rem 1.25rem 0.75rem;
  border-bottom:1px solid rgba(201,168,76,0.08); flex-shrink:0;
}
.hole-nav { display:flex; align-items:center; justify-content:space-between; margin-bottom:0.75rem; }
.hole-arrow {
  width:44px; height:44px; border-radius:50%;
  border:1px solid rgba(201,168,76,0.2);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; background:transparent; flex-shrink:0;
  transition:border-color 0.2s, background 0.2s; -webkit-appearance:none;
}
.hole-arrow:active { border-color:var(--gold); background:rgba(201,168,76,0.1); }
.hole-arrow svg { width:18px; height:18px; stroke:var(--cream); }
.hole-center { text-align:center; }
.hole-eyebrow {
  font-family:'DM Mono',monospace; font-size:0.6rem; font-weight:300;
  letter-spacing:0.2em; text-transform:uppercase; color:var(--gold); margin-bottom:0.2rem;
}
.hole-par-big { font-size:2.2rem; font-weight:300; line-height:1; }
.hole-yds { font-family:'DM Mono',monospace; font-size:0.6rem; color:var(--gray); margin-top:0.2rem; }

.hole-dots { display:flex; gap:4px; justify-content:center; margin-top:0.75rem; flex-wrap:wrap; }
.hole-dot {
  width:18px; height:6px; border-radius:3px;
  background:rgba(240,235,224,0.1); cursor:pointer;
  transition:background 0.2s;
}
.hole-dot.current  { background:var(--gold); }
.hole-dot.entered  { background:rgba(201,168,76,0.4); }
.hole-dot.birdie   { background:var(--green); }
.hole-dot.eagle    { background:var(--gold); }
.hole-dot.bogey,
.hole-dot.double   { background:var(--red); }

/* Score pad */
.score-pad { flex:1; padding:1rem 1.25rem; display:flex; flex-direction:column; gap:0.75rem; overflow-y:auto; }
.score-display {
  text-align:center; padding:1.25rem;
  background:rgba(240,235,224,0.04);
  border:1px solid rgba(201,168,76,0.15); border-radius:var(--radius);
}
.score-display-player {
  font-family:'DM Mono',monospace; font-size:0.6rem;
  letter-spacing:0.15em; text-transform:uppercase; color:var(--gold); margin-bottom:0.5rem;
}
.score-display-num { font-size:3.5rem; font-weight:300; line-height:1; color:var(--cream); }
.score-display-rel { font-family:'DM Mono',monospace; font-size:0.85rem; margin-top:0.4rem; color:var(--gray); }
.score-display-label { font-family:'DM Mono',monospace; font-size:0.65rem; color:var(--gray); margin-top:0.3rem; }

.score-picker { display:grid; grid-template-columns:repeat(4,1fr); gap:0.5rem; }
.score-chip {
  padding:0.9rem 0; text-align:center; border-radius:var(--radius-sm);
  border:1px solid rgba(201,168,76,0.15);
  background:rgba(240,235,224,0.04);
  cursor:pointer; transition:all 0.15s; user-select:none;
}
.score-chip:active { transform:scale(0.95); }
.score-chip.selected { border-color:var(--gold); background:rgba(201,168,76,0.15); }
.sc-num { font-size:1.4rem; font-weight:300; line-height:1; }
.sc-label { font-family:'DM Mono',monospace; font-size:0.52rem; color:var(--gray); margin-top:3px; }
.score-chip.eagle  .sc-num { color:var(--gold); }
.score-chip.birdie .sc-num { color:var(--green); }
.score-chip.par    .sc-num { color:var(--cream); }
.score-chip.bogey  .sc-num,
.score-chip.double .sc-num { color:var(--red); }

/* Entry actions */
.entry-actions {
  padding:0.75rem 1.25rem calc(env(safe-area-inset-bottom,12px) + 0.75rem);
  display:flex; gap:0.75rem; flex-shrink:0; background:var(--ink);
}
.btn-next {
  flex:1; padding:1rem; border-radius:var(--radius-sm);
  font-family:'DM Mono',monospace; font-size:0.72rem; font-weight:400;
  letter-spacing:0.12em; text-transform:uppercase;
  background:var(--gold); color:var(--ink); border:none; cursor:pointer;
  transition:background 0.2s, transform 0.1s; -webkit-appearance:none;
}
.btn-next:active { transform:scale(0.98); background:var(--gold-l); }
.btn-skip {
  padding:1rem 1.2rem; border-radius:var(--radius-sm);
  font-family:'DM Mono',monospace; font-size:0.72rem; font-weight:300;
  letter-spacing:0.1em; text-transform:uppercase;
  border:1px solid rgba(201,168,76,0.2); color:var(--gray);
  background:transparent; cursor:pointer; transition:border-color 0.2s;
  -webkit-appearance:none;
}
.btn-skip:active { border-color:var(--gold); color:var(--gold); }

/* ── S4 DONE ──────────────────────────────── */
#s-done {
  background:var(--forest);
  align-items:center; justify-content:center;
  padding:2rem;
}
.done-content { width:100%; max-width:400px; text-align:center; }
.done-check {
  width:72px; height:72px; border-radius:50%;
  border:1px solid rgba(201,168,76,0.35);
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 1.5rem;
  animation:scaleIn 0.4s ease-out;
}
@keyframes scaleIn { from{transform:scale(0.5);opacity:0} to{transform:scale(1);opacity:1} }
.done-check svg { width:30px; height:30px; stroke:var(--gold); }
.done-title { font-size:1.8rem; font-weight:300; margin-bottom:0.5rem; }
.done-sub {
  font-family:'DM Mono',monospace; font-size:0.68rem; font-weight:300;
  letter-spacing:0.1em; color:var(--gray); margin-bottom:2rem; line-height:1.7;
}
.done-scorecard {
  width:100%; background:rgba(240,235,224,0.04);
  border:1px solid rgba(201,168,76,0.18); border-radius:var(--radius);
  padding:1.25rem; margin-bottom:2rem; text-align:left;
}
.done-row {
  display:flex; justify-content:space-between; align-items:center;
  padding:0.6rem 0; border-bottom:1px solid rgba(201,168,76,0.07);
}
.done-row:last-child { border-bottom:none; }
.done-row-label { font-family:'DM Mono',monospace; font-size:0.65rem; color:var(--gray); }
.done-row-val { font-size:1rem; font-weight:400; }
.btn-done {
  width:100%; padding:1rem; border-radius:var(--radius-sm);
  font-family:'DM Mono',monospace; font-size:0.72rem; font-weight:400;
  letter-spacing:0.12em; text-transform:uppercase;
  background:var(--gold); color:var(--ink); border:none; cursor:pointer;
  transition:background 0.2s; -webkit-appearance:none;
}
.btn-done:active { background:var(--gold-l); }
