/* ================================================================
   TrkFit V4 — css/utilities.css
   Flex • Spacing • Display • Visibility helpers
================================================================ */

/* ── Flex ────────────────────────────────────────────────────── */
.flex         { display: flex; }
.inline-flex  { display: inline-flex; }
.flex-col     { flex-direction: column; }
.flex-wrap    { flex-wrap: wrap; }
.flex-nowrap  { flex-wrap: nowrap; }
.flex-1       { flex: 1; }
.flex-shrink-0{ flex-shrink: 0; }

.items-start  { align-items: flex-start; }
.items-center { align-items: center; }
.items-end    { align-items: flex-end; }

.justify-start  { justify-content: flex-start; }
.justify-center { justify-content: center; }
.justify-end    { justify-content: flex-end; }
.justify-between{ justify-content: space-between; }

.gap-1  { gap: var(--sp-1); }
.gap-2  { gap: var(--sp-2); }
.gap-3  { gap: var(--sp-3); }
.gap-4  { gap: var(--sp-4); }
.gap-5  { gap: var(--sp-5); }
.gap-6  { gap: var(--sp-6); }
.gap-8  { gap: var(--sp-8); }

/* ── Display ─────────────────────────────────────────────────── */
.block         { display: block; }
.inline-block  { display: inline-block; }
.inline        { display: inline; }
.grid          { display: grid; }
.hidden        { display: none !important; }

/* Responsive visibility */
@media (max-width: 639px)  { .hide-mobile  { display: none !important; } }
@media (min-width: 640px)  { .hide-tablet  { display: none !important; } }
@media (min-width: 900px)  { .hide-desktop { display: none !important; } }
@media (max-width: 899px)  { .show-desktop { display: none !important; } }
@media (max-width: 639px)  { .show-tablet  { display: none !important; } }
@media (min-width: 640px)  { .show-mobile  { display: none !important; } }

/* ── Spacing — margin ────────────────────────────────────────── */
.m-0  { margin: 0; }
.mt-1 { margin-top: var(--sp-1); }   .mb-1 { margin-bottom: var(--sp-1); }
.mt-2 { margin-top: var(--sp-2); }   .mb-2 { margin-bottom: var(--sp-2); }
.mt-3 { margin-top: var(--sp-3); }   .mb-3 { margin-bottom: var(--sp-3); }
.mt-4 { margin-top: var(--sp-4); }   .mb-4 { margin-bottom: var(--sp-4); }
.mt-5 { margin-top: var(--sp-5); }   .mb-5 { margin-bottom: var(--sp-5); }
.mt-6 { margin-top: var(--sp-6); }   .mb-6 { margin-bottom: var(--sp-6); }
.mt-8 { margin-top: var(--sp-8); }   .mb-8 { margin-bottom: var(--sp-8); }
.ml-auto { margin-left: auto; }
.mx-auto { margin-inline: auto; }

/* ── Spacing — padding ───────────────────────────────────────── */
.p-0  { padding: 0; }
.p-2  { padding: var(--sp-2); }
.p-4  { padding: var(--sp-4); }
.p-5  { padding: var(--sp-5); }
.p-6  { padding: var(--sp-6); }
.px-4 { padding-inline: var(--sp-4); }
.px-6 { padding-inline: var(--sp-6); }
.py-2 { padding-block: var(--sp-2); }
.py-4 { padding-block: var(--sp-4); }
.py-6 { padding-block: var(--sp-6); }

/* ── Width / Height ──────────────────────────────────────────── */
.w-full  { width: 100%; }
.h-full  { height: 100%; }
.min-h-screen { min-height: 100dvh; }

/* ── Overflow ────────────────────────────────────────────────── */
.overflow-hidden { overflow: hidden; }
.overflow-x-auto { overflow-x: auto; scrollbar-width: none; }
.overflow-x-auto::-webkit-scrollbar { display: none; }

/* ── Position ────────────────────────────────────────────────── */
.relative { position: relative; }
.absolute { position: absolute; }
.fixed    { position: fixed; }
.sticky   { position: sticky; }

/* ── Border radius ───────────────────────────────────────────── */
.rounded-sm   { border-radius: var(--r-sm); }
.rounded      { border-radius: var(--r); }
.rounded-md   { border-radius: var(--r-md); }
.rounded-full { border-radius: var(--r-full); }

/* ── Cursor ──────────────────────────────────────────────────── */
.cursor-pointer { cursor: pointer; }

/* ── Opacity ─────────────────────────────────────────────────── */
.opacity-50 { opacity: .5; }
.opacity-70 { opacity: .7; }

/* ── Pointer events ──────────────────────────────────────────── */
.pointer-none { pointer-events: none; }

/* ── Surface helpers ─────────────────────────────────────────── */
.surface   { background: var(--c-surface);  }
.surface-2 { background: var(--c-surface2); }
.bg-accent { background: var(--c-accent);   }

/* ── SR-only (screen reader) ─────────────────────────────────── */
.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;
}
