:is(h1, h2, h3) small {
  font-weight: normal;
  opacity: 0.5;
}

.dropdown-item a {
  text-decoration: none !important;
}

.right {
  text-align: right;
}

.vcentered {
  vertical-align: middle;
}

.tabs-tab .icon {
  vertical-align: -10%;
}

/* tables */

table.index th:first-child,
table.index td:first-child {
  padding: 0.5rem 0.5rem 0.5rem 0rem;
}

table.index th,
table.index td {
  padding: 0.5rem 0.5rem 0.5rem 0.5rem;
}

#turnierliste td,
#turnierliste th {
  min-width: 0.5em;
  vertical-align: middle;
}

#turnierliste thead th:nth-child(1),
#turnierliste tbody td:nth-child(1) {
  width: 32px;
}

#turnierliste td.gameicon img {
  border-radius: 3px;
  max-width: none;
}

.tourney-state {
  margin-bottom: 0.25rem;
}

ol.tourney-attendees {
  --column-count: 2;
  columns: var(--column-count) !important;
}

@media (max-width: 41.75rem) { /* 668px / 16px */

  #turnierliste :is(.col-participants, .col-coins) {
    display: none;
  }

  ol.tourney-attendees {
    --column-count: 1;
  }
}

td.treeline {
  /* background-color: #dedede; */
  border-bottom: #cccccc solid 1px;
  border-right: #cccccc solid 1px;
  border-top: #cccccc solid 1px;
}

td.treelinelb {
  border-bottom: #cccccc solid 1px;
  border-left: #cccccc solid 1px;
  border-top: #cccccc solid 1px;
}

.clickable {
  cursor: pointer;
}

.matchid,
.matchnote {
  font-size: 0.75rem;
  font-style: italic;
}

.matchnote {
  display: block;
  padding-top: 0.2rem;
  text-align: right;
}

table#tree {
  border-collapse: separate;
}

table.match {
  border-bottom: #cccccc solid 1px;
  border-collapse: collapse;
  border-spacing: 0;
  min-width: 9rem;
  white-space: nowrap;
  width: 100%;
}

#tree td,
#tree th {
  font-size: 0.8rem;
  padding: 0 0.2em 0 0.2em;
}

#tree td table.match td {
  border-top: #cccccc solid 1px;
  padding: 0.2rem 0.2rem 0.2rem 0;
  vertical-align: middle;
}

table.match td:last-child {
  width: 1em;
}

.mymatch {
  /* background-color: #f8f888; */
  color: #f00;
  font-weight: bold;
}

#treecontainer {
  overflow: auto;
}

.fullscreen #treecontainer {
  overflow: initial;
}

#turnierbaum.fullscreen {
  background-color: inherit;
  bottom: 0;
  left: 0;
  max-width: 100%;
  padding-top: 1em;
  position: fixed;
  right: 0;
  top: 0;
  z-index: 200;
}

/* strafkarten */

.yellowcard,
.redcard {
  border: 1px solid black;
  border-radius: 3px;
  box-shadow: 0 0 1px rgba(0, 0, 0, 0.15);
  cursor: help;
  display: inline-block;
  font-size: 0.7em;
  line-height: 1.3em;
  margin: 0 0.3em 0 0.3em;
  padding: 0 0.325em;
  vertical-align: baseline;
}

#turniertable .yellowcard,
#turniertable .redcard {
  font-size: 1em;
}

.yellowcard {
  background-color: yellow;
}

.redcard {
  background-color: red;
}

.red {
  color: red;
}

.green {
  color: #009900;
}

#tree th .roundinfo {
  font-weight: normal;
}

#tree td.matchcol {
  vertical-align: middle;
}

#tree td.team {
  text-align: right;
}

#tree td.result {
  text-align: right;
}

.view-actions {
  clear: right;
  float: right;
  list-style: none;
  margin: 0;
  padding: 0;
}

.fullscreen .view-actions {
  opacity: 0.5;
  position: fixed;
  right: 1em;
  top: 1em;
  transition: opacity 0.3s ease-in-out;
}

.fullscreen .view-actions:hover {
  opacity: 1;
}

.fullscreen {
  border: #cccccc solid 1px;
  box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.1);
  overflow: auto;
  padding: 1em;
}

.fullscreen #tree {
  padding-right: 1em;
}

#tree tr.winner {
  font-weight: bold;
}

input.hidden {
  display: none;
}

.input-button {
  flex-wrap: wrap;
  max-width: 400px;
}

.input-button input {
  box-shadow: 0;
  flex: 0 0 100%;
  font-size: 1.2em;
  text-align: center;
  -webkit-transition: width 1s;
  transition: width 1s;
  width: 13ch;
}

.input-button input:focus {
  width: 20em;
}

table.match-result {
  width: 100%;
}

table.match-result h1 {
  word-break: break-all;
}

table.match-result .button {
  font: 0.85em sans-serif;
  margin-top: 0.4em;
  margin-bottom: 0.4em;
}

table.match-result input {
  font-size: 1.25rem;
}

.tourney-matches {
  margin-bottom: 1.5rem;
}

:is(.open-matches, .tourney-matches) td {
  padding: 0;
}

.tourney-match-in-list,
.tourney-match-in-team-history,
.tourney-match-in-open-matches {
  --hover-bg-color: #f4f4f4;
  color: currentColor;
  padding-left: var(--cell-padding-horizontal);
  padding-right: var(--cell-padding-horizontal);
  text-decoration: none;
}

.tourney-match-in-list,
.tourney-match-in-team-history {
  align-items: center;
  column-gap: 0.5rem;
  display: grid;
}

.tourney-match-in-list {
  grid-template-areas: "matchnumber team1-name team1-avatar team1-trophy score team2-trophy team2-avatar team2-name";
  grid-template-columns: 5rem 1fr 2rem 1rem 4rem 1rem 2rem 1fr;
}

.tourney-match-in-team-history {
  grid-template-areas: "matchnumber team1-name score team2-name";
  grid-template-columns: 5rem 1fr 4rem 1fr;
}

.tourney-match-in-open-matches {
  display: block;
}

:is(.tourney-match-in-list, .tourney-match-in-team-history, .tourney-match-in-open-matches) > * {
  padding-bottom: var(--cell-padding-vertical);
  padding-top: var(--cell-padding-vertical);
}

:is(.tourney-match-in-list, .tourney-match-in-team-history, .tourney-match-in-open-matches):hover {
  background-color: var(--hover-bg-color);
}

:is(.tourney-match-in-list, .tourney-match-in-team-history) .matchnumber {
  grid-area: matchnumber;
  white-space: nowrap;
}

:is(.tourney-match-in-list, .tourney-match-in-team-history) :is(.team1-name, .team2-name) {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

:is(.tourney-match-in-list, .tourney-match-in-team-history) .team1-name {
  grid-area: team1-name;
  text-align: right;
}

:is(.tourney-match-in-list, .tourney-match-in-team-history) .team2-name {
  grid-area: team2-name;
}

:is(.tourney-match-in-list, .tourney-match-in-team-history) .team1-avatar {
  grid-area: team1-avatar;
}

:is(.tourney-match-in-list, .tourney-match-in-team-history) .team2-avatar {
  grid-area: team2-avatar;
}

:is(.tourney-match-in-list, .tourney-match-in-team-history) :is(.team1-trophy, .team2-trophy) {
  text-align: center;
}

:is(.tourney-match-in-list, .tourney-match-in-team-history) .team1-trophy {
  grid-area: team1-trophy;
}

:is(.tourney-match-in-list, .tourney-match-in-team-history) .team2-trophy {
  grid-area: team2-trophy;
}

:is(.tourney-match-in-list, .tourney-match-in-team-history) .score {
  grid-area: score;
  text-align: center;
  white-space: nowrap;
}

.tourney-match-in-team-history .score {
  align-self: stretch;
  display: grid;
  place-items: center;
}

.tourney-match-in-team-history .score.result-won {
  background-color: #4aaf4f;
}

.tourney-match-in-team-history .score.result-lost {
  background-color: #f44433;
}

@media (max-width: 41.75rem) { /* 668px / 16px */

  .tourney-match-in-list {
    grid-template-areas: "team1-name team1-avatar score team2-avatar team2-name";
    grid-template-columns: 1fr 1.5rem 4rem 1.5rem 1fr;
  }

  .tourney-match-in-team-history {
    grid-template-areas: "team1-name score team2-name";
    grid-template-columns: 1fr 4rem 1fr;
  }

  :is(.tourney-match-in-list, .tourney-match-in-team-history) :is(.matchnumber, .team1-trophy, .team2-trophy) {
    display: none;
  }

  :is(.tourney-match-in-list, .tourney-match-in-team-history) :is(.team1-name, .team2-name) {
    white-space: normal;
  }

  :is(.tourney-match-in-list, .tourney-match-in-team-history) :is(.team1-avatar, .team2-avatar) .avatar {
    height: auto;
    width: 24px;
  }

}

td.icon-col {
  padding-left: 0 !important;
  padding-right: 0 !important;
  vertical-align: middle;
  width: 1em;
}

.team {
  display: inline-block;
  max-width: 12.25rem;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: middle;
}

.matchtable .score {
  padding-bottom: 0;
  padding-right: 0;
  padding-top: 0;
  text-align: center;
}

.matchtable .score a {
  color: currentColor;
  display: block;
  padding-bottom: var(--cell-padding-vertical);
  padding-top: var(--cell-padding-vertical);
}

.matchtable .score a:not(:hover) {
  text-decoration: none;
}

.matchtable td:nth-child(3).icon-col {
  text-align: left;
  width: 1.1em;
}

.matchtable td:nth-child(5).icon-col {
  text-align: right;
  width: 1.1em;
}

#turniertable td.team {
  white-space: nowrap;
  width: 19em;
}

#turniertable col.matchnum {
  width: 4.5em;
}

#turniertable td.team:nth-child(2) .avatar {
  margin-left: 0.75rem;
}

#turniertable td.team:nth-child(6) .avatar {
  margin-right: 0.75rem;
}

.action-expand.compressed .icon-compress,
.action-expand.expanded .icon-expand  {
  display: none;
}

.action-expand.compressed .icon-expand,
.action-expand.expanded .icon-compress{
  display: block;
}

#page-grid-main {
  overflow: hidden;
}


/* not open */
.tag-tourney-0 { background-color: #666666; }

/* open */
.tag-tourney-1 { background-color: #4aaf4f; }

/* closed */
.tag-tourney-2 {
  background-color: #ffcc11;
  color: #111111;
  text-shadow: none;
}

/* seeding */
.tag-tourney-3 {
  background-color: #ffffff;
  color: #000000;
  text-shadow: none;
}

/* running */
.tag-tourney-4 { background-color: #04aff4; }

/* paused */
.tag-tourney-5 {
  background-color: #ac2925;
  color: #ffffff;
  text-shadow: none;
}

/* finished */
.tag-tourney-6 { background-color: #333333; }

/* canceled */
.tag-tourney-7 { background-color: #f44433; }

.tourney-header {
  margin-top: 0.5rem;
}

.tourney-header .tourney-title {
  margin: 0;
  padding: 0;
}

.tourney-subtitle {
  color: #888888;
  font-size: 0.75rem;
  width: 100%;
}

.tourney-header .tourney-subtitle {
  font-size: 1rem;
}

.tourney-subtitle img {
  max-height: 1em;
  vertical-align: middle;
}

.user-comment-meta-top .team-link a {
  /* color: #f4f4f4;  // NorthCon */
  font-style: italic;
}

.event-creator {
  font-size: 0.6875rem;
}

.event-creator a {
  border: none;
}

.event-creator a:not(:hover) {
  text-decoration: none;
}

.event-creator .team-link a,
.event-creator .user-link a {
  /* color: #f4f4f4;  // NorthCon */
}

.event-creator .team-link a {
  font-style: italic;
  font-weight: bold;
}


.brackets-viewer {
  /* Colors */
  --primary-background: var(--bg-color);
  --secondary-background: var(--border-color);
  --match-background: var(--primary-background);
  --font-color: var(--color-text);
  --win-color: var(--success-color);
  --loss-color: var(--warn-color);
  --label-color: var(--dimmed-color);
  --hint-color: var(--color-link-decoration);
  --connector-color: var(--border-color);
  --border-hover-color: var(--dimmed-color);
  --border-selected-color: var(--color-primary);
  /* Sizes */
  --text-size: 12px;
  --round-margin: 20px;
  --match-width: 150px;
  --match-horizontal-padding: 8px;
  --match-vertical-padding: 4px;
  --connector-border-width: 1px;
  --match-border-width: 1px;
  --match-border-radius: 0.6em;
  --participant-image-size: 1.25em;
}
.participant .name.bye {
  color: var(--dimmed-color);
  font-style: italic;
}

.brackets-viewer {
  font-size: var(--text-size);
  text-align: left;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  overflow: auto;
  user-select: none;
  margin: 0 auto;
}
.brackets-viewer:empty {
  display: none;
}
.brackets-viewer *,
.brackets-viewer ::after,
.brackets-viewer ::before {
  box-sizing: border-box;
}
.brackets-viewer h1,
.brackets-viewer h2,
.brackets-viewer h3 {
  margin-bottom: 0.5em;
  font-weight: 500;
  line-height: 1.2;
}
.brackets-viewer h1 {
  font-size: 2em;
  margin-top: 30px;
  margin-bottom: 20px;
}
.brackets-viewer h2 {
  font-size: 1.7em;
}
.brackets-viewer h3 {
  text-align: center;
  background: var(--secondary-background);
  font-size: 1.1em;
  padding: 10px 0px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  width: var(--match-width);
}
.brackets-viewer .round-robin {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  row-gap: 24px;
}
.brackets-viewer .round-robin h1 {
  flex-basis: 100%;
}
.brackets-viewer .round-robin h2 {
  text-align: center;
}
.brackets-viewer .round-robin .group:not(:last-of-type) {
  margin-right: var(--round-margin);
}
.brackets-viewer .round-robin .group h2 {
  margin: 0 0 25px 0;
}
.brackets-viewer .round-robin .group table {
  font-size: 1em;
  margin: 30px 0 20px 0;
  color: #a7a7a7;
  border-collapse: collapse;
}
.brackets-viewer .round-robin .group th {
  font-weight: normal;
  text-align: start;
  cursor: help;
  border-bottom: var(--match-border-width) solid var(--border-color);
}
.brackets-viewer .round-robin .group td.hover {
  background: var(--secondary-background);
}
.brackets-viewer .round-robin .group th,
.brackets-viewer .round-robin .group td {
  padding: 5px;
}
.brackets-viewer .round-robin .group td:nth-of-type(2), .brackets-viewer .round-robin .group td:last-of-type {
  color: var(--font-color);
  font-weight: 500;
}
.brackets-viewer .round-robin .round {
  width: fit-content;
  margin: 0 auto;
}
.brackets-viewer .bracket h2 {
  font-size: 1.5em;
  color: #888888;
}
.brackets-viewer .bracket .rounds {
  display: flex;
}
.brackets-viewer .bracket .rounds:not(:last-of-type) {
  margin-bottom: 15px;
}
.brackets-viewer .bracket .rounds .round {
  display: flex;
  flex-direction: column;
}
.brackets-viewer .bracket .rounds .round:not(:last-of-type) {
  margin-right: var(--round-margin);
}
.brackets-viewer .match {
  flex: 1;
  display: flex;
  align-items: center;
  margin: 8px 0;
  width: var(--match-width);
  position: relative;
}
.brackets-viewer .match.connect-next::after {
  content: "";
  display: block;
  position: absolute;
  right: calc(-1 * var(--round-margin)/2);
  width: calc(var(--round-margin)/2);
  height: 50%;
  border-right: var(--connector-border-width) solid var(--connector-color);
}
.brackets-viewer .match.connect-next:nth-of-type(odd)::after {
  top: 50%;
  border-top: var(--connector-border-width) solid var(--connector-color);
}
.brackets-viewer .match.connect-next:nth-of-type(even)::after {
  top: 0;
  border-bottom: var(--connector-border-width) solid var(--connector-color);
}
.brackets-viewer .match.connect-next.straight::after {
  width: var(--round-margin);
  right: calc(-1 * var(--round-margin));
  top: 0;
  border-bottom: var(--connector-border-width) solid var(--connector-color);
  border-top: unset;
  border-right: unset;
}
.brackets-viewer .opponents {
  width: 100%;
  position: relative;
  border: var(--match-border-width) solid var(--border-color);
  border-radius: var(--match-border-radius);
  background: var(--match-background);
}
.brackets-viewer .opponents:hover {
  border: 1px solid var(--border-hover-color);
}
.brackets-viewer .opponents.popover-selected, .brackets-viewer .selected .opponents {
  border: 1px solid var(--border-selected-color);
}

.brackets-viewer .opponents > span {
  position: absolute;
  top: -8px;
  font-size: 0.75em;
  padding: 0 5px;
  color: var(--label-color);
  background: var(--primary-background, #f4f4f4);
  border-radius: 3px;
}
.brackets-viewer .opponents > span:nth-of-type(1) {
  left: 3px;
}
.brackets-viewer .opponents > span:nth-of-type(2) {
  right: 3px;
}
.brackets-viewer .opponents.connect-previous::before {
  content: "";
  display: block;
  position: absolute;
  left: calc(-1 * var(--round-margin)/2);
  width: calc(var(--round-margin)/2);
  height: 50%;
  border-bottom: var(--connector-border-width) solid var(--connector-color);
}
.bracket:nth-of-type(2) .brackets-viewer .opponents.connect-previous .opponents.connect-previous.straight::before, .bracket:nth-of-type(1) .brackets-viewer .opponents.connect-previous .opponents.connect-previous.straight::after {
  border-left: unset;
  left: var(--round-margin);
  width: var(--round-margin);
}
.bracket:nth-of-type(1) .brackets-viewer .opponents.connect-previous.straight::before {
  content: unset;
}
.bracket:nth-of-type(2) .brackets-viewer .opponents.connect-previous.straight::after {
  content: unset;
}
.brackets-viewer .participant {
  display: flex;
  justify-content: space-between;
  padding: 2px var(--match-horizontal-padding);
  background: var(--match-background);
}
.brackets-viewer .participant.hover {
  background: var(--secondary-background) !important;
}
.brackets-viewer .participant:nth-of-type(1) {
  border-bottom: none;
  border-top-left-radius: var(--match-border-radius);
  border-top-right-radius: var(--match-border-radius);
  padding-top: var(--match-vertical-padding);
}
.brackets-viewer .participant:nth-of-type(2) {
  border-top: none;
  border-bottom-left-radius: var(--match-border-radius);
  border-bottom-right-radius: var(--match-border-radius);
  padding-bottom: var(--match-vertical-padding);
}
.brackets-viewer .participant .name {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  width: 80%;
}
.brackets-viewer .participant .name.hint {
  color: var(--hint-color);
}
.brackets-viewer .participant .name > img {
  width: var(--participant-image-size);
  height: var(--participant-image-size);
  margin-right: 4px;
  object-fit: cover;
  border-radius: 4px;
  vertical-align: middle;
  position: relative;
  bottom: 1px;
}
.brackets-viewer .participant .name > span {
  color: var(--hint-color);
  font-size: 0.9em;
  font-weight: initial;
}
.brackets-viewer .participant .result {
  margin-left: 10px;
  width: 15%;
  text-align: center;
}
.brackets-viewer .participant.win .name {
  font-weight: bold;
}
.brackets-viewer .participant.win .result {
  color: var(--win-color);
}
.brackets-viewer .participant.loss .result {
  color: var(--loss-color);
}
.brackets-viewer [popover] {
  padding: 0 14px 10px 14px;
}
.brackets-viewer [popover] h4 {
  font-size: 1.1em;
  margin-bottom: 24px;
}
.brackets-viewer [popover] .match:not(:last-of-type) {
  margin-bottom: 20px;
}
