:root {
  --interrogation-viewport-height: 100dvh;
  --font-ui: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
}

* {
box-sizing: border-box;
}

html,
body {
margin: 0;
  height: var(--interrogation-viewport-height, 100dvh);
  background: var(--interrogation-html-bg, #03070e);
  color: var(--interrogation-html-text, #d8ecff);
  font-family: var(--font-ui);
  overflow: hidden;
}

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

button {
cursor: pointer;
}

button:disabled {
cursor: not-allowed;
}

#wrap {
position: relative;
  width: 100vw;
  height: var(--interrogation-viewport-height, 100dvh);
  overflow: hidden;
  background: var(--interrogation-wrap-bg, #03070e);
}

#game {
position: absolute;
  inset: 0;
  width: 100vw;
  height: var(--interrogation-viewport-height, 100dvh);
  max-height: var(--interrogation-viewport-height, 100dvh);
  max-width: 100vw;
  pointer-events: none;
  opacity: 0.25;
  image-rendering: auto;
  background: transparent;
}

#html-ui {
position: absolute;
  inset: 0;
  z-index: 2;
}

.interrogation-app {
width: 100%;
  height: 100%;
  min-width: 1080px;
  color: var(--c-text);
  background:
    linear-gradient(rgba(0, 200, 255, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 200, 255, 0.035) 1px, transparent 1px),
    radial-gradient(circle at 25% 0%, rgba(0, 200, 255, 0.12), transparent 32%),
    radial-gradient(circle at 85% 12%, rgba(255, 51, 87, 0.12), transparent 28%);
  background-size: 48px 48px, 48px 48px, auto, auto;
  padding: 8px;
  overflow: hidden;
}

.app-shell {
height: 100%;
  display: grid;
  grid-template-rows: 68px minmax(0, 1fr);
  gap: 8px;
}

.app-shell--fullscreen-map {
grid-template-rows: minmax(0, 1fr);
}

.topbar,
.panel,
.modal-card,
.toast-error {
background: linear-gradient(180deg, rgba(10, 24, 38, 0.91), rgba(5, 13, 22, 0.92));
  border: 1px solid var(--panel-border);
  box-shadow:
    inset 0 0 24px rgba(0, 200, 255, 0.045),
    0 0 30px rgba(0, 0, 0, 0.4),
    0 0 24px var(--panel-glow);
}

.topbar {
display: grid;
  grid-template-columns: minmax(320px, 1fr) auto;
  gap: 12px;
  align-items: stretch;
  padding: 10px 12px;
}

.topbar__title-line {
display: flex;
  align-items: baseline;
  gap: 16px;
  min-width: 0;
}

.app-title {
color: var(--c-cyan);
  font-weight: 900;
  letter-spacing: 0.12em;
  font-size: 14px;
  text-shadow: 0 0 12px rgba(0, 200, 255, 0.5);
}

.app-dept {
color: var(--c-blue);
  font-size: 12px;
  opacity: 0.85;
  letter-spacing: 0.1em;
}

.case-title {
margin-top: 7px;
  font-size: 18px;
  font-weight: 800;
  color: var(--c-white);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.case-meta {
margin-top: 5px;
  color: var(--c-muted);
  font-size: 11px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

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

.layout {
min-height: 0;
  display: grid;
  grid-template-columns: 360px minmax(420px, 1fr) 360px;
  gap: 8px;
}

.layout--fullscreen {
display: block;
  min-height: 0;
}

.panel {
min-height: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.panel__head {
padding: 12px 14px 8px;
  border-bottom: 1px solid rgba(46, 155, 255, 0.18);
  background: rgba(3, 7, 14, 0.28);
}

.panel__title {
display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  color: var(--c-red);
  font-size: 14px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.panel__subtle {
color: var(--c-dim);
  font-size: 10px;
  text-transform: uppercase;
}

.panel__body {
flex: 1;
  min-height: 0;
  overflow: auto;
  padding: 12px 14px;
  scrollbar-color: var(--c-line2) rgba(0,0,0,0.25);
  scrollbar-width: thin;
}

.panel__body--no-pad {
padding: 0;
}

.button-row,
.filter-row,
.tab-row {
display: flex;
  gap: 6px;
  flex-wrap: wrap;
  align-items: center;
}

.filter-row {
margin-top: 10px;
}

.ui-btn,
.tab-btn,
.icon-btn {
border: 1px solid rgba(46, 155, 255, 0.36);
  color: var(--c-cyan);
  background: linear-gradient(180deg, rgba(12, 28, 49, 0.88), rgba(6, 15, 28, 0.92));
  box-shadow:
    inset 0 0 18px rgba(0, 200, 255, 0.06),
    0 0 12px rgba(0, 200, 255, 0.08);
  min-height: 28px;
  padding: 6px 10px;
  text-transform: uppercase;
  font-weight: 800;
  font-size: 11px;
  letter-spacing: 0.04em;
}

.ui-btn:hover,
.tab-btn:hover,
.icon-btn:hover,
.ui-btn:focus-visible,
.tab-btn:focus-visible,
.icon-btn:focus-visible {
color: var(--c-white);
  border-color: var(--c-cyan);
  outline: none;
  box-shadow:
    inset 0 0 22px rgba(0, 200, 255, 0.11),
    0 0 18px rgba(0, 200, 255, 0.28);
}

.ui-btn:disabled,
.tab-btn:disabled,
.icon-btn:disabled {
color: var(--c-dim);
  border-color: rgba(82, 104, 120, 0.3);
  background: rgba(8, 15, 23, 0.75);
  box-shadow: none;
  opacity: 0.6;
}

.ui-btn--active,
.tab-btn--active {
color: var(--c-white);
  border-color: var(--c-cyan);
  background: linear-gradient(180deg, rgba(0, 102, 150, 0.34), rgba(8, 30, 49, 0.94));
  text-shadow: 0 0 10px currentColor;
}

.ui-btn--danger {
color: var(--c-red);
  border-color: rgba(255, 51, 87, 0.52);
  box-shadow: 0 0 16px var(--danger-glow);
}

.ui-btn--ok {
color: var(--c-green); border-color: rgba(88, 242, 162, 0.42);
}

.ui-btn--warning {
color: var(--c-yellow); border-color: rgba(255, 191, 46, 0.42);
}

.ui-btn--purple {
color: var(--c-purple); border-color: rgba(198, 76, 255, 0.42);
}

.ui-btn--compact {
min-height: 24px; padding: 4px 8px; font-size: 10px;
}

.ui-btn--wide {
width: 100%; justify-content: center;
}

.tabs-panel {
display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
}

.tab-row {
padding: 10px 12px 0;
  border-bottom: 1px solid rgba(46, 155, 255, 0.16);
}

.tab-btn {
min-height: 34px;
  padding-inline: 14px;
}

.center-content {
min-height: 0;
  overflow: auto;
  padding: 12px;
}

.chat-scene {
position: relative;
  min-height: 265px;
  border: 1px solid rgba(46, 155, 255, 0.22);
  overflow: hidden;
  background: #050b13;
  margin-bottom: 12px;
}

.chat-scene__bg {
position: absolute;
  inset: 0;
  background-position: center;
  background-size: cover;
  opacity: 0.72;
  image-rendering: pixelated;
  filter: saturate(1.04) contrast(1.02);
}

.chat-scene__shade {
position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(2, 6, 12, 0.85), rgba(2, 6, 12, 0.26), rgba(2, 6, 12, 0.78)),
    linear-gradient(0deg, rgba(2, 6, 12, 0.86), transparent 45%);
}

.chat-scene__portrait {
position: absolute;
  right: 4%;
  bottom: 0;
  width: min(36%, 360px);
  max-height: 104%;
  object-fit: contain;
  object-position: bottom center;
  image-rendering: pixelated;
  filter: drop-shadow(0 0 24px rgba(0, 0, 0, 0.72));
}

.chat-scene__meta {
position: absolute;
  left: 14px;
  top: 12px;
  max-width: 62%;
}

.chat-scene__name {
color: var(--c-white);
  font-size: 23px;
  font-weight: 900;
  text-shadow: 0 0 20px rgba(0, 200, 255, 0.55);
}

.chat-scene__loc {
margin-top: 6px;
  color: var(--c-muted);
  font-size: 12px;
}

.emotion-grid {
position: absolute;
  left: 14px;
  bottom: 12px;
  display: grid;
  grid-template-columns: repeat(3, minmax(120px, 1fr));
  gap: 8px;
  width: min(62%, 520px);
}

.metric-pill {
border: 1px solid rgba(46, 155, 255, 0.26);
  background: rgba(4, 10, 18, 0.78);
  padding: 7px 8px;
}

.metric-pill__label {
color: var(--c-muted); font-size: 10px; text-transform: uppercase;
}

.metric-pill__value {
margin-top: 4px; color: var(--accent, var(--c-cyan)); font-weight: 900;
}

.transcript {
display: flex;
  flex-direction: column;
  gap: 8px;
  max-height: 310px;
  overflow: auto;
  padding-right: 4px;
}

.chat-bubble {
border: 1px solid rgba(46, 155, 255, 0.23);
  padding: 9px 11px;
  background: rgba(6, 14, 26, 0.72);
  line-height: 1.42;
  box-shadow: inset 0 0 18px rgba(0, 200, 255, 0.035);
}

.chat-bubble__who {
font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  color: var(--accent, var(--c-blue));
  margin-bottom: 4px;
}

.chat-bubble__text {
white-space: pre-wrap; font-size: 12px;
}

.chat-bubble--suspect {
background: rgba(9, 28, 20, 0.72); border-color: rgba(88, 242, 162, 0.25);
}

.chat-bubble--interrogator {
background: rgba(4, 36, 42, 0.72); border-color: rgba(0, 200, 255, 0.38);
}

.chat-bubble--apparatus {
background: rgba(7, 20, 38, 0.72); border-color: rgba(46, 155, 255, 0.40);
}

.chat-bubble--warning {
background: rgba(30, 13, 26, 0.72); border-color: rgba(255, 191, 46, 0.38);
}

.chat-bubble--error {
background: rgba(35, 10, 28, 0.74); border-color: rgba(255, 51, 87, 0.42);
}

.chat-bubble--breakthrough {
border-color: rgba(88, 242, 162, 0.46); box-shadow: 0 0 18px rgba(88, 242, 162, 0.08);
}

.inline-evidence {
margin-top: 7px;
  display: flex;
  gap: 7px;
  flex-wrap: wrap;
}

.inline-evidence img {
width: var(--fact-card-image-w);
  height: var(--fact-card-image-h);
  object-fit: cover;
  object-position: center center;
  image-rendering: auto !important;
  opacity: 1 !important;
  filter: none !important;
  mix-blend-mode: normal !important;
  border: 1px solid var(--evidence-thumb-border);
  background: var(--evidence-thumb-bg);
  cursor: zoom-in;
  box-shadow: none;
  transition: border-color 120ms ease;
}

.inline-evidence img:hover,
.inline-evidence img:focus-visible {
  border-color: var(--evidence-thumb-border-hover);
  filter: none !important;
  box-shadow: none;
}

.dossier-list {
display: flex;
  flex-direction: column;
  gap: 10px;
}

.section-title {
margin: 12px 0 2px;
  padding: 5px 8px;
  color: var(--c-text);
  border: 1px solid rgba(46, 155, 255, 0.18);
  background: rgba(12, 28, 49, 0.58);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.card {
position: relative;
  display: block;
  width: 100%;
  text-align: left;
  color: var(--c-text);
  background: linear-gradient(180deg, rgba(12, 28, 49, 0.94), rgba(4, 10, 18, 0.93));
  border: 1px solid var(--accent, var(--c-cyan));
  border-left-width: 5px;
  padding: 10px 11px;
  box-shadow: inset 0 0 18px rgba(0, 200, 255, 0.035);
}

.card:hover,
.card:focus-visible {
outline: none;
  border-color: var(--accent, var(--c-cyan));
  box-shadow: 0 0 18px rgba(0, 200, 255, 0.22), inset 0 0 20px rgba(255,255,255,0.025);
}

.card--selected {
border-color: var(--c-white);
  box-shadow: 0 0 18px rgba(0, 200, 255, 0.32);
}

.card--inactive {
opacity: 0.62; filter: saturate(0.65);
}

.card--new::after,
.card--used::after {
content: attr(data-badge);
  position: absolute;
  top: 9px;
  right: 10px;
  color: var(--badge-color, var(--c-yellow));
  font-size: 10px;
  font-weight: 900;
}

.card__type {
color: var(--accent, var(--c-cyan)); font-size: 10px; font-weight: 900; text-transform: uppercase; padding-right: 72px;
}

.card__title {
margin-top: 5px; color: var(--c-white); font-size: 14px; font-weight: 900; line-height: 1.25;
}

.card__body {
margin-top: 8px; color: var(--c-muted); font-size: 11.5px; line-height: 1.42;
}

.card__tags {
margin-top: 8px; color: var(--accent, var(--c-cyan)); font-size: 10px; font-weight: 800; opacity: 0.9;
}

.card__hint {
margin-top: 6px; color: var(--c-text); font-size: 10px; opacity: 0.82;
}

.card__image {
width: 92px;
  height: 58px;
  float: right;
  margin: 2px 0 8px 9px;
  object-fit: cover;
  border: 1px solid var(--accent, var(--c-cyan));
  background: var(--c-black);
}

.card__image-fallback {
  display: grid;
  place-items: center;
  width: 92px;
  height: 58px;
  float: right;
  margin: 2px 0 8px 9px;
  border: 1px solid var(--accent, var(--c-cyan));
  background: rgba(0, 6, 12, 0.92);
  color: var(--accent, var(--c-cyan));
}

.card__image-fallback-icon {
  width: 24px;
  height: 24px;
}

.selected-strip,
.action-strip {
border-top: 1px solid rgba(46, 155, 255, 0.18);
  background: rgba(3, 7, 14, 0.42);
  padding: 10px 12px;
}

.selected-strip {
display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
}

.selected-cards {
display: flex;
  gap: 8px;
  overflow: auto;
  min-height: 54px;
}

.selected-mini {
min-width: 170px;
  max-width: 220px;
  border: 1px solid rgba(0, 200, 255, 0.32);
  background: rgba(8, 20, 33, 0.88);
  padding: 7px 9px;
  color: var(--c-text);
}

.selected-mini__type {
color: var(--accent, var(--c-cyan)); font-size: 9px; font-weight: 900;
}

.selected-mini__title {
margin-top: 4px; font-size: 11px; font-weight: 900; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.action-strip {
display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.last-effect {
margin-left: auto;
  max-width: 42%;
  color: var(--c-muted);
  font-size: 10px;
  line-height: 1.35;
}

.status-block {
margin-bottom: 12px;
  border: 1px solid rgba(46, 155, 255, 0.16);
  background: rgba(3, 7, 14, 0.32);
  padding: 10px;
}

.status-block__title {
color: var(--c-blue);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.stat-row {
display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  color: var(--c-muted);
  font-size: 11px;
  padding: 3px 0;
}

.stat-row strong {
color: var(--c-text);
}

.progressbar {
height: 8px;
  border: 1px solid rgba(46, 155, 255, 0.22);
  background: rgba(0, 0, 0, 0.28);
  margin-top: 5px;
}

.progressbar__fill {
height: 100%;
  width: var(--value, 0%);
  background: linear-gradient(90deg, var(--accent, var(--c-cyan)), rgba(244, 251, 255, 0.88));
  box-shadow: 0 0 12px var(--accent, var(--c-cyan));
}

.map-tools {
display: flex; align-items: center; gap: 8px; margin-bottom: 10px; flex-wrap: wrap;
}

.map-view {
position: relative;
  height: min(62vh, 560px);
  min-height: 360px;
  overflow: auto;
  border: 1px solid rgba(46, 155, 255, 0.22);
  background:
    linear-gradient(rgba(0, 200, 255, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 200, 255, 0.035) 1px, transparent 1px),
    rgba(3, 7, 14, 0.62);
  background-size: 36px 36px;
  padding: 18px;
}

.map-view--fullscreen {
height: calc(100vh - 16px);
}

.map-board {
display: grid;
  grid-template-columns: repeat(var(--cols, 4), 220px);
  gap: 20px 26px;
  align-items: start;
  min-width: max-content;
}

.map-col {
display: flex;
  flex-direction: column;
  gap: 14px;
}

.map-col__title {
color: var(--c-muted);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding-bottom: 5px;
  border-bottom: 1px solid rgba(46, 155, 255, 0.22);
}

.map-node {
text-align: left;
  min-height: 66px;
  border: 1px solid var(--accent, var(--c-cyan));
  border-left-width: 4px;
  background: rgba(9, 19, 31, 0.94);
  color: var(--c-text);
  padding: 8px;
}

.map-node--selected {
border-color: var(--c-white); box-shadow: 0 0 18px rgba(0, 200, 255, 0.30);
}

.map-node--closed {
opacity: 0.68;
}

.map-node--hidden {
border-style: dashed; color: var(--c-dim);
}

.map-node__type {
color: var(--accent, var(--c-cyan)); font-size: 9px; font-weight: 900; text-transform: uppercase;
}

.map-node__title {
margin-top: 5px; font-size: 12px; font-weight: 900; line-height: 1.24;
}

.protocol-grid,
.shop-grid {
display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}

.protocol-card {
border: 1px solid rgba(198, 76, 255, 0.32);
  background: rgba(14, 11, 34, 0.7);
  padding: 12px;
}

.protocol-card__name {
color: var(--c-purple); font-weight: 900; margin-bottom: 7px;
}

.protocol-card__desc {
color: var(--c-muted); font-size: 11px; line-height: 1.42; margin-bottom: 9px;
}

.protocol-card__cost {
color: var(--c-yellow); font-size: 11px; font-weight: 900;
}

.modal-backdrop {
position: fixed;
  inset: 0;
  z-index: 2000 !important;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(1, 4, 10, 0.78);
  backdrop-filter: blur(3px);
}

.modal-card {
width: min(940px, calc(100vw - 40px));
  max-height: calc(100vh - 40px);
  overflow: auto;
  padding: 18px;
}

.modal-card--image {
width: min(1100px, calc(100vw - 40px));
}

.modal-title {
color: var(--c-red); font-size: 18px; font-weight: 900; margin-bottom: 8px;
}

.modal-text {
color: var(--c-muted); line-height: 1.45; font-size: 12px;
}

.modal-actions {
display: flex; gap: 8px; margin-top: 14px; flex-wrap: wrap; justify-content: flex-end;
}

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

.modal-card--report {
position: relative;
  z-index: 1;
  width: min(1180px, calc(100vw - 28px));
  padding: 18px;
  background: rgba(4, 13, 20, 0.98);
  border: 1px solid rgba(89, 198, 255, 0.30);
}

.report-close {
position: absolute;
  top: 12px;
  right: 12px;
  width: 28px;
  height: 28px;
  border: 1px solid var(--c-red);
  background: rgba(18, 28, 28, 0.78);
  color: var(--c-red);
  font: 900 13px/1 var(--font-ui);
  cursor: pointer;
}

.report-subject {
margin: 10px 0 6px;
  color: var(--c-text);
  font-size: 16px;
  font-weight: 900;
}

.report-forced {
margin-top: 8px;
  color: var(--c-yellow);
  font-size: 12px;
  font-weight: 900;
}

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

.report-modal-grid--evidence {
margin-top: 18px;
}

.report-modal-grid--summary {
margin-top: 14px;
}

.report-evidence-panel,
.report-requirements,
.report-readiness {
min-height: 150px;
  max-height: 150px;
  margin-bottom: 0;
  padding: 14px 12px;
  overflow: hidden;
}

.report-evidence-panel__title {
margin-bottom: 12px;
}

.report-evidence-panel__body {
min-height: 108px;
  max-height: 108px;
  overflow: auto;
  padding: 0 8px 0 0;
  scrollbar-width: thin;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.report-fact {
padding: 0 0 12px;
  color: var(--c-muted);
}

.report-fact + .report-fact {
padding-top: 12px;
  border-top: 1px solid rgba(82, 104, 120, 0.22);
}

.report-fact__head {
display: flex;
  align-items: center;
  gap: 8px;
  color: var(--accent, var(--c-cyan));
  font-size: 12px;
  font-weight: 900;
}

.report-fact__icon {
width: 15px;
  height: 15px;
  flex: 0 0 auto;
}

.report-fact__body {
margin: 6px 0 0 23px;
  color: var(--c-muted);
  font-size: 11px;
  line-height: 1.45;
}

.report-empty {
color: var(--c-yellow);
  font-size: 12px;
  font-weight: 900;
}

.report-requirements,
.report-readiness {
padding: 14px 12px;
  overflow: auto;
  scrollbar-width: thin;
}

.report-readiness__score {
margin-bottom: 12px;
  color: var(--c-yellow);
  font-size: 17px;
  font-weight: 900;
}

.report-verdict-title {
display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-top: 34px;
  color: var(--c-red);
  font-size: 22px;
  font-weight: 900;
  text-transform: uppercase;
}

.report-verdict-title__icon {
width: 26px;
  height: 26px;
}

.report-verdict-row {
display: grid;
  grid-template-columns: repeat(2, minmax(0, 246px));
  justify-content: center;
  gap: 20px;
  margin-top: 14px;
}

.report-choice {
min-height: 56px;
  width: 100%;
  justify-content: center;
  font-size: 14px;
}

.report-choice .ui-icon {
width: 20px;
  height: 20px;
}

.report-choice--human {
background: transparent;
  border-color: color-mix(in srgb, var(--c-green) 72%, transparent);
  color: var(--c-green);
}

.report-choice--android {
background: transparent;
  border-color: color-mix(in srgb, var(--c-red) 72%, transparent);
  color: var(--c-red);
}

.preview-image {
width: 100%;
  max-height: 64vh;
  object-fit: contain;
  background: var(--c-black);
  border: 1px solid rgba(0, 200, 255, 0.08);
}

.modal-card--fact-detail {
  border-color: var(--fact-card-border);
  box-shadow:
    0 0 26px color-mix(in srgb, var(--accent, var(--c-cyan)) 18%, transparent),
    inset 0 0 22px color-mix(in srgb, var(--accent, var(--c-cyan)) 8%, transparent);
}

.modal-title--fact-detail {
  display: flex;
  align-items: center;
  gap: 9px;
  color: var(--c-white);
}

.modal-title__icon {
  width: 22px;
  height: 22px;
  color: var(--accent, var(--c-cyan));
}

.fact-detail__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 10px;
  color: var(--accent, var(--c-cyan));
  font: 800 10px/1.2 var(--font-ui);
  text-transform: uppercase;
}

.fact-detail__meta span,
.fact-detail__tags span {
  padding: 3px 6px;
  border: 1px solid color-mix(in srgb, var(--accent, var(--c-cyan)) 38%, transparent);
  background: color-mix(in srgb, var(--accent, var(--c-cyan)) 9%, rgba(0, 0, 0, 0.36));
}

.fact-detail__caption {
  margin-top: 10px;
  color: var(--c-text);
  font: 800 12px/1.4 var(--font-ui);
}

.fact-detail__body {
  margin-top: 10px;
  color: var(--c-muted);
  font: 12px/1.55 var(--font-ui);
  white-space: pre-wrap;
}

.fact-detail__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 12px;
  color: var(--accent, var(--c-cyan));
  font: 800 10px/1.2 var(--font-ui);
}

.empty-state {
color: var(--c-dim);
  border: 1px dashed rgba(82, 104, 120, 0.35);
  padding: 16px;
  background: rgba(3, 7, 14, 0.28);
  font-size: 12px;
  line-height: 1.45;
}

.help-list {
margin: 0;
  padding-left: 18px;
  color: var(--c-muted);
  line-height: 1.55;
  font-size: 12px;
}

.toast-error {
margin: 24px;
  padding: 18px 20px;
  max-width: 960px;
  white-space: pre-wrap;
  line-height: 1.45;
  color: var(--c-text);
  border-color: var(--c-red);
  box-shadow: 0 0 24px rgba(255, 51, 87, 0.25);
}

@media (max-width: 1320px) {
  .interrogation-app { min-width: 960px; }
  .layout { grid-template-columns: 320px minmax(360px, 1fr) 310px; }
  .topbar { grid-template-columns: 1fr; }
  .topbar__actions { justify-content: flex-start; }
  .last-effect { max-width: 100%; width: 100%; margin-left: 0; }
}

/* v69 polish pass: game-like HUD, chat-scene bubbles, action slots and graph map. */

.app-shell {
grid-template-rows: 76px minmax(0, 1fr);
  gap: 6px;
}

.topbar {
position: relative;
  display: grid;
  grid-template-columns: minmax(470px, 1fr) minmax(260px, 0.7fr) minmax(520px, 1fr);
  gap: 10px;
  align-items: stretch;
  padding: 8px 12px;
  min-height: 76px;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(0, 200, 255, 0.08), transparent 24%, transparent 72%, rgba(255, 51, 87, 0.06)),
    linear-gradient(180deg, rgba(7, 18, 31, 0.98), rgba(2, 8, 16, 0.96));
  border-color: rgba(0, 200, 255, 0.28);
}

.topbar__scanline {
position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(0, 200, 255, 0.7), rgba(255, 51, 87, 0.45), transparent);
  opacity: 0.75;
}

.topbar__left,
.topbar__center,
.topbar__right {
min-width: 0;
  position: relative;
  z-index: 1;
}

.topbar__center {
display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 2px;
}

.topbar__right {
display: grid;
  grid-template-rows: auto 1fr;
  justify-items: end;
  align-content: start;
  gap: 5px;
}

.topbar__actions {
width: 100%;
  display: grid;
  grid-template-columns: repeat(6, minmax(76px, 1fr));
  gap: 8px;
  align-items: stretch;
  justify-content: stretch;
}

.app-title {
font-size: 14px;
  line-height: 1;
  letter-spacing: 0.18em;
}

.app-dept {
color: var(--c-blue);
  font-size: 15px;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-align: center;
  text-shadow: 0 0 12px rgba(46, 155, 255, 0.55);
}

.user-badge {
color: var(--c-blue);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-shadow: 0 0 10px rgba(46, 155, 255, 0.55);
}

.case-title {
margin-top: 8px;
  font-size: clamp(14px, 1vw, 18px);
  letter-spacing: 0.03em;
}

.case-title span {
color: var(--c-muted);
}

.case-meta--meters {
margin-top: 6px;
  display: flex;
  align-items: center;
  gap: 10px;
  overflow: hidden;
}

.top-stat,
.top-meter {
display: inline-flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
  color: var(--c-muted);
  font-size: 11px;
}

.top-stat strong,
.top-meter strong {
color: var(--c-yellow);
  font-weight: 900;
}

.pip-row {
display: inline-flex;
  gap: 2px;
}

.pip {
width: 9px;
  height: 9px;
  border: 1px solid rgba(255, 191, 46, 0.28);
  background: rgba(0, 0, 0, 0.28);
  box-shadow: inset 0 0 4px rgba(255, 191, 46, 0.08);
}

.pip--on {
background: var(--accent, var(--c-yellow));
  box-shadow: 0 0 8px var(--accent, var(--c-yellow));
}

.layout {
grid-template-columns: minmax(305px, 360px) minmax(520px, 1fr) minmax(310px, 360px);
  gap: 8px;
}

.panel,
.topbar {
clip-path: polygon(0 0, calc(100% - 8px) 0, 100% 8px, 100% 100%, 8px 100%, 0 calc(100% - 8px));
}

.tab-row {
display: grid;
  grid-template-columns: repeat(4, minmax(120px, 1fr));
  gap: 8px;
  padding: 10px 12px 8px;
}

.tab-btn {
min-height: 36px;
  text-align: center;
}

.center-content {
overflow: hidden;
  display: flex;
  flex-direction: column;
}

.chat-scene {
flex: 1;
  min-height: 360px;
  margin-bottom: 0;
  border-color: rgba(0, 200, 255, 0.32);
  background: #03070e;
}

.chat-scene__bg {
opacity: 0.9;
  background-position: center center;
}

.chat-scene__shade {
background:
    radial-gradient(circle at 51% 76%, rgba(255, 51, 87, 0.10), transparent 30%),
    linear-gradient(90deg, rgba(0, 6, 14, 0.90), rgba(0, 6, 14, 0.18) 40%, rgba(0, 6, 14, 0.68)),
    linear-gradient(0deg, rgba(0, 4, 10, 0.92), transparent 44%, rgba(0, 4, 10, 0.42));
}

.chat-scene__portrait {
left: 50%;
  right: auto;
  transform: translateX(-50%);
  width: min(42%, 420px);
  max-height: 96%;
  opacity: 0.98;
}

.chat-scene__meta,
.emotion-grid {
display: none;
}

.transcript {
position: absolute;
  inset: 14px 18px 16px 18px;
  z-index: 4;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 8px;
  max-height: none;
  overflow: auto;
  padding: 4px 4px 4px 0;
  scrollbar-width: thin;
  scrollbar-color: rgba(0, 200, 255, 0.28) rgba(2, 8, 16, 0.58);
}

.chat-bubble {
width: min(520px, 72%);
  border-color: rgba(0, 200, 255, 0.32);
  background: rgba(3, 9, 18, 0.78);
  backdrop-filter: blur(1px);
  box-shadow:
    inset 0 0 18px rgba(0, 200, 255, 0.05),
    0 0 18px rgba(0, 0, 0, 0.32);
}

.chat-bubble--suspect {
align-self: flex-start;
  margin-left: 0;
  margin-top: 2px;
  background: rgba(16, 2, 28, 0.78);
  border-color: rgba(198, 76, 255, 0.48);
}

.chat-bubble--interrogator,
.chat-bubble--you,
.chat-bubble--player {
align-self: flex-end;
  background: rgba(2, 20, 32, 0.82);
  border-color: rgba(0, 200, 255, 0.50);
}

.chat-bubble--system {
align-self: flex-start;
  width: min(640px, 76%);
  background: rgba(3, 9, 18, 0.72);
}

.chat-bubble__who {
font-size: 11px;
}

.chat-bubble__text {
font-size: 13px; line-height: 1.45;
}

.action-builder {
border-top: 1px solid rgba(46, 155, 255, 0.24);
  background: linear-gradient(180deg, rgba(3, 7, 14, 0.58), rgba(5, 12, 22, 0.86));
  padding: 10px 12px 12px;
}

.action-builder__head {
display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin-bottom: 8px;
}

.action-builder__label {
color: var(--c-red);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.action-builder__hint {
margin-top: 3px;
  color: var(--c-muted);
  font-size: 10px;
}

.action-builder__tools {
display: flex;
  gap: 8px;
  align-items: center;
}

.action-slots {
display: grid;
  grid-template-columns: repeat(var(--slot-count, 2), minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 12px;
}

.action-slot--empty {
min-height: 118px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 8px;
  border: 1px dashed rgba(46, 155, 255, 0.24);
  background: rgba(4, 11, 20, 0.66);
  color: var(--c-dim);
}

.action-slot__plus {
font-size: 24px;
  color: rgba(0, 200, 255, 0.45);
}

.action-slot__label {
font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.card--action-slot {
min-height: 118px;
  max-height: 168px;
  overflow: hidden;
  border-left-width: 4px;
}

.card--action-slot .card__body {
max-height: 42px;
  overflow: hidden;
}

.card__remove {
position: absolute;
  top: 7px;
  right: 9px;
  color: var(--c-red);
  font-weight: 900;
  font-size: 13px;
}

.action-strip {
display: grid;
  grid-template-columns: repeat(5, minmax(130px, 1fr));
  align-items: stretch;
  gap: 10px;
  padding: 0;
  border-top: 0;
  background: transparent;
}

.action-strip .ui-btn {
min-height: 44px;
  font-size: 12px;
  justify-content: center;
  text-align: center;
}

.last-effect {
margin-top: 8px;
  margin-left: 0;
  max-width: none;
  min-height: 26px;
  padding: 6px 8px;
  border: 1px solid rgba(46, 155, 255, 0.14);
  background: rgba(2, 8, 16, 0.44);
}

.map-view {
height: min(66vh, 620px);
  min-height: 430px;
  padding: 0;
  overflow: auto;
  border-color: rgba(0, 200, 255, 0.30);
}

.map-tools--overlay {
position: sticky;
  top: 0;
  z-index: 8;
  margin: 0;
  padding: 10px;
  background: linear-gradient(180deg, rgba(3, 7, 14, 0.92), rgba(3, 7, 14, 0.40));
  backdrop-filter: blur(2px);
}

.case-graph {
position: relative;
  width: var(--graph-w);
  height: var(--graph-h);
  min-width: 100%;
  min-height: 100%;
  background:
    linear-gradient(rgba(0, 200, 255, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 200, 255, 0.035) 1px, transparent 1px),
    radial-gradient(circle at 50% 10%, rgba(0, 200, 255, 0.10), transparent 38%),
    rgba(3, 7, 14, 0.70);
  background-size: 36px 36px, 36px 36px, auto, auto;
}

.case-graph__edges {
position: absolute;
  inset: 0;
  overflow: visible;
  color: var(--c-cyan);
  pointer-events: none;
}

.case-graph__edge {
fill: none;
  stroke: var(--edge, var(--c-cyan));
  stroke-width: 2;
  stroke-opacity: 0.55;
  filter: drop-shadow(0 0 5px var(--edge, var(--c-cyan)));
}

.map-node {
position: absolute;
  text-align: left;
  border-left-width: 4px;
  box-shadow: 0 0 14px rgba(0, 0, 0, 0.35), inset 0 0 15px rgba(0, 200, 255, 0.035);
}

.map-node__body {
margin-top: 6px;
  color: var(--c-muted);
  font-size: 10px;
  line-height: 1.35;
  max-height: 34px;
  overflow: hidden;
}

.panel__body,
.center-content,
.transcript,
.map-view,
.selected-cards,
.modal-card {
scrollbar-width: thin;
  scrollbar-color: rgba(0, 200, 255, 0.35) rgba(2, 8, 16, 0.65);
}

.panel__body::-webkit-scrollbar,
.center-content::-webkit-scrollbar,
.transcript::-webkit-scrollbar,
.map-view::-webkit-scrollbar,
.selected-cards::-webkit-scrollbar,
.modal-card::-webkit-scrollbar {
width: 8px; height: 8px;
}

.panel__body::-webkit-scrollbar-track,
.center-content::-webkit-scrollbar-track,
.transcript::-webkit-scrollbar-track,
.map-view::-webkit-scrollbar-track,
.selected-cards::-webkit-scrollbar-track,
.modal-card::-webkit-scrollbar-track {
background: rgba(2, 8, 16, 0.75);
}

.panel__body::-webkit-scrollbar-thumb,
.center-content::-webkit-scrollbar-thumb,
.transcript::-webkit-scrollbar-thumb,
.map-view::-webkit-scrollbar-thumb,
.selected-cards::-webkit-scrollbar-thumb,
.modal-card::-webkit-scrollbar-thumb {
background: rgba(0, 200, 255, 0.32);
  border: 1px solid rgba(0, 200, 255, 0.18);
}

@media (max-width: 1400px) {
  .topbar { grid-template-columns: minmax(420px, 1fr) 220px minmax(440px, 1fr); }
  .topbar__actions { grid-template-columns: repeat(3, minmax(90px, 1fr)); }
  .layout { grid-template-columns: 300px minmax(460px, 1fr) 300px; }
  .action-strip { grid-template-columns: repeat(3, minmax(130px, 1fr)); }
  .chat-bubble { width: min(500px, 82%); }
}

@media (max-width: 1100px) {
  .interrogation-app { min-width: 0; overflow: auto; }
  .app-shell { min-width: 960px; }
}

/* v70 refinement pass: readable chat scroll, flatter panels, fuller graph map, cleaner header. */

.interrogation-app {
position: relative;
}

.panel,
.topbar {
clip-path: none;
}

.app-shell {
grid-template-rows: 72px minmax(0, 1fr);
}

.topbar {
min-height: 72px;
  grid-template-columns: minmax(430px, 1fr) minmax(300px, 0.78fr) minmax(520px, 1fr);
  padding: 9px 12px;
}

.case-title--main,
.case-title {
margin-top: 0;
  font-size: clamp(16px, 1.12vw, 19px);
  line-height: 1.2;
}

.case-meta--meters {
margin-top: 9px;
}

.app-title {
display: none;
}

.app-version-badge {
position: absolute;
  left: 12px;
  bottom: 8px;
  z-index: 20;
  color: rgba(0, 200, 255, 0.58);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.12em;
  pointer-events: none;
  text-shadow: 0 0 8px rgba(0, 200, 255, 0.35);
}

.chat-scene__bg {
opacity: 1;
  filter: none;
}

.chat-scene__shade {
background:
    radial-gradient(circle at 52% 72%, rgba(255, 51, 87, 0.06), transparent 34%),
    linear-gradient(90deg, rgba(0, 6, 14, 0.20), rgba(0, 6, 14, 0.04) 46%, rgba(0, 6, 14, 0.16)),
    linear-gradient(0deg, rgba(0, 4, 10, 0.18), transparent 44%, rgba(0, 4, 10, 0.05));
}

.chat-scene__portrait {
opacity: 1;
  filter: none;
}

.transcript {
justify-content: flex-start;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding: 4px 10px 16px 0;
}

.transcript::before {
content: "";
  flex: 0 0 auto;
  height: 0;
}

.chat-bubble:first-child {
margin-top: auto;
}

.map-tools--overlay {
display: flex;
  align-items: center;
  gap: 8px;
}

.map-zoom-btn {
min-width: 38px;
  padding-inline: 0;
  font-size: 14px;
}

.map-zoom-label {
min-width: 46px;
  color: var(--c-cyan);
  font-size: 11px;
  font-weight: 900;
  text-align: center;
  text-shadow: 0 0 8px rgba(0, 200, 255, 0.45);
}

.case-graph {
position: relative;
  min-width: 100%;
  min-height: 100%;
  overflow: visible;
  background:
    linear-gradient(rgba(0, 200, 255, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 200, 255, 0.035) 1px, transparent 1px),
    radial-gradient(circle at 50% 10%, rgba(0, 200, 255, 0.10), transparent 38%),
    rgba(3, 7, 14, 0.70);
  background-size: 36px 36px, 36px 36px, auto, auto;
}

.case-graph__canvas {
position: relative;
  transform-origin: 0 0;
  overflow: visible;
}

.map-node--hidden {
opacity: 0.48;
  background: rgba(4, 10, 18, 0.86);
  border-style: dashed;
  filter: saturate(0.45);
}

.map-node--hidden .map-node__title {
color: rgba(138, 167, 189, 0.72);
  letter-spacing: 0.12em;
}

.map-node--hidden .map-node__type {
color: rgba(46, 155, 255, 0.62);
}

.case-graph__edge {
stroke-opacity: 0.42;
}

@media (max-width: 1400px) {
  .topbar { grid-template-columns: minmax(360px, 1fr) 190px minmax(410px, 1fr); }
}

.case-graph__edge--hidden {
stroke-dasharray: 7 8;
  stroke-opacity: 0.20;
  filter: none;
}

.case-graph__edge--revealed {
stroke-opacity: 0.64;
}

/* v71 terminal-flat pass: no panel/button gradients, fixed action cards, detailed map toggle. */


#wrap,
.interrogation-app {
background: #03070e;
}

.interrogation-app {
background-image: none;
}

.topbar,
.panel,
.modal-card,
.toast-error,
.status-block,
.protocol-card,
.empty-state,
.section-title,
.selected-strip,
.action-strip,
.action-builder,
.last-effect,
.metric-pill {
background: rgba(5, 13, 22, 0.94);
  background-image: none;
}

.topbar,
.panel,
.modal-card,
.toast-error {
box-shadow:
    inset 0 0 18px rgba(0, 200, 255, 0.035),
    0 0 18px rgba(0, 0, 0, 0.42),
    0 0 14px rgba(0, 200, 255, 0.10);
}

.ui-btn,
.tab-btn,
.icon-btn,
.ui-btn--active,
.tab-btn--active,
.card,
.selected-mini,
.action-slot--empty,
.map-node,
.map-tools--overlay {
background: rgba(7, 16, 27, 0.94);
  background-image: none;
}

.ui-btn:hover,
.tab-btn:hover,
.icon-btn:hover,
.ui-btn:focus-visible,
.tab-btn:focus-visible,
.icon-btn:focus-visible,
.card:hover,
.card:focus-visible {
background: rgba(8, 20, 32, 0.98);
  background-image: none;
}

.progressbar__fill {
background: var(--accent, var(--c-cyan));
  background-image: none;
}

.topbar__scanline {
background: rgba(0, 200, 255, 0.42);
  box-shadow: 0 0 12px rgba(0, 200, 255, 0.32);
}

/* The image and cutout must keep equal brightness; readability comes from the bubbles, not a dark overlay. */

.chat-scene__shade {
background: transparent;
  background-image: none;
  pointer-events: none;
}

.chat-bubble {
backdrop-filter: none;
}

.chat-bubble--suspect,
.chat-bubble--interrogator,
.chat-bubble--you,
.chat-bubble--player,
.chat-bubble--system,
.chat-bubble--apparatus,
.chat-bubble--warning,
.chat-bubble--error {
background-image: none;
}

/* Dossier cards need breathing room between individual facts. */

.dossier-group {
display: flex;
  flex-direction: column;
  gap: 10px;
}

.dossier-group + .dossier-group {
margin-top: 12px;
}

.dossier-group .section-title {
margin: 0 0 2px;
}

/* Subtle, neutral frames around evidence thumbnails. */

.card__image,
.inline-evidence img,
.preview-image {
border-color: rgba(235, 245, 255, 0.08);
  box-shadow: 0 0 5px rgba(235, 245, 255, 0.01);
}

/* Action builder cards should not stretch like fluid columns; they keep the same card-like width. */

.action-slots {
display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: stretch;
  gap: 12px;
  overflow-x: auto;
  padding-bottom: 4px;
}

.action-slot--empty,
.card--action-slot {
flex: 0 0 320px;
  width: 320px;
  max-width: 320px;
}

.card--action-slot {
min-height: 132px;
  max-height: 176px;
}

.card--action-slot .card__title {
max-width: calc(100% - 24px);
}

/* Fullscreen map fills the available shell down to the bottom edge. */

.interrogation-app:has(.map-view--fullscreen) {
height: 100%;
  padding: 8px;
}

.app-shell--fullscreen-map,
.layout--fullscreen {
height: 100%;
  min-height: 0;
}

.map-view--fullscreen {
height: 100%;
  min-height: 0;
}

.map-view {
background: rgba(3, 7, 14, 0.72);
  background-image: none;
}

.case-graph {
background: rgba(3, 7, 14, 0.78);
  background-image: none;
}

.map-tools--overlay {
backdrop-filter: none;
  border-bottom: 1px solid rgba(0, 200, 255, 0.18);
}

.map-node--full-card {
min-height: 164px;
  padding: 10px 11px;
}

.map-node--full-card .card__body {
max-height: 52px;
  overflow: hidden;
}

.map-node--full-card .card__tags {
white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Cleaner header: keep the functional HUD row, hide decorative/top-line labels. */

.topbar {
grid-template-columns: minmax(520px, 1fr) minmax(520px, 1fr);
}

.topbar__center,
.user-badge {
display: none;
}

.topbar__right {
grid-column: 2;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

.topbar__actions {
max-width: 720px;
}

@media (max-width: 1400px) {
  .topbar { grid-template-columns: minmax(420px, 1fr) minmax(420px, 1fr); }
  .action-slot--empty,
  .card--action-slot { flex-basis: 300px; width: 300px; max-width: 300px; }
}

/* v72 interaction/layout pass: verdict on status panel, hidden header tools, red selection, cleaner map. */

.topbar {
overflow: visible;
  grid-template-columns: minmax(430px, 1fr) minmax(300px, 0.78fr) minmax(210px, 0.34fr);
}

.topbar__right {
position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: flex-start;
  overflow: visible;
}

.topbar__user-line {
display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  width: 100%;
}

.topbar__gear {
min-width: 34px;
  width: 34px;
  height: 30px;
  padding: 0;
  font-size: 15px;
  line-height: 1;
  color: var(--c-cyan);
}

.topbar__actions,
.topbar__actions-panel {
display: grid;
  grid-template-columns: repeat(2, minmax(120px, 1fr));
  gap: 8px;
  align-items: stretch;
  justify-content: stretch;
}

.topbar__actions-panel {
position: absolute;
  z-index: 50;
  right: 0;
  top: 36px;
  grid-template-columns: minmax(180px, 1fr);
  width: min(300px, 50vw);
  padding: 10px;
  border: 1px solid rgba(0, 200, 255, 0.32);
  background: rgba(5, 13, 22, 0.98);
  box-shadow: 0 0 24px rgba(0, 200, 255, 0.18), 0 0 36px rgba(0,0,0,0.65);
}

.ui-sfx-volume {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  min-height: 30px;
  padding: 0 10px;
  border: 1px solid rgba(0, 200, 255, 0.24);
  background: rgba(0, 18, 28, 0.46);
  color: var(--c-cyan);
  font: 700 10px/1 var(--font-ui);
  letter-spacing: 0;
}

.ui-sfx-volume input {
  width: 100%;
  accent-color: var(--c-cyan);
}

.card--selected,
.map-node--selected,
.ui-btn--active,
.tab-btn--active,
.topbar__gear.ui-btn--active,
.topbar__gear.tab-btn--active {
border-color: var(--c-red) !important;
  color: var(--c-red);
  box-shadow:
    0 0 18px rgba(255, 51, 87, 0.42),
    inset 0 0 16px rgba(255, 51, 87, 0.08) !important;
}

.card--selected {
border-left-color: var(--c-red) !important;
}

.tabs-panel {
grid-template-rows: auto minmax(0, 1fr) auto;
}

.center-content {
min-height: 0;
  padding: 8px 10px;
}

.chat-scene {
min-height: 410px;
}

.chat-scene__bg,
.chat-scene__portrait {
filter: brightness(0.78) saturate(1.08) contrast(1.02);
}

.chat-scene__shade {
background: rgba(0, 4, 10, 0.10);
}

.chat-scene__portrait {
bottom: -18px;
  width: min(40%, 420px);
  max-height: 106%;
}

.action-builder {
flex: 0 0 auto;
  padding: 10px 12px 10px;
}

.action-builder__hint,
.last-effect,
.card__remove {
display: none !important;
}

.action-slots {
margin-bottom: 10px;
}

.card--action-slot {
cursor: pointer;
}

.status-verdict-bar {
flex: 0 0 auto;
  padding: 10px 12px 12px;
  border-top: 1px solid rgba(46, 155, 255, 0.18);
  background: rgba(3, 7, 14, 0.48);
}

.verdict-btn {
min-height: 48px;
  font-size: 13px;
  letter-spacing: 0.08em;
  color: var(--c-red);
  border-color: rgba(255, 51, 87, 0.62);
  box-shadow: 0 0 18px rgba(255, 51, 87, 0.24), inset 0 0 14px rgba(255, 51, 87, 0.05);
}

.status-block:first-child .stat-row span {
color: var(--c-blue);
  font-weight: 900;
}

.map-view--fullscreen {
height: calc(100vh - 16px);
  min-height: calc(100vh - 16px);
  overflow: auto;
}

.map-view--fullscreen .case-graph {
min-height: calc(100vh - 76px);
}

.map-view--fullscreen .map-tools--overlay {
min-height: 52px;
}

.map-tools--overlay .ui-btn[data-ui="set-tab"],
.map-tools--overlay .ui-btn[data-ui="open-report"] {
display: none;
}

.map-node--selected {
border-left-color: var(--c-red) !important;
}

@media (max-width: 1400px) {
  .topbar { grid-template-columns: minmax(360px, 1fr) minmax(190px, 0.48fr) minmax(180px, 0.32fr); }
  .topbar__actions-panel { width: min(460px, 60vw); }
}

/* Keep navigation/tab active states cyan; only selected cards/nodes use the red evidence lock-on frame. */

.ui-btn--active:not(.topbar__gear),
.tab-btn--active {
color: var(--c-white);
  border-color: var(--c-cyan) !important;
  box-shadow:
    0 0 16px rgba(0, 200, 255, 0.26),
    inset 0 0 14px rgba(0, 200, 255, 0.08) !important;
}

.card--selected,
.map-node--selected {
border-color: var(--c-red) !important;
  color: var(--c-text);
  box-shadow:
    0 0 20px rgba(255, 51, 87, 0.48),
    inset 0 0 16px rgba(255, 51, 87, 0.08) !important;
}

/* v73 header/map/action refinements. */

.topbar {
grid-template-columns: minmax(520px, 1fr) minmax(220px, auto) 56px;
  align-items: center;
}

.topbar__left {
min-width: 0;
}

.topbar__right {
grid-column: 3;
  align-self: stretch;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.topbar__user-line {
width: auto;
  height: 100%;
  align-items: center;
  justify-content: flex-end;
}

.topbar__gear {
align-self: center;
  justify-self: end;
  margin: auto 0;
}

.topbar__actions-panel {
top: 52px;
  right: 0;
}

/* Yellow reputation should read as a real HUD meter, not just small pips. */

.top-meter {
color: var(--c-yellow);
  text-shadow: 0 0 8px rgba(255, 191, 46, 0.38);
}

.top-meter .pip-row {
padding: 2px 3px;
  border: 1px solid rgba(255, 191, 46, 0.30);
  box-shadow:
    0 0 12px rgba(255, 191, 46, 0.18),
    inset 0 0 10px rgba(255, 191, 46, 0.055);
}

.top-meter .pip--on {
box-shadow:
    0 0 8px rgba(255, 191, 46, 0.70),
    0 0 16px rgba(255, 191, 46, 0.26);
}

/* Keep selected cards in the action builder from resizing the whole action area. */

.action-builder {
min-height: 258px;
}

.action-slots {
min-height: 138px;
  align-items: stretch;
}

.action-slot--empty,
.card--action-slot {
height: 132px;
  min-height: 132px;
  max-height: 132px;
}

.card--action-slot .card__body {
max-height: 34px;
}

.card--action-slot .card__hint {
display: none;
}

.card--action-slot .card__image {
width: 86px;
  height: 54px;
}

/* Map cards: simple mode is compact; full mode matches dossier/action card dimensions. */

.map-node {
z-index: 3;
}

.case-graph__edges {
z-index: 1;
}

.case-graph__edge--backbone {
stroke-width: 2;
}

.case-graph__edge--cross {
stroke-width: 1.5;
  stroke-dasharray: 7 8;
  stroke-opacity: 0.20;
}

.map-node:not(.map-node--full-card) {
min-height: 56px;
  padding: 6px 8px;
}

.map-node:not(.map-node--full-card) .map-node__type {
font-size: 8px;
  letter-spacing: 0.055em;
}

.map-node:not(.map-node--full-card) .map-node__title {
margin-top: 4px;
  font-size: 11px;
  line-height: 1.15;
}

.map-node--hidden {
opacity: 0.76;
  background: rgba(4, 10, 18, 0.96);
  box-shadow:
    0 0 12px rgba(0, 0, 0, 0.72),
    inset 0 0 12px rgba(0, 200, 255, 0.02);
}

.map-node--full-card {
width: 320px;
  min-height: 142px;
  height: 142px;
  max-height: 142px;
  padding: 9px 10px;
  overflow: hidden;
}

.map-node--full-card .card__image {
width: 92px;
  height: 58px;
}

.map-node--full-card .card__title {
font-size: 13px;
}

.map-node--full-card .card__body {
max-height: 34px;
}

.map-node--full-card .card__hint {
display: none;
}

/* The right panel title already says KONTROLA ROZMOWY; avoid a duplicated row looking like a second title. */

.status-block:first-child .stat-row span {
color: var(--c-muted);
  font-weight: 700;
}

@media (max-width: 1400px) {
  .topbar {
    grid-template-columns: minmax(430px, 1fr) minmax(160px, auto) 56px;
  }
}

/* v74 dossier/chat scale pass: compact evidence cards and two-column dialogue bubbles. */

.dossier-panel .panel__body {
padding: 10px 12px;
}

.dossier-panel .dossier-list,
.dossier-panel .dossier-group {
gap: 8px;
}

.dossier-panel .dossier-group + .dossier-group {
margin-top: 10px;
}

.dossier-panel .section-title {
padding: 4px 7px;
  font-size: 10.5px;
}

.dossier-panel .card {
min-height: 102px;
  padding: 8px 9px 8px 10px;
  border-left-width: 4px;
  background: rgba(7, 16, 27, 0.94);
  background: color-mix(in srgb, var(--accent, var(--c-cyan)) 12%, rgba(7, 16, 27, 0.94));
  box-shadow:
    inset 0 0 16px color-mix(in srgb, var(--accent, var(--c-cyan)) 8%, transparent),
    0 0 10px rgba(0, 0, 0, 0.30);
}

.dossier-panel .card:hover,
.dossier-panel .card:focus-visible {
background: color-mix(in srgb, var(--accent, var(--c-cyan)) 17%, rgba(7, 16, 27, 0.96));
  box-shadow:
    0 0 14px color-mix(in srgb, var(--accent, var(--c-cyan)) 24%, transparent),
    inset 0 0 16px color-mix(in srgb, var(--accent, var(--c-cyan)) 9%, transparent);
}

.dossier-panel .card--selected {
background: color-mix(in srgb, var(--c-red) 10%, rgba(7, 16, 27, 0.96));
}

.dossier-panel .card__type {
font-size: 9px;
  line-height: 1.1;
  padding-right: 54px;
}

.dossier-panel .card__title {
margin-top: 4px;
  font-size: 13px;
  line-height: 1.18;
}

.dossier-panel .card__body {
margin-top: 6px;
  font-size: 11px;
  line-height: 1.34;
  max-height: 45px;
  overflow: hidden;
}

.dossier-panel .card__tags {
margin-top: 6px;
  font-size: 9px;
}

.dossier-panel .card__hint {
margin-top: 4px;
  font-size: 9px;
}

.dossier-panel .card__image {
width: 82px;
  height: 50px;
  margin: 2px 0 5px 8px;
  border-color: rgba(235, 245, 255, 0.22);
}

.dossier-panel .card--new::after,
.dossier-panel .card--used::after {
top: 7px;
  right: 8px;
  font-size: 9px;
}

/* Keep the portrait lane readable: bubbles live in left/right columns and avoid the center silhouette. */

.transcript {
inset: 12px 14px 14px 14px;
  gap: 7px;
}

.chat-bubble {
width: min(460px, 42%);
  max-width: 42%;
  padding: 8px 10px;
}

.chat-bubble--system,
.chat-bubble--apparatus,
.chat-bubble--warning,
.chat-bubble--error,
.chat-bubble--breakthrough,
.chat-bubble--interrogator,
.chat-bubble--you,
.chat-bubble--player {
align-self: flex-start;
  margin-left: 0;
  margin-right: auto;
}

.chat-bubble--suspect {
align-self: flex-end;
  margin-left: auto;
  margin-right: 0;
  width: min(460px, 42%);
  max-width: 42%;
}

.chat-bubble--system {
width: min(500px, 44%);
  max-width: 44%;
}

.chat-bubble__who {
font-size: 10px;
  line-height: 1.1;
}

.chat-bubble__text {
font-size: 12px;
  line-height: 1.38;
}

.inline-evidence img {
width: 58px;
  height: 40px;
}

@media (max-width: 1400px) {
  .chat-bubble,
  .chat-bubble--suspect {
    width: min(400px, 40%);
    max-width: 40%;
  }

  .chat-bubble--system {
    width: min(440px, 42%);
    max-width: 42%;
  }

  .dossier-panel .card__image {
    width: 74px;
    height: 46px;
  }
}

/* v74 compatibility fallback: use JS-provided rgba tones so old CEF builds still get card-colored backgrounds. */

.dossier-panel .card {
background: var(--card-bg, rgba(7, 16, 27, 0.94));
}

.dossier-panel .card:hover,
.dossier-panel .card:focus-visible {
background: var(--card-hover-bg, rgba(8, 20, 32, 0.98));
  box-shadow:
    0 0 14px var(--card-glow, rgba(0, 200, 255, 0.22)),
    inset 0 0 16px rgba(255, 255, 255, 0.025);
}

/* v75 polish: compact right progress panel, chat autoscroll-friendly bubbles, smaller map nodes and terminal HUD glow. */

.status-panel__body {
padding: 10px 12px;
}

.status-block {
margin-bottom: 10px;
  padding: 10px;
}

.status-block--progress-summary {
background: rgba(5, 18, 25, 0.82);
  border-color: rgba(0, 200, 255, 0.24);
}

.status-block__title--folded,
.status-bucket__head {
display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-height: 25px;
  padding: 0 0 6px;
  color: var(--c-cyan);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.065em;
  text-transform: uppercase;
}

.status-block__title--folded strong,
.status-bucket__head strong {
color: var(--c-yellow);
  font-size: 11px;
}

.status-bucket {
margin-bottom: 10px;
  padding: 8px 10px;
  border: 1px solid rgba(46, 155, 255, 0.22);
  background: rgba(5, 18, 25, 0.70);
  box-shadow: inset 3px 0 0 color-mix(in srgb, var(--accent, var(--c-cyan)) 70%, transparent);
}

.status-bucket__head {
padding: 0;
  color: var(--accent, var(--c-cyan));
}

.status-bucket__items {
margin: 7px 0 0;
  padding-left: 15px;
  color: var(--c-muted);
  font-size: 10px;
  line-height: 1.45;
}

.status-block--emotion {
margin-top: 12px;
}

.status-block--control .status-block__title {
color: var(--c-cyan);
}

.status-block--control .stat-row span {
color: var(--c-muted) !important;
  font-weight: 700 !important;
}

/* Same compact width for system/interrogator bubbles as other left-lane bubbles. */

.transcript {
scroll-behavior: auto;
}

.chat-bubble,
.chat-bubble--system,
.chat-bubble--apparatus,
.chat-bubble--warning,
.chat-bubble--error,
.chat-bubble--breakthrough,
.chat-bubble--interrogator,
.chat-bubble--you,
.chat-bubble--player,
.chat-bubble--suspect {
width: min(420px, 40%);
  max-width: 40%;
}

.chat-bubble--system {
width: min(420px, 40%);
  max-width: 40%;
}

.inline-evidence {
margin-top: 7px;
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.inline-evidence img {
flex: 0 0 auto;
}

/* Smaller graph nodes: simple is a terminal glyph, full mirrors compact cards instead of growing the whole graph. */

.map-node:not(.map-node--full-card) {
min-height: 44px !important;
  height: 44px;
  padding: 5px 7px;
}

.map-node:not(.map-node--full-card) .map-node__type {
font-size: 7px;
  line-height: 1;
}

.map-node:not(.map-node--full-card) .map-node__title {
margin-top: 3px;
  font-size: 9px;
  line-height: 1.14;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.map-node--full-card {
width: 285px !important;
  height: 112px !important;
  min-height: 112px !important;
  max-height: 112px !important;
  padding: 7px 8px;
}

.map-node--full-card .card__type {
font-size: 8px;
}

.map-node--full-card .card__title {
margin-top: 3px;
  font-size: 11px;
  line-height: 1.12;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.map-node--full-card .card__body {
margin-top: 4px;
  max-height: 28px;
  font-size: 9px;
  line-height: 1.25;
}

.map-node--full-card .card__tags {
margin-top: 4px;
  font-size: 8px;
}

.map-node--full-card .card__image {
width: 70px;
  height: 43px;
}

/* Reputation meter: no extra frame, just yellow phosphor glow. */

.top-meter {
color: var(--c-yellow) !important;
  text-shadow:
    0 0 6px rgba(255, 191, 46, 0.72),
    0 0 16px rgba(255, 191, 46, 0.28);
}

.top-meter .pip-row {
border: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
}

.top-meter .pip {
box-shadow: 0 0 4px rgba(255, 191, 46, 0.12);
}

.top-meter .pip--on {
box-shadow:
    0 0 5px rgba(255, 191, 46, 0.90),
    0 0 14px rgba(255, 191, 46, 0.55),
    0 0 24px rgba(255, 191, 46, 0.22) !important;
}

.verdict-btn:hover,
.verdict-btn:focus-visible {
color: var(--c-red) !important;
  border-color: rgba(255, 51, 87, 0.95) !important;
  box-shadow:
    0 0 12px rgba(255, 51, 87, 0.72),
    0 0 28px rgba(255, 51, 87, 0.36),
    inset 0 0 18px rgba(255, 51, 87, 0.09) !important;
  text-shadow: 0 0 10px rgba(255, 51, 87, 0.85);
}

@media (max-width: 1400px) {
  .chat-bubble,
  .chat-bubble--system,
  .chat-bubble--suspect {
    width: min(360px, 39%);
    max-width: 39%;
  }
}

/* v76 map semantics + collapsible side panels. */

.panel,
.topbar {
clip-path: none;
}

.layout--dossier-collapsed {
grid-template-columns: 38px minmax(520px, 1fr) minmax(310px, 360px);
}

.layout--status-collapsed {
grid-template-columns: minmax(305px, 360px) minmax(520px, 1fr) 38px;
}

.layout--dossier-collapsed.layout--status-collapsed {
grid-template-columns: 38px minmax(520px, 1fr) 38px;
}

.panel__title-tools {
display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  min-width: 0;
}

.panel-collapse-btn {
width: 24px;
  min-width: 24px;
  height: 24px;
  min-height: 24px;
  padding: 0;
  line-height: 1;
}

.dossier-panel--collapsed,
.status-panel--collapsed {
overflow: hidden;
  min-width: 38px;
}

.panel-collapse-rail {
width: 100%;
  height: 100%;
  border: 0;
  color: var(--c-cyan);
  background: rgba(5, 13, 22, 0.96);
  box-shadow: inset 0 0 16px rgba(0, 200, 255, 0.06);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  writing-mode: vertical-rl;
  text-orientation: mixed;
}

.panel-collapse-rail--left {
border-right: 1px solid rgba(0, 200, 255, 0.28);
}

.panel-collapse-rail--right {
border-left: 1px solid rgba(0, 200, 255, 0.28);
  transform: rotate(180deg);
}

.panel-collapse-rail:hover,
.panel-collapse-rail:focus-visible,
.panel-collapse-btn:hover,
.panel-collapse-btn:focus-visible {
color: var(--c-white);
  outline: none;
  box-shadow:
    0 0 16px rgba(0, 200, 255, 0.30),
    inset 0 0 16px rgba(0, 200, 255, 0.08);
}

/* Make reputation pips glow vertically as well as horizontally, without an extra frame. */

.top-meter .pip--on {
background: var(--c-yellow) !important;
  border-color: rgba(255, 226, 117, 0.88) !important;
  filter:
    drop-shadow(0 -4px 7px rgba(255, 191, 46, 0.34))
    drop-shadow(0 4px 7px rgba(255, 191, 46, 0.34))
    drop-shadow(0 0 11px rgba(255, 191, 46, 0.62));
  box-shadow:
    0 0 6px rgba(255, 191, 46, 0.92),
    0 0 16px rgba(255, 191, 46, 0.42),
    inset 0 0 3px rgba(255, 255, 255, 0.30) !important;
}

/* Map relation colors: both line and arrowhead use the same CSS variable. */

.case-graph__edge {
stroke: var(--edge, var(--c-cyan));
  filter: drop-shadow(0 0 4px var(--edge, var(--c-cyan)));
}

.case-graph__arrow {
fill: var(--edge, var(--c-cyan));
  stroke: none;
  opacity: 0.88;
  filter: drop-shadow(0 0 4px var(--edge, var(--c-cyan)));
}

.case-graph__edge--hidden,
.case-graph__arrow.case-graph__edge--hidden {
opacity: 0.34;
  filter: none;
}

.case-graph__edge--hidden {
stroke-dasharray: 7 8;
}

.map-node--hidden {
border-color: rgba(100, 123, 139, 0.54) !important;
  border-left-color: rgba(100, 123, 139, 0.72) !important;
  color: rgba(138, 167, 189, 0.76);
  filter: saturate(0.28);
}

.map-node--hidden .card__type,
.map-node--hidden .map-node__type,
.map-node--hidden .card__tags {
color: rgba(100, 123, 139, 0.80) !important;
}

.map-node--hidden .card__title,
.map-node--hidden .map-node__title {
color: rgba(170, 187, 199, 0.72) !important;
}

/* Full-card hidden placeholders must reserve full card height. */

.map-node--full-card.map-node--hidden {
height: 122px !important;
  min-height: 122px !important;
  max-height: 122px !important;
  padding: 9px 10px;
}

.map-node--full-card.map-node--hidden .card__body {
margin-top: 10px;
  max-height: 34px;
  font-size: 9px;
  opacity: 0.72;
}

.map-node:not(.map-node--full-card) {
width: 120px !important;
  min-height: 40px !important;
  height: 40px !important;
  padding: 4px 6px;
}

.map-node:not(.map-node--full-card) .map-node__type {
font-size: 6.5px;
}

.map-node:not(.map-node--full-card) .map-node__title {
font-size: 8.5px;
}

.map-legend {
position: sticky;
  left: 0;
  bottom: 0;
  z-index: 7;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  min-height: 34px;
  padding: 7px 10px;
  border-top: 1px solid rgba(0, 200, 255, 0.18);
  background: rgba(3, 7, 14, 0.96);
  box-shadow: 0 -6px 18px rgba(0, 0, 0, 0.36);
}

.map-legend__item {
display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--accent, var(--c-cyan));
  font-size: 9px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-shadow: 0 0 8px var(--accent, var(--c-cyan));
}

.map-legend__item i {
width: 20px;
  height: 2px;
  background: var(--accent, var(--c-cyan));
  box-shadow: 0 0 7px var(--accent, var(--c-cyan));
}

.map-legend__item--hidden i {
background: rgba(100, 123, 139, 0.70);
  box-shadow: none;
}

/* v76 action panel collapse rail and stronger terminal reputation phosphor. */

.action-builder--collapsed {
flex: 0 0 36px;
  min-height: 36px;
  height: 36px;
  padding: 0;
  overflow: hidden;
  border-top: 1px solid rgba(0, 200, 255, 0.22);
}

.panel-collapse-rail--bottom {
writing-mode: horizontal-tb;
  text-orientation: mixed;
  border-top: 1px solid rgba(0, 200, 255, 0.28);
  letter-spacing: 0.08em;
}

.top-meter .pip-row {
filter:
    drop-shadow(0 -4px 6px rgba(255, 191, 46, 0.22))
    drop-shadow(0 4px 6px rgba(255, 191, 46, 0.22));
}

.top-meter .pip--on {
box-shadow:
    0 -3px 8px rgba(255, 191, 46, 0.46),
    0 3px 8px rgba(255, 191, 46, 0.46),
    0 0 8px rgba(255, 191, 46, 0.94),
    0 0 18px rgba(255, 191, 46, 0.50),
    inset 0 0 4px rgba(255, 255, 255, 0.38) !important;
}

.case-graph__edge--backbone.case-graph__edge--revealed,
.case-graph__arrow.case-graph__edge--backbone.case-graph__edge--revealed {
opacity: 0.9;
}

.case-graph__arrow {
transform-box: fill-box;
}

/* v77: map stays underneath overlay panels, compact collapse tabs, collapsible topbar, map chat overlay. */

.app-shell--topbar-collapsed {
grid-template-rows: 38px minmax(0, 1fr);
}

.topbar--collapsed {
display: flex !important;
  align-items: center;
  justify-content: center;
  padding: 0;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  min-height: 36px;
}

.topbar-tab,
.topbar .topbar-tab {
width: max-content;
  min-width: 0;
  min-height: 30px;
  padding: 6px 18px;
  background: rgba(5, 13, 22, 0.94) !important;
  border: 1px solid rgba(46, 155, 255, 0.76) !important;
  box-shadow: 0 0 11px rgba(0, 160, 255, 0.17), inset 0 0 9px rgba(0, 200, 255, 0.04) !important;
  color: var(--c-blue) !important;
  text-align: center;
}

.topbar__collapse {
width: 28px;
  min-width: 28px;
  padding: 0;
}

.layout:has(.map-view:not(.map-view--fullscreen)) .tabs-panel,
.tabs-panel:has(.map-view:not(.map-view--fullscreen)) {
min-height: 0;
}

.tabs-panel:has(.map-view:not(.map-view--fullscreen)) .center-content {
display: flex;
  min-height: 0;
  overflow: hidden;
}

.tabs-panel:has(.map-view:not(.map-view--fullscreen)) .map-view {
flex: 1 1 auto;
  height: auto;
  min-height: 0;
  margin: 0;
}

/* Collapsed side panels are small tabs, not full-height rails. */

.dossier-panel--collapsed,
.status-panel--collapsed {
display: block !important;
  align-self: start;
  justify-self: stretch;
  width: auto;
  min-width: 0 !important;
  height: auto !important;
  min-height: 0 !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.panel-collapse-rail {
width: max-content !important;
  height: 32px !important;
  min-height: 32px !important;
  padding: 6px 12px !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
  border: 1px solid rgba(46, 155, 255, 0.66) !important;
  background: rgba(5, 13, 22, 0.96) !important;
  color: var(--c-blue) !important;
  box-shadow: 0 0 12px rgba(0, 160, 255, 0.12), inset 0 0 8px rgba(0, 200, 255, 0.04) !important;
  transform: none !important;
}

.panel-collapse-rail--right {
justify-self: end;
  margin-left: auto;
}

.panel-collapse-rail--bottom {
display: inline-flex;
  align-items: center;
  justify-content: center;
  width: max-content !important;
  margin: 0 auto;
}

.layout--dossier-collapsed {
grid-template-columns: 46px minmax(520px, 1fr) minmax(310px, 360px);
}

.layout--status-collapsed {
grid-template-columns: minmax(305px, 360px) minmax(520px, 1fr) 46px;
}

.layout--dossier-collapsed.layout--status-collapsed {
grid-template-columns: 46px minmax(520px, 1fr) 46px;
}

/* Full map screen: map is the background canvas; panels float above it. */

.app-shell--fullscreen-map {
position: relative;
  display: block;
  height: 100%;
  min-height: 0;
}

.full-map-stage {
position: relative;
  width: 100%;
  height: 100%;
  min-height: 0;
  overflow: hidden;
}

.full-map-stage__map {
position: absolute;
  inset: 0;
  z-index: 1;
}

.full-map-stage__map .map-view--fullscreen {
position: absolute;
  inset: 0;
  width: auto;
  height: auto !important;
  min-height: 0 !important;
  border: 0;
  padding: 56px 18px 38px;
  overflow: auto;
  background-color: rgba(3, 7, 14, 0.84);
}

.full-map-stage__top,
.full-map-stage__dossier,
.full-map-stage__status,
.full-map-stage__action,
.full-map-stage__chat {
position: absolute;
  z-index: 20;
  pointer-events: none;
}

.full-map-stage__top > *,
.full-map-stage__dossier > *,
.full-map-stage__status > *,
.full-map-stage__action > *,
.full-map-stage__chat > * {
pointer-events: auto;
}

.full-map-stage__top {
top: 6px;
  left: 50%;
  transform: translateX(-50%);
  width: min(760px, calc(100vw - 520px));
  display: flex;
  justify-content: center;
}

.map-header-panel {
width: 100%;
}

.map-header-panel .topbar {
height: auto;
  min-height: 58px;
  grid-template-columns: minmax(320px, 1fr) minmax(180px, 0.55fr) minmax(220px, 0.75fr);
  padding: 7px 10px;
}

.map-header-panel .case-title,
.map-header-panel .case-meta {
font-size: 10px;
}

.map-header-panel .topbar__actions-panel {
right: 0;
}

.full-map-stage__dossier {
top: 58px;
  bottom: 10px;
  left: 12px;
  width: 360px;
}

.full-map-stage__dossier .dossier-panel:not(.dossier-panel--collapsed) {
width: 100%;
  height: 100%;
}

.full-map-stage__dossier .dossier-panel--collapsed {
width: max-content;
}

.full-map-stage__status {
top: 58px;
  bottom: 10px;
  right: 12px;
  width: 350px;
}

.full-map-stage__status .status-panel:not(.status-panel--collapsed) {
width: 100%;
  height: 100%;
}

.full-map-stage__status .status-panel--collapsed {
margin-left: auto;
  width: max-content;
}

.full-map-stage__action {
left: 50%;
  bottom: 10px;
  transform: translateX(-50%);
  width: min(1040px, max(580px, calc(100vw - 780px)));
}

.full-map-stage__action .action-builder {
border: 1px solid rgba(46, 155, 255, 0.26);
  background: rgba(3, 9, 18, 0.86) !important;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.42), inset 0 0 16px rgba(0, 200, 255, 0.04);
}

.full-map-stage__action .action-builder--collapsed {
display: flex;
  align-items: center;
  justify-content: center;
  background: transparent !important;
  border: 0;
  box-shadow: none;
}

.full-map-stage__chat {
top: 44px;
  left: 50%;
  transform: translateX(-50%);
  width: min(780px, calc(100vw - 760px));
}

.topbar-tab--chat {
margin-top: 2px;
}

.map-chat-overlay {
height: min(44vh, 430px);
  width: 100%;
  background: rgba(3, 9, 18, 0.78) !important;
  border-color: rgba(0, 200, 255, 0.34) !important;
  box-shadow: 0 0 24px rgba(0, 0, 0, 0.40), inset 0 0 22px rgba(0, 200, 255, 0.04) !important;
}

.map-chat-overlay__head {
padding: 8px 10px;
}

.map-chat-overlay__body {
padding: 10px 12px;
  overflow: auto;
}

.map-chat-overlay .transcript {
position: static !important;
  inset: auto !important;
  max-height: none !important;
  height: auto !important;
  overflow: visible !important;
  justify-content: flex-start !important;
  padding: 0 !important;
}

.map-chat-overlay .chat-bubble {
width: min(460px, 48%) !important;
  max-width: 48% !important;
}

.map-chat-overlay .inline-evidence img {
width: 60px;
  height: 38px;
}

.full-map-stage__map .map-tools--overlay {
position: sticky;
  top: 0;
  left: 0;
  z-index: 8;
  width: max-content;
  margin: 0 0 10px 0;
  background: rgba(3, 7, 14, 0.74);
  border: 1px solid rgba(0, 200, 255, 0.18);
  padding: 6px;
}

.full-map-stage__map .map-legend {
position: sticky;
  bottom: 0;
  z-index: 8;
}

/* Cleaner reputation glow: like the Obrona progress bar, with one soft meter aura instead of pip explosions. */

.top-meter {
text-shadow: none !important;
}

.top-meter .pip-row {
position: relative;
  gap: 2px;
  filter: none !important;
  box-shadow:
    0 0 5px rgba(255, 191, 46, 0.56),
    0 0 11px rgba(255, 191, 46, 0.30),
    0 0 20px rgba(255, 191, 46, 0.14) !important;
}

.top-meter .pip {
background: rgba(255, 191, 46, 0.12) !important;
  border-color: rgba(255, 191, 46, 0.55) !important;
  filter: none !important;
  box-shadow: none !important;
}

.top-meter .pip--on {
background: #ffd457 !important;
  border-color: rgba(255, 234, 153, 0.86) !important;
  box-shadow:
    inset 0 0 3px rgba(255, 255, 255, 0.48),
    0 0 4px rgba(255, 191, 46, 0.72) !important;
}

@media (max-width: 1500px) {
  .full-map-stage__chat { width: min(660px, calc(100vw - 680px)); }
  .full-map-stage__action { width: min(920px, max(520px, calc(100vw - 720px))); }
}

.map-header-panel {
position: relative;
  display: grid;
  grid-template-columns: minmax(280px, 1fr) auto 28px;
  align-items: center;
  gap: 12px;
  width: 100%;
  min-height: 42px;
  padding: 7px 10px;
  border: 1px solid rgba(46, 155, 255, 0.42);
  background: rgba(5, 13, 22, 0.92);
  box-shadow: 0 0 18px rgba(0, 0, 0, 0.36), inset 0 0 12px rgba(0, 200, 255, 0.04);
}

.map-header-panel__title {
color: var(--c-white);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.06em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.map-header-panel__title span {
color: var(--c-muted);
  padding-inline: 5px;
}

.map-header-panel__meter {
display: flex;
  justify-content: flex-end;
}

.map-header-panel__collapse {
justify-self: end;
}

/* v78 polish: edge tabs, map overlays, compact bar meter and clearer themes. */

.top-meter--bar {
display: inline-grid;
  grid-template-columns: auto 126px auto;
  align-items: center;
  gap: 6px;
  color: var(--c-muted) !important;
  text-shadow: none !important;
}

.top-meter--bar .top-meter__label {
color: var(--c-yellow);
  font-weight: 900;
}

.top-meter--bar .top-meter__track {
display: block;
  width: 126px;
  height: 8px;
  border: 1px solid rgba(255, 191, 46, 0.35);
  background: rgba(0, 0, 0, 0.32);
  box-shadow:
    0 0 5px rgba(255, 191, 46, 0.16),
    inset 0 0 8px rgba(255, 191, 46, 0.06);
  overflow: visible;
}

.top-meter--bar .top-meter__fill {
display: block;
  width: var(--value, 0%);
  height: 100%;
  background: var(--accent, var(--c-yellow));
  box-shadow:
    0 0 8px rgba(255, 191, 46, 0.58),
    0 0 18px rgba(255, 191, 46, 0.30);
}

.map-header-panel .top-meter--bar {
grid-template-columns: auto 96px auto;
}

.map-header-panel .top-meter--bar .top-meter__track {
width: 96px;
}

/* Collapsed tabs should sit on the edge midpoint, not become full-height rails. */

.layout--dossier-collapsed,
.layout--status-collapsed,
.layout--dossier-collapsed.layout--status-collapsed {
align-items: stretch;
}

.dossier-panel--collapsed,
.status-panel--collapsed {
align-self: center !important;
  justify-self: stretch !important;
  width: 38px !important;
  min-width: 38px !important;
  height: auto !important;
  min-height: 0 !important;
}

.panel-collapse-rail {
display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 34px !important;
  max-width: 34px !important;
  height: max-content !important;
  min-height: 122px !important;
  padding: 12px 6px !important;
  writing-mode: vertical-rl !important;
  text-orientation: mixed !important;
  white-space: nowrap !important;
}

.panel-collapse-rail--left {
transform: rotate(180deg) !important;
}

.panel-collapse-rail--right {
transform: none !important;
  margin-left: auto;
}

.panel-collapse-rail--bottom {
writing-mode: horizontal-tb !important;
  width: max-content !important;
  max-width: none !important;
  min-height: 32px !important;
  height: 32px !important;
  padding: 6px 14px !important;
  transform: none !important;
}

.full-map-stage__dossier .dossier-panel--collapsed {
position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}

.full-map-stage__status .status-panel--collapsed {
position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}

.full-map-stage__dossier .dossier-panel--collapsed .panel-collapse-rail--left {
transform: rotate(180deg) !important;
}

.full-map-stage__status .status-panel--collapsed .panel-collapse-rail--right {
transform: none !important;
}

/* Full-map controls stay above the map and outside the dossier overlay. */

.full-map-stage__map .map-tools--overlay {
position: fixed !important;
  top: 6px !important;
  right: 12px !important;
  left: auto !important;
  z-index: 45 !important;
  margin: 0 !important;
}

.full-map-stage__map .map-view--fullscreen {
padding-top: 58px !important;
}

/* Map chat overlay belongs to the top edge of the playable area and spans the free center width. */

.full-map-stage__chat {
top: 46px !important;
  left: 380px !important;
  right: 380px !important;
  width: auto !important;
  transform: none !important;
}

.full-map-stage__chat .topbar-tab--chat {
margin: 0 auto;
}

.map-chat-overlay {
width: 100% !important;
  height: min(52vh, 500px) !important;
}

.map-chat-overlay .chat-bubble {
width: min(560px, 46%) !important;
  max-width: 46% !important;
}

.full-map-stage:has(.full-map-stage__dossier .dossier-panel--collapsed) .full-map-stage__chat {
left: 64px !important;
}

.full-map-stage:has(.full-map-stage__status .status-panel--collapsed) .full-map-stage__chat {
right: 64px !important;
}

/* Keep normal map using the full current center area. */

.tabs-panel:has(.map-view:not(.map-view--fullscreen)) {
overflow: hidden;
}

.tabs-panel:has(.map-view:not(.map-view--fullscreen)) .center-content {
flex: 1 1 auto;
}

.tabs-panel:has(.map-view:not(.map-view--fullscreen)) .case-graph {
min-width: 100%;
  min-height: calc(100% - 48px);
}

@media (max-width: 1500px) {
  .full-map-stage__chat {
    left: 350px !important;
    right: 350px !important;
  }
}

/* v79 theme pass: terminal-green cleanup, verdict red preservation, segmented reputation. */

.topbar__scanline {
display: none !important;
}

.topbar {
border-bottom-width: 1px !important;
}

.top-meter--segments {
display: inline-grid;
  grid-template-columns: auto auto auto;
  align-items: center;
  gap: 6px;
  color: var(--c-muted) !important;
  text-shadow: none !important;
  overflow: visible;
}

.top-meter--segments .top-meter__label {
color: var(--c-yellow);
  font-weight: 900;
}

.top-meter__segments {
display: inline-flex;
  align-items: center;
  gap: 2px;
  overflow: visible;
  filter: drop-shadow(0 0 4px rgba(255, 191, 46, 0.36));
}

.top-meter__pip {
width: 9px;
  height: 10px;
  display: block;
  border: 1px solid rgba(255, 191, 46, 0.34);
  background: rgba(255, 191, 46, 0.08);
  box-shadow: inset 0 0 3px rgba(255, 191, 46, 0.08);
}

.top-meter__pip--on {
background: #ffd457;
  border-color: rgba(255, 237, 164, 0.86);
  box-shadow:
    0 0 4px rgba(255, 191, 46, 0.80),
    inset 0 0 3px rgba(255, 255, 255, 0.38);
}

.map-header-panel .top-meter--segments .top-meter__pip {
width: 8px;
  height: 9px;
}

/* WERDYKT is always danger/red; it must not inherit the GREEN terminal palette. */

.ui-btn--danger,
.verdict-btn,
.status-verdict-bar .ui-btn {
color: var(--c-red) !important;
  border-color: rgba(255, 88, 108, 0.72) !important;
  background: rgba(30, 7, 14, 0.92) !important;
  box-shadow:
    0 0 13px rgba(255, 51, 87, 0.22),
    inset 0 0 12px rgba(255, 51, 87, 0.04) !important;
  text-shadow: none;
}

.ui-btn--danger:hover,
.verdict-btn:hover,
.status-verdict-bar .ui-btn:hover,
.ui-btn--danger:focus-visible,
.verdict-btn:focus-visible,
.status-verdict-bar .ui-btn:focus-visible {
color: var(--c-red) !important;
  border-color: rgba(255, 88, 108, 0.95) !important;
  background: rgba(40, 8, 18, 0.96) !important;
  box-shadow:
    0 0 16px rgba(255, 51, 87, 0.62),
    0 0 32px rgba(255, 51, 87, 0.28),
    inset 0 0 14px rgba(255, 51, 87, 0.08) !important;
  text-shadow: 0 0 9px rgba(255, 51, 87, 0.70);
}

/* v80 theme/layout polish: complete theme variables, full-map topbar, cleaner active states. */


/* Hover is subtle; selected/current tab is clearly lit. */


/* Do not let global selected-red treatment recolor navigation tabs. */

.card--selected,
.map-node--selected {
border-color: var(--c-red) !important;
  color: inherit;
  box-shadow: 0 0 18px rgba(255, 51, 87, 0.42), inset 0 0 16px rgba(255, 51, 87, 0.08) !important;
}

/* Theme scrollbars, including the FULL MAP page scrollbars. */

.panel__body,
.center-content,
.transcript,
.map-view,
.selected-cards,
.modal-card {
scrollbar-color: var(--theme-scroll) var(--theme-scroll-track) !important;
}

.panel__body::-webkit-scrollbar-track,
.center-content::-webkit-scrollbar-track,
.transcript::-webkit-scrollbar-track,
.map-view::-webkit-scrollbar-track,
.selected-cards::-webkit-scrollbar-track,
.modal-card::-webkit-scrollbar-track {
background: var(--theme-scroll-track) !important;
}

.panel__body::-webkit-scrollbar-thumb,
.center-content::-webkit-scrollbar-thumb,
.transcript::-webkit-scrollbar-thumb,
.map-view::-webkit-scrollbar-thumb,
.selected-cards::-webkit-scrollbar-thumb,
.modal-card::-webkit-scrollbar-thumb {
background: var(--theme-scroll) !important;
  border-color: rgba(0, 0, 0, 0.45) !important;
  box-shadow: 0 0 10px var(--theme-glow) !important;
}

/* FULL MAP header: expanded equals the main header across the whole viewport. */

.full-map-stage__top {
top: 6px !important;
  left: 8px !important;
  right: 8px !important;
  width: auto !important;
  transform: none !important;
  justify-content: stretch !important;
  z-index: 120 !important;
}

.full-map-stage__top:has(.topbar-tab--map) {
left: 50% !important;
  right: auto !important;
  width: max-content !important;
  transform: translateX(-50%) !important;
  justify-content: center !important;
}

.map-header-panel--full,
.map-header-panel--full .topbar {
width: 100% !important;
}

.map-header-panel--full .topbar {
height: 68px !important;
  min-height: 68px !important;
  grid-template-columns: minmax(430px, 1fr) minmax(300px, 0.78fr) minmax(210px, 0.34fr) !important;
  padding: 10px 12px !important;
}

.map-header-panel--full .case-title,
.map-header-panel--full .case-meta {
font-size: inherit !important;
}

.map-header-panel--full .topbar__actions-panel {
right: 0 !important;
}

.full-map-stage--top-open .full-map-stage__map .map-view--fullscreen {
padding-top: 92px !important;
}

.full-map-stage--top-collapsed .full-map-stage__map .map-view--fullscreen {
padding-top: 54px !important;
}

/* FULL MAP chat tab should be attached to the upper edge, not float in the middle. */

.full-map-stage__chat:has(.topbar-tab--chat) {
top: 86px !important;
  left: 50% !important;
  right: auto !important;
  width: max-content !important;
  transform: translateX(-50%) !important;
}

.full-map-stage--top-collapsed .full-map-stage__chat:has(.topbar-tab--chat) {
top: 44px !important;
}

.full-map-stage__chat:has(.topbar-tab--chat) .topbar-tab--chat {
margin: 0 !important;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

.full-map-stage__chat:has(.map-chat-overlay) {
top: 86px !important;
}

.full-map-stage--top-collapsed .full-map-stage__chat:has(.map-chat-overlay) {
top: 44px !important;
}

/* Header actions menu must float above map/status overlays. */

.topbar,
.topbar__right {
position: relative;
  z-index: 140 !important;
}

.topbar__right {
padding-right: 16px;
}

.topbar__actions-panel {
z-index: 500 !important;
  right: 16px !important;
  top: 38px !important;
}

.full-map-stage__map .map-tools--overlay {
z-index: 70 !important;
}

.full-map-stage__status,
.full-map-stage__dossier,
.full-map-stage__action,
.full-map-stage__chat {
z-index: 80 !important;
}

.full-map-stage__top {
z-index: 160 !important;
}

/* Reputacja: segmented again, flat yellow like the label, with a contained glow. */

.top-meter--segments {
overflow: visible !important;
}

.top-meter__segments {
filter: drop-shadow(0 0 3px rgba(255, 191, 46, 0.42)) !important;
}

.top-meter__pip {
width: 9px !important;
  height: 10px !important;
  border: 1px solid rgba(255, 191, 46, 0.38) !important;
  background: rgba(255, 191, 46, 0.08) !important;
  box-shadow: none !important;
}

.top-meter__pip--on {
background: var(--c-yellow) !important;
  border-color: var(--c-yellow) !important;
  box-shadow: 0 0 4px rgba(255, 191, 46, 0.42), inset 0 0 2px rgba(255, 255, 255, 0.24) !important;
}

/* v81: panel layout/persistence polish.
   Keep the readable subpanels strong, but dim only the largest screen frames. */

.dossier-panel:not(.dossier-panel--collapsed),
.tabs-panel,
.status-panel:not(.status-panel--collapsed),
.topbar:not(.topbar--collapsed),
.map-header-panel--full .topbar,
.full-map-stage__action .action-builder:not(.action-builder--collapsed) {
border-color: rgba(0, 200, 255, 0.16) !important;
  box-shadow: inset 0 0 14px rgba(0, 200, 255, 0.025), 0 0 10px rgba(0, 0, 0, 0.22) !important;
}


/* The actual controls inside those big frames should stay more readable. */

.tab-btn,
.ui-btn,
.icon-btn,
.panel-collapse-btn,
.filter-row .ui-btn,
.card,
.action-slot--empty,
.status-block,
.status-bucket,
.section-title,
.chat-bubble,
.map-node {
border-width: 1px;
}

/* Collapsed BUILD ACTION tab is centered, also inside FULL MAP. */

.action-builder--collapsed {
display: flex !important;
  justify-content: center !important;
  align-items: center !important;
}

.full-map-stage__action:has(.action-builder--collapsed) {
left: 50% !important;
  right: auto !important;
  width: max-content !important;
  transform: translateX(-50%) !important;
}

.full-map-stage__action .action-builder--collapsed {
width: max-content !important;
  min-width: 0 !important;
}

.full-map-stage__action .action-builder--collapsed .panel-collapse-rail--bottom {
margin-left: auto !important;
  margin-right: auto !important;
}

/* Right panel uses the mirror of the left panel: collapse control starts near the outer edge. */

.status-panel .panel__title--status {
display: grid !important;
  grid-template-columns: auto auto minmax(0, 1fr);
  align-items: center;
  gap: 8px;
}

.status-panel .panel__title-tools--leading {
justify-content: flex-start;
}

.status-panel .panel__title--status > .panel__title-tools:last-child {
justify-content: flex-end;
}

/* Map controls are controls, not map content: keep them above the floating panels. */

.full-map-stage__map .map-tools--overlay {
z-index: 150 !important;
}

.full-map-stage__top {
z-index: 180 !important;
}

.topbar__actions-panel {
z-index: 600 !important;
}

/* Preserve the compact vertical tabs along the edge, but never full-height rails. */

.dossier-panel--collapsed,
.status-panel--collapsed {
align-self: center !important;
  width: 38px !important;
  min-width: 38px !important;
  max-width: 38px !important;
}

.panel-collapse-rail:not(.panel-collapse-rail--bottom) {
min-height: 112px !important;
  height: max-content !important;
  max-height: 180px !important;
}

/* v82 layout polish: blue frame dimming, fullscreen map header, symmetric panels, compact build action. */


/* Symmetric main side-panel header bands. Subpanels inside remain stronger. */

.dossier-panel:not(.dossier-panel--collapsed) > .panel__head,
.status-panel:not(.status-panel--collapsed) > .panel__head {
min-height: 86px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.status-panel:not(.status-panel--collapsed) > .panel__head .panel__title {
min-height: 38px;
}

.status-panel:not(.status-panel--collapsed) > .panel__head .panel__subtle {
display: block;
  max-width: 150px;
  white-space: normal;
  line-height: 1.25;
  text-align: right;
}

/* Left collapsed dossier tab expands inward/right; do not rotate the arrow backwards. */

.panel-collapse-rail--left,
.full-map-stage__dossier .dossier-panel--collapsed .panel-collapse-rail--left {
transform: none !important;
}

/* Full-map top header should be the same HUD bar, not a nested framed panel. */

.map-header-panel--full {
padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.full-map-stage__top {
z-index: 130 !important;
}

.full-map-stage__map .map-tools--overlay {
z-index: 150 !important;
}

.full-map-stage--top-open .full-map-stage__map .map-tools--overlay {
top: 98px !important;
}

.full-map-stage--top-collapsed .full-map-stage__map .map-tools--overlay {
top: 8px !important;
}

.full-map-stage--top-open .full-map-stage__map .map-view--fullscreen {
padding-top: 142px !important;
}

.full-map-stage--top-collapsed .full-map-stage__map .map-view--fullscreen {
padding-top: 58px !important;
}

/* Compact, more canvas-like BUILD ACTION panel. */

.tabs-panel > .action-builder {
margin: 8px 10px 10px;
  border: 1px solid rgba(46, 155, 255, 0.16);
}

.action-builder {
min-height: 0 !important;
  padding: 8px 10px 9px !important;
}

.action-builder__head {
margin-bottom: 6px !important;
}

.action-builder__label {
font-size: 12px;
}

.action-builder__tools {
gap: 6px;
}

.action-slots {
min-height: 98px !important;
  margin-bottom: 8px !important;
  gap: 10px !important;
}

.action-slot--empty,
.card--action-slot {
flex: 0 0 300px !important;
  width: 300px !important;
  max-width: 300px !important;
  height: 98px !important;
  min-height: 98px !important;
  max-height: 98px !important;
}

.action-slot__plus {
font-size: 18px !important;
}

.action-slot__label {
font-size: 9px !important;
}

.card--action-slot {
padding: 8px 10px !important;
}

.card--action-slot .card__title {
font-size: 12.5px !important;
  margin-top: 3px !important;
}

.card--action-slot .card__body {
max-height: 28px !important;
  font-size: 10.5px !important;
  margin-top: 5px !important;
}

.card--action-slot .card__tags {
margin-top: 5px !important;
  font-size: 9px !important;
}

.card--action-slot .card__image {
width: 74px !important;
  height: 46px !important;
}

.action-strip {
grid-template-columns: minmax(168px, 0.85fr) repeat(5, minmax(118px, 1fr)) !important;
  gap: 8px !important;
}

.action-strip .ui-btn {
min-height: 36px !important;
  font-size: 11px !important;
}

.action-style-btn {
justify-self: stretch;
}

/* Full-map action overlay should stay compact and centered. */

.full-map-stage__action .action-builder:not(.action-builder--collapsed) {
margin: 0 !important;
  padding: 8px 10px 9px !important;
}

.full-map-stage__action {
bottom: 12px !important;
}

@media (max-height: 900px) {
  .chat-scene {
    min-height: 360px;
  }
  .action-slot--empty,
  .card--action-slot {
    height: 92px !important;
    min-height: 92px !important;
    max-height: 92px !important;
  }
  .action-slots {
    min-height: 92px !important;
  }
}

/* v83 final alignment pass: compact collapsed action tab, status header symmetry,
   full-map spacing, and canvas-like action panel proportions. */

.tabs-panel > .action-builder--collapsed,
.action-builder--collapsed {
width: max-content !important;
  min-width: 0 !important;
  max-width: none !important;
  margin: 8px auto 10px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.action-builder--collapsed .panel-collapse-rail--bottom {
border: 1px solid var(--theme-border, rgba(46, 155, 255, 0.34)) !important;
  background: var(--theme-bg-flat, rgba(5, 13, 22, 0.96)) !important;
  box-shadow: inset 0 0 10px rgba(0, 200, 255, 0.035), 0 0 10px rgba(0, 200, 255, 0.08) !important;
}


/* Main side-panel headers should be balanced; content description belongs to body. */

.dossier-panel:not(.dossier-panel--collapsed) > .panel__head,
.status-panel:not(.status-panel--collapsed) > .panel__head {
min-height: 84px !important;
  justify-content: center !important;
}

.status-panel:not(.status-panel--collapsed) > .panel__head .panel__title,
.dossier-panel:not(.dossier-panel--collapsed) > .panel__head .panel__title {
min-height: 28px !important;
}

.status-panel:not(.status-panel--collapsed) > .panel__head .panel__subtle {
display: none !important;
}

.status-block--subject {
color: var(--c-muted);
}

.status-subject__name {
margin-top: 8px;
  color: var(--c-white);
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 0.02em;
}

.status-subject__desc {
margin-top: 8px;
  line-height: 1.42;
  font-size: 11px;
}

.status-subject__meta {
display: grid;
  grid-template-columns: 96px minmax(0, 1fr);
  gap: 8px;
  align-items: baseline;
  margin-top: 8px;
  font-size: 11px;
}

.status-subject__meta span {
color: var(--theme-accent, var(--c-cyan));
  font-weight: 900;
  text-transform: uppercase;
}

.status-subject__meta strong {
color: var(--c-white);
}

/* Full-map top header no longer covers map controls; controls sit in a clear row below it. */

.full-map-stage--top-open .full-map-stage__map .map-tools--overlay {
top: 112px !important;
  z-index: 210 !important;
}

.full-map-stage--top-open .full-map-stage__map .map-view--fullscreen {
padding-top: 158px !important;
}

.full-map-stage__top {
pointer-events: none;
}

.full-map-stage__top .topbar,
.full-map-stage__top .topbar-tab,
.full-map-stage__top .map-header-panel {
pointer-events: auto;
}

.full-map-stage__top .topbar__actions-panel {
pointer-events: auto;
}

/* Build Action: shorter and more symmetric, with STYLE returned to the tool cluster. */

.tabs-panel > .action-builder:not(.action-builder--collapsed) {
margin: 10px 10px 10px !important;
}

.action-builder:not(.action-builder--collapsed) {
padding: 8px 10px 9px !important;
}

.action-builder__hint {
display: none !important;
}

.action-builder__head {
margin-bottom: 6px !important;
}

.action-builder__tools .action-style-btn {
min-width: 124px;
}

.action-slots {
min-height: 82px !important;
  margin-bottom: 8px !important;
  gap: 10px !important;
  justify-content: center;
}

.action-slot--empty,
.card--action-slot {
flex: 0 0 280px !important;
  width: 280px !important;
  max-width: 280px !important;
  height: 82px !important;
  min-height: 82px !important;
  max-height: 82px !important;
}

.card--action-slot .card__title {
font-size: 12px !important;
  margin-top: 2px !important;
}

.card--action-slot .card__body {
max-height: 22px !important;
  margin-top: 4px !important;
  font-size: 10px !important;
}

.card--action-slot .card__tags,
.card--action-slot .card__hint {
display: none !important;
}

.card--action-slot .card__image {
width: 62px !important;
  height: 38px !important;
}

.action-strip {
grid-template-columns: repeat(5, minmax(120px, 1fr)) !important;
  gap: 8px !important;
}

.action-strip .ui-btn {
min-height: 34px !important;
}

.full-map-stage__action .action-builder:not(.action-builder--collapsed) {
width: min(940px, calc(100vw - 760px));
}

/* Keep main BLUE frames dimmed after the later theme rules. */


@media (max-height: 900px) {
  .action-slot--empty,
  .card--action-slot {
    height: 76px !important;
    min-height: 76px !important;
    max-height: 76px !important;
  }
  .action-slots {
    min-height: 76px !important;
  }
}

/* v84 right panel, full-map header, and action builder polish. */

/* Main side-panel headers: compact and symmetrical; content belongs to body blocks. */

.dossier-panel:not(.dossier-panel--collapsed) > .panel__head,
.status-panel:not(.status-panel--collapsed) > .panel__head {
min-height: 72px !important;
  padding: 9px 12px !important;
  justify-content: center !important;
}

.status-panel:not(.status-panel--collapsed) > .panel__head .panel__title,
.dossier-panel:not(.dossier-panel--collapsed) > .panel__head .panel__title {
min-height: 28px !important;
  align-items: center !important;
}

.status-panel:not(.status-panel--collapsed) > .panel__head {
flex: 0 0 72px !important;
}

.dossier-panel:not(.dossier-panel--collapsed) > .panel__head {
flex: 0 0 72px !important;
}

.status-panel .panel__title--status {
grid-template-columns: auto auto minmax(0, 1fr) !important;
}

.status-panel__body {
padding-top: 10px !important;
}

.status-block--subject {
padding-bottom: 12px !important;
}

.status-subject__state {
margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid rgba(46, 155, 255, 0.18);
}

.status-block__title--inline {
margin-bottom: 6px !important;
}


/* BUILD ACTION: selected cards should read like dossier cards again, with room for three. */

.tabs-panel > .action-builder {
margin: 10px 10px 10px !important;
}

.action-builder {
padding: 9px 12px 10px !important;
}

.action-builder__head {
display: grid !important;
  grid-template-columns: minmax(180px, 1fr) auto !important;
  gap: 12px !important;
  align-items: start !important;
  margin-bottom: 8px !important;
}

.action-builder__tools {
justify-content: flex-end !important;
  align-items: center !important;
  align-self: start !important;
  flex-wrap: nowrap !important;
}

.action-builder__label {
line-height: 1.2 !important;
}

.action-slots {
display: grid !important;
  grid-template-columns: repeat(var(--slot-count, 2), 300px) !important;
  justify-content: center !important;
  align-items: stretch !important;
  gap: 12px !important;
  min-height: 118px !important;
  margin-bottom: 10px !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  padding-bottom: 2px !important;
}

.action-slot--empty,
.card--action-slot {
flex: none !important;
  width: 300px !important;
  min-width: 300px !important;
  max-width: 300px !important;
  height: 118px !important;
  min-height: 118px !important;
  max-height: 118px !important;
}

.card--action-slot {
padding: 9px 10px !important;
}

.card--action-slot .card__type {
font-size: 9.5px !important;
  padding-right: 68px !important;
}

.card--action-slot .card__title {
font-size: 13px !important;
  margin-top: 4px !important;
  line-height: 1.22 !important;
  white-space: normal !important;
}

.card--action-slot .card__body {
display: block !important;
  max-height: 38px !important;
  margin-top: 6px !important;
  font-size: 10.5px !important;
  line-height: 1.32 !important;
  overflow: hidden !important;
}

.card--action-slot .card__tags {
display: block !important;
  margin-top: 5px !important;
  font-size: 9px !important;
}

.card--action-slot .card__hint {
display: none !important;
}

.card--action-slot .card__image {
width: 74px !important;
  height: 46px !important;
  margin-left: 8px !important;
}

.action-strip {
display: grid !important;
  grid-template-columns: repeat(5, minmax(120px, 1fr)) !important;
  gap: 8px !important;
}

.action-strip .ui-btn {
min-height: 34px !important;
}

@media (max-width: 1460px) {
  .action-slots { grid-template-columns: repeat(var(--slot-count, 2), 280px) !important; }
  .action-slot--empty,
  .card--action-slot {
    width: 280px !important;
    min-width: 280px !important;
    max-width: 280px !important;
  }
}

/* FULL MAP: expanded top HUD should be the normal full-width topbar and must not collide with controls. */

.full-map-stage__top {
top: 8px !important;
  left: 8px !important;
  right: 8px !important;
  width: auto !important;
  max-width: none !important;
  z-index: 170 !important;
}

.map-header-panel--full,
.map-header-panel--full .topbar {
width: 100% !important;
  max-width: none !important;
}

.map-header-panel--full .topbar {
height: 76px !important;
  min-height: 76px !important;
  grid-template-columns: minmax(470px, 1fr) minmax(260px, 0.7fr) minmax(520px, 1fr) !important;
  padding: 8px 12px !important;
}

.map-header-panel--full .case-title {
font-size: clamp(14px, 1vw, 18px) !important;
}

.map-header-panel--full .case-meta {
font-size: 11px !important;
}

.full-map-stage--top-open .full-map-stage__map .map-tools--overlay {
top: 96px !important;
  right: 10px !important;
  z-index: 155 !important;
}

.full-map-stage--top-open .full-map-stage__map .map-view--fullscreen {
padding-top: 140px !important;
}

.full-map-stage--top-open .full-map-stage__chat:has(.topbar-tab--chat) {
top: 96px !important;
}

.full-map-stage--top-open .full-map-stage__chat:has(.map-chat-overlay) {
top: 96px !important;
}

/* Collapsed action is a button only, never a framed strip. */

.tabs-panel > .action-builder--collapsed,
.action-builder--collapsed {
border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.action-builder--collapsed .panel-collapse-rail--bottom {
min-height: 34px !important;
  height: 34px !important;
  padding: 0 18px !important;
}

/* v85: normalize right panel header and make FULL MAP panels use the same topbar geometry as the normal view. */

.status-panel:not(.status-panel--collapsed) > .panel__head {
flex: 0 0 auto !important;
  min-height: 46px !important;
  height: auto !important;
  padding: 10px 12px 6px !important;
  justify-content: flex-start !important;
  border-bottom: 0 !important;
  background: transparent !important;
}

.status-panel:not(.status-panel--collapsed) > .panel__head .panel__title {
min-height: 28px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  width: 100% !important;
  color: var(--c-red) !important;
}

.status-panel .panel__title--status {
grid-template-columns: none !important;
}

.status-panel .panel__title-tools,
.status-panel .panel__title-tools--leading {
display: inline-flex !important;
  margin: 0 !important;
}

.status-panel__body {
padding-top: 0 !important;
}

.status-panel__body .status-block--subject:first-child {
margin-top: 0 !important;
}

.status-block--subject {
border-top-color: rgba(46, 155, 255, 0.16) !important;
}


/* Keep the dossier header height independent: it has filters, status header does not. */

.dossier-panel:not(.dossier-panel--collapsed) > .panel__head {
min-height: 72px !important;
  flex: 0 0 72px !important;
  padding: 9px 12px !important;
}

/* FULL MAP header: use the exact same topbar block as the normal screen, only positioned as overlay. */

.full-map-stage__top {
top: 8px !important;
  left: 8px !important;
  right: 8px !important;
  width: auto !important;
  max-width: none !important;
  transform: none !important;
  display: block !important;
  justify-content: stretch !important;
  z-index: 220 !important;
}

.full-map-stage__top .topbar.topbar--full-map {
width: 100% !important;
  min-height: 76px !important;
  height: 76px !important;
  display: grid !important;
  grid-template-columns: minmax(430px, 1fr) minmax(300px, 0.78fr) minmax(210px, 0.34fr) !important;
  padding: 8px 12px !important;
  margin: 0 !important;
}

.full-map-stage__top .topbar.topbar--full-map .case-title,
.full-map-stage__top .topbar.topbar--full-map .case-meta {
font-size: inherit !important;
}

.full-map-stage__top .topbar.topbar--full-map .topbar__center,
.full-map-stage__top .topbar.topbar--full-map .user-badge {
display: none !important;
}

.full-map-stage__top .topbar.topbar--full-map .topbar__right {
grid-column: 3 !important;
}

.full-map-stage__top .topbar.topbar--full-map .topbar__actions-panel {
right: 0 !important;
  top: 36px !important;
  z-index: 260 !important;
}

.full-map-stage--top-open .full-map-stage__map .map-tools--overlay {
top: 96px !important;
  right: 10px !important;
  z-index: 180 !important;
}

.full-map-stage--top-open .full-map-stage__map .map-view--fullscreen {
padding-top: 138px !important;
}

.full-map-stage--top-collapsed .full-map-stage__map .map-view--fullscreen {
padding-top: 54px !important;
}

/* FULL MAP overlay panels use the same vertical row as the normal layout: below expanded topbar, or near top when collapsed. */

.full-map-stage--top-open .full-map-stage__dossier,
.full-map-stage--top-open .full-map-stage__status {
top: 94px !important;
}

.full-map-stage--top-collapsed .full-map-stage__dossier,
.full-map-stage--top-collapsed .full-map-stage__status {
top: 48px !important;
}

.full-map-stage--top-open .full-map-stage__chat:has(.topbar-tab--chat) {
top: 94px !important;
}

.full-map-stage--top-open .full-map-stage__chat:has(.map-chat-overlay) {
top: 94px !important;
}

.full-map-stage--top-collapsed .full-map-stage__chat:has(.topbar-tab--chat),
.full-map-stage--top-collapsed .full-map-stage__chat:has(.map-chat-overlay) {
top: 48px !important;
}

/* Expanded status panel should feel continuous: title band + suspect block without a heavy dividing bar. */

.status-panel:not(.status-panel--collapsed) .status-panel__body > .status-block:first-child {
border-top-width: 1px !important;
}

/* v86: FULL MAP uses the same panel grid as CLOSED MAP.
   The node graph is the underlay; header/dossier/status/build-action keep the
   exact normal case-screen geometry. */

.app-shell--fullscreen-map {
position: relative !important;
  display: block !important;
  height: 100% !important;
  min-height: 0 !important;
}

.full-map-stage {
position: relative !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  overflow: hidden !important;
}

.full-map-stage__map {
position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  pointer-events: auto !important;
}

.full-map-stage__map .map-view--fullscreen-underlay {
position: absolute !important;
  inset: 0 !important;
  width: auto !important;
  height: auto !important;
  min-height: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  overflow: auto !important;
  background:
    linear-gradient(rgba(0, 200, 255, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 200, 255, 0.035) 1px, transparent 1px),
    rgba(3, 7, 14, 0.90) !important;
  background-size: 36px 36px, 36px 36px, auto !important;
}

.full-map-stage__map .map-view--fullscreen-underlay .case-graph {
min-width: 100% !important;
  min-height: 100% !important;
  background:
    radial-gradient(circle at 50% 10%, rgba(0, 200, 255, 0.10), transparent 38%),
    rgba(3, 7, 14, 0.46) !important;
}

.full-map-stage__shell {
position: relative !important;
  z-index: 20 !important;
  height: 100% !important;
  min-height: 0 !important;
  display: grid !important;
  grid-template-rows: 72px minmax(0, 1fr) !important;
  gap: 8px !important;
  pointer-events: none !important;
}

.full-map-stage--top-collapsed .full-map-stage__shell {
grid-template-rows: 38px minmax(0, 1fr) !important;
}

.full-map-stage__shell > .full-map-stage__top {
position: static !important;
  inset: auto !important;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  bottom: auto !important;
  transform: none !important;
  width: auto !important;
  max-width: none !important;
  z-index: auto !important;
  pointer-events: auto !important;
}

.full-map-stage--top-collapsed .full-map-stage__top {
display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.full-map-stage__top .topbar.topbar--full-map {
width: 100% !important;
  height: auto !important;
  min-height: 72px !important;
  display: grid !important;
  grid-template-columns: minmax(430px, 1fr) minmax(300px, 0.78fr) minmax(210px, 0.34fr) !important;
  padding: 9px 12px !important;
  margin: 0 !important;
}

.full-map-stage__top .topbar.topbar--full-map .topbar__right {
grid-column: 3 !important;
}

.full-map-stage__top .topbar.topbar--full-map .topbar__center,
.full-map-stage__top .topbar.topbar--full-map .user-badge {
display: none !important;
}

.full-map-stage__top .topbar.topbar--full-map .topbar__actions-panel {
right: 0 !important;
  top: 36px !important;
  z-index: 260 !important;
}

.layout--fullscreen-map {
position: relative !important;
  z-index: 25 !important;
  min-height: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(305px, 360px) minmax(520px, 1fr) minmax(310px, 360px) !important;
  gap: 8px !important;
  pointer-events: none !important;
}

.layout--fullscreen-map.layout--dossier-collapsed {
grid-template-columns: 46px minmax(520px, 1fr) minmax(310px, 360px) !important;
}

.layout--fullscreen-map.layout--status-collapsed {
grid-template-columns: minmax(305px, 360px) minmax(520px, 1fr) 46px !important;
}

.layout--fullscreen-map.layout--dossier-collapsed.layout--status-collapsed {
grid-template-columns: 46px minmax(520px, 1fr) 46px !important;
}

.layout--fullscreen-map > .dossier-panel,
.layout--fullscreen-map > .status-panel {
pointer-events: auto !important;
}

.layout--fullscreen-map > .tabs-panel {
pointer-events: none !important;
  background: linear-gradient(180deg, rgba(10, 24, 38, 0.58), rgba(5, 13, 22, 0.58)) !important;
}

.layout--fullscreen-map > .tabs-panel .tab-row,
.layout--fullscreen-map > .tabs-panel .action-builder,
.layout--fullscreen-map .map-view--fullscreen-chrome .map-tools--overlay,
.layout--fullscreen-map .map-view--fullscreen-chrome .map-legend {
pointer-events: auto !important;
}

.layout--fullscreen-map .center-content {
display: flex !important;
  min-height: 0 !important;
  overflow: hidden !important;
  padding: 8px 10px !important;
}

.layout--fullscreen-map .map-view--fullscreen-chrome {
flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
  height: auto !important;
  min-height: 0 !important;
  width: auto !important;
  padding: 0 !important;
  overflow: hidden !important;
  border: 1px solid rgba(0, 200, 255, 0.30) !important;
  background: rgba(3, 7, 14, 0.30) !important;
}

.layout--fullscreen-map .map-view--fullscreen-chrome .map-tools--overlay {
position: sticky !important;
  top: 0 !important;
  left: 0 !important;
  right: auto !important;
  z-index: 4 !important;
  width: max-content !important;
  max-width: calc(100% - 12px) !important;
  margin: 0 !important;
  padding: 10px !important;
  background: linear-gradient(180deg, rgba(3, 7, 14, 0.92), rgba(3, 7, 14, 0.48)) !important;
  border: 0 !important;
  backdrop-filter: blur(2px);
}

.layout--fullscreen-map .map-fullscreen-guide {
flex: 1 1 auto;
  min-height: 0;
  pointer-events: none;
}

.layout--fullscreen-map .map-view--fullscreen-chrome .map-legend {
position: sticky !important;
  bottom: 0 !important;
  z-index: 4 !important;
}

/* v87: FULL MAP keeps the closed-map header geometry and removes the central map chrome panel.
   The graph stays as a full-screen underlay; only compact controls, optional transparent chat,
   side panels and the build-action panel sit above it. */

.full-map-stage__shell {
grid-template-rows: 68px minmax(0, 1fr) !important;
  gap: 8px !important;
}

.full-map-stage--top-collapsed .full-map-stage__shell {
grid-template-rows: 38px minmax(0, 1fr) !important;
}

.full-map-stage__shell > .full-map-stage__top {
display: block !important;
  min-height: 0 !important;
}

.full-map-stage__top .topbar:not(.topbar--collapsed) {
width: 100% !important;
  height: 68px !important;
  min-height: 0 !important;
  max-height: 68px !important;
  margin: 0 !important;
  padding: 10px 12px !important;
  display: grid !important;
  grid-template-columns: minmax(520px, 1fr) minmax(220px, auto) 56px !important;
  align-items: center !important;
}

.full-map-stage__top .topbar:not(.topbar--collapsed) .topbar__center {
display: none !important;
}

.full-map-stage__top .topbar:not(.topbar--collapsed) .topbar__right {
grid-column: 3 !important;
  align-self: stretch !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  padding-right: 16px !important;
}

.full-map-stage__top .topbar:not(.topbar--collapsed) .topbar__user-line {
width: auto !important;
  height: 100% !important;
  align-items: center !important;
}

.full-map-stage__top .topbar:not(.topbar--collapsed) .case-title {
margin-top: 7px !important;
}

.full-map-stage__top .topbar:not(.topbar--collapsed) .case-meta {
margin-top: 5px !important;
}

.full-map-stage__top .topbar.topbar--collapsed {
height: 38px !important;
  min-height: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
}

.layout--fullscreen-map {
grid-template-columns: minmax(305px, 360px) minmax(520px, 1fr) minmax(310px, 360px) !important;
}

.layout--fullscreen-map.layout--dossier-collapsed {
grid-template-columns: 46px minmax(520px, 1fr) minmax(310px, 360px) !important;
}

.layout--fullscreen-map.layout--status-collapsed {
grid-template-columns: minmax(305px, 360px) minmax(520px, 1fr) 46px !important;
}

.layout--fullscreen-map.layout--dossier-collapsed.layout--status-collapsed {
grid-template-columns: 46px minmax(520px, 1fr) 46px !important;
}

.full-map-center {
min-width: 0 !important;
  min-height: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  pointer-events: none !important;
}

.full-map-center__tools {
pointer-events: auto !important;
  align-self: flex-start !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin: 10px 10px 0 !important;
  padding: 8px 10px !important;
  max-width: calc(100% - 20px) !important;
  border: 1px solid rgba(0, 200, 255, 0.32) !important;
  background: rgba(3, 7, 14, 0.56) !important;
  box-shadow: inset 0 0 16px rgba(0, 200, 255, 0.045), 0 0 20px rgba(0, 0, 0, 0.36) !important;
  backdrop-filter: blur(2px);
}

.full-map-center__tools .map-zoom-label {
min-width: 48px !important;
  align-self: center !important;
  text-align: center !important;
  color: var(--c-cyan) !important;
  font-weight: 900 !important;
}

.full-map-center__spacer {
flex: 1 1 auto !important;
  min-height: 0 !important;
  pointer-events: none !important;
}

.full-map-center > .action-builder,
.full-map-center > .action-builder--collapsed {
pointer-events: auto !important;
  margin: 10px !important;
  flex: 0 0 auto !important;
}

.full-map-center > .action-builder:not(.action-builder--collapsed) {
background: linear-gradient(180deg, rgba(10, 24, 38, 0.68), rgba(5, 13, 22, 0.68)) !important;
  backdrop-filter: blur(2px);
}

.map-chat-overlay--transparent {
pointer-events: auto !important;
  width: min(720px, calc(100% - 20px)) !important;
  max-height: min(48vh, 430px) !important;
  margin: 10px auto 0 !important;
  display: flex !important;
  flex-direction: column !important;
  min-height: 0 !important;
  overflow: hidden !important;
  border: 1px solid rgba(0, 200, 255, 0.34) !important;
  background: rgba(3, 7, 14, 0.50) !important;
  box-shadow: inset 0 0 22px rgba(0, 200, 255, 0.04), 0 0 28px rgba(0, 0, 0, 0.38) !important;
  backdrop-filter: blur(3px);
  clip-path: polygon(0 0, calc(100% - 8px) 0, 100% 8px, 100% 100%, 8px 100%, 0 calc(100% - 8px));
}

.map-chat-overlay--transparent .map-chat-overlay__head {
flex: 0 0 auto !important;
  padding: 10px 12px 8px !important;
  border-bottom: 1px solid rgba(0, 200, 255, 0.18) !important;
  background: rgba(3, 7, 14, 0.34) !important;
}

.map-chat-overlay--transparent .map-chat-overlay__body {
flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow: auto !important;
  padding: 10px 12px 12px !important;
}

.map-chat-overlay--transparent .transcript {
max-height: none !important;
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
}

/* v88: FULL MAP keeps the same topbar/main panel styling as CLOSED MAP.
   Only the optional chat scene drops its background/portrait images so the map can show through. */

.full-map-stage__top .topbar:not(.topbar--collapsed) {
width: 100% !important;
  height: 68px !important;
  min-height: 0 !important;
  max-height: 68px !important;
  margin: 0 !important;
  padding: 10px 12px !important;
  display: grid !important;
  grid-template-columns: minmax(520px, 1fr) minmax(520px, 1fr) !important;
  gap: 12px !important;
  align-items: stretch !important;
}

.full-map-stage__top .topbar:not(.topbar--collapsed) .topbar__right {
grid-column: 2 !important;
  align-self: stretch !important;
  display: flex !important;
  align-items: stretch !important;
  justify-content: flex-end !important;
  padding-right: 0 !important;
}

.full-map-stage__top .topbar:not(.topbar--collapsed) .topbar__user-line {
width: auto !important;
  height: auto !important;
  align-items: flex-start !important;
}

.full-map-stage__top .topbar:not(.topbar--collapsed) .case-title,
.full-map-stage__top .topbar:not(.topbar--collapsed) .case-meta {
margin-top: 0 !important;
}

.layout--fullscreen-map > .dossier-panel:not(.dossier-panel--collapsed),
.layout--fullscreen-map > .status-panel:not(.status-panel--collapsed),
.full-map-center > .action-builder:not(.action-builder--collapsed) {
background: var(--theme-panel-flat, rgba(5, 13, 22, 0.94)) !important;
  border-color: var(--theme-border, rgba(46, 155, 255, 0.34)) !important;
}

.full-map-center > .action-builder:not(.action-builder--collapsed) {
backdrop-filter: none !important;
}

.map-chat-panel--transparent {
pointer-events: auto !important;
  position: relative !important;
  width: min(980px, calc(100% - 20px)) !important;
  max-height: min(50vh, 460px) !important;
  margin: 10px auto 0 !important;
  overflow: visible !important;
}

.map-chat-panel__close {
position: absolute !important;
  top: 10px !important;
  right: 10px !important;
  z-index: 12 !important;
}

.map-chat-panel--transparent .chat-scene {
height: clamp(260px, 42vh, 460px) !important;
  min-height: 260px !important;
  max-height: min(50vh, 460px) !important;
  margin: 0 !important;
}

.chat-scene--transparent {
background: rgba(3, 7, 14, 0.34) !important;
  backdrop-filter: blur(2px);
}

.chat-scene--transparent .transcript {
background: transparent !important;
}

/* v89: FULL MAP must never trap the player in a dark overlay state.
   The collapsed header now carries its own escape/chat controls, and the
   floating map toolbar stays above the graph underlay with normal opacity. */

.full-map-stage__top {
z-index: 520 !important;
  pointer-events: auto !important;
}

.full-map-stage__top .topbar.topbar--full-map-collapsed {
width: max-content !important;
  max-width: calc(100vw - 24px) !important;
  height: 40px !important;
  min-height: 40px !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
  pointer-events: auto !important;
}

.full-map-stage__top .topbar.topbar--full-map-collapsed .ui-btn,
.full-map-stage__top .topbar.topbar--full-map-collapsed .topbar-tab {
opacity: 1 !important;
  pointer-events: auto !important;
  flex: 0 0 auto !important;
}

.full-map-stage__shell {
isolation: isolate !important;
}

.full-map-stage__map {
z-index: 0 !important;
}

.layout--fullscreen-map,
.full-map-center {
position: relative !important;
  z-index: 60 !important;
}

.full-map-center__tools {
position: relative !important;
  z-index: 560 !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}

.full-map-center > .action-builder,
.full-map-center > .action-builder--collapsed,
.layout--fullscreen-map > .dossier-panel,
.layout--fullscreen-map > .status-panel {
opacity: 1 !important;
}

/* v90: stabilize FULL MAP overlays without changing the normal panel skin. */

/* The fullscreen node canvas keeps the same dark map surface as the regular MAPA SPRAWY panel. */

.full-map-stage__map .map-view--fullscreen-underlay {
background: rgba(3, 7, 14, 0.72) !important;
  background-image: none !important;
  background-size: auto !important;
}

.full-map-stage__map .map-view--fullscreen-underlay .case-graph {
background: rgba(3, 7, 14, 0.78) !important;
  background-image: none !important;
}

/* Collapsed top HUD is only the centered protocol restore tab; map/chat controls stay in the map toolbar. */

.full-map-stage--top-collapsed .full-map-stage__shell > .full-map-stage__top {
display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  pointer-events: none !important;
}

.full-map-stage__top .topbar.topbar--full-map-collapsed {
width: max-content !important;
  max-width: calc(100vw - 24px) !important;
  margin: 0 auto !important;
  pointer-events: auto !important;
}

.full-map-stage__top .topbar.topbar--full-map-collapsed .topbar-tab--map {
margin: 0 auto !important;
}

/* Build Action must fit inside the available center column and never be clipped by its own margins. */

.full-map-center {
overflow: hidden !important;
  min-width: 0 !important;
}

.full-map-center > .action-builder:not(.action-builder--collapsed) {
width: calc(100% - 20px) !important;
  max-width: calc(100% - 20px) !important;
  margin: 10px auto !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}

.full-map-center > .action-builder:not(.action-builder--collapsed) .action-slots {
max-width: 100% !important;
}

.full-map-center > .action-builder:not(.action-builder--collapsed) .action-strip {
min-width: 0 !important;
}

/* Collapsed Build Action is a centered button, not a side rail or offset strip. */

.full-map-center > .action-builder--collapsed {
align-self: center !important;
  justify-self: center !important;
  width: max-content !important;
  max-width: calc(100% - 20px) !important;
  margin: 10px auto !important;
}

.full-map-center > .action-builder--collapsed .panel-collapse-rail--bottom {
margin: 0 auto !important;
}

/* v91: FULL MAP action panel geometry fix.
   Keep this scoped to FULL MAP so normal CLOSED MAP layout remains unchanged. */

.layout--fullscreen-map .full-map-center {
box-sizing: border-box !important;
  padding-left: 10px !important;
  padding-right: 10px !important;
  overflow: visible !important;
}

.layout--fullscreen-map .full-map-center > .action-builder:not(.action-builder--collapsed) {
align-self: stretch !important;
  width: auto !important;
  max-width: none !important;
  margin: 10px 0 !important;
  box-sizing: border-box !important;
  overflow: visible !important;
}

.layout--fullscreen-map .full-map-center > .action-builder--collapsed {
align-self: stretch !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  width: auto !important;
  max-width: none !important;
  margin: 10px 0 !important;
  box-sizing: border-box !important;
  overflow: visible !important;
}

.layout--fullscreen-map .full-map-center > .action-builder--collapsed .panel-collapse-rail--bottom {
flex: 0 0 auto !important;
  width: max-content !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* v92: FULL MAP must not horizontally clip BUILD ACTION on narrower viewports.
   The full-map grid may have both side overlays open, so only the fullscreen
   middle column is allowed to shrink; the action builder then uses responsive
   slots/buttons inside that available column. Normal CLOSED MAP styles stay
   untouched. */

.layout--fullscreen-map {
width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  grid-template-columns: minmax(0, 360px) minmax(0, 1fr) minmax(0, 360px) !important;
  overflow: visible !important;
}

.layout--fullscreen-map.layout--dossier-collapsed {
grid-template-columns: 46px minmax(0, 1fr) minmax(0, 360px) !important;
}

.layout--fullscreen-map.layout--status-collapsed {
grid-template-columns: minmax(0, 360px) minmax(0, 1fr) 46px !important;
}

.layout--fullscreen-map.layout--dossier-collapsed.layout--status-collapsed {
grid-template-columns: 46px minmax(0, 1fr) 46px !important;
}

.layout--fullscreen-map .full-map-center {
min-width: 0 !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  padding-left: 12px !important;
  padding-right: 12px !important;
  overflow: visible !important;
}

.layout--fullscreen-map .full-map-center > .action-builder:not(.action-builder--collapsed) {
align-self: stretch !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 10px 0 !important;
  box-sizing: border-box !important;
  overflow: visible !important;
}

.layout--fullscreen-map .full-map-center > .action-builder:not(.action-builder--collapsed) .action-builder__head {
min-width: 0 !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
}

.layout--fullscreen-map .full-map-center > .action-builder:not(.action-builder--collapsed) .action-builder__tools {
min-width: 0 !important;
  flex-wrap: wrap !important;
  justify-content: flex-end !important;
}

.layout--fullscreen-map .full-map-center > .action-builder:not(.action-builder--collapsed) .action-slots {
width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  grid-template-columns: repeat(var(--slot-count, 2), minmax(0, 1fr)) !important;
  justify-content: stretch !important;
  overflow: visible !important;
  padding-bottom: 0 !important;
}

.layout--fullscreen-map .full-map-center > .action-builder:not(.action-builder--collapsed) .action-slot--empty,
.layout--fullscreen-map .full-map-center > .action-builder:not(.action-builder--collapsed) .card--action-slot {
width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
  overflow: hidden !important;
}

.layout--fullscreen-map .full-map-center > .action-builder:not(.action-builder--collapsed) .action-strip {
width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  overflow: visible !important;
}

.layout--fullscreen-map .full-map-center > .action-builder:not(.action-builder--collapsed) .action-strip .ui-btn {
min-width: 0 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.layout--fullscreen-map .full-map-center > .action-builder--collapsed {
align-self: stretch !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 10px 0 !important;
  display: flex !important;
  justify-content: center !important;
  overflow: visible !important;
}

@media (max-width: 1280px) {
  .layout--fullscreen-map {
    grid-template-columns: minmax(0, 300px) minmax(0, 1fr) minmax(0, 300px) !important;
  }
  .layout--fullscreen-map.layout--dossier-collapsed {
    grid-template-columns: 46px minmax(0, 1fr) minmax(0, 300px) !important;
  }
  .layout--fullscreen-map.layout--status-collapsed {
    grid-template-columns: minmax(0, 300px) minmax(0, 1fr) 46px !important;
  }
}

/* v93: final FULL MAP action-dock guardrails.
   The full-map center column can be squeezed by side overlays and browser scaling.
   Keep BUILD ACTION inside the visible middle column with real side gutters, while
   leaving the normal CLOSED MAP action builder untouched. */

.layout--fullscreen-map .full-map-center {
align-items: center !important;
  box-sizing: border-box !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
  overflow: visible !important;
}

.layout--fullscreen-map .full-map-center > .action-builder:not(.action-builder--collapsed) {
align-self: center !important;
  width: calc(100% - 48px) !important;
  max-width: 1080px !important;
  min-width: 0 !important;
  margin: 10px auto !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}

.layout--fullscreen-map .full-map-center > .action-builder:not(.action-builder--collapsed) .action-builder__head,
.layout--fullscreen-map .full-map-center > .action-builder:not(.action-builder--collapsed) .action-slots,
.layout--fullscreen-map .full-map-center > .action-builder:not(.action-builder--collapsed) .action-strip {
min-width: 0 !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

.layout--fullscreen-map .full-map-center > .action-builder:not(.action-builder--collapsed) .action-strip {
grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
}

.layout--fullscreen-map .full-map-center > .action-builder--collapsed {
align-self: center !important;
  width: 100% !important;
  max-width: 1080px !important;
  margin: 10px auto !important;
  display: flex !important;
  justify-content: center !important;
  box-sizing: border-box !important;
}

/* Normal MAPA SPRAWY toolbar used to hide set-tab buttons. Keep the dedicated
   ROZMOWA shortcut visible there too, not only in FULL MAP. */

.map-tools--overlay .ui-btn--map-conversation {
display: inline-flex !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}

/* v94: FULL MAP action panel reuses the normal tabs-panel/action-builder shell.
   This restores the same outer frame as CLOSED MAP instead of a free-floating,
   visually clipped BUILD ACTION block. */

.layout--fullscreen-map .full-map-center {
align-items: stretch !important;
  padding-left: 10px !important;
  padding-right: 10px !important;
  overflow: visible !important;
}

.layout--fullscreen-map .full-map-center > .full-map-action-dock {
pointer-events: auto !important;
  align-self: stretch !important;
  justify-self: stretch !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 10px 0 !important;
  box-sizing: border-box !important;
  display: block !important;
  overflow: visible !important;
  background: var(--theme-panel-flat, rgba(5, 13, 22, 0.94)) !important;
  border: 1px solid var(--theme-border, rgba(46, 155, 255, 0.34)) !important;
  box-shadow: inset 0 0 8px rgba(0, 200, 255, 0.014), 0 0 8px rgba(0, 0, 0, 0.28) !important;
}

.layout--fullscreen-map .full-map-action-dock > .action-builder:not(.action-builder--collapsed) {
width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 10px !important;
  box-sizing: border-box !important;
  overflow: visible !important;
  background: var(--theme-panel-flat, rgba(5, 13, 22, 0.94)) !important;
  border-top: 1px solid rgba(46, 155, 255, 0.24) !important;
  border-right: 0 !important;
  border-bottom: 0 !important;
  border-left: 0 !important;
  box-shadow: none !important;
}

.layout--fullscreen-map .full-map-action-dock > .action-builder:not(.action-builder--collapsed) .action-slots {
overflow-x: auto !important;
  overflow-y: hidden !important;
}

/* The collapsed BUILD ACTION tab remains a centered standalone button. */

.layout--fullscreen-map .full-map-center > .action-builder--collapsed {
align-self: center !important;
  width: max-content !important;
  max-width: calc(100% - 20px) !important;
  margin: 10px auto !important;
}

/* ROZMOWA in the normal MAPA SPRAWY toolbar toggles the same transparent
   chat-scene overlay used by FULL MAP, rather than switching tabs. */

.map-view > .map-chat-panel--map-tab {
position: sticky !important;
  top: 54px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  z-index: 18 !important;
  width: min(860px, calc(100% - 24px)) !important;
  margin: 0 auto 12px !important;
}

.map-view > .map-chat-panel--map-tab .chat-scene {
height: clamp(240px, 38vh, 420px) !important;
  min-height: 240px !important;
  max-height: min(48vh, 420px) !important;
}

.map-view > .map-chat-panel--map-tab .chat-scene--transparent {
background: rgba(3, 7, 14, 0.58) !important;
}

/* v95: FULL MAP uses the exact same BUILD ACTION component as normal MAPA SPRAWY.
   The center column is a transparent .tabs-panel shell only so the selector
   .tabs-panel > .action-builder applies identically in both modes. */

.layout--fullscreen-map > .tabs-panel.full-map-center {
pointer-events: none !important;
  display: flex !important;
  flex-direction: column !important;
  min-width: 0 !important;
  min-height: 0 !important;
  overflow: visible !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

.layout--fullscreen-map > .tabs-panel.full-map-center > .full-map-center__tools,
.layout--fullscreen-map > .tabs-panel.full-map-center > .map-chat-panel,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder--collapsed {
pointer-events: auto !important;
}

.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder:not(.action-builder--collapsed) {
/* Match the normal tabs-panel > action-builder geometry/skin. */
  align-self: stretch !important;
  flex: 0 0 auto !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 10px 10px 10px !important;
  padding: 9px 12px 10px !important;
  box-sizing: border-box !important;
  overflow: visible !important;
  border: 1px solid rgba(46, 155, 255, 0.16) !important;
  border-top-color: rgba(46, 155, 255, 0.24) !important;
  background: linear-gradient(180deg, rgba(3, 7, 14, 0.58), rgba(5, 12, 22, 0.86)) !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder:not(.action-builder--collapsed) .action-builder__head,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder:not(.action-builder--collapsed) .action-slots,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder:not(.action-builder--collapsed) .action-strip {
min-width: 0 !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder:not(.action-builder--collapsed) .action-slots {
overflow-x: auto !important;
  overflow-y: hidden !important;
}

.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder--collapsed {
align-self: center !important;
  width: max-content !important;
  max-width: calc(100% - 20px) !important;
  margin: 10px auto !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

/* Normal MAPA SPRAWY ROZMOWA overlay should have the same transparent chat scene
   as FULL MAP: no image backdrop/portrait and the same translucent terminal glass. */

.map-view > .map-chat-panel--map-tab {
background: rgba(3, 7, 14, 0.50) !important;
  border: 1px solid rgba(0, 200, 255, 0.34) !important;
  box-shadow: inset 0 0 22px rgba(0, 200, 255, 0.04), 0 0 28px rgba(0, 0, 0, 0.38) !important;
  backdrop-filter: blur(3px) !important;
}

.map-view > .map-chat-panel--map-tab .chat-scene--transparent {
background: rgba(3, 7, 14, 0.34) !important;
  backdrop-filter: blur(2px) !important;
}

.map-view > .map-chat-panel--map-tab .chat-scene__bg,
.map-view > .map-chat-panel--map-tab .chat-scene__shade,
.map-view > .map-chat-panel--map-tab .chat-scene__portrait {
display: none !important;
}

/* v96: FULL MAP BUILD ACTION keeps the same opaque panel surface that the
   normal tabs-panel parent gives it in CLOSED MAP. The component/layout stays
   shared; this only restores the missing parent-like background in FULL MAP. */

.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder:not(.action-builder--collapsed) {
background: var(--theme-panel-flat, rgba(5, 13, 22, 0.94)) !important;
  box-shadow: inset 0 0 8px rgba(0, 200, 255, 0.014), 0 0 8px rgba(0, 0, 0, 0.28) !important;
}



/* v98: graceful empty-data boot screen. */
.interrogation-app--empty {
  display: grid;
  place-items: center;
  min-height: var(--interrogation-viewport-height, 100dvh);
  padding: 24px;
}

.empty-boot-panel {
  width: min(720px, calc(100vw - 48px));
  max-width: 720px;
}

.empty-state--boot {
  margin: 12px 0 16px;
  white-space: normal;
  line-height: 1.55;
}

.empty-boot-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

/* Lucide icon support. Icons are injected by js/view/dom_view.js and themed by currentColor. */
.ui-btn,
.tab-btn,
.icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

.ui-icon,
.panel-title-icon,
.inline-ui-icon {
  width: 1.05em;
  height: 1.05em;
  flex: 0 0 auto;
  stroke-width: 1.85;
  color: currentColor;
  filter: drop-shadow(0 0 4px color-mix(in srgb, currentColor 34%, transparent));
}

.panel-title-label,
.status-title-label,
.section-title-label,
.status-bucket-label {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-width: 0;
}

.ui-btn__label--sr {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* v98 polish: dossier filters are compact icon buttons with native tooltips. */
.filter-row--icons {
  gap: 4px;
  flex-wrap: nowrap;
  align-items: center;
  overflow: visible;
}

.filter-row--icons .dossier-filter-btn,
.filter-row--icons .ui-btn--icon-only {
  width: 26px;
  min-width: 26px;
  max-width: 26px;
  height: 26px;
  min-height: 26px;
  padding: 0;
  flex: 0 0 26px;
}

.filter-row--icons .ui-icon {
  width: 14px;
  height: 14px;
}

@media (max-width: 1040px) {
  .filter-row--icons .dossier-filter-btn,
  .filter-row--icons .ui-btn--icon-only {
    width: 24px;
    min-width: 24px;
    max-width: 24px;
    height: 24px;
    min-height: 24px;
  }
  .filter-row--icons {
    gap: 3px;
  }
}

/* v99 touch pass: consistent minimum targets and default vertical dossier filters. */
:root {
  --touch-target-min: 42px;
  --touch-target-icon: 42px;
  --dossier-filter-rail-width: 54px;
}

.ui-btn,
.tab-btn,
.icon-btn {
  min-width: var(--touch-target-min);
  min-height: var(--touch-target-min);
}

.ui-btn--compact {
  min-height: var(--touch-target-min) !important;
  padding: 6px 10px !important;
}

.icon-btn,
.panel-collapse-btn,
.ui-btn--icon-only {
  width: var(--touch-target-icon);
  min-width: var(--touch-target-icon);
  height: var(--touch-target-icon);
  min-height: var(--touch-target-icon);
  padding: 0 !important;
}

.tab-btn {
  min-height: 42px !important;
}

.ui-icon {
  width: 18px;
  height: 18px;
}

.dossier-panel:not(.dossier-panel--collapsed) {
  position: relative;
}

.dossier-panel:not(.dossier-panel--collapsed) > .panel__head,
.dossier-panel:not(.dossier-panel--collapsed) > .panel__body {
  padding-left: calc(var(--dossier-filter-rail-width) + 8px) !important;
}

.dossier-panel:not(.dossier-panel--collapsed) > .panel__head {
  min-height: 72px !important;
  flex-basis: 72px !important;
}

.dossier-filter-rail {
  position: absolute;
  z-index: 8;
  left: 7px;
  top: 8px;
  bottom: 10px;
  width: var(--dossier-filter-rail-width);
  margin: 0 !important;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 6px;
  flex-wrap: nowrap;
  overflow: visible;
}

.filter-row--icons.dossier-filter-rail .dossier-filter-btn,
.filter-row--icons.dossier-filter-rail .ui-btn--icon-only {
  width: 44px;
  min-width: 44px;
  max-width: 44px;
  height: 44px;
  min-height: 44px;
  flex: 0 0 44px;
  padding: 0 !important;
}

.filter-row--icons.dossier-filter-rail .ui-icon {
  width: 21px;
  height: 21px;
}

.filter-row--icons.dossier-filter-rail .ui-btn--active .ui-icon {
  transform: scale(1.06);
}

@media (max-height: 760px) {
  :root {
    --touch-target-min: 40px;
    --touch-target-icon: 40px;
    --dossier-filter-rail-width: 50px;
  }

  .filter-row--icons.dossier-filter-rail .dossier-filter-btn,
  .filter-row--icons.dossier-filter-rail .ui-btn--icon-only {
    width: 40px;
    min-width: 40px;
    max-width: 40px;
    height: 40px;
    min-height: 40px;
    flex-basis: 40px;
  }

  .filter-row--icons.dossier-filter-rail .ui-icon {
    width: 19px;
    height: 19px;
  }
}

/* v100 touch/folder-tab pass: filters become edge tabs, while collapse controls stay compact. */
:root {
  --touch-target-min: 40px;
  --touch-target-icon: 38px;
  --dossier-filter-rail-width: 42px;
}

.ui-btn,
.tab-btn,
.icon-btn {
  min-width: var(--touch-target-min);
  min-height: var(--touch-target-min);
}

.ui-btn--compact {
  min-height: 38px !important;
  padding: 6px 10px !important;
}

.icon-btn,
.panel-collapse-btn,
.topbar__collapse,
.topbar__gear,
.map-zoom-btn,
.ui-btn--icon-only:not(.dossier-filter-btn) {
  width: var(--touch-target-icon) !important;
  min-width: var(--touch-target-icon) !important;
  max-width: var(--touch-target-icon) !important;
  height: var(--touch-target-icon) !important;
  min-height: var(--touch-target-icon) !important;
  padding: 0 !important;
}

.panel-collapse-btn .ui-icon,
.topbar__collapse .ui-icon,
.topbar__gear .ui-icon,
.map-zoom-btn .ui-icon,
.icon-btn .ui-icon {
  width: 18px;
  height: 18px;
}

.panel__title-tools,
.topbar__user-line {
  gap: 8px;
}

.topbar__user-line {
  padding-right: 4px;
}

.panel-title-label,
.status-title-label,
.section-title-label,
.status-bucket-label,
.ui-btn:not(.ui-btn--icon-only) {
  gap: 8px;
}

.panel-title-icon,
.status-title-label .panel-title-icon,
.section-title-label .panel-title-icon,
.status-bucket-label .panel-title-icon {
  margin-right: 1px;
}

.dossier-panel:not(.dossier-panel--collapsed) {
  position: relative;
}

.dossier-panel:not(.dossier-panel--collapsed) > .panel__head {
  padding-left: 12px !important;
  min-height: 72px !important;
  flex: 0 0 72px !important;
}

.dossier-panel:not(.dossier-panel--collapsed) > .panel__body {
  padding-left: calc(var(--dossier-filter-rail-width) + 10px) !important;
}

.dossier-filter-rail,
.filter-row--icons.dossier-filter-rail {
  position: absolute !important;
  z-index: 8;
  left: 0 !important;
  top: 72px !important;
  bottom: 10px !important;
  width: var(--dossier-filter-rail-width) !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  justify-content: flex-start !important;
  gap: 0 !important;
  flex-wrap: nowrap !important;
  overflow: visible !important;
}

.filter-row--icons.dossier-filter-rail .dossier-filter-btn,
.filter-row--icons.dossier-filter-rail .ui-btn--icon-only.dossier-filter-btn {
  width: var(--dossier-filter-rail-width) !important;
  min-width: var(--dossier-filter-rail-width) !important;
  max-width: var(--dossier-filter-rail-width) !important;
  height: 45px !important;
  min-height: 45px !important;
  flex: 0 0 45px !important;
  margin: 0 !important;
  padding: 0 !important;
  border-left-width: 0 !important;
  border-radius: 0 5px 5px 0 !important;
}

.filter-row--icons.dossier-filter-rail .dossier-filter-btn + .dossier-filter-btn {
  margin-top: -1px !important;
}

.filter-row--icons.dossier-filter-rail .ui-icon {
  width: 22px !important;
  height: 22px !important;
}

.filter-row--icons.dossier-filter-rail .ui-btn--active .ui-icon {
  transform: scale(1.05);
}

@media (max-height: 760px) {
  :root {
    --touch-target-min: 38px;
    --touch-target-icon: 36px;
    --dossier-filter-rail-width: 40px;
  }

  .filter-row--icons.dossier-filter-rail .dossier-filter-btn,
  .filter-row--icons.dossier-filter-rail .ui-btn--icon-only.dossier-filter-btn {
    height: 41px !important;
    min-height: 41px !important;
    flex-basis: 41px !important;
  }

  .filter-row--icons.dossier-filter-rail .ui-icon {
    width: 20px !important;
    height: 20px !important;
  }
}

/* v101 filter-rail refinement: flatter folder tabs, active tab on top, and a gap between mode and type filters. */
:root {
  --dossier-filter-rail-width: 42px;
}

.filter-row--icons.dossier-filter-rail .dossier-filter-btn,
.filter-row--icons.dossier-filter-rail .ui-btn--icon-only.dossier-filter-btn {
  position: relative !important;
  z-index: 1;
  border-radius: 0 2px 2px 0 !important;
}

.filter-row--icons.dossier-filter-rail .dossier-filter-btn:hover,
.filter-row--icons.dossier-filter-rail .dossier-filter-btn:focus-visible {
  z-index: 6;
}

.filter-row--icons.dossier-filter-rail .dossier-filter-btn.ui-btn--active,
.filter-row--icons.dossier-filter-rail .ui-btn--icon-only.dossier-filter-btn.ui-btn--active {
  z-index: 12;
}

.filter-row--icons.dossier-filter-rail .dossier-filter-btn:nth-child(3) {
  margin-top: 10px !important;
}

.filter-row--icons.dossier-filter-rail .dossier-filter-btn:nth-child(3)::before {
  content: "";
  position: absolute;
  left: 6px;
  right: 6px;
  top: -6px;
  height: 1px;
  background: color-mix(in srgb, var(--c-line) 56%, transparent);
  opacity: 0.72;
  pointer-events: none;
}

@media (max-height: 760px) {
  .filter-row--icons.dossier-filter-rail .dossier-filter-btn:nth-child(3) {
    margin-top: 8px !important;
  }

  .filter-row--icons.dossier-filter-rail .dossier-filter-btn:nth-child(3)::before {
    top: -5px;
  }
}



/* v103 dossier polish: remove the dossier header separator and add fact-type icons on cards. */
.dossier-panel:not(.dossier-panel--collapsed) > .panel__head {
  border-bottom-color: transparent !important;
}

.card__type {
  display: flex;
  align-items: center;
  gap: 5px;
}

.card__type-icon {
  width: 12px;
  height: 12px;
  flex: 0 0 12px;
  color: currentColor;
  stroke: currentColor;
}

.card__type-label {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dossier-panel .card__type-icon {
  width: 11px;
  height: 11px;
  flex-basis: 11px;
}

/* v104 dossier/header polish: align first group with filter rail and make fact icons stronger. */
.dossier-panel:not(.dossier-panel--collapsed) > .panel__body {
  padding-top: 0 !important;
}

.dossier-panel .dossier-list,
.dossier-panel .dossier-group:first-child,
.dossier-panel .dossier-group:first-child .section-title {
  margin-top: 0 !important;
}

.status-panel:not(.status-panel--collapsed) > .panel__head .panel__title,
.status-panel .panel__title--status {
  display: flex !important;
  width: 100% !important;
  justify-content: space-between !important;
  align-items: center !important;
}

.status-panel .panel__title-tools {
  margin-left: auto !important;
  justify-content: flex-end !important;
}

.status-panel .panel-collapse-btn {
  margin-left: auto !important;
  margin-right: 0 !important;
}

.card__type {
  gap: 7px !important;
}

.card__type-icon {
  width: 18px !important;
  height: 18px !important;
  flex: 0 0 18px !important;
  color: var(--accent, var(--c-cyan)) !important;
  stroke: currentColor !important;
  stroke-width: 2.05 !important;
  filter: none !important;
}

.dossier-panel .card__type-icon,
.card--action-slot .card__type-icon,
.map-node--full-card .card__type-icon {
  width: 20px !important;
  height: 20px !important;
  flex-basis: 20px !important;
}

.dossier-panel .card__type-label,
.card--action-slot .card__type-label,
.map-node--full-card .card__type-label {
  line-height: 1.1;
}

.dossier-filter-btn[data-value="active"] .ui-icon { color: var(--c-red) !important; }
.dossier-filter-btn[data-value="all"] .ui-icon { color: var(--c-cyan) !important; }
.dossier-filter-btn[data-value="evidence"] .ui-icon { color: var(--c-cyan) !important; }
.dossier-filter-btn[data-value="claims"] .ui-icon { color: var(--c-green) !important; }
.dossier-filter-btn[data-value="emotion"] .ui-icon { color: var(--c-purple) !important; }
.dossier-filter-btn[data-value="apparatus"] .ui-icon { color: var(--c-blue) !important; }
.dossier-filter-btn[data-value="leads"] .ui-icon { color: var(--c-orange) !important; }

/* v105 fact-card icon pass: type icons sit beside type+title, while non-map cards use neutral frames. */
:root {
  --fact-card-bg: rgba(7, 16, 27, 0.94);
  --fact-card-bg-hover: rgba(9, 21, 35, 0.97);
  --fact-card-border: rgba(46, 155, 255, 0.26);
  --fact-card-border-hover: rgba(46, 155, 255, 0.48);
  --fact-card-selected-border: var(--c-white);
  --fact-card-hover-glow: rgba(0, 200, 255, 0.20);
}

.card:not(.map-node) {
  background: var(--fact-card-bg) !important;
  border-color: var(--fact-card-border) !important;
  border-left-color: var(--fact-card-border) !important;
  box-shadow: inset 0 0 16px rgba(0, 200, 255, 0.025) !important;
}

.card:not(.map-node):hover,
.card:not(.map-node):focus-visible {
  background: var(--fact-card-bg-hover) !important;
  border-color: var(--fact-card-border-hover) !important;
  border-left-color: var(--fact-card-border-hover) !important;
  box-shadow:
    0 0 14px var(--fact-card-hover-glow),
    inset 0 0 16px rgba(255, 255, 255, 0.025) !important;
}

.card:not(.map-node).card--selected {
  border-color: var(--fact-card-selected-border) !important;
  border-left-color: var(--fact-card-selected-border) !important;
}

.card:not(.map-node) .card__image {
  border-color: var(--fact-card-border) !important;
}

.card__head {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  min-width: 0;
  padding-right: 68px;
}

.card__head-copy {
  min-width: 0;
  flex: 1 1 auto;
}

.card__fact-icon,
.card__type-icon {
  width: 22px !important;
  height: 22px !important;
  flex: 0 0 22px !important;
  color: var(--accent, var(--c-cyan)) !important;
  stroke: currentColor !important;
  stroke-width: 2.05 !important;
  filter: none !important;
}

.card__type {
  padding-right: 0 !important;
  color: var(--accent, var(--c-cyan)) !important;
}

.card__type-label {
  color: var(--accent, var(--c-cyan)) !important;
}

.card__title {
  margin-top: 4px !important;
}

.dossier-panel .card__head {
  gap: 7px;
  padding-right: 52px;
}

.dossier-panel .card__fact-icon,
.dossier-panel .card__type-icon,
.card--action-slot .card__fact-icon,
.card--action-slot .card__type-icon,
.map-node--full-card .card__fact-icon,
.map-node--full-card .card__type-icon {
  width: 22px !important;
  height: 22px !important;
  flex-basis: 22px !important;
}

.map-node:not(.map-node--full-card) {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 8px !important;
  padding: 8px 10px !important;
}

.map-node__copy {
  display: flex;
  min-width: 0;
  flex: 1 1 auto;
  flex-direction: column;
  gap: 4px;
}

.map-node__type,
.map-node__title {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.map-node__fact-icon {
  width: 24px !important;
  height: 24px !important;
  flex: 0 0 24px !important;
  color: var(--accent, var(--c-cyan)) !important;
  stroke: currentColor !important;
  stroke-width: 2.05 !important;
  filter: none !important;
}

/* Active/all mode icons are neutral, while fact-type filters keep their semantic colors. */
.dossier-filter-btn[data-value="active"] .ui-icon { color: var(--c-cyan) !important; }
.dossier-filter-btn[data-value="all"] .ui-icon { color: var(--c-muted) !important; }
.dossier-filter-btn[data-value="evidence"] .ui-icon { color: var(--c-cyan) !important; }
.dossier-filter-btn[data-value="claims"] .ui-icon { color: var(--c-green) !important; }
.dossier-filter-btn[data-value="emotion"] .ui-icon { color: var(--c-purple) !important; }
.dossier-filter-btn[data-value="apparatus"] .ui-icon { color: var(--c-blue) !important; }
.dossier-filter-btn[data-value="leads"] .ui-icon { color: var(--c-orange) !important; }

/* v106: red selected fact frames, flatter dossier cards, and symmetric dossier collapse control. */
:root {
  --fact-card-selected-border: var(--c-red);
}

.card.card--selected,
.card:not(.map-node).card--selected,
.map-node.map-node--selected {
  border-color: var(--c-red) !important;
  border-left-color: var(--c-red) !important;
}

.dossier-panel .card,
.dossier-panel .card:hover,
.dossier-panel .card:focus-visible,
.dossier-panel .card.card--selected {
  border-left-width: 1px !important;
}

.dossier-panel:not(.dossier-panel--collapsed) > .panel__head {
  position: relative !important;
  padding-left: calc(var(--dossier-filter-rail-width) + 10px) !important;
  padding-right: 12px !important;
}

.dossier-panel:not(.dossier-panel--collapsed) > .panel__head .panel__title {
  min-width: 0;
  width: 100%;
}

.dossier-panel:not(.dossier-panel--collapsed) > .panel__head .panel-title-label {
  min-width: 0;
}

.dossier-panel:not(.dossier-panel--collapsed) > .panel__head .panel__title-tools {
  margin-left: auto !important;
  min-width: max-content;
}

.dossier-panel:not(.dossier-panel--collapsed) > .panel__head .panel-collapse-btn {
  position: absolute !important;
  left: 0 !important;
  top: 8px !important;
  width: var(--dossier-filter-rail-width) !important;
  min-width: var(--dossier-filter-rail-width) !important;
  height: 48px !important;
  min-height: 48px !important;
  margin: 0 !important;
  border-radius: 0 2px 2px 0 !important;
  padding: 0 !important;
  z-index: 14;
}

.dossier-panel:not(.dossier-panel--collapsed) > .panel__head .panel-collapse-btn .ui-icon {
  margin: 0 !important;
}

/* Keep selected cards clean: red frame only, hover glow remains reserved for unselected hover. */
.card.card--selected:hover,
.card.card--selected:focus-visible,
.card:not(.map-node).card--selected:hover,
.card:not(.map-node).card--selected:focus-visible {
  border-color: var(--c-red) !important;
  border-left-color: var(--c-red) !important;
}

/* v107: preserve semantic fact colors, selected-red frames, and tab-like collapse buttons. */
:root {
  --fact-selected-glow: rgba(255, 51, 87, 0.46);
}

.card.card--selected,
.card:not(.map-node).card--selected,
.map-node.map-node--selected {
  border-color: var(--c-red) !important;
  border-left-color: var(--c-red) !important;
}

.card.card--selected .card__type,
.card.card--selected .card__type-label,
.card.card--selected .card__fact-icon,
.card.card--selected .card__type-icon,
.card.card--selected .card__tags,
.map-node.map-node--selected .map-node__type,
.map-node.map-node--selected .map-node__fact-icon {
  color: var(--accent, var(--c-cyan)) !important;
  stroke: currentColor !important;
}

.card.card--selected .card__title,
.map-node.map-node--selected .map-node__title {
  color: var(--c-white) !important;
}

.card.card--selected .card__body {
  color: var(--c-muted) !important;
}

.card.card--selected:not(:hover):not(:focus-visible),
.card:not(.map-node).card--selected:not(:hover):not(:focus-visible),
.map-node.map-node--selected:not(:hover):not(:focus-visible) {
  box-shadow: none !important;
}

.card.card--selected:hover,
.card.card--selected:focus-visible,
.card:not(.map-node).card--selected:hover,
.card:not(.map-node).card--selected:focus-visible,
.map-node.map-node--selected:hover,
.map-node.map-node--selected:focus-visible {
  border-color: var(--c-red) !important;
  border-left-color: var(--c-red) !important;
  box-shadow: 0 0 18px var(--fact-selected-glow), inset 0 0 14px rgba(255, 51, 87, 0.08) !important;
}

.dossier-panel:not(.dossier-panel--collapsed) > .panel__head .panel-collapse-btn {
  left: -1px !important;
}

.status-panel:not(.status-panel--collapsed) > .panel__head {
  position: relative !important;
  padding-right: calc(var(--dossier-filter-rail-width) + 10px) !important;
  padding-left: 12px !important;
}

.status-panel:not(.status-panel--collapsed) > .panel__head .panel__title {
  width: 100% !important;
  min-width: 0 !important;
}

.status-panel:not(.status-panel--collapsed) > .panel__head .panel__title-tools {
  margin-left: auto !important;
  min-width: max-content !important;
}

.status-panel:not(.status-panel--collapsed) > .panel__head .panel-collapse-btn {
  position: absolute !important;
  right: -1px !important;
  top: 8px !important;
  width: var(--dossier-filter-rail-width) !important;
  min-width: var(--dossier-filter-rail-width) !important;
  height: 48px !important;
  min-height: 48px !important;
  margin: 0 !important;
  border-radius: 2px 0 0 2px !important;
  padding: 0 !important;
  z-index: 14;
}

.status-panel:not(.status-panel--collapsed) > .panel__head .panel-collapse-btn .ui-icon {
  margin: 0 !important;
}

/* v108: compact symmetric side headers and non-overlapping folder-tab collapse buttons. */
:root {
  --side-panel-header-height: 58px;
  --side-panel-tab-height: 50px;
}

.dossier-panel:not(.dossier-panel--collapsed) > .panel__head,
.status-panel:not(.status-panel--collapsed) > .panel__head {
  flex: 0 0 var(--side-panel-header-height) !important;
  min-height: var(--side-panel-header-height) !important;
  height: var(--side-panel-header-height) !important;
  padding-top: 7px !important;
  padding-bottom: 7px !important;
  box-sizing: border-box !important;
  align-items: center !important;
}

.dossier-panel:not(.dossier-panel--collapsed) > .panel__head {
  padding-left: calc(var(--dossier-filter-rail-width) + 10px) !important;
  padding-right: 12px !important;
}

.status-panel:not(.status-panel--collapsed) > .panel__head {
  padding-left: 12px !important;
  padding-right: calc(var(--dossier-filter-rail-width) + 10px) !important;
}

.dossier-panel:not(.dossier-panel--collapsed) > .panel__head .panel__title,
.status-panel:not(.status-panel--collapsed) > .panel__head .panel__title {
  min-height: 0 !important;
  height: 100% !important;
  align-items: center !important;
}

.dossier-panel:not(.dossier-panel--collapsed) > .panel__head .panel-title-label,
.status-panel:not(.status-panel--collapsed) > .panel__head .panel-title-label {
  line-height: 1.15 !important;
}

.dossier-panel:not(.dossier-panel--collapsed) > .panel__head .panel-collapse-btn,
.status-panel:not(.status-panel--collapsed) > .panel__head .panel-collapse-btn {
  top: 4px !important;
  height: var(--side-panel-tab-height) !important;
  min-height: var(--side-panel-tab-height) !important;
  max-height: var(--side-panel-tab-height) !important;
}

.dossier-filter-rail,
.filter-row--icons.dossier-filter-rail {
  top: var(--side-panel-header-height) !important;
}

.dossier-panel:not(.dossier-panel--collapsed) > .panel__body,
.status-panel:not(.status-panel--collapsed) > .panel__body {
  min-height: 0 !important;
}


/* v109: keep fact card titles on one line and remove framed dossier section dividers. */
.card__title,
.card__head-copy .card__title,
.dossier-panel .card__title,
.card--action-slot .card__title,
.map-node--full-card .card__title {
  display: block !important;
  max-width: 100% !important;
  min-width: 0 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.card__head-copy,
.dossier-panel .card__head-copy,
.card--action-slot .card__head-copy,
.map-node--full-card .card__head-copy {
  min-width: 0 !important;
  max-width: 100% !important;
  overflow: hidden !important;
}

.dossier-panel .section-title {
  border-color: transparent !important;
  background: transparent !important;
  box-shadow: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

:root[data-theme="dark"] .dossier-panel .section-title,
:root[data-theme="classic"] .dossier-panel .section-title,
:root[data-theme="terminal"] .dossier-panel .section-title,
:root[data-theme="concept_art"] .dossier-panel .section-title {
  border-color: transparent !important;
  background: transparent !important;
  box-shadow: none !important;
}

/* v110: top/bottom collapse controls use the same folder-tab language as side panels. */
:root {
  --edge-panel-tab-width: 54px;
  --edge-panel-tab-height: 38px;
}

.topbar,
.topbar--collapsed,
.action-builder,
.action-builder--collapsed {
  position: relative !important;
  overflow: visible !important;
}

.topbar__user-line {
  justify-content: flex-end !important;
}

.panel-collapse-rail--top,
.panel-collapse-rail--bottom.action-collapse-tab {
  position: absolute !important;
  left: 50% !important;
  width: var(--edge-panel-tab-width) !important;
  min-width: var(--edge-panel-tab-width) !important;
  max-width: var(--edge-panel-tab-width) !important;
  height: var(--edge-panel-tab-height) !important;
  min-height: var(--edge-panel-tab-height) !important;
  max-height: var(--edge-panel-tab-height) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
  font-size: 20px !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  z-index: 26 !important;
}

.panel-collapse-rail--top {
  top: -1px !important;
  transform: translateX(-50%) !important;
  border-radius: 0 0 2px 2px !important;
}

.panel-collapse-rail--bottom.action-collapse-tab {
  bottom: -1px !important;
  transform: translateX(-50%) !important;
  border-radius: 2px 2px 0 0 !important;
}

.topbar:not(.topbar--collapsed) .topbar-collapse-tab {
  top: -1px !important;
}

.topbar--collapsed {
  min-height: var(--edge-panel-tab-height) !important;
  height: var(--edge-panel-tab-height) !important;
  display: block !important;
  padding: 0 !important;
}

.topbar--collapsed .topbar-collapse-tab {
  top: 0 !important;
}

.app-shell--topbar-collapsed {
  grid-template-rows: var(--edge-panel-tab-height) minmax(0, 1fr) !important;
}

/* The top tab sits above the department line, so nudge the centered label down a little. */
.topbar:not(.topbar--collapsed) .topbar__center {
  padding-top: 13px !important;
  box-sizing: border-box !important;
}

.topbar-tab {
  display: none !important;
}

.action-builder:not(.action-builder--collapsed) {
  padding-bottom: calc(var(--edge-panel-tab-height) + 8px) !important;
}

.action-builder--collapsed,
.tabs-panel > .action-builder--collapsed {
  align-self: stretch !important;
  width: auto !important;
  max-width: none !important;
  height: var(--edge-panel-tab-height) !important;
  min-height: var(--edge-panel-tab-height) !important;
  margin: 0 10px 10px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.action-builder--collapsed .action-collapse-tab {
  bottom: 0 !important;
}

.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder--collapsed {
  align-self: stretch !important;
  width: auto !important;
  max-width: none !important;
  height: var(--edge-panel-tab-height) !important;
  min-height: var(--edge-panel-tab-height) !important;
  margin: 8px 10px 10px !important;
}

.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder--collapsed .action-collapse-tab {
  bottom: 0 !important;
}

@media (max-height: 760px) {
  :root {
    --edge-panel-tab-height: 34px;
    --edge-panel-tab-width: 50px;
  }

  .panel-collapse-rail--top,
  .panel-collapse-rail--bottom.action-collapse-tab {
    font-size: 18px !important;
  }

  .topbar:not(.topbar--collapsed) .topbar__center {
    padding-top: 10px !important;
  }
}


/* v111: make top/bottom tabs compact, let BUILD ACTION tab overlap outward instead of enlarging the panel,
   and make collapsed side restore buttons mirror the expanded folder-tab controls. */
:root {
  --edge-panel-tab-width: 58px;
  --edge-panel-tab-height: 30px;
  --edge-panel-action-tab-height: 36px;
}

.panel-collapse-rail--top {
  width: var(--edge-panel-tab-width) !important;
  min-width: var(--edge-panel-tab-width) !important;
  max-width: var(--edge-panel-tab-width) !important;
  height: var(--edge-panel-tab-height) !important;
  min-height: var(--edge-panel-tab-height) !important;
  max-height: var(--edge-panel-tab-height) !important;
  font-size: 16px !important;
}

.topbar--collapsed {
  min-height: var(--edge-panel-tab-height) !important;
  height: var(--edge-panel-tab-height) !important;
}

.app-shell--topbar-collapsed {
  grid-template-rows: var(--edge-panel-tab-height) minmax(0, 1fr) !important;
}

.topbar:not(.topbar--collapsed) .topbar__center {
  padding-top: 7px !important;
}

.panel-collapse-rail--bottom.action-collapse-tab {
  width: var(--edge-panel-tab-width) !important;
  min-width: var(--edge-panel-tab-width) !important;
  max-width: var(--edge-panel-tab-width) !important;
  height: var(--edge-panel-action-tab-height) !important;
  min-height: var(--edge-panel-action-tab-height) !important;
  max-height: var(--edge-panel-action-tab-height) !important;
  bottom: calc(-1 * var(--edge-panel-action-tab-height) + 1px) !important;
  font-size: 16px !important;
}

.action-builder:not(.action-builder--collapsed) {
  padding-bottom: 10px !important;
}

.action-builder--collapsed,
.tabs-panel > .action-builder--collapsed,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder--collapsed {
  height: 0 !important;
  min-height: 0 !important;
  max-height: 0 !important;
  margin: 0 10px 10px !important;
  padding: 0 !important;
  overflow: visible !important;
}

.action-builder--collapsed .action-collapse-tab,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder--collapsed .action-collapse-tab {
  bottom: calc(-1 * var(--edge-panel-action-tab-height) + 1px) !important;
}

/* Collapsed side panels should restore via the same tab geometry and position as the open-panel collapse tabs. */
.dossier-panel--collapsed,
.status-panel--collapsed,
.full-map-stage__dossier .dossier-panel--collapsed,
.full-map-stage__status .status-panel--collapsed {
  position: relative !important;
  overflow: visible !important;
  min-width: var(--dossier-filter-rail-width) !important;
  width: var(--dossier-filter-rail-width) !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.dossier-panel--collapsed .panel-collapse-rail--left,
.status-panel--collapsed .panel-collapse-rail--right,
.full-map-stage__dossier .dossier-panel--collapsed .panel-collapse-rail--left,
.full-map-stage__status .status-panel--collapsed .panel-collapse-rail--right {
  position: absolute !important;
  top: 4px !important;
  width: var(--dossier-filter-rail-width) !important;
  min-width: var(--dossier-filter-rail-width) !important;
  max-width: var(--dossier-filter-rail-width) !important;
  height: var(--side-panel-tab-height) !important;
  min-height: var(--side-panel-tab-height) !important;
  max-height: var(--side-panel-tab-height) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
  transform: none !important;
  letter-spacing: 0 !important;
  font-size: 18px !important;
  line-height: 1 !important;
  z-index: 30 !important;
}

.dossier-panel--collapsed .panel-collapse-rail--left,
.full-map-stage__dossier .dossier-panel--collapsed .panel-collapse-rail--left {
  left: -1px !important;
  border-radius: 0 2px 2px 0 !important;
  border-left-width: 0 !important;
  border-right-width: 1px !important;
}

.status-panel--collapsed .panel-collapse-rail--right,
.full-map-stage__status .status-panel--collapsed .panel-collapse-rail--right {
  right: -1px !important;
  border-radius: 2px 0 0 2px !important;
  border-right-width: 0 !important;
  border-left-width: 1px !important;
}

@media (max-height: 760px) {
  :root {
    --edge-panel-tab-width: 54px;
    --edge-panel-tab-height: 28px;
    --edge-panel-action-tab-height: 34px;
  }

  .panel-collapse-rail--top,
  .panel-collapse-rail--bottom.action-collapse-tab {
    font-size: 15px !important;
  }

  .topbar:not(.topbar--collapsed) .topbar__center {
    padding-top: 6px !important;
  }
}

/* v112: normalize edge-tab geometry.
   Header/action tabs are fixed-size folder tabs. Collapsed side-panel restore tabs
   use the same top position as the expanded minimize tabs. */
:root {
  --edge-panel-tab-width: 58px;
  --edge-panel-tab-height: 30px;
  --edge-panel-action-tab-height: 34px;
}

/* Top HUD tab: never stretch with the topbar/full-map container. */
.panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.topbar .panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.topbar--collapsed .panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.full-map-stage__top .topbar .panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.full-map-stage__top .topbar.topbar--collapsed .panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.full-map-stage__top .topbar.topbar--full-map-collapsed .panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab {
  position: absolute !important;
  left: 50% !important;
  top: -1px !important;
  bottom: auto !important;
  width: var(--edge-panel-tab-width) !important;
  min-width: var(--edge-panel-tab-width) !important;
  max-width: var(--edge-panel-tab-width) !important;
  height: var(--edge-panel-tab-height) !important;
  min-height: var(--edge-panel-tab-height) !important;
  max-height: var(--edge-panel-tab-height) !important;
  padding: 0 !important;
  transform: translateX(-50%) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
  line-height: 1 !important;
  font-size: 15px !important;
  border-radius: 0 0 2px 2px !important;
}

.topbar--collapsed,
.full-map-stage__top .topbar.topbar--collapsed,
.full-map-stage__top .topbar.topbar--full-map-collapsed {
  height: var(--edge-panel-tab-height) !important;
  min-height: var(--edge-panel-tab-height) !important;
  max-height: var(--edge-panel-tab-height) !important;
  padding: 0 !important;
  display: block !important;
  overflow: visible !important;
}

.app-shell--topbar-collapsed,
.full-map-stage--top-collapsed .full-map-stage__shell {
  grid-template-rows: var(--edge-panel-tab-height) minmax(0, 1fr) !important;
}

/* Bottom BUILD ACTION tab: visible full height, but pulled out of layout so it does not enlarge the action panel. */
.action-builder--collapsed,
.tabs-panel > .action-builder--collapsed,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder--collapsed,
.full-map-center > .action-builder--collapsed {
  position: relative !important;
  height: var(--edge-panel-action-tab-height) !important;
  min-height: var(--edge-panel-action-tab-height) !important;
  max-height: var(--edge-panel-action-tab-height) !important;
  margin: calc(-1 * var(--edge-panel-action-tab-height) + 1px) 10px 10px !important;
  padding: 0 !important;
  overflow: visible !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.action-builder--collapsed .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder--collapsed .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.full-map-center > .action-builder--collapsed .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab {
  position: absolute !important;
  left: 50% !important;
  top: 0 !important;
  bottom: auto !important;
  width: var(--edge-panel-tab-width) !important;
  min-width: var(--edge-panel-tab-width) !important;
  max-width: var(--edge-panel-tab-width) !important;
  height: var(--edge-panel-action-tab-height) !important;
  min-height: var(--edge-panel-action-tab-height) !important;
  max-height: var(--edge-panel-action-tab-height) !important;
  padding: 0 !important;
  transform: translateX(-50%) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
  line-height: 1 !important;
  font-size: 15px !important;
  border-radius: 2px 2px 0 0 !important;
}

.action-builder:not(.action-builder--collapsed) {
  padding-bottom: 10px !important;
}

/* Collapsed side panels: same coordinates as the minimize tabs, not vertical center rails. */
.dossier-panel--collapsed,
.status-panel--collapsed,
.full-map-stage__dossier .dossier-panel--collapsed,
.full-map-stage__status .status-panel--collapsed {
  align-self: start !important;
  justify-self: stretch !important;
  position: relative !important;
  width: var(--dossier-filter-rail-width) !important;
  min-width: var(--dossier-filter-rail-width) !important;
  max-width: var(--dossier-filter-rail-width) !important;
  height: var(--side-panel-header-height) !important;
  min-height: var(--side-panel-header-height) !important;
  max-height: var(--side-panel-header-height) !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.dossier-panel--collapsed .panel-collapse-rail--left,
.status-panel--collapsed .panel-collapse-rail--right,
.full-map-stage__dossier .dossier-panel--collapsed .panel-collapse-rail--left,
.full-map-stage__status .status-panel--collapsed .panel-collapse-rail--right {
  top: 4px !important;
  height: var(--side-panel-tab-height) !important;
  min-height: var(--side-panel-tab-height) !important;
  max-height: var(--side-panel-tab-height) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  font-size: 18px !important;
  line-height: 1 !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
  transform: none !important;
}

.dossier-panel--collapsed .panel-collapse-rail--left,
.full-map-stage__dossier .dossier-panel--collapsed .panel-collapse-rail--left {
  position: absolute !important;
  left: -1px !important;
  right: auto !important;
}

.status-panel--collapsed .panel-collapse-rail--right,
.full-map-stage__status .status-panel--collapsed .panel-collapse-rail--right {
  position: absolute !important;
  right: -1px !important;
  left: auto !important;
}


/* v113: make BUILD ACTION edge tab match the compact top HUD tab and sit on the bottom edge. */
:root {
  --edge-panel-action-tab-height: var(--edge-panel-tab-height);
}

.panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.action-builder .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.action-builder--collapsed .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder--collapsed .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.full-map-center > .action-builder .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.full-map-center > .action-builder--collapsed .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab {
  width: var(--edge-panel-tab-width) !important;
  min-width: var(--edge-panel-tab-width) !important;
  max-width: var(--edge-panel-tab-width) !important;
  height: var(--edge-panel-tab-height) !important;
  min-height: var(--edge-panel-tab-height) !important;
  max-height: var(--edge-panel-tab-height) !important;
  top: auto !important;
  bottom: -1px !important;
  transform: translateX(-50%) !important;
  border-radius: 2px 2px 0 0 !important;
}

.action-builder:not(.action-builder--collapsed),
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder:not(.action-builder--collapsed),
.full-map-center > .action-builder:not(.action-builder--collapsed) {
  overflow: visible !important;
  padding-bottom: 10px !important;
}

.action-builder--collapsed,
.tabs-panel > .action-builder--collapsed,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder--collapsed,
.full-map-center > .action-builder--collapsed {
  height: var(--edge-panel-tab-height) !important;
  min-height: var(--edge-panel-tab-height) !important;
  max-height: var(--edge-panel-tab-height) !important;
  margin: calc(-1 * var(--edge-panel-tab-height) + 1px) 10px 10px !important;
  padding: 0 !important;
  overflow: visible !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.action-builder--collapsed .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder--collapsed .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.full-map-center > .action-builder--collapsed .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab {
  bottom: -1px !important;
}


/* v114: move BUILD ACTION tab to the lower edge-panel and make collapse/restore
   controls read as connected tabs instead of framed buttons. */
:root {
  --edge-panel-tab-width: 58px;
  --edge-panel-tab-height: 30px;
  --edge-panel-tab-lower-offset: calc(-1 * var(--edge-panel-tab-height) + 1px);
}

/* Every centered edge control keeps the compact geometry from the top HUD tab. */
.panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.topbar .panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.topbar--collapsed .panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.full-map-stage__top .topbar .panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.full-map-stage__top .topbar.topbar--collapsed .panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.full-map-stage__top .topbar.topbar--full-map-collapsed .panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.action-builder .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.action-builder--collapsed .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder--collapsed .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.full-map-center > .action-builder .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.full-map-center > .action-builder--collapsed .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab {
  width: var(--edge-panel-tab-width) !important;
  min-width: var(--edge-panel-tab-width) !important;
  max-width: var(--edge-panel-tab-width) !important;
  height: var(--edge-panel-tab-height) !important;
  min-height: var(--edge-panel-tab-height) !important;
  max-height: var(--edge-panel-tab-height) !important;
  padding: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
  font-size: 14px !important;
  z-index: 90 !important;
}

/* Top tab: attached to the top frame, no lower lip while expanded/restored. */
.panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.topbar .panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.topbar--collapsed .panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.full-map-stage__top .topbar .panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.full-map-stage__top .topbar.topbar--collapsed .panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.full-map-stage__top .topbar.topbar--full-map-collapsed .panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab {
  top: -1px !important;
  bottom: auto !important;
  border-radius: 0 0 2px 2px !important;
  border-bottom-width: 0 !important;
}

/* Expanded BUILD ACTION: tab is now one panel lower, attached to the lower edge.
   It does not reserve layout height and does not cover the action buttons. */
.action-builder:not(.action-builder--collapsed) .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder:not(.action-builder--collapsed) .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.full-map-center > .action-builder:not(.action-builder--collapsed) .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab {
  top: auto !important;
  bottom: var(--edge-panel-tab-lower-offset) !important;
  border-radius: 2px 2px 0 0 !important;
  border-bottom-width: 0 !important;
}

/* Collapsed BUILD ACTION restore tab keeps the same compact tab skin. */
.action-builder--collapsed .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder--collapsed .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.full-map-center > .action-builder--collapsed .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab {
  top: auto !important;
  bottom: -1px !important;
  border-radius: 2px 2px 0 0 !important;
  border-bottom-width: 0 !important;
}

/* Let the lower protruding tab cross the panel edge without changing panel height. */
.tabs-panel,
.action-builder:not(.action-builder--collapsed),
.layout--fullscreen-map > .tabs-panel.full-map-center,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder:not(.action-builder--collapsed),
.full-map-center,
.full-map-center > .action-builder:not(.action-builder--collapsed) {
  overflow: visible !important;
}

.action-builder:not(.action-builder--collapsed),
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder:not(.action-builder--collapsed),
.full-map-center > .action-builder:not(.action-builder--collapsed) {
  padding-bottom: 8px !important;
}

/* v115: refine centered edge tabs.
   The BUILD ACTION tab sits back on the higher action-panel edge, while the
   top HUD tab removes the edge line on its connected side (opposite of bottom). */
.panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.topbar .panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.topbar--collapsed .panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.full-map-stage__top .topbar .panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.full-map-stage__top .topbar.topbar--collapsed .panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab,
.full-map-stage__top .topbar.topbar--full-map-collapsed .panel-collapse-rail.panel-collapse-rail--top.topbar-collapse-tab {
  top: -1px !important;
  bottom: auto !important;
  border-top-width: 0 !important;
  border-bottom-width: 1px !important;
}

.action-builder:not(.action-builder--collapsed) .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder:not(.action-builder--collapsed) .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.full-map-center > .action-builder:not(.action-builder--collapsed) .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab {
  top: auto !important;
  bottom: -1px !important;
  border-top-width: 1px !important;
  border-bottom-width: 0 !important;
}

.action-builder--collapsed .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder--collapsed .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.full-map-center > .action-builder--collapsed .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab {
  top: auto !important;
  bottom: -1px !important;
  border-top-width: 1px !important;
  border-bottom-width: 0 !important;
}


/* v116: place the BUILD ACTION tab on the lower parent panel edge, not on the
   action button strip itself. Keep the compact height from the top tab. */
.action-builder:not(.action-builder--collapsed) .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder:not(.action-builder--collapsed) .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab,
.full-map-center > .action-builder:not(.action-builder--collapsed) .panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab {
  top: auto !important;
  bottom: var(--edge-panel-tab-lower-offset) !important;
  border-top-width: 1px !important;
  border-bottom-width: 0 !important;
}

.action-builder:not(.action-builder--collapsed),
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder:not(.action-builder--collapsed),
.full-map-center > .action-builder:not(.action-builder--collapsed) {
  padding-bottom: 8px !important;
  overflow: visible !important;
}

.tabs-panel,
.layout--fullscreen-map > .tabs-panel.full-map-center,
.full-map-center {
  overflow: visible !important;
}

/* v118: BUILD ACTION collapse/restore tab belongs to the parent edge, not to the
   action-builder child. This keeps its location stable in FULL MAP before and
   after collapse/restore. */
.tabs-panel,
.layout--fullscreen-map > .tabs-panel.full-map-center,
.full-map-center {
  position: relative !important;
  overflow: visible !important;
}

.tabs-panel > .action-collapse-tab--parent,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-collapse-tab--parent,
.full-map-center > .action-collapse-tab--parent {
  position: absolute !important;
  left: 50% !important;
  right: auto !important;
  top: auto !important;
  bottom: calc(-1 * var(--edge-panel-tab-height) + 1px) !important;
  width: var(--edge-panel-tab-width) !important;
  min-width: var(--edge-panel-tab-width) !important;
  max-width: var(--edge-panel-tab-width) !important;
  height: var(--edge-panel-tab-height) !important;
  min-height: var(--edge-panel-tab-height) !important;
  max-height: var(--edge-panel-tab-height) !important;
  margin: 0 !important;
  padding: 0 !important;
  transform: translateX(-50%) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
  line-height: 1 !important;
  font-size: 14px !important;
  border-radius: 2px 2px 0 0 !important;
  border-top-width: 1px !important;
  border-bottom-width: 0 !important;
  z-index: 140 !important;
}

/* The empty collapsed action-builder is now only a state marker. It must not
   pull the parent edge tab upward or reserve vertical space. */
.tabs-panel > .action-builder--collapsed,
.action-builder--collapsed,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder--collapsed,
.full-map-center > .action-builder--collapsed {
  position: static !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: 0 !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: visible !important;
  pointer-events: none !important;
}

.action-builder:not(.action-builder--collapsed),
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder:not(.action-builder--collapsed),
.full-map-center > .action-builder:not(.action-builder--collapsed) {
  padding-bottom: 8px !important;
  overflow: visible !important;
}

.layout--fullscreen-map > .tabs-panel.full-map-center > .action-collapse-tab--parent,
.full-map-center > .action-collapse-tab--parent {
  pointer-events: auto !important;
}


/* v119: compact parent BUILD ACTION tab and keep it visible in FULL MAP.
   The normal map tab is shorter so it no longer overlaps the action buttons.
   In FULL MAP the tab is kept inside the visible parent edge instead of being
   pushed below the viewport, which previously left only its top border visible. */
:root {
  --edge-panel-action-parent-tab-height: 20px;
}

.tabs-panel > .action-collapse-tab--parent,
.full-map-center > .action-collapse-tab--parent,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-collapse-tab--parent {
  height: var(--edge-panel-action-parent-tab-height) !important;
  min-height: var(--edge-panel-action-parent-tab-height) !important;
  max-height: var(--edge-panel-action-parent-tab-height) !important;
  line-height: 1 !important;
  font-size: 12px !important;
  z-index: 260 !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}

.tabs-panel > .action-collapse-tab--parent,
.full-map-center > .action-collapse-tab--parent {
  bottom: calc(-1 * var(--edge-panel-action-parent-tab-height) + 1px) !important;
}

.layout--fullscreen-map > .tabs-panel.full-map-center > .action-collapse-tab--parent {
  bottom: -1px !important;
  transform: translateX(-50%) translateY(0) !important;
  display: inline-flex !important;
  background: var(--theme-panel-flat, rgba(5, 13, 22, 0.96)) !important;
  border-color: var(--theme-border, rgba(46, 155, 255, 0.34)) !important;
  border-top-width: 1px !important;
  border-bottom-width: 0 !important;
}

.layout--fullscreen-map > .tabs-panel.full-map-center,
.full-map-stage__shell,
.full-map-stage {
  overflow: visible !important;
}

@media (max-height: 760px) {
  :root {
    --edge-panel-action-parent-tab-height: 20px;
  }
}

/* v120: hard-lock the parent BUILD ACTION tab size in the normal view too.
   Later generic touch/min-height rules must not let this tab grow again. */
:root {
  --edge-panel-action-parent-tab-height: 16px;
}

button.panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab.action-collapse-tab--parent,
.tabs-panel > button.panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab.action-collapse-tab--parent,
.full-map-center > button.panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab.action-collapse-tab--parent,
.layout--fullscreen-map > .tabs-panel.full-map-center > button.panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab.action-collapse-tab--parent {
  box-sizing: border-box !important;
  width: var(--edge-panel-tab-width) !important;
  min-width: var(--edge-panel-tab-width) !important;
  max-width: var(--edge-panel-tab-width) !important;
  height: var(--edge-panel-action-parent-tab-height) !important;
  min-height: var(--edge-panel-action-parent-tab-height) !important;
  max-height: var(--edge-panel-action-parent-tab-height) !important;
  padding: 0 !important;
  line-height: var(--edge-panel-action-parent-tab-height) !important;
  font-size: 10px !important;
  overflow: hidden !important;
  flex: 0 0 var(--edge-panel-action-parent-tab-height) !important;
  aspect-ratio: auto !important;
}

.tabs-panel > button.panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab.action-collapse-tab--parent,
.full-map-center > button.panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab.action-collapse-tab--parent {
  bottom: calc(-1 * var(--edge-panel-action-parent-tab-height) + 1px) !important;
}

.layout--fullscreen-map > .tabs-panel.full-map-center > button.panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab.action-collapse-tab--parent {
  bottom: -1px !important;
  display: inline-flex !important;
  visibility: visible !important;
  opacity: 1 !important;
}


/* v121: keep the BUILD ACTION parent tab compact, but place it higher in the
   normal layout. FULL MAP already uses the correct edge position and remains unchanged. */
.tabs-panel:not(.full-map-center) > button.panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab.action-collapse-tab--parent {
  bottom: -1px !important;
  transform: translateX(-50%) translateY(0) !important;
}

.full-map-center > button.panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab.action-collapse-tab--parent,
.layout--fullscreen-map > .tabs-panel.full-map-center > button.panel-collapse-rail.panel-collapse-rail--bottom.action-collapse-tab.action-collapse-tab--parent {
  bottom: -1px !important;
  transform: translateX(-50%) translateY(0) !important;
}

/* v122: small-device layout safety.
   On iPhone-sized screens the HUD should not be squeezed smaller in either axis.
   Keep a readable/touch-friendly logical stage and let the user pan/scroll it. */
@media (max-width: 1180px), (max-height: 720px) {
  :root {
    --small-device-stage-width: 1180px;
    --small-device-stage-height: 720px;
    --small-device-side-width: 306px;
    --small-device-center-width: 548px;
    --small-device-shell-gap: 6px;
  }

  html,
  body {
    width: max(100vw, var(--small-device-stage-width)) !important;
    min-width: var(--small-device-stage-width) !important;
    height: auto !important;
    min-height: max(var(--interrogation-viewport-height, 100dvh), var(--small-device-stage-height)) !important;
    overflow: auto !important;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
  }

  #wrap {
    position: relative !important;
    display: block !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    width: max(100vw, var(--small-device-stage-width)) !important;
    min-width: var(--small-device-stage-width) !important;
    height: max(var(--interrogation-viewport-height, 100dvh), var(--small-device-stage-height)) !important;
    min-height: var(--small-device-stage-height) !important;
    overflow: visible !important;
    touch-action: pan-x pan-y;
  }

  #html-ui {
    width: 100% !important;
    min-width: var(--small-device-stage-width) !important;
    height: 100% !important;
    min-height: var(--small-device-stage-height) !important;
    overflow: visible !important;
    touch-action: manipulation;
  }

  #game {
    width: 100vw !important;
    height: var(--interrogation-viewport-height, 100dvh) !important;
    max-width: none !important;
    max-height: none !important;
  }

  .interrogation-app {
    width: 100% !important;
    min-width: var(--small-device-stage-width) !important;
    height: 100% !important;
    min-height: var(--small-device-stage-height) !important;
    padding: 6px !important;
    overflow: hidden !important;
    background-size: 40px 40px, 40px 40px, auto, auto;
  }

  .app-shell {
    min-height: calc(var(--small-device-stage-height) - 12px) !important;
    grid-template-rows: 58px minmax(0, 1fr) !important;
    gap: var(--small-device-shell-gap) !important;
  }

  .app-shell--topbar-collapsed {
    grid-template-rows: 30px minmax(0, 1fr) !important;
  }

  .topbar {
    min-height: 58px !important;
    padding: 6px 8px !important;
    gap: 8px !important;
  }

  .topbar__left,
  .topbar__center,
  .topbar__right,
  .topbar__user-line,
  .case-title,
  .case-meta {
    min-width: 0 !important;
  }

  .case-title {
    margin-top: 2px !important;
    font-size: 14px !important;
    line-height: 1.18 !important;
  }

  .case-meta,
  .case-meta--meters,
  .top-stat,
  .top-meter {
    font-size: 9px !important;
  }

  .app-dept,
  .user-badge {
    font-size: 9px !important;
  }

  .top-meter__segments {
    gap: 2px !important;
  }

  .top-meter__pip,
  .top-meter .pip,
  .pip {
    width: 8px !important;
    min-width: 8px !important;
  }

  .layout,
  .layout--dossier-collapsed,
  .layout--status-collapsed,
  .layout--dossier-collapsed.layout--status-collapsed {
    grid-template-columns: var(--small-device-side-width) minmax(var(--small-device-center-width), 1fr) var(--small-device-side-width) !important;
    gap: var(--small-device-shell-gap) !important;
    min-width: 0 !important;
    min-height: 0 !important;
  }

  .layout--dossier-collapsed {
    grid-template-columns: 46px minmax(calc(var(--small-device-center-width) + var(--small-device-side-width) - 46px), 1fr) var(--small-device-side-width) !important;
  }

  .layout--status-collapsed {
    grid-template-columns: var(--small-device-side-width) minmax(calc(var(--small-device-center-width) + var(--small-device-side-width) - 46px), 1fr) 46px !important;
  }

  .layout--dossier-collapsed.layout--status-collapsed {
    grid-template-columns: 46px minmax(calc(var(--small-device-stage-width) - 104px), 1fr) 46px !important;
  }

  .panel__head {
    min-height: 48px !important;
    padding: 9px 10px !important;
  }

  .panel__title {
    font-size: 12px !important;
    line-height: 1.15 !important;
  }

  .panel__body {
    padding: 9px 10px !important;
  }

  .dossier-panel .panel__body {
    padding-left: 54px !important;
  }

  .dossier-filter-rail {
    top: 58px !important;
  }

  .dossier-filter-btn,
  .ui-btn--icon-only.dossier-filter-btn {
    width: 42px !important;
    min-width: 42px !important;
    height: 42px !important;
    min-height: 42px !important;
  }

  .card {
    padding: 9px 9px !important;
  }

  .dossier-panel .card {
    min-height: 96px !important;
  }

  .card__title {
    font-size: 12px !important;
  }

  .card__type,
  .card__tags,
  .card__hint {
    font-size: 8.5px !important;
  }

  .card__body {
    font-size: 10px !important;
    line-height: 1.35 !important;
  }

  .card__image {
    width: 82px !important;
    height: 52px !important;
  }

  .tabs-panel {
    grid-template-rows: auto minmax(0, 1fr) auto !important;
  }

  .tab-row {
    grid-template-columns: repeat(4, minmax(112px, 1fr)) !important;
    gap: 6px !important;
    padding: 7px 8px 6px !important;
  }

  .tab-btn,
  .ui-btn,
  .icon-btn {
    min-height: 40px;
  }

  .center-content {
    padding: 8px !important;
  }

  .chat-scene {
    min-height: 215px !important;
    margin-bottom: 8px !important;
  }

  .chat-scene__portrait {
    width: min(34%, 270px) !important;
  }

  .chat-scene__meta,
  .emotion-grid {
    transform: scale(0.9);
    transform-origin: top left;
  }

  .emotion-grid {
    transform-origin: top right;
  }

  .chat-bubble {
    max-width: 68% !important;
  }

  .chat-bubble__text {
    font-size: 11px !important;
    line-height: 1.35 !important;
  }

  .action-builder {
    padding: 8px 10px 8px !important;
  }

  .action-builder__head {
    margin-bottom: 6px !important;
  }

  .action-builder__label {
    font-size: 11px !important;
  }

  .action-builder__hint {
    font-size: 8.5px !important;
  }

  .action-slots {
    gap: 8px !important;
    margin-bottom: 8px !important;
  }

  .action-slot--empty,
  .card--action-slot {
    min-height: 92px !important;
    max-height: 120px !important;
  }

  .card--action-slot .card__body {
    max-height: 32px !important;
  }

  .action-strip {
    grid-template-columns: repeat(5, minmax(96px, 1fr)) !important;
    gap: 7px !important;
  }

  .action-strip .ui-btn {
    min-height: 42px !important;
    font-size: 10px !important;
    padding: 5px 7px !important;
  }

  .status-block,
  .status-bucket,
  .progress-block {
    padding: 8px !important;
  }

  .stat-row,
  .status-bucket__items,
  .status-subject__desc,
  .status-subject__meta {
    font-size: 10px !important;
  }

  .map-view {
    min-height: 360px !important;
  }

  .map-tools--overlay {
    max-width: calc(100% - 16px) !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    flex-wrap: nowrap !important;
    -webkit-overflow-scrolling: touch;
  }

  .map-tools--overlay .ui-btn {
    white-space: nowrap !important;
    flex: 0 0 auto !important;
  }

  .panel-collapse-rail--left,
  .panel-collapse-rail--right,
  .panel-collapse-rail--top,
  .panel-collapse-rail--bottom {
    touch-action: manipulation;
  }
}

@media (max-width: 900px), (max-height: 520px) {
  :root {
    --small-device-stage-width: 1120px;
    --small-device-stage-height: 680px;
    --small-device-side-width: 292px;
    --small-device-center-width: 520px;
  }

  .app-shell {
    grid-template-rows: 54px minmax(0, 1fr) !important;
  }

  .topbar {
    min-height: 54px !important;
  }

  .panel__head {
    min-height: 44px !important;
  }

  .chat-scene {
    min-height: 192px !important;
  }

  .action-slot--empty,
  .card--action-slot {
    min-height: 84px !important;
    max-height: 108px !important;
  }

  .action-builder__hint {
    display: none !important;
  }

  .status-block,
  .status-bucket {
    margin-bottom: 7px !important;
  }

  .map-view {
    min-height: 330px !important;
  }
}


/* v123: phone layout correction.
   On iPhone-sized landscape screens the right status panel was too wide and its
   header kept desktop spacing, which made CASE STATUS look detached and stole
   width from the interrogation column. Keep the fixed/pannable stage, but bias
   space toward the middle column and compact the status header/body. */
@media (max-width: 1180px), (max-height: 720px) {
  :root {
    --small-device-dossier-width: 306px;
    --small-device-status-width: 252px;
    --small-device-center-width: 610px;
    --small-device-status-header-height: 46px;
  }

  .layout,
  .layout--dossier-collapsed,
  .layout--status-collapsed,
  .layout--dossier-collapsed.layout--status-collapsed {
    grid-template-columns: var(--small-device-dossier-width) minmax(var(--small-device-center-width), 1fr) var(--small-device-status-width) !important;
  }

  .layout--dossier-collapsed {
    grid-template-columns: 46px minmax(calc(var(--small-device-center-width) + var(--small-device-dossier-width) - 46px), 1fr) var(--small-device-status-width) !important;
  }

  .layout--status-collapsed {
    grid-template-columns: var(--small-device-dossier-width) minmax(calc(var(--small-device-center-width) + var(--small-device-status-width) - 46px), 1fr) 46px !important;
  }

  .layout--dossier-collapsed.layout--status-collapsed {
    grid-template-columns: 46px minmax(calc(var(--small-device-stage-width) - 104px), 1fr) 46px !important;
  }

  .status-panel:not(.status-panel--collapsed) > .panel__head,
  .layout > .status-panel:not(.status-panel--collapsed) > .panel__head {
    flex: 0 0 var(--small-device-status-header-height) !important;
    min-height: var(--small-device-status-header-height) !important;
    height: var(--small-device-status-header-height) !important;
    padding-top: 4px !important;
    padding-bottom: 4px !important;
    padding-left: 10px !important;
    padding-right: calc(var(--dossier-filter-rail-width) + 8px) !important;
    align-items: center !important;
  }

  .status-panel:not(.status-panel--collapsed) > .panel__head .panel__title,
  .layout > .status-panel:not(.status-panel--collapsed) > .panel__head .panel__title,
  .status-panel .panel__title--status {
    height: 100% !important;
    min-height: 0 !important;
    align-items: center !important;
    align-self: center !important;
    font-size: 11px !important;
    line-height: 1.05 !important;
  }

  .status-panel:not(.status-panel--collapsed) > .panel__head .panel-collapse-btn,
  .layout > .status-panel:not(.status-panel--collapsed) > .panel__head .panel-collapse-btn {
    top: 3px !important;
    height: calc(var(--small-device-status-header-height) - 6px) !important;
    min-height: calc(var(--small-device-status-header-height) - 6px) !important;
    max-height: calc(var(--small-device-status-header-height) - 6px) !important;
  }

  .status-panel__body,
  .status-panel:not(.status-panel--collapsed) > .panel__body {
    padding: 6px 8px 8px !important;
    gap: 7px !important;
  }

  .status-panel__body .status-block--subject:first-child,
  .status-panel .status-block:first-child {
    margin-top: 0 !important;
  }

  .status-block,
  .status-bucket,
  .progress-block {
    padding: 7px !important;
  }

  .status-block__title,
  .status-bucket__head,
  .status-title-label,
  .status-bucket-label {
    font-size: 9.5px !important;
    line-height: 1.12 !important;
  }

  .status-panel .ui-btn,
  .status-verdict-bar .ui-btn {
    min-height: 38px !important;
  }
}

@media (max-width: 900px), (max-height: 520px) {
  :root {
    --small-device-dossier-width: 292px;
    --small-device-status-width: 238px;
    --small-device-center-width: 584px;
    --small-device-status-header-height: 42px;
  }

  .status-panel:not(.status-panel--collapsed) > .panel__head,
  .layout > .status-panel:not(.status-panel--collapsed) > .panel__head {
    flex-basis: var(--small-device-status-header-height) !important;
    min-height: var(--small-device-status-header-height) !important;
    height: var(--small-device-status-header-height) !important;
  }

  .status-panel:not(.status-panel--collapsed) > .panel__head .panel-collapse-btn,
  .layout > .status-panel:not(.status-panel--collapsed) > .panel__head .panel-collapse-btn {
    top: 3px !important;
    height: calc(var(--small-device-status-header-height) - 6px) !important;
    min-height: calc(var(--small-device-status-header-height) - 6px) !important;
    max-height: calc(var(--small-device-status-header-height) - 6px) !important;
  }

  .status-panel__body,
  .status-panel:not(.status-panel--collapsed) > .panel__body {
    padding: 5px 7px 7px !important;
  }
}

/* v124: phone width rebalance, theme-correct FULL MAP panels, less aggressive title clipping,
   and full-card map nodes that match Dossier fact-card proportions. */
@media (max-width: 1180px), (max-height: 720px) {
  :root {
    --small-device-status-width: 232px;
    --small-device-center-width: 630px;
  }

  .layout,
  .layout--dossier-collapsed,
  .layout--status-collapsed,
  .layout--dossier-collapsed.layout--status-collapsed {
    grid-template-columns: var(--small-device-dossier-width) minmax(var(--small-device-center-width), 1fr) var(--small-device-status-width) !important;
  }

  .layout--dossier-collapsed {
    grid-template-columns: 46px minmax(calc(var(--small-device-center-width) + var(--small-device-dossier-width) - 46px), 1fr) var(--small-device-status-width) !important;
  }

  .layout--status-collapsed {
    grid-template-columns: var(--small-device-dossier-width) minmax(calc(var(--small-device-center-width) + var(--small-device-status-width) - 46px), 1fr) 46px !important;
  }
}

@media (max-width: 900px), (max-height: 520px) {
  :root {
    --small-device-status-width: 208px;
    --small-device-center-width: 608px;
  }

  .layout,
  .layout--dossier-collapsed,
  .layout--status-collapsed,
  .layout--dossier-collapsed.layout--status-collapsed {
    grid-template-columns: var(--small-device-dossier-width) minmax(var(--small-device-center-width), 1fr) var(--small-device-status-width) !important;
  }

  .layout--dossier-collapsed {
    grid-template-columns: 46px minmax(calc(var(--small-device-center-width) + var(--small-device-dossier-width) - 46px), 1fr) var(--small-device-status-width) !important;
  }

  .layout--status-collapsed {
    grid-template-columns: var(--small-device-dossier-width) minmax(calc(var(--small-device-center-width) + var(--small-device-status-width) - 46px), 1fr) 46px !important;
  }
}

/* Give one-line fact titles more room before ellipsis while preserving badge safety. */
.card__head,
.card--action-slot .card__head,
.map-node--full-card .card__head {
  padding-right: 44px !important;
}

.dossier-panel .card__head {
  padding-right: 34px !important;
}

.card__type,
.dossier-panel .card__type,
.card--action-slot .card__type,
.map-node--full-card .card__type {
  padding-right: 34px !important;
}

.card:not(.card--new):not(.card--used) .card__head,
.card--action-slot:not(.card--new):not(.card--used) .card__head,
.map-node--full-card:not(.card--new):not(.card--used) .card__head {
  padding-right: 20px !important;
}

.dossier-panel .card:not(.card--new):not(.card--used) .card__head {
  padding-right: 16px !important;
}

.card:not(.card--new):not(.card--used) .card__type,
.card--action-slot:not(.card--new):not(.card--used) .card__type,
.map-node--full-card:not(.card--new):not(.card--used) .card__type {
  padding-right: 16px !important;
}

/* FULL MAP controls should inherit the active theme instead of carrying stale hard-coded frames. */
.layout--fullscreen-map .map-tools--overlay,
.full-map-stage__map .map-tools--overlay,
.layout--fullscreen-map > .tabs-panel.full-map-center > .full-map-center__tools,
.layout--fullscreen-map > .tabs-panel.full-map-center > .map-chat-panel,
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder:not(.action-builder--collapsed),
.full-map-center > .action-builder:not(.action-builder--collapsed) {
  background: var(--theme-panel-flat, var(--c-panel)) !important;
  border-color: var(--theme-border, var(--panel-border)) !important;
  box-shadow:
    inset 0 0 14px color-mix(in srgb, var(--theme-accent, var(--c-cyan)) 8%, transparent),
    0 0 12px color-mix(in srgb, var(--theme-accent, var(--c-cyan)) 7%, transparent) !important;
}

:root[data-theme="dark"] .layout--fullscreen-map .map-tools--overlay,
:root[data-theme="dark"] .full-map-stage__map .map-tools--overlay,
:root[data-theme="dark"] .layout--fullscreen-map > .tabs-panel.full-map-center > .full-map-center__tools,
:root[data-theme="dark"] .layout--fullscreen-map > .tabs-panel.full-map-center > .map-chat-panel,
:root[data-theme="dark"] .layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder:not(.action-builder--collapsed),
:root[data-theme="dark"] .full-map-center > .action-builder:not(.action-builder--collapsed) {
  box-shadow: none !important;
}

.layout--fullscreen-map .map-tools--overlay .ui-btn:not(.ui-btn--danger):not(.ui-btn--action-ready),
.full-map-stage__map .map-tools--overlay .ui-btn:not(.ui-btn--danger):not(.ui-btn--action-ready),
.layout--fullscreen-map > .tabs-panel.full-map-center > .action-builder .ui-btn:not(.ui-btn--danger):not(.ui-btn--action-ready) {
  border-color: var(--theme-border, var(--panel-border)) !important;
}

/* In CARDS: FULL mode, map nodes use the same vertical rhythm as Dossier cards. */
.map-node--full-card.card,
.map-node--full-card.card--map-card {
  width: 320px !important;
  height: auto !important;
  min-height: 96px !important;
  max-height: none !important;
  padding: 9px 9px !important;
  overflow: visible !important;
}

.map-node--full-card .card__head {
  gap: 7px !important;
  margin-bottom: 0 !important;
}

.map-node--full-card .card__fact-icon,
.map-node--full-card .card__type-icon {
  width: 22px !important;
  height: 22px !important;
  flex-basis: 22px !important;
}

.map-node--full-card .card__type {
  font-size: 8.5px !important;
  line-height: 1.1 !important;
}

.map-node--full-card .card__title {
  margin-top: 4px !important;
  font-size: 12px !important;
  line-height: 1.15 !important;
}

.map-node--full-card .card__body {
  margin-top: 6px !important;
  max-height: none !important;
  font-size: 10px !important;
  line-height: 1.35 !important;
  overflow: visible !important;
}

.map-node--full-card .card__tags {
  margin-top: 5px !important;
  font-size: 8.5px !important;
  line-height: 1.2 !important;
}

.map-node--full-card .card__image {
  width: 82px !important;
  height: 50px !important;
  margin: 2px 0 5px 8px !important;
}


/* v125: fixed evidence-card footprint shared by Dossier, CASE MAP / CARDS: FULL,
   and BUILD ACTION slots. Cards clip internal copy instead of changing height. */
:root {
  --fact-card-box-width: 300px;
  --fact-card-box-height: 142px;
  --fact-card-box-pad-y: 10px;
  --fact-card-box-pad-x: 10px;
  --fact-card-image-w: 96px;
  --fact-card-image-h: 56px;
  --evidence-thumb-border: rgba(220, 235, 245, 0.08);
  --evidence-thumb-border-hover: rgba(244, 251, 255, 0.82);
  --evidence-thumb-bg: rgba(0, 0, 0, 0.35);
}

.dossier-panel .dossier-list,
.dossier-panel .dossier-group {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 8px !important;
  min-width: 0 !important;
}

.dossier-panel .dossier-group {
  width: 100% !important;
}

.dossier-panel .section-title {
  width: min(100%, var(--fact-card-box-width)) !important;
  max-width: var(--fact-card-box-width) !important;
}

.dossier-panel .card,
.card--action-slot,
.action-slot--empty,
.map-node--full-card.card,
.map-node--full-card.card--map-card {
  box-sizing: border-box !important;
  width: min(100%, var(--fact-card-box-width)) !important;
  min-width: min(100%, var(--fact-card-box-width)) !important;
  max-width: var(--fact-card-box-width) !important;
  height: var(--fact-card-box-height) !important;
  min-height: var(--fact-card-box-height) !important;
  max-height: var(--fact-card-box-height) !important;
  padding: var(--fact-card-box-pad-y) var(--fact-card-box-pad-x) !important;
  overflow: hidden !important;
}

.dossier-panel .card,
.card--action-slot,
.map-node--full-card.card,
.map-node--full-card.card--map-card,
.card--art-qa-fact-card {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) var(--fact-card-image-w) !important;
  grid-template-rows: auto minmax(0, 1fr) auto !important;
  column-gap: 10px !important;
  row-gap: 5px !important;
  align-items: stretch !important;
}

.dossier-panel .card,
.map-node--full-card.card,
.map-node--full-card.card--map-card {
  flex: 0 0 var(--fact-card-box-height) !important;
}

.action-slot--empty,
.card--action-slot {
  flex: 0 0 var(--fact-card-box-width) !important;
}

.action-slots {
  grid-template-columns: repeat(var(--slot-count, 2), var(--fact-card-box-width)) !important;
  min-height: var(--fact-card-box-height) !important;
  align-items: start !important;
}

.card__head,
.dossier-panel .card__head,
.card--action-slot .card__head,
.map-node--full-card .card__head {
  grid-column: 1 / -1 !important;
  grid-row: 1 / 2 !important;
  gap: 7px !important;
  margin-bottom: 0 !important;
  padding-right: 0 !important;
  min-height: 38px !important;
  max-height: 50px !important;
  overflow: hidden !important;
}

.card--new .card__head,
.card--used .card__head,
.dossier-panel .card--new .card__head,
.dossier-panel .card--used .card__head,
.map-node--full-card.card--new .card__head,
.map-node--full-card.card--used .card__head {
  padding-right: 42px !important;
}

.card__type,
.dossier-panel .card__type,
.card--action-slot .card__type,
.map-node--full-card .card__type {
  padding-right: 0 !important;
  font-size: 8.5px !important;
  line-height: 1.05 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.card__title,
.card__head-copy .card__title,
.dossier-panel .card__title,
.card--action-slot .card__title,
.map-node--full-card .card__title {
  display: -webkit-box !important;
  -webkit-line-clamp: 4 !important;
  -webkit-box-orient: vertical !important;
  margin-top: 3px !important;
  font-size: 12px !important;
  line-height: 1.16 !important;
  max-width: 100% !important;
  white-space: normal !important;
  overflow: hidden !important;
}

.card__body,
.dossier-panel .card__body,
.card--action-slot .card__body,
.map-node--full-card .card__body {
  grid-column: 1 / 2 !important;
  grid-row: 2 / 3 !important;
  align-self: start !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 4 !important;
  -webkit-box-orient: vertical !important;
  margin-top: 0 !important;
  max-height: 56px !important;
  font-size: 10px !important;
  line-height: 1.45 !important;
  overflow: hidden !important;
}

.card__tags,
.dossier-panel .card__tags,
.card--action-slot .card__tags,
.map-node--full-card .card__tags {
  grid-column: 1 / -1 !important;
  grid-row: 3 / 4 !important;
  display: block !important;
  margin-top: 0 !important;
  max-width: 100% !important;
  font-size: 8.5px !important;
  line-height: 1.15 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.card__hint,
.dossier-panel .card__hint,
.card--action-slot .card__hint,
.map-node--full-card .card__hint {
  display: none !important;
}

.card__image,
.card__image-fallback,
.dossier-panel .card__image,
.dossier-panel .card__image-fallback,
.card:not(.map-node) .card__image,
.card:not(.map-node) .card__image-fallback,
.card--action-slot .card__image,
.card--action-slot .card__image-fallback,
.map-node--full-card .card__image,
.map-node--full-card .card__image-fallback {
  grid-column: 2 / 3 !important;
  grid-row: 2 / 4 !important;
  align-self: start !important;
  justify-self: end !important;
  float: none !important;
  width: var(--fact-card-image-w) !important;
  height: var(--fact-card-image-h) !important;
  margin: 0 !important;
  border: 1px solid rgba(220, 235, 245, 0.08) !important;
  background: var(--evidence-thumb-bg) !important;
  box-shadow: none !important;
  opacity: 1 !important;
  filter: none !important;
  mix-blend-mode: normal !important;
  cursor: zoom-in !important;
  transition: border-color 120ms ease;
}

.card__image,
.dossier-panel .card__image,
.card--action-slot .card__image,
.map-node--full-card .card__image {
  object-fit: cover !important;
  object-position: center center !important;
  image-rendering: auto !important;
  opacity: 1 !important;
  filter: none !important;
  mix-blend-mode: normal !important;
}

.card__image:hover,
.card__image:focus-visible,
.card__image-fallback:hover,
.card__image-fallback:focus-visible,
.inline-evidence-card__image:hover,
.inline-evidence-card__image:focus-visible,
.inline-evidence img:hover,
.inline-evidence img:focus-visible,
.inline-evidence-card .card__image-fallback:hover,
.inline-evidence-card .card__image-fallback:focus-visible,
.gamepad-hover.card__image,
.gamepad-hover.card__image-fallback,
.inline-evidence-card__image.gamepad-hover,
.inline-evidence img.gamepad-hover {
  border-color: var(--evidence-thumb-border-hover) !important;
  filter: none !important;
  opacity: 1 !important;
  mix-blend-mode: normal !important;
  box-shadow: none !important;
}

.inline-evidence-card__image,
.inline-evidence img,
.inline-evidence-card .card__image-fallback {
  width: var(--fact-card-image-w) !important;
  height: var(--fact-card-image-h) !important;
  margin: 0 !important;
  border: 1px solid rgba(220, 235, 245, 0.08) !important;
  object-fit: cover !important;
  object-position: center center !important;
  image-rendering: auto !important;
  opacity: 1 !important;
  filter: none !important;
  mix-blend-mode: normal !important;
  background: var(--evidence-thumb-bg);
  box-shadow: none !important;
  cursor: zoom-in !important;
  transition: border-color 120ms ease;
}

.inline-evidence {
  gap: 10px !important;
}

.inline-evidence-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) var(--fact-card-image-w);
  grid-template-rows: auto auto;
  column-gap: 10px;
  row-gap: 5px;
  align-items: center;
  width: min(100%, calc(var(--fact-card-image-w) + 174px));
  min-height: calc(var(--fact-card-image-h) + 18px);
  padding: 8px;
  border: 1px solid var(--fact-card-border);
  background: var(--fact-card-bg);
  box-shadow: none;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  transition: border-color 120ms ease, background-color 120ms ease, box-shadow 120ms ease;
}

.inline-evidence-card:hover,
.inline-evidence-card:focus-visible {
  border-color: var(--fact-card-border-hover);
  background: var(--fact-card-bg-hover, rgba(9, 21, 35, 0.97));
}

.inline-evidence-card__head {
  display: flex;
  align-items: center;
  gap: 4px;
  grid-column: 1 / 2;
  grid-row: 1 / 2;
  min-width: 0;
  color: var(--accent, var(--c-cyan));
  font: 800 7.5px/1 var(--font-ui);
  text-transform: uppercase;
}

.inline-evidence-card__icon {
  width: 12px;
  height: 12px;
  flex: 0 0 12px;
}

.inline-evidence-card__type,
.inline-evidence-card__title {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.inline-evidence-card__title {
  grid-column: 1 / 2;
  grid-row: 2 / 3;
  color: var(--c-white);
  font: 900 10px/1.25 var(--font-ui);
  white-space: normal;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.inline-evidence-card__image,
.inline-evidence-card .card__image-fallback {
  grid-column: 2 / 3 !important;
  grid-row: 1 / 3 !important;
  align-self: center !important;
  justify-self: end !important;
}

.card__image-fallback,
.dossier-panel .card__image-fallback,
.card--action-slot .card__image-fallback,
.map-node--full-card .card__image-fallback {
  display: grid !important;
  place-items: center !important;
  background:
    linear-gradient(rgba(220, 235, 245, 0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(220, 235, 245, 0.045) 1px, transparent 1px),
    var(--evidence-thumb-bg) !important;
  background-size: 9px 9px, 9px 9px, auto !important;
  color: rgba(220, 235, 245, 0.72) !important;
}

.card__image-fallback-icon {
  width: 28px !important;
  height: 28px !important;
  opacity: 0.9;
}

.map-node--full-card.card,
.map-node--full-card.card--map-card {
  min-height: var(--fact-card-box-height) !important;
  max-height: var(--fact-card-box-height) !important;
}

.map-node--full-card.card--map-card {
  width: var(--fact-card-box-width) !important;
  min-width: var(--fact-card-box-width) !important;
  max-width: var(--fact-card-box-width) !important;
}

@media (max-width: 1460px) {
  :root {
    --fact-card-box-width: 280px;
    --fact-card-box-height: 138px;
    --fact-card-image-w: 88px;
    --fact-card-image-h: 52px;
  }

  .action-slots {
    grid-template-columns: repeat(var(--slot-count, 2), var(--fact-card-box-width)) !important;
  }
}

@media (max-width: 900px), (max-height: 520px) {
  :root {
    --fact-card-box-width: 276px;
    --fact-card-box-height: 134px;
    --fact-card-image-w: 84px;
    --fact-card-image-h: 50px;
  }

  .card__body,
  .dossier-panel .card__body,
  .card--action-slot .card__body,
  .map-node--full-card .card__body {
    -webkit-line-clamp: 4 !important;
    max-height: 52px !important;
    line-height: 1.38 !important;
  }
}

/* v126: FULL MAP graph-aware side clearances.
   Node coordinates are computed in DOM view from the currently expanded side panels:
   expanded DOSSIER keeps the first nodes to its right, while collapsed side panels
   free the playable map area and let the graph recenter. These classes are kept
   on the stage for debugging and future theme-specific tuning. */
.full-map-stage--dossier-open,
.full-map-stage--dossier-collapsed,
.full-map-stage--status-open,
.full-map-stage--status-collapsed {
  --full-map-graph-clearance-model: active;
}

.full-map-stage__map .map-view--fullscreen-underlay .case-graph__canvas {
  transform-origin: top left !important;
}

/* Ready BUILD ACTION commands reuse the WERDYKT/danger skin across all themes. */
.action-builder .action-strip .ui-btn--action-ready:not(:disabled):hover,
.action-builder .action-strip .ui-btn--action-ready:not(:disabled):focus-visible {
  color: var(--c-white) !important;
}

.action-builder .action-strip .ui-btn--action-ready:not(:disabled):hover .ui-icon,
.action-builder .action-strip .ui-btn--action-ready:not(:disabled):focus-visible .ui-icon {
  color: var(--c-white) !important;
}

/* ART QA fullscreen evidence review. This file is the stylesheet loaded by index.html. */
.app-shell--art-qa {
  display: grid !important;
  grid-template-rows: auto minmax(0, 1fr) !important;
  height: var(--interrogation-viewport-height, 100dvh) !important;
  min-height: var(--interrogation-viewport-height, 100dvh) !important;
  overflow: hidden !important;
}

.app-shell--art-qa .topbar {
  position: sticky;
  top: 0;
  z-index: 30;
}

.art-qa-page {
  display: block;
  gap: 12px;
  min-width: 1120px;
  padding: 12px 20px 28px;
  min-height: 0;
  overflow: auto;
}

.art-qa-page__tabs {
  display: grid;
  grid-template-columns: repeat(5, minmax(170px, 1fr));
  gap: 8px;
  position: sticky;
  top: 76px;
  z-index: 25;
  padding: 8px 0;
  background: rgba(3, 7, 14, 0.94);
  backdrop-filter: blur(8px);
}

.app-shell--art-qa .art-qa-view {
  display: block;
  height: auto;
  min-height: 0;
}

.app-shell--art-qa .art-qa-toolbar {
  display: grid;
  gap: 10px;
  margin-bottom: 12px;
  padding: 10px;
  border: 1px solid rgba(0, 200, 255, 0.22);
  background: rgba(3, 12, 20, 0.82);
}

.art-qa-title {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
  color: var(--c-cyan);
  font: 700 12px/1 var(--font-ui);
}

.art-qa-title small {
  color: var(--c-muted);
  font-size: 10px;
}

.art-qa-column-toggles {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.art-qa-case-select {
  display: flex;
  align-items: center;
  gap: 8px;
  max-width: 520px;
  color: var(--c-cyan);
  font: 700 10px/1 var(--font-ui);
}

.art-qa-case-select select {
  width: min(420px, 100%);
  min-height: 30px;
  border: 1px solid rgba(0, 200, 255, 0.32);
  background: rgba(0, 8, 14, 0.92);
  color: var(--c-white);
  font: 700 11px/1 var(--font-ui);
}

.art-qa-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 28px;
  padding: 5px 8px;
  border: 1px solid rgba(0, 200, 255, 0.24);
  background: rgba(0, 18, 28, 0.56);
  color: var(--c-cyan);
  font: 700 9px/1 var(--font-ui);
}

.art-qa-toggle--gemini { color: var(--c-green); }
.art-qa-toggle--claude { color: var(--c-purple); }
.art-qa-toggle input { accent-color: currentColor; }

.app-shell--art-qa .art-qa-grid-wrap {
  overflow-x: auto;
  overflow-y: visible;
  border: 1px solid rgba(0, 200, 255, 0.18);
  background: rgba(0, 0, 0, 0.24);
}

.app-shell--art-qa .art-qa-grid {
  display: grid;
  grid-template-columns: calc(var(--fact-card-box-width) + 20px) repeat(var(--art-qa-cols), minmax(260px, 300px));
  gap: 1px;
  min-width: max-content;
  background: rgba(0, 200, 255, 0.20);
}

.app-shell--art-qa .art-qa-head {
  position: sticky;
  top: 0;
  z-index: 2;
  min-height: 30px;
  padding: 8px;
  background: rgba(5, 13, 22, 0.98);
  color: var(--c-cyan);
  font: 700 10px/1 var(--font-ui);
}

.app-shell--art-qa .art-qa-head--gemini { color: var(--c-green); }
.app-shell--art-qa .art-qa-head--claude { color: var(--c-purple); }
.app-shell--art-qa .art-qa-head--orig { color: var(--c-red); }

.app-shell--art-qa .art-qa-fact-cell,
.app-shell--art-qa .art-qa-image-cell {
  min-height: 250px;
  padding: 10px;
  background: rgba(6, 16, 26, 0.92);
}

.app-shell--art-qa .art-qa-fact-cell .card {
  width: var(--fact-card-box-width) !important;
  min-width: var(--fact-card-box-width) !important;
  max-width: var(--fact-card-box-width) !important;
  min-height: var(--fact-card-box-height) !important;
  max-height: var(--fact-card-box-height) !important;
}

.app-shell--art-qa .art-qa-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.app-shell--art-qa .art-qa-status {
  color: var(--c-muted);
  font: 700 10px/1.2 var(--font-ui);
}

.app-shell--art-qa .art-qa-backups {
  display: grid;
  gap: 6px;
  max-width: 760px;
  padding: 8px;
  border: 1px solid rgba(255, 204, 51, 0.20);
  background: rgba(16, 12, 0, 0.28);
  color: var(--c-muted);
  font: 700 10px/1.3 var(--font-ui);
}

.app-shell--art-qa .art-qa-backups--empty {
  max-width: 360px;
}

.app-shell--art-qa .art-qa-backups__title {
  color: var(--c-yellow);
}

.app-shell--art-qa .art-qa-backups__list {
  display: grid;
  gap: 4px;
  max-height: 150px;
  overflow: auto;
}

.app-shell--art-qa .art-qa-backup-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
}

.app-shell--art-qa .art-qa-backup-row span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.app-shell--art-qa .art-qa-target {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 24px;
  margin-bottom: 7px;
  padding: 4px 7px;
  border: 1px solid rgba(0, 200, 255, 0.24);
  background: rgba(0, 18, 28, 0.56);
  color: var(--c-cyan);
  font: 700 9px/1 var(--font-ui);
}

.app-shell--art-qa .art-qa-target input {
  accent-color: var(--c-red);
}

.app-shell--art-qa .art-qa-thumb {
  position: relative;
  display: block;
  width: 100%;
  min-height: 220px;
  aspect-ratio: 4 / 3;
  padding: 0;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(0, 0, 0, 0.45);
  cursor: zoom-in;
}

.app-shell--art-qa .art-qa-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
}

.app-shell--art-qa .art-qa-thumb span {
  position: absolute;
  left: 6px;
  bottom: 6px;
  padding: 2px 5px;
  background: rgba(0, 0, 0, 0.72);
  color: var(--c-cyan);
  font: 700 10px/1 var(--font-ui);
}

.app-shell--art-qa .art-qa-thumb--missing {
  display: grid;
  place-items: center;
}

.app-shell--art-qa .art-qa-thumb--missing img {
  display: none;
}

.app-shell--art-qa .art-qa-thumb--missing::before {
  content: "MISSING";
  color: var(--c-yellow);
  font: 700 10px/1 var(--font-ui);
}

.app-shell--art-qa .art-qa-empty {
  grid-column: 1 / -1;
  min-height: 120px;
}

/* Final evidence thumbnail normalization: neutral, browser-smoothed thumbnails. */
.card__image,
.card__image-fallback,
.dossier-panel .card__image,
.dossier-panel .card__image-fallback,
.card--action-slot .card__image,
.card--action-slot .card__image-fallback,
.map-node--full-card .card__image,
.map-node--full-card .card__image-fallback,
.inline-evidence-card__image,
.inline-evidence-card .card__image-fallback,
.inline-evidence img {
  border: 1px solid rgba(220, 235, 245, 0.08) !important;
  background: rgba(0, 0, 0, 0.35) !important;
  box-shadow: none !important;
  filter: none !important;
  opacity: 1 !important;
  mix-blend-mode: normal !important;
  image-rendering: auto !important;
}

.card__image:is(:hover, :focus-visible, .gamepad-hover),
.card__image-fallback:is(:hover, :focus-visible, .gamepad-hover),
.dossier-panel .card__image:is(:hover, :focus-visible, .gamepad-hover),
.dossier-panel .card__image-fallback:is(:hover, :focus-visible, .gamepad-hover),
.card:not(.map-node) .card__image:is(:hover, :focus-visible, .gamepad-hover),
.card:not(.map-node) .card__image-fallback:is(:hover, :focus-visible, .gamepad-hover),
.card--action-slot .card__image:is(:hover, :focus-visible, .gamepad-hover),
.card--action-slot .card__image-fallback:is(:hover, :focus-visible, .gamepad-hover),
.map-node--full-card .card__image:is(:hover, :focus-visible, .gamepad-hover),
.map-node--full-card .card__image-fallback:is(:hover, :focus-visible, .gamepad-hover),
.inline-evidence-card__image:is(:hover, :focus-visible, .gamepad-hover),
.inline-evidence-card .card__image-fallback:is(:hover, :focus-visible, .gamepad-hover),
.inline-evidence img:is(:hover, :focus-visible, .gamepad-hover) {
  border-color: rgba(244, 251, 255, 0.82) !important;
  box-shadow: none !important;
  filter: none !important;
}


/* Fact details modal responsive height adjustments */
@media (max-height: 860px) {
  .modal-card {
    max-height: calc(100vh - 24px) !important;
    padding: 12px !important;
  }
  .preview-image {
    max-height: 48vh !important;
  }
  .modal-title {
    margin-bottom: 6px !important;
  }
  .modal-actions {
    margin-top: 10px !important;
  }
}

@media (max-height: 700px) {
  .preview-image {
    max-height: 38vh !important;
  }
}

/* Report modal must keep the former wide verdict layout even when generic modal
   rules or theme overrides compact ordinary dialogs. */
.modal-backdrop .modal-card--report {
  width: min(1180px, calc(100vw - 28px)) !important;
  padding: 18px !important;
}

@media (max-width: 920px) {
  .modal-backdrop .modal-card--report {
    width: min(940px, calc(100vw - 24px)) !important;
    padding: 12px !important;
  }

  .modal-card--report .report-modal-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .modal-card--report .report-modal-grid--evidence {
    margin-top: 18px;
  }

  .modal-card--report .report-modal-grid--summary {
    margin-top: 18px;
  }

  .modal-card--report .report-evidence-panel__body {
    min-height: auto;
    max-height: 180px;
  }

  .modal-card--report .report-verdict-row {
    margin-top: 24px;
  }

  .modal-card--report .report-verdict-title {
    margin-top: 24px;
  }
}

/* v161: right CASE STATUS panel uses real numeric scales and full-width meters. */
.status-panel:not(.status-panel--collapsed) {
  min-width: 360px;
}

.status-panel:not(.status-panel--collapsed) > .panel__head {
  min-height: 58px !important;
  height: 58px !important;
  flex: 0 0 58px !important;
}

.status-panel:not(.status-panel--collapsed) > .panel__body,
.status-panel__body {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  padding: 12px !important;
  overflow-y: auto !important;
}

.status-panel .status-block,
.status-panel .status-bucket {
  margin: 0 !important;
  padding: 12px !important;
  border: 1px solid rgba(46, 155, 255, 0.26) !important;
  background: rgba(4, 13, 20, 0.88) !important;
  box-shadow: inset 0 0 18px rgba(0, 200, 255, 0.025) !important;
}

.status-panel .status-block__title,
.status-panel .status-block__title--folded,
.status-panel .status-bucket__head,
.status-panel .status-title-label,
.status-panel .status-bucket-label {
  color: var(--c-cyan) !important;
  font-size: 11px !important;
  line-height: 1.2 !important;
  font-weight: 900 !important;
  letter-spacing: 0.055em !important;
  text-transform: uppercase !important;
}

.status-panel .panel-title-icon,
.status-panel .status-title-label .panel-title-icon,
.status-panel .status-bucket-label .panel-title-icon {
  width: 14px !important;
  height: 14px !important;
  color: currentColor !important;
}

.status-panel .stat-row {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: baseline !important;
  gap: 10px !important;
  padding: 3px 0 !important;
  color: var(--c-muted) !important;
  font-size: 11px !important;
  line-height: 1.25 !important;
}

.status-panel .stat-row span {
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  color: var(--c-muted) !important;
  font-weight: 700 !important;
}

.status-panel .stat-row strong {
  color: var(--c-white) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  white-space: nowrap !important;
}

.status-panel .progressbar {
  display: block !important;
  width: 100% !important;
  height: 8px !important;
  min-height: 8px !important;
  margin: 4px 0 7px !important;
  overflow: hidden !important;
  border: 1px solid rgba(120, 170, 210, 0.26) !important;
  background: rgba(0, 0, 0, 0.34) !important;
  box-shadow: none !important;
}

.status-panel .progressbar__fill {
  display: block !important;
  height: 100% !important;
  width: var(--value, 0%) !important;
  min-width: 0 !important;
  max-width: 100% !important;
  background: linear-gradient(90deg, var(--accent, var(--c-cyan)), color-mix(in srgb, var(--accent, var(--c-cyan)) 68%, white)) !important;
  box-shadow: 0 0 12px color-mix(in srgb, var(--accent, var(--c-cyan)) 60%, transparent) !important;
}

.status-panel .status-subject__name {
  margin-top: 8px !important;
  font-size: 14px !important;
  line-height: 1.2 !important;
}

.status-panel .status-subject__desc {
  margin-top: 8px !important;
  color: var(--c-muted) !important;
  font-size: 11px !important;
  line-height: 1.35 !important;
}

.status-panel .status-subject__meta {
  display: grid !important;
  grid-template-columns: 94px minmax(0, 1fr) !important;
  gap: 8px !important;
  margin-top: 8px !important;
}

.status-panel .status-subject__state {
  margin-top: 12px !important;
  padding-top: 10px !important;
  border-top: 1px solid rgba(46, 155, 255, 0.18) !important;
}

.status-panel .status-bucket {
  min-height: 48px !important;
}

.status-panel .status-bucket__items {
  max-height: 86px !important;
  overflow-y: auto !important;
  padding-right: 4px !important;
}

.status-panel .status-verdict-bar {
  padding: 10px 12px 12px !important;
}

/* v162: concept-art inspired status dots and procedural icon slots. */
.status-panel .status-dot-metric {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto auto !important;
  align-items: center !important;
  gap: 9px !important;
  padding: 5px 0 !important;
  color: var(--c-muted) !important;
}

.status-panel .status-dot-metric__label {
  min-width: 0 !important;
  overflow: hidden !important;
  color: var(--c-muted) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.status-panel .status-dot-metric__dots {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
}

.status-panel .status-dot-metric__dot {
  width: 7px !important;
  height: 7px !important;
  border-radius: 50% !important;
  background: rgba(120, 170, 210, 0.16) !important;
  box-shadow: inset 0 0 0 1px rgba(120, 170, 210, 0.10) !important;
}

.status-panel .status-dot-metric__dot.is-filled {
  background: var(--accent, var(--c-cyan)) !important;
  box-shadow: 0 0 8px color-mix(in srgb, var(--accent, var(--c-cyan)) 72%, transparent) !important;
}

.status-panel .status-dot-metric__value {
  color: var(--c-white) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  line-height: 1.2 !important;
  white-space: nowrap !important;
}

.status-panel .status-segment-meter {
  margin-top: 8px !important;
}

.status-panel .status-segment-meter__head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  color: var(--c-muted) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
}

.status-panel .status-segment-meter__head strong {
  color: var(--c-white) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  white-space: nowrap !important;
}

.status-panel .status-segment-meter__track {
  display: grid !important;
  grid-template-columns: repeat(var(--segment-count, 10), minmax(0, 1fr)) !important;
  gap: 3px !important;
  margin-top: 8px !important;
}

.status-panel .status-segment-meter__segment {
  height: 9px !important;
  border: 1px solid rgba(46, 155, 255, 0.26) !important;
  background: rgba(0, 0, 0, 0.22) !important;
}

.status-panel .status-segment-meter__segment.is-filled {
  border-color: color-mix(in srgb, var(--accent, var(--c-cyan)) 72%, transparent) !important;
  background: var(--accent, var(--c-cyan)) !important;
  box-shadow: 0 0 8px color-mix(in srgb, var(--accent, var(--c-cyan)) 50%, transparent) !important;
}

.procedure-panel .status-procedure-row {
  margin-top: 10px !important;
  padding-top: 10px !important;
  border-top: 1px solid rgba(46, 155, 255, 0.14) !important;
}

.procedure-panel .status-procedure-row:first-of-type {
  border-top: 0 !important;
}

.procedure-panel .status-procedure-row__head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  color: var(--accent, var(--c-cyan)) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: 0.045em !important;
  line-height: 1.2 !important;
  text-transform: uppercase !important;
}

.procedure-panel .status-procedure-row__head strong {
  color: var(--accent, var(--c-cyan)) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  white-space: nowrap !important;
}

.procedure-panel .status-procedure-row__slots {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin-top: 8px !important;
}

.procedure-panel .status-procedure-slot {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 31px !important;
  height: 27px !important;
  border: 1px dashed color-mix(in srgb, var(--accent, var(--c-cyan)) 46%, transparent) !important;
  background: rgba(0, 0, 0, 0.16) !important;
  color: var(--accent, var(--c-cyan)) !important;
  opacity: 0.62 !important;
}

.procedure-panel button.status-procedure-slot {
  padding: 0 !important;
  appearance: none !important;
  cursor: pointer !important;
}

.procedure-panel .status-procedure-slot.is-filled {
  border-style: solid !important;
  background: color-mix(in srgb, var(--accent, var(--c-cyan)) 13%, transparent) !important;
  opacity: 1 !important;
  box-shadow: 0 0 10px color-mix(in srgb, var(--accent, var(--c-cyan)) 44%, transparent), inset 0 0 10px color-mix(in srgb, var(--accent, var(--c-cyan)) 16%, transparent) !important;
}

.procedure-panel button.status-procedure-slot.is-filled:hover,
.procedure-panel button.status-procedure-slot.is-filled:focus-visible {
  color: var(--c-white) !important;
  border-color: var(--accent, var(--c-cyan)) !important;
  box-shadow: 0 0 14px color-mix(in srgb, var(--accent, var(--c-cyan)) 70%, transparent), inset 0 0 12px color-mix(in srgb, var(--accent, var(--c-cyan)) 24%, transparent) !important;
}

.procedure-panel .status-procedure-slot__icon {
  width: 18px !important;
  height: 18px !important;
  color: currentColor !important;
  stroke-width: 2.1 !important;
}

.procedure-panel .status-procedure-row__note {
  margin-top: 7px !important;
  color: var(--c-muted) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
}

.modal-card--report .report-procedure-panel {
  margin-top: 18px !important;
}

.modal-card--report .report-procedure-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 16px !important;
  margin-top: 10px !important;
}

.modal-card--report .report-procedure-slots,
.modal-card--report .report-procedure-detail {
  min-height: 220px !important;
  border: 1px solid rgba(46, 155, 255, 0.18) !important;
  background: rgba(0, 0, 0, 0.16) !important;
  padding: 12px !important;
}

.modal-card--report .report-procedure-detail {
  border-color: rgba(46, 155, 255, 0.18) !important;
}

.modal-card--report .report-procedure-detail__title {
  color: var(--accent, var(--c-cyan)) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: 0.05em !important;
  line-height: 1.2 !important;
  text-transform: uppercase !important;
}

.modal-card--report .report-procedure-detail__body {
  max-height: 260px !important;
  margin-top: 10px !important;
  overflow-y: auto !important;
  padding-right: 6px !important;
}

@media (max-width: 980px) {
  .modal-card--report .report-procedure-grid {
    grid-template-columns: 1fr !important;
  }
}

/* === UI POLISH: Segment meter glow, STAN inline, KONTROLA count, procedural status panel === */

/* 1) STAN ROZMOWCY title row - inline with emotion state value right-aligned */
.status-block__title--with-value {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
}

.status-title-value {
  color: var(--c-white) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  text-align: right !important;
  margin-left: auto !important;
  white-space: nowrap !important;
  opacity: 0.9;
}

/* 2) KONTROLA ROZMOWY - count displayed inline with segments */
.status-block--control .status-segment-meter {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  margin-top: 6px !important;
}

.status-block--control .status-segment-meter__track {
  order: 1 !important;
  flex: 1 1 auto !important;
  margin-top: 0 !important;
}

.status-block--control .status-segment-meter__head {
  order: 2 !important;
  display: flex !important;
  margin-top: 0 !important;
  flex: 0 0 auto !important;
}

.status-block--control .status-segment-meter__head span {
  display: none !important;
}

.status-block--control .status-segment-meter__head strong {
  color: var(--c-white) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  white-space: nowrap !important;
}

/* 4) Disable glow for KONTROLA ROZMOWY segments */
.status-block--control .status-panel .status-segment-meter__segment.is-filled,
.status-block--control .status-segment-meter__segment.is-filled {
  box-shadow: none !important;
  border-color: var(--accent, var(--c-cyan)) !important;
  background: var(--accent, var(--c-cyan)) !important;
}

/* 5) Procedural progress in status panel - uses same procedure-panel styles as WERDYKT modal */
.status-panel .report-procedure-panel {
  margin-top: 0 !important;
  padding-top: 10px !important;
  margin-bottom: 0 !important;
}

.status-panel .report-procedure-panel .report-procedure-slots {
  width: 100% !important;
  min-width: 0 !important;
}

/* Procedural progress row container (inline 3-column layout) */
.procedure-panel .status-procedure-row__container {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto auto !important;
  align-items: center !important;
  gap: 12px !important;
}

.procedure-panel .status-procedure-row__label {
  color: var(--accent, var(--c-cyan)) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  line-height: 1.2 !important;
}

.procedure-panel .status-procedure-row__slots {
  margin-top: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
}

.procedure-panel .status-procedure-row__value {
  color: var(--accent, var(--c-cyan)) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  white-space: nowrap !important;
  line-height: 1.2 !important;
}



/* 6) WERDYKT modal - equal evidence columns, readiness bar */
.report-modal-grid--evidence {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.report-readiness-bar {
  display: flex !important;
  align-items: baseline !important;
  gap: 16px !important;
  margin-top: 10px !important;
  padding: 10px 14px !important;
  background: rgba(10, 18, 26, 0.6) !important;
  border: 1px solid rgba(255, 200, 0, 0.18) !important;
  border-radius: 2px !important;
}

.report-readiness-bar .report-readiness__score {
  color: var(--c-yellow) !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  white-space: nowrap !important;
  flex: 0 0 auto !important;
}

.report-readiness-bar .report-readiness__hint {
  color: var(--c-muted) !important;
  font-size: 11px !important;
  line-height: 1.4 !important;
  flex: 1 1 auto !important;
}

/* 7) Remove glow from Reputation top meter */
html:root[data-theme] body .top-meter__pip--on,
html:root[data-theme] body .pip--on,
html:root[data-theme] body .top-meter__segments,
html:root[data-theme] body .pip-row,
html:root[data-theme] body .topbar .top-meter__segments,
html:root[data-theme] body .topbar .top-meter__pip--on,
html:root[data-theme] body .top-meter--segments .top-meter__segments,
html:root[data-theme] body .top-meter--segments .top-meter__pip--on,
.topbar .top-meter__segments,
.top-meter__segments,
.top-meter__pip,
.top-meter__pip--on,
.top-meter .pip,
.top-meter .pip--on {
  filter: none !important;
  box-shadow: none !important;
}

/* 8) Align CASE STATUS panel header and body padding with center panel tab-row */
.status-panel:not(.status-panel--collapsed) > .panel__head {
  height: 46px !important;
  min-height: 46px !important;
  padding: 10px 12px 0 !important;
  justify-content: flex-start !important;
  border-bottom: 0 !important;
  background: transparent !important;
  display: flex !important;
  align-items: center !important;
}

.status-panel:not(.status-panel--collapsed) > .panel__body {
  padding-top: 0 !important;
}

/* Inline note for procedure row */
.procedure-panel .status-procedure-row__note-inline {
  color: var(--c-muted) !important;
  font-size: 9px !important;
  text-transform: none !important;
  font-weight: normal !important;
  margin-left: 3px !important;
  display: inline !important;
}

/* Suspect name inline styling */
.status-panel .status-subject-name-value {
  color: var(--c-white) !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  text-transform: none !important;
  white-space: nowrap !important;
  margin-left: auto !important;
}

.status-panel .status-subject__meta strong {
  text-align: right !important;
}

/* 9) Make Reputation segments perfect squares, and color Conversation Control value text */
.top-meter__pip,
.top-meter--segments .top-meter__pip,
.map-header-panel .top-meter--segments .top-meter__pip {
  width: 10px !important;
  height: 10px !important;
}

.status-block--control .status-segment-meter__head strong {
  color: var(--accent, var(--c-cyan)) !important;
}

/* 10) Make Procedural Progress icons and boxes smaller (2/3 of Verdict size) */
.status-panel .report-procedure-panel .status-procedure-slot {
  width: 20px !important;
  height: 18px !important;
}

.status-panel .report-procedure-panel .status-procedure-slot__icon {
  width: 12px !important;
  height: 12px !important;
}

.status-panel .report-procedure-panel .status-procedure-row__slots {
  gap: 4px !important;
}

/* 11) Verdict panel - align columns and set DECISION AUTH detail border same as other panels */
.modal-card--report .report-procedure-detail {
  border-color: rgba(46, 155, 255, 0.18) !important;
}

/* 12) Verdict panel - new readiness panel in place of findings list */
.report-readiness-panel,
.report-readiness-panel .report-evidence-panel__body {
  overflow: hidden !important;
}

.report-readiness-panel__body {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  align-items: center !important;
  text-align: center !important;
  height: 100% !important;
  gap: 4px !important;
  padding: 0 !important;
  overflow: hidden !important;
}

.report-readiness-score {
  color: var(--c-yellow) !important;
  font-size: 26px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
}

.report-readiness-hint {
  color: var(--c-muted) !important;
  font-size: 11px !important;
  line-height: 1.4 !important;
  margin: 0 !important;
}

/* 13) Verdict panel - vertical compaction */
.modal-card--report .report-procedure-slots,
.modal-card--report .report-procedure-detail {
  height: 210px !important;
  min-height: 210px !important;
  max-height: 210px !important;
}

.modal-card--report .report-procedure-detail__body {
  max-height: 161px !important;
}

.modal-card--report .report-procedure-panel .status-procedure-row {
  margin-top: 6px !important;
  padding-top: 6px !important;
}

.modal-card--report .report-procedure-panel .status-procedure-row:first-of-type {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

.modal-card--report .report-evidence-panel {
  min-height: 145px !important;
  max-height: 145px !important;
  padding: 8px 12px !important;
}

.modal-card--report .report-evidence-panel__title {
  margin-bottom: 6px !important;
}

.modal-card--report .report-evidence-panel__body {
  min-height: 108px !important;
  max-height: 108px !important;
}

.modal-card--report .report-evidence-panel .report-fact {
  padding: 0 0 4px !important;
}

.modal-card--report .report-evidence-panel .report-fact + .report-fact {
  padding-top: 4px !important;
  border-top: 1px solid rgba(82, 104, 120, 0.15) !important;
}

.modal-card--report .report-evidence-panel .report-fact__body {
  margin: 1px 0 0 23px !important;
  font-size: 10.5px !important;
  line-height: 1.25 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 1 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.modal-card--report .report-procedure-panel {
  margin-top: 10px !important;
}

.modal-card--report .report-modal-grid--evidence {
  margin-top: 10px !important;
}

.modal-card--report .report-verdict-title {
  margin-top: 18px !important;
}

.modal-card--report .report-verdict-row {
  margin-top: 10px !important;
}

