/**
 * Utility Classes
 * Single-purpose helper classes
 */

/* ==========================================================================
   DISPLAY
   ========================================================================== */

.hidden { display: none; }
.block { display: block; }
.inline { display: inline; }
.inline-block { display: inline-block; }

/* ==========================================================================
   VISIBILITY
   ========================================================================== */

.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;
}

.sr-only-focusable:focus {
    position: static;
    width: auto;
    height: auto;
    padding: inherit;
    margin: inherit;
    overflow: visible;
    clip: auto;
    white-space: normal;
}

/* ==========================================================================
   SPACING
   ========================================================================== */

/* Margin */
.m-0 { margin: 0; }
.m-auto { margin: auto; }
.mx-auto { margin-inline: auto; }
.my-auto { margin-block: auto; }

.mt-4 { margin-top: var(--space-4); }
.mt-8 { margin-top: var(--space-8); }
.mt-12 { margin-top: var(--space-12); }
.mt-16 { margin-top: var(--space-16); }

.mb-4 { margin-bottom: var(--space-4); }
.mb-8 { margin-bottom: var(--space-8); }
.mb-12 { margin-bottom: var(--space-12); }
.mb-16 { margin-bottom: var(--space-16); }

/* Padding */
.p-0 { padding: 0; }
.p-4 { padding: var(--space-4); }
.p-6 { padding: var(--space-6); }
.p-8 { padding: var(--space-8); }

.py-4 { padding-block: var(--space-4); }
.py-8 { padding-block: var(--space-8); }
.py-12 { padding-block: var(--space-12); }
.py-16 { padding-block: var(--space-16); }

.px-4 { padding-inline: var(--space-4); }
.px-6 { padding-inline: var(--space-6); }
.px-8 { padding-inline: var(--space-8); }

/* ==========================================================================
   TEXT ALIGNMENT
   ========================================================================== */

.text-left { text-align: left; }
.text-center { text-align: center; }
.text-right { text-align: right; }

/* ==========================================================================
   WIDTH & HEIGHT
   ========================================================================== */

.w-full { width: 100%; }
.w-auto { width: auto; }
.max-w-prose { max-width: 65ch; }

.h-full { height: 100%; }
.h-screen { height: 100vh; }
.min-h-screen { min-height: 100vh; }

/* ==========================================================================
   POSITION
   ========================================================================== */

.relative { position: relative; }
.absolute { position: absolute; }
.fixed { position: fixed; }
.sticky { position: sticky; }

.inset-0 {
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
}

/* ==========================================================================
   OVERFLOW
   ========================================================================== */

.overflow-hidden { overflow: hidden; }
.overflow-auto { overflow: auto; }
.overflow-x-auto { overflow-x: auto; }
.overflow-y-auto { overflow-y: auto; }

/* ==========================================================================
   CURSOR
   ========================================================================== */

.cursor-pointer { cursor: pointer; }
.cursor-not-allowed { cursor: not-allowed; }

/* ==========================================================================
   OPACITY
   ========================================================================== */

.opacity-0 { opacity: 0; }
.opacity-50 { opacity: 0.5; }
.opacity-75 { opacity: 0.75; }
.opacity-100 { opacity: 1; }

/* ==========================================================================
   TRANSITIONS
   ========================================================================== */

.transition {
    transition-property: color, background-color, border-color, transform, opacity;
    transition-duration: 250ms;
    transition-timing-function: ease;
}

.transition-fast { transition-duration: 150ms; }
.transition-slow { transition-duration: 350ms; }

/* ==========================================================================
   TRANSFORMS
   ========================================================================== */

.rotate-45 { transform: rotate(45deg); }
.rotate-90 { transform: rotate(90deg); }
.rotate-180 { transform: rotate(180deg); }

.scale-95 { transform: scale(0.95); }
.scale-100 { transform: scale(1); }
.scale-105 { transform: scale(1.05); }

/* ==========================================================================
   BACKGROUND COLORS
   ========================================================================== */

.bg-black { background-color: var(--color-black); }
.bg-charcoal { background-color: var(--color-charcoal); }
.bg-concrete { background-color: var(--color-concrete); }
.bg-brick { background-color: var(--color-brick); }

.bg-ai { background-color: var(--color-ai-primary); }
.bg-fivem { background-color: var(--color-fivem-primary); }
.bg-api { background-color: var(--color-api-primary); }

/* ==========================================================================
   BORDERS
   ========================================================================== */

.border { border: var(--border-thin) solid var(--color-brick); }
.border-2 { border-width: var(--border-medium); }
.border-4 { border-width: var(--border-thick); }

.border-t { border-top: var(--border-thin) solid var(--color-brick); }
.border-b { border-bottom: var(--border-thin) solid var(--color-brick); }
.border-l { border-left: var(--border-thin) solid var(--color-brick); }
.border-r { border-right: var(--border-thin) solid var(--color-brick); }

/* ==========================================================================
   BORDER RADIUS
   ========================================================================== */

.rounded-none { border-radius: var(--radius-none); }
.rounded-sm { border-radius: var(--radius-sm); }
.rounded { border-radius: var(--radius-md); }
.rounded-lg { border-radius: var(--radius-lg); }
.rounded-full { border-radius: var(--radius-full); }

/* ==========================================================================
   SHADOWS
   ========================================================================== */

.shadow-sm { box-shadow: var(--shadow-sm); }
.shadow { box-shadow: var(--shadow-md); }
.shadow-lg { box-shadow: var(--shadow-lg); }
.shadow-xl { box-shadow: var(--shadow-xl); }
.shadow-gritty { box-shadow: var(--shadow-gritty); }

/* ==========================================================================
   Z-INDEX
   ========================================================================== */

.z-0 { z-index: var(--z-base); }
.z-10 { z-index: 10; }
.z-20 { z-index: 20; }
.z-50 { z-index: 50; }
.z-max { z-index: var(--z-max); }

/* ==========================================================================
   POINTER EVENTS
   ========================================================================== */

.pointer-events-none { pointer-events: none; }
.pointer-events-auto { pointer-events: auto; }

/* ==========================================================================
   USER SELECT
   ========================================================================== */

.select-none { user-select: none; }
.select-text { user-select: text; }
.select-all { user-select: all; }

