/* ========================================
   RFN FULLWIDTH MEDIA TEXT BLOCK STYLES
   Simplified Version 2.0
   ======================================== */

.rfn-fullwidth-media-text-block {
    display: flex;
    align-items: stretch;
    min-height: 400px;
    margin: 2rem 0;
    overflow: hidden;
    position: relative;
}

.rfn-fullwidth-media-text-block .text-section {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 3rem 2rem;
    position: relative;
    z-index: 10;
    overflow: hidden;
    box-sizing: border-box;
}

.rfn-fullwidth-media-text-block .text-content {
    max-width: 720px;
    width: 100%;
    position: relative;
    z-index: 11;
    overflow: hidden;
    word-wrap: break-word;
    overflow-wrap: break-word;
    box-sizing: border-box;
    padding: var(--text-content-spacing, 2rem);
}

.rfn-fullwidth-media-text-block .accent-line {
    width: 60px;
    height: 4px;
    margin-bottom: 1rem;
    display: block;
}

.rfn-fullwidth-media-text-block .block-title {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 1.5rem;
    color: inherit;
    word-wrap: break-word;
    overflow-wrap: break-word;
    max-width: 100%;
    overflow: hidden;
}

.rfn-fullwidth-media-text-block .block-content {
    font-size: 1.1rem;
    line-height: 1.6;
    color: inherit;
    word-wrap: break-word;
    overflow-wrap: break-word;
    max-width: 100%;
    overflow: hidden;
}

.rfn-fullwidth-media-text-block .image-section {
    position: relative;
    overflow: hidden;
}

.rfn-fullwidth-media-text-block .image-section img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}

.rfn-fullwidth-media-text-block .btn {
    display: inline-block;
    padding: 0.75rem 1.5rem;
    text-decoration: none;
    border-radius: 4px;
    font-weight: 600;
    transition: all 0.3s ease;
}

.rfn-fullwidth-media-text-block .btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

/* Hide on mobile */
.rfn-fullwidth-media-text-block.hide-on-mobile {
    display: none !important;
}

/* Mobile responsive styles */
@media (max-width: 768px) {
    .rfn-fullwidth-media-text-block {
        flex-direction: column !important;
        min-height: auto !important;
        margin-left: calc(-50vw + 50%) !important;
        margin-right: calc(-50vw + 50%) !important;
        width: 100vw !important;
        max-width: 100vw !important;
        padding: 0 !important;
        overflow-x: hidden !important;
        position: relative !important;
        left: 0 !important;
        right: 0 !important;
        box-sizing: border-box !important;
    }
    
    .rfn-fullwidth-media-text-block .text-section {
        flex: none !important;
        width: 100% !important;
        padding: 2rem 1.5rem !important;
        min-height: auto !important;
        box-sizing: border-box !important;
    }
    
    .rfn-fullwidth-media-text-block .text-content {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }
    
    .rfn-fullwidth-media-text-block .image-section {
        flex: none !important;
        width: 100% !important;
        height: 300px !important;
        min-height: 300px !important;
        max-height: 300px !important;
        overflow: hidden !important;
        box-sizing: border-box !important;
    }
    
    .rfn-fullwidth-media-text-block .accent-line {
        margin: 0 auto 1rem auto !important;
    }
    
    .rfn-fullwidth-media-text-block .block-title {
        font-size: 1.75rem !important;
        line-height: 1.3 !important;
        margin-bottom: 1rem !important;
        text-align: center !important;
    }
    
    .rfn-fullwidth-media-text-block .block-content {
        font-size: 1rem !important;
        line-height: 1.6 !important;
        text-align: justify !important;
    }
    
    .rfn-fullwidth-media-text-block .btn {
        width: auto !important;
        margin: 0 auto !important;
        display: block !important;
        text-align: center !important;
    }
}

/* Small mobile adjustments */
@media (max-width: 576px) {
    .rfn-fullwidth-media-text-block .text-section {
        padding: 1.5rem 1rem !important;
    }
    
    .rfn-fullwidth-media-text-block .block-title {
        font-size: 1.5rem !important;
    }
    
    .rfn-fullwidth-media-text-block .block-content {
        font-size: 0.95rem !important;
    }
    
    .rfn-fullwidth-media-text-block .image-section {
        height: 250px !important;
        min-height: 250px !important;
        max-height: 250px !important;
    }
}

/* Safari iPhone fix - override 100vw approach */
/* Safari calculates 100vw as viewport + scrollbar width, causing horizontal overflow and content shift */
/* Solution: Use position-based breakout instead of 100vw + negative margins */
@supports (-webkit-touch-callout: none) {
    @media (max-width: 768px) {
        /* Clip overflow at root level */
        html {
            overflow-x: hidden !important;
        }
        
        body {
            overflow-x: hidden !important;
        }
        
        /* Ensure containers that wrap blocks also clip overflow */
        .site-main,
        .wp-block-group,
        .entry-content,
        .post-content,
        .page-content {
            overflow-x: hidden !important;
        }
        
        /* Override the 100vw approach for Safari - use container-relative breakout */
        .rfn-fullwidth-media-text-block {
            /* Remove the problematic calc margins and 100vw width from mobile styles */
            margin-left: 0 !important;
            margin-right: 0 !important;
            width: 100% !important;
            max-width: none !important;
            left: auto !important;
            right: auto !important;
            
            /* Break out of container using negative margins - same as fullwidth-image */
            /* Break out by container padding amount (typically 1-2rem) */
            margin-left: -2rem !important;
            margin-right: -2rem !important;
            padding-left: 0 !important;
            padding-right: 0 !important;
            
            /* Width accounts for the breakout - this ensures it spans both edges */
            width: calc(100% + 4rem) !important;
            
            /* Override max-width from mobile styles - allow it to break out */
            max-width: calc(100% + 4rem) !important;
            
            /* Clip any overflow at block level */
            overflow-x: hidden !important;
            box-sizing: border-box !important;
        }
        
        /* Ensure child elements don't exceed block boundaries */
        .rfn-fullwidth-media-text-block .text-section {
            /* Maintain padding for text content, but ensure it doesn't cause overflow */
            padding-left: 2rem !important;
            padding-right: 2rem !important;
            max-width: 100% !important;
            box-sizing: border-box !important;
        }
        
        .rfn-fullwidth-media-text-block .image-section,
        .rfn-fullwidth-media-text-block .text-content {
            max-width: 100% !important;
            box-sizing: border-box !important;
        }
        
        .rfn-fullwidth-media-text-block .image-section img {
            max-width: 100% !important;
        }
    }
}

