/* CareDex — admin UI components · Index Ink Light v1.0
   Requires caredex-tokens.css + fonts (Space Grotesk, Instrument Sans, IBM Plex Mono) */

/* ============ Buttons ============ */
.cdx-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--cd-font-body); font-weight: 600; font-size: 14px; line-height: 1;
  padding: 11px 18px; border-radius: var(--cd-radius); border: 1px solid transparent;
  cursor: pointer; text-decoration: none; white-space: nowrap;
  transition: background 0.15s, border-color 0.15s, color 0.15s, box-shadow 0.15s;
}
.cdx-btn:focus-visible { outline: 2px solid var(--cd-signal-600); outline-offset: 2px; }
.cdx-btn--primary { background: var(--cd-ink); color: var(--cd-paper-text); }
.cdx-btn--primary:hover { background: #1C2740; }
.cdx-btn--secondary { background: var(--cd-card); color: var(--cd-ink); border-color: #D5D1C6; }
.cdx-btn--secondary:hover { background: #F4F1EA; border-color: #C2BDB0; }
.cdx-btn--ghost { background: transparent; color: var(--cd-ink); }
.cdx-btn--ghost:hover { background: rgba(11, 18, 32, 0.06); }
.cdx-btn--signal { background: var(--cd-signal-600); color: #FFFFFF; }
.cdx-btn--signal:hover { background: #0C8456; }
.cdx-btn--danger { background: transparent; color: var(--cqc-inadequate); }
.cdx-btn--danger:hover { background: #F8ECED; }
.cdx-btn--sm { padding: 8px 13px; font-size: 13px; border-radius: var(--cd-radius-sm); }
.cdx-btn[disabled], .cdx-btn--disabled { opacity: 0.4; pointer-events: none; }
.cdx-btn--icon { padding: 10px; }
.cdx-btn .cdx-btn-glyph { width: 15px; height: 15px; flex: none; }

/* ============ Forms ============ */
.cdx-field { display: flex; flex-direction: column; gap: 6px; font-family: var(--cd-font-body); }
.cdx-label { font-size: 13px; font-weight: 600; color: var(--cd-ink); }
.cdx-label .opt { font-weight: 400; color: var(--cd-steel); }
.cdx-help { font-size: 12.5px; color: var(--cd-steel); }
.cdx-input, .cdx-select, .cdx-textarea {
  font-family: var(--cd-font-body); font-size: 14.5px; color: var(--cd-ink);
  background: var(--cd-card); border: 1px solid #D5D1C6; border-radius: var(--cd-radius);
  padding: 10px 14px; width: 100%; box-sizing: border-box;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.cdx-input::placeholder, .cdx-textarea::placeholder { color: #9AA0AB; }
.cdx-input:hover, .cdx-select:hover, .cdx-textarea:hover { border-color: #BDB8AA; }
.cdx-input:focus, .cdx-select:focus, .cdx-textarea:focus {
  outline: none; border-color: var(--cd-ink); box-shadow: 0 0 0 3px rgba(11, 18, 32, 0.08);
}
.cdx-field--error .cdx-input, .cdx-field--error .cdx-select {
  border-color: var(--cqc-inadequate); box-shadow: 0 0 0 3px rgba(177, 14, 30, 0.07);
}
.cdx-field--error .cdx-help { color: var(--cqc-inadequate); }
.cdx-select {
  appearance: none; padding-right: 38px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1.5 6 6.5 11 1.5' fill='none' stroke='%235C6675' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 14px center;
}
.cdx-search { position: relative; }
.cdx-search .cdx-input { padding-left: 38px; }
.cdx-search::before {
  content: ""; position: absolute; left: 13px; top: 50%; width: 15px; height: 15px;
  transform: translateY(-50%); pointer-events: none;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='15' height='15' viewBox='0 0 15 15'%3E%3Ccircle cx='6.5' cy='6.5' r='5' fill='none' stroke='%235C6675' stroke-width='1.7'/%3E%3Cpath d='M10.5 10.5 14 14' stroke='%235C6675' stroke-width='1.7' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat center;
}
.cdx-check { display: inline-flex; align-items: center; gap: 9px; font-family: var(--cd-font-body); font-size: 14px; color: var(--cd-ink); cursor: pointer; }
.cdx-check input[type="checkbox"], .cdx-check input[type="radio"] {
  width: 17px; height: 17px; margin: 0; accent-color: var(--cd-ink); cursor: pointer;
}
/* Toggle */
.cdx-toggle { position: relative; display: inline-flex; align-items: center; gap: 10px; cursor: pointer; font-family: var(--cd-font-body); font-size: 14px; color: var(--cd-ink); }
.cdx-toggle input { position: absolute; opacity: 0; width: 0; height: 0; }
.cdx-toggle .trk {
  width: 38px; height: 22px; border-radius: 999px; background: #CFCBBF; flex: none;
  transition: background 0.18s; position: relative;
}
.cdx-toggle .trk::after {
  content: ""; position: absolute; top: 3px; left: 3px; width: 16px; height: 16px;
  border-radius: 999px; background: #FFFFFF; box-shadow: 0 1px 3px rgba(11,18,32,0.25);
  transition: left 0.18s;
}
.cdx-toggle input:checked + .trk { background: var(--cd-signal-600); }
.cdx-toggle input:checked + .trk::after { left: 19px; }
.cdx-toggle input:focus-visible + .trk { outline: 2px solid var(--cd-signal-600); outline-offset: 2px; }

/* ============ Pills, badges, tags ============ */
.cdx-rating {
  display: inline-flex; align-items: center; gap: 7px; padding: 5px 12px; border-radius: 999px;
  font-family: var(--cd-font-body); font-weight: 600; font-size: 13px; line-height: 1.2; white-space: nowrap;
}
.cdx-rating .dot { width: 8px; height: 8px; border-radius: 999px; flex: none; background: currentColor; }
.cdx-rating--outstanding { background: #E0EEE6; color: var(--cqc-outstanding); }
.cdx-rating--good { background: #E4F2E9; color: #20753F; }
.cdx-rating--requires { background: #F7EBDA; color: #9C5708; }
.cdx-rating--inadequate { background: #F5E0E2; color: var(--cqc-inadequate); }
.cdx-rating--notrated { background: #EAEBEE; color: var(--cqc-not-rated); }

.cdx-tag {
  display: inline-flex; align-items: center; padding: 4px 10px; border-radius: var(--cd-radius-sm);
  font-family: var(--cd-font-body); font-weight: 500; font-size: 12.5px;
  background: var(--cd-paper); border: 1px solid var(--cd-border); color: var(--cd-steel);
}
.cdx-status { display: inline-flex; align-items: center; gap: 7px; font-family: var(--cd-font-body); font-weight: 600; font-size: 13px; color: var(--cd-ink); }
.cdx-status .dot { width: 8px; height: 8px; border-radius: 999px; flex: none; }
.cdx-status--live .dot { background: var(--cd-signal-600); box-shadow: 0 0 0 3px rgba(14, 154, 99, 0.18); }
.cdx-status--paused .dot { background: #C7700A; }
.cdx-status--off .dot { background: #9AA0AB; }
.cdx-count {
  display: inline-flex; align-items: center; justify-content: center; min-width: 21px; height: 21px;
  padding: 0 6px; border-radius: 999px; font-family: var(--cd-font-data); font-size: 11.5px; font-weight: 500;
  background: var(--cd-ink); color: var(--cd-paper-text);
}
.cdx-count--signal { background: var(--cd-signal-600); }
.cdx-delta { font-family: var(--cd-font-data); font-size: 12.5px; font-weight: 500; }
.cdx-delta--up { color: var(--cd-signal-600); }
.cdx-delta--down { color: var(--cqc-inadequate); }

/* ============ Filters ============ */
.cdx-filterbar { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.cdx-filterbtn {
  display: inline-flex; align-items: center; gap: 8px; padding: 8px 13px;
  font-family: var(--cd-font-body); font-weight: 600; font-size: 13px; color: var(--cd-ink);
  background: var(--cd-card); border: 1px solid #D5D1C6; border-radius: var(--cd-radius); cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}
.cdx-filterbtn:hover { border-color: #BDB8AA; background: #F4F1EA; }
.cdx-filterbtn::after {
  content: ""; width: 10px; height: 7px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7' viewBox='0 0 10 7'%3E%3Cpath d='M1 1.2 5 5.8 9 1.2' fill='none' stroke='%235C6675' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat center;
}
.cdx-filterbtn--active { border-color: var(--cd-ink); background: var(--cd-card); box-shadow: inset 0 0 0 1px var(--cd-ink); }
.cdx-chip {
  display: inline-flex; align-items: center; gap: 8px; padding: 7px 8px 7px 13px;
  font-family: var(--cd-font-body); font-weight: 600; font-size: 13px;
  background: var(--cd-ink); color: var(--cd-paper-text); border-radius: 999px;
}
.cdx-chip .x {
  width: 17px; height: 17px; border-radius: 999px; border: none; cursor: pointer; padding: 0;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(244, 242, 236, 0.16); color: var(--cd-paper-text); font-size: 11px; line-height: 1;
}
.cdx-chip .x:hover { background: rgba(244, 242, 236, 0.32); }
.cdx-chip .k { font-weight: 400; opacity: 0.65; }
.cdx-clearall { font-family: var(--cd-font-body); font-weight: 600; font-size: 13px; color: var(--cd-signal-600); background: none; border: none; cursor: pointer; padding: 8px 6px; }
.cdx-clearall:hover { text-decoration: underline; }
/* Segmented control */
.cdx-seg { display: inline-flex; background: #ECE8DE; border-radius: var(--cd-radius); padding: 3px; gap: 2px; }
.cdx-seg button {
  font-family: var(--cd-font-body); font-weight: 600; font-size: 13px; color: var(--cd-steel);
  background: transparent; border: none; border-radius: 7px; padding: 7px 14px; cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.cdx-seg button:hover { color: var(--cd-ink); }
.cdx-seg button.on { background: var(--cd-card); color: var(--cd-ink); box-shadow: 0 1px 2px rgba(11,18,32,0.1); }

/* ============ Cards ============ */
.cdx-card { background: var(--cd-card); border: 1px solid var(--cd-border); border-radius: var(--cd-radius-lg); box-shadow: var(--cd-shadow-card); }
.cdx-stat { padding: 20px 22px 18px; display: flex; flex-direction: column; gap: 4px; }
.cdx-stat .lbl { font-family: var(--cd-font-data); font-size: 11px; letter-spacing: 0.07em; text-transform: uppercase; color: var(--cd-steel); }
.cdx-stat .val { font-family: var(--cd-font-head); font-weight: 700; font-size: 32px; letter-spacing: -0.02em; line-height: 1.1; color: var(--cd-ink); font-variant-numeric: tabular-nums; }
.cdx-stat .sub { display: flex; align-items: baseline; gap: 8px; font-family: var(--cd-font-body); font-size: 12.5px; color: var(--cd-steel); }

.cdx-est { padding: 18px 20px; display: flex; flex-direction: column; gap: 10px; }
.cdx-est .top { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; }
.cdx-est .nm { font-family: var(--cd-font-head); font-weight: 500; font-size: 17px; letter-spacing: -0.01em; color: var(--cd-ink); line-height: 1.25; }
.cdx-est .id { font-family: var(--cd-font-data); font-size: 11.5px; color: var(--cd-steel); margin-top: 3px; }
.cdx-est .meta { display: flex; flex-wrap: wrap; gap: 6px; }
.cdx-est .foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; border-top: 1px solid var(--cd-border); padding-top: 12px; margin-top: 2px; }
.cdx-est .foot .upd { font-family: var(--cd-font-data); font-size: 11.5px; color: var(--cd-steel); }

/* ============ Data table ============ */
.cdx-tablewrap { background: var(--cd-card); border: 1px solid var(--cd-border); border-radius: var(--cd-radius-lg); overflow: hidden; box-shadow: var(--cd-shadow-card); }
.cdx-table { width: 100%; border-collapse: collapse; font-family: var(--cd-font-body); font-size: 14px; color: var(--cd-ink); }
.cdx-table th {
  font-family: var(--cd-font-data); font-size: 11px; font-weight: 500; letter-spacing: 0.07em;
  text-transform: uppercase; color: var(--cd-steel); text-align: left;
  padding: 12px 16px; border-bottom: 1px solid var(--cd-border); background: #FBFAF7; white-space: nowrap;
}
.cdx-table th.sortable { cursor: pointer; }
.cdx-table th.sortable:hover { color: var(--cd-ink); }
.cdx-table th.sorted { color: var(--cd-ink); }
.cdx-table th.sorted::after { content: " ↓"; color: var(--cd-signal-600); }
.cdx-table td { padding: 13px 16px; border-bottom: 1px solid #F0EDE6; vertical-align: middle; }
.cdx-table tbody tr { transition: background 0.12s; }
.cdx-table tbody tr:hover { background: #FAF8F3; }
.cdx-table tbody tr.selected { background: #F0F7F3; }
.cdx-table tbody tr:last-child td { border-bottom: none; }
.cdx-table .mono { font-family: var(--cd-font-data); font-size: 12.5px; color: var(--cd-steel); }
.cdx-table .num { font-variant-numeric: tabular-nums; text-align: right; }
.cdx-table .primarycell { font-weight: 600; }
.cdx-table .primarycell .sub { font-family: var(--cd-font-data); font-size: 11.5px; font-weight: 400; color: var(--cd-steel); margin-top: 2px; }
.cdx-table .ck { width: 36px; padding-right: 0; }
.cdx-table .ck input { width: 16px; height: 16px; accent-color: var(--cd-ink); margin: 0; display: block; }
.cdx-rowlink { font-weight: 600; font-size: 13px; color: var(--cd-signal-600); text-decoration: none; }
.cdx-rowlink:hover { text-decoration: underline; }
/* table toolbar + pagination */
.cdx-tabletop { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 14px 16px; border-bottom: 1px solid var(--cd-border); flex-wrap: wrap; }
.cdx-tablefoot { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 12px 16px; border-top: 1px solid var(--cd-border); font-family: var(--cd-font-body); font-size: 13px; color: var(--cd-steel); flex-wrap: wrap; }
.cdx-pages { display: flex; gap: 4px; }
.cdx-pages button {
  min-width: 30px; height: 30px; padding: 0 8px; border-radius: var(--cd-radius-sm); border: none;
  background: transparent; font-family: var(--cd-font-body); font-weight: 600; font-size: 13px;
  color: var(--cd-steel); cursor: pointer;
}
.cdx-pages button:hover { background: #F0EDE6; color: var(--cd-ink); }
.cdx-pages button.on { background: var(--cd-ink); color: var(--cd-paper-text); }

/* ============ Tabs ============ */
.cdx-tabs { display: flex; gap: 2px; border-bottom: 1px solid var(--cd-border); }
.cdx-tabs button {
  font-family: var(--cd-font-body); font-weight: 600; font-size: 14px; color: var(--cd-steel);
  background: none; border: none; padding: 10px 14px 12px; cursor: pointer; position: relative;
  display: inline-flex; align-items: center; gap: 8px;
}
.cdx-tabs button:hover { color: var(--cd-ink); }
.cdx-tabs button.on { color: var(--cd-ink); }
.cdx-tabs button.on::after { content: ""; position: absolute; left: 10px; right: 10px; bottom: -1px; height: 2.5px; border-radius: 2px; background: var(--cd-signal-600); }
