/* ══════════════════════════════════════════
   OLLAGE COMPONENTS
   Canonical .bb-* classes. Depends on tokens.css.
   Import via: <link rel="stylesheet" href="/tokens.css">
               <link rel="stylesheet" href="/bb-components.css">
   See /brand for the live styleguide.
   ══════════════════════════════════════════ */

/* ── Buttons ── */
.bb-btn {
  padding: 0.4rem 1rem;
  border-radius: var(--radius);
  border: none;
  font-size: var(--text-base);
  font-weight: 600;
  cursor: pointer;
  font-family: var(--font);
  transition: all var(--dur-fast) var(--ease);
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  text-decoration: none;
  line-height: 1.2;
}
.bb-btn--primary { background: var(--primary); color: #fff; }
.bb-btn--primary:hover { background: var(--primary-hover); }
.bb-btn--ghost { background: transparent; border: 1px solid var(--border); color: var(--text); }
.bb-btn--ghost:hover { border-color: var(--primary); }
.bb-btn--danger { background: var(--red); color: #fff; }
.bb-btn--danger:hover { filter: brightness(1.15); }
.bb-btn--link { background: transparent; color: var(--primary-hover); padding: 0; font-weight: 500; }
.bb-btn--link:hover { text-decoration: underline; }
.bb-btn--sm { padding: 0.3rem 0.7rem; font-size: var(--text-sm); }
.bb-btn--xs { padding: 0.2rem 0.5rem; font-size: var(--text-xs); }
.bb-btn--block { width: 100%; justify-content: center; }
.bb-btn:disabled,
.bb-btn[aria-disabled="true"] { opacity: 0.5; cursor: not-allowed; }

/* ── Pills / filter chips ──────────────────────────────────────────────────
   .bb-pill  — canonical class (use in new components)
   .pill      — legacy alias used by tagbar; same styles, different modifiers
   Modifier map: .bb-pill.is-active == .pill.active
   ─────────────────────────────────────────────────────────────────────── */
.bb-pill,
.pill {
  padding: 0.2rem 0.5rem;
  border-radius: var(--radius-pill);
  font-size: var(--text-xs);
  font-family: var(--mono);
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text-dim);
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease);
  display: inline-flex;
  align-items: center;
  gap: 4px;
  white-space: nowrap;
}
.bb-pill:hover,
.pill:hover { border-color: var(--text); color: var(--text); }

/* Active state — .is-active (.bb-pill) / .active (.pill) */
.bb-pill.is-active,
.pill.active { background: var(--surface); border-color: var(--primary); color: var(--primary-hover); }

/* Changed / dirty state */
.bb-pill.is-changed { background: var(--green-soft); border-color: var(--green); color: var(--green); }

/* HD badge treatment */
.bb-pill.is-hd { background: var(--amber-soft); border-color: var(--amber); color: var(--amber); font-weight: 700; }

/* Exclude / crossed-out state (tagbar filter negation) */
.pill.exclude {
  background: var(--red-soft);
  border-color: var(--red);
  color: var(--red);
  text-decoration: line-through;
  text-decoration-thickness: 1px;
}
.pill.exclude:hover { border-color: var(--red); color: var(--red); }

/* Count chip inside pill */
.bb-pill .ct,
.pill .ct { opacity: 0.5; font-size: var(--text-xxs); }

/* ── Badges ── */
.bb-badge {
  padding: 0.15rem 0.5rem;
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  display: inline-block;
}
.bb-badge--green   { background: var(--green-soft);   color: var(--green); }
.bb-badge--red     { background: var(--red-soft);     color: var(--red); }
.bb-badge--amber   { background: var(--amber-soft);   color: var(--amber); }
.bb-badge--primary { background: var(--primary-soft); color: var(--primary-hover); }

/* ── Card archetypes ── */
.bb-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: border-color var(--dur-fast) var(--ease);
  overflow: hidden;
}
.bb-card:hover { border-color: var(--primary); }
.bb-card.is-selected { box-shadow: var(--ring-selected); border-color: var(--primary); }

.bb-card--media { aspect-ratio: 9/16; position: relative; }
.bb-card--media-16x9 { aspect-ratio: 16/9; }
.bb-card--media-1x1  { aspect-ratio: 1/1; }
.bb-card--media img,
.bb-card--media video,
.bb-card--media .media-fill {
  width: 100%; height: 100%; object-fit: cover; display: block;
}

.bb-card--row {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm) var(--space-md);
}
.bb-card--row .row-thumb {
  width: 56px; height: 56px; border-radius: var(--radius);
  background: var(--bg); border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-dim); flex-shrink: 0;
  overflow: hidden;
}
.bb-card--row .row-thumb img { width: 100%; height: 100%; object-fit: cover; }
.bb-card--row .row-meta { flex: 1; min-width: 0; }
.bb-card--row .row-title {
  font-size: var(--text-base); font-weight: 600;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.bb-card--row .row-sub { font-size: var(--text-xs); color: var(--text-dim); }

.bb-card--form {
  padding: var(--space-xl);
  max-width: 420px;
  width: 100%;
}

/* ── 6-position media overlay (4 corners + 2 edge strips) ── */
.media-overlay { position: absolute; pointer-events: none; z-index: 2; }
.media-overlay--tl { top: var(--space-xs); left: var(--space-xs); }
.media-overlay--tr { top: var(--space-xs); right: var(--space-xs); }
.media-overlay--bl { bottom: var(--space-xs); left: var(--space-xs); }
.media-overlay--br { bottom: var(--space-xs); right: var(--space-xs); }
/* Edge strips run the full vertical height of the card, between the corners.
   Children stack vertically (column flex), centered. Wrap in pointer-events:auto
   if children are interactive. */
.media-overlay--l,
.media-overlay--r {
  top: var(--space-xs); bottom: var(--space-xs);
  display: flex; flex-direction: column;
  gap: var(--space-xs);
  justify-content: center;
}
.media-overlay--l { left: var(--space-xs); align-items: flex-start; }
.media-overlay--r { right: var(--space-xs); align-items: flex-end; }

.media-badge {
  padding: 2px 6px;
  border-radius: var(--radius-pill);
  font-size: var(--text-xxs);
  font-family: var(--mono);
  font-weight: 600;
}
.media-badge--mono     { background: rgba(0,0,0,0.7); color: #fff; }
.media-badge .cr-icon  { vertical-align: -1.5px; }
.media-badge--duration { background: rgba(0,0,0,0.7); color: #fff; }
.media-badge--hd       { background: var(--amber); color: #000; }
.media-badge--verified { background: var(--green-soft); color: var(--green); border: 1px solid var(--green); }

/* ── Form field (shared by login, claim, edit modals) ── */
.bb-field { display: block; margin-bottom: var(--space-md); }
.bb-field label {
  display: block;
  font-size: var(--text-sm);
  color: var(--text-dim);
  margin-bottom: var(--space-xs);
}
.bb-input {
  width: 100%;
  padding: 0.5rem 0.75rem;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text);
  font-family: var(--font);
  font-size: var(--text-base);
  transition: border-color var(--dur-fast) var(--ease);
}
.bb-input:focus { outline: none; border-color: var(--primary); }
.bb-input:disabled { opacity: 0.5; cursor: not-allowed; }

/* ── Centered viewport layout (login, no-access, claim) ── */
.bb-center {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-xl);
}

/* ── Message blocks (error, success, info) ── */
.bb-msg {
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius);
  font-size: var(--text-sm);
  margin-bottom: var(--space-md);
  border: 1px solid transparent;
}
.bb-msg--error   { background: var(--red-soft);     border-color: var(--red);     color: var(--red); }
.bb-msg--success { background: var(--green-soft);   border-color: var(--green);   color: var(--green); }
.bb-msg--info    { background: var(--primary-soft); border-color: var(--primary); color: var(--primary-hover); }
