/* =====================================================
   Ofis Möble — Layout & Grid
   ===================================================== */

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

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

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

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

.section--dark h2,
.section--dark h3 { color: var(--color-text-on-dark); }

/* Section Headers */
.section__header, .section-header {
    text-align: left;
    margin-bottom: var(--space-4xl);
    max-width: 600px;
}

.section__header h2, .section-header h2 {
    font-size: var(--fs-4xl);
    margin-bottom: var(--space-sm);
    line-height: var(--lh-tight);
}

.section__header p, .section-header p {
    font-size: var(--fs-lg);
    color: var(--color-text-secondary);
}

/* Labels & Tags */
.section-label, .section__label {
    display: inline-block;
    font-size: var(--fs-xs);
    font-weight: var(--fw-medium);
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--color-text-secondary);
    margin-bottom: var(--space-md);
}

/* Flex / Grid Utilities */
.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); }

.flex { display: flex; }
.flex--center { align-items: center; justify-content: center; }
.flex--between { align-items: center; justify-content: space-between; }
.flex--gap { gap: var(--space-md); }

/* Breadcrumbs & Page Header for non-home pages */
.breadcrumb {
    padding: var(--space-lg) 0;
    font-size: var(--fs-sm);
    color: var(--color-text-light);
}

.breadcrumb a { color: var(--color-text-light); }
.breadcrumb a:hover { color: var(--color-accent); }
.breadcrumb span { margin: 0 var(--space-sm); }

.page-header {
    background: var(--color-bg-alt);
    padding: var(--space-3xl) 0;
    text-align: center;
    position: relative;
    overflow: hidden;
}

.page-header h1 {
    color: var(--color-primary);
    font-size: var(--fs-4xl);
    position: relative;
    z-index: 1;
}
