/* ── ATP Portal — Questions tab ────────────────────────────────── */

/* ── Base table ──────────────────────────────────────────────────── */
.q-table {
  width: auto;
  border-collapse: collapse;
  font-size: 14px;
}

.q-table th {
  background: var(--bg2);
  color: var(--text2);
  font-weight: 600;
  font-size: 13px;
  padding: 7px 10px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}

/* Right-align n and % headers to match their cells */
.q-table th:nth-child(3),
.q-table th:nth-child(4) {
  text-align: right;
}

.q-table td {
  padding: 6px 10px;
  border-bottom: 1px solid var(--border);
  color: var(--text1);
  vertical-align: middle;
}

.q-table tbody tr:last-child td {
  border-bottom: none;
}

.q-table tbody tr:hover td {
  background: rgba(127, 119, 221, .05);
}

.q-table tfoot td {
  border-top: 1px solid var(--border);
  border-bottom: none;
}

/* ── Column sizing ───────────────────────────────────────────────── */
.q-td-code {
  width: 52px;
  min-width: 40px;
  color: var(--text3) !important;
  font-size: 12px;
}

.q-td-label {
  min-width: 160px;
  max-width: 320px;
  padding-right: 32px !important;   /* breathing room before n */
  color: var(--text1);
}

.q-td-n {
  width: 64px;
  text-align: right;
  color: var(--text2);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.q-td-pct {
  width: 64px;
  text-align: right;
  color: var(--text2);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.q-td-mean {
  width: 80px;
  text-align: right;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.q-foot-label {
  color: var(--text3);
  font-size: 12px;
}

/* ── Grid tables ─────────────────────────────────────────────────── */
.q-table-wrap {
  overflow-x: auto;
}

.q-grid-table {
  width: auto;
}

.q-grid-table th {
  text-align: center;
}

.q-grid-row-hdr {
  text-align: left !important;
  min-width: 180px;
  max-width: 320px;
}

.q-grid-row-lbl {
  color: var(--text1);
  font-size: 14px;
  min-width: 180px;
  max-width: 320px;
  padding-right: 24px !important;
}

.q-grid-cell {
  text-align: center;
  white-space: nowrap;
  color: var(--text1);
  min-width: 64px;
}

.q-cell-pct {
  color: var(--text3);
  font-size: 11px;
  margin-left: 3px;
}

.q-cell-empty {
  color: var(--border);
}

/* ── Text question card ──────────────────────────────────────────── */
.q-text-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 4px 8px;
}

.q-text-count {
  font-size: 32px;
  font-weight: 700;
  color: var(--teal);
  line-height: 1;
  flex-shrink: 0;
}

.q-text-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.q-text-label {
  font-size: 14px;
  color: var(--text2);
}

.q-text-sub {
  font-size: 11px;
  color: var(--text3);
  font-style: italic;
}

/* ── Filters card (mockup-style: header + toolbar + chips + counter) ── */
.q-filters-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 18px 22px;
  margin-bottom: 22px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* Header */
.q-filters-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.q-filters-header-left {
  display: flex;
  align-items: center;
  gap: 14px;
}

.q-filters-icon {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: rgba(64, 196, 196, .12);
  color: var(--teal);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.q-filters-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--text1);
  line-height: 1.2;
}

.q-filters-sub {
  font-size: 12px;
  color: var(--text3);
  margin-top: 2px;
}

.q-filters-toggle {
  background: transparent;
  border: none;
  color: var(--text3);
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  transition: color .15s, background .15s;
}

.q-filters-toggle:hover {
  color: var(--text1);
  background: var(--bg1);
}

/* Collapsed state — no inner padding under the header */
.q-filters-card.q-collapsed {
  padding-bottom: 18px;
  gap: 0;
}

/* Toolbar (Saved · Add · Save · Clear) */
.q-filters-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.q-toolbar-divider {
  width: 1px;
  height: 28px;
  background: var(--border);
  margin: 0 4px;
}

/* Saved views select wrapper (icon + native select + caret overlay) */
.q-saved-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.q-saved-icon {
  position: absolute;
  left: 14px;
  color: var(--text2);
  pointer-events: none;
  display: flex;
}

.q-saved-caret {
  position: absolute;
  right: 12px;
  color: var(--text2);
  pointer-events: none;
  display: flex;
}

.q-saved-select {
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 9px 32px 9px 38px;
  color: var(--text1);
  font-size: 13px;
  font-weight: 500;
  outline: none;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  min-width: 180px;
  transition: border-color .15s, background .15s;
}

.q-saved-select:hover,
.q-saved-select:focus {
  border-color: var(--teal);
}

/* Toolbar buttons — same height as the saved select (~38px) */
.q-btn-add,
.q-btn-apply,
.q-btn-save,
.q-btn-clear {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 8px;
  padding: 9px 16px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: filter .15s, background .15s, border-color .15s, color .15s;
  border: 1px solid transparent;
  height: 38px;
  white-space: nowrap;
}

/* Apply — primary action; lights up (accented) when there are unapplied edits */
.q-btn-apply {
  background: var(--bg1);
  color: var(--text2);
  border-color: var(--border);
}
.q-btn-apply.dirty {
  background: var(--teal);
  color: #fff;
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(64, 196, 196, .18);
}
.q-btn-apply.dirty:hover:not(:disabled) { filter: brightness(1.1); }
.q-btn-apply:disabled { opacity: .5; cursor: not-allowed; }

.q-btn-add {
  background: var(--teal);
  color: white;
  border-color: var(--teal);
}
.q-btn-add:hover:not(:disabled) { filter: brightness(1.1); }
.q-btn-add:disabled { opacity: .5; cursor: not-allowed; filter: none; }

.q-btn-plus {
  font-size: 16px;
  font-weight: 700;
  line-height: 1;
}

.q-btn-save {
  background: var(--bg1);
  color: var(--text1);
  border-color: var(--border);
}
.q-btn-save:hover:not(:disabled) { border-color: var(--teal); color: var(--teal); }
.q-btn-save:disabled { opacity: .5; cursor: not-allowed; }

.q-btn-clear {
  background: transparent;
  color: var(--text2);
  border-color: transparent;
}
.q-btn-clear:hover:not(:disabled) {
  background: rgba(255, 100, 100, .08);
  color: var(--red, #f33);
}
.q-btn-clear:disabled { opacity: .4; cursor: not-allowed; }

/* Legacy buttons used inside the picker only */
.q-btn {
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 6px 12px;
  color: var(--text1);
  font-size: 13px;
  cursor: pointer;
  transition: border-color .15s, background .15s;
}
.q-btn:hover:not(:disabled) { border-color: var(--teal); }
.q-btn:disabled { opacity: .4; cursor: not-allowed; }
.q-btn-primary {
  background: var(--teal);
  color: white;
  border-color: var(--teal);
}
.q-btn-primary:hover:not(:disabled) { filter: brightness(1.1); }

/* Active filter chips */
.q-chip-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.q-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 6px 8px 14px;
  background: rgba(64, 196, 196, .08);
  border: 1px solid rgba(64, 196, 196, .35);
  border-radius: 999px;
  font-size: 13px;
  color: var(--text1);
}

.q-chip-key {
  color: var(--teal);
  font-weight: 700;
}

.q-chip-val {
  color: var(--text1);
}

.q-chip-x {
  background: transparent;
  border: none;
  color: var(--text3);
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  cursor: pointer;
  border-radius: 50%;
  line-height: 1;
  transition: background .15s, color .15s;
}

.q-chip-x:hover {
  background: rgba(255, 100, 100, .15);
  color: var(--red, #f33);
}

/* Saved-filter management strip (small delete chips under the dropdown) */
.q-saved-mgmt {
  display: inline-flex;
  gap: 6px;
  flex-wrap: wrap;
  padding-left: 10px;
  border-left: 1px solid var(--border);
  margin-left: 4px;
}

.q-saved-del {
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 3px 8px;
  font-size: 11px;
  color: var(--text3);
  cursor: pointer;
}

.q-saved-del:hover {
  background: rgba(255, 100, 100, .1);
  color: var(--red, #f33);
}

/* Inline picker (Add filter) */
.q-picker {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  flex-wrap: wrap;
  padding: 12px;
  background: var(--bg1);
  border: 1px dashed var(--border);
  border-radius: 8px;
}

.q-picker-var {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 7px 10px;
  color: var(--text1);
  font-size: 13px;
  min-width: 220px;
}

.q-picker-values {
  flex: 1;
  min-width: 280px;
  max-height: 200px;
  overflow-y: auto;
  padding: 4px;
}

.q-picker-actions {
  display: inline-flex;
  align-items: flex-start;
  gap: 8px;
}

.q-picker-opt {
  display: grid;
  grid-template-columns: 18px 1fr auto;
  gap: 8px;
  align-items: center;
  padding: 4px 8px;
  font-size: 13px;
  color: var(--text1);
  cursor: pointer;
  border-radius: 4px;
}

.q-picker-opt:hover {
  background: rgba(127, 119, 221, .08);
}

.q-picker-opt code {
  color: var(--text3);
  font-size: 10px;
}

.q-picker-empty {
  font-size: 12px;
  color: var(--text3);
  font-style: italic;
}

.q-picker-or-hint {
  flex-basis: 100%;
  font-size: 11px;
  color: var(--text3);
  font-style: italic;
}

.q-picker-or-hint strong {
  color: var(--teal);
  font-style: normal;
}

/* Free-text input for numeric / rank-row / grid-number filters */
.q-picker-freetext-wrap {
  width: 100%;
  padding: 4px;
}

.q-picker-freetext-input {
  width: 100%;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 7px 10px;
  color: var(--text1);
  font-size: 13px;
  font-family: inherit;
  outline: none;
}

.q-picker-freetext-input:focus {
  border-color: var(--teal);
}

.q-picker-hint {
  font-size: 11px;
  color: var(--text3);
  margin-top: 4px;
  font-style: italic;
}

/* Counter line with icon */
.q-filter-counter {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--text2);
  padding-top: 6px;
  border-top: 1px solid var(--border);
}

.q-counter-icon {
  display: flex;
  align-items: center;
  color: var(--teal);
}

.q-filter-counter strong {
  color: var(--text1);
  font-weight: 700;
}

/* Loading state while filter recompute is in flight */
.q-loading {
  padding: 30px 14px;
  text-align: center;
  color: var(--text3);
  font-size: 13px;
  font-style: italic;
}

/* ── Boolean builder — Notion-style inline rows ───────────────────── */
.q-builder { margin-top: 2px; }

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

/* Root group is flat; sub-groups get an indented bordered box */
.q-group-sub {
  border: 1px solid var(--border);
  border-left: 3px solid var(--teal);
  border-radius: 8px;
  padding: 12px 14px;
  background: rgba(64, 196, 196, .04);
  margin-left: 6px;
}

/* Group header: "Match [ALL/ANY] of these conditions:" */
.q-group-header {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.q-match-lead, .q-match-trail {
  font-size: 13px;
  color: var(--text2);
}
.q-match-select {
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 4px 8px;
  color: var(--teal);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  outline: none;
}
.q-match-select:hover, .q-match-select:focus { border-color: var(--teal); }

/* group action buttons (footer + NOT) */
.q-group-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 5px 10px;
  font-size: 12px;
  font-weight: 600;
  color: var(--text2);
  cursor: pointer;
  transition: border-color .15s, color .15s, background .15s;
}
.q-group-btn:hover { border-color: var(--teal); color: var(--teal); }
.q-neg-toggle { font-size: 11px; padding: 4px 9px; margin-left: auto; }
.q-neg-toggle.active {
  background: rgba(255, 100, 100, .12);
  border-color: var(--red, #f33);
  color: var(--red, #f33);
}

.q-group-body {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-left: 4px;
}
.q-group-footer { display: flex; gap: 8px; margin-top: 2px; }

.q-group-empty {
  font-size: 12px;
  color: var(--text3);
  font-style: italic;
  padding: 2px 0;
}

/* Condition row — inline Field · operator · value · remove */
.q-cond-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.q-op-select {
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 6px 10px;
  color: var(--text2);
  font-size: 13px;
  outline: none;
  cursor: pointer;
  min-width: 80px;
}
.q-op-select:hover, .q-op-select:focus { border-color: var(--teal); }

/* ── Field picker (searchable combobox) ───────────────────────────── */
.q-field-wrap {
  position: relative;
  display: inline-block;
}
.q-field-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 6px 10px;
  color: var(--text1);
  font-size: 13px;
  cursor: pointer;
  outline: none;
  min-width: 200px;
  max-width: 360px;
  text-align: left;
}
.q-field-btn:hover, .q-field-btn:focus { border-color: var(--teal); }
.q-field-btn-lbl {
  flex: 1 1 auto;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.q-field-btn-caret {
  flex: 0 0 auto;
  color: var(--text3);
  font-size: 11px;
}
.q-field-panel {
  position: absolute;
  z-index: 31;
  top: 100%;
  left: 0;
  margin-top: 6px;
  min-width: 320px;
  max-width: 460px;
  max-height: 360px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, .3);
}
.q-field-search {
  flex: 0 0 auto;
  width: 100%;
  background: var(--bg1);
  border: none;
  border-bottom: 1px solid var(--border);
  padding: 8px 10px;
  color: var(--text1);
  font-size: 13px;
  outline: none;
  box-sizing: border-box;
}
.q-field-search::placeholder { color: var(--text3); }
.q-field-list {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 4px;
}
.q-field-opt {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  width: 100%;
  background: transparent;
  border: none;
  border-radius: 4px;
  padding: 6px 8px;
  color: var(--text1);
  font-size: 13px;
  text-align: left;
  cursor: pointer;
  outline: none;
}
.q-field-opt:hover,
.q-field-opt.is-highlight {
  background: rgba(127, 119, 221, .12);
}
.q-field-opt.is-selected .q-field-opt-lbl {
  color: var(--teal);
  font-weight: 600;
}
.q-field-opt-lbl {
  flex: 1 1 auto;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.q-field-type {
  flex: 0 0 auto;
  font-size: 10px;
  color: var(--text3);
  white-space: nowrap;
}
.q-field-empty {
  padding: 16px 10px;
  text-align: center;
  font-size: 12px;
  color: var(--text3);
  font-style: italic;
}

/* Value: categorical summary button + inline checkbox panel */
.q-val-wrap { position: relative; display: inline-block; }

.q-val-btn {
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 6px 10px;
  color: var(--text1);
  font-size: 13px;
  cursor: pointer;
  min-width: 120px;
  text-align: left;
}
.q-val-btn:hover { border-color: var(--teal); }

.q-val-panel {
  position: absolute;
  z-index: 30;
  top: 100%;
  left: 0;
  margin-top: 6px;
  min-width: 240px;
  max-height: 260px;
  overflow-y: auto;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 6px;
  box-shadow: 0 8px 24px rgba(0,0,0,.3);
}
.q-val-panel-actions {
  display: flex;
  justify-content: flex-end;
  padding: 6px 4px 2px;
  position: sticky;
  bottom: 0;
  background: var(--bg2);
}

.q-picker-opt {
  display: grid;
  grid-template-columns: 18px 1fr auto;
  gap: 8px;
  align-items: center;
  padding: 4px 8px;
  font-size: 13px;
  color: var(--text1);
  cursor: pointer;
  border-radius: 4px;
}
.q-picker-opt:hover { background: rgba(127, 119, 221, .08); }
.q-picker-opt code { color: var(--text3); font-size: 10px; }

/* Value: numeric inputs */
.q-num {
  width: 110px;
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 6px 10px;
  color: var(--text1);
  font-size: 13px;
  outline: none;
}
.q-num:focus { border-color: var(--teal); }
.q-val-num-wrap { display: inline-flex; align-items: center; gap: 8px; }
.q-num-sep { font-size: 12px; color: var(--text3); }
.q-val-text {
  width: 200px;
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 6px 10px;
  color: var(--text1);
  font-size: 13px;
  outline: none;
}
.q-val-text:focus { border-color: var(--teal); }

/* Expression preview line */
.q-expr-preview {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--text2);
  padding-top: 4px;
}
.q-expr-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text3);
}
.q-expr-preview code {
  font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  font-size: 12px;
  color: var(--teal);
  background: rgba(64, 196, 196, .08);
  padding: 3px 8px;
  border-radius: 5px;
}

/* Loaded saved-view info line */
.q-loaded-view {
  font-size: 12px;
  color: var(--text3);
}
.q-loaded-view strong { color: var(--text1); font-weight: 600; }
.q-loaded-dirty { color: var(--red, #f33); font-weight: 600; }

/* Field referencing a variable removed from the project config */
.q-field-missing,
.q-field-btn.q-field-missing {
  border-color: var(--amber, #e0a500) !important;
  color: var(--amber, #e0a500);
}

/* ── Helper states ───────────────────────────────────────────────── */
.q-base-note {
  font-size: 11px;
  color: var(--text3);
  margin-top: 6px;
  margin-bottom: 4px;
}

.q-no-data {
  color: var(--text3);
  font-size: 13px;
  font-style: italic;
  padding: 8px 0;
  margin: 0;
}

/* ── Loop card (Questions tab) ───────────────────────────────────── */
.q-loop-card .card-sub {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.q-loop-iter-pick {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--text3);
  text-transform: none;
  letter-spacing: 0;
  font-weight: 400;
}
.q-loop-iter-select {
  background: var(--bg1);
  border: 1px solid var(--teal);
  border-radius: 6px;
  padding: 3px 8px;
  color: var(--text1);
  font-size: 12px;
  font-weight: 600;
  outline: none;
}
.q-loop-body {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 12px;
}
.q-loop-child {
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 12px;
  background: var(--bg2);
}
.q-loop-child-head {
  font-size: 13px;
  color: var(--text1);
  margin-bottom: 6px;
}
.q-loop-child-sub {
  font-size: 11px;
  color: var(--text3);
  margin-left: 6px;
  font-weight: 400;
}
.q-loop-child-sub code {
  font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  font-size: 10px;
}
