/* ═════════════════════════════════════════════════════════════════════
   Uboros Design System — components.css
   Reusable component classes. All values reference tokens.css variables.
   Class prefix: `u-` (avoid clashing with product CSS).
   ═════════════════════════════════════════════════════════════════════ */

/* ── Reset / page ────────────────────────────────────────────────── */

.u-app {
  font-family: var(--font-body);
  font-size: var(--type-body);
  line-height: var(--leading-normal);
  color: var(--ink-hi);
  background: var(--bg);
}

/* ── Buttons ─────────────────────────────────────────────────────── */

.u-btn {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-body);
  font-weight: var(--weight-medium);
  font-size: var(--type-body-sm);
  line-height: 1;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  padding: 0 var(--space-4);
  height: var(--btn-h-md, 32px);
  cursor: pointer;
  transition: background-color var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out),
              transform var(--dur-fast) var(--ease-out);
  white-space: nowrap;
  user-select: none;
}
.u-btn:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
}
.u-btn:active {
  transform: translateY(0.5px);
}

/* Primary — solid ink */
.u-btn-primary {
  background: var(--ink-hi);
  color: var(--ink-inverse);
  border-color: var(--ink-hi);
}
.u-btn-primary:hover { opacity: 0.92; }

/* Accent — sage */
.u-btn-accent {
  background: var(--sage);
  color: var(--ink-inverse);
  border-color: var(--sage);
}
[data-theme="dark"] .u-btn-accent { color: var(--sage-ink); }
.u-btn-accent:hover { opacity: 0.92; }

/* Ghost — surface with rule */
.u-btn-ghost {
  background: var(--surface);
  color: var(--ink-md);
  border-color: var(--rule);
  box-shadow: var(--shadow-sm);
}
.u-btn-ghost:hover {
  color: var(--ink-hi);
  border-color: var(--rule-strong);
}

/* Quiet — text-only */
.u-btn-quiet {
  background: transparent;
  color: var(--ink-md);
  border-color: transparent;
}
.u-btn-quiet:hover {
  color: var(--ink-hi);
  background: var(--surface-2);
}

/* Danger */
.u-btn-danger {
  background: var(--danger);
  color: white;
  border-color: var(--danger);
}
.u-btn-danger:hover { opacity: 0.92; }

/* Size modifiers */
.u-btn-lg {
  height: var(--btn-h-lg, 40px);
  padding: 0 var(--space-5);
  font-size: var(--type-body);
}
.u-btn-sm {
  height: 26px;
  padding: 0 var(--space-3);
  font-size: var(--type-caption);
  border-radius: var(--radius-sm);
}

/* Icon-only */
.u-btn-icon {
  padding: 0;
  width: var(--btn-h-md, 32px);
}

/* ── Inputs / fields ─────────────────────────────────────────────── */

.u-input {
  width: 100%;
  appearance: none;
  font-family: var(--font-body);
  font-size: var(--type-body);
  color: var(--ink-hi);
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: var(--radius-md);
  padding: var(--space-2) var(--space-3);
  height: 36px;
  line-height: 1.4;
  transition: border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
}
.u-input::placeholder { color: var(--ink-xl); }
.u-input:hover { border-color: var(--rule-strong); }
.u-input:focus-visible {
  outline: none;
  border-color: var(--sage);
  box-shadow: 0 0 0 3px var(--sage-soft);
}

.u-textarea {
  composes: u-input;
  height: auto;
  min-height: 96px;
  padding: var(--space-3);
  resize: vertical;
}

/* Field row — label + value pattern */
.u-field-row {
  display: grid;
  grid-template-columns: var(--field-label-w, 140px) 1fr auto;
  gap: var(--space-4);
  align-items: center;
  padding: var(--field-pad-y, 12px) var(--field-pad-x, 16px);
  border-radius: var(--radius-md);
  transition: background-color var(--dur-fast) var(--ease-out);
}
.u-field-row:hover { background: var(--surface-2); }
.u-field-label {
  font-size: var(--field-label-size, 12.5px);
  color: var(--ink-lo);
}
.u-field-val {
  font-size: var(--field-val-size, 14px);
  color: var(--ink-hi);
}
.u-field-val--mono {
  font-family: var(--font-mono);
  font-size: calc(var(--field-val-size, 14px) - 1px);
}

/* ── Cards ───────────────────────────────────────────────────────── */

.u-card {
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: var(--card-radius, var(--radius-xl));
  box-shadow: var(--shadow-md);
  overflow: hidden;
}
.u-card-head {
  padding: var(--card-pad-y, 20px) var(--card-pad-x, 24px) calc(var(--card-pad-y, 20px) - 8px);
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
}
.u-card-head__num {
  font-family: var(--font-mono);
  font-size: var(--type-eyebrow);
  color: var(--ink-lo);
  background: var(--surface-2);
  border-radius: var(--radius-sm);
  padding: 3px 8px;
  align-self: flex-start;
  margin-top: 2px;
}
.u-card-title {
  font-family: var(--font-display);
  font-size: var(--card-title-size, 19px);
  font-weight: var(--weight-medium);
  letter-spacing: var(--track-snug);
  margin: 0;
}
.u-card-sub {
  font-size: var(--card-sub-size, 12.5px);
  color: var(--ink-lo);
  margin-top: 3px;
}
.u-card-actions {
  margin-left: auto;
  display: flex;
  gap: var(--space-2);
}
.u-card-body {
  padding: 0 var(--card-pad-x, 24px) var(--card-pad-y, 20px);
}

/* ── Chips ───────────────────────────────────────────────────────── */

.u-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  background: var(--surface-2);
  border: 1px solid var(--rule);
  color: var(--ink-md);
  border-radius: var(--radius-pill);
  padding: 4px 10px;
  font-size: var(--type-caption);
  line-height: 1.2;
}
.u-chip--accent {
  background: var(--sage-soft);
  border-color: var(--sage-soft-2);
  color: var(--sage);
}
.u-chip--warn {
  background: var(--warn-soft);
  border-color: var(--warn);
  color: var(--warn);
}
.u-chip--danger {
  background: var(--danger-soft);
  border-color: var(--danger);
  color: var(--danger);
}
.u-chip--mono {
  font-family: var(--font-mono);
}
.u-chip-dot {
  width: 6px;
  height: 6px;
  border-radius: var(--radius-pill);
  background: currentColor;
}

/* ── Badges (square pills) ───────────────────────────────────────── */

.u-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 2px 8px;
  border-radius: var(--radius-xs);
  font-family: var(--font-mono);
  font-size: 10.5px;
  letterspacing: var(--track-mono);
  text-transform: uppercase;
  background: var(--surface-2);
  color: var(--ink-md);
  border: 1px solid var(--rule);
}

/* ── Avatar / tenant dot ─────────────────────────────────────────── */

.u-avatar {
  width: 30px;
  height: 30px;
  border-radius: var(--radius-pill);
  background: var(--sand-soft);
  color: var(--sand-ink);
  font-family: var(--font-display);
  font-weight: var(--weight-semibold);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  border: 1px solid var(--rule);
}
.u-tenant-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: var(--radius-pill);
  padding: 4px 12px 4px 4px;
  font-size: var(--type-body-sm);
  color: var(--ink-hi);
  cursor: pointer;
  height: 32px;
}
.u-tenant-dot {
  width: 22px;
  height: 22px;
  border-radius: var(--radius-pill);
  background: var(--sage);
  color: var(--ink-inverse);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: var(--weight-semibold);
}
[data-theme="dark"] .u-tenant-dot { color: var(--sage-ink); }

/* ── Status indicator ────────────────────────────────────────────── */

.u-status {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--type-body-sm);
  color: var(--ink-md);
}
.u-status-dot {
  width: 6px;
  height: 6px;
  border-radius: var(--radius-pill);
  background: var(--sage);
  box-shadow: 0 0 0 3px var(--sage-soft);
}
.u-status-dot--warn {
  background: var(--warn);
  box-shadow: 0 0 0 3px var(--warn-soft);
}
.u-status-dot--danger {
  background: var(--danger);
  box-shadow: 0 0 0 3px var(--danger-soft);
}

/* ── Segmented control ───────────────────────────────────────────── */

.u-seg {
  display: inline-flex;
  background: var(--surface-2);
  border-radius: var(--radius-pill);
  padding: 4px;
  gap: 2px;
}
.u-seg-item {
  padding: 6px 14px;
  border-radius: var(--radius-pill);
  font-size: var(--type-body-sm);
  color: var(--ink-md);
  cursor: pointer;
  transition: background-color var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out);
  background: transparent;
  border: none;
  font-family: var(--font-body);
}
.u-seg-item:hover { color: var(--ink-hi); }
.u-seg-item[aria-selected="true"] {
  background: var(--surface);
  color: var(--ink-hi);
  font-weight: var(--weight-medium);
  box-shadow: var(--shadow-sm);
}

/* ── Page chrome (topbar + rail) ─────────────────────────────────── */

.u-topbar {
  height: var(--topbar-h, 60px);
  display: flex;
  align-items: center;
  padding: 0 calc(var(--main-pad-x, 32px) - 4px);
  gap: var(--space-5);
  background: color-mix(in srgb, var(--bg) 80%, transparent);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--rule);
}

.u-rail {
  width: var(--rail-w, 240px);
  flex: 0 0 var(--rail-w, 240px);
  padding: var(--rail-pad-y, 24px) var(--rail-pad-x, 16px);
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.u-rail-eyebrow {
  font-size: var(--type-eyebrow);
  color: var(--ink-lo);
  padding: 10px var(--rail-item-pad-x, 12px) 6px;
  letter-spacing: var(--track-eyebrow);
}
.u-rail-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--rail-item-pad-y, 8px) var(--rail-item-pad-x, 12px);
  border-radius: var(--radius-md);
  font-size: var(--rail-font, 13px);
  color: var(--ink-md);
  cursor: pointer;
  transition: background-color var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out);
  white-space: nowrap;
}
.u-rail-item:hover { color: var(--ink-hi); background: var(--surface-2); }
.u-rail-item[aria-current="page"] {
  background: var(--surface);
  color: var(--ink-hi);
  box-shadow: var(--shadow-sm), 0 0 0 1px var(--rule);
  font-weight: var(--weight-medium);
}
.u-rail-count {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: var(--type-eyebrow);
  color: var(--ink-lo);
}

/* ── Save bar (sticky bottom) ────────────────────────────────────── */

.u-savebar {
  height: 56px;
  border-top: 1px solid var(--rule);
  background: var(--surface);
  display: flex;
  align-items: center;
  padding: 0 var(--main-pad-x, 32px);
  gap: var(--space-4);
}
.u-savebar-status {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--type-body-sm);
  color: var(--ink-md);
}
.u-savebar-actions {
  margin-left: auto;
  display: flex;
  gap: var(--space-2);
}

/* ── Page header ─────────────────────────────────────────────────── */

.u-pagehead {
  padding: var(--pagehead-pad-y, 24px) 4px calc(var(--pagehead-pad-y, 24px) + 4px);
  display: flex;
  align-items: flex-end;
  gap: var(--space-6);
  flex-wrap: wrap;
}
.u-page-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--page-eyebrow-size, 11.5px);
  color: var(--ink-lo);
  margin-bottom: var(--space-3);
}
.u-page-title {
  font-family: var(--font-display);
  font-size: var(--page-title-size, 42px);
  line-height: 1.02;
  letter-spacing: var(--track-tight);
  font-weight: var(--weight-medium);
  margin: 0;
}
.u-page-sub {
  color: var(--ink-md);
  font-size: var(--page-sub-size, 14px);
  margin: var(--pagehead-gap, 8px) 0 0;
  max-width: 480px;
}
.u-page-actions {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

/* ── Voice card (accent quote pattern) ───────────────────────────── */

.u-voice-card {
  background: var(--sage-soft);
  border-radius: var(--radius-lg);
  padding: var(--voice-pad, 22px);
  border: 1px solid var(--sage-soft-2);
}
.u-voice-text {
  font-family: var(--font-display);
  font-size: var(--voice-size, 19px);
  line-height: var(--leading-snug);
  letter-spacing: var(--track-snug);
  font-weight: var(--weight-regular);
  color: var(--ink-hi);
  margin: 0;
}
[data-theme="dark"] .u-voice-text { color: var(--sage-ink); }

/* ── Misc ────────────────────────────────────────────────────────── */

.u-divider {
  height: 1px;
  background: var(--rule);
  border: none;
  margin: var(--space-4) 0;
}
.u-divider--dashed {
  background: none;
  border-top: 1px dashed var(--rule);
}

.u-kbd {
  font-family: var(--font-mono);
  font-size: 10.5px;
  background: var(--surface-2);
  border: 1px solid var(--rule);
  border-radius: var(--radius-xs);
  padding: 1px 5px;
  color: var(--ink-md);
}
