/* ===================================
   LAYOUT SYSTEMS
   =================================== */

/* ===== CONTAINERS ===== */
.container {
    max-width: var(--breakpoint-xl);
    margin: 0 auto;
    padding: 0 var(--spacing-md);
}

.container--fluid {
    max-width: none;
    padding: 0 var(--spacing-md);
}

.container--sm {
    max-width: var(--breakpoint-md);
}

.container--lg {
    max-width: var(--breakpoint-2xl);
}

/* ===== GRID SYSTEM ===== */
.grid {
    display: grid;
    gap: var(--spacing-md);
}

.grid--2-cols {
    grid-template-columns: repeat(2, 1fr);
}

.grid--3-cols {
    grid-template-columns: repeat(3, 1fr);
}

.grid--4-cols {
    grid-template-columns: repeat(4, 1fr);
}

.grid--5-cols {
    grid-template-columns: repeat(5, 1fr);
}

.grid--6-cols {
    grid-template-columns: repeat(6, 1fr);
}

.grid--auto-fit {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.grid--auto-fill {
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
}

/* ===== FLEXBOX UTILITIES ===== */
.flex {
    display: flex;
}

.flex--inline {
    display: inline-flex;
}

.flex--column {
    flex-direction: column;
}

.flex--row {
    flex-direction: row;
}

.flex--wrap {
    flex-wrap: wrap;
}

.flex--nowrap {
    flex-wrap: nowrap;
}

/* Flex Alignment */
.flex--center {
    align-items: center;
    justify-content: center;
}

.flex--start {
    align-items: flex-start;
    justify-content: flex-start;
}

.flex--end {
    align-items: flex-end;
    justify-content: flex-end;
}

.flex--between {
    justify-content: space-between;
}

.flex--around {
    justify-content: space-around;
}

.flex--evenly {
    justify-content: space-evenly;
}

.flex--stretch {
    align-items: stretch;
}

.flex--baseline {
    align-items: baseline;
}

/* ===== SPACING UTILITIES ===== */
/* Margin Top */
.mt-0 { margin-top: var(--spacing-0); }
.mt-1 { margin-top: var(--spacing-xs); }
.mt-2 { margin-top: var(--spacing-sm); }
.mt-3 { margin-top: var(--spacing-md); }
.mt-4 { margin-top: var(--spacing-lg); }
.mt-5 { margin-top: var(--spacing-xl); }
.mt-6 { margin-top: var(--spacing-2xl); }
.mt-7 { margin-top: var(--spacing-3xl); }
.mt-8 { margin-top: var(--spacing-4xl); }

/* Margin Bottom */
.mb-0 { margin-bottom: var(--spacing-0); }
.mb-1 { margin-bottom: var(--spacing-xs); }
.mb-2 { margin-bottom: var(--spacing-sm); }
.mb-3 { margin-bottom: var(--spacing-md); }
.mb-4 { margin-bottom: var(--spacing-lg); }
.mb-5 { margin-bottom: var(--spacing-xl); }
.mb-6 { margin-bottom: var(--spacing-2xl); }
.mb-7 { margin-bottom: var(--spacing-3xl); }
.mb-8 { margin-bottom: var(--spacing-4xl); }

/* Margin Left */
.ml-0 { margin-left: var(--spacing-0); }
.ml-1 { margin-left: var(--spacing-xs); }
.ml-2 { margin-left: var(--spacing-sm); }
.ml-3 { margin-left: var(--spacing-md); }
.ml-4 { margin-left: var(--spacing-lg); }
.ml-5 { margin-left: var(--spacing-xl); }
.ml-6 { margin-left: var(--spacing-2xl); }
.ml-7 { margin-left: var(--spacing-3xl); }
.ml-8 { margin-left: var(--spacing-4xl); }

/* Margin Right */
.mr-0 { margin-right: var(--spacing-0); }
.mr-1 { margin-right: var(--spacing-xs); }
.mr-2 { margin-right: var(--spacing-sm); }
.mr-3 { margin-right: var(--spacing-md); }
.mr-4 { margin-right: var(--spacing-lg); }
.mr-5 { margin-right: var(--spacing-xl); }
.mr-6 { margin-right: var(--spacing-2xl); }
.mr-7 { margin-right: var(--spacing-3xl); }
.mr-8 { margin-right: var(--spacing-4xl); }

/* Margin X (Left & Right) */
.mx-0 { margin-left: var(--spacing-0); margin-right: var(--spacing-0); }
.mx-1 { margin-left: var(--spacing-xs); margin-right: var(--spacing-xs); }
.mx-2 { margin-left: var(--spacing-sm); margin-right: var(--spacing-sm); }
.mx-3 { margin-left: var(--spacing-md); margin-right: var(--spacing-md); }
.mx-4 { margin-left: var(--spacing-lg); margin-right: var(--spacing-lg); }
.mx-5 { margin-left: var(--spacing-xl); margin-right: var(--spacing-xl); }
.mx-6 { margin-left: var(--spacing-2xl); margin-right: var(--spacing-2xl); }
.mx-7 { margin-left: var(--spacing-3xl); margin-right: var(--spacing-3xl); }
.mx-8 { margin-left: var(--spacing-4xl); margin-right: var(--spacing-4xl); }

/* Margin Y (Top & Bottom) */
.my-0 { margin-top: var(--spacing-0); margin-bottom: var(--spacing-0); }
.my-1 { margin-top: var(--spacing-xs); margin-bottom: var(--spacing-xs); }
.my-2 { margin-top: var(--spacing-sm); margin-bottom: var(--spacing-sm); }
.my-3 { margin-top: var(--spacing-md); margin-bottom: var(--spacing-md); }
.my-4 { margin-top: var(--spacing-lg); margin-bottom: var(--spacing-lg); }
.my-5 { margin-top: var(--spacing-xl); margin-bottom: var(--spacing-xl); }
.my-6 { margin-top: var(--spacing-2xl); margin-bottom: var(--spacing-2xl); }
.my-7 { margin-top: var(--spacing-3xl); margin-bottom: var(--spacing-3xl); }
.my-8 { margin-top: var(--spacing-4xl); margin-bottom: var(--spacing-4xl); }

/* Margin All */
.m-0 { margin: var(--spacing-0); }
.m-1 { margin: var(--spacing-xs); }
.m-2 { margin: var(--spacing-sm); }
.m-3 { margin: var(--spacing-md); }
.m-4 { margin: var(--spacing-lg); }
.m-5 { margin: var(--spacing-xl); }
.m-6 { margin: var(--spacing-2xl); }
.m-7 { margin: var(--spacing-3xl); }
.m-8 { margin: var(--spacing-4xl); }

/* Padding Top */
.pt-0 { padding-top: var(--spacing-0); }
.pt-1 { padding-top: var(--spacing-xs); }
.pt-2 { padding-top: var(--spacing-sm); }
.pt-3 { padding-top: var(--spacing-md); }
.pt-4 { padding-top: var(--spacing-lg); }
.pt-5 { padding-top: var(--spacing-xl); }
.pt-6 { padding-top: var(--spacing-2xl); }
.pt-7 { padding-top: var(--spacing-3xl); }
.pt-8 { padding-top: var(--spacing-4xl); }

/* Padding Bottom */
.pb-0 { padding-bottom: var(--spacing-0); }
.pb-1 { padding-bottom: var(--spacing-xs); }
.pb-2 { padding-bottom: var(--spacing-sm); }
.pb-3 { padding-bottom: var(--spacing-md); }
.pb-4 { padding-bottom: var(--spacing-lg); }
.pb-5 { padding-bottom: var(--spacing-xl); }
.pb-6 { padding-bottom: var(--spacing-2xl); }
.pb-7 { padding-bottom: var(--spacing-3xl); }
.pb-8 { padding-bottom: var(--spacing-4xl); }

/* Padding Left */
.pl-0 { padding-left: var(--spacing-0); }
.pl-1 { padding-left: var(--spacing-xs); }
.pl-2 { padding-left: var(--spacing-sm); }
.pl-3 { padding-left: var(--spacing-md); }
.pl-4 { padding-left: var(--spacing-lg); }
.pl-5 { padding-left: var(--spacing-xl); }
.pl-6 { padding-left: var(--spacing-2xl); }
.pl-7 { padding-left: var(--spacing-3xl); }
.pl-8 { padding-left: var(--spacing-4xl); }

/* Padding Right */
.pr-0 { padding-right: var(--spacing-0); }
.pr-1 { padding-right: var(--spacing-xs); }
.pr-2 { padding-right: var(--spacing-sm); }
.pr-3 { padding-right: var(--spacing-md); }
.pr-4 { padding-right: var(--spacing-lg); }
.pr-5 { padding-right: var(--spacing-xl); }
.pr-6 { padding-right: var(--spacing-2xl); }
.pr-7 { padding-right: var(--spacing-3xl); }
.pr-8 { padding-right: var(--spacing-4xl); }

/* Padding X (Left & Right) */
.px-0 { padding-left: var(--spacing-0); padding-right: var(--spacing-0); }
.px-1 { padding-left: var(--spacing-xs); padding-right: var(--spacing-xs); }
.px-2 { padding-left: var(--spacing-sm); padding-right: var(--spacing-sm); }
.px-3 { padding-left: var(--spacing-md); padding-right: var(--spacing-md); }
.px-4 { padding-left: var(--spacing-lg); padding-right: var(--spacing-lg); }
.px-5 { padding-left: var(--spacing-xl); padding-right: var(--spacing-xl); }
.px-6 { padding-left: var(--spacing-2xl); padding-right: var(--spacing-2xl); }
.px-7 { padding-left: var(--spacing-3xl); padding-right: var(--spacing-3xl); }
.px-8 { padding-left: var(--spacing-4xl); padding-right: var(--spacing-4xl); }

/* Padding Y (Top & Bottom) */
.py-0 { padding-top: var(--spacing-0); padding-bottom: var(--spacing-0); }
.py-1 { padding-top: var(--spacing-xs); padding-bottom: var(--spacing-xs); }
.py-2 { padding-top: var(--spacing-sm); padding-bottom: var(--spacing-sm); }
.py-3 { padding-top: var(--spacing-md); padding-bottom: var(--spacing-md); }
.py-4 { padding-top: var(--spacing-lg); padding-bottom: var(--spacing-lg); }
.py-5 { padding-top: var(--spacing-xl); padding-bottom: var(--spacing-xl); }
.py-6 { padding-top: var(--spacing-2xl); padding-bottom: var(--spacing-2xl); }
.py-7 { padding-top: var(--spacing-3xl); padding-bottom: var(--spacing-3xl); }
.py-8 { padding-top: var(--spacing-4xl); padding-bottom: var(--spacing-4xl); }

/* Padding All */
.p-0 { padding: var(--spacing-0); }
.p-1 { padding: var(--spacing-xs); }
.p-2 { padding: var(--spacing-sm); }
.p-3 { padding: var(--spacing-md); }
.p-4 { padding: var(--spacing-lg); }
.p-5 { padding: var(--spacing-xl); }
.p-6 { padding: var(--spacing-2xl); }
.p-7 { padding: var(--spacing-3xl); }
.p-8 { padding: var(--spacing-4xl); }

/* ===== POSITIONING ===== */
.relative { position: relative; }
.absolute { position: absolute; }
.fixed { position: fixed; }
.sticky { position: sticky; }
.static { position: static; }

/* ===== DISPLAY ===== */
.block { display: block; }
.inline { display: inline; }
.inline-block { display: inline-block; }
.hidden { display: none; }

/* ===== WIDTH & HEIGHT ===== */
.w-full { width: 100%; }
.h-full { height: 100%; }
.w-auto { width: auto; }
.h-auto { height: auto; }

/* ===== RESPONSIVE UTILITIES ===== */
@media (max-width: 1023px) {
    .grid--4-cols {
        grid-template-columns: repeat(3, 1fr);
    }
    
    .grid--5-cols,
    .grid--6-cols {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media (max-width: 767px) {
    .grid--3-cols,
    .grid--4-cols,
    .grid--5-cols,
    .grid--6-cols {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .container {
        padding: 0 var(--spacing-sm);
    }
    
    .flex--mobile-column {
        flex-direction: column;
    }
    
    .flex--mobile-wrap {
        flex-wrap: wrap;
    }
}

@media (max-width: 480px) {
    .grid--2-cols,
    .grid--3-cols,
    .grid--4-cols,
    .grid--5-cols,
    .grid--6-cols {
        grid-template-columns: 1fr;
    }
    
    .container {
        padding: 0 var(--spacing-xs);
    }
}

