/* CrowGolfTracker — design tokens & base styles */

:root {
  /* Greens */
  --green-900: #102a20;
  --green-800: #14352a;
  --green-700: #1f3a2e;
  --green-600: #2a4a3a;
  --green-500: #3a5d4a;
  --green-300: #6e8a7c;
  --green-100: #c4d3c9;

  /* Creams / paper */
  --cream-50:  #faf6ec;
  --cream-100: #f4efe4;
  --cream-200: #ede6d3;
  --cream-300: #ddd4bd;

  /* Ink */
  --ink-900: #1a1a1a;
  --ink-700: #2c2c2a;
  --ink-500: #5a5a55;
  --ink-400: #888378;
  --ink-300: #b3ad9f;
  --ink-200: #cec8b8;

  /* Accent — aged brass */
  --brass-700: #8a5a2b;
  --brass-600: #a8743a;
  --brass-500: #b8862d;
  --brass-300: #d6b787;

  /* Semantic */
  --bg:            var(--cream-100);
  --bg-elev:       #faf7ed;
  --bg-sunk:       #ede6d3;
  --border:        #d8cfb6;
  --border-strong: #b9ae8f;
  --fg:            var(--ink-900);
  --fg-muted:      var(--ink-500);
  --fg-faint:      var(--ink-400);
  --primary:       var(--green-700);
  --accent:        var(--brass-600);

  /* Status */
  --good: #3f7a5a;
  --bad:  #a83a3a;

  /* Fonts */
  --font-display: 'Fraunces', 'Iowan Old Style', Georgia, serif;
  --font-sans:    'Inter', -apple-system, system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, Menlo, monospace;

  /* Shape */
  --radius-sm: 4px;
  --radius:    6px;
  --radius-lg: 10px;
}

/* ── Reset ─────────────────────────────────────────── */

*, *::before, *::after { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.45;
  color: var(--fg);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  font-feature-settings: 'cv11', 'ss01';
}

button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; padding: 0; }
a { color: inherit; text-decoration: none; }

input, select, textarea {
  font-family: inherit;
  font-size: inherit;
  color: inherit;
}

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 500;
  font-variation-settings: 'opsz' 30, 'SOFT' 30;
  letter-spacing: -0.01em;
  margin: 0;
  color: var(--ink-900);
}

.mono { font-family: var(--font-mono); font-feature-settings: 'tnum'; }
.tnum { font-variant-numeric: tabular-nums; font-feature-settings: 'tnum'; }
.serif { font-family: var(--font-display); }

/* ── App Shell ─────────────────────────────────────── */

.app {
  display: grid;
  grid-template-columns: 232px 1fr;
  min-height: 100vh;
  align-content: start;
}

/* ── Sidebar ───────────────────────────────────────── */

.sidebar {
  background: var(--green-700);
  color: var(--cream-100);
  padding: 22px 18px;
  display: flex;
  flex-direction: column;
  gap: 28px;
  position: sticky;
  top: 0;
  height: 100svh;
  border-right: 1px solid var(--green-900);
  z-index: 100;
}

.sidebar-brand {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 6px 4px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.sidebar-brand .brand-row {
  display: flex;
  align-items: center;
  gap: 10px;
}
.sidebar-brand .crest {
  width: 30px; height: 30px;
  color: var(--brass-300);
  flex-shrink: 0;
}
.sidebar-brand .wordmark {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 18px;
  letter-spacing: -0.01em;
  line-height: 1;
  color: var(--cream-100);
}
.sidebar-brand .tag {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--brass-300);
  padding-left: 40px;
}

.nav { display: flex; flex-direction: column; gap: 1px; }
.nav-section-title {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.4);
  padding: 14px 8px 6px;
}
.nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: var(--radius);
  color: rgba(255,255,255,0.78);
  font-size: 13.5px;
  transition: background 0.12s, color 0.12s;
  width: 100%;
  text-align: left;
}
.nav-item:hover { background: rgba(255,255,255,0.05); color: white; }
.nav-item.active {
  background: rgba(255,255,255,0.07);
  color: white;
  box-shadow: inset 2px 0 0 var(--brass-500);
}
.nav-item svg { width: 16px; height: 16px; opacity: 0.7; flex-shrink: 0; }
.nav-item.active svg { opacity: 1; color: var(--brass-300); }

.sidebar-footer-legacy { display: none; }
.sidebar-user { display: flex; flex-direction: column; gap: 2px; }
.sidebar-username { color: var(--cream-50); font-weight: 500; font-size: 12px; }
.sidebar-hcp { font-size: 10px; opacity: 0.6; }
.avatar {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--brass-600);
  color: white;
  display: grid; place-items: center;
  font-size: 11px;
  font-weight: 600;
  flex-shrink: 0;
}

/* ── Main content ──────────────────────────────────── */

.main {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 36px;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
  position: sticky; top: 0; z-index: 10;
}
.topbar .crumbs { font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-faint); }
.topbar h1 { font-size: 24px; font-weight: 500; }
.topbar .actions { display: flex; align-items: center; gap: 10px; }
.topbar-season { font-size: 12px; color: var(--fg-muted); white-space: nowrap; }
.topbar-cta { font-size: 12px; padding: 6px 12px; }

.content {
  padding: 28px 36px 60px;
  max-width: 1280px;
  width: 100%;
}

/* ── Buttons ───────────────────────────────────────── */

.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px;
  border-radius: var(--radius);
  font-size: 13px;
  font-weight: 500;
  border: 1px solid var(--border-strong);
  background: var(--bg-elev);
  color: var(--ink-900);
  transition: background 0.12s, border-color 0.12s;
  cursor: pointer;
}
.btn:hover { background: var(--cream-200); }
.btn-primary { background: var(--green-700); color: var(--cream-50); border-color: var(--green-800); }
.btn-primary:hover { background: var(--green-800); }
.btn-accent { background: var(--brass-600); color: var(--cream-50); border-color: var(--brass-700); }
.btn-accent:hover { background: var(--brass-700); }
.btn-ghost { background: transparent; border-color: transparent; color: var(--fg-muted); }
.btn-ghost:hover { background: var(--cream-200); color: var(--ink-900); }
.btn-danger { background: transparent; color: var(--bad); border-color: var(--bad); }
.btn-danger:hover { background: var(--bad); color: white; }

/* ── Cards ─────────────────────────────────────────── */

.card { background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius); padding: 22px; }
.card-title { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 14px; }
.card-title h3 { font-size: 14px; letter-spacing: 0.16em; text-transform: uppercase; font-family: var(--font-sans); font-weight: 600; color: var(--fg-muted); }
.card-title .meta { font-size: 11px; color: var(--fg-faint); }

/* ── Stat blocks ───────────────────────────────────── */

.stat-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 1px; background: var(--border); border-radius: var(--radius); overflow: hidden; }
.stat { background: var(--bg-elev); padding: 18px 20px; display: flex; flex-direction: column; gap: 4px; }
.stat .label { font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-faint); }
.stat .value { font-family: var(--font-display); font-size: 32px; font-weight: 400; font-variation-settings: 'opsz' 96; letter-spacing: -0.02em; color: var(--ink-900); line-height: 1.05; }
.stat .delta { font-size: 11px; font-family: var(--font-mono); display: inline-flex; align-items: center; gap: 4px; }
.delta.up   { color: var(--good); }
.delta.down { color: var(--bad); }
.delta.flat { color: var(--fg-faint); }

/* ── Tables ────────────────────────────────────────── */

table.scorecard { width: 100%; border-collapse: collapse; font-size: 13px; font-variant-numeric: tabular-nums; }
.scorecard th, .scorecard td { padding: 10px 8px; text-align: center; border-bottom: 1px solid var(--border); }
.scorecard th { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600; color: var(--fg-faint); background: var(--cream-100); }
.scorecard td.label { text-align: left; font-weight: 500; color: var(--fg-muted); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; }
.scorecard tr.totals td { background: var(--cream-50); font-weight: 600; border-top: 1px solid var(--border-strong); border-bottom: 1px solid var(--border-strong); }
.scorecard td.score-eagle  { color: #b8862d; font-weight: 600; }
.scorecard td.score-birdie { color: #3f7a5a; font-weight: 600; }
.scorecard td.score-par    { color: var(--ink-900); }
.scorecard td.score-bogey  { color: var(--ink-500); }
.scorecard td.score-double { color: var(--bad); }

.score-pip { display: inline-grid; place-items: center; width: 24px; height: 24px; font-weight: 600; font-size: 13px; }
/* Eagle (≤-2): double circle, brass */
.score-pip.eagle  { color: var(--brass-600); border-radius: 50%;
                    box-shadow: 0 0 0 1.5px var(--brass-600), 0 0 0 3.5px var(--bg-elev), 0 0 0 5px var(--brass-600); }
/* Birdie (-1): single circle, green */
.score-pip.birdie { color: var(--green-700); border-radius: 50%;
                    box-shadow: 0 0 0 1.5px var(--green-700); }
/* Par (0): plain */
.score-pip.par    { color: var(--ink-900); }
/* Bogey (+1): single box, muted */
.score-pip.bogey  { color: var(--ink-700); border-radius: 3px;
                    box-shadow: 0 0 0 1.5px var(--ink-400); }
/* Double (+2): double box, red */
.score-pip.double { color: var(--bad); border-radius: 3px;
                    box-shadow: 0 0 0 1.5px var(--bad), 0 0 0 3.5px var(--bg-elev), 0 0 0 5px var(--bad); }
/* Triple+ (≥+3): solid red square */
.score-pip.triple { color: white; background: var(--bad); border-radius: 3px; }

/* ── Form controls ─────────────────────────────────── */

.field { display: flex; flex-direction: column; gap: 6px; }
.field label { font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-faint); font-weight: 600; }
.input, .select { height: 36px; padding: 0 10px; border: 1px solid var(--border-strong); border-radius: var(--radius); background: var(--bg-elev); color: var(--ink-900); outline: none; width: 100%; }
.input:focus, .select:focus { border-color: var(--green-600); box-shadow: 0 0 0 3px rgba(31,58,46,0.12); }
.input.error { border-color: var(--bad); }
.field .hint { font-size: 11px; color: var(--fg-faint); }
.field .error-msg { font-size: 11px; color: var(--bad); }

/* ── Segmented control ─────────────────────────────── */

.segmented { display: inline-flex; background: var(--cream-200); border: 1px solid var(--border); border-radius: var(--radius); padding: 2px; }
.segmented button { padding: 6px 12px; font-size: 12px; border-radius: 4px; color: var(--fg-muted); font-weight: 500; }
.segmented button.active { background: var(--bg-elev); color: var(--ink-900); box-shadow: 0 1px 2px rgba(0,0,0,0.06); }

/* ── Yes/No toggle ─────────────────────────────────── */

.yn { display: inline-flex; border: 1px solid var(--border-strong); border-radius: var(--radius); overflow: hidden; background: var(--bg-elev); }
.yn button { padding: 6px 12px; font-size: 12px; font-weight: 500; color: var(--fg-muted); min-width: 40px; }
.yn button + button { border-left: 1px solid var(--border); }
.yn button.on-yes { background: var(--green-700); color: var(--cream-50); }
.yn button.on-no  { background: var(--cream-300); color: var(--ink-900); }
.yn button.disabled { opacity: 0.3; cursor: not-allowed; }

/* ── Number stepper ────────────────────────────────── */

.num-step { display: inline-flex; align-items: stretch; border: 1px solid var(--border-strong); border-radius: var(--radius); overflow: hidden; background: var(--bg-elev); }
.num-step button { width: 28px; color: var(--fg-muted); font-size: 14px; background: var(--cream-100); }
.num-step button:hover { background: var(--cream-200); }
.num-step .val { min-width: 36px; display: grid; place-items: center; font-variant-numeric: tabular-nums; font-weight: 600; border-left: 1px solid var(--border); border-right: 1px solid var(--border); }

/* ── Misc ──────────────────────────────────────────── */

.bar { height: 6px; background: var(--cream-200); border-radius: 999px; overflow: hidden; }
.bar > span { display: block; height: 100%; background: var(--green-700); }
.bar.brass > span { background: var(--brass-600); }

.rule { height: 1px; background: linear-gradient(to right, transparent, var(--border-strong) 10%, var(--border-strong) 90%, transparent); margin: 24px 0; }

.page-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 24px; }
.page-header .eyebrow { font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--brass-600); font-weight: 600; margin-bottom: 6px; }
.page-header h2 { font-size: 36px; line-height: 1; font-weight: 400; font-variation-settings: 'opsz' 90; }
.page-header p { margin: 6px 0 0; color: var(--fg-muted); font-size: 13.5px; }

.grid-2 { display: grid; grid-template-columns: 2fr 1fr; gap: 20px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }

.chip { display: inline-flex; align-items: center; gap: 6px; padding: 3px 8px; border-radius: 999px; font-size: 11px; background: var(--cream-200); color: var(--fg-muted); border: 1px solid var(--border); }
.chip.green { background: rgba(31,58,46,0.08); color: var(--green-700); border-color: rgba(31,58,46,0.18); }
.chip.brass { background: rgba(168,116,58,0.1); color: var(--brass-700); border-color: rgba(168,116,58,0.25); }

/* ── Login ─────────────────────────────────────────── */

.login-shell { min-height: 100vh; display: grid; grid-template-columns: 1fr 1fr; }
.login-art { background: var(--green-700); color: var(--cream-100); padding: 48px; display: flex; flex-direction: column; justify-content: space-between; position: relative; overflow: hidden; }
.login-art .crest-bg { position: absolute; right: -120px; bottom: -100px; width: 480px; height: 480px; color: rgba(255,255,255,0.05); }
.login-form-wrap { display: grid; place-items: center; padding: 48px; }
.login-form { width: 100%; max-width: 360px; display: flex; flex-direction: column; gap: 0; }
.login-form h2 { font-size: 28px; margin-bottom: 6px; }
.login-form .subtitle { color: var(--fg-muted); font-size: 13.5px; margin-bottom: 28px; }
.login-form .field { margin-bottom: 16px; }
.login-form .btn { width: 100%; justify-content: center; height: 40px; font-size: 14px; margin-top: 8px; }
.login-error { color: var(--bad); font-size: 12px; margin-top: 10px; min-height: 18px; }

/* ── Page stubs ────────────────────────────────────── */

.page-placeholder { display: flex; flex-direction: column; gap: 8px; padding: 60px 36px; color: var(--fg-muted); }
.page-placeholder h2 { color: var(--ink-900); }
.page-placeholder p { font-size: 13px; }

/* ── Blazor error UI ───────────────────────────────── */

#blazor-error-ui {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 1000;
  padding: 10px 48px 10px 20px;
  background: #fff3cd;
  border-top: 1px solid var(--border-strong);
  font-size: 13px;
  color: var(--ink-700);
}

#blazor-error-ui .reload {
  font-weight: 600;
  margin-left: 8px;
  color: var(--green-700);
}

#blazor-error-ui .dismiss {
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  cursor: pointer;
  color: var(--fg-muted);
  font-size: 16px;
}

/* ── Round entry ──────────────────────────────────── */

/* Course cards */
.course-card { text-align:left; padding:20px; background:var(--bg-elev); border:1px solid var(--border); border-radius:var(--radius); display:flex; flex-direction:column; transition:border-color 0.12s,background 0.12s,box-shadow 0.12s; }
.course-card:hover { border-color:var(--border-strong); background:var(--cream-50); }
.course-card.selected { border-color:var(--green-700); background:var(--cream-50); box-shadow:0 0 0 3px rgba(31,58,46,0.08); }
.course-card-new { border-style:dashed; background:transparent; align-items:flex-start; justify-content:center; min-height:90px; }
.course-card-new.selected { border-style:solid; border-color:var(--brass-600); box-shadow:0 0 0 3px rgba(168,116,58,0.1); background:var(--cream-50); }
.new-course-plus { width:36px; height:36px; border-radius:50%; background:var(--brass-600); color:var(--cream-50); display:grid; place-items:center; font-size:20px; font-weight:bold; flex-shrink:0; }

/* Course management */
.course-mgmt-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.course-mgmt-card { background:var(--bg-elev); border:1px solid var(--border); border-radius:var(--radius); padding:20px; display:flex; flex-direction:column; gap:16px; transition:border-color 0.12s; }
.course-mgmt-card.editing { border-color:var(--brass-600); box-shadow:0 0 0 3px rgba(168,116,58,0.08); }
.course-mgmt-body { flex:1; }
.course-mgmt-actions { display:flex; gap:8px; align-items:center; border-top:1px solid var(--border); padding-top:14px; }
.empty-state { display:flex; flex-direction:column; align-items:center; gap:16px; padding:60px 0; color:var(--fg-muted); font-size:14px; }

/* User management cards */
.user-mgmt-card { background:var(--bg-elev); border:1px solid var(--border); border-radius:var(--radius); padding:20px; display:flex; align-items:center; gap:16px; }
.user-mgmt-avatar { width:40px; height:40px; border-radius:50%; background:var(--green-700); color:var(--cream-100); display:grid; place-items:center; font-size:16px; font-weight:600; flex-shrink:0; }
.user-mgmt-body { flex:1; min-width:0; }
.user-mgmt-name { font-family:var(--font-display); font-size:18px; margin-bottom:4px; }
.user-mgmt-meta { display:flex; align-items:center; gap:8px; font-size:12px; color:var(--fg-muted); flex-wrap:wrap; }
.role-badge { font-size:10px; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; padding:2px 8px; border-radius:20px; }
.role-admin { background:rgba(168,116,58,0.15); color:var(--brass-600); }
.role-player { background:rgba(31,58,46,0.1); color:var(--green-700); }

@media (max-width: 640px) {
    .course-mgmt-grid { grid-template-columns:1fr; }
    .user-mgmt-card { flex-wrap:wrap; }
    .user-mgmt-card .course-mgmt-actions { width:100%; border-top:1px solid var(--border); padding-top:12px; }
}

/* Par grid */
.par-section-label { font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--fg-faint); font-weight:600; margin-bottom:8px; }
.par-group-header { display:flex; align-items:center; gap:12px; margin-bottom:6px; }
.par-group-label { font-size:10px; letter-spacing:0.14em; text-transform:uppercase; color:var(--fg-muted); font-weight:600; min-width:60px; }
.par-group-par { font-size:11px; color:var(--fg-faint); }
.par-grid-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.par-grid { display:grid; grid-template-columns:repeat(9,1fr); gap:6px; margin-bottom:4px; min-width: 468px; }
.par-cell-edit { display:flex; flex-direction:column; align-items:center; gap:6px; padding:8px 0; border:1px solid var(--border); border-radius:var(--radius-sm); background:var(--bg-elev); }
.par-hole-n { font-size:10px; letter-spacing:0.14em; text-transform:uppercase; color:var(--fg-faint); font-weight:600; }
.par-toggle { display:inline-flex; border:1px solid var(--border); border-radius:4px; overflow:hidden; background:var(--cream-100); }
.par-toggle button { width:24px; height:24px; font-size:12px; font-weight:600; font-variant-numeric:tabular-nums; color:var(--fg-muted); font-family:var(--font-mono); }
.par-toggle button+button { border-left:1px solid var(--border); }
.par-toggle button.active { background:var(--green-700); color:var(--cream-50); }
.par-toggle button:not(.active):hover { background:var(--cream-200); }

/* Hole strip + pills */
.hole-strip { display:grid; grid-template-columns:repeat(9,1fr); gap:4px; padding:14px; background:var(--bg-elev); border:1px solid var(--border); border-radius:var(--radius); }
.hole-pill { display:flex; flex-direction:column; align-items:center; padding:8px 6px; border-radius:var(--radius); border:1px solid var(--border); background:var(--cream-50); gap:2px; transition:all 0.12s; min-width:0; }
.hole-pill:hover { border-color:var(--border-strong); }
.hole-pill.active { background:var(--green-700); border-color:var(--green-800); color:var(--cream-50); box-shadow:0 4px 12px rgba(31,58,46,0.15); }
.hole-pill.filled:not(.active) { background:var(--cream-200); }
.pill-n { font-family:var(--font-display); font-size:16px; font-variant-numeric:tabular-nums; font-weight:500; }
.pill-par { font-size:9px; opacity:0.6; letter-spacing:0.1em; text-transform:uppercase; }
.pill-score { font-size:10px; font-variant-numeric:tabular-nums; margin-top:2px; padding:1px 6px; background:rgba(255,255,255,0.15); border-radius:8px; }
.hole-pill:not(.active) .pill-score { background:var(--bg-elev); color:var(--fg-muted); }
.pill-score.good { background:var(--good); color:white; }
.pill-score.bad { background:var(--bad); color:white; }

/* Score tiles */
.score-grid { display:grid; grid-template-columns:repeat(6,1fr); gap:6px; max-width:460px; }
.score-tile { aspect-ratio:1; display:flex; flex-direction:column; align-items:center; justify-content:center; background:var(--bg-elev); border:1px solid var(--border-strong); border-radius:var(--radius); font-family:var(--font-display); font-size:22px; color:var(--ink-900); transition:all 0.1s; gap:2px; }
.score-tile:hover { background:var(--cream-200); }
.score-tile .tile-label { font-size:9px; font-family:var(--font-sans); letter-spacing:0.1em; text-transform:uppercase; color:var(--fg-faint); }
.score-tile.selected { background:var(--green-700); color:var(--cream-50); border-color:var(--green-800); }
.score-tile.selected .tile-label { color:var(--cream-200); }
.score-tile.selected.birdie { background:var(--good); }
.score-tile.selected.double { background:var(--bad); }

/* YN big */
.yn-big { display:grid; grid-template-columns:1fr 1fr; gap:6px; }
.yn-big button { display:inline-flex; align-items:center; justify-content:center; gap:8px; height:44px; border:1px solid var(--border-strong); border-radius:var(--radius); background:var(--bg-elev); font-size:13px; font-weight:500; color:var(--fg-muted); }
.yn-big button.on-yes { background:var(--green-700); color:var(--cream-50); border-color:var(--green-800); }
.yn-big button.on-no { background:var(--cream-300); color:var(--ink-900); border-color:var(--border-strong); }
.yn-big button:disabled { opacity:0.4; cursor:not-allowed; }

/* Mini totals + field labels */
.mini-label { font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--fg-faint); font-weight:600; }
.mini-value { font-family:var(--font-display); font-size:22px; }
.big-field-label { font-size:11px; letter-spacing:0.16em; text-transform:uppercase; color:var(--fg-faint); font-weight:600; margin-bottom:8px; }
.big-field-hint { font-size:11px; color:var(--fg-faint); margin-top:6px; font-style:italic; }

/* ── Round detail ─────────────────────────────────── */
.detail-hero-grid { display:grid; grid-template-columns:auto 1fr; gap:0; align-items:center; }
.detail-hero-score { padding-right:32px; margin-right:32px; border-right:1px solid var(--border); }
.detail-stat-row { display:grid; grid-template-columns:repeat(5,1fr); }
.detail-stat { padding:4px 20px; border-right:1px solid var(--border); }
.detail-stat:last-child { border-right:none; }
.detail-stat-label { font-size:10px; letter-spacing:0.14em; text-transform:uppercase; color:var(--fg-faint); font-weight:600; }
.detail-stat-value { font-family:var(--font-display); font-size:24px; margin-top:4px; }
.detail-stat-sub { font-size:11px; color:var(--fg-muted); }
.legend-dot { display:inline-block; width:10px; height:10px; border-radius:2px; vertical-align:middle; margin-right:5px; }

/* ── Round history ────────────────────────────────── */
.history-table { width:100%; border-collapse:collapse; font-size:13px; }
.history-table th { font-size:10px; letter-spacing:0.14em; text-transform:uppercase; font-weight:600; color:var(--fg-faint); padding:14px 16px; text-align:left; background:var(--cream-100); border-bottom:1px solid var(--border); white-space:nowrap; }
.history-table td { padding:12px 16px; border-bottom:1px solid var(--border); vertical-align:middle; }
.history-table tbody tr { cursor:pointer; transition:background 0.1s; }
.history-table tbody tr:hover td { background:var(--cream-50); }
.history-table tbody tr:last-child td { border-bottom:none; }
.history-table .trend-cell { padding:8px 16px; width:120px; }
.small-num-label { font-size:10px; letter-spacing:0.14em; text-transform:uppercase; color:var(--fg-faint); margin-bottom:4px; }

/* ── Responsive ───────────────────────────────────── */

/* Table horizontal scroll wrapper */
.table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }

/* Mobile header — hidden on desktop */
.mobile-header {
  display: none;
  align-items: center;
  justify-content: space-between;
  padding: 0 16px;
  height: 52px;
  background: var(--green-700);
  color: var(--cream-100);
  position: sticky;
  top: 0;
  z-index: 90;
  border-bottom: 1px solid var(--green-900);
  flex-shrink: 0;
}
.mobile-header .crest { width: 24px; height: 24px; color: var(--brass-300); }
.mobile-header .wordmark { font-family: var(--font-display); font-size: 16px; color: var(--cream-100); letter-spacing: -0.01em; }
.mobile-brand { display: flex; align-items: center; gap: 8px; }

/* Hamburger button */
.hamburger {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  padding: 8px;
  border-radius: var(--radius);
}
.hamburger span {
  display: block;
  height: 1.5px;
  background: var(--cream-100);
  border-radius: 2px;
  transition: opacity 0.15s;
}
.hamburger:hover span { opacity: 0.7; }

/* Nav overlay */
.nav-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  z-index: 98;
  opacity: 0;
  transition: opacity 0.25s;
  pointer-events: none;
}
.nav-overlay.open { opacity: 1; pointer-events: auto; }

@media (max-width: 960px) {
  /* Switch to single-column layout */
  .app {
    grid-template-columns: 1fr;
  }

  /* Show mobile header */
  .mobile-header {
    display: flex;
  }

  /* Sidebar becomes a slide-in drawer */
  .sidebar {
    position: fixed;
    top: 0;
    left: 0;
    height: 100svh;
    width: 260px;
    z-index: 100;
    transform: translateX(-100%);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
    box-shadow: none;
  }
  .sidebar.open {
    transform: translateX(0);
    box-shadow: 6px 0 32px rgba(0, 0, 0, 0.2);
  }

  /* Show overlay when nav is open */
  .nav-overlay { display: block; }

  /* Tighter content padding */
  .content { padding: 20px 16px 60px; }
  .topbar  { padding: 10px 16px; top: 52px; }
  .topbar-season { display: none; }

  /* Page headers stack vertically */
  .page-header { flex-direction: column; align-items: flex-start; gap: 12px; }
  .page-header > div:last-child { align-self: flex-start; }

  /* Grids collapse to fewer columns */
  .grid-2 { grid-template-columns: 1fr !important; }
  .grid-3 { grid-template-columns: 1fr 1fr !important; }
  .stat-grid { grid-template-columns: repeat(2, 1fr) !important; }

  /* Round detail hero */
  .detail-hero-grid { grid-template-columns: 1fr; }
  .detail-hero-score { border-right:none; border-bottom:1px solid var(--border); padding-right:0; margin-right:0; padding-bottom:20px; margin-bottom:20px; }
  .detail-stat-row { grid-template-columns: repeat(3, 1fr); }
  .detail-stat { padding: 8px 12px; }
}

@media (max-width: 480px) {
  .grid-3 { grid-template-columns: 1fr !important; }
  .stat-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .content { padding: 16px 12px 60px; }
}

/* ── Hole editor grid ─────────────────────────────── */
.hole-editor-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
@media (max-width: 720px) {
  .hole-editor-grid { grid-template-columns: 1fr; gap: 20px; }
}

/* ── Login responsive ─────────────────────────────── */

@media (max-width: 640px) {
  .login-shell {
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr;
    min-height: 100vh;
  }

  /* Compact green header instead of half-screen art panel */
  .login-art {
    padding: 24px 28px;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
  }
  .login-art .crest-bg { display: none; }
  /* Hide the tagline on mobile, keep brand + subtitle only */
  .login-art > div:last-child { display: none; }

  .login-form-wrap {
    padding: 32px 24px;
    align-items: stretch;
  }
  .login-form {
    max-width: 100%;
  }
}

/* ── Loaders ── */

/* PuttLoader */
.putt-loader { display: inline-flex; flex-direction: column; align-items: center; gap: 14px; color: var(--ink-900); }
.putt-loader svg { display: block; overflow: visible; }

.pl-green       { fill: var(--green-700); }
.pl-green-light { fill: var(--green-300); opacity: 0.55; }
.pl-hole        { fill: #0d1612; }
.pl-hole-rim    { fill: none; stroke: var(--green-800); stroke-width: 1; }
.pl-pole        { fill: var(--ink-300); }
.pl-flagstick   { transform-origin: 218px 86px; }
.pl-flag {
  fill: var(--brass-600);
  transform-origin: 218px 28px;
  animation: pl-flag-wave 1.6s ease-in-out infinite;
}
@keyframes pl-flag-wave {
  0%, 100% { transform: skewY(-2deg) scaleX(1); }
  50%      { transform: skewY(2deg)  scaleX(0.94); }
}

.pl-ball-group { animation: pl-ball-roll 2.6s cubic-bezier(.55,.05,.7,.45) infinite; }
.pl-ball       { fill: var(--cream-50); stroke: var(--ink-300); stroke-width: 0.6; }
.pl-ball-shine { fill: rgba(255,255,255,0.85); }
.pl-ball-shadow { fill: rgba(0,0,0,0.22); animation: pl-shadow 2.6s cubic-bezier(.55,.05,.7,.45) infinite; }

@keyframes pl-ball-roll {
  0%            { transform: translate(54px, 86px) scale(1); }
  4%            { transform: translate(54px, 78px) scale(1); }
  10%           { transform: translate(70px, 86px) scale(1); }
  78%           { transform: translate(214px, 86px) scale(1); }
  86%           { transform: translate(218px, 87px) scale(0.65); }
  92%           { transform: translate(218px, 92px) scale(0.2); opacity: 0.3; }
  93%           { opacity: 0; transform: translate(218px, 92px) scale(0); }
  94%, 100%     { opacity: 0; transform: translate(54px, 86px) scale(0); }
}
@keyframes pl-shadow {
  0%        { transform: translate(54px, 92px) scale(1); opacity: 0.6; }
  10%       { transform: translate(70px, 92px) scale(1); opacity: 0.6; }
  78%       { transform: translate(214px, 92px) scale(1); opacity: 0.6; }
  86%       { transform: translate(218px, 92px) scale(0.4); opacity: 0.2; }
  92%, 100% { opacity: 0; transform: translate(218px, 92px) scale(0); }
}

.pl-crow-fill { fill: var(--ink-900); }
.pl-crow-beak { fill: var(--brass-600); }
.pl-crow-eye  { fill: var(--cream-50); }
.pl-crow-wing { fill: #2c302a; }
.pl-mound     { fill: var(--green-300); opacity: 0.55; }
.pl-crow-body {
  transform-origin: 0 0;
  animation: pl-crow-tilt 2.6s ease-in-out infinite;
}
@keyframes pl-crow-tilt {
  0%, 70%   { transform: rotate(0deg); }
  82%       { transform: rotate(-12deg) translateY(-1px); }
  92%, 100% { transform: rotate(0deg); }
}

.pl-text  { text-align: center; }
.pl-label {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 500;
  color: var(--ink-900);
  display: inline-flex;
  align-items: baseline;
}
.pl-sub   { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-faint); margin-top: 4px; }
.pl-dots  { display: inline-flex; margin-left: 4px; gap: 2px; }
.pl-dots span {
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--brass-600);
  animation: pl-dot 1.2s ease-in-out infinite;
}
.pl-dots span:nth-child(2) { animation-delay: 0.15s; }
.pl-dots span:nth-child(3) { animation-delay: 0.3s; }
@keyframes pl-dot {
  0%, 80%, 100% { opacity: 0.2; transform: translateY(0); }
  40%           { opacity: 1;   transform: translateY(-2px); }
}

/* CrestSpinner */
.crest-spinner { display: inline-grid; place-items: center; color: var(--green-700); }
.cs-ring {
  fill: none;
  stroke: var(--brass-600);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-dasharray: 30 200;
  transform-origin: 50% 50%;
  animation: cs-spin 1.4s linear infinite;
}
@keyframes cs-spin { to { transform: rotate(360deg); } }
.cs-bob { transform-origin: 32px 32px; animation: cs-bob 1.2s ease-in-out infinite; }
@keyframes cs-bob {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-2px); }
}

/* InlineSpinner */
.inline-spinner { display: inline-grid; place-items: center; color: currentColor; }
.inline-spinner svg { animation: cs-spin 0.9s linear infinite; }

/* PageLoader */
.page-loader {
  position: fixed;
  inset: 0;
  background: var(--cream-100);
  z-index: 9999;
  display: grid;
  place-items: center;
  animation: pl-fade-in 0.25s ease-out both;
}
.page-loader.fading { animation: pl-fade-out 0.4s ease-in both; pointer-events: none; }
@keyframes pl-fade-in  { from { opacity: 0; } to { opacity: 1; } }
@keyframes pl-fade-out { to   { opacity: 0; } }

.page-loader-inner   { display: flex; flex-direction: column; align-items: center; gap: 28px; }
.page-loader-brand   { display: inline-flex; align-items: center; gap: 12px; color: var(--green-800); }
.page-loader-wordmark {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 500;
  letter-spacing: -0.01em;
}

/* Card-level loader */
.card-loading-overlay {
  position: absolute;
  inset: 0;
  background: rgba(246, 241, 230, 0.7);
  backdrop-filter: blur(2px);
  display: grid;
  place-items: center;
  border-radius: var(--radius);
}

/* Page-level loading state */
.loading-center { display: flex; justify-content: center; padding-top: 60px; }

/* ── Account / Settings ─────────────────────────────── */

/* Sidebar footer — now a button that opens the action menu */
.sidebar-footer-wrap { margin-top: auto; position: relative; }

.sidebar-footer {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 6px;
  border-top: 1px solid rgba(255,255,255,0.08);
  font-size: 12px;
  color: rgba(255,255,255,0.7);
  background: none;
  border-left: none;
  border-right: none;
  border-bottom: none;
  cursor: pointer;
  border-radius: 6px;
  transition: background 0.15s;
  text-align: left;
}
.sidebar-footer:hover { background: rgba(255,255,255,0.06); }

/* Action menu popover */
.sidebar-menu {
  position: absolute;
  bottom: calc(100% + 8px);
  left: 0;
  width: 252px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 8px 32px rgba(0,0,0,0.14);
  z-index: 300;
  overflow: hidden;
}
.sidebar-menu-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px;
}
.sidebar-menu-avatar { width: 40px !important; height: 40px !important; font-size: 15px !important; }
.sidebar-menu-name { font-size: 14px; font-weight: 600; color: var(--ink-900); line-height: 1.2; }
.sidebar-menu-sub  { font-size: 12px; color: var(--fg-muted); margin-top: 2px; }
.sidebar-menu-divider { height: 1px; background: var(--border); }
.sidebar-menu-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 16px;
  font-size: 13px;
  color: var(--ink-900);
  background: none;
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.1s;
  font-family: var(--font-body);
}
.sidebar-menu-item:hover { background: var(--cream-200); }
.sidebar-menu-item svg { width: 15px; height: 15px; color: var(--fg-muted); flex-shrink: 0; }
.sidebar-menu-item-danger { color: var(--bad); }
.sidebar-menu-item-danger svg { color: var(--bad); }
.sidebar-menu-item-danger:hover { background: rgba(168,58,58,0.06); }

.account-content { max-width: 720px; padding-bottom: 60px; }

.account-signout-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}

.field-static { font-size: 14px; color: var(--fg-muted); margin: 0; padding: 2px 0; }
.settings-row-label { font-size: 13px; font-weight: 500; color: var(--ink-900); }
.settings-row-sub   { font-size: 12px; color: var(--fg-muted); margin-top: 2px; }

.form-error   { font-size: 12px; color: var(--bad);   margin: 0 0 12px; }
.form-success { font-size: 12px; color: var(--green-700); margin: 0 0 12px; }

/* ─── Stats page ──────────────────────────────────────────────────────────── */
.stats-content .page-header { display: flex; align-items: flex-start; justify-content: space-between; flex-wrap: wrap; gap: 12px; margin-bottom: 24px; }

.stats-donuts-card { margin-bottom: 20px; }
.stats-donuts-card .stats-donuts { display: flex; flex-wrap: wrap; gap: 24px; justify-content: space-around; padding: 8px 0; }

/* StatDonut wrapper */
.stat-donut-wrap { display: flex; flex-direction: column; align-items: center; gap: 4px; }
.stat-donut-label { font-size: 12px; font-weight: 600; color: var(--ink-900); letter-spacing: .3px; }
.stat-donut-delta { font-size: 11px; font-weight: 500; }
.stat-donut-delta.good    { color: var(--green-700); }
.stat-donut-delta.bad     { color: var(--bad); }
.stat-donut-delta.neutral { color: var(--fg-faint); }

/* Chart legend */
.chart-legend { display: flex; gap: 16px; font-size: 11px; color: var(--fg-muted); margin-top: 8px; flex-wrap: wrap; }
.legend-line   { display: inline-block; width: 20px; height: 2px; vertical-align: middle; margin-right: 4px; }
.legend-swatch { display: inline-block; width: 10px; height: 10px; border-radius: 2px; vertical-align: middle; margin-right: 4px; }

/* Score distribution */
.score-dist { display: flex; flex-direction: column; gap: 8px; }
.score-dist-row { display: flex; justify-content: space-between; font-size: 12px; margin-bottom: 2px; }
.score-dist-label { color: var(--fg-muted); }
.bar { height: 6px; background: var(--cream-200); border-radius: 3px; overflow: hidden; }
.bar span { display: block; height: 100%; border-radius: 3px; transition: width .3s; }

/* Wasted shots section */
.stats-waste-grid { display: grid; grid-template-columns: 1fr 200px; gap: 24px; align-items: start; }
.stats-waste-summary { display: flex; flex-direction: column; gap: 12px; padding-top: 4px; }
.stat-eyebrow { font-size: 11px; font-weight: 600; letter-spacing: .5px; text-transform: uppercase; color: var(--fg-faint); margin-bottom: 2px; }
.stat-hero    { font-size: 32px; font-weight: 700; font-family: var(--font-display); line-height: 1; }
.stats-insight { font-size: 12px; color: var(--fg-muted); line-height: 1.5; }

/* Putting sub-stats */
.stats-sub-row { display: flex; gap: 0; margin-top: 12px; border-top: 1px solid var(--border); padding-top: 12px; }
.sub-stat { flex: 1; text-align: center; }
.sub-stat + .sub-stat { border-left: 1px solid var(--border); }
.sub-stat-label { font-size: 11px; color: var(--fg-faint); margin-bottom: 2px; }
.sub-stat-value { font-size: 18px; font-weight: 700; font-family: var(--font-display); color: var(--ink-900); }

/* Par breakdown */
.par-breakdown { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.par-col { border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; }
.par-col-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .8px; color: var(--fg-faint); margin-bottom: 8px; }
.par-col-score { display: flex; align-items: baseline; gap: 8px; margin-bottom: 8px; }
.par-hero { font-size: 28px; font-weight: 700; font-family: var(--font-display); color: var(--ink-900); }
.par-vs-par { font-size: 12px; color: var(--fg-muted); }
.par-col-stats, .par-col-waste { display: flex; flex-direction: column; gap: 3px; font-size: 12px; color: var(--fg-muted); }
.par-col-waste { margin-top: 8px; padding-top: 8px; border-top: 1px solid var(--border); }

/* Empty state */
.stats-empty { padding: 40px 0; text-align: center; font-size: 13px; color: var(--fg-faint); }

/* input-sm */
.input-sm { padding: 4px 8px; font-size: 12px; height: auto; }

/* Responsive */
@media (max-width: 700px) {
    .stats-waste-grid { grid-template-columns: 1fr; }
    .par-breakdown    { grid-template-columns: 1fr; }
    .stats-donuts .stat-donut-wrap { min-width: 80px; }
}

/* ─── Dashboard ───────────────────────────────────────────────────────────── */

/* Headline stat grid */
.stat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 20px; background: transparent; }
.stat { background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; }
.stat .label { font-size: 11px; font-weight: 600; letter-spacing: .4px; text-transform: uppercase; color: var(--fg-faint); margin-bottom: 8px; }
.stat .value { font-family: var(--font-display); font-size: 26px; line-height: 1; color: var(--ink-900); }
.stat-value-row { display: flex; align-items: flex-end; justify-content: space-between; gap: 8px; margin-bottom: 6px; }
.stat .delta { font-size: 11px; font-weight: 500; }
.stat .delta.up      { color: var(--green-700); }
.stat .delta.down    { color: var(--bad); }
.stat .delta.neutral { color: var(--fg-faint); }

/* Main grid tweak — last round card doesn't need equal height forcing on mobile */
.dash-main-grid { margin-bottom: 20px; }

/* Last round card */
.dash-last-round { display: flex; flex-direction: column; gap: 0; }
.dash-hero-score { font-family: var(--font-display); font-size: 52px; line-height: 1; color: var(--green-700); margin-bottom: 4px; }
.dash-hero-meta { font-size: 12px; color: var(--fg-muted); margin-bottom: 16px; }
.dash-kv-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 16px; }
.dash-kv-row { display: flex; justify-content: space-between; font-size: 12px; margin-bottom: 4px; }
.dash-kv-label { font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--fg-faint); font-weight: 600; }
.dash-detail-link { align-self: flex-start; font-size: 12px; margin-top: auto; padding-top: 4px; }
.dash-no-rounds { justify-content: center; align-items: center; min-height: 200px; }

/* bar (shared with stats page, but ensure brass variant exists) */
.bar.brass span { background: var(--brass-600); }

/* Training suggestion */
.dash-training { display: flex; align-items: flex-start; gap: 16px; margin-bottom: 20px; }
.dash-training-icon { font-size: 22px; color: var(--brass-600); line-height: 1; padding-top: 2px; min-width: 24px; text-align: center; }
.dash-training-body { flex: 1; }
.dash-training-label { font-size: 13px; font-weight: 500; color: var(--ink-900); margin-bottom: 4px; }
.dash-training-detail { font-size: 13px; color: var(--fg-muted); line-height: 1.5; }

/* Recent rounds table */
.table-wrap { overflow-x: auto; }
.rounds-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.rounds-table th { text-align: left; padding: 10px 8px; font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--fg-faint); font-weight: 600; border-bottom: 1px solid var(--border); }
.rounds-table td { padding: 12px 8px; border-bottom: 1px solid var(--border); color: var(--ink-700); }
.rounds-table tr:last-child td { border-bottom: none; }
.rounds-table tr:hover td { background: var(--cream-50); }
.rounds-table .num { text-align: right; }
.rounds-table .bold { font-weight: 600; color: var(--ink-900); }
.rounds-table .good { color: var(--good); font-weight: 600; }
.rounds-table .bad  { color: var(--bad);  font-weight: 600; }
.rounds-table .course-cell { color: var(--ink-900); }

/* Responsive */
@media (max-width: 600px) {
    .stat-grid { grid-template-columns: repeat(2, 1fr); }
    .dash-hero-score { font-size: 40px; }
    .dash-kv-grid { grid-template-columns: 1fr; }
}

.score-avg-vp { font-size: 11px; color: var(--fg-faint); margin-top: 2px; }
.score-avg-vp.vp-good { color: var(--good); }

.stat-donut-note { font-size: 10px; color: var(--fg-faint); margin-top: 1px; }
