:root {
  --bg: oklch(0.17 0.012 60);
  --bg-raise: oklch(0.21 0.014 60);
  --bg-hover: oklch(0.25 0.016 60);
  --line: oklch(0.30 0.015 60);
  --ink: oklch(0.93 0.008 75);
  --ink-dim: oklch(0.66 0.012 70);
  --accent: oklch(0.70 0.17 55);
  --accent-soft: oklch(0.70 0.17 55 / 0.12);
  --accent-ink: oklch(0.20 0.05 55);
  --win: oklch(0.72 0.13 145);
  --loss: oklch(0.62 0.14 25);
  --svt: oklch(0.62 0.10 250);
  --tv4: oklch(0.58 0.16 20);
}

* { box-sizing: border-box; }

[hidden] { display: none !important; }

html { color-scheme: dark; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font: 400 1rem/1.5 system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  -webkit-tap-highlight-color: transparent;
}

a { color: inherit; }

.wrap { max-width: 1100px; margin: 0 auto; padding: 0 1.25rem; }

/* Toppbar ------------------------------------------------------------ */

.top {
  position: sticky; top: 0; z-index: 10;
  background: var(--bg-raise);
  border-bottom: 1px solid var(--line);
}

.bar { display: flex; align-items: center; gap: 2rem; height: 3.5rem; min-width: 0; }

.brand {
  font-size: 1.2rem; font-weight: 700; text-decoration: none; letter-spacing: -0.01em;
  white-space: nowrap;
}
.brand span { color: var(--accent); }

.tabs {
  display: flex; gap: 0.25rem; margin-left: auto;
  overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch;
}
.tabs::-webkit-scrollbar { display: none; }
.tabs a { flex: 0 0 auto; }
.tabs a {
  padding: 0.45rem 0.9rem;
  text-decoration: none;
  color: var(--ink-dim);
  font-weight: 600;
  font-size: 0.875rem;
  border-radius: 999px;
  transition: color 150ms ease-out, background 150ms ease-out;
}
.tabs a:hover, .tabs a:active { color: var(--ink); background: var(--bg-hover); }
.tabs a.active { color: var(--accent-ink); background: var(--accent); }

main { padding: 1.75rem 1.25rem 3rem; min-height: 60vh; }
main.wide { max-width: none; }
.m-only { display: none; }

h1 { font-size: 1.45rem; margin: 0 0 1rem; letter-spacing: -0.01em; }
h2 { font-size: 1.2rem; margin: 2.5rem 0 0.75rem; }

.num, td, .time, .score { font-variant-numeric: tabular-nums; }

/* Sverige härnäst ----------------------------------------------------- */

.next-se {
  display: flex; flex-wrap: wrap; align-items: center; gap: 0.6rem 1rem;
  background: var(--bg-raise);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 0.8rem 1.1rem;
  margin-bottom: 1.75rem;
  font-size: 0.93rem;
}
.next-se .label {
  color: var(--accent); font-weight: 700; font-size: 0.78rem;
  text-transform: uppercase; letter-spacing: 0.06em;
}
.next-se .teams { font-weight: 700; font-size: 1.05rem; }
.next-se .meta { color: var(--ink-dim); }

/* Live nu ------------------------------------------------------------- */

.live-now {
  display: flex; flex-wrap: wrap; align-items: center; gap: 0.5rem 1rem;
  background: var(--bg-raise);
  border: 1px solid color-mix(in oklab, var(--accent) 45%, var(--line));
  border-radius: 10px;
  padding: 0.75rem 1.1rem;
  margin-bottom: 0.75rem;
  font-size: 0.93rem;
}
.live-now .label {
  display: flex; align-items: center; gap: 0.35rem;
  color: var(--accent); font-weight: 700; font-size: 0.75rem;
  text-transform: uppercase; letter-spacing: 0.06em;
  white-space: nowrap;
}
.ln-teams {
  display: flex; align-items: center; gap: 0.6rem; font-weight: 600;
}
.ln-score {
  font-size: 1.15rem; font-weight: 700; color: var(--accent);
  padding: 0 0.15rem;
}
.ln-min {
  color: var(--accent); font-variant-numeric: tabular-nums;
}
.ln-meta { color: var(--ink-dim); font-size: 0.78rem; }

/* Scenarios (kvalificering) ------------------------------------------ */

.scenario {
  background: var(--bg-raise);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 0.6rem 1.1rem;
  margin-bottom: 0.75rem;
  font-size: 0.875rem;
}
.scenario.ok { border-color: var(--win); color: var(--win); }
.scenario.out { border-color: var(--loss); color: var(--loss); }

/* Nedräkning ---------------------------------------------------------- */

.countdown { color: var(--accent); font-weight: 700; font-variant-numeric: tabular-nums; }

/* Live-badge på fliken ------------------------------------------------ */

.tabs a.has-live::after {
  content: ''; display: inline-block;
  width: 0.38rem; height: 0.38rem; border-radius: 50%;
  background: var(--accent); margin-left: 0.3rem; vertical-align: middle;
  animation: pulse 1.4s ease-out infinite;
}
.tabs a.active.has-live::after { background: var(--accent-ink); }

/* Filter -------------------------------------------------------------- */

.filters {
  display: flex; flex-wrap: wrap; gap: 0.6rem;
  margin-bottom: 1.5rem;
}
.filters input[type="search"], .filters select {
  background: var(--bg-raise);
  border: 1px solid var(--line);
  color: var(--ink);
  border-radius: 8px;
  padding: 0.45rem 0.7rem;
  font: inherit;
  font-size: 0.875rem;
}
.filters input[type="search"] { flex: 1 1 12rem; min-width: 9rem; }
.filter-more { display: contents; }
#f-toggle { display: none; }
.filters input:focus-visible, .filters select:focus-visible,
.chip:focus-visible, button:focus-visible, .tabs a:focus-visible {
  outline: 2px solid var(--accent); outline-offset: 1px;
}

.chip {
  background: var(--bg-raise);
  border: 1px solid var(--line);
  color: var(--ink-dim);
  border-radius: 999px;
  padding: 0.45rem 0.9rem;
  font: inherit; font-size: 0.875rem; font-weight: 600;
  cursor: pointer;
  transition: color 150ms ease-out, background 150ms ease-out;
}
.chip:hover { color: var(--ink); background: var(--bg-hover); }
.chip.on { color: var(--accent-ink); background: var(--accent); border-color: var(--accent); }

/* Schema -------------------------------------------------------------- */

.day { margin: 0 0 2rem; }
.day > h2 {
  margin: 0 0 0.4rem;
  font-size: 1.2rem;
}
.day > h2 small { color: var(--accent); font-size: 0.78rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.06em; margin-left: 0.6rem; }

.match-list { border-top: 1px solid var(--line); }

.match {
  display: grid;
  grid-template-columns: 3.2rem 1fr auto 1fr 4.5rem minmax(0, 12rem);
  align-items: center;
  gap: 0.75rem;
  padding: 0.55rem 0.5rem;
  border-bottom: 1px solid var(--line);
  font-size: 0.93rem;
  transition: background 150ms ease-out;
}
.match > * { min-width: 0; }
.match:hover, .match.has-goals:active { background: var(--bg-hover); }
.match.sweden { background: var(--accent-soft); }
.match.sweden:hover { background: var(--bg-hover); }

.match .time { font-weight: 600; white-space: nowrap; }
.match .time .live-dot {
  display: inline-block; width: 0.5rem; height: 0.5rem; border-radius: 50%;
  background: var(--accent); margin-right: 0.3rem;
  animation: pulse 1.4s ease-out infinite;
}
@keyframes pulse { 0% { opacity: 1; } 50% { opacity: 0.35; } 100% { opacity: 1; } }

.match .home { text-align: right; }
.match .away { text-align: left; }
.team {
  display: inline-block; max-width: 100%; vertical-align: bottom;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.team.tbd { color: var(--ink-dim); font-size: 0.875rem; }
.flag {
  display: inline-block; overflow: hidden;
  max-width: 1.6em; vertical-align: -0.1em;
}
.team .flag { margin: 0 0.35rem; }
.team.winner { font-weight: 700; }
.team.loser { color: var(--ink-dim); }

.score { text-align: center; font-weight: 700; min-width: 3rem; }
.score .pen { display: block; font-size: 0.7rem; font-weight: 600; color: var(--ink-dim); }
.score.upcoming { color: var(--ink-dim); font-weight: 400; }
.score.is-live { color: var(--accent); }
.score.is-live .pen { color: var(--accent); }
.cards-sum {
  display: flex; justify-content: space-between;
  font-size: 0.62rem; line-height: 1; margin-top: 0.1rem;
  min-width: 3rem; font-weight: 400;
}

.match .where {
  color: var(--ink-dim); font-size: 0.78rem;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  text-align: right;
}
.match .where .stage { display: block; }

.badge {
  display: inline-block;
  border-radius: 999px;
  padding: 0.1rem 0.55rem;
  font-size: 0.78rem; font-weight: 700;
  text-align: center;
  text-decoration: none;
  transition: filter 150ms ease-out;
}
a.badge:hover { filter: brightness(1.25); }
a.badge:focus-visible { outline: 2px solid var(--accent); outline-offset: 1px; }
.badge.svt  { background: color-mix(in oklab, var(--svt) 18%, transparent); color: oklch(0.78 0.08 250); }
.badge.tv4  { background: color-mix(in oklab, var(--tv4) 18%, transparent); color: oklch(0.75 0.12 20); }
.badge.none { color: var(--ink-dim); font-weight: 400; }

.empty { color: var(--ink-dim); padding: 2rem 0; }

/* Målskyttar ----------------------------------------------------------- */

.match.has-goals { cursor: pointer; }
.match.has-goals:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
  border-radius: 6px;
}
.match.has-goals .score {
  text-decoration: underline dotted;
  text-underline-offset: 3px;
}
.goal-detail {
  display: flex; flex-wrap: wrap; align-items: flex-start; gap: 1rem;
  padding: 0.45rem 0.5rem 0.8rem;
  border-bottom: 1px solid var(--line);
  font-size: 0.82rem; color: var(--ink-dim);
}

.match-stats {
  flex-basis: 100%; margin-top: 0.4rem;
  padding-top: 0.5rem; border-top: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 0.3rem;
}
.ms-row {
  display: flex; align-items: center; gap: 0.5rem;
}
.ms-v {
  font-variant-numeric: tabular-nums; font-size: 0.78rem;
  width: 2.4rem; flex-shrink: 0;
}
.ms-v:last-child { text-align: right; }
.ms-mid { flex: 1; }
.ms-label {
  display: block; text-align: center;
  font-size: 0.68rem; color: var(--ink-dim); margin-bottom: 0.18rem;
}
.ms-bar {
  height: 3px; border-radius: 2px;
  background: linear-gradient(to right, var(--accent) var(--h), var(--line) var(--h));
}
.goal-detail .gd-col { flex: 1; min-width: 0; display: grid; gap: 0.15rem; }
.goal-detail .gd-col.home { text-align: right; border-right: 1px solid var(--line); padding-right: 1rem; }
.gmin { font-variant-numeric: tabular-nums; }
.gicon { font-size: 0.7rem; }

/* Grupper ------------------------------------------------------------- */

.group-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(330px, 100%), 1fr));
  gap: 1.5rem 2rem;
}

table { border-collapse: collapse; width: 100%; font-size: 0.875rem; }
caption {
  text-align: left; font-size: 1rem; font-weight: 700;
  padding: 0 0 0.4rem 0;
}
caption small { color: var(--ink-dim); font-weight: 400; font-size: 0.78rem; margin-left: 0.5rem; }
th {
  text-align: right; font-weight: 600; color: var(--ink-dim);
  font-size: 0.78rem; padding: 0.3rem 0.4rem;
  border-bottom: 1px solid var(--line);
}
th.t, td.t { text-align: left; }
td { padding: 0.38rem 0.4rem; text-align: right; border-bottom: 1px solid var(--line); }
tbody tr { transition: background 150ms ease-out; }
tbody tr:hover { background: var(--bg-hover); }
tr.sweden { background: var(--accent-soft); }
td.rank { color: var(--ink-dim); width: 1.4rem; }
tr.q td.rank { color: var(--win); font-weight: 700; }
tr.q3 td.rank { color: color-mix(in oklab, var(--win) 70%, var(--bg)); font-weight: 700; }
tr.out td.rank { color: var(--loss); }
tr.cut td { border-bottom: 1px solid var(--ink-dim); }
td.pts { font-weight: 700; }

.thirds { margin-top: 2.5rem; max-width: 560px; }
.scorers { max-width: 560px; }
.scorers td.t { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 14rem; }
.note { color: var(--ink-dim); font-size: 0.875rem; margin: 0.5rem 0 1rem; }

/* Slutspel ------------------------------------------------------------ */

.bracket-scroll {
  overflow-x: auto;
  padding-bottom: 1rem;
  /* Scrollskuggor: kantvinjetter som täcks av lokala bakgrunder vid kanten,
     så att "det finns mer åt sidan" syns utan extra element. */
  background:
    linear-gradient(90deg, var(--bg) 45%, oklch(0.17 0.012 60 / 0)) left center / 56px 100% no-repeat local,
    linear-gradient(270deg, var(--bg) 45%, oklch(0.17 0.012 60 / 0)) right center / 56px 100% no-repeat local,
    linear-gradient(90deg, oklch(0.05 0 0 / 0.7), transparent) left center / 22px 100% no-repeat scroll,
    linear-gradient(270deg, oklch(0.05 0 0 / 0.7), transparent) right center / 22px 100% no-repeat scroll;
}
.bracket {
  display: grid;
  grid-template-columns: repeat(5, minmax(230px, 1fr));
  gap: 0 1.5rem;
  min-width: 1250px;
  max-width: 1500px;
  margin: 0 auto;
}
.round-col { display: grid; grid-template-rows: auto repeat(32, minmax(1.4rem, auto)); gap: 0.5rem 0; }
.round-col h2 {
  margin: 0 0 0.5rem; font-size: 0.875rem; color: var(--ink-dim);
  text-transform: uppercase; letter-spacing: 0.06em; grid-row: 1;
}
.ko {
  align-self: center;
  background: var(--bg-raise);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 0.55rem 0.75rem;
  font-size: 0.875rem;
  width: 100%;
}
.ko.sweden { border-color: var(--accent); }
.ko .meta {
  display: flex; justify-content: space-between; gap: 0.5rem;
  color: var(--ink-dim); font-size: 0.7rem; margin-bottom: 0.35rem;
}
.ko .row { display: flex; justify-content: space-between; gap: 0.5rem; padding: 0.1rem 0; }
.ko .row .team { flex: 1; min-width: 0; }
.ko.final-card { border-color: var(--accent); }
.ko.final-card .meta { color: var(--ink); }

/* Sveriges väg ---------------------------------------------------------- */

.se-path { max-width: 640px; margin: 0 0 2rem; }
.se-path h2 { margin: 0 0 0.6rem; font-size: 1.05rem; }
.se-path ol { list-style: none; margin: 0; padding: 0; border-top: 1px solid var(--line); }
.se-path li {
  display: grid;
  grid-template-columns: 9.5rem 1fr;
  gap: 0.75rem;
  padding: 0.5rem 0.25rem;
  border-bottom: 1px solid var(--line);
  font-size: 0.875rem;
}
.se-path .sp-stage { color: var(--ink-dim); font-size: 0.78rem; font-weight: 600; padding-top: 0.1rem; }
.se-path .sp-win { color: var(--win); font-weight: 700; }
.se-path .sp-loss { color: var(--loss); font-weight: 700; }
.se-path .sp-live { color: var(--accent); font-weight: 700; }
.se-path .sp-out .sp-body { color: var(--loss); }
.se-path .sp-champ .sp-body { color: var(--accent); font-weight: 700; }

/* Admin --------------------------------------------------------------- */

.admin-bar { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.admin-bar input[type="password"] {
  background: var(--bg-raise); border: 1px solid var(--line); color: var(--ink);
  border-radius: 8px; padding: 0.5rem 0.7rem; font: inherit; font-size: 0.875rem;
  width: 16rem; max-width: 100%;
}
button.primary {
  background: var(--accent); color: var(--accent-ink);
  border: 0; border-radius: 8px; padding: 0.5rem 1rem;
  font: inherit; font-size: 0.875rem; font-weight: 700; cursor: pointer;
}
button.primary:hover { filter: brightness(1.08); }
button.ghost {
  background: none; border: 1px solid var(--line); color: var(--ink-dim);
  border-radius: 8px; padding: 0.35rem 0.7rem; font: inherit; font-size: 0.78rem; cursor: pointer;
}
button.ghost:hover, button.ghost:active { color: var(--ink); background: var(--bg-hover); }
button.primary:active { filter: brightness(0.92); }
.chip:active { background: var(--bg-hover); }
.sync-status { color: var(--ink-dim); font-size: 0.875rem; }

.admin-row {
  display: grid;
  grid-template-columns: 3rem 1fr 3rem 1.2rem 3rem 1fr 7rem 6rem auto;
  align-items: center; gap: 0.6rem;
  padding: 0.45rem 0.5rem;
  border-bottom: 1px solid var(--line);
  font-size: 0.875rem;
}
.admin-row .mid { text-align: center; color: var(--ink-dim); }
.admin-row input[type="number"], .admin-row select {
  background: var(--bg); border: 1px solid var(--line); color: var(--ink);
  border-radius: 6px; padding: 0.3rem 0.4rem; font: inherit; font-size: 0.875rem;
  width: 100%;
}
.admin-row .manual { color: var(--accent); font-size: 0.7rem; font-weight: 700; }
.row-note { font-size: 0.78rem; font-weight: 700; }
.row-note.ok { color: var(--win); }
.row-note.err { color: var(--loss); }
button.ghost.danger { border-color: var(--loss); color: var(--loss); }

.goal-editor {
  display: grid; gap: 0.4rem;
  padding: 0.6rem 0.5rem 0.8rem 3.6rem;
  background: var(--bg-raise);
  border-bottom: 1px solid var(--line);
}
.goal-line {
  display: grid;
  grid-template-columns: 4rem 9rem minmax(8rem, 12rem) 1fr auto;
  gap: 0.5rem;
}
.goal-line input, .goal-line select {
  background: var(--bg); border: 1px solid var(--line); color: var(--ink);
  border-radius: 6px; padding: 0.3rem 0.4rem; font: inherit; font-size: 0.875rem;
  min-width: 0;
}
.goal-editor .note { font-size: 0.78rem; }

@media (max-width: 720px) {
  .goal-editor { padding-left: 0.5rem; }
  .goal-line { grid-template-columns: 3.2rem 1fr 1fr auto; }
  .goal-line [data-g="player"] { grid-column: 1 / -2; }
}

.skeleton { display: grid; gap: 0.6rem; padding: 1rem 0; }
.skeleton div {
  height: 2.2rem; border-radius: 8px;
  background: var(--bg-raise);
  animation: pulse 1.4s ease-out infinite;
}

.foot {
  border-top: 1px solid var(--line);
  padding-top: 1.25rem; padding-bottom: 2.5rem;
  color: var(--ink-dim); font-size: 0.78rem;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* Extremsmala skärmar: tätare tabeller så grupp A-L får plats. */
@media (max-width: 360px) {
  table { font-size: 0.8rem; }
  th, td { padding: 0.3rem 0.25rem; }
  caption { font-size: 0.93rem; }
}

/* Mobil --------------------------------------------------------------- */

@media (max-width: 720px) {
  .wrap { padding-left: 0.9rem; padding-right: 0.9rem; }
  main { padding: 1rem 0.9rem 2rem; }
  body { padding-bottom: calc(3.6rem + env(safe-area-inset-bottom)); }
  h1 { font-size: 1.3rem; }

  /* Navigeringen flyttar till tumzonen: fast rad längst ner. */
  .top { position: static; }
  .bar { height: 2.9rem; justify-content: center; }
  .brand { font-size: 1rem; }
  .tabs {
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 20;
    margin: 0;
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.25rem;
    padding: 0.3rem 0.5rem calc(0.3rem + env(safe-area-inset-bottom));
    background: var(--bg-raise);
    border-top: 1px solid var(--line);
  }
  .tabs a {
    display: flex; align-items: center; justify-content: center;
    min-height: 44px; padding: 0.3rem 0.2rem;
    font-size: 0.78rem; text-align: center;
  }

  /* Dagrubriken klistras högst upp så man alltid vet var i schemat man är. */
  .day > h2 {
    position: sticky; top: 0; z-index: 5;
    background: var(--bg);
    margin: 0; padding: 0.5rem 0 0.4rem;
  }

  /* Tryckytor och iOS: 16px i fält stoppar fokuszoomen. */
  .filters input[type="search"], .filters select, .chip,
  .admin-row input, .admin-row select, .admin-bar input,
  .goal-line input, .goal-line select, button.primary {
    font-size: 1rem; min-height: 44px;
  }
  .admin-row button.ghost, .goal-line button.ghost { min-height: 40px; min-width: 40px; }

  .next-se { padding: 0.7rem 0.9rem; gap: 0.35rem 0.8rem; }
  .m-only { display: inline; }

  /* Filtren fälls ihop bakom en knapp så schemat börjar ovanför vikningen. */
  #f-toggle { display: inline-block; }
  .filter-more { display: none; }
  .filter-more.open {
    display: grid; gap: 0.6rem;
    flex-basis: 100%; min-width: 0;
  }
  .se-path li { grid-template-columns: 1fr; gap: 0.1rem; }

  .match {
    grid-template-columns: 2.9rem 1fr auto 1fr;
    grid-template-areas: "time home score away" ". where where chan";
    align-items: start;
    gap: 0.15rem 0.5rem;
    padding: 0.6rem 0.5rem;
    font-size: 0.875rem;
  }
  .match .score { padding-top: 0.1rem; }
  .match .time { grid-area: time; }
  .match .home { grid-area: home; }
  .match .score { grid-area: score; }
  .match .away { grid-area: away; }
  .match .chan { grid-area: chan; text-align: right; }
  .match .where { grid-area: where; text-align: left; white-space: normal; }

  /* Lagnamn: radbryt i stället för att trunkera med "…" */
  .team { white-space: normal; overflow: visible; text-overflow: clip; }

  /* Grupptabeller: dölj V/O/F-kolumnerna (4–6) – de är redundanta på liten skärm */
  .group-grid th:nth-child(4), .group-grid th:nth-child(5), .group-grid th:nth-child(6),
  .group-grid td:nth-child(4), .group-grid td:nth-child(5), .group-grid td:nth-child(6),
  .thirds th:nth-child(4), .thirds th:nth-child(5), .thirds th:nth-child(6),
  .thirds td:nth-child(4), .thirds td:nth-child(5), .thirds td:nth-child(6) { display: none; }

  /* Bracket: smalare kort så fler omgångar syns per skärm */
  .bracket {
    grid-template-columns: repeat(5, minmax(185px, 1fr));
    min-width: 980px;
  }
  .ko { font-size: 0.8rem; padding: 0.4rem 0.55rem; }
  .ko .meta { font-size: 0.62rem; margin-bottom: 0.25rem; }

  .goal-detail { gap: 0.6rem; font-size: 0.78rem; }
  .goal-detail .gd-col.home { padding-right: 0.6rem; }

  /* Admin: radbruten flexlayout i stället för den breda gridden */
  .admin-row {
    display: flex; flex-wrap: wrap; align-items: center;
    gap: 0.4rem 0.5rem;
  }
  .admin-row .t { text-align: left !important; }
  .admin-row input[type="number"] { width: 3.2rem; }
  .admin-row select { width: auto; max-width: 100%; }
  .admin-row .win-cell:empty { display: none; }
}
