/* ============================================================
   TBB Pages — Utility Classes
   Scoped under .tbb-page.  All classes prefixed with tbb-.
   ============================================================ */

/* ── Display ───────────────────────────────────────────────── */
.tbb-page .tbb-flex        { display: flex; }
.tbb-page .tbb-inline-flex { display: inline-flex; }
.tbb-page .tbb-grid        { display: grid; }
.tbb-page .tbb-block       { display: block; }
.tbb-page .tbb-hidden      { display: none; }

/* ── Flex helpers ──────────────────────────────────────────── */
.tbb-page .tbb-flex-col        { flex-direction: column; }
.tbb-page .tbb-flex-wrap       { flex-wrap: wrap; }
.tbb-page .tbb-items-center    { align-items: center; }
.tbb-page .tbb-items-start     { align-items: flex-start; }
.tbb-page .tbb-justify-center  { justify-content: center; }
.tbb-page .tbb-justify-between { justify-content: space-between; }
.tbb-page .tbb-justify-end     { justify-content: flex-end; }
.tbb-page .tbb-flex-1          { flex: 1; }
.tbb-page .tbb-shrink-0        { flex-shrink: 0; }

/* ── Gap ───────────────────────────────────────────────────── */
.tbb-page .tbb-gap-1  { gap: var(--tbb-s-1); }
.tbb-page .tbb-gap-2  { gap: var(--tbb-s-2); }
.tbb-page .tbb-gap-3  { gap: var(--tbb-s-3); }
.tbb-page .tbb-gap-4  { gap: var(--tbb-s-4); }
.tbb-page .tbb-gap-6  { gap: var(--tbb-s-6); }
.tbb-page .tbb-gap-8  { gap: var(--tbb-s-8); }

/* ── Text alignment ────────────────────────────────────────── */
.tbb-page .tbb-text-center { text-align: center; }
.tbb-page .tbb-text-left   { text-align: left; }
.tbb-page .tbb-text-right  { text-align: right; }

/* ── Font size ─────────────────────────────────────────────── */
.tbb-page .tbb-text-xs   { font-size: var(--tbb-text-xs); }
.tbb-page .tbb-text-sm   { font-size: var(--tbb-text-sm); }
.tbb-page .tbb-text-base { font-size: var(--tbb-text-base); }
.tbb-page .tbb-text-lg   { font-size: var(--tbb-text-lg); }
.tbb-page .tbb-text-xl   { font-size: var(--tbb-text-xl); }

/* ── Font weight ───────────────────────────────────────────── */
.tbb-page .tbb-font-medium    { font-weight: var(--tbb-weight-medium); }
.tbb-page .tbb-font-semibold  { font-weight: var(--tbb-weight-semibold); }
.tbb-page .tbb-font-bold      { font-weight: var(--tbb-weight-bold); }
.tbb-page .tbb-font-extrabold { font-weight: var(--tbb-weight-extrabold); }

/* ── Color ─────────────────────────────────────────────────── */
.tbb-page .tbb-text-white  { color: var(--tbb-white); }
.tbb-page .tbb-text-muted  { color: var(--tbb-gray-500); }
.tbb-page .tbb-text-blue   { color: var(--tbb-blue-600); }
.tbb-page .tbb-text-dark   { color: var(--tbb-gray-900); }

/* ── Background ────────────────────────────────────────────── */
.tbb-page .tbb-bg-white    { background: var(--tbb-white); }
.tbb-page .tbb-bg-gray     { background: var(--tbb-gray-50); }
.tbb-page .tbb-bg-blue-50  { background: var(--tbb-blue-50); }

/* ── Margin ────────────────────────────────────────────────── */
.tbb-page .tbb-mt-4  { margin-top: var(--tbb-s-4); }
.tbb-page .tbb-mt-6  { margin-top: var(--tbb-s-6); }
.tbb-page .tbb-mt-8  { margin-top: var(--tbb-s-8); }
.tbb-page .tbb-mt-12 { margin-top: var(--tbb-s-12); }
.tbb-page .tbb-mb-4  { margin-bottom: var(--tbb-s-4); }
.tbb-page .tbb-mb-6  { margin-bottom: var(--tbb-s-6); }
.tbb-page .tbb-mb-8  { margin-bottom: var(--tbb-s-8); }
.tbb-page .tbb-mx-auto { margin-inline: auto; }

/* ── Max width ─────────────────────────────────────────────── */
.tbb-page .tbb-max-w-sm  { max-width: 480px; }
.tbb-page .tbb-max-w-md  { max-width: 640px; }
.tbb-page .tbb-max-w-lg  { max-width: 768px; }
.tbb-page .tbb-max-w-xl  { max-width: 1024px; }

/* ── Width ─────────────────────────────────────────────────── */
.tbb-page .tbb-w-full  { width: 100%; }

/* ── Border radius ─────────────────────────────────────────── */
.tbb-page .tbb-rounded    { border-radius: var(--tbb-r-md); }
.tbb-page .tbb-rounded-lg { border-radius: var(--tbb-r-lg); }
.tbb-page .tbb-rounded-xl { border-radius: var(--tbb-r-xl); }
.tbb-page .tbb-rounded-2xl{ border-radius: var(--tbb-r-2xl); }

/* ── Overflow ──────────────────────────────────────────────── */
.tbb-page .tbb-overflow-hidden { overflow: hidden; }

/* ── Relative / absolute ───────────────────────────────────── */
.tbb-page .tbb-relative { position: relative; }

/* ── Screen reader only ────────────────────────────────────── */
.tbb-page .tbb-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
