/**
 * 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;
}

/* ============================================
 * KADENCE OVERRIDE - Full width for immobilien
 * ============================================ */
body.wp-r2go4-detail-template-active #inner-wrap,
body.wp-r2go4-detail-template-active .site-container,
body.wp-r2go4-detail-template-active .site-inner,
body.wp-r2go4-detail-template-active .content-wrap,
body.wp-r2go4-detail-template-active .site-main {
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin: 0 !important;
}

/* Hide Kadence sidebar on immobilien detail pages */
body.wp-r2go4-detail-template-active .site-sidebar,
body.wp-r2go4-detail-template-active aside.sidebar,
body.wp-r2go4-detail-template-active .widget-area {
    display: none !important;
}

/* Ensure content area takes full width */
body.wp-r2go4-detail-template-active .content-area,
body.wp-r2go4-detail-template-active #primary {
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 100% !important;
    float: none !important;
}

/* Remove Kadence's content constraints */
body.wp-r2go4-detail-template-active .entry-content-wrap,
body.wp-r2go4-detail-template-active .content-container {
    max-width: 100% !important;
    padding: 0 !important;
}

.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;
    }
}
