/*
╔════════════════════════════════════════════════════════════════════╗
║  ROOTED VITALITY, INC.                                             ║
║  File: styles/layout.css                                           ║
║  Purpose: Layout Containers, Grid & Spacing Utilities              ║
║  Holistic Wellness · Modern Connection Platform                    ║
║  rootedvitality.health | 2025                                         ║
╚════════════════════════════════════════════════════════════════════╝

TABLE OF CONTENTS
  1. CONTAINERS
  2. GRID & FLEX UTILITIES
  3. SPACING UTILITIES
  4. RESPONSIVE LAYOUTS

Extracted from: styles_legacy.css
*/

/* ========================================== */
/* 1. CONTAINERS */
/* ========================================== */
.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 clamp(1rem, 5vw, 3rem);
    position: relative;
    z-index: 10;
    width: 100%;
    box-sizing: border-box;
}

.container-narrow {
    max-width: 900px;
    margin: 0 auto;
    padding: clamp(1rem, 5vw, 3rem);
    background: var(--glass-white);
    backdrop-filter: blur(6px);
    border-radius: var(--radius-md);
    border: 1px solid rgba(92, 154, 114, 0.25);
    position: relative;
    z-index: 10;
    box-shadow: var(--shadow-medium);
    animation: fadeUp 0.8s ease 0.1s both;
}

/* ========================================== */
/* 2. GRID & FLEX UTILITIES */
/* ========================================== */
.flex {
    display: flex;
}

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

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

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

.grid {
    display: grid;
    gap: var(--spacing-md);
}

.grid-2 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-md);
}

.grid-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-md);
}

/* ========================================== */
/* 3. SPACING UTILITIES */
/* ========================================== */
.mt-xs { margin-top: var(--spacing-xs); }
.mt-sm { margin-top: var(--spacing-sm); }
.mt-md { margin-top: var(--spacing-md); }
.mt-lg { margin-top: var(--spacing-lg); }
.mt-xl { margin-top: var(--spacing-xl); }

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

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

/* ========================================== */
/* 4. RESPONSIVE LAYOUTS */
/* ========================================== */
@media (max-width: 1024px) {
    .container, .container-narrow {
        padding: 0 1.5rem;
    }
    
    .grid-3 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .container {
        padding: 0 1rem;
        width: 95%;
    }
    
    .container-narrow {
        max-width: 95%;
        padding: 1.5rem 1rem;
    }
    
    .grid-2, .grid-3 {
        grid-template-columns: 1fr;
    }
    
    .flex-between {
        flex-direction: column;
        gap: var(--spacing-sm);
    }
}

@media (max-width: 480px) {
    html {
        font-size: 14px;
    }
    
    .container {
        padding: 0 0.75rem;
        width: 100%;
    }
    
    .container-narrow {
        max-width: 100%;
        padding: 1rem 0.75rem;
        border-radius: 8px;
    }
}







/* FORCE: Black text in dark mode for maximum readability */








