body {
  x-margin: 5mm;
}

@page  { 
  size: auto;   /* auto is the initial value */ 

  width: 290mm;
  height: 210mm;
  /* this affects the margin in the printer settings */ 
  x-margin: 5mm 5mm 5mm 5mm;  
} 


.page {
  x-border: 1px dashed green;
  page-break-after: always;
  position: relative;
}

.player {
  background: white;
  border: 1px dashed gray;
  padding: 0.5em;
  display: block;
  height: 1em;
}

.grid-cell {
  align: left;
  vertical-align: top;
  width: 18em;
  height: 8em;
  x-font-size: 7pt;
  margin: 1em;
  display: inline-block;
  x-border: 1px dashed blue;
}

.match {
  width: 100%;
  height: 100%;
  border: 1px solid black;
  display: inline-block;
  background: lightgrey;
}

.match .title {
  text-align: right;
  font-size: larger;
  margin-bottom: 0.5em;
  padding-right: 1em;
  display: block;
}

h1, h2, h3 {
  display: block;
}

.page-break {
  page-break-after: always;
}

.results-container {
  height: 14em;
  padding-top: 1em;
}

.results {
  float:left;
  width: 40%;
  font-size: larger;
  margin-top: 1em;
  margin-right: 1em;
}


.results-container legend {
  font-size: larger;
}

.ref {
  border: 1px solid;
  width: 50%;
  font-size: larger;
  margin-top: 1em;
  float: right;
}

.ref .input-field {
  display: inline-block;
  margin: 1em;
}

.ref input {
  font-size: larger;
}

.ref label {
  font-size: larger;
}

#logo {
  float: right;
  margin-right: 5em;
}

hr {
  clear: both;
}
