:root {
  /* ── COLORS ── */
  --ink: #0f0f0f;
  --ink-2: #2a2a2a;
  --ink-3: #5a5a5a;
  --rule: #e0ddd8;
  --bg: #f4f3f0;
  --accent: #12094c;
  --accent-light: #eceaf5;
  --accent-mid: #2a1a8a;
  --paper: #ffffff;
  --sidebar-w: 0px;
  --green: #1a6b3a;
  --green-bg: #e8f4ed;
  --amber: #854f0b;
  --amber-bg: #faeeda;

  /* ── FONTS ── */
  --mono: 'DM Sans', sans-serif;
  --serif: 'Playfair Display', Georgia, serif;
  --sans: 'DM Sans', sans-serif;

  /* ── FONT WEIGHTS ── */
  --weight-light: 300;
  --weight-normal: 400;
  --weight-medium: 500;
  --weight-bold: 700;

  /* ── TYPE SCALE ── */
  /* Extra Large: Page titles, modal headers */
  --text-xl-size: 32px;
  --text-xl-weight: var(--weight-medium);
  --text-xl-line: 1.2;
  --text-xl-letter: -0.01em;

  /* Large: Section headers, subtitles */
  --text-lg-size: 24px;
  --text-lg-weight: var(--weight-medium);
  --text-lg-line: 1.3;
  --text-lg-letter: -0.005em;

  /* Medium: Subheadings, form labels */
  --text-md-size: 18px;
  --text-md-weight: var(--weight-normal);
  --text-md-line: 1.4;
  --text-md-letter: 0em;

  /* Base: Body text, buttons */
  --text-base-size: 14px;
  --text-base-weight: var(--weight-normal);
  --text-base-line: 1.5;
  --text-base-letter: 0em;

  /* Small: Secondary text, hints */
  --text-sm-size: 12px;
  --text-sm-weight: var(--weight-normal);
  --text-sm-line: 1.5;
  --text-sm-letter: 0.02em;

  /* Extra Small: Tags, badges, mono text */
  --text-xs-size: 11px;
  --text-xs-weight: var(--weight-normal);
  --text-xs-line: 1.4;
  --text-xs-letter: 0.04em;

  /* Tiny: Smallest labels, captions */
  --text-tiny-size: 9px;
  --text-tiny-weight: var(--weight-normal);
  --text-tiny-line: 1.3;
  --text-tiny-letter: 0.06em;

  /* ── RADII ── */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;

  /* ── TRANSITIONS ── */
  --transition-fast: all 0.12s;
  --transition-std: all 0.15s;
}

/* Mind Map */
.mind-map-panel {
  display: flex;
  flex-direction: column;
  min-height: 620px;
  background: #fbfbfd;
  border: 1px solid rgba(17,24,39,0.10);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 10px 28px rgba(17,24,39,0.06);
}
.mind-map-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px 14px;
  border-bottom: 1px solid rgba(17,24,39,0.08);
  background: #f6f5fa;
  flex-wrap: wrap;
}
.mind-map-account-chips {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  width: 100%;
}
.mind-map-account-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(17,24,39,0.10);
  border-radius: 999px;
  background: #fff;
  color: #2f3340;
  min-height: 38px;
  max-width: 260px;
  padding: 7px 13px;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(17,24,39,0.07);
  text-transform: none;
  letter-spacing: 0;
  font-family: var(--sans);
  font-size: 14px;
}
.mind-map-account-chip.active {
  border-color: rgba(109,91,208,0.36);
  background: #fff;
  box-shadow: inset 0 0 0 1px rgba(109,91,208,0.10), 0 2px 9px rgba(17,24,39,0.08);
}
.mind-map-chip-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  flex: 0 0 auto;
}
.mind-map-chip-kind {
  border: 1px solid rgba(109,91,208,0.30);
  border-radius: 6px;
  color: #6d5bd0;
  padding: 1px 6px;
  font-size: 11px;
  line-height: 1.2;
  background: #f3f0ff;
}
.mind-map-chip-count {
  color: #94949f;
  font-size: 13px;
}
.mind-map-side-picker {
  display: flex;
  align-items: center;
  gap: 7px;
}
.mind-map-side-picker label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.mind-map-side-picker select {
  min-width: 180px;
  max-width: 260px;
  padding: 7px 10px;
  border: 1px solid var(--rule);
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 13px;
}
.mind-map-toolbar-spacer {
  flex: 1;
  min-width: 12px;
}
.mind-map-btn,
.mind-map-icon-btn {
  border: 1px solid var(--rule);
  background: var(--paper);
  color: var(--ink-2);
  cursor: pointer;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 7px 10px;
}
.mind-map-icon-btn {
  width: 42px;
  height: 42px;
  padding: 0;
  font-size: 24px;
  line-height: 1;
  border-radius: 9px;
  text-transform: none;
  letter-spacing: 0;
  background: rgba(255,255,255,0.94);
  box-shadow: 0 1px 5px rgba(17,24,39,0.08);
}
.mind-map-btn:hover,
.mind-map-icon-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
}
.mind-map-workspace {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 370px;
  min-height: 560px;
}
.mind-map-stage {
  position: relative;
  min-height: 520px;
  height: min(68vh, 760px);
  overflow: hidden;
  background: #fbfbfd;
}
.mind-map-controls {
  position: absolute;
  top: 16px;
  left: 16px;
  z-index: 3;
  display: flex;
  gap: 7px;
}
.mind-map-breadcrumbs {
  position: absolute;
  top: auto;
  left: 96px;
  right: auto;
  bottom: 14px;
  z-index: 3;
  display: flex;
  align-items: center;
  gap: 7px;
  min-height: 32px;
  pointer-events: none;
}
.mind-map-breadcrumbs button {
  border: 1px solid rgba(17,24,39,0.10);
  background: rgba(255,255,255,0.92);
  color: var(--ink-2);
  border-radius: 999px;
  padding: 7px 12px;
  cursor: pointer;
  pointer-events: auto;
  font-family: var(--sans);
  font-size: 12px;
  text-transform: none;
  letter-spacing: 0;
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.mind-map-breadcrumbs span {
  color: rgba(17,24,39,0.38);
}
#mind-map-canvas {
  display: block;
  width: 100%;
  height: 100%;
  cursor: grab;
}
#mind-map-canvas.is-dragging {
  cursor: grabbing;
}
.mind-map-tooltip {
  position: absolute;
  z-index: 4;
  max-width: 300px;
  display: none;
  pointer-events: auto;
  background: var(--paper);
  border: 1px solid rgba(17,24,39,0.10);
  border-radius: 8px;
  box-shadow: 0 14px 36px rgba(17,24,39,0.14);
  padding: 10px 12px;
  color: var(--ink);
}
.mind-map-tooltip.open {
  display: block;
}
.mind-map-tip-kicker {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 5px;
}
.mind-map-tip-title {
  font-family: var(--serif);
  font-size: 15px;
  line-height: 1.25;
  color: var(--ink);
  margin-bottom: 6px;
}
.mind-map-tip-meta {
  font-family: var(--sans);
  font-size: 12px;
  line-height: 1.45;
  color: var(--ink-2);
}
.mind-map-tip-action {
  margin-top: 9px;
  border: 1px solid var(--accent);
  background: var(--accent);
  color: #fff;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 6px 9px;
  cursor: pointer;
}
.mind-map-empty {
  position: absolute;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 28px;
  text-align: center;
  color: var(--ink-3);
  font-family: var(--sans);
  font-size: 14px;
  background: rgba(255,255,255,0.72);
}
.mind-map-empty.open {
  display: flex;
}
.mind-map-zoom-stage {
  position: absolute;
  left: 16px;
  bottom: 14px;
  z-index: 3;
  border: 1px solid rgba(17,24,39,0.10);
  border-radius: 999px;
  background: rgba(255,255,255,0.92);
  color: var(--ink-3);
  padding: 7px 11px;
  font-family: var(--sans);
  font-size: 13px;
  letter-spacing: 0.04em;
}
.mind-map-detail {
  position: relative;
  border-left: 1px solid rgba(17,24,39,0.10);
  background: #fff;
  padding: 24px 24px 18px;
  overflow: auto;
  max-height: min(68vh, 760px);
}
.mind-map-detail-close {
  position: absolute;
  top: 18px;
  right: 18px;
  width: 36px;
  height: 36px;
  border: 1px solid rgba(17,24,39,0.13);
  border-radius: 9px;
  background: #fff;
  color: var(--ink-3);
  cursor: pointer;
  font-size: 22px;
  line-height: 1;
}
.mind-map-detail-kicker,
.mind-map-detail-label {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.mind-map-detail h3 {
  margin: 8px 44px 8px 0;
  font-family: var(--sans);
  font-size: 22px;
  line-height: 1.2;
  font-weight: 600;
  color: var(--ink);
}
.mind-map-detail-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 20px;
}
.mind-map-detail-tags span {
  border-radius: 999px;
  background: #efedf7;
  color: #514878;
  padding: 4px 9px;
  font-size: 12px;
}
.mind-map-detail-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  border-top: 1px solid rgba(17,24,39,0.09);
  border-bottom: 1px solid rgba(17,24,39,0.09);
  padding: 18px 0;
  margin-bottom: 20px;
}
.mind-map-detail-stats div {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.mind-map-detail-stats b {
  font-size: 27px;
  line-height: 1.1;
  color: var(--ink);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}
.mind-map-detail-stats span {
  color: var(--ink-3);
  font-size: 12px;
}
.mind-map-detail-section {
  margin-top: 20px;
}
.mind-map-split-bar {
  display: flex;
  height: 13px;
  overflow: hidden;
  border-radius: 999px;
  background: #e8e8ef;
  margin: 10px 0 12px;
}
.mind-map-split-bar span {
  display: block;
}
.mind-map-split-row {
  display: grid;
  grid-template-columns: 12px minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  margin: 8px 0;
  color: var(--ink-2);
  font-size: 13px;
}
.mind-map-split-row b {
  color: var(--ink-3);
  font-weight: 500;
}
.mind-map-bars {
  display: flex;
  align-items: end;
  gap: 8px;
  min-height: 94px;
  padding-top: 12px;
  overflow-x: auto;
}
.mind-map-year-bar {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: end;
  gap: 5px;
  min-width: 34px;
}
.mind-map-year-bar span {
  display: block;
  width: 100%;
  border-radius: 5px 5px 1px 1px;
  background: #a9adc4;
  opacity: 0.92;
}
.mind-map-year-bar small {
  color: var(--ink-3);
  font-size: 10px;
}
.mind-map-example {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 8px;
  width: 100%;
  border: 0;
  border-top: 1px solid var(--rule);
  background: transparent;
  color: var(--ink-2);
  padding: 10px 0;
  text-align: left;
  cursor: pointer;
  text-transform: none;
  letter-spacing: 0;
  font-size: 13px;
}
.mind-map-example span {
  color: var(--ink-3);
  font-family: var(--mono);
  font-size: 11px;
}
.mind-map-example b {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 500;
}
.mind-map-feature-list {
  border: 1px solid rgba(17,24,39,0.08);
  border-radius: 8px;
  background: #fafafc;
  margin: 10px 0 12px;
  padding: 10px 12px;
}
.mind-map-feature-kicker {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 7px;
}
.mind-map-feature-row {
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr);
  gap: 8px;
  align-items: start;
  padding: 6px 0;
  border-top: 1px solid rgba(17,24,39,0.06);
}
.mind-map-feature-row:first-of-type {
  border-top: 0;
}
.mind-map-feature-row span {
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: #efedf7;
  color: #514878;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--mono);
  font-size: 10px;
}
.mind-map-feature-row b {
  color: var(--ink-2);
  font-size: 12px;
  line-height: 1.45;
  font-weight: 500;
}
.mind-map-detail-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 22px;
}
.mind-map-muted {
  color: var(--ink-3);
  font-size: 12px;
  padding: 8px 0;
}
.supercharge-tip-host {
  position: relative;
}
.supercharge-tip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  margin-left: 6px;
  border: 1px solid rgba(177, 120, 22, 0.34);
  border-radius: 999px;
  background: #fffaf0;
  color: #8a5a00;
  font-size: 11px;
  line-height: 1;
  vertical-align: middle;
  cursor: help;
  box-shadow: 0 1px 4px rgba(31, 41, 55, 0.08);
  transition: transform 0.12s ease, border-color 0.12s ease, background 0.12s ease;
  flex: 0 0 auto;
}
.supercharge-tip-bulb {
  position: relative;
  display: inline-block;
  width: 9px;
  height: 11px;
  border: 1.7px solid #b17816;
  border-radius: 50% 50% 42% 42%;
  background: #ffd970;
  box-shadow: inset 0 0 0 2px rgba(255,255,255,0.28);
}
.supercharge-tip-bulb::after {
  content: '';
  position: absolute;
  left: 2px;
  right: 2px;
  bottom: -4px;
  height: 3px;
  border-radius: 1px;
  background: #8a5a00;
}
.supercharge-tip:hover,
.supercharge-tip:focus {
  outline: none;
  transform: translateY(-1px);
  border-color: rgba(177, 120, 22, 0.72);
  background: #fff3cf;
}
.supercharge-tip-overlay {
  position: absolute;
  top: 8px;
  right: 10px;
  margin-left: 0;
  z-index: 8;
}
.chart-panel-header.supercharge-tip-host {
  padding-right: 44px;
}
.mind-map-toolbar.supercharge-tip-host {
  padding-right: 44px;
}
.supercharge-tip-popover {
  position: fixed;
  z-index: 9200;
  width: min(270px, calc(100vw - 20px));
  padding: 10px 12px;
  border: 1px solid rgba(177, 120, 22, 0.28);
  border-radius: 6px;
  background: #fffdf7;
  color: var(--ink-2);
  box-shadow: 0 12px 30px rgba(17, 24, 39, 0.14);
  font-family: var(--sans);
  pointer-events: none;
}
.supercharge-tip-title {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 5px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #7a520a;
}
.supercharge-tip-text {
  font-size: 12px;
  line-height: 1.45;
}
.mind-map-footer {
  display: flex;
  align-items: center;
  gap: 14px;
  border-top: 1px solid rgba(17,24,39,0.10);
  flex-wrap: wrap;
  background: #fff;
}
.mind-map-table-toggle {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 0 10px 14px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-3);
}
#mm-table-account-buttons {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.mind-map-table-btn {
  border: 1px solid var(--rule);
  background: var(--paper);
  color: var(--ink-2);
  cursor: pointer;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 6px 9px;
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.mind-map-table-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
}
.mind-map-table-btn.active {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
.mind-map-status {
  padding: 12px 14px;
  min-height: 58px;
  font-family: var(--sans);
  font-size: 13px;
  color: var(--ink-2);
  flex: 1;
  min-width: 240px;
}

@media (max-width: 860px) {
  .mind-map-workspace {
    grid-template-columns: 1fr;
  }
  .mind-map-detail {
    border-left: 0;
    border-top: 1px solid var(--rule);
    max-height: none;
  }
  .mind-map-breadcrumbs {
    left: 18px;
    top: 62px;
  }
  .mind-map-side-picker select {
    min-width: 132px;
    max-width: 42vw;
  }
}
* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-weight: var(--weight-light);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  display: flex;
  min-height: 100vh;
}

/* ── TYPOGRAPHY UTILITIES ── */
.text-xl { font-size: var(--text-xl-size); font-weight: var(--text-xl-weight); line-height: var(--text-xl-line); letter-spacing: var(--text-xl-letter); }
.text-lg { font-size: var(--text-lg-size); font-weight: var(--text-lg-weight); line-height: var(--text-lg-line); letter-spacing: var(--text-lg-letter); }
.text-md { font-size: var(--text-md-size); font-weight: var(--text-md-weight); line-height: var(--text-md-line); letter-spacing: var(--text-md-letter); }
.text-base { font-size: var(--text-base-size); font-weight: var(--text-base-weight); line-height: var(--text-base-line); letter-spacing: var(--text-base-letter); }
.text-sm { font-size: var(--text-sm-size); font-weight: var(--text-sm-weight); line-height: var(--text-sm-line); letter-spacing: var(--text-sm-letter); }
.text-xs { font-size: var(--text-xs-size); font-weight: var(--text-xs-weight); line-height: var(--text-xs-line); letter-spacing: var(--text-xs-letter); }
.text-tiny { font-size: var(--text-tiny-size); font-weight: var(--text-tiny-weight); line-height: var(--text-tiny-line); letter-spacing: var(--text-tiny-letter); }

.font-serif { font-family: var(--serif); }
.font-mono { font-family: var(--mono); }
.font-sans { font-family: var(--sans); }

.font-light { font-weight: var(--weight-light); }
.font-normal { font-weight: var(--weight-normal); }
.font-medium { font-weight: var(--weight-medium); }
.font-bold { font-weight: var(--weight-bold); }

/* ── UNIFIED COMPONENT STYLES (All using type scale) ── */
h1, h2, h3, h4, h5, h6 { font-weight: var(--weight-medium); }
h1 { font-size: var(--text-xl-size); line-height: var(--text-xl-line); letter-spacing: var(--text-xl-letter); }
h2 { font-size: var(--text-lg-size); line-height: var(--text-lg-line); letter-spacing: var(--text-lg-letter); }
h3 { font-size: var(--text-md-size); line-height: var(--text-md-line); letter-spacing: var(--text-md-letter); }
h4 { font-size: var(--text-base-size); line-height: var(--text-base-line); letter-spacing: var(--text-base-letter); }
h5 { font-size: var(--text-sm-size); line-height: var(--text-sm-line); letter-spacing: var(--text-sm-letter); }
h6 { font-size: var(--text-xs-size); line-height: var(--text-xs-line); letter-spacing: var(--text-xs-letter); }

button, input, select, textarea { font-family: inherit; font-size: inherit; }
button { font-weight: var(--weight-medium); }

/* ── GLOBAL TYPE SCALE ENFORCEMENT ── */
/* Normalize all scattered font sizes to type scale */
[class*="label"], [class*="caption"], [class*="badge"], [class*="tag"] { font-size: var(--text-xs-size); }
[class*="btn"], [class*="button"], button { font-size: var(--text-sm-size); font-weight: var(--weight-medium); }
input, textarea, select { font-size: var(--text-base-size); }

/* Override scattered font sizes throughout component CSS */
*[style*="font-size: var(--text-tiny-size)"] { font-size: var(--text-tiny-size) !important; }
*[style*="font-size: var(--text-xs-size)"] { font-size: var(--text-xs-size) !important; }
*[style*="font-size: var(--text-xs-size)"] { font-size: var(--text-xs-size) !important; }
*[style*="font-size: var(--text-sm-size)"] { font-size: var(--text-sm-size) !important; }
*[style*="font-size: var(--text-sm-size)"] { font-size: var(--text-sm-size) !important; }
*[style*="font-size: var(--text-base-size)"] { font-size: var(--text-base-size) !important; }
*[style*="font-size: var(--text-base-size)"] { font-size: var(--text-base-size) !important; }
*[style*="font-size: var(--text-lg-size)"] { font-size: var(--text-lg-size) !important; }
*[style*="font-size: var(--text-xl-size)"] { font-size: var(--text-xl-size) !important; }
*[style*="font-size: var(--text-xl-size)"] { font-size: var(--text-xl-size) !important; }
.sidebar { display: none; }
.sidebar-logo {
  padding: 22px 20px 18px; border-bottom: 1px solid rgba(255,255,255,0.08);
  text-decoration: none; display: block;
}
.sidebar-logo-text { font-family: var(--mono); font-size: var(--text-sm-size); font-weight: var(--weight-medium); letter-spacing: 0.08em; color: white; }
.sidebar-logo-text span { color: rgba(255,255,255,0.4); }
.sidebar-logo-sub { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.28); margin-top: 3px; }

.sidebar-nav { padding: 14px 0; flex: 1; }
.nav-section-label { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.18em; text-transform: uppercase; color: rgba(255,255,255,0.28); padding: 12px 20px 5px; }
.nav-item {
  display: flex; align-items: center; gap: 10px; padding: 8px 20px;
  font-family: var(--mono); font-size: var(--text-sm-size); letter-spacing: 0.04em;
  color: rgba(255,255,255,0.52); cursor: pointer; transition: background 0.15s, color 0.15s;
  text-decoration: none; border-left: 2px solid transparent;
}
.nav-item:hover { background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.85); }
.nav-item.active { background: rgba(255,255,255,0.1); color: white; border-left-color: rgba(255,255,255,0.5); }
.nav-icon { width: 14px; height: 14px; flex-shrink: 0; opacity: 0.6; }
.nav-item.active .nav-icon { opacity: 1; }

.sidebar-user { padding: 14px 20px; border-top: 1px solid rgba(255,255,255,0.08); display: flex; align-items: center; gap: 10px; }
.user-avatar { width: 28px; height: 28px; background: rgba(255,255,255,0.14); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--mono); font-size: var(--text-xs-size); font-weight: var(--weight-medium); color: white; flex-shrink: 0; }
.user-name { font-family: var(--mono); font-size: var(--text-xs-size); color: rgba(255,255,255,0.65); letter-spacing: 0.04em; }
.user-plan { font-size: var(--text-xs-size); color: rgba(255,255,255,0.3); }

/* ── MAIN LAYOUT ── */
.main { margin-left: var(--sidebar-w); flex: 1; display: flex; flex-direction: column; min-height: 100vh; }

/* ── TOPBAR ── */
.topbar {
  background: var(--paper); border-bottom: 1px solid var(--rule);
  padding: 0 32px; height: 54px; display: flex; align-items: center; gap: 14px;
  position: sticky; top: 0; z-index: 50;
}
.topbar-crumb { font-family: var(--mono); font-size: var(--text-sm-size); color: var(--ink-2); letter-spacing: 0.05em; display: flex; align-items: center; gap: 8px; }
.topbar-crumb span { color: var(--ink-2); }
.topbar-sep { color: var(--rule); }
.topbar-actions { margin-left: auto; display: flex; gap: 8px; align-items: center; }
.tb-btn { font-family: var(--mono); font-size: var(--text-sm-size); letter-spacing: 0.08em; text-transform: uppercase; padding: 7px 14px; border: 1px solid var(--rule); background: none; color: var(--ink-2); cursor: pointer; transition: all 0.15s; }
.tb-btn:hover { border-color: var(--accent); color: var(--accent); }
.tb-btn.primary { background: var(--accent); color: white; border-color: var(--accent); }
.tb-btn.primary:hover { background: var(--accent-mid); }
.date-range { font-family: var(--mono); font-size: var(--text-sm-size); color: var(--ink-2); letter-spacing: 0.05em; background: var(--bg); border: 1px solid var(--rule); padding: 6px 12px; }

/* ── MAINTENANCE MODE ── */
#maintenance-overlay {
  position: fixed;
  inset: 0;
  z-index: 9900;
  display: none;
  align-items: center;
  justify-content: center;
  background: var(--bg);
  flex-direction: column;
}
#maintenance-overlay.open { display: flex; }
.maintenance-card {
  max-width: 520px;
  width: 90%;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 12px;
  padding: 48px 40px 40px;
  text-align: center;
  box-shadow: 0 8px 40px rgba(0,0,0,0.08);
}
.maintenance-icon {
  font-size: var(--text-xl-size);
  margin-bottom: 20px;
  line-height: 1;
}
.maintenance-title {
  font-family: var(--serif);
  font-size: var(--text-lg-size);
  font-weight: var(--weight-medium);
  color: var(--ink);
  margin-bottom: 12px;
  letter-spacing: -0.01em;
}
.maintenance-message {
  font-family: var(--sans);
  font-size: var(--text-base-size);
  color: var(--ink-3);
  line-height: 1.6;
  margin-bottom: 28px;
}
.maintenance-badge {
  display: inline-block;
  font-family: var(--mono);
  font-size: var(--text-xs-size);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  background: var(--accent-light);
  border: 1px solid rgba(18,9,76,0.12);
  border-radius: 4px;
  padding: 4px 10px;
}

/* ── AUTH ── */
.auth-overlay,
.login-overlay {
  position: fixed;
  inset: 0;
  z-index: 9800;
  display: none;
  align-items: center;
  justify-content: center;
  background: var(--bg);
}
.auth-overlay.open,
.login-overlay.open { display: flex; }
.auth-overlay.hidden,
.login-overlay.hidden { display: none; }
/* ── DATA LOADING INTERSTITIAL ── */
#data-loading-overlay {
  position: fixed; inset: 0; z-index: 9700;
  display: none; align-items: center; justify-content: center;
  background: var(--paper);
  flex-direction: column; gap: 0;
  opacity: 1; transition: opacity 0.3s;
}
#data-loading-overlay.open { display: flex; }
#data-loading-overlay.fade-out { opacity: 0; pointer-events: none; }
.dl-card {
  text-align: center; padding: 48px 40px 40px; max-width: 480px;
  display: flex; flex-direction: column; align-items: center; gap: 0;
}
.dl-brand { font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 10px; }
.dl-title { font-family: var(--serif); font-size: var(--text-xl-size); font-weight: var(--weight-medium); color: var(--ink); margin-bottom: 28px; letter-spacing: -0.01em; }
.dl-spinner-wrap { display: flex; align-items: center; justify-content: center; gap: 10px; margin-bottom: 18px; }
.dl-spinner { width: 18px; height: 18px; border: 2px solid var(--rule); border-top-color: var(--accent); border-radius: 50%; animation: backend-spin 0.75s linear infinite; }
.dl-status { font-family: var(--mono); font-size: var(--text-sm-size); color: var(--ink-2); line-height: 1.5; letter-spacing: 0.04em; }
.dl-status strong { color: var(--ink); font-weight: var(--weight-bold); }
.dl-progress-wrap { width: 220px; height: 2px; background: var(--rule); border-radius: 1px; margin: 0 auto; overflow: hidden; }
.dl-progress-bar { height: 100%; width: 0%; background: var(--accent); border-radius: 1px; transition: width 0.4s ease; }
.dl-sub { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-3); margin-top: 12px; letter-spacing: 0.06em; }
.auth-modal,
.login-card {
  width: 420px;
  max-width: 96vw;
  background: var(--paper);
  border: 1px solid var(--rule);
  box-shadow: 0 20px 80px rgba(0,0,0,0.12);
  overflow: hidden;
  animation: authModalIn 0.28s cubic-bezier(.16,1,.3,1);
}
.auth-modal:has(#auth-mode-signup.active),
.login-card:has(#auth-mode-signup.active) {
  width: 560px;
}
@keyframes authModalIn {
  from { transform: translateY(8px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}
.auth-brand,
.login-brand {
  background: var(--accent);
  padding: 28px 32px 24px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.auth-eyebrow,
.login-brand-logo {
  font-family: var(--mono);
  font-size: var(--text-xs-size);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  margin-bottom: 6px;
}
.auth-title,
.login-brand-name {
  font-family: var(--serif);
  font-size: var(--text-lg-size);
  font-weight: var(--weight-medium);
  color: #fff;
  line-height: 1.1;
}
.auth-sub,
.login-brand-sub {
  font-family: var(--mono);
  font-size: var(--text-tiny-size);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.4);
  margin-top: 4px;
}
.auth-body,
.login-body {
  padding: 28px 32px 32px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.auth-status {
  display: none;
  margin-top: -4px;
  border: 1px solid #e4caca;
  background: #fbefef;
  padding: 7px 10px;
  font-family: var(--mono);
  font-size: var(--text-tiny-size);
  letter-spacing: 0.06em;
  color: #a02020;
}
.auth-status.error { display: block; border-color: #e4caca; background: #fbefef; color: #a02020; }
.auth-status.ok { display: block; border-color: #b9d7c2; background: #edf7f1; color: #1a6b3a; }
.login-error {
  display: none;
  margin-top: -4px;
  border: 1px solid #e4caca;
  background: #fbefef;
  padding: 7px 10px;
  font-family: var(--mono);
  font-size: var(--text-tiny-size);
  letter-spacing: 0.06em;
  color: #a02020;
}
.login-error.show { display: block; }
.auth-mode { display: none; }
.auth-mode.active { display: block; }
.auth-fields {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
.auth-field,
.login-field { display: flex; flex-direction: column; gap: 6px; }
.pw-wrap { position:relative; display:flex; align-items:center; }
.pw-wrap input { flex:1; padding-right:36px !important; }
.pw-eye { position:absolute; right:10px; background:none; border:none; cursor:pointer; color:var(--ink-3); font-size: var(--text-base-size); padding:0; line-height:1; user-select:none; }
.pw-eye:hover { color:var(--ink); }
.auth-field.full { grid-column: 1 / span 1; }
.auth-label,
.login-label {
  font-family: var(--mono);
  font-size: var(--text-tiny-size);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
}
.auth-input,
.login-input {
  width: 100%;
  font-family: var(--mono);
  font-size: var(--text-sm-size);
  letter-spacing: 0.03em;
  color: var(--ink);
  border: 1px solid var(--rule);
  background: var(--bg);
  padding: 10px 12px;
  outline: none;
}
.auth-input:focus,
.login-input:focus { border-color: var(--accent); background: var(--paper); }
.auth-input.error,
.login-input.error { border-color: #a02020; }
.auth-textarea {
  min-height: 58px;
  resize: vertical;
  line-height: 1.4;
  letter-spacing: 0.01em;
}
.auth-signup-fields {
  grid-template-columns: 1fr 1fr;
  gap: 10px 12px;
}
.auth-signup-fields .auth-field:nth-child(1),
.auth-signup-fields .auth-field:nth-child(n+4) {
  grid-column: 1 / -1;
}
.auth-plan-row {
  margin-top: 12px;
  padding: 10px 12px;
  border: 1px solid var(--rule);
  background: var(--bg);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-family: var(--mono);
  font-size: var(--text-tiny-size);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.auth-plan-row strong {
  color: var(--accent);
  font-weight: var(--weight-bold);
}
.auth-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
}
.auth-btn {
  font-family: var(--mono);
  font-size: var(--text-xs-size);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 10px 12px;
  border: 1px solid var(--rule);
  background: none;
  color: var(--ink-2);
  cursor: pointer;
  width: 100%;
}
.auth-btn:hover { border-color: var(--accent); color: var(--accent); }
.auth-btn.primary,
.login-submit {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
.auth-btn.primary:hover,
.login-submit:hover { background: var(--accent-mid); border-color: var(--accent-mid); color: #fff; }
.auth-register-btn {
  display: block;
  margin-top: 8px;
}
.auth-btn:disabled,
.auth-btn[aria-disabled="true"] {
  opacity: 0.42;
  cursor: not-allowed;
  border-color: var(--rule);
  color: var(--ink-3);
}
.auth-btn:disabled:hover,
.auth-btn[aria-disabled="true"]:hover {
  border-color: var(--rule);
  color: var(--ink-3);
}
.auth-note {
  margin-top: 8px;
  font-family: var(--mono);
  font-size: var(--text-tiny-size);
  letter-spacing: 0.06em;
  color: var(--ink-3);
  line-height: 1.45;
}
.auth-footer-row,
.login-footer-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--mono);
  font-size: var(--text-tiny-size);
  letter-spacing: 0.06em;
  color: var(--ink-3);
  margin-top: -4px;
}
.auth-footer-link,
.login-footer-link {
  color: var(--accent);
  cursor: pointer;
  text-decoration: none;
}
.auth-footer-link:hover,
.login-footer-link:hover { text-decoration: underline; }
.login-or {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--mono);
  font-size: var(--text-tiny-size);
  letter-spacing: 0.1em;
  color: var(--ink-3);
}
.login-or::before,
.login-or::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--rule);
}
.login-sso-btn {
  font-family: var(--mono);
  font-size: var(--text-xs-size);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 10px;
  background: none;
  color: var(--ink-2);
  border: 1px solid var(--rule);
  cursor: pointer;
  transition: all 0.15s;
  width: 100%;
}
.login-sso-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
}
@media (max-width: 640px) {
  .auth-signup-fields {
    grid-template-columns: 1fr;
  }
  .auth-signup-fields .auth-field {
    grid-column: 1 / -1;
  }
}
.auth-admin-wrap {
  margin-top: 12px;
  border-top: 1px solid var(--rule);
  padding-top: 12px;
}
.auth-client-card {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 10px 12px; background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.12);
  cursor: pointer; transition: background 0.13s;
}
.auth-client-card:hover { background: rgba(255,255,255,0.14); border-color: rgba(255,255,255,0.28); }
.auth-client-card-name { font-family: var(--mono); font-size: var(--text-xs-size); font-weight: var(--weight-medium); color: #fff; }
.auth-client-card-id { font-family: var(--mono); font-size: var(--text-tiny-size); color: rgba(255,255,255,0.4); margin-top: 2px; letter-spacing: 0.06em; }
.auth-client-enter { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.1em; text-transform: uppercase;
  padding: 4px 10px; background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.2);
  color: rgba(255,255,255,0.8); cursor: pointer; transition: all 0.13s; flex-shrink: 0; }
.auth-client-enter:hover { background: #fff; color: var(--accent); }
.auth-admin-title {
  font-family: var(--mono);
  font-size: var(--text-tiny-size);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 8px;
}

/* ── Admin Portal Overlay ─────────────────────────────────────── */
#admin-portal {
  position: fixed; inset: 0; z-index: 9000;
  background: rgba(10,10,18,0.72); backdrop-filter: blur(4px);
  display: none; align-items: center; justify-content: center;
}
#admin-portal.open { display: flex; }
body.admin-home .sidebar,
body.admin-home .main { display: none !important; }
.ap-panel {
  background: var(--bg, #fff); border: 1px solid var(--rule, #e0e0e0);
  border-radius: 12px; width: 1400px; max-width: 96vw; max-height: 92vh;
  display: flex; flex-direction: column; overflow: hidden;
  box-shadow: 0 24px 64px rgba(0,0,0,0.28); position: relative;
}
.ap-header {
  display: flex; align-items: center; gap: 12px; padding: 18px 22px 14px;
  border-bottom: 1px solid var(--rule, #e0e0e0); flex-shrink: 0;
}
.ap-header-icon {
  width: 32px; height: 32px; border-radius: 6px; background: var(--accent, #4f8ef7);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.ap-header-title { font-size: var(--text-base-size); font-weight: var(--weight-bold); color: var(--ink, #0a0a12); flex: 1; }
.ap-header-sub { font-family: var(--mono, monospace); font-size: var(--text-xs-size); color: var(--ink-3, #888); margin-top: 1px; }
.ap-close {
  width: 28px; height: 28px; border: none; background: none; cursor: pointer;
  color: var(--ink-3, #888); font-size: var(--text-md-size); line-height: 1; display: flex;
  align-items: center; justify-content: center; border-radius: 4px;
  transition: background 0.12s;
}
.ap-close:hover { background: var(--bg-2, #f5f5f5); color: var(--ink, #0a0a12); }
.ap-search-bar {
  padding: 12px 22px 10px; flex-shrink: 0; border-bottom: 1px solid var(--rule, #e0e0e0);
}
.ap-search {
  width: 100%; box-sizing: border-box; padding: 8px 12px;
  border: 1px solid var(--rule, #e0e0e0); border-radius: 6px;
  font-family: var(--mono, monospace); font-size: var(--text-xs-size); background: var(--bg, #fff);
  color: var(--ink, #0a0a12); outline: none;
}
.ap-search:focus { border-color: var(--accent, #4f8ef7); }
.ap-active-banner {
  padding: 8px 22px; background: var(--accent-light, #eef3ff); border-bottom: 1px solid var(--rule, #e0e0e0);
  font-family: var(--mono, monospace); font-size: var(--text-xs-size); color: var(--accent, #4f8ef7);
  letter-spacing: 0.06em; flex-shrink: 0; display: none; align-items: center; gap: 6px;
}
.ap-active-banner.visible { display: flex; }
.ap-body {
  flex: 1; overflow-y: auto; display: flex; flex-direction: column;
}
.ap-client-card {
  border: 1px solid var(--rule, #e0e0e0); border-radius: 8px; padding: 14px 16px;
  cursor: pointer; transition: all 0.13s; background: var(--bg, #fff);
  display: flex; flex-direction: column; gap: 4px; position: relative;
}
.ap-client-card:hover { border-color: var(--accent, #4f8ef7); background: var(--accent-light, #eef3ff); }
.ap-client-card.active-client { border-color: var(--accent, #4f8ef7); background: var(--accent-light, #eef3ff); }
.ap-client-name { font-size: var(--text-sm-size); font-weight: var(--weight-bold); color: var(--ink, #0a0a12); }
.ap-client-id { font-family: var(--mono, monospace); font-size: var(--text-tiny-size); color: var(--ink-3, #888); letter-spacing: 0.06em; }
.ap-client-enter {
  margin-top: 10px; padding: 5px 10px; border: 1px solid var(--accent, #4f8ef7);
  border-radius: 4px; background: none; color: var(--accent, #4f8ef7);
  font-family: var(--mono, monospace); font-size: var(--text-tiny-size); letter-spacing: 0.1em;
  text-transform: uppercase; cursor: pointer; transition: all 0.12s; align-self: flex-start;
}
.ap-client-enter:hover { background: var(--accent, #4f8ef7); color: #fff; }
.ap-active-badge {
  position: absolute; top: 10px; right: 10px;
  font-family: var(--mono, monospace); font-size: var(--text-tiny-size); letter-spacing: 0.08em;
  text-transform: uppercase; background: var(--accent, #4f8ef7); color: #fff;
  padding: 2px 6px; border-radius: 3px;
}
.ap-footer {
  padding: 14px 22px; border-top: 1px solid var(--rule, #e0e0e0); flex-shrink: 0;
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
}
.ap-new-client-btn {
  padding: 7px 16px; border: 1px dashed var(--accent, #4f8ef7); border-radius: 6px;
  background: none; color: var(--accent, #4f8ef7); font-family: var(--mono, monospace);
  font-size: var(--text-xs-size); letter-spacing: 0.08em; text-transform: uppercase; cursor: pointer;
  transition: all 0.12s;
}
.ap-new-client-btn:hover { background: var(--accent-light, #eef3ff); }
.ap-signout-btn {
  padding: 7px 14px; border: 1px solid var(--rule, #e0e0e0); border-radius: 6px;
  background: none; color: var(--ink-3, #888); font-family: var(--mono, monospace);
  font-size: var(--text-xs-size); letter-spacing: 0.08em; text-transform: uppercase; cursor: pointer;
  transition: all 0.12s;
}
.ap-signout-btn:hover { border-color: #c0392b; color: #c0392b; }
.ap-empty { padding: 32px; text-align: center; color: var(--ink-3,#888); font-family: var(--mono,monospace); font-size: var(--text-xs-size); }
.ap-loading { padding: 32px; text-align: center; color: var(--ink-3,#888); font-family: var(--mono,monospace); font-size: var(--text-xs-size); }
/* Admin portal tabs */
.ap-tabs { display: flex; border-bottom: 1px solid var(--rule,#e0e0e0); flex-shrink: 0; }
.ap-tab { flex: 1; padding: 10px 12px; border: none; background: none; cursor: pointer; font-family: var(--mono,monospace); font-size: var(--text-xs-size); letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3,#888); border-bottom: 2px solid transparent; margin-bottom: -1px; transition: color 0.12s; }
.ap-tab:hover { color: var(--accent,#4f8ef7); }
.ap-tab.active { color: var(--accent,#4f8ef7); border-bottom-color: var(--accent,#4f8ef7); }
.ap-tab-pane { display: none; flex: 1; flex-direction: column; overflow: hidden; min-height: 0; }
.ap-tab-pane.active { display: flex; }
/* Client list rows */
.ap-client-grid-head { display: none; }
.ap-client-row {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 22px;
  border-bottom: 1px solid var(--rule,#e0e0e0);
  transition: background 0.1s;
}
.ap-client-row:last-child { border-bottom: none; }
.ap-client-row:hover { background: var(--bg-2,#f7f7f8); }
.ap-client-row.active-client { background: var(--accent-light,#eef3ff); }
.ap-client-row-name-wrap { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.ap-client-row-name { font-size: var(--text-md-size); font-weight: var(--weight-bold); color: var(--ink,#0a0a12); line-height: 1.2; }
.ap-client-row-sub { font-family: var(--mono,monospace); font-size: var(--text-tiny-size); letter-spacing: 0.06em; color: var(--ink-3,#999); }
.ap-client-row-controls { display: flex; align-items: center; gap: 4px; flex-shrink: 0; }
.ap-client-row-actions { display: flex; align-items: center; gap: 4px; flex-shrink: 0; }
.ap-client-row-mode { display: none; }
.ap-client-row-feature { padding: 3px 7px; border: 1px solid var(--rule,#ddd); border-radius: 3px; background: none; color: var(--ink-3,#888); font-family: var(--mono,monospace); font-size: var(--text-tiny-size); letter-spacing: 0.04em; text-transform: uppercase; cursor: pointer; transition: all 0.12s; white-space: nowrap; }
.ap-client-row-feature:hover:not(:disabled) { border-color: var(--accent,#4f8ef7); color: var(--accent,#4f8ef7); }
.ap-client-row-feature.on { border-color: #7dc5a1; color: #0f5a34; background: #eaf7f0; }
.ap-client-row-feature:disabled { opacity: 0.5; cursor: not-allowed; }
.ap-client-row-danger { padding: 3px 7px; border: 1px solid #e0c0c0; border-radius: 3px; background: none; color: #b03535; font-family: var(--mono,monospace); font-size: var(--text-tiny-size); letter-spacing: 0.04em; text-transform: uppercase; cursor: pointer; transition: all 0.12s; white-space: nowrap; }
.ap-client-row-danger:hover:not(:disabled) { border-color: #b03535; background: #fdf0f0; }
.ap-client-row-danger:disabled { opacity: 0.5; cursor: not-allowed; }
.ap-client-row-enter { padding: 4px 12px; border: 1px solid var(--accent,#4f8ef7); border-radius: 4px; background: var(--accent,#4f8ef7); color: #fff; font-family: var(--mono,monospace); font-size: var(--text-tiny-size); letter-spacing: 0.06em; text-transform: uppercase; cursor: pointer; transition: all 0.12s; white-space: nowrap; flex-shrink: 0; }
.ap-client-row-enter:hover:not(:disabled) { background: #3a6fd4; }
.ap-client-row-enter:disabled { opacity: 0.5; cursor: not-allowed; }
.ap-client-row-sync { padding: 3px 7px; border: 1px solid var(--rule,#ccc); border-radius: 3px; background: none; color: var(--ink-3,#777); font-family: var(--mono,monospace); font-size: var(--text-tiny-size); letter-spacing: 0.04em; text-transform: uppercase; cursor: pointer; transition: all 0.12s; white-space: nowrap; }
.ap-client-row-sync:hover:not(:disabled) { border-color: var(--ink,#444); color: var(--ink,#333); }
.ap-client-row-sync:disabled { opacity: 0.5; cursor: not-allowed; }
.ap-client-row-sync.synced { border-color: #2a9d5c; color: #2a9d5c; }
.ap-client-row-sync.sync-err { border-color: #c0392b; color: #c0392b; }
/* Loading overlay on panel */
.ap-panel-loading { position: absolute; inset: 0; display: none; align-items: center; justify-content: center; background: rgba(var(--bg-rgb,255,255,255),0.88); border-radius: 12px; z-index: 10; flex-direction: column; gap: 14px; }
.ap-panel-loading.show { display: flex; }
.ap-spinner { width: 30px; height: 30px; border: 3px solid var(--rule,#e0e0e0); border-top-color: var(--accent,#4f8ef7); border-radius: 50%; animation: ap-spin 0.7s linear infinite; }
@keyframes ap-spin { to { transform: rotate(360deg); } }
.ap-loading-label { font-family: var(--mono,monospace); font-size: var(--text-xs-size); color: var(--ink-3,#888); letter-spacing: 0.06em; }
/* Inline forms */
.ap-form { padding: 18px 22px; display: flex; flex-direction: column; gap: 11px; overflow-y: auto; flex: 1; }
.ap-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 11px; }
.ap-form-field { display: flex; flex-direction: column; gap: 4px; }
.ap-form-label { font-family: var(--mono,monospace); font-size: var(--text-tiny-size); letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3,#888); }
.ap-form-input { padding: 7px 10px; border: 1px solid var(--rule,#e0e0e0); border-radius: 4px; font-family: var(--mono,monospace); font-size: var(--text-xs-size); background: var(--bg,#fff); color: var(--ink,#0a0a12); outline: none; width: 100%; box-sizing: border-box; }
.ap-form-input:focus { border-color: var(--accent,#4f8ef7); }
.ap-form-actions { display: flex; gap: 8px; align-items: center; }
.ap-form-btn { padding: 7px 16px; border: none; border-radius: 4px; background: var(--accent,#4f8ef7); color: #fff; font-family: var(--mono,monospace); font-size: var(--text-xs-size); letter-spacing: 0.08em; text-transform: uppercase; cursor: pointer; transition: opacity 0.12s; }
.ap-form-btn:hover { opacity: 0.85; }
.ap-form-btn.sec { background: none; border: 1px solid var(--rule,#e0e0e0); color: var(--ink-3,#888); }
.ap-form-btn.sec:hover { border-color: var(--accent,#4f8ef7); color: var(--accent,#4f8ef7); }
.ap-form-msg { font-family: var(--mono,monospace); font-size: var(--text-xs-size); color: var(--ink-3,#888); }
.ap-form-msg.ok { color: var(--green,#27ae60); }
.ap-form-msg.err { color: #c0392b; }
.ap-feature-toggle { display: inline-flex; align-items: center; gap: 8px; font-family: var(--mono,monospace); font-size: var(--text-tiny-size); letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-2,#444); }
.ap-feature-toggle input { width: 13px; height: 13px; margin: 0; accent-color: var(--accent,#4f8ef7); cursor: pointer; }
.ap-section-title { font-family: var(--mono,monospace); font-size: var(--text-tiny-size); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-3,#888); padding: 14px 22px 6px; border-bottom: 1px solid var(--rule,#e0e0e0); flex-shrink: 0; }
/* User rows */
.ap-user-row { display: flex; align-items: center; padding: 10px 22px; border-bottom: 1px solid var(--rule,#e0e0e0); gap: 10px; }
.ap-user-row:last-child { border-bottom: none; }
.ap-user-name { flex: 1; font-family: var(--mono,monospace); font-size: var(--text-xs-size); color: var(--ink,#0a0a12); }
.ap-user-client { font-family: var(--mono,monospace); font-size: var(--text-tiny-size); letter-spacing: 0.06em; color: var(--ink-3,#888); text-transform: uppercase; min-width: 110px; text-align: right; }
.ap-user-role { font-family: var(--mono,monospace); font-size: var(--text-tiny-size); color: var(--ink-3,#888); letter-spacing: 0.06em; margin-right: 8px; }
.ap-user-action { padding: 4px 10px; border: 1px solid var(--rule,#e0e0e0); border-radius: 4px; background: none; color: var(--ink-3,#888); font-family: var(--mono,monospace); font-size: var(--text-tiny-size); letter-spacing: 0.06em; text-transform: uppercase; cursor: pointer; transition: all 0.12s; }
.ap-user-action:hover { border-color: var(--accent,#4f8ef7); color: var(--accent,#4f8ef7); }
.ap-user-action.danger { border-color: #e7b3b3; color: #b03535; background: #fff8f8; }
.ap-user-action.danger:hover { border-color: #b03535; color: #8c1f1f; }
/* Cost tracking panel */
.ap-costs-kpi-banner { display: flex; gap: 1px; padding: 10px 22px; flex-shrink: 0; background: var(--bg-2,#f7f7f8); border-bottom: 1px solid var(--rule,#e0e0e0); }
.ap-costs-kpi { flex: 1; text-align: center; padding: 6px 8px; }
.ap-costs-kpi-label { font-family: var(--mono,monospace); font-size: var(--text-tiny-size); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-3,#888); margin-bottom: 2px; }
.ap-costs-kpi-value { font-family: var(--mono,monospace); font-size: var(--text-base-size); font-weight: var(--weight-bold); color: var(--ink,#0a0a12); letter-spacing: 0.02em; }
.ap-costs-client-row { display: flex; align-items: center; padding: 11px 22px; border-bottom: 1px solid var(--rule,#e0e0e0); gap: 10px; cursor: pointer; transition: background 0.1s; }
.ap-costs-client-row:last-child { border-bottom: none; }
.ap-costs-client-row:hover { background: var(--accent-light,#eef3ff); }
.ap-costs-client-name { flex: 1; font-size: var(--text-sm-size); font-weight: var(--weight-bold); color: var(--ink,#0a0a12); }
.ap-costs-client-stats { display: flex; align-items: center; gap: 14px; }
.ap-costs-client-stat { font-family: var(--mono,monospace); font-size: var(--text-xs-size); color: var(--ink-3,#888); }
.ap-costs-client-cost { font-family: var(--sans,'DM Sans',sans-serif); font-size: var(--text-sm-size); font-weight: var(--weight-bold); color: var(--ink,#0a0a12); }
.ap-costs-client-enter { padding: 5px 13px; border: 1px solid var(--accent,#4f8ef7); border-radius: 4px; background: none; color: var(--accent,#4f8ef7); font-family: var(--mono,monospace); font-size: var(--text-tiny-size); letter-spacing: 0.1em; text-transform: uppercase; cursor: pointer; transition: all 0.12s; }
.ap-costs-client-enter:hover { background: var(--accent,#4f8ef7); color: #fff; }
.ap-costs-detail-toolbar { display: flex; align-items: center; gap: 12px; padding: 10px 22px; border-bottom: 1px solid var(--rule,#e0e0e0); flex-shrink: 0; background: var(--bg-2,#f7f7f8); }
.ap-costs-back-btn { padding: 4px 10px; border: 1px solid var(--rule,#ddd); border-radius: 4px; background: #fff; color: var(--ink,#0a0a12); font-family: var(--mono,monospace); font-size: var(--text-tiny-size); letter-spacing: 0.06em; cursor: pointer; transition: all 0.12s; }
.ap-costs-back-btn:hover { border-color: var(--accent,#4f8ef7); color: var(--accent,#4f8ef7); }
.ap-costs-detail-title { font-size: var(--text-base-size); font-weight: var(--weight-bold); color: var(--ink,#0a0a12); }
.ap-costs-detail-kpis { display: flex; gap: 1px; padding: 14px 22px; flex-shrink: 0; }
.ap-costs-detail-kpi { flex: 1; padding: 8px 10px; background: var(--bg-2,#f7f7f8); text-align: center; }
.ap-costs-detail-kpi:first-child { border-radius: 4px 0 0 4px; }
.ap-costs-detail-kpi:last-child { border-radius: 0 4px 4px 0; }
.ap-costs-detail-section { padding: 12px 22px 8px; }
.ap-costs-detail-section-title { font-family: var(--mono,monospace); font-size: var(--text-tiny-size); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-3,#888); margin-bottom: 8px; }
.ap-costs-feat-row { display: flex; align-items: center; padding: 6px 0; border-bottom: 1px solid var(--rule,#e0e0e0); gap: 8px; }
.ap-costs-feat-row:last-child { border-bottom: none; }
.ap-costs-feat-name { flex: 1; font-size: var(--text-xs-size); color: var(--ink,#0a0a12); }
.ap-costs-feat-bar-wrap { width: 60px; flex-shrink: 0; }
.ap-costs-feat-bar { height: 4px; border-radius: 2px; background: var(--accent,#4f8ef7); transition: width 0.3s; }
.ap-costs-feat-stat { font-family: var(--mono,monospace); font-size: var(--text-xs-size); color: var(--ink-3,#888); white-space: nowrap; }
.ap-costs-table { width: 100%; border-collapse: collapse; font-size: var(--text-xs-size); }
.ap-costs-table th { text-align: left; padding: 5px 6px; font-family: var(--mono,monospace); font-size: var(--text-tiny-size); color: var(--ink-3,#888); font-weight: var(--weight-normal); letter-spacing: 0.06em; text-transform: uppercase; border-bottom: 1px solid var(--rule,#e0e0e0); }
.ap-costs-table td { padding: 5px 6px; border-bottom: 1px solid var(--rule,#e0e0e0); }
.ap-costs-table tr:last-child td { border-bottom: none; }
.ap-costs-table .mono { font-family: var(--mono,monospace); font-size: var(--text-xs-size); }
.ap-costs-table .right { text-align: right; }
/* Batch jobs in task dropdown */
.task-batch-section { border-top: 1px solid var(--rule); }
.task-batch-item { display: flex; align-items: center; padding: 9px 12px; gap: 9px; border-bottom: 1px solid var(--rule); cursor: pointer; transition: background 0.1s; }
.task-batch-item:last-child { border-bottom: none; }
.task-batch-item:hover { background: var(--accent-light); }
.task-batch-body { flex: 1; min-width: 0; }
.task-batch-title { font-family: var(--mono); font-size: var(--text-xs-size); font-weight: var(--weight-medium); color: var(--ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.task-batch-sub { font-size: var(--text-xs-size); color: var(--ink-3); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.task-batch-badge { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.06em; text-transform: uppercase; padding: 2px 5px; border-radius: 2px; flex-shrink: 0; }
.task-batch-badge.RUNNING,.task-batch-badge.STARTING,.task-batch-badge.RUNNABLE { background: #e8f5e9; color: #27ae60; }
.task-batch-badge.SUBMITTED,.task-batch-badge.PENDING { background: #fff8e1; color: #f39c12; }
.task-batch-badge.SUCCEEDED { background: var(--accent-light); color: var(--accent); }
.task-batch-badge.FAILED { background: #fde8e8; color: #c0392b; }
.task-batch-badge.UNKNOWN { background: var(--bg-2,#f5f5f5); color: var(--ink-3); }
/* Batch log modal */
#ap-log-modal { display: none; position: fixed; inset: 0; z-index: 9100; align-items: center; justify-content: center; background: rgba(10,10,18,0.7); backdrop-filter: blur(3px); }
#ap-log-modal.open { display: flex; }
.ap-log-panel { background: #111118; border: 1px solid #2a2a3a; border-radius: 8px; width: 760px; max-width: 95vw; max-height: 86vh; display: flex; flex-direction: column; overflow: hidden; box-shadow: 0 24px 64px rgba(0,0,0,0.5); }
.ap-log-header { display: flex; align-items: center; gap: 10px; padding: 13px 18px; border-bottom: 1px solid #2a2a3a; flex-shrink: 0; }
.ap-log-title { font-family: var(--mono); font-size: var(--text-xs-size); font-weight: var(--weight-bold); color: #e0e8f8; flex: 1; }
.ap-log-close { width: 26px; height: 26px; border: none; background: none; cursor: pointer; color: #6a6a8a; font-size: var(--text-md-size); line-height: 1; border-radius: 4px; }
.ap-log-close:hover { background: #2a2a3a; color: #e0e8f8; }
.ap-log-body { flex: 1; overflow-y: auto; padding: 14px 18px; background: #0c0c16; font-family: var(--mono); font-size: var(--text-xs-size); color: #b0bcd8; line-height: 1.8; white-space: pre-wrap; word-break: break-all; }
.ap-log-msg { padding: 24px; text-align: center; color: #6a6a8a; font-family: var(--mono); font-size: var(--text-xs-size); }
/* topbar admin chip */
.ap-topbar-chip {
  display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px;
  background: var(--accent-light, #eef3ff); border: 1px solid var(--accent, #4f8ef7);
  border-radius: 4px; font-family: var(--mono, monospace); font-size: var(--text-tiny-size);
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--accent, #4f8ef7);
  cursor: pointer; transition: all 0.12s; white-space: nowrap;
}
.ap-topbar-chip:hover { background: var(--accent, #4f8ef7); color: #fff; }
.auth-user-badge {
  font-family: var(--mono);
  font-size: var(--text-xs-size);
  color: var(--ink-3);
  border: 1px solid var(--rule);
  padding: 6px 10px;
  background: var(--bg);
  margin-bottom: 8px;
}
.auth-mode#auth-mode-bootstrap .auth-fields,
.auth-mode#auth-mode-manage .auth-fields {
  grid-template-columns: 1fr 1fr;
  gap: 9px;
}
.auth-mode#auth-mode-bootstrap .auth-field.full,
.auth-mode#auth-mode-manage .auth-field.full {
  grid-column: 1 / span 2;
}
.auth-mode#auth-mode-manage .auth-actions {
  flex-wrap: wrap;
}
.auth-mode#auth-mode-manage .auth-actions .auth-btn {
  width: auto;
  min-width: 120px;
}
.auth-mode#auth-mode-login .auth-subnote {
  font-size: var(--text-sm-size);
  color: var(--ink-3);
}

/* ── CONTENT ── */
.content { padding: 28px 32px; flex: 1; display: flex; flex-direction: column; gap: 20px; }

/* PAGE HEADER */
.page-header { display: flex; justify-content: space-between; align-items: flex-start; }
.page-header-left {}
.backend-status-row {
  display: none;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
  font-family: var(--mono);
  font-size: var(--text-xs-size);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.backend-status-row.show { display: inline-flex; }
.backend-status-spinner {
  width: 12px;
  height: 12px;
  border: 1.8px solid var(--rule);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: backend-spin 0.8s linear infinite;
  flex-shrink: 0;
}
.backend-status-spinner.done {
  animation: none;
  border-color: var(--green);
  border-top-color: var(--green);
}
@keyframes backend-spin { to { transform: rotate(360deg); } }

/* ── DATA-SYNCING BANNER ───────────────────────────────────────────── */
.data-syncing-banner {
  display: none;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  margin-bottom: 14px;
  border-radius: 8px;
  background: var(--bg-alt, #f8f4ee);
  border: 1px solid var(--accent, #b68d40);
  color: var(--ink, #1a1a1a);
  font-size: var(--text-sm-size);
  font-weight: 400;
  line-height: 1.4;
  animation: banner-fade-in 0.3s ease;
}
.data-syncing-banner.show { display: flex; }
.data-syncing-banner .sync-spinner {
  width: 16px; height: 16px; flex-shrink: 0;
  border: 2px solid var(--rule, #ddd);
  border-top-color: var(--accent, #b68d40);
  border-radius: 50%;
  animation: backend-spin 0.9s linear infinite;
}
.data-syncing-banner .sync-text { flex: 1; }
.data-syncing-banner .sync-text strong { font-weight: var(--weight-bold); }
.data-syncing-banner .sync-progress {
  height: 4px;
  background: var(--rule, #ddd);
  border-radius: 2px;
  margin-top: 6px;
  overflow: hidden;
}
.data-syncing-banner .sync-progress-bar {
  height: 100%;
  background: var(--accent, #b68d40);
  border-radius: 2px;
  transition: width 0.5s ease;
  width: 0%;
}
.data-syncing-banner.done {
  border-color: var(--green, #27ae60);
  background: color-mix(in srgb, var(--green, #27ae60) 8%, var(--bg, #fff));
}
.data-syncing-banner.done .sync-spinner {
  animation: none;
  border-color: var(--green, #27ae60);
  border-top-color: var(--green, #27ae60);
}
@keyframes banner-fade-in { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }

.page-eyebrow { font-family: var(--sans); font-size: var(--text-xs-size); letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); margin-bottom: 4px; font-weight: var(--weight-medium); }
.page-title { font-family: var(--serif); font-size: var(--text-lg-size); font-weight: var(--weight-medium); color: var(--ink); margin-bottom: 3px; }
.page-sub { font-size: var(--text-base-size); font-weight: var(--weight-light); color: var(--ink-2); }
.page-header-actions { display: flex; gap: 8px; padding-top: 4px; }
.page-title-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; margin-bottom: 3px; }

/* ── RECENT TASK DROPDOWN ───────────────────────────────────────────────── */
.task-dropdown-wrap { position: relative; display: inline-block; }
.task-dropdown-btn {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 7px 14px; border: 1px solid var(--rule); background: var(--paper);
  color: var(--ink-2); cursor: pointer; transition: all 0.13s; white-space: nowrap;
}
.task-dropdown-btn:hover { border-color: var(--accent); color: var(--accent); }
.task-dropdown-btn.has-tasks { border-color: var(--accent); color: var(--accent); }
.task-dropdown-btn svg { opacity: 0.55; transition: transform 0.15s; }
.task-dropdown-btn.open svg:last-child { transform: rotate(180deg); }
.task-dropdown-menu {
  display: none; position: absolute; top: calc(100% + 4px); left: 0;
  min-width: 320px; max-width: 400px; background: var(--paper); border: 1px solid var(--rule);
  box-shadow: 0 8px 32px rgba(0,0,0,0.14); z-index: 220; flex-direction: column;
}
.task-dropdown-menu.open { display: flex; }
.task-dropdown-header {
  padding: 6px 10px; font-family: var(--mono); font-size: var(--text-tiny-size);
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-3);
  border-bottom: 1px solid var(--rule); background: var(--bg);
}
.task-item {
  display: flex; align-items: flex-start; gap: 8px; padding: 8px 10px;
  cursor: pointer; border-bottom: 1px solid var(--rule); transition: background 0.1s;
}
.task-item:last-child { border-bottom: none; }
.task-item:hover { background: var(--accent-light); }
.task-item-icon { font-size: var(--text-sm-size); flex-shrink: 0; margin-top: 1px; color: var(--accent); }
.task-item-body { flex: 1; min-width: 0; }
.task-item-title {
  font-family: var(--mono); font-size: var(--text-tiny-size); font-weight: var(--weight-medium); color: var(--ink);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.task-item-sub {
  font-size: var(--text-xs-size); color: var(--ink-3); margin-top: 2px; font-weight: var(--weight-light);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.task-item-badge {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.05em; text-transform: uppercase;
  padding: 1px 6px; background: var(--accent-light); color: var(--accent); border: 1px solid #c5c0e8;
  display: inline-flex; width: auto; margin-top: 4px; align-self: flex-start;
}
.task-empty {
  padding: 12px 10px; font-family: var(--mono); font-size: var(--text-tiny-size);
  color: var(--ink-3); text-align: center; letter-spacing: 0.06em;
}
/* STATS ROW */
.stats-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.stat-card { background: var(--paper); border: 1px solid var(--rule); padding: 16px 18px; }
.stat-label { font-family: var(--mono); font-size: var(--text-sm-size); letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-2); margin-bottom: 9px; }
.stat-value { font-family: var(--serif); font-size: var(--text-lg-size); font-weight: var(--weight-normal); color: var(--ink); line-height: 1; }
.stat-sub { font-family: var(--sans); font-size: var(--text-sm-size); color: var(--ink-2); margin-top: 6px; font-weight: var(--weight-light); }

/* MAIN GRID */
.main-grid { display: grid; grid-template-columns: minmax(0, 1fr) 420px; gap: 16px; flex: 1; }
.main-grid > * { min-width: 0; }

/* ── PORTFOLIO SUB-TOGGLE ──────────────────────────────────────────────── */
.portfolio-subtoggle {
  display: flex; gap: 0; border-bottom: 1px solid var(--rule); background: var(--bg);
}
.pst-btn {
  display: flex; align-items: center; gap: 6px;
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 10px 18px; background: none; border: none; border-bottom: 2px solid transparent;
  color: var(--ink-2); cursor: pointer; transition: all 0.13s; margin-bottom: -1px;
}
.pst-btn:hover { color: var(--accent); }
.pst-btn.active { color: var(--accent); border-bottom-color: var(--accent); background: var(--paper); }
.pst-btn svg { opacity: 0.6; }
.pst-btn.active svg { opacity: 1; }
.pst-panel { display: none; }
.pst-panel.active { display: flex; flex-direction: column; }
/* Trend panel wrapper */
.pt-trend-wrap { display: flex; flex-direction: column; padding: 14px 18px 12px; gap: 10px; }
.pt-trend-controls { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
/* CHART PANEL */
.chart-panel { width: 100%; min-width: 0; background: var(--paper); border: 1px solid var(--rule); display: flex; flex-direction: column; }
body.pm-feature-map-active .chart-panel {
  width: 100%;
  max-width: none;
}
.chart-panel-header {
  padding: 16px 20px; border-bottom: 1px solid var(--rule);
  display: flex; align-items: center; justify-content: space-between; flex-wrap: nowrap; gap: 10px;
}
.chart-panel-title { font-family: var(--serif); font-size: var(--text-md-size); font-weight: var(--weight-medium); color: var(--ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.chart-panel-meta { font-family: var(--sans); font-size: var(--text-sm-size); color: var(--ink-2); letter-spacing: 0; margin-top: 4px; font-weight: var(--weight-light); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.view-toggle { display: flex; gap: 2px; }
.vt-btn { font-family: var(--sans); font-size: var(--text-xs-size); letter-spacing: 0.04em; text-transform: uppercase; padding: 5px 12px; border: 1px solid var(--rule); background: var(--bg); color: var(--ink-2); cursor: pointer; transition: all 0.15s; font-weight: var(--weight-medium); }
.vt-btn.active { background: var(--accent); color: white; border-color: var(--accent); }
.vt-btn:hover:not(.active) { border-color: var(--accent); color: var(--accent); }
.export-view-wrap { position: relative; display: inline-block; }
.export-view-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  height: 29px;
  border: 1px solid var(--accent);
  background: var(--accent);
  color: #fff;
  cursor: pointer;
  font-family: var(--sans);
  font-size: var(--text-xs-size);
  font-weight: var(--weight-medium);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 5px 12px;
  transition: all 0.15s;
}
.export-view-btn:hover { background: var(--accent-mid); border-color: var(--accent-mid); }
.export-view-btn span { font-family: var(--mono); font-size: var(--text-xs-size); line-height: 1; opacity: .72; }
.export-view-menu {
  position: absolute;
  top: calc(100% + 5px);
  right: 0;
  z-index: 200;
  min-width: 210px;
  overflow: hidden;
  border: 1px solid var(--rule);
  background: var(--paper);
  box-shadow: 0 12px 28px rgba(20,20,46,.14);
}
.export-view-menu div {
  border-bottom: 1px solid var(--rule);
  color: var(--ink-2);
  cursor: pointer;
  font-family: var(--mono);
  font-size: var(--text-tiny-size);
  letter-spacing: .08em;
  padding: 9px 12px;
  text-transform: uppercase;
}
.export-view-menu div:last-child { border-bottom: 0; }
.export-view-menu div:hover { background: var(--accent-light); color: var(--accent); }

/* CHART AREA */
.chart-area { display: flex; align-items: flex-start; padding: 20px; gap: 24px; }
.chart-canvas-wrap { position: relative; width: 405px; height: 405px; flex-shrink: 0; margin-top: 4px; }
.chart-center-label { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); text-align: center; pointer-events: none; max-width: 120px; }
.chart-center-num { font-family: var(--serif); font-size: var(--text-lg-size); font-weight: var(--weight-medium); color: var(--ink); display: block; }
.chart-center-sub { font-family: var(--mono); font-size: var(--text-base-size); letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-2); display: block; margin-top: 2px; }
.chart-center-name { font-family: var(--sans); font-size: var(--text-sm-size); color: var(--ink-2); display: block; margin-top: 4px; line-height: 1.6; font-weight: 400; }

/* LEGEND — dual column scrollable */
.chart-legend-wrap { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 8px; max-height: 440px; overflow: hidden; }
.legend-search { font-family: var(--sans); font-size: var(--text-base-size); padding: 10px 12px; border: 1px solid var(--rule); background: var(--bg); color: var(--ink); outline: none; width: 100%; }
.legend-search:focus { border-color: var(--accent); }
.legend-reset-bar { display: flex; justify-content: space-between; align-items: center; }
.legend-reset-btn { font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.08em; text-transform: uppercase; color: var(--accent); cursor: pointer; background: none; border: none; padding: 0; }
.legend-reset-btn:hover { text-decoration: underline; }
.legend-pinned-label { font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-2); }
.chart-legend { flex: 1; overflow-y: auto; display: flex; flex-direction: column; gap: 2px; }
.legend-group-header { font-family: var(--sans); font-size: 14px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-2); padding: 9px 8px 5px; border-top: 1px solid var(--rule); margin-top: 4px; display: flex; align-items: center; gap: 6px; cursor: pointer; font-weight: var(--weight-bold); }
.legend-group-header:first-child { border-top: none; margin-top: 0; }
.legend-group-dot { width: 8px; height: 8px; border-radius: 1px; flex-shrink: 0; }
.legend-group-count { font-family: var(--sans); font-size: 14px; color: var(--ink); font-weight: var(--weight-bold); }
.legend-item {
  display: flex; align-items: center; gap: 8px; padding: 6px 8px;
  border: 1px solid transparent; cursor: pointer; transition: all 0.12s;
}
.legend-item:hover { background: var(--bg); border-color: var(--rule); }
.legend-item.active { background: var(--accent-light); border-color: #c5c0e8; }
.legend-item.pinned { background: var(--accent-light); border-color: var(--accent); }
.legend-item.dimmed { opacity: 0.35; }
.legend-dot { width: 8px; height: 8px; border-radius: 2px; flex-shrink: 0; }
.legend-name { font-family: var(--sans); font-size: 12px; color: var(--ink); font-weight: 400; flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.legend-count { font-family: var(--sans); font-size: 12px; font-weight: var(--weight-bold); color: var(--ink); flex-shrink: 0; }
.legend-pct { font-family: var(--sans); font-size: 12px; color: var(--ink-2); font-weight: var(--weight-medium); min-width: 34px; text-align: right; flex-shrink: 0; }
.legend-pin-icon { font-size: var(--text-base-size); opacity: 0; transition: opacity 0.1s; flex-shrink: 0; }
.legend-item:hover .legend-pin-icon, .legend-item.pinned .legend-pin-icon { opacity: 1; }

/* SLICE DETAIL POPOVER */
.slice-popover {
  position: fixed; z-index: 200; background: var(--paper); border: 1px solid var(--rule);
  padding: 14px 16px; min-width: 220px; box-shadow: 0 4px 24px rgba(0,0,0,0.12);
  pointer-events: none; display: none;
}
.sp-group { font-family: var(--mono); font-size: var(--text-base-size); letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-2); margin-bottom: 4px; }
.sp-name { font-family: var(--serif); font-size: var(--text-base-size); font-weight: var(--weight-medium); color: var(--ink); margin-bottom: 10px; line-height: 1.6; }
.sp-row { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 6px; }
.sp-label { font-family: var(--mono); font-size: var(--text-sm-size); color: var(--ink-2); letter-spacing: 0.04em; }
.sp-val { font-family: var(--mono); font-size: var(--text-sm-size); font-weight: var(--weight-medium); color: var(--ink); }
.sp-bar-wrap { margin-top: 10px; background: var(--bg); height: 4px; }
.sp-bar { height: 4px; transition: width 0.3s; }
.sp-hint { font-family: var(--mono); font-size: var(--text-base-size); color: var(--ink-2); margin-top: 10px; letter-spacing: 0.06em; border-top: 1px solid var(--rule); padding-top: 8px; }

/* BOTTOM PANEL */
.bottom-panel { min-width: 0; background: var(--paper); border: 1px solid var(--rule); overflow: hidden; }
.bottom-panel-header {
  padding: 12px 20px; border-bottom: 1px solid var(--rule);
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
}
.bottom-panel-title { font-family: var(--mono); font-size: var(--text-sm-size); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-2); }
.selected-bucket { font-family: var(--mono); font-size: var(--text-sm-size); color: var(--accent); letter-spacing: 0.05em; }
.category-actions { display: flex; gap: 8px; align-items: center; margin-left: auto; }
.ca-select { font-family: var(--mono); font-size: var(--text-sm-size); padding: 6px 10px; border: 1px solid var(--rule); background: var(--bg); color: var(--ink-2); cursor: pointer; outline: none; appearance: none; }
.patent-table-wrap { max-width: 100%; overflow-x: auto; }
.patent-table { width: 100%; min-width: 980px; border-collapse: collapse; }
.patent-table th { padding: 10px 16px; text-align: left; font-family: var(--mono); font-size: var(--text-base-size); letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-2); border-bottom: 1px solid var(--rule); background: var(--bg); font-weight: var(--weight-medium); white-space: nowrap; }
.patent-table th.sortable { cursor: pointer; user-select: none; transition: color 0.15s; }
.patent-table th.sortable:hover { color: var(--accent); }
.patent-table th.sort-active { color: var(--accent); }
.sort-arrow { display: inline-block; margin-left: 4px; opacity: 0.4; font-style: normal; }
.patent-table th.sort-active .sort-arrow { opacity: 1; }
.patent-table td { padding: 13px 16px; border-bottom: 1px solid var(--rule); font-size: var(--text-base-size); color: var(--ink); font-family: var(--mono); letter-spacing: 0.02em; }
/* filter pills */
.filter-bar { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.filter-pill {
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 3px 8px; border: 1px solid var(--rule); background: var(--bg); color: var(--ink-2);
  cursor: pointer; transition: all 0.15s; white-space: nowrap;
}
.filter-pill:hover { border-color: var(--accent); color: var(--accent); }
.filter-pill.active { background: var(--accent); color: white; border-color: var(--accent); }
.filter-pill.pill-granted.active  { background: var(--green);  border-color: var(--green);  }
.filter-pill.pill-publication.active { background: #2a5a6a; border-color: #2a5a6a; }
.filter-pill.pill-abandoned.active { background: #a02020; border-color: #a02020; }
.filter-pill.pill-pct.active      { background: var(--accent-mid); border-color: var(--accent-mid); }
.filter-pill.pill-unknown.active  { background: var(--ink-3); border-color: var(--ink-3); }
.filter-label { font-family: var(--mono); font-size: var(--text-base-size); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-2); }
.jur-flag { font-size: var(--text-sm-size); margin-right: 3px; font-family: var(--sans); font-weight: var(--weight-medium); }
.doctype-badge { font-family: var(--sans); font-size: var(--text-sm-size); padding: 4px 8px; letter-spacing: 0.06em; text-transform: uppercase; font-weight: var(--weight-medium); }
.doctype-granted     { background: var(--green-bg);  color: var(--green); }
.doctype-publication { background: #e4eef2; color: #2a5a6a; }
.doctype-abandoned   { background: #fde8e8; color: #a02020; }
.doctype-expired     { background: #f0eeeb; color: var(--ink-3); }
.doctype-pending     { background: #e4eef2; color: #2a5a6a; }
.doctype-active      { background: var(--green-bg); color: var(--green); }
.doctype-pct         { background: var(--accent-light); color: var(--accent); }
.doctype-unknown     { background: #f0eeeb; color: var(--ink-2); }
.patent-table tr:last-child td { border-bottom: none; }
.patent-table tr:hover td { background: var(--bg); }
.patent-num { color: var(--accent); font-weight: var(--weight-medium); font-family: var(--sans); font-size: var(--text-sm-size); }
.status-pill { font-size: var(--text-sm-size); padding: 4px 8px; letter-spacing: 0.06em; text-transform: uppercase; font-family: var(--sans); font-weight: var(--weight-medium); }
.status-active { background: var(--green-bg); color: var(--green); }
.status-pending { background: var(--amber-bg); color: var(--amber); font-family: var(--sans); font-size: var(--text-sm-size); padding: 4px 8px; text-transform: uppercase; font-weight: var(--weight-medium); }
.status-expired { background: #f0ece8; color: #8a7a6a; }

/* Assertion view table cells */
.aa-cell {
  padding: 8px 12px;
  font-family: var(--sans);
  font-size: var(--text-base-size);
  font-weight: var(--weight-normal);
  color: var(--ink);
  vertical-align: middle;
}
.aa-cell-patent { color: var(--accent); white-space: nowrap; }
.aa-cell-title { max-width: 300px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.aa-cell-bucket,
.aa-cell-subcat { color: var(--ink-2); }
.aa-cell-links { color: var(--accent); }
.aa-cell-status .status-pill { font-size: var(--text-sm-size); }
/* Priority column hidden on production, shown on staging */
body:not(.pm-staging) #th-priority, body:not(.pm-staging) .priority-cell { display: none; }
.priority-pill { font-size: var(--text-sm-size); padding: 4px 8px; letter-spacing: 0.06em; text-transform: uppercase; font-family: var(--sans); font-weight: var(--weight-medium); }
.priority-high { background: #fde8e8; color: #a02020; }
.priority-medium { background: var(--amber-bg); color: var(--amber); }
.priority-low { background: var(--bg); color: var(--ink-3); }
.priority-none { background: var(--bg); color: var(--rule); }

/* PAGINATION */
.pagination-bar { display: flex; align-items: center; justify-content: center; gap: 4px; padding: 10px 16px; border-top: 1px solid var(--rule); background: var(--bg); font-family: var(--mono); font-size: var(--text-xs-size); }
.pagination-bar button { font-family: var(--mono); font-size: var(--text-xs-size); padding: 4px 10px; border: 1px solid var(--rule); background: var(--surface); color: var(--ink-2); cursor: pointer; transition: all 0.15s; }
.pagination-bar button:hover:not(:disabled) { border-color: var(--accent); color: var(--accent); }
.pagination-bar button:disabled { opacity: 0.35; cursor: default; }
.pagination-bar button.pg-active { background: var(--accent); color: white; border-color: var(--accent); }
.pagination-bar .pg-info { color: var(--ink-3); font-size: var(--text-xs-size); letter-spacing: 0.08em; margin: 0 8px; }

/* RIGHT PANEL — COMMAND CENTER */
.right-panel { display: flex; flex-direction: column; gap: 10px; }
.table-search-wrap { display: inline-flex; align-items: center; gap: 6px; margin-left: auto; }
.table-search-input {
  border: 2px solid var(--rule);
  border-radius: 6px;
  background: var(--paper);
  height: 38px;
  padding: 0 14px;
  min-width: 320px;
  font-family: var(--mono);
  font-size: var(--text-base-size);
  font-weight: var(--weight-medium);
  letter-spacing: 0.03em;
  color: var(--ink);
}
.table-search-input:focus { outline: none; border-color: var(--accent); }
.command-panel { background: var(--paper); border: 1px solid var(--rule); }
.command-header { padding: 14px 18px; border-bottom: 1px solid var(--rule); background: var(--accent); }
.command-title { font-family: var(--serif); font-size: var(--text-md-size); font-weight: var(--weight-medium); color: white; }
.command-sub { font-size: var(--text-base-size); font-weight: var(--weight-light); color: rgba(255,255,255,0.85); line-height: 1.65; margin-top: 6px; }
.command-body { padding: 16px 18px; display: flex; flex-direction: column; gap: 14px; }
.command-section-label { font-family: var(--sans); font-size: var(--text-base-size); letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-2); margin-bottom: 8px; font-weight: var(--weight-bold); }
.command-btn {
  width: 100%; font-family: var(--mono); font-size: var(--text-sm-size); letter-spacing: 0.08em;
  text-transform: uppercase; padding: 10px 14px; text-align: left;
  border: 1px solid var(--rule); background: var(--bg); color: var(--ink-2);
  cursor: pointer; transition: all 0.15s; display: flex; align-items: center; justify-content: space-between;
}
.command-btn:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-light); }
.command-btn.primary { background: var(--accent); color: white; border-color: var(--accent); }
.command-btn.primary:hover { background: var(--accent-mid); }
.command-btn-arrow { opacity: 0.4; font-size: var(--text-base-size); }
.command-btn:hover .command-btn-arrow { opacity: 1; }
.command-input {
  width: 100%; font-family: var(--mono); font-size: var(--text-base-size); padding: 9px 12px;
  border: 1px solid var(--rule); background: var(--bg); color: var(--ink); outline: none;
  transition: border-color 0.15s; letter-spacing: 0.03em;
}
.command-input:focus { border-color: var(--accent); }
.command-input::placeholder { color: var(--ink-2); }
.date-row { display: flex; flex-direction: column; gap: 6px; }
.date-label { font-family: var(--mono); font-size: var(--text-sm-size); letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-2); }

/* INFO CARD */
.info-card { background: var(--paper); border: 1px solid var(--rule); padding: 20px 20px; }
.info-card-title { font-family: var(--sans); font-size: var(--text-base-size); letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-2); margin-bottom: 16px; font-weight: var(--weight-bold); }
.info-stat { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 12px; }
.info-stat-label { font-family: var(--sans); font-size: var(--text-base-size); font-weight: 400; color: var(--ink); }
.info-stat-val { font-family: var(--sans); font-size: var(--text-md-size); font-weight: var(--weight-bold); color: var(--ink); }
.info-stat-val.green { color: var(--green); }
.info-stat-val.amber { color: var(--amber); }
.info-divider { height: 1px; background: var(--rule); margin: 10px 0; }

/* ── COMPARISON DONUT PANEL ─────────────────────────────────── */
.comp-donut-panel {
  display: none;
  border-top: 1px solid var(--rule);
  padding: 16px 20px 20px;
  animation: cvIn 0.2s ease;
}
.comp-donut-panel.open { display: block; }
.comp-donut-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 14px;
}
.comp-donut-title {
  font-family: var(--serif); font-size: var(--text-base-size); font-weight: var(--weight-medium); color: var(--ink);
}
.comp-donut-sub {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--ink-3); margin-top: 3px;
}
.comp-donut-close {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--ink-3); background: none;
  border: 1px solid var(--rule); padding: 4px 10px; cursor: pointer;
  transition: all 0.13s;
}
.comp-donut-close:hover { border-color: var(--accent); color: var(--accent); }

.comp-donut-wrap { position: relative; width: 420px; height: 420px; }
.comp-donut-center {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  text-align: center; pointer-events: none;
}
.comp-donut-center-num { font-family: var(--serif); font-size: 28px; font-weight: var(--weight-medium); color: var(--ink); display: block; }
.comp-donut-center-sub { font-family: var(--mono); font-size: 14px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-2); display: block; margin-top: 2px; }
.comp-mini-legend { width: 100%; display: flex; flex-direction: column; gap: 3px; max-height: 180px; overflow-y: auto; }
.comp-mini-legend-item { display: flex; align-items: center; gap: 6px; padding: 3px 0; font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-2); }
.comp-mini-dot { width: 7px; height: 7px; border-radius: 1px; flex-shrink: 0; }
.comp-mini-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.comp-mini-pct { color: var(--ink-3); flex-shrink: 0; }
.comp-donut-btn {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 2px 7px; border: 1px solid var(--rule); background: var(--bg); color: var(--ink-3);
  cursor: pointer; margin-left: 6px; transition: all 0.13s; flex-shrink: 0;
}
.comp-donut-btn:hover { border-color: var(--accent); color: var(--accent); }
/* Comp donut panel internals */
.comp-donut-filter-bar {
  display: none;
}
.comp-donut-filter-label { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); margin-right: 2px; flex-shrink: 0; }
.comp-donut-filter-pill {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.07em; text-transform: uppercase;
  padding: 3px 8px; border: 1px solid var(--rule); background: var(--paper); color: var(--ink-3);
  cursor: pointer; transition: all 0.13s; white-space: nowrap;
}
.comp-donut-filter-pill:hover { border-color: var(--accent); color: var(--accent); }
.comp-donut-filter-pill.active { background: var(--accent); color: white; border-color: var(--accent); }
.comp-donut-filter-clear { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.08em; text-transform: uppercase; color: var(--accent); cursor: pointer; background: none; border: none; padding: 0; margin-left: 4px; }
.comp-donut-filter-clear:hover { text-decoration: underline; }
.comp-donut-main { display: flex; gap: 24px; align-items: flex-start; padding: 16px; }
.comp-donut-legend-col { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 8px; max-height: 440px; }
.comp-donut-search { font-family: var(--sans); font-size: var(--text-base-size); padding: 10px 12px; border: 1px solid var(--rule); background: var(--bg); color: var(--ink); outline: none; width: 100%; }
.comp-donut-search:focus { border-color: var(--accent); }
.comp-donut-legend { flex: 1; overflow-y: auto; display: flex; flex-direction: column; gap: 2px; }
.comp-donut-group-header { font-family: var(--sans); font-size: 14px; font-weight: var(--weight-bold); color: var(--ink-2); padding: 9px 8px 5px; border-top: 1px solid var(--rule); margin-top: 3px; display: flex; align-items: center; gap: 5px; }
.comp-donut-group-header:first-child { border-top: none; margin-top: 0; }
.comp-donut-group-dot { width: 8px; height: 8px; border-radius: 2px; flex-shrink: 0; }
.comp-donut-group-total { margin-left: auto; font-family: var(--sans); font-size: 14px; font-weight: var(--weight-bold); color: var(--ink-2); }
.comp-donut-legend-item {
  display: flex; align-items: center; gap: 8px; padding: 6px 8px;
  border: 1px solid transparent; cursor: pointer; transition: all 0.12s;
}
.comp-donut-legend-item:hover { background: var(--bg); border-color: var(--rule); }
.comp-donut-legend-item.pinned { background: var(--accent-light); border-color: var(--accent); }
.comp-donut-legend-item.dimmed { opacity: 0.3; }
.comp-donut-legend-dot { width: 8px; height: 8px; border-radius: 2px; flex-shrink: 0; }
.comp-donut-legend-name { font-family: var(--sans); font-size: 12px; color: var(--ink); flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.comp-donut-legend-count { font-family: var(--sans); font-size: 12px; font-weight: var(--weight-bold); color: var(--ink); flex-shrink: 0; }
.comp-donut-legend-pct { font-family: var(--sans); font-size: 12px; font-weight: var(--weight-medium); color: var(--ink-2); min-width: 34px; text-align: right; flex-shrink: 0; }
.comp-donut-center-name { font-family: var(--sans); font-size: 13px; color: var(--ink-2); display: block; margin-top: 3px; line-height: 1.3; font-weight: var(--weight-light); max-width: 120px; }

/* ── COMPETITOR TREND VIEW ─────────────────────────────────── */
.chart-view { display: none; flex-direction: column; width: 100%; min-width: 0; }
.chart-view.active { display: flex; flex-direction: column; width: 100%; min-width: 0; animation: cvIn 0.18s ease; }
@keyframes cvIn { from { opacity:0; } to { opacity:1; } }

/* Competitor view wrapper */
.competitor-trend-wrap {
  display: flex; flex-direction: column; padding: 16px 20px 12px;
}
.ctrend-header {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 16px;
  margin-bottom: 14px; flex-wrap: wrap;
}
.ctrend-title { font-family: var(--serif); font-size: var(--text-md-size); font-weight: var(--weight-medium); color: var(--ink); }
.ctrend-meta  { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-3); letter-spacing: 0.04em; margin-top: 3px; }
.ctrend-controls { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.ctrend-control-label { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-3); white-space: nowrap; }
.ctrend-toggles { display: flex; gap: 4px; flex-wrap: wrap; }
.ct-pill {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.06em; text-transform: uppercase;
  padding: 4px 9px; border: 1px solid var(--rule); cursor: pointer;
  transition: all 0.14s; white-space: nowrap; background: var(--bg);
  display: flex; align-items: center; gap: 4px; color: var(--ink-3);
}
.ct-pill:hover { opacity: 0.85; }
.ct-pill.co { cursor: default; font-weight: var(--weight-medium); }
.ct-pill-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.ctrend-canvas-wrap { position: relative; }
.ctrend-legend {
  display: flex; gap: 8px; flex-wrap: wrap;
  padding-top: 12px; margin-top: 10px; border-top: 1px solid var(--rule);
}
.ctl-item {
  display: flex; align-items: center; gap: 5px; cursor: pointer;
  padding: 3px 7px; border: 1px solid transparent; transition: all 0.12s;
}
.ctl-item:hover { background: var(--bg); border-color: var(--rule); }
.ctl-item.ctl-off { opacity: 0.32; }
.ctl-item.ctl-co  { cursor: default; }
.ctl-line { border-radius: 1px; flex-shrink: 0; }
.ctl-name { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-2); letter-spacing: 0.03em; }
.ctl-val  { font-family: var(--mono); font-size: var(--text-xs-size); font-weight: var(--weight-medium); color: var(--ink); margin-left: 2px; }

/* ── SETTINGS MODAL ─────────────────────────────────────────────────────── */
.s-overlay {
  position: fixed; inset: 0; background: rgba(10,8,30,0.55); z-index: 900;
  display: none; align-items: center; justify-content: center;
  backdrop-filter: blur(3px);
}
.s-overlay.open { display: flex; }

.s-modal {
  background: var(--paper); width: 1100px; max-width: 96vw;
  height: 85vh; max-height: 92vh;
  display: flex; overflow: hidden; box-shadow: 0 12px 64px rgba(0,0,0,0.22);
  animation: sModalIn 0.22s cubic-bezier(.16,1,.3,1);
}
@keyframes sModalIn {
  from { opacity:0; transform:translateY(12px) scale(0.98); }
  to   { opacity:1; transform:translateY(0)     scale(1);    }
}

/* LEFT NAV */
.s-nav {
  width: 188px; flex-shrink: 0;
  background: var(--accent); display: flex; flex-direction: column;
}
.s-nav-header {
  padding: 20px 18px 14px; border-bottom: 1px solid rgba(255,255,255,0.1);
}
.s-nav-title { font-family: var(--serif); font-size: var(--text-md-size); color: #fff; font-weight: var(--weight-medium); }
.s-nav-sub { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.35); margin-top: 3px; }
.s-nav-items { flex: 1; padding: 10px 0; overflow-y: auto; }
.s-nav-section { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.2em; text-transform: uppercase; color: rgba(255,255,255,0.28); padding: 10px 18px 4px; }
.s-nav-item {
  display: flex; align-items: center; gap: 9px;
  padding: 8px 18px; cursor: pointer;
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.04em;
  color: rgba(255,255,255,0.52); transition: background 0.13s, color 0.13s;
  border-left: 2px solid transparent;
}
.s-nav-item:hover { background: rgba(255,255,255,0.07); color: rgba(255,255,255,0.85); }
.s-nav-item.active { background: rgba(255,255,255,0.12); color: #fff; border-left-color: rgba(255,255,255,0.55); }
.s-nav-icon { width: 13px; height: 13px; flex-shrink: 0; opacity: 0.6; }
.s-nav-item.active .s-nav-icon { opacity: 1; }
.s-nav-footer {
  padding: 12px 18px; border-top: 1px solid rgba(255,255,255,0.1);
  display: flex; gap: 6px;
}

/* INTAKE PROGRESS CONSOLE */
.s-console { border-top: 1px solid var(--rule); background: #0f172a; color: #94a3b8; font-family: var(--mono); font-size: var(--text-xs-size); max-height: 0; overflow: hidden; transition: max-height 0.3s ease; flex-shrink: 0; }
.s-console.open { max-height: 260px; }
.s-console-toolbar { display: flex; align-items: center; justify-content: space-between; padding: 5px 14px 0; gap: 8px; }
.s-console-toolbar span { color: #475569; font-size: var(--text-tiny-size); letter-spacing: 0.08em; text-transform: uppercase; }
.s-console-toolbar-btns { display: flex; gap: 6px; }
.s-console-btn { background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.12); color: rgba(255,255,255,0.55); font-family: var(--mono); font-size: var(--text-tiny-size); padding: 2px 8px; cursor: pointer; border-radius: 3px; transition: all 0.12s; }
.s-console-btn:hover { background: rgba(255,255,255,0.13); color: rgba(255,255,255,0.85); }
.s-console-btn.copied { color: #4ade80; border-color: #4ade80; }
.s-console-inner { padding: 6px 14px 10px; height: 200px; overflow-y: auto; display: flex; flex-direction: column; gap: 4px; box-sizing: border-box; }
.s-console-line { white-space: pre-wrap; line-height: 1.5; }
.s-console-line.running { color: #e2e8f0; }
.s-console-line.running::before { content: '→ '; color: #60a5fa; }
.s-console-line.done { color: #4ade80; }
.s-console-line.done::before { content: '✓ '; }
.s-console-line.error { color: #f87171; }
.s-console-line.error::before { content: '✗ '; }
.s-close-btn {
  flex: 1; font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.1em; text-transform: uppercase;
  padding: 8px; background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.18);
  color: rgba(255,255,255,0.7); cursor: pointer; transition: all 0.13s;
}
.s-close-btn:hover { background: rgba(255,255,255,0.18); color: #fff; }
.s-save-btn {
  flex: 1; font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.1em; text-transform: uppercase;
  padding: 8px; background: #fff; border: 1px solid rgba(255,255,255,0.3);
  color: var(--accent); cursor: pointer; transition: all 0.13s; font-weight: var(--weight-medium);
}
.s-save-btn:hover { background: var(--accent-light); }

/* SETTINGS TABS */
.s-tab-btn { font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.08em; text-transform: uppercase; padding: 10px 18px; border: none; background: none; color: var(--ink-3); cursor: pointer; border-bottom: 2px solid transparent; transition: all 0.15s; }
.s-tab-btn:hover { color: var(--ink); }
.s-tab-btn.active { color: var(--accent); border-bottom-color: var(--accent); font-weight: var(--weight-bold); }
.s-tab-panel { display: none; }
.s-tab-panel.active { display: block; }

/* RIGHT CONTENT */
.s-content { flex: 1; display: flex; flex-direction: column; min-width: 0; overflow: hidden; min-height: 0; }
.s-pages { flex: 1; display: flex; flex-direction: column; overflow: hidden; min-height: 0; }
.s-page-header {
  padding: 20px 24px 14px; border-bottom: 1px solid var(--rule);
  display: flex; align-items: flex-start; justify-content: space-between;
}
.s-page-eyebrow { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent); margin-bottom: 4px; }
.s-page-title { font-family: var(--serif); font-size: var(--text-lg-size); font-weight: var(--weight-medium); color: var(--ink); }
.s-page-desc { font-size: var(--text-sm-size); color: var(--ink-3); margin-top: 3px; font-weight: var(--weight-light); }
.s-page-num { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-3); letter-spacing: 0.06em; }

.s-body { flex: 1; overflow-y: auto; padding: 20px 24px; display: flex; flex-direction: column; gap: 18px; }

/* FIELD ROWS */
.s-field { display: flex; flex-direction: column; gap: 6px; }
.s-label { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); }
.s-label-sub { font-size: var(--text-xs-size); color: var(--ink-3); font-weight: var(--weight-light); margin-top: 1px; }
.s-input {
  font-family: var(--mono); font-size: var(--text-sm-size); padding: 9px 12px;
  border: 1px solid var(--rule); background: var(--bg); color: var(--ink);
  outline: none; transition: border-color 0.15s; letter-spacing: 0.03em; width: 100%;
}
.s-input:focus { border-color: var(--accent); }
.s-textarea {
  font-family: var(--mono); font-size: var(--text-sm-size); padding: 9px 12px;
  border: 1px solid var(--rule); background: var(--bg); color: var(--ink);
  outline: none; transition: border-color 0.15s; letter-spacing: 0.03em;
  width: 100%; resize: vertical; min-height: 90px; line-height: 1.7;
}
.s-textarea:focus { border-color: var(--accent); }
.s-tip { font-size: var(--text-xs-size); color: var(--ink-3); font-weight: var(--weight-light); line-height: 1.5; }
.s-tip strong { font-weight: var(--weight-medium); color: var(--ink-2); }
.s-divider { height: 1px; background: var(--rule); }
/* ACCESS PAGE — user list */
.s-access-row { display:grid; grid-template-columns:1fr 1fr auto auto auto; align-items:center; gap:10px; padding:7px 10px; border-radius:5px; font-size: var(--text-xs-size); background:var(--bg); border:1px solid var(--rule); margin-bottom:4px; }
.s-access-email { font-family:var(--mono); font-size: var(--text-xs-size); color:var(--ink-2); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.s-access-name { color:var(--ink-2); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.s-access-sso { font-size: var(--text-xs-size); color:var(--ink-3); }
.s-access-badge { display:inline-block; padding:2px 8px; border-radius:20px; font-size: var(--text-xs-size); font-family:var(--mono); letter-spacing:0.06em; text-transform:uppercase; }
.s-access-badge-admin { background:#fef3c7; color:#92400e; }
.s-access-badge-client_admin { background:#dbeafe; color:#1e40af; }
.s-access-badge-editor { background:#d1fae5; color:#065f46; }
.s-access-badge-viewer { background:#f3f4f6; color:#374151; }
.s-access-add-form { background:var(--bg-2,#f9f9f9); border:1px solid var(--rule); border-radius:6px; padding:14px; margin-top:6px; }

/* TAGS INPUT (chips) */
.s-tags-wrap {
  border: 1px solid var(--rule); background: var(--bg); padding: 6px 8px;
  display: flex; flex-wrap: wrap; gap: 5px; cursor: text; min-height: 44px;
  transition: border-color 0.15s;
}
.s-tags-wrap:focus-within { border-color: var(--accent); }
.s-tags-wrap.s-tags-list {
  flex-direction: column;
  align-items: stretch;
  flex-wrap: nowrap;
  gap: 6px;
}
.s-tag {
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.04em;
  background: var(--accent-light); color: var(--accent); border: 1px solid #c5c0e8;
  padding: 2px 7px; display: flex; align-items: center; gap: 5px;
}
.s-tags-list .s-tag {
  justify-content: space-between;
  width: 100%;
  min-height: 28px;
  padding: 5px 8px;
}
.s-tag-x { cursor: pointer; opacity: 0.5; font-size: var(--text-xs-size); line-height: 1; }
.s-tag-x:hover { opacity: 1; }
.s-tag-input {
  border: none; background: transparent; outline: none;
  font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink);
  flex: 1; min-width: 100px; padding: 2px 4px;
}
.s-tags-list .s-tag-input {
  width: 100%;
  min-height: 28px;
  padding: 6px 4px;
  flex: 0 0 auto;
}

/* AUTOCOMPLETE DROPDOWN */
.s-autocomplete-modal {
  position: absolute; z-index: 10001; margin-top: 4px; top: 100%;
  background: var(--paper); border: 1px solid var(--rule); border-radius: 6px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
  min-width: 280px; max-width: 480px; max-height: 300px; overflow-y: auto;
  padding: 8px;
}
.s-autocomplete-item {
  display: inline-block; margin: 4px; padding: 6px 12px;
  background: var(--accent-light); color: var(--accent); border: 1px solid var(--accent);
  border-radius: 4px; cursor: pointer; font-family: var(--mono); font-size: var(--text-xs-size);
  transition: all 0.15s ease;
  white-space: nowrap;
}
.s-autocomplete-item:hover {
  background: var(--accent); color: #fff; transform: translateY(-1px);
  box-shadow: 0 2px 6px rgba(0,0,0,0.1);
}

/* PATENT TAG PICKER MODAL */
.pm-tag-picker-overlay {
  position: fixed; inset: 0; z-index: 2100;
  background: rgba(10, 10, 18, 0.42);
  display: none; align-items: center; justify-content: center;
  padding: 24px;
}
.pm-tag-picker-overlay.open { display: flex; }
.pm-tag-picker-modal {
  width: min(560px, 92vw); max-height: 82vh; overflow: hidden;
  background: var(--paper); border: 1px solid var(--rule);
  box-shadow: 0 24px 64px rgba(0,0,0,0.22);
  display: flex; flex-direction: column;
}
.pm-tag-picker-head {
  padding: 16px 18px; border-bottom: 1px solid var(--rule); background: var(--bg);
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
}
.pm-tag-picker-title { font-family: var(--serif); font-size: var(--text-lg-size); color: var(--ink); }
.pm-tag-picker-sub { font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); }
.pm-tag-picker-body { padding: 16px 18px; overflow-y: auto; }
.pm-tag-pill-grid { display: flex; flex-wrap: wrap; gap: 8px; max-width: 520px; }
.pm-tag-pill {
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.04em;
  padding: 8px 12px; border: 1px solid var(--rule); background: var(--bg);
  color: var(--ink-2); cursor: pointer; transition: all 0.14s ease;
}
.pm-tag-pill:hover { border-color: var(--accent); color: var(--accent); transform: translateY(-1px); }
.pm-tag-pill.active { background: var(--accent-light); border-color: var(--accent); color: var(--accent); }
.pm-tag-picker-foot {
  border-top: 1px solid var(--rule); padding: 12px 18px; background: var(--bg);
  display: flex; justify-content: space-between; align-items: center; gap: 12px;
}
.pm-tag-picker-count { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-3); }
.pm-tag-picker-actions { display: flex; gap: 8px; }
.pm-tag-picker-btn {
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 8px 12px; border: 1px solid var(--rule); background: var(--paper); color: var(--ink-2); cursor: pointer;
}
.pm-tag-picker-btn.primary { background: var(--accent); border-color: var(--accent); color: #fff; }

.pm-patent-tags-picker-btn {
  width: 100%; min-height: 34px; text-align: left;
  padding: 5px 8px; border: 1px solid var(--rule); background: var(--paper);
  display: flex; align-items: center; flex-wrap: wrap; gap: 5px; cursor: pointer;
}
.pm-patent-tags-chip {
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.03em;
  padding: 2px 7px; border: 1px solid #c5c0e8; background: var(--accent-light); color: var(--accent);
}
.pm-patent-tags-empty {
  font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-3); letter-spacing: 0.06em; text-transform: uppercase;
}

/* NAV PROGRESS DOTS */
.s-progress { display: flex; gap: 5px; align-items: center; padding-top: 2px; }
.s-dot { width: 5px; height: 5px; border-radius: 50%; background: rgba(255,255,255,0.2); transition: all 0.2s; }
.s-dot.active { background: #fff; width: 14px; border-radius: 3px; }

/* PAGE TRANSITIONS */
.s-page { display: none; flex-direction: column; gap: 18px; min-height: 0; }
.s-page.active { display: flex; flex: 1; overflow: hidden; min-height: 0; animation: sPageIn 0.18s ease; }
@keyframes sPageIn { from { opacity:0; transform:translateX(8px); } to { opacity:1; transform:translateX(0); } }

/* ── DRAG-RESIZE CHART HEIGHT ──────────────────────────────────────────────── */
.resizable-chart-wrap {
  position: relative;
  /* height is set inline via JS / default */
}
.resizable-chart-wrap canvas {
  width: 100% !important;
  height: 100% !important;
  display: block;
}
.resize-handle {
  width: 100%;
  height: 10px;
  background: var(--bg);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  cursor: ns-resize;
  display: flex;
  align-items: center;
  justify-content: center;
  user-select: none;
  flex-shrink: 0;
  transition: background 0.15s;
}
.resize-handle:hover, .resize-handle.dragging { background: var(--accent-light); border-color: #c5c0e8; }
.resize-handle-grip {
  width: 32px;
  height: 3px;
  background: var(--ink-3);
  border-radius: 2px;
  opacity: 0.4;
  position: relative;
}
.resize-handle-grip::before,
.resize-handle-grip::after {
  content: '';
  position: absolute;
  width: 32px;
  height: 3px;
  background: var(--ink-3);
  border-radius: 2px;
  opacity: 1;
  left: 0;
}
.resize-handle-grip::before { top: -5px; }
.resize-handle-grip::after  { top:  5px; }

/* ── WHITE SPACE MAP MODAL ──────────────────────────────────────────────── */
.ws-overlay {
  position: fixed; inset: 0; background: rgba(10,8,30,0.6); z-index: 910;
  display: none; align-items: center; justify-content: center;
  backdrop-filter: blur(3px);
}
.ws-overlay.open { display: flex; }
.ws-modal {
  background: var(--paper);
  width: min(1420px, calc(100vw - 24px));
  height: min(90vh, 980px);
  max-width: 99vw;
  max-height: 94vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 16px 64px rgba(0,0,0,0.28);
  animation: sModalIn 0.22s cubic-bezier(.16,1,.3,1);
  overflow: hidden;
}
.ws-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 20px 24px 16px; border-bottom: 1px solid var(--rule); flex-shrink: 0;
}
.ws-header-left {}
.ws-eyebrow { font-family: var(--mono); font-size: var(--text-base-size); letter-spacing: 0.08em; text-transform: uppercase; color: var(--accent); margin-bottom: 4px; }
.ws-title { font-family: var(--serif); font-size: var(--text-lg-size); font-weight: var(--weight-medium); color: var(--ink); }
.ws-desc { font-size: var(--text-base-size); color: var(--ink-2); margin-top: 6px; font-weight: var(--weight-light); max-width: 760px; line-height: 1.6; }
.ws-main {
  display: flex;
  flex: 1 1 auto;
  min-height: 0;
  min-width: 0;
  overflow: hidden;
  border-top: 1px solid var(--rule);
}
.ws-pane-left {
  width: clamp(240px, 22vw, 320px);
  flex: 0 0 clamp(240px, 22vw, 320px);
  min-width: 220px;
  border-right: 1px solid var(--rule);
  overflow: auto;
  background: var(--bg);
}
.ws-pane-right {
  flex: 1 1 auto;
  min-width: 0;
  min-height: 0;
  overflow: hidden;
  background: var(--paper);
}
#ws-license-list {
  height: 100%;
  min-width: 0;
  min-height: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.ws-header-actions { display: flex; gap: 8px; align-items: center; }
.ws-close { font-family: var(--mono); font-size: var(--text-sm-size); letter-spacing: 0.1em; text-transform: uppercase; padding: 7px 14px; border: 1px solid var(--rule); background: none; color: var(--ink-2); cursor: pointer; transition: all 0.13s; }
.ws-close:hover { border-color: var(--accent); color: var(--accent); }

/* Controls bar */
.ws-controls {
  display: flex; align-items: center; gap: 12px; padding: 10px 24px;
  border-bottom: 1px solid var(--rule); background: var(--bg); flex-shrink: 0; flex-wrap: wrap;
}
.ws-control-label { font-family: var(--mono); font-size: var(--text-base-size); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-2); }
.ws-filter-pill {
  font-family: var(--mono); font-size: var(--text-base-size); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 4px 10px; border: 1px solid var(--rule); background: var(--paper);
  color: var(--ink-2); cursor: pointer; transition: all 0.13s;
}
.ws-filter-pill:hover { border-color: var(--accent); color: var(--accent); }
.ws-filter-pill.active { background: var(--accent); color: white; border-color: var(--accent); }
.ws-divider-v { width: 1px; height: 16px; background: var(--rule); flex-shrink: 0; }

/* Legend strip */
.ws-legend-strip {
  display: flex; align-items: center; gap: 6px; margin-left: auto;
  font-family: var(--mono); font-size: var(--text-base-size); color: var(--ink-2); letter-spacing: 0.06em;
}
.ws-swatch { width: 12px; height: 12px; border-radius: 2px; flex-shrink: 0; }

/* Body */
.ws-body { flex: 1; overflow-y: auto; padding: 20px 24px; display: flex; flex-direction: column; gap: 20px; }

/* Summary KPI row */
.ws-kpi-row { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; }
.ws-kpi {
  background: var(--bg); border: 1px solid var(--rule); padding: 12px 14px;
}
.ws-kpi-label { font-family: var(--mono); font-size: var(--text-base-size); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-2); margin-bottom: 5px; }
.ws-kpi-val { font-family: var(--serif); font-size: var(--text-lg-size); font-weight: var(--weight-medium); color: var(--ink); line-height: 1; }
.ws-kpi-sub { font-family: var(--mono); font-size: var(--text-sm-size); color: var(--ink-2); margin-top: 4px; }
.ws-kpi-val.green { color: var(--green); }
.ws-kpi-val.amber { color: var(--amber); }
.ws-kpi-val.accent { color: var(--accent); }

/* Section header */
.ws-section-header { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 10px; }
.ws-section-title { font-family: var(--serif); font-size: var(--text-xs-size); font-weight: var(--weight-medium); color: var(--ink); }
.ws-section-sub { font-family: var(--mono); font-size: var(--text-base-size); color: var(--ink-2); letter-spacing: 0.06em; }

/* Heat grid */
.ws-grid { display: flex; flex-direction: column; gap: 3px; }
.ws-grid-row { display: grid; grid-template-columns: 180px 1fr 80px 80px 80px 100px; gap: 0; align-items: center; }
.ws-grid-head { font-family: var(--mono); font-size: var(--text-base-size); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-2); padding: 4px 8px; background: var(--bg); border-bottom: 2px solid var(--rule); }
.ws-grid-head:first-child { border-radius: 0; }
.ws-cat-name { font-family: var(--mono); font-size: var(--text-sm-size); color: var(--ink-2); padding: 7px 8px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; border-bottom: 1px solid var(--rule); }
.ws-heat-cell { padding: 4px 6px; border-bottom: 1px solid var(--rule); border-left: 1px solid var(--rule); }
.ws-heat-bar-wrap { height: 18px; background: var(--bg); border-radius: 1px; overflow: hidden; position: relative; }
.ws-heat-bar { height: 100%; border-radius: 1px; transition: width 0.4s; }
.ws-num-cell { font-family: var(--mono); font-size: var(--text-sm-size); padding: 7px 8px; text-align: right; border-bottom: 1px solid var(--rule); border-left: 1px solid var(--rule); }
.ws-opp-cell { padding: 5px 8px; border-bottom: 1px solid var(--rule); border-left: 1px solid var(--rule); }
.ws-opp-badge {
  font-family: var(--mono); font-size: var(--text-base-size); letter-spacing: 0.06em; text-transform: uppercase;
  padding: 4px 6px; border-radius: 0; display: inline-block;
}
.opp-high   { background: #e8f4ed; color: var(--green); }
.opp-medium { background: #faeeda; color: var(--amber); }
.opp-low    { background: #f0eeeb; color: var(--ink-2); }
.opp-risk   { background: #fde8e8; color: #a02020; }
.ws-grid-row.ws-row-highlight .ws-cat-name { color: var(--accent); font-weight: var(--weight-medium); }
.ws-grid-row { cursor: pointer; transition: background 0.12s; }
.ws-grid-row:not(:first-child):hover { background: var(--bg); }
.ws-grid-row.ws-row-selected { background: var(--accent-light) !important; }
.ws-grid-row.ws-row-selected .ws-cat-name { color: var(--accent); font-weight: var(--weight-medium); }
.ws-stat-mini { background: var(--bg); border: 1px solid var(--rule); padding: 8px 10px; }
.ws-stat-mini-label { font-family: var(--mono); font-size: var(--text-base-size); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-2); margin-bottom: 3px; }
.ws-stat-mini-val { font-family: var(--serif); font-size: var(--text-md-size); font-weight: var(--weight-medium); color: var(--ink); line-height: 1; }
.ws-prompt-btn {
  width: 100%; text-align: left; padding: 9px 12px;
  font-family: var(--sans); font-size: var(--text-base-size); font-weight: var(--weight-light); color: var(--ink-2);
  background: var(--bg); border: 1px solid var(--rule); cursor: pointer;
  transition: all 0.13s; line-height: 1.6;
}
.ws-prompt-btn:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-light); }
.ws-chat-bubble { padding: 8px 10px; font-size: var(--text-sm-size); line-height: 1.65; }
.ws-chat-user { background: var(--accent); color: white; font-family: var(--mono); font-size: var(--text-sm-size); align-self: flex-end; max-width: 90%; }
.ws-chat-ai { background: var(--bg); border: 1px solid var(--rule); color: var(--ink-2); font-weight: var(--weight-light); max-width: 100%; }
@keyframes ws-spin { to { transform: rotate(360deg); } }
.ws-spinner { width: 14px; height: 14px; border: 2px solid var(--rule); border-top-color: var(--accent); border-radius: 50%; animation: ws-spin 0.7s linear infinite; flex-shrink: 0; }
.ws-tab {
  flex: 1; text-align: center; padding: 9px 6px;
  font-family: var(--mono); font-size: var(--text-base-size); letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-2); cursor: pointer; border-bottom: 2px solid transparent;
  transition: all 0.13s;
}
.ws-tab:hover { color: var(--accent); }
.ws-tab.active { color: var(--accent); border-bottom-color: var(--accent); background: var(--paper); }
.ws-opp-card {
  padding: 14px 16px; border-bottom: 1px solid var(--rule);
  cursor: pointer; transition: background 0.12s; border-left: 3px solid transparent;
}
.ws-opp-card:hover { background: var(--bg); }
.ws-opp-card.selected { background: var(--accent-light); border-left-color: var(--accent); }
.ws-opp-card-name { font-family: var(--mono); font-size: var(--text-sm-size); font-weight: var(--weight-medium); color: var(--ink); margin-bottom: 4px; }
.ws-opp-card-group { font-family: var(--mono); font-size: var(--text-sm-size); letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-2); margin-bottom: 6px; }
.ws-opp-card-meta { display: flex; align-items: center; gap: 8px; }
.ws-opp-card-badge {
  font-family: var(--mono); font-size: var(--text-sm-size); letter-spacing: 0.06em; text-transform: uppercase;
  padding: 2px 7px;
}
.ws-stat-strip-item { flex: 1; padding: 10px 16px; border-right: 1px solid var(--rule); }
.ws-stat-strip-item:last-child { border-right: none; }
.ws-stat-strip-label { font-family: var(--mono); font-size: var(--text-sm-size); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-2); margin-bottom: 3px; }
.ws-stat-strip-val { font-family: var(--serif); font-size: var(--text-md-size); font-weight: var(--weight-medium); color: var(--ink); }
.ws-cat-item { padding: 14px 18px; border-bottom: 1px solid var(--rule); cursor: pointer; transition: background 0.1s; border-left: 3px solid transparent; }
.ws-cat-item:hover { background: var(--accent-light); }
.ws-cat-item.active { background: var(--accent-light); border-left-color: var(--accent); }
.ws-cat-item-name  { font-family: var(--sans); font-size: var(--text-base-size); color: var(--ink); font-weight: 400; }
.ws-cat-item.active .ws-cat-item-name { color: var(--accent); font-weight: var(--weight-bold); }
.ws-cat-item-count { font-family: var(--sans); font-size: var(--text-base-size); color: var(--ink-2); margin-top: 4px; }
.ws-cat-section-hdr {
  padding: 12px 14px 10px; background: var(--bg); border-bottom: 1px solid var(--rule);
  border-top: 2px solid var(--rule); position: sticky; top: 0; z-index: 1;
}
.ws-cat-section-hdr-type {
  font-family: var(--mono); font-size: var(--text-base-size); letter-spacing: 0.14em; text-transform: uppercase;
  margin-bottom: 5px;
}
.ws-cat-section-hdr-def {
  font-family: var(--sans); font-size: var(--text-sm-size); font-weight: var(--weight-light); color: var(--ink);
  line-height: 1.6; text-transform: none;
}

/* ── PATENTS TO ACQUIRE TABLE ────────────────────────────────────────────── */
.ws-acq-table { border-collapse: collapse; table-layout: fixed; width: max-content; min-width: 1140px; }
.ws-acq-table-wrap { flex: 1 1 auto; min-height: 0; width: 100%; overflow: auto; }
.ws-acq-th {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-2); padding: 10px 16px; text-align: left; border-bottom: 2px solid var(--rule);
  background: var(--bg); position: sticky; top: 0; z-index: 2; white-space: nowrap;
}
.ws-acq-td { padding: 11px 14px; vertical-align: top; border-bottom: 1px solid var(--rule); overflow: hidden; max-width: 0; }
.ws-acq-td-patent { vertical-align: top; }
.ws-acq-td-title  { vertical-align: top; }
.ws-acq-td-assignee { vertical-align: top; }
.ws-acq-td-date   { font-family: var(--mono); font-size: var(--text-base-size); color: var(--ink-2); white-space: nowrap; vertical-align: top; padding-top: 13px; }
.ws-acq-td-gap    { vertical-align: top; padding-top: 13px; }
.ws-acq-td-why    { font-size: var(--text-base-size); color: var(--ink-2); font-weight: var(--weight-light); line-height: 1.65; vertical-align: top; }
.ws-acq-why-text  { line-height: 1.6; word-break: break-word; }
.ws-acq-td-priority { vertical-align: top; padding: 13px 24px 13px 14px; }
.ws-acq-num       { font-family: var(--serif); font-size: var(--text-base-size); font-weight: var(--weight-medium); color: var(--accent); margin-bottom: 3px; word-break: break-word; }
.ws-acq-affects   { font-family: var(--mono); font-size: var(--text-base-size); color: var(--ink-2); margin-top: 3px; word-break: break-word; line-height: 1.6; }
.ws-acq-title     { font-size: var(--text-base-size); color: var(--ink); font-weight: 400; line-height: 1.6; word-break: break-word; }
.ws-acq-assignee  { font-family: var(--sans); font-size: var(--text-base-size); color: var(--ink); font-weight: 400; margin-bottom: 3px; word-break: break-word; }
.ws-acq-email     { font-family: var(--mono); font-size: var(--text-base-size); color: var(--accent); text-decoration: none; display: block; word-break: break-all; }
.ws-acq-email:hover { text-decoration: underline; }
.ws-acq-badge     { font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.06em; text-transform: uppercase; padding: 3px 8px; display: inline-block; white-space: nowrap; }

@media (max-width: 1280px) {
  .ws-modal { width: min(1320px, calc(100vw - 16px)); height: min(92vh, 960px); }
}
@media (max-width: 960px) {
  .ws-modal { width: calc(100vw - 8px); height: calc(100vh - 8px); max-height: calc(100vh - 8px); }
  .ws-main { flex-direction: column; }
  .ws-pane-left {
    width: 100%;
    flex: 0 0 auto;
    min-width: 0;
    max-height: 34vh;
    border-right: none;
    border-bottom: 1px solid var(--rule);
  }
  .ws-acq-table { min-width: 980px; }
}
@media (max-width: 640px) {
  .ws-header { padding: 14px 14px 12px; }
  .ws-title { font-size: var(--text-lg-size); }
  .ws-desc { font-size: var(--text-sm-size); line-height: 1.5; }
  .ws-close { font-size: var(--text-xs-size); padding: 6px 10px; }
  .ws-cat-item { padding: 10px 12px; }
}

/* ── COMPETITOR ANALYSIS DASHBOARD ─────────────────────────────────────── */
.ca-overlay {
  position: fixed; inset: 0; background: rgba(10,8,30,0.6); z-index: 920;
  display: none; align-items: center; justify-content: center;
  backdrop-filter: blur(3px);
}
.ca-overlay.open { display: flex; }
.ca-modal {
  background: var(--paper); width: 1200px; max-width: 97vw; height: 86vh; max-height: 92vh;
  box-shadow: 0 16px 64px rgba(0,0,0,0.28);
  animation: sModalIn 0.22s cubic-bezier(.16,1,.3,1);
  display: flex; flex-direction: column; overflow: hidden;
}
.ca-header {
  display: flex; justify-content: space-between; align-items: flex-start;
  padding: 18px 22px 14px; border-bottom: 1px solid var(--rule);
}
.ca-eyebrow { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent); margin-bottom: 4px; }
.ca-title { font-family: var(--serif); font-size: var(--text-lg-size); font-weight: var(--weight-medium); color: var(--ink); }
.ca-desc { font-size: var(--text-sm-size); color: var(--ink-3); margin-top: 4px; font-weight: var(--weight-light); max-width: 720px; line-height: 1.5; }
.ca-header-actions { display: flex; align-items: center; gap: 8px; }
.ca-btn {
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 7px 12px; border: 1px solid var(--rule); background: var(--paper); color: var(--ink-2);
  cursor: pointer; transition: all 0.13s;
}
.ca-btn:hover { border-color: var(--accent); color: var(--accent); }
.ca-close {
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.1em; text-transform: uppercase;
  padding: 7px 14px; border: 1px solid var(--rule); background: none; color: var(--ink-2);
  cursor: pointer; transition: all 0.13s;
}
.ca-close:hover { border-color: var(--accent); color: var(--accent); }

.ca-tabs {
  display: flex; align-items: center; gap: 8px; padding: 10px 22px;
  border-bottom: 1px solid var(--rule); background: var(--bg);
}
.ca-tab-btn {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.09em; text-transform: uppercase;
  padding: 6px 11px; border: 1px solid var(--rule); background: var(--paper); color: var(--ink-3);
  cursor: pointer; transition: all 0.13s;
}
.ca-tab-btn:hover { border-color: var(--accent); color: var(--accent); }
.ca-tab-btn.active { background: var(--accent); color: white; border-color: var(--accent); }

.ca-status {
  display: none; margin: 10px 22px 0; padding: 9px 12px; border: 1px solid var(--rule); background: var(--bg);
  font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-3); letter-spacing: 0.05em;
}
.ca-status.error { border-color: #d7b4b4; background: #fbefef; color: #8a3838; }

.ca-content { flex: 1; min-height: 0; display: flex; flex-direction: column; }
.ca-main-view { flex: 1; min-height: 0; display: block; }
.ca-panel { display: none; height: 100%; overflow: auto; padding: 16px 24px 24px; }
.ca-panel.active { display: block; }

.ca-kpi-row { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 10px; margin-bottom: 12px; }
.ca-kpi-card { border: 1px solid var(--rule); background: var(--bg); padding: 12px; }
.ca-kpi-label { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 4px; }
.ca-kpi-value { font-family: var(--serif); font-size: var(--text-lg-size); font-weight: var(--weight-medium); color: var(--ink); line-height: 1; }
.ca-kpi-sub { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-3); margin-top: 5px; }
.ca-kpi-value.green { color: var(--green); }
.ca-kpi-value.accent { color: var(--accent); }
.ca-kpi-value.amber { color: var(--amber); }

.ca-grid-2 { display: grid; grid-template-columns: 1.35fr 1fr; gap: 10px; margin-bottom: 10px; }
.ca-grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 10px; }
.ca-card { border: 1px solid var(--rule); background: var(--paper); padding: 10px; }
.ca-card-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 8px; gap: 10px; }
.ca-card-title { font-family: var(--serif); font-size: var(--text-base-size); font-weight: var(--weight-medium); color: var(--ink); }
.ca-card-sub { font-family: var(--mono); font-size: var(--text-tiny-size); color: var(--ink-3); letter-spacing: 0.06em; text-transform: uppercase; }
.ca-chart-wrap { height: 230px; }
.ca-category-legend {
  margin-top: 8px;
  border: 1px solid var(--rule);
  background: var(--bg);
  max-height: 130px;
  overflow-y: auto;
  padding: 4px;
}
.ca-category-legend-item {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 4px 6px;
  font-family: var(--mono);
  font-size: var(--text-xs-size);
  color: var(--ink-2);
}
.ca-category-legend-swatch { width: 8px; height: 8px; border-radius: 2px; flex-shrink: 0; }
.ca-category-legend-name { font-size: 12px; flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ca-category-legend-count { font-size: 12px; color: var(--ink); font-weight: var(--weight-medium); }
.ca-category-legend-pct { font-size: 12px; color: var(--ink-3); min-width: 34px; text-align: right; }
.ca-commentary {
  margin-top: 8px; border-top: 1px solid var(--rule); padding-top: 8px;
  font-size: var(--text-sm-size); color: var(--ink-2); line-height: 1.6; font-weight: var(--weight-light);
}
.ca-guide {
  border: 1px solid var(--rule);
  background: var(--bg);
  padding: 12px 12px;
  margin-bottom: 12px;
}
.ca-guide-title {
  font-family: var(--mono);
  font-size: var(--text-tiny-size);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 6px;
}
.ca-guide-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.ca-guide-item {
  border: 1px solid var(--rule);
  background: var(--paper);
  padding: 9px 10px;
}
.ca-guide-item-label {
  font-family: var(--mono);
  font-size: var(--text-tiny-size);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 3px;
}
.ca-guide-item-text {
  font-size: var(--text-xs-size);
  line-height: 1.5;
  color: var(--ink-2);
}

.ca-filter-row {
  display: flex; gap: 8px; align-items: center; flex-wrap: wrap;
  margin-bottom: 12px; padding: 10px 12px; border: 1px solid var(--rule); background: var(--bg);
  row-gap: 8px;
}
.ca-filter-label { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); }
.ca-select, .ca-input {
  font-family: var(--mono); font-size: var(--text-xs-size); padding: 5px 8px;
  border: 1px solid var(--rule); background: var(--paper); color: var(--ink-2);
}
.ca-select:focus, .ca-input:focus { outline: none; border-color: var(--accent); }

.ca-table-wrap { border: 1px solid var(--rule); background: var(--paper); overflow: auto; max-height: 62vh; scrollbar-gutter: stable both-edges; }
.ca-table { width: 100%; border-collapse: collapse; }
.ca-table thead th {
  position: sticky; top: 0; z-index: 1;
  font-family: var(--mono); font-size: var(--text-sm-size); letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-3); background: #f7f6f3; border-bottom: 1px solid var(--rule);
  padding: 8px 10px; text-align: left; font-weight: var(--weight-medium); white-space: nowrap;
}
.ca-table thead th.ca-sortable { cursor: pointer; }
.ca-table thead th.ca-sortable:hover { color: var(--accent); }
.ca-table td { border-bottom: 1px solid var(--rule); padding: 10px 12px; font-size: var(--text-base-size); color: var(--ink-2); vertical-align: top; line-height: 1.45; }
.ca-table tbody tr:hover { background: var(--accent-light); }
.ca-table tbody tr.ca-row-selected { background: var(--accent-light); box-shadow: inset 2px 0 0 var(--accent); }
.ca-click-row { cursor: pointer; }
.ca-empty { padding: 22px 10px; text-align: center; font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-3); letter-spacing: 0.04em; }
.ca-link-btn {
  font-family: var(--mono);
  font-size: var(--text-xs-size);
  letter-spacing: 0.02em;
  border: 1px solid var(--rule);
  background: var(--paper);
  color: var(--accent);
  padding: 3px 7px;
  cursor: pointer;
  text-align: left;
}
.ca-link-btn:hover { border-color: var(--accent); background: var(--accent-light); }
.ca-mono { font-family: var(--mono); font-size: var(--text-sm-size); color: var(--ink-2); }
.ca-badge {
  display: inline-block; padding: 2px 6px; font-family: var(--mono); font-size: var(--text-xs-size);
  letter-spacing: 0.08em; text-transform: uppercase; border-radius: 2px;
}
.ca-badge.signal-action { cursor: pointer; transition: transform 0.08s ease, filter 0.12s ease; }
.ca-badge.signal-action:hover { filter: brightness(0.97); transform: translateY(-1px); }
.ca-badge.surprise { background: #fde8e8; color: #8f2727; border: 1px solid #e7c4c4; }
.ca-badge.spike { background: #fff3e0; color: #8a5a14; border: 1px solid #ebd3af; }
.ca-badge.good { background: #e8f4ed; color: var(--green); border: 1px solid #c5dfd0; }
.ca-muted { color: var(--ink-3); font-size: var(--text-sm-size); }
.ca-lic-summary-card { margin-top: 10px; }
.ca-lic-summary-status { margin-bottom: 8px; }
.ca-lic-summary-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; margin-bottom: 10px; }
.ca-lic-summary-box {
  border: 1px solid var(--rule);
  background: var(--bg);
  padding: 8px 10px;
}
.ca-lic-summary-box h4 {
  margin: 0 0 5px;
  font-family: var(--mono);
  font-size: var(--text-xs-size);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: var(--weight-medium);
}
.ca-lic-summary-box p {
  margin: 0;
  font-size: var(--text-sm-size);
  line-height: 1.55;
  color: var(--ink-2);
}
.ca-lic-patent-list {
  border: 1px solid var(--rule);
  background: var(--paper);
  max-height: 250px;
  overflow: auto;
}
.ca-lic-patent-item {
  display: grid;
  grid-template-columns: 1fr;
  gap: 4px;
  border-bottom: 1px solid var(--rule);
  padding: 8px 10px;
}
.ca-lic-patent-item:last-child { border-bottom: 0; }
.ca-lic-patent-meta {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}
.ca-lic-patent-reason {
  font-size: var(--text-xs-size);
  line-height: 1.5;
  color: var(--ink-3);
}
.ca-signal-cell { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; min-width: 180px; }
.ca-signal-detail {
  border: 1px solid var(--rule);
  background: var(--bg);
  padding: 10px;
  margin-bottom: 10px;
}
.ca-signal-detail-head { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.ca-signal-detail-title { font-family: var(--serif); font-size: var(--text-base-size); color: var(--ink); font-weight: var(--weight-medium); }
.ca-signal-detail-sub { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-3); letter-spacing: 0.07em; text-transform: uppercase; }
.ca-signal-detail-close {
  margin-left: auto;
  font-family: var(--mono);
  font-size: var(--text-tiny-size);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: 1px solid var(--rule);
  background: var(--paper);
  color: var(--ink-2);
  padding: 4px 8px;
  cursor: pointer;
}
.ca-signal-detail-close:hover { border-color: var(--accent); color: var(--accent); }
.ca-signal-detail-body { font-size: var(--text-sm-size); color: var(--ink-2); line-height: 1.6; }
.ca-signal-detail-list { margin: 8px 0 0; padding-left: 18px; }
.ca-track-toggle {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 2px 6px; border: 1px solid var(--rule); background: var(--bg);
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.07em; text-transform: uppercase; color: var(--ink-3);
}
.ca-track-toggle input { width: 11px; height: 11px; margin: 0; }
.ca-track-toggle.off { opacity: 0.7; }

.ca-empty {
  padding: 26px 16px; text-align: center; border: 1px solid var(--rule); background: var(--bg);
  font-size: var(--text-sm-size); color: var(--ink-3); font-family: var(--mono); letter-spacing: 0.04em;
}

.ca-detail-view { display: none; flex: 1; min-height: 0; overflow: auto; padding: 14px 22px 22px; }
.ca-detail-view.open { display: block; }
.ca-back-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.ca-back-btn {
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 6px 10px; border: 1px solid var(--rule); background: var(--paper); color: var(--ink-2);
  cursor: pointer; transition: all 0.13s;
}
.ca-back-btn:hover { border-color: var(--accent); color: var(--accent); }
.ca-detail-title { font-family: var(--serif); font-size: var(--text-lg-size); color: var(--ink); font-weight: var(--weight-medium); }
.ca-detail-sub { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-3); letter-spacing: 0.07em; text-transform: uppercase; margin-top: 2px; }
.ca-meta-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 8px; margin: 12px 0; }
.ca-meta-card { border: 1px solid var(--rule); background: var(--bg); padding: 10px; }
.ca-meta-label { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 4px; }
.ca-meta-value { font-family: var(--serif); font-size: var(--text-xs-size); color: var(--ink); line-height: 1; }
.ca-detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 10px; }
.ca-abstract { border: 1px solid var(--rule); background: var(--paper); padding: 12px; font-size: var(--text-sm-size); line-height: 1.7; color: var(--ink-2); font-weight: var(--weight-light); }
.ca-code-list { border: 1px solid var(--rule); background: var(--paper); padding: 12px; font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-2); line-height: 1.5; min-height: 84px; }
.ca-related-wrap { margin-top: 10px; }

@media (max-width: 1040px) {
  .ca-modal { width: 98vw; height: 92vh; }
  .ws-guide { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ca-kpi-row { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .ca-grid-2 { grid-template-columns: 1fr; }
  .ca-grid-3 { grid-template-columns: 1fr; }
  .ca-guide-grid { grid-template-columns: 1fr; }
  .ca-lic-summary-grid { grid-template-columns: 1fr; }
  .ca-detail-grid { grid-template-columns: 1fr; }
  .ca-meta-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 680px) {
  .ca-tabs { overflow-x: auto; }
  .ws-guide { grid-template-columns: 1fr; margin: 0 12px; }
  .ws-guide-card { border-right: 0; border-bottom: 1px solid var(--rule); }
  .ws-guide-card:last-child { border-bottom: 0; }
  .ca-meta-grid { grid-template-columns: 1fr; }
}

/* ── CATEGORY SELECTOR ─────────────────────────────────────────────────── */
.cat-selector-bar {
  display: flex; align-items: center; gap: 8px; padding: 8px 16px;
  border-bottom: 1px solid var(--rule); background: var(--bg); flex-wrap: wrap;
}
.cat-selector-label { font-family: var(--mono); font-size: var(--text-base-size); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-2); white-space: nowrap; flex-shrink: 0; }
.cat-group-select {
  font-family: var(--mono); font-size: var(--text-sm-size); padding: 5px 8px;
  border: 1px solid var(--rule); background: var(--paper); color: var(--ink-2);
  cursor: pointer; outline: none; transition: border-color 0.13s;
}
.cat-group-select:focus { border-color: var(--accent); }
.cat-sub-select {
  font-family: var(--mono); font-size: var(--text-sm-size); padding: 5px 8px;
  border: 1px solid var(--rule); background: var(--paper); color: var(--ink-2);
  cursor: pointer; outline: none; transition: border-color 0.13s; min-width: 180px;
}
.cat-sub-select:focus { border-color: var(--accent); }
.cat-clear-btn {
  font-family: var(--mono); font-size: var(--text-base-size); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 4px 10px; border: 1px solid var(--rule); background: none; color: var(--ink-2);
  cursor: pointer; transition: all 0.13s; display: none;
}
.cat-clear-btn:hover { border-color: var(--accent); color: var(--accent); }
.cat-active-label {
  font-family: var(--mono); font-size: var(--text-sm-size); color: var(--accent);
  letter-spacing: 0.04em; font-weight: var(--weight-medium);
}

/* ── PATENT DETAIL MODAL ────────────────────────────────────────────────── */
.pd-overlay {
  position: fixed; inset: 0; background: rgba(10,8,30,0.5); z-index: 930;
  display: none; align-items: center; justify-content: center;
  backdrop-filter: blur(2px);
}
.pd-overlay.open { display: flex; }
.pd-card {
  background: var(--paper); width: 760px; max-width: calc(100vw - 48px); max-height: 94vh; min-height: 520px;
  border-radius: 6px; display: flex; flex-direction: column; overflow: hidden;
  box-shadow: 0 12px 48px rgba(0,0,0,0.22);
  animation: sModalIn 0.2s cubic-bezier(.16,1,.3,1);
}
.pd-top {
  display: flex; justify-content: space-between; align-items: flex-start;
  padding: 24px 28px 10px;
}
.pd-num { font-family: var(--sans); font-size: 22px; font-weight: var(--weight-bold); color: var(--ink); letter-spacing: -0.01em; }
.pd-date { font-family: var(--mono); font-size: 12px; color: var(--ink-3); background: var(--bg); border: 1px solid var(--rule); padding: 3px 10px; border-radius: 4px; }
.pd-title { font-family: var(--sans); font-size: 18px; font-weight: var(--weight-bold); color: var(--ink); padding: 0 28px 18px; line-height: 1.38; }
.pd-meta { display: flex; flex-direction: column; gap: 0; padding: 0 28px 18px; }
.pd-meta-row { display: flex; align-items: baseline; gap: 14px; padding: 7px 0; border-bottom: 1px solid var(--rule); }
.pd-meta-row:last-child { border-bottom: none; }
.pd-meta-key { font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-3); width: 96px; flex-shrink: 0; }
.pd-meta-val { font-size: 15px; color: var(--ink-2); font-weight: 400; }
.pd-similar-dropdown { width: 100%; }
.pd-similar-dropdown summary {
  color: var(--accent);
  cursor: pointer;
  font-family: var(--mono);
  font-size: var(--text-tiny-size);
  letter-spacing: 0.08em;
  list-style-position: outside;
  text-transform: uppercase;
}
.pd-similar-dropdown summary:hover { color: var(--ink); }
.pd-similar-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  list-style: none;
  margin: 7px 0 0;
  padding: 0;
  width: 100%;
}
.pd-similar-list li { border-top: 1px solid var(--rule); }
.pd-similar-link {
  display: grid;
  grid-template-columns: minmax(92px, auto) minmax(0, 1fr);
  gap: 9px;
  align-items: baseline;
  color: var(--ink-2);
  padding: 6px 0;
  text-decoration: none;
}
.pd-similar-link:hover { color: var(--accent); }
.pd-similar-link b {
  color: var(--accent);
  font-family: var(--mono);
  font-size: var(--text-tiny-size);
  white-space: nowrap;
}
.pd-similar-link span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: var(--text-xs-size);
}
.pd-similar-link em {
  color: var(--ink-3);
  font-family: var(--mono);
  font-size: var(--text-tiny-size);
  font-style: normal;
  white-space: nowrap;
}
.pd-stage-pill {
  font-family: var(--sans); font-size: var(--text-sm-size); font-weight: var(--weight-medium);
  padding: 3px 14px; border-radius: 20px; display: inline-block;
}
.pd-stage-granted     { background: #f0e8d0; color: #8a5a00; border: 1px solid #e0c880; }
.pd-stage-publication { background: #f5ead8; color: #9a6010; border: 1px solid #e8d0a0; }
.pd-stage-pct         { background: var(--accent-light); color: var(--accent); border: 1px solid #c5c0e8; }
.pd-stage-unknown     { background: var(--bg); color: var(--ink-3); border: 1px solid var(--rule); }
.pd-scroll-body { flex: 1; overflow-y: auto; min-height: 0; }
.pd-abstract-wrap { margin: 0 28px 18px; border: 1px solid var(--rule); border-radius: 4px; padding: 16px 18px; background: #fafaf8; }
.pd-abstract-label { font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 9px; }
.pd-abstract-text { font-size: 15px; color: var(--ink-2); line-height: 1.72; font-weight: var(--weight-normal); }
.pd-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 28px; border-top: 1px solid var(--rule); background: var(--bg); flex-shrink: 0;
}
.pd-footer-left { display: flex; gap: 8px; }
.pd-view-spec {
  font-family: var(--sans); font-size: var(--text-sm-size); font-weight: var(--weight-bold);
  padding: 9px 18px; background: var(--accent); color: white; border: none;
  border-radius: 4px; cursor: pointer; transition: background 0.13s; letter-spacing: 0.02em;
}
.pd-view-spec:hover { background: var(--accent-mid); }
.pd-assign {
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.1em; text-transform: uppercase;
  padding: 9px 14px; background: none; color: var(--ink-3); border: 1px solid var(--rule);
  border-radius: 4px; cursor: pointer; transition: all 0.13s;
}
.pd-assign:hover { border-color: var(--accent); color: var(--accent); }
.pd-coverage-btn {
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 9px 14px; background: none; color: var(--accent); border: 1px solid var(--accent);
  border-radius: 4px; cursor: pointer; transition: all 0.13s;
}
.pd-coverage-btn:hover { background: var(--accent); color: white; }
.pd-invalidity-search-btn {
  font-family: var(--mono); font-size: var(--text-xs-size); font-weight: var(--weight-bold); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 9px 14px; background: #8f1f1f; color: #fff; border: 1px solid #8f1f1f;
  border-radius: 4px; cursor: pointer; transition: all 0.13s; text-decoration: none; display: inline-block;
}
.pd-invalidity-search-btn:hover { background: #741818; border-color: #741818; color: #fff; }
.pd-google {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 9px 14px; background: none; color: var(--ink-3); border: 1px solid var(--rule);
  border-radius: 4px; cursor: pointer; transition: all 0.13s; text-decoration: none; display: inline-flex; align-items: center; gap: 5px;
}
.pd-google:hover { border-color: var(--accent); color: var(--accent); }
.pd-close-x {
  position: absolute; top: 16px; right: 16px;
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase;
  background: none; border: 1px solid var(--rule); color: var(--ink-3); cursor: pointer;
  padding: 5px 14px; border-radius: 4px; transition: all 0.13s;
}
.pd-close-x:hover { background: var(--bg); color: var(--ink); }
.pd-card { position: relative; }
.pd-card.is-loading .pd-scroll-body {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  padding: 32px 24px;
}
.pd-card.is-loading .pd-top,
.pd-card.is-loading .pd-meta,
.pd-card.is-loading .pd-abstract-label {
  display: none !important;
}
.pd-card.is-loading .pd-title {
  width: 100%;
  max-width: 960px;
  padding: 0;
  margin: 0 0 14px;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pd-card.is-loading .pd-abstract-wrap {
  margin: 0;
  padding: 0;
  border: none;
  background: transparent;
}
.pd-card.is-loading .pd-abstract-text {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-size: var(--text-sm-size);
  color: var(--ink-2);
}
.pd-loading-spinner {
  width: 16px;
  height: 16px;
  border-width: 2px;
}

/* ── SPEC VIEWER MODAL ───────────────────────────────────────────────────── */
.spec-overlay {
  position: fixed; inset: 0; background: rgba(10,8,30,0.56); z-index: 940;
  display: none; align-items: center; justify-content: center;
  backdrop-filter: blur(2px);
}
.spec-overlay.open { display: flex; }
.spec-card {
  background: var(--paper); width: 1020px; max-width: 96vw; max-height: 92vh;
  border-radius: 6px; display: flex; flex-direction: column; overflow: hidden;
  box-shadow: 0 12px 48px rgba(0,0,0,0.22);
  animation: sModalIn 0.2s cubic-bezier(.16,1,.3,1);
}
.spec-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; border-bottom: 1px solid var(--rule); background: #fafaf8;
}
.spec-title-wrap { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.spec-kicker { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-3); }
.spec-title { font-family: var(--serif); font-size: var(--text-xs-size); color: var(--ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 720px; }
.spec-search-wrap { display: flex; align-items: center; gap: 8px; }
.spec-text-size-wrap { display: inline-flex; align-items: center; gap: 4px; margin-right: 4px; }
.spec-size-btn {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 6px 7px; background: var(--paper); border: 1px solid var(--rule); border-radius: 3px;
  color: var(--ink-3); cursor: pointer; transition: all 0.13s;
}
.spec-size-btn:hover { border-color: var(--accent); color: var(--accent); }
.spec-search {
  border: 1px solid var(--rule); background: var(--paper); height: 32px;
  padding: 0 10px; min-width: 300px; font-family: var(--mono); font-size: var(--text-xs-size);
  letter-spacing: 0.03em; color: var(--ink-2);
}
.spec-search:focus { outline: none; border-color: var(--accent); }
.spec-close {
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.1em; text-transform: uppercase;
  padding: 8px 10px; background: none; border: 1px solid var(--rule); border-radius: 4px;
  color: var(--ink-3); cursor: pointer; transition: all 0.13s;
}
.spec-close:hover { border-color: var(--accent); color: var(--accent); }
.spec-body {
  display: grid; grid-template-columns: 330px 1fr; min-height: 0; flex: 1;
}
.spec-left {
  border-right: 1px solid var(--rule); overflow: auto; padding: 14px 16px;
}
.spec-right {
  overflow: auto; padding: 14px 18px 18px;
}
.spec-field { margin-bottom: 12px; }
.spec-field-label { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 5px; }
.spec-field-val { font-size: var(--text-sm-size); color: var(--ink-2); line-height: 1.6; }
.spec-abstract { white-space: pre-wrap; }
.spec-section {
  border: 1px solid var(--rule); border-radius: 4px; margin-bottom: 10px; overflow: hidden;
}
.spec-section-head {
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--accent); background: var(--bg); padding: 7px 10px; border-bottom: 1px solid var(--rule);
}
.spec-section-body {
  font-size: calc(14px * var(--spec-font-scale, 1));
  line-height: calc(1.78 * var(--spec-font-scale, 1));
  color: #1f1f1f;
  padding: 14px 16px;
  white-space: pre-wrap;
  tab-size: 4;
  font-family: var(--sans);
  letter-spacing: 0.005em;
  word-break: normal;
  overflow-wrap: anywhere;
}
.spec-section-body.spec-tabular {
  font-family: var(--mono);
  font-size: calc(12px * var(--spec-font-scale, 1));
  line-height: 1.6;
  letter-spacing: 0;
}
.spec-empty {
  border: 1px dashed var(--rule); border-radius: 4px; padding: 12px;
  font-size: var(--text-sm-size); color: var(--ink-3); background: #fafaf8;
}
.spec-mark { background: #ffe29f; color: #3a2a00; padding: 0 1px; border-radius: 2px; }

/* ── COVERAGE MATRIX MODAL ──────────────────────────────────────────────── */
.cm-overlay {
  position: fixed; inset: 0; background: rgba(10,8,30,0.65); z-index: 940;
  display: none; align-items: center; justify-content: center;
  backdrop-filter: blur(3px);
}
.cm-overlay.open { display: flex; }
.cm-modal {
  background: var(--paper); width: 1000px; max-width: 97vw; height: 88vh;
  display: flex; flex-direction: column; overflow: hidden;
  box-shadow: 0 20px 80px rgba(0,0,0,0.3);
  animation: sModalIn 0.22s cubic-bezier(.16,1,.3,1);
}
/* Header */
.cm-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 18px 24px 14px; border-bottom: 1px solid var(--rule); flex-shrink: 0;
  background: var(--bg);
}
.cm-eyebrow { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent); margin-bottom: 3px; }
.cm-title { font-family: var(--serif); font-size: var(--text-xs-size); font-weight: var(--weight-medium); color: var(--ink); }
.cm-close { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.1em; text-transform: uppercase; padding: 6px 12px; border: 1px solid var(--rule); background: none; color: var(--ink-3); cursor: pointer; transition: all 0.13s; }
.cm-close:hover { border-color: var(--accent); color: var(--accent); }
/* Step bar */
.cm-steps { display: flex; border-bottom: 1px solid var(--rule); flex-shrink: 0; }
.cm-step { flex: 1; padding: 10px 16px; font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); border-bottom: 2px solid transparent; display: flex; align-items: center; gap: 8px; }
.cm-step.active { color: var(--accent); border-bottom-color: var(--accent); background: var(--accent-light); }
.cm-step.done   { color: var(--green); border-bottom-color: var(--green); }
.cm-step-num { width: 18px; height: 18px; border-radius: 50%; background: var(--rule); display: flex; align-items: center; justify-content: center; font-size: var(--text-tiny-size); flex-shrink: 0; }
.cm-step.active .cm-step-num { background: var(--accent); color: white; }
.cm-step.done   .cm-step-num { background: var(--green); color: white; }
/* Body */
.cm-body { flex: 1; overflow-y: auto; display: flex; flex-direction: column; }
.cm-page { display: none; flex-direction: column; padding: 24px; gap: 18px; flex: 1; }
.cm-page.active { display: flex; }
/* Input fields */
.cm-field-label { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); margin-bottom: 6px; }
.cm-field-sub { font-size: var(--text-xs-size); color: var(--ink-3); font-weight: var(--weight-light); margin-bottom: 8px; }
.cm-textarea { font-family: var(--mono); font-size: var(--text-xs-size); padding: 10px 12px; border: 1px solid var(--rule); background: var(--bg); color: var(--ink); outline: none; resize: vertical; min-height: 120px; line-height: 1.65; width: 100%; transition: border-color 0.15s; letter-spacing: 0.02em; }
.cm-textarea:focus { border-color: var(--accent); }
.cm-input { font-family: var(--mono); font-size: var(--text-sm-size); padding: 9px 12px; border: 1px solid var(--rule); background: var(--bg); color: var(--ink); outline: none; width: 100%; transition: border-color 0.15s; }
.cm-input:focus { border-color: var(--accent); }
.cm-or-divider { display: flex; align-items: center; gap: 12px; margin: 4px 0; font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); }
.cm-or-divider::before, .cm-or-divider::after { content:''; flex:1; height:1px; background:var(--rule); }
/* Upload zone */
.cm-upload-zone { border: 2px dashed var(--rule); padding: 24px; text-align: center; cursor: pointer; transition: all 0.15s; background: var(--bg); }
.cm-upload-zone:hover, .cm-upload-zone.drag-over { border-color: var(--accent); background: var(--accent-light); }
.cm-upload-icon { font-size: var(--text-lg-size); margin-bottom: 8px; }
.cm-upload-label { font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3); }
.cm-upload-sub { font-size: var(--text-xs-size); color: var(--ink-3); margin-top: 4px; }
.cm-file-chosen { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--accent); margin-top: 8px; }
/* Spec preview chips */
.cm-ref-card { border: 1px solid var(--rule); padding: 10px 12px; background: var(--bg); display: flex; align-items: flex-start; gap: 10px; }
.cm-ref-num { font-family: var(--mono); font-size: var(--text-xs-size); font-weight: var(--weight-bold); color: var(--accent); flex-shrink: 0; }
.cm-ref-title { font-size: var(--text-sm-size); color: var(--ink-2); font-weight: var(--weight-light); }
/* Matrix result */
.cm-matrix-wrap { display: flex; flex-direction: column; gap: 0; flex: 1; }
.cm-matrix-header-row { display: grid; gap: 0; background: var(--accent); color: white; }
.cm-matrix-row { display: grid; gap: 0; border-bottom: 1px solid var(--rule); }
.cm-matrix-row:last-child { border-bottom: none; }
.cm-matrix-cell { padding: 10px 12px; border-right: 1px solid var(--rule); font-size: var(--text-sm-size); }
.cm-matrix-cell:last-child { border-right: none; }
.cm-matrix-cell.head { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.1em; text-transform: uppercase; font-weight: var(--weight-medium); color: white; }
.cm-matrix-cell.limitation { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-2); font-weight: var(--weight-medium); }
.cm-matrix-cell.analysis { font-size: var(--text-xs-size); color: var(--ink-2); font-weight: var(--weight-light); line-height: 1.55; }
.cm-verdict { display: inline-block; font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.08em; text-transform: uppercase; padding: 2px 7px; border-radius: 2px; margin-bottom: 4px; }
.cm-verdict.meets    { background: #e8f4ed; color: var(--green); }
.cm-verdict.partial  { background: #faeeda; color: var(--amber); }
.cm-verdict.gap      { background: #fde8e8; color: #a02020; }
.cm-verdict.unclear  { background: var(--bg); color: var(--ink-3); border: 1px solid var(--rule); }
/* Loading */
.cm-loading { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 16px; padding: 48px; }
.cm-spinner-lg { width: 32px; height: 32px; border: 3px solid var(--rule); border-top-color: var(--accent); border-radius: 50%; animation: ws-spin 0.8s linear infinite; }
.cm-loading-text { font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); }
/* Footer nav */
.cm-footer { display: flex; justify-content: space-between; align-items: center; padding: 14px 24px; border-top: 1px solid var(--rule); background: var(--bg); flex-shrink: 0; }
.cm-back-btn { font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.08em; text-transform: uppercase; padding: 8px 16px; border: 1px solid var(--rule); background: none; color: var(--ink-2); cursor: pointer; transition: all 0.13s; }
.cm-back-btn:hover { border-color: var(--accent); color: var(--accent); }
.cm-next-btn { font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.08em; text-transform: uppercase; padding: 8px 20px; background: var(--accent); color: white; border: none; cursor: pointer; transition: background 0.13s; }
.cm-next-btn:hover { background: var(--accent-mid); }
.cm-next-btn:disabled { background: var(--ink-3); cursor: not-allowed; opacity: 0.5; }
.cm-analysis-btn { font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.08em; text-transform: uppercase; padding: 8px 20px; background: #6b4f00; color: white; border: none; cursor: pointer; transition: background 0.13s; }
.cm-analysis-btn:hover { background: #5a4200; }
.cm-step-hint { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-3); letter-spacing: 0.06em; }

/* ── VIEW SUB-CATEGORY MODAL ── */
.sc-overlay {
  position: fixed; inset: 0; background: rgba(10,8,30,0.65); z-index: 950;
  display: none; align-items: center; justify-content: center;
  backdrop-filter: blur(3px);
}
.sc-overlay.open { display: flex; }
.sc-modal {
  background: var(--bg); width: 1060px; max-width: 97vw; height: 90vh;
  display: flex; flex-direction: column; overflow: hidden;
  box-shadow: 0 20px 80px rgba(0,0,0,0.32);
  animation: sModalIn 0.22s cubic-bezier(.16,1,.3,1);
}
/* Step bar */
.sc-steps {
  display: flex; background: var(--accent); flex-shrink: 0; border-bottom: none;
}
.sc-step {
  flex: 1; display: flex; align-items: center; gap: 10px;
  padding: 14px 20px; font-family: var(--mono); font-size: var(--text-tiny-size);
  letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.4);
  border-bottom: 3px solid transparent; transition: all 0.15s;
  position: relative;
}
.sc-step::after {
  content: ''; position: absolute; right: 0; top: 20%; height: 60%;
  width: 1px; background: rgba(255,255,255,0.12);
}
.sc-step:last-child::after { display: none; }
.sc-step.active { color: white; border-bottom-color: white; background: rgba(255,255,255,0.08); }
.sc-step.done   { color: rgba(255,255,255,0.6); border-bottom-color: rgba(255,255,255,0.3); }
.sc-step-num {
  width: 20px; height: 20px; border-radius: 50%; border: 1px solid rgba(255,255,255,0.3);
  display: flex; align-items: center; justify-content: center;
  font-size: var(--text-xs-size); flex-shrink: 0; color: rgba(255,255,255,0.5); background: transparent;
}
.sc-step.active .sc-step-num { background: white; color: var(--accent); border-color: white; font-weight: var(--weight-bold); }
.sc-step.done   .sc-step-num { background: rgba(255,255,255,0.2); color: white; border-color: rgba(255,255,255,0.4); }
/* Body */
.sc-body { flex: 1; overflow-y: auto; display: flex; flex-direction: column; background: var(--paper); }
.sc-page { display: none; flex-direction: column; flex: 1; }
.sc-page.active { display: flex; }

/* PAGE 0 — VIEW SIMILAR */
.sc-p0-header {
  padding: 20px 28px 16px; border-bottom: 1px solid var(--rule); flex-shrink: 0;
}
.sc-p0-eyebrow {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-3); margin-bottom: 8px; display: flex; align-items: center; gap: 8px;
}
.sc-p0-eyebrow span { color: var(--accent); }
.sc-p0-title {
  font-family: var(--serif); font-size: var(--text-lg-size); font-weight: var(--weight-medium); color: var(--ink);
  line-height: 1.25; margin-bottom: 4px; display: flex; align-items: flex-start; justify-content: space-between; gap: 20px;
}
.sc-p0-title-text { flex: 1; }
.sc-targets-box {
  flex-shrink: 0; border: 1px solid var(--rule); padding: 10px 16px; text-align: center; background: var(--bg);
}
.sc-targets-label { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-3); }
.sc-targets-num { font-family: var(--serif); font-size: var(--text-xs-size); font-weight: var(--weight-medium); color: var(--ink); line-height: 1.1; }
.sc-p0-meta { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-3); letter-spacing: 0.03em; }

.sc-what-box {
  margin: 18px 28px 0; padding: 14px 18px; border: 1px solid var(--rule); background: var(--bg);
  flex-shrink: 0;
}
.sc-what-label { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 7px; }
.sc-what-text { font-size: var(--text-sm-size); color: var(--ink-2); font-weight: var(--weight-light); line-height: 1.5; }

.sc-matches-label {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-3); padding: 18px 28px 10px; flex-shrink: 0;
}
.sc-match-list { flex: 1; overflow-y: auto; display: flex; flex-direction: column; padding: 0 28px 20px; gap: 0; }
.sc-match-item {
  border: 1px solid var(--rule); border-top: none; padding: 14px 18px; cursor: pointer;
  transition: background 0.13s; background: var(--paper);
}
.sc-match-item:first-child { border-top: 1px solid var(--rule); }
.sc-match-item:hover { background: var(--accent-light); }
.sc-match-cats {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.06em; color: var(--accent);
  margin-bottom: 5px; display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
}
.sc-match-catdot { color: var(--ink-3); }
.sc-match-title {
  font-family: var(--mono); font-size: var(--text-xs-size); font-weight: var(--weight-medium); color: var(--ink);
  letter-spacing: 0.03em; text-transform: uppercase; margin-bottom: 4px; line-height: 1.4;
}
.sc-match-sub { font-size: var(--text-xs-size); color: var(--ink-3); font-weight: var(--weight-light); }

/* Footer */
.sc-footer {
  display: flex; justify-content: flex-end; align-items: center; gap: 12px;
  padding: 14px 24px; border-top: 1px solid var(--rule); background: var(--bg); flex-shrink: 0;
}
.sc-done-btn {
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.1em; text-transform: uppercase;
  padding: 9px 20px; border: 1px solid var(--rule); background: none;
  color: var(--ink-2); cursor: pointer; transition: all 0.13s;
}
.sc-done-btn:hover { border-color: var(--accent); color: var(--accent); }
.sc-back-btn {
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.1em; text-transform: uppercase;
  padding: 9px 20px; border: 1px solid var(--rule); background: none;
  color: var(--ink-2); cursor: pointer; transition: all 0.13s;
}
.sc-back-btn:hover { border-color: var(--accent); color: var(--accent); }
.sc-footer-hint { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--green); letter-spacing: 0.06em; }

/* PAGE 3 — CLAIM AROUND ANALYSIS */
.sc-ca3-steps {
  display: flex; background: #111827; flex-shrink: 0; border-bottom: 1px solid rgba(255,255,255,0.08);
}
.sc-ca3-step {
  flex: 1; display: flex; align-items: center; gap: 10px;
  padding: 12px 20px; font-family: var(--mono); font-size: var(--text-tiny-size);
  letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.35);
  border-bottom: 3px solid transparent;
}
.sc-ca3-step::after { content:''; position:absolute; right:0; top:20%; height:60%; width:1px; background:rgba(255,255,255,0.1); }
.sc-ca3-done  { color: rgba(100,200,120,0.9); border-bottom-color: #3a7a4a; }
.sc-ca3-active { color: white; border-bottom-color: white; background: rgba(255,255,255,0.06); }
.sc-ca3-num {
  width: 20px; height: 20px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center; font-size: var(--text-xs-size); flex-shrink: 0;
  background: rgba(255,255,255,0.15); color: rgba(255,255,255,0.6);
}
.sc-ca3-done .sc-ca3-num  { background: #3a7a4a; color: white; }
.sc-ca3-active .sc-ca3-num { background: white; color: #111827; font-weight: var(--weight-bold); }

.sc-ca3-header {
  display: grid; grid-template-columns: 1fr 140px 1fr;
  border-bottom: 1px solid var(--rule); flex-shrink: 0;
}
.sc-ca3-patent-panel { padding: 16px 20px; display: flex; flex-direction: column; gap: 3px; }
.sc-ca3-left  { border-right: 1px solid var(--rule); }
.sc-ca3-right { border-left: 1px solid var(--rule); }
.sc-ca3-panel-label {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.16em; text-transform: uppercase; color: #b86a00; margin-bottom: 4px;
}
.sc-ca3-right .sc-ca3-panel-label { color: var(--green); }
.sc-ca3-panel-num { font-family: var(--serif); font-size: var(--text-lg-size); font-weight: var(--weight-medium); color: var(--ink); }
.sc-ca3-panel-title { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-2); margin-top: 2px; }
.sc-ca3-panel-assignee { font-size: var(--text-xs-size); color: var(--ink-3); font-weight: var(--weight-light); margin-top: 4px; }
.sc-ca3-panel-meta { font-size: var(--text-xs-size); color: var(--ink-3); font-weight: var(--weight-light); }
.sc-ca3-center-badge {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 16px 8px; background: #fdf8f0; border-left: 1px solid #e8d8b0; border-right: 1px solid #e8d8b0;
}
.sc-ca3-badge-label { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.1em; text-transform: uppercase; color: #6b4f00; }

.sc-ca3-stats {
  display: grid; grid-template-columns: repeat(4, 1fr);
  border-bottom: 1px solid var(--rule); flex-shrink: 0;
}
.sc-ca3-stat { padding: 14px 20px; border-right: 1px solid var(--rule); }
.sc-ca3-stat:last-child { border-right: none; }
.sc-ca3-stat-num { font-family: var(--serif); font-size: var(--text-xs-size); font-weight: 400; color: var(--ink); line-height: 1; margin-bottom: 4px; }
.sc-ca3-stat-label { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); }
.sc-ca3-stat-avoid  .sc-ca3-stat-num { color: #a02020; }
.sc-ca3-stat-partial .sc-ca3-stat-num { color: var(--amber); }
.sc-ca3-stat-safe   .sc-ca3-stat-num { color: var(--green); }

.sc-ca3-verdict-bar {
  display: flex; align-items: center; gap: 8px; padding: 8px 20px;
  border-bottom: 1px solid var(--rule); background: var(--bg); flex-shrink: 0;
}
.sc-ca3-verdict-label { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-3); margin-right: 4px; }
.sc-ca3-verdict-pill {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.06em; text-transform: uppercase;
  padding: 4px 10px; border: 1px solid var(--rule); background: var(--paper); color: var(--ink-3);
  cursor: pointer; opacity: 0.5; transition: opacity 0.13s;
}
.sc-ca3-verdict-pill.active { opacity: 1; }
.sc-ca3-vp-avoid   { border-color: #e88; color: #a02020; }
.sc-ca3-vp-partial { border-color: #e0c080; color: var(--amber); }
.sc-ca3-vp-safe    { border-color: #80c898; color: var(--green); }
.sc-ca3-vp-unclear { border-color: var(--rule); color: var(--ink-3); }

.sc-ca3-table-wrap { flex: 1; overflow-y: auto; display: flex; flex-direction: column; min-height: 0; }
.sc-ca3-table-head {
  display: grid;
  grid-template-columns: 220px 220px 80px 1fr;
  background: #6b4f00; flex-shrink: 0; position: sticky; top: 0; z-index: 10;
}
.sc-ca3-th {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.1em; text-transform: uppercase;
  color: white; padding: 10px 14px; border-right: 1px solid rgba(255,255,255,0.15);
}
.sc-ca3-th:last-child { border-right: none; }
.sc-ca3-claim-group { border-bottom: 2px solid var(--rule); }
.sc-ca3-claim-group-label {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink-3); padding: 8px 14px; background: var(--bg); border-bottom: 1px solid var(--rule);
}
.sc-ca3-row {
  display: grid; grid-template-columns: 220px 220px 80px 1fr;
  border-bottom: 1px solid var(--rule); min-height: 80px;
}
.sc-ca3-row.hidden { display: none; }
.sc-ca3-cell {
  padding: 12px 14px; border-right: 1px solid var(--rule); font-size: var(--text-xs-size);
  color: var(--ink-2); font-weight: var(--weight-light); line-height: 1.6; overflow: hidden;
}
.sc-ca3-cell:last-child { border-right: none; }
.sc-ca3-cell-label { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 6px; }
.sc-ca3-reads-pill {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 4px 8px; border: 1px solid var(--rule); text-align: center; cursor: default;
}
.sc-ca3-reads-avoid   { background: #fde8e8; color: #a02020; border-color: #e8a0a0; }
.sc-ca3-reads-partial { background: var(--amber-bg); color: var(--amber); border-color: #e0c080; }
.sc-ca3-reads-safe    { background: var(--green-bg); color: var(--green); border-color: #80c898; }
.sc-ca3-reads-unclear { background: var(--bg); color: var(--ink-3); }
.sc-ca3-th-dropdown {}
.sc-ca3-col-mode-wrap { display: flex; align-items: center; gap: 8px; position: relative; }
.sc-ca3-col-mode-label { flex: 1; }
.sc-ca3-col-toggle-btn {
  background: none; border: 1px solid rgba(255,255,255,0.3); color: white;
  cursor: pointer; font-size: var(--text-xs-size); padding: 2px 6px; flex-shrink: 0;
  transition: background 0.13s;
}
.sc-ca3-col-toggle-btn:hover { background: rgba(255,255,255,0.15); }
.sc-ca3-col-dropdown {
  display: none; position: absolute; top: 100%; right: 0; z-index: 100;
  background: var(--paper); border: 1px solid var(--rule);
  box-shadow: 0 6px 24px rgba(0,0,0,0.18); min-width: 200px; flex-direction: column;
}
.sc-ca3-col-dropdown.open { display: flex; }
.sc-ca3-col-opt {
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 10px 14px; text-align: left; border: none; background: none;
  color: var(--ink-2); cursor: pointer; border-bottom: 1px solid var(--rule); transition: background 0.12s;
}
.sc-ca3-col-opt:last-child { border-bottom: none; }
.sc-ca3-col-opt:hover { background: var(--accent-light); color: var(--accent); }
.sc-ca3-col-opt.active { color: var(--accent); background: var(--accent-light); font-weight: var(--weight-medium); }
.sc-ca3-proposed-claim {
  font-family: var(--mono); font-size: var(--text-xs-size); line-height: 1.7; color: #d4d0f0;
  background: #1e1a3a; border-left: 4px solid #5b4fc7;
  padding: 14px 16px; margin-bottom: 14px; white-space: pre-wrap; letter-spacing: 0.01em;
  border-radius: 2px;
}
.sc-ca3-rationale {
  font-size: var(--text-sm-size); color: var(--ink-2); font-weight: var(--weight-light); line-height: 1.65;
}
.sc-cc-header {
  padding: 20px 28px 14px; border-bottom: 1px solid var(--rule); flex-shrink: 0;
}
.sc-cc-title { font-family: var(--serif); font-size: var(--text-lg-size); font-weight: var(--weight-medium); color: var(--ink); margin-bottom: 4px; }
.sc-cc-sub { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-3); letter-spacing: 0.02em; }
.sc-cc-cards {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
  padding: 14px 28px; flex-shrink: 0; border-bottom: 1px solid var(--rule);
}
.sc-cc-patent-card {
  border: 1px solid var(--rule); padding: 12px 16px; background: var(--bg);
  display: flex; flex-direction: column; gap: 3px;
}
.sc-cc-card-label {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-3); margin-bottom: 4px;
}
.sc-cc-card-num { font-family: var(--mono); font-size: var(--text-sm-size); font-weight: var(--weight-bold); color: var(--accent); }
.sc-cc-card-title { font-size: var(--text-sm-size); color: var(--ink-2); font-weight: var(--weight-light); font-style: italic; line-height: 1.4; margin-top: 2px; }
.sc-cc-card-meta { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-3); margin-top: 4px; }
.sc-cc-instruction {
  margin: 0 28px 0; padding: 12px 16px; border: 1px solid var(--rule);
  font-size: var(--text-sm-size); color: var(--ink-3); font-weight: var(--weight-light); line-height: 1.6;
  background: var(--bg); flex-shrink: 0;
}
.sc-cc-claims-wrap {
  display: grid; grid-template-columns: 1fr 1fr; flex: 1; min-height: 0;
  border-top: 1px solid var(--rule); margin-top: 14px;
}
.sc-cc-col { display: flex; flex-direction: column; min-height: 0; border-right: 1px solid var(--rule); }
.sc-cc-col:last-child { border-right: none; }
.sc-cc-col-header {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink-3); padding: 10px 20px; border-bottom: 1px solid var(--rule);
  background: var(--bg); flex-shrink: 0;
}
.sc-cc-claims-scroll { flex: 1; overflow-y: auto; padding: 0 20px 20px; }
.sc-cc-claim-item { border-bottom: 1px solid var(--rule); padding: 14px 0; }
.sc-cc-claim-item:last-child { border-bottom: none; }
.sc-cc-claim-num {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-3); margin-bottom: 6px; margin-top: 2px;
}
.sc-cc-claim-text { font-size: var(--text-sm-size); color: var(--ink-2); font-weight: var(--weight-light); line-height: 1.65; }

/* Analysis buttons */
.sc-analysis-btn {
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.1em; text-transform: uppercase;
  padding: 9px 18px; border: none; cursor: pointer; transition: all 0.13s;
}
.sc-licensing-btn { background: var(--accent); color: white; }
.sc-licensing-btn:hover { background: var(--accent-mid); }
.sc-claimaround-btn { background: #6b4f00; color: white; }
.sc-claimaround-btn:hover { background: #8a6500; }
.sc-ca-match-item {
  border: 1px solid var(--rule); border-top: none; padding: 14px 18px;
  display: flex; align-items: flex-start; justify-content: space-between; gap: 16px;
  background: var(--paper); transition: background 0.13s;
}
.sc-ca-match-item:first-child { border-top: 1px solid var(--rule); }
.sc-ca-match-item:hover { background: var(--accent-light); }
.sc-ca-match-left { flex: 1; min-width: 0; }
.sc-ca-match-right { display: flex; flex-direction: column; align-items: flex-end; gap: 8px; flex-shrink: 0; }
.sc-ca-relevance {
  font-family: var(--mono); font-size: var(--text-tiny-size); font-weight: var(--weight-bold); letter-spacing: 0.1em; text-transform: uppercase; color: var(--green);
}
.sc-ca-relevance.medium { color: var(--amber); }
.sc-ca-relevance.low { color: var(--ink-3); }
.sc-open-claim-btn {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 6px 12px; border: 1px solid var(--accent); color: var(--accent);
  background: none; cursor: pointer; white-space: nowrap; transition: all 0.13s;
}
.sc-open-claim-btn:hover { background: var(--accent); color: white; }
.sc-rerun-btn {
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.1em; text-transform: uppercase;
  padding: 9px 22px; background: var(--accent); color: white; border: none; cursor: pointer; transition: background 0.13s;
}
.sc-rerun-btn:hover { background: var(--accent-mid); }
.sc-next-btn {
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.1em; text-transform: uppercase;
  padding: 9px 22px; background: var(--accent); color: white; border: none; cursor: pointer; transition: background 0.13s;
}
.sc-next-btn:hover { background: var(--accent-mid); }

/* ── LICENSING ANALYSIS ─────────────────────────────────────────────────── */
.cm-prior-patent-card {
  border: 1px solid var(--rule); padding: 12px 14px; background: var(--paper);
  display: flex; align-items: flex-start; justify-content: space-between; gap: 14px;
  transition: border-color 0.13s;
}
.cm-prior-patent-card:hover { border-color: var(--accent); }
.cm-prior-patent-info { flex: 1; min-width: 0; }
.cm-prior-patent-num { font-family: var(--mono); font-size: var(--text-base-size); font-weight: var(--weight-bold); color: var(--accent); margin-bottom: 3px; }
.cm-prior-patent-title { font-size: var(--text-xs-size); color: var(--ink-2); font-weight: var(--weight-light); line-height: 1.4; }
.cm-prior-patent-meta { font-family: var(--mono); font-size: var(--text-sm-size); color: var(--ink-3); margin-top: 5px; letter-spacing: 0.04em; }
.cm-prior-patent-match { font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.08em; text-transform: uppercase; padding: 2px 7px; flex-shrink: 0; margin-top: 2px; }
.match-strong  { background: #e8f4ed; color: var(--green); }
.match-partial { background: #faeeda; color: var(--amber); }
.cm-claim-map-btn {
  font-family: var(--mono); font-size: var(--text-sm-size); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 7px 12px; border: 1px solid var(--accent); background: none; color: var(--accent);
  cursor: pointer; transition: all 0.13s; flex-shrink: 0; white-space: nowrap;
}
.cm-claim-map-btn:hover { background: var(--accent); color: white; }
.cm-lic-score-high   { color: var(--green); border-color: var(--green) !important; }
.cm-lic-score-medium { color: var(--amber); border-color: var(--amber) !important; }
.cm-lic-score-low    { color: var(--ink-3); }
.cm-lic-tab {
  flex: 1; padding: 10px 16px; font-family: var(--mono); font-size: var(--text-sm-size); letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--ink-3); border: none; border-bottom: 2px solid transparent;
  background: none; cursor: pointer; transition: all 0.13s; text-align: left;
}
.cm-lic-tab:hover { color: var(--accent); }
.cm-lic-tab.active { color: var(--accent); border-bottom-color: var(--accent); background: var(--accent-light); }

/* ── CLAIM MAP REDESIGN ──────────────────────────────────────────────────── */
.cm-map-mode-licenseout   { --map-accent: var(--green); --map-bg: #e8f4ed; }
.cm-map-mode-designaround { --map-accent: var(--amber); --map-bg: #faeeda; }
.cm-matrix-row.reads-on    { border-left: 3px solid var(--green); }
.cm-matrix-row.does-not    { border-left: 3px solid #c0392b; }
.cm-matrix-row.partial-row { border-left: 3px solid var(--amber); }
.cm-matrix-row.unclear-row { border-left: 3px solid var(--rule); }
.cm-map-stat-cell {
  flex: 1; padding: 8px 16px; border-right: 1px solid var(--rule);
  display: flex; flex-direction: column; gap: 2px;
}
.cm-map-stat-cell:last-child { border-right: none; }
.cm-map-stat-val { font-family: var(--serif); font-size: var(--text-xs-size); font-weight: var(--weight-medium); color: var(--ink); line-height: 1; }
.cm-map-stat-lbl { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); }
.cm-action-step {
  display: flex; gap: 8px; align-items: flex-start; padding: 8px 10px;
  background: var(--paper); border: 1px solid var(--rule);
}
.cm-action-step-num {
  font-family: var(--mono); font-size: var(--text-xs-size); font-weight: var(--weight-bold);
  color: white; background: var(--accent); width: 16px; height: 16px;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0; border-radius: 2px;
  margin-top: 1px;
}
.cm-action-step-num.green { background: var(--green); }
.cm-action-step-num.amber { background: var(--amber); }
.cm-action-step-text { font-size: var(--text-base-size); color: var(--ink-2); font-weight: var(--weight-light); line-height: 1.5; }
.cm-risk-row { display: flex; align-items: center; gap: 8px; }
.cm-risk-label { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-3); width: 60px; flex-shrink: 0; }
.cm-risk-bar-wrap { flex: 1; height: 4px; background: var(--rule); border-radius: 2px; overflow: hidden; }
.cm-risk-bar { height: 4px; border-radius: 2px; transition: width 0.6s ease; }
.cm-risk-pct { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-3); width: 28px; text-align: right; flex-shrink: 0; }
/* Matrix header color modes */
.cm-matrix-header-row.licenseout  { background: var(--green) !important; }
.cm-matrix-header-row.designaround{ background: #6b4f00 !important; }
.cm-matrix-header-row.designaround .cm-matrix-cell.head:last-child { background: #5a4200 !important; }
/* Limit cell widths */
.cm-matrix-cell.limitation { font-size: var(--text-sm-size); }
.cm-matrix-cell.analysis   { font-size: var(--text-sm-size); }
.cm-matrix-cell.action-col { font-size: var(--text-sm-size); color: var(--ink-2); font-weight: var(--weight-light); line-height: 1.5; }
/* New Claim Language column */
.cm-new-claim-cell {
  font-family: var(--mono); font-size: var(--text-sm-size); line-height: 1.65;
  color: var(--ink-2); background: #fdf8f0; border-left: 2px solid var(--amber);
  transition: background 0.4s;
}
.cm-new-claim-cell.populated { background: #fffbf0; }
.cm-new-claim-cell .new-claim-text {
  font-family: var(--mono); font-size: var(--text-sm-size); color: var(--ink); line-height: 1.7;
  white-space: pre-wrap;
}
.cm-new-claim-cell .new-claim-rationale {
  font-size: var(--text-sm-size); color: var(--amber); margin-top: 5px; font-style: italic;
  font-family: var(--sans); font-weight: var(--weight-light);
}
/* Resizable matrix columns */
.cm-col-resize-handle {
  width: 5px; cursor: col-resize; background: transparent; flex-shrink: 0;
  position: relative; user-select: none; z-index: 2;
}
.cm-col-resize-handle:hover, .cm-col-resize-handle.dragging { background: var(--accent); opacity: 0.5; }
#cm-matrix-scroll { overflow-x: auto; }

/* ── NEW ISSUED PRIOR ART MODAL ───────────────────────────────────────────── */
.np-overlay {
  position: fixed; inset: 0; background: rgba(10,8,30,0.6); z-index: 920;
  display: none; align-items: center; justify-content: center; backdrop-filter: blur(3px);
}
.np-overlay.open { display: flex; }
.np-modal {
  background: var(--paper); width: 96vw; max-width: 96vw; height: 92vh;
  display: flex; flex-direction: column; overflow: hidden;
  box-shadow: 0 20px 80px rgba(0,0,0,0.28);
  animation: sModalIn 0.22s cubic-bezier(.16,1,.3,1);
}
.np-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 18px 24px 14px; border-bottom: 1px solid var(--rule); flex-shrink: 0; background: var(--bg);
}
.np-eyebrow { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent); margin-bottom: 3px; }
.np-title { font-family: var(--serif); font-size: var(--text-lg-size); font-weight: var(--weight-medium); color: var(--ink); }
.np-desc { font-size: var(--text-sm-size); color: var(--ink-2); margin-top: 3px; font-weight: var(--weight-light); }
.np-close { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.1em; text-transform: uppercase; padding: 6px 12px; border: 1px solid var(--rule); background: none; color: var(--ink-3); cursor: pointer; transition: all 0.13s; }
.np-close:hover { border-color: var(--accent); color: var(--accent); }
.np-filter-bar {
  display: flex; align-items: center; gap: 10px; padding: 10px 24px;
  border-bottom: 1px solid var(--rule); background: var(--bg); flex-shrink: 0; flex-wrap: wrap;
}
.np-filter-label { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-3); flex-shrink: 0; }
.np-filter-select, .np-filter-input, .np-filter-date {
  font-family: var(--mono); font-size: var(--text-xs-size); padding: 5px 8px;
  border: 1px solid var(--rule); background: var(--paper); color: var(--ink-2);
  outline: none; transition: border-color 0.13s;
}
.np-filter-select:focus, .np-filter-input:focus, .np-filter-date:focus { border-color: var(--accent); }
.np-filter-select { min-width: 140px; cursor: pointer; }
.np-filter-input { min-width: 180px; }
.np-filter-date { width: 130px; }
.np-reset-btn { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.1em; text-transform: uppercase; padding: 5px 10px; border: 1px solid var(--rule); background: none; color: var(--ink-3); cursor: pointer; transition: all 0.13s; }
.np-reset-btn:hover { border-color: var(--accent); color: var(--accent); }
.np-count-label { font-family: var(--mono); font-size: var(--text-tiny-size); color: var(--ink-3); margin-left: auto; letter-spacing: 0.06em; }
.np-invalidity-btn {
  font-family: var(--mono); font-size: var(--text-xs-size); font-weight: var(--weight-bold); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 8px 16px; border: none; background: #8f1f1f; color: #fff; cursor: pointer;
  transition: all 0.13s;
}
.np-invalidity-btn:hover { background: #8a1818; }
.np-invalidity-btn:disabled { opacity: 0.4; cursor: default; }
/* Move to status dropdown */
.np-move-status-wrap { position: relative; display: inline-block; }
.np-move-status-btn {
  font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 3px 8px; border: 1px solid var(--rule); background: var(--paper); color: var(--ink-3);
  cursor: pointer; transition: all 0.12s;
}
.np-move-status-btn:hover { border-color: var(--accent); color: var(--accent); }
.np-move-status-menu {
  display: none; position: absolute; top: 100%; left: 0; z-index: 200;
  background: #fff; border: 1px solid var(--rule); box-shadow: 0 4px 12px rgba(0,0,0,.12);
  min-width: 120px; margin-top: 2px;
}
.np-move-status-menu.open { display: block; }
.np-move-status-opt {
  padding: 6px 12px; font-family: var(--mono); font-size: var(--text-xs-size); cursor: pointer;
  border-bottom: 1px solid var(--rule); transition: background 0.1s;
}
.np-move-status-opt:hover { background: #f0f4f8; }
.np-move-status-opt:last-child { border-bottom: none; }
.np-body { flex: 1; overflow-y: auto; display: flex; flex-direction: column; }
.np-table { width: 100%; border-collapse: collapse; }
.np-table thead th {
  font-family: var(--mono); font-size: var(--text-sm-size); letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink); padding: 11px 12px; text-align: left; border-bottom: 2px solid var(--rule);
  background: var(--bg); position: sticky; top: 0; white-space: nowrap; font-weight: var(--weight-bold);
}
.np-table tbody tr { border-bottom: 1px solid var(--rule); cursor: pointer; transition: background 0.1s; }
.np-table tbody tr:hover { background: var(--accent-light); }
.np-table tbody tr.np-selected { background: #e8f0ff; }
.np-table tbody tr.np-selected:hover { background: #dce8fa; }
.np-table tbody td { padding: 11px 12px; font-family: var(--sans); font-size: var(--text-base-size); font-weight: var(--weight-normal); color: var(--ink); vertical-align: middle; }
.np-td-patent { font-family: var(--sans); font-size: var(--text-base-size); font-weight: var(--weight-normal); color: var(--accent); white-space: nowrap; }
.np-td-title { font-family: var(--sans); font-size: var(--text-base-size); font-weight: var(--weight-normal); max-width: 420px; line-height: 1.45; color: var(--ink); }
.np-td-assignee { font-family: var(--sans); font-size: var(--text-base-size); font-weight: var(--weight-normal); color: var(--ink); max-width: 200px; word-wrap: break-word; }
.np-td-date { font-family: var(--sans); font-size: var(--text-base-size); font-weight: var(--weight-normal); color: var(--ink); white-space: nowrap; }
.np-td-inventors { font-family: var(--sans); font-size: var(--text-base-size); font-weight: var(--weight-normal); color: var(--ink); max-width: 240px; line-height: 1.35; }
.np-td-cat { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-2); }
.np-td-subcat { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink-3); }
.np-relevance { display: flex; align-items: center; gap: 6px; }
.np-rel-bar-wrap { width: 52px; height: 6px; background: var(--rule); border-radius: 2px; overflow: hidden; flex-shrink: 0; }
.np-rel-bar { height: 6px; border-radius: 2px; }
.np-rel-val { font-family: var(--mono); font-size: var(--text-base-size); color: var(--ink); flex-shrink: 0; font-weight: var(--weight-bold); }
.np-entry-badge { font-family: var(--mono); font-size: var(--text-tiny-size); letter-spacing: 0.06em; text-transform: uppercase; padding: 2px 6px; border-radius: 1px; display: inline-block; white-space: nowrap; }
.np-entry-core     { background: var(--accent-light); color: var(--accent); }
.np-entry-adjacent { background: #faeeda; color: var(--amber); }
.np-entry-new      { background: #fde8e8; color: #a02020; }
.np-td-invalidity { text-align: right; min-width: 132px; }
.np-invalidity-link {
  font-family: var(--mono); font-size: var(--text-xs-size); font-weight: var(--weight-bold); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 7px 10px; border: 1px solid #8f1f1f; background: #fff; color: #8f1f1f;
  cursor: pointer; transition: all 0.12s;
}
.np-invalidity-link:hover { background: #8f1f1f; color: #fff; }
.np-pgr-link { font-family: var(--mono); font-size: var(--text-xs-size); color: #fff; background: var(--accent); cursor: pointer; transition: all 0.12s; padding: 5px 12px; border-radius: 4px; border: none; display: inline-block; margin-top: 6px; font-weight: var(--weight-bold); letter-spacing: 0.08em; text-transform: uppercase; }
.np-pgr-link:hover { background: #12263A; }
body:not(.pm-admin) .np-pgr-link { display: none !important; }
.np-loading { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px; flex: 1; padding: 48px; }
.np-td-cb { width: 32px; text-align: center; }
.np-td-cb input[type="checkbox"] { cursor: pointer; width: 15px; height: 15px; }
.np-submenu-overlay {
  display: none;
}
.np-submenu-overlay.open { display: none; }
.np-submenu-modal {
  width: 100%; max-height: min(72vh, 620px); background: var(--paper);
  border: 1px solid var(--rule); box-shadow: 0 10px 28px rgba(0,0,0,0.14);
  display: flex; flex-direction: column; overflow: hidden;
}
.np-submenu-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 16px 20px 12px; border-bottom: 1px solid var(--rule); background: var(--bg);
}
.np-submenu-eyebrow { font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); margin-bottom: 3px; }
.np-submenu-title { font-family: var(--serif); font-size: var(--text-lg-size); font-weight: var(--weight-bold); color: var(--ink); }
.np-submenu-focus { font-family: var(--mono); font-size: var(--text-sm-size); color: var(--ink); margin-top: 4px; }
.np-submenu-toolbar {
  display: flex; align-items: center; gap: 12px; padding: 10px 20px;
  border-bottom: 1px solid var(--rule); background: #f6f8fb; flex-wrap: wrap;
}
.np-submenu-select-all { font-family: var(--mono); font-size: var(--text-sm-size); color: var(--ink); display: flex; align-items: center; gap: 6px; }
.np-submenu-clear-btn {
  font-family: var(--mono); font-size: var(--text-xs-size); letter-spacing: 0.06em; text-transform: uppercase;
  border: 1px solid var(--rule); background: #fff; color: var(--ink); padding: 6px 10px; cursor: pointer;
}
.np-submenu-clear-btn:hover { border-color: var(--accent); color: var(--accent); }
.np-submenu-selected { font-family: var(--mono); font-size: var(--text-sm-size); color: var(--ink); }
.np-submenu-cost { font-family: var(--mono); font-size: var(--text-sm-size); color: #8f1f1f; font-weight: var(--weight-bold); }
.np-submenu-kpr-btn {
  margin-left: auto;
  font-family: var(--mono); font-size: var(--text-xs-size); font-weight: var(--weight-bold); letter-spacing: 0.08em; text-transform: uppercase;
  border: 1px solid var(--accent); background: var(--accent); color: #fff; padding: 8px 12px; cursor: pointer;
}
.np-submenu-kpr-btn:hover { background: #12263A; border-color: #12263A; }
.np-submenu-list {
  padding: 10px 20px 14px; overflow: auto; display: flex; flex-direction: column; gap: 10px; background: #fff; max-height: min(48vh, 420px);
}
.np-submenu-item {
  display: grid; grid-template-columns: 24px 1fr auto; gap: 10px; align-items: flex-start;
  border: 1px solid var(--rule); padding: 10px 12px; background: #fff;
}
.np-submenu-item.selected { border-color: #8f1f1f; background: #fff8f8; }
.np-submenu-item input[type="checkbox"] { margin-top: 2px; width: 15px; height: 15px; cursor: pointer; }
.np-submenu-patent { font-family: var(--mono); font-size: var(--text-sm-size); color: var(--accent); font-weight: var(--weight-bold); }
.np-submenu-titleline { font-size: var(--text-base-size); color: var(--ink); font-weight: var(--weight-bold); line-height: 1.35; margin-top: 2px; }
.np-submenu-meta { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--ink); margin-top: 5px; line-height: 1.4; }
.np-submenu-inventors { font-size: var(--text-sm-size); color: var(--ink); margin-top: 4px; line-height: 1.35; }
.np-submenu-score { font-family: var(--mono); font-size: var(--text-sm-size); color: var(--ink); font-weight: var(--weight-bold); white-space: nowrap; margin-top: 1px; }
.np-submenu-empty {
  border: 1px dashed var(--rule); background: var(--bg); color: var(--ink-2);
  font-family: var(--mono); font-size: var(--text-sm-size); letter-spacing: 0.04em; padding: 16px; text-align: center;
}
.np-submenu-inline-row { cursor: default !important; }
.np-submenu-inline-row:hover { background: transparent !important; }
.np-submenu-inline-cell {
  padding: 0 12px 14px !important;
  background: #f6f8fb;
  border-bottom: 1px solid var(--rule);
}

/* TOOLTIP */
.chart-tooltip {
  position: fixed; z-index: 999; background: var(--paper); border: 1px solid var(--rule);
  padding: 10px 14px; max-width: 220px; font-size: var(--text-sm-size); line-height: 1.55;
  pointer-events: none; display: none; box-shadow: 0 2px 16px rgba(0,0,0,0.08);
}
.tt-name { font-family: var(--mono); font-size: var(--text-xs-size); color: var(--accent); margin-bottom: 4px; font-weight: var(--weight-medium); }
.tt-body { font-size: var(--text-sm-size); color: var(--ink-2); }




/* ─── Share gate overlay ─────────────────────────────────────── */
#pm-share-gate {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(8, 16, 36, 0.97);
  display: flex; align-items: center; justify-content: center;
}
.pm-share-gate-inner {
  background: #fff; border-radius: 12px; padding: 40px 36px;
  max-width: 380px; width: 100%; box-shadow: 0 8px 40px rgba(0,0,0,.32);
  text-align: center;
}
.pm-share-gate-logo { font-family: var(--mono); font-size: 13px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent, #12094c); margin-bottom: 14px; }
.pm-share-gate-title { font-family: var(--sans); font-size: 18px; font-weight: 500; color: #12094c; margin-bottom: 6px; }
.pm-share-gate-subtitle { font-family: var(--sans); font-size: 13px; color: #777; margin-bottom: 22px; }
.pm-share-gate-input {
  width: 100%; padding: 10px 14px; border: 1.5px solid #d0d5e8; border-radius: 6px;
  font-size: 15px; font-family: var(--sans); outline: none; box-sizing: border-box; margin-bottom: 12px;
}
.pm-share-gate-input:focus { border-color: var(--accent); }
.pm-share-gate-btn {
  width: 100%; padding: 11px; background: var(--accent); color: #fff;
  border: none; border-radius: 6px; font-size: 15px; font-family: var(--sans);
  font-weight: 500; cursor: pointer; transition: background 0.15s;
}
.pm-share-gate-btn:hover:not(:disabled) { background: var(--accent-mid, #2a1a8a); }
.pm-share-gate-btn:disabled { opacity: 0.6; cursor: default; }
.pm-share-gate-error { color: #c0392b; font-size: 13px; margin-top: 10px; font-family: var(--sans); }

/* ─── Viewer mode — hide AI + admin elements ─────────────────── */
body.pm-viewer-mode #cmd-chat-btn,
body.pm-viewer-mode #chat-panel,
body.pm-viewer-mode .intake-btn,
body.pm-viewer-mode #command-intake-btn,
body.pm-viewer-mode .auth-topbar-actions,
body.pm-viewer-mode #auth-manage-btn,
body.pm-viewer-mode #auth-logout-btn,
body.pm-viewer-mode #auth-user-chip,
body.pm-viewer-mode #auth-chpw-btn,
body.pm-viewer-mode .ws-map-run-whitespace,
body.pm-viewer-mode #pgr-run-btn,
body.pm-viewer-mode .competitor-intake-actions,
body.pm-viewer-mode #command-export-view-btn { display: none !important; }
body.pm-viewer-mode #pm-share-logout-btn { display: inline-block !important; }

/* ─── Share management modal ─────────────────────────────────── */
#pm-share-modal {
  position: fixed; inset: 0; z-index: 9000;
  background: rgba(0,0,0,.45);
  display: none; align-items: center; justify-content: center;
}
#pm-share-modal.open { display: flex; }
.pm-share-modal-inner {
  background: #fff; border-radius: 10px; padding: 28px 26px;
  max-width: 520px; width: 100%; max-height: 80vh; overflow-y: auto;
  box-shadow: 0 8px 40px rgba(0,0,0,.2);
}
.pm-share-link-row {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 0; border-bottom: 1px solid #eef0f5;
}
.pm-share-revoke-btn {
  flex-shrink: 0; padding: 4px 10px; background: #c0392b; color: #fff;
  border: none; border-radius: 4px; cursor: pointer; font-size: 11px;
  font-family: var(--sans);
}
.pm-share-revoke-btn:hover { background: #a33; }

/* ─── Share gate overlay ─────────────────────────────────────── */
#pm-share-gate {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(8, 16, 36, 0.97);
  display: flex; align-items: center; justify-content: center;
}
.pm-share-gate-inner {
  background: #fff; border-radius: 12px; padding: 40px 36px;
  max-width: 380px; width: 100%; box-shadow: 0 8px 40px rgba(0,0,0,.32);
  text-align: center;
}
.pm-share-gate-logo { font-family: var(--mono); font-size: 13px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent, #12094c); margin-bottom: 14px; }
.pm-share-gate-title { font-family: var(--sans); font-size: 18px; font-weight: 500; color: #12094c; margin-bottom: 6px; }
.pm-share-gate-subtitle { font-family: var(--sans); font-size: 13px; color: #777; margin-bottom: 22px; }
.pm-share-gate-input {
  width: 100%; padding: 10px 14px; border: 1.5px solid #d0d5e8; border-radius: 6px;
  font-size: 15px; font-family: var(--sans); outline: none; box-sizing: border-box; margin-bottom: 12px;
}
.pm-share-gate-input:focus { border-color: var(--accent); }
.pm-share-gate-btn {
  width: 100%; padding: 11px; background: var(--accent); color: #fff;
  border: none; border-radius: 6px; font-size: 15px; font-family: var(--sans);
  font-weight: 500; cursor: pointer; transition: background 0.15s;
}
.pm-share-gate-btn:hover:not(:disabled) { background: var(--accent-mid, #2a1a8a); }
.pm-share-gate-btn:disabled { opacity: 0.6; cursor: default; }
.pm-share-gate-error { color: #c0392b; font-size: 13px; margin-top: 10px; font-family: var(--sans); }

/* ─── Viewer mode — hide AI + admin elements ─────────────────── */
body.pm-viewer-mode #cmd-chat-btn,
body.pm-viewer-mode #chat-panel,
body.pm-viewer-mode .intake-btn,
body.pm-viewer-mode #command-intake-btn,
body.pm-viewer-mode .auth-topbar-actions,
body.pm-viewer-mode #auth-manage-btn,
body.pm-viewer-mode #auth-logout-btn,
body.pm-viewer-mode #auth-user-chip,
body.pm-viewer-mode #auth-chpw-btn,
body.pm-viewer-mode .ws-map-run-whitespace,
body.pm-viewer-mode #pgr-run-btn,
body.pm-viewer-mode .competitor-intake-actions,
body.pm-viewer-mode #command-export-view-btn { display: none !important; }
body.pm-viewer-mode #pm-share-logout-btn { display: inline-block !important; }

/* ─── Share management modal ─────────────────────────────────── */
#pm-share-modal {
  position: fixed; inset: 0; z-index: 9000;
  background: rgba(0,0,0,.45);
  display: none; align-items: center; justify-content: center;
}
#pm-share-modal.open { display: flex; }
.pm-share-modal-inner {
  background: #fff; border-radius: 10px; padding: 28px 26px;
  max-width: 520px; width: 100%; max-height: 80vh; overflow-y: auto;
  box-shadow: 0 8px 40px rgba(0,0,0,.2);
}
.pm-share-link-row {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 0; border-bottom: 1px solid #eef0f5;
}
.pm-share-revoke-btn {
  flex-shrink: 0; padding: 4px 10px; background: #c0392b; color: #fff;
  border: none; border-radius: 4px; cursor: pointer; font-size: 11px;
  font-family: var(--sans);
}
.pm-share-revoke-btn:hover { background: #a33; }
/* Feature Map */
.stats-row,
.command-panel,
#view-controls-section,
.view-toggle,
.right-panel,
.bottom-panel,
.task-dropdown-wrap,
#vt-portfolio,
#vt-competitor,
#vt-vendor,
#vt-feature-map,
.pd-assign,
#pd-coverage-btn,
#pd-invalidity-search {
  display: none !important;
}

body.pm-feature-map-active {
  display: block;
  overflow-x: hidden;
}

body.pm-feature-map-active .main {
  width: 100vw;
  max-width: 100vw;
  margin-left: 0 !important;
  overflow-x: hidden;
}

body.pm-feature-map-active .topbar {
  padding-left: max(32px, calc((100vw - 1600px) / 2));
  padding-right: max(32px, calc((100vw - 1600px) / 2));
}

body.pm-feature-map-active .content {
  width: 1600px !important;
  min-width: 1600px !important;
  max-width: 1600px !important;
  margin-left: 0;
  margin-right: 0;
  padding-left: 0;
  padding-right: 0;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  flex: 0 0 1600px !important;
  flex-shrink: 0 !important;
}

body.pm-feature-map-active .page-header,
body.pm-feature-map-active .main-grid,
body.pm-feature-map-active .data-syncing-banner {
  width: 100%;
  max-width: none;
  margin-left: 0;
  margin-right: 0;
}

body.pm-feature-map-active .page-header {
  margin-bottom: 0;
}

body.pm-feature-map-active .main-grid {
  grid-template-columns: minmax(0, 1fr) !important;
}

body.pm-feature-map-active .chart-panel {
  width: 100% !important;
  max-width: 1600px !important;
  margin-left: auto;
  margin-right: auto;
}

#view-feature-map {
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  align-self: stretch;
  overflow: hidden;
  min-height: calc(100vh - 148px);
}
.feature-map-brief {
  box-sizing: border-box;
  width: 100%;
  min-width: 0;
  padding: 0 14px 0;
  background: #f5f1e9;
  color: #2b2b33;
  border-top: 1px solid var(--rule);
}
.feature-map-crumb {
  display: none;
  margin-bottom: 10px;
  color: #6b6b76;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.feature-map-crumb b {
  color: #2b2b33;
  font-weight: 700;
}
.feature-map-topgrid {
  display: none;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  overflow: hidden;
  border: 1px solid #d9d3c7;
  border-radius: 8px;
  background: #fff;
}
.feature-map-cell {
  min-width: 0;
  padding: 13px 15px;
  border-right: 1px solid #d9d3c7;
}
.feature-map-cell:last-child {
  border-right: 0;
}
.feature-map-cell-label {
  margin-bottom: 5px;
  color: #6b6b76;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .09em;
  text-transform: uppercase;
}
.feature-map-cell-value {
  overflow: hidden;
  color: #2b2b33;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.25;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.feature-map-insight-band {
  width: 100%;
  box-sizing: border-box;
  overflow: hidden;
  margin: 0 0 6px;
  border-radius: 0 0 8px 8px;
  background: #1c1b3e;
  color: #ece8df;
}
.feature-map-insight-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 18px;
  background: #15142f;
  color: #c8c4e4;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .13em;
  text-transform: uppercase;
}
.feature-map-insight-cols {
  display: none;
  grid-template-columns: 1.05fr 1.15fr 1fr;
}
.feature-map-insight-col {
  min-width: 0;
  padding: 16px 22px 18px;
  border-right: 1px solid rgba(255,255,255,.09);
}
.feature-map-insight-col:last-child {
  border-right: 0;
}
.feature-map-insight-eyebrow {
  margin-bottom: 7px;
  color: #9995c0;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .13em;
  text-transform: uppercase;
}
.feature-map-insight-col h4 {
  margin: 0 0 10px;
  color: #fffaf2;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(21px, 1.7vw, 28px);
  font-weight: 500;
  line-height: 1.12;
}
.feature-map-insight-col ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
.feature-map-insight-col li {
  position: relative;
  margin-bottom: 8px;
  padding-left: 16px;
  color: #eeeafd;
  font-size: clamp(13px, .95vw, 16px);
  line-height: 1.38;
}
.feature-map-insight-col li::before {
  content: "";
  position: absolute;
  top: .58em;
  left: 0;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #8b6085;
}
.feature-map-plothead {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-top: 0;
  padding-bottom: 4px;
  border-bottom: 2px solid #2b2b33;
}
.feature-map-plot-title {
  min-width: 0;
  display: flex;
  align-items: baseline;
  gap: 14px;
}
.feature-map-plothead h3 {
  margin: 0;
  color: #111;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 20px;
  font-weight: 700;
}
.feature-map-plothead span {
  color: #6b6b76;
  font-size: 12px;
}
.feature-map-assignee-filter {
  position: relative;
  flex: 0 0 auto;
}
.feature-map-assignee-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 34px;
  max-width: 260px;
  border: 1px solid #d8d0c2;
  border-radius: 7px;
  background: #fffdf9;
  color: #2b2b33;
  cursor: pointer;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 0 9px 0 11px;
}
.feature-map-assignee-btn:hover,
.feature-map-assignee-filter.open .feature-map-assignee-btn {
  border-color: #8b6085;
  color: #5f3f62;
  background: #fff;
}
.feature-map-assignee-btn-label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.feature-map-assignee-btn-count {
  min-width: 28px;
  border-radius: 999px;
  background: #1c1b3e;
  color: #fffaf2;
  font-size: 10px;
  line-height: 18px;
  text-align: center;
  padding: 0 7px;
}
.feature-map-assignee-menu {
  position: absolute;
  z-index: 12;
  top: calc(100% + 7px);
  right: 0;
  display: none;
  width: min(380px, 86vw);
  overflow: hidden;
  border: 1px solid #d8d0c2;
  border-radius: 9px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(20,20,46,.18);
}
.feature-map-assignee-filter.open .feature-map-assignee-menu {
  display: block;
}
.feature-map-assignee-menu-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 13px 10px;
  border-bottom: 1px solid #ece7dc;
}
.feature-map-assignee-menu-head strong {
  color: #2b2b33;
  font-size: 13px;
}
.feature-map-assignee-menu-head span {
  color: #6b6b76;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .07em;
  text-transform: uppercase;
}
.feature-map-assignee-actions {
  display: flex;
  gap: 7px;
  padding: 9px 13px;
  border-bottom: 1px solid #ece7dc;
  background: #faf8f3;
}
.feature-map-assignee-actions button {
  height: 26px;
  border: 1px solid #d8d0c2;
  border-radius: 6px;
  background: #fff;
  color: #4b4652;
  cursor: pointer;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 0 9px;
}
.feature-map-assignee-actions button:hover {
  border-color: #8b6085;
  color: #5f3f62;
}
.feature-map-assignee-list {
  max-height: 300px;
  overflow: auto;
  padding: 5px;
}
.feature-map-assignee-option {
  width: 100%;
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr) minmax(82px, .48fr) auto;
  align-items: center;
  gap: 8px;
  min-height: 36px;
  border: 0;
  border-radius: 7px;
  background: transparent;
  color: #2b2b33;
  cursor: pointer;
  text-align: left;
  padding: 6px 8px;
}
.feature-map-assignee-option:hover {
  background: #f4f0e8;
}
.feature-map-assignee-option.is-hidden {
  color: #98929b;
}
.feature-map-assignee-check {
  width: 18px;
  height: 18px;
  border: 1px solid #cfc6b7;
  border-radius: 5px;
  color: #fff;
  background: #1c1b3e;
  font-size: 11px;
  line-height: 17px;
  text-align: center;
}
.feature-map-assignee-option.is-hidden .feature-map-assignee-check {
  background: #fff;
}
.feature-map-assignee-name,
.feature-map-assignee-account {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.feature-map-assignee-name {
  font-size: 12px;
  font-weight: 600;
}
.feature-map-assignee-account {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #6b6b76;
  font-size: 10px;
}
.feature-map-assignee-account i {
  width: 8px;
  height: 8px;
  flex: 0 0 auto;
  border-radius: 50%;
}
.feature-map-assignee-total {
  color: #6b6b76;
  font-family: var(--mono);
  font-size: 10px;
}
.feature-map-legend {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px 14px;
  padding: 6px 0 6px;
}
.feature-map-legend-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #2b2b33;
  font-size: 12px;
}
.feature-map-legend-swatch {
  width: 13px;
  height: 13px;
  flex: 0 0 auto;
  border-radius: 50%;
}
.feature-map-legend-meta {
  margin-left: auto;
  color: #6b6b76;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .03em;
  text-transform: lowercase;
}
.feature-map-tools {
  display: none !important;
  grid-template-columns: minmax(0, 1fr);
  gap: 7px;
  padding: 8px 0 9px;
  border-top: 1px solid #ded6c8;
}
.feature-map-tool-head {
  display: flex;
  align-items: center;
  gap: 10px;
}
.feature-map-tool-head span {
  color: #1c1b3e;
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.feature-map-tool-head input {
  min-width: 180px;
  flex: 1;
  height: 30px;
  border: 1px solid #d8d0c2;
  border-radius: 7px;
  background: #fffdf9;
  color: #2b2b33;
  font-family: var(--mono);
  font-size: 10px;
  padding: 0 10px;
}
.feature-map-tool-toggles,
.feature-map-visual-row,
.feature-map-lab-results {
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
  min-width: 0;
}
.feature-map-tool-toggles button,
.feature-map-visual-row button {
  border: 1px solid #d8d0c2;
  border-radius: 7px;
  background: #fffdf9;
  color: #4b4652;
  cursor: pointer;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .08em;
  text-transform: uppercase;
  height: 28px;
  padding: 0 9px;
}
.feature-map-tool-toggles button.active,
.feature-map-visual-row button:hover {
  border-color: #1c1b3e;
  background: #1c1b3e;
  color: #fffaf2;
}
.feature-map-visual-row label {
  color: #6b6b76;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.feature-map-visual-row select {
  height: 28px;
  border: 1px solid #d8d0c2;
  border-radius: 7px;
  background: #fffdf9;
  color: #2b2b33;
  font-family: var(--mono);
  font-size: 10px;
  padding: 0 8px;
}
.feature-map-lab-card {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  max-width: 100%;
  border: 1px solid #ddd5c7;
  border-radius: 999px;
  background: #fffdf9;
  color: #3e3a45;
  cursor: pointer;
  font-size: 11px;
  min-height: 27px;
  padding: 0 10px;
}
.feature-map-lab-card:hover {
  border-color: #8b6085;
  color: #5f3f62;
}
.feature-map-lab-card strong {
  color: #1c1b3e;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.feature-map-lab-card span,
.feature-map-lab-card em {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.feature-map-lab-card em {
  color: #7b7480;
  font-style: normal;
  font-size: 10px;
}
.feature-map-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  box-sizing: border-box;
  width: auto;
  height: calc(100vh - 252px) !important;
  min-height: 720px !important;
  margin: 0 14px 14px;
  overflow: hidden;
  border: 1px solid #d8d0c2;
  border-radius: 10px;
  background: #fffdf9;
}
.feature-map-shell.detail-open {
  grid-template-columns: minmax(0, 1fr) minmax(360px, 440px);
}
.feature-map-main {
  min-width: 0;
  min-height: 0;
  height: 100%;
  display: flex;
  flex-direction: column;
}
.feature-map-toolbar {
  display: none;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-bottom: 1px solid #ece7dc;
  background: #fff;
}
.feature-map-tabs {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.feature-map-tab,
.feature-map-reset {
  border: 1px solid #d8dce8;
  background: #fff;
  color: #2b2b33;
  border-radius: 6px;
  height: 32px;
  padding: 0 11px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .06em;
  text-transform: uppercase;
  cursor: pointer;
}
.feature-map-tab:hover,
.feature-map-reset:hover {
  border-color: #6d4c6d;
  color: #6d4c6d;
}
.feature-map-tab.active {
  background: #1a1a3d;
  border-color: #1a1a3d;
  color: #fbf8f1;
}
.feature-map-canvas-wrap {
  position: relative;
  width: 100%;
  min-height: 0;
  flex: 1;
  overflow: hidden;
  background-image:
    linear-gradient(rgba(154,148,138,.17) 1px, transparent 1px),
    linear-gradient(90deg, rgba(154,148,138,.17) 1px, transparent 1px);
  background-color: #fffdf9;
  background-size: 25% 25%;
}
#feature-map-canvas {
  width: 100%;
  height: 100%;
  max-width: 100%;
  display: block;
  cursor: grab;
  touch-action: pan-y;
}
#feature-map-canvas.is-panning {
  cursor: grabbing;
}
.feature-map-zoom-controls {
  position: absolute;
  z-index: 4;
  top: 18px;
  left: 18px;
  display: flex;
  gap: 8px;
}
.feature-map-zoom-controls button {
  min-width: 46px;
  height: 46px;
  border: 1px solid #d8d0c2;
  border-radius: 10px;
  background: rgba(255,253,249,.94);
  color: #2b2b33;
  box-shadow: 0 1px 6px rgba(20,20,46,.08);
  cursor: pointer;
  font-family: var(--mono);
  font-size: 24px;
  line-height: 1;
  padding: 0 13px;
}
.feature-map-zoom-controls button:hover {
  border-color: #9a948a;
  background: #fff;
}
.feature-map-axis-y,
.feature-map-axis-x {
  position: absolute;
  z-index: 2;
  color: #9a948a;
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: .12em;
  text-transform: none;
  pointer-events: none;
}
.feature-map-axis-y {
  left: 28px;
  top: 50%;
  transform: translateY(-50%) rotate(-90deg);
  transform-origin: left center;
}
.feature-map-axis-x {
  left: 0;
  right: 0;
  bottom: 31px;
  text-align: center;
}
.feature-map-empty {
  position: absolute;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  color: var(--ink-3);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .06em;
  text-transform: uppercase;
  pointer-events: none;
}
.feature-map-tooltip {
  position: absolute;
  display: none;
  z-index: 3;
  width: 260px;
  padding: 11px 13px;
  border: 1px solid rgba(20,20,46,.16);
  border-radius: 8px;
  background: #1a1a3d;
  color: #ece8df;
  box-shadow: 0 10px 28px rgba(20,20,46,.23);
  pointer-events: none;
}
.feature-map-tooltip strong {
  display: block;
  color: #fbf8f1;
  font-size: 12px;
  line-height: 1.25;
  margin-bottom: 4px;
}
.feature-map-tooltip span {
  color: #c9c3d6;
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.feature-map-detail {
  display: none;
  flex-direction: column;
  border-left: 1px solid #d9d3c7;
  background: #fff;
  padding: 18px 18px 14px;
  min-width: 0;
  min-height: 0;
  overflow: hidden;
}
.feature-map-shell.detail-open .feature-map-detail {
  display: flex;
}
.feature-map-sidebar-patents-section {
  margin-top: 20px;
  min-height: 0;
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
}
.feature-map-sidebar-search {
  display: flex;
  align-items: stretch;
  gap: 6px;
  margin-top: 9px;
}
.feature-map-sidebar-search input {
  min-width: 0;
  flex: 1 1 auto;
  height: 34px;
  border: 1px solid #e2dbcf;
  border-radius: 8px;
  background: #fffdf9;
  color: #252230;
  font-family: var(--sans);
  font-size: 12px;
  outline: none;
  padding: 0 10px;
}
.feature-map-sidebar-search input:focus {
  border-color: #bdb4cb;
  box-shadow: 0 0 0 2px rgba(101,87,210,.10);
}
.feature-map-sidebar-search button {
  flex: 0 0 auto;
  height: 34px;
  border: 1px solid #e2dbcf;
  border-radius: 8px;
  background: #f8f4ec;
  color: #5f5863;
  cursor: pointer;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 0 10px;
}
.feature-map-sidebar-search button:hover {
  border-color: #c8bfb1;
  color: #1c1b3e;
}
.feature-map-sidebar-patents {
  margin-top: 9px;
  min-height: 0;
  max-height: none;
  flex: 1 1 auto;
  overflow: auto;
  border: 1px solid #ece7dc;
  border-radius: 8px;
  background: #fffdf9;
}
.feature-map-sidebar-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--sans);
  font-size: 12px;
}
.feature-map-sidebar-table th {
  position: sticky;
  top: 0;
  z-index: 1;
  padding: 8px 9px;
  background: #f5f1e9;
  border-bottom: 1px solid #e5ded2;
  color: #6d6670;
  font-family: var(--mono);
  font-size: 9px;
  font-weight: 500;
  letter-spacing: .08em;
  text-align: left;
  text-transform: uppercase;
}
.feature-map-sidebar-table td {
  padding: 8px 9px;
  border-bottom: 1px solid #eee8dd;
  color: #2b2b33;
  line-height: 1.35;
  vertical-align: top;
}
.feature-map-sidebar-table tr {
  cursor: pointer;
}
.feature-map-sidebar-table tr:hover td {
  background: #f8f4ec;
}
.feature-map-sidebar-table button {
  display: block;
  width: 100%;
  border: 0;
  background: transparent;
  color: #1c1b3e;
  cursor: pointer;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .02em;
  text-align: left;
}
.feature-map-sidebar-table span {
  display: block;
  max-width: 160px;
  margin-top: 3px;
  color: #776f78;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.feature-map-sidebar-table small {
  display: block;
  max-width: 170px;
  margin-top: 3px;
  color: #4f7f6b;
  font-family: var(--sans);
  font-size: 11px;
  line-height: 1.25;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
body.pm-feature-map-fullscreen .stats-row,
body.pm-feature-map-fullscreen .right-panel,
body.pm-feature-map-fullscreen .bottom-panel,
body.pm-feature-map-fullscreen .page-header {
  display: none !important;
}
body.pm-feature-map-fullscreen .main-grid {
  grid-template-columns: minmax(0, 1fr);
}
body.pm-feature-map-fullscreen .feature-map-shell {
  height: calc(100vh - 245px);
  min-height: 520px;
}
.feature-map-kicker,
.feature-map-section-title {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.feature-map-titlebar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.feature-map-rename-inline {
  display: none;
  border: 1px solid #d8d0c2;
  border-radius: 999px;
  background: #fffdf9;
  color: #6b6072;
  cursor: pointer;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .08em;
  text-transform: uppercase;
  height: 24px;
  padding: 0 9px;
  white-space: nowrap;
}
.feature-map-rename-inline:hover {
  border-color: #1c1b3e;
  color: #1c1b3e;
}
.feature-map-detail h3 {
  margin: 6px 0 14px;
  color: #2b2b33;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 22px;
  line-height: 1.18;
  letter-spacing: 0;
}
.feature-map-preview-badge {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  margin: -7px 0 13px;
  border: 1px solid #d8d0c2;
  border-radius: 999px;
  background: #f8f4ec;
  color: #6b6072;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .08em;
  line-height: 1.2;
  padding: 5px 9px;
  text-transform: uppercase;
}
.feature-map-preview-strip {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 14px;
  margin: 8px 0 9px;
  border: 1px solid #d8d0c2;
  border-radius: 8px;
  background: #fffdf9;
  box-shadow: 0 1px 0 rgba(20,20,46,.04);
  padding: 10px 12px;
}
.feature-map-preview-strip div {
  display: grid;
  gap: 2px;
}
.feature-map-preview-strip span {
  color: #7a746d;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .12em;
  text-transform: uppercase;
  white-space: nowrap;
}
.feature-map-preview-strip strong {
  color: #1c1b3e;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 16px;
  line-height: 1.1;
}
.feature-map-preview-strip p {
  margin: 0;
  color: #5f5965;
  font-size: 12px;
  line-height: 1.35;
}

/* Site experience: topbar changelog, story/brief, notes */
.pm-changelog-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.pm-changelog-btn {
  position: relative;
  width: 30px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--rule, #e0e0e0);
  border-radius: 50%;
  background: #fff;
  color: var(--ink-2, #444);
  cursor: pointer;
  transition: border-color .14s, color .14s, background .14s;
}
.pm-changelog-btn:hover,
.pm-changelog-btn[aria-expanded="true"] {
  border-color: var(--accent, #4f8ef7);
  color: var(--accent, #4f8ef7);
  background: #fffdf9;
}
.pm-changelog-dot {
  position: absolute;
  top: 4px;
  right: 4px;
  width: 7px;
  height: 7px;
  border: 2px solid #fff;
  border-radius: 50%;
  background: #c7567d;
  display: none;
}
.pm-changelog-menu {
  position: absolute;
  top: calc(100% + 9px);
  right: 0;
  z-index: 2100;
  width: min(380px, calc(100vw - 28px));
  max-height: min(620px, calc(100vh - 90px));
  display: none;
  overflow: hidden;
  border: 1px solid #d8d0c2;
  border-radius: 10px;
  background: #fffdf9;
  box-shadow: 0 18px 48px rgba(20, 20, 46, .18);
}
.pm-changelog-menu.open {
  display: block;
}
.pm-changelog-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  padding: 14px 15px 12px;
  border-bottom: 1px solid #ece7dc;
}
.pm-changelog-head strong {
  display: block;
  margin-top: 2px;
  color: #1c1b3e;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 18px;
  line-height: 1.1;
}
.pm-changelog-kicker {
  color: #7a746d;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .14em;
  text-transform: uppercase;
}
#pm-changelog-close {
  width: 26px;
  height: 26px;
  border: 1px solid #d8d0c2;
  border-radius: 50%;
  background: #fff;
  color: #6b6072;
  cursor: pointer;
}
.pm-changelog-tabs {
  display: flex;
  gap: 8px;
  padding: 10px 12px;
  border-bottom: 1px solid #ece7dc;
}
.pm-changelog-tabs button {
  border: 1px solid #d8d0c2;
  border-radius: 6px;
  background: #fff;
  color: #2b2b33;
  cursor: pointer;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .08em;
  padding: 8px 10px;
  text-transform: uppercase;
}
.pm-changelog-tabs button.active {
  border-color: #1c1b3e;
  background: #1c1b3e;
  color: #fbf8f1;
}
.pm-changelog-body {
  max-height: 380px;
  overflow: auto;
  padding: 6px 0;
}
.pm-changelog-empty {
  padding: 18px 14px;
  color: #7a746d;
  font-size: 12px;
  line-height: 1.4;
}
.pm-changelog-version {
  border-top: 1px solid #ece7dc;
  padding: 10px 14px 12px;
  color: #8a837b;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .1em;
  text-transform: uppercase;
}
.pm-change-item {
  display: grid;
  grid-template-columns: 12px minmax(0, 1fr);
  gap: 10px;
  padding: 10px 14px;
}
.pm-change-icon {
  width: 7px;
  height: 7px;
  margin-top: 5px;
  border-radius: 50%;
  background: #3f6f5b;
  box-shadow: 0 0 0 4px rgba(63,111,91,.11);
}
.pm-change-item strong {
  display: block;
  color: #2b2b33;
  font-size: 12px;
  line-height: 1.25;
}
.pm-change-item span {
  display: block;
  margin-top: 3px;
  color: #6b6b76;
  font-size: 11px;
  line-height: 1.4;
}
.feature-map-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-bottom: 16px;
}
.feature-map-stats div {
  border: 1px solid #ece7dc;
  border-radius: 6px;
  padding: 9px 8px;
  background: #fafafa;
}
.feature-map-stats strong {
  display: block;
  font-size: 18px;
  color: #2b2b33;
  line-height: 1;
}
.feature-map-stats span {
  display: block;
  margin-top: 5px;
  color: var(--ink-3);
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.feature-map-health {
  display: block;
  margin-bottom: 14px;
  border: 1px solid #e2dbcf;
  border-radius: 8px;
  background: #fffdf9;
  padding: 12px;
}
.feature-map-health-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  border-bottom: 1px solid #ece7dc;
  padding-bottom: 8px;
  margin-bottom: 10px;
}
.feature-map-health-head span,
.feature-map-health-label {
  color: #7a746d;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.feature-map-health-head strong {
  color: #1c1b3e;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.feature-map-health-signal {
  margin-bottom: 11px;
}
.feature-map-health-signal strong {
  display: block;
  color: #2b2b33;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 18px;
  line-height: 1.15;
}
.feature-map-health-signal span {
  display: block;
  margin-top: 4px;
  color: #6b6b76;
  font-size: 12px;
  line-height: 1.35;
}
.feature-map-health-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.feature-map-health-card {
  border: 1px solid #e2dbcf;
  border-radius: 7px;
  background: #faf7f0;
  padding: 10px 10px 9px;
}
.feature-map-health-card strong {
  display: block;
  color: #1c1b3e;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 22px;
  line-height: 1;
}
.feature-map-health-card span {
  display: block;
  margin-top: 6px;
  color: #6b6b76;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .07em;
  text-transform: uppercase;
}
.feature-map-health-card em {
  display: block;
  margin-top: 5px;
  color: #7a746d;
  font-size: 11px;
  font-style: normal;
  line-height: 1.25;
}
.feature-map-health-split {
  border-top: 1px solid #ece7dc;
  margin-top: 12px;
  padding-top: 11px;
}
.feature-map-health-split-row {
  display: grid;
  grid-template-columns: 10px minmax(0, 1fr) auto;
  align-items: center;
  gap: 7px;
  margin-top: 8px;
  color: #2b2b33;
  font-size: 12px;
}
.feature-map-health-split-row b {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.feature-map-health-split-row em {
  color: #7a746d;
  font-style: normal;
  white-space: nowrap;
}
.feature-map-story {
  display: none;
  border: 1px solid #ded6c8;
  border-radius: 8px;
  background: #f8f4ec;
  padding: 12px;
  margin: 0 0 14px;
}
.feature-map-story.open {
  display: block;
}
.feature-map-story-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 9px;
}
.feature-map-story-title {
  color: #1c1b3e;
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.feature-map-story button {
  border: 1px solid #d8d0c2;
  border-radius: 999px;
  background: #fffdf9;
  color: #4b4652;
  cursor: pointer;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .07em;
  text-transform: uppercase;
  padding: 5px 9px;
}
.feature-map-story button:hover {
  border-color: #1c1b3e;
  color: #1c1b3e;
}
.feature-map-story-list {
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.feature-map-story-step {
  width: 100%;
  text-align: left;
}
.feature-map-story-step strong {
  display: block;
  color: #2b2b33;
  font-size: 12px;
  line-height: 1.25;
}
.feature-map-story-step span {
  display: block;
  margin-top: 3px;
  color: #6b6b76;
  font-size: 11px;
  line-height: 1.35;
  text-transform: none;
  letter-spacing: 0;
}
.feature-map-section {
  border-top: 1px solid #ece7dc;
  padding-top: 13px;
  margin-top: 13px;
}
.feature-map-split-row {
  position: relative;
  display: grid;
  grid-template-columns: 12px minmax(0, 1fr) auto;
  align-items: center;
  gap: 7px;
  padding: 7px 0 9px;
  color: var(--ink);
  font-size: 12px;
}
.feature-map-split-row i {
  position: absolute;
  left: 19px;
  bottom: 2px;
  height: 3px;
  border-radius: 99px;
  background: #6366f1;
}
.feature-map-split-bar {
  display: flex;
  overflow: hidden;
  height: 12px;
  margin: 10px 0 8px;
  border-radius: 999px;
  background: #efeae0;
}
.feature-map-split-segment {
  min-width: 2px;
  height: 100%;
}
.feature-map-split-legend {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 7px 10px;
}
.feature-map-split-legend .feature-map-split-row {
  padding: 1px 0;
}
.feature-map-split-legend .feature-map-split-row i {
  display: none;
}
.feature-map-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #6366f1;
}
.feature-map-dot.c1 { background: #0891b2; }
.feature-map-dot.c2 { background: #16a34a; }
.feature-map-dot.c3 { background: #dc2626; }
.feature-map-dot.c4 { background: #ca8a04; }
.feature-map-timeline {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(18px, 1fr));
  align-items: end;
  gap: 5px;
  min-height: 72px;
  margin-top: 10px;
}
.feature-map-year {
  position: relative;
  display: flex;
  min-width: 0;
  height: 72px;
  flex-direction: column;
  justify-content: flex-end;
  gap: 5px;
  border: 0;
  background: transparent;
  cursor: pointer;
  padding: 0;
}
.feature-map-year-popup {
  position: absolute;
  z-index: 5;
  left: 50%;
  bottom: calc(100% + 9px);
  display: none;
  min-width: 112px;
  transform: translateX(-50%);
  border: 1px solid rgba(20,20,46,.16);
  border-radius: 8px;
  background: #1a1a3d;
  box-shadow: 0 10px 24px rgba(20,20,46,.22);
  color: #fbf8f1;
  pointer-events: none;
  padding: 8px 10px;
  text-align: left;
}
.feature-map-year-popup::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 100%;
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-top-color: #1a1a3d;
}
.feature-map-year:hover .feature-map-year-popup,
.feature-map-year:focus-visible .feature-map-year-popup {
  display: block;
}
.feature-map-year-popup strong {
  display: block;
  font-family: var(--serif);
  font-size: 17px;
  line-height: 1;
}
.feature-map-year-popup em,
.feature-map-year-popup small {
  display: block;
  margin-top: 4px;
  color: #c9c3d6;
  font-family: var(--mono);
  font-size: 9px;
  font-style: normal;
  letter-spacing: .06em;
  text-transform: uppercase;
  white-space: nowrap;
}
.feature-map-year-popup small {
  color: #b68931;
}
.feature-map-year:hover .feature-map-year-bar,
.feature-map-year.is-active .feature-map-year-bar {
  background: #b68931;
}
.feature-map-year.is-active .feature-map-year-label {
  color: #5f3f10;
  font-weight: 700;
}
.feature-map-year-bar {
  min-height: 3px;
  border-radius: 3px 3px 0 0;
  background: #a9adc4;
}
.feature-map-year-label {
  overflow: hidden;
  color: #8b8795;
  font-family: var(--mono);
  font-size: 8px;
  line-height: 1;
  text-align: center;
  text-overflow: clip;
  white-space: nowrap;
}
.feature-map-insights,
.feature-map-examples {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 10px;
}
.feature-map-examples {
  max-height: 300px;
  overflow: auto;
  padding-right: 3px;
}
.feature-map-list-count {
  position: sticky;
  top: 0;
  z-index: 1;
  padding: 4px 0 7px;
  background: #fff;
  color: #6b6b76;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.feature-map-insight,
.feature-map-example {
  width: 100%;
  text-align: left;
  border: 1px solid var(--rule);
  background: #fff;
  border-radius: 6px;
  padding: 10px;
  cursor: pointer;
}
.feature-map-insight:hover,
.feature-map-example:hover {
  border-color: var(--accent);
  background: #fafaff;
}
.feature-map-insight strong,
.feature-map-example strong {
  display: block;
  color: #111827;
  font-size: 12px;
  line-height: 1.25;
}
.feature-map-insight span,
.feature-map-example em {
  display: block;
  margin-top: 4px;
  color: var(--ink-3);
  font-style: normal;
  font-size: 11px;
  line-height: 1.35;
}
.feature-map-example span {
  display: block;
  color: var(--accent);
  font-family: var(--mono);
  font-size: 10px;
  margin-bottom: 4px;
}
.feature-map-muted {
  color: var(--ink-3);
  font-size: 12px;
  padding: 8px 0;
}
@media (max-width: 980px) {
  body.pm-feature-map-active .content {
    width: 1600px;
    min-width: 1600px;
  }
  .feature-map-topgrid,
  .feature-map-insight-cols {
    grid-template-columns: 1fr 1fr;
  }
  .feature-map-insight-col {
    border-bottom: 1px solid rgba(255,255,255,.08);
  }
  .feature-map-shell {
    width: auto;
    height: clamp(420px, 64vh, 640px);
    min-height: 380px;
    margin: 0 14px 18px;
  }
  .feature-map-canvas-wrap {
    min-height: 0;
  }
  .feature-map-shell.detail-open {
    grid-template-columns: minmax(0, 1fr);
    height: auto !important;
  }
  .feature-map-shell.detail-open .feature-map-detail {
    border-left: 0;
    border-top: 1px solid #d9d3c7;
    max-height: 440px;
  }
}
@media (max-width: 720px) {
  body.pm-feature-map-active .content {
    width: 1600px;
    min-width: 1600px;
  }
  #view-feature-map {
    width: 100%;
    max-width: 100%;
  }
  .feature-map-brief {
    padding: 0 12px;
  }
  .feature-map-topgrid,
  .feature-map-insight-cols {
    grid-template-columns: 1fr;
  }
  .feature-map-cell,
  .feature-map-insight-col {
    border-right: 0;
  }
  .feature-map-cell {
    border-bottom: 1px solid #d9d3c7;
  }
  .feature-map-cell:last-child {
    border-bottom: 0;
  }
  .feature-map-plothead {
    align-items: flex-start;
    flex-direction: column;
    gap: 5px;
  }
  .feature-map-shell {
    width: auto;
    height: clamp(360px, 58vh, 520px);
    min-height: 340px;
    margin: 0 8px 14px;
    border-radius: 8px;
  }
  .feature-map-zoom-controls {
    top: 10px;
    left: 10px;
    gap: 6px;
  }
  .feature-map-zoom-controls button {
    width: 38px;
    height: 38px;
    border-radius: 8px;
    font-size: 20px;
  }
}
