/* Krakeroyhb Informasjonstavle — app.css v9 (lys/mørk tema) */

:root {
  --bg:          #0d0d0d;
  --card-bg:     #141414;
  --accent:      #ffffff;
  --accent-dim:  #d0d0d0;
  --text:        #f0f0f0;
  --text-muted:  #888;
  --border:      #2a2a2a;
  --success:     #22c55e;
  --warning:     #eab308;
  --danger:      #ef4444;
  --blue:        #3b82f6;
  --cyan:        #06b6d4;
  --row-hover:   #1f1f1f;   /* hover/aktiv bakgrunn for klikkbare rader */
}

/* ════════════════════════════════════════════════════════════════════
   LYST TEMA (premium sports-tech-palett) — aktivt når html[data-theme="light"]
   Bruker som standard mørkt — bytter via tema-velger i headeren (lagres
   i localStorage som 'kil-theme').
   ════════════════════════════════════════════════════════════════════ */
html[data-theme="light"] {
  --bg:          #F6F8FA;
  --card-bg:     #FFFFFF;
  --accent:      #0F7A4F;
  --accent-dim:  #0c6843;
  --text:        #111827;
  --text-muted:  #5B6472;
  --border:      #E6EAEF;
  --success:     #0F7A4F;
  --warning:     #B7791F;
  --danger:      #DC2626;
  --blue:        #2563eb;
  --cyan:        #0891b2;
  --row-hover:   #EEF1F5;   /* lys hover/aktiv bakgrunn */
}
/* Fang hardkodede mørke bakgrunner (hex og rgba) på inline-styles */
html[data-theme="light"] [style*="rgba(255,255,255,0.02)"],
html[data-theme="light"] [style*="rgba(255,255,255,0.025)"],
html[data-theme="light"] [style*="rgba(255,255,255,0.05)"],
html[data-theme="light"] [style*="rgba(255,255,255,0.06)"],
html[data-theme="light"] [style*="rgba(255,255,255,0.08)"],
html[data-theme="light"] [style*="rgba(255,255,255,0.12)"] { background:var(--bg) !important; }
html[data-theme="light"] [style*="background:#0a0a0a"],
html[data-theme="light"] [style*="background:#0d0d0d"],
html[data-theme="light"] [style*="background:#0e0e0e"],
html[data-theme="light"] [style*="background:#121212"],
html[data-theme="light"] [style*="background:#131313"],
html[data-theme="light"] [style*="background:#141414"],
html[data-theme="light"] [style*="background:#161616"],
html[data-theme="light"] [style*="background:#1a1a1a"],
html[data-theme="light"] [style*="background:#1e1e1e"],
html[data-theme="light"] [style*="background: #0d0d0d"],
html[data-theme="light"] [style*="background: #1a1a1a"] { background:var(--card-bg) !important; color:var(--text) !important; }
html[data-theme="light"] input[style*="background:#0d0d0d"],
html[data-theme="light"] input[style*="background:#1a1a1a"],
html[data-theme="light"] select[style*="background:#0e0e0e"],
html[data-theme="light"] select[style*="background:#1a1a1a"] { background:var(--card-bg) !important; color:var(--text) !important; border-color:var(--border) !important; }
html[data-theme="light"] [style*="color:#aaa"],
html[data-theme="light"] [style*="color:#bbb"],
html[data-theme="light"] [style*="color:#ccc"],
html[data-theme="light"] [style*="color:#ddd"] { color:#374151 !important; }

/* Form-felter, tabeller og kort */
html[data-theme="light"] .form-control { background:var(--card-bg); color:var(--text); border-color:var(--border); }
html[data-theme="light"] .form-control:focus { border-color:var(--accent); }
html[data-theme="light"] .form-control::placeholder { color:var(--text-muted); opacity:0.7; }
/* Statistikk/MEP — klasse-baserte mørke farger som må følge lyst tema */
html[data-theme="light"] .stat-table thead th { background:#eef1f5; }
html[data-theme="light"] .stat-table tbody tr:hover td { background:rgba(0,0,0,0.035); }
html[data-theme="light"] .mep-sparkline-section { background:var(--row-hover); }
html[data-theme="light"] .btn-secondary { background:var(--card-bg); color:var(--text); border:1px solid var(--border); }
html[data-theme="light"] .btn-secondary:hover { background:#f0f4f8; }
html[data-theme="light"] .btn-primary { background:var(--accent); color:#fff; }
html[data-theme="light"] .btn-primary:hover { background:var(--accent-dim); }

/* Oppslagstavle / Meldinger */
html[data-theme="light"] .postit p { color:#374151; }
html[data-theme="light"] .postit-author { background:#eef2f6; color:#475569; }
html[data-theme="light"] .attachment-pill { background:#eef2f6; color:#374151; border-color:var(--border); }
html[data-theme="light"] .attachment-pill:hover { background:#e6eaef; color:var(--accent); border-color:var(--accent); }
html[data-theme="light"] .role-badge.admin { background:rgba(15,122,79,0.14); color:#065f46; }
html[data-theme="light"] .announcement-body p { color:#374151; }
html[data-theme="light"] .announcement-actions button { background:var(--card-bg); color:var(--text); border-color:var(--border); }

/* Medlemsregister — rolle-/konto-badges */
html[data-theme="light"] .reg-badge { background:#eef2f6; color:#374151; border-color:var(--border); }
html[data-theme="light"] .reg-badge.super { background:rgba(249,115,22,0.16); color:#9a3412; border-color:transparent; }
html[data-theme="light"] .reg-badge.play { background:rgba(59,130,246,0.14); color:#1e40af; border-color:transparent; }
html[data-theme="light"] .reg-badge.plat { background:rgba(168,85,247,0.16); color:#6b21a8; border-color:transparent; }
html[data-theme="light"] .reg-flag.info { background:#eef2f6; color:#374151; }
html[data-theme="light"] .reg-flag.warn { background:rgba(234,179,8,0.16); color:#92400e; }
html[data-theme="light"] .reg-flag.err { background:rgba(239,68,68,0.14); color:#991b1b; }
html[data-theme="light"] .reg-tip { background:var(--card-bg); border-color:var(--border); color:var(--text); box-shadow:0 6px 24px rgba(17,24,39,0.12); }
html[data-theme="light"] .reg-row-warn td { background:rgba(234,179,8,0.06); }
html[data-theme="light"] .reg-row-err td { background:rgba(239,68,68,0.05); }
html[data-theme="light"] .acct.on  { background:rgba(15,122,79,0.12); color:#065f46; }
html[data-theme="light"] .acct.inv { background:rgba(183,121,31,0.14); color:#92400e; }
html[data-theme="light"] .acct.off { background:#eef2f6; color:#475569; }

/* Treningsplan-grid */
html[data-theme="light"] .tg-header { background:#eef2f6; color:var(--text-muted); }
html[data-theme="light"] .tg-label { background:#f0f4f8; color:var(--text-muted); }
html[data-theme="light"] .tg-cell { background:var(--card-bg); border-color:var(--border); }
html[data-theme="light"] .tg-event { background:rgba(249,115,22,0.10); color:#7c2d12; border-left-color:var(--accent); }
html[data-theme="light"] .tg-event.green { background:rgba(15,122,79,0.10); color:#064e3b; }
html[data-theme="light"] .tg-event.blue { background:rgba(59,130,246,0.10); color:#1e3a8a; }

/* Booking-kalender + admin */
html[data-theme="light"] .bk-dh { background:#eef2f6; color:var(--text-muted); }
html[data-theme="light"] .bk-day { background:var(--card-bg); }
html[data-theme="light"] .bk-day:hover { background:#f0f4f8; }
html[data-theme="light"] .bk-ev { color:#1a1f2c; }
html[data-theme="light"] .bk-ev b { color:#0b1220; font-weight:700; }
html[data-theme="light"] .bk-ev .bk-sport { background:rgba(0,0,0,0.10); color:#1a1f2c; }
html[data-theme="light"] .bk-ev.blocked { background:repeating-linear-gradient(45deg,#e6eaef,#e6eaef 6px,#f0f4f8 6px,#f0f4f8 12px) !important; border-left-color:#9ca3af !important; color:#374151; }
html[data-theme="light"] .bk-note { background:#f8f9fb; color:var(--text-muted); }
html[data-theme="light"] .bka-node { background:var(--card-bg); }
html[data-theme="light"] .bka-l2 { background:#f8f9fb; }
html[data-theme="light"] .bka-l3 { background:#fafbfd; }
html[data-theme="light"] .bka-chip { background:var(--card-bg); color:var(--text-muted); }
html[data-theme="light"] .bka-chip.on { background:rgba(15,122,79,0.10); color:var(--text); border-color:var(--accent); }
html[data-theme="light"] .bka-approver { background:var(--card-bg); }
html[data-theme="light"] .bka-fieldgrid label { background:var(--card-bg); }
html[data-theme="light"] .bka-tag { background:#eef2f6; color:#475569; }
html[data-theme="light"] .bka-iconbtn { background:var(--card-bg); color:var(--text-muted); border-color:var(--border); }
html[data-theme="light"] .bka-iconbtn:hover { color:var(--text); border-color:#9ca3af; background:#f8f9fb; }

/* Kjøregodtgjørelse */
html[data-theme="light"] .km-table th { background:#eef2f6; color:var(--text-muted); }
html[data-theme="light"] .km-table input[type=text],
html[data-theme="light"] .km-table input[type=number],
html[data-theme="light"] .km-table input[type=date] { background:var(--card-bg); color:var(--text); border-color:var(--border); }
html[data-theme="light"] .km-total-row td { background:#f0f4f8; color:var(--text); }
html[data-theme="light"] .km-sigpad { background:var(--card-bg); border:1px dashed #b6bdc6; }
html[data-theme="light"] .km-hist { background:var(--card-bg); }
html[data-theme="light"] .kma-sigblock { background:#f8f9fb; }

/* Cup + diverse chips */
html[data-theme="light"] .cup-toggle button.active { background:rgba(15,122,79,0.10); color:var(--text); }
html[data-theme="light"] .cup-bm-meta { background:#f0f4f8; }

/* Trener-brief (gradient-kort med stat-bokser) */
html[data-theme="light"] .trener-brief { background:linear-gradient(180deg, #ffffff 0%, #f6fbff 100%); border-color:var(--border); border-left:3px solid #0891b2; box-shadow:0 1px 3px rgba(17,24,39,0.04); }
html[data-theme="light"] .tb-eyebrow { color:#0891b2; }
html[data-theme="light"] .tb-stat { background:#f6fbff; border-color:var(--border); }
html[data-theme="light"] .tb-stat-val { color:var(--text); }
html[data-theme="light"] .tb-stat.good .tb-stat-val { color:#0F7A4F; }
html[data-theme="light"] .tb-stat.bad .tb-stat-val { color:#dc2626; }
html[data-theme="light"] .tb-stat.muted .tb-stat-val { color:#6b7280; }
html[data-theme="light"] .tb-stat.info .tb-stat-val { color:#d97706; }
html[data-theme="light"] .tb-ins { background:#f6fbff; border-color:var(--border); }
html[data-theme="light"] .tb-sync { background:rgba(8,145,178,0.08); border-color:rgba(8,145,178,0.25); color:#0891b2; }
html[data-theme="light"] .tb-sync:hover { background:rgba(8,145,178,0.15); }

/* Treningssaldo-stripen (Mistet/Hentet/Netto tap) */
html[data-theme="light"] .balance-bar { background:#eef2f6; color:var(--text-muted); border-color:var(--border); }
html[data-theme="light"] .balance-team { color:var(--text); }
html[data-theme="light"] .balance-hint { color:var(--text-muted); }
/* User-pill (initialer) — lys grå på lys bg for kontrast med ellers hvit bakgrunn */
html[data-theme="light"] .user-pill { background:#eef2f6; color:var(--text); border-color:var(--border); }

/* ── LAG-VELGER (foreldre med flere barn / stab på flere lag) ──────────── */
.team-switcher { position: relative; }
.team-switcher-btn {
  display: inline-flex; align-items: center; gap: 4px;
  background: var(--card-bg); border: 1px solid var(--border);
  color: var(--text); border-radius: 8px;
  padding: 6px 10px; font-size: 0.82rem; font-weight: 500;
  cursor: pointer; transition: background 0.15s;
  max-width: 180px;
}
.team-switcher-btn:hover { background: var(--bg); }
.team-switcher-btn #team-switcher-label {
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 140px;
}
.team-switcher-menu {
  position: absolute; top: calc(100% + 4px); right: 0;
  background: var(--card-bg); border: 1px solid var(--border);
  border-radius: 10px; padding: 4px; min-width: 200px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.35);
  z-index: 1000;
}
html[data-theme="light"] .team-switcher-menu { box-shadow: 0 8px 24px rgba(17,24,39,0.12); }
.team-switcher-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 12px; border-radius: 6px; cursor: pointer;
  font-size: 0.85rem; color: var(--text);
  white-space: nowrap;
}
.team-switcher-item:hover { background: var(--bg); }
.team-switcher-item.active { background: rgba(59,130,246,0.12); color: var(--blue); font-weight: 600; }
.team-switcher-item .team-switcher-role {
  font-size: 0.7rem; color: var(--text-muted);
  margin-left: 8px; text-transform: lowercase;
}
.team-switcher-item.active .team-switcher-role { color: var(--blue); opacity: 0.75; }

/* Medlemsregister — sorterbare kolonne-headere */
.mem-sort-th { cursor: pointer; user-select: none; transition: color 0.15s; white-space: nowrap; }
.mem-sort-th:hover { color: var(--text); }
.mem-sort-th:hover .mem-sort-ico { color: var(--text); }
.mem-sort-ico { font-size: 0.7rem; margin-left: 2px; }
/* Logout-knapp — gi litt mer synlig kontrast i lys modus */
html[data-theme="light"] .user-logout-btn { color:var(--text); border-color:#cbd5e1; }
html[data-theme="light"] .user-logout-btn:hover { color:#dc2626; border-color:#dc2626; background:rgba(220,38,38,0.06); }

/* ── Mobil-spesifikke overrides ─────────────────────────────────────── */
/* FAB (+ ny melding-knappen) — hardkodet color:#0d0d0d blir usynlig på lys bg */
html[data-theme="light"] .fab { color:#fff; box-shadow:0 6px 18px rgba(17,24,39,0.15); }
/* Bottom nav-hover/active */
html[data-theme="light"] .more-item:hover { background:rgba(15,122,79,0.06); }
html[data-theme="light"] .more-grip { background:#cbd2da; }
/* Player-kort i mobil-grid (#1a1a1a hardkodet) */
html[data-theme="light"] .player-card { background:var(--card-bg); border-color:var(--border); }
/* Safe-area-stripen øverst på iPhone (statusbar bakgrunn) */
html[data-theme="light"] .safe-top { background:var(--card-bg); }
/* Bottom-nav-bakgrunn i lys modus */
html[data-theme="light"] .bottom-nav { background:var(--card-bg); border-top-color:var(--border); }
/* Mer-arket */
html[data-theme="light"] .more-sheet { background:var(--card-bg); border-top-color:var(--border); }
html[data-theme="light"] .more-sheet-overlay { background:rgba(17,24,39,0.45); }
/* Komprimer tema-velgeren litt for mer-arket */
.more-sheet .theme-toggle { gap:0; }
.more-sheet .theme-toggle button { padding:5px 9px; font-size:0.85rem; }

/* Tema-velger i headeren */
.theme-toggle { display:inline-flex; border:1px solid var(--border); border-radius:8px; overflow:hidden; }
.theme-toggle button {
  background:none; border:none; border-right:1px solid var(--border);
  color:var(--text-muted); font-size:0.78rem; font-weight:600;
  padding:6px 10px; cursor:pointer; transition:all .15s;
  display:inline-flex; align-items:center; gap:4px;
}
.theme-toggle button:last-child { border-right:none; }
.theme-toggle button.active { background:var(--accent); color:#fff; }
html[data-theme="light"] .theme-toggle button.active { color:#fff; }

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Segoe UI', system-ui, sans-serif;
  min-height: 100vh;
  font-size: 15px;
}

a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ── HEADER ───────────────────────────────── */
.app-header {
  background: var(--card-bg);
  border-bottom: 2px solid var(--accent);
  padding: 12px 20px;
  display: flex;
  align-items: center;
  gap: 14px;
  position: sticky;
  top: 0;
  z-index: 200;
}
.app-header .logo { height: 48px; width: auto; }
.app-header .title h1 { font-size: 1.2rem; color: var(--accent); font-weight: 700; line-height: 1.2; }
.app-header .title p  { font-size: 0.75rem; color: var(--text-muted); }
.app-header .header-right { margin-left: auto; display: flex; align-items: center; gap: 10px; }
.user-pill {
  font-size: 0.78rem; font-weight: 700; letter-spacing: 0.3px;
  color: var(--text);
  /* Tema-bevisst — auto-bytter med data-theme. I lys modus brukes
     en lys-grå (#eef2f6) overstyring lenger ned, ellers var(--card-bg). */
  background: var(--card-bg); border: 1px solid var(--border);
  border-radius: 20px; padding: 4px 10px;
  display: inline-flex; align-items: center;
  cursor: default;
}
.user-pill:hover { border-color: var(--accent); }

/* Dedikert logout-knapp ved siden av initial-pillen */
.user-logout-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 30px; height: 30px;
  background: none; border: 1px solid var(--border);
  border-radius: 50%; color: var(--text-muted);
  cursor: pointer; transition: all 0.15s; padding: 0;
}
.user-logout-btn:hover {
  border-color: #f87171; color: #f87171;
  background: rgba(248,113,113,0.08);
}

/* ── NAV TABS ─────────────────────────────── */
.app-nav {
  background: var(--card-bg);
  border-bottom: 1px solid var(--border);
  padding: 0 20px;
  display: flex;
  gap: 0;
  overflow-x: auto;
}
.app-nav a {
  color: var(--text-muted);
  padding: 12px 18px;
  font-size: 0.85rem;
  font-weight: 500;
  border-bottom: 3px solid transparent;
  white-space: nowrap;
  cursor: pointer;
  transition: color 0.15s;
}
.app-nav a.active { color: var(--text); border-bottom-color: var(--accent); }
.app-nav a:hover  { color: var(--text); text-decoration: none; }

/* ── MAIN ─────────────────────────────────── */
.app-main { padding: 20px; max-width: 1400px; margin: 0 auto; }

/* Tab content */
.tab-pane { display: none; }
.tab-pane.active { display: block; }

/* ── BUTTONS ──────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px; border-radius: 8px; border: none;
  cursor: pointer; font-size: 0.85rem; font-weight: 600;
  transition: background 0.15s, opacity 0.15s;
  white-space: nowrap;
}
.btn:disabled { opacity: 0.4; cursor: not-allowed; }
.btn-primary   { background: var(--accent); color: #0d0d0d; }
.btn-primary:hover:not(:disabled) { background: var(--accent-dim); }
.btn-secondary { background: #1e1e1e; color: var(--text); border: 1px solid var(--border); }
.btn-secondary:hover:not(:disabled) { background: #2a2a2a; }
.btn-danger    { background: rgba(239,68,68,0.15); color: #f87171; border: 1px solid rgba(239,68,68,0.3); }
.btn-danger:hover:not(:disabled) { background: rgba(239,68,68,0.3); }
.btn-success   { background: rgba(34,197,94,0.15); color: #4ade80; border: 1px solid rgba(34,197,94,0.3); }
.btn-success:hover:not(:disabled) { background: rgba(34,197,94,0.3); }
.btn-sm { padding: 5px 10px; font-size: 0.75rem; }

/* ── STATS ROW ────────────────────────────── */
.stats-row {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 12px;
  margin-bottom: 24px;
}
.stat-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 16px;
}
.stat-label { font-size: 0.7rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.4px; }
.stat-value { font-size: 1.5rem; font-weight: 700; color: var(--accent); margin-top: 4px; }
.stat-sub   { font-size: 0.72rem; color: var(--text-muted); margin-top: 2px; }

/* ── TRENER-BRIEF (auto fra Spond — kun coach/team_leader/admin) ── */
/* Bruker <details>+<summary> som «Slik bruker du klubb-felles»-mønsteret. */
.trener-brief {
  background: rgba(6,182,212,0.05);
  border: 1px solid rgba(6,182,212,0.25);
  border-radius: 8px;
  margin-bottom: 16px;
}
.trener-brief[open] {
  background: linear-gradient(180deg, #131a22 0%, #10161c 100%);
  border-color: var(--border);
  border-left: 3px solid #06b6d4;
}
.tb-summary {
  cursor: pointer;
  padding: 9px 14px;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  font-weight: 500;
  color: #67e8f9;
  flex-wrap: wrap;
}
.tb-summary::-webkit-details-marker { display: none; }
.tb-summary::before {
  content: '▸';
  font-size: 0.7rem;
  opacity: 0.7;
  transition: transform 0.15s;
}
.trener-brief[open] .tb-summary { color: #67e8f9; padding-bottom: 4px; }
.trener-brief[open] .tb-summary::before { transform: rotate(90deg); }
.tb-summary .tb-bot { font-size: 0.95rem; }
.tb-summary-main { flex: 1; min-width: 0; color: var(--text); font-weight: 400; display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; }
.tb-summary-main strong { color: #67e8f9; font-weight: 700; }
.tb-s-countdown { font-size: 0.72rem; color: var(--text-muted); }
.tb-s-nums { color: var(--text-muted); font-size: 0.78rem; }
.tb-s-bad { color: #f87171; font-weight: 600; }
.tb-s-fresh { color: #fca5a5; font-weight: 600; }
.tb-summary-hint { font-size: 0.72rem; color: var(--text-muted); font-weight: 400; }
.tb-body { padding: 8px 18px 14px; border-top: 1px solid rgba(6,182,212,0.15); margin-top: 4px; }
.tb-head { display:flex; align-items:flex-start; gap:12px; margin: 10px 0 14px; flex-wrap:wrap; }
.tb-head-meta { flex:1; min-width:0; }
.tb-eyebrow { display:flex; align-items:center; gap:6px; font-size:0.66rem; text-transform:uppercase; letter-spacing:0.6px; color:#06b6d4; font-weight:600; margin-bottom:3px; }
.tb-eyebrow .tb-bot { font-size:0.82rem; }
.tb-title-sub { font-size: 0.82rem; color: var(--text-muted); }
.tb-head-actions { display:flex; gap:6px; align-items:center; flex-shrink:0; }
.tb-sync {
  background:rgba(6,182,212,0.08); border:1px solid rgba(6,182,212,0.25);
  color:#67e8f9; font-size:0.7rem; padding:4px 10px; border-radius:6px;
  cursor:pointer; display:inline-flex; align-items:center; gap:5px;
  font-variant-numeric:tabular-nums;
}
.tb-sync:hover { background:rgba(6,182,212,0.15); }
.tb-sync:disabled { cursor:wait; opacity:0.7; }
.tb-role-note { font-size:0.66rem; color:var(--text-muted); padding:3px 8px; border:1px dashed var(--border); border-radius:6px; }

.tb-stats { display:grid; grid-template-columns:repeat(4, 1fr); gap:8px; margin-bottom:14px; }
.tb-stat {
  background:rgba(255,255,255,0.025); border:1px solid var(--border);
  border-radius:8px; padding:10px 12px; text-align:center;
}
.tb-stat-val { font-size:1.5rem; font-weight:800; line-height:1; font-variant-numeric:tabular-nums; }
.tb-stat-lab { font-size:0.66rem; text-transform:uppercase; letter-spacing:0.4px; color:var(--text-muted); margin-top:5px; }
.tb-stat.good  .tb-stat-val { color:#22c55e; }
.tb-stat.bad   .tb-stat-val { color:#f87171; }
.tb-stat.muted .tb-stat-val { color:#cbd5e1; }
.tb-stat.info  .tb-stat-val { color:#fbbf24; }

.tb-insights { display:flex; flex-direction:column; gap:6px; margin-bottom:14px; }
.tb-ins {
  display:flex; gap:8px; align-items:flex-start;
  background:rgba(255,255,255,0.02); border:1px solid var(--border);
  border-radius:8px; padding:8px 12px; font-size:0.82rem; line-height:1.4;
}
.tb-ins strong { font-weight:700; }
.tb-ins.alert { background:rgba(248,113,113,0.07); border-color:rgba(248,113,113,0.25); color:#fecaca; }
.tb-ins.alert strong { color:#fca5a5; }
.tb-ins.warn  { background:rgba(251,191,36,0.06); border-color:rgba(251,191,36,0.22); }
.tb-ins .tb-ins-ico { flex-shrink:0; font-size:0.95rem; line-height:1.3; }

.tb-foot { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.tb-foot .btn { font-size:0.78rem; padding:6px 14px; }
.tb-foot .tb-spacer { flex:1; }
.tb-foot .tb-last { font-size:0.7rem; color:var(--text-muted); }

.tb-empty-state {
  text-align:center; padding:24px 16px; color:var(--text-muted); font-size:0.85rem;
}
.tb-empty-state .tb-empty-ico { font-size:1.8rem; margin-bottom:6px; }

/* Detalj-modal: faner + spiller-rader */
.tb-tabs { display:flex; gap:0; border-bottom:1px solid var(--border); margin-bottom:14px; overflow-x:auto; }
.tb-tab {
  padding:9px 14px; font-size:0.78rem; font-weight:500;
  color:var(--text-muted); cursor:pointer; border:none;
  border-bottom:2px solid transparent; background:none; transition:all 0.15s;
  white-space:nowrap; display:flex; align-items:center; gap:6px;
}
.tb-tab.active { color:#06b6d4; border-bottom-color:#06b6d4; }
.tb-tab .tb-tab-count {
  background:rgba(255,255,255,0.06); color:var(--text); padding:1px 7px;
  border-radius:8px; font-size:0.68rem; font-weight:700; font-variant-numeric:tabular-nums;
}
.tb-tab.active .tb-tab-count { background:rgba(6,182,212,0.18); color:#67e8f9; }

.tb-rows { display:flex; flex-direction:column; gap:5px; max-height:55vh; overflow-y:auto; }
.tb-row {
  display:flex; align-items:center; gap:10px; padding:9px 12px;
  background:rgba(255,255,255,0.025); border:1px solid var(--border);
  border-radius:8px;
}
.tb-row-num {
  width:32px; flex-shrink:0; text-align:center; font-size:0.74rem; font-weight:700;
  color:var(--text-muted); font-variant-numeric:tabular-nums;
}
.tb-row-main { flex:1; min-width:0; }
.tb-row-name { font-size:0.88rem; font-weight:600; }
.tb-row-meta { font-size:0.72rem; color:var(--text-muted); margin-top:2px; }
.tb-row-meta.warn { color:#fca5a5; }
.tb-row-time {
  font-size:0.72rem; color:var(--text-muted); font-variant-numeric:tabular-nums;
  flex-shrink:0; text-align:right;
}
.tb-row-time.fresh { color:#fca5a5; font-weight:600; }
.tb-empty-list { text-align:center; padding:30px 10px; color:var(--text-muted); font-size:0.85rem; }

@media (max-width: 640px) {
  .tb-stats { grid-template-columns:repeat(2, 1fr); }
  .tb-body { padding: 8px 12px 12px; }
  .tb-head-actions { width:100%; justify-content:space-between; margin-top:4px; }
  .tb-summary-hint { display: none; } /* spar plass på telefon */
}

/* ── ARCHIVE TOGGLE ──────────────────────── */
.archive-toggle {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  border-radius: 20px;
  border: 1px solid var(--border);
  background: none;
  color: var(--text-muted);
  font-size: 0.75rem;
  cursor: pointer;
  transition: all 0.15s;
  white-space: nowrap;
  margin-bottom: 4px;
}
.archive-toggle.active {
  border-color: #60a5fa;
  color: #60a5fa;
  background: rgba(96,165,250,0.08);
}
.archive-toggle .toggle-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--border);
  flex-shrink: 0;
  transition: background 0.15s;
}
.archive-toggle.active .toggle-dot { background: #60a5fa; }

/* ── PINNED BANNER ────────────────────────── */
.pinned-banner {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 20px;
  display: flex; align-items: flex-start; gap: 12px;
}
.pinned-banner .pin-icon { font-size: 1.1rem; margin-top: 2px; flex-shrink: 0; }
.pinned-banner h4 { font-size: 0.9rem; margin-bottom: 3px; }
.pinned-banner p  { font-size: 0.8rem; color: #bbb; line-height: 1.4; }

.announcement-banner {
  background: rgba(249,115,22,0.07);
  border: 1px solid rgba(249,115,22,0.35);
  border-left: 4px solid #f97316;
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 20px;
  display: flex; align-items: flex-start; gap: 12px;
  position: relative;
}
.announcement-icon { font-size: 1.2rem; margin-top: 2px; flex-shrink: 0; }
.announcement-body { flex: 1; }
.announcement-label {
  font-size: 0.62rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.6px; color: #f97316; margin-bottom: 4px;
}
.announcement-body h4 { font-size: 0.9rem; color: var(--accent); margin-bottom: 3px; }
.announcement-body p  { font-size: 0.8rem; color: #bbb; line-height: 1.4; }
.announcement-actions { display: flex; gap: 6px; flex-shrink: 0; margin-top: 2px; }
.announcement-actions button {
  background: none; border: 1px solid var(--border); border-radius: 6px;
  color: var(--text-muted); font-size: 0.72rem; padding: 3px 10px;
  cursor: pointer; transition: all 0.15s;
}
.announcement-actions button:hover { border-color: var(--accent); color: var(--accent); }
.announcement-actions .btn-remove:hover { border-color: var(--danger); color: #f87171; }

/* ── AUDIENCE TABS ────────────────────────── */
.audience-tabs {
  display: flex;
  border-bottom: 1px solid var(--border);
  margin-bottom: 0;
}
.aud-tab {
  background: none; border: none;
  border-bottom: 3px solid transparent;
  color: var(--text-muted); font-size: 0.95rem; font-weight: 600;
  padding: 10px 20px; cursor: pointer; transition: all 0.15s;
}
.aud-tab.active { color: var(--text); border-bottom-color: var(--accent); }
.aud-tab:hover  { color: var(--text); }

/* ── FILTER BAR ───────────────────────────── */
.filter-bar {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 10px 0 6px;
}
.filter-chip {
  padding: 5px 12px; border-radius: 20px;
  border: 1px solid var(--border); background: none;
  color: var(--text-muted); font-size: 0.75rem; cursor: pointer;
  transition: all 0.15s;
}
.filter-chip.active,
.filter-chip:hover {
  border-color: var(--accent); color: var(--accent);
  background: rgba(255,255,255,0.06);
}

/* ── EGENDEFINERT LAG-VELGER ───────────────── */
.team-picker { background: rgba(255,255,255,0.02); border: 1px solid var(--border); border-radius: 10px; padding: 12px 14px; }
.team-picker-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 8px; flex-wrap: wrap; }
.team-picker-head .label { font-size: 0.75rem; color: var(--text-muted); font-weight: 600; }
.team-count { font-weight: 400; color: var(--text-muted); font-size: 0.72rem; margin-left: 6px; }
.team-count.has-sel { color: var(--success); }
.linkbtn { background: none; border: none; color: var(--accent); cursor: pointer; font-size: 0.74rem; padding: 0; }
.linkbtn:hover { text-decoration: underline; }
.team-picker-actions .sep { color: var(--text-muted); margin: 0 7px; font-size: 0.72rem; }
.team-group { margin-top: 10px; }
.team-group-head { display: flex; align-items: center; justify-content: space-between; font-size: 0.68rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.5px; font-weight: 700; margin-bottom: 6px; }
.team-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.team-chip {
  padding: 5px 12px; border-radius: 20px; border: 1px solid var(--border);
  background: none; color: var(--text-muted); font-size: 0.78rem; cursor: pointer; transition: all 0.15s;
}
.team-chip:hover { border-color: var(--accent); color: var(--text); }
.team-chip.selected { border-color: var(--accent); color: var(--accent); background: rgba(255,255,255,0.08); }
.team-chip.selected::before { content: '\2713\00a0'; font-weight: 700; }

/* ── POST-IT GRID ─────────────────────────── */
.postit-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(270px, 1fr));
  gap: 14px;
  margin-top: 16px;
}

.postit {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 15px;
  cursor: pointer;
  position: relative;
  transition: transform 0.15s, box-shadow 0.15s;
}
.postit:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,0.4); }

/* Kategori-fargekoding — tydeligere enn ren 3px topp-stripe.
   Hver kategori får:
     • Tykk topp-stripe (5px) — primær signal-farge
     • Lett farget bakgrunns-tint så hele kortet «føles» kategorien
     • Matchende kategori-tag-farge (.postit-category)
   Kombinasjonen gjør oppslagstavla klart skannbar uten å bli skrikende. */
.postit-accent-white  { border-top: 5px solid var(--accent); }
.postit-accent-green {
  border-top: 5px solid var(--success);
  background: linear-gradient(rgba(34,197,94,0.07), rgba(34,197,94,0.07)), var(--card-bg);
}
.postit-accent-yellow {
  border-top: 5px solid var(--warning);
  background: linear-gradient(rgba(234,179,8,0.07), rgba(234,179,8,0.07)), var(--card-bg);
}
.postit-accent-red {
  border-top: 5px solid var(--danger);
  background: linear-gradient(rgba(239,68,68,0.07), rgba(239,68,68,0.07)), var(--card-bg);
}
.postit-accent-blue {
  border-top: 5px solid var(--blue);
  background: linear-gradient(rgba(59,130,246,0.07), rgba(59,130,246,0.07)), var(--card-bg);
}
.postit-accent-cyan {
  border-top: 5px solid var(--cyan);
  background: linear-gradient(rgba(6,182,212,0.07), rgba(6,182,212,0.07)), var(--card-bg);
}

/* Lys modus: litt sterkere tint så det fortsatt er lett å se forskjell
   mot den hvite kortbakgrunnen. */
html[data-theme="light"] .postit-accent-green {
  background: linear-gradient(rgba(34,197,94,0.09), rgba(34,197,94,0.09)), var(--card-bg);
}
html[data-theme="light"] .postit-accent-yellow {
  background: linear-gradient(rgba(234,179,8,0.10), rgba(234,179,8,0.10)), var(--card-bg);
}
html[data-theme="light"] .postit-accent-red {
  background: linear-gradient(rgba(239,68,68,0.09), rgba(239,68,68,0.09)), var(--card-bg);
}
html[data-theme="light"] .postit-accent-blue {
  background: linear-gradient(rgba(59,130,246,0.09), rgba(59,130,246,0.09)), var(--card-bg);
}
html[data-theme="light"] .postit-accent-cyan {
  background: linear-gradient(rgba(6,182,212,0.09), rgba(6,182,212,0.09)), var(--card-bg);
}

.postit-category {
  font-size: 0.65rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.5px;
  color: var(--text-muted); margin-bottom: 5px;
}
/* Kategori-tag tar farge av kortet (overstyrt av .postit-accent-*) */
.postit-accent-green  .postit-category { color: var(--success); }
.postit-accent-yellow .postit-category { color: var(--warning); }
.postit-accent-red    .postit-category { color: var(--danger);  }
.postit-accent-blue   .postit-category { color: var(--blue);    }
.postit-accent-cyan   .postit-category { color: var(--cyan);    }

/* ── SPOND-IMPORTERTE POSTER ──────────────────────────────────────────────
   Kun topp-linjen byttes til en pastell-mint (lysegrønn) farge. Selve
   kortet beholder vanlig hvit/mørk bakgrunn — eneste signal er den lyse
   grønne stripa på toppen + «📲 SPOND»-merket i kategori-raden. */
.postit-spond {
  border-top: 5px solid #86efac !important;       /* mint/lysegrønn — mørkt tema */
}
html[data-theme="light"] .postit-spond {
  border-top-color: #34d399 !important;            /* dypere mint i lys modus */
}

.postit-source-spond {
  display: inline-block;
  font-weight: 700;
  font-size: 0.62rem;
  letter-spacing: 0.3px;
  padding: 1px 6px;
  border-radius: 8px;
  background: rgba(134,239,172,0.20);      /* matchende mint-bg */
  color: #86efac;
  margin-left: 2px;
  vertical-align: middle;
}
html[data-theme="light"] .postit-source-spond {
  background: #D1FAE5;
  color: #047857;
}
.postit h3 { font-size: 0.95rem; margin-bottom: 8px; line-height: 1.3; }
.postit .short-text {
  font-size: 0.82rem; color: #bbb; line-height: 1.5;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}

.postit-meta {
  display: flex; align-items: center; gap: 6px;
  margin-top: 12px; flex-wrap: wrap;
}
.postit-date   { font-size: 0.7rem; color: var(--text-muted); }
.postit-author { font-size: 0.7rem; background: #1e1e1e; color: var(--text-muted); padding: 2px 8px; border-radius: 20px; }

.role-badge { font-size: 0.63rem; font-weight: 700; padding: 2px 7px; border-radius: 20px; text-transform: uppercase; }
.role-master_admin { background: rgba(239,68,68,0.2);   color: #f87171; }
.role-admin        { background: rgba(255,255,255,0.12); color: #ddd; }
.role-coach        { background: rgba(34,197,94,0.2);   color: var(--success); }
.role-team_leader  { background: rgba(59,130,246,0.2);  color: #60a5fa; }
.role-parent       { background: rgba(234,179,8,0.2);   color: var(--warning); }

.postit-actions {
  position: absolute; top: 10px; right: 10px;
  display: flex; gap: 4px; opacity: 0; transition: opacity 0.15s;
}
.postit:hover .postit-actions { opacity: 1; }
.action-btn {
  /* Tema-bevisst: bruker var(--card-bg) i stedet for hardkodet #1e1e1e
     så slett-knappen i hjørnet ikke står som en mørk firkant i lys modus. */
  background: var(--card-bg); border: 1px solid var(--border);
  color: var(--text-muted); width: 26px; height: 26px;
  border-radius: 6px; cursor: pointer; font-size: 0.75rem;
  display: flex; align-items: center; justify-content: center;
}
.action-btn:hover { background: var(--bg); color: var(--text); }
html[data-theme="light"] .action-btn { background:#F6F8FA; }
html[data-theme="light"] .action-btn:hover { background:#E6EAEF; }

/* Attachments */
.attachments { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 10px; }
.attachment-pill {
  display: inline-flex; align-items: center; gap: 4px;
  background: #1a1a1a; border: 1px solid var(--border);
  border-radius: 6px; padding: 3px 8px;
  font-size: 0.7rem; color: #aaa; cursor: pointer;
}
.attachment-pill:hover { border-color: var(--accent); color: var(--accent); }

/* Bildevedlegg: thumbnail på kortet, større i pop-up */
.msg-image {
  flex: 0 0 100%;
  width: 100%;
  max-height: 150px;
  object-fit: cover;
  object-position: center top;
  border-radius: 8px;
  border: 1px solid var(--border);
  display: block;
  cursor: pointer;
}
#detail-attachments .msg-image {
  max-height: 380px;
  object-fit: contain;
  object-position: center;
  background: #0a0a0a;
}
.comment .msg-image { max-height: 120px; }

/* Empty state */
.empty-state {
  text-align: center; padding: 48px 20px;
  color: var(--text-muted); font-size: 0.9rem;
}
.empty-state .empty-icon { font-size: 2.5rem; margin-bottom: 12px; opacity: 0.4; }

/* ── TRAINING CALENDAR ────────────────────── */
.training-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 8px;
}
.training-header h2 { font-size: 1.05rem; }

.training-note { font-size: 0.8rem; color: var(--text-muted); margin-bottom: 14px; }

.training-grid {
  display: grid;
  grid-template-columns: 110px repeat(7, 1fr);
  gap: 2px;
  font-size: 0.75rem;
  overflow-x: auto;
}
.tg-header {
  background: #1a1a1a; padding: 8px 4px;
  text-align: center; color: var(--text-muted);
  font-weight: 600; border-radius: 4px;
}
.tg-label {
  background: #1a1a1a; padding: 8px 10px;
  color: var(--text-muted); border-radius: 4px;
  display: flex; align-items: center; font-weight: 500;
}
.tg-cell {
  background: var(--card-bg); border: 1px solid var(--border);
  border-radius: 4px; padding: 4px; min-height: 54px;
}
.tg-event {
  border-radius: 3px; padding: 3px 5px;
  margin-bottom: 3px; font-size: 0.68rem; color: #ddd; line-height: 1.3;
}
.tg-event.orange { background: rgba(255,255,255,0.08); border-left: 2px solid var(--accent); }
.tg-event.green  { background: rgba(34,197,94,0.15);  border-left: 2px solid var(--success); }
.tg-event.blue   { background: rgba(59,130,246,0.15); border-left: 2px solid var(--blue); }
.tg-event.yellow { background: rgba(234,179,8,0.15);  border-left: 2px solid var(--warning); }
.tg-event.released { background: rgba(239,68,68,0.1); border-left: 2px solid var(--danger); opacity: 0.6; }
.tg-event.match { background: rgba(239,68,68,0.18); border-left: 3px solid #ef4444; color: #fecaca; font-weight: 600; }
.tg-event.match strong { color: #fff; }
.tg-event .tg-match-loc { font-weight: 400; color: var(--text-muted); font-size: 0.62rem; }
.tg-ha { display: inline-block; padding: 0 5px; border-radius: 3px; font-size: 0.62rem; font-weight: 700; margin-left: 2px; }
.tg-ha.home { background: rgba(34,197,94,0.28); color: #4ade80; }
.tg-ha.away { background: rgba(59,130,246,0.28); color: #60a5fa; }
.tg-event.clickable { cursor: pointer; }
.tg-event.clickable:hover { filter: brightness(1.3); }

/* Treningsplan: eget lag øverst, andre lag skjult bak en knapp */
.training-grid:not(.show-others) .tg-other { display: none; }
.tg-toggle-row { grid-column: 1 / -1; padding: 14px 4px 4px; }

/* Time slot modal table */
.ts-table { width: 100%; border-collapse: collapse; margin-bottom: 16px; }
.ts-table th { text-align: left; font-size: 0.7rem; color: var(--text-muted); text-transform: uppercase; padding: 6px 10px; border-bottom: 1px solid var(--border); }
.ts-table td { padding: 10px; border-bottom: 1px solid #1e1e1e; font-size: 0.85rem; vertical-align: middle; }
.ts-table tr:last-child td { border-bottom: none; }
.ts-mine td { background: rgba(255,255,255,0.03); }

/* Balance indicator */
.balance-bar {
  display: flex; align-items: center; flex-wrap: wrap; gap: 8px 14px;
  font-size: 0.8rem; color: var(--text-muted);
  background: #1a1a1a; border: 1px solid var(--border);
  border-radius: 8px; padding: 8px 14px; margin-bottom: 16px;
}
.balance-team { font-weight: 700; color: var(--text); }
.balance-stats { display: flex; flex-wrap: wrap; gap: 8px 14px; align-items: center; }
.bstat { display: inline-flex; align-items: baseline; gap: 5px; white-space: nowrap; }
.bstat .bs-label { color: var(--text-muted); }
.bstat .bs-val { font-weight: 700; color: var(--text); }
.balance-hint { font-size: 0.75rem; color: var(--text-muted); }
.balance-value { font-weight: 700; font-size: 1rem; }
.balance-value.positive { color: var(--danger); }
.balance-value.zero     { color: var(--success); }
.balance-value.negative { color: var(--success); }

/* ── MODALS ───────────────────────────────── */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.75);
  display: flex; align-items: center; justify-content: center;
  z-index: 300; padding: 16px;
  animation: fadeIn 0.15s ease;
}
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

.modal {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 24px;
  max-width: 580px; width: 100%;
  position: relative;
  max-height: 90vh; overflow-y: auto;
  animation: slideUp 0.2s ease;
}
@keyframes slideUp { from { transform: translateY(16px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

.modal-close {
  position: absolute; top: 14px; right: 14px;
  background: none; border: none; color: var(--text-muted);
  font-size: 1.4rem; cursor: pointer; line-height: 1;
}
.modal-close:hover { color: var(--text); }
.modal h2 { font-size: 1.1rem; margin-bottom: 4px; }
.modal-subtitle { font-size: 0.8rem; color: var(--text-muted); margin-bottom: 18px; }
.modal-footer { display: flex; gap: 8px; justify-content: flex-end; margin-top: 16px; border-top: 1px solid var(--border); padding-top: 16px; }
.modal-meta { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin: 10px 0 16px; padding-bottom: 14px; border-bottom: 1px solid var(--border); }

/* ── DETAIL MODAL + KOMMENTARER ───────────────── */
.detail-modal { display: flex; flex-direction: column; overflow: hidden; }
.detail-scroll { overflow-y: auto; flex: 1 1 auto; min-height: 0; margin-right: -8px; padding-right: 8px; }
.comments-section { margin-top: 22px; padding-top: 18px; border-top: 1px solid var(--border); }
.comments-header { font-size: 0.8rem; font-weight: 700; color: var(--text); margin-bottom: 14px; }
.comment-empty { font-size: 0.8rem; color: var(--text-muted); font-style: italic; }
.comment-list { display: flex; flex-direction: column; gap: 16px; }
.comment { display: flex; gap: 10px; }
.comment-avatar {
  flex: 0 0 auto; width: 30px; height: 30px; border-radius: 50%;
  background: #2a2a2a; color: #ddd; font-size: 0.68rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}
.comment-body { flex: 1; min-width: 0; }
.comment-head { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin-bottom: 3px; }
.comment-name { font-size: 0.78rem; font-weight: 700; color: var(--text); }
.comment-time { font-size: 0.68rem; color: var(--text-muted); }
.comment-text { font-size: 0.82rem; color: #ccc; line-height: 1.5; word-wrap: break-word; white-space: pre-line; }
.comment-actions { display: flex; gap: 16px; margin-top: 6px; }
.comment-action {
  background: none; border: none; color: var(--text-muted); font-size: 0.72rem;
  cursor: pointer; display: inline-flex; align-items: center; gap: 4px; padding: 0;
  transition: color 0.12s;
}
.comment-action:hover { color: var(--text); }
.comment-action.liked { color: #f87171; }
.comment-replies {
  margin-top: 16px; padding-left: 14px; border-left: 2px solid var(--border);
  display: flex; flex-direction: column; gap: 16px;
}
.comment-composer { flex: 0 0 auto; margin-top: 18px; padding-top: 16px; border-top: 1px solid var(--border); }
.reply-context {
  display: flex; align-items: center; gap: 8px; font-size: 0.72rem; color: var(--text-muted);
  background: #1a1a1a; border: 1px solid var(--border); border-radius: 6px; padding: 5px 10px; margin-bottom: 8px;
}
.reply-context strong { color: var(--text); font-weight: 600; }
.reply-context button { background: none; border: none; color: var(--text-muted); cursor: pointer; font-size: 0.85rem; margin-left: auto; }
.reply-context button:hover { color: var(--text); }
.composer-input {
  width: 100%; background: #0a0a0a; border: 1px solid var(--border); border-radius: 8px;
  color: var(--text); padding: 9px 12px; font-size: 0.83rem; outline: none; resize: vertical;
  min-height: 44px; font-family: inherit; line-height: 1.5;
}
.composer-input:focus { border-color: var(--accent); }
.composer-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-top: 8px; }
.composer-attach {
  background: #1a1a1a; border: 1px solid var(--border); color: #aaa;
  border-radius: 8px; padding: 6px 11px; cursor: pointer; font-size: 0.8rem; transition: border-color 0.15s, color 0.15s;
}
.composer-attach:hover { border-color: var(--accent); color: var(--accent); }
.composer-filename { font-size: 0.72rem; color: var(--text-muted); margin-top: 6px; }

/* ── FORMS ────────────────────────────────── */
.form-row   { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 12px; }
.form-group { flex: 1; min-width: 180px; }
.form-group label { display: block; font-size: 0.75rem; color: var(--text-muted); margin-bottom: 5px; font-weight: 500; }
.form-control {
  width: 100%; background: #0a0a0a; border: 1px solid var(--border);
  border-radius: 8px; color: var(--text); padding: 8px 12px;
  font-size: 0.85rem; outline: none; transition: border-color 0.15s;
  font-family: inherit;
}
.form-control:focus { border-color: var(--accent); }
textarea.form-control { resize: vertical; min-height: 80px; }
select.form-control   { cursor: pointer; }

.file-drop {
  border: 2px dashed var(--border); border-radius: 8px;
  padding: 16px; text-align: center; cursor: pointer;
  transition: border-color 0.15s, background 0.15s; margin-bottom: 10px;
}
.file-drop:hover { border-color: var(--accent); background: rgba(255,255,255,0.03); }
.file-drop p { font-size: 0.8rem; color: var(--text-muted); }
.file-drop p span { color: var(--accent); }

.file-list { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; }
.file-item {
  display: inline-flex; align-items: center; gap: 6px;
  background: #1a1a1a; border: 1px solid var(--border);
  border-radius: 6px; padding: 4px 10px; font-size: 0.75rem; color: #bbb;
}
.file-remove { color: var(--text-muted); cursor: pointer; }
.file-remove:hover { color: var(--danger); }

/* ── ADMIN PANEL ──────────────────────────── */
.admin-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 16px; margin-top: 16px;
}
.admin-card {
  background: var(--card-bg); border: 1px solid var(--border);
  border-radius: 12px; padding: 18px;
}
.admin-card h3 { font-size: 0.9rem; margin-bottom: 14px; color: var(--text-muted); text-transform: uppercase; font-size: 0.7rem; letter-spacing: 0.5px; }

.member-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 0; border-bottom: 1px solid #1a1a1a;
}
.member-row:last-child { border-bottom: none; }
.member-avatar {
  width: 32px; height: 32px; border-radius: 50%;
  background: #2a2a2a; display: flex; align-items: center; justify-content: center;
  font-size: 0.8rem; font-weight: 700; color: var(--text-muted); flex-shrink: 0;
}
.member-info { flex: 1; min-width: 0; }
.member-name { font-size: 0.85rem; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.member-email { font-size: 0.72rem; color: var(--text-muted); }

/* ── TOAST ────────────────────────────────── */
#toast-container {
  position: fixed; bottom: 20px; right: 20px;
  z-index: 999; display: flex; flex-direction: column; gap: 8px;
}
.toast {
  /* Tema-bevisst — bytter automatisk med data-theme.
     I lys modus brukes en lys grå (#eef2f6) overstyring lenger ned, ellers var(--card-bg). */
  background: var(--card-bg); border: 1px solid var(--border);
  border-radius: 10px; padding: 10px 16px;
  font-size: 0.85rem; color: var(--text);
  animation: slideUp 0.2s ease;
  max-width: 320px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.25);
}
.toast.success { border-color: var(--success); }
.toast.error   { border-color: var(--danger); color: #f87171; }
html[data-theme="light"] .toast { background:#ffffff; box-shadow:0 6px 20px rgba(17,24,39,0.12); }
html[data-theme="light"] .toast.error { color: #dc2626; }

/* ── ALERT-BANNERE i modaler (godkjenning-pending m.fl.) ──────────────────
   Bruker amber/warning-paletten, men leser var(--warning) så den justeres
   pent i begge tema. Brukes bl.a. i «Gi fra deg treningstid»-modalen.
   Brødtekst bruker solid lys/mørk farge (uten opacity) for solid kontrast
   mot amber-bakgrunnen — ellers blir teksten utvasket. */
.alert-pending-approval {
  background: rgba(234, 179, 8, 0.14);   /* mørkt tema: subtil amber-overlay */
  border: 1px solid rgba(234, 179, 8, 0.45);
  border-radius: 8px;
  padding: 16px;
  margin-bottom: 16px;
}
.alert-pending-approval .alert-title {
  color: #fde68a;                        /* lys amber — sterk kontrast på mørk bg */
  font-weight: 600;
  margin-bottom: 6px;
  font-size: 0.95rem;
}
.alert-pending-approval .alert-body {
  font-size: 0.9rem;
  color: #f5f5f5;                        /* nesten hvit — full lesbarhet */
  line-height: 1.5;
}
html[data-theme="light"] .alert-pending-approval {
  background: #FEF6E0;                   /* mild amber-bakgrunn */
  border-color: #E8C46A;
}
html[data-theme="light"] .alert-pending-approval .alert-title {
  color: #92400E;                        /* mørk amber for tittel på lys bg */
}
html[data-theme="light"] .alert-pending-approval .alert-body {
  color: #5C4408;                        /* mørk amber for tekst på lys bg */
}

/* ── LOGIN PAGE ───────────────────────────── */
.login-page {
  min-height: 100vh; display: flex;
  align-items: center; justify-content: center;
  padding: 20px;
}
.login-box {
  background: var(--card-bg); border: 1px solid var(--border);
  border-radius: 16px; padding: 32px; width: 100%; max-width: 380px;
}
.login-logo { height: 64px; margin: 0 auto 20px; display: block; }
.login-box h1 { font-size: 1.1rem; text-align: center; margin-bottom: 4px; }
.login-box p  { font-size: 0.8rem; color: var(--text-muted); text-align: center; margin-bottom: 24px; }

/* SUB-TABS */
.sub-tabs { display:flex; gap:0; border-bottom:1px solid var(--border); margin-bottom:20px; }
.sub-tab { padding:10px 16px; font-size:0.82rem; font-weight:500; color:var(--text-muted); cursor:pointer; border-bottom:3px solid transparent; background:none; border-top:none; border-left:none; border-right:none; transition:all 0.15s; }
.sub-tab.active { color:var(--accent); border-bottom-color:var(--accent); }
.sub-tab:hover { color:var(--text); }

/* ── OM LAGET: 3 HOVEDFANER + KORTGRID ─────────────────────────────────
   Erstatter den gamle flate sub-tabs-raden under Om laget. Tre store
   hovedfaner-knapper øverst, deretter et kortgrid med knappene innenfor
   den valgte gruppen. Hver knapp er en sub-tab i bunnen — så onclick-
   logikken i initSubTabs gjenbrukes uendret. */
.om-grupper { display:grid; grid-template-columns:repeat(auto-fit,minmax(120px,1fr)); gap:8px; margin-bottom:14px; }
.om-gruppe { background:var(--card-bg); border:1px solid var(--border); border-radius:11px; padding:11px 8px; display:flex; flex-direction:column; align-items:center; gap:3px; cursor:pointer; color:var(--text); font:inherit; transition:all 0.15s; }
.om-gruppe:hover { border-color:var(--text-muted); }
.om-gruppe.active { background:var(--accent); border-color:var(--accent); color:#0d0d0d; }
.om-gruppe .og-ic { font-size:1.2rem; line-height:1; }
.om-gruppe .og-lbl { font-size:0.85rem; font-weight:600; letter-spacing:0.1px; }

.om-knapper { display:grid; grid-template-columns:repeat(auto-fit,minmax(95px,1fr)); gap:8px; margin-bottom:22px; padding:14px; background:color-mix(in srgb, var(--card-bg) 60%, transparent); border:1px solid var(--border); border-radius:12px; }
.om-knapp { position:relative; background:var(--bg); border:1px solid var(--border); border-radius:9px; padding:11px 6px 9px; display:flex; flex-direction:column; align-items:center; gap:5px; cursor:pointer; color:var(--text); font:inherit; transition:all 0.15s; border-bottom-width:1px; }
.om-knapp:hover { border-color:var(--accent); transform:translateY(-1px); }
.om-knapp.active { background:color-mix(in srgb, var(--accent) 14%, var(--bg)); border-color:color-mix(in srgb, var(--accent) 50%, var(--border)); }
.om-knapp .ok-ic { font-size:1.25rem; line-height:1; color:var(--accent); }
.om-knapp .ok-lbl { font-size:0.74rem; font-weight:600; line-height:1.1; text-align:center; }
.om-knapp .mg-nav-badge { position:absolute; top:5px; right:6px; }

/* ── VIDEO-BIBLIOTEK (Om laget → Sport → Bibliotek) ────────────────────
   Trener limer inn URL fra Instagram/TikTok/YouTube/Vimeo → embed-kort
   med tittel, beskrivelse og pille-tagger. Fri-tag-filter øverst (sky),
   søk-felt, grid-layout som tilpasser seg bredden. */
.vl-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 6px; flex-wrap: wrap; }
.vl-add-btn { white-space: nowrap; }
.vl-intro { font-size: 0.85rem; color: var(--text-muted); margin: 0 0 16px; line-height: 1.5; }
.vl-filters { display: flex; flex-direction: column; gap: 10px; margin-bottom: 18px; }
.vl-search { background: var(--card-bg); border: 1px solid var(--border); border-radius: 9px; padding: 9px 13px; font-size: 0.88rem; color: var(--text); font-family: inherit; max-width: 400px; }
.vl-search:focus { outline: none; border-color: var(--accent); }
.vl-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.vl-tag-chip { background: var(--card-bg); border: 1px solid var(--border); border-radius: 999px; padding: 5px 12px; font-size: 0.76rem; font-weight: 600; color: var(--text-muted); cursor: pointer; font-family: inherit; transition: all 0.12s; display: inline-flex; align-items: center; gap: 5px; }
.vl-tag-chip:hover { border-color: var(--text-muted); color: var(--text); }
.vl-tag-chip.on { background: var(--accent); border-color: var(--accent); color: #0d0d0d; }
.vl-tag-count { font-weight: 500; opacity: 0.7; font-size: 0.7rem; }
.vl-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 16px; }
.vl-empty { grid-column: 1 / -1; text-align: center; padding: 40px 20px; color: var(--text-muted); font-size: 0.88rem; line-height: 1.6; }
.vl-card { background: var(--card-bg); border: 1px solid var(--border); border-radius: 12px; overflow: hidden; display: flex; flex-direction: column; }
.vl-card-embed { background: #0a0a0a; display: flex; align-items: center; justify-content: center; min-height: 180px; padding: 10px; }
.vl-card-embed > * { max-width: 100%; }
.vl-iframe-wrap { position: relative; width: 100%; padding-bottom: 56.25%; height: 0; }
.vl-iframe-wrap iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: 0; border-radius: 6px; }
/* Instagram-reels og TikTok er portrett-orientert — bruk 9:16-ish proporsjon
   (instagram-embed har egen interaksjons-UI, så gi den ekstra høyde). */
.vl-iframe-wrap.vl-iframe-ig { padding-bottom: 0; height: 600px; max-width: 540px; margin: 0 auto; background: #fff; border-radius: 8px; }
.vl-iframe-wrap.vl-iframe-tt { padding-bottom: 0; height: 740px; max-width: 325px; margin: 0 auto; }
/* V2: thumbnail som klikkbart kort (åpner videoen i ny fane) */
.vl-thumb-link { position: relative; display: block; width: 100%; max-width: 540px; margin: 0 auto; border-radius: 8px; overflow: hidden; line-height: 0; text-decoration: none; }
.vl-thumb-link img { width: 100%; height: auto; max-height: 540px; object-fit: cover; display: block; transition: transform 0.18s ease; }
.vl-thumb-link:hover img { transform: scale(1.02); }
.vl-thumb-link .vl-thumb-play { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 64px; height: 64px; border-radius: 50%; background: rgba(0, 0, 0, 0.55); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 1.6rem; pointer-events: none; backdrop-filter: blur(2px); }
/* Plakat-fallback når thumbnail mangler */
.vl-poster-link { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px; min-height: 220px; padding: 24px; background: linear-gradient(135deg, var(--card-bg) 0%, rgba(0, 0, 0, 0.04) 100%); border-radius: 8px; text-decoration: none; color: var(--text); text-align: center; }
.vl-poster-emoji { font-size: 2.4rem; }
.vl-poster-text { font-weight: 600; font-size: 0.95rem; }
.vl-poster-hint { font-size: 0.75rem; color: var(--text-muted); }
/* Thumbnail-uploader i modal */
.vl-thumb-drop { position: relative; border: 2px dashed var(--border); border-radius: 8px; min-height: 110px; padding: 14px; display: flex; align-items: center; justify-content: center; cursor: pointer; background: var(--input-bg, transparent); transition: border-color 0.15s; }
.vl-thumb-drop:hover, .vl-thumb-drop:focus-visible { border-color: var(--primary, var(--accent)); outline: none; }
.vl-thumb-empty { color: var(--text-muted); font-size: 0.82rem; text-align: center; line-height: 1.5; }
.vl-thumb-preview { max-width: 100%; max-height: 220px; border-radius: 6px; display: block; }
.vl-thumb-clear { position: absolute; top: 6px; right: 6px; width: 28px; height: 28px; border-radius: 50%; background: rgba(0, 0, 0, 0.65); color: #fff; border: 0; cursor: pointer; font-size: 0.85rem; line-height: 1; display: flex; align-items: center; justify-content: center; }
.vl-thumb-clear:hover { background: rgba(0, 0, 0, 0.85); }
.vl-card-body { padding: 13px 14px 14px; display: flex; flex-direction: column; gap: 7px; }
.vl-card-title-row { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; }
.vl-card-title { font-size: 0.95rem; font-weight: 700; margin: 0; color: var(--text); line-height: 1.3; flex: 1; min-width: 0; }
.vl-card-actions { display: flex; gap: 2px; flex-shrink: 0; }
.vl-card-edit, .vl-card-del { background: none; border: none; color: var(--text-muted); cursor: pointer; font-size: 0.95rem; padding: 2px 4px; }
.vl-card-edit:hover { color: var(--accent); }
.vl-card-del:hover { color: var(--danger); }
.vl-card-warn { background: rgba(234,179,8,0.10); border: 1px solid rgba(234,179,8,0.35); border-radius: 6px; padding: 6px 10px; font-size: 0.74rem; color: var(--warning); }
.vl-card-url { display: inline-block; font-size: 0.72rem; color: var(--text-muted); text-decoration: none; word-break: break-all; padding: 4px 8px; background: var(--bg); border: 1px solid var(--border); border-radius: 6px; max-width: 100%; }
.vl-card-url:hover { color: var(--accent); border-color: var(--accent); text-decoration: none; }
.vl-card-desc { font-size: 0.82rem; color: var(--text-muted); margin: 0; line-height: 1.5; }
.vl-card-tags { display: flex; flex-wrap: wrap; gap: 4px; }
.vl-card-tag { background: var(--bg); border: 1px solid var(--border); color: var(--text-muted); font-size: 0.7rem; font-weight: 600; padding: 2px 8px; border-radius: 999px; cursor: pointer; font-family: inherit; }
.vl-card-tag:hover { color: var(--text); border-color: var(--text-muted); }
.vl-card-meta { font-size: 0.7rem; color: var(--text-muted); margin-top: 2px; }
.vl-link-fallback { display: inline-flex; align-items: center; gap: 6px; padding: 10px 16px; background: rgba(34,197,94,0.12); color: var(--accent); border: 1px solid rgba(34,197,94,0.4); border-radius: 8px; text-decoration: none; font-size: 0.85rem; font-weight: 600; }
@media (max-width: 600px) {
  .vl-grid { grid-template-columns: 1fr; }
  .vl-card-embed { min-height: 220px; }
}

/* ⚙ Oppsett-knapp øverst i Lag-fanen — kun synlig for admin (vises via JS
   som fjerner inline style="display:none"). Default-display er inline-flex
   slik at button-tagen får sentrert ikon når den faktisk vises. */
.om-toolbar { display:flex; justify-content:flex-end; margin-bottom:8px; }
.om-cog { background:var(--card-bg); border:1px solid var(--border); border-radius:9px; width:36px; height:36px; display:inline-flex; align-items:center; justify-content:center; font-size:0.95rem; cursor:pointer; color:var(--text-muted); transition:all 0.15s; }
.om-cog:hover { color:var(--text); border-color:var(--text-muted); }
@media (max-width: 900px) {
  /* Mer kompakte knapper på mobil, men aldri mindre enn 80px så tekst rommer */
  .om-grupper { grid-template-columns:repeat(3,1fr); gap:6px; margin-bottom:10px; }
  .om-gruppe { padding:8px 4px; }
  .om-gruppe .og-ic { font-size:1.05rem; }
  .om-gruppe .og-lbl { font-size:0.74rem; }
  .om-knapper { grid-template-columns:repeat(2,1fr); gap:6px; padding:10px; margin-bottom:14px; }
  .om-knapp { padding:9px 4px 7px; }
  .om-knapp .ok-ic { font-size:1.1rem; }
  .om-knapp .ok-lbl { font-size:0.7rem; }
}

/* PLAYER CARDS */
.player-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); gap:12px; margin-top:4px; }
.player-card { background:var(--card-bg); border:1px solid var(--border); border-radius:10px; padding:14px 10px; text-align:center; cursor:pointer; transition:all 0.15s; overflow:hidden; min-width:0; color:var(--text); }
.player-card:hover { transform:translateY(-2px); box-shadow:0 4px 16px rgba(0,0,0,0.3); }
html[data-theme="light"] .player-card:hover { box-shadow:0 4px 16px rgba(17,24,39,0.10); }
/* Status-rammer: kun trener/lagleder ser disse (JS setter klassene basert på
   canSeeInjuryDetails). Mockup-stil:
     • Tydelig tykk topp-stripe (5px) — signal-fargen som ses ved første blikk
     • Tynn ramme på sidene/bunn (2px) i samme farge — så hele kortet «hører
       sammen» med toppen
     • Lett tint i bakgrunnen for skadet/ute
*/
.player-card.s-active  {
  border: 2px solid var(--success);
  border-top-width: 5px;
}
.player-card.s-injured {
  /* Litt mørkere gul ramme enn standard --warning så skadet-kortene
     skiller seg klart fra den lyse bakgrunnsfargen. */
  border: 2px solid #ca8a04;            /* amber-600 — mørkere enn --warning */
  border-top: 5px solid #ca8a04;
  background:
    linear-gradient(rgba(234,179,8,0.08), rgba(234,179,8,0.08)),
    var(--card-bg);
}
.player-card.s-out {
  border: 2px solid var(--danger);
  border-top-width: 5px;
  background:
    linear-gradient(rgba(239,68,68,0.08), rgba(239,68,68,0.08)),
    var(--card-bg);
}
/* Lys modus: bakgrunnen blir lett tonet i statusfargen, så topp-stripa må
   være mørkere enn både rammen og bakgrunnen for å virkelig stå frem.
   Vi bruker eksplisitte mørkere nyanser (Tailwind 700-skalaen) på toppen. */
html[data-theme="light"] .player-card.s-active {
  border-top-color: #15803d;          /* mørkere grønn */
}
html[data-theme="light"] .player-card.s-injured {
  /* Lys modus: ramme i mid-amber, topp i dyp amber for tydelig signal. */
  border-color: #B45309;              /* amber-700 — mørkere enn dark-mode */
  border-top-color: #92400E;          /* amber-800 — dypeste, kun topp */
  background:
    linear-gradient(rgba(234,179,8,0.10), rgba(234,179,8,0.10)),
    var(--card-bg);
}
html[data-theme="light"] .player-card.s-out {
  border-top-color: #991b1b;          /* mørkere rød */
  background:
    linear-gradient(rgba(239,68,68,0.08), rgba(239,68,68,0.08)),
    var(--card-bg);
}
.player-number { font-size:1.7rem; font-weight:800; color:var(--accent); line-height:1; margin-bottom:6px; }
.player-name { font-size:0.8rem; font-weight:600; margin-bottom:3px; overflow-wrap:anywhere; }
.player-pos  { font-size:0.7rem; color:var(--text-muted); margin-bottom:8px; overflow-wrap:anywhere; }
.player-badge { font-size:0.62rem; font-weight:700; text-transform:uppercase; padding:2px 8px; border-radius:10px; display:inline-block; }
.player-badge.active  { background:rgba(34,197,94,0.15);  color:var(--success); }
.player-badge.injured { background:rgba(234,179,8,0.15);   color:var(--warning); }
.player-badge.out     { background:rgba(239,68,68,0.15);   color:var(--danger);  }

/* MATCH TABLE */
.match-table { width:100%; border-collapse:collapse; }
.match-table th { text-align:left; font-size:0.68rem; font-weight:700; text-transform:uppercase; letter-spacing:0.4px; color:var(--text-muted); padding:6px 10px; border-bottom:1px solid var(--border); }
.match-table td { padding:10px; font-size:0.83rem; border-bottom:1px solid #1a1a1a; vertical-align:middle; }
.match-table tr:last-child td { border-bottom:none; }
.result-w { color:var(--success); font-weight:700; }
.result-l { color:var(--danger);  font-weight:700; }
.result-pending { color:var(--text-muted); font-style:italic; }
.home-badge  { font-size:0.65rem; background:rgba(255,255,255,0.08); padding:2px 7px; border-radius:4px; color:var(--text-muted); }
.away-badge  { font-size:0.65rem; background:rgba(249,115,22,0.1);   padding:2px 7px; border-radius:4px; color:#f97316; }
/* Mobil: kamp-kort i stedet for tabell */
.match-cards { display:none; flex-direction:column; gap:8px; margin-top:4px; }
.match-card { display:flex; align-items:center; justify-content:space-between; gap:12px; background:var(--card-bg); border:1px solid var(--border); border-radius:10px; padding:12px 14px; }
.match-card .mc-opp { font-size:0.9rem; font-weight:600; color:var(--text); }
.match-card .mc-meta { font-size:0.74rem; color:var(--text-muted); margin-top:3px; display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.match-card .mc-result { font-size:0.95rem; font-weight:700; white-space:nowrap; }
@media (max-width:640px) {
  #om-kamper .kamp-table-wrap { display:none; }
  #om-kamper .match-cards { display:flex; }
}

/* ── RESPONSIVE ───────────────────────────── */
.title-short { display: none; }
@media (max-width: 540px) {
  .title-full  { display: none; }
  .title-short { display: inline; }
}

@media (max-width: 768px) {
  .app-header { padding: 10px 14px; }
  .app-header .logo { height: 38px; }
  .app-header .title h1 { font-size: 1rem; }
  .app-main { padding: 14px; }
  .postit-grid { grid-template-columns: 1fr; }
  .training-grid { font-size: 0.62rem; grid-template-columns: 72px repeat(7,1fr); }
  .stats-row { grid-template-columns: repeat(2, 1fr); }
}

/* ── TRENING: dag-for-dag liste (mobil) ── */
.training-daylist { display: none; }
.dl-toggle-row { display: flex; justify-content: flex-end; margin-bottom: 12px; }
.dl-toggle { background: none; border: 1px solid var(--border); color: var(--text-muted); border-radius: 20px; padding: 6px 14px; font-size: 0.8rem; cursor: pointer; }
.dl-toggle.active { border-color: var(--accent); color: var(--accent); background: rgba(255,255,255,0.06); }
.day-card { background: var(--card-bg); border: 1px solid var(--border); border-radius: 12px; margin-bottom: 12px; overflow: hidden; }
.day-head { background: rgba(0,0,0,0.20); padding: 10px 14px; font-weight: 700; font-size: 0.9rem; display: flex; justify-content: space-between; align-items: center; }
html[data-theme="light"] .day-head { background: #eef2f6; color: var(--text); }
.day-head .dh-count { font-size: 0.72rem; color: var(--text-muted); font-weight: 500; }
.day-events { display: flex; flex-direction: column; }
.day-event { display: flex; align-items: center; gap: 12px; padding: 12px 14px; border-top: 1px solid var(--border); }
.day-event:first-child { border-top: none; }
.day-event .de-time { font-weight: 700; font-size: 0.85rem; color: var(--text); white-space: nowrap; min-width: 92px; }
.day-event .de-body { flex: 1; min-width: 0; }
.day-event .de-team { font-size: 0.84rem; font-weight: 600; }
.day-event .de-loc { font-size: 0.75rem; color: var(--text-muted); margin-top: 1px; }
.day-event.mine { background: rgba(255,255,255,0.04); }
html[data-theme="light"] .day-event.mine { background: rgba(15,122,79,0.04); }
.day-event.mine .de-team { color: var(--accent); }
.day-event.match { border-left: 3px solid #ef4444; background: rgba(239,68,68,0.08); }
.day-event.match .de-time { color: #fca5a5; }
.day-event.match.mine .de-team { color: #fff; }
.day-event.clickable { cursor: pointer; }
.day-empty { padding: 12px 14px; color: var(--text-muted); font-size: 0.8rem; font-style: italic; }
.de-moved { display: inline-block; margin-left: 6px; background: rgba(34,177,76,0.18); color: #22B14C; padding: 0 6px; border-radius: 4px; font-size: 0.68rem; font-weight: 700; vertical-align: middle; }
@media (max-width: 640px) {
  #tab-treningsplan .training-grid { display: none; }
  .training-daylist { display: block; }
  .balance-bar { flex-direction: column; align-items: flex-start; gap: 6px; }
  .balance-stats { width: 100%; justify-content: space-between; gap: 6px; }
}

/* ── MEDLEMSREGISTER mobil: kort + sammenleggbare filtre ── */
.reg-cardlist { display: none; flex-direction: column; gap: 8px; }
.reg-card { background: var(--card-bg); border: 1px solid var(--border); border-radius: 10px; padding: 12px 14px; cursor: pointer; }
.reg-card.reg-row-warn { border-left: 3px solid #eab308; }
.reg-card.reg-row-err { border-left: 3px solid #ef4444; }
.rc-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 6px; }
.rc-types { margin-bottom: 4px; }
.rc-meta { font-size: 0.8rem; color: var(--text-muted); }
.rc-contact { font-size: 0.8rem; color: var(--text-muted); margin-top: 2px; word-break: break-word; }
.rc-flags { margin-top: 6px; }
.reg-filter-toggle { display: none; }
.reg-collapse { display: block; }
@media (max-width: 640px) {
  #klubb-medlemmer .mem-table-wrap { display: none; }
  #klubb-medlemmer .reg-cardlist { display: flex; }
  #klubb-medlemmer .reg-filter-toggle { display: inline-flex; }
  #klubb-medlemmer .reg-collapse { display: none; }
  #klubb-medlemmer .reg-collapse.open { display: block; }
}

/* ── MOBIL-LAG: bunnmeny, slank topp, FAB, bunn-ark ── */
.bottom-nav, .fab, .safe-top { display: none; }
.safe-top { position: fixed; top: 0; left: 0; right: 0; height: env(safe-area-inset-top); background: var(--card-bg); z-index: 140; }
.more-sheet-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.6); z-index: 320; display: none; align-items: flex-end; }
.more-sheet-overlay.open { display: flex; }
.more-sheet { width: 100%; background: var(--card-bg); border-top: 1px solid var(--border); border-radius: 16px 16px 0 0; padding: 8px 12px calc(16px + env(safe-area-inset-bottom)); }
.more-grip { width: 38px; height: 4px; border-radius: 2px; background: var(--border); margin: 8px auto 12px; }
.more-item { display: flex; align-items: center; gap: 12px; width: 100%; text-align: left; background: none; border: none; color: var(--text); font-size: 0.95rem; padding: 13px 8px; cursor: pointer; border-radius: 8px; }
.more-item:hover { background: rgba(255,255,255,0.05); }
.more-item .mi-ico { font-size: 1.2rem; width: 24px; text-align: center; }
/* FAB-arkets tittel — speiler Spond-stilen («Hva vil du gjøre?») */
.fab-sheet-title { font-size: 0.74rem; font-weight: 700; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: 0.4px; padding: 2px 8px 10px; }

@media (max-width: 900px) {
  /* Topp-nav er duplikat av bunn-nav på smalere skjerm — bunn-nav viser
     samme items (Tavle/Trening/Lag/Filer/Mer) som ikoner. Skjul topp-raden
     for å frigjøre vertikal plass og fjerne forvirringen. */
  .app-nav { display: none; }
  /* Slank app-header: skjul både klubbnavn-overskrift og lag-subtittelen
     (begge er duplikat — lag-velgeren til høyre viser allerede lagnavnet,
     sesongen vises overalt ellers). Bare logo + tema + lag-velger igjen. */
  .app-header .title { display: none; }
  /* Header-right stables vertikalt på mobil: tema-velger øverst, lag-velger
     under. Beholder bare det som faktisk hører hjemme i headeren —
     kunngjøring/ny-melding/manual-knappen ligger uansett i FAB eller Mer. */
  .app-header { align-items: flex-start; padding: 10px 14px; }
  .app-header .header-right { display: flex; flex-direction: column; gap: 6px; align-items: flex-end; margin-left: auto; }
  .app-header .header-right > #btn-announcement,
  .app-header .header-right > #btn-new-post,
  .app-header .header-right > .user-logout-btn { display: none; }
  /* User-pill skjules på mobil hvis lag-velger vises (de overlapper logisk);
     velgeren har samme tilgang via klikk på avatar/initialer i Mer-arket. */
  .team-switcher:not([style*="display:none"]) ~ .user-pill { display: none; }
  body { padding-top: env(safe-area-inset-top); }
  .safe-top { display: block; }
  .app-main { padding-bottom: 88px; }

  .bottom-nav {
    display: flex; position: fixed; bottom: 0; left: 0; right: 0; z-index: 120;
    background: var(--card-bg); border-top: 1px solid var(--border);
    padding: 6px 4px calc(6px + env(safe-area-inset-bottom));
  }
  .bn-item { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 2px; background: none; border: none; color: var(--text-muted); cursor: pointer; font-size: 0.62rem; font-weight: 600; padding: 4px 2px; }
  .bn-item .bn-ico { font-size: 1.25rem; line-height: 1; }
  .bn-item.active { color: var(--accent); }

  .fab { display: flex; align-items: center; justify-content: center; position: fixed; right: 16px; bottom: 76px; z-index: 121; width: 52px; height: 52px; border-radius: 50%; border: none; cursor: pointer; background: var(--accent); color: #0d0d0d; font-size: 1.8rem; line-height: 1; box-shadow: 0 6px 18px rgba(0,0,0,0.45); }

  .modal-overlay { padding: 0; align-items: flex-end; }
  .modal { width: 100%; max-width: 100% !important; max-height: 92vh; border-radius: 16px 16px 0 0; }

  .sub-tabs { overflow-x: auto; flex-wrap: nowrap; -webkit-overflow-scrolling: touch; }
  /* Om laget: la under-fanene brytes til flere linjer så «Trening» alltid er
     synlig på mobil (ellers havner den utenfor skjermen i den scrollende raden). */
  #tab-om .sub-tabs { flex-wrap: wrap; overflow-x: visible; row-gap: 2px; }
}

@media (min-width: 1200px) {
  .postit-grid { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }
}

/* ── SPOND-IMPORT ─────────────────────────── */
.spond-step {
  font-size: 0.82rem;
  font-weight: 600;
  margin: 14px 0 8px;
}
.spond-map-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 8px;
}
.spond-map-row {
  display: flex;
  flex-direction: column;
  gap: 3px;
  font-size: 0.72rem;
  color: var(--text-muted);
}
.spond-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px;
}
.spond-summary span {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 5px 10px;
  font-size: 0.78rem;
}
.spond-summary strong { color: var(--blue); }
.spond-table-wrap {
  max-height: 280px;
  overflow-y: auto;
  border: 1px solid var(--border);
  border-radius: 8px;
}
.spond-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.78rem;
}
.spond-table th,
.spond-table td {
  text-align: left;
  padding: 7px 10px;
  border-bottom: 1px solid var(--border);
}
.spond-table th {
  position: sticky;
  top: 0;
  background: var(--card-bg);
  color: var(--text-muted);
  font-size: 0.68rem;
  text-transform: uppercase;
}
.spond-table tr:last-child td { border-bottom: none; }
.spond-tag {
  font-size: 0.66rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 5px;
  white-space: nowrap;
}
.spond-insert { background: rgba(34,197,94,0.18);  color: #4ade80; }
.spond-update { background: rgba(59,130,246,0.18); color: #60a5fa; }
.spond-leader { background: rgba(249,115,22,0.18); color: #fb923c; }
.spond-warn {
  list-style: none;
  margin: 0 0 10px;
  padding: 8px 12px;
  background: rgba(234,179,8,0.1);
  border: 1px solid rgba(234,179,8,0.3);
  border-radius: 8px;
  font-size: 0.74rem;
  color: var(--warning);
}
.spond-warn li { margin: 2px 0; }
.spond-invite-opt {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  font-size: 0.8rem;
}

/* ── MEDLEMSREGISTER (Klubb) ── */
.klubb-pane { margin-top: 4px; }
.mem-table th { text-align: left; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.3px; color: var(--text-muted); padding: 8px 10px; border-bottom: 1px solid var(--border); }
.mem-table td { padding: 9px 10px; border-bottom: 1px solid var(--border); font-size: 0.85rem; vertical-align: top; }
.reg-badge { display: inline-block; font-size: 0.68rem; padding: 2px 7px; border-radius: 999px; background: #1e1e1e; border: 1px solid var(--border); color: var(--text-muted); margin: 1px 2px; white-space: nowrap; }
.reg-badge.super { background: rgba(249,115,22,0.16); color: var(--accent); border-color: transparent; }
.reg-badge.plat  { background: rgba(168,85,247,0.18); color: #c084fc; border-color: transparent; }
.reg-badge.play  { background: rgba(59,130,246,0.16); color: #60a5fa; border-color: transparent; }
.reg-flag { display: inline-block; font-size: 0.65rem; padding: 1px 7px; border-radius: 999px; margin: 2px 3px 0 0; white-space: nowrap; }
.reg-flag.err  { background: rgba(239,68,68,0.16); color: #f87171; }
.reg-flag.warn { background: rgba(234,179,8,0.16); color: #eab308; }
.reg-flag.info { background: #1e1e1e; color: var(--text-muted); }
.reg-row-warn td { background: rgba(234,179,8,0.05); }
.reg-row-err td  { background: rgba(239,68,68,0.06); }
.reg-name { font-weight: 600; color: var(--text); }
.reg-link { cursor: pointer; }
.reg-link:hover .reg-name { color: var(--accent); }
.acct { display: inline-block; font-size: 0.68rem; padding: 2px 8px; border-radius: 999px; }
.acct.on  { background: rgba(34,197,94,0.16); color: #4ade80; }
.acct.inv { background: rgba(234,179,8,0.16); color: #eab308; }
.acct.off { background: #1e1e1e; color: var(--text-muted); }
.reg-muted { color: var(--text-muted); font-size: 0.8rem; }
.reg-drow { display: flex; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--border); font-size: 0.85rem; }
.reg-drow .k { color: var(--text-muted); width: 120px; flex-shrink: 0; }
.reg-role-edit { display: flex; gap: 8px; align-items: center; margin: 6px 0; flex-wrap: wrap; }
.mem-chk { display: flex; gap: 8px; align-items: center; cursor: pointer; }
.reg-info { display: inline-flex; align-items: center; justify-content: center; width: 16px; height: 16px; border-radius: 50%; border: 1px solid var(--text-muted); color: var(--text-muted); font-size: 0.62rem; font-style: italic; font-weight: 700; cursor: pointer; line-height: 1; flex-shrink: 0; }
.reg-info:hover { border-color: var(--accent); color: var(--accent); }
.reg-tip { position: fixed; max-width: 280px; background: #1e1e1e; border: 1px solid var(--border); border-radius: 8px; padding: 10px 12px; font-size: 0.76rem; color: var(--text); line-height: 1.5; z-index: 9999; box-shadow: 0 6px 24px rgba(0,0,0,0.5); display: none; }

/* ── BOOKING-KALENDER ──────────────────────────────────────────────────────── */
.bk-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  padding: 10px 0 14px;
}
.bk-view-btn {
  font-size: 0.78rem;
  padding: 5px 12px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: var(--card-bg);
  color: var(--text-muted);
  cursor: pointer;
}
.bk-view-btn.active { background: #fff; color: #0d0d0d; border-color: #fff; }
.bk-view-btn:hover:not(.active) { border-color: var(--accent); color: var(--text); }

.bk-nav-label {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text);
  min-width: 150px;
  text-align: center;
}

.bk-res-selectors {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.bk-res-selectors select {
  flex: 1;
  min-width: 140px;
  max-width: 240px;
}

/* ── UKE-KALENDER ───────────────────────────── */
.bk-week-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.bk-week-header {
  display: grid;
  grid-template-columns: 48px repeat(7, 1fr);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  background: var(--card-bg);
  z-index: 10;
}
.bk-week-head {
  text-align: center;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text-muted);
  padding: 8px 4px;
  border-left: 1px solid var(--border);
}
.bk-today-head { color: var(--accent); background: rgba(255,255,255,0.04); }
.bk-day-num { display: block; font-size: 1.1rem; font-weight: 700; color: var(--text); }
.bk-today-head .bk-day-num { color: var(--accent); }

.bk-week-body {
  position: relative;
  display: grid;
  grid-template-columns: 48px 1fr;
}

.bk-time-col {
  position: relative;
  width: 48px;
  flex-shrink: 0;
}
.bk-time-label {
  position: absolute;
  right: 6px;
  font-size: 0.65rem;
  color: var(--text-muted);
  line-height: 1;
  transform: translateY(-50%);
}
.bk-grid-lines {
  position: absolute;
  left: 48px;
  right: 0;
  top: 0;
  bottom: 0;
  pointer-events: none;
  z-index: 1;
}
.bk-hline {
  position: absolute;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--border);
}
.bk-hline-half { background: rgba(255,255,255,0.04); }

.bk-events-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  position: relative;
  min-width: 420px;
}
.bk-day-col {
  position: relative;
  border-left: 1px solid var(--border);
  cursor: pointer;
}
.bk-day-col:hover { background: rgba(255,255,255,0.015); }

.bk-event {
  position: absolute;
  left: 2px;
  right: 2px;
  border-radius: 4px;
  padding: 3px 5px;
  cursor: pointer;
  overflow: hidden;
  z-index: 5;
  font-size: 0.7rem;
  transition: opacity 0.15s;
}
.bk-event:hover { opacity: 0.85; }
.bk-event-title { font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.bk-event-time  { font-size: 0.65rem; color: rgba(255,255,255,0.6); }
.bk-event-badge { font-size: 0.6rem; margin-top: 2px; }
.bk-event-pending { opacity: 0.65; }

/* ── DAG-HEADER ─────────────────────────────── */
.bk-day-header {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 1rem;
  font-weight: 700;
  padding: 10px 0 14px;
  color: var(--text);
}

/* ── MÅNED-KALENDER ─────────────────────────── */
.bk-month-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
}
.bk-month-head {
  background: var(--card-bg);
  text-align: center;
  font-size: 0.72rem;
  color: var(--text-muted);
  padding: 6px 4px;
  font-weight: 600;
}
.bk-month-cell {
  background: var(--bg);
  min-height: 80px;
  padding: 4px;
  cursor: pointer;
  font-size: 0.75rem;
}
.bk-month-cell:hover { background: var(--card-bg); }
.bk-month-empty { background: var(--bg); opacity: 0.4; }
.bk-today-cell { background: rgba(255,255,255,0.04); }
.bk-today-cell .bk-month-date { color: var(--accent); font-weight: 700; }
.bk-month-date { font-size: 0.8rem; color: var(--text-muted); margin-bottom: 4px; }
.bk-month-evt {
  font-size: 0.67rem;
  padding: 2px 5px;
  border-radius: 3px;
  margin-bottom: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  cursor: pointer;
}
.bk-month-more { font-size: 0.65rem; color: var(--text-muted); padding-left: 4px; }

/* ── LISTE-VISNING ─────────────────────────── */
.bk-list-item {
  padding: 12px 14px;
  background: var(--card-bg);
  border-radius: 8px;
  margin-bottom: 8px;
  cursor: pointer;
  transition: opacity 0.15s;
}
.bk-list-item:hover { opacity: 0.85; }
.bk-list-meta  { font-size: 0.72rem; color: var(--text-muted); margin-bottom: 3px; }
.bk-list-title { font-weight: 600; font-size: 0.9rem; margin-bottom: 3px; }
.bk-list-sub   { font-size: 0.78rem; color: var(--text-muted); }

/* ── BOOKING ADMIN ─────────────────────────── */
.bk-res-node { margin-bottom: 4px; }
.bk-res-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  padding: 8px 10px;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 8px;
}
.bk-res-name { font-weight: 600; font-size: 0.88rem; flex: 1; min-width: 80px; }
.bk-res-actions { display: flex; gap: 6px; margin-left: auto; flex-wrap: wrap; }
.bk-kind-badge {
  font-size: 0.68rem;
  padding: 2px 8px;
  border-radius: 999px;
  background: var(--bg);
  border: 1px solid var(--border);
  color: var(--text-muted);
  white-space: nowrap;
}
.bk-kind-rom  { background: rgba(167,139,250,0.12); color: #c084fc; border-color: transparent; }
.bk-kind-bane { background: rgba(59,130,246,0.12);  color: #60a5fa; border-color: transparent; }
.bk-badge-approval {
  font-size: 0.68rem;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(234,179,8,0.12);
  color: var(--warning);
  white-space: nowrap;
}
.bk-type-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* ── MODALER ───────────────────────────────── */
.bk-modal-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
/* La form-felt krympe under sin intrinsic min-width (clock-ikon etc) i grid/flex.
   Uten dette stikker time-/date-inputs ut av container på smale skjermer. */
.bk-modal-grid .form-group,
.bk-modal-grid .form-control { min-width: 0; }
@media (max-width: 480px) {
  .bk-modal-grid { grid-template-columns: 1fr; }
  .bk-events-grid { min-width: 360px; }
  .bk-week-header { grid-template-columns: 36px repeat(7, 1fr); }
  .bk-time-col { width: 36px; }
  .bk-time-label { font-size: 0.58rem; right: 3px; }
}

/* ── KJØREGODTGJØRELSE ──────────────────────────────────────────────────────── */

.km-list-item {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px 14px;
  margin-bottom: 8px;
  cursor: pointer;
  transition: border-color .15s, background .15s;
}
.km-list-item:hover { border-color: var(--accent); background: #1a1a1a; }

/* Status-badges */
.km-status-badge {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 20px;
  letter-spacing: .02em;
  text-transform: uppercase;
}
.km-status-draft     { background: #2a2a2a; color: #aaa; border: 1px solid #444; }
.km-status-submitted { background: #1e3a5f; color: #60a5fa; border: 1px solid #3b82f6; }
.km-status-approved  { background: #14532d; color: #4ade80; border: 1px solid #22c55e; }
.km-status-rejected  { background: #450a0a; color: #f87171; border: 1px solid #ef4444; }
.km-status-paid      { background: #2e1065; color: #c4b5fd; border: 1px solid #8b5cf6; }

/* Turtabell */
.km-trip-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
  white-space: nowrap;
}
.km-trip-table th {
  background: var(--bg);
  color: var(--text-muted);
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  padding: 7px 5px;
  border-bottom: 1px solid var(--border);
  text-align: left;
}
.km-trip-table td {
  padding: 4px 4px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  vertical-align: middle;
}
.km-trip-table tfoot td {
  border-bottom: none;
  border-top: 1px solid var(--border);
}
.km-cell-input {
  background: transparent;
  border: 1px solid transparent;
  border-radius: 5px;
  color: var(--text);
  font-size: 0.82rem;
  padding: 4px 5px;
  width: 70px;
  transition: border-color .15s, background .15s;
}
.km-cell-input:focus {
  outline: none;
  border-color: var(--accent);
  background: #1a1a1a;
}
.km-cell-input[type="date"] { width: 120px; }
.km-num { width: 60px; text-align: right; }
.km-calc {
  text-align: right;
  font-variant-numeric: tabular-nums;
  color: var(--text-muted);
  padding-right: 8px;
}
.km-total-cell { color: var(--text); font-weight: 600; }
.km-del-row {
  background: transparent;
  border: none;
  color: #f87171;
  font-size: 1.1rem;
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 4px;
  line-height: 1;
}
.km-del-row:hover { background: rgba(248,113,113,.15); }

/* Signatur-canvas */
#km-sig-canvas {
  display: block;
  border-radius: 6px;
  touch-action: none;
}

/* ── PRINT-STIL ───────────────────────────────────────────────────────────── */
#km-print-area { display: none; }

@media print {
  /* Skjul alt unntatt print-området */
  body > *:not(#km-print-area) { display: none !important; }
  #km-print-area {
    display: block !important;
    font-family: Arial, sans-serif;
    font-size: 11pt;
    color: #000;
    background: #fff;
    padding: 0;
    margin: 0;
  }

  .km-print-doc { padding: 16mm 12mm; }

  .km-print-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    border-bottom: 2px solid #000;
    padding-bottom: 8px;
    margin-bottom: 14px;
  }

  .km-print-info {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 14px;
    font-size: 10pt;
  }
  .km-print-info td {
    padding: 3px 8px 3px 0;
    vertical-align: top;
  }
  .km-print-info td:nth-child(odd) {
    color: #555;
    white-space: nowrap;
    width: 110px;
  }

  .km-print-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 9pt;
    margin-bottom: 14px;
  }
  .km-print-table th {
    background: #eee;
    border: 1px solid #999;
    padding: 4px 5px;
    text-align: left;
    font-weight: 700;
  }
  .km-print-table td {
    border: 1px solid #ccc;
    padding: 3px 5px;
    vertical-align: middle;
  }
  .km-print-table tfoot td {
    border-top: 2px solid #000;
    background: #f8f8f8;
  }

  .km-print-footer {
    display: flex;
    gap: 32px;
    flex-wrap: wrap;
    margin-top: 20px;
  }
}

/* ── STATISTIKK-TAB ──────────────────────────────────────────── */

/* Sub-tab-bar med sesongvelger */
.stat-tab-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--border);
  padding-bottom: 10px;
}
.stat-tab-bar #stat-subtabs {
  flex: 1;
  min-width: 0;
}
.stat-season-sel {
  flex-shrink: 0;
  width: 90px !important;
  font-size: 0.82rem;
  padding: 5px 8px;
  /* Midtstill loddrett mot fane-TEKSTEN. Fanene har 10px topp/bunn-
     padding + 3px aktiv-underkant, så boksens senter må løftes for å
     ligge på linje med tekstens senter (ikke fane-boksens senter). */
  align-self: center;
  position: relative;
  top: -7px;
}

/* Sesong-oversikt: summary-kort */
.stat-summary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 10px;
  margin-bottom: 18px;
}
.stat-summary-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 12px;
  text-align: center;
}
.ssc-value {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--accent);
  line-height: 1.1;
  white-space: nowrap;
}
.ssc-label {
  font-size: 0.7rem;
  color: var(--text-muted);
  margin-top: 3px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

/* Høydepunkt-rad */
.stat-highlight-row {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}
.stat-highlight-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent);
  border-radius: 10px;
  padding: 12px 14px;
}
.shc-label {
  font-size: 0.68rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.4px;
  margin-bottom: 4px;
  font-weight: 700;
}
.shc-name {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.shc-value {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--accent);
}
.shc-sub {
  font-size: 0.72rem;
  color: var(--text-muted);
  margin-top: 2px;
}

/* ── SESONG-FANEN: form-stripe, sesongproduksjon-bar, skuddtype-stack ── */
.ses-twoup {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}
.ses-panel {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px 14px;
}
.ses-panel-lbl {
  font-size: 0.7rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.4px;
  font-weight: 600;
  margin-bottom: 10px;
}
.form-row { display: flex; gap: 6px; flex-wrap: wrap; }
.form-badge {
  display: inline-flex; align-items: center; justify-content: center;
  width: 30px; height: 30px; border-radius: 7px;
  font-size: 0.74rem; font-weight: 700;
}
.form-w { background: rgba(34,197,94,0.14);  color: #22c55e; border: 1px solid rgba(34,197,94,0.32); }
.form-d { background: rgba(148,163,184,0.10); color: #cbd5e1; border: 1px solid rgba(148,163,184,0.28); }
.form-l { background: rgba(248,113,113,0.10); color: #f87171; border: 1px solid rgba(248,113,113,0.32); }

.prod-bars { display: flex; flex-direction: column; gap: 9px; }
.prod-bar-head {
  display: flex; justify-content: space-between;
  font-size: 0.74rem; margin-bottom: 3px;
}
.prod-bar-head > :first-child { color: var(--text-muted); }
.prod-bar-head > :last-child  { color: var(--text); font-weight: 600; font-variant-numeric: tabular-nums; }
.prod-bar-track { height: 6px; background: #1a1a1a; border-radius: 3px; overflow: hidden; }
.prod-bar-fill  { height: 100%; }

.shot-stack {
  display: flex; height: 24px;
  border-radius: 6px; overflow: hidden;
  background: #1a1a1a; margin-bottom: 12px;
}
.shot-legend {
  display: flex; flex-wrap: wrap; gap: 14px;
  font-size: 0.72rem; color: var(--text-muted);
}
.shot-legend strong { color: var(--text); font-weight: 600; font-variant-numeric: tabular-nums; }
.shot-leg-dot {
  display: inline-block; width: 9px; height: 9px;
  border-radius: 2px; margin-right: 5px; vertical-align: middle;
}

/* Generell statistikk-tabell */
.stat-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
}
.stat-table thead th {
  background: #1a1a1a;
  color: var(--text-muted);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  padding: 7px 10px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
.stat-table tbody td {
  padding: 8px 10px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}
.stat-table tbody tr:last-child td { border-bottom: none; }
.stat-table tbody tr:hover td { background: rgba(255,255,255,0.025); }
.stat-rank-col { width: 32px; }
.stat-num-col  { width: 52px; }
.stat-rank     { font-size: 0.75rem; color: var(--text-muted); font-weight: 600; text-align: center; }
.stat-player-name { font-weight: 600; }
.stat-num      { text-align: right; font-variant-numeric: tabular-nums; }
.stat-goals    { font-weight: 700; color: var(--accent); }
.stat-saves    { font-weight: 700; color: #3b82f6; }
.stat-pos      { color: #22c55e; font-weight: 600; }
.stat-neg      { color: #f87171; font-weight: 600; }
.stat-muted    { color: var(--text-muted); }
.stat-section-head {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-muted);
  margin: 0 0 8px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
}
.stat-empty-note { font-size: 0.82rem; color: var(--text-muted); padding: 8px 0; }

/* Kampiste */
.stat-match-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.stat-match-row {
  display: grid;
  grid-template-columns: 72px 26px 1fr 68px 28px;
  align-items: center;
  gap: 8px;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-left: 3px solid var(--border);
  border-radius: 8px;
  padding: 8px 12px;
  font-size: 0.82rem;
}
.stat-match-row.smr-win  { border-left-color: #22c55e; }
.stat-match-row.smr-loss { border-left-color: #f87171; }
.stat-match-row.smr-draw { border-left-color: #eab308; }
.smr-date     { font-size: 0.74rem; color: var(--text-muted); white-space: nowrap; }
.smr-ha       { font-size: 0.68rem; font-weight: 700; border-radius: 4px;
                 padding: 2px 5px; text-align: center; }
.smr-ha-home  { background: rgba(34,197,94,0.15);  color: #22c55e; }
.smr-ha-away  { background: rgba(59,130,246,0.15); color: #3b82f6; }
.smr-opponent { font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.smr-score    { text-align: right; font-weight: 700; font-variant-numeric: tabular-nums; }
.smr-result   { text-align: center; font-size: 0.7rem; font-weight: 700; }
.smr-res-W    { color: #22c55e; }
.smr-res-L    { color: #f87171; }
.smr-res-D    { color: #eab308; }

/* ── MEP LEADERBOARD ──────────────────────────────────────────── */
.mep-header {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}
.mep-title    { font-size: 1rem; font-weight: 700; margin: 0 0 2px; }
.mep-subtitle { font-size: 0.78rem; color: var(--text-muted); margin: 0; }
.mep-recalc-btn { margin-left: auto; white-space: nowrap; }
.mep-cached-note {
  font-size: 0.72rem;
  color: var(--text-muted);
  margin-bottom: 12px;
}

.mep-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 4px;
}
.mep-row {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px 14px;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}
.mep-row:hover,
.mep-row:active {
  border-color: var(--accent);
  background: var(--row-hover);   /* lys grå i lyst tema, dempet grå i mørkt — aldri svart */
}
.mep-rank {
  width: 24px;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--text-muted);
  text-align: center;
  flex-shrink: 0;
}
.mep-info    { flex: 1; min-width: 0; }
.mep-name    { font-size: 0.88rem; font-weight: 600; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.mep-num     { font-size: 0.72rem; color: var(--text-muted); font-weight: 400; }
.mep-meta    { font-size: 0.72rem; color: var(--text-muted); margin: 2px 0 5px; }
.mep-bar-wrap {
  height: 4px;
  background: var(--border);
  border-radius: 2px;
  overflow: hidden;
}
.mep-bar {
  height: 100%;
  border-radius: 2px;
  transition: width 0.3s;
}
.mep-score-badge {
  font-size: 1.1rem;
  font-weight: 800;
  min-width: 44px;
  text-align: right;
  flex-shrink: 0;
  font-variant-numeric: tabular-nums;
}
.mep-tier-badge {
  font-size: 0.64rem;
  padding: 1px 6px;
  border-radius: 8px;
  background: rgba(234,179,8,0.15);
  color: #eab308;
  border: 1px solid rgba(234,179,8,0.25);
  font-weight: 600;
  letter-spacing: 0.2px;
}

/* ── MEP PLAYER DETAIL (i modal) ─────────────────────────────── */
.mep-detail-header {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.mep-detail-name { font-size: 1.15rem; font-weight: 800; margin: 0 0 2px; }
.mep-detail-meta { font-size: 0.8rem; color: var(--text-muted); margin: 0; }
.mep-detail-score-badge {
  flex-shrink: 0;
  border: 1px solid;
  border-radius: 12px;
  padding: 8px 14px;
  text-align: center;
  min-width: 60px;
}
.mdsb-num   { font-size: 1.4rem; font-weight: 800; line-height: 1; }
.mdsb-label { font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.5px; margin-top: 2px; opacity: 0.7; }

/* Sparkline */
.mep-sparkline-section {
  background: #0d0d0d;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px 14px;
  margin-bottom: 14px;
  overflow-x: auto;
}
.mss-label { font-size: 0.7rem; color: var(--text-muted); margin-bottom: 6px; }
.mep-sparkline { display: block; }

/* Faktorkort */
.mep-factors {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 4px;
}
.mf-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 14px;
  text-align: center;
  min-width: 80px;
  flex: 1;
}
.mf-val  { font-size: 1.1rem; font-weight: 700; color: var(--accent); }
.mf-unit { font-size: 0.7rem; font-weight: 400; }
.mf-label { font-size: 0.68rem; color: var(--text-muted); margin-top: 2px;
            text-transform: uppercase; letter-spacing: 0.3px; }

/* Clutch-liste */
.clutch-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.clutch-item {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 8px 12px;
}
.clutch-pos { border-left: 3px solid #22c55e; }
.clutch-neg { border-left: 3px solid #f87171; }
.ci-icon  { font-size: 1rem; flex-shrink: 0; }
.ci-body  { flex: 1; min-width: 0; }
.ci-event { font-size: 0.82rem; font-weight: 600; }
.ci-meta  { font-size: 0.72rem; color: var(--text-muted); margin-top: 1px; }
.ci-val   { font-size: 0.9rem; font-weight: 700; flex-shrink: 0; min-width: 36px; text-align: right; }
.ci-pos   { color: #22c55e; }
.ci-neg   { color: #f87171; }
}

/* ── BESTE LAG ───────────────────────────────────────────────── */

.bl-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.8rem;
  color: var(--text-muted);
  padding: 8px 12px;
  border-radius: 8px;
  margin-bottom: 14px;
  flex-wrap: wrap;
}
.bl-banner-v2 { background: rgba(34,197,94,0.08);  border: 1px solid rgba(34,197,94,0.2); }
.bl-banner-v1 { background: rgba(251,191,36,0.08); border: 1px solid rgba(251,191,36,0.2); }

.bl-method-badge {
  font-size: 0.72rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 99px;
  background: rgba(34,197,94,0.2);
  color: #22c55e;
  flex-shrink: 0;
}
.bl-method-est {
  background: rgba(251,191,36,0.2);
  color: #fbbf24;
}

.bl-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 14px;
}

.bl-card {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px 14px;
  transition: border-color 0.15s;
}
.bl-card-top {
  border-color: rgba(255,255,255,0.14);
  background: #1a1a1a;
}
.bl-card-top:first-child {
  border-color: rgba(251,191,36,0.4);
  background: rgba(251,191,36,0.04);
}

.bl-rank {
  font-size: 1.3rem;
  width: 32px;
  text-align: center;
  flex-shrink: 0;
  line-height: 1.2;
  padding-top: 2px;
}

.bl-card-body { flex: 1; min-width: 0; }

.bl-players {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 10px;
}
.bl-player {
  display: flex;
  align-items: center;
  gap: 4px;
  background: var(--input-bg, rgba(255,255,255,0.05));
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 3px 7px;
  font-size: 0.78rem;
}
.bl-gk-badge {
  font-size: 0.64rem;
  font-weight: 700;
  background: rgba(99,102,241,0.25);
  color: #a5b4fc;
  padding: 1px 4px;
  border-radius: 3px;
  letter-spacing: 0.02em;
}
.bl-pnum  { color: var(--text-muted); font-variant-numeric: tabular-nums; }
.bl-pname { font-weight: 600; }

.bl-stats {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}
.bl-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 48px;
}
.bl-stat-val {
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.1;
  font-variant-numeric: tabular-nums;
}
.bl-stat-lbl {
  font-size: 0.65rem;
  color: var(--text-muted);
  text-align: center;
  margin-top: 1px;
  white-space: nowrap;
}

.bl-footnote {
  font-size: 0.72rem;
  color: var(--text-muted);
  text-align: center;
  margin-top: 4px;
}

/* ════════════════════════════════════════════════════════════════════════
   FILER-FANEN — dropzone, forhåndsvisning, papirkurv
   Portert fra design/mockup.html
   ════════════════════════════════════════════════════════════════════════ */

.space-slider { display: flex; gap: 10px; overflow-x: auto; padding: 4px 2px 14px; -webkit-overflow-scrolling: touch; }
.space-card {
  flex: 0 0 auto; min-width: 130px; background: var(--card-bg); border: 1px solid var(--border);
  border-radius: 12px; padding: 12px 14px; cursor: pointer; transition: all 0.15s; text-align: left;
}
.space-card:hover { border-color: var(--accent); }
.space-card.active { border-color: var(--accent); background: rgba(249,115,22,0.08); }
.space-card .space-icon { font-size: 1.4rem; }
.space-card .space-name { font-weight: 700; font-size: 0.9rem; margin-top: 4px; color: var(--text); }
.space-card .space-role { font-size: 0.66rem; color: var(--text-muted); margin-top: 2px; }

.files-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin: 2px 0 14px; }
.breadcrumb { display: flex; align-items: center; gap: 6px; font-size: 0.82rem; flex-wrap: wrap; }
.breadcrumb a { color: var(--text-muted); cursor: pointer; }
.breadcrumb a:hover { color: var(--accent); }
.breadcrumb .sep { color: var(--text-muted); }
.breadcrumb .current { color: var(--text); font-weight: 600; }

.files-actions { display: flex; gap: 8px; margin-bottom: 12px; align-items: center; }
.file-list { display: flex; flex-direction: column; gap: 6px; }
.file-row {
  display: flex; align-items: center; gap: 12px; padding: 10px 12px;
  background: var(--card-bg); border: 1px solid var(--border); border-radius: 10px;
  cursor: pointer; transition: border-color 0.12s; position: relative;
}
.file-row:hover { border-color: var(--accent); }
.file-row .fr-icon { font-size: 1.3rem; flex: 0 0 auto; }
.file-row .fr-main { flex: 1; min-width: 0; }
.file-row .fr-name { font-size: 0.88rem; font-weight: 600; color: var(--text); }
.file-row .fr-sub { font-size: 0.72rem; color: var(--text-muted); margin-top: 1px; }
.file-row .fr-chev { color: var(--text-muted); font-size: 1rem; }
.file-row .fr-actions { display: flex; gap: 4px; align-items: center; flex-shrink: 0; }
.file-row .fr-action-btn {
  background: none; border: 1px solid transparent; color: var(--text-muted);
  width: 28px; height: 28px; border-radius: 6px; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 0.95rem; transition: all 0.12s; opacity: 0;
}
.file-row:hover .fr-action-btn { opacity: 1; }
.file-row .fr-action-btn:hover { border-color: var(--border); background: rgba(255,255,255,0.04); color: var(--text); }
.file-row .fr-action-btn.danger:hover { color: #f87171; border-color: rgba(248,113,113,0.3); background: rgba(248,113,113,0.08); }
@media (max-width: 640px) { .file-row .fr-action-btn { opacity: 1; } }
.badge-office { font-size: 0.6rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.4px; color: #c084fc; background: rgba(168,85,247,0.12); border: 1px solid rgba(168,85,247,0.3); border-radius: 4px; padding: 1px 6px; margin-left: 6px; }
.badge-new { font-size: 0.6rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.4px; color: #22c55e; background: rgba(34,197,94,0.12); border: 1px solid rgba(34,197,94,0.3); border-radius: 4px; padding: 1px 6px; margin-left: 6px; }
.files-empty { font-size: 0.85rem; color: var(--text-muted); padding: 16px 2px; }

.dropzone { position: relative; min-height: 80px; border-radius: 12px; transition: background 0.15s; }
.dropzone.dragging { background: rgba(59,130,246,0.06); outline: 2px dashed #60a5fa; outline-offset: 4px; }
.drop-overlay { position: absolute; inset: 0; display: none; align-items: center; justify-content: center; background: rgba(13,13,13,0.85); border-radius: 12px; pointer-events: none; z-index: 4; border: 2px dashed #60a5fa; }
.dropzone.dragging .drop-overlay { display: flex; }
.drop-overlay-inner { text-align: center; pointer-events: none; }
.drop-overlay-icon { font-size: 2.4rem; margin-bottom: 6px; }
.drop-overlay-text { font-size: 0.95rem; font-weight: 600; color: var(--text); }
.drop-overlay-sub { font-size: 0.78rem; color: var(--text-muted); margin-top: 3px; }

.upload-panel { position: fixed; right: 20px; bottom: 20px; width: 320px; max-width: calc(100vw - 40px); background: var(--card-bg); border: 1px solid var(--border); border-radius: 12px; padding: 14px; box-shadow: 0 12px 36px rgba(0,0,0,0.5); z-index: 50; display: none; flex-direction: column; gap: 10px; }
.upload-panel.show { display: flex; }
.upload-panel-head { display: flex; justify-content: space-between; align-items: center; font-size: 0.82rem; font-weight: 700; color: var(--text); }
.upload-panel-close { background: none; border: none; color: var(--text-muted); cursor: pointer; font-size: 1rem; padding: 0; }
.upload-item { display: flex; flex-direction: column; gap: 4px; font-size: 0.76rem; }
.upload-item-name { color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.upload-item-sub { display: flex; justify-content: space-between; color: var(--text-muted); font-size: 0.7rem; }
.upload-bar { height: 4px; background: var(--border); border-radius: 2px; overflow: hidden; }
.upload-bar-fill { height: 100%; background: #60a5fa; transition: width 0.3s; }
.upload-bar-fill.done { background: #22c55e; }
.upload-bar-fill.error { background: #f87171; }

.preview-modal { position: fixed; inset: 0; display: none; z-index: 100; background: rgba(0,0,0,0.85); padding: 30px; align-items: center; justify-content: center; }
.preview-modal.show { display: flex; }
.preview-content { background: var(--card-bg); border: 1px solid var(--border); border-radius: 14px; max-width: 1100px; width: 100%; max-height: calc(100vh - 60px); display: flex; flex-direction: column; overflow: hidden; box-shadow: 0 20px 60px rgba(0,0,0,0.6); }
.preview-head { display: flex; align-items: center; gap: 12px; padding: 14px 18px; border-bottom: 1px solid var(--border); }
.preview-head-icon { font-size: 1.4rem; flex-shrink: 0; }
.preview-head-main { flex: 1; min-width: 0; }
.preview-head-name { font-size: 0.95rem; font-weight: 700; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.preview-head-sub { font-size: 0.75rem; color: var(--text-muted); margin-top: 2px; }
.preview-head-actions { display: flex; gap: 8px; flex-shrink: 0; }
.preview-body { flex: 1; min-height: 0; overflow: auto; display: flex; align-items: center; justify-content: center; background: #0a0a0a; }
.preview-body img, .preview-body video { max-width: 100%; max-height: calc(100vh - 200px); display: block; border-radius: 6px; }
.preview-body iframe { width: 100%; height: calc(100vh - 200px); border: 0; background: #fff; }
.preview-office-placeholder { padding: 50px; text-align: center; color: var(--text-muted); }
.preview-office-placeholder .poff-icon { font-size: 3.4rem; margin-bottom: 12px; }
.preview-office-placeholder .poff-title { font-size: 1.1rem; font-weight: 700; color: var(--text); margin-bottom: 6px; }
.preview-office-placeholder .poff-sub { font-size: 0.88rem; max-width: 380px; line-height: 1.5; margin: 0 auto 18px; }
.preview-office-placeholder .poff-actions { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }

.trash-modal { position: fixed; inset: 0; display: none; z-index: 100; background: rgba(0,0,0,0.7); padding: 30px; align-items: center; justify-content: center; }
.trash-modal.show { display: flex; }
.trash-content { background: var(--card-bg); border: 1px solid var(--border); border-radius: 14px; max-width: 640px; width: 100%; max-height: calc(100vh - 60px); overflow: hidden; display: flex; flex-direction: column; box-shadow: 0 20px 60px rgba(0,0,0,0.6); }
.trash-head { display: flex; align-items: center; justify-content: space-between; padding: 14px 18px; border-bottom: 1px solid var(--border); }
.trash-title { font-size: 1rem; font-weight: 700; color: var(--text); }
.trash-sub { font-size: 0.74rem; color: var(--text-muted); margin-top: 3px; }
.trash-body { flex: 1; overflow-y: auto; padding: 8px 14px 14px; }
.trash-item { display: flex; align-items: center; gap: 12px; padding: 10px 12px; border-bottom: 1px solid var(--border); }
.trash-item:last-child { border-bottom: none; }
.trash-empty { text-align: center; color: var(--text-muted); padding: 30px 14px; font-size: 0.88rem; }

.trash-btn { background: none; border: 1px solid var(--border); color: var(--text-muted); border-radius: 8px; padding: 5px 11px; font-size: 0.78rem; cursor: pointer; display: inline-flex; align-items: center; gap: 6px; transition: all 0.12s; }
.trash-btn:hover { border-color: var(--accent); color: var(--accent); }
.trash-btn .trash-count { background: rgba(248,113,113,0.15); color: #f87171; border-radius: 99px; padding: 0 6px; font-weight: 700; font-size: 0.7rem; }

@media (max-width: 640px) {
  .preview-modal, .trash-modal { padding: 10px; }
  .preview-head, .trash-head { padding: 12px 14px; }
  .preview-head-actions .btn { padding: 6px 9px; font-size: 0.78rem; }
  .upload-panel { width: calc(100vw - 24px); right: 12px; bottom: 12px; }
}

/* ── SPOND-INTEGRASJON (Klubb → Spond) ─────────────────────────────────────── */
.sp-pill {
  padding: 3px 10px;
  border-radius: 99px;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.4px;
  display: inline-block;
}
.sp-pill-on  { background: rgba(34,177,76,0.15);  color: #22B14C; }
.sp-pill-off { background: rgba(148,163,184,0.18); color: var(--text-muted); }

/* Toggle-switch (master + dry-run) */
.sp-toggle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  flex-shrink: 0;
}
.sp-toggle input { display: none; }
.sp-slider {
  position: relative;
  width: 48px;
  height: 26px;
  background: rgba(148,163,184,0.4);
  border-radius: 99px;
  transition: background 0.18s;
  flex-shrink: 0;
}
.sp-knob {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 20px;
  height: 20px;
  background: #fff;
  border-radius: 50%;
  transition: left 0.18s, transform 0.18s;
  box-shadow: 0 2px 4px rgba(0,0,0,0.3);
}
.sp-toggle input:checked + .sp-slider              { background: rgba(34,177,76,0.6); }
.sp-toggle input:checked + .sp-slider .sp-knob     { left: 25px; }
.sp-toggle-label {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--text);
}

.sp-mapping-row select.form-control { padding: 5px 8px; }
.sp-mapping-row { transition: background 0.12s; }

/* ══════════════════════════════════════════════════════════════════════════
   TRENING → DELE INN I LAG  (mobil-først trener-verktøy)
   ══════════════════════════════════════════════════════════════════════════ */
.ld-subtabs { display:flex; gap:4px; margin-bottom:16px; border-bottom:1px solid var(--border); }
.ld-subtab { flex:1; text-align:center; padding:10px 6px; font-size:0.85rem; font-weight:600;
  color:var(--text-muted); background:none; border:none; border-bottom:2px solid transparent;
  cursor:pointer; }
.ld-subtab.active { color:var(--accent); border-bottom-color:var(--accent); }
.ld-hidden { display:none !important; }

.ld-card { background:var(--card-bg); border:1px solid var(--border); border-radius:14px;
  padding:14px; margin-bottom:12px; }
.ld-card h3 { margin:0 0 12px; font-size:0.98rem; display:flex; align-items:center; gap:8px; }
.ld-step { display:inline-flex; width:21px; height:21px; border-radius:50%; background:var(--accent);
  color:#0d0d0d; font-size:0.74rem; font-weight:800; align-items:center; justify-content:center; flex-shrink:0; }
.ld-hint { font-size:0.74rem; color:var(--text-muted); line-height:1.45; }

/* Spond-status */
.ld-spond-bar { display:flex; align-items:center; justify-content:space-between; gap:10px;
  background:rgba(6,182,212,0.08); border:1px solid var(--border); border-radius:10px;
  padding:10px 12px; margin-bottom:12px; }
.ld-spond-meta { font-size:0.68rem; color:var(--cyan); font-weight:700; letter-spacing:0.04em; }
.ld-spond-sub { font-size:0.74rem; color:var(--text-muted); margin-top:2px; }
.ld-btn-sync { background:var(--cyan); color:#04121a; border:none; border-radius:8px;
  padding:8px 13px; font-size:0.78rem; font-weight:700; cursor:pointer; white-space:nowrap; }

.ld-present-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; }
.ld-present-head .cnt { font-size:0.82rem; color:var(--text-muted); }
.ld-present-head .cnt b { color:var(--accent); font-size:1.05rem; }
.ld-link { background:none; border:none; color:var(--accent); font-size:0.78rem; font-weight:600;
  cursor:pointer; padding:0; text-decoration:underline; }

.ld-legend { display:flex; flex-wrap:wrap; gap:8px; margin:0 0 12px; }
.ld-legend span { font-size:0.62rem; color:var(--text-muted); display:inline-flex; align-items:center; gap:4px; }
.ld-legend i { width:9px; height:9px; border-radius:3px; display:inline-block; }

/* Spillerliste (oppmøte) */
.ld-plist { display:flex; flex-direction:column; gap:6px; }
.ld-prow { display:flex; align-items:center; gap:10px; background:var(--bg);
  border:1px solid var(--border); border-radius:10px; padding:8px 10px; cursor:pointer;
  transition:opacity 0.15s; }
.ld-prow.off { opacity:0.42; }
.ld-pcheck { width:21px; height:21px; border-radius:6px; border:2px solid var(--border); flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:0.72rem; color:#0d0d0d; }
.ld-prow:not(.off) .ld-pcheck { background:var(--success); border-color:var(--success); }
.ld-pname { flex:1; font-size:0.86rem; font-weight:600; display:flex; align-items:center; gap:6px; }
.ld-inj { font-size:0.78rem; }
.ld-mep { font-size:0.64rem; font-weight:800; color:var(--text);
  background:var(--bg); border:1px solid var(--border); border-radius:5px;
  padding:2px 6px; min-width:30px; text-align:center; }
.ld-mep.no { color:var(--text-muted); font-weight:600; }
.ld-lvl { font-size:0.62rem; font-weight:700; color:var(--text-muted); border:1px solid var(--border);
  border-radius:5px; padding:1px 5px; cursor:pointer; user-select:none; }
.ld-lvl:hover { border-color:var(--accent); color:var(--text); }
/* Manuelt satt nivå-tag — markeres tydelig så treneren ser hvilke som er overstyrt */
.ld-lvl.manual { background:color-mix(in srgb, var(--accent) 14%, var(--bg)); color:var(--text);
  border-color:color-mix(in srgb, var(--accent) 45%, var(--border)); font-weight:800; }

/* Posisjonsmerke (farget) */
.ld-pos { font-size:0.6rem; font-weight:800; padding:2px 7px; border-radius:20px; color:#04121a;
  text-transform:uppercase; letter-spacing:0.02em; }
.ld-pos.pos-Målvakt { background:#f59e0b; }
.ld-pos.pos-Kant    { background:#06b6d4; }
.ld-pos.pos-Back    { background:#8b5cf6; color:#fff; }
.ld-pos.pos-Linje   { background:#22c55e; }
.ld-pos.pos-Ukjent  { background:var(--border); color:var(--text-muted); }

/* Oppsett */
.ld-field { margin-bottom:14px; }
.ld-field > label { display:block; font-size:0.78rem; font-weight:700; margin-bottom:7px; }
.ld-stepper { display:flex; align-items:center; gap:14px; }
.ld-stepper button { width:42px; height:42px; border-radius:11px; border:1px solid var(--border);
  background:var(--bg); color:var(--text); font-size:1.4rem; font-weight:700; cursor:pointer; }
.ld-stepper .val { font-size:1.7rem; font-weight:800; min-width:34px; text-align:center; }
.ld-stepper .per { font-size:0.74rem; color:var(--text-muted); line-height:1.3; }
.ld-seg { display:flex; background:var(--bg); border:1px solid var(--border); border-radius:11px;
  padding:3px; gap:3px; }
.ld-seg button { flex:1; padding:9px 4px; border:none; background:none; color:var(--text-muted);
  font-size:0.76rem; font-weight:700; border-radius:8px; cursor:pointer; }
.ld-seg button.active { background:var(--accent); color:#0d0d0d; }
.ld-method-desc { font-size:0.72rem; color:var(--text-muted); margin-top:8px; line-height:1.5;
  background:var(--bg); border-radius:8px; padding:9px 11px; border-left:3px solid var(--accent); }
/* Diagnose-banner for Pos+nivå-metoden — viser N1/N2-tellinger + status. */
.ld-niva-diag { display:flex; gap:10px; align-items:flex-start; font-size:0.74rem;
  line-height:1.5; margin-top:8px; padding:10px 12px; border-radius:8px;
  background:color-mix(in srgb, var(--card-bg) 92%, transparent);
  border:1px solid var(--border); }
.ld-niva-diag b { color:var(--text); }

.ld-toggle-row { display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:12px 0; border-top:1px solid var(--border); }
.ld-toggle-row .tl { font-size:0.82rem; font-weight:700; }
.ld-toggle-row .ts { font-size:0.7rem; color:var(--text-muted); margin-top:2px; }
.ld-switch { width:46px; height:27px; border-radius:20px; background:#333; position:relative;
  flex-shrink:0; cursor:pointer; transition:background 0.2s; border:none; }
.ld-switch.on { background:var(--success); }
.ld-switch::after { content:""; position:absolute; top:3px; left:3px; width:21px; height:21px;
  border-radius:50%; background:#fff; transition:transform 0.2s; }
.ld-switch.on::after { transform:translateX(19px); }
.ld-switch.locked { opacity:0.35; cursor:not-allowed; }
.ld-locked-note { font-size:0.72rem; color:var(--warning, #f59e0b); line-height:1.5;
  background:var(--bg); border-radius:8px; padding:9px 11px; border-left:3px solid var(--warning, #f59e0b);
  margin-top:6px; }
.ld-sub-opt { margin-top:4px; padding:4px 0 2px; }

.ld-lock-list { display:flex; flex-direction:column; gap:6px; margin-top:6px; }
.ld-lock-row { display:flex; align-items:center; gap:8px; background:var(--bg);
  border:1px solid var(--border); border-radius:9px; padding:7px 10px; }
.ld-lock-row .ln { flex:1; font-size:0.8rem; font-weight:600; display:flex; align-items:center; }
.ld-lock-row select { background:var(--card-bg); color:var(--text); border:1px solid var(--border);
  border-radius:7px; padding:6px 8px; font-size:0.76rem; }

.ld-genrow { display:flex; gap:8px; margin-top:6px; }
.ld-genrow .btn-primary { flex:1; }
.ld-genrow .btn-secondary { flex:0 0 auto; }

/* Resultat */
.ld-result-head { display:flex; align-items:center; justify-content:space-between; margin:18px 2px 12px; }
.ld-result-head h2 { margin:0; font-size:1.1rem; }
.ld-result-head .meta { font-size:0.72rem; color:var(--text-muted); }
.ld-team-card { background:var(--card-bg); border:1px solid var(--border); border-radius:14px;
  margin-bottom:11px; overflow:hidden; }
.ld-team-head { display:flex; align-items:center; gap:9px; padding:11px 13px;
  background:linear-gradient(90deg,rgba(255,255,255,0.06),transparent); border-bottom:1px solid var(--border); }
.ld-team-dot { width:26px; height:26px; border-radius:8px; background:var(--accent); color:#0d0d0d;
  font-weight:800; font-size:0.85rem; display:flex; align-items:center; justify-content:center; }
.ld-team-name { font-weight:800; font-size:0.95rem; flex:1; }
.ld-tier { font-size:0.6rem; font-weight:800; padding:2px 7px; border-radius:20px; text-transform:uppercase; }
.ld-tier.tier-1 { background:rgba(34,197,94,0.18); color:var(--success); border:1px solid rgba(34,197,94,0.4); }
.ld-tier.tier-2 { background:rgba(139,92,246,0.18); color:#a78bfa; border:1px solid rgba(139,92,246,0.4); }
.ld-team-strength { font-size:0.66rem; color:var(--text-muted); text-align:right; line-height:1.3; }
.ld-team-strength b { color:var(--text); font-size:0.78rem; }
.ld-team-players { padding:6px 8px 9px; display:flex; flex-direction:column; gap:5px; }
.ld-tp { display:flex; align-items:center; gap:9px; padding:7px 8px; border-radius:9px; cursor:pointer; }
.ld-tp:active { background:var(--bg); }
.ld-tp-name { flex:1; font-size:0.84rem; font-weight:600; }
.ld-lockic { font-size:0.72rem; }
.ld-pos-mini { display:flex; gap:3px; padding:6px 13px 11px; flex-wrap:wrap; }
.ld-pos-mini span { font-size:0.58rem; color:var(--text-muted); background:var(--bg);
  border:1px solid var(--border); border-radius:6px; padding:2px 6px; }

/* Bottom sheet (flytt spiller) */
.ld-sheet-bg { position:fixed; inset:0; background:rgba(0,0,0,0.6); z-index:200; display:none; }
.ld-sheet-bg.show { display:block; }
.ld-sheet { position:fixed; bottom:0; left:0; right:0; max-width:560px; margin:0 auto;
  background:var(--card-bg); border-radius:18px 18px 0 0; border-top:1px solid var(--border);
  padding:8px 16px calc(22px + env(safe-area-inset-bottom)); transform:translateY(100%);
  transition:transform 0.22s; }
.ld-sheet-bg.show .ld-sheet { transform:translateY(0); }
.ld-sheet-grab { width:38px; height:4px; border-radius:3px; background:#444; margin:6px auto 12px; }
.ld-sheet h4 { margin:0 0 10px; font-size:0.92rem; }
.ld-opt { display:block; width:100%; text-align:left; background:var(--bg); border:1px solid var(--border);
  border-radius:10px; padding:13px 14px; margin-bottom:7px; color:var(--text); font-size:0.86rem;
  font-weight:600; cursor:pointer; }
.ld-opt.cur { border-color:var(--accent); color:var(--accent); }

/* Treningsplanlegger placeholder */
.ld-placeholder { text-align:center; padding:60px 20px; color:var(--text-muted); }
.ld-ph-big { font-size:2.6rem; margin-bottom:12px; }
.ld-placeholder p { line-height:1.6; font-size:0.9rem; }

/* Filer: Liste/Kart-visningsbryter + mappe-tre (Kart) */
.view-toggle { display:flex; gap:4px; }
.view-btn { background:none; border:1px solid var(--border); color:var(--text-muted); border-radius:8px; padding:5px 11px; font-size:0.78rem; cursor:pointer; }
.view-btn.active { border-color:var(--accent); color:var(--accent); background:rgba(249,115,22,0.08); }
.tree { text-align:center; overflow-x:auto; padding:18px 4px 6px; }
.tree ul { display:flex; justify-content:center; padding-top:20px; position:relative; list-style:none; margin:0; }
.tree li { list-style:none; text-align:center; position:relative; padding:20px 10px 0; }
.tree li::before, .tree li::after {
  content:''; position:absolute; top:0; right:50%; border-top:2px solid var(--border); width:50%; height:20px;
}
.tree li::after { right:auto; left:50%; border-left:2px solid var(--border); }
.tree li:only-child::before, .tree li:only-child::after { display:none; }
.tree li:only-child { padding-top:0; }
.tree li:first-child::before, .tree li:last-child::after { border:0; }
.tree li:last-child::before { border-right:2px solid var(--border); border-radius:0 6px 0 0; }
.tree li:first-child::after { border-radius:6px 0 0 0; }
.tree ul ul::before { content:''; position:absolute; top:0; left:50%; border-left:2px solid var(--border); width:0; height:20px; }
.tree .node {
  display:inline-block; border:1px solid var(--border); border-radius:10px; padding:9px 14px;
  background:var(--card-bg); cursor:pointer; transition:all 0.12s; font-size:0.85rem; color:var(--text); white-space:nowrap;
}
.tree .node:hover { border-color:var(--accent); }
.tree .node-root { background:rgba(249,115,22,0.10); border-color:var(--accent); font-weight:700; cursor:default; }
.tree .node-sub { font-size:0.66rem; color:var(--text-muted); margin-top:2px; font-weight:400; }
.tree-hint { text-align:center; font-size:0.78rem; color:var(--text-muted); margin-top:10px; }

/* Filer: intern drag-and-drop (flytt fil → mappe) */
.file-row[data-kind="file"] { cursor:grab; }
.file-row.dragging-file { opacity:0.45; }
.file-row[data-kind="folder"].drop-target { background:rgba(249,115,22,0.12); box-shadow:inset 0 0 0 2px var(--accent); border-radius:8px; }

/* Filer: «Flytt til…»-velger (touch-vennlig alternativ til drag-and-drop) */
.move-modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.6); display:flex; align-items:center; justify-content:center; z-index:1000; padding:16px; }
.move-modal { background:var(--card-bg); border:1px solid var(--border); border-radius:12px; padding:16px; width:100%; max-width:340px; max-height:80vh; display:flex; flex-direction:column; }
.move-modal-head { font-size:0.9rem; font-weight:600; margin-bottom:12px; color:var(--text); }
.move-modal-list { display:flex; flex-direction:column; gap:6px; overflow-y:auto; }
.move-target { text-align:left; padding:11px 12px; border:1px solid var(--border); border-radius:8px; background:var(--bg); color:var(--text); font-size:0.85rem; cursor:pointer; }
.move-target:hover { border-color:var(--accent); }
.move-modal-cancel { margin-top:12px; padding:9px; border:1px solid var(--border); border-radius:8px; background:none; color:var(--text-muted); cursor:pointer; font-size:0.82rem; }

/* ═══════════════ KJØREPLANLEGGER (Om laget → Kjøreplan) ═══════════════ */
/* NB: --accent er hvit i dette temaet → bruk #0d0d0d for tekst/ikon PÅ aksent. */
.kp-wrap { max-width:880px; }
.kp-steps { display:flex; gap:8px; margin-bottom:20px; }
.kp-step { flex:1; text-align:left; background:none; border:none; cursor:pointer; padding:0; font-family:inherit; }
.kp-step .kp-bar { height:4px; border-radius:999px; background:var(--border); margin-bottom:8px; transition:background .2s; }
.kp-step.done .kp-bar, .kp-step.active .kp-bar { background:var(--accent); }
.kp-step .kp-lbl { font-size:0.78rem; color:var(--text-muted); font-weight:500; }
.kp-step.active .kp-lbl { color:var(--text); font-weight:700; }
.kp-step.done .kp-lbl { color:var(--accent); }
.kp-panel { display:none; }
.kp-panel.show { display:block; animation:kpRise .25s ease both; }
@keyframes kpRise { from{opacity:0;transform:translateY(6px)} to{opacity:1;transform:none} }
.kp-eyebrow { font-size:0.68rem; font-weight:700; letter-spacing:0.09em; text-transform:uppercase; color:var(--accent); margin-bottom:10px; }
.kp-card { background:var(--card-bg); border:1px solid var(--border); border-radius:14px; padding:20px; }
.kp-card + .kp-card { margin-top:14px; }
.kp-h { font-size:1.15rem; font-weight:700; margin-bottom:4px; }
.kp-sub { color:var(--text-muted); font-size:0.85rem; line-height:1.5; }
.kp-field { display:block; margin-bottom:14px; }
.kp-field > span { display:block; font-size:0.72rem; font-weight:700; text-transform:uppercase; letter-spacing:0.4px; color:var(--text-muted); margin-bottom:6px; }
.kp-input, .kp-select { width:100%; font-family:inherit; font-size:0.92rem; color:var(--text); background:var(--card-bg); border:1px solid var(--border); border-radius:9px; padding:11px 13px; -webkit-appearance:none; appearance:none; }
.kp-input:focus, .kp-select:focus { outline:none; border-color:var(--accent); box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 22%, transparent); }
.kp-row { display:flex; gap:12px; flex-wrap:wrap; }
.kp-row > * { flex:1; min-width:140px; }
.kp-actions { display:flex; gap:10px; align-items:center; margin-top:18px; flex-wrap:wrap; }
.kp-actions .kp-spacer { margin-left:auto; }
.kp-count { font-size:0.82rem; color:var(--text-muted); }
.kp-count b { color:var(--text); }
.kp-search { position:relative; margin-bottom:12px; }
.kp-search .kp-input { padding-left:38px; }
.kp-search svg { position:absolute; left:12px; top:50%; transform:translateY(-50%); width:17px; height:17px; stroke:var(--text-muted); }
.kp-roster { display:grid; grid-template-columns:1fr 1fr; gap:9px; }
.kp-pick { display:flex; align-items:center; gap:10px; padding:10px 12px; border:1px solid var(--border); border-radius:10px; cursor:pointer; background:var(--card-bg); transition:border-color .15s, background .15s; user-select:none; }
.kp-pick:hover { border-color:var(--text-muted); }
.kp-pick.on { border-color:var(--accent); background:color-mix(in srgb, var(--accent) 9%, var(--card-bg)); }
.kp-box { width:20px; height:20px; border-radius:6px; border:2px solid var(--border); flex:none; display:grid; place-items:center; transition:.15s; }
.kp-pick.on .kp-box { background:var(--accent); border-color:var(--accent); }
.kp-box svg { width:12px; height:12px; stroke:#0d0d0d; stroke-width:2.6; opacity:0; }
.kp-pick.on .kp-box svg { opacity:1; }
.kp-av { width:30px; height:30px; border-radius:50%; flex:none; display:grid; place-items:center; font-size:0.7rem; font-weight:700; color:var(--accent); background:color-mix(in srgb, var(--accent) 14%, transparent); }
.kp-pick.guest .kp-av { color:var(--warning); background:color-mix(in srgb, var(--warning) 16%, transparent); }
.kp-nm { font-size:0.86rem; font-weight:500; }
.kp-nm small { display:block; font-size:0.68rem; color:var(--text-muted); font-weight:400; }
.kp-gtag { margin-left:auto; font-size:0.6rem; font-weight:700; letter-spacing:0.04em; text-transform:uppercase; color:var(--warning); background:color-mix(in srgb, var(--warning) 16%, transparent); padding:3px 7px; border-radius:6px; }
.kp-addguest { display:flex; gap:9px; margin-top:14px; padding-top:14px; border-top:1px solid var(--border); }
.kp-addguest .kp-input { flex:1; }
.kp-cov { display:flex; align-items:center; gap:14px; }
.kp-cov-track { flex:1; height:10px; border-radius:999px; background:var(--border); overflow:hidden; }
.kp-cov-fill { height:100%; background:var(--accent); border-radius:999px; width:0; transition:width .4s cubic-bezier(.2,.7,.2,1); }
.kp-cov-fill.over { background:var(--warning); }
.kp-cov-num { font-weight:700; font-size:0.85rem; white-space:nowrap; }
.kp-cov-note { font-size:0.8rem; color:var(--text-muted); margin-top:9px; }
.kp-cov-note b { color:var(--accent); }
.kp-cov-note.warn b { color:var(--warning); }
.kp-msg { background:color-mix(in srgb, var(--accent) 7%, var(--card-bg)); border:1px solid color-mix(in srgb, var(--accent) 22%, var(--border)); border-radius:10px; padding:14px 15px; font-size:0.84rem; line-height:1.5; position:relative; }
.kp-msg .kp-copy { position:absolute; top:10px; right:10px; }
.kp-addrow { display:flex; gap:10px; align-items:flex-end; flex-wrap:wrap; }
.kp-addrow .kp-nmf { flex:1; min-width:180px; }
.kp-addrow .kp-seatsf { flex:none; width:120px; }
.kp-cars { display:grid; grid-template-columns:1fr 1fr; gap:15px; }
.kp-car { border:1px solid var(--border); border-radius:14px; padding:17px; background:var(--card-bg); }
.kp-car-top { display:flex; align-items:center; gap:10px; margin-bottom:2px; }
.kp-car-top .kp-av { width:34px; height:34px; font-size:0.78rem; }
.kp-who { font-weight:700; font-size:0.95rem; line-height:1.15; }
.kp-who small { display:block; font-weight:500; font-size:0.7rem; color:var(--text-muted); }
.kp-del { margin-left:auto; background:none; border:none; cursor:pointer; color:var(--text-muted); width:30px; height:30px; border-radius:8px; display:grid; place-items:center; }
.kp-del:hover { background:var(--bg); color:var(--danger); }
.kp-del svg { width:17px; height:17px; }
.kp-carsvg { display:block; width:100%; height:auto; margin:6px 0 10px; }
.kp-seatlist { display:flex; flex-direction:column; gap:7px; }
.kp-seat { display:flex; align-items:center; gap:8px; }
.kp-ix { width:21px; height:21px; border-radius:50%; flex:none; display:grid; place-items:center; font-size:0.66rem; font-weight:700; color:var(--text-muted); background:var(--bg); border:1px solid var(--border); }
.kp-seat.filled .kp-ix { color:#0d0d0d; background:var(--accent); border-color:var(--accent); }
.kp-seat .kp-select { padding:9px 12px; font-size:0.83rem; border-radius:8px; }
.kp-seat .kp-select.filled { border-color:var(--accent); background:color-mix(in srgb, var(--accent) 8%, var(--card-bg)); }
.kp-pax { margin-top:13px; padding-top:13px; border-top:1px dashed var(--border); }
.kp-pax .kp-pax-h { font-size:0.68rem; font-weight:700; text-transform:uppercase; letter-spacing:0.5px; color:var(--text-muted); margin-bottom:9px; display:flex; align-items:center; gap:6px; }
.kp-pax-row { display:flex; align-items:center; gap:9px; padding:6px 0; }
.kp-pax-row .kp-av { width:27px; height:27px; font-size:0.62rem; }
.kp-pax-row .kp-pnm { font-size:0.82rem; font-weight:500; flex:1; }
.kp-pax-row .kp-call { font-size:0.74rem; font-weight:600; color:var(--accent); text-decoration:none; display:inline-flex; align-items:center; gap:5px; border:1px solid var(--border); border-radius:7px; padding:5px 9px; }
.kp-pax-row .kp-call:hover { border-color:var(--accent); }
.kp-pax-row .kp-call svg { width:13px; height:13px; }
.kp-pax-empty { font-size:0.78rem; color:var(--text-muted); font-style:italic; }
.kp-meet { margin-top:13px; padding-top:13px; border-top:1px dashed var(--border); }
.kp-meet-h { font-size:0.68rem; font-weight:700; text-transform:uppercase; letter-spacing:0.5px; color:var(--text); margin-bottom:9px; }
.kp-meet-h span { color:var(--text-muted); font-weight:500; text-transform:none; letter-spacing:0; }
.kp-meet-fields { display:flex; gap:8px; }
.kp-meet-fields .kp-place { flex:1; }
.kp-meet-fields .kp-time { flex:none; width:110px; }
.kp-meet .kp-input { padding:9px 11px; font-size:0.83rem; }
.kp-pin-btn { margin-top:8px; width:100%; }
.kp-pin-res { margin-top:8px; font-size:0.78rem; display:none; align-items:center; gap:7px; background:color-mix(in srgb, var(--warning) 12%, var(--card-bg)); border:1px solid color-mix(in srgb, var(--warning) 30%, var(--border)); border-radius:8px; padding:8px 10px; color:var(--text); }
.kp-pin-res.show { display:flex; }
.kp-pin-res svg { width:15px; height:15px; flex:none; stroke:var(--warning); }
.kp-pin-res a { color:var(--warning); font-weight:700; text-decoration:none; }
.kp-empty { text-align:center; padding:30px 18px; color:var(--text-muted); font-size:0.85rem; border:1px dashed var(--border); border-radius:14px; }
.kp-summary { display:flex; align-items:center; gap:10px; font-size:0.84rem; color:var(--text-muted); background:var(--card-bg); border:1px solid var(--border); border-radius:10px; padding:12px 15px; margin-bottom:14px; }
.kp-summary .kp-dot { width:7px; height:7px; border-radius:50%; background:var(--accent); flex:none; }
.kp-summary b { color:var(--text); }
.kp-summary .kp-when { margin-left:auto; }
.kp-note { font-size:0.74rem; color:var(--text-muted); line-height:1.5; }
.kp-modeswitch { display:inline-flex; border:1px solid var(--border); border-radius:10px; overflow:hidden; margin-bottom:16px; }
.kp-modeswitch button { background:none; border:none; border-right:1px solid var(--border); color:var(--text-muted); font-family:inherit; font-size:0.82rem; font-weight:600; padding:9px 16px; cursor:pointer; transition:all .15s; }
.kp-modeswitch button:last-child { border-right:none; }
.kp-modeswitch button.active { background:var(--accent); color:#0d0d0d; }
.kp-carbox { margin:6px 0 10px; min-height:90px; display:flex; align-items:center; justify-content:center; }
.kp-carbox .kp-carsvg { margin:0; }
.kp-carimg { display:block; width:100%; height:140px; object-fit:contain; background:#fff; border-radius:12px; padding:4px; }
.kp-carbox.kp-generic { flex-direction:column; }
.kp-gennote { font-size:0.66rem; color:var(--text-muted); text-align:center; margin-top:5px; font-style:italic; line-height:1.4; }
.kp-bilmeta { display:flex; align-items:center; gap:7px; font-size:0.72rem; color:var(--text-muted); font-weight:600; margin:0 0 4px; flex-wrap:wrap; }
.kp-swatch { width:12px; height:12px; border-radius:3px; border:1px solid rgba(128,128,128,.4); flex:none; }
.kp-who .kp-dphone { margin-top:4px; }
.kp-dphone { font-size:0.74rem; font-weight:700; color:var(--accent); text-decoration:none; display:inline-flex; align-items:center; gap:5px; white-space:nowrap; }
.kp-dphone svg { width:13px; height:13px; }
.kp-optrow { display:flex; gap:9px; flex-wrap:wrap; margin-top:11px; padding-top:11px; border-top:1px dashed var(--border); }
.kp-optrow > label { flex:1; min-width:130px; margin:0; }
.kp-opthint { font-size:0.7rem; color:var(--text-muted); margin-top:9px; line-height:1.5; }
.kp-myhero { background:var(--card-bg); border:1px solid var(--border); border-radius:14px; padding:18px; }
.kp-gps-btn { width:100%; margin-top:12px; font-size:0.95rem; padding:13px; text-decoration:none; text-align:center; }
.kp-gps-btn.dis { opacity:.55; pointer-events:none; }
.kp-ro-meet { display:flex; gap:26px; flex-wrap:wrap; margin-top:13px; padding:12px 15px; background:var(--bg); border:1px solid var(--border); border-radius:10px; }
.kp-ro-meet .lab { font-size:0.64rem; text-transform:uppercase; letter-spacing:0.5px; color:var(--text-muted); font-weight:700; }
.kp-ro-meet .val { font-size:0.98rem; font-weight:700; margin-top:3px; }
.kp-mehi { display:inline-block; font-size:0.62rem; font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:#0d0d0d; background:var(--accent); padding:3px 8px; border-radius:6px; margin-left:6px; }
.kp-pick-right { margin-left:auto; display:flex; gap:7px; align-items:center; flex:none; }
.kp-pick-right .kp-gtag { margin-left:0; }
.kp-self { font-family:inherit; font-size:0.66rem; font-weight:700; letter-spacing:.02em; color:var(--text-muted); background:var(--bg); border:1px solid var(--border); border-radius:7px; padding:4px 8px; cursor:pointer; display:inline-flex; align-items:center; gap:4px; white-space:nowrap; transition:all .15s; }
.kp-self:hover { border-color:var(--text-muted); color:var(--text); }
.kp-self.on { color:#0d0d0d; background:var(--warning); border-color:var(--warning); }
.kp-self svg { width:12px; height:12px; }
.kp-pick.self { border-color:color-mix(in srgb, var(--warning) 45%, var(--border)); background:color-mix(in srgb, var(--warning) 7%, var(--card-bg)); }
@media (max-width:620px){ .kp-cars{grid-template-columns:1fr;} .kp-roster{grid-template-columns:1fr;} }

/* ===================== STYREKOMMUNIKASJON ===================== */
.sc-wrap { max-width:840px; margin:0 auto; }
.sc-head { display:flex; justify-content:space-between; align-items:flex-start; gap:14px; flex-wrap:wrap; margin-bottom:4px; }
.sc-title { font-size:1.2rem; margin:0; }
.sc-sub { font-size:0.8rem; color:var(--text-muted); margin:4px 0 16px; line-height:1.45; max-width:640px; }
.sc-boardtabs { display:flex; gap:7px; margin-bottom:16px; flex-wrap:wrap; }
.sc-btab { display:inline-flex; align-items:center; gap:7px; border:1px solid var(--border); background:var(--card-bg); color:var(--text-muted); border-radius:999px; padding:8px 15px; font-size:0.84rem; font-weight:600; cursor:pointer; transition:all .15s; }
.sc-btab:hover { color:var(--text); }
.sc-btab.active { color:var(--text); border-color:var(--sc-bc); background:color-mix(in srgb, var(--sc-bc) 14%, var(--card-bg)); }
.sc-single { display:inline-flex; align-items:center; gap:8px; font-size:0.9rem; font-weight:600; color:var(--text); margin-bottom:14px; padding:8px 14px; border:1px solid var(--border); border-left:3px solid var(--sc-bc); border-radius:9px; background:var(--card-bg); }
.sc-single-note { font-weight:400; color:var(--text-muted); font-size:0.76rem; }
.sc-thread { display:flex; flex-direction:column; gap:11px; padding:6px 2px 18px; }
.sc-day { align-self:center; font-size:0.68rem; color:var(--text-muted); background:var(--card-bg); border:1px solid var(--border); border-radius:999px; padding:3px 11px; margin:6px 0; }
.sc-empty { text-align:center; color:var(--text-muted); font-size:0.85rem; padding:32px 12px; }
.sc-msg { display:flex; flex-direction:column; max-width:80%; }
.sc-msg.me { align-self:flex-end; align-items:flex-end; }
.sc-author { font-weight:700; color:var(--text); font-size:0.72rem; margin:0 5px 3px; }
.sc-bubble { background:var(--card-bg); border:1px solid var(--border); border-radius:15px; padding:10px 14px; font-size:0.89rem; line-height:1.45; color:var(--text); white-space:pre-wrap; overflow-wrap:anywhere; }
.sc-msg.me .sc-bubble { background:color-mix(in srgb, var(--sc-bc) 18%, var(--card-bg)); border-color:color-mix(in srgb, var(--sc-bc) 40%, var(--border)); }
.sc-meta { font-size:0.67rem; color:var(--text-muted); margin:4px 5px 0; display:flex; gap:9px; align-items:center; }
.sc-edit-btn { background:none; border:none; color:var(--accent); cursor:pointer; font-size:0.67rem; font-weight:600; padding:0; }
.sc-locktag { display:inline-flex; align-items:center; gap:3px; opacity:0.7; }
.sc-editbox { display:flex; flex-direction:column; gap:7px; width:100%; }
.sc-editbox textarea { width:100%; font-family:inherit; font-size:0.88rem; color:var(--text); background:var(--card-bg); border:1px solid var(--sc-bc); border-radius:11px; padding:9px 12px; resize:vertical; min-height:54px; }
.sc-editact { display:flex; gap:7px; }
.sc-composer { display:flex; gap:9px; align-items:flex-end; border-top:1px solid var(--border); padding-top:14px; }
.sc-composer textarea { flex:1; font-family:inherit; font-size:0.9rem; color:var(--text); background:var(--card-bg); border:1px solid var(--border); border-radius:12px; padding:11px 13px; resize:none; min-height:46px; max-height:160px; }
.sc-composer textarea:focus { outline:none; border-color:var(--sc-bc); }
.sc-backup { font-size:0.7rem; color:var(--text-muted); text-align:center; margin-top:14px; opacity:0.8; }
.sc-locked { text-align:center; padding:54px 22px; color:var(--text-muted); }
.sc-locked .sc-lock-ico { font-size:2.1rem; display:block; margin-bottom:12px; }
.sc-locked h3 { color:var(--text); font-size:1rem; margin:0 0 8px; }
.sc-locked p { font-size:0.84rem; line-height:1.5; max-width:440px; margin:0 auto; }

/* ===================== MELDINGER-hub (kanal-liste + medlemmer + opprett) ===================== */
.mg-wrap { max-width:860px; margin:0 auto; }
.mg-toolbar { display:flex; justify-content:space-between; align-items:center; gap:10px; margin:2px 0 16px; }
.mg-section { margin-bottom:18px; }
.mg-section > h4 { font-size:0.7rem; text-transform:uppercase; letter-spacing:0.5px; color:var(--text-muted); margin:0 0 8px; font-weight:700; }
.mg-list { display:flex; flex-direction:column; gap:8px; }
.mg-item { display:flex; align-items:center; gap:12px; padding:11px 14px; border:1px solid var(--border); border-radius:12px; background:var(--card-bg); cursor:pointer; transition:border-color .15s, background .15s; text-align:left; width:100%; font-family:inherit; }
.mg-item:hover { border-color:var(--text-muted); }
.mg-ico { width:40px; height:40px; border-radius:11px; display:grid; place-items:center; font-size:1.15rem; flex:none; background:color-mix(in srgb, var(--mg-c) 16%, var(--card-bg)); border:1px solid color-mix(in srgb, var(--mg-c) 35%, var(--border)); }
.mg-it-main { flex:1; min-width:0; }
.mg-it-name { font-weight:650; font-size:0.9rem; color:var(--text); display:flex; align-items:center; gap:7px; }
.mg-it-sub { font-size:0.76rem; color:var(--text-muted); margin-top:2px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; display:block; max-width:100%; }
.mg-it-side { display:flex; flex-direction:column; align-items:flex-end; gap:5px; flex:none; }
.mg-badge { background:var(--accent); color:var(--bg); font-size:0.66rem; font-weight:800; border-radius:999px; padding:1px 7px; min-width:20px; text-align:center; line-height:1.5; }
.mg-muted-ico { font-size:0.8rem; opacity:0.6; }
.mg-pill { font-size:0.62rem; font-weight:700; text-transform:uppercase; letter-spacing:0.3px; padding:2px 7px; border-radius:999px; border:1px solid color-mix(in srgb, var(--mg-c) 40%, var(--border)); color:var(--mg-c); }
.mg-empty { text-align:center; padding:48px 22px; color:var(--text-muted); }
.mg-empty .mg-empty-ico { font-size:2rem; display:block; margin-bottom:12px; }
.mg-empty h3 { color:var(--text); font-size:1rem; margin:0 0 8px; }
.mg-empty p { font-size:0.84rem; line-height:1.5; max-width:430px; margin:0 auto; }
/* Samtale-header sticker til toppen av siden mens du scroller, så tilbake-
   knappen og lag-navnet alltid er nådbart uten å scrolle hele veien opp.
   top-verdien er høyden på den globale .app-header (sticky over oss). */
.mg-cv-head {
  display:flex; align-items:center; gap:11px;
  padding:12px 0 13px;
  border-bottom:1px solid var(--border);
  margin-bottom:12px;
  position:sticky; top:72px; z-index:50;
  background:var(--bg);
}
.mg-back { position:relative; background:none; border:1px solid var(--border); border-radius:9px; color:var(--text); cursor:pointer; padding:8px 11px; font-size:0.82rem; font-weight:600; flex:none; }
.mg-back:hover { border-color:var(--text-muted); }
/* Ulest-badge på tilbake-pilen: viser totalt antall uleste meldinger i
   ANDRE samtaler, så du ser om noe venter mens du står i én chat. */
.mg-back-badge {
  position:absolute; top:-6px; right:-6px;
  background:var(--accent); color:#0d0d0d;
  font-size:0.62rem; font-weight:800;
  border-radius:999px; min-width:18px; height:18px;
  display:inline-flex; align-items:center; justify-content:center;
  padding:0 5px; line-height:1;
  box-shadow:0 0 0 2px var(--bg);
}
/* Tittel-blokken er klikkbar — åpner medlemsliste. Større treffeflate enn
   den gamle «👥 X medlemmer»-tekstlenken. */
.mg-cv-title { flex:1; min-width:0; cursor:pointer; padding:4px 6px; margin:-4px -6px; border-radius:8px; transition:background 0.12s; }
.mg-cv-title:hover { background:color-mix(in srgb, var(--accent) 6%, transparent); }
.mg-cv-title:focus-visible { outline:2px solid var(--accent); outline-offset:2px; }
.mg-cv-title:hover .mg-cv-name-text { text-decoration:underline; }
.mg-cv-name { font-weight:700; font-size:1rem; color:var(--text); display:flex; align-items:center; gap:8px; }
.mg-cv-meta { font-size:0.72rem; color:var(--text-muted); margin-top:3px; }
.mg-memberlink { background:none; border:none; color:var(--accent); font:inherit; font-size:0.72rem; font-weight:600; cursor:pointer; padding:0; }
.mg-memberlink:hover { text-decoration:underline; }
@media (max-width: 768px) {
  /* Mobil-header er lavere — juster sticky-offset så den klistrer rett under. */
  .mg-cv-head { top:58px; padding:10px 0 11px; }
}
.mg-mute-btn { background:none; border:1px solid var(--border); border-radius:9px; color:var(--text-muted); cursor:pointer; padding:8px 11px; font-size:0.78rem; font-weight:600; flex:none; }
.mg-mute-btn.on { color:var(--accent); border-color:color-mix(in srgb, var(--accent) 45%, var(--border)); }
.mg-pushnote { font-size:0.71rem; color:var(--text-muted); background:color-mix(in srgb, var(--accent) 5%, var(--card-bg)); border:1px solid var(--border); border-radius:9px; padding:8px 12px; margin-bottom:12px; display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.mg-membernote { font-size:0.76rem; color:var(--text-muted); background:color-mix(in srgb, var(--accent) 5%, var(--card-bg)); border:1px solid var(--border); border-radius:9px; padding:9px 12px; margin-bottom:12px; line-height:1.45; }
.mg-mlist { display:flex; flex-direction:column; gap:7px; }
.mg-mrow { display:flex; align-items:center; gap:12px; padding:10px 13px; border:1px solid var(--border); border-radius:11px; background:var(--card-bg); }
.mg-mavatar { width:36px; height:36px; border-radius:50%; flex:none; display:grid; place-items:center; font-size:0.76rem; font-weight:700; color:var(--text); background:color-mix(in srgb, var(--mg-c) 18%, var(--card-bg)); border:1px solid color-mix(in srgb, var(--mg-c) 38%, var(--border)); }
.mg-minfo { flex:1; min-width:0; }
.mg-mname { font-size:0.88rem; font-weight:650; color:var(--text); display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.mg-mtag { font-size:0.6rem; font-weight:700; text-transform:uppercase; letter-spacing:0.3px; color:var(--text-muted); border:1px solid var(--border); border-radius:999px; padding:1px 7px; }
.mg-rm { background:none; border:1px solid color-mix(in srgb, #f87171 35%, var(--border)); color:#f87171; border-radius:8px; font-size:0.74rem; font-weight:600; padding:6px 11px; cursor:pointer; flex:none; }
.mg-rm:hover { background:color-mix(in srgb, #f87171 12%, var(--card-bg)); }
.mg-mfoot { margin-top:16px; display:flex; flex-direction:column; gap:9px; }
.mg-leave { color:#f87171; border-color:color-mix(in srgb, #f87171 35%, var(--border)); align-self:flex-start; }
.mg-delete { color:#f87171; border-color:color-mix(in srgb, #f87171 35%, var(--border)); align-self:flex-start; }
.mg-delete:hover { background:color-mix(in srgb, #f87171 12%, var(--card-bg)); }
.mg-addbtn { align-self:flex-start; }
.mg-create { border:1px solid var(--border); border-radius:14px; padding:18px; background:var(--card-bg); max-width:580px; }
.mg-create h3 { margin:0 0 4px; font-size:1.05rem; }
.mg-create .mg-c-sub { font-size:0.78rem; color:var(--text-muted); margin:0 0 16px; line-height:1.4; }
.mg-field { margin-bottom:15px; }
.mg-field > label { display:block; font-size:0.7rem; font-weight:700; text-transform:uppercase; letter-spacing:0.4px; color:var(--text-muted); margin-bottom:7px; }
.mg-typesel { display:flex; gap:8px; flex-wrap:wrap; }
.mg-typeopt { flex:1; min-width:170px; border:1px solid var(--border); border-radius:10px; padding:11px 13px; cursor:pointer; background:var(--bg); transition:all .15s; }
.mg-typeopt:hover { border-color:var(--text-muted); }
.mg-typeopt.on { border-color:var(--accent); background:color-mix(in srgb, var(--accent) 8%, var(--card-bg)); }
.mg-typeopt b { display:block; font-size:0.86rem; color:var(--text); }
.mg-typeopt small { color:var(--text-muted); font-size:0.72rem; line-height:1.35; display:block; margin-top:3px; }
.mg-input { width:100%; font-family:inherit; font-size:0.9rem; color:var(--text); background:var(--bg); border:1px solid var(--border); border-radius:9px; padding:10px 12px; }
.mg-input:focus { outline:none; border-color:var(--accent); }
.mg-presets { display:flex; gap:7px; flex-wrap:wrap; margin-bottom:9px; }
.mg-preset { font-size:0.74rem; font-weight:600; border:1px dashed var(--border); background:none; color:var(--text-muted); border-radius:999px; padding:5px 11px; cursor:pointer; }
.mg-preset:hover { color:var(--text); border-color:var(--text-muted); }
.mg-pool { display:flex; flex-direction:column; gap:4px; max-height:240px; overflow:auto; border:1px solid var(--border); border-radius:10px; padding:7px; }
.mg-poolrow { display:flex; align-items:center; gap:11px; padding:8px 9px; border-radius:8px; cursor:pointer; }
.mg-poolrow:hover { background:color-mix(in srgb, var(--text) 5%, var(--card-bg)); }
.mg-poolrow input { width:16px; height:16px; flex:none; }
.mg-poolrow .mg-pn { font-size:0.86rem; color:var(--text); }
.mg-poolrow small { color:var(--text-muted); font-size:0.74rem; }
.mg-pool-empty { font-size:0.8rem; color:var(--text-muted); padding:10px; }
.mg-pickbar { display:flex; gap:8px; flex-wrap:wrap; align-items:center; margin-bottom:9px; }
.mg-filtersel { width:auto; min-width:140px; padding:7px 10px; font-size:0.82rem; }
.mg-rolefilter { display:inline-flex; border:1px solid var(--border); border-radius:9px; overflow:hidden; }
.mg-rolefilter button { background:none; border:none; border-right:1px solid var(--border); color:var(--text-muted); font-size:0.78rem; font-weight:600; padding:7px 13px; cursor:pointer; }
.mg-rolefilter button:last-child { border-right:none; }
.mg-rolefilter button.on { background:color-mix(in srgb, var(--accent) 12%, var(--card-bg)); color:var(--text); }
.mg-selcount { font-size:0.74rem; color:var(--text-muted); margin-top:8px; font-weight:600; }
.mg-create-actions { display:flex; gap:8px; margin-top:6px; }

/* ── Meldinger: reaksjoner, vedlegg, fil-kø, fane-merke ── */
.mg-reacts { display:flex; flex-wrap:wrap; gap:5px; margin:5px 4px 0; align-items:center; }
.sc-msg.me .mg-reacts { justify-content:flex-end; }
.mg-react { display:inline-flex; align-items:center; gap:3px; font-size:0.78rem; border:1px solid var(--border); background:var(--card-bg); color:var(--text); border-radius:999px; padding:2px 8px; cursor:pointer; line-height:1.4; }
.mg-react.on { border-color:color-mix(in srgb, var(--accent) 50%, var(--border)); background:color-mix(in srgb, var(--accent) 12%, var(--card-bg)); }
.mg-react-add { background:none; border:none; color:var(--text-muted); cursor:pointer; font-size:0.78rem; padding:0; opacity:0.7; }
.mg-react-add:hover { opacity:1; }
.mg-react-palette { display:inline-flex; gap:2px; background:var(--card-bg); border:1px solid var(--border); border-radius:999px; padding:3px 6px; flex-wrap:wrap; }
.mg-react-palette button { background:none; border:none; cursor:pointer; font-size:1.05rem; padding:2px 3px; border-radius:6px; line-height:1; }
.mg-react-palette button:hover { background:color-mix(in srgb, var(--text) 8%, var(--card-bg)); }
.mg-atts { display:flex; flex-direction:column; gap:6px; margin:6px 4px 0; max-width:80%; }
.sc-msg.me .mg-atts { align-items:flex-end; }
.mg-att-img { display:inline-block; max-width:240px; border-radius:12px; overflow:hidden; border:1px solid var(--border); }
.mg-att-img img { display:block; max-width:100%; height:auto; }
.mg-att-file { display:inline-flex; align-items:center; gap:7px; text-decoration:none; color:var(--text); background:var(--card-bg); border:1px solid var(--border); border-radius:10px; padding:8px 12px; font-size:0.84rem; max-width:280px; }
.mg-att-file:hover { border-color:var(--text-muted); }
.mg-att-name { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.mg-att-size { color:var(--text-muted); font-size:0.72rem; flex:none; }
.mg-file-btn { background:none; border:1px solid var(--border); border-radius:10px; color:var(--text-muted); cursor:pointer; font-size:1.05rem; padding:8px 11px; flex:none; align-self:flex-end; }
.mg-file-btn:hover { color:var(--text); border-color:var(--text-muted); }
.mg-queue { display:flex; flex-wrap:wrap; gap:6px; padding:0 2px; margin-bottom:8px; }
.mg-queue:empty { display:none; }
.mg-qchip { display:inline-flex; align-items:center; gap:6px; font-size:0.78rem; background:var(--card-bg); border:1px solid var(--border); border-radius:999px; padding:4px 10px; color:var(--text); }
.mg-qchip button { background:none; border:none; color:var(--text-muted); cursor:pointer; font-size:0.8rem; padding:0; }
.mg-quploading { color:var(--text-muted); }
.mg-nav-badge { display:inline-flex; align-items:center; justify-content:center; min-width:18px; height:18px; padding:0 5px; margin-left:6px; font-size:0.66rem; font-weight:800; line-height:1; border-radius:999px; background:#ef4444; color:#fff; vertical-align:middle; }

/* ════════════════════════════════════════════════════════════════════
   ARRANGEMENT (Om laget → 📋 Arrangement) — portet fra design/mockup.html.
   Temasatt via CSS-variabler (lys + mørk). arr-* prefiks, scopet på panelet.
   ════════════════════════════════════════════════════════════════════ */
#om-arrangement{ --arr-inset: color-mix(in srgb, var(--text) 5%, var(--card-bg)); --arr-box: color-mix(in srgb, var(--text) 3%, var(--card-bg)); }
#om-arrangement .arr-card{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;padding:16px;margin-bottom:14px;}
#om-arrangement .arr-card h3.arr-h{font-size:1rem;font-weight:700;margin-bottom:4px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
#om-arrangement .arr-sub{font-size:0.8rem;color:var(--text-muted);margin-bottom:14px;line-height:1.5;}
#om-arrangement .arr-hidden{display:none !important;}
#om-arrangement .arr-magic{display:flex;gap:12px;align-items:flex-start;background:color-mix(in srgb,var(--success) 10%,var(--card-bg));border:1px solid color-mix(in srgb,var(--success) 35%,var(--border));border-radius:14px;padding:14px 16px;margin-bottom:14px;}
#om-arrangement .arr-magic .ic{font-size:1.4rem;}
#om-arrangement .arr-magic p{font-size:0.84rem;line-height:1.55;color:var(--text);}
#om-arrangement .arr-magic .src{font-size:0.72rem;color:var(--text-muted);margin-top:4px;}
#om-arrangement .arr-types{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;}
#om-arrangement .arr-type{display:inline-flex;align-items:center;gap:6px;padding:10px 15px;border-radius:10px;border:1px solid var(--border);background:var(--arr-inset);color:var(--text);font-size:0.86rem;font-weight:600;cursor:pointer;transition:all .12s;}
#om-arrangement .arr-type.active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);}
#om-arrangement .arr-subtypes{display:flex;flex-wrap:wrap;gap:7px;margin-top:12px;}
#om-arrangement .arr-subtype{font-size:0.78rem;padding:7px 11px;border-radius:8px;border:1px solid var(--border);background:var(--arr-inset);color:var(--text-muted);cursor:pointer;font-weight:600;}
#om-arrangement .arr-subtype.active{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent);}
#om-arrangement .arr-tag{font-size:0.62rem;font-weight:700;text-transform:uppercase;letter-spacing:0.4px;color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,transparent);border:1px solid color-mix(in srgb,var(--accent) 30%,var(--border));border-radius:20px;padding:2px 8px;}
#om-arrangement .arr-field{margin-top:13px;}
#om-arrangement .arr-field label{display:flex;align-items:center;gap:8px;font-size:0.74rem;color:var(--text-muted);margin-bottom:5px;font-weight:600;}
#om-arrangement .arr-field .val{background:var(--arr-inset);border:1px solid var(--border);border-radius:8px;padding:9px 12px;font-size:0.86rem;color:var(--text);}
#om-arrangement .arr-field input.val:focus,#om-arrangement .arr-field select.val:focus{outline:none;border-color:var(--accent);}
#om-arrangement .arr-field input.val,#om-arrangement .arr-field select.val{width:100%;font-family:inherit;}
#om-arrangement .arr-row2{display:flex;gap:12px;flex-wrap:wrap;} #om-arrangement .arr-row2 .arr-field{flex:1;min-width:150px;}
/* Mobil: 150px-minimum tvinger overlap på smale skjermer (datetime-local er
   ekstra bred på iOS). Tving full bredde — én rad per felt. */
@media (max-width: 600px) {
  #om-arrangement .arr-row2 { flex-direction: column; gap: 0; }
  #om-arrangement .arr-row2 .arr-field { width: 100%; min-width: 0; }
}
/* datetime-local kan rendre wider enn container. Sikre boks-modellen. */
#om-arrangement .arr-field input.val[type="datetime-local"],
#om-arrangement .arr-field input.val[type="date"] { max-width: 100%; box-sizing: border-box; }
#om-arrangement .arr-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:11px 18px;border-radius:9px;border:none;cursor:pointer;font-size:0.85rem;font-weight:700;}
#om-arrangement .arr-btn-primary{background:var(--accent);color:var(--bg);} html[data-theme="light"] #om-arrangement .arr-btn-primary{color:#fff;}
#om-arrangement .arr-btn-ghost{background:var(--arr-inset);border:1px solid var(--border);color:var(--text);}
#om-arrangement .arr-switch{display:inline-flex;align-items:center;gap:9px;font-size:0.82rem;cursor:pointer;color:var(--text);}
#om-arrangement .arr-switch input{display:none;}
#om-arrangement .arr-switch .track{width:38px;height:21px;border-radius:20px;background:var(--border);position:relative;transition:.15s;flex:none;}
#om-arrangement .arr-switch .track::after{content:"";position:absolute;top:2px;left:2px;width:17px;height:17px;border-radius:50%;background:var(--text-muted);transition:.15s;}
#om-arrangement .arr-switch input:checked + .track{background:color-mix(in srgb,var(--accent) 40%,transparent);}
#om-arrangement .arr-switch input:checked + .track::after{left:19px;background:var(--accent);}
#om-arrangement .arr-series{margin-top:11px;background:var(--arr-inset);border:1px dashed var(--border);border-radius:9px;padding:11px 13px;}
#om-arrangement .arr-box{background:var(--arr-box);border:1px solid var(--border);border-radius:11px;padding:13px 14px;margin-bottom:11px;margin-top:11px;}
#om-arrangement .arr-box h4{font-size:0.82rem;font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:7px;}
#om-arrangement .arr-kv{display:flex;gap:10px;font-size:0.82rem;padding:4px 0;line-height:1.5;}
#om-arrangement .arr-kv .k{color:var(--text-muted);min-width:96px;flex-shrink:0;}
#om-arrangement .arr-kv .v{color:var(--text);}
#om-arrangement .arr-kv .v a{color:var(--accent);}
#om-arrangement .arr-verdict{border-radius:8px;padding:9px 12px;font-size:0.82rem;margin-top:10px;line-height:1.5;color:var(--text);}
#om-arrangement .arr-verdict.warn{background:color-mix(in srgb,var(--warning) 13%,var(--card-bg));border:1px solid color-mix(in srgb,var(--warning) 40%,var(--border));}
#om-arrangement .arr-att-bar{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap;}
#om-arrangement .arr-att-stat{flex:1;min-width:80px;text-align:center;background:var(--arr-inset);border:1px solid var(--border);border-radius:9px;padding:9px;}
#om-arrangement .arr-att-stat .n{font-size:1.5rem;font-weight:800;line-height:1;}
#om-arrangement .arr-att-stat .l{font-size:0.7rem;color:var(--text-muted);margin-top:3px;}
#om-arrangement .arr-att-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-top:1px solid var(--border);}
#om-arrangement .arr-att-row .nm{flex:1;font-size:0.84rem;color:var(--text);} #om-arrangement .arr-att-row .nm .meta{font-size:0.7rem;color:var(--text-muted);}
#om-arrangement .arr-ab{width:30px;height:30px;border-radius:7px;border:1px solid var(--border);background:var(--arr-inset);color:var(--text-muted);font-size:0.85rem;cursor:pointer;}
#om-arrangement .arr-ab.yes.on{background:color-mix(in srgb,var(--success) 20%,transparent);border-color:var(--success);color:var(--success);}
#om-arrangement .arr-ab.no.on{background:color-mix(in srgb,var(--danger) 18%,transparent);border-color:var(--danger);color:var(--danger);}
#om-arrangement .arr-cup-match{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--arr-inset);border:1px solid var(--border);border-radius:9px;margin-bottom:7px;font-size:0.82rem;}
#om-arrangement .arr-cup-match:hover{border-color:var(--accent);}
#om-arrangement .arr-cup-match .cm-no{width:28px;height:28px;border-radius:6px;background:color-mix(in srgb,var(--accent) 14%,transparent);display:flex;align-items:center;justify-content:center;font-size:0.85rem;flex:none;}
#om-arrangement .arr-cup-match .cm-main{flex:1;color:var(--text);font-weight:600;}
#om-arrangement .arr-cup-match .cm-meta{font-size:0.72rem;color:var(--text-muted);font-weight:400;margin-top:2px;}
#om-arrangement .arr-rsvp{display:flex;gap:8px;font-size:0.74rem;flex:none;}
#om-arrangement .arr-disclaimer{font-size:0.72rem;color:var(--text-muted);line-height:1.5;margin-top:6px;}
#om-arrangement details summary{cursor:pointer;font-size:0.86rem;font-weight:700;color:var(--text);}
@media(max-width:560px){ #om-arrangement .arr-kv .k{min-width:80px;} }

/* Arrangement: medlemsplukker (kun inviterte) */
#om-arrangement .arr-pick{max-height:280px;overflow-y:auto;border:1px solid var(--border);border-radius:9px;background:var(--arr-inset);}
#om-arrangement .arr-pick-row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-bottom:1px solid var(--border);cursor:pointer;font-size:0.84rem;color:var(--text);}
#om-arrangement .arr-pick-row:last-child{border-bottom:none;}
#om-arrangement .arr-pick-row.on{background:color-mix(in srgb,var(--accent) 8%,transparent);}
#om-arrangement .arr-pick-row input{accent-color:var(--accent);width:16px;height:16px;flex:none;}
#om-arrangement .arr-pick-row .pk-nm{flex:1;}
#om-arrangement .arr-pick-row .pk-meta{font-size:0.7rem;color:var(--text-muted);}

/* Arrangement: hall-søk (venues + Google-fallback) */
#om-arrangement .arr-venue-wrap{position:relative;}
#om-arrangement .arr-venue-sug{border-radius:0 0 9px 9px;overflow:hidden;}
#om-arrangement .arr-venue-sug:not(:empty){border:1px solid var(--border);border-top:none;background:var(--card-bg);}
#om-arrangement .arr-venue-row{padding:8px 12px;font-size:0.8rem;color:var(--text);cursor:pointer;border-bottom:1px solid var(--border);}
#om-arrangement .arr-venue-row:last-child{border-bottom:none;}
#om-arrangement .arr-venue-row:hover{background:var(--arr-inset);}
#om-arrangement .arr-venue-row .muted,#om-arrangement .arr-venue-row.muted{color:var(--text-muted);font-size:0.72rem;cursor:default;}
#om-arrangement .arr-venue-row.ok{color:var(--success);cursor:default;}

/* Arrangement: drakt-velger + kollisjon */
#om-arrangement .arr-swatches{display:flex;flex-wrap:wrap;gap:5px;margin:4px 0 8px;}
#om-arrangement .arr-swatch{width:24px;height:24px;border-radius:6px;border:1px solid rgba(128,128,128,.4);cursor:pointer;padding:0;position:relative;}
#om-arrangement .arr-swatch.on{outline:2px solid var(--accent);outline-offset:1px;}
#om-arrangement .arr-jersey{vertical-align:middle;}
#om-arrangement .arr-kit-empty{display:inline-flex;align-items:center;justify-content:center;border:1px dashed var(--border);border-radius:6px;color:var(--text-muted);font-weight:700;}
#om-arrangement .arr-kit-edit{display:flex;gap:14px;align-items:flex-start;}
#om-arrangement .arr-kit-prev{flex:none;}
#om-arrangement .arr-kit-ctrls{flex:1;min-width:0;}
#om-arrangement .arr-kit-ctrls label{display:block;font-size:0.72rem;color:var(--text-muted);font-weight:600;margin-top:6px;}
#om-arrangement .arr-kit-pair{display:flex;gap:16px;flex-wrap:wrap;}
#om-arrangement .arr-kit-pair > div{flex:1;min-width:220px;}
#om-arrangement .arr-kit-sub{font-size:0.76rem;font-weight:700;color:var(--text);margin-bottom:4px;}
#om-arrangement .arr-kit-label{font-size:0.78rem;font-weight:700;color:var(--text);display:flex;align-items:center;flex-wrap:wrap;gap:4px;}
#om-arrangement .arr-kit-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:4px 0;}
#om-arrangement .arr-kit-mini{display:inline-flex;align-items:center;gap:4px;font-size:0.78rem;color:var(--text);}
#om-arrangement .arr-kit-muted{font-size:0.78rem;color:var(--text-muted);}
#om-arrangement .arr-kit-opp{margin-top:12px;border-top:1px solid var(--border);padding-top:10px;}
#om-arrangement .arr-kit-vs{display:flex;align-items:center;gap:14px;justify-content:center;margin:6px 0;}
#om-arrangement .arr-kit-side{text-align:center;}
#om-arrangement .arr-kit-x{color:var(--text-muted);font-size:0.8rem;font-weight:700;}
/* Arrangement: vedlegg */
#om-arrangement .arr-att-grid{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px;}
#om-arrangement .arr-att-item{position:relative;}
#om-arrangement .arr-att-item img{width:90px;height:90px;object-fit:cover;border-radius:9px;border:1px solid var(--border);display:block;}
#om-arrangement .arr-att-file{display:inline-flex;align-items:center;gap:6px;padding:10px 12px;border:1px solid var(--border);border-radius:9px;background:var(--arr-inset);color:var(--text);font-size:0.8rem;text-decoration:none;}
#om-arrangement .arr-att-del{position:absolute;top:-6px;right:-6px;width:20px;height:20px;border-radius:50%;border:none;background:var(--danger);color:#fff;font-size:0.7rem;cursor:pointer;line-height:1;}
/* Arrangement: kommentarer */
#om-arrangement .arr-cmt{padding:8px 0;border-top:1px solid var(--border);}
#om-arrangement .arr-cmt-h{display:flex;align-items:center;gap:8px;font-size:0.8rem;color:var(--text);}
#om-arrangement .arr-cmt-h .pk-meta{font-size:0.7rem;color:var(--text-muted);}
#om-arrangement .arr-cmt-del{margin-left:auto;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:0.8rem;}
#om-arrangement .arr-cmt-b{font-size:0.85rem;color:var(--text);line-height:1.5;margin-top:3px;}
#om-arrangement .arr-cmt-compose{display:flex;gap:8px;margin-top:10px;}
#om-arrangement .arr-cmt-compose .val{flex:1;background:var(--arr-inset);border:1px solid var(--border);border-radius:8px;padding:9px 12px;font-size:0.85rem;color:var(--text);font-family:inherit;}
