:root{
	--bg:#fbfaf8;
	--card:#ffffff;
	--muted:#6b6b6b;
	--accent:#0b6d44; /* green */
	--accent-strong:#05512f;
	--accent-soft:#e6f4ef;
	--danger:#e06;
	--nav-bg:#063b23;
	--nav-text:#ffffff;
	--touch-size:48px;
}

/* Typography inspired by golf club sites: clear headings, roomy body */
body{font-family: 'Source Sans Pro', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial; margin:0;background:var(--bg);color:#111}
main{margin:12px auto;background:var(--card);padding:16px;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,0.06);max-width:min(980px, calc(100vw - 24px));overflow:hidden}
header,h1,h2,h3{font-family:'Montserrat', 'Segoe UI', sans-serif;margin:0 0 8px 0}
section{margin-bottom:14px}
input,select,button{margin-right:8px;font-size:14px}
table{width:100%;border-collapse:collapse;max-width:100%}
td,th{padding:8px;border-bottom:1px solid #eee;text-align:left}
a{color:var(--accent);text-decoration:underline}
a:hover{text-decoration:none}
a:visited{color:var(--accent-strong);text-decoration:underline}

/* Horizontal overflow helpers (prefer wrapping tables instead of main) */
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.table-scroll > table{width:max(100%, 400px)}

/* Navigation */
.topnav{display:flex;flex-wrap:wrap;gap:4px;padding:0 4px 0 0;background:var(--nav-bg);color:var(--nav-text);border-radius:0;margin-bottom:12px;align-items:center;max-width:100%;overflow:visible;min-height:56px}
.topnav a{color:var(--nav-text);text-decoration:none;padding:8px 6px;border-radius:6px;background:transparent;font-weight:500;font-family:inherit;font-size:14px;line-height:1.2}
.topnav a:hover{background:rgba(255,255,255,0.06)}
.topnav a.active{background:rgba(255,255,255,0.15);font-weight:700;border-bottom:3px solid var(--accent-soft)}
.topnav > a{display:flex;align-items:center}
.topnav a.nav-logo-link{padding:0 4px 0 2px;display:flex;align-items:center;height:56px}
.topnav a.nav-logo-link:hover{background:rgba(255,255,255,0.06)}
.nav-logo{height:100%;width:auto;display:block;object-fit:contain}
#league-nav-slot{display:flex;align-items:center}
.nav-dropdown{display:flex;align-items:center}
.nav-role{display:inline-block;padding:3px 10px;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-size:12px;font-weight:700;line-height:1.2;white-space:nowrap}

/* Dropdown menu */
.nav-dropdown{position:relative}
.nav-dropdown-btn{color:var(--nav-text);background:transparent;border:none;padding:8px 6px;border-radius:6px;cursor:pointer;font-weight:500;display:flex;align-items:center;gap:4px;font-family:inherit;font-size:14px;line-height:1.2}
.nav-dropdown-btn:hover{background:rgba(255,255,255,0.06)}
.nav-dropdown-btn.active{background:rgba(255,255,255,0.15);font-weight:700}
.nav-dropdown-content{display:none;position:absolute;top:100%;left:0;background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 12px rgba(0,0,0,0.15);min-width:150px;margin-top:4px;z-index:1000}
.nav-dropdown-content a{display:block;color:#333;padding:10px 16px;text-decoration:none;font-weight:500}
.nav-dropdown-content a:hover{background:#f0f0f0}
.nav-dropdown-content a.active{background:var(--accent-soft);color:var(--accent);font-weight:700}
.nav-dropdown.open .nav-dropdown-content{display:block}

/* Mobile: keep dropdown button; show a vertical menu */
@media (max-width:640px){
  .nav-dropdown-btn{display:flex}
  .nav-dropdown-content{position:absolute;left:0;right:0;min-width:unset;width:calc(100vw - 24px);max-width:calc(100vw - 24px)}
  .nav-dropdown-content a{color:#333;background:#fff}
}

/* Modal Styles */
.modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0,0,0,0.5);
  z-index: 1000;
  align-items: center;
  justify-content: center;
}

.modal-overlay {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0,0,0,0.5);
  z-index: 1000;
  align-items: center;
  justify-content: center;
}

.modal-overlay.open {
  display: flex;
}

.modal-content {
  background: var(--card);
  padding: 20px;
  border-radius: 8px;
  max-width: 600px;
  width: 90%;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 4px 20px rgba(0,0,0,0.2);
}

/* For modals that provide their own header/body/footer regions. */
.modal-content.modal-structured {
  padding: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.modal-header {
  padding: 20px;
  border-bottom: 1px solid #eee;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.modal-body {
  padding: 20px;
  overflow-y: auto;
  flex: 1;
}

.modal-footer {
  padding: 20px;
  border-top: 1px solid #eee;
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}

.modal-close {
  background: none;
  border: none;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  color: #999;
  padding: 0;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal-close:hover {
  color: #333;
}

/* Buttons and cards */
.card{padding:10px;margin-bottom:12px;border-radius:6px;background:linear-gradient(180deg,#fff,#fafafa);border:1px solid #8ac88697}
.bigbtn{display:inline-block;background:var(--accent);color:#fff;padding:2px 12px;border-radius:6px;text-decoration:none;font: size 14px;}

/* --- Page template utilities (use for new/updated pages) --- */
.page-header{margin:0 0 16px 0}
.page-header h1{margin:0 0 6px 0}
.page-subtitle{margin:0;color:var(--muted);font-size:14px}

.section-header{display:flex;justify-content:space-between;align-items:center;gap:12px}
.section-header h3{margin:0}
.section-actions{display:flex;gap:8px;align-items:center}

/* Use flex gap for spacing inside section actions (avoid double-spacing from global button margins). */
.section-actions button{margin-right:0}


.toolbar{display:flex;gap:12px;align-items:flex-end;margin:12px 0;flex-wrap:wrap}

/* Toolbars commonly pair inputs with action buttons; keep controls visually aligned. */
.toolbar .section-actions{align-items:flex-end}

.two-column{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
@media (max-width:600px){.two-column{grid-template-columns:1fr}}

/* Some selectors (e.g., matchup lineup/side selectors) should stay two-up on small screens.
   Use with a scroll container (e.g., .table-scroll) to avoid vertical stacking. */
@media (max-width:600px){
  .two-column.keep-two{grid-template-columns:1fr 1fr;min-width:400px}
}

.panel-title{margin-top:0}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:600px){.form-grid{grid-template-columns:1fr}}

.form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px}

.muted{color:var(--muted)}
.stack > * + *{margin-top:10px}

/* Utility: prevent wrapping (dates/times, compact labels, etc.) */
.nowrap{white-space:nowrap}

/* Highlight substitute players in schedule summaries */
.sub-highlight{color:var(--accent);font-weight:700;font-style: italic;}

/* Responsive columns for "Players Available To Sub" */
.sub-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));gap:8px 16px}
.sub-grid-item{min-width:0}

.form-group.inline label{display:block;font-size:12px;color:var(--muted);margin-bottom:4px}
button{background:var(--accent);color:#fff;border:0;padding:4px 12px;border-radius:6px}
button.secondary{background:#888}

/* Inputs and touch targets */
input,select{padding:6px;border-radius:6px;border:1px solid #ddd}
input.invalid{border:2px solid var(--danger)}

.hole-row{display:flex;align-items:center;gap:10px;padding:8px 4px;border-bottom:1px solid #f0f0f0}
.hole-player{flex:1;font-weight:600}
.hole-total{width:84px;text-align:right;color:var(--muted)}
input[type=number]{width:72px;padding:6px;border-radius:6px}

.par-header{background:var(--accent-soft);font-weight:700;text-align:center}

/* Save all */
.save-all-button{margin-left:12px}

/* Accessibility */
button:focus, a:focus, input:focus{outline:3px solid rgba(10,100,60,0.15);outline-offset:2px}

/* Mobile layout */
@media (max-width:640px){
	main{padding:12px;margin:6px}
  .topnav{overflow:visible}
	.hole-row{flex-direction:row;gap:8px}
	td,th{padding:4px}
	.bigbtn{width:100%;text-align:center}
}

/* Form Styles (Restored) */
.form-group {
  margin-bottom: 16px;
}

.form-group label {
  display: block;
  margin-bottom: 6px;
  font-weight: 600;
  color: #333;
  font-size: 14px;
}

.form-group input, 
.form-group select, 
.form-group textarea {
  width: 100%;
  padding: 6px;
  border: 1px solid #ddd;
  border-radius: 6px;
  font-size: 16px;
  box-sizing: border-box; /* Critical for layout */
  transition: border-color 0.2s;
}

.form-group input:focus, 
.form-group select:focus, 
.form-group textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

/* Container */
.container {
  width: 100%;
  /* max-width is handled by main, but if container is inside main, it just fills it */
}

/* Utility */
.text-center { text-align: center; }
.mt-4 { margin-top: 16px; }
.mb-4 { margin-bottom: 16px; }

/* Tabs */
.tab-container { display: flex; border-bottom: 1px solid #ddd; margin-bottom: 16px; }
.tab { padding: 10px 20px; cursor: pointer; border-bottom: 2px solid transparent; }
.tab.active { border-bottom-color: var(--accent); color: var(--accent); font-weight: bold; }
.tab-content { display: none; }
.tab-content.active { display: block; }

/* Participant List */
.participant-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; }
.participant-card { background: #f9f9f9; padding: 10px; border-radius: 4px; border: 1px solid #eee; display: flex; justify-content: space-between; align-items: center; }

/* Standings Table */
.standings-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}

.standings-table th,
.standings-table td {
  padding: 3px 2px;
  text-align: left;
  border: 1px solid #e0e0e0;
}

.standings-table th {
  font-weight: 700;
  text-align: center;
}

.standings-table td {
  border-bottom: 1px solid #f0f0f0;
}