@page {
  size: A4 portrait;
  margin: 7mm;
}

html,
body {
  margin: 0 !important;
  padding: 0 !important;
  background: #ffffff !important;
  color: #000000 !important;
  -webkit-print-color-adjust: exact;
  print-color-adjust: exact;
}

/* Nur der rechte Charakterbogen wird gedruckt */
.app-header,
.editor-panel,
.print-button,
.warnings,
.column-intro {
  display: none !important;
}

.layout {
  display: block !important;
  padding: 0 !important;
  margin: 0 !important;
}

.sheet-panel {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

.sheet {
  position: static !important;
  width: 196mm !important;
  min-height: auto !important;
  margin: 0 auto !important;
  padding: 4.5mm !important;
  border: 3px double #000000 !important;
  box-shadow: none !important;
  background: #ffffff !important;
  color: #000000 !important;
  font-size: 8pt !important;
  line-height: 1.08 !important;
}

/* Kopfbereich kompakt */
.sheet-header {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  gap: 4mm !important;
  border-bottom: 2px solid #000000 !important;
  padding-bottom: 2mm !important;
  margin-bottom: 2.5mm !important;
}

.sheet-header h2 {
  margin: 0 !important;
  font-size: 17pt !important;
  line-height: 1 !important;
}

.sheet-header p {
  margin: 1mm 0 0 !important;
  font-size: 8pt !important;
  line-height: 1.1 !important;
}

.sheet-logo {
  border: 2px solid #000000 !important;
  padding: 2mm 3mm !important;
  font-size: 10pt !important;
  line-height: 1 !important;
}

/* Abschnitte stark verdichten */
.sheet-section {
  padding: 1.7mm 0 !important;
  margin: 0 !important;
  border-bottom: 1px solid #b8b8b8 !important;
  break-inside: avoid !important;
  page-break-inside: avoid !important;
}

.sheet-section h3 {
  margin: 0 0 1.2mm !important;
  font-size: 10.5pt !important;
  line-height: 1 !important;
}

.sheet-section h4 {
  margin: 0 0 1mm !important;
  font-size: 8.5pt !important;
  line-height: 1 !important;
}

/* Wichtig: Raster im Druck erzwingen, sonst wird alles einspaltig */
.info-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 1.4mm !important;
}

.attribute-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 1.4mm !important;
}

.derived-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 1.4mm !important;
}

.two-columns {
  display: grid !important;
  grid-template-columns: 0.85fr 1.7fr !important;
  gap: 3mm !important;
}

/* Boxen kompakter */
.info-box,
.attribute-box,
.derived-box {
  min-height: 0 !important;
  padding: 1.2mm !important;
  border: 1px solid #000000 !important;
  background: #ffffff !important;
}

.info-box span,
.attribute-box span,
.derived-box span {
  display: block !important;
  font-size: 7pt !important;
  line-height: 1 !important;
  color: #4f4f4f !important;
}

.info-box strong,
.attribute-box strong,
.derived-box strong {
  display: block !important;
  margin-top: 0.7mm !important;
  font-size: 8.5pt !important;
  line-height: 1.05 !important;
}

.money-breakdown {
  display: block !important;
  margin-top: 0.5mm !important;
  font-size: 6.7pt !important;
  line-height: 1 !important;
  color: #555555 !important;
  font-weight: normal !important;
}

/* Würfel im Druck kleiner */
.dice-row,
.derived-box strong.dice-row {
  display: inline-flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 1.2mm !important;
  white-space: nowrap !important;
}

.die {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: auto !important;
  height: auto !important;
  min-width: 0 !important;
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  line-height: 1 !important;
  overflow: visible !important;
  flex: 0 0 auto !important;
}

.die .symbol {
  font-size: 12pt !important;
  line-height: 1 !important;
}

/* Tags kompakter */
.tag-list {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 1mm !important;
}

.tag-list span {
  padding: 0.7mm 1mm !important;
  border: 1px solid #000000 !important;
  background: #ffffff !important;
  font-size: 7pt !important;
  line-height: 1 !important;
}

/* Lange Listen enger setzen */
.rules-list {
  margin: 0 !important;
  padding-left: 4mm !important;
  font-size: 7pt !important;
  line-height: 1.08 !important;
}

.rules-list li {
  margin: 0 0 0.6mm !important;
}

.small-note {
  margin: 1mm 0 0 !important;
  font-size: 6.8pt !important;
  line-height: 1.05 !important;
}

p {
  margin-top: 0 !important;
  margin-bottom: 1.2mm !important;
}

/* Hintergrund kompakt halten */
.sheet-section:last-child p {
  font-size: 7.2pt !important;
  line-height: 1.08 !important;
}

/* Browser sollen keine unnötigen Seitenumbrüche setzen */
.sheet,
.sheet-header,
.sheet-section,
.info-grid,
.attribute-grid,
.derived-grid,
.two-columns {
  break-before: auto !important;
  break-after: auto !important;
}