/* OLO Bericht-Modul — optisch an OLO-Cards / Dashboard angeglichen */

.br-page {
  --br-radius-card: var(--olo-radius-card);
  --br-radius-inner: var(--olo-radius-sm);
  --br-radius-tight: var(--olo-radius-xs);
}

.br-shell {
  max-width: var(--olo-shell-max);
  margin: 0 auto;
  padding: var(--olo-space-4) clamp(18px, 2.5vw, 32px) 52px;
  box-sizing: border-box;
}

body.olo-work-mode.br-page .br-shell {
  padding-top: var(--olo-space-3);
}

.br-header {
  display: grid;
  grid-template-columns: minmax(112px, 140px) minmax(0, 1fr);
  align-items: center;
  gap: var(--olo-space-3);
  margin-bottom: var(--olo-space-4);
  padding-bottom: var(--olo-space-3);
  border-bottom: 1px solid var(--border);
}

.br-header-center {
  text-align: left;
  min-width: 0;
}

.br-page-title {
  margin: 0;
  font-size: clamp(15px, 1.9vw, 18px);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.25;
}

.br-subtitle {
  margin: 4px 0 0;
  font-size: 13px;
  color: var(--muted);
}

/* ── Toolbar ── */

.br-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--olo-space-3);
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--olo-space-4);
  padding: var(--olo-space-4);
  border-radius: var(--br-radius-card);
  border: 1px solid var(--border);
  background: var(--card-bg);
  box-shadow: var(--olo-shadow-sm);
  transition:
    box-shadow var(--olo-transition),
    border-color var(--olo-transition);
}

.br-toolbar-left,
.br-toolbar-right {
  display: flex;
  flex-wrap: wrap;
  gap: var(--olo-space-2);
  align-items: center;
}

.br-view-toggle {
  display: inline-flex;
  border-radius: var(--olo-radius-pill);
  border: 1px solid var(--border);
  overflow: hidden;
  background: var(--card-bg-soft);
}

.br-view-btn {
  border: none;
  background: transparent;
  padding: 8px 14px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 600;
  color: var(--muted);
  cursor: pointer;
  transition: background var(--olo-transition-fast), color var(--olo-transition-fast);
}

.br-view-btn.is-active {
  background: var(--olo-selected-bg);
  color: var(--olo-selected-text);
  box-shadow: inset 0 -2px 0 var(--olo-accent-indicator);
}

.br-module-status {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.br-mod-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  border-radius: var(--olo-radius-pill);
  font-size: 11px;
  font-weight: 600;
  border: 1px solid var(--border);
  background: var(--card-bg-soft);
  color: var(--muted);
}

.br-mod-pill--on {
  border-color: var(--success-border);
  background: var(--success-soft);
  color: var(--success);
}

.br-mod-pill__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--hint);
}

.br-mod-pill--on .br-mod-pill__dot {
  background: var(--success);
}

/* ── Layout ── */

.br-layout {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: var(--olo-space-6);
  align-items: start;
}

.br-sidebar {
  position: sticky;
  top: 12px;
  display: flex;
  flex-direction: column;
  gap: var(--olo-space-4);
}

.br-sidebar-card {
  padding: var(--olo-space-5);
  border-radius: var(--br-radius-card);
  border: 1px solid var(--border);
  background: var(--card-bg);
  box-shadow: var(--olo-shadow-sm);
  transition:
    box-shadow var(--olo-transition),
    border-color var(--olo-transition);
}

.br-sidebar-card:hover {
  border-color: var(--border-strong);
  box-shadow: var(--olo-shadow-md);
}

.br-sidebar-title {
  margin: 0 0 10px;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--hint);
}

.br-section-check {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 8px 10px;
  margin: 0 -4px;
  border-radius: var(--br-radius-inner);
  font-size: 13px;
  color: var(--text);
  cursor: pointer;
  transition: background-color var(--olo-transition-fast);
}

.br-section-check:hover {
  background: var(--card-bg-soft);
}

.br-section-check input {
  margin-top: 2px;
  accent-color: var(--olo-accent);
}

/* ── Preview ── */

.br-preview {
  display: flex;
  flex-direction: column;
  gap: var(--olo-space-4);
  min-width: 0;
}

.br-summary-banner {
  padding: var(--olo-space-4);
  border-radius: var(--br-radius-card);
  border: 1px solid var(--olo-accent-border);
  background: var(--olo-accent-subtle);
  font-size: 14px;
  line-height: 1.55;
  color: var(--text);
  box-shadow: var(--olo-shadow-xs), inset 3px 0 0 var(--olo-accent-indicator);
}

/* ── Report cards ── */

.br-report-card {
  padding: var(--olo-space-5) var(--olo-space-5);
  border-radius: var(--br-radius-card);
  border: 1px solid var(--border);
  background: var(--card-bg);
  box-shadow: var(--olo-shadow-sm);
  overflow: hidden;
  transition:
    box-shadow var(--olo-transition),
    border-color var(--olo-transition);
}

.br-report-card:hover {
  border-color: var(--border-strong);
  box-shadow: var(--olo-shadow-md);
}

.br-report-card__title {
  margin: 0 0 4px;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--text);
}

.br-report-card__sub {
  margin: 0 0 14px;
  font-size: 12px;
  color: var(--muted);
}

.br-report-card h3 {
  font-size: 14px;
  font-weight: 600;
  margin: 14px 0 8px;
  color: var(--text);
}

.br-report-card h3:first-of-type {
  margin-top: 0;
}

.br-empty {
  margin: 0;
  padding: 12px 14px;
  border-radius: var(--br-radius-inner);
  background: var(--card-bg-soft);
  border: 1px dashed var(--border);
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

/* ── Key-value blocks ── */

.br-kv-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px 12px;
  margin-bottom: 8px;
}

.br-kv {
  padding: 10px 12px;
  border-radius: var(--br-radius-inner);
  background: var(--card-bg-soft);
  border: 1px solid var(--border);
}

.br-kv__label {
  display: block;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--hint);
  margin-bottom: 2px;
}

.br-kv__value {
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
}

/* ── Wertepass ── */

.br-wertepass {
  border: 2px solid var(--olo-accent-border);
  background: linear-gradient(135deg, var(--card-grad-1), var(--card-grad-2));
}

.br-wertepass-header {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}

.br-wertepass-type {
  display: inline-block;
  padding: 4px 10px;
  border-radius: var(--olo-radius-pill);
  font-size: 11px;
  font-weight: 600;
  background: var(--olo-accent-soft);
  color: var(--olo-accent);
  border: 1px solid var(--olo-accent-border);
}

.br-eye-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--olo-space-3);
}

.br-eye-block {
  padding: var(--olo-space-3);
  border-radius: var(--br-radius-inner);
  border: 1px solid var(--border);
  background: var(--card-bg);
  overflow: hidden;
  box-shadow: var(--olo-shadow-xs);
}

.br-eye-block__title {
  margin: 0 0 10px;
  font-size: 13px;
  font-weight: 700;
  color: var(--olo-accent);
}

.br-values-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
  border-radius: var(--br-radius-tight);
  overflow: hidden;
}

.br-values-table th,
.br-values-table td {
  padding: 8px 10px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}

.br-values-table th {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--hint);
  font-weight: 600;
  background: var(--card-bg-soft);
}

.br-values-table tr:last-child td {
  border-bottom: none;
}

.br-legend {
  margin: 12px 0 0;
  padding: 10px 12px;
  border-radius: var(--br-radius-inner);
  background: var(--card-bg-soft);
  border: 1px solid var(--border);
  font-size: 12px;
  line-height: 1.5;
  color: var(--muted);
}

.br-legend strong {
  color: var(--text);
}

.br-diff-list {
  margin: 10px 0 0;
  padding: 10px 12px 10px 28px;
  border-radius: var(--br-radius-inner);
  background: var(--card-bg-soft);
  border: 1px solid var(--border);
  font-size: 12px;
  color: var(--muted);
}

.br-diff-list li {
  margin-bottom: 4px;
}

.br-diff-warn {
  color: var(--warn);
  font-weight: 500;
}

.br-hint-list {
  margin: 0;
  padding: 10px 12px 10px 28px;
  border-radius: var(--br-radius-inner);
  background: var(--card-bg-soft);
  border: 1px solid var(--border);
  font-size: 13px;
  line-height: 1.55;
  color: var(--muted);
}

.br-hint-list li {
  margin-bottom: 6px;
}

.br-list-plain {
  margin: 0;
  padding: 0;
  list-style: none;
  border-radius: var(--br-radius-inner);
  border: 1px solid var(--border);
  background: var(--card-bg-soft);
  overflow: hidden;
}

.br-list-plain li {
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  font-size: 13px;
}

.br-list-plain li:last-child {
  border-bottom: none;
}

.br-optician-only {
  display: block;
}

body.br-view-customer .br-optician-only {
  display: none !important;
}

.br-grading-row {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding: 8px 10px;
  margin-bottom: 6px;
  font-size: 13px;
  border-radius: var(--br-radius-inner);
  border: 1px solid var(--border);
  background: var(--card-bg-soft);
}

.br-grading-row:last-child {
  margin-bottom: 0;
}

.br-grading-grade {
  font-weight: 600;
  color: var(--text);
}

/* ── Print ── */
@media print {
  body.br-print-mode .br-sidebar,
  body.br-print-mode .br-toolbar,
  body.br-print-mode .br-header .br-back,
  body.br-print-mode .olo-order-gate,
  body.br-print-mode #olo-session-lock-modal {
    display: none !important;
  }

  body.br-print-mode .br-layout {
    display: block;
  }

  body.br-print-mode .br-shell {
    max-width: none;
    padding: 0;
  }

  body.br-print-mode .br-report-card {
    break-inside: avoid;
    page-break-inside: avoid;
    box-shadow: none;
    margin-bottom: 12px;
    border-radius: var(--br-radius-inner);
  }

  body.br-print-wertepass .br-report-card:not([data-print-section='wertepass']) {
    display: none !important;
  }

  body.br-print-report .br-report-card[data-print-section='wertepass'] {
    display: none !important;
  }

  body.br-print-mode .br-section-hidden {
    display: none !important;
  }
}

@page {
  size: A4;
  margin: 14mm;
}

@media (max-width: 1100px) {
  .br-layout {
    grid-template-columns: 1fr;
  }

  .br-sidebar {
    position: static;
  }
}

@media (max-width: 700px) {
  .br-shell {
    padding: var(--olo-space-4) var(--olo-space-4) 40px;
  }

  .br-eye-grid,
  .br-kv-row {
    grid-template-columns: 1fr;
  }

  .br-header {
    grid-template-columns: 1fr;
  }

  .br-header-center {
    order: -1;
    text-align: left;
  }
}
