/* Utility Classes - Reusable helper classes for Infowise Enterprises */
/* Based on utility-first principles like Tailwind CSS */

/* Import variables for use */
@import 'variables.css';

/* ===== Display Utilities ===== */
.u-block { display: block; }
.u-inline { display: inline; }
.u-inline-block { display: inline-block; }
.u-flex { display: flex; }
.u-inline-flex { display: inline-flex; }
.u-grid { display: grid; }
.u-inline-grid { display: inline-grid; }
.u-hidden { display: none; }
.u-visible { visibility: visible; }
.u-invisible { visibility: hidden; }

/* ===== Flexbox Utilities ===== */
.u-flex-row { flex-direction: row; }
.u-flex-row-reverse { flex-direction: row-reverse; }
.u-flex-col { flex-direction: column; }
.u-flex-col-reverse { flex-direction: column-reverse; }
.u-flex-wrap { flex-wrap: wrap; }
.u-flex-nowrap { flex-wrap: nowrap; }
.u-flex-wrap-reverse { flex-wrap: wrap-reverse; }

.u-justify-start { justify-content: flex-start; }
.u-justify-end { justify-content: flex-end; }
.u-justify-center { justify-content: center; }
.u-justify-between { justify-content: space-between; }
.u-justify-around { justify-content: space-around; }
.u-justify-evenly { justify-content: space-evenly; }

.u-items-start { align-items: flex-start; }
.u-items-end { align-items: flex-end; }
.u-items-center { align-items: center; }
.u-items-baseline { align-items: baseline; }
.u-items-stretch { align-items: stretch; }

.u-self-auto { align-self: auto; }
.u-self-start { align-self: flex-start; }
.u-self-end { align-self: flex-end; }
.u-self-center { align-self: center; }
.u-self-stretch { align-self: stretch; }
.u-self-baseline { align-self: baseline; }

.u-flex-1 { flex: 1 1 0%; }
.u-flex-auto { flex: 1 1 auto; }
.u-flex-initial { flex: 0 1 auto; }
.u-flex-none { flex: none; }

.u-gap-0 { gap: var(--spacing-0); }
.u-gap-1 { gap: var(--spacing-1); }
.u-gap-2 { gap: var(--spacing-2); }
.u-gap-3 { gap: var(--spacing-3); }
.u-gap-4 { gap: var(--spacing-4); }
.u-gap-5 { gap: var(--spacing-5); }
.u-gap-6 { gap: var(--spacing-6); }
.u-gap-8 { gap: var(--spacing-8); }
.u-gap-10 { gap: var(--spacing-10); }
.u-gap-12 { gap: var(--spacing-12); }

/* ===== Grid Utilities ===== */
.u-grid-cols-1 { grid-template-columns: repeat(1, minmax(0, 1fr)); }
.u-grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.u-grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.u-grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.u-grid-cols-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.u-grid-cols-6 { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.u-grid-cols-12 { grid-template-columns: repeat(12, minmax(0, 1fr)); }

.u-col-span-1 { grid-column: span 1 / span 1; }
.u-col-span-2 { grid-column: span 2 / span 2; }
.u-col-span-3 { grid-column: span 3 / span 3; }
.u-col-span-4 { grid-column: span 4 / span 4; }
.u-col-span-5 { grid-column: span 5 / span 5; }
.u-col-span-6 { grid-column: span 6 / span 6; }
.u-col-span-full { grid-column: 1 / -1; }

.u-grid-rows-1 { grid-template-rows: repeat(1, minmax(0, 1fr)); }
.u-grid-rows-2 { grid-template-rows: repeat(2, minmax(0, 1fr)); }
.u-grid-rows-3 { grid-template-rows: repeat(3, minmax(0, 1fr)); }
.u-grid-rows-4 { grid-template-rows: repeat(4, minmax(0, 1fr)); }
.u-grid-rows-6 { grid-template-rows: repeat(6, minmax(0, 1fr)); }

.u-row-span-1 { grid-row: span 1 / span 1; }
.u-row-span-2 { grid-row: span 2 / span 2; }
.u-row-span-3 { grid-row: span 3 / span 3; }
.u-row-span-full { grid-row: 1 / -1; }

/* ===== Spacing Utilities ===== */
/* Margin */
.u-m-0 { margin: var(--spacing-0); }
.u-m-1 { margin: var(--spacing-1); }
.u-m-2 { margin: var(--spacing-2); }
.u-m-3 { margin: var(--spacing-3); }
.u-m-4 { margin: var(--spacing-4); }
.u-m-5 { margin: var(--spacing-5); }
.u-m-6 { margin: var(--spacing-6); }
.u-m-8 { margin: var(--spacing-8); }
.u-m-10 { margin: var(--spacing-10); }
.u-m-12 { margin: var(--spacing-12); }
.u-m-16 { margin: var(--spacing-16); }
.u-m-20 { margin: var(--spacing-20); }
.u-m-24 { margin: var(--spacing-24); }
.u-m-auto { margin: auto; }

/* Margin Top */
.u-mt-0 { margin-top: var(--spacing-0); }
.u-mt-1 { margin-top: var(--spacing-1); }
.u-mt-2 { margin-top: var(--spacing-2); }
.u-mt-3 { margin-top: var(--spacing-3); }
.u-mt-4 { margin-top: var(--spacing-4); }
.u-mt-5 { margin-top: var(--spacing-5); }
.u-mt-6 { margin-top: var(--spacing-6); }
.u-mt-8 { margin-top: var(--spacing-8); }
.u-mt-10 { margin-top: var(--spacing-10); }
.u-mt-12 { margin-top: var(--spacing-12); }
.u-mt-16 { margin-top: var(--spacing-16); }
.u-mt-20 { margin-top: var(--spacing-20); }
.u-mt-24 { margin-top: var(--spacing-24); }
.u-mt-auto { margin-top: auto; }

/* Margin Right */
.u-mr-0 { margin-right: var(--spacing-0); }
.u-mr-1 { margin-right: var(--spacing-1); }
.u-mr-2 { margin-right: var(--spacing-2); }
.u-mr-3 { margin-right: var(--spacing-3); }
.u-mr-4 { margin-right: var(--spacing-4); }
.u-mr-5 { margin-right: var(--spacing-5); }
.u-mr-6 { margin-right: var(--spacing-6); }
.u-mr-8 { margin-right: var(--spacing-8); }
.u-mr-10 { margin-right: var(--spacing-10); }
.u-mr-12 { margin-right: var(--spacing-12); }
.u-mr-16 { margin-right: var(--spacing-16); }
.u-mr-20 { margin-right: var(--spacing-20); }
.u-mr-24 { margin-right: var(--spacing-24); }
.u-mr-auto { margin-right: auto; }

/* Margin Bottom */
.u-mb-0 { margin-bottom: var(--spacing-0); }
.u-mb-1 { margin-bottom: var(--spacing-1); }
.u-mb-2 { margin-bottom: var(--spacing-2); }
.u-mb-3 { margin-bottom: var(--spacing-3); }
.u-mb-4 { margin-bottom: var(--spacing-4); }
.u-mb-5 { margin-bottom: var(--spacing-5); }
.u-mb-6 { margin-bottom: var(--spacing-6); }
.u-mb-8 { margin-bottom: var(--spacing-8); }
.u-mb-10 { margin-bottom: var(--spacing-10); }
.u-mb-12 { margin-bottom: var(--spacing-12); }
.u-mb-16 { margin-bottom: var(--spacing-16); }
.u-mb-20 { margin-bottom: var(--spacing-20); }
.u-mb-24 { margin-bottom: var(--spacing-24); }
.u-mb-auto { margin-bottom: auto; }

/* Margin Left */
.u-ml-0 { margin-left: var(--spacing-0); }
.u-ml-1 { margin-left: var(--spacing-1); }
.u-ml-2 { margin-left: var(--spacing-2); }
.u-ml-3 { margin-left: var(--spacing-3); }
.u-ml-4 { margin-left: var(--spacing-4); }
.u-ml-5 { margin-left: var(--spacing-5); }
.u-ml-6 { margin-left: var(--spacing-6); }
.u-ml-8 { margin-left: var(--spacing-8); }
.u-ml-10 { margin-left: var(--spacing-10); }
.u-ml-12 { margin-left: var(--spacing-12); }
.u-ml-16 { margin-left: var(--spacing-16); }
.u-ml-20 { margin-left: var(--spacing-20); }
.u-ml-24 { margin-left: var(--spacing-24); }
.u-ml-auto { margin-left: auto; }

/* Padding */
.u-p-0 { padding: var(--spacing-0); }
.u-p-1 { padding: var(--spacing-1); }
.u-p-2 { padding: var(--spacing-2); }
.u-p-3 { padding: var(--spacing-3); }
.u-p-4 { padding: var(--spacing-4); }
.u-p-5 { padding: var(--spacing-5); }
.u-p-6 { padding: var(--spacing-6); }
.u-p-8 { padding: var(--spacing-8); }
.u-p-10 { padding: var(--spacing-10); }
.u-p-12 { padding: var(--spacing-12); }
.u-p-16 { padding: var(--spacing-16); }
.u-p-20 { padding: var(--spacing-20); }
.u-p-24 { padding: var(--spacing-24); }

/* Padding Top */
.u-pt-0 { padding-top: var(--spacing-0); }
.u-pt-1 { padding-top: var(--spacing-1); }
.u-pt-2 { padding-top: var(--spacing-2); }
.u-pt-3 { padding-top: var(--spacing-3); }
.u-pt-4 { padding-top: var(--spacing-4); }
.u-pt-5 { padding-top: var(--spacing-5); }
.u-pt-6 { padding-top: var(--spacing-6); }
.u-pt-8 { padding-top: var(--spacing-8); }
.u-pt-10 { padding-top: var(--spacing-10); }
.u-pt-12 { padding-top: var(--spacing-12); }
.u-pt-16 { padding-top: var(--spacing-16); }
.u-pt-20 { padding-top: var(--spacing-20); }
.u-pt-24 { padding-top: var(--spacing-24); }

/* Padding Right */
.u-pr-0 { padding-right: var(--spacing-0); }
.u-pr-1 { padding-right: var(--spacing-1); }
.u-pr-2 { padding-right: var(--spacing-2); }
.u-pr-3 { padding-right: var(--spacing-3); }
.u-pr-4 { padding-right: var(--spacing-4); }
.u-pr-5 { padding-right: var(--spacing-5); }
.u-pr-6 { padding-right: var(--spacing-6); }
.u-pr-8 { padding-right: var(--spacing-8); }
.u-pr-10 { padding-right: var(--spacing-10); }
.u-pr-12 { padding-right: var(--spacing-12); }
.u-pr-16 { padding-right: var(--spacing-16); }
.u-pr-20 { padding-right: var(--spacing-20); }
.u-pr-24 { padding-right: var(--spacing-24); }

/* Padding Bottom */
.u-pb-0 { padding-bottom: var(--spacing-0); }
.u-pb-1 { padding-bottom: var(--spacing-1); }
.u-pb-2 { padding-bottom: var(--spacing-2); }
.u-pb-3 { padding-bottom: var(--spacing-3); }
.u-pb-4 { padding-bottom: var(--spacing-4); }
.u-pb-5 { padding-bottom: var(--spacing-5); }
.u-pb-6 { padding-bottom: var(--spacing-6); }
.u-pb-8 { padding-bottom: var(--spacing-8); }
.u-pb-10 { padding-bottom: var(--spacing-10); }
.u-pb-12 { padding-bottom: var(--spacing-12); }
.u-pb-16 { padding-bottom: var(--spacing-16); }
.u-pb-20 { padding-bottom: var(--spacing-20); }
.u-pb-24 { padding-bottom: var(--spacing-24); }

/* Padding Left */
.u-pl-0 { padding-left: var(--spacing-0); }
.u-pl-1 { padding-left: var(--spacing-1); }
.u-pl-2 { padding-left: var(--spacing-2); }
.u-pl-3 { padding-left: var(--spacing-3); }
.u-pl-4 { padding-left: var(--spacing-4); }
.u-pl-5 { padding-left: var(--spacing-5); }
.u-pl-6 { padding-left: var(--spacing-6); }
.u-pl-8 { padding-left: var(--spacing-8); }
.u-pl-10 { padding-left: var(--spacing-10); }
.u-pl-12 { padding-left: var(--spacing-12); }
.u-pl-16 { padding-left: var(--spacing-16); }
.u-pl-20 { padding-left: var(--spacing-20); }
.u-pl-24 { padding-left: var(--spacing-24); }

/* ===== Typography Utilities ===== */
/* Font Size */
.u-text-xs { font-size: var(--font-size-xs); }
.u-text-sm { font-size: var(--font-size-sm); }
.u-text-base { font-size: var(--font-size-base); }
.u-text-lg { font-size: var(--font-size-lg); }
.u-text-xl { font-size: var(--font-size-xl); }
.u-text-2xl { font-size: var(--font-size-2xl); }
.u-text-3xl { font-size: var(--font-size-3xl); }
.u-text-4xl { font-size: var(--font-size-4xl); }
.u-text-5xl { font-size: var(--font-size-5xl); }
.u-text-6xl { font-size: var(--font-size-6xl); }
.u-text-7xl { font-size: var(--font-size-7xl); }

/* Font Weight */
.u-font-light { font-weight: var(--font-weight-light); }
.u-font-normal { font-weight: var(--font-weight-normal); }
.u-font-medium { font-weight: var(--font-weight-medium); }
.u-font-semibold { font-weight: var(--font-weight-semibold); }
.u-font-bold { font-weight: var(--font-weight-bold); }
.u-font-extrabold { font-weight: var(--font-weight-extrabold); }
.u-font-black { font-weight: var(--font-weight-black); }

/* Text Color */
.u-text-primary { color: var(--color-text-primary); }
.u-text-secondary { color: var(--color-text-secondary); }
.u-text-tertiary { color: var(--color-text-tertiary); }
.u-text-light { color: var(--color-text-light); }
.u-text-muted { color: var(--color-text-muted); }
.u-text-success { color: var(--color-success); }
.u-text-warning { color: var(--color-warning); }
.u-text-error { color: var(--color-error); }
.u-text-info { color: var(--color-info); }

/* Brand Colors */
.u-text-brand-primary { color: var(--color-primary-500); }
.u-text-brand-secondary { color: var(--color-secondary-500); }

/* Text Alignment */
.u-text-left { text-align: left; }
.u-text-center { text-align: center; }
.u-text-right { text-align: right; }
.u-text-justify { text-align: justify; }

/* Text Decoration */
.u-underline { text-decoration: underline; }
.u-line-through { text-decoration: line-through; }
.u-no-underline { text-decoration: none; }

/* Text