:root {
  font-family: 'Geist', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  /* Design tokens (light mode) */
  --tt-container-bg: oklch(96.7% 0.003 264.542);
  --tt-card-bg: #ffffff;
  --tt-card-border: #e5e5e5;
  --tt-divider: #e5e7eb;
  --tt-shadow-sm: 0px 1px 2px rgba(0, 0, 0, 0.05);

  --tt-text: #171717;
  --tt-text-muted: #525252;
  --tt-icon-muted: #a3a3a3;
  --tt-accent: #f59e0b;

  --tt-primary: #119f14;
  --tt-primary-hover: #0f8f12;

  --tt-danger: #dc2626;
  --tt-danger-hover: #b91c1c;

  --tt-card-radius: 3px;

  --tt-nav-bg: #ffffff;
  --tt-nav-border: #e5e5e5;
  --tt-nav-control-bg: #ffffff;
  --tt-nav-control-border: #e5e5e5;
  --tt-nav-control-hover-bg: rgba(15, 23, 42, 0.03);

  --tt-footer-border: #e5e5e5;
  --tt-footer-text: #525252;
}

body,
h1, h2, h3, h4, h5, h6,
p, a, button, input, select, textarea {
  font-family: 'Geist', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
  font-weight: 400 !important;
}

body {
  color: var(--tt-text) !important;
}

html:not(.dark) #main > .inner {
  background-color: var(--tt-container-bg) !important;
}

/* Let Tailwind control most colors; only set sensible defaults via tokens. */

nav a,
.header-link {
  color: #0f172a !important;
  border-bottom-color: transparent !important;
}

nav a:hover,
.header-link:hover {
  color: rgba(0, 0, 0, 0.95) !important;
}

/* Neutralize legacy global link styling for unstyled content links only.
   (If an <a> has any class, Tailwind/component classes should win.) */
#main a:not([class]) {
  color: inherit;
  border-bottom: none;
}

#main a:not([class]):hover {
  color: rgba(0, 0, 0, 0.85);
}

html.dark #main a:not([class]):hover {
  color: rgba(248, 250, 252, 0.92);
}

html:not(.dark) input::placeholder,
html:not(.dark) textarea::placeholder {
  color: #334155 !important;
}

html:not(.dark) .dark\:bg-slate-900,
html:not(.dark) .dark\:bg-slate-800 {
  background-color: #ffffff !important;
}

.btn-google {
  background-color: #ffffff !important;
  color: #1f2937 !important;
  border: 1px solid rgba(148, 163, 184, 0.6) !important;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08) !important;
  transition: background-color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

.btn-google:hover {
  background-color: #f8fafc !important;
  border-color: rgba(148, 163, 184, 0.8) !important;
  box-shadow: 0 2px 6px rgba(15, 23, 42, 0.12) !important;
}

.divider-text {
  color: rgba(0, 0, 0, 0.55) !important;
  background-color: #ffffff !important;
}

.login-card,
.signup-card {
  background-color: #ffffff !important;
}

input, select, textarea {
  border-radius: 0.625rem !important;
  border-width: 1px !important;
  border-color: rgba(148, 163, 184, 0.5) !important;
}

#main > .inner {
  max-width: 1200px !important;
  padding: 0 1.25rem 2rem 1.25rem !important;
}

html.dark body { background-color: #0f172a !important; color: #f8fafc !important; }
html.dark #main { background-color: #0f172a !important; }
html.dark #main > .inner { background-color: transparent !important; }
html.dark .bg-white { background-color: #0b1220 !important; }
html.dark nav,
html.dark nav.bg-white {
  background-color: #0f172a !important;
  border-color: #1f2937 !important;
}

html.dark #footer,
html.dark #footer a,
html.dark #footer .copyright,
html.dark #footer span {
  color: #ffffff !important;
}
html.dark .text-slate-900 { color: #f8fafc !important; }
html.dark .text-slate-700 { color: #e2e8f0 !important; }
html.dark .text-slate-600 { color: #cbd5f5 !important; }
html.dark .text-slate-500 { color: #94a3b8 !important; }
html.dark .border-slate-200 { border-color: #1f2937 !important; }
html.dark nav a,
html.dark nav .header-link,
html.dark nav #theme-toggle {
  color: #f8fafc !important;
  border-color: #334155 !important;
}

html.dark input,
html.dark select,
html.dark textarea {
  background-color: #0b1220 !important;
  color: #f8fafc !important;
  border-color: rgba(148, 163, 184, 0.4) !important;
}
html.dark input::placeholder,
html.dark textarea::placeholder {
  color: #94a3b8 !important;
}
/* Don't globally restyle all buttons; let Tailwind utilities control them. */

html.dark .login-card,
html.dark .signup-card {
  background-color: #0b1220 !important;
}
html.dark .btn-google {
  background-color: #1f2937 !important;
  color: #f8fafc !important;
  border-color: #334155 !important;
  box-shadow: 0 1px 2px rgba(2, 6, 23, 0.4) !important;
}
html.dark .btn-google:hover {
  background-color: #273244 !important;
  border-color: #475569 !important;
  box-shadow: 0 2px 6px rgba(2, 6, 23, 0.5) !important;
}
html.dark .divider-text {
  background-color: #0b1220 !important;
  color: #94a3b8 !important;
}

/* Design tokens (dark mode) */
html.dark {
  --tt-card-bg: #0b1220;
  --tt-card-border: #1f2937;
  --tt-divider: #1f2937;
  --tt-text: #f8fafc;
  --tt-text-muted: #cbd5e1;
  --tt-icon-muted: #94a3b8;

  --tt-nav-bg: #0f172a;
  --tt-nav-border: #1f2937;
  --tt-nav-control-bg: #0b1220;
  --tt-nav-control-border: #334155;
  --tt-nav-control-hover-bg: rgba(148, 163, 184, 0.06);

  --tt-footer-border: #1f2937;
  --tt-footer-text: #cbd5e1;
}

/* Base layout: nav + footer should be token-driven */
#main nav {
  background: var(--tt-nav-bg) !important;
  border-color: var(--tt-nav-border) !important;
  margin-left: -1.25rem !important;
  margin-right: -1.25rem !important;
  padding-left: calc(1.25rem + 1rem) !important;
  padding-right: calc(1.25rem + 1rem) !important;
}

#main nav a,
#main nav .header-link {
  color: var(--tt-text) !important;
  border-bottom-color: transparent !important;
}

#main nav a:hover,
#main nav .header-link:hover {
  color: var(--tt-text) !important;
  opacity: 0.92;
}

#theme-toggle {
  background: var(--tt-nav-control-bg) !important;
  border-color: var(--tt-nav-control-border) !important;
  color: var(--tt-text) !important;
}

#theme-toggle:hover {
  background: var(--tt-nav-control-hover-bg) !important;
}

#footer {
  border-color: var(--tt-footer-border) !important;
  color: var(--tt-footer-text) !important;
}

#footer a,
#footer span {
  color: var(--tt-footer-text) !important;
}

#footer a:hover {
  color: var(--tt-text) !important;
}

/* Reusable components */
.tt-card {
  background: var(--tt-card-bg) !important;
  border: 1px solid var(--tt-card-border) !important;
  border-radius: var(--tt-card-radius) !important;
  box-shadow: var(--tt-shadow-sm) !important;
}

.tt-divider {
  height: 1px !important;
  width: 100% !important;
  background: var(--tt-divider) !important;
}

.tt-text-muted { color: var(--tt-text-muted) !important; }
.tt-icon-muted { color: var(--tt-icon-muted) !important; }
.tt-accent { color: var(--tt-accent) !important; }

.tt-btn {
  height: 48px !important;
  border-radius: 12px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.5rem !important;
  padding: 0 1rem !important;
  font-size: 0.875rem !important;
  line-height: 1.25rem !important;
  box-shadow: var(--tt-shadow-sm) !important;
  text-decoration: none !important;
}

.tt-btn-secondary {
  background: #ffffff !important;
  border: 2px solid var(--tt-card-border) !important;
  color: #404040 !important;
}

html.dark .tt-btn-secondary {
  background: #0b1220 !important;
  border-color: var(--tt-card-border) !important;
  color: #e2e8f0 !important;
}

.tt-btn-secondary:hover {
  background: rgba(15, 23, 42, 0.03) !important;
}

html.dark .tt-btn-secondary:hover {
  background: rgba(148, 163, 184, 0.06) !important;
}

.tt-btn-primary {
  background: var(--tt-primary) !important;
  border: 1px solid rgba(0, 0, 0, 0) !important;
  color: #ffffff !important;
  font-weight: 600 !important;
}

.tt-btn-primary:hover {
  background: var(--tt-primary-hover) !important;
  color: #ffffff !important;
}

.tt-btn-danger {
  background: var(--tt-danger) !important;
  border: 1px solid rgba(0, 0, 0, 0) !important;
  color: #ffffff !important;
  font-weight: 700 !important;
}

.tt-btn-danger:hover {
  background: var(--tt-danger-hover) !important;
  color: #ffffff !important;
}

/* Score / table UI helpers (replaces legacy main.css bits we still rely on) */
.tt-table {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  font-size: 0.875rem !important;
  line-height: 1.25rem !important;
  color: var(--tt-text) !important;
}

.tt-table th,
.tt-table td {
  padding: 0.5rem 0.75rem !important;
  border-bottom: 1px solid var(--tt-divider) !important;
  vertical-align: middle !important;
  white-space: nowrap;
}

.tt-table th {
  font-weight: 600 !important;
  text-align: left !important;
  background: rgba(15, 23, 42, 0.03) !important;
}

html.dark .tt-table th {
  background: rgba(148, 163, 184, 0.06) !important;
}

.tt-table tr:last-child td {
  border-bottom: none !important;
}

.tt-table a {
  color: inherit;
  text-decoration: none;
}

.tt-table a:hover {
  text-decoration: underline;
}

.tt-table th.tt-sticky-solid {
  background: var(--tt-card-bg) !important;
}

html.dark .tt-table th.tt-sticky-solid {
  background: var(--tt-card-bg) !important;
}

.overflow-x-auto.tt-drag-scroll {
  cursor: grab;
}

.overflow-x-auto.tt-drag-scroll.is-dragging {
  cursor: grabbing;
}

.overflow-x-auto.tt-drag-scroll.is-dragging,
.overflow-x-auto.tt-drag-scroll.is-dragging * {
  user-select: none;
}

.tt-table.tt-table-freeze-first-only tr > *:nth-child(2) {
  position: static !important;
  left: auto !important;
  z-index: auto !important;
}

.tt-table.tt-table-freeze-first-only tr > *:first-child {
  max-width: 11rem;
  width: 11rem;
  overflow: hidden;
  text-overflow: ellipsis;
}

.tt-table.tt-table-freeze-first-only tr > *:first-child a {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tt-label {
  font-size: 0.875rem !important;
  line-height: 1.25rem !important;
  font-weight: 600 !important;
  color: var(--tt-text) !important;
}

.tt-input,
.tt-select {
  height: 48px !important;
  padding: 0 0.75rem !important;
  border-radius: 12px !important;
  background: var(--tt-card-bg) !important;
  border: 1px solid rgba(148, 163, 184, 0.55) !important;
  color: var(--tt-text) !important;
}

html.dark .tt-input,
html.dark .tt-select {
  border-color: rgba(148, 163, 184, 0.4) !important;
}

.tt-input:focus,
.tt-select:focus {
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(17, 159, 20, 0.25) !important;
  border-color: rgba(17, 159, 20, 0.65) !important;
}

.tt-textarea {
  padding: 0.75rem !important;
  border-radius: 12px !important;
  background: var(--tt-card-bg) !important;
  border: 1px solid rgba(148, 163, 184, 0.55) !important;
  color: var(--tt-text) !important;
  min-height: 120px;
}

html.dark .tt-textarea {
  border-color: rgba(148, 163, 184, 0.4) !important;
}

.tt-textarea:focus {
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(17, 159, 20, 0.25) !important;
  border-color: rgba(17, 159, 20, 0.65) !important;
}

.tt-pill {
  height: 40px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 0.875rem !important;
  border-radius: 9999px !important;
  border: 1px solid var(--tt-card-border) !important;
  background: transparent !important;
  color: var(--tt-text) !important;
  font-size: 0.875rem !important;
  line-height: 1.25rem !important;
  font-weight: 600 !important;
  text-decoration: none !important;
}

.tt-pill:hover {
  background: var(--tt-nav-control-hover-bg) !important;
}

.tt-pill-active {
  border-color: var(--tt-primary) !important;
  background: rgba(17, 159, 20, 0.12) !important;
}

html.dark .tt-pill-active {
  background: rgba(17, 159, 20, 0.18) !important;
}

.tt-pill-danger {
  border-color: var(--tt-danger) !important;
  color: #ffffff !important;
  background: var(--tt-danger) !important;
}

.tt-pill-danger:hover {
  background: var(--tt-danger-hover) !important;
}

/* Minimal-form upgrade helper: opt-in only (add class="tt-form" on a form) */
.tt-form label {
  display: block;
  margin: 0.75rem 0 0.25rem 0;
  font-size: 0.875rem;
  line-height: 1.25rem;
  font-weight: 600;
  color: var(--tt-text);
}

.tt-form input[type="text"],
.tt-form input[type="number"],
.tt-form input[type="date"],
.tt-form input[type="email"],
.tt-form input[type="password"],
.tt-form select {
  height: 48px;
  width: 100%;
  max-width: 42rem;
  padding: 0 0.75rem;
  border-radius: 12px;
  background: var(--tt-card-bg);
  border: 1px solid rgba(148, 163, 184, 0.55);
  color: var(--tt-text);
}

.tt-form textarea {
  width: 100%;
  max-width: 42rem;
  padding: 0.75rem;
  border-radius: 12px;
  background: var(--tt-card-bg);
  border: 1px solid rgba(148, 163, 184, 0.55);
  color: var(--tt-text);
  min-height: 120px;
}

.tt-form input:focus,
.tt-form select:focus,
.tt-form textarea:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(17, 159, 20, 0.25);
  border-color: rgba(17, 159, 20, 0.65);
}

html.dark .tt-form input[type="text"],
html.dark .tt-form input[type="number"],
html.dark .tt-form input[type="date"],
html.dark .tt-form input[type="email"],
html.dark .tt-form input[type="password"],
html.dark .tt-form select,
html.dark .tt-form textarea {
  border-color: rgba(148, 163, 184, 0.4);
}

.message,
.message_error {
  width: 100% !important;
  border-radius: 12px !important;
  padding: 0.75rem 1rem !important;
  margin: 0 0 0.75rem 0 !important;
  font-weight: 600 !important;
}

.message {
  border: 1px solid rgba(5, 164, 92, 0.5) !important;
  background: rgba(5, 164, 92, 0.12) !important;
  color: var(--tt-text) !important;
}

html.dark .message {
  background: rgba(5, 164, 92, 0.18) !important;
  color: var(--tt-text) !important;
}

.message_error {
  border: 1px solid rgba(122, 1, 5, 0.5) !important;
  background: rgba(122, 1, 5, 0.12) !important;
  color: var(--tt-text) !important;
}

html.dark .message_error {
  background: rgba(122, 1, 5, 0.18) !important;
}

.small-text {
  font-size: 0.75rem !important;
  line-height: 1rem !important;
  color: var(--tt-text-muted) !important;
  vertical-align: text-top;
}

.score_small {
  width: 5.5rem;
  height: 40px;
  padding: 0 0.5rem;
  text-align: center;
  border-radius: 12px;
}

/* Scores page: stretch all cards to 5px from the viewport edge (matches score table card) */
.scores-section .tt-card {
  margin-left: -15px !important;
  margin-right: -15px !important;
}

/* Score display table: fixed layout gives equal width to all data columns (holes + Scr + Pts) */
.score-display-table {
  table-layout: fixed;
}

.score-display-table th,
.score-display-table td {
  padding: 0.2rem 0.25rem !important;
  text-align: center !important;
}

.score-display-table th {
  padding-top: 0.5rem !important;
  padding-bottom: 0.5rem !important;
}

/* Mobile: narrow player name so 11 data columns share remaining space equally on 375px */
.score-display-table tr > *:first-child {
  width: 5rem !important;
  max-width: 5rem !important;
  white-space: normal !important;
  word-break: break-word !important;
  text-align: left !important;
}

/* Larger screens: show more of the player name */
@media (min-width: 640px) {
  .score-display-table tr > *:first-child {
    width: 8rem !important;
    max-width: 8rem !important;
  }
}

/* Smaller badge in display tables (entry table keeps the larger 1.75rem) */
.score-display-table td .score-num {
  width: 1.1rem;
  height: 1.1rem;
  font-size: 0.7rem;
}

/* 2px breathing room between score badge and stableford number below it; match cell text colour */
.score-display-table td .small-text {
  display: inline-block;
  margin-top: 2px;
  color: inherit !important;
}

/* Score entry table: all 5 columns fit within 375px mobile without horizontal scroll */
.score-entry-table {
  table-layout: fixed;
}

.score-entry-table th,
.score-entry-table td {
  padding: 0.4rem 0.4rem !important;
  text-align: center !important;
}

.score-entry-table .score_small {
  width: 3.5rem !important;
  min-width: 0 !important;
}

/* Remove the global grey cell border from score class cells in both entry and display tables */
.score-entry-table td.albatross,
.score-entry-table td.eagle,
.score-entry-table td.birdie,
.score-entry-table td.par,
.score-entry-table td.bogey,
.score-entry-table td.double-bogey,
.score-entry-table td.worse-than-double-bogey,
.score-display-table td.albatross,
.score-display-table td.eagle,
.score-display-table td.birdie,
.score-display-table td.par,
.score-display-table td.bogey,
.score-display-table td.double-bogey,
.score-display-table td.worse-than-double-bogey {
  border: none !important;
  border-bottom: 1px solid var(--tt-divider) !important;
}

/* Score badge: number inside a circle (under par) or square (over par) */
td .score-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  font-weight: 700;
  font-size: 0.875rem;
  line-height: 1;
}

/* Birdie: single circle */
td.birdie .score-num {
  border-radius: 50%;
  border: 1px solid currentColor;
}

/* Eagle / albatross: double circle */
td.eagle .score-num,
td.albatross .score-num {
  border-radius: 50%;
  border: 1px solid currentColor;
  outline: 1px solid currentColor;
  outline-offset: 2px;
}

/* Bogey: single square */
td.bogey .score-num {
  border: 1px solid currentColor;
}

/* Double bogey / worse: double square */
td.double-bogey .score-num,
td.worse-than-double-bogey .score-num {
  border: 1px solid currentColor;
  outline: 1px solid currentColor;
  outline-offset: 2px;
}

.albatross,
.eagle,
.birdie,
.par,
.bogey,
.double-bogey,
.worse-than-double-bogey {
  border: 1px solid rgba(0, 0, 0, 0.22) !important;
  font-weight: 700 !important;
  text-align: center;
}

.albatross { background-color: #66ff66 !important; color: #0b1220 !important; }
.eagle { background-color: #ffff00 !important; color: #0b1220 !important; }
.birdie { background-color: #6699ff !important; color: #ffffff !important; }
.par { background-color: transparent !important; color: var(--tt-text) !important; }
.bogey { background-color: #000000 !important; color: #ffffff !important; }
.double-bogey { background-color: #ff3333 !important; color: #ffffff !important; }
.worse-than-double-bogey { background-color: #9966cc !important; color: #ffffff !important; }

a.disabled {
  opacity: 0.45;
  pointer-events: none;
  cursor: default;
  text-decoration: none !important;
}
