/* Define spacing scale (similar to Bootstrap) */
:root {
    --spacer: 1rem; /* Base unit (can be adjusted) */
}

/* Spacing scale: multiply base spacer */
.spacing-0 { margin: 0 !important; padding: 0 !important; }
.spacing-1 { margin: calc(var(--spacer) * 0.25) !important; padding: calc(var(--spacer) * 0.25) !important; }
.spacing-2 { margin: calc(var(--spacer) * 0.5) !important; padding: calc(var(--spacer) * 0.5) !important; }
.spacing-3 { margin: calc(var(--spacer) * 1) !important; padding: calc(var(--spacer) * 1) !important; }
.spacing-4 { margin: calc(var(--spacer) * 1.5) !important; padding: calc(var(--spacer) * 1.5) !important; }
.spacing-5 { margin: calc(var(--spacer) * 3) !important; padding: calc(var(--spacer) * 3) !important; }

/* Direction-specific margin utilities */
.m-0 { margin: 0 !important; }
.m-1 { margin: calc(var(--spacer) * 0.25) !important; }
.m-2 { margin: calc(var(--spacer) * 0.5) !important; }
.m-3 { margin: calc(var(--spacer) * 1) !important; }
.m-4 { margin: calc(var(--spacer) * 1.5) !important; }
.m-5 { margin: calc(var(--spacer) * 3) !important; }

/* Horizontal (mx) and vertical (my) */
.mx-0 { margin-left: 0 !important; margin-right: 0 !important; }
.mx-1 { margin-left: calc(var(--spacer) * 0.25) !important; margin-right: calc(var(--spacer) * 0.25) !important; }
.mx-2 { margin-left: calc(var(--spacer) * 0.5) !important; margin-right: calc(var(--spacer) * 0.5) !important; }
.mx-3 { margin-left: calc(var(--spacer) * 1) !important; margin-right: calc(var(--spacer) * 1) !important; }
.mx-4 { margin-left: calc(var(--spacer) * 1.5) !important; margin-right: calc(var(--spacer) * 1.5) !important; }
.mx-5 { margin-left: calc(var(--spacer) * 3) !important; margin-right: calc(var(--spacer) * 3) !important; }

.my-0 { margin-top: 0 !important; margin-bottom: 0 !important; }
.my-1 { margin-top: calc(var(--spacer) * 0.25) !important; margin-bottom: calc(var(--spacer) * 0.25) !important; }
.my-2 { margin-top: calc(var(--spacer) * 0.5) !important; margin-bottom: calc(var(--spacer) * 0.5) !important; }
.my-3 { margin-top: calc(var(--spacer) * 1) !important; margin-bottom: calc(var(--spacer) * 1) !important; }
.my-4 { margin-top: calc(var(--spacer) * 1.5) !important; margin-bottom: calc(var(--spacer) * 1.5) !important; }
.my-5 { margin-top: calc(var(--spacer) * 3) !important; margin-bottom: calc(var(--spacer) * 3) !important; }

/* Top, bottom, left, right margins */
.mt-0 { margin-top: 0 !important; }
.mt-1 { margin-top: calc(var(--spacer) * 0.25) !important; }
.mt-2 { margin-top: calc(var(--spacer) * 0.5) !important; }
.mt-3 { margin-top: calc(var(--spacer) * 1) !important; }
.mt-4 { margin-top: calc(var(--spacer) * 1.5) !important; }
.mt-5 { margin-top: calc(var(--spacer) * 3) !important; }

.mb-0 { margin-bottom: 0 !important; }
.mb-1 { margin-bottom: calc(var(--spacer) * 0.25) !important; }
.mb-2 { margin-bottom: calc(var(--spacer) * 0.5) !important; }
.mb-3 { margin-bottom: calc(var(--spacer) * 1) !important; }
.mb-4 { margin-bottom: calc(var(--spacer) * 1.5) !important; }
.mb-5 { margin-bottom: calc(var(--spacer) * 3) !important; }

.ml-0 { margin-left: 0 !important; }
.ml-1 { margin-left: calc(var(--spacer) * 0.25) !important; }
.ml-2 { margin-left: calc(var(--spacer) * 0.5) !important; }
.ml-3 { margin-left: calc(var(--spacer) * 1) !important; }
.ml-4 { margin-left: calc(var(--spacer) * 1.5) !important; }
.ml-5 { margin-left: calc(var(--spacer) * 3) !important; }

.mr-0 { margin-right: 0 !important; }
.mr-1 { margin-right: calc(var(--spacer) * 0.25) !important; }
.mr-2 { margin-right: calc(var(--spacer) * 0.5) !important; }
.mr-3 { margin-right: calc(var(--spacer) * 1) !important; }
.mr-4 { margin-right: calc(var(--spacer) * 1.5) !important; }
.mr-5 { margin-right: calc(var(--spacer) * 3) !important; }

/* Auto margins */
.mt-auto { margin-top: auto !important; }
.mb-auto { margin-bottom: auto !important; }
.ml-auto { margin-left: auto !important; }
.mr-auto { margin-right: auto !important; }
.mx-auto { margin-left: auto !important; margin-right: auto !important; }
.my-auto { margin-top: auto !important; margin-bottom: auto !important; }

/* === PADDING CLASSES === */

.p-0 { padding: 0 !important; }
.p-1 { padding: calc(var(--spacer) * 0.25) !important; }
.p-2 { padding: calc(var(--spacer) * 0.5) !important; }
.p-3 { padding: calc(var(--spacer) * 1) !important; }
.p-4 { padding: calc(var(--spacer) * 1.5) !important; }
.p-5 { padding: calc(var(--spacer) * 3) !important; }

/* Horizontal and vertical padding */
.px-0 { padding-left: 0 !important; padding-right: 0 !important; }
.px-1 { padding-left: calc(var(--spacer) * 0.25) !important; padding-right: calc(var(--spacer) * 0.25) !important; }
.px-2 { padding-left: calc(var(--spacer) * 0.5) !important; padding-right: calc(var(--spacer) * 0.5) !important; }
.px-3 { padding-left: calc(var(--spacer) * 1) !important; padding-right: calc(var(--spacer) * 1) !important; }
.px-4 { padding-left: calc(var(--spacer) * 1.5) !important; padding-right: calc(var(--spacer) * 1.5) !important; }
.px-5 { padding-left: calc(var(--spacer) * 3) !important; padding-right: calc(var(--spacer) * 3) !important; }

.py-0 { padding-top: 0 !important; padding-bottom: 0 !important; }
.py-1 { padding-top: calc(var(--spacer) * 0.25) !important; padding-bottom: calc(var(--spacer) * 0.25) !important; }
.py-2 { padding-top: calc(var(--spacer) * 0.5) !important; padding-bottom: calc(var(--spacer) * 0.5) !important; }
.py-3 { padding-top: calc(var(--spacer) * 1) !important; padding-bottom: calc(var(--spacer) * 1) !important; }
.py-4 { padding-top: calc(var(--spacer) * 1.5) !important; padding-bottom: calc(var(--spacer) * 1.5) !important; }
.py-5 { padding-top: calc(var(--spacer) * 3) !important; padding-bottom: calc(var(--spacer) * 3) !important; }

/* Individual sides */
.pt-0 { padding-top: 0 !important; }
.pt-1 { padding-top: calc(var(--spacer) * 0.25) !important; }
.pt-2 { padding-top: calc(var(--spacer) * 0.5) !important; }
.pt-3 { padding-top: calc(var(--spacer) * 1) !important; }
.pt-4 { padding-top: calc(var(--spacer) * 1.5) !important; }
.pt-5 { padding-top: calc(var(--spacer) * 3) !important; }

.pb-0 { padding-bottom: 0 !important; }
.pb-1 { padding-bottom: calc(var(--spacer) * 0.25) !important; }
.pb-2 { padding-bottom: calc(var(--spacer) * 0.5) !important; }
.pb-3 { padding-bottom: calc(var(--spacer) * 1) !important; }
.pb-4 { padding-bottom: calc(var(--spacer) * 1.5) !important; }
.pb-5 { padding-bottom: calc(var(--spacer) * 3) !important; }

.pl-0 { padding-left: 0 !important; }
.pl-1 { padding-left: calc(var(--spacer) * 0.25) !important; }
.pl-2 { padding-left: calc(var(--spacer) * 0.5) !important; }
.pl-3 { padding-left: calc(var(--spacer) * 1) !important; }
.pl-4 { padding-left: calc(var(--spacer) * 1.5) !important; }
.pl-5 { padding-left: calc(var(--spacer) * 3) !important; }

.pr-0 { padding-right: 0 !important; }
.pr-1 { padding-right: calc(var(--spacer) * 0.25) !important; }
.pr-2 { padding-right: calc(var(--spacer) * 0.5) !important; }
.pr-3 { padding-right: calc(var(--spacer) * 1) !important; }
.pr-4 { padding-right: calc(var(--spacer) * 1.5) !important; }
.pr-5 { padding-right: calc(var(--spacer) * 3) !important; }

/* Responsive variants (example for small screens only) */
@media (max-width: 575.98px) {
    .mt-sm-0 { margin-top: 0 !important; }
    .mt-sm-1 { margin-top: calc(var(--spacer) * 0.25) !important; }
    .mt-sm-2 { margin-top: calc(var(--spacer) * 0.5) !important; }
    .mt-sm-3 { margin-top: calc(var(--spacer) * 1) !important; }
    .mt-sm-4 { margin-top: calc(var(--spacer) * 1.5) !important; }
    .mt-sm-5 { margin-top: calc(var(--spacer) * 3) !important; }

    .mb-sm-3 { margin-bottom: calc(var(--spacer) * 1) !important; }
    .pt-sm-3 { padding-top: calc(var(--spacer) * 1) !important; }
    /* Add more as needed */
}