/* ===================================
    Utility Classes
    =================================== */

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

.mobile { display: flex; }
.desktop { display: none; }

@media screen and (min-width: 990px) {
     .mobile { display: none; }
     .desktop { display: flex; }
}

/* ===================================
     Margin Utilities
     =================================== */

.m-0 { margin: 0; }
.m-xs { margin: var(--spacing-xs); }
.m-sm { margin: var(--spacing-sm); }
.m-md { margin: var(--spacing-md); }
.m-lg { margin: var(--spacing-lg); }
.m-xl { margin: var(--spacing-xl); }

.mt-xs { margin-top: var(--spacing-xs); }
.mt-sm { margin-top: var(--spacing-sm); }
.mt-md { margin-top: var(--spacing-md); }
.mt-lg { margin-top: var(--spacing-lg); }

.mb-xs { margin-bottom: var(--spacing-xs); }
.mb-sm { margin-bottom: var(--spacing-sm); }
.mb-md { margin-bottom: var(--spacing-md); }
.mb-lg { margin-bottom: var(--spacing-lg); }

.mx-auto { margin-left: auto; margin-right: auto; }

/* ===================================
     Padding Utilities
     =================================== */

.p-0 { padding: 0; }
.p-xs { padding: var(--spacing-xs); }
.p-sm { padding: var(--spacing-sm); }
.p-base { padding: var(--spacing-base); }
.p-md { padding: var(--spacing-md); }
.p-lg { padding: var(--spacing-lg); }
.p-xl { padding: var(--spacing-xl); }

.pt-xs { padding-top: var(--spacing-xs); }
.pt-sm { padding-top: var(--spacing-sm); }
.pt-base { padding-top: var(--spacing-base); }
.pt-md { padding-top: var(--spacing-md); }
.pt-lg { padding-top: var(--spacing-lg); }
.pt-xl { padding-top: var(--spacing-xl); }
.pt-2xl { padding-top: var(--spacing-2xl); }
.pt-3xl { padding-top: var(--spacing-3xl); }
.pt-4xl { padding-top: var(--spacing-4xl); }

.pb-xs { padding-bottom: var(--spacing-xs); }
.pb-sm { padding-bottom: var(--spacing-sm); }
.pb-base { padding-bottom: var(--spacing-base); }
.pb-md { padding-bottom: var(--spacing-md); }
.pb-lg { padding-bottom: var(--spacing-lg); }
.pb-xl { padding-bottom: var(--spacing-xl); }
.pb-2xl { padding-bottom: var(--spacing-2xl); }
.pb-3xl { padding-bottom: var(--spacing-3xl); }
.pb-4xl { padding-bottom: var(--spacing-4xl); }

.flex-column { display: flex; flex-direction: column; }
.flex-row { display: flex; flex-direction: row; }
.flex-grow { flex-grow: 1; }

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

.gap-xs { gap: var(--spacing-xs); }
.gap-sm { gap: var(--spacing-sm); }
.gap-md { gap: var(--spacing-md); }
.gap-lg { gap: var(--spacing-lg); }

@media screen and (max-width: 989px) {
     .p-0-mb { padding: 0; }
     .p-xs-mb { padding: var(--spacing-xs); }
     .p-sm-mb { padding: var(--spacing-sm); }
     .p-md-mb { padding: var(--spacing-md); }
     .p-lg-mb { padding: var(--spacing-lg); }
     .p-xl-mb { padding: var(--spacing-xl); }

     .pt-xs-mb { padding-top: var(--spacing-xs); }
     .pt-sm-mb { padding-top: var(--spacing-sm); }
     .pt-base-mb { padding-top: var(--spacing-base); }
     .pt-md-mb { padding-top: var(--spacing-md); }
     .pt-lg-mb { padding-top: var(--spacing-lg); }
     .pt-xl-mb { padding-top: var(--spacing-xl); }
     .pt-2xl-mb { padding-top: var(--spacing-2xl); }
     .pt-3xl-mb { padding-top: var(--spacing-3xl); }
     .pt-4xl-mb { padding-top: var(--spacing-4xl); }

     .pb-xs-mb { padding-bottom: var(--spacing-xs); }
     .pb-sm-mb { padding-bottom: var(--spacing-sm); }
     .pb-md-mb { padding-bottom: var(--spacing-md); }
     .pb-lg-mb { padding-bottom: var(--spacing-lg); }
     .pb-xl-mb { padding-bottom: var(--spacing-xl); }
     .pb-base-mb { padding-bottom: var(--spacing-base); }
     .pb-2xl-mb { padding-bottom: var(--spacing-2xl); }
     .pb-3xl-mb { padding-bottom: var(--spacing-3xl); }
     .pb-4xl-mb { padding-bottom: var(--spacing-4xl); }

     .flex-column-mb { display: flex; flex-direction: column; }
     .flex-row-mb { display: flex; flex-direction: row; }
     
     .align-start-mb { align-items: flex-start; }
     .align-center-mb { align-items: center; }
     .align-end-mb { align-items: flex-end; }
     
     .gap-xs-mb { gap: var(--spacing-xs); }
     .gap-sm-mb { gap: var(--spacing-sm); }
     .gap-md-mb { gap: var(--spacing-md); }
     .gap-lg-mb { gap: var(--spacing-lg); }
}