/* ==========================================
   AE PRO W2P ENGINE - TAILWIND-PROOF CSS 
   ========================================== */

:root { 
    --ae-primary: #F97316; /* Synced with your theme's orange */
    --aev5-dark: #0f172a; 
    --aev5-gray: #e2e8f0; 
    --aev5-bg: #f8fafc; 
    --aev5-depth: 10px; 
}

/* 1. TAILWIND SHIELD & RESET */
.ae-v5-master * { 
    box-sizing: border-box !important; 
    -webkit-tap-highlight-color: transparent !important; 
}
.ae-v5-master svg { 
    display: inline-block !important; 
    vertical-align: middle;
}

/* 2. FLATSOME & WOOCOMMERCE CONFLICT KILLERS */
.woocommerce-product-gallery, .product-thumbnails, .product-images.relative, .flex-control-nav, ul.next-prev-thumbs, .product-gallery-slider { display: none !important; height: 0 !important; visibility: hidden !important; position: absolute !important; opacity: 0 !important; pointer-events: none !important; }
form.cart table.variations, .woocommerce-variation-add-to-cart table.variations, .reset_variations, form.cart div.quantity, .woocommerce-variation-price, .single_variation_wrap .price, .woocommerce-variation-add-to-cart .price { display: none !important; height:0 !important; visibility:hidden !important; position:absolute !important; }

/* 3. PRODUCT INFO & PRICING */
.product-info h1.product-title { font-size: 28px !important; margin-bottom: 12px !important; line-height: 1.2 !important; color: var(--aev5-dark) !important; font-weight: 900 !important; font-family: 'Montserrat', sans-serif !important;}
.product-info .price-wrapper .price, .summary > .price, .ae-split-right .price { font-size: 24px !important; color: var(--aev5-dark) !important; font-weight: 800 !important; margin-bottom: 15px !important; display: block !important;}

/* 4. BUTTONS (Tailwind Overrides) */
.ae-v5-trigger-edit-wrapper { margin-top: 15px !important; width: 100% !important; display: flex !important; justify-content: center !important; }
.ae-v5-trigger-edit { width: 100% !important; max-width: 400px !important; padding: 15px 20px !important; background: var(--ae-primary) !important; color: #fff !important; border: none !important; border-radius: 12px !important; font-weight: 800 !important; font-size: 15px !important; letter-spacing: 1px !important; display: flex !important; align-items: center !important; justify-content: center !important; gap: 10px !important; cursor: pointer !important; box-shadow: 0 4px 15px rgba(0,0,0,0.15) !important; transition: 0.3s !important; text-transform: uppercase !important; }
.ae-v5-trigger-edit:hover { transform: translateY(-3px) !important; box-shadow: 0 8px 25px rgba(0,0,0,0.25) !important; background: var(--aev5-dark) !important;}
.woocommerce-page button.button.alt.single_add_to_cart_button { flex: 1 !important; margin: 0 !important; height: 50px !important; border-radius: 8px !important; font-size: 15px !important; font-weight: 800 !important; display: flex !important; justify-content: center !important; align-items: center !important; border: none !important; text-transform: uppercase !important; transition: 0.3s !important; width: 100% !important; background: var(--ae-primary) !important; color: #fff !important; box-shadow: 0 4px 15px rgba(0,0,0,0.1) !important; }
.woocommerce-page button.button.alt.single_add_to_cart_button:hover { background: var(--aev5-dark) !important; color: #fff !important; transform: translateY(-2px); }

/* 5. TOP TOOLBAR */
.ae-v5-workspace { display: flex !important; flex-direction: column !important; background: transparent !important; position: relative !important; z-index: 1 !important; margin-top: 20px !important;}
.ae-v5-toolbar-top { display: flex !important; justify-content: space-between !important; align-items: center !important; padding: 0 5px 15px 5px !important; width: 100% !important; border-bottom: 1px solid var(--aev5-gray) !important; margin-bottom: 15px !important;}
.ae-v5-tb-group { display: flex !important; gap: 8px !important; align-items: center !important; }

.ae-v5-icon-btn { width: 40px !important; height: 40px !important; border-radius: 8px !important; border: 1px solid var(--aev5-gray) !important; background: #fff !important; color: var(--aev5-dark) !important; display: inline-flex !important; justify-content: center !important; align-items: center !important; cursor: pointer !important; transition: 0.2s !important; padding: 0 !important; margin: 0 !important; box-shadow: 0 2px 5px rgba(0,0,0,0.05) !important; }
.ae-v5-icon-btn.active, .ae-v5-icon-btn:hover { background: var(--ae-primary) !important; color: #fff !important; border-color: var(--ae-primary) !important; box-shadow: 0 4px 10px rgba(249, 115, 22, 0.3) !important; }

.ae-v5-top-action-btn { background: var(--ae-primary) !important; color: #fff !important; height: 40px !important; border: none !important; border-radius: 8px !important; padding: 0 16px !important; font-weight: 800 !important; font-size: 13px !important; display: inline-flex !important; align-items: center !important; gap: 6px !important; cursor: pointer !important; box-shadow: 0 4px 10px rgba(0,0,0,0.15) !important; transition: 0.2s !important; font-family: 'Montserrat', sans-serif !important;}
.ae-v5-btn-secondary { background: #475569 !important; color: #fff !important; height: 40px !important; border: none !important; border-radius: 8px !important; padding: 0 16px !important; font-weight: 800 !important; font-size: 12px !important; cursor: pointer !important; }

/* 6. BOTTOM TOOLBAR & ZOOM */
.ae-v5-toolbar-bottom { display: flex !important; flex-wrap: wrap !important; justify-content: center !important; gap: 15px !important; align-items: center !important; padding: 15px 0 !important; border: none !important; background: transparent !important; position: relative !important; z-index: 60 !important;}
.ae-v5-zoom-wrapper { display: flex !important; align-items: center !important; gap: 10px !important; background: #fff !important; border-radius: 40px !important; padding: 5px 15px !important; height: 44px !important; box-shadow: 0 4px 12px rgba(0,0,0,0.08) !important; border: 1px solid var(--aev5-gray) !important; }
.ae-z-btn { background: none !important; border: none !important; padding: 0 !important; cursor: pointer !important; color: #64748b !important; display: flex !important; align-items: center !important; justify-content: center !important; }
.ae-z-btn:hover { color: var(--ae-primary) !important; }
.ae-v5-master input[type="range"] { -webkit-appearance: none !important; appearance: none !important; width: 120px !important; background: transparent !important; height: 4px !important; margin: 0 !important; padding: 0 !important;}
.ae-v5-master input[type="range"]::-webkit-slider-runnable-track { width: 100% !important; height: 6px !important; background: #e2e8f0 !important; border-radius: 10px !important; }
.ae-v5-master input[type="range"]::-webkit-slider-thumb { -webkit-appearance: none !important; appearance: none !important; height: 18px !important; width: 18px !important; border-radius: 50% !important; background: var(--ae-primary) !important; margin-top: -6px !important; cursor: pointer !important; box-shadow: 0 2px 6px rgba(0,0,0,0.25) !important; }

.ae-v5-tools-cluster { display: flex !important; gap: 8px !important; }
.ae-v5-tool-trigger { background: #fff !important; border: 1px solid #cbd5e1 !important; width: 44px !important; height: 44px !important; border-radius: 10px !important; cursor: pointer !important; display: inline-flex !important; justify-content: center !important; align-items: center !important; color: #475569 !important; padding: 0 !important; margin: 0 !important; font-weight:800 !important; font-size:13px !important; box-shadow: 0 4px 10px rgba(0,0,0,0.05) !important; }
.ae-v5-tool-trigger.active, .ae-v5-tool-trigger:hover { background: var(--ae-primary) !important; color: #fff !important; border-color: var(--ae-primary) !important; box-shadow: 0 6px 15px rgba(249, 115, 22, 0.3) !important; transform: translateY(-2px); }

/* 7. CANVAS 3D ENGINE (REAL ACRYLIC) */
.ae-v5-canvas-container { width: 100% !important; min-height: 450px !important; margin: 0 auto !important; display: flex !important; justify-content: center !important; align-items: center !important; position: relative !important; overflow: hidden !important; padding: 20px 0 !important; border-radius: 12px !important; background: transparent !important; transition: all 0.5s ease !important; border: 1px dashed #cbd5e1 !important; }
.ae-v5-canvas-container.is-3d-mode { background: #111827 !important; border-color: #000 !important; }

#ae-v5-3d-node { position: relative !important; display: flex !important; justify-content: center !important; align-items: center !important; perspective: 2000px !important; transition: transform 0.6s cubic-bezier(0.2, 0.8, 0.2, 1) !important; margin: 0 auto !important;}
.ae-v5-canvas-inner { position: relative !important; z-index: 2 !important; transform-style: preserve-3d !important; transition: filter 0.3s !important; width: 100% !important; height: 100% !important; background: transparent !important; border-radius: inherit !important; }

/* Real Acrylic Thickness Layer */
.is-3d-active .ae-v5-canvas-inner {
    box-shadow: 1px 1px 0px rgba(255,255,255,0.6), 2px 2px 0px rgba(255,255,255,0.4), 3px 3px 0px rgba(200,210,220,0.8), 4px 4px 0px rgba(180,190,200,0.8), 5px 5px 0px rgba(150,160,170,0.8), var(--aev5-depth) var(--aev5-depth) 20px rgba(0,0,0,0.7) !important;
    animation: spin3D 15s ease-in-out infinite alternate !important;
}
/* Glass Shine / Glare */
.is-3d-active .ae-v5-canvas-inner::after { 
    content: '' !important; position: absolute !important; inset: 0 !important; z-index: 10 !important; pointer-events: none !important; border-radius: inherit !important; 
    background: linear-gradient(135deg, rgba(255,255,255,0.6) 0%, rgba(255,255,255,0) 40%, rgba(255,255,255,0.1) 100%) !important; 
    transform: translateZ(1px) !important; border: 1px solid rgba(255,255,255,0.3) !important;
}
@keyframes spin3D { 0% { transform: rotateX(10deg) rotateY(-20deg); } 100% { transform: rotateX(15deg) rotateY(20deg); } }
#ae-v5-3d-toggle.is-active { background: var(--ae-primary) !important; color: #fff !important; border-color: var(--ae-primary) !important; }

/* 8. POPUPS (Fixed Text Inputs) */
.ae-v5-bottom-popups { position: absolute !important; bottom: 85px !important; left: 0 !important; width: 100% !important; display: flex !important; justify-content: center !important; pointer-events: none !important; z-index: 99999 !important;}
.ae-v5-popup { display: none !important; pointer-events: auto !important; background: rgba(255, 255, 255, 0.98) !important; backdrop-filter: blur(12px) !important; border: 1px solid var(--aev5-gray) !important; border-radius: 16px !important; padding: 20px !important; width: 95% !important; max-width: 400px !important; box-shadow: 0 15px 40px rgba(0,0,0,0.15) !important; }
.ae-v5-popup.active { display: flex !important; flex-direction: column !important; animation: popUp 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important; }
@keyframes popUp { from { opacity:0; transform:translateY(20px); } to { opacity:1; transform:translateY(0); } }

.ae-popup-header { display: flex !important; justify-content: space-between !important; align-items: center !important; border-bottom: 1px solid #e2e8f0 !important; padding-bottom: 10px !important; margin-bottom: 12px !important; }
.ae-popup-header h5 { margin: 0 !important; font-size: 14px !important; font-weight: 800 !important; color: #334155 !important; text-transform: uppercase !important; font-family: 'Montserrat', sans-serif !important;}
.ae-close-popup { width: 28px !important; height: 28px !important; background: #f1f5f9 !important; color: #475569 !important; border: none !important; border-radius: 50% !important; cursor: pointer !important; display: flex !important; justify-content: center !important; align-items: center !important; font-size: 12px !important; font-weight: bold !important; }

.ae-v5-popup button, .ae-v5-popup select { background: #fff !important; border: 1px solid var(--aev5-gray) !important; padding: 10px !important; border-radius: 8px !important; font-size: 13px !important; font-weight: 700 !important; color: var(--aev5-dark) !important; cursor: pointer !important; width: 100% !important;}
.ae-v5-popup input[type="text"] { width: 100% !important; padding: 10px 12px !important; border: 1px solid var(--aev5-gray) !important; border-radius: 8px !important; font-size: 14px !important; outline: none !important; background: #fff !important; color: #000 !important; line-height: normal !important; box-shadow: none !important;}
.ae-primary-btn { background: var(--ae-primary) !important; color: #fff !important; border-color: var(--ae-primary) !important; }

/* 9. WIZARD & SPLIT SCREEN (Tailwind Fixes) */
.ae-mag-step-header { font-size: 14px !important; font-weight: 800 !important; color: var(--ae-primary) !important; margin-bottom: 15px !important; text-transform: uppercase !important; display: flex !important; align-items: center !important; gap: 8px !important; cursor: pointer !important; }
.ae-mag-step-header svg { width: 20px !important; height: 20px !important; }

.ae-pricing-box { border: 1px solid #e2e8f0 !important; background: #f8fafc !important; padding: 15px 20px !important; border-radius: 12px !important; margin-bottom: 25px !important; }
.ae-pricing-box h4 { margin: 0 0 5px 0 !important; color: var(--ae-primary) !important; font-size: 12px !important; font-weight: 800 !important; text-transform: uppercase !important; }
.ae-price-display { font-size: 20px !important; font-weight: bold !important; color: #000 !important; font-family: 'Montserrat', sans-serif !important;}

/* Fix for Pricing Table Alignment */
.ae-tier-row { display: flex !important; justify-content: space-between !important; align-items: center !important; padding: 15px !important; border: 1px solid #e2e8f0 !important; border-radius: 8px !important; margin-bottom: 8px !important; font-weight: 600 !important; color: #475569 !important; background: #fff !important;}
.ae-tier-row.active { border-color: var(--ae-primary) !important; background: #fff !important; box-shadow: 0 2px 10px rgba(0,0,0,0.05) !important; color: #000 !important; }

/* Fix for Shape Grid & Overlapping SVGs */
#ae-magnet-shape-grid { display: grid !important; grid-template-columns: repeat(auto-fill, minmax(100px, 1fr)) !important; gap: 12px !important; margin: 20px 0 !important; }
.ae-shape-card { display: flex !important; flex-direction: column !important; align-items: center !important; justify-content: center !important; border: 2px solid #e2e8f0 !important; border-radius: 12px !important; padding: 15px 10px !important; text-align: center !important; cursor: pointer !important; transition: 0.2s !important; position: relative !important; background: #fff !important; }
.ae-shape-card svg { width: 40px !important; height: 40px !important; margin: 0 auto 10px auto !important; stroke: var(--ae-primary) !important; stroke-width: 2 !important; fill: transparent !important; display: block !important; }
.ae-shape-card.active { border-color: var(--ae-primary) !important; box-shadow: 0 4px 15px rgba(0,0,0,0.1) !important; }
.ae-shape-card .check-icon { display: none !important; position: absolute !important; top: -8px !important; right: -8px !important; background: var(--ae-primary) !important; color: #fff !important; width: 22px !important; height: 22px !important; border-radius: 50% !important; font-size: 12px !important; font-weight: bold !important; line-height: 22px !important; text-align: center !important;}
.ae-shape-card.active .check-icon { display: block !important; }
.ae-shape-name { font-size: 12px !important; font-weight: 800 !important; color: #334155 !important; line-height: 1.2 !important; }

.ae-split-screen { display: flex !important; flex-wrap: wrap !important; gap: 30px !important; align-items: flex-start !important; }
.ae-split-left { flex: 1 !important; min-width: 300px !important; }
.ae-split-right { width: 350px !important; background: #fff !important; padding: 20px !important; border-radius: 16px !important; border: 1px solid #e2e8f0 !important; box-shadow: 0 4px 15px rgba(0,0,0,0.03) !important; }

/* Fix for A+ Outside Text Box */
.ae-outside-text-box { display: flex !important; align-items: center !important; gap: 12px !important; border: 2px solid #e2e8f0 !important; border-radius: 12px !important; padding: 12px 15px !important; margin-bottom: 20px !important; background: #fff !important; transition: 0.2s !important; }
.ae-outside-text-box.hidden { display: none !important; }
.ae-outside-text-box:focus-within { border-color: var(--ae-primary) !important; box-shadow: 0 0 0 3px rgba(249, 115, 22, 0.1) !important; }
.ae-outside-text-box input { border: none !important; outline: none !important; width: 100% !important; font-size: 16px !important; font-weight: 600 !important; padding: 0 !important; background: transparent !important; margin: 0 !important; line-height: normal !important; box-shadow: none !important;}
.ae-text-icon { font-size: 24px !important; font-weight: 900 !important; color: #64748b !important; font-family: serif !important; line-height: 1 !important; margin: 0 !important; display: block !important;}

/* 10. DYNAMIC VARIATIONS */
.ae-v5-dyn-wrap { display: flex !important; flex-direction: column !important; gap: 12px !important; margin-bottom: 20px !important; border-top: 1px solid var(--aev5-gray) !important; padding-top: 15px !important;}
.ae-v5-dyn-group { display: flex !important; flex-direction: column !important; gap: 6px !important; }
.ae-v5-dyn-lbl { font-size: 13px !important; font-weight: 800 !important; text-transform: uppercase !important; color: #334155 !important; margin:0 !important; padding:0 !important;}
.ae-v5-dyn-btns { display: flex !important; flex-wrap: wrap !important; gap: 8px !important; }
.ae-v5-d-btn { background: #fff !important; border: 1px solid var(--aev5-gray) !important; padding: 8px 16px !important; border-radius: 8px !important; font-size: 13px !important; font-weight: 700 !important; cursor: pointer !important; transition: 0.15s !important; color: #475569 !important; margin:0 !important; min-height: 36px !important;}
.ae-v5-d-btn:hover { border-color: #94a3b8 !important; background: #f8fafc !important; }
.ae-v5-d-btn.active { background: var(--ae-primary) !important; color: #fff !important; border-color: var(--ae-primary) !important; box-shadow: 0 4px 10px rgba(0,0,0,0.1) !important;}

/* RESPONSIVE FIXES */
@media(max-width: 768px) { 
    .ae-split-right { width: 100% !important; } 
    .ae-v5-toolbar-bottom { justify-content: space-between !important; }
    .ae-v5-popup { position: fixed !important; bottom: 0 !important; left: 50% !important; transform: translateX(-50%) !important; width: 100% !important; max-width: 100% !important; border-radius: 24px 24px 0 0 !important; padding: 20px 20px 30px 20px !important; margin: 0 !important; border: none !important; box-shadow: 0 -10px 40px rgba(0,0,0,0.2) !important; z-index: 9999999 !important; max-height: 80vh !important; overflow-y: auto !important; }
    .ae-v5-popup.active { animation: slideUpSheet 0.3s cubic-bezier(0.16, 1, 0.3, 1) forwards !important; }
}
@keyframes slideUpSheet { from { transform: translateY(100%) translateX(-50%); } to { transform: translateY(0) translateX(-50%); } }

@media (min-width: 769px) {
    .ae-v5-master, .ae-v5-workspace { overflow: visible !important; } 
    .ae-v5-bottom-popups { position: absolute !important; top: 15px !important; left: 100% !important; width: 320px !important; height: 100% !important; pointer-events: none !important; z-index: 99999 !important; }
    .ae-v5-popup { position: absolute !important; top: 0 !important; left: 20px !important; width: 100% !important; height: auto !important; max-height: 90% !important; overflow-y: auto !important; border-radius: 16px !important; box-shadow: 0 15px 45px rgba(0,0,0,0.15) !important; border: 1px solid #e2e8f0 !important; opacity: 0 !important; visibility: hidden !important; transform: translateX(-40px) !important; transition: all 0.35s cubic-bezier(0.2, 0.8, 0.2, 1) !important; }
    .ae-v5-popup.active { opacity: 1 !important; visibility: visible !important; transform: translateX(0) !important; pointer-events: auto !important; }
}