@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&display=swap');

:root {
  --bg-primary: #060a12;
  --bg-secondary: #0c1220;
  --bg-panel: #0f1628;
  --bg-card: #131d30;
  --bg-card-strong: #16233a;
  --border-color: #1a2a42;
  --border-accent: #2a3a5a;
  --text-primary: #c8d8e8;
  --text-secondary: #8d9db2;
  --text-muted: #5c6d86;
  --accent-blue: #00d4ff;
  --accent-green: #2aad4a;
  --accent-yellow: #e8a820;
  --accent-red: #e84040;
  --accent-orange: #ff834f;
  --shadow-panel: 0 18px 44px rgba(0, 0, 0, 0.26);
  --font-mono: 'JetBrains Mono', 'SF Mono', 'Fira Code', 'Consolas', monospace;
  --workflow-height: 720px;
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  color-scheme: dark;
}

body {
  min-height: 100vh;
  font-family: var(--font-mono);
  background: var(--bg-primary);
  color: var(--text-primary);
}

button,
input,
select,
a {
  font: inherit;
}

a {
  color: inherit;
  text-decoration: none;
}

.ambient {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
  background:
    radial-gradient(circle at 12% 18%, rgba(0, 212, 255, 0.1), transparent 42%),
    radial-gradient(circle at 84% 10%, rgba(232, 168, 32, 0.08), transparent 38%),
    radial-gradient(circle at 75% 76%, rgba(232, 64, 64, 0.06), transparent 34%);
}

.header {
  position: sticky;
  top: 0;
  z-index: 40;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 24px;
  background: rgba(12, 18, 32, 0.92);
  border-bottom: 1px solid var(--border-color);
  backdrop-filter: blur(10px);
}

.header-left,
.header-right {
  display: flex;
  align-items: center;
  gap: 16px;
}

.header-right {
  margin-left: auto;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.realm-logo {
  height: 24px;
  width: auto;
}

.header-toggle-group {
  background: rgba(6, 10, 18, 0.82);
}

.header-title {
  font-size: 13px;
  color: var(--text-secondary);
  letter-spacing: 0.02em;
}

.mine-label {
  font-size: 11px;
  color: var(--text-muted);
}

.status-indicator {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  color: var(--accent-green);
}

.status-dot {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--accent-green);
  animation: pulse-dot 2s infinite;
}

@keyframes pulse-dot {
  0%, 100% {
    opacity: 1;
  }

  50% {
    opacity: 0.35;
  }
}

.summary-tags {
  margin-top: 14px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.summary-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(42, 58, 90, 0.9);
  background: rgba(19, 29, 48, 0.75);
  color: var(--text-secondary);
  border-radius: 999px;
  padding: 7px 12px;
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.summary-tag strong {
  color: var(--text-primary);
  font-weight: 600;
}

.summary-cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(180px, 1fr));
  gap: 12px;
}

html.presentation-mode .assistant-launcher {
  display: none !important;
}

.signal-layout {
  padding: 20px 24px 32px;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 16px;
}

html.presentation-focus-quarterly .signal-layout,
body.presentation-focus-quarterly .signal-layout {
  padding: 14px 18px 20px;
  gap: 12px;
}

html.presentation-focus-quarterly .outlook-panel,
body.presentation-focus-quarterly .outlook-panel {
  gap: 12px;
  padding: 14px;
}

html.presentation-focus-quarterly .outlook-panel .panel-header p,
body.presentation-focus-quarterly .outlook-panel .panel-header p,
html.presentation-focus-quarterly .outlook-snapshot-copy,
body.presentation-focus-quarterly .outlook-snapshot-copy,
html.presentation-focus-quarterly .outlook-note,
body.presentation-focus-quarterly .outlook-note,
html.presentation-focus-quarterly .quarter-metrics,
body.presentation-focus-quarterly .quarter-metrics {
  display: none;
}

html.presentation-focus-quarterly .outlook-intro,
body.presentation-focus-quarterly .outlook-intro {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 320px);
  gap: 12px;
  align-items: start;
}

html.presentation-focus-quarterly .outlook-summary-block,
body.presentation-focus-quarterly .outlook-summary-block {
  grid-column: 1;
  grid-row: 1;
}

html.presentation-focus-quarterly .outlook-primary,
body.presentation-focus-quarterly .outlook-primary {
  grid-column: 1;
  grid-row: 2;
}

html.presentation-focus-quarterly .outlook-summary,
body.presentation-focus-quarterly .outlook-summary {
  max-width: none;
  margin-top: 6px;
}

html.presentation-focus-quarterly .outlook-side,
body.presentation-focus-quarterly .outlook-side {
  width: 100%;
  grid-column: 2;
  grid-row: 2;
}

html.presentation-focus-quarterly .briefing-launch,
body.presentation-focus-quarterly .briefing-launch {
  gap: 8px;
  padding: 10px;
}

html.presentation-focus-quarterly .briefing-launch-title,
body.presentation-focus-quarterly .briefing-launch-title {
  font-size: 12px;
  line-height: 1.45;
}

html.presentation-focus-quarterly .briefing-launch-meta,
body.presentation-focus-quarterly .briefing-launch-meta {
  font-size: 10px;
  line-height: 1.5;
}

html.presentation-focus-quarterly .briefing-launch-stats,
body.presentation-focus-quarterly .briefing-launch-stats {
  gap: 6px;
}

html.presentation-focus-quarterly .briefing-launch-stat,
body.presentation-focus-quarterly .briefing-launch-stat {
  padding: 8px;
}

html.presentation-focus-quarterly .outlook-snapshot,
body.presentation-focus-quarterly .outlook-snapshot {
  gap: 8px;
}

html.presentation-focus-quarterly .summary-cards,
body.presentation-focus-quarterly .summary-cards,
html.presentation-focus-quarterly .outlook-grid,
body.presentation-focus-quarterly .outlook-grid {
  gap: 8px;
}

html.presentation-focus-quarterly .stat-card,
body.presentation-focus-quarterly .stat-card,
html.presentation-focus-quarterly .outlook-card,
body.presentation-focus-quarterly .outlook-card {
  padding: 12px;
}

html.presentation-focus-quarterly .assistant-overlay,
body.presentation-focus-quarterly .assistant-overlay {
  padding: 18px;
}

html.presentation-focus-quarterly .assistant-drawer,
body.presentation-focus-quarterly .assistant-drawer {
  width: min(430px, calc(100vw - 36px));
  min-height: 480px;
  max-height: min(72vh, 640px);
}

.outlook-intro {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(300px, 360px);
  gap: 16px;
  align-items: start;
}

.outlook-summary-block {
  min-width: 0;
  grid-column: 1;
  grid-row: 1;
}

.outlook-primary {
  min-width: 0;
  display: grid;
  grid-column: 1;
  grid-row: 2;
  gap: 14px;
}

.outlook-period {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent-orange);
}

.outlook-summary {
  margin-top: 8px;
  max-width: 760px;
  font-size: 12px;
  line-height: 1.8;
  color: var(--text-secondary);
}

.outlook-note {
  max-width: 280px;
  border: 1px solid rgba(42, 58, 90, 0.82);
  border-radius: 10px;
  background: rgba(12, 18, 32, 0.62);
  padding: 10px 12px;
  font-size: 11px;
  line-height: 1.7;
  color: var(--text-muted);
}

.outlook-side {
  display: grid;
  gap: 10px;
  width: 100%;
  grid-column: 2;
  grid-row: 2;
}

.briefing-launch {
  display: grid;
  gap: 10px;
  border: 1px solid rgba(42, 58, 90, 0.82);
  border-radius: 10px;
  background:
    linear-gradient(180deg, rgba(19, 29, 48, 0.82), rgba(12, 18, 32, 0.82)),
    radial-gradient(circle at top right, rgba(255, 79, 0, 0.12), transparent 42%);
  padding: 12px;
}

.briefing-launch-title {
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-primary);
}

.briefing-launch-meta {
  font-size: 11px;
  line-height: 1.7;
  color: var(--text-secondary);
}

.briefing-launch-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.briefing-launch-stat {
  border: 1px solid rgba(42, 58, 90, 0.68);
  border-radius: 10px;
  background: rgba(6, 10, 18, 0.48);
  padding: 9px 10px;
}

.briefing-launch-stat-label {
  display: block;
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.briefing-launch-stat strong {
  display: block;
  margin-top: 6px;
  font-size: 12px;
  line-height: 1.5;
  color: var(--text-primary);
}

.quarter-metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 10px;
}

.outlook-snapshot {
  display: grid;
  gap: 12px;
}

.outlook-snapshot-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.outlook-snapshot-copy {
  margin-top: 8px;
  max-width: 760px;
  font-size: 12px;
  line-height: 1.8;
  color: var(--text-secondary);
}

.summary-cards-quarterly {
  margin-top: 2px;
}

.summary-tags-quarterly {
  margin-top: 0;
}

.quarter-chart {
  margin-top: 12px;
}

.trend-svg {
  width: 100%;
  height: auto;
  display: block;
}

.trend-grid-line {
  stroke: rgba(42, 58, 90, 0.78);
  stroke-width: 1;
  stroke-dasharray: 4 6;
}

.trend-grid-label {
  font-size: 10px;
  fill: var(--text-muted);
}

.trend-bar {
  fill: rgba(0, 212, 255, 0.18);
  stroke: rgba(0, 212, 255, 0.3);
  stroke-width: 1;
}

.trend-bar.is-focus {
  fill: rgba(0, 212, 255, 0.24);
  stroke: rgba(0, 212, 255, 0.54);
}

.trend-bar-ss {
  fill: rgba(232, 168, 32, 0.82);
}

.trend-axis-label {
  font-size: 10px;
  fill: var(--text-secondary);
}

.trend-total-label {
  font-size: 10px;
  fill: #d9f5fb;
}

.trend-legend {
  margin-top: 10px;
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.trend-legend-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-secondary);
}

.trend-legend-swatch {
  width: 12px;
  height: 12px;
  border-radius: 4px;
  border: 1px solid rgba(42, 58, 90, 0.72);
}

.trend-legend-swatch.volume {
  background: rgba(0, 212, 255, 0.18);
  border-color: rgba(0, 212, 255, 0.3);
}

.trend-legend-swatch.ss {
  background: rgba(232, 168, 32, 0.82);
  border-color: rgba(232, 168, 32, 0.42);
}

.trend-caption {
  margin-top: 12px;
  font-size: 11px;
  line-height: 1.7;
  color: var(--text-secondary);
}

.outlook-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.outlook-card {
  border: 1px solid rgba(42, 58, 90, 0.72);
  border-radius: 10px;
  background: rgba(19, 29, 48, 0.68);
  padding: 14px;
  min-height: 0;
}

.outlook-card-hero {
  padding: 14px;
}

.outlook-card-wide {
  grid-column: 1 / -1;
}

.outlook-list,
.recommendation-list {
  margin-top: 10px;
  display: grid;
  gap: 10px;
}

.outlook-item,
.recommendation-item {
  border: 1px solid rgba(42, 58, 90, 0.72);
  border-radius: 10px;
  background: rgba(12, 18, 32, 0.62);
  padding: 12px;
}

.outlook-item.is-focus,
.recommendation-item.is-focus {
  border-color: rgba(0, 212, 255, 0.42);
  box-shadow: 0 0 0 1px rgba(0, 212, 255, 0.12);
}

.outlook-item-head,
.recommendation-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.outlook-item-title {
  font-size: 13px;
  color: var(--text-primary);
}

.outlook-item-meta,
.recommendation-owner,
.assistant-context,
.chat-meta {
  margin-top: 6px;
  font-size: 11px;
  line-height: 1.7;
  color: var(--text-secondary);
}

.outlook-item-copy {
  margin-top: 8px;
  font-size: 11px;
  line-height: 1.7;
  color: var(--text-primary);
}

.trend-pill,
.priority-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 5px 9px;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.trend-pill.up,
.priority-pill.high {
  border: 1px solid rgba(232, 64, 64, 0.38);
  background: rgba(232, 64, 64, 0.12);
  color: #ffaeae;
}

.trend-pill.flat,
.priority-pill.medium {
  border: 1px solid rgba(232, 168, 32, 0.42);
  background: rgba(232, 168, 32, 0.14);
  color: #f2ce6e;
}

.trend-pill.down,
.priority-pill.low {
  border: 1px solid rgba(42, 173, 74, 0.44);
  background: rgba(42, 173, 74, 0.12);
  color: #8fe0a4;
}

.recommendation-points {
  margin-top: 10px;
  display: grid;
  gap: 7px;
}

.recommendation-point {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  font-size: 11px;
  line-height: 1.7;
  color: var(--text-primary);
}

.recommendation-point::before {
  content: '•';
  color: var(--accent-blue);
}

.assistant-panel {
  min-height: 0;
}

.assistant-launcher {
  position: fixed;
  right: 16px;
  bottom: 12px;
  z-index: 860;
  min-width: 216px;
  max-width: min(320px, calc(100vw - 48px));
  display: inline-flex;
  align-items: center;
  gap: 12px;
  border: 1px solid rgba(0, 212, 255, 0.34);
  background:
    linear-gradient(180deg, rgba(15, 22, 40, 0.96), rgba(9, 14, 24, 0.98)),
    radial-gradient(circle at top left, rgba(0, 212, 255, 0.18), transparent 56%);
  color: var(--text-primary);
  border-radius: 18px;
  padding: 10px 12px;
  box-shadow:
    0 20px 48px rgba(0, 0, 0, 0.34),
    0 0 0 1px rgba(0, 212, 255, 0.08);
  cursor: pointer;
  text-align: left;
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.assistant-launcher:hover,
.assistant-launcher:focus-visible {
  outline: none;
  transform: translateY(-2px);
  border-color: rgba(0, 212, 255, 0.46);
  box-shadow:
    0 24px 54px rgba(0, 0, 0, 0.38),
    0 0 0 1px rgba(0, 212, 255, 0.12);
}

.assistant-launcher-dot {
  width: 10px;
  height: 10px;
  flex: 0 0 auto;
  border-radius: 999px;
  background: var(--accent-blue);
  box-shadow: 0 0 16px rgba(0, 212, 255, 0.45);
  animation: pulse-dot 2s infinite;
}

.assistant-launcher-copy {
  min-width: 0;
  display: grid;
  gap: 4px;
}

.assistant-launcher-label {
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent-blue);
}

.assistant-launcher-state {
  font-size: 12px;
  line-height: 1.5;
  color: var(--text-primary);
}

.assistant-launcher-meta {
  font-size: 11px;
  line-height: 1.5;
  color: var(--text-secondary);
}

.assistant-overlay {
  position: fixed;
  inset: 0;
  z-index: 880;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  padding: 24px;
}

.assistant-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(3, 6, 12, 0.14);
}

.assistant-drawer {
  position: relative;
  width: min(480px, calc(100vw - 48px));
  min-height: 540px;
  max-height: min(78vh, 760px);
  gap: 14px;
  overflow: hidden;
  border-color: rgba(42, 58, 90, 0.98);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(15, 22, 40, 0.98), rgba(10, 16, 28, 0.98)),
    radial-gradient(circle at top left, rgba(0, 212, 255, 0.1), transparent 54%);
  box-shadow:
    0 28px 72px rgba(0, 0, 0, 0.42),
    0 0 0 1px rgba(0, 212, 255, 0.06);
}

.assistant-panel-head {
  align-items: flex-start;
}

.assistant-panel-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.assistant-context {
  border: 1px solid rgba(42, 58, 90, 0.8);
  border-radius: 10px;
  background: rgba(12, 18, 32, 0.58);
  padding: 10px 12px;
}

.assistant-suggestions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.chat-thread {
  min-height: 260px;
  max-height: 520px;
  overflow: auto;
  padding-right: 4px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.assistant-drawer .chat-thread {
  flex: 1 1 auto;
  min-height: 220px;
  max-height: none;
}

.chat-message {
  max-width: 100%;
  border: 1px solid rgba(42, 58, 90, 0.76);
  border-radius: 10px;
  background: rgba(12, 18, 32, 0.62);
  padding: 12px;
}

.chat-message.user {
  align-self: flex-end;
  background: rgba(0, 212, 255, 0.12);
  border-color: rgba(0, 212, 255, 0.34);
}

.chat-message.assistant {
  align-self: stretch;
}

.chat-message.assistant.is-streaming {
  border-color: rgba(0, 212, 255, 0.34);
  box-shadow: 0 0 0 1px rgba(0, 212, 255, 0.08);
}

.chat-role {
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.chat-copy {
  margin-top: 8px;
  font-size: 12px;
  line-height: 1.8;
  color: var(--text-primary);
  white-space: pre-wrap;
}

.chat-message.assistant.is-streaming .chat-copy::after {
  content: '|';
  display: inline-block;
  margin-left: 2px;
  color: var(--accent-blue);
  animation: chat-cursor 0.9s steps(1, end) infinite;
}

@keyframes chat-cursor {
  0%, 48% {
    opacity: 1;
  }

  49%, 100% {
    opacity: 0;
  }
}

.chat-form {
  display: flex;
  align-items: center;
  gap: 8px;
}

.chat-form input {
  flex: 1;
  border: 1px solid var(--border-accent);
  background: rgba(6, 10, 18, 0.88);
  color: var(--text-primary);
  border-radius: 8px;
  padding: 11px 12px;
}

.chat-form input:focus {
  outline: none;
  border-color: rgba(0, 212, 255, 0.5);
  box-shadow: 0 0 0 1px rgba(0, 212, 255, 0.18);
}

.chat-form input:disabled {
  cursor: wait;
  color: var(--text-secondary);
}

.stat-card {
  background: rgba(19, 29, 48, 0.9);
  border: 1px solid var(--border-color);
  border-radius: 10px;
  padding: 14px 16px;
  box-shadow: var(--shadow-panel);
}

.stat-label {
  font-size: 10px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.stat-value {
  margin-top: 10px;
  font-size: clamp(24px, 2.1vw, 30px);
  color: var(--text-primary);
}

.stat-helper {
  margin-top: 6px;
  font-size: 11px;
  line-height: 1.5;
  color: var(--text-secondary);
}

.layout {
  height: var(--workflow-height);
  min-height: 480px;
  padding: 12px 24px 12px;
  display: grid;
  grid-template-columns: minmax(320px, 360px) minmax(460px, 1.15fr) minmax(320px, 0.92fr);
  gap: 14px;
  align-items: stretch;
}

html.presentation-focus-detail .layout,
body.presentation-focus-detail .layout,
html.presentation-focus-abatement .layout,
body.presentation-focus-abatement .layout {
  grid-template-columns: minmax(0, 1fr);
}

html.presentation-focus-detail .records-panel,
body.presentation-focus-detail .records-panel,
html.presentation-focus-detail .similar-panel,
body.presentation-focus-detail .similar-panel,
html.presentation-focus-abatement .records-panel,
body.presentation-focus-abatement .records-panel,
html.presentation-focus-abatement .similar-panel,
body.presentation-focus-abatement .similar-panel {
  display: none;
}

.panel {
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
  overflow: hidden;
  background: rgba(15, 22, 40, 0.92);
  border: 1px solid var(--border-color);
  border-radius: 12px;
  padding: 18px;
  box-shadow: var(--shadow-panel);
  animation: rise 0.6s ease both;
}

.records-panel,
.similar-panel {
  gap: 10px;
  padding: 12px;
}

.records-panel .panel-header,
.similar-panel .panel-header {
  gap: 8px;
  align-items: center;
}

.records-panel .panel-header p,
.similar-panel .panel-header p {
  display: none;
}

@keyframes rise {
  from {
    opacity: 0;
    transform: translateY(8px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.panel-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.panel-header-stack {
  align-items: center;
}

.panel-header h2 {
  font-size: 14px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-primary);
}

.panel-header p {
  margin-top: 6px;
  font-size: 11px;
  line-height: 1.6;
  color: var(--text-secondary);
}

.panel-actions,
.button-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.records-panel .panel-actions {
  gap: 6px;
}

.records-panel .panel-actions .button {
  padding: 7px 10px;
  font-size: 10px;
}

.button {
  border: 1px solid rgba(0, 212, 255, 0.38);
  background: rgba(0, 212, 255, 0.16);
  color: var(--accent-blue);
  border-radius: 8px;
  padding: 10px 14px;
  cursor: pointer;
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.button:hover,
.button:focus-visible {
  background: rgba(0, 212, 255, 0.24);
  border-color: rgba(0, 212, 255, 0.56);
  outline: none;
  transform: translateY(-1px);
}

.button:disabled {
  cursor: wait;
  opacity: 0.58;
  transform: none;
}

.button.secondary {
  border-color: rgba(42, 58, 90, 0.95);
  background: rgba(22, 35, 58, 0.85);
  color: var(--text-primary);
}

.button.secondary:hover,
.button.secondary:focus-visible {
  background: rgba(29, 45, 71, 0.9);
}

.button.ghost {
  border-color: rgba(42, 58, 90, 0.95);
  background: transparent;
  color: var(--text-secondary);
}

.button.ghost:hover,
.button.ghost:focus-visible {
  color: var(--text-primary);
  background: rgba(19, 29, 48, 0.72);
}

.status-pill {
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(42, 58, 90, 0.95);
  background: rgba(19, 29, 48, 0.75);
  border-radius: 999px;
  padding: 7px 12px;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-secondary);
}

.status-pill.high {
  border-color: rgba(232, 64, 64, 0.38);
  background: rgba(232, 64, 64, 0.12);
  color: #ffaeae;
}

.status-pill.medium {
  border-color: rgba(232, 168, 32, 0.42);
  background: rgba(232, 168, 32, 0.14);
  color: #f2ce6e;
}

.status-pill.low {
  border-color: rgba(42, 173, 74, 0.42);
  background: rgba(42, 173, 74, 0.12);
  color: #8fe0a4;
}

.filters {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
}

.filters-compact {
  grid-template-columns: minmax(0, 1.3fr) repeat(2, minmax(96px, 0.8fr));
  align-items: end;
}

.field {
  display: grid;
  gap: 6px;
}

.field span {
  font-size: 10px;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.field input,
.field select {
  width: 100%;
  border: 1px solid var(--border-accent);
  background: rgba(6, 10, 18, 0.88);
  color: var(--text-primary);
  border-radius: 8px;
  padding: 8px 10px;
}

.field input::placeholder {
  color: var(--text-muted);
}

.field input:focus,
.field select:focus {
  outline: none;
  border-color: rgba(0, 212, 255, 0.5);
  box-shadow: 0 0 0 1px rgba(0, 212, 255, 0.18);
}

.field-search {
  grid-column: 1 / -1;
}

.filters-compact .field-search {
  grid-column: auto;
}

.field-compact {
  min-width: 82px;
}

.field-limit {
  min-width: 72px;
}

.records-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}

.chip-group {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.chip {
  border: 1px solid rgba(42, 58, 90, 0.95);
  background: rgba(19, 29, 48, 0.7);
  color: var(--text-secondary);
  border-radius: 999px;
  padding: 6px 9px;
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
}

.chip:hover,
.chip:focus-visible,
.chip.is-active {
  outline: none;
  border-color: rgba(0, 212, 255, 0.45);
  color: var(--accent-blue);
  background: rgba(0, 212, 255, 0.12);
}

.chip:disabled {
  cursor: wait;
  opacity: 0.54;
}

.records-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  color: var(--text-muted);
  font-size: 10px;
  white-space: nowrap;
}

.records-list,
.detail-view,
.similar-body {
  flex: 1 1 auto;
  min-height: 0;
  overflow: auto;
  padding-right: 4px;
  overscroll-behavior: contain;
}

.records-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.record-card {
  border: 1px solid rgba(42, 58, 90, 0.7);
  background: linear-gradient(180deg, rgba(19, 29, 48, 0.9), rgba(16, 24, 39, 0.88));
  border-radius: 10px;
  padding: 12px;
  cursor: pointer;
  transition: border-color 0.18s ease, background 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.record-card:hover,
.record-card:focus-visible {
  outline: none;
  border-color: rgba(0, 212, 255, 0.42);
  background: linear-gradient(180deg, rgba(22, 35, 58, 0.96), rgba(19, 29, 48, 0.94));
  transform: translateY(-1px);
}

.record-card.is-selected {
  border-color: rgba(0, 212, 255, 0.56);
  box-shadow: 0 0 0 1px rgba(0, 212, 255, 0.14);
}

.record-card-head {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}

.record-tag {
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(42, 58, 90, 0.95);
  border-radius: 999px;
  padding: 4px 9px;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.record-tag.citation {
  border-color: rgba(0, 212, 255, 0.45);
  color: var(--accent-blue);
  background: rgba(0, 212, 255, 0.1);
}

.record-tag.order {
  border-color: rgba(232, 64, 64, 0.35);
  color: #ff9b9b;
  background: rgba(232, 64, 64, 0.12);
}

.record-number {
  font-size: 12px;
  color: var(--text-primary);
}

.record-date {
  font-size: 10px;
  color: var(--text-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.record-text {
  font-size: 11px;
  line-height: 1.5;
  color: var(--text-primary);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.record-meta {
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.record-meta-item {
  border: 1px solid rgba(42, 58, 90, 0.72);
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 10px;
  color: var(--text-secondary);
  background: rgba(12, 18, 32, 0.72);
}

.empty-state {
  border: 1px dashed rgba(42, 58, 90, 0.82);
  border-radius: 10px;
  padding: 18px;
  text-align: center;
  color: var(--text-secondary);
  background: rgba(12, 18, 32, 0.52);
  line-height: 1.7;
}

.detail-empty {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: auto;
}

.detail-view {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.detail-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.detail-status-band {
  display: grid;
  gap: 14px;
  border: 1px solid rgba(42, 58, 90, 0.82);
  border-radius: 12px;
  padding: 16px;
  background: rgba(19, 29, 48, 0.72);
}

.detail-status-band.high {
  border-color: rgba(232, 64, 64, 0.34);
  background:
    linear-gradient(180deg, rgba(46, 18, 26, 0.78), rgba(19, 29, 48, 0.78)),
    radial-gradient(circle at top right, rgba(232, 64, 64, 0.14), transparent 42%);
}

.detail-status-band.medium {
  border-color: rgba(232, 168, 32, 0.34);
  background:
    linear-gradient(180deg, rgba(43, 29, 14, 0.74), rgba(19, 29, 48, 0.78)),
    radial-gradient(circle at top right, rgba(232, 168, 32, 0.12), transparent 42%);
}

.detail-status-band.low {
  border-color: rgba(42, 173, 74, 0.34);
  background:
    linear-gradient(180deg, rgba(15, 34, 24, 0.74), rgba(19, 29, 48, 0.78)),
    radial-gradient(circle at top right, rgba(42, 173, 74, 0.1), transparent 42%);
}

.detail-status-band-copy {
  display: grid;
  gap: 8px;
}

.detail-status-band-label {
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.detail-status-title {
  font-size: 18px;
  line-height: 1.3;
  color: var(--text-primary);
}

.detail-status-copy {
  font-size: 11px;
  line-height: 1.8;
  color: var(--text-secondary);
}

.detail-status-chips {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 10px;
}

.detail-status-chip {
  border: 1px solid rgba(42, 58, 90, 0.72);
  border-radius: 10px;
  padding: 10px 12px;
  background: rgba(6, 10, 18, 0.42);
}

.detail-status-chip-label {
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.detail-status-chip-value {
  margin-top: 6px;
  font-size: 12px;
  line-height: 1.6;
  color: var(--text-primary);
}

.detail-tag-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.detail-number {
  font-size: 24px;
  line-height: 1.2;
}

.detail-meta,
.detail-mine,
.detail-footer {
  font-size: 11px;
  line-height: 1.7;
  color: var(--text-secondary);
}

.detail-entity {
  margin-top: 10px;
  display: grid;
  gap: 4px;
}

.detail-operator {
  font-size: 13px;
  color: var(--text-primary);
}

.callout {
  border: 1px solid rgba(42, 58, 90, 0.82);
  border-left: 3px solid var(--accent-yellow);
  border-radius: 10px;
  padding: 16px;
  background: rgba(19, 29, 48, 0.72);
}

.callout-label,
.section-title {
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.callout-copy {
  margin-top: 10px;
  font-size: 12px;
  line-height: 1.8;
  color: var(--text-primary);
}

.detail-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.detail-support-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.detail-item {
  border: 1px solid rgba(42, 58, 90, 0.72);
  border-radius: 10px;
  padding: 12px;
  background: rgba(12, 18, 32, 0.58);
}

.detail-item-label {
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.detail-item-value {
  margin-top: 7px;
  font-size: 12px;
  line-height: 1.6;
  color: var(--text-primary);
}

.guides-block {
  display: grid;
  gap: 10px;
}

.people-block {
  display: grid;
  gap: 10px;
}

.people-grid {
  display: grid;
  gap: 8px;
}

.person-card {
  border: 1px solid rgba(42, 58, 90, 0.72);
  border-radius: 10px;
  padding: 12px;
  background: rgba(12, 18, 32, 0.58);
}

.person-card.inspector {
  border-color: rgba(0, 212, 255, 0.3);
}

.person-card.escort {
  border-color: rgba(232, 168, 32, 0.28);
}

.person-card.owner {
  border-color: rgba(42, 173, 74, 0.28);
}

.person-role {
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.person-name {
  margin-top: 6px;
  font-size: 13px;
  line-height: 1.5;
  color: var(--text-primary);
}

.person-meta,
.person-note {
  margin-top: 6px;
  font-size: 11px;
  line-height: 1.7;
}

.person-meta {
  color: var(--text-secondary);
}

.person-note {
  color: var(--text-primary);
}

.abatement-block {
  display: grid;
  gap: 10px;
}

.abatement-body {
  display: grid;
  gap: 12px;
}

.abatement-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.abatement-copy {
  max-width: 520px;
  font-size: 12px;
  line-height: 1.8;
  color: var(--text-secondary);
}

.workflow-status {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 7px 12px;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border: 1px solid rgba(42, 58, 90, 0.82);
  background: rgba(19, 29, 48, 0.75);
  color: var(--text-secondary);
}

.workflow-status.ready {
  border-color: rgba(0, 212, 255, 0.42);
  background: rgba(0, 212, 255, 0.12);
  color: var(--accent-blue);
}

.workflow-status.submitted,
.workflow-status.review {
  border-color: rgba(232, 168, 32, 0.42);
  background: rgba(232, 168, 32, 0.12);
  color: #f2ce6e;
}

.workflow-status.waiting {
  border-color: rgba(42, 173, 74, 0.44);
  background: rgba(42, 173, 74, 0.12);
  color: #8fe0a4;
}

.workflow-timeline {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.workflow-step {
  border: 1px solid rgba(42, 58, 90, 0.72);
  border-radius: 10px;
  padding: 10px 12px;
  background: rgba(12, 18, 32, 0.58);
}

.workflow-step.is-complete {
  border-color: rgba(42, 173, 74, 0.34);
  background: rgba(42, 173, 74, 0.08);
}

.workflow-step.is-active {
  border-color: rgba(0, 212, 255, 0.42);
  box-shadow: 0 0 0 1px rgba(0, 212, 255, 0.12);
}

.workflow-step-label {
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.workflow-step-value {
  margin-top: 7px;
  font-size: 12px;
  line-height: 1.6;
  color: var(--text-primary);
}

.abatement-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.abatement-card {
  border: 1px solid rgba(42, 58, 90, 0.72);
  border-radius: 10px;
  padding: 14px;
  background: rgba(12, 18, 32, 0.58);
}

.abatement-card h3 {
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-primary);
}

.abatement-card-copy {
  margin-top: 8px;
  font-size: 11px;
  line-height: 1.7;
  color: var(--text-secondary);
}

.abatement-meta {
  margin-top: 10px;
  display: grid;
  gap: 8px;
}

.abatement-meta-item {
  border: 1px solid rgba(42, 58, 90, 0.64);
  border-radius: 10px;
  padding: 10px 12px;
  background: rgba(19, 29, 48, 0.74);
}

.abatement-meta-label {
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.abatement-meta-value {
  margin-top: 6px;
  font-size: 11px;
  line-height: 1.7;
  color: var(--text-primary);
}

.abatement-list {
  margin-top: 10px;
  display: grid;
  gap: 8px;
}

.abatement-list-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 11px;
  line-height: 1.7;
  color: var(--text-primary);
}

.abatement-list-item::before {
  content: '';
  width: 8px;
  height: 8px;
  margin-top: 6px;
  flex: 0 0 auto;
  border-radius: 999px;
  background: var(--accent-blue);
  box-shadow: 0 0 0 4px rgba(0, 212, 255, 0.08);
}

.abatement-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.abatement-footnote {
  font-size: 11px;
  line-height: 1.7;
  color: var(--text-secondary);
}

.document-list {
  display: grid;
  gap: 8px;
}

.document-row {
  width: 100%;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  text-align: left;
  border: 1px solid rgba(42, 58, 90, 0.8);
  border-radius: 10px;
  background: rgba(19, 29, 48, 0.78);
  color: var(--text-primary);
  padding: 12px 14px;
  cursor: pointer;
}

.document-row:hover,
.document-row:focus-visible {
  outline: none;
  border-color: rgba(0, 212, 255, 0.42);
  background: rgba(22, 35, 58, 0.86);
}

.document-kind {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(42, 58, 90, 0.8);
  border-radius: 999px;
  padding: 5px 8px;
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.document-main {
  min-width: 0;
  display: grid;
  gap: 5px;
}

.document-title {
  font-size: 12px;
  line-height: 1.6;
  color: var(--text-primary);
}

.document-meta {
  font-size: 11px;
  line-height: 1.6;
  color: var(--text-secondary);
}

.document-action {
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent-blue);
}

.mode-controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}

.mode-controls-compact {
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
}

.toggle-group {
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(42, 58, 90, 0.95);
  border-radius: 8px;
  overflow: hidden;
  background: rgba(6, 10, 18, 0.88);
}

.toggle-btn {
  border: 0;
  background: transparent;
  color: var(--text-muted);
  padding: 8px 12px;
  cursor: pointer;
  font-size: 10px;
  letter-spacing: 0.11em;
  text-transform: uppercase;
}

.toggle-btn:hover,
.toggle-btn:focus-visible {
  outline: none;
  color: var(--text-secondary);
  background: rgba(0, 212, 255, 0.08);
}

.toggle-btn.is-active {
  color: var(--accent-blue);
  background: rgba(0, 212, 255, 0.14);
}

.toggle-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.context-label {
  font-size: 10px;
  line-height: 1.4;
  color: var(--text-secondary);
}

.mode-controls-compact .context-label {
  margin-left: auto;
  flex: 1 1 0;
  text-align: right;
}

.similar-panel .field span {
  font-size: 9px;
}

.similar-panel .field select {
  padding: 6px 10px;
}

.similar-body {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.metric-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.metric-card {
  flex: 1 1 132px;
  border: 1px solid rgba(42, 58, 90, 0.72);
  border-radius: 8px;
  padding: 8px 10px;
  background: rgba(19, 29, 48, 0.72);
}

.metric-card-label {
  font-size: 9px;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.metric-card-value {
  margin-top: 4px;
  font-size: 13px;
  color: var(--text-primary);
}

.table-shell {
  border: 1px solid rgba(42, 58, 90, 0.72);
  border-radius: 10px;
  overflow: auto;
  background: rgba(12, 18, 32, 0.62);
}

.similar-table {
  width: 100%;
  border-collapse: collapse;
}

.similar-table th,
.similar-table td {
  padding: 10px;
  text-align: left;
  vertical-align: top;
  border-bottom: 1px solid rgba(42, 58, 90, 0.42);
  font-size: 10px;
  line-height: 1.5;
}

.similar-table th {
  position: sticky;
  top: 0;
  background: rgba(15, 22, 40, 0.96);
  color: var(--text-muted);
  font-size: 10px;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  z-index: 1;
}

.similar-table tr:last-child td {
  border-bottom: 0;
}

.table-subtle {
  display: block;
  margin-top: 3px;
  color: var(--text-muted);
}

.inline-toggle {
  display: inline-flex;
  align-self: flex-start;
  border: 0;
  background: transparent;
  color: var(--accent-blue);
  cursor: pointer;
  padding: 0;
}

.distribution-grid {
  display: grid;
  gap: 8px;
}

.distribution-card {
  border: 1px solid rgba(42, 58, 90, 0.72);
  border-radius: 10px;
  padding: 12px;
  background: rgba(19, 29, 48, 0.72);
}

.distribution-card h3 {
  font-size: 10px;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.distribution-list {
  margin-top: 10px;
  display: grid;
  gap: 7px;
}

.distribution-item {
  font-size: 11px;
  line-height: 1.5;
  color: var(--text-primary);
}

.error-state {
  border-color: rgba(232, 64, 64, 0.4);
  color: #ffb0b0;
}

.loading-block {
  display: grid;
  justify-items: center;
  gap: 10px;
  padding: 20px;
  color: var(--text-secondary);
}

.spinner {
  width: 24px;
  height: 24px;
  border: 2px solid rgba(42, 58, 90, 0.95);
  border-top-color: var(--accent-blue);
  border-radius: 999px;
  animation: spin 0.7s linear infinite;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

.pdf-overlay {
  position: fixed;
  inset: 0;
  z-index: 999;
  display: flex;
  justify-content: flex-end;
}

.pdf-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(3, 6, 12, 0.76);
}

.pdf-drawer {
  position: relative;
  width: min(980px, 78vw);
  min-width: 320px;
  height: 100vh;
  background: rgba(12, 18, 32, 0.98);
  border-left: 1px solid var(--border-color);
  box-shadow: -22px 0 44px rgba(0, 0, 0, 0.36);
  display: flex;
  flex-direction: column;
}

.pdf-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 18px 20px;
  border-bottom: 1px solid var(--border-color);
}

.pdf-title {
  font-size: 16px;
  color: var(--text-primary);
}

.pdf-meta {
  margin-top: 6px;
  font-size: 11px;
  line-height: 1.6;
  color: var(--text-secondary);
}

.pdf-frame {
  flex: 1;
  width: 100%;
  border: 0;
  background: #0e1418;
}

[hidden] {
  display: none !important;
}

@media (max-width: 1440px) {
  .layout {
    grid-template-columns: minmax(300px, 340px) minmax(0, 1fr) minmax(300px, 360px);
  }

  .filters-compact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .filters-compact .field-search {
    grid-column: 1 / -1;
  }
}

@media (max-width: 1220px) {
  .summary {
    grid-template-columns: 1fr;
  }

  .outlook-intro {
    grid-template-columns: minmax(0, 1fr);
  }

  .outlook-summary-block,
  .outlook-primary,
  .outlook-side {
    grid-column: auto;
    grid-row: auto;
  }

  .signal-layout,
  .layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .detail-support-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .layout {
    height: auto;
    min-height: 0;
  }

  .panel {
    overflow: visible;
  }

  .records-list,
  .detail-view,
  .similar-body,
  .chat-thread {
    max-height: none;
    overflow: visible;
  }
}

@media (max-width: 760px) {
  .header,
  .signal-layout,
  .layout {
    padding-left: 16px;
    padding-right: 16px;
  }

  .header,
  .header-right,
  .panel-header,
  .detail-head,
  .mode-controls {
    flex-direction: column;
    align-items: flex-start;
  }

  .summary-cards,
  .quarter-metrics,
  .outlook-grid,
  .briefing-launch-stats,
  .filters,
  .abatement-grid,
  .workflow-timeline,
  .detail-grid,
  .detail-status-chips,
  .detail-support-grid,
  .metric-strip {
    grid-template-columns: 1fr;
  }

  .chat-form,
  .outlook-item-head,
  .recommendation-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .outlook-side {
    width: 100%;
  }

  .assistant-launcher {
    right: 16px;
    left: 16px;
    bottom: 12px;
    max-width: none;
    width: auto;
  }

  .assistant-overlay {
    padding: 16px;
  }

  .assistant-drawer {
    width: 100%;
    min-height: min(620px, calc(100vh - 32px));
    max-height: calc(100vh - 32px);
  }

  .assistant-panel-actions {
    width: 100%;
    justify-content: space-between;
  }

  .mode-controls-compact .context-label {
    margin-left: 0;
    text-align: left;
  }

  .pdf-drawer {
    width: 100vw;
  }
}
