/* ===============================================
   GOLF CLUBBER - LAYOUT SYSTEM
   =============================================== */

/* === BASE LAYOUT === */

body {
    font-family: var(--font-primary);
    color: var(--color-text);
    background: var(--color-bg);
    font-size: var(--font-size-base);
    line-height: var(--line-height-relaxed);
}

/* === CONTAINER === */

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

.container-fluid {
    width: 100%;
    padding: 0 var(--container-padding);
}

/* === SECTIONS === */

section {
    position: relative;
    width: 100%;
}

.section {
    padding: var(--space-4xl) 0;
}

.section-sm {
    padding: var(--space-3xl) 0;
}

.section-lg {
    padding: var(--space-5xl) 0;
}

.section-bg-alt {
    background: var(--color-bg-alt);
}

.section-bg-dark {
    background: var(--color-bg-dark);
}

/* === GRID SYSTEM === */

.grid {
    display: grid;
    gap: var(--space-lg);
}

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

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

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

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

.grid-gap-sm {
    gap: var(--space-sm);
}

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

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

.grid-gap-xl {
    gap: var(--space-xl);
}

/* === FLEX SYSTEM === */

.flex {
    display: flex;
}

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

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

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

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

.flex-gap-sm {
    gap: var(--space-sm);
}

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

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

/* === ALIGNMENT === */

.text-left {
    text-align: left;
}

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

.text-right {
    text-align: right;
}

.align-center {
    margin-left: auto;
    margin-right: auto;
}

/* === 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); }
.mt-2xl { margin-top: var(--space-2xl); }

.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); }
.mb-2xl { margin-bottom: var(--space-2xl); }

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

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

/* === RESPONSIVE BREAKPOINTS === */

/* Mobile First Approach */

/* Tablet (768px and up) */
@media (max-width: 768px) {
    .container {
        padding: 0 var(--space-sm);
    }
    
    .grid-2,
    .grid-3,
    .grid-4 {
        grid-template-columns: 1fr;
    }
    
    .section {
        padding: var(--space-3xl) 0;
    }
    
    .section-sm {
        padding: var(--space-2xl) 0;
    }
    
    .section-lg {
        padding: var(--space-4xl) 0;
    }
}

/* Desktop (1200px and up) */
@media (min-width: 1200px) {
    .container {
        padding: 0 var(--space-xl);
    }
}

/* Hide/Show utilities */
@media (max-width: 768px) {
    .hide-mobile {
        display: none !important;
    }
}

@media (min-width: 769px) {
    .hide-desktop {
        display: none !important;
    }
    
    .show-mobile {
        display: none !important;
    }
}

@media (max-width: 768px) {
    .show-desktop {
        display: none !important;
    }
}
