/* Layout Base Styles */
body {
    background-color: var(--color-bg-secondary);
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.main-content {
    flex: 1;
    width: 100%;
}

.container {
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 var(--space-lg);
}

.container--narrow {
    max-width: 768px;
}

.container--wide {
    max-width: 1536px;
}

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

.grid--2-cols {
    grid-template-columns: repeat(2, 1fr);
}

.grid--3-cols {
    grid-template-columns: repeat(3, 1fr);
}

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

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

.flex--center {
    justify-content: center;
    align-items: center;
}

.flex--between {
    justify-content: space-between;
    align-items: center;
}

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

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

/* Spacing Utilities */
.mt-sm { margin-top: var(--space-sm); }
.mt-md { margin-top: var(--space-md); }
.mt-lg { margin-top: var(--space-lg); }
.mt-xl { margin-top: var(--space-xl); }

.mb-sm { margin-bottom: var(--space-sm); }
.mb-md { margin-bottom: var(--space-md); }
.mb-lg { margin-bottom: var(--space-lg); }
.mb-xl { margin-bottom: var(--space-xl); }

.p-sm { padding: var(--space-sm); }
.p-md { padding: var(--space-md); }
.p-lg { padding: var(--space-lg); }
.p-xl { padding: var(--space-xl); }

/* Loading State */
.loading {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: var(--space-2xl);
    color: var(--color-text-secondary);
    font-size: var(--font-size-lg);
}

/* Error Message */
.error-message {
    padding: var(--space-md);
    background-color: #fee2e2;
    color: var(--color-error);
    border-radius: var(--border-radius-md);
    margin-bottom: var(--space-md);
    font-size: var(--font-size-sm);
}

/* Success Message */
.success-message {
    padding: var(--space-md);
    background-color: #d1fae5;
    color: var(--color-success);
    border-radius: var(--border-radius-md);
    margin-bottom: var(--space-md);
    font-size: var(--font-size-sm);
}

