/**
 * Layout
 * 
 * @package MinimalInk
 */

/* Container */
.container {
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: clamp(1rem, 5vw, 2rem);
    width: 100%;
}

.content-wrapper {
    max-width: var(--content-max);
    margin-inline: auto;
}

/* Grid System */
.grid {
    display: grid;
    gap: var(--gap);
}

.grid--2 {
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

.grid--3 {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.grid--4 {
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

/* Masonry Grid */
.grid--masonry {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    grid-auto-flow: dense;
    gap: var(--gap-sm);
}

/* Flexbox utilities */
.flex {
    display: flex;
}

.flex-col {
    flex-direction: column;
}

.flex-wrap {
    flex-wrap: wrap;
}

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

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

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

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

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

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

/* Spacing utilities */
.gap-sm {
    gap: var(--gap-sm);
}

.gap-md {
    gap: var(--gap);
}

.gap-lg {
    gap: var(--gap-lg);
}

/* Content area */
.content-area {
    padding-block: var(--space-3xl);
}

/* Site layout */
.site-main {
    min-height: 60vh;
}

/* Responsive breakpoints */
@media (max-width: 768px) {
    .grid--2,
    .grid--3,
    .grid--4 {
        grid-template-columns: 1fr;
    }
    
    .grid--masonry {
        grid-template-columns: 1fr;
    }
    
    .content-area {
        padding-block: var(--space-2xl);
    }
}

@media (min-width: 769px) and (max-width: 1024px) {
    .grid--3,
    .grid--4 {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .grid--masonry {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1025px) {
    .grid--4 {
        grid-template-columns: repeat(4, 1fr);
    }
    
    .grid--masonry {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* Aspect ratios */
.aspect-square {
    aspect-ratio: 1 / 1;
}

.aspect-video {
    aspect-ratio: 16 / 9;
}

.aspect-portrait {
    aspect-ratio: 3 / 4;
}

/* Width utilities */
.w-full {
    width: 100%;
}

.max-w-content {
    max-width: var(--content-max);
}

/* Height utilities */
.h-full {
    height: 100%;
}

.min-h-screen {
    min-height: 100vh;
}
