/* ============================================================
   Golf Leaderboard — mobil-först CSS
   Rent, tydligt, stora träffytor för tummen.
   ============================================================ */

/* hidden-attributet måste ALLTID dölja elementet. Annars överkör
   t.ex. ".pin-screen { display: flex }" webbläsarens [hidden]-regel
   och PIN-skärmen göms inte trots att JS satt hidden=true. */
[hidden] { display: none !important; }

:root {
  --green-900: #0b3d26;
  --green-700: #16653f;
  --green-500: #1f8a55;
  --green-100: #e3f3ea;
  --fairway:   #f4f8f5;
  --ink:       #16231c;
  --muted:     #5d6b63;
  --line:      #d9e3dc;
  --white:     #ffffff;
  --gold:      #e0a82e;
  --silver:    #9aa7b0;
  --bronze:    #c08457;
  --danger:    #c0392b;
  --radius:    14px;
  --radius-lg: 18px;
  --shadow:    0 2px 10px rgba(11, 61, 38, 0.08);
  --shadow-md: 0 6px 22px rgba(11, 61, 38, 0.12);
  /* Läsbar mörk gradient-overlay för text ovanpå banbilder */
  --img-overlay: linear-gradient(180deg, rgba(11,61,38,0.10) 0%, rgba(11,61,38,0.30) 45%, rgba(8,43,28,0.82) 100%);
}

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }

html, body {
  margin: 0;
  padding: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  color: var(--ink);
  background: var(--fairway);
  font-size: 17px;
  line-height: 1.4;
}

/* ============================================================
   BAKGRUNDSBILD bakom hela appen.
   En fast (fixed) banbild läggs i body::before, MED en kraftig
   ljus scrim ovanpå (vit gradient på ~88–92 % opacitet). Det gör
   att fotot bara anas som en subtil ton — de vita korten, tabeller
   (scorekort!) och formulär behåller knivskarp kontrast och text
   förblir lättläst. Bilden är `fixed` så den inte scrollar med.
   FALLBACK: laddas bilden inte syns bara den ljusa --fairway-tonen.
   ============================================================ */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  background:
    /* Ljus scrim överst → säkrar läsbarheten oavsett foto */
    linear-gradient(180deg, rgba(244,248,245,0.90) 0%, rgba(244,248,245,0.92) 100%),
    /* Björns fairwayfoto, dämpat */
    url("images/course-loslagos.jpg") center / cover no-repeat,
    var(--fairway);
  background-attachment: fixed;
}

/* ---------- PIN-grind ---------- */
.pin-screen {
  position: fixed; inset: 0;
  display: flex; align-items: center; justify-content: center;
  /* Grön gradient = robust fallback om hjältebilden inte laddar. */
  background: linear-gradient(160deg, var(--green-700), var(--green-900));
  padding: 24px;
  z-index: 100;
  overflow: hidden;
}
/* Hjältebild: täcker hela skärmen bakom kortet, med mörk overlay för djup.
   Faller bilden bort (onerror→display:none) syns den gröna gradienten. */
.pin-hero {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: 0;
}
.pin-screen::after {
  content: ""; position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(165deg, rgba(11,61,38,0.62) 0%, rgba(8,43,28,0.82) 100%);
}
.pin-card {
  position: relative; z-index: 2;
  background: rgba(255,255,255,0.97);
  border-radius: var(--radius-lg);
  padding: 34px 26px;
  width: 100%; max-width: 360px;
  text-align: center;
  box-shadow: 0 18px 50px rgba(0,0,0,0.40);
  backdrop-filter: saturate(1.1);
}
.pin-logo { font-size: 52px; line-height: 1; }
.pin-card h1 { font-size: 24px; margin: 12px 0 4px; color: var(--green-900); }
.pin-sub { color: var(--muted); margin: 0 0 20px; }
.pin-input {
  width: 100%;
  font-size: 28px;
  text-align: center;
  letter-spacing: 8px;
  padding: 14px;
  border: 2px solid var(--line);
  border-radius: var(--radius);
  margin-bottom: 16px;
}
.pin-input:focus { outline: none; border-color: var(--green-500); }
.pin-error { color: var(--danger); font-size: 15px; margin: 12px 0 0; }
.pin-version { color: #9aa6a0; font-size: 12px; margin: 18px 0 0; letter-spacing: .04em; }

/* ---------- App-skal ---------- */
.app { min-height: 100vh; padding-bottom: 76px; /* plats för tabbar */ }

.topbar {
  position: sticky; top: 0; z-index: 20;
  background: linear-gradient(135deg, var(--green-700) 0%, var(--green-900) 100%);
  color: var(--white);
  display: flex; align-items: center; justify-content: space-between;
  padding: 15px 18px;
  font-weight: 600;
  box-shadow: var(--shadow-md);
}
.topbar-title { font-size: 18px; letter-spacing: 0.01em; }
.conn-status { font-size: 12px; color: #8ee0b0; }
.conn-status.off { color: #ffd27a; }

.demo-banner {
  background: #fff4d6;
  color: #7a5a10;
  font-size: 14px;
  padding: 10px 16px;
  text-align: center;
  border-bottom: 1px solid #f0e0a8;
}

.content { padding: 18px 16px 24px; max-width: 640px; margin: 0 auto; }

.view-title { font-size: 21px; margin: 4px 0 6px; color: var(--green-900); }
.view-hint { color: var(--muted); font-size: 14px; margin: 0 0 16px; }
.sub-head { font-size: 16px; margin: 22px 0 8px; color: var(--green-900); }

/* ---------- Leaderboard ---------- */
.board { display: flex; flex-direction: column; gap: 10px; }
.board-row {
  display: flex; align-items: center; gap: 13px;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 14px 16px;
  box-shadow: var(--shadow);
  position: relative; overflow: hidden;
}
/* Medaljfärgad kantremsa för topp 3 */
.board-row.rank-1, .board-row.rank-2, .board-row.rank-3 { border-left: 4px solid var(--line); }
.board-row.rank-1 { border-left-color: var(--gold);   background: #fffdf5; box-shadow: var(--shadow-md); }
.board-row.rank-2 { border-left-color: var(--silver); }
.board-row.rank-3 { border-left-color: var(--bronze); }
/* Rangbricka — rund, medaljfärgad för topp 3 */
.rank-num {
  font-size: 17px; font-weight: 700; color: var(--muted);
  width: 32px; height: 32px; flex: none;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%; background: var(--fairway);
}
.rank-1 .rank-num { color: #6b5310; background: #fbeec2; }
.rank-2 .rank-num { color: #4a545b; background: #e7ebee; }
.rank-3 .rank-num { color: #7a4f2e; background: #f0e0d2; }
.row-main { flex: 1 1 auto; min-width: 0; }
.row-name { font-weight: 600; font-size: 18px; }
.row-sub { color: var(--muted); font-size: 13px; }
.row-score { font-size: 22px; font-weight: 700; color: var(--green-700); flex: none; }
.row-score small { font-size: 13px; font-weight: 500; color: var(--muted); }

/* ---------- Sidegame: utfällbart scorekort per spelare ---------- */
.sidegame-item { display: flex; flex-direction: column; gap: 0; }
.board-row--btn { cursor: pointer; user-select: none; padding-right: 12px; }
.board-row--btn:hover { box-shadow: var(--shadow-md); }
.board-row--btn:focus-visible { outline: 2px solid var(--green-500); outline-offset: 2px; }
.sg-chevron { flex: none; color: var(--muted); font-size: 16px; margin-left: 4px; transition: transform .18s ease; }
.sidegame-item.is-open .sg-chevron { transform: rotate(180deg); color: var(--green-700); }
.sidegame-item.is-open .board-row--btn { border-bottom-left-radius: 0; border-bottom-right-radius: 0; }
/* Sidegame-score: nettototal + mot-hcp (+6 / −12 / E) bredvid varandra på samma rad,
   i samma stil som scoren. Mot-hcp färgas: under = grönt/bra, över = rött. */
.sidegame-item .row-score { display: flex; align-items: baseline; gap: 12px; }
.rs-net { color: var(--green-700); }
.rs-hcp { font-size: 20px; font-weight: 700; }
.rs-net small, .rs-hcp small { font-size: 12px; font-weight: 500; color: var(--muted); }
.rs-hcp.vh-under { color: #15683f; }
.rs-hcp.vh-over  { color: var(--danger); }
.rs-hcp.vh-even  { color: var(--muted); }
.sg-detail {
  background: var(--white);
  border: 1px solid var(--line); border-top: none;
  border-radius: 0 0 var(--radius) var(--radius);
  margin-top: -2px; padding: 12px 12px 14px;
  box-shadow: var(--shadow);
  display: flex; flex-direction: column; gap: 12px;
}
.sg-card { border: 1px solid var(--line); border-radius: 12px; overflow: hidden; background: var(--fairway); }
.sg-card-head {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  padding: 8px 12px; background: var(--green-100);
}
.sg-card-title { font-weight: 700; color: var(--green-900); font-size: 14px; }
.sg-card-ch { font-size: 12px; font-weight: 600; color: var(--green-700); background: var(--white); border-radius: 999px; padding: 2px 9px; }
.sg-table { margin: 0; }
.sg-scorelabel { font-weight: 700; color: var(--green-900); }
.sg-empty { color: var(--muted); font-size: 14px; padding: 8px 4px; }

.empty-state {
  text-align: center; color: var(--muted);
  padding: 40px 20px; font-size: 15px;
}

/* ---------- Formulär / inputs ---------- */
.field-label { display: block; font-weight: 600; margin: 4px 0 6px; font-size: 15px; }
.input, .select {
  width: 100%;
  font-size: 17px;
  padding: 12px 14px;
  border: 1.5px solid var(--line);
  border-radius: var(--radius);
  background: var(--white);
  color: var(--ink);
}
.input:focus, .select:focus { outline: none; border-color: var(--green-500); }
.input-date { max-width: 170px; }
.input-time { max-width: 130px; }
.row { display: flex; gap: 10px; align-items: center; margin-bottom: 8px; flex-wrap: wrap; }
.row .input { flex: 1 1 140px; }
.select-inline { flex: 0 0 auto; max-width: 45%; }

/* ---------- Knappar ---------- */
.btn {
  font-size: 16px; font-weight: 600;
  padding: 12px 18px;
  border: none; border-radius: var(--radius);
  background: var(--green-100); color: var(--green-900);
  cursor: pointer; flex: none;
}
.btn:active { transform: translateY(1px); }
.btn-primary { background: linear-gradient(135deg, var(--green-700), var(--green-900)); color: var(--white); box-shadow: 0 4px 14px rgba(11,61,38,0.22); }
.btn-big { width: 100%; padding: 16px; font-size: 18px; margin-top: 20px; }
.btn-danger { background: #fbe4e1; color: var(--danger); }

/* ---------- Setup-block ---------- */
.setup-block {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 16px;
  margin-bottom: 16px;
  box-shadow: var(--shadow);
}
.danger-block { border-color: #f3c9c3; }
.chip-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 12px; }
.chip {
  display: flex; align-items: center; justify-content: space-between;
  background: var(--fairway);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px 12px;
  font-size: 15px;
}
.chip-meta { color: var(--muted); font-size: 13px; }
.chip-del {
  border: none; background: none; color: var(--danger);
  font-size: 20px; cursor: pointer; padding: 0 4px; line-height: 1;
}

/* ---------- Mata-in-vyn ---------- */
.match-inputs, .sidegame-inputs { display: flex; flex-direction: column; gap: 10px; }
.match-row, .sg-row {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 12px 14px;
  box-shadow: var(--shadow);
}
.match-row .mr-team { font-weight: 600; margin-bottom: 8px; }
.result-buttons { display: flex; gap: 8px; }
.result-btn {
  flex: 1; padding: 12px 0; font-size: 15px; font-weight: 600;
  border: 1.5px solid var(--line); border-radius: 10px;
  background: var(--white); color: var(--ink); cursor: pointer;
}
.result-btn.sel-win  { background: var(--green-700); color: #fff; border-color: var(--green-700); }
.result-btn.sel-draw { background: var(--gold);      color: #fff; border-color: var(--gold); }
.result-btn.sel-loss { background: #6b7785;          color: #fff; border-color: #6b7785; }
.sg-row { display: flex; align-items: center; gap: 12px; }
.sg-row .sg-name { flex: 1; font-weight: 600; }
.sg-row .sg-input { width: 90px; text-align: center; font-size: 18px; padding: 10px; }

/* ============================================================
   BILDHUVUD PER BANA (course-header)
   Banbild + mörk gradient-overlay + rundans namn/datum/spelform.
   FALLBACK: <img onerror> döljer bilden → den gröna gradienten på
   .course-header tar över → texten förblir läsbar oavsett.
   ============================================================ */
.course-header {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  /* Grön gradient = fallback-bakgrund (syns om bilden inte laddar). */
  background: linear-gradient(150deg, var(--green-700) 0%, var(--green-900) 100%);
  display: flex; align-items: flex-end;
  isolation: isolate;
}
.ch-schedule { min-height: 132px; }
.ch-info     { min-height: 116px; }
.course-header .ch-img {
  position: absolute; inset: 0; z-index: 0;
  width: 100%; height: 100%; object-fit: cover;
  display: block;
}
.course-header .ch-overlay {
  position: relative; z-index: 1;
  width: 100%;
  padding: 14px 16px;
  background: var(--img-overlay);
  color: #fff;
}
.ch-name {
  font-weight: 700; font-size: 18px; line-height: 1.2;
  letter-spacing: 0.01em; text-shadow: 0 1px 3px rgba(0,0,0,0.45);
}
.ch-meta {
  font-size: 13px; margin-top: 3px; color: #eaf3ec;
  text-shadow: 0 1px 2px rgba(0,0,0,0.5);
}
.ch-format {
  font-size: 13px; margin-top: 5px;
  display: inline-block;
  background: rgba(255,255,255,0.18);
  border: 1px solid rgba(255,255,255,0.28);
  border-radius: 999px; padding: 3px 10px;
  color: #fff; text-shadow: 0 1px 2px rgba(0,0,0,0.35);
}

/* ---------- Rundinfo i Mata-in-/Scorekort-vyn ---------- */
.round-info {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  margin: 12px 0 4px;
  box-shadow: var(--shadow);
  background: var(--white);
}
.round-info-format { color: var(--muted); font-size: 14px; padding: 10px 14px; }
.round-info-format .ri-label { font-weight: 600; color: var(--ink); }
/* När ett bildhuvud finns vill vi att bandata-raden ligger under bilden */
.round-info .course-header { border-radius: 0; }

/* ---------- Rundöversikt på Lag-vyn ---------- */
.rounds-schedule { display: flex; flex-direction: column; gap: 12px; }
.schedule-row--img {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
}
.schedule-row--img .course-header { border-radius: 0; }
.schedule-meta { color: var(--muted); font-size: 13px; margin-top: 2px; }
.schedule-banddata { padding: 9px 14px; margin-top: 0; }

/* Klickbar runda → hoppar till scorekort. Tydlig hover/aktiv + CTA-rad. */
.schedule-row--link {
  cursor: pointer;
  transition: box-shadow .15s ease, transform .12s ease, border-color .15s ease;
  -webkit-tap-highlight-color: transparent;
}
.schedule-row--link:hover,
.schedule-row--link:focus-visible {
  border-color: var(--green-700, #16653f);
  box-shadow: 0 4px 16px rgba(0,0,0,.16);
  outline: none;
}
.schedule-row--link:active { transform: scale(.995); }
.schedule-cta {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 4px;
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 600;
  color: var(--green-700, #16653f);
  border-top: 1px solid var(--line);
}
.schedule-row--link:hover .schedule-cta,
.schedule-row--link:focus-visible .schedule-cta { text-decoration: underline; }

/* ============================================================
   BRED HJÄLTEBANNER (Björns foto) — högst upp på Lag-vyn.
   Grön gradient = fallback om bilden saknas; onerror döljer hela bannern.
   ============================================================ */
.wide-banner {
  position: relative;
  margin: -4px 0 18px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  min-height: 150px;
  background: linear-gradient(150deg, var(--green-700) 0%, var(--green-900) 100%);
  display: flex; align-items: flex-end;
  box-shadow: var(--shadow-md);
  isolation: isolate;
}
.wide-banner-img {
  position: absolute; inset: 0; z-index: 0;
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.wide-banner-overlay {
  position: relative; z-index: 1; width: 100%;
  padding: 16px 18px;
  background: var(--img-overlay);
  color: #fff;
}
.wide-banner-title {
  font-weight: 800; font-size: 22px; line-height: 1.15;
  letter-spacing: 0.01em; text-shadow: 0 1px 4px rgba(0,0,0,0.5);
}
.wide-banner-sub {
  font-size: 13px; margin-top: 3px; color: #eaf3ec;
  text-transform: uppercase; letter-spacing: 0.08em;
  text-shadow: 0 1px 2px rgba(0,0,0,0.5);
}

/* ============================================================
   FLIK-BANNER (tab-banner) — slim toppbild-huvud per vy.
   Ger Sidegame / Scorekort / Mata in / Setup samma proffsiga
   bildhuvud som Lag-vyns wide-banner. Bild + mörk gradient +
   vyns titel ovanpå. FALLBACK: grön gradient om bilden saknas
   (onerror på <img> döljer bilden → gradienten kvar → titeln läsbar).
   ============================================================ */
.tab-banner {
  position: relative;
  margin: -4px 0 18px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  min-height: 118px;
  background: linear-gradient(150deg, var(--green-700) 0%, var(--green-900) 100%);
  display: flex; align-items: flex-end;
  box-shadow: var(--shadow-md);
  isolation: isolate;
}
.tab-banner-img {
  position: absolute; inset: 0; z-index: 0;
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.tab-banner-overlay {
  position: relative; z-index: 1; width: 100%;
  padding: 14px 18px;
  background: var(--img-overlay);
  color: #fff;
}
.tab-banner-title {
  font-weight: 800; font-size: 21px; line-height: 1.15;
  letter-spacing: 0.01em; color: #fff;
  text-shadow: 0 1px 4px rgba(0,0,0,0.55);
}
.tab-banner-sub {
  font-size: 13px; margin-top: 3px; color: #eaf3ec;
  text-transform: uppercase; letter-spacing: 0.08em;
  text-shadow: 0 1px 2px rgba(0,0,0,0.5);
}
/* När en flik-banner ligger överst i vyn behövs ingen separat h2-titel. */
.tab-banner + .view-title { display: none; }

/* ============================================================
   GALLERI ("Resan") — horisontellt svepbar rad med Björns foton.
   ============================================================ */
.trip-gallery {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
  padding: 2px 0 6px;
  /* Tunn scrollbar på desktop, dold men funktionell på mobil */
  scrollbar-width: thin;
}
.gallery-item {
  flex: 0 0 auto;
  scroll-snap-align: start;
  width: 200px;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
  background: var(--green-100);
}
.gallery-img {
  display: block;
  width: 200px;
  height: 140px;
  object-fit: cover;
}

/* ---------- Runda-chips i Setup (flerradiga) ---------- */
.chip-round { align-items: flex-start; }
.chip-round-text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.chip-round-name { font-weight: 600; }
.chip-format { color: var(--ink); font-size: 13px; }
.round-tools { margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--line); }
.round-tools .view-hint { margin-top: 8px; }

.inline-msg { text-align: center; font-size: 15px; margin-top: 12px; }
.inline-msg.ok  { color: var(--green-700); }
.inline-msg.err { color: var(--danger); }

/* ---------- Nedre flikmeny ---------- */
.tabbar {
  position: fixed; bottom: 0; left: 0; right: 0;
  display: flex; background: var(--white);
  border-top: 1px solid var(--line);
  box-shadow: 0 -2px 10px rgba(11,61,38,0.06);
  z-index: 30;
  padding-bottom: env(safe-area-inset-bottom);
}
.tab {
  flex: 1; border: none; background: none; cursor: pointer;
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  padding: 9px 4px; color: var(--muted); font-size: 11px;
}
.tab-icon { font-size: 21px; line-height: 1; }
.tab-active { color: var(--green-700); font-weight: 700; }

/* ---------- Handicap-fält ---------- */
.input-hcp { max-width: 100%; }
.chip-player { flex-wrap: wrap; gap: 6px; }
.chip-player-name { flex: 1 1 140px; }
.chip-hcp { font-size: 13px; color: var(--muted); display: flex; align-items: center; gap: 6px; }
.hcp-input { width: 64px; text-align: center; font-size: 15px; padding: 6px 8px;
  border: 1.5px solid var(--line); border-radius: 8px; }
.chip-team { font-size: 13px; color: var(--muted); display: flex; align-items: center; gap: 6px; }
.team-input { font-size: 15px; padding: 6px 8px; border: 1.5px solid var(--line);
  border-radius: 8px; background: var(--white); color: var(--ink); max-width: 150px; }

/* ---------- Inloggningskoder (spelare + följare) ---------- */
.chip-code { font-size: 13px; color: var(--muted); display: flex; align-items: center; gap: 6px; }
.code-input, .vcode-input { width: 110px; font-size: 15px; padding: 6px 8px;
  border: 1.5px solid var(--line); border-radius: 8px; background: var(--white); color: var(--ink); }
.input-code { max-width: 170px; }
.chip-viewer { flex-wrap: wrap; gap: 6px; }
.code-warnings { background: #fff7ed; border: 1.5px solid #f6c177; color: #7a4b08;
  border-radius: 10px; padding: 10px 14px; font-size: 13px; line-height: 1.5; margin-top: 4px; }
.code-warnings ul { margin: 6px 0 0; padding-left: 18px; }
.code-warnings li { margin-bottom: 4px; }

/* ---------- Redigerbar bandata i Setup ---------- */
.round-edit { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 8px; align-items: center; }
.round-edit label { font-size: 12px; color: var(--muted); display: flex; align-items: center; gap: 4px; }
.r-edit { width: 62px; text-align: center; font-size: 14px; padding: 5px 6px;
  border: 1.5px solid var(--line); border-radius: 8px; }
.btn-tiny { font-size: 13px; padding: 6px 10px; }

/* ---------- Scorekort-inmatning (hål för hål) ---------- */
.entry-players { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 10px; }
.entry-tab {
  border: 1.5px solid var(--line); background: var(--white); color: var(--ink);
  border-radius: 999px; padding: 7px 12px; font-size: 14px; font-weight: 600; cursor: pointer;
}
.entry-tab.sel { background: var(--green-700); color: #fff; border-color: var(--green-700); }
.entry-tab-badge { font-size: 11px; opacity: .8; font-weight: 500; }

.sc-meta { font-size: 14px; color: var(--ink); margin: 4px 0 10px; }
.scorecard {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
}
.sc-cell {
  background: var(--white); border: 1px solid var(--line); border-radius: 10px;
  padding: 8px 6px; text-align: center;
}
.sc-hole { font-weight: 700; font-size: 15px; color: var(--green-900); }
.sc-par { font-size: 11px; color: var(--muted); margin-bottom: 4px; min-height: 14px; }
.sc-dots { color: var(--green-500); font-weight: 700; }
.sc-input {
  width: 100%; text-align: center; font-size: 19px; font-weight: 600;
  padding: 8px 2px; border: 1.5px solid var(--line); border-radius: 8px;
}
.sc-input:focus { outline: none; border-color: var(--green-500); }
.sc-totals {
  display: flex; flex-wrap: wrap; gap: 14px; justify-content: space-around;
  background: var(--green-100); border-radius: var(--radius);
  padding: 12px; margin: 14px 0 4px; font-size: 15px;
}
.sc-totals b { color: var(--green-900); }

@media (min-width: 420px) {
  .scorecard { grid-template-columns: repeat(6, 1fr); }
}

/* ---------- Lagmatcher (auto + override) ---------- */
.match-list { display: flex; flex-direction: column; gap: 10px; margin-bottom: 16px; }
.match-card {
  background: var(--white); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 12px 14px; box-shadow: var(--shadow);
}
.mm-head { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.mm-side { display: flex; flex-direction: column; }
.mm-players { font-size: 12px; color: var(--muted); }
.mm-vs { color: var(--muted); font-size: 13px; }
.mm-head .chip-del { margin-left: auto; }
.mm-auto { font-size: 13px; color: var(--muted); margin: 8px 0 6px; }
.mm-overridden { color: var(--gold); font-weight: 600; }
.mm-ov-label { font-size: 13px; color: var(--ink); display: block; margin-bottom: 4px; }
.mm-result { font-size: 14px; margin-top: 8px; }
.result-btn.sel-auto { background: var(--green-100); color: var(--green-900); border-color: var(--green-500); }

/* Singel: en override-ruta per duell */
.mm-singles-note { font-size: 13px; color: var(--muted); margin: 8px 0 6px; }
.duel-ov-list { display: flex; flex-direction: column; gap: 10px; }
.duel-ov {
  background: var(--fairway); border: 1px solid var(--line);
  border-radius: 10px; padding: 10px 12px;
}
.duel-ov-head { font-size: 14px; margin-bottom: 2px; }
.duel-ov-head .duel-seg {
  display: inline-block; font-size: 12px; font-weight: 700; color: var(--green-900);
  background: var(--green-100); border-radius: 6px; padding: 1px 7px; margin-right: 6px;
}
.win-a { color: var(--green-700); }
.win-b { color: #2563a8; }

.add-match {
  background: var(--fairway); border: 1px dashed var(--line); border-radius: var(--radius);
  padding: 14px; margin-top: 4px;
}
.add-match-title { margin: 0 0 10px; font-size: 15px; color: var(--green-900); }
.add-match-vs { color: var(--muted); flex: none; }
.add-match select[multiple] { height: auto; }

/* ---------- Scorekort- & resultatvy (läsvy) ---------- */
.scorecard-view { margin-bottom: 8px; }

/* Vågrät scroll med sticky första kolumn */
.hbh-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--white);
  box-shadow: var(--shadow);
}
.hbh-table {
  border-collapse: separate;
  border-spacing: 0;
  font-size: 15px;
  white-space: nowrap;
}
.hbh-table th, .hbh-table td {
  padding: 9px 6px;
  text-align: center;
  min-width: 42px;
  border-bottom: 1px solid var(--line);
}
/* Sticky första kolumn (spelarnamn/etikett).
   OBS: .hbh-table td sätter min-width:42px med högre specificitet (klass+element)
   än enbart .hbh-name, så bredden måste anges med matchande specificitet här. */
.hbh-name {
  position: sticky; left: 0; z-index: 2;
  background: var(--white);
  text-align: left !important;
  white-space: normal;
  box-shadow: 2px 0 6px rgba(11,61,38,0.08);
  padding-left: 11px !important;
}
.hbh-table th.hbh-name, .hbh-table td.hbh-name {
  min-width: 116px; max-width: 138px;
}
.hbh-table thead th {
  position: sticky; top: 0; z-index: 1;
  background: var(--green-700); color: #fff; font-weight: 700;
}
.hbh-table thead th.hbh-name { z-index: 3; background: var(--green-700); color: #fff; }
.hbh-h { font-weight: 800; font-size: 16px; }
.hbh-sub { background: var(--green-100); font-weight: 800; }
.hbh-tot { background: #dfeede; font-weight: 800; }
thead th.hbh-sub, thead th.hbh-tot { background: var(--green-900); color: #fff; }

.hbh-pararow td, .hbh-sirow td { color: var(--muted); font-size: 14px; font-weight: 600; }
.hbh-pararow td { background: #f3f8f4; }
.hbh-pararow .hbh-name, .hbh-sirow .hbh-name { color: var(--green-900); font-weight: 700; font-size: 13px; }
.hbh-info { font-size: 14px; color: var(--muted); font-weight: 600; }
.hbh-pararow .hbh-info { color: var(--green-900); }

/* Lag-rubrik: ska otvetydigt läsas som HUVUD för spelarna UNDER den.
   Därför kraftig avskiljare OVANFÖR rubriken (stänger föregående lag) och
   bara en tunn linje under (rubriken hör ihop med sina egna spelare). */
.hbh-teamrow td {
  background: var(--green-100);
  border-top: 3px solid var(--green-700);
  border-bottom: 1px solid var(--line);
}
/* Första lag-rubriken behöver ingen tung topplinje (inget lag ovanför). */
.hbh-teamrow.is-first td { border-top: 1px solid var(--line); }
.hbh-teamname {
  font-weight: 800; color: var(--green-900);
  text-transform: uppercase; letter-spacing: 0.04em; font-size: 14px;
}
.hbh-spacer { padding: 0; background: var(--green-100); }
/* Sista spelaren i ett lag får en tydlig avslutslinje så grupperna ramas in. */
.hbh-playerrow.is-team-last td { border-bottom: 2px solid var(--line); }

.hbh-playerrow .hbh-name { display: flex; flex-direction: column; gap: 2px; }
.hbh-pname { font-weight: 700; font-size: 15px; color: var(--ink); }
.hbh-ch { font-size: 11px; color: var(--muted); font-weight: 600; }
.hbh-scramblerow td { background: #f7fbf8; }

/* Cell-innehåll: brutto stort, netto litet, prickar för handikappslag */
.hbh-cell { line-height: 1.1; }
.hc-gross { display: inline-block; font-size: 20px; font-weight: 800; }
.hc-empty { color: var(--line); font-weight: 400; }
.hc-net { display: block; font-size: 12px; color: var(--muted); font-weight: 600; }
.hc-dots { display: block; font-size: 9px; color: var(--green-500); line-height: 1; margin-top: 0; letter-spacing: 1px; }
.hc-dots.hc-minus { color: var(--danger); }

/* Färgkodning mot par (diskret) */
.sc-eagle   { color: #b8860b; }
.sc-birdie  { color: #c0392b; }
.sc-parscore { color: var(--ink); }
.sc-bogey   { color: #2c6fb0; }
.sc-dbogey  { color: #6b7785; }
.hbh-cell .sc-birdie { background: #fdecea; border-radius: 7px; padding: 1px 5px; }
.hbh-cell .sc-eagle  { background: #fbf1d8; border-radius: 7px; padding: 1px 5px; }
.hbh-cell .sc-bogey  { background: #eaf1fa; border-radius: 7px; padding: 1px 5px; }

.hbh-sub .hc-gross, .hbh-tot .hc-gross { font-size: 18px; }
.hbh-sub .hc-net, .hbh-tot .hc-net { font-size: 12px; }

.hbh-legend {
  display: flex; flex-wrap: wrap; gap: 12px; align-items: center;
  font-size: 13px; color: var(--muted); padding: 12px 4px 0;
}
.hbh-legend .lg-dot { display: inline-block; width: 10px; height: 10px; border-radius: 3px; margin-right: 4px; vertical-align: middle; }
.lg-dot.sc-birdie { background: #c0392b; }
.lg-dot.sc-parscore { background: var(--ink); }
.lg-dot.sc-bogey { background: #2c6fb0; }
.lg-dot.sc-dbogey { background: #6b7785; }
.hbh-legend-net { flex-basis: 100%; }

/* ---------- Hål-för-hål-matcher ---------- */
.hbh-matches { display: flex; flex-direction: column; gap: 14px; }
.hbhm-card {
  background: var(--white); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 12px 14px; box-shadow: var(--shadow);
}
.hbhm-head { display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px; }
.hbhm-teams { font-size: 15px; }
.hbhm-mplayers { color: var(--muted); font-size: 12px; }
.hbhm-vs { color: var(--muted); font-size: 13px; }
.hbhm-result {
  align-self: flex-start; font-size: 13px; font-weight: 600;
  background: var(--green-100); color: var(--green-900);
  padding: 4px 10px; border-radius: 999px;
}
.hbhm-result.is-won { background: var(--green-700); color: #fff; }

.hbhm-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.hbhm-table { border-collapse: separate; border-spacing: 3px; }
.hbhm-cell {
  min-width: 30px; text-align: center; border-radius: 8px;
  padding: 4px 2px; background: var(--fairway); border: 1px solid var(--line);
  vertical-align: top;
}
.hbhm-h { display: block; font-size: 10px; color: var(--muted); }
.hbhm-w { display: block; font-size: 15px; font-weight: 700; line-height: 1.2; }
.hbhm-s { display: block; font-size: 9px; color: var(--muted); white-space: nowrap; }
.hbhm-cell.hbh-win-a { background: var(--green-100); border-color: var(--green-500); }
.hbhm-cell.hbh-win-a .hbhm-w { color: var(--green-700); }
.hbhm-cell.hbh-win-b { background: #eaf1fa; border-color: #2c6fb0; }
.hbhm-cell.hbh-win-b .hbhm-w { color: #2c6fb0; }
.hbhm-cell.hbh-win-d { background: #fdf6e3; border-color: var(--gold); }
.hbhm-cell.hbh-win-d .hbhm-w { color: var(--gold); }
.hbhm-foot { font-size: 14px; margin-top: 10px; }

/* ---------- Singel-dueller (1-mot-1, byte efter hål 9) ---------- */
.win-a { color: var(--green-700); }
.win-b { color: #2c6fb0; }
.duel-list { display: flex; flex-direction: column; gap: 12px; }
.duel {
  border: 1px solid var(--line); border-radius: 10px;
  padding: 8px 10px; background: var(--fairway);
}
.duel-head {
  display: flex; flex-wrap: wrap; align-items: center; gap: 6px 10px;
  margin-bottom: 8px; font-size: 13px;
}
.duel-seg {
  font-size: 11px; font-weight: 700; color: var(--muted);
  background: var(--white); border: 1px solid var(--line);
  border-radius: 999px; padding: 2px 8px; white-space: nowrap;
}
.duel-names { font-size: 14px; }
.duel-res {
  margin-left: auto; font-size: 12px; font-weight: 600;
  background: var(--green-100); color: var(--green-900);
  padding: 3px 9px; border-radius: 999px; white-space: nowrap;
}
.duel-res.is-won { background: var(--green-700); color: #fff; }
.hbhm-singles .hbhm-foot {
  border-top: 1px solid var(--line); padding-top: 8px;
}

@media (min-width: 700px) {
  .content { padding-top: 28px; }
}

/* ---------- Topbar-höger: roll-etikett + anslutningsprick ---------- */
.topbar-right { display: flex; align-items: center; gap: 10px; }
.role-badge {
  font-size: 11px; font-weight: 700; letter-spacing: .03em;
  background: rgba(255,255,255,0.18); color: #fff;
  padding: 3px 9px; border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.28);
  white-space: nowrap;
}

/* ---------- Chatt ---------- */
.chat-nick-bar {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  background: var(--green-100); border-radius: var(--radius);
  padding: 10px 12px; margin-bottom: 12px; font-size: 14px;
}
.chat-nick-label { color: var(--ink); }
.chat-nick-label b { color: var(--green-900); }
.chat-nick-bar .btn { margin-left: auto; }

.chat-messages {
  display: flex; flex-direction: column; gap: 10px;
  /* Fast höjd så listan scrollar internt och inmatningsraden alltid syns. */
  height: 52vh; min-height: 240px;
  overflow-y: auto; -webkit-overflow-scrolling: touch;
  background: var(--white); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 12px;
  box-shadow: var(--shadow);
}
.chat-empty { color: var(--muted); font-size: 14px; text-align: center; margin: auto; }
.chat-empty small { color: #9aa6a0; }

.chat-msg {
  background: var(--fairway); border: 1px solid var(--line);
  border-radius: 12px; padding: 8px 11px; max-width: 92%;
  align-self: flex-start; word-break: break-word; overflow-wrap: anywhere;
}
.chat-msg-meta {
  display: flex; align-items: baseline; gap: 8px;
  font-size: 12px; margin-bottom: 2px;
}
.chat-msg-nick { font-weight: 700; color: var(--green-700); }
.chat-msg-time { color: var(--muted); font-size: 11px; }
.chat-msg-text { font-size: 15px; line-height: 1.35; color: var(--ink); }

.chat-input-bar {
  display: flex; gap: 8px; margin-top: 12px;
}
.chat-input {
  flex: 1 1 auto; min-width: 0;
  font-size: 16px; padding: 12px 14px;
  border: 1.5px solid var(--line); border-radius: var(--radius);
  background: var(--white); color: var(--ink);
}
.chat-input:focus { outline: none; border-color: var(--green-500); }
.chat-send-btn { flex: 0 0 auto; white-space: nowrap; }
