/*
 * GYSMAP Utilities Foundation
 *
 * Provides single-purpose utility classes (flexbox, spacing, display)
 * heavily inspired by modern atomic CSS frameworks (like Tailwind/Bootstrap).
 * Uses our --spacing scale defined in global.css.
 */

/* Display Utilities */
.d-none { display: none !important; }
.d-block { display: block !important; }
.d-flex { display: flex !important; }
.d-inline-flex { display: inline-flex !important; }
.d-inline-block { display: inline-block !important; }

/* Flexbox Layouts */
.flex-row { flex-direction: row !important; }
.flex-column { flex-direction: column !important; }
.flex-wrap { flex-wrap: wrap !important; }

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

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

/* Spacing Utilities (Margins) */
.m-0 { margin: 0 !important; }
.mt-0 { margin-top: 0 !important; }
.mb-0 { margin-bottom: 0 !important; }

.mt-2 { margin-top: var(--spacing-2) !important; }
.mb-2 { margin-bottom: var(--spacing-2) !important; }
.my-2 { margin-top: var(--spacing-2) !important; margin-bottom: var(--spacing-2) !important; }

.mt-4 { margin-top: var(--spacing-4) !important; }
.mb-4 { margin-bottom: var(--spacing-4) !important; }
.my-4 { margin-top: var(--spacing-4) !important; margin-bottom: var(--spacing-4) !important; }

.mt-8 { margin-top: var(--spacing-8) !important; }
.mb-8 { margin-bottom: var(--spacing-8) !important; }

.ms-auto { margin-left: auto !important; }
.me-auto { margin-right: auto !important; }
.mx-auto { margin-left: auto !important; margin-right: auto !important; }

/* Spacing Utilities (Paddings) */
.p-0 { padding: 0 !important; }
.p-2 { padding: var(--spacing-2) !important; }
.p-4 { padding: var(--spacing-4) !important; }
.p-6 { padding: var(--spacing-6) !important; }

.pt-4 { padding-top: var(--spacing-4) !important; }
.pb-4 { padding-bottom: var(--spacing-4) !important; }
.px-4 { padding-left: var(--spacing-4) !important; padding-right: var(--spacing-4) !important; }
.py-4 { padding-top: var(--spacing-4) !important; padding-bottom: var(--spacing-4) !important; }

/* Sizing Utilities */
.w-100 { width: 100% !important; }
.h-100 { height: 100% !important; }

/* Visibility / Semantic state */
.sr-only,
.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}
