/**
 * Layout CSS
 *
 * Style strukturalne: kontener, grid, flexbox,
 * Wykorzystuje fluid design i auto-responsive gridy.
 *
 * @package Design System
 * @since 1.0.0
 */

/* ==========================================================================
   Body i struktura podstawowa
   ========================================================================== */

body {
    font-family: var(--font-family-primary);
    font-size: var(--font-size-base);
    line-height: var(--line-height-normal);
    color: var(--color-text);
    background-color: var(--color-background);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* ==========================================================================
   Container - Fluid
   ========================================================================== */

.container {
    width: min(100% - var(--container-padding) * 2, var(--container-max));
    margin-inline: auto;
}

/* Warianty kontenera */
.container--xs {
    width: min(100% - var(--container-padding) * 2, var(--container-xs));
}

.container--sm {
    width: min(100% - var(--container-padding) * 2, var(--container-sm));
}

.container--md {
    width: min(100% - var(--container-padding) * 2, var(--container-md));
}

.container--lg {
    width: min(100% - var(--container-padding) * 2, var(--container-lg));
}

.container--xl {
    width: min(100% - var(--container-padding) * 2, var(--container-xl));
}

.container--fluid {
    width: 100%;
    padding-inline: var(--container-padding);
}

/* ==========================================================================
   Główna treść (Site Main)
   ========================================================================== */

.site-main {
    flex: 1 0 auto;
}


/* ==========================================================================
   Grid System - Auto-responsive
   ========================================================================== */

.grid {
    --grid-gap: var(--spacing-8);
    --grid-min: 280px;
    display: grid;
    gap: var(--grid-gap);
    grid-template-columns: repeat(auto-fit, minmax(min(var(--grid-min), 100%), 1fr));
}

/* Grid z określoną liczbą kolumn - używa auto-fit dla responsywności */

.grid--1 {
    --grid-min: 340px;
}

.grid--2 {
    --grid-min: 300px;
}

.grid--3 {
    --grid-min: 260px;
}

.grid--4 {
    --grid-min: 220px;
}

/* Grid ze stałą liczbą kolumn (rzadko używane) */
.grid--cols-1 {
    grid-template-columns: repeat(1, 1fr);
}

.grid--cols-2 {
    grid-template-columns: repeat(2, 1fr);
}

.grid--cols-3 {
    grid-template-columns: repeat(3, 1fr);
}

.grid--cols-4 {
    grid-template-columns: repeat(4, 1fr);
}

.grid--cols-5 {
    grid-template-columns: repeat(5, 1fr);
}

.grid--cols-6 {
    grid-template-columns: repeat(6, 1fr);
}

/* Responsive Grid Columns (Mobile First) */

/* sm: 640px */
@media (min-width: 640px) {
    .grid--cols--sm-1 {
        grid-template-columns: repeat(1, 1fr);
    }

    .grid--cols--sm-2 {
        grid-template-columns: repeat(2, 1fr);
    }

    .grid--cols--sm-3 {
        grid-template-columns: repeat(3, 1fr);
    }

    .grid--cols--sm-4 {
        grid-template-columns: repeat(4, 1fr);
    }

    .grid--cols--sm-5 {
        grid-template-columns: repeat(5, 1fr);
    }

    .grid--cols--sm-6 {
        grid-template-columns: repeat(6, 1fr);
    }
}

/* md: 768px */
@media (min-width: 768px) {
    .grid--cols--md-1 {
        grid-template-columns: repeat(1, 1fr);
    }

    .grid--cols--md-2 {
        grid-template-columns: repeat(2, 1fr);
    }

    .grid--cols--md-3 {
        grid-template-columns: repeat(3, 1fr);
    }

    .grid--cols--md-4 {
        grid-template-columns: repeat(4, 1fr);
    }

    .grid--cols--md-5 {
        grid-template-columns: repeat(5, 1fr);
    }

    .grid--cols--md-6 {
        grid-template-columns: repeat(6, 1fr);
    }
}

/* lg: 1024px */
@media (min-width: 1024px) {
    .grid--cols--lg-1 {
        grid-template-columns: repeat(1, 1fr);
    }

    .grid--cols--lg-2 {
        grid-template-columns: repeat(2, 1fr);
    }

    .grid--cols--lg-3 {
        grid-template-columns: repeat(3, 1fr);
    }

    .grid--cols--lg-4 {
        grid-template-columns: repeat(4, 1fr);
    }

    .grid--cols--lg-5 {
        grid-template-columns: repeat(5, 1fr);
    }

    .grid--cols--lg-6 {
        grid-template-columns: repeat(6, 1fr);
    }
}

/* xl: 1280px */
@media (min-width: 1280px) {
    .grid--cols--xl-1 {
        grid-template-columns: repeat(1, 1fr);
    }

    .grid--cols--xl-2 {
        grid-template-columns: repeat(2, 1fr);
    }

    .grid--cols--xl-3 {
        grid-template-columns: repeat(3, 1fr);
    }

    .grid--cols--xl-4 {
        grid-template-columns: repeat(4, 1fr);
    }

    .grid--cols--xl-5 {
        grid-template-columns: repeat(5, 1fr);
    }

    .grid--cols--xl-6 {
        grid-template-columns: repeat(6, 1fr);
    }
}

/* 2xl: 1536px */
@media (min-width: 1536px) {
    .grid--cols--2xl-1 {
        grid-template-columns: repeat(1, 1fr);
    }

    .grid--cols--2xl-2 {
        grid-template-columns: repeat(2, 1fr);
    }

    .grid--cols--2xl-3 {
        grid-template-columns: repeat(3, 1fr);
    }

    .grid--cols--2xl-4 {
        grid-template-columns: repeat(4, 1fr);
    }

    .grid--cols--2xl-5 {
        grid-template-columns: repeat(5, 1fr);
    }

    .grid--cols--2xl-6 {
        grid-template-columns: repeat(6, 1fr);
    }
}

/* Gridy asymetryczne */
.grid--3-2 {
    grid-template-columns: 3fr 2fr;
}

@media (max-width: 992px) {
    .grid--3-2 {
        grid-template-columns: 1fr;
    }
}

/* Grid gap modyfikatory */
.grid--gap-sm {
    --grid-gap: var(--spacing-4);
}

.grid--gap-lg {
    --grid-gap: var(--spacing-8);
}

.grid--gap-xl {
    --grid-gap: var(--spacing-12);
}

/* ==========================================================================
   Flexbox Utilities
   ========================================================================== */

.flex {
    display: flex;
}

.flex--inline {
    display: inline-flex;
}

.flex--center {
    align-items: center;
    justify-content: center;
}

.flex--between {
    justify-content: space-between;
}

.flex--around {
    justify-content: space-around;
}

.flex--evenly {
    justify-content: space-evenly;
}

.flex--start {
    justify-content: flex-start;
}

.flex--end {
    justify-content: flex-end;
}

.flex--wrap {
    flex-wrap: wrap;
}

.flex--column {
    flex-direction: column;
}

.flex--row-reverse {
    flex-direction: row-reverse;
}

.flex--column-reverse {
    flex-direction: column-reverse;
}

/* Align items */
.items-start {
    align-items: flex-start;
}

.items-center {
    align-items: center;
}

.items-end {
    align-items: flex-end;
}

.items-stretch {
    align-items: stretch;
}

.items-baseline {
    align-items: baseline;
}

/* Gap utilities */
.gap-1 {
    gap: var(--spacing-1);
}

.gap-2 {
    gap: var(--spacing-2);
}

.gap-3 {
    gap: var(--spacing-3);
}

.gap-4 {
    gap: var(--spacing-4);
}

.gap-5 {
    gap: var(--spacing-5);
}

.gap-6 {
    gap: var(--spacing-6);
}

.gap-8 {
    gap: var(--spacing-8);
}

.gap-10 {
    gap: var(--spacing-10);
}

.gap-12 {
    gap: var(--spacing-12);
}

/* ==========================================================================
   Spacing Utilities (margin/padding)
   ========================================================================== */

/* Margin - all sides */
.m-1 { margin: var(--spacing-1); }
.m-2 { margin: var(--spacing-2); }
.m-3 { margin: var(--spacing-3); }
.m-4 { margin: var(--spacing-4); }
.m-5 { margin: var(--spacing-5); }

/* Margin - directional */
.mt-1 { margin-top: var(--spacing-1); }
.mt-2 { margin-top: var(--spacing-2); }
.mt-3 { margin-top: var(--spacing-3); }
.mt-4 { margin-top: var(--spacing-4); }
.mt-5 { margin-top: var(--spacing-5); }

.mb-1 { margin-bottom: var(--spacing-1); }
.mb-2 { margin-bottom: var(--spacing-2); }
.mb-3 { margin-bottom: var(--spacing-3); }
.mb-4 { margin-bottom: var(--spacing-4); }
.mb-5 { margin-bottom: var(--spacing-5); }

.mr-1 { margin-right: var(--spacing-1); }
.mr-2 { margin-right: var(--spacing-2); }
.mr-3 { margin-right: var(--spacing-3); }
.mr-4 { margin-right: var(--spacing-4); }
.mr-5 { margin-right: var(--spacing-5); }

.ml-1 { margin-left: var(--spacing-1); }
.ml-2 { margin-left: var(--spacing-2); }
.ml-3 { margin-left: var(--spacing-3); }
.ml-4 { margin-left: var(--spacing-4); }
.ml-5 { margin-left: var(--spacing-5); }

/* Padding - all sides */
.p-1 { padding: var(--spacing-1); }
.p-2 { padding: var(--spacing-2); }
.p-3 { padding: var(--spacing-3); }
.p-4 { padding: var(--spacing-4); }
.p-5 { padding: var(--spacing-5); }

/* Padding - directional */
.pt-1 { padding-top: var(--spacing-1); }
.pt-2 { padding-top: var(--spacing-2); }
.pt-3 { padding-top: var(--spacing-3); }
.pt-4 { padding-top: var(--spacing-4); }
.pt-5 { padding-top: var(--spacing-5); }

.pb-1 { padding-bottom: var(--spacing-1); }
.pb-2 { padding-bottom: var(--spacing-2); }
.pb-3 { padding-bottom: var(--spacing-3); }
.pb-4 { padding-bottom: var(--spacing-4); }
.pb-5 { padding-bottom: var(--spacing-5); }

.pr-1 { padding-right: var(--spacing-1); }
.pr-2 { padding-right: var(--spacing-2); }
.pr-3 { padding-right: var(--spacing-3); }
.pr-4 { padding-right: var(--spacing-4); }
.pr-5 { padding-right: var(--spacing-5); }

.pl-1 { padding-left: var(--spacing-1); }
.pl-2 { padding-left: var(--spacing-2); }
.pl-3 { padding-left: var(--spacing-3); }
.pl-4 { padding-left: var(--spacing-4); }
.pl-5 { padding-left: var(--spacing-5); }

/* ==========================================================================
   Sekcje - Fluid padding
   ========================================================================== */

.section {
    padding-block: var(--spacing-section);
}

.section--sm {
    padding-block: var(--spacing-section-sm);
}

.section--lg {
    padding-block: var(--spacing-section-lg);
}

/* Backgrounds */
.section--gray {
    background-color: var(--color-background-gray);
    border-radius: var(--radius-base);
}

.section--dark {
    background-color: var(--color-background-dark);
    color: var(--color-text-inverse);
}

.section--primary {
    background: var(--gradient-primary);
    color: var(--color-text-inverse);
}

/* Section header */
.section__header {
    text-align: center;
    margin-inline: auto;
    margin-bottom: var(--spacing-section-sm);
}

@media (max-width: 1024px) {
    .section__header {
        margin-bottom: var(--spacing-8);
    }
}

@media (max-width: 640px) {
    .section__header {
        margin-bottom: var(--spacing-6);
    }
}

.section__title {
    font-size: var(--font-size-h2);
    font-weight: var(--font-weight-bold);
    color: var(--color-heading);
    margin-bottom: var(--spacing-4);
    line-height: var(--line-height-tight);
}

.section--dark .section__title,
.section--primary .section__title {
    color: var(--color-white);
}

.section__subtitle {
    font-size: var(--font-size-lg);
    color: var(--color-text-light);
    line-height: var(--line-height-relaxed);
}

.section__subtitle a {
    color: var(--color-primary);
}

.section--dark .section__subtitle,
.section--primary .section__subtitle {
    color: var(--color-gray-300);
}

/* Section header align */
.section__header--left {
    text-align: left;
    margin-inline: 0;
}

.section__header--right {
    text-align: right;
    margin-inline: 0;
    margin-left: auto;
}

/* ==========================================================================
   Two Column Layout
   ========================================================================== */

.two-col {
    display: grid;
    gap: var(--spacing-8);
    grid-template-columns: repeat(auto-fit, minmax(min(400px, 100%), 1fr));
    align-items: center;
}

.two-col--reverse {
    direction: rtl;
}

.two-col--reverse>* {
    direction: ltr;
}

/* Asymetryczne proporcje */
.two-col--sidebar {
    grid-template-columns: minmax(min(300px, 100%), 1fr) minmax(min(200px, 100%), 280px);
}

.two-col--sidebar-left {
    grid-template-columns: minmax(min(200px, 100%), 280px) minmax(min(300px, 100%), 1fr);
}

/* ==========================================================================
   Wrapper dla pełnej szerokości z containerd content
   ========================================================================== */

.full-width {
    width: 100%;
    padding-inline: var(--container-padding);
}

.full-bleed {
    width: 100vw;
    margin-left: calc(-50vw + 50%);
}