/* ============================================================
   DATA ROOM — authored fresh in the mellio visual language.
   White room: pure white ground, structure in ink (hairlines,
   short ink tabs, two written voices), one accent carrying only
   meaning, three button roles. Components lean on mellio-visual.css
   (--mv-* tokens, loaded before this file); this file is layout
   plus the data room's own pieces. Nothing here is inherited from
   the first implementation.
   ============================================================ */

#dataRoom { background: #fff; color: var(--mv-ink); }
#dataRoom.view { padding-top: 64px; }
#dataRoom [hidden] { display: none !important; }
#dataRoom .dr-shell { max-width: none; padding: 0; }
#dataRoom .dr-main { padding: 0; }
#dataRoom .dr-flex { flex: 1; }

/* ---------- the two written voices + ink tabs ---------- */
#dataRoom .dr-cap, #dataRoom .dr-band-head h2 {
  font-family: var(--mv-mono); font-size: 9.5px; font-weight: 500;
  letter-spacing: .15em; text-transform: uppercase; color: var(--mv-ink-40);
  margin: 0;
}
#dataRoom .dr-band-head { display: flex; align-items: baseline; gap: 10px; margin: 0 0 12px; }
#dataRoom .dr-band-head h2::before {
  content: ""; display: inline-block; width: 14px; height: 2px;
  background: var(--mv-ink); margin-right: 9px; vertical-align: 3px;
}
#dataRoom .dr-ann {
  font-family: var(--mv-serif); font-style: italic; font-size: 11.5px;
  color: var(--mv-ink-40); font-weight: 400; text-transform: none; letter-spacing: 0;
}

/* ---------- buttons: exactly three roles ---------- */
#dataRoom .dr-btn {
  display: inline-flex; align-items: center; gap: 7px;
  font: inherit; font-size: 12.5px; font-weight: 500; color: var(--mv-ink);
  background: #fff; border: 1px solid var(--mv-ink-12); border-radius: var(--mv-r-btn);
  padding: 7px 13px; cursor: pointer; box-shadow: 0 1px 2px rgba(20,24,33,.06);
  transition: border-color var(--mv-t-control), transform var(--mv-t-control), box-shadow var(--mv-t-control);
}
#dataRoom .dr-btn:hover { border-color: var(--mv-ink-30); transform: translateY(-1px); box-shadow: var(--mv-shadow-rest); }
#dataRoom .dr-btn:active { transform: none; }
#dataRoom .dr-btn svg { width: 13px; height: 13px; }
#dataRoom .dr-btn.primary { color: #fff; background: var(--mv-ink); border-color: var(--mv-ink); }
#dataRoom .dr-btn.primary:hover { background: #000; border-color: #000; }
#dataRoom .dr-mini {
  display: inline-flex; align-items: center; gap: 6px;
  font: inherit; font-size: 11.5px; font-weight: 500; color: var(--mv-ink);
  background: #fff; border: 1px solid var(--mv-ink-12); border-radius: var(--mv-r-btn);
  padding: 4px 10px; cursor: pointer;
  transition: border-color var(--mv-t-control), transform var(--mv-t-control), box-shadow var(--mv-t-control);
}
#dataRoom .dr-mini:hover { border-color: var(--mv-ink-30); transform: translateY(-1px); box-shadow: 0 3px 8px -3px rgba(20,24,33,.18); }
#dataRoom .dr-mini.warn { color: #7a5a18; }
#dataRoom .dr-mini.danger { color: #b8493a; }
#dataRoom .dr-link {
  font-family: var(--mv-serif); font-style: italic; font-size: 11.5px; color: var(--mv-blue);
  background: none; border: none; padding: 0; cursor: pointer;
  text-decoration: underline dashed rgba(45,74,110,.4); text-underline-offset: 3px;
}
#dataRoom .dr-link:hover { text-decoration-style: solid; }
#dataRoom button:focus-visible, #dataRoom input:focus-visible, #dataRoom select:focus-visible {
  outline: none; box-shadow: 0 0 0 1.5px #fff, 0 0 0 3.5px var(--mv-blue);
}

/* ---------- fields: boxed values, blue only as feedback ---------- */
#dataRoom .dr-field { display: block; margin: 0 0 10px; }
#dataRoom .dr-field > span {
  display: block; font-family: var(--mv-mono); font-size: 9px; font-weight: 500;
  letter-spacing: .13em; text-transform: uppercase; color: var(--mv-ink-40); margin: 0 0 4px;
}
#dataRoom .dr-field input, #dataRoom .dr-field select, #dataRoom select, #dataRoom input[type="text"] {
  width: 100%; font: inherit; font-size: 12.5px; color: var(--mv-ink);
  background: #fff; border: none; border-radius: var(--mv-r-control);
  box-shadow: inset 0 0 0 1px var(--mv-ink-12); padding: 7px 10px;
  transition: box-shadow var(--mv-t-control), transform var(--mv-t-control);
}
#dataRoom .dr-field select, #dataRoom select {
  -webkit-appearance: none; appearance: none;
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 16 16'%3E%3Cpath d='M4 6l4 4 4-4' fill='none' stroke='%23878d97' stroke-width='1.8' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 10px center; padding-right: 28px;
}
#dataRoom .dr-field input:hover, #dataRoom .dr-field select:hover {
  box-shadow: inset 0 0 0 1px var(--mv-blue-mid), 0 3px 10px -5px rgba(20,24,33,.3); transform: translateY(-1px);
}
#dataRoom .dr-field input:focus, #dataRoom .dr-field select:focus { transform: none; }
#dataRoom .dr-check { display: flex; gap: 8px; align-items: center; font-size: 12px; color: var(--mv-ink-70); padding: 2px 0; cursor: pointer; }
#dataRoom .dr-inline-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
#dataRoom .dr-row-actions { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }

/* ---------- chips: mono provenance metadata ---------- */
#dataRoom .dr-chip {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--mv-mono); font-size: 10px; color: var(--mv-ink-55);
  background: rgba(27,30,36,.05); border: none; border-radius: 5px; padding: 3px 8px;
}

/* ---------- empty state ---------- */
#dataRoom .dr-empty { min-height: calc(100vh - 120px); display: flex; align-items: center; justify-content: center; }
#dataRoom .dr-drop {
  width: min(440px, 90%); text-align: center;
  background: #fff; border: 1px dashed var(--mv-ink-30); border-radius: var(--mv-r-card);
  padding: 42px 36px 36px;
  transition: border-color var(--mv-t-control), box-shadow var(--mv-t-panel) var(--mv-ease), transform var(--mv-t-control);
}
#dataRoom .dr-drop:hover, #dataRoom .dr-drop.is-over { border-color: var(--mv-blue); box-shadow: var(--mv-shadow-lit); transform: translateY(-1px); }
#dataRoom .dr-xls { width: 38px; height: 38px; margin: 0 auto 14px; color: var(--mv-ink-55); }
#dataRoom .dr-xls svg { width: 100%; height: 100%; }
#dataRoom .dr-drop strong { display: block; font-size: 14.5px; font-weight: 500; margin-bottom: 4px; }
#dataRoom .dr-drop > span { display: block; font-size: 11.5px; color: var(--mv-ink-55); margin-bottom: 16px; }
#dataRoom .dr-status { font-family: var(--mv-serif); font-style: italic; font-size: 12px; color: var(--mv-ink-55); margin-top: 12px; min-height: 18px; }

/* ---------- toolbar ---------- */
#dataRoom .dr-toolbar {
  display: flex; align-items: center; gap: 12px;
  padding: 16px 28px 12px; border-bottom: 1px solid var(--mv-ink-08);
}
#dataRoom .dr-seg { display: inline-flex; background: rgba(27,30,36,.06); border-radius: var(--mv-r-control); padding: 2px; }
#dataRoom .dr-seg button {
  font: inherit; font-size: 12px; font-weight: 500; color: var(--mv-ink-55);
  background: transparent; border: none; border-radius: 6px; padding: 4px 13px; cursor: pointer;
  transition: color var(--mv-t-micro);
}
#dataRoom .dr-seg button:hover { color: var(--mv-ink); }
#dataRoom .dr-seg button.on { background: #fff; color: var(--mv-ink); box-shadow: 0 1px 3px rgba(20,24,33,.14); }
#dataRoom .dr-fileline { display: flex; align-items: baseline; gap: 10px; }
#dataRoom .dr-fileline strong { font-family: var(--mv-serif); font-style: italic; font-weight: 500; font-size: 15px; }
#dataRoom .dr-fileline span { font-family: var(--mv-mono); font-size: 10px; color: var(--mv-ink-40); }

/* ---------- the three zones, told apart by hairlines ---------- */
#dataRoom .dr-workspace {
  display: grid; grid-template-columns: 300px minmax(0, 1fr) 290px;
  min-height: calc(100vh - 120px);
}
#dataRoom .dr-rail { grid-column: 1; grid-row: 1; border-right: 1px solid var(--mv-ink-08); padding: 18px 22px 28px 28px; min-width: 0; }
#dataRoom .dr-center { grid-column: 2; grid-row: 1; padding: 18px 28px 60px; min-width: 0; max-width: none; }
#dataRoom .dr-rightbar { grid-column: 3; grid-row: 1; border-left: 1px solid var(--mv-ink-08); padding: 18px 28px 28px 22px; min-width: 0; width: auto; max-width: none; position: static; }
#dataRoom .dr-railgrp { padding: 16px 0 8px; border-top: 1px solid var(--mv-ink-08); }
#dataRoom .dr-railgrp:first-child { border-top: none; padding-top: 0; }
@media (max-width: 1200px) {
  #dataRoom .dr-workspace { grid-template-columns: 264px minmax(0,1fr) 252px; }
}

/* ---------- data health: the dot/italic notice voice ---------- */
#dataRoom .dr-flag { display: flex; gap: 9px; align-items: baseline; margin: 0 0 8px; font-family: var(--mv-serif); font-style: italic; font-size: 12px; line-height: 1.55; color: var(--mv-ink-70); }
#dataRoom .dr-flag .dr-dot { flex-shrink: 0; width: 7px; height: 7px; border-radius: 50%; background: var(--mv-ink-30); transform: translateY(-1px); }
#dataRoom .dr-flag.warn .dr-dot { background: #b07d2e; }
#dataRoom .dr-flag.danger .dr-dot { background: #b8493a; }
#dataRoom .dr-health:empty::after {
  content: "no flags — the file reads clean";
  font-family: var(--mv-serif); font-style: italic; font-size: 11.5px; color: var(--mv-ink-30);
}

/* ---------- recipe: quiet italic history ---------- */
#dataRoom .dr-recipe { font-family: var(--mv-serif); font-style: italic; font-size: 11.5px; line-height: 1.55; color: var(--mv-ink-55); padding: 4px 0; border-top: 1px solid rgba(27,30,36,.05); }
#dataRoom .dr-recipe:first-child { border-top: none; }
#dataRoom .dr-recipes:empty::after { content: "edits are recorded here, step by step"; font-family: var(--mv-serif); font-style: italic; font-size: 11.5px; color: var(--mv-ink-30); }

/* ---------- the sheet ---------- */
#dataRoom .dr-sheet { border: 1px solid var(--mv-ink-12); border-radius: var(--mv-r-card); overflow: hidden; }
#dataRoom .dr-gridwrap { overflow: auto; max-height: calc(100vh - 240px); }
#dataRoom .dr-grid { border-collapse: collapse; width: 100%; font-size: 11.5px; font-variant-numeric: tabular-nums; white-space: nowrap; }
#dataRoom .dr-grid thead th {
  position: sticky; top: 0; z-index: 2; background: #fff;
  font-family: var(--mv-mono); font-size: 10px; font-weight: 500; color: var(--mv-ink);
  text-align: left; padding: 8px 12px; border-bottom: 1px solid var(--mv-ink-30); cursor: pointer; user-select: none;
}
#dataRoom .dr-grid thead th:hover { background: var(--mv-blue-soft); }
#dataRoom .dr-grid thead th.is-selected { background: var(--mv-blue-soft); box-shadow: inset 0 -2px 0 var(--mv-blue); }
#dataRoom .dr-grid td { padding: 5px 12px; border-top: 1px solid rgba(27,30,36,.05); max-width: 240px; overflow: hidden; text-overflow: ellipsis; }
#dataRoom .dr-grid td.is-selected { background: var(--mv-blue-soft); }
#dataRoom .dr-grid tbody tr:hover td { background: var(--mv-blue-soft); }
#dataRoom .dr-rowhead { width: 34px; }
#dataRoom .dr-rownum, #dataRoom td.dr-rownum { font-family: var(--mv-mono); font-size: 9.5px; color: var(--mv-ink-30); text-align: right; background: #fff; border-right: 1px solid rgba(27,30,36,.06); }
#dataRoom .dr-foot { display: flex; gap: 14px; padding: 8px 14px; border-top: 1px solid var(--mv-ink-08); font-family: var(--mv-serif); font-style: italic; font-size: 11.5px; color: var(--mv-ink-40); }

/* ---------- the variables list: one flat surface, families inline ---------- */
#dataRoom .dr-workbench { display: block; max-width: 940px; }
#dataRoom .dr-band { margin: 0 0 24px; }
#dataRoom .dr-varlist { border-top: 1px solid var(--mv-ink-12); }
#dataRoom .dr-vrow {
  display: grid; grid-template-columns: 16px minmax(150px, 230px) 110px minmax(0, 1fr);
  gap: 12px; align-items: center; padding: 9px 10px 9px 2px;
  border-bottom: 1px solid rgba(27,30,36,.06); cursor: pointer;
  transition: background var(--mv-t-micro);
}
#dataRoom .dr-vrow:hover { background: var(--mv-blue-soft); }
#dataRoom .dr-vrow.is-selected { background: var(--mv-blue-soft); box-shadow: inset 2px 0 0 var(--mv-blue); }
#dataRoom .dr-vrow.is-hidden { opacity: .45; }
#dataRoom .dr-vname { font-family: var(--mv-mono); font-size: 11px; color: var(--mv-ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
#dataRoom .dr-vtype { font-size: 10.5px; color: var(--mv-ink-40); }
#dataRoom .dr-vsum { font-family: var(--mv-charter); font-size: 12px; color: var(--mv-ink-70); font-variant-numeric: tabular-nums; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
#dataRoom .dr-vchild { padding-left: 28px; background: rgba(27,30,36,.015); }
#dataRoom .dr-fam .dr-famrow .dr-chev { color: var(--mv-ink-40); transition: transform .2s var(--mv-ease); justify-self: center; }
#dataRoom .dr-fam.is-open > .dr-famrow .dr-chev { transform: rotate(90deg); }
#dataRoom .dr-famsum { color: var(--mv-ink-70); }
#dataRoom .dr-warntxt { color: #7a5a18; }
#dataRoom .dr-score-controls { padding: 12px 14px 14px 28px; background: rgba(27,30,36,.015); border-bottom: 1px solid rgba(27,30,36,.06); }
#dataRoom .dr-family-builder { border: 1px solid var(--mv-ink-12); border-radius: var(--mv-r-panel); padding: 14px; margin: 0 0 12px; }
#dataRoom .dr-manual-items { max-height: 180px; overflow: auto; box-shadow: inset 0 0 0 1px var(--mv-ink-08); border-radius: var(--mv-r-control); padding: 6px 10px; margin: 6px 0 10px; }
#dataRoom .dr-tool-title { font-family: var(--mv-mono); font-size: 9.5px; letter-spacing: .13em; text-transform: uppercase; color: var(--mv-ink-40); font-weight: 500; margin-bottom: 8px; }

/* ---------- quick actions ---------- */
#dataRoom .dr-col-title { font-family: var(--mv-mono); font-size: 11.5px; color: var(--mv-ink); }
#dataRoom .dr-col-sub { font-family: var(--mv-serif); font-style: italic; font-size: 11.5px; color: var(--mv-ink-55); margin: 2px 0 10px; line-height: 1.5; }
#dataRoom .dr-stat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0 12px; margin-bottom: 12px; }
#dataRoom .dr-stat { padding: 5px 0; border-top: 1px solid var(--mv-ink-08); }
#dataRoom .dr-stat-label { font-family: var(--mv-mono); font-size: 8.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--mv-ink-40); }
#dataRoom .dr-stat-value { font-size: 12.5px; font-weight: 500; font-variant-numeric: tabular-nums; }
#dataRoom .dr-basics-grid { display: grid; grid-template-columns: minmax(0,1fr) 116px; gap: 8px; margin-bottom: 4px; }
#dataRoom .dr-basics-grid .dr-field { margin: 0; }
#dataRoom .dr-acts { margin-top: 8px; border-top: 1px solid var(--mv-ink-08); }
#dataRoom .dr-act { border-bottom: 1px solid var(--mv-ink-08); }
#dataRoom .dr-act-row {
  display: flex; align-items: center; gap: 9px; width: 100%;
  padding: 10px 2px; font: inherit; font-size: 12.5px; font-weight: 500; color: var(--mv-ink-70);
  background: none; border: none; cursor: pointer; text-align: left;
  transition: color var(--mv-t-micro);
}
#dataRoom .dr-act-row:hover { color: var(--mv-ink); }
#dataRoom .dr-act-row .dr-g { width: 13px; height: 13px; flex-shrink: 0; color: var(--mv-ink-40); transition: color var(--mv-t-micro), transform var(--mv-t-control); }
#dataRoom .dr-act-row:hover .dr-g { color: var(--mv-ink); transform: translateY(-1px); }
#dataRoom .dr-act-row .dr-chev { margin-left: auto; color: var(--mv-ink-30); transition: transform .2s var(--mv-ease); }
#dataRoom .dr-act.is-open .dr-act-row .dr-chev { transform: rotate(90deg); }
#dataRoom .dr-act-body { padding: 2px 2px 14px 22px; }
#dataRoom .dr-act-body > * { margin-bottom: 8px; }
#dataRoom .dr-act-direct { border-bottom: 1px solid var(--mv-ink-08); }
#dataRoom .dr-act-direct.dr-danger { color: #b8493a; }
#dataRoom .dr-act-direct.dr-danger .dr-g { color: #b8493a; }
#dataRoom .dr-preview { font-family: var(--mv-serif); font-style: italic; font-size: 11.5px; line-height: 1.55; color: var(--mv-ink-55); }
#dataRoom .dr-emptyline { font-family: var(--mv-serif); font-style: italic; font-size: 11.5px; color: var(--mv-ink-30); }

/* ---------- drafts: run → draft → send ---------- */
#dataRoom .dr-draft { border: 1px solid var(--mv-ink-12); border-radius: var(--mv-r-panel); padding: 11px 13px; margin: 0 0 10px; box-shadow: 0 1px 2px rgba(20,24,33,.05); }
#dataRoom .dr-draft-title { font-family: var(--mv-mono); font-size: 10.5px; color: var(--mv-ink); }
#dataRoom .dr-draft-sub { font-family: var(--mv-serif); font-style: italic; font-size: 11.5px; color: var(--mv-ink-55); margin: 3px 0 6px; line-height: 1.5; }
#dataRoom .dr-draft-stats { font-family: var(--mv-charter); font-size: 12px; color: var(--mv-ink-70); font-variant-numeric: tabular-nums; margin-bottom: 9px; }
#dataRoom .dr-draft-actions { display: flex; gap: 6px; align-items: center; }
#dataRoom .dr-draft-list:empty::after { content: "runs land here as drafts; only what you send reaches Stats"; font-family: var(--mv-serif); font-style: italic; font-size: 11.5px; line-height: 1.55; color: var(--mv-ink-30); display: block; }

/* ---------- the right bar: the analyzer's reserved home ---------- */
#dataRoom .dr-brand { font-family: var(--mv-serif); font-size: 17px; font-weight: 500; letter-spacing: -.01em; }
#dataRoom .dr-brand-o { font-style: italic; color: var(--mv-green); }
#dataRoom .dr-brand-an { color: var(--mv-blue); font-weight: 600; }
#dataRoom .dr-brand-sub { font-family: var(--mv-serif); font-style: italic; font-size: 11.5px; color: var(--mv-ink-55); margin: 3px 0 18px; }
#dataRoom .dr-interim { opacity: .85; }
#dataRoom .dr-runbar { display: flex; align-items: center; gap: 10px; margin-top: 12px; }
#dataRoom #drAnalyzeStatus { font-family: var(--mv-serif); font-style: italic; font-size: 11.5px; color: var(--mv-ink-55); }
#dataRoom .dr-dockfoot { font-family: var(--mv-serif); font-style: italic; font-size: 11px; color: var(--mv-ink-30); margin-top: 16px; }
#dataRoom .dr-ok { color: var(--mv-green); font-style: normal; }

/* engine / privacy: the notice voice, not a box */
#dataRoom .dr-origin { display: flex; gap: 9px; align-items: baseline; font-family: var(--mv-serif); font-style: italic; font-size: 11.5px; line-height: 1.55; color: var(--mv-ink-70); }
#dataRoom .dr-origin b { font-weight: 600; font-style: normal; font-family: var(--mv-sans); font-size: 11px; }
#dataRoom .dr-origin-dot { flex-shrink: 0; width: 7px; height: 7px; border-radius: 50%; background: var(--mv-blue); transform: translateY(-1px); }
#dataRoom .dr-trust { font-family: var(--mv-serif); font-style: italic; font-size: 11.5px; line-height: 1.55; color: var(--mv-ink-55); margin: 9px 0 0; }

@media (prefers-reduced-motion: reduce) {
  #dataRoom * { transition-duration: .01ms !important; }
}

/* shape dots + stat facts (markup from the renderers) */
#dataRoom .dr-dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: #5a7384; justify-self: center; }
#dataRoom .dr-dot.cat { border-radius: 2px; background: #7c6a9a; }
#dataRoom .dr-dot.id { background: transparent; box-shadow: inset 0 0 0 1.3px var(--mv-ink-30); }
#dataRoom .dr-stat span { display: block; font-family: var(--mv-mono); font-size: 8.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--mv-ink-40); }
#dataRoom .dr-stat strong { font-size: 12.5px; font-weight: 500; font-variant-numeric: tabular-nums; }

#dataRoom .dr-band-head h2 { white-space: nowrap; }
#dataRoom .dr-grid thead th .dr-dot { margin-right: 6px; }

/* ---------- the question mark: guidance that expands under the hand ---------- */
#dataRoom .dr-help {
  position: relative; display: inline-flex; align-items: center; justify-content: center;
  width: 13px; height: 13px; margin-left: 5px; vertical-align: 1px;
  font-family: var(--mv-sans); font-size: 9px; font-weight: 600; font-style: normal;
  letter-spacing: 0; text-transform: none;
  color: var(--mv-ink-40); box-shadow: inset 0 0 0 1px var(--mv-ink-30); border-radius: 50%;
  cursor: help; transition: color var(--mv-t-micro), box-shadow var(--mv-t-micro);
}
#dataRoom .dr-help:hover { color: var(--mv-blue); box-shadow: inset 0 0 0 1px var(--mv-blue); }
#dataRoom .dr-help::after {
  content: attr(data-tip);
  position: absolute; left: 0; top: 18px; z-index: 40; width: 230px;
  font-family: var(--mv-serif); font-style: italic; font-size: 11.5px; font-weight: 400;
  line-height: 1.55; color: var(--mv-ink-70); text-align: left;
  background: #fff; border: 1px solid var(--mv-ink-12); border-radius: var(--mv-r-panel);
  box-shadow: var(--mv-shadow-card); padding: 9px 12px;
  opacity: 0; transform: translateY(-2px); pointer-events: none;
  transition: opacity var(--mv-t-micro), transform var(--mv-t-micro);
}
#dataRoom .dr-help:hover::after { opacity: 1; transform: none; }

/* ---------- full level table: nothing is cut silently ---------- */
#dataRoom .dr-levels { max-height: 176px; overflow: auto; border-top: 1px solid var(--mv-ink-08); margin-bottom: 10px; }
#dataRoom .dr-levelrow { display: grid; grid-template-columns: minmax(0,1fr) 44px 48px; gap: 8px; padding: 4px 0; border-bottom: 1px solid rgba(27,30,36,.05); font-size: 12px; }
#dataRoom .dr-levelname { font-family: var(--mv-charter); color: var(--mv-ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
#dataRoom .dr-leveln { font-variant-numeric: tabular-nums; text-align: right; color: var(--mv-ink-70); }
#dataRoom .dr-levelpct { font-variant-numeric: tabular-nums; text-align: right; color: var(--mv-ink-40); }

/* ---------- assign-labels rows ---------- */
#dataRoom .dr-maprow { display: grid; grid-template-columns: 44px minmax(0,1fr); gap: 8px; align-items: center; margin: 0 0 6px; }
#dataRoom .dr-mapval { font-family: var(--mv-mono); font-size: 11px; color: var(--mv-ink-55); text-align: right; }
#dataRoom #drGroupMap { margin: 0 0 10px; max-height: 200px; overflow: auto; }

/* ---------- recipe stays small: six steps, then it scrolls ---------- */
#dataRoom .dr-recipes { max-height: 156px; overflow: auto; }

/* ---------- scale-builder filter ---------- */
#dataRoom .dr-scale-search { margin: 0 0 6px; }

/* ---------- scale membership editing ---------- */
#dataRoom .dr-item-x {
  margin-left: auto; width: 18px; height: 18px; flex-shrink: 0;
  font: inherit; font-size: 13px; line-height: 1; color: var(--mv-ink-30);
  background: none; border: none; border-radius: 50%; cursor: pointer;
  opacity: 0; transition: opacity var(--mv-t-micro), color var(--mv-t-micro);
}
#dataRoom .dr-vrow:hover .dr-item-x { opacity: 1; }
#dataRoom .dr-item-x:hover { color: #b8493a; }
#dataRoom .dr-vrow { grid-template-columns: 16px minmax(150px, 230px) 110px minmax(0, 1fr) auto; }
#dataRoom .dr-scale-edit { padding: 8px 14px 8px 28px; background: rgba(27,30,36,.015); border-bottom: 1px solid rgba(27,30,36,.06); }
#dataRoom .dr-scale-add { padding: 10px 14px 14px 28px; background: rgba(27,30,36,.015); border-bottom: 1px solid rgba(27,30,36,.06); }
#dataRoom .dr-scale-add .dr-manual-items { background: #fff; }
#dataRoom .dr-pickall { margin: 6px 0; gap: 12px; }

/* upload feedback lives where the eyes are, in every state */
#dataRoom .dr-busy { display: inline-flex; align-items: center; gap: 8px; font-family: var(--mv-serif); font-style: italic; font-size: 12px; color: var(--mv-blue); }
#dataRoom .dr-busy::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--mv-blue); animation: drPulse 1s ease-in-out infinite; }
@keyframes drPulse { 50% { opacity: .25; } }

/* the rails come along: sticky, self-scrolling, full-height */
#dataRoom .dr-rail, #dataRoom .dr-rightbar {
  position: sticky; top: 64px; align-self: start;
  height: calc(100vh - 64px); overflow-y: auto;
}

/* sticky heads must be opaque — translucent washes let rows shine through */
#dataRoom .dr-grid thead th:hover { background: #eef1f6; }
#dataRoom .dr-grid thead th.is-selected { background: #e9eef5; }

/* the data-room loader: not a reboot, a moment — a small card over a
   frosted room. The full-screen boot mark stays reserved for refresh. */
#dataRoom .dr-loader { display: none; }
#dataRoom .dr-loader.on {
  display: flex; align-items: center; justify-content: center;
  position: fixed; inset: 0; z-index: 80;
  background: rgba(252, 253, 255, 0.45);
  -webkit-backdrop-filter: blur(7px) saturate(120%);
  backdrop-filter: blur(7px) saturate(120%);
  animation: drLoaderIn 0.22s ease both;
}
@keyframes drLoaderIn { from { opacity: 0; } to { opacity: 1; } }
#dataRoom .dr-loader-card {
  min-width: 270px; max-width: 360px; text-align: center;
  background: #fff; border: 1px solid var(--mv-ink-12);
  border-radius: 14px; box-shadow: var(--mv-shadow-card);
  padding: 28px 36px 24px;
}
#dataRoom .dr-mark { font-family: var(--mv-serif); font-size: 26px; font-weight: 500; letter-spacing: -0.01em; color: var(--mv-ink); }
#dataRoom .dr-mark-o { font-style: italic; color: var(--mv-green); display: inline-block; animation: drMarkPulse 1.5s ease-in-out infinite; }
@keyframes drMarkPulse { 50% { opacity: 0.35; transform: translateY(-1px); } }
#dataRoom .dr-loader-msg {
  margin-top: 10px; font-family: var(--mv-serif); font-style: italic;
  font-size: 12.5px; line-height: 1.55; color: var(--mv-ink-55);
}
@media (prefers-reduced-motion: reduce) {
  #dataRoom .dr-mark-o { animation: none; }
}

/* variables filter + rail scales group */
#dataRoom .dr-varfilter { width: 180px; font-size: 12px; padding: 5px 9px; }
#dataRoom #drScaleHost .dr-family-builder { margin: 0; }
#dataRoom #drScaleHost .dr-manual-items { max-height: 150px; }

/* help marks ride the right edge of action rows — out of the click path */
#dataRoom .dr-act-row .dr-help { margin-left: auto; }
#dataRoom .dr-act-row .dr-help::after { left: auto; right: 0; }

/* ---------- collapse + resize: panes keep width, slide out, never reflow ---------- */
#dataRoom .dr-workspace {
  --dr-rail-w: 344px;
  --dr-right-w: 330px;
  grid-template-columns: var(--dr-rail-w) minmax(0, 1fr) var(--dr-right-w);
  position: relative;
  overflow: hidden;
  transition: grid-template-columns 0.42s cubic-bezier(0.16, 1, 0.3, 1);
}
#dataRoom .dr-workspace.rail-collapsed { grid-template-columns: 0 minmax(0, 1fr) var(--dr-right-w); }
#dataRoom .dr-workspace.right-collapsed { grid-template-columns: var(--dr-rail-w) minmax(0, 1fr) 0; }
#dataRoom .dr-workspace.rail-collapsed.right-collapsed { grid-template-columns: 0 minmax(0, 1fr) 0; }
#dataRoom .dr-workspace.dr-resizing { transition: none; user-select: none; cursor: ew-resize; }
#dataRoom .dr-rail, #dataRoom .dr-rightbar {
  width: auto; min-width: 0;
  transform: translateX(0); opacity: 1;
  transition: transform 0.42s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.28s ease, border-color 0.28s ease;
  will-change: transform, opacity;
}
#dataRoom .dr-rail { width: var(--dr-rail-w); max-width: var(--dr-rail-w); }
#dataRoom .dr-rightbar { width: var(--dr-right-w); max-width: var(--dr-right-w); }
#dataRoom .dr-workspace.rail-collapsed .dr-rail {
  border-right-color: transparent; opacity: 0; pointer-events: none;
  transform: translateX(calc(-1 * var(--dr-rail-w)));
}
#dataRoom .dr-workspace.right-collapsed .dr-rightbar {
  border-left-color: transparent; opacity: 0; pointer-events: none;
  transform: translateX(var(--dr-right-w));
}
#dataRoom .dr-collapse-pill {
  background: #fff; border: 1px solid var(--mv-ink-12); border-radius: 6px; padding: 5px 11px;
  font-family: var(--mv-serif); font-style: italic; font-size: 12px; color: var(--mv-ink-55);
  cursor: pointer; display: inline-flex; align-items: center; gap: 6px;
  transition: color 0.12s, border-color 0.12s;
}
#dataRoom .dr-collapse-pill:hover { color: var(--mv-ink); border-color: var(--mv-ink-30); }
#dataRoom .dr-collapse-pill .arrow { width: 11px; height: 11px; color: currentColor; }
#dataRoom .dr-brand .dr-collapse-pill { margin-left: auto; align-self: center; }
#dataRoom .dr-edge-open {
  position: absolute; top: 14px; z-index: 12;
  background: #fff; border: 1px solid var(--mv-ink-12); border-radius: 6px; padding: 6px 12px;
  font-family: var(--mv-serif); font-style: italic; font-size: 12.5px; color: var(--mv-ink-55);
  cursor: pointer; box-shadow: 0 1px 2px rgba(0,0,0,0.04);
  display: inline-flex; align-items: center; gap: 6px;
  opacity: 0; pointer-events: none;
  transition: color 0.12s, border-color 0.12s, opacity 0.18s ease, transform 0.22s ease;
}
#dataRoom .dr-edge-open:hover { color: var(--mv-ink); border-color: var(--mv-ink-30); }
#dataRoom .dr-edge-open .arrow { width: 11px; height: 11px; color: currentColor; }
#dataRoom .dr-edge-left { left: 16px; transform: translateX(-8px); }
#dataRoom .dr-edge-right { right: 16px; transform: translateX(8px); }
#dataRoom .dr-workspace.rail-collapsed .dr-edge-left,
#dataRoom .dr-workspace.right-collapsed .dr-edge-right {
  opacity: 1; pointer-events: auto; transform: translateX(0);
  transition: color 0.12s, border-color 0.12s, opacity 0.2s ease 0.22s, transform 0.24s ease 0.22s;
}
#dataRoom .dr-resize { position: absolute; top: 0; bottom: 0; width: 10px; cursor: ew-resize; z-index: 11; }
#dataRoom .dr-resize-left { right: -5px; }
#dataRoom .dr-resize-right { left: -5px; }
#dataRoom .dr-resize::before, #dataRoom .dr-resize::after {
  content: ""; position: absolute; top: 50%; width: 1px; height: 34px; border-radius: 999px;
  background: rgba(26,29,36,0.16); opacity: 0; transform: translateY(-50%);
  transition: opacity 0.14s, background 0.14s;
}
#dataRoom .dr-resize::before { left: 3.5px; }
#dataRoom .dr-resize::after { left: 6.5px; }
#dataRoom .dr-resize:hover::before, #dataRoom .dr-resize:hover::after,
#dataRoom .dr-workspace.dr-resizing .dr-resize::before, #dataRoom .dr-workspace.dr-resizing .dr-resize::after {
  opacity: 1; background: rgba(26,29,36,0.3);
}

/* ---------- the column finder ---------- */
#dataRoom .dr-jumpwrap { position: relative; }
#dataRoom .dr-jumpinput { width: 190px; font-size: 12px; padding: 6px 10px; }
#dataRoom .dr-jumplist {
  position: absolute; top: calc(100% + 5px); left: 0; z-index: 45; min-width: 230px;
  background: #fff; border: 1px solid var(--mv-ink-12); border-radius: var(--mv-r-panel);
  box-shadow: var(--mv-shadow-card); padding: 5px;
}
#dataRoom .dr-jump-hit {
  display: flex; align-items: center; gap: 9px; width: 100%; text-align: left;
  font-family: var(--mv-mono); font-size: 11px; color: var(--mv-ink);
  background: none; border: none; border-radius: 6px; padding: 7px 9px; cursor: pointer;
  transition: background var(--mv-t-micro);
}
#dataRoom .dr-jump-hit:hover { background: var(--mv-blue-soft); }

#dataRoom .dr-labelmap { max-height: 200px; overflow: auto; margin: 0 0 10px; }

/* ---------- review fixes: inputs, collapse ghosts, clearance, title ---------- */

/* every text input wears the boxed-value skin — no raw browser fields */
#dataRoom input:not([type="checkbox"]):not([type="radio"]):not([type="file"]) {
  font: inherit; font-size: 12.5px; color: var(--mv-ink);
  background: #fff; border: none; border-radius: var(--mv-r-control);
  box-shadow: inset 0 0 0 1px var(--mv-ink-12); padding: 7px 10px;
  transition: box-shadow var(--mv-t-control), transform var(--mv-t-control);
}
#dataRoom input:not([type="checkbox"]):not([type="radio"]):not([type="file"]):hover {
  box-shadow: inset 0 0 0 1px var(--mv-blue-mid), 0 3px 10px -5px rgba(20,24,33,.3);
}
#dataRoom input:not([type="checkbox"]):not([type="radio"]):not([type="file"]):focus {
  outline: none; box-shadow: inset 0 0 0 1px var(--mv-blue), 0 0 0 3px var(--mv-blue-soft);
}
#dataRoom .dr-labelmap input, #dataRoom .dr-maprow input { width: 100%; font-size: 12px; padding: 6px 9px; }
#dataRoom .dr-maprow { margin: 0 0 7px; }

/* collapse: a quiet icon ghost pinned to the panel corner */
#dataRoom .dr-collapse-ghost {
  position: absolute; top: 12px; right: 8px; z-index: 6;
  width: 26px; height: 24px; display: inline-flex; align-items: center; justify-content: center;
  color: var(--mv-ink-30); background: none; border: none; border-radius: 6px; cursor: pointer;
  transition: color var(--mv-t-micro), background var(--mv-t-micro);
}
#dataRoom .dr-collapse-ghost:hover { color: var(--mv-ink); background: rgba(27,30,36,.06); }
#dataRoom .dr-collapse-ghost-right { right: auto; left: 8px; }
#dataRoom .dr-rail { padding-right: 30px; }
#dataRoom .dr-rightbar { padding-left: 30px; }

/* the annotation stays on one line beside its title */
#dataRoom .dr-band-head .dr-ann { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* the rail's primary header earns its weight */
#dataRoom .dr-railtitle h2 { font-size: 11px; color: var(--mv-ink); letter-spacing: .16em; }
#dataRoom .dr-railtitle h2::before { width: 18px; }

/* collapsed sides leave room for their re-openers — nothing overlaps */
#dataRoom .dr-center { transition: padding 0.42s cubic-bezier(0.16, 1, 0.3, 1); }
#dataRoom .dr-workspace.rail-collapsed .dr-center { padding-left: 118px; }
#dataRoom .dr-workspace.right-collapsed .dr-center { padding-right: 132px; }

/* tooltips escape their scrolling panels: fixed-position bubbles render
   above everything and never get cut by overflow ancestors */
#dataRoom .dr-help::after,
#dataRoom .dr-act-row .dr-help::after {
  position: fixed; left: auto; right: auto; top: auto;
  width: max-content; max-width: 260px;
  transform: translate(-30%, 14px);
  z-index: 95;
}
#dataRoom .dr-help:hover::after,
#dataRoom .dr-act-row .dr-help:hover::after {
  opacity: 1; transform: translate(-30%, 14px);
}

/* the help bubble lives at body level; the old pseudo tips retire */
#dataRoom .dr-help::after, #dataRoom .dr-act-row .dr-help::after { display: none !important; }
.dr-tipbubble {
  position: fixed; z-index: 200; width: max-content; max-width: 270px;
  font-family: 'Newsreader', Georgia, serif; font-style: italic;
  font-size: 11.5px; font-weight: 400; line-height: 1.55; color: rgba(27,30,36,.7);
  text-align: left; background: #fff;
  border: 1px solid rgba(27,30,36,.12); border-radius: 10px;
  box-shadow: 0 1px 2px rgba(20,24,33,.06), 0 18px 44px -22px rgba(20,24,33,.25);
  padding: 9px 12px; pointer-events: none;
}

/* Variables scrolls INSIDE its list, like the data grid — the page never
   scrolls, so the toolbar and both rails stay exactly where they are
   and no gap opens above the sidebars */
#dataRoom .dr-varlist { max-height: calc(100vh - 232px); overflow-y: auto; }
#dataRoom .dr-workbench { max-width: none; }

/* ---------- reorder: a quiet grip, a single drop line ---------- */
#dataRoom .dr-vrow { position: relative; padding-left: 22px; }
#dataRoom .dr-grip {
  position: absolute; left: 4px; top: 50%; transform: translateY(-50%);
  font-size: 10px; line-height: 1; color: var(--mv-ink-30);
  opacity: 0; cursor: grab; user-select: none; padding: 4px 2px;
  transition: opacity var(--mv-t-micro), color var(--mv-t-micro);
}
#dataRoom .dr-vrow:hover .dr-grip { opacity: 1; }
#dataRoom .dr-grip:hover { color: var(--mv-ink); }
#dataRoom .dr-vrow.dr-dragging { opacity: 0.35; }
.dr-dropline {
  position: fixed; height: 2px; background: var(--mv-blue, #2d4a6e);
  border-radius: 2px; z-index: 150; pointer-events: none;
}
