/* ===== Golf Bucket List — "Heritage Scorecard" theme ===== */
:root{
  --paper:#f1e8d6;
  --paper-card:#fbf7ed;
  --paper-deep:#e7dbc1;
  --ink:#23281f;
  --ink-soft:#4a4d40;
  --green:#1f5134;
  --green-deep:#143b26;
  --green-soft:#3c7c56;
  --brass:#a9793a;
  --brass-soft:#caa25c;
  --flag:#a8392c;
  --line:#d6c9ad;
  --muted:#76705c;
  --display:"Fraunces", Georgia, "Times New Roman", serif;
  --body:"Hanken Grotesk", system-ui, -apple-system, sans-serif;
  --card-shadow:0 10px 24px -18px rgba(20,40,30,.55);
}
*{box-sizing:border-box;}
body{
  margin:0; color:var(--ink); font-family:var(--body); font-size:16px;
  background-color:var(--paper);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  -webkit-text-size-adjust:100%; -webkit-tap-highlight-color:transparent;
}
h1,h2,h3{font-family:var(--display); font-weight:600;}

/* ---- Top bar ---- */
.topbar{background:var(--green-deep); color:var(--paper); padding:18px 18px 14px; border-bottom:3px solid var(--brass);}
.topbar-row{display:flex; align-items:flex-start; justify-content:space-between; gap:12px;}
.topbar h1{margin:0; font-size:1.5rem; line-height:1; font-weight:700; letter-spacing:.2px;}
.tagline{margin:6px 0 0; font-size:.68rem; text-transform:uppercase; letter-spacing:.24em; color:var(--brass-soft);}
.user{display:flex; flex-direction:column; align-items:flex-end; gap:3px; white-space:nowrap; font-size:.78rem; padding-top:3px;}
.user .who{opacity:.92;}
.user .signout{color:var(--brass-soft); text-decoration:none; border-bottom:1px solid transparent;}
.user .signout:hover{border-bottom-color:currentColor;}

/* ---- Tabs (segmented, paper pill on green) ---- */
.tabs{display:flex; gap:7px; background:var(--green-deep); padding:12px 14px;}
.tab{flex:1; padding:9px 8px; border:none; cursor:pointer; border-radius:9px;
  background:rgba(251,247,237,.10); color:var(--paper); opacity:.72;
  font-family:var(--body); font-size:.85rem; font-weight:600;
  transition:opacity .15s, background .15s, color .15s, transform .08s;}
.tab.active{background:var(--paper); color:var(--green-deep); opacity:1; box-shadow:0 2px 8px -4px rgba(0,0,0,.45);}
.tab:active{transform:translateY(1px);}

/* ---- Peer bar ---- */
.peerbar{display:flex; align-items:center; gap:12px; padding:10px 18px; background:var(--paper-deep); border-bottom:1px solid var(--line);}
.peerbar .back{border:1px solid var(--line); background:var(--paper-card); color:var(--ink); border-radius:8px; padding:6px 12px; font-size:.82rem; font-weight:600; cursor:pointer; font-family:var(--body);}
.peerbar .peername{font-size:.88rem; color:var(--muted);}
.peerbar .peername strong{font-family:var(--display); color:var(--ink);}

/* ---- Progress ("your round") ---- */
.progress{padding:14px 18px; background:var(--paper-card); border-bottom:1px solid var(--line);}
.progress-head{display:flex; justify-content:space-between; align-items:baseline; margin-bottom:8px;}
#played{font-size:.68rem; text-transform:uppercase; letter-spacing:.16em; color:var(--muted);}
.progress-head .pct{font-family:var(--display); font-weight:700; font-size:1.55rem; line-height:1; color:var(--green);}
.bar{height:9px; background:var(--paper-deep); border:1px solid var(--line); border-radius:999px; overflow:hidden;}
.barfill{height:100%; width:0%; background:linear-gradient(90deg, var(--green-soft), var(--green)); border-radius:999px; transition:width .55s cubic-bezier(.22,.61,.36,1);}

/* ---- Filters ---- */
.filters{position:sticky; top:0; z-index:5; background:var(--paper); padding:12px 18px; border-bottom:1px solid var(--line); box-shadow:0 8px 14px -14px rgba(0,0,0,.5);}
.filters #search{width:100%; padding:12px 14px; font-size:16px; font-family:var(--body); color:var(--ink); background:var(--paper-card); border:1px solid var(--line); border-radius:11px;}
.filters #search:focus{outline:none; border-color:var(--brass); box-shadow:0 0 0 3px rgba(169,121,58,.18);}
.selects{display:flex; flex-wrap:wrap; gap:8px; margin-top:9px;}
.selects select{flex:1 1 92px; min-width:92px; padding:10px 9px; font-size:16px; font-family:var(--body); color:var(--ink); background:var(--paper-card); border:1px solid var(--line); border-radius:10px;}
.selects select:focus{outline:none; border-color:var(--brass);}
.count{margin:9px 0 0; font-size:.7rem; text-transform:uppercase; letter-spacing:.14em; color:var(--muted);}

/* ---- Course list ---- */
.list{padding:14px 16px 48px; display:flex; flex-direction:column; gap:11px;}
.empty{color:var(--muted); text-align:center; padding:48px 16px; font-family:var(--display); font-style:italic; font-size:1.1rem;}

.course{position:relative; display:flex; align-items:stretch; gap:13px;
  background:var(--paper-card); border:1px solid var(--line); border-radius:13px;
  padding:13px 15px 13px 14px; box-shadow:var(--card-shadow);}
.tee{flex:0 0 4px; align-self:stretch; border-radius:4px; background:#a59c84;}
.tee-public{background:var(--green-soft);}
.tee-private{background:var(--brass);}
.tee-resort{background:#9c5a73;}
.tee-municipal{background:#5d6b86;}
.tee-semi-private{background:var(--brass-soft);}
.tee-military{background:#7d7a4a;}
.course-body{flex:1; min-width:0;}
.course h3{margin:0 0 3px; font-size:1.08rem; font-weight:600; line-height:1.18; color:var(--ink);}
.loc{margin:0 0 9px; font-size:.7rem; text-transform:uppercase; letter-spacing:.1em; color:var(--muted);}
.course.played{background:linear-gradient(0deg, rgba(31,81,52,.06), rgba(31,81,52,.06)), var(--paper-card); border-color:var(--green-soft);}
.course.played h3{color:var(--green-deep);}

/* badges */
.badges{display:flex; flex-wrap:wrap; gap:6px;}
.badge{font-size:.62rem; text-transform:uppercase; letter-spacing:.07em; font-weight:700;
  padding:3px 8px; border-radius:5px; background:var(--paper-deep); color:var(--muted); border:1px solid var(--line);}
.badge.closed{background:rgba(168,57,44,.12); color:var(--flag); border-color:rgba(168,57,44,.32);}
.badge.muted{background:var(--paper-deep); color:var(--muted);}
.badge.type-public{background:rgba(60,124,86,.13); color:var(--green); border-color:rgba(60,124,86,.32);}
.badge.type-private{background:rgba(169,121,58,.15); color:var(--brass); border-color:rgba(169,121,58,.34);}
.badge.type-resort{background:rgba(156,90,115,.14); color:#8a4a63; border-color:rgba(156,90,115,.34);}
.badge.type-municipal{background:rgba(93,107,134,.12); color:#4a5774; border-color:rgba(93,107,134,.32);}
.badge.type-semi-private{background:rgba(202,162,92,.16); color:#8a6a2f; border-color:rgba(202,162,92,.36);}
.badge.type-military{background:rgba(125,122,74,.14); color:#5f5d35; border-color:rgba(125,122,74,.32);}
.badge.type-unknown{background:var(--paper-deep); color:var(--muted);}

/* check "stamp" */
.check{flex:0 0 auto; align-self:center; width:42px; height:42px; border-radius:50%;
  border:2px dashed var(--line); background:transparent; color:transparent;
  font-size:1.2rem; font-weight:800; line-height:1; cursor:pointer; padding:0;
  display:flex; align-items:center; justify-content:center;
  transition:transform .12s, background .18s, border-color .18s, color .18s;}
.course.played .check{background:var(--green); border:2px solid var(--green); color:var(--paper); box-shadow:0 3px 10px -4px rgba(31,81,52,.6);}
.course:not(.readonly) .check:active{transform:scale(.85);}
.course.readonly .check{cursor:default; border-style:solid;}

/* ---- Leaderboard (clubhouse standings) ---- */
.lb-row{width:100%; display:grid; grid-template-columns:34px 1fr auto; align-items:center; gap:9px 13px;
  background:var(--paper-card); border:1px solid var(--line); border-radius:13px; padding:13px 15px;
  cursor:pointer; text-align:left; font:inherit; color:var(--ink); box-shadow:var(--card-shadow); transition:transform .08s;}
.lb-row:active{transform:translateY(1px);}
.lb-rank{font-family:var(--display); font-weight:700; font-size:1.2rem; color:var(--muted); text-align:center;}
.lb-name{min-width:0; font-weight:600; font-size:1rem; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;}
.lb-name em{color:var(--muted); font-weight:500; font-style:italic; font-family:var(--display);}
.lb-stat{font-family:var(--display); font-weight:700; font-size:1.2rem; color:var(--green); white-space:nowrap;}
.lb-of{color:var(--muted); font-weight:500; font-size:.68em; font-family:var(--body);}
.lb-bar{grid-column:2 / 4; height:6px; background:var(--paper-deep); border-radius:999px; overflow:hidden;}
.lb-fill{display:block; height:100%; background:var(--green-soft); border-radius:999px;}
.lb-row.me{border-color:var(--green-soft); background:linear-gradient(0deg, rgba(31,81,52,.06), rgba(31,81,52,.06)), var(--paper-card);}
.lb-row.lead{border-color:var(--brass); box-shadow:0 0 0 1px var(--brass-soft), var(--card-shadow);}
.lb-row.lead .lb-rank{color:var(--brass);}

/* ---- Gate (login wall / access-denied) ---- */
.gate{max-width:430px; margin:9vh auto 0; padding:34px 28px; text-align:center;
  background:var(--paper-card); border:1px solid var(--line); border-radius:18px; box-shadow:var(--card-shadow);}
.gate h1{margin:0 0 10px; color:var(--green); font-size:1.7rem; font-weight:700;}
.gate-sub{color:var(--muted); margin:0 0 24px;}
.btn{display:inline-block; background:var(--green); color:var(--paper); text-decoration:none; padding:13px 24px; border:none; border-radius:11px; font-weight:600; font-family:var(--body); cursor:pointer;}
.btn:hover{background:var(--green-deep);}
.gate-note{color:var(--muted); font-size:.8rem; margin:18px 0 0;}

/* ---- Rich login page ---- */
.login{max-width:440px; margin:0 auto; min-height:100svh; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center; padding:32px 26px;}
.login-mark{margin-bottom:16px; animation:rise .7s both;}
.login-eyebrow{margin:0 0 12px; font-size:.7rem; text-transform:uppercase; letter-spacing:.3em; color:var(--brass); animation:rise .7s .06s both;}
.login-title{margin:0; font-family:var(--display); font-weight:700; font-size:3rem; line-height:.92; letter-spacing:-.01em; color:var(--green-deep); animation:rise .7s .14s both;}
.login-sub{margin:18px 0 30px; max-width:30ch; font-family:var(--display); font-style:italic; font-size:1.1rem; color:var(--ink-soft); animation:rise .7s .22s both;}
.gbtn{display:inline-flex; align-items:center; gap:11px; background:var(--green); color:var(--paper);
  text-decoration:none; padding:14px 26px; border-radius:12px; font-weight:600; font-size:1rem;
  box-shadow:0 14px 28px -16px rgba(20,50,30,.85); animation:rise .7s .3s both; transition:transform .12s, background .15s;}
.gbtn:hover{background:var(--green-deep); transform:translateY(-1px);}
.gbtn-g{display:inline-grid; place-items:center; width:24px; height:24px; border-radius:50%; background:var(--paper); color:var(--green); font-family:var(--display); font-weight:700; font-size:.95rem;}
.login-foot{margin:26px 0 0; font-size:.76rem; color:var(--muted); animation:rise .7s .38s both;}
@keyframes rise{from{opacity:0; transform:translateY(14px);} to{opacity:1; transform:none;}}

/* ---- Admin "Manage access" modal ---- */
.modal{position:fixed; inset:0; background:rgba(20,30,22,.5); z-index:50; display:flex; align-items:flex-end; justify-content:center;}
.modal[hidden]{display:none;}
.modal-card{background:var(--paper-card); width:100%; max-width:480px; max-height:86vh; overflow:auto;
  border-radius:18px 18px 0 0; padding:20px 20px 30px; border-top:3px solid var(--brass);}
.modal-head{display:flex; justify-content:space-between; align-items:center;}
.modal-head h2{margin:0; font-size:1.3rem; color:var(--green-deep);}
.modal-close{border:none; background:none; font-size:1.8rem; line-height:1; cursor:pointer; color:var(--muted);}
.modal-sub{color:var(--muted); font-size:.85rem; margin:6px 0 16px;}
.add-form{display:flex; gap:8px;}
.add-form input{flex:1; min-width:0; padding:12px 13px; font-size:16px; font-family:var(--body); border:1px solid var(--line); border-radius:10px; background:var(--paper);}
.add-form input:focus{outline:none; border-color:var(--brass);}
.add-msg{font-size:.8rem; color:var(--muted); margin:9px 0 0; min-height:1.1em;}
.allow-list{list-style:none; padding:0; margin:16px 0 0;}
.allow-row{display:flex; justify-content:space-between; align-items:center; gap:10px; padding:12px 2px; border-bottom:1px solid var(--line);}
.allow-email{min-width:0; word-break:break-all; font-size:.92rem;}
.allow-email em{color:var(--brass); font-style:italic; font-family:var(--display); font-size:.85em;}
.allow-remove{flex:0 0 auto; border:1px solid rgba(168,57,44,.3); background:rgba(168,57,44,.06); color:var(--flag); border-radius:8px; padding:7px 12px; font-size:.8rem; cursor:pointer; font-family:var(--body);}

/* ---- Larger screens ---- */
@media (min-width:640px){
  .topbar, .tabs, .progress, .filters, .peerbar{padding-left:26px; padding-right:26px;}
  .list{padding:18px 24px 56px; display:grid; grid-template-columns:repeat(auto-fill, minmax(300px,1fr));}
  .login-title{font-size:3.6rem;}
  .modal{align-items:center;}
  .modal-card{border-radius:18px; border-top:none; border:1px solid var(--line);}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none !important; transition:none !important;}
}
