@charset "UTF-8";
/*@import url('https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300..800;1,300..800&display=swap');*/

:root {
    --theme-primary-color: #ff0080;
    --theme-secondary-color: #7928ca;
    --gradient-color: linear-gradient(310deg, var(--theme-secondary-color), var(--theme-primary-color));
    --gradient-bg-color: var(--gradient-color);
    --dark: #000000;
    --light-dark: #999999;
    --white: #ffffff;
    --gray: #eeeeee;
    --anchor-text-color: #5846f9;
    --anchor-text-color-hover: var(--theme-secondary-color);
    --heading-text-color: #141417;
    --heading-line-color: #b9c7f6;
    --header-footer-color: var(--heading-text-color);
    --body-text-color: #4b4b4b;
    --font-14-size: 14px;
    --font-family-body: "Open Sans", sans-serif;
    --font-family-head: var(--font-family-body);

    --badge-font-size: 0.75rem;        /* 75% of base */
    --badge-font-weight: 700;
    --badge-padding-y: 0.25rem;        /* vertical padding */
    --badge-padding-x: 0.4rem;         /* horizontal padding */
    --badge-line-height: 1;
    --badge-border-radius: 0.25rem;
    --badge-pill-radius: 10rem;

    --badge-bg-primary: #0d6efd;
    --badge-bg-secondary: #6c757d;
    --badge-bg-success: #198754;
    --badge-bg-danger: #dc3545;
    --badge-bg-warning: #ffc107;
    --badge-bg-info: #0dcaf0;
    --badge-bg-light: #f8f9fa;
    --badge-bg-dark: #212529;

    --badge-color-light: #fff;
    --badge-color-dark: #212529;

}

*, ::after, ::before {
    box-sizing: border-box;
}


body {
    /*font-family: var(--font-family-body);*/
    font-family: system-ui;
    color: var(--body-text-color);
    padding: 0;
    margin: 0;
    font-display: swap;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: transparent;
}

.text-sm {
    font-size: 0.875rem !important;
}

.text-xs {
    font-size: .75rem !important;
    line-height: 1.25;
}

.text-xxs {
    font-size: 0.65rem !important;
}

.text-dark {
    color: #344767 !important;
}

.theme-text-primary {
    color: var(--theme-primary-color) !important;
}
.theme-bg-primary {
    background-color: var(--theme-primary-color) !important;
}

.btn-link {
    text-decoration: none;
    color: var(--theme-primary-color);
}

input:-webkit-autofill,
input:-webkit-autofill:focus {
    transition: background-color 600000s 0s, color 600000s 0s !important;
}

input[data-autocompleted] {
    background-color: transparent !important;
}

a {
    color: var(--theme-primary-color);
    text-decoration: none;
}

a:hover {
    color: var(--anchor-text-color-hover);
    text-decoration: none;
}


h1,
h2,
h3,
h4,
h5,
h6 {
    /*font-family: var(--font-family-head);*/
    font-family: system-ui;
    color: var(--heading-text-color);
    font-weight: 600 !important;
    letter-spacing: -1px;
    font-style: normal;
    margin-top: 0 !important;
    margin-bottom: 10px !important;
    line-height: 1.25 !important;
}

h1, .h1 {
    font-size: clamp(1.75rem, 1.02rem + 3.36vw, 2.825rem) !important;
}

h2, .h2 {
    font-size: clamp(1.5rem, 1.14rem + 1.85vw, 2.25rem) !important;
}

h3, .h3 {
    font-size: clamp(1.063rem, 1.016rem + 0.217vw, 1.25rem) !important;
}

h4, .h4 {
    font-size: clamp(1rem, 0.96rem + 0.2vw, 1.125rem);
}

h5, .h5 {
    font-size: clamp(0.875rem, 0.82rem + 0.2vw, 1rem);
}

h6, .h6 {
    font-size: clamp(0.75rem, 0.71rem + 0.15vw, 0.875rem);
}

@media (min-width: 1200px) {
    h1, .h1 {
        font-size: 2.825rem;
    }

    h2, .h2 {
        font-size: 2.25rem;
    }

    h3, .h3 {
        font-size: 1.25rem;
    }

    h4, .h4 {
        font-size: 1.20rem;
    }
}

p, ul, ol {
    margin-top: 0;
    margin-bottom: 1rem;
}

.p_relative {
    position: relative;
}

.p_absolute {
    position: absolute;
}

hr {
    margin: 1rem 0;
    color: inherit;
    border: 0;
    opacity: .25;
    border-top: none !important;
    height: 1px !important;
}

hr.horizontal {
    background-color: transparent !important;
}

hr.horizontal.dark {
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0), rgba(0, 0, 0, .4), rgba(0, 0, 0, 0)) !important;
}

/* Container class to center content and add padding */
/* Common container settings */
.container,
.container-fluid,
.container-sm,
.container-md,
.container-lg,
.container-xl,
.container-xxl {
    --bs-gutter-x: 1.5rem;
    --bs-gutter-y: 0;
    width: 100%;
    padding-right: calc(var(--bs-gutter-x) * 0.5);
    padding-left: calc(var(--bs-gutter-x) * 0.5);
    margin-right: auto;
    margin-left: auto;
}

/* Fluid container (always full width) */
.container-fluid {
    max-width: 100%;
}

/* Fixed-width containers at each breakpoint */
@media (min-width: 576px) {
    .container-sm, .container {
        max-width: 540px;
    }
}

@media (min-width: 768px) {
    .container-md, .container {
        max-width: 720px;
    }
}

@media (min-width: 992px) {
    .container-lg, .container {
        max-width: 960px;
    }
}

@media (min-width: 1200px) {
    .container-xl, .container {
        max-width: 1140px;
    }
}

@media (min-width: 1400px) {
    .container-xxl, .container {
        max-width: 1320px;
    }
}

/* Row class to contain columns */
/* Apply gutter spacing to all direct children of .row */
/* ROW with gutter support */
.row {
    --bs-gutter-x: 1.5rem;
    --bs-gutter-y: 0;
    display: flex;
    flex-wrap: wrap;
    margin-top: calc(-1 * var(--bs-gutter-y));
    margin-right: calc(-0.5 * var(--bs-gutter-x));
    margin-left: calc(-0.5 * var(--bs-gutter-x));
}

.row > * {
    flex-shrink: 0;
    width: 100%;
    max-width: 100%;
    padding-right: calc(var(--bs-gutter-x) * 0.5);
    padding-left: calc(var(--bs-gutter-x) * 0.5);
    margin-top: var(--bs-gutter-y);
}

/* Base col class for auto sizing */
.col-auto {
    flex: 0 0 auto;
    width: auto;
}
.col {
    flex: 1 0 0%;
}

/* Fixed width cols */
.col-1 {
    flex: 0 0 auto;
    width: 8.333333%;
}

.col-2 {
    flex: 0 0 auto;
    width: 16.666667%;
}

.col-3 {
    flex: 0 0 auto;
    width: 25%;
}

.col-4 {
    flex: 0 0 auto;
    width: 33.333333%;
}

.col-5 {
    flex: 0 0 auto;
    width: 41.666667%;
}

.col-6 {
    flex: 0 0 auto;
    width: 50%;
}

.col-7 {
    flex: 0 0 auto;
    width: 58.333333%;
}

.col-8 {
    flex: 0 0 auto;
    width: 66.666667%;
}

.col-9 {
    flex: 0 0 auto;
    width: 75%;
}

.col-10 {
    flex: 0 0 auto;
    width: 83.333333%;
}

.col-11 {
    flex: 0 0 auto;
    width: 91.666667%;
}

.col-12 {
    flex: 0 0 auto;
    width: 100%;
}

/* Responsive breakpoints (sm ≥576px) */
@media (min-width: 576px) {
    .col-sm-auto {
        flex: 0 0 auto;
        width: auto;
    }
    .col-sm-1 {
        flex: 0 0 auto;
        width: 8.333333%;
    }

    .col-sm-2 {
        flex: 0 0 auto;
        width: 16.666667%;
    }

    .col-sm-3 {
        flex: 0 0 auto;
        width: 25%;
    }

    .col-sm-4 {
        flex: 0 0 auto;
        width: 33.333333%;
    }

    .col-sm-5 {
        flex: 0 0 auto;
        width: 41.666667%;
    }

    .col-sm-6 {
        flex: 0 0 auto;
        width: 50%;
    }

    .col-sm-7 {
        flex: 0 0 auto;
        width: 58.333333%;
    }

    .col-sm-8 {
        flex: 0 0 auto;
        width: 66.666667%;
    }

    .col-sm-9 {
        flex: 0 0 auto;
        width: 75%;
    }

    .col-sm-10 {
        flex: 0 0 auto;
        width: 83.333333%;
    }

    .col-sm-11 {
        flex: 0 0 auto;
        width: 91.666667%;
    }

    .col-sm-12 {
        flex: 0 0 auto;
        width: 100%;
    }
}

/* md ≥768px */
@media (min-width: 768px) {
    .col-md-auto {
        flex: 0 0 auto;
        width: auto;
    }
    .col-md-1 {
        flex: 0 0 auto;
        width: 8.333333%;
    }

    .col-md-2 {
        flex: 0 0 auto;
        width: 16.666667%;
    }

    .col-md-3 {
        flex: 0 0 auto;
        width: 25%;
    }

    .col-md-4 {
        flex: 0 0 auto;
        width: 33.333333%;
    }

    .col-md-5 {
        flex: 0 0 auto;
        width: 41.666667%;
    }

    .col-md-6 {
        flex: 0 0 auto;
        width: 50%;
    }

    .col-md-7 {
        flex: 0 0 auto;
        width: 58.333333%;
    }

    .col-md-8 {
        flex: 0 0 auto;
        width: 66.666667%;
    }

    .col-md-9 {
        flex: 0 0 auto;
        width: 75%;
    }

    .col-md-10 {
        flex: 0 0 auto;
        width: 83.333333%;
    }

    .col-md-11 {
        flex: 0 0 auto;
        width: 91.666667%;
    }

    .col-md-12 {
        flex: 0 0 auto;
        width: 100%;
    }
}

/* lg ≥992px */
@media (min-width: 992px) {
    .col-lg-auto {
        flex: 0 0 auto;
        width: auto;
    }
    .col-lg-1 {
        flex: 0 0 auto;
        width: 8.333333%;
    }

    .col-lg-2 {
        flex: 0 0 auto;
        width: 16.666667%;
    }

    .col-lg-3 {
        flex: 0 0 auto;
        width: 25%;
    }

    .col-lg-4 {
        flex: 0 0 auto;
        width: 33.333333%;
    }

    .col-lg-5 {
        flex: 0 0 auto;
        width: 41.666667%;
    }

    .col-lg-6 {
        flex: 0 0 auto;
        width: 50%;
    }

    .col-lg-7 {
        flex: 0 0 auto;
        width: 58.333333%;
    }

    .col-lg-8 {
        flex: 0 0 auto;
        width: 66.666667%;
    }

    .col-lg-9 {
        flex: 0 0 auto;
        width: 75%;
    }

    .col-lg-10 {
        flex: 0 0 auto;
        width: 83.333333%;
    }

    .col-lg-11 {
        flex: 0 0 auto;
        width: 91.666667%;
    }

    .col-lg-12 {
        flex: 0 0 auto;
        width: 100%;
    }
}

/* xl ≥1200px */
@media (min-width: 1200px) {
    .col-xl-auto {
        flex: 0 0 auto;
        width: auto;
    }
    .col-xl-1 {
        flex: 0 0 auto;
        width: 8.333333%;
    }

    .col-xl-2 {
        flex: 0 0 auto;
        width: 16.666667%;
    }

    .col-xl-3 {
        flex: 0 0 auto;
        width: 25%;
    }

    .col-xl-4 {
        flex: 0 0 auto;
        width: 33.333333%;
    }

    .col-xl-5 {
        flex: 0 0 auto;
        width: 41.666667%;
    }

    .col-xl-6 {
        flex: 0 0 auto;
        width: 50%;
    }

    .col-xl-7 {
        flex: 0 0 auto;
        width: 58.333333%;
    }

    .col-xl-8 {
        flex: 0 0 auto;
        width: 66.666667%;
    }

    .col-xl-9 {
        flex: 0 0 auto;
        width: 75%;
    }

    .col-xl-10 {
        flex: 0 0 auto;
        width: 83.333333%;
    }

    .col-xl-11 {
        flex: 0 0 auto;
        width: 91.666667%;
    }

    .col-xl-12 {
        flex: 0 0 auto;
        width: 100%;
    }
}

/* Utility classes for offsets, ordering, etc. */
.offset-1 {
    margin-left: 8.333333%;
}

.offset-2 {
    margin-left: 16.666667%;
}

.offset-3 {
    margin-left: 25%;
}

.offset-4 {
    margin-left: 33.333333%;
}

.offset-5 {
    margin-left: 41.666667%;
}

.offset-6 {
    margin-left: 50%;
}

.offset-7 {
    margin-left: 58.333333%;
}

.offset-8 {
    margin-left: 66.666667%;
}

.offset-9 {
    margin-left: 75%;
}

.offset-10 {
    margin-left: 83.333333%;
}

.offset-11 {
    margin-left: 91.666667%;
}

.order-first {
    order: -1;
}

.order-last {
    order: 13;
}

.order-0 {
    order: 0;
}

.order-1 {
    order: 1;
}

.order-2 {
    order: 2;
}

.order-3 {
    order: 3;
}

.order-4 {
    order: 4;
}

.order-5 {
    order: 5;
}

.order-6 {
    order: 6;
}

.order-7 {
    order: 7;
}

.order-8 {
    order: 8;
}

.order-9 {
    order: 9;
}

.order-10 {
    order: 10;
}

.order-11 {
    order: 11;
}

.order-12 {
    order: 12;
}

/* Medium (≥768px) */
@media (min-width: 768px) {
    .order-md-0  { order: 0; }
    .order-md-1  { order: 1; }
    .order-md-2  { order: 2; }
    .order-md-3  { order: 3; }
    .order-md-4  { order: 4; }
    .order-md-5  { order: 5; }
    .order-md-6  { order: 6; }
    .order-md-7  { order: 7; }
    .order-md-8  { order: 8; }
    .order-md-9  { order: 9; }
    .order-md-10 { order: 10; }
    .order-md-first { order: -9999; }
    .order-md-last  { order: 9999; }
    .order-md-none  { order: 0; }
}

/* Large (≥1024px) */
@media (min-width: 1024px) {
    .order-lg-0  { order: 0; }
    .order-lg-1  { order: 1; }
    .order-lg-2  { order: 2; }
    .order-lg-3  { order: 3; }
    .order-lg-4  { order: 4; }
    .order-lg-5  { order: 5; }
    .order-lg-6  { order: 6; }
    .order-lg-7  { order: 7; }
    .order-lg-8  { order: 8; }
    .order-lg-9  { order: 9; }
    .order-lg-10 { order: 10; }
    .order-lg-first { order: -9999; }
    .order-lg-last  { order: 9999; }
    .order-lg-none  { order: 0; }
}
/**/

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

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

.align-items-center {
    align-items: center !important;
}

.align-items-baseline {
    align-items: baseline !important;
}

.align-items-stretch {
    align-items: stretch !important;
}


.justify-content-start {
    justify-content: flex-start !important;
}

.justify-content-end {
    justify-content: flex-end !important;
}

.justify-content-center {
    justify-content: center !important;
}

.justify-content-between {
    justify-content: space-between !important;
}

.justify-content-around {
    justify-content: space-around !important;
}

.justify-content-evenly {
    justify-content: space-evenly !important;
}

.align-self-start {
    align-self: flex-start !important;
}

.align-self-end {
    align-self: flex-end !important;
}

.align-self-center {
    align-self: center !important;
}

.align-self-baseline {
    align-self: baseline !important;
}

.align-self-stretch {
    align-self: stretch !important;
}


.text-start {
    text-align: left !important;
}

.text-center {
    text-align: center !important;
}

.text-end {
    text-align: right !important;
}

.d-flex {
    display: flex !important;
}

.d-inline-flex {
    display: inline-flex !important;
}

.d-grid {
    display: grid !important;
}

.d-inline-grid {
    display: inline-grid !important;
}
.d-block {
    display: block !important;
}
.d-inline {
    display: inline !important;
}
.d-inline-block {
    display: inline-block !important;
}

.d-none {
    display: none !important;
}

/* Breakpoint sizes */
@media (min-width: 576px) {
    .d-sm-none { display: none !important; }
    .d-sm-block { display: block !important; }
    .d-sm-inline { display: inline !important; }
    .d-sm-inline-block { display: inline-block !important; }
    .d-sm-flex { display: flex !important; }
    .d-sm-inline-flex { display: inline-flex !important; }
}

@media (min-width: 768px) {
    .d-md-none { display: none !important; }
    .d-md-block { display: block !important; }
    .d-md-inline { display: inline !important; }
    .d-md-inline-block { display: inline-block !important; }
    .d-md-flex { display: flex !important; }
    .d-md-inline-flex { display: inline-flex !important; }
}

@media (min-width: 992px) {
    .d-lg-none { display: none !important; }
    .d-lg-block { display: block !important; }
    .d-lg-inline { display: inline !important; }
    .d-lg-inline-block { display: inline-block !important; }
    .d-lg-flex { display: flex !important; }
    .d-lg-inline-flex { display: inline-flex !important; }
}

@media (min-width: 1200px) {
    .d-xl-none { display: none !important; }
    .d-xl-block { display: block !important; }
    .d-xl-inline { display: inline !important; }
    .d-xl-inline-block { display: inline-block !important; }
    .d-xl-flex { display: flex !important; }
    .d-xl-inline-flex { display: inline-flex !important; }
}

@media (min-width: 1400px) {
    .d-xxl-none { display: none !important; }
    .d-xxl-block { display: block !important; }
    .d-xxl-inline { display: inline !important; }
    .d-xxl-inline-block { display: inline-block !important; }
    .d-xxl-flex { display: flex !important; }
    .d-xxl-inline-flex { display: inline-flex !important; }
}

@media (min-width: 576px) {
    .text-sm-start {
        text-align: left !important;
    }

    .text-sm-center {
        text-align: center !important;
    }

    .text-sm-end {
        text-align: right !important;
    }

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

    .align-items-sm-center {
        align-items: center !important;
    }

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

    .justify-content-sm-start {
        justify-content: flex-start !important;
    }

    .justify-content-sm-center {
        justify-content: center !important;
    }

    .justify-content-sm-end {
        justify-content: flex-end !important;
    }

    .justify-content-sm-between {
        justify-content: space-between !important;
    }

    .justify-content-sm-around {
        justify-content: space-around !important;
    }

    .justify-content-sm-evenly {
        justify-content: space-evenly !important;
    }
}

@media (min-width: 768px) {
    .text-md-start {
        text-align: left !important;
    }

    .text-md-center {
        text-align: center !important;
    }

    .text-md-end {
        text-align: right !important;
    }

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

    .align-items-md-center {
        align-items: center !important;
    }

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

    .justify-content-md-start {
        justify-content: flex-start !important;
    }

    .justify-content-md-center {
        justify-content: center !important;
    }

    .justify-content-md-end {
        justify-content: flex-end !important;
    }

    .justify-content-md-between {
        justify-content: space-between !important;
    }

    .justify-content-md-around {
        justify-content: space-around !important;
    }

    .justify-content-md-evenly {
        justify-content: space-evenly !important;
    }
}

@media (min-width: 992px) {
    .text-lg-start {
        text-align: left !important;
    }

    .text-lg-center {
        text-align: center !important;
    }

    .text-lg-end {
        text-align: right !important;
    }

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

    .align-items-lg-center {
        align-items: center !important;
    }

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

    .justify-content-lg-start {
        justify-content: flex-start !important;
    }

    .justify-content-lg-center {
        justify-content: center !important;
    }

    .justify-content-lg-end {
        justify-content: flex-end !important;
    }

    .justify-content-lg-between {
        justify-content: space-between !important;
    }

    .justify-content-lg-around {
        justify-content: space-around !important;
    }

    .justify-content-lg-evenly {
        justify-content: space-evenly !important;
    }
}

@media (min-width: 1200px) {
    .text-xl-start {
        text-align: left !important;
    }

    .text-xl-center {
        text-align: center !important;
    }

    .text-xl-end {
        text-align: right !important;
    }

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

    .align-items-xl-center {
        align-items: center !important;
    }

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

    .justify-content-xl-start {
        justify-content: flex-start !important;
    }

    .justify-content-xl-center {
        justify-content: center !important;
    }

    .justify-content-xl-end {
        justify-content: flex-end !important;
    }

    .justify-content-xl-between {
        justify-content: space-between !important;
    }

    .justify-content-xl-around {
        justify-content: space-around !important;
    }

    .justify-content-xl-evenly {
        justify-content: space-evenly !important;
    }
}

@media (min-width: 1400px) {
    .text-xxl-start {
        text-align: left !important;
    }

    .text-xxl-center {
        text-align: center !important;
    }

    .text-xxl-end {
        text-align: right !important;
    }

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

    .align-items-xxl-center {
        align-items: center !important;
    }

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

    .justify-content-xxl-start {
        justify-content: flex-start !important;
    }

    .justify-content-xxl-center {
        justify-content: center !important;
    }

    .justify-content-xxl-end {
        justify-content: flex-end !important;
    }

    .justify-content-xxl-between {
        justify-content: space-between !important;
    }

    .justify-content-xxl-around {
        justify-content: space-around !important;
    }

    .justify-content-xxl-evenly {
        justify-content: space-evenly !important;
    }
}
.flex-wrap{flex-wrap:wrap!important}
.flex-nowrap{flex-wrap:nowrap!important}
.flex-wrap-reverse{flex-wrap:wrap-reverse!important}
.flex-row{flex-direction:row!important}
.flex-row-reverse{flex-direction:row-reverse!important}
.flex-column{flex-direction:column!important}
.flex-column-reverse{flex-direction:column-reverse!important}
@media(min-width:576px){.flex-sm-wrap{flex-wrap:wrap!important}.flex-sm-nowrap{flex-wrap:nowrap!important}.flex-sm-wrap-reverse{flex-wrap:wrap-reverse!important}.flex-sm-row{flex-direction:row!important}.flex-sm-row-reverse{flex-direction:row-reverse!important}.flex-sm-column{flex-direction:column!important}.flex-sm-column-reverse{flex-direction:column-reverse!important}}
@media(min-width:768px){.flex-md-wrap{flex-wrap:wrap!important}.flex-md-nowrap{flex-wrap:nowrap!important}.flex-md-wrap-reverse{flex-wrap:wrap-reverse!important}.flex-md-row{flex-direction:row!important}.flex-md-row-reverse{flex-direction:row-reverse!important}.flex-md-column{flex-direction:column!important}.flex-md-column-reverse{flex-direction:column-reverse!important}}
@media(min-width:992px){.flex-lg-wrap{flex-wrap:wrap!important}.flex-lg-nowrap{flex-wrap:nowrap!important}.flex-lg-wrap-reverse{flex-wrap:wrap-reverse!important}.flex-lg-row{flex-direction:row!important}.flex-lg-row-reverse{flex-direction:row-reverse!important}.flex-lg-column{flex-direction:column!important}.flex-lg-column-reverse{flex-direction:column-reverse!important}}
@media(min-width:1200px){.flex-xl-wrap{flex-wrap:wrap!important}.flex-xl-nowrap{flex-wrap:nowrap!important}.flex-xl-wrap-reverse{flex-wrap:wrap-reverse!important}.flex-xl-row{flex-direction:row!important}.flex-xl-row-reverse{flex-direction:row-reverse!important}.flex-xl-column{flex-direction:column!important}.flex-xl-column-reverse{flex-direction:column-reverse!important}}
@media(min-width:1400px){.flex-xxl-wrap{flex-wrap:wrap!important}.flex-xxl-nowrap{flex-wrap:nowrap!important}.flex-xxl-wrap-reverse{flex-wrap:wrap-reverse!important}.flex-xxl-row{flex-direction:row!important}.flex-xxl-row-reverse{flex-direction:row-reverse!important}.flex-xxl-column{flex-direction:column!important}.flex-xxl-column-reverse{flex-direction:column-reverse!important}}

.gap-0 {
    gap: 0 !important;
}

.gap-1 {
    gap: 0.25rem !important;
}

/* 4px */
.gap-2 {
    gap: 0.5rem !important;
}

/* 8px */
.gap-3 {
    gap: 1rem !important;
}

/* 16px */
.gap-4 {
    gap: 1.5rem !important;
}

/* 24px */
.gap-5 {
    gap: 3rem !important;
}

/* 48px */

.row-gap-0 {
    row-gap: 0 !important;
}

.row-gap-1 {
    row-gap: 0.25rem !important;
}

.row-gap-2 {
    row-gap: 0.5rem !important;
}

.row-gap-3 {
    row-gap: 1rem !important;
}

.row-gap-4 {
    row-gap: 1.5rem !important;
}

.row-gap-5 {
    row-gap: 3rem !important;
}

.column-gap-0 {
    column-gap: 0 !important;
}

.column-gap-1 {
    column-gap: 0.25rem !important;
}

.column-gap-2 {
    column-gap: 0.5rem !important;
}

.column-gap-3 {
    column-gap: 1rem !important;
}

.column-gap-4 {
    column-gap: 1.5rem !important;
}

.column-gap-5 {
    column-gap: 3rem !important;
}


@media (min-width: 576px) {
    .gap-sm-0 {
        gap: 0 !important;
    }

    .gap-sm-1 {
        gap: 0.25rem !important;
    }

    .gap-sm-2 {
        gap: 0.5rem !important;
    }

    .gap-sm-3 {
        gap: 1rem !important;
    }

    .gap-sm-4 {
        gap: 1.5rem !important;
    }

    .gap-sm-5 {
        gap: 3rem !important;
    }
}

@media (min-width: 768px) {
    .gap-md-0 {
        gap: 0 !important;
    }

    .gap-md-1 {
        gap: 0.25rem !important;
    }

    .gap-md-2 {
        gap: 0.5rem !important;
    }

    .gap-md-3 {
        gap: 1rem !important;
    }

    .gap-md-4 {
        gap: 1.5rem !important;
    }

    .gap-md-5 {
        gap: 3rem !important;
    }
}

@media (min-width: 992px) {
    .gap-lg-0 {
        gap: 0 !important;
    }

    .gap-lg-1 {
        gap: 0.25rem !important;
    }

    .gap-lg-2 {
        gap: 0.5rem !important;
    }

    .gap-lg-3 {
        gap: 1rem !important;
    }

    .gap-lg-4 {
        gap: 1.5rem !important;
    }

    .gap-lg-5 {
        gap: 3rem !important;
    }
}

@media (min-width: 1200px) {
    .gap-xl-0 {
        gap: 0 !important;
    }

    .gap-xl-1 {
        gap: 0.25rem !important;
    }

    .gap-xl-2 {
        gap: 0.5rem !important;
    }

    .gap-xl-3 {
        gap: 1rem !important;
    }

    .gap-xl-4 {
        gap: 1.5rem !important;
    }

    .gap-xl-5 {
        gap: 3rem !important;
    }
}

@media (min-width: 1400px) {
    .gap-xxl-0 {
        gap: 0 !important;
    }

    .gap-xxl-1 {
        gap: 0.25rem !important;
    }

    .gap-xxl-2 {
        gap: 0.5rem !important;
    }

    .gap-xxl-3 {
        gap: 1rem !important;
    }

    .gap-xxl-4 {
        gap: 1.5rem !important;
    }

    .gap-xxl-5 {
        gap: 3rem !important;
    }
}


/* Base spacing scale */
:root {
    --space-0: 0;
    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-7: 1.75rem;
    --space-8: 2rem;
    --space-9: 2.5rem;
    --space-10: 3rem;
    --space-11: 4rem;
    --space-12: 5rem;
    --space-13: 6rem;
    --space-14: 8rem;
    --space-15: 10rem;
}

/* Margin Utilities */
.m-0 {
    margin: var(--space-0) !important;
}

.m-1 {
    margin: var(--space-1) !important;
}

.m-2 {
    margin: var(--space-2) !important;
}

.m-3 {
    margin: var(--space-3) !important;
}

.m-4 {
    margin: var(--space-4) !important;
}

.m-5 {
    margin: var(--space-5) !important;
}

.m-6 {
    margin: var(--space-6) !important;
}

.m-7 {
    margin: var(--space-7) !important;
}

.m-8 {
    margin: var(--space-8) !important;
}

.m-9 {
    margin: var(--space-9) !important;
}

.m-10 {
    margin: var(--space-10) !important;
}

.m-11 {
    margin: var(--space-11) !important;
}

.m-12 {
    margin: var(--space-12) !important;
}

.m-13 {
    margin: var(--space-13) !important;
}

.m-14 {
    margin: var(--space-14) !important;
}

.m-15 {
    margin: var(--space-15) !important;
}
/* SM (≥576px) */
@media (min-width: 576px) {
    .sm-m-0  { margin: var(--space-0) !important; }
    .sm-m-1  { margin: var(--space-1) !important; }
    .sm-m-2  { margin: var(--space-2) !important; }
    .sm-m-3  { margin: var(--space-3) !important; }
    .sm-m-4  { margin: var(--space-4) !important; }
    .sm-m-5  { margin: var(--space-5) !important; }
    .sm-m-6  { margin: var(--space-6) !important; }
    .sm-m-7  { margin: var(--space-7) !important; }
    .sm-m-8  { margin: var(--space-8) !important; }
    .sm-m-9  { margin: var(--space-9) !important; }
    .sm-m-10 { margin: var(--space-10) !important; }
    .sm-m-11 { margin: var(--space-11) !important; }
    .sm-m-12 { margin: var(--space-12) !important; }
    .sm-m-13 { margin: var(--space-13) !important; }
    .sm-m-14 { margin: var(--space-14) !important; }
    .sm-m-15 { margin: var(--space-15) !important; }
}

/* MD (≥768px) */
@media (min-width: 768px) {
    .md-m-0  { margin: var(--space-0) !important; }
    .md-m-1  { margin: var(--space-1) !important; }
    .md-m-2  { margin: var(--space-2) !important; }
    .md-m-3  { margin: var(--space-3) !important; }
    .md-m-4  { margin: var(--space-4) !important; }
    .md-m-5  { margin: var(--space-5) !important; }
    .md-m-6  { margin: var(--space-6) !important; }
    .md-m-7  { margin: var(--space-7) !important; }
    .md-m-8  { margin: var(--space-8) !important; }
    .md-m-9  { margin: var(--space-9) !important; }
    .md-m-10 { margin: var(--space-10) !important; }
    .md-m-11 { margin: var(--space-11) !important; }
    .md-m-12 { margin: var(--space-12) !important; }
    .md-m-13 { margin: var(--space-13) !important; }
    .md-m-14 { margin: var(--space-14) !important; }
    .md-m-15 { margin: var(--space-15) !important; }
}

/* LG (≥992px) */
@media (min-width: 992px) {
    .lg-m-0  { margin: var(--space-0) !important; }
    .lg-m-1  { margin: var(--space-1) !important; }
    .lg-m-2  { margin: var(--space-2) !important; }
    .lg-m-3  { margin: var(--space-3) !important; }
    .lg-m-4  { margin: var(--space-4) !important; }
    .lg-m-5  { margin: var(--space-5) !important; }
    .lg-m-6  { margin: var(--space-6) !important; }
    .lg-m-7  { margin: var(--space-7) !important; }
    .lg-m-8  { margin: var(--space-8) !important; }
    .lg-m-9  { margin: var(--space-9) !important; }
    .lg-m-10 { margin: var(--space-10) !important; }
    .lg-m-11 { margin: var(--space-11) !important; }
    .lg-m-12 { margin: var(--space-12) !important; }
    .lg-m-13 { margin: var(--space-13) !important; }
    .lg-m-14 { margin: var(--space-14) !important; }
    .lg-m-15 { margin: var(--space-15) !important; }
}

/* Margin Top */
.mt-0 {
    margin-top: var(--space-0) !important;
}

.mt-1 {
    margin-top: var(--space-1) !important;
}

.mt-2 {
    margin-top: var(--space-2) !important;
}

.mt-3 {
    margin-top: var(--space-3) !important;
}

.mt-4 {
    margin-top: var(--space-4) !important;
}

.mt-5 {
    margin-top: var(--space-5) !important;
}

.mt-6 {
    margin-top: var(--space-6) !important;
}

.mt-7 {
    margin-top: var(--space-7) !important;
}

.mt-8 {
    margin-top: var(--space-8) !important;
}

.mt-9 {
    margin-top: var(--space-9) !important;
}

.mt-10 {
    margin-top: var(--space-10) !important;
}

.mt-11 {
    margin-top: var(--space-11) !important;
}

.mt-12 {
    margin-top: var(--space-12) !important;
}

.mt-13 {
    margin-top: var(--space-13) !important;
}

.mt-14 {
    margin-top: var(--space-14) !important;
}

.mt-15 {
    margin-top: var(--space-15) !important;
}

@media (min-width: 576px) {
    .sm-mt-0  { margin-top: var(--space-0) !important; }
    .sm-mt-1  { margin-top: var(--space-1) !important; }
    .sm-mt-2  { margin-top: var(--space-2) !important; }
    .sm-mt-3  { margin-top: var(--space-3) !important; }
    .sm-mt-4  { margin-top: var(--space-4) !important; }
    .sm-mt-5  { margin-top: var(--space-5) !important; }
    .sm-mt-6  { margin-top: var(--space-6) !important; }
    .sm-mt-7  { margin-top: var(--space-7) !important; }
    .sm-mt-8  { margin-top: var(--space-8) !important; }
    .sm-mt-9  { margin-top: var(--space-9) !important; }
    .sm-mt-10 { margin-top: var(--space-10) !important; }
    .sm-mt-11 { margin-top: var(--space-11) !important; }
    .sm-mt-12 { margin-top: var(--space-12) !important; }
    .sm-mt-13 { margin-top: var(--space-13) !important; }
    .sm-mt-14 { margin-top: var(--space-14) !important; }
    .sm-mt-15 { margin-top: var(--space-15) !important; }
}
@media (min-width: 768px) {
    .md-mt-0  { margin-top: var(--space-0) !important; }
    .md-mt-1  { margin-top: var(--space-1) !important; }
    .md-mt-2  { margin-top: var(--space-2) !important; }
    .md-mt-3  { margin-top: var(--space-3) !important; }
    .md-mt-4  { margin-top: var(--space-4) !important; }
    .md-mt-5  { margin-top: var(--space-5) !important; }
    .md-mt-6  { margin-top: var(--space-6) !important; }
    .md-mt-7  { margin-top: var(--space-7) !important; }
    .md-mt-8  { margin-top: var(--space-8) !important; }
    .md-mt-9  { margin-top: var(--space-9) !important; }
    .md-mt-10 { margin-top: var(--space-10) !important; }
    .md-mt-11 { margin-top: var(--space-11) !important; }
    .md-mt-12 { margin-top: var(--space-12) !important; }
    .md-mt-13 { margin-top: var(--space-13) !important; }
    .md-mt-14 { margin-top: var(--space-14) !important; }
    .md-mt-15 { margin-top: var(--space-15) !important; }
}
@media (min-width: 992px) {
    .lg-mt-0  { margin-top: var(--space-0) !important; }
    .lg-mt-1  { margin-top: var(--space-1) !important; }
    .lg-mt-2  { margin-top: var(--space-2) !important; }
    .lg-mt-3  { margin-top: var(--space-3) !important; }
    .lg-mt-4  { margin-top: var(--space-4) !important; }
    .lg-mt-5  { margin-top: var(--space-5) !important; }
    .lg-mt-6  { margin-top: var(--space-6) !important; }
    .lg-mt-7  { margin-top: var(--space-7) !important; }
    .lg-mt-8  { margin-top: var(--space-8) !important; }
    .lg-mt-9  { margin-top: var(--space-9) !important; }
    .lg-mt-10 { margin-top: var(--space-10) !important; }
    .lg-mt-11 { margin-top: var(--space-11) !important; }
    .lg-mt-12 { margin-top: var(--space-12) !important; }
    .lg-mt-13 { margin-top: var(--space-13) !important; }
    .lg-mt-14 { margin-top: var(--space-14) !important; }
    .lg-mt-15 { margin-top: var(--space-15) !important; }
}
/* Margin Right */
.mr-0 {
    margin-right: var(--space-0) !important;
}

.mr-1 {
    margin-right: var(--space-1) !important;
}

.mr-2 {
    margin-right: var(--space-2) !important;
}

.mr-3 {
    margin-right: var(--space-3) !important;
}

.mr-4 {
    margin-right: var(--space-4) !important;
}

.mr-5 {
    margin-right: var(--space-5) !important;
}

.mr-6 {
    margin-right: var(--space-6) !important;
}

.mr-7 {
    margin-right: var(--space-7) !important;
}

.mr-8 {
    margin-right: var(--space-8) !important;
}

.mr-9 {
    margin-right: var(--space-9) !important;
}

.mr-10 {
    margin-right: var(--space-10) !important;
}

.mr-11 {
    margin-right: var(--space-11) !important;
}

.mr-12 {
    margin-right: var(--space-12) !important;
}

.mr-13 {
    margin-right: var(--space-13) !important;
}

.mr-14 {
    margin-right: var(--space-14) !important;
}

.mr-15 {
    margin-right: var(--space-15) !important;
}
@media (min-width: 576px) {
    .sm-mr-0  { margin-right: var(--space-0) !important; }
    .sm-mr-1  { margin-right: var(--space-1) !important; }
    .sm-mr-2  { margin-right: var(--space-2) !important; }
    .sm-mr-3  { margin-right: var(--space-3) !important; }
    .sm-mr-4  { margin-right: var(--space-4) !important; }
    .sm-mr-5  { margin-right: var(--space-5) !important; }
    .sm-mr-6  { margin-right: var(--space-6) !important; }
    .sm-mr-7  { margin-right: var(--space-7) !important; }
    .sm-mr-8  { margin-right: var(--space-8) !important; }
    .sm-mr-9  { margin-right: var(--space-9) !important; }
    .sm-mr-10 { margin-right: var(--space-10) !important; }
    .sm-mr-11 { margin-right: var(--space-11) !important; }
    .sm-mr-12 { margin-right: var(--space-12) !important; }
    .sm-mr-13 { margin-right: var(--space-13) !important; }
    .sm-mr-14 { margin-right: var(--space-14) !important; }
    .sm-mr-15 { margin-right: var(--space-15) !important; }
}
@media (min-width: 768px) {
    .md-mr-0  { margin-right: var(--space-0) !important; }
    .md-mr-1  { margin-right: var(--space-1) !important; }
    .md-mr-2  { margin-right: var(--space-2) !important; }
    .md-mr-3  { margin-right: var(--space-3) !important; }
    .md-mr-4  { margin-right: var(--space-4) !important; }
    .md-mr-5  { margin-right: var(--space-5) !important; }
    .md-mr-6  { margin-right: var(--space-6) !important; }
    .md-mr-7  { margin-right: var(--space-7) !important; }
    .md-mr-8  { margin-right: var(--space-8) !important; }
    .md-mr-9  { margin-right: var(--space-9) !important; }
    .md-mr-10 { margin-right: var(--space-10) !important; }
    .md-mr-11 { margin-right: var(--space-11) !important; }
    .md-mr-12 { margin-right: var(--space-12) !important; }
    .md-mr-13 { margin-right: var(--space-13) !important; }
    .md-mr-14 { margin-right: var(--space-14) !important; }
    .md-mr-15 { margin-right: var(--space-15) !important; }
}
@media (min-width: 992px) {
    .lg-mr-0  { margin-right: var(--space-0) !important; }
    .lg-mr-1  { margin-right: var(--space-1) !important; }
    .lg-mr-2  { margin-right: var(--space-2) !important; }
    .lg-mr-3  { margin-right: var(--space-3) !important; }
    .lg-mr-4  { margin-right: var(--space-4) !important; }
    .lg-mr-5  { margin-right: var(--space-5) !important; }
    .lg-mr-6  { margin-right: var(--space-6) !important; }
    .lg-mr-7  { margin-right: var(--space-7) !important; }
    .lg-mr-8  { margin-right: var(--space-8) !important; }
    .lg-mr-9  { margin-right: var(--space-9) !important; }
    .lg-mr-10 { margin-right: var(--space-10) !important; }
    .lg-mr-11 { margin-right: var(--space-11) !important; }
    .lg-mr-12 { margin-right: var(--space-12) !important; }
    .lg-mr-13 { margin-right: var(--space-13) !important; }
    .lg-mr-14 { margin-right: var(--space-14) !important; }
    .lg-mr-15 { margin-right: var(--space-15) !important; }
}
/* Margin Bottom */
.mb-0 {
    margin-bottom: var(--space-0) !important;
}

.mb-1 {
    margin-bottom: var(--space-1) !important;
}

.mb-2 {
    margin-bottom: var(--space-2) !important;
}

.mb-3 {
    margin-bottom: var(--space-3) !important;
}

.mb-4 {
    margin-bottom: var(--space-4) !important;
}

.mb-5 {
    margin-bottom: var(--space-5) !important;
}

.mb-6 {
    margin-bottom: var(--space-6) !important;
}

.mb-7 {
    margin-bottom: var(--space-7) !important;
}

.mb-8 {
    margin-bottom: var(--space-8) !important;
}

.mb-9 {
    margin-bottom: var(--space-9) !important;
}

.mb-10 {
    margin-bottom: var(--space-10) !important;
}

.mb-11 {
    margin-bottom: var(--space-11) !important;
}

.mb-12 {
    margin-bottom: var(--space-12) !important;
}

.mb-13 {
    margin-bottom: var(--space-13) !important;
}

.mb-14 {
    margin-bottom: var(--space-14) !important;
}

.mb-15 {
    margin-bottom: var(--space-15) !important;
}
@media (min-width: 576px) {
    .sm-mb-0  { margin-bottom: var(--space-0) !important; }
    .sm-mb-1  { margin-bottom: var(--space-1) !important; }
    .sm-mb-2  { margin-bottom: var(--space-2) !important; }
    .sm-mb-3  { margin-bottom: var(--space-3) !important; }
    .sm-mb-4  { margin-bottom: var(--space-4) !important; }
    .sm-mb-5  { margin-bottom: var(--space-5) !important; }
    .sm-mb-6  { margin-bottom: var(--space-6) !important; }
    .sm-mb-7  { margin-bottom: var(--space-7) !important; }
    .sm-mb-8  { margin-bottom: var(--space-8) !important; }
    .sm-mb-9  { margin-bottom: var(--space-9) !important; }
    .sm-mb-10 { margin-bottom: var(--space-10) !important; }
    .sm-mb-11 { margin-bottom: var(--space-11) !important; }
    .sm-mb-12 { margin-bottom: var(--space-12) !important; }
    .sm-mb-13 { margin-bottom: var(--space-13) !important; }
    .sm-mb-14 { margin-bottom: var(--space-14) !important; }
    .sm-mb-15 { margin-bottom: var(--space-15) !important; }
}
@media (min-width: 768px) {
    .md-mb-0  { margin-bottom: var(--space-0) !important; }
    .md-mb-1  { margin-bottom: var(--space-1) !important; }
    .md-mb-2  { margin-bottom: var(--space-2) !important; }
    .md-mb-3  { margin-bottom: var(--space-3) !important; }
    .md-mb-4  { margin-bottom: var(--space-4) !important; }
    .md-mb-5  { margin-bottom: var(--space-5) !important; }
    .md-mb-6  { margin-bottom: var(--space-6) !important; }
    .md-mb-7  { margin-bottom: var(--space-7) !important; }
    .md-mb-8  { margin-bottom: var(--space-8) !important; }
    .md-mb-9  { margin-bottom: var(--space-9) !important; }
    .md-mb-10 { margin-bottom: var(--space-10) !important; }
    .md-mb-11 { margin-bottom: var(--space-11) !important; }
    .md-mb-12 { margin-bottom: var(--space-12) !important; }
    .md-mb-13 { margin-bottom: var(--space-13) !important; }
    .md-mb-14 { margin-bottom: var(--space-14) !important; }
    .md-mb-15 { margin-bottom: var(--space-15) !important; }
}
@media (min-width: 992px) {
    .lg-mb-0  { margin-bottom: var(--space-0) !important; }
    .lg-mb-1  { margin-bottom: var(--space-1) !important; }
    .lg-mb-2  { margin-bottom: var(--space-2) !important; }
    .lg-mb-3  { margin-bottom: var(--space-3) !important; }
    .lg-mb-4  { margin-bottom: var(--space-4) !important; }
    .lg-mb-5  { margin-bottom: var(--space-5) !important; }
    .lg-mb-6  { margin-bottom: var(--space-6) !important; }
    .lg-mb-7  { margin-bottom: var(--space-7) !important; }
    .lg-mb-8  { margin-bottom: var(--space-8) !important; }
    .lg-mb-9  { margin-bottom: var(--space-9) !important; }
    .lg-mb-10 { margin-bottom: var(--space-10) !important; }
    .lg-mb-11 { margin-bottom: var(--space-11) !important; }
    .lg-mb-12 { margin-bottom: var(--space-12) !important; }
    .lg-mb-13 { margin-bottom: var(--space-13) !important; }
    .lg-mb-14 { margin-bottom: var(--space-14) !important; }
    .lg-mb-15 { margin-bottom: var(--space-15) !important; }
}
/* Margin Left */
.ml-0 {
    margin-left: var(--space-0) !important;
}

.ml-1 {
    margin-left: var(--space-1) !important;
}

.ml-2 {
    margin-left: var(--space-2) !important;
}

.ml-3 {
    margin-left: var(--space-3) !important;
}

.ml-4 {
    margin-left: var(--space-4) !important;
}

.ml-5 {
    margin-left: var(--space-5) !important;
}

.ml-6 {
    margin-left: var(--space-6) !important;
}

.ml-7 {
    margin-left: var(--space-7) !important;
}

.ml-8 {
    margin-left: var(--space-8) !important;
}

.ml-9 {
    margin-left: var(--space-9) !important;
}

.ml-10 {
    margin-left: var(--space-10) !important;
}

.ml-11 {
    margin-left: var(--space-11) !important;
}

.ml-12 {
    margin-left: var(--space-12) !important;
}

.ml-13 {
    margin-left: var(--space-13) !important;
}

.ml-14 {
    margin-left: var(--space-14) !important;
}

.ml-15 {
    margin-left: var(--space-15) !important;
}
@media (min-width: 576px) {
    .sm-ml-0  { margin-left: var(--space-0) !important; }
    .sm-ml-1  { margin-left: var(--space-1) !important; }
    .sm-ml-2  { margin-left: var(--space-2) !important; }
    .sm-ml-3  { margin-left: var(--space-3) !important; }
    .sm-ml-4  { margin-left: var(--space-4) !important; }
    .sm-ml-5  { margin-left: var(--space-5) !important; }
    .sm-ml-6  { margin-left: var(--space-6) !important; }
    .sm-ml-7  { margin-left: var(--space-7) !important; }
    .sm-ml-8  { margin-left: var(--space-8) !important; }
    .sm-ml-9  { margin-left: var(--space-9) !important; }
    .sm-ml-10 { margin-left: var(--space-10) !important; }
    .sm-ml-11 { margin-left: var(--space-11) !important; }
    .sm-ml-12 { margin-left: var(--space-12) !important; }
    .sm-ml-13 { margin-left: var(--space-13) !important; }
    .sm-ml-14 { margin-left: var(--space-14) !important; }
    .sm-ml-15 { margin-left: var(--space-15) !important; }
}
@media (min-width: 768px) {
    .md-ml-0  { margin-left: var(--space-0) !important; }
    .md-ml-1  { margin-left: var(--space-1) !important; }
    .md-ml-2  { margin-left: var(--space-2) !important; }
    .md-ml-3  { margin-left: var(--space-3) !important; }
    .md-ml-4  { margin-left: var(--space-4) !important; }
    .md-ml-5  { margin-left: var(--space-5) !important; }
    .md-ml-6  { margin-left: var(--space-6) !important; }
    .md-ml-7  { margin-left: var(--space-7) !important; }
    .md-ml-8  { margin-left: var(--space-8) !important; }
    .md-ml-9  { margin-left: var(--space-9) !important; }
    .md-ml-10 { margin-left: var(--space-10) !important; }
    .md-ml-11 { margin-left: var(--space-11) !important; }
    .md-ml-12 { margin-left: var(--space-12) !important; }
    .md-ml-13 { margin-left: var(--space-13) !important; }
    .md-ml-14 { margin-left: var(--space-14) !important; }
    .md-ml-15 { margin-left: var(--space-15) !important; }
}
@media (min-width: 992px) {
    .lg-ml-0  { margin-left: var(--space-0) !important; }
    .lg-ml-1  { margin-left: var(--space-1) !important; }
    .lg-ml-2  { margin-left: var(--space-2) !important; }
    .lg-ml-3  { margin-left: var(--space-3) !important; }
    .lg-ml-4  { margin-left: var(--space-4) !important; }
    .lg-ml-5  { margin-left: var(--space-5) !important; }
    .lg-ml-6  { margin-left: var(--space-6) !important; }
    .lg-ml-7  { margin-left: var(--space-7) !important; }
    .lg-ml-8  { margin-left: var(--space-8) !important; }
    .lg-ml-9  { margin-left: var(--space-9) !important; }
    .lg-ml-10 { margin-left: var(--space-10) !important; }
    .lg-ml-11 { margin-left: var(--space-11) !important; }
    .lg-ml-12 { margin-left: var(--space-12) !important; }
    .lg-ml-13 { margin-left: var(--space-13) !important; }
    .lg-ml-14 { margin-left: var(--space-14) !important; }
    .lg-ml-15 { margin-left: var(--space-15) !important; }
}
/* Margin X-Axis (left & right) */
.mx-0 {
    margin-left: var(--space-0) !important;
    margin-right: var(--space-0) !important;
}

.mx-1 {
    margin-left: var(--space-1) !important;
    margin-right: var(--space-1) !important;
}

.mx-2 {
    margin-left: var(--space-2) !important;
    margin-right: var(--space-2) !important;
}

.mx-3 {
    margin-left: var(--space-3) !important;
    margin-right: var(--space-3) !important;
}

.mx-4 {
    margin-left: var(--space-4) !important;
    margin-right: var(--space-4) !important;
}

.mx-5 {
    margin-left: var(--space-5) !important;
    margin-right: var(--space-5) !important;
}

.mx-6 {
    margin-left: var(--space-6) !important;
    margin-right: var(--space-6) !important;
}

.mx-7 {
    margin-left: var(--space-7) !important;
    margin-right: var(--space-7) !important;
}

.mx-8 {
    margin-left: var(--space-8) !important;
    margin-right: var(--space-8) !important;
}

.mx-9 {
    margin-left: var(--space-9) !important;
    margin-right: var(--space-9) !important;
}

.mx-10 {
    margin-left: var(--space-10) !important;
    margin-right: var(--space-10) !important;
}

.mx-11 {
    margin-left: var(--space-11) !important;
    margin-right: var(--space-11) !important;
}

.mx-12 {
    margin-left: var(--space-12) !important;
    margin-right: var(--space-12) !important;
}

.mx-13 {
    margin-left: var(--space-13) !important;
    margin-right: var(--space-13) !important;
}

.mx-14 {
    margin-left: var(--space-14) !important;
    margin-right: var(--space-14) !important;
}

.mx-15 {
    margin-left: var(--space-15) !important;
    margin-right: var(--space-15) !important;
}
@media (min-width: 576px) {
    .sm-mx-0  { margin-left: var(--space-0) !important; margin-right: var(--space-0) !important; }
    .sm-mx-1  { margin-left: var(--space-1) !important; margin-right: var(--space-1) !important; }
    .sm-mx-2  { margin-left: var(--space-2) !important; margin-right: var(--space-2) !important; }
    .sm-mx-3  { margin-left: var(--space-3) !important; margin-right: var(--space-3) !important; }
    .sm-mx-4  { margin-left: var(--space-4) !important; margin-right: var(--space-4) !important; }
    .sm-mx-5  { margin-left: var(--space-5) !important; margin-right: var(--space-5) !important; }
    .sm-mx-6  { margin-left: var(--space-6) !important; margin-right: var(--space-6) !important; }
    .sm-mx-7  { margin-left: var(--space-7) !important; margin-right: var(--space-7) !important; }
    .sm-mx-8  { margin-left: var(--space-8) !important; margin-right: var(--space-8) !important; }
    .sm-mx-9  { margin-left: var(--space-9) !important; margin-right: var(--space-9) !important; }
    .sm-mx-10 { margin-left: var(--space-10) !important; margin-right: var(--space-10) !important; }
    .sm-mx-11 { margin-left: var(--space-11) !important; margin-right: var(--space-11) !important; }
    .sm-mx-12 { margin-left: var(--space-12) !important; margin-right: var(--space-12) !important; }
    .sm-mx-13 { margin-left: var(--space-13) !important; margin-right: var(--space-13) !important; }
    .sm-mx-14 { margin-left: var(--space-14) !important; margin-right: var(--space-14) !important; }
    .sm-mx-15 { margin-left: var(--space-15) !important; margin-right: var(--space-15) !important; }
}
@media (min-width: 768px) {
    .md-mx-0  { margin-left: var(--space-0) !important; margin-right: var(--space-0) !important; }
    .md-mx-1  { margin-left: var(--space-1) !important; margin-right: var(--space-1) !important; }
    .md-mx-2  { margin-left: var(--space-2) !important; margin-right: var(--space-2) !important; }
    .md-mx-3  { margin-left: var(--space-3) !important; margin-right: var(--space-3) !important; }
    .md-mx-4  { margin-left: var(--space-4) !important; margin-right: var(--space-4) !important; }
    .md-mx-5  { margin-left: var(--space-5) !important; margin-right: var(--space-5) !important; }
    .md-mx-6  { margin-left: var(--space-6) !important; margin-right: var(--space-6) !important; }
    .md-mx-7  { margin-left: var(--space-7) !important; margin-right: var(--space-7) !important; }
    .md-mx-8  { margin-left: var(--space-8) !important; margin-right: var(--space-8) !important; }
    .md-mx-9  { margin-left: var(--space-9) !important; margin-right: var(--space-9) !important; }
    .md-mx-10 { margin-left: var(--space-10) !important; margin-right: var(--space-10) !important; }
    .md-mx-11 { margin-left: var(--space-11) !important; margin-right: var(--space-11) !important; }
    .md-mx-12 { margin-left: var(--space-12) !important; margin-right: var(--space-12) !important; }
    .md-mx-13 { margin-left: var(--space-13) !important; margin-right: var(--space-13) !important; }
    .md-mx-14 { margin-left: var(--space-14) !important; margin-right: var(--space-14) !important; }
    .md-mx-15 { margin-left: var(--space-15) !important; margin-right: var(--space-15) !important; }
}
@media (min-width: 992px) {
    .lg-mx-0  { margin-left: var(--space-0) !important; margin-right: var(--space-0) !important; }
    .lg-mx-1  { margin-left: var(--space-1) !important; margin-right: var(--space-1) !important; }
    .lg-mx-2  { margin-left: var(--space-2) !important; margin-right: var(--space-2) !important; }
    .lg-mx-3  { margin-left: var(--space-3) !important; margin-right: var(--space-3) !important; }
    .lg-mx-4  { margin-left: var(--space-4) !important; margin-right: var(--space-4) !important; }
    .lg-mx-5  { margin-left: var(--space-5) !important; margin-right: var(--space-5) !important; }
    .lg-mx-6  { margin-left: var(--space-6) !important; margin-right: var(--space-6) !important; }
    .lg-mx-7  { margin-left: var(--space-7) !important; margin-right: var(--space-7) !important; }
    .lg-mx-8  { margin-left: var(--space-8) !important; margin-right: var(--space-8) !important; }
    .lg-mx-9  { margin-left: var(--space-9) !important; margin-right: var(--space-9) !important; }
    .lg-mx-10 { margin-left: var(--space-10) !important; margin-right: var(--space-10) !important; }
    .lg-mx-11 { margin-left: var(--space-11) !important; margin-right: var(--space-11) !important; }
    .lg-mx-12 { margin-left: var(--space-12) !important; margin-right: var(--space-12) !important; }
    .lg-mx-13 { margin-left: var(--space-13) !important; margin-right: var(--space-13) !important; }
    .lg-mx-14 { margin-left: var(--space-14) !important; margin-right: var(--space-14) !important; }
    .lg-mx-15 { margin-left: var(--space-15) !important; margin-right: var(--space-15) !important; }
}
/* Margin Y-Axis (top & bottom) */
.my-0 {
    margin-top: var(--space-0) !important;
    margin-bottom: var(--space-0) !important;
}

.my-1 {
    margin-top: var(--space-1) !important;
    margin-bottom: var(--space-1) !important;
}

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

.my-3 {
    margin-top: var(--space-3) !important;
    margin-bottom: var(--space-3) !important;
}

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

.my-5 {
    margin-top: var(--space-5) !important;
    margin-bottom: var(--space-5) !important;
}

.my-6 {
    margin-top: var(--space-6) !important;
    margin-bottom: var(--space-6) !important;
}

.my-7 {
    margin-top: var(--space-7) !important;
    margin-bottom: var(--space-7) !important;
}

.my-8 {
    margin-top: var(--space-8) !important;
    margin-bottom: var(--space-8) !important;
}

.my-9 {
    margin-top: var(--space-9) !important;
    margin-bottom: var(--space-9) !important;
}

.my-10 {
    margin-top: var(--space-10) !important;
    margin-bottom: var(--space-10) !important;
}

.my-11 {
    margin-top: var(--space-11) !important;
    margin-bottom: var(--space-11) !important;
}

.my-12 {
    margin-top: var(--space-12) !important;
    margin-bottom: var(--space-12) !important;
}

.my-13 {
    margin-top: var(--space-13) !important;
    margin-bottom: var(--space-13) !important;
}

.my-14 {
    margin-top: var(--space-14) !important;
    margin-bottom: var(--space-14) !important;
}

.my-15 {
    margin-top: var(--space-15) !important;
    margin-bottom: var(--space-15) !important;
}

@media (min-width: 576px) {
    .sm-my-0  { margin-top: var(--space-0) !important; margin-bottom: var(--space-0) !important; }
    .sm-my-1  { margin-top: var(--space-1) !important; margin-bottom: var(--space-1) !important; }
    .sm-my-2  { margin-top: var(--space-2) !important; margin-bottom: var(--space-2) !important; }
    .sm-my-3  { margin-top: var(--space-3) !important; margin-bottom: var(--space-3) !important; }
    .sm-my-4  { margin-top: var(--space-4) !important; margin-bottom: var(--space-4) !important; }
    .sm-my-5  { margin-top: var(--space-5) !important; margin-bottom: var(--space-5) !important; }
    .sm-my-6  { margin-top: var(--space-6) !important; margin-bottom: var(--space-6) !important; }
    .sm-my-7  { margin-top: var(--space-7) !important; margin-bottom: var(--space-7) !important; }
    .sm-my-8  { margin-top: var(--space-8) !important; margin-bottom: var(--space-8) !important; }
    .sm-my-9  { margin-top: var(--space-9) !important; margin-bottom: var(--space-9) !important; }
    .sm-my-10 { margin-top: var(--space-10) !important; margin-bottom: var(--space-10) !important; }
    .sm-my-11 { margin-top: var(--space-11) !important; margin-bottom: var(--space-11) !important; }
    .sm-my-12 { margin-top: var(--space-12) !important; margin-bottom: var(--space-12) !important; }
    .sm-my-13 { margin-top: var(--space-13) !important; margin-bottom: var(--space-13) !important; }
    .sm-my-14 { margin-top: var(--space-14) !important; margin-bottom: var(--space-14) !important; }
    .sm-my-15 { margin-top: var(--space-15) !important; margin-bottom: var(--space-15) !important; }
}
@media (min-width: 768px) {
    .md-my-0  { margin-top: var(--space-0) !important; margin-bottom: var(--space-0) !important; }
    .md-my-1  { margin-top: var(--space-1) !important; margin-bottom: var(--space-1) !important; }
    .md-my-2  { margin-top: var(--space-2) !important; margin-bottom: var(--space-2) !important; }
    .md-my-3  { margin-top: var(--space-3) !important; margin-bottom: var(--space-3) !important; }
    .md-my-4  { margin-top: var(--space-4) !important; margin-bottom: var(--space-4) !important; }
    .md-my-5  { margin-top: var(--space-5) !important; margin-bottom: var(--space-5) !important; }
    .md-my-6  { margin-top: var(--space-6) !important; margin-bottom: var(--space-6) !important; }
    .md-my-7  { margin-top: var(--space-7) !important; margin-bottom: var(--space-7) !important; }
    .md-my-8  { margin-top: var(--space-8) !important; margin-bottom: var(--space-8) !important; }
    .md-my-9  { margin-top: var(--space-9) !important; margin-bottom: var(--space-9) !important; }
    .md-my-10 { margin-top: var(--space-10) !important; margin-bottom: var(--space-10) !important; }
    .md-my-11 { margin-top: var(--space-11) !important; margin-bottom: var(--space-11) !important; }
    .md-my-12 { margin-top: var(--space-12) !important; margin-bottom: var(--space-12) !important; }
    .md-my-13 { margin-top: var(--space-13) !important; margin-bottom: var(--space-13) !important; }
    .md-my-14 { margin-top: var(--space-14) !important; margin-bottom: var(--space-14) !important; }
    .md-my-15 { margin-top: var(--space-15) !important; margin-bottom: var(--space-15) !important; }
}
@media (min-width: 992px) {
    .lg-my-0  { margin-top: var(--space-0) !important; margin-bottom: var(--space-0) !important; }
    .lg-my-1  { margin-top: var(--space-1) !important; margin-bottom: var(--space-1) !important; }
    .lg-my-2  { margin-top: var(--space-2) !important; margin-bottom: var(--space-2) !important; }
    .lg-my-3  { margin-top: var(--space-3) !important; margin-bottom: var(--space-3) !important; }
    .lg-my-4  { margin-top: var(--space-4) !important; margin-bottom: var(--space-4) !important; }
    .lg-my-5  { margin-top: var(--space-5) !important; margin-bottom: var(--space-5) !important; }
    .lg-my-6  { margin-top: var(--space-6) !important; margin-bottom: var(--space-6) !important; }
    .lg-my-7  { margin-top: var(--space-7) !important; margin-bottom: var(--space-7) !important; }
    .lg-my-8  { margin-top: var(--space-8) !important; margin-bottom: var(--space-8) !important; }
    .lg-my-9  { margin-top: var(--space-9) !important; margin-bottom: var(--space-9) !important; }
    .lg-my-10 { margin-top: var(--space-10) !important; margin-bottom: var(--space-10) !important; }
    .lg-my-11 { margin-top: var(--space-11) !important; margin-bottom: var(--space-11) !important; }
    .lg-my-12 { margin-top: var(--space-12) !important; margin-bottom: var(--space-12) !important; }
    .lg-my-13 { margin-top: var(--space-13) !important; margin-bottom: var(--space-13) !important; }
    .lg-my-14 { margin-top: var(--space-14) !important; margin-bottom: var(--space-14) !important; }
    .lg-my-15 { margin-top: var(--space-15) !important; margin-bottom: var(--space-15) !important; }
}
.m-auto {
    margin: auto !important;
}

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

.my-auto {
    margin-top: auto !important;
    margin-bottom: auto !important;
}

.mt-auto {
    margin-top: auto !important;
}

.mb-auto {
    margin-bottom: auto !important;
}

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

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

/* Small (min-width: 576px) */
@media (min-width: 576px) {
    .sm-m-auto {
        margin: auto !important;
    }

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

    .sm-my-auto {
        margin-top: auto !important;
        margin-bottom: auto !important;
    }

    .sm-mt-auto {
        margin-top: auto !important;
    }

    .sm-mb-auto {
        margin-bottom: auto !important;
    }

    .sm-ms-auto {
        margin-left: auto !important;
    }

    .sm-me-auto {
        margin-right: auto !important;
    }
}

/* Medium (min-width: 768px) */
@media (min-width: 768px) {
    .md-m-auto {
        margin: auto !important;
    }

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

    .md-my-auto {
        margin-top: auto !important;
        margin-bottom: auto !important;
    }

    .md-mt-auto {
        margin-top: auto !important;
    }

    .md-mb-auto {
        margin-bottom: auto !important;
    }

    .md-ms-auto {
        margin-left: auto !important;
    }

    .md-me-auto {
        margin-right: auto !important;
    }
}

/* Large (min-width: 992px) */
@media (min-width: 992px) {
    .lg-m-auto {
        margin: auto !important;
    }

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

    .lg-my-auto {
        margin-top: auto !important;
        margin-bottom: auto !important;
    }

    .lg-mt-auto {
        margin-top: auto !important;
    }

    .lg-mb-auto {
        margin-bottom: auto !important;
    }

    .lg-ms-auto {
        margin-left: auto !important;
    }

    .lg-me-auto {
        margin-right: auto !important;
    }
}

/* Padding Utilities */
.p-0 {
    padding: var(--space-0) !important;
}

.p-1 {
    padding: var(--space-1) !important;
}

.p-2 {
    padding: var(--space-2) !important;
}

.p-3 {
    padding: var(--space-3) !important;
}

.p-4 {
    padding: var(--space-4) !important;
}

.p-5 {
    padding: var(--space-5) !important;
}

.p-6 {
    padding: var(--space-6) !important;
}

.p-7 {
    padding: var(--space-7) !important;
}

.p-8 {
    padding: var(--space-8) !important;
}

.p-9 {
    padding: var(--space-9) !important;
}

.p-10 {
    padding: var(--space-10) !important;
}

.p-11 {
    padding: var(--space-11) !important;
}

.p-12 {
    padding: var(--space-12) !important;
}

.p-13 {
    padding: var(--space-13) !important;
}

.p-14 {
    padding: var(--space-14) !important;
}

.p-15 {
    padding: var(--space-15) !important;
}
/* Small (≥576px) */
@media (min-width: 576px) {
    .sm-p-0  { padding: var(--space-0) !important; }
    .sm-p-1  { padding: var(--space-1) !important; }
    .sm-p-2  { padding: var(--space-2) !important; }
    .sm-p-3  { padding: var(--space-3) !important; }
    .sm-p-4  { padding: var(--space-4) !important; }
    .sm-p-5  { padding: var(--space-5) !important; }
    .sm-p-6  { padding: var(--space-6) !important; }
    .sm-p-7  { padding: var(--space-7) !important; }
    .sm-p-8  { padding: var(--space-8) !important; }
    .sm-p-9  { padding: var(--space-9) !important; }
    .sm-p-10 { padding: var(--space-10) !important; }
    .sm-p-11 { padding: var(--space-11) !important; }
    .sm-p-12 { padding: var(--space-12) !important; }
    .sm-p-13 { padding: var(--space-13) !important; }
    .sm-p-14 { padding: var(--space-14) !important; }
    .sm-p-15 { padding: var(--space-15) !important; }
}

/* Medium (≥768px) */
@media (min-width: 768px) {
    .md-p-0  { padding: var(--space-0) !important; }
    .md-p-1  { padding: var(--space-1) !important; }
    .md-p-2  { padding: var(--space-2) !important; }
    .md-p-3  { padding: var(--space-3) !important; }
    .md-p-4  { padding: var(--space-4) !important; }
    .md-p-5  { padding: var(--space-5) !important; }
    .md-p-6  { padding: var(--space-6) !important; }
    .md-p-7  { padding: var(--space-7) !important; }
    .md-p-8  { padding: var(--space-8) !important; }
    .md-p-9  { padding: var(--space-9) !important; }
    .md-p-10 { padding: var(--space-10) !important; }
    .md-p-11 { padding: var(--space-11) !important; }
    .md-p-12 { padding: var(--space-12) !important; }
    .md-p-13 { padding: var(--space-13) !important; }
    .md-p-14 { padding: var(--space-14) !important; }
    .md-p-15 { padding: var(--space-15) !important; }
}

/* Large (≥992px) */
@media (min-width: 992px) {
    .lg-p-0  { padding: var(--space-0) !important; }
    .lg-p-1  { padding: var(--space-1) !important; }
    .lg-p-2  { padding: var(--space-2) !important; }
    .lg-p-3  { padding: var(--space-3) !important; }
    .lg-p-4  { padding: var(--space-4) !important; }
    .lg-p-5  { padding: var(--space-5) !important; }
    .lg-p-6  { padding: var(--space-6) !important; }
    .lg-p-7  { padding: var(--space-7) !important; }
    .lg-p-8  { padding: var(--space-8) !important; }
    .lg-p-9  { padding: var(--space-9) !important; }
    .lg-p-10 { padding: var(--space-10) !important; }
    .lg-p-11 { padding: var(--space-11) !important; }
    .lg-p-12 { padding: var(--space-12) !important; }
    .lg-p-13 { padding: var(--space-13) !important; }
    .lg-p-14 { padding: var(--space-14) !important; }
    .lg-p-15 { padding: var(--space-15) !important; }
}

/* Padding Top */
.pt-0 {
    padding-top: var(--space-0) !important;
}

.pt-1 {
    padding-top: var(--space-1) !important;
}

.pt-2 {
    padding-top: var(--space-2) !important;
}

.pt-3 {
    padding-top: var(--space-3) !important;
}

.pt-4 {
    padding-top: var(--space-4) !important;
}

.pt-5 {
    padding-top: var(--space-5) !important;
}

.pt-6 {
    padding-top: var(--space-6) !important;
}

.pt-7 {
    padding-top: var(--space-7) !important;
}

.pt-8 {
    padding-top: var(--space-8) !important;
}

.pt-9 {
    padding-top: var(--space-9) !important;
}

.pt-10 {
    padding-top: var(--space-10) !important;
}

.pt-11 {
    padding-top: var(--space-11) !important;
}

.pt-12 {
    padding-top: var(--space-12) !important;
}

.pt-13 {
    padding-top: var(--space-13) !important;
}

.pt-14 {
    padding-top: var(--space-14) !important;
}

.pt-15 {
    padding-top: var(--space-15) !important;
}

/* Small (≥576px) */
@media (min-width: 576px) {
    .sm-pt-0  { padding-top: var(--space-0) !important; }
    .sm-pt-1  { padding-top: var(--space-1) !important; }
    .sm-pt-2  { padding-top: var(--space-2) !important; }
    .sm-pt-3  { padding-top: var(--space-3) !important; }
    .sm-pt-4  { padding-top: var(--space-4) !important; }
    .sm-pt-5  { padding-top: var(--space-5) !important; }
    .sm-pt-6  { padding-top: var(--space-6) !important; }
    .sm-pt-7  { padding-top: var(--space-7) !important; }
    .sm-pt-8  { padding-top: var(--space-8) !important; }
    .sm-pt-9  { padding-top: var(--space-9) !important; }
    .sm-pt-10 { padding-top: var(--space-10) !important; }
    .sm-pt-11 { padding-top: var(--space-11) !important; }
    .sm-pt-12 { padding-top: var(--space-12) !important; }
    .sm-pt-13 { padding-top: var(--space-13) !important; }
    .sm-pt-14 { padding-top: var(--space-14) !important; }
    .sm-pt-15 { padding-top: var(--space-15) !important; }
}

/* Medium (≥768px) */
@media (min-width: 768px) {
    .md-pt-0  { padding-top: var(--space-0) !important; }
    .md-pt-1  { padding-top: var(--space-1) !important; }
    .md-pt-2  { padding-top: var(--space-2) !important; }
    .md-pt-3  { padding-top: var(--space-3) !important; }
    .md-pt-4  { padding-top: var(--space-4) !important; }
    .md-pt-5  { padding-top: var(--space-5) !important; }
    .md-pt-6  { padding-top: var(--space-6) !important; }
    .md-pt-7  { padding-top: var(--space-7) !important; }
    .md-pt-8  { padding-top: var(--space-8) !important; }
    .md-pt-9  { padding-top: var(--space-9) !important; }
    .md-pt-10 { padding-top: var(--space-10) !important; }
    .md-pt-11 { padding-top: var(--space-11) !important; }
    .md-pt-12 { padding-top: var(--space-12) !important; }
    .md-pt-13 { padding-top: var(--space-13) !important; }
    .md-pt-14 { padding-top: var(--space-14) !important; }
    .md-pt-15 { padding-top: var(--space-15) !important; }
}

/* Large (≥992px) */
@media (min-width: 992px) {
    .lg-pt-0  { padding-top: var(--space-0) !important; }
    .lg-pt-1  { padding-top: var(--space-1) !important; }
    .lg-pt-2  { padding-top: var(--space-2) !important; }
    .lg-pt-3  { padding-top: var(--space-3) !important; }
    .lg-pt-4  { padding-top: var(--space-4) !important; }
    .lg-pt-5  { padding-top: var(--space-5) !important; }
    .lg-pt-6  { padding-top: var(--space-6) !important; }
    .lg-pt-7  { padding-top: var(--space-7) !important; }
    .lg-pt-8  { padding-top: var(--space-8) !important; }
    .lg-pt-9  { padding-top: var(--space-9) !important; }
    .lg-pt-10 { padding-top: var(--space-10) !important; }
    .lg-pt-11 { padding-top: var(--space-11) !important; }
    .lg-pt-12 { padding-top: var(--space-12) !important; }
    .lg-pt-13 { padding-top: var(--space-13) !important; }
    .lg-pt-14 { padding-top: var(--space-14) !important; }
    .lg-pt-15 { padding-top: var(--space-15) !important; }
}

/* Padding Right */
.pr-0 {
    padding-right: var(--space-0) !important;
}

.pr-1 {
    padding-right: var(--space-1) !important;
}

.pr-2 {
    padding-right: var(--space-2) !important;
}

.pr-3 {
    padding-right: var(--space-3) !important;
}

.pr-4 {
    padding-right: var(--space-4) !important;
}

.pr-5 {
    padding-right: var(--space-5) !important;
}

.pr-6 {
    padding-right: var(--space-6) !important;
}

.pr-7 {
    padding-right: var(--space-7) !important;
}

.pr-8 {
    padding-right: var(--space-8) !important;
}

.pr-9 {
    padding-right: var(--space-9) !important;
}

.pr-10 {
    padding-right: var(--space-10) !important;
}

.pr-11 {
    padding-right: var(--space-11) !important;
}

.pr-12 {
    padding-right: var(--space-12) !important;
}

.pr-13 {
    padding-right: var(--space-13) !important;
}

.pr-14 {
    padding-right: var(--space-14) !important;
}

.pr-15 {
    padding-right: var(--space-15) !important;
}
/* Small (≥576px) */
@media (min-width: 576px) {
    .sm-pr-0  { padding-right: var(--space-0) !important; }
    .sm-pr-1  { padding-right: var(--space-1) !important; }
    .sm-pr-2  { padding-right: var(--space-2) !important; }
    .sm-pr-3  { padding-right: var(--space-3) !important; }
    .sm-pr-4  { padding-right: var(--space-4) !important; }
    .sm-pr-5  { padding-right: var(--space-5) !important; }
    .sm-pr-6  { padding-right: var(--space-6) !important; }
    .sm-pr-7  { padding-right: var(--space-7) !important; }
    .sm-pr-8  { padding-right: var(--space-8) !important; }
    .sm-pr-9  { padding-right: var(--space-9) !important; }
    .sm-pr-10 { padding-right: var(--space-10) !important; }
    .sm-pr-11 { padding-right: var(--space-11) !important; }
    .sm-pr-12 { padding-right: var(--space-12) !important; }
    .sm-pr-13 { padding-right: var(--space-13) !important; }
    .sm-pr-14 { padding-right: var(--space-14) !important; }
    .sm-pr-15 { padding-right: var(--space-15) !important; }
}

/* Medium (≥768px) */
@media (min-width: 768px) {
    .md-pr-0  { padding-right: var(--space-0) !important; }
    .md-pr-1  { padding-right: var(--space-1) !important; }
    .md-pr-2  { padding-right: var(--space-2) !important; }
    .md-pr-3  { padding-right: var(--space-3) !important; }
    .md-pr-4  { padding-right: var(--space-4) !important; }
    .md-pr-5  { padding-right: var(--space-5) !important; }
    .md-pr-6  { padding-right: var(--space-6) !important; }
    .md-pr-7  { padding-right: var(--space-7) !important; }
    .md-pr-8  { padding-right: var(--space-8) !important; }
    .md-pr-9  { padding-right: var(--space-9) !important; }
    .md-pr-10 { padding-right: var(--space-10) !important; }
    .md-pr-11 { padding-right: var(--space-11) !important; }
    .md-pr-12 { padding-right: var(--space-12) !important; }
    .md-pr-13 { padding-right: var(--space-13) !important; }
    .md-pr-14 { padding-right: var(--space-14) !important; }
    .md-pr-15 { padding-right: var(--space-15) !important; }
}

/* Large (≥992px) */
@media (min-width: 992px) {
    .lg-pr-0  { padding-right: var(--space-0) !important; }
    .lg-pr-1  { padding-right: var(--space-1) !important; }
    .lg-pr-2  { padding-right: var(--space-2) !important; }
    .lg-pr-3  { padding-right: var(--space-3) !important; }
    .lg-pr-4  { padding-right: var(--space-4) !important; }
    .lg-pr-5  { padding-right: var(--space-5) !important; }
    .lg-pr-6  { padding-right: var(--space-6) !important; }
    .lg-pr-7  { padding-right: var(--space-7) !important; }
    .lg-pr-8  { padding-right: var(--space-8) !important; }
    .lg-pr-9  { padding-right: var(--space-9) !important; }
    .lg-pr-10 { padding-right: var(--space-10) !important; }
    .lg-pr-11 { padding-right: var(--space-11) !important; }
    .lg-pr-12 { padding-right: var(--space-12) !important; }
    .lg-pr-13 { padding-right: var(--space-13) !important; }
    .lg-pr-14 { padding-right: var(--space-14) !important; }
    .lg-pr-15 { padding-right: var(--space-15) !important; }
}
/* Padding Bottom */
.pb-0 {
    padding-bottom: var(--space-0) !important;
}

.pb-1 {
    padding-bottom: var(--space-1) !important;
}

.pb-2 {
    padding-bottom: var(--space-2) !important;
}

.pb-3 {
    padding-bottom: var(--space-3) !important;
}

.pb-4 {
    padding-bottom: var(--space-4) !important;
}

.pb-5 {
    padding-bottom: var(--space-5) !important;
}

.pb-6 {
    padding-bottom: var(--space-6) !important;
}

.pb-7 {
    padding-bottom: var(--space-7) !important;
}

.pb-8 {
    padding-bottom: var(--space-8) !important;
}

.pb-9 {
    padding-bottom: var(--space-9) !important;
}

.pb-10 {
    padding-bottom: var(--space-10) !important;
}

.pb-11 {
    padding-bottom: var(--space-11) !important;
}

.pb-12 {
    padding-bottom: var(--space-12) !important;
}

.pb-13 {
    padding-bottom: var(--space-13) !important;
}

.pb-14 {
    padding-bottom: var(--space-14) !important;
}

.pb-15 {
    padding-bottom: var(--space-15) !important;
}

/* Small (≥576px) */
@media (min-width: 576px) {
    .sm-pb-0  { padding-bottom: var(--space-0) !important; }
    .sm-pb-1  { padding-bottom: var(--space-1) !important; }
    .sm-pb-2  { padding-bottom: var(--space-2) !important; }
    .sm-pb-3  { padding-bottom: var(--space-3) !important; }
    .sm-pb-4  { padding-bottom: var(--space-4) !important; }
    .sm-pb-5  { padding-bottom: var(--space-5) !important; }
    .sm-pb-6  { padding-bottom: var(--space-6) !important; }
    .sm-pb-7  { padding-bottom: var(--space-7) !important; }
    .sm-pb-8  { padding-bottom: var(--space-8) !important; }
    .sm-pb-9  { padding-bottom: var(--space-9) !important; }
    .sm-pb-10 { padding-bottom: var(--space-10) !important; }
    .sm-pb-11 { padding-bottom: var(--space-11) !important; }
    .sm-pb-12 { padding-bottom: var(--space-12) !important; }
    .sm-pb-13 { padding-bottom: var(--space-13) !important; }
    .sm-pb-14 { padding-bottom: var(--space-14) !important; }
    .sm-pb-15 { padding-bottom: var(--space-15) !important; }
}

/* Medium (≥768px) */
@media (min-width: 768px) {
    .md-pb-0  { padding-bottom: var(--space-0) !important; }
    .md-pb-1  { padding-bottom: var(--space-1) !important; }
    .md-pb-2  { padding-bottom: var(--space-2) !important; }
    .md-pb-3  { padding-bottom: var(--space-3) !important; }
    .md-pb-4  { padding-bottom: var(--space-4) !important; }
    .md-pb-5  { padding-bottom: var(--space-5) !important; }
    .md-pb-6  { padding-bottom: var(--space-6) !important; }
    .md-pb-7  { padding-bottom: var(--space-7) !important; }
    .md-pb-8  { padding-bottom: var(--space-8) !important; }
    .md-pb-9  { padding-bottom: var(--space-9) !important; }
    .md-pb-10 { padding-bottom: var(--space-10) !important; }
    .md-pb-11 { padding-bottom: var(--space-11) !important; }
    .md-pb-12 { padding-bottom: var(--space-12) !important; }
    .md-pb-13 { padding-bottom: var(--space-13) !important; }
    .md-pb-14 { padding-bottom: var(--space-14) !important; }
    .md-pb-15 { padding-bottom: var(--space-15) !important; }
}

/* Large (≥992px) */
@media (min-width: 992px) {
    .lg-pb-0  { padding-bottom: var(--space-0) !important; }
    .lg-pb-1  { padding-bottom: var(--space-1) !important; }
    .lg-pb-2  { padding-bottom: var(--space-2) !important; }
    .lg-pb-3  { padding-bottom: var(--space-3) !important; }
    .lg-pb-4  { padding-bottom: var(--space-4) !important; }
    .lg-pb-5  { padding-bottom: var(--space-5) !important; }
    .lg-pb-6  { padding-bottom: var(--space-6) !important; }
    .lg-pb-7  { padding-bottom: var(--space-7) !important; }
    .lg-pb-8  { padding-bottom: var(--space-8) !important; }
    .lg-pb-9  { padding-bottom: var(--space-9) !important; }
    .lg-pb-10 { padding-bottom: var(--space-10) !important; }
    .lg-pb-11 { padding-bottom: var(--space-11) !important; }
    .lg-pb-12 { padding-bottom: var(--space-12) !important; }
    .lg-pb-13 { padding-bottom: var(--space-13) !important; }
    .lg-pb-14 { padding-bottom: var(--space-14) !important; }
    .lg-pb-15 { padding-bottom: var(--space-15) !important; }
}

/* Padding Left */
.pl-0 {
    padding-left: var(--space-0) !important;
}

.pl-1 {
    padding-left: var(--space-1) !important;
}

.pl-2 {
    padding-left: var(--space-2) !important;
}

.pl-3 {
    padding-left: var(--space-3) !important;
}

.pl-4 {
    padding-left: var(--space-4) !important;
}

.pl-5 {
    padding-left: var(--space-5) !important;
}

.pl-6 {
    padding-left: var(--space-6) !important;
}

.pl-7 {
    padding-left: var(--space-7) !important;
}

.pl-8 {
    padding-left: var(--space-8) !important;
}

.pl-9 {
    padding-left: var(--space-9) !important;
}

.pl-10 {
    padding-left: var(--space-10) !important;
}

.pl-11 {
    padding-left: var(--space-11) !important;
}

.pl-12 {
    padding-left: var(--space-12) !important;
}

.pl-13 {
    padding-left: var(--space-13) !important;
}

.pl-14 {
    padding-left: var(--space-14) !important;
}

.pl-15 {
    padding-left: var(--space-15) !important;
}
/* Small (≥576px) */
@media (min-width: 576px) {
    .sm-pl-0  { padding-left: var(--space-0) !important; }
    .sm-pl-1  { padding-left: var(--space-1) !important; }
    .sm-pl-2  { padding-left: var(--space-2) !important; }
    .sm-pl-3  { padding-left: var(--space-3) !important; }
    .sm-pl-4  { padding-left: var(--space-4) !important; }
    .sm-pl-5  { padding-left: var(--space-5) !important; }
    .sm-pl-6  { padding-left: var(--space-6) !important; }
    .sm-pl-7  { padding-left: var(--space-7) !important; }
    .sm-pl-8  { padding-left: var(--space-8) !important; }
    .sm-pl-9  { padding-left: var(--space-9) !important; }
    .sm-pl-10 { padding-left: var(--space-10) !important; }
    .sm-pl-11 { padding-left: var(--space-11) !important; }
    .sm-pl-12 { padding-left: var(--space-12) !important; }
    .sm-pl-13 { padding-left: var(--space-13) !important; }
    .sm-pl-14 { padding-left: var(--space-14) !important; }
    .sm-pl-15 { padding-left: var(--space-15) !important; }
}

/* Medium (≥768px) */
@media (min-width: 768px) {
    .md-pl-0  { padding-left: var(--space-0) !important; }
    .md-pl-1  { padding-left: var(--space-1) !important; }
    .md-pl-2  { padding-left: var(--space-2) !important; }
    .md-pl-3  { padding-left: var(--space-3) !important; }
    .md-pl-4  { padding-left: var(--space-4) !important; }
    .md-pl-5  { padding-left: var(--space-5) !important; }
    .md-pl-6  { padding-left: var(--space-6) !important; }
    .md-pl-7  { padding-left: var(--space-7) !important; }
    .md-pl-8  { padding-left: var(--space-8) !important; }
    .md-pl-9  { padding-left: var(--space-9) !important; }
    .md-pl-10 { padding-left: var(--space-10) !important; }
    .md-pl-11 { padding-left: var(--space-11) !important; }
    .md-pl-12 { padding-left: var(--space-12) !important; }
    .md-pl-13 { padding-left: var(--space-13) !important; }
    .md-pl-14 { padding-left: var(--space-14) !important; }
    .md-pl-15 { padding-left: var(--space-15) !important; }
}

/* Large (≥992px) */
@media (min-width: 992px) {
    .lg-pl-0  { padding-left: var(--space-0) !important; }
    .lg-pl-1  { padding-left: var(--space-1) !important; }
    .lg-pl-2  { padding-left: var(--space-2) !important; }
    .lg-pl-3  { padding-left: var(--space-3) !important; }
    .lg-pl-4  { padding-left: var(--space-4) !important; }
    .lg-pl-5  { padding-left: var(--space-5) !important; }
    .lg-pl-6  { padding-left: var(--space-6) !important; }
    .lg-pl-7  { padding-left: var(--space-7) !important; }
    .lg-pl-8  { padding-left: var(--space-8) !important; }
    .lg-pl-9  { padding-left: var(--space-9) !important; }
    .lg-pl-10 { padding-left: var(--space-10) !important; }
    .lg-pl-11 { padding-left: var(--space-11) !important; }
    .lg-pl-12 { padding-left: var(--space-12) !important; }
    .lg-pl-13 { padding-left: var(--space-13) !important; }
    .lg-pl-14 { padding-left: var(--space-14) !important; }
    .lg-pl-15 { padding-left: var(--space-15) !important; }
}

/* Padding X-Axis (left & right) */
.px-0 {
    padding-left: var(--space-0) !important;
    padding-right: var(--space-0) !important;
}

.px-1 {
    padding-left: var(--space-1) !important;
    padding-right: var(--space-1) !important;
}

.px-2 {
    padding-left: var(--space-2) !important;
    padding-right: var(--space-2) !important;
}

.px-3 {
    padding-left: var(--space-3) !important;
    padding-right: var(--space-3) !important;
}

.px-4 {
    padding-left: var(--space-4) !important;
    padding-right: var(--space-4) !important;
}

.px-5 {
    padding-left: var(--space-5) !important;
    padding-right: var(--space-5) !important;
}

.px-6 {
    padding-left: var(--space-6) !important;
    padding-right: var(--space-6) !important;
}

.px-7 {
    padding-left: var(--space-7) !important;
    padding-right: var(--space-7) !important;
}

.px-8 {
    padding-left: var(--space-8) !important;
    padding-right: var(--space-8) !important;
}

.px-9 {
    padding-left: var(--space-9) !important;
    padding-right: var(--space-9) !important;
}

.px-10 {
    padding-left: var(--space-10) !important;
    padding-right: var(--space-10) !important;
}

.px-11 {
    padding-left: var(--space-11) !important;
    padding-right: var(--space-11) !important;
}

.px-12 {
    padding-left: var(--space-12) !important;
    padding-right: var(--space-12) !important;
}

.px-13 {
    padding-left: var(--space-13) !important;
    padding-right: var(--space-13) !important;
}

.px-14 {
    padding-left: var(--space-14) !important;
    padding-right: var(--space-14) !important;
}

.px-15 {
    padding-left: var(--space-15) !important;
    padding-right: var(--space-15) !important;
}
/* Small (≥576px) */
@media (min-width: 576px) {
    .sm-px-0  { padding-left: var(--space-0) !important; padding-right: var(--space-0) !important; }
    .sm-px-1  { padding-left: var(--space-1) !important; padding-right: var(--space-1) !important; }
    .sm-px-2  { padding-left: var(--space-2) !important; padding-right: var(--space-2) !important; }
    .sm-px-3  { padding-left: var(--space-3) !important; padding-right: var(--space-3) !important; }
    .sm-px-4  { padding-left: var(--space-4) !important; padding-right: var(--space-4) !important; }
    .sm-px-5  { padding-left: var(--space-5) !important; padding-right: var(--space-5) !important; }
    .sm-px-6  { padding-left: var(--space-6) !important; padding-right: var(--space-6) !important; }
    .sm-px-7  { padding-left: var(--space-7) !important; padding-right: var(--space-7) !important; }
    .sm-px-8  { padding-left: var(--space-8) !important; padding-right: var(--space-8) !important; }
    .sm-px-9  { padding-left: var(--space-9) !important; padding-right: var(--space-9) !important; }
    .sm-px-10 { padding-left: var(--space-10) !important; padding-right: var(--space-10) !important; }
    .sm-px-11 { padding-left: var(--space-11) !important; padding-right: var(--space-11) !important; }
    .sm-px-12 { padding-left: var(--space-12) !important; padding-right: var(--space-12) !important; }
    .sm-px-13 { padding-left: var(--space-13) !important; padding-right: var(--space-13) !important; }
    .sm-px-14 { padding-left: var(--space-14) !important; padding-right: var(--space-14) !important; }
    .sm-px-15 { padding-left: var(--space-15) !important; padding-right: var(--space-15) !important; }
}

/* Medium (≥768px) */
@media (min-width: 768px) {
    .md-px-0  { padding-left: var(--space-0) !important; padding-right: var(--space-0) !important; }
    .md-px-1  { padding-left: var(--space-1) !important; padding-right: var(--space-1) !important; }
    .md-px-2  { padding-left: var(--space-2) !important; padding-right: var(--space-2) !important; }
    .md-px-3  { padding-left: var(--space-3) !important; padding-right: var(--space-3) !important; }
    .md-px-4  { padding-left: var(--space-4) !important; padding-right: var(--space-4) !important; }
    .md-px-5  { padding-left: var(--space-5) !important; padding-right: var(--space-5) !important; }
    .md-px-6  { padding-left: var(--space-6) !important; padding-right: var(--space-6) !important; }
    .md-px-7  { padding-left: var(--space-7) !important; padding-right: var(--space-7) !important; }
    .md-px-8  { padding-left: var(--space-8) !important; padding-right: var(--space-8) !important; }
    .md-px-9  { padding-left: var(--space-9) !important; padding-right: var(--space-9) !important; }
    .md-px-10 { padding-left: var(--space-10) !important; padding-right: var(--space-10) !important; }
    .md-px-11 { padding-left: var(--space-11) !important; padding-right: var(--space-11) !important; }
    .md-px-12 { padding-left: var(--space-12) !important; padding-right: var(--space-12) !important; }
    .md-px-13 { padding-left: var(--space-13) !important; padding-right: var(--space-13) !important; }
    .md-px-14 { padding-left: var(--space-14) !important; padding-right: var(--space-14) !important; }
    .md-px-15 { padding-left: var(--space-15) !important; padding-right: var(--space-15) !important; }
}

/* Large (≥992px) */
@media (min-width: 992px) {
    .lg-px-0  { padding-left: var(--space-0) !important; padding-right: var(--space-0) !important; }
    .lg-px-1  { padding-left: var(--space-1) !important; padding-right: var(--space-1) !important; }
    .lg-px-2  { padding-left: var(--space-2) !important; padding-right: var(--space-2) !important; }
    .lg-px-3  { padding-left: var(--space-3) !important; padding-right: var(--space-3) !important; }
    .lg-px-4  { padding-left: var(--space-4) !important; padding-right: var(--space-4) !important; }
    .lg-px-5  { padding-left: var(--space-5) !important; padding-right: var(--space-5) !important; }
    .lg-px-6  { padding-left: var(--space-6) !important; padding-right: var(--space-6) !important; }
    .lg-px-7  { padding-left: var(--space-7) !important; padding-right: var(--space-7) !important; }
    .lg-px-8  { padding-left: var(--space-8) !important; padding-right: var(--space-8) !important; }
    .lg-px-9  { padding-left: var(--space-9) !important; padding-right: var(--space-9) !important; }
    .lg-px-10 { padding-left: var(--space-10) !important; padding-right: var(--space-10) !important; }
    .lg-px-11 { padding-left: var(--space-11) !important; padding-right: var(--space-11) !important; }
    .lg-px-12 { padding-left: var(--space-12) !important; padding-right: var(--space-12) !important; }
    .lg-px-13 { padding-left: var(--space-13) !important; padding-right: var(--space-13) !important; }
    .lg-px-14 { padding-left: var(--space-14) !important; padding-right: var(--space-14) !important; }
    .lg-px-15 { padding-left: var(--space-15) !important; padding-right: var(--space-15) !important; }
}
/* Padding Y-Axis (top & bottom) */
.py-0 {
    padding-top: var(--space-0) !important;
    padding-bottom: var(--space-0) !important;
}

.py-1 {
    padding-top: var(--space-1) !important;
    padding-bottom: var(--space-1) !important;
}

.py-2 {
    padding-top: var(--space-2) !important;
    padding-bottom: var(--space-2) !important;
}

.py-3 {
    padding-top: var(--space-3) !important;
    padding-bottom: var(--space-3) !important;
}

.py-4 {
    padding-top: var(--space-4) !important;
    padding-bottom: var(--space-4) !important;
}

.py-5 {
    padding-top: var(--space-5) !important;
    padding-bottom: var(--space-5) !important;
}

.py-6 {
    padding-top: var(--space-6) !important;
    padding-bottom: var(--space-6) !important;
}

.py-7 {
    padding-top: var(--space-7) !important;
    padding-bottom: var(--space-7) !important;
}

.py-8 {
    padding-top: var(--space-8) !important;
    padding-bottom: var(--space-8) !important;
}

.py-9 {
    padding-top: var(--space-9) !important;
    padding-bottom: var(--space-9) !important;
}

.py-10 {
    padding-top: var(--space-10) !important;
    padding-bottom: var(--space-10) !important;
}

.py-11 {
    padding-top: var(--space-11) !important;
    padding-bottom: var(--space-11) !important;
}

.py-12 {
    padding-top: var(--space-12) !important;
    padding-bottom: var(--space-12) !important;
}

.py-13 {
    padding-top: var(--space-13) !important;
    padding-bottom: var(--space-13) !important;
}

.py-14 {
    padding-top: var(--space-14) !important;
    padding-bottom: var(--space-14) !important;
}

.py-15 {
    padding-top: var(--space-15) !important;
    padding-bottom: var(--space-15) !important;
}
/* Small (≥576px) */
@media (min-width: 576px) {
    .sm-py-0  { padding-top: var(--space-0) !important; padding-bottom: var(--space-0) !important; }
    .sm-py-1  { padding-top: var(--space-1) !important; padding-bottom: var(--space-1) !important; }
    .sm-py-2  { padding-top: var(--space-2) !important; padding-bottom: var(--space-2) !important; }
    .sm-py-3  { padding-top: var(--space-3) !important; padding-bottom: var(--space-3) !important; }
    .sm-py-4  { padding-top: var(--space-4) !important; padding-bottom: var(--space-4) !important; }
    .sm-py-5  { padding-top: var(--space-5) !important; padding-bottom: var(--space-5) !important; }
    .sm-py-6  { padding-top: var(--space-6) !important; padding-bottom: var(--space-6) !important; }
    .sm-py-7  { padding-top: var(--space-7) !important; padding-bottom: var(--space-7) !important; }
    .sm-py-8  { padding-top: var(--space-8) !important; padding-bottom: var(--space-8) !important; }
    .sm-py-9  { padding-top: var(--space-9) !important; padding-bottom: var(--space-9) !important; }
    .sm-py-10 { padding-top: var(--space-10) !important; padding-bottom: var(--space-10) !important; }
    .sm-py-11 { padding-top: var(--space-11) !important; padding-bottom: var(--space-11) !important; }
    .sm-py-12 { padding-top: var(--space-12) !important; padding-bottom: var(--space-12) !important; }
    .sm-py-13 { padding-top: var(--space-13) !important; padding-bottom: var(--space-13) !important; }
    .sm-py-14 { padding-top: var(--space-14) !important; padding-bottom: var(--space-14) !important; }
    .sm-py-15 { padding-top: var(--space-15) !important; padding-bottom: var(--space-15) !important; }
}

/* Medium (≥768px) */
@media (min-width: 768px) {
    .md-py-0  { padding-top: var(--space-0) !important; padding-bottom: var(--space-0) !important; }
    .md-py-1  { padding-top: var(--space-1) !important; padding-bottom: var(--space-1) !important; }
    .md-py-2  { padding-top: var(--space-2) !important; padding-bottom: var(--space-2) !important; }
    .md-py-3  { padding-top: var(--space-3) !important; padding-bottom: var(--space-3) !important; }
    .md-py-4  { padding-top: var(--space-4) !important; padding-bottom: var(--space-4) !important; }
    .md-py-5  { padding-top: var(--space-5) !important; padding-bottom: var(--space-5) !important; }
    .md-py-6  { padding-top: var(--space-6) !important; padding-bottom: var(--space-6) !important; }
    .md-py-7  { padding-top: var(--space-7) !important; padding-bottom: var(--space-7) !important; }
    .md-py-8  { padding-top: var(--space-8) !important; padding-bottom: var(--space-8) !important; }
    .md-py-9  { padding-top: var(--space-9) !important; padding-bottom: var(--space-9) !important; }
    .md-py-10 { padding-top: var(--space-10) !important; padding-bottom: var(--space-10) !important; }
    .md-py-11 { padding-top: var(--space-11) !important; padding-bottom: var(--space-11) !important; }
    .md-py-12 { padding-top: var(--space-12) !important; padding-bottom: var(--space-12) !important; }
    .md-py-13 { padding-top: var(--space-13) !important; padding-bottom: var(--space-13) !important; }
    .md-py-14 { padding-top: var(--space-14) !important; padding-bottom: var(--space-14) !important; }
    .md-py-15 { padding-top: var(--space-15) !important; padding-bottom: var(--space-15) !important; }
}

/* Large (≥992px) */
@media (min-width: 992px) {
    .lg-py-0  { padding-top: var(--space-0) !important; padding-bottom: var(--space-0) !important; }
    .lg-py-1  { padding-top: var(--space-1) !important; padding-bottom: var(--space-1) !important; }
    .lg-py-2  { padding-top: var(--space-2) !important; padding-bottom: var(--space-2) !important; }
    .lg-py-3  { padding-top: var(--space-3) !important; padding-bottom: var(--space-3) !important; }
    .lg-py-4  { padding-top: var(--space-4) !important; padding-bottom: var(--space-4) !important; }
    .lg-py-5  { padding-top: var(--space-5) !important; padding-bottom: var(--space-5) !important; }
    .lg-py-6  { padding-top: var(--space-6) !important; padding-bottom: var(--space-6) !important; }
    .lg-py-7  { padding-top: var(--space-7) !important; padding-bottom: var(--space-7) !important; }
    .lg-py-8  { padding-top: var(--space-8) !important; padding-bottom: var(--space-8) !important; }
    .lg-py-9  { padding-top: var(--space-9) !important; padding-bottom: var(--space-9) !important; }
    .lg-py-10 { padding-top: var(--space-10) !important; padding-bottom: var(--space-10) !important; }
    .lg-py-11 { padding-top: var(--space-11) !important; padding-bottom: var(--space-11) !important; }
    .lg-py-12 { padding-top: var(--space-12) !important; padding-bottom: var(--space-12) !important; }
    .lg-py-13 { padding-top: var(--space-13) !important; padding-bottom: var(--space-13) !important; }
    .lg-py-14 { padding-top: var(--space-14) !important; padding-bottom: var(--space-14) !important; }
    .lg-py-15 { padding-top: var(--space-15) !important; padding-bottom: var(--space-15) !important; }
}
/* Responsive Breakpoints */
/* Small devices (landscape phones, 576px and up) */
@media (min-width: 576px) {
    .sm\:m-0 {
        margin: var(--space-0) !important;
    }

    .sm\:m-1 {
        margin: var(--space-1) !important;
    }

    /* Continue for all margin and padding classes with sm: prefix */
    /* Example: .sm\:mt-2, .sm\:px-4, etc. */
}

/* Medium devices (tablets, 768px and up) */
@media (min-width: 768px) {
    .md\:m-0 {
        margin: var(--space-0) !important;
    }

    .md\:m-1 {
        margin: var(--space-1) !important;
    }

    /* Continue for all margin and padding classes with md: prefix */
}

/* Large devices (desktops, 992px and up) */
@media (min-width: 992px) {
    .lg\:m-0 {
        margin: var(--space-0) !important;
    }

    .lg\:m-1 {
        margin: var(--space-1) !important;
    }

    /* Continue for all margin and padding classes with lg: prefix */
}

/* Extra large devices (large desktops, 1200px and up) */
@media (min-width: 1200px) {
    .xl\:m-0 {
        margin: var(--space-0) !important;
    }

    .xl\:m-1 {
        margin: var(--space-1) !important;
    }

    /* Continue for all margin and padding classes with xl: prefix */
}

/* Negative Margins (for pulling elements) */
.-m-1 {
    margin: calc(var(--space-1) * -1) !important;
}

.-mt-1 {
    margin-top: calc(var(--space-1) * -1) !important;
}

.-mr-1 {
    margin-right: calc(var(--space-1) * -1) !important;
}

.-mb-1 {
    margin-bottom: calc(var(--space-1) * -1) !important;
}

.-ml-1 {
    margin-left: calc(var(--space-1) * -1) !important;
}

.-mx-1 {
    margin-left: calc(var(--space-1) * -1);
    margin-right: calc(var(--space-1) * -1) !important;
}

.-my-1 {
    margin-top: calc(var(--space-1) * -1);
    margin-bottom: calc(var(--space-1) * -1) !important;
}


/**/
.overflow-auto {
    overflow: auto !important;
}

.overflow-hidden {
    overflow: hidden !important;
}

.overflow-visible {
    overflow: visible !important;
}

.overflow-scroll {
    overflow: scroll !important;
}

.overflow-x-auto {
    overflow-x: auto !important;
}

.overflow-x-hidden {
    overflow-x: hidden !important;
}

.overflow-x-visible {
    overflow-x: visible !important;
}

.overflow-x-scroll {
    overflow-x: scroll !important;
}

.overflow-y-auto {
    overflow-y: auto !important;
}

.overflow-y-hidden {
    overflow-y: hidden !important;
}

.overflow-y-visible {
    overflow-y: visible !important;
}

.overflow-y-scroll {
    overflow-y: scroll !important;
}

@media (min-width: 576px) {
    .sm-overflow-hidden {
        overflow: hidden !important;
    }

    .sm-overflow-x-auto {
        overflow-x: auto !important;
    }

    /* Add more as needed */
}

@media (min-width: 768px) {
    .md-overflow-hidden {
        overflow: hidden !important;
    }

    .md-overflow-y-scroll {
        overflow-y: scroll !important;
    }
}

@media (min-width: 992px) {
    .lg-overflow-visible {
        overflow: visible !important;
    }
}

/* Layout */
.section-wrapper {
    position: relative;
    padding-top: 48px;
    overflow: hidden;
    display: flex;
    align-items: center;
}

.text-primary {
    color: #0d6efd !important;
}

.text-secondary {
    color: #6c757d !important;
}

.text-success {
    color: #198754 !important;
}

.text-danger {
    color: #dc3545 !important;
}

.text-warning {
    color: #ffc107 !important;
}

.text-info {
    color: #0dcaf0 !important;
}

.text-light {
    color: #f8f9fa !important;
}

.text-dark {
    color: #212529 !important;
}

.text-body {
    color: #212529 !important;
}

.text-muted {
    color: #6c757d !important;
}

.text-white {
    color: #fff !important;
}

.text-black {
    color: #000 !important;
}


/* ============================
   Background Color Utilities
============================ */
.bg-white {
    background-color: #ffffff;
}

.bg-light {
    background-color: #f8f9fa !important;
}

.bg-dark {
    background-color: #212529 !important;
}

.bg-primary {
    background-color: #0d6efd !important;
}

.bg-secondary {
    background-color: #6c757d !important;
}

.bg-success {
    background-color: #198754 !important;
}

.bg-danger {
    background-color: #dc3545 !important;
}

.bg-warning {
    background-color: #ffc107 !important;
}

.bg-info {
    background-color: #0dcaf0 !important;
}

.bg-transparent {
    background-color: transparent !important;
}

.bg-gradient {
    background-image: var(--gradient-bg-color) !important;
}

/* ============================
   Width & Height Utilities
============================ */
.w-0 {
    width: 0 !important;
}

.w-25 {
    width: 25% !important;
}

.w-50 {
    width: 50% !important;
}

.w-75 {
    width: 75% !important;
}

.w-100 {
    width: 100% !important;
}

.w-auto {
    width: auto !important;
}

/* Small (mobile-first) */
@media (min-width: 576px) {
    .sm-w-25 {
        width: 25% !important;
    }

    .sm-w-50 {
        width: 50% !important;
    }

    .sm-w-75 {
        width: 75% !important;
    }

    .sm-w-100 {
        width: 100% !important;
    }

    .sm-w-auto {
        width: auto !important;
    }
}

/* Medium (tablet) */
@media (min-width: 768px) {
    .md-w-25 {
        width: 25% !important;
    }

    .md-w-50 {
        width: 50% !important;
    }

    .md-w-75 {
        width: 75% !important;
    }

    .md-w-100 {
        width: 100% !important;
    }

    .md-w-auto {
        width: auto !important;
    }
}

/* Large (desktop) */
@media (min-width: 992px) {
    .lg-w-25 {
        width: 25% !important;
    }

    .lg-w-50 {
        width: 50% !important;
    }

    .lg-w-75 {
        width: 75% !important;
    }

    .lg-w-100 {
        width: 100% !important;
    }

    .lg-w-auto {
        width: auto !important;
    }
}


.h-0 {
    height: 0 !important;
}

.h-25 {
    height: 25% !important;
}

.h-50 {
    height: 50% !important;
}

.h-75 {
    height: 75% !important;
}

.h-100 {
    height: 100% !important;
}

.h-auto {
    height: auto !important;
}

.h-100vh {
    height: 100vh !important;
}

.h-100px {
    height: 100px !important;
}

/* Small (mobile-first) */
@media (min-width: 576px) {
    .sm-h-25 {
        height: 25% !important;
    }

    .sm-h-50 {
        height: 50% !important;
    }

    .sm-h-75 {
        height: 75% !important;
    }

    .sm-h-100 {
        height: 100% !important;
    }

    .sm-h-auto {
        height: auto !important;
    }
}

/* Medium (tablet) */
@media (min-width: 768px) {
    .md-h-25 {
        height: 25% !important;
    }

    .md-h-50 {
        height: 50% !important;
    }

    .md-h-75 {
        height: 75% !important;
    }

    .md-h-100 {
        height: 100% !important;
    }

    .md-h-auto {
        height: auto !important;
    }
}

/* Large (desktop) */
@media (min-width: 992px) {
    .lg-h-25 {
        height: 25% !important;
    }

    .lg-h-50 {
        height: 50% !important;
    }

    .lg-h-75 {
        height: 75% !important;
    }

    .lg-h-100 {
        height: 100% !important;
    }

    .lg-h-auto {
        height: auto !important;
    }
}

/* ============================
   Position Utilities
============================ */
.position-static {
    position: static !important;
}

.position-relative {
    position: relative !important;
}

.position-absolute {
    position: absolute !important;
}

.position-fixed {
    position: fixed !important;
}

.position-sticky {
    position: sticky !important;
}


.top-0 {
    top: 0 !important;
}

.left-0 {
    left: 0 !important;
}

.right-0 {
    right: 0 !important;
}

.bottom-0 {
    bottom: 0 !important;
}

.top-50 {
    top: 50% !important;
}

.left-50 {
    left: 50% !important;
}

.right-50 {
    right: 50% !important;
}

.bottom-50 {
    bottom: 50% !important;
}

.top-100 {
    top: 100% !important;
}

.left-100 {
    left: 100% !important;
}

.right-100 {
    right: 100% !important;
}

.bottom-100 {
    bottom: 100% !important;
}

.translate-middle {
    transform: translate(-50%, -50%) !important;
}

.translate-middle-x {
    transform: translateX(-50%) !important;
}

.translate-middle-y {
    transform: translateY(-50%) !important;
}


/* Small Screens (≥576px) */
@media (min-width: 576px) {
    .sm-top-0 {
        top: 0 !important;
    }

    .sm-left-0 {
        left: 0 !important;
    }

    .sm-top-50 {
        top: 50% !important;
    }

    .sm-left-50 {
        left: 50% !important;
    }
}

/* Medium Screens (≥768px) */
@media (min-width: 768px) {
    .md-top-0 {
        top: 0 !important;
    }

    .md-left-0 {
        left: 0 !important;
    }

    .md-top-50 {
        top: 50% !important;
    }

    .md-left-50 {
        left: 50% !important;
    }
}

/* Large Screens (≥992px) */
@media (min-width: 992px) {
    .lg-top-0 {
        top: 0 !important;
    }

    .lg-left-0 {
        left: 0 !important;
    }

    .lg-top-50 {
        top: 50% !important;
    }

    .lg-left-50 {
        left: 50% !important;
    }
}

/* ============================
   Border Utilities
============================ */

.border {
    border: 1px solid #dee2e6 !important;
}

.border-top {
    border-top: 1px solid #dee2e6 !important;
}

.border-end {
    border-right: 1px solid #dee2e6 !important;
}

.border-bottom {
    border-bottom: 1px solid #dee2e6 !important;
}

.border-start {
    border-left: 1px solid #dee2e6 !important;
}

.border-0 {
    border: 0 !important;
}

.border-top-0 {
    border-top: 0 !important;
}

.border-end-0 {
    border-right: 0 !important;
}

.border-bottom-0 {
    border-bottom: 0 !important;
}

.border-start-0 {
    border-left: 0 !important;
}

.border-primary {
    border-color: #0d6efd !important;
}

.border-secondary {
    border-color: #6c757d !important;
}

.border-success {
    border-color: #198754 !important;
}

.border-danger {
    border-color: #dc3545 !important;
}

.border-warning {
    border-color: #ffc107 !important;
}

.border-info {
    border-color: #0dcaf0 !important;
}

.border-light {
    border-color: #f8f9fa !important;
}

.border-dark {
    border-color: #212529 !important;
}

.border-white {
    border-color: #fff !important;
}

.border-transparent {
    border-color: transparent !important;
}
.theme-border-primary {  border-color: var(--theme-primary-color) !important;}

.border-1 {
    border-width: 1px !important;
}

.border-2 {
    border-width: 2px !important;
}

.border-3 {
    border-width: 3px !important;
}

.border-4 {
    border-width: 4px !important;
}

.border-5 {
    border-width: 5px !important;
}

@media (min-width: 576px) {
    .border-sm {
        border: 1px solid #dee2e6 !important;
    }

    .border-sm-0 {
        border: 0 !important;
    }

    .border-sm-primary {
        border-color: #0d6efd !important;
    }

    .border-sm-2 {
        border-width: 2px !important;
    }
}

@media (min-width: 768px) {
    .border-md {
        border: 1px solid #dee2e6 !important;
    }

    .border-md-0 {
        border: 0 !important;
    }

    .border-md-success {
        border-color: #198754 !important;
    }

    .border-md-3 {
        border-width: 3px !important;
    }
}

@media (min-width: 992px) {
    .border-lg {
        border: 1px solid #dee2e6 !important;
    }

    .border-lg-0 {
        border: 0 !important;
    }

    .border-lg-danger {
        border-color: #dc3545 !important;
    }

    .border-lg-4 {
        border-width: 4px !important;
    }
}

@media (min-width: 1200px) {
    .border-xl {
        border: 1px solid #dee2e6 !important;
    }

    .border-xl-0 {
        border: 0 !important;
    }

    .border-xl-warning {
        border-color: #ffc107 !important;
    }

    .border-xl-5 {
        border-width: 5px !important;
    }
}

@media (min-width: 1400px) {
    .border-xxl {
        border: 1px solid #dee2e6 !important;
    }

    .border-xxl-0 {
        border: 0 !important;
    }

    .border-xxl-info {
        border-color: #0dcaf0 !important;
    }
}

/* ============================
   Border Radius Utilities
============================ */
.rounded-0 {
    border-radius: 0 !important;
}

.rounded-1 {
    border-radius: 0.2rem !important;
}

.rounded-2 {
    border-radius: 0.25rem !important;
}

.rounded-3 {
    border-radius: 0.5rem !important;
}

.rounded-4 {
    border-radius: 0.75rem !important;
}

.rounded-5 {
    border-radius: 1rem !important;
}

.rounded {
    border-radius: 0.25rem !important;
}

/* Default */
.rounded-pill {
    border-radius: 50rem !important;
}

.rounded-circle {
    border-radius: 50% !important;
}

/*Shadow*/
.shadow-none {
    box-shadow: none !important;
}

.shadow-sm {
    box-shadow: 0 .125rem .25rem rgba(0, 0, 0, 0.075) !important;
}

.shadow {
    box-shadow: 0 .5rem 1rem rgba(0, 0, 0, 0.15) !important;
}

.shadow-lg {
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.175) !important;
}

/*Button Style*/
.btn {
    display: inline-block;
    text-align: center;
    text-decoration: none;
    vertical-align: middle;
    user-select: none;
    background-color: var(--white);
    border: 1px solid transparent;
    text-transform: uppercase;
    padding: 0.375rem 0.75rem;
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.4;
    border-radius: 0.375rem;
    transition: all 0.2s ease-in-out;
    cursor: pointer;
    box-shadow: 0 4px 7px -1px rgba(0, 0, 0, .11), 0 2px 4px -1px rgba(0, 0, 0, .07);
}

.btn:hover:not(.btn-icon-only) {
    box-shadow: 0 3px 5px -1px rgba(0, 0, 0, .09), 0 2px 3px -1px rgba(0, 0, 0, .07);
    transform: scale(1.02);
}

.btn-primary {
    background-color: #0d6efd;
    color: var(--white) !important;
    border-color: #0d6efd;
}

.btn-primary:hover {
    background-color: #0b5ed7;
    border-color: #0a58ca;
}

.btn-secondary {
    background-color: #6c757d;
    color: var(--white) !important;
    border-color: #6c757d;
}

.btn-secondary:hover {
    background-color: #5c636a;
    border-color: #545b62;
}

.btn-success {
    background-color: #198754;
    color: var(--white) !important;
    border-color: #198754;
}

.btn-success:hover {
    background-color: #157347;
    border-color: #146c43;
}

.btn-danger {
    background-color: #dc3545;
    color: var(--white) !important;
    border-color: #dc3545;
}

.btn-danger:hover {
    background-color: #bb2d3b;
    border-color: #b02a37;
}

.btn-warning {
    background-color: #ffc107;
    color: #212529;
    border-color: #ffc107;
}

.btn-warning:hover {
    background-color: #e0a800;
    border-color: #d39e00;
}

.btn-info {
    background-color: #0dcaf0;
    color: #000;
    border-color: #0dcaf0;
}

.btn-info:hover {
    background-color: #31d2f2;
    border-color: #25cff2;
}

.btn-light {
    background-color: #f8f9fa;
    color: #000;
    border-color: #f8f9fa;
}

.btn-dark {
    background-color: #212529;
    color: var(--white) !important;
    border-color: #212529;
}

.btn-outline-primary {
    background-color: transparent;
    color: #0d6efd;
    border: 1px solid #0d6efd;
}

.btn-outline-primary:hover {
    background-color: #0d6efd;
    color: #fff;
}

.btn-outline-secondary {
    background-color: transparent;
    color: #6c757d;
    border: 1px solid #6c757d;
}

.btn-outline-secondary:hover {
    background-color: #6c757d;
    color: #fff;
}

.btn-sm {
    padding: 0.25rem 0.5rem;
    font-size: 0.875rem !important;
    border-radius: 0.25rem;
}

.btn-lg {
    padding: 0.5rem 1rem;
    font-size: 1.25rem;
    border-radius: 0.5rem;
}

.btn-block {
    display: block;
    width: 100% !important;
}

.btn:disabled, .btn.disabled {
    opacity: 0.65;
    cursor: not-allowed;
    pointer-events: none;
}

@media (min-width: 576px) {
    .sm-btn-block {
        width: 100% !important;
    }
}

@media (min-width: 768px) {
    .md-btn-block {
        width: 100% !important;
    }
}

@media (min-width: 992px) {
    .lg-btn-block {
        width: 100% !important;
    }
}

.font-thin {  font-weight: 100 !important;}
.font-light { font-weight: 300 !important;}
.font-normal { font-weight: 400 !important;}
.font-medium { font-weight: 500 !important;}
.font-semibold {  font-weight: 600 !important;}
.font-bold { font-weight: 700 !important;}
.font-black {  font-weight: 900 !important;}
.text-uppercase {  text-transform: uppercase !important;}
.text-decoration-line-through { text-decoration: line-through!important;}
.img-fluid { max-width: 100%;  height: auto;}

.box-blur {
    box-shadow: inset 0px 0px 2px #fefefed1;
    -webkit-backdrop-filter: saturate(200%) blur(30px);
    backdrop-filter: saturate(200%) blur(30px);
    background-color: rgba(255, 255, 255, 0.8) !important;
}
.shadow-blur {
    box-shadow: inset 0 0px 1px 1px rgba(254, 254, 254, 0.9), 0 20px 27px 0 rgba(0, 0, 0, 0.05) !important;
}

.vertical {
    position: absolute;
    background-color: transparent;
    height: 100%;
    right: 0;
    top: 0;
    width: 1px;
    background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.4), rgba(0, 0, 0, 0));
}
.move-on-hover {
    -webkit-transition: 0.2s ease-out;
    transition: 0.2s ease-out;
    overflow: hidden;
    -webkit-transform-origin: 50% 0;
    transform-origin: 50% 0;
    transform-origin: 50% 0;
    -webkit-transform: perspective(999px) rotateX(0deg) translate3d(0, 0, 0);
    transform: perspective(999px) rotateX(0deg) translate3d(0, 0, 0);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    will-change: transform, box-shadow;
}
.move-on-hover:hover {
    -webkit-transform: perspective(999px) rotateX(7deg) translate3d(0px, -4px, 5px);
    transform: perspective(999px) rotateX(7deg) translate3d(0px, -4px, 5px);
}
.user-select-none {user-select: none;}
.cursor-pointer {cursor: pointer;}


/* Base badge */
.badge{
    display: inline-block;
    padding: var(--badge-padding-y) var(--badge-padding-x);
    font-size: var(--badge-font-size);
    font-weight: var(--badge-font-weight);
    line-height: var(--badge-line-height);
    color: var(--badge-color-light);
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
    border-radius: var(--badge-border-radius);
    background-color: var(--badge-bg-secondary);
    user-select: none;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    box-sizing: border-box;
}

/* Size modifiers */
.badge-sm{ font-size: 0.65rem; padding: 0.18rem 0.35rem;}
.badge-lg{ font-size: 0.85rem;  padding: 0.28rem 0.5rem;}
/* Pill (rounded) */
.badge-pill{  border-radius: var(--badge-pill-radius); padding-left: calc(var(--badge-padding-x) + 0.1rem); padding-right: calc(var(--badge-padding-x) + 0.1rem);}

/* Color variants */
.badge-primary{ background-color: var(--badge-bg-primary); color: var(--badge-color-light); }
.badge-secondary{ background-color: var(--badge-bg-secondary); color: var(--badge-color-light); }
.badge-success{ background-color: var(--badge-bg-success); color: var(--badge-color-light); }
.badge-danger{ background-color: var(--badge-bg-danger); color: var(--badge-color-light); }
.badge-warning{ background-color: var(--badge-bg-warning); color: var(--badge-color-dark); }
.badge-info{ background-color: var(--badge-bg-info); color: var(--badge-color-dark); }
.badge-light{ background-color: var(--badge-bg-light); color: var(--badge-color-dark); }
.badge-dark{ background-color: var(--badge-bg-dark); color: var(--badge-color-light); }

/* Transparent link-like badge (acts as a link) */
.badge-link{ background: transparent; color: var(--badge-bg-primary); text-decoration: underline; padding: 0;  font-weight: 600;}
/* Outline variants (bordered, transparent background) */
.badge-outline{ background: transparent; color: var(--badge-color-light);  border: 1px solid rgba(255,255,255,0.15);}
.badge-outline.badge-light{ border-color: rgba(0,0,0,0.08); color: var(--badge-color-dark); }
/* Accessibility: focus-visible styling if badge is focusable (e.g., tabindex) */
.badge:focus,.badge:focus-visible{ outline: 3px solid rgba(13,110,253,0.25); outline-offset: 2px;}

/* Helpful utilities */
.badge + .badge{ margin-left: 0.25rem; } /* spacing between adjacent badges */
.badge-inverse{ filter: brightness(0.9); } /* small visual tweak */

/* Truncate long text inside a constrained badge */
.badge.truncate{  max-width: 8rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; display: inline-block;}

/* High-contrast mode: prefer plain borders and high contrast text */
@media (prefers-contrast: more){
    .badge{ box-shadow: none; border: 1px solid rgba(0,0,0,0.2); }
    .badge-warning{ color: #000; } /* ensure readability */
}
/* Spinner Border (Bootstrap-like) */
.spinner-border { display: inline-block; width: 2rem; height: 2rem; vertical-align: text-bottom; border: 0.25em solid currentColor; border-right-color: transparent;  border-radius: 50%; animation: spinner-border 0.75s linear infinite;}
/* Small size */
.spinner-border-sm { width: 1rem; height: 1rem; border-width: 0.2em;}
/* Animation */
@keyframes spinner-border {100% { transform: rotate(360deg); }}

/*modal Overlay background */
.modal {
    position:fixed;
    inset:0;
    display:none;                 /* hidden by default */
    align-items:center;
    justify-content:center;
    background:rgba(0,0,0,.5);
    z-index:1000;
}
.modal:target { display:flex; }

/* Dialog */
.modal-dialog {
    background:#fff;
    border-radius:.5rem;
    padding:1rem;
    width:90%;
    max-width:500px; /* default */
    position:relative;
    box-shadow:0 5px 20px rgba(0,0,0,.3);
    animation:fadeIn .25s ease;
}

/* Sizes */
.modal-sm  .modal-dialog { max-width:300px; }
.modal-md  .modal-dialog { max-width:600px; }
.modal-lg  .modal-dialog { max-width:900px; }
.modal-xl  .modal-dialog { max-width:1140px; }
.modal-fullscreen .modal-dialog {
    width:100%;
    max-width:none;
    height:100%;
    border-radius:0;
}

/* Responsive default scaling */
@media (min-width:576px){ .modal:not(.modal-sm):not(.modal-md):not(.modal-lg):not(.modal-xl):not(.modal-fullscreen) .modal-dialog{max-width:500px} }
@media (min-width:768px){ .modal:not(.modal-sm):not(.modal-md):not(.modal-lg):not(.modal-xl):not(.modal-fullscreen) .modal-dialog{max-width:700px} }
@media (min-width:992px){ .modal:not(.modal-sm):not(.modal-md):not(.modal-lg):not(.modal-xl):not(.modal-fullscreen) .modal-dialog{max-width:900px} }
@media (min-width:1200px){.modal:not(.modal-sm):not(.modal-md):not(.modal-lg):not(.modal-xl):not(.modal-fullscreen) .modal-dialog{max-width:1140px} }

/* Header */
.modal-header {
    display:flex;
    justify-content:space-between;
    align-items:center;
    border-bottom:1px solid #ddd;
    padding-bottom:.5rem;
}
.modal-title { margin:0; font-size:1.2rem; font-weight:bold; }
.close {
    text-decoration:none;
    font-size:1.5rem;
    color:#000;
}
.close:hover { color:#dc3545; }

/* Body */
.modal-body { padding:1rem 0; }

/* Animation */
@keyframes fadeIn {
    from{opacity:0;transform:translateY(-10px)}
    to{opacity:1;transform:translateY(0)}
}



/*fome*/
/* Base form-control */
.form-control {
    display: block;
    width: 100%;
    padding: 0.375rem 0.75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: #212529;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid #ced4da;
    border-radius: 0.375rem;
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
    font-family: inherit;
}

/* form-control css */
.form-control:focus {
    color: #212529;
    background-color: #fff;
    border-color: #86b7fe;
    outline: 0;
    box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}

/* Disabled */
.form-control:disabled,
.form-control[readonly] {
    background-color: #e9ecef;
    opacity: 1;
}

/* Placeholder */
.form-control::placeholder {
    color: #6c757d;
    opacity: 1;
}

/* Textarea */
textarea.form-control {
    min-height: calc(1.5em + 0.75rem + 2px);
}

/* Select */
select.form-control {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='gray' class='bi bi-caret-down-fill' viewBox='0 0 16 16'%3e%3cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592c.86 0 1.319 1.013.753 1.658l-4.796 5.482a1 1 0 0 1-1.506 0z'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    background-size: 16px 16px;
    padding-right: 2rem;
}
/* Size variants */
.form-control-sm {
    padding: 0.25rem 0.5rem;
    font-size: 0.875rem;
    border-radius: 0.25rem;
}
.form-control-lg {
    padding: 0.5rem 1rem;
    font-size: 1.25rem;
    border-radius: 0.5rem;
}

/*skeleton loader*/
:root {
    --sk-bg: #e5e7eb;     /* base gray */
    --sk-highlight: #f5f5f5;
    --sk-radius: 0.6rem;
    --sk-speed: 1.3s;
}
.skeleton { position: relative;overflow: hidden;background: var(--sk-bg);border-radius: var(--sk-radius);user-select: none;}
.skeleton::after { content: "";position: absolute;inset: 0; transform: translateX(-100%); background: linear-gradient(90deg, transparent, var(--sk-highlight), transparent); animation: shimmer var(--sk-speed) infinite;}
@keyframes shimmer { 100% { transform: translateX(100%); }}
