/**
 * Layout Styles
 *
 * @package WP_R2Go4_Detail
 *
 * Layout-System mit Variablen aus Admin-Einstellungen
 */

:root {
    --wp-r2go4-content-width: 1200px;
    --wp-r2go4-padding-top: 80px;
    --wp-r2go4-padding-bottom: 80px;
}

.wp-r2go4-detail-page {
    width: 100%;
}

/* Layout Row System */
.wp-r2go4-layout-row {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    gap: 60px;
    max-width: var(--wp-r2go4-content-width);
    margin-left: auto;
    margin-right: auto;
    padding-top: var(--wp-r2go4-padding-top);
}

.wp-r2go4-layout-row:last-child {
    padding-bottom: var(--wp-r2go4-padding-bottom);
}

/* Full width row (100% container) - no gap, no max-width, no padding */
.wp-r2go4-layout-row-full {
    gap: 0;
    max-width: none;
    padding-top: 0;
    padding-bottom: 0;
    padding-left: 0;
    padding-right: 0;
}

/* Layout Column */
.wp-r2go4-layout-col {
    box-sizing: border-box;
}

/* Module Wrapper System */
.wp-r2go4-module-wrapper {
    width: 100%;
}

.wp-r2go4-module-inner {
    width: 100%;
}

/* Fullwidth Module */
.wp-r2go4-module-fullwidth {
    width: 100%;
}

/* Responsive Layout */
@media (max-width: 1024px) {
    :root {
        --wp-r2go4-padding-top: 60px;
        --wp-r2go4-padding-bottom: 60px;
    }

    .wp-r2go4-layout-row {
        padding-left: 50px;
        padding-right: 50px;
        flex-direction: column;
        gap: 40px;
    }

    .wp-r2go4-layout-row-full {
        padding-top: 0;
        padding-bottom: 0;
        padding-left: 0;
        padding-right: 0;
    }

    .wp-r2go4-layout-col {
        width: 100%;
        max-width: 100%;
        flex: 0 0 100%;
    }

    .wp-r2go4-module-inner {
        padding-left: 50px;
        padding-right: 50px;
    }

    .wp-r2go4-module-fullwidth .wp-r2go4-module-inner {
        padding-left: 0;
        padding-right: 0;
    }

    /* Override module paddings on tablet: max 60px (use clamp to keep smaller values) */
    .wp-r2go4-module-wrapper[style*="--module-padding-top"] {
        padding-top: clamp(0px, var(--module-padding-top), 60px) !important;
    }
    .wp-r2go4-module-wrapper[style*="--module-padding-bottom"] {
        padding-bottom: clamp(0px, var(--module-padding-bottom), 60px) !important;
    }
}

@media (max-width: 768px) {
    :root {
        --wp-r2go4-padding-top: 50px;
        --wp-r2go4-padding-bottom: 50px;
    }

    .wp-r2go4-layout-row {
        padding-left: 20px;
        padding-right: 20px;
        gap: 30px;
    }

    .wp-r2go4-layout-row-full {
        padding-top: 0;
        padding-bottom: 0;
        padding-left: 0;
        padding-right: 0;
    }

    .wp-r2go4-module-inner {
        padding-left: 20px;
        padding-right: 20px;
    }

    .wp-r2go4-module-fullwidth .wp-r2go4-module-inner {
        padding-left: 0;
        padding-right: 0;
    }

    /* Override module paddings on mobile: max 50px (use clamp to keep smaller values) */
    .wp-r2go4-module-wrapper[style*="--module-padding-top"] {
        padding-top: clamp(0px, var(--module-padding-top), 50px) !important;
    }
    .wp-r2go4-module-wrapper[style*="--module-padding-bottom"] {
        padding-bottom: clamp(0px, var(--module-padding-bottom), 50px) !important;
    }
}
