.elementor-20149 .elementor-element.elementor-element-7c2cf387{--display:flex;--flex-wrap:wrap;}.elementor-20149 .elementor-element.elementor-element-7c2cf387.e-con{--flex-grow:0;--flex-shrink:0;}@media(max-width:767px){.elementor-20149 .elementor-element.elementor-element-7c2cf387{--width:98.97%;}.elementor-20149 .elementor-element.elementor-element-7c2cf387.e-con{--align-self:center;}}@media(min-width:768px){.elementor-20149 .elementor-element.elementor-element-7c2cf387{--width:68%;}}@media(max-width:1366px) and (min-width:768px){.elementor-20149 .elementor-element.elementor-element-7c2cf387{--width:100%;}}/* Start custom CSS for container, class: .elementor-element-7c2cf387 *//* ULTRA RESPONSIVE CSS - MAKES SECTIONS SMALL & WRAP PERFECTLY */

/* BASE RESPONSIVE GRID SYSTEM */
.container { 
    display: flex; 
    flex-direction: column; 
    gap: 20px; 
}
.calculator, .result, .cta { 
    width: 100%; 
    max-width: 100%; 
}

/* MOBILE FIRST - Everything stacks & shrinks */
@media (max-width: 480px) {
    body { padding: 5px !important; font-size: 15px !important; }
    .container { 
        padding: 15px 10px !important; 
        gap: 15px !important; 
    }
    
    /* Shrink all sections */
    .calculator { padding: 20px 15px !important; }
    .result { padding: 20px 15px !important; }
    .cta { padding: 20px 15px !important; }
    
    /* Headers tiny */
    h1 { font-size: 24px !important; }
    h2 { font-size: 20px !important; margin: 15px 0 10px !important; }
    h3 { font-size: 18px !important; }
    
    /* Inputs wrap & full width */
    .input-group { margin-bottom: 15px !important; }
    input, select { 
        padding: 12px 10px !important; 
        font-size: 16px !important; 
    }
    
    /* Button wraps perfectly */
    .calculate-btn { 
        padding: 14px !important; 
        font-size: 16px !important; 
    }
    
    /* Table → Cards on mobile */
    table { display: none; }
    table.mobile-only { display: table !important; font-size: 13px; }
    th, td { padding: 6px 3px !important; }
    
    /* Results shrink */
    .price-display { font-size: 28px !important; line-height: 1.2 !important; }
    .breakdown-item { 
        flex-direction: column !important; 
        gap: 5px !important; 
        text-align: center !important; 
    }
    
    /* Tabs stack */
    .tabs-container { flex-direction: column !important; }
    .tab-btn { padding: 14px !important; border-radius: 0 !important; }
    
    /* Checkbox wrap */
    .checkbox-group { 
        flex-direction: column !important; 
        align-items: flex-start !important; 
        gap: 8px !important; 
    }
}

/* TABLET - 2-column wrap */
@media (min-width: 481px) and (max-width: 768px) {
    .container { padding: 25px 20px !important; }
    .result-grid { 
        grid-template-columns: 1fr 1fr !important; 
        gap: 15px !important; 
    }
    h2 { font-size: 22px !important; }
    .price-display { font-size: 32px !important; }
}

/* LARGE TABLET/DESKTOP - Full features */
@media (min-width: 769px) {
    .container { max-width: 900px !important; padding: 40px !important; }
    .result-grid { grid-template-columns: repeat(3, 1fr) !important; }
}

/* UNIVERSAL WRAP FIXES */
.tabs-container { 
    flex-wrap: wrap !important; 
}
.tab-btn { 
    flex: 1 1 45% !important; 
    white-space: nowrap !important; 
}
.breakdown { 
    display: flex !important; 
    flex-wrap: wrap !important; 
    gap: 10px !important; 
}
.breakdown-item { 
    flex: 1 1 45% !important; 
    min-width: 200px !important; 
}

/* NO SCROLL FIX */
html, body { 
    width: 100% !important; 
    overflow-x: hidden !important; 
}
* { 
    max-width: 100% !important; 
}

/* TOUCH FRIENDLY */
input, select, button { 
    min-height: 48px !important; 
    touch-action: manipulation !important; 
}/* End custom CSS */