/* =============================================================
   BLACKNODE v3 — Component library (depends on tokens-v3.css)
   ============================================================= */

/* ============ LAYOUT PRIMITIVES ============ */
.bn-shell {
  min-height: 100vh;
  background:
    radial-gradient(ellipse 800px 600px at 80% -20%, var(--bn-accent-soft), transparent 70%),
    radial-gradient(ellipse 600px 400px at -10% 90%, rgba(74, 111, 165, 0.06), transparent 70%),
    var(--bn-bg-page);
}
.bn-container {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 var(--bn-s-6);
}
.bn-container--narrow { max-width: 720px; }
.bn-container--wide   { max-width: 1440px; }

/* ============ TOP NAV BAR ============ */
.bn-topbar {
  position: sticky;
  top: 0;
  z-index: var(--bn-z-sticky);
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
  padding: 0 var(--bn-s-6);
  background: rgba(248, 246, 242, 0.78);
  backdrop-filter: saturate(1.4) blur(14px);
  -webkit-backdrop-filter: saturate(1.4) blur(14px);
  border-bottom: 1px solid var(--bn-border-soft);
}
.bn-topbar__brand {
  display: flex;
  align-items: center;
  gap: var(--bn-s-2);
  font-weight: var(--bn-fw-semibold);
  letter-spacing: var(--bn-ls-tight);
  color: var(--bn-ink);
}
.bn-topbar__brand svg { width: 22px; height: 22px; }
.bn-topbar__nav {
  display: flex;
  gap: var(--bn-s-1);
  align-items: center;
}
.bn-topbar__nav a {
  font-size: var(--bn-text-md);
  color: var(--bn-ink-secondary);
  padding: var(--bn-s-2) var(--bn-s-3);
  border-radius: var(--bn-r-pill);
  transition: background var(--bn-dur-fast) var(--bn-ease), color var(--bn-dur-fast) var(--bn-ease);
}
.bn-topbar__nav a:hover { color: var(--bn-ink); background: rgba(26, 24, 21, 0.05); }
.bn-topbar__nav a.is-active {
  color: var(--bn-ink);
  background: rgba(26, 24, 21, 0.08);
  font-weight: var(--bn-fw-medium);
}
.bn-topbar__right { display: flex; align-items: center; gap: var(--bn-s-2); }

/* ============ BUTTONS ============ */
.bn-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--bn-s-2);
  font-family: var(--bn-font-sans);
  font-size: var(--bn-text-md);
  font-weight: var(--bn-fw-medium);
  line-height: 1;
  letter-spacing: var(--bn-ls-normal);
  padding: 10px 18px;
  border-radius: var(--bn-r-pill);
  border: 1px solid transparent;
  background: transparent;
  color: var(--bn-ink);
  cursor: pointer;
  white-space: nowrap;
  user-select: none;
  transition:
    background var(--bn-dur-fast) var(--bn-ease),
    border-color var(--bn-dur-fast) var(--bn-ease),
    color var(--bn-dur-fast) var(--bn-ease),
    transform var(--bn-dur-fast) var(--bn-ease),
    box-shadow var(--bn-dur-fast) var(--bn-ease);
}
.bn-btn:focus-visible {
  outline: 2px solid var(--bn-accent);
  outline-offset: 2px;
}
.bn-btn:active { transform: translateY(0.5px) scale(0.99); }

.bn-btn--primary {
  background: var(--bn-ink);
  color: var(--bn-ink-inverse);
  border-color: var(--bn-ink);
  box-shadow: var(--bn-shadow-sm), inset 0 1px 0 rgba(255,255,255,0.1);
}
.bn-btn--primary:hover { background: #28241F; }

.bn-btn--accent {
  background: var(--bn-accent);
  color: #fff;
  border-color: var(--bn-accent);
  box-shadow: 0 4px 10px var(--bn-accent-glow), inset 0 1px 0 rgba(255,255,255,0.18);
}
.bn-btn--accent:hover { background: var(--bn-accent-hover); }

.bn-btn--secondary {
  background: var(--bn-bg-surface-1);
  color: var(--bn-ink);
  border-color: var(--bn-border);
}
.bn-btn--secondary:hover {
  background: var(--bn-bg-surface-2);
  border-color: var(--bn-border-strong);
}

.bn-btn--ghost {
  background: transparent;
  color: var(--bn-ink-secondary);
}
.bn-btn--ghost:hover {
  background: rgba(26, 24, 21, 0.05);
  color: var(--bn-ink);
}

.bn-btn--icon {
  width: 36px;
  height: 36px;
  padding: 0;
  flex-shrink: 0;
  background: var(--bn-bg-surface-1);
  border-color: var(--bn-border);
  border-radius: var(--bn-r-md);
}
.bn-btn--icon:hover { background: var(--bn-bg-surface-2); }

.bn-btn--lg { padding: 14px 26px; font-size: var(--bn-text-base); min-height: 44px; }
.bn-btn--sm { padding: 7px 12px; font-size: var(--bn-text-sm); min-height: 32px; }
.bn-btn--full { width: 100%; }
.bn-btn[aria-pressed="true"] { background: var(--bn-bg-surface-2); }

/* ============ CARDS ============ */
.bn-card {
  background: var(--bn-bg-surface-1);
  border: 1px solid var(--bn-border-soft);
  border-radius: var(--bn-r-xl);
  padding: var(--bn-s-6);
  transition:
    border-color var(--bn-dur) var(--bn-ease),
    background var(--bn-dur) var(--bn-ease),
    transform var(--bn-dur) var(--bn-ease),
    box-shadow var(--bn-dur) var(--bn-ease);
}
.bn-card--interactive { cursor: pointer; }
.bn-card--interactive:hover {
  border-color: var(--bn-border-strong);
  background: var(--bn-bg-surface-2);
  transform: translateY(-1px);
  box-shadow: var(--bn-shadow-md);
}
.bn-card--premium {
  background:
    linear-gradient(135deg, var(--bn-bg-surface-1) 0%, var(--bn-bg-surface-2) 100%);
  border-color: var(--bn-border);
  box-shadow: var(--bn-shadow-md), var(--bn-inset-highlight);
}
.bn-card--inverse {
  background: var(--bn-bg-inverse);
  color: var(--bn-ink-inverse);
  border-color: rgba(255,255,255,0.06);
}

/* ============ INPUTS ============ */
.bn-input, .bn-textarea, .bn-select {
  width: 100%;
  font-family: var(--bn-font-sans);
  font-size: var(--bn-text-base);
  font-weight: var(--bn-fw-regular);
  line-height: var(--bn-lh-normal);
  color: var(--bn-ink);
  background: var(--bn-bg-page);
  border: 1px solid var(--bn-border);
  border-radius: var(--bn-r-md);
  padding: 10px 14px;
  transition:
    border-color var(--bn-dur-fast) var(--bn-ease),
    box-shadow var(--bn-dur-fast) var(--bn-ease),
    background var(--bn-dur-fast) var(--bn-ease);
}
.bn-input:hover, .bn-textarea:hover, .bn-select:hover { border-color: var(--bn-border-strong); }
.bn-input:focus, .bn-textarea:focus, .bn-select:focus {
  outline: none;
  border-color: var(--bn-accent);
  box-shadow: 0 0 0 3px var(--bn-accent-soft);
}
.bn-input::placeholder { color: var(--bn-ink-muted); }
.bn-textarea { min-height: 96px; resize: vertical; }

.bn-label {
  display: block;
  margin-bottom: var(--bn-s-2);
  font-size: var(--bn-text-sm);
  font-weight: var(--bn-fw-medium);
  color: var(--bn-ink);
}
.bn-help {
  margin-top: var(--bn-s-2);
  font-size: var(--bn-text-xs);
  color: var(--bn-ink-muted);
}

/* ============ COMPOSER (chat input bar) ============ */
.bn-composer {
  display: flex;
  align-items: center;
  gap: var(--bn-s-2);
  padding: var(--bn-s-2) var(--bn-s-3);
  background: var(--bn-bg-surface-1);
  border: 1px solid var(--bn-border);
  border-radius: var(--bn-r-pill);
  box-shadow: var(--bn-shadow-md), var(--bn-inset-highlight);
  transition: border-color var(--bn-dur-fast) var(--bn-ease), box-shadow var(--bn-dur-fast) var(--bn-ease);
}
.bn-composer:focus-within {
  border-color: var(--bn-border-strong);
  box-shadow: var(--bn-shadow-lg), 0 0 0 3px var(--bn-accent-soft);
}
.bn-composer__field {
  flex: 1;
  font-family: var(--bn-font-sans);
  font-size: var(--bn-text-base);
  color: var(--bn-ink);
  background: transparent;
  border: none;
  outline: none;
  padding: var(--bn-s-2);
}
.bn-composer__field::placeholder { color: var(--bn-ink-muted); }
.bn-composer__icon-btn {
  width: 36px; height: 36px;
  flex-shrink: 0;
  display: grid;
  place-items: center;
  background: transparent;
  color: var(--bn-ink-secondary);
  border: none;
  border-radius: var(--bn-r-md);
  cursor: pointer;
  transition: background var(--bn-dur-fast) var(--bn-ease), color var(--bn-dur-fast) var(--bn-ease), transform var(--bn-dur-fast) var(--bn-ease);
}
.bn-composer__icon-btn:hover { background: rgba(26, 24, 21, 0.05); color: var(--bn-ink); }
.bn-composer__icon-btn:active { transform: scale(0.94); }
.bn-composer__icon-btn.is-recording { color: var(--bn-accent); background: var(--bn-accent-soft); animation: bn-mic-pulse 1.4s var(--bn-ease) infinite; }
@keyframes bn-mic-pulse {
  0%, 100% { box-shadow: 0 0 0 0 var(--bn-accent-soft); }
  50%      { box-shadow: 0 0 0 6px transparent; }
}
.bn-composer__send {
  width: 36px; height: 36px;
  flex-shrink: 0;
  display: grid;
  place-items: center;
  background: var(--bn-ink);
  color: var(--bn-ink-inverse);
  border: none;
  border-radius: var(--bn-r-pill);
  cursor: pointer;
  transition: background var(--bn-dur-fast) var(--bn-ease), transform var(--bn-dur-fast) var(--bn-ease);
}
.bn-composer__send:hover { background: var(--bn-accent); transform: scale(1.05); }
.bn-composer__send:active { transform: scale(0.96); }

/* ============ PILLS / CHIPS / BADGES ============ */
.bn-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--bn-s-2);
  font-size: var(--bn-text-xs);
  font-weight: var(--bn-fw-medium);
  padding: 5px 11px;
  background: var(--bn-bg-surface-1);
  border: 1px solid var(--bn-border);
  border-radius: var(--bn-r-pill);
  color: var(--bn-ink-secondary);
}
.bn-pill--accent {
  background: var(--bn-accent-soft);
  border-color: transparent;
  color: var(--bn-accent);
}
.bn-pill--success { background: rgba(74, 124, 89, 0.12); color: var(--bn-success); border-color: transparent; }
.bn-pill--warning { background: rgba(194, 138, 46, 0.12); color: var(--bn-warning); border-color: transparent; }
.bn-pill--danger  { background: rgba(197, 57, 42, 0.10); color: var(--bn-danger); border-color: transparent; }
.bn-pill__dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.bn-pill__dot--pulse {
  animation: bn-pulse 1.6s var(--bn-ease) infinite;
}
@keyframes bn-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.5; transform: scale(0.85); }
}

/* ============ MODAL ============ */
.bn-modal-root {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  padding: var(--bn-s-6);
  background: rgba(26, 24, 21, 0.32);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: var(--bn-z-modal);
  animation: bn-fade-in var(--bn-dur) var(--bn-ease);
}
.bn-modal-root[hidden] { display: none !important; }
.bn-modal {
  width: min(460px, 100%);
  max-height: 90vh;
  overflow-y: auto;
  background: var(--bn-bg-page);
  border: 1px solid var(--bn-border);
  border-radius: var(--bn-r-2xl);
  padding: var(--bn-s-7);
  box-shadow: var(--bn-shadow-xl);
  animation: bn-modal-in var(--bn-dur) var(--bn-ease-spring);
}
.bn-modal__head {
  display: flex;
  align-items: flex-start;
  gap: var(--bn-s-3);
  margin-bottom: var(--bn-s-5);
}
.bn-modal__icon {
  width: 40px; height: 40px;
  display: grid; place-items: center;
  background: var(--bn-accent-soft);
  color: var(--bn-accent);
  border-radius: var(--bn-r-md);
  font-size: 18px;
  flex-shrink: 0;
}
.bn-modal__title {
  font-family: var(--bn-font-display);
  font-size: var(--bn-text-xl);
  font-weight: var(--bn-fw-semibold);
  line-height: var(--bn-lh-snug);
  letter-spacing: var(--bn-ls-tight);
  color: var(--bn-ink);
}
.bn-modal__body {
  color: var(--bn-ink-secondary);
  font-size: var(--bn-text-md);
  line-height: var(--bn-lh-relaxed);
}
.bn-modal__field { margin-bottom: var(--bn-s-3); }
.bn-modal__label {
  display: block;
  margin-bottom: var(--bn-s-2);
  font-size: var(--bn-text-sm);
  font-weight: var(--bn-fw-medium);
  color: var(--bn-ink);
}
.bn-modal__link {
  color: var(--bn-accent);
  font-size: var(--bn-text-sm);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border-bottom: 1px solid transparent;
  transition: border-color var(--bn-dur-fast) var(--bn-ease);
}
.bn-modal__link:hover { border-bottom-color: currentColor; }
.bn-modal__actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--bn-s-2);
  margin-top: var(--bn-s-6);
}
@keyframes bn-fade-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes bn-modal-in {
  from { opacity: 0; transform: scale(0.96) translateY(8px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

/* ============ TOAST ============ */
.bn-toasts {
  position: fixed;
  top: 80px;
  right: var(--bn-s-6);
  display: flex;
  flex-direction: column;
  gap: var(--bn-s-2);
  z-index: var(--bn-z-toast);
  pointer-events: none;
  max-width: 380px;
}
.bn-toast {
  display: flex;
  align-items: flex-start;
  gap: var(--bn-s-3);
  padding: var(--bn-s-3) var(--bn-s-4);
  background: var(--bn-bg-page);
  border: 1px solid var(--bn-border);
  border-radius: var(--bn-r-md);
  box-shadow: var(--bn-shadow-lg);
  pointer-events: auto;
  animation: bn-toast-in var(--bn-dur-slow) var(--bn-ease-spring);
  font-size: var(--bn-text-sm);
  color: var(--bn-ink);
}
.bn-toast--success { border-left: 3px solid var(--bn-success); }
.bn-toast--error   { border-left: 3px solid var(--bn-danger); }
.bn-toast--info    { border-left: 3px solid var(--bn-info); }
@keyframes bn-toast-in {
  from { opacity: 0; transform: translateX(20px); }
  to   { opacity: 1; transform: translateX(0); }
}

/* ============ DROPDOWN ============ */
.bn-dropdown {
  position: absolute;
  min-width: 220px;
  background: var(--bn-bg-page);
  border: 1px solid var(--bn-border);
  border-radius: var(--bn-r-md);
  box-shadow: var(--bn-shadow-lg);
  padding: var(--bn-s-1);
  animation: bn-dropdown-in var(--bn-dur-fast) var(--bn-ease);
}
.bn-dropdown[hidden] { display: none !important; }
.bn-dropdown__label {
  padding: var(--bn-s-2) var(--bn-s-3);
  font-size: var(--bn-text-xs);
  color: var(--bn-ink-muted);
  font-weight: var(--bn-fw-medium);
}
.bn-dropdown__item {
  display: flex;
  align-items: center;
  gap: var(--bn-s-3);
  width: 100%;
  padding: var(--bn-s-2) var(--bn-s-3);
  background: transparent;
  border: none;
  border-radius: var(--bn-r-sm);
  font-size: var(--bn-text-md);
  color: var(--bn-ink);
  cursor: pointer;
  text-align: left;
  transition: background var(--bn-dur-fast) var(--bn-ease);
}
.bn-dropdown__item:hover { background: var(--bn-bg-surface-1); }
.bn-dropdown__item--danger { color: var(--bn-danger); }
.bn-dropdown__sep {
  height: 1px;
  background: var(--bn-border-soft);
  margin: var(--bn-s-1) 0;
}
@keyframes bn-dropdown-in {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ============ KBD ============ */
kbd {
  display: inline-flex;
  align-items: center;
  padding: 2px 6px;
  font-family: var(--bn-font-mono);
  font-size: 11px;
  background: var(--bn-bg-surface-2);
  border: 1px solid var(--bn-border);
  border-radius: var(--bn-r-xs);
  color: var(--bn-ink-secondary);
}

/* ============ AVATAR ============ */
.bn-avatar {
  width: 36px; height: 36px;
  display: grid;
  place-items: center;
  background: var(--bn-ink);
  color: var(--bn-ink-inverse);
  border-radius: var(--bn-r-pill);
  font-size: var(--bn-text-sm);
  font-weight: var(--bn-fw-medium);
  cursor: pointer;
  border: 1px solid transparent;
  transition: transform var(--bn-dur-fast) var(--bn-ease), box-shadow var(--bn-dur-fast) var(--bn-ease);
}
.bn-avatar:hover { transform: scale(1.05); box-shadow: var(--bn-shadow-sm); }
.bn-avatar--signed-out {
  background: var(--bn-bg-surface-1);
  color: var(--bn-ink);
  border-color: var(--bn-border);
  padding: 0 14px;
  width: auto;
  height: 36px;
  border-radius: var(--bn-r-pill);
  font-size: var(--bn-text-md);
}

/* ============ TABS ============ */
.bn-tabs {
  display: inline-flex;
  background: var(--bn-bg-surface-1);
  border: 1px solid var(--bn-border);
  border-radius: var(--bn-r-pill);
  padding: 3px;
  gap: 2px;
}
.bn-tab {
  display: inline-flex;
  align-items: center;
  gap: var(--bn-s-2);
  padding: 6px 14px;
  font-size: var(--bn-text-sm);
  font-weight: var(--bn-fw-medium);
  color: var(--bn-ink-secondary);
  background: transparent;
  border: none;
  border-radius: var(--bn-r-pill);
  cursor: pointer;
  transition: background var(--bn-dur-fast) var(--bn-ease), color var(--bn-dur-fast) var(--bn-ease);
}
.bn-tab:hover { color: var(--bn-ink); }
.bn-tab.is-active {
  background: var(--bn-bg-page);
  color: var(--bn-ink);
  box-shadow: var(--bn-shadow-xs);
}

/* ============ ICON CHIP (brand box) ============ */
.bn-icon-chip {
  width: 40px; height: 40px;
  display: grid;
  place-items: center;
  border-radius: var(--bn-r-md);
  overflow: hidden;
  position: relative;
  isolation: isolate;
}
.bn-icon-chip iconify-icon { filter: drop-shadow(0 1px 1px rgba(0,0,0,0.20)); }
.bn-icon-chip--sm { width: 32px; height: 32px; border-radius: var(--bn-r-sm); }
.bn-icon-chip--lg { width: 48px; height: 48px; border-radius: var(--bn-r-lg); }

/* ============ DIVIDER ============ */
.bn-divider {
  height: 1px;
  background: var(--bn-border-soft);
  margin: var(--bn-s-5) 0;
  border: none;
}

/* ============ SECTION HEADINGS ============ */
.bn-section__title {
  font-size: var(--bn-text-sm);
  font-weight: var(--bn-fw-semibold);
  color: var(--bn-ink-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 var(--bn-s-3) 0;
}

/* ============ LINK ============ */
.bn-link {
  color: var(--bn-accent);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color var(--bn-dur-fast) var(--bn-ease);
}
.bn-link:hover { border-bottom-color: currentColor; }

/* ============ FOCUS RING ============ */
:focus-visible {
  outline: 2px solid var(--bn-accent);
  outline-offset: 2px;
  border-radius: var(--bn-r-xs);
}

/* ============ SCREEN-READER-ONLY (visually hidden) ============ */
.bn-sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ============ DISABLED / BUSY STATE ============ */
.bn-btn[disabled],
.bn-btn[aria-busy="true"],
.bn-btn:disabled,
button[disabled] {
  opacity: 0.55;
  cursor: not-allowed !important;
  pointer-events: none;
}
.bn-btn[aria-busy="true"] {
  pointer-events: none;
}

/* ============ LOADING SHIMMER ============ */
.bn-shimmer {
  position: relative;
  overflow: hidden;
  background: var(--bn-bg-surface-1);
  border-radius: var(--bn-r-md);
}
.bn-shimmer::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255, 255, 255, 0.30) 50%,
    transparent 100%
  );
  animation: bn-shimmer 1.4s linear infinite;
}
@keyframes bn-shimmer {
  from { transform: translateX(-100%); }
  to   { transform: translateX(100%); }
}

/* Skeleton sizes */
.bn-skel { height: 14px; border-radius: var(--bn-r-sm); }
.bn-skel--lg { height: 22px; }
.bn-skel--sm { height: 10px; }
.bn-skel--circle { border-radius: 50%; aspect-ratio: 1; height: 40px; }

/* Spinner */
@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.bn-spin { animation: spin 1s linear infinite; }

/* ============ TOOLTIP (data-bn-tooltip) ============ */
[data-bn-tooltip] { position: relative; }
[data-bn-tooltip]::after {
  content: attr(data-bn-tooltip);
  position: absolute;
  left: 100%; top: 50%;
  transform: translate(8px, -50%);
  background: var(--bn-ink);
  color: var(--bn-ink-inverse);
  font-size: 11px;
  font-weight: var(--bn-fw-medium);
  padding: 4px 8px;
  border-radius: var(--bn-r-sm);
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--bn-dur-fast) var(--bn-ease), transform var(--bn-dur-fast) var(--bn-ease);
  z-index: var(--bn-z-tooltip);
}
[data-bn-tooltip]:hover::after,
[data-bn-tooltip]:focus-visible::after {
  opacity: 1;
  transform: translate(12px, -50%);
}
/* On mobile (no hover), hide tooltips */
@media (hover: none) { [data-bn-tooltip]::after { display: none; } }
