/**
 * MTM Design System - CSS Variables
 * Medical Tourism Module v3.9.211
 *
 * SINGLE SOURCE OF TRUTH for all CSS variables
 * Culori: #009DD1 (albastru) + #1CCF5A (verde)
 *
 * FIX 19 Dec 2025: Eliminated duplicate definitions from other files
 * FIX 02 Jan 2026: Added CSS isolation from Avada/themes
 * FIX 05 Jan 2026: Removed admin-specific duplicates (moved to mtm-dashboard-admin.css)
 * FIX 05 Feb 2026: Added Roboto font for professional dashboard look
 */

/* Google Fonts - Roboto */
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;600;700&display=swap');

/* =============================================
   CSS ISOLATION - Protect MTM from theme styles
   ============================================= */

/* Reset inherited styles for all MTM containers */
.mtm-registration,
.mtm-dashboard,
.mtm-modal,
.mtm-login-container,
[class^="mtm-"],
[class*=" mtm-"] {
    /* Ensure our font is used - Roboto */
    font-family: var(--mtm-font-family, 'Roboto', sans-serif) !important;
    /* Reset box-sizing */
    box-sizing: border-box !important;
    /* Prevent theme line-height issues */
    line-height: 1.5 !important;
}

/* Block Avada/Fusion from styling MTM elements */
/* NOTE: Removed "all: revert" as it breaks flex layouts on descendant elements */
.fusion-body .mtm-registration,
.fusion-body .mtm-dashboard,
.fusion-body .mtm-login-container,
.avada-page-wrapper .mtm-registration,
.avada-page-wrapper .mtm-dashboard,
.avada-page-wrapper .mtm-login-container,
.awb-off-canvas__content .mtm-registration {
    /* Apply our base styles with high specificity */
    font-family: var(--mtm-font-family) !important;
    box-sizing: border-box !important;
    line-height: 1.5 !important;
    color: var(--mtm-text-primary) !important;
}

/* Re-apply modal styles for Avada/Fusion (modals need special handling) */
.fusion-body .mtm-modal-overlay,
.avada-page-wrapper .mtm-modal-overlay,
.awb-off-canvas__content .mtm-modal-overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: var(--mtm-z-modal-backdrop) !important;
    background: rgba(0, 0, 0, 0.5) !important;
    display: none;
    align-items: center !important;
    justify-content: center !important;
}

.fusion-body .mtm-modal-overlay.active,
.avada-page-wrapper .mtm-modal-overlay.active,
.awb-off-canvas__content .mtm-modal-overlay.active {
    display: flex !important;
}

.fusion-body .mtm-modal,
.avada-page-wrapper .mtm-modal,
.awb-off-canvas__content .mtm-modal {
    display: flex !important;
    flex-direction: column !important;
    max-width: 600px !important;
    max-height: 90vh !important;
    width: 100% !important;
    z-index: var(--mtm-z-modal) !important;
    background: white !important;
    border-radius: 12px !important;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25) !important;
}

.fusion-body .mtm-modal-xl,
.avada-page-wrapper .mtm-modal-xl {
    max-width: 1000px !important;
}

.fusion-body .mtm-modal-lg,
.avada-page-wrapper .mtm-modal-lg {
    max-width: 800px !important;
}

/* =============================================
   RE-APPLY GRID STYLES AFTER REVERT
   These must come AFTER all:revert to take effect
   ============================================= */

/* Base grid class - must re-apply display:grid after revert */
.fusion-body .mtm-dashboard .mtm-grid,
.fusion-body .mtm-dashboard [class*="mtm-grid"] {
    display: grid !important;
    gap: 16px !important;
}

/* Note: .mtm-quick-actions-grid and .mtm-settings-nav styles
   are in mtm-dashboard-admin.css (admin-specific) */

/* Stats Grid - 4 columns */
.fusion-body .mtm-dashboard .mtm-stats-grid {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 16px !important;
}

/* Stats grid children need min-width:0 for 1fr to work */
.fusion-body .mtm-dashboard .mtm-stats-grid > * {
    min-width: 0 !important;
}

/* Flex utilities */
.fusion-body .mtm-dashboard .mtm-flex {
    display: flex !important;
}

.fusion-body .mtm-dashboard .mtm-flex-col {
    flex-direction: column !important;
}

/* =============================================
   SVG ICON FIXES FOR AVADA/FUSION
   Ensure icons are visible after revert
   ============================================= */

/* Force SVG base visibility in dashboard - general rule */
.fusion-body .mtm-dashboard svg,
.avada-page-wrapper .mtm-dashboard svg {
    display: inline-block !important;
    visibility: visible !important;
    opacity: 1 !important;
    stroke: currentColor !important;
    stroke-width: 1.5 !important;
    fill: none !important;
    flex-shrink: 0 !important;
    overflow: visible !important;
}

/* List item icons - MUST come after general rule for higher specificity */
.fusion-body .mtm-dashboard .mtm-list-item-icon {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    min-height: 40px !important;
    background: #f3f4f6 !important;
    border-radius: 8px !important;
    flex-shrink: 0 !important;
    color: #009DD1 !important;
}

.fusion-body .mtm-dashboard .mtm-list-item-icon svg {
    display: inline-block !important;
    visibility: visible !important;
    width: 20px !important;
    height: 20px !important;
    min-width: 20px !important;
    min-height: 20px !important;
    color: #009DD1 !important;
    stroke: #009DD1 !important;
    stroke-width: 1.5 !important;
    fill: none !important;
}

/* Card title icons */
.fusion-body .mtm-dashboard .mtm-card-title svg {
    display: inline-block !important;
    visibility: visible !important;
    width: 20px !important;
    height: 20px !important;
    min-width: 20px !important;
    min-height: 20px !important;
    margin-right: 8px !important;
    color: #009DD1 !important;
    stroke: #009DD1 !important;
    stroke-width: 1.5 !important;
    fill: none !important;
}

/* Button icons */
.fusion-body .mtm-dashboard .mtm-btn svg {
    display: inline-block !important;
    visibility: visible !important;
    width: 16px !important;
    height: 16px !important;
    min-width: 16px !important;
    min-height: 16px !important;
    color: currentColor !important;
    stroke: currentColor !important;
    stroke-width: 1.5 !important;
    fill: none !important;
}

/* Icon-only buttons - no margin */
.fusion-body .mtm-dashboard .mtm-btn-icon svg {
    margin-right: 0 !important;
}

/* Text + icon buttons - add spacing */
.fusion-body .mtm-dashboard .mtm-btn:not(.mtm-btn-icon) svg {
    margin-right: 4px !important;
}

/* Prevent Avada button styles from affecting MTM buttons - targeted overrides instead of all:unset */
.fusion-body .mtm-btn,
.fusion-body [class^="mtm-btn"],
.avada-page-wrapper .mtm-btn,
.avada-page-wrapper [class^="mtm-btn"],
body.flavor-developer .mtm-btn {
    /* Reset only Avada-specific properties, not all */
    box-shadow: none !important;
    text-shadow: none !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    font-family: var(--mtm-font-family) !important;
    box-sizing: border-box !important;
    /* Ensure MTM button display */
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
}

/* Prevent Avada input styles from affecting MTM inputs - targeted overrides instead of all:unset */
.fusion-body .mtm-form-input,
.fusion-body .mtm-form-select,
.fusion-body .mtm-form-textarea,
.avada-page-wrapper .mtm-form-input,
.avada-page-wrapper .mtm-form-select,
.avada-page-wrapper .mtm-form-textarea {
    /* Reset only Avada-specific properties, not all */
    box-shadow: none !important;
    text-shadow: none !important;
    outline: none !important;
    font-family: var(--mtm-font-family) !important;
    box-sizing: border-box !important;
    /* Ensure MTM input display */
    display: block !important;
    width: 100% !important;
    background-color: #fff !important;
    border: 1px solid var(--mtm-border-color, #e5e7eb) !important;
    border-radius: var(--mtm-radius-md, 8px) !important;
    padding: 10px 12px !important;
}

:root {
    /* ========================================
       PRIMARY COLORS (Blue)
       ======================================== */
    --mtm-primary: #009DD1;
    --mtm-primary-light: #33b5e0;
    --mtm-primary-dark: #0080ab;
    --mtm-primary-rgb: 0, 157, 209;
    
    /* ========================================
       SECONDARY COLORS (Green)
       ======================================== */
    --mtm-secondary: #1CCF5A;
    --mtm-secondary-light: #4eda7a;
    --mtm-secondary-dark: #1A932D;
    --mtm-secondary-rgb: 28, 207, 90;
    
    /* ========================================
       GRADIENT (Primary → Secondary)
       ======================================== */
    --mtm-gradient: linear-gradient(135deg, #009DD1 0%, #1CCF5A 100%);
    --mtm-gradient-hover: linear-gradient(135deg, #0080ab 0%, #1A932D 100%);
    --mtm-gradient-vertical: linear-gradient(180deg, #009DD1 0%, #1CCF5A 100%);
    --mtm-gradient-soft: linear-gradient(135deg, rgba(0,157,209,0.1) 0%, rgba(28,207,90,0.1) 100%);
    
    /* ========================================
       STATUS COLORS
       ======================================== */
    --mtm-success: #10B981;
    --mtm-success-light: #d1fae5;
    --mtm-success-dark: #059669;
    
    --mtm-warning: #F59E0B;
    --mtm-warning-light: #fef3c7;
    --mtm-warning-dark: #d97706;
    
    --mtm-danger: #EF4444;
    --mtm-danger-light: #fee2e2;
    --mtm-danger-dark: #dc2626;
    
    --mtm-info: #3B82F6;
    --mtm-info-light: #dbeafe;
    --mtm-info-dark: #2563eb;
    
    /* ========================================
       NEUTRAL COLORS (Gray Scale)
       ======================================== */
    --mtm-white: #FFFFFF;
    --mtm-black: #000000;
    
    --mtm-gray-50: #F9FAFB;
    --mtm-gray-100: #F3F4F6;
    --mtm-gray-200: #E5E7EB;
    --mtm-gray-300: #D1D5DB;
    --mtm-gray-400: #9CA3AF;
    --mtm-gray-500: #6B7280;
    --mtm-gray-600: #4B5563;
    --mtm-gray-700: #374151;
    --mtm-gray-800: #1F2937;
    --mtm-gray-900: #111827;
    
    /* ========================================
       BACKGROUND COLORS
       ======================================== */
    --mtm-bg-body: #f8fafc;
    --mtm-bg-sidebar: #ffffff;
    --mtm-bg-card: #ffffff;
    --mtm-bg-input: #ffffff;
    --mtm-bg-hover: rgba(0, 157, 209, 0.05);
    --mtm-bg-active: rgba(0, 157, 209, 0.1);
    
    /* ========================================
       TEXT COLORS
       ======================================== */
    --mtm-text-primary: #1F2937;
    --mtm-text-secondary: #4B5563;
    --mtm-text-muted: #9CA3AF;
    --mtm-text-inverse: #FFFFFF;
    
    /* ========================================
       BORDER COLORS
       ======================================== */
    --mtm-border-light: #F3F4F6;
    --mtm-border-default: #E5E7EB;
    --mtm-border-dark: #D1D5DB;
    
    /* ========================================
       TYPOGRAPHY - Roboto Professional Dashboard
       ======================================== */
    --mtm-font-family: 'Roboto', sans-serif;
    --mtm-font-mono: 'Roboto', sans-serif;

    /* Font sizes - optimized for dashboard readability */
    --mtm-text-xs: 0.6875rem;  /* 11px - labels, hints */
    --mtm-text-sm: 0.8125rem;  /* 13px - table cells, secondary */
    --mtm-text-base: 0.875rem; /* 14px - body text */
    --mtm-text-lg: 1rem;       /* 16px - emphasized text */
    --mtm-text-xl: 1.125rem;   /* 18px - section titles */
    --mtm-text-2xl: 1.375rem;  /* 22px - card titles */
    --mtm-text-3xl: 1.625rem;  /* 26px - page titles */

    /* Font weights */
    --mtm-font-light: 300;
    --mtm-font-normal: 400;
    --mtm-font-medium: 500;
    --mtm-font-semibold: 600;
    --mtm-font-bold: 700;

    /* Line heights - professional spacing */
    --mtm-leading-tight: 1.25;
    --mtm-leading-normal: 1.5;
    --mtm-leading-relaxed: 1.625;

    /* Letter spacing */
    --mtm-tracking-tight: -0.025em;
    --mtm-tracking-normal: 0;
    --mtm-tracking-wide: 0.025em;
    
    /* ========================================
       SPACING
       ======================================== */
    --mtm-space-0: 0;
    --mtm-space-1: 0.25rem;    /* 4px */
    --mtm-space-2: 0.5rem;     /* 8px */
    --mtm-space-3: 0.75rem;    /* 12px */
    --mtm-space-4: 1rem;       /* 16px */
    --mtm-space-5: 1.25rem;    /* 20px */
    --mtm-space-6: 1.5rem;     /* 24px */
    --mtm-space-8: 2rem;       /* 32px */
    --mtm-space-10: 2.5rem;    /* 40px */
    --mtm-space-12: 3rem;      /* 48px */
    
    /* ========================================
       BORDER RADIUS
       ======================================== */
    --mtm-radius-none: 0;
    --mtm-radius-sm: 4px;
    --mtm-radius-default: 8px;
    --mtm-radius-md: 10px;
    --mtm-radius-lg: 12px;
    --mtm-radius-xl: 16px;
    --mtm-radius-2xl: 20px;
    --mtm-radius-full: 9999px;
    
    /* ========================================
       SHADOWS
       ======================================== */
    --mtm-shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.05);
    --mtm-shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.1);
    --mtm-shadow-default: 0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 2px rgba(0, 0, 0, 0.06);
    --mtm-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --mtm-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
    --mtm-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
    --mtm-shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    
    /* ========================================
       TRANSITIONS
       ======================================== */
    --mtm-transition-fast: 0.15s ease;
    --mtm-transition-default: 0.2s ease;
    --mtm-transition-slow: 0.3s ease;
    --mtm-transition-smooth: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    
    /* ========================================
       Z-INDEX LAYERS (UNIFIED)
       ======================================== */
    --mtm-z-dropdown: 100;
    --mtm-z-sticky: 200;
    --mtm-z-fixed: 300;
    --mtm-z-sidebar: 400;
    --mtm-z-modal-backdrop: 99998;
    --mtm-z-modal: 99999;
    --mtm-z-popover: 100000;
    --mtm-z-tooltip: 100001;
    --mtm-z-toast: 100002;
    
    /* ========================================
       SIDEBAR DIMENSIONS
       ======================================== */
    --mtm-sidebar-width: 260px;
    --mtm-sidebar-collapsed: 72px;
    --mtm-sidebar-transition: 300ms cubic-bezier(0.4, 0, 0.2, 1);
    
    /* ========================================
       LAYOUT
       ======================================== */
    --mtm-header-height: 64px;
    --mtm-content-max-width: 1400px;
    --mtm-card-padding: var(--mtm-space-6);
    
    /* ========================================
       BREAKPOINTS (for reference in JS)
       ======================================== */
    --mtm-breakpoint-sm: 640px;
    --mtm-breakpoint-md: 768px;
    --mtm-breakpoint-lg: 1024px;
    --mtm-breakpoint-xl: 1280px;
    --mtm-breakpoint-2xl: 1536px;

    /* ========================================
       SHORTHAND ALIASES
       Used by registration forms & components
       ======================================== */
    --mtm-text: var(--mtm-text-primary);
    --mtm-text-light: var(--mtm-text-secondary);
    --mtm-bg: var(--mtm-bg-card);
    --mtm-bg-subtle: var(--mtm-gray-50);
    --mtm-border: var(--mtm-border-default);
    --mtm-radius: var(--mtm-radius-default);
    --mtm-shadow: var(--mtm-shadow-default);
    --mtm-transition: var(--mtm-transition-default);
    --mtm-error: var(--mtm-danger);
    --mtm-error-light: var(--mtm-danger-light);
    --mtm-primary-hover: var(--mtm-primary-dark);
}

/* ========================================
   FUSION/AVADA RESET
   Override Fusion responsive typography
   ======================================== */
.mtm-app .fusion-responsive-typography-calculated,
.mtm-app [data-fontsize],
.mtm-app h1,
.mtm-app h2,
.mtm-app h3,
.mtm-app h4,
.mtm-app h5,
.mtm-app h6 {
    font-size: inherit !important;
    line-height: inherit !important;
}

.mtm-app {
    font-family: var(--mtm-font-family) !important;
}

/* ========================================
   DARK MODE (optional, for future)
   ======================================== */
[data-theme="dark"] {
    --mtm-bg-body: #111827;
    --mtm-bg-sidebar: #1F2937;
    --mtm-bg-card: #1F2937;
    --mtm-bg-input: #374151;
    --mtm-bg-hover: #374151;

    --mtm-border-light: #374151;
    --mtm-border-default: #4B5563;

    --mtm-text-primary: #F9FAFB;
    --mtm-text-secondary: #D1D5DB;
    --mtm-text-muted: #9CA3AF;
}

/* ========================================
   AVADA LAYOUT BUILDER OVERRIDES
   Force MTM layout styles when inside Avada
   Using extremely high specificity to override Avada
   ======================================== */

/* Reset all Avada/Fusion container styles inside MTM app */
html body .mtm-app,
html body .mtm-app *,
.fusion-body .mtm-app,
.fusion-body .mtm-app *,
.avada-html-layout-boxed .mtm-app,
.avada-html-layout-boxed .mtm-app *,
body.fusion-body .mtm-app,
body.fusion-body .mtm-app * {
    box-sizing: border-box !important;
    direction: ltr !important;
}

/* Force MTM app to be full width and properly positioned */
html body .mtm-app,
.fusion-body .mtm-app,
body.fusion-body .mtm-app {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    position: relative !important;
}

/* Force grid display on MTM grid classes */
html body .mtm-app .mtm-grid,
html body .fusion-body .mtm-grid,
html body.fusion-body .mtm-app .mtm-grid,
.fusion-builder-live .mtm-grid,
.fusion-body .mtm-grid,
body .mtm-app .mtm-grid {
    display: grid !important;
    gap: var(--mtm-space-4) !important;
}

html body .mtm-app .mtm-grid-2,
html body.fusion-body .mtm-app .mtm-grid-2,
.fusion-builder-live .mtm-grid-2,
.fusion-body .mtm-grid-2,
body .mtm-app .mtm-grid-2 {
    grid-template-columns: repeat(2, 1fr) !important;
}

html body .mtm-app .mtm-grid-3,
html body.fusion-body .mtm-app .mtm-grid-3,
.fusion-builder-live .mtm-grid-3,
.fusion-body .mtm-grid-3,
body .mtm-app .mtm-grid-3 {
    grid-template-columns: repeat(3, 1fr) !important;
}

html body .mtm-app .mtm-grid-4,
html body.fusion-body .mtm-app .mtm-grid-4,
.fusion-builder-live .mtm-grid-4,
.fusion-body .mtm-grid-4,
body .mtm-app .mtm-grid-4 {
    grid-template-columns: repeat(4, 1fr) !important;
}

/* Force flex display on MTM flex classes */
html body .mtm-app .mtm-flex,
html body.fusion-body .mtm-app .mtm-flex,
.fusion-builder-live .mtm-flex,
.fusion-body .mtm-flex,
body .mtm-app .mtm-flex {
    display: flex !important;
}

html body .mtm-app .mtm-flex-col,
html body.fusion-body .mtm-app .mtm-flex-col,
.fusion-builder-live .mtm-flex-col,
.fusion-body .mtm-flex-col,
body .mtm-app .mtm-flex-col {
    flex-direction: column !important;
}

html body .mtm-app .mtm-items-center,
html body.fusion-body .mtm-app .mtm-items-center,
.fusion-builder-live .mtm-items-center,
.fusion-body .mtm-items-center,
body .mtm-app .mtm-items-center {
    align-items: center !important;
}

html body .mtm-app .mtm-justify-between,
html body.fusion-body .mtm-app .mtm-justify-between,
.fusion-builder-live .mtm-justify-between,
.fusion-body .mtm-justify-between,
body .mtm-app .mtm-justify-between {
    justify-content: space-between !important;
}

/* Profile layout - two columns */
html body .mtm-app .mtm-profile-layout,
html body.fusion-body .mtm-app .mtm-profile-layout,
.fusion-builder-live .mtm-profile-layout,
.fusion-body .mtm-profile-layout,
body .mtm-app .mtm-profile-layout {
    display: grid !important;
    grid-template-columns: 2fr 1fr !important;
    gap: 24px !important;
    align-items: start !important;
}

/* Stats grid - 4 columns */
html body .mtm-app .mtm-stats-grid,
html body.fusion-body .mtm-app .mtm-stats-grid,
.fusion-builder-live .mtm-stats-grid,
.fusion-body .mtm-stats-grid,
body .mtm-app .mtm-stats-grid {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: var(--mtm-space-4) !important;
}

/* Override inline grid styles for overview - CRITICAL for 2fr 1fr layout */
html body .mtm-app .mtm-grid[style*="2fr 1fr"],
html body.fusion-body .mtm-app .mtm-grid[style*="2fr 1fr"],
.fusion-body .mtm-grid[style*="2fr 1fr"],
body .mtm-app .mtm-grid[style*="2fr 1fr"],
html body .mtm-app .mtm-grid.mtm-grid-2[style],
html body.fusion-body .mtm-app .mtm-grid.mtm-grid-2[style] {
    display: grid !important;
    grid-template-columns: 2fr 1fr !important;
}

/* Direct children of 2fr 1fr grid */
html body .mtm-app .mtm-grid[style*="2fr 1fr"] > *:first-child,
html body.fusion-body .mtm-app .mtm-grid[style*="2fr 1fr"] > *:first-child {
    grid-column: 1 !important;
    order: 0 !important;
}

html body .mtm-app .mtm-grid[style*="2fr 1fr"] > *:last-child,
html body.fusion-body .mtm-app .mtm-grid[style*="2fr 1fr"] > *:last-child {
    grid-column: 2 !important;
    order: 1 !important;
}

/* Card styles */
html body .mtm-app .mtm-card,
html body.fusion-body .mtm-app .mtm-card,
.fusion-builder-live .mtm-card,
.fusion-body .mtm-card,
body .mtm-app .mtm-card {
    display: block !important;
    background: var(--mtm-bg-card) !important;
    border-radius: var(--mtm-radius-lg) !important;
    box-shadow: var(--mtm-shadow-sm) !important;
}

/* Form rows */
html body .mtm-app .mtm-form-row,
html body.fusion-body .mtm-app .mtm-form-row,
.fusion-builder-live .mtm-form-row,
.fusion-body .mtm-form-row,
body .mtm-app .mtm-form-row {
    display: grid !important;
    gap: 16px !important;
}

html body .mtm-app .mtm-form-row-2,
html body.fusion-body .mtm-app .mtm-form-row-2,
.fusion-builder-live .mtm-form-row-2,
.fusion-body .mtm-form-row-2,
body .mtm-app .mtm-form-row-2 {
    grid-template-columns: repeat(2, 1fr) !important;
}

html body .mtm-app .mtm-form-row-3,
html body.fusion-body .mtm-app .mtm-form-row-3,
.fusion-builder-live .mtm-form-row-3,
.fusion-body .mtm-form-row-3,
body .mtm-app .mtm-form-row-3 {
    grid-template-columns: repeat(3, 1fr) !important;
}

/* Gap utilities */
html body .mtm-app .mtm-gap-4,
html body.fusion-body .mtm-app .mtm-gap-4,
.fusion-body .mtm-gap-4,
body .mtm-app .mtm-gap-4 {
    gap: var(--mtm-space-4) !important;
}

html body .mtm-app .mtm-gap-6,
html body.fusion-body .mtm-app .mtm-gap-6,
.fusion-body .mtm-gap-6,
body .mtm-app .mtm-gap-6 {
    gap: var(--mtm-space-6) !important;
}

/* Responsive overrides for Avada */
@media (max-width: 1024px) {
    html body .mtm-app .mtm-grid-4,
    html body.fusion-body .mtm-app .mtm-grid-4,
    .fusion-body .mtm-grid-4,
    body .mtm-app .mtm-grid-4,
    html body .mtm-app .mtm-stats-grid,
    html body.fusion-body .mtm-app .mtm-stats-grid,
    .fusion-body .mtm-stats-grid,
    body .mtm-app .mtm-stats-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    html body .mtm-app .mtm-profile-layout,
    html body.fusion-body .mtm-app .mtm-profile-layout,
    .fusion-body .mtm-profile-layout,
    body .mtm-app .mtm-profile-layout {
        grid-template-columns: 1fr !important;
    }

    html body .mtm-app .mtm-grid[style*="2fr 1fr"],
    html body.fusion-body .mtm-app .mtm-grid[style*="2fr 1fr"],
    .fusion-body .mtm-grid[style*="2fr 1fr"],
    body .mtm-app .mtm-grid[style*="2fr 1fr"] {
        grid-template-columns: 1fr !important;
    }

    /* Reset grid-column for children when stacking */
    html body .mtm-app .mtm-grid[style*="2fr 1fr"] > *,
    html body.fusion-body .mtm-app .mtm-grid[style*="2fr 1fr"] > * {
        grid-column: auto !important;
    }
}

@media (max-width: 768px) {
    html body .mtm-app .mtm-grid-2,
    html body .mtm-app .mtm-grid-3,
    html body .mtm-app .mtm-grid-4,
    html body .mtm-app .mtm-stats-grid,
    html body.fusion-body .mtm-app .mtm-grid-2,
    html body.fusion-body .mtm-app .mtm-grid-3,
    html body.fusion-body .mtm-app .mtm-grid-4,
    html body.fusion-body .mtm-app .mtm-stats-grid,
    .fusion-body .mtm-grid-2,
    .fusion-body .mtm-grid-3,
    .fusion-body .mtm-grid-4,
    .fusion-body .mtm-stats-grid,
    body .mtm-app .mtm-grid-2,
    body .mtm-app .mtm-grid-3,
    body .mtm-app .mtm-grid-4,
    body .mtm-app .mtm-stats-grid {
        grid-template-columns: 1fr !important;
    }

    html body .mtm-app .mtm-form-row-2,
    html body .mtm-app .mtm-form-row-3,
    html body.fusion-body .mtm-app .mtm-form-row-2,
    html body.fusion-body .mtm-app .mtm-form-row-3,
    .fusion-body .mtm-form-row-2,
    .fusion-body .mtm-form-row-3,
    body .mtm-app .mtm-form-row-2,
    body .mtm-app .mtm-form-row-3 {
        grid-template-columns: 1fr !important;
    }
}

/* =============================================
   AVADA LAYOUTS WPAUTOP PROTECTION
   Neutralize parasitic <p> and <br> tags injected by WordPress/Avada
   This CSS makes the layout resilient even if wpautop adds unwanted elements
   ============================================= */

/* Make <p> tags invisible inside MTM flex/grid containers */
.mtm-app > p,
.mtm-dashboard > p,
.mtm-sidebar > p,
.mtm-main > p,
.mtm-content > p,
.mtm-tab-content > p:empty,
.mtm-toolbar > p,
.mtm-list-item > p,
.mtm-modal-header > p,
.mtm-modal-footer > p,
.mtm-card-header > p,
.mtm-card-footer > p,
.mtm-stats-grid > p,
.mtm-grid > p,
.mtm-flex > p,
html body .fusion-body .mtm-app > p,
html body .fusion-body .mtm-dashboard > p,
html body .fusion-body .mtm-sidebar > p {
    display: contents !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Remove <br> tags that break flexbox/grid layouts */
.mtm-app > br,
.mtm-dashboard > br,
.mtm-sidebar > br,
.mtm-main > br,
.mtm-content > br,
.mtm-toolbar > br,
.mtm-list-item > br,
.mtm-modal-header > br,
.mtm-modal-footer > br,
.mtm-card-header > br,
.mtm-card-footer > br,
.mtm-stats-grid > br,
.mtm-grid > br,
.mtm-flex > br,
html body .fusion-body .mtm-app > br,
html body .fusion-body .mtm-dashboard > br {
    display: none !important;
}

/* Ensure direct children of flex containers ignore parasitic elements */
/* NOTE: Do NOT override .mtm-sidebar here - it has its own flex-direction: column */
/* Nav sections need column direction (title on top, items below) */
.fusion-body .mtm-sidebar .mtm-nav-section,
.avada-page-wrapper .mtm-sidebar .mtm-nav-section,
body .mtm-dashboard .mtm-sidebar .mtm-nav-section,
body .mtm-app .mtm-sidebar .mtm-nav-section,
.mtm-sidebar .mtm-nav-section,
.mtm-nav-section {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
}

/* Make parasitic <p> tags inside nav-section transparent (keep contents visible) */
/* wpautop wraps nav-items inside <p>, so we use display:contents to unwrap them */
.mtm-nav-section > p {
    display: contents !important;
}

/* Other flex containers - row direction */
.mtm-toolbar,
.mtm-list-item,
.mtm-modal-header,
.mtm-modal-footer,
.mtm-card-header,
.mtm-card-footer,
.mtm-offer-header,
.mtm-offer-footer {
    display: flex !important;
}

/* Nav list items should be row flex (icon + text + badge on same line) */
/* HIGH SPECIFICITY for Avada/Fusion override */
.fusion-body .mtm-sidebar .mtm-nav-item,
.avada-page-wrapper .mtm-sidebar .mtm-nav-item,
body .mtm-dashboard .mtm-sidebar .mtm-nav-item,
body .mtm-app .mtm-sidebar .mtm-nav-item,
.mtm-sidebar .mtm-nav-item,
.mtm-nav-item {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: var(--mtm-space-3, 12px) !important;
}

/* Nav item children - ensure they don't wrap */
.fusion-body .mtm-sidebar .mtm-nav-item > *,
body .mtm-dashboard .mtm-sidebar .mtm-nav-item > *,
.mtm-sidebar .mtm-nav-item > * {
    flex-shrink: 0 !important;
}

/* Nav item text should flex to fill space */
.fusion-body .mtm-sidebar .mtm-nav-item-text,
body .mtm-dashboard .mtm-sidebar .mtm-nav-item-text,
.mtm-sidebar .mtm-nav-item-text,
.mtm-nav-item-text {
    flex: 1 !important;
    flex-shrink: 1 !important;
}

/* Nav list is a column of nav items */
.fusion-body .mtm-sidebar .mtm-nav-list,
.avada-page-wrapper .mtm-sidebar .mtm-nav-list,
body .mtm-dashboard .mtm-sidebar .mtm-nav-list,
body .mtm-app .mtm-sidebar .mtm-nav-list,
.mtm-sidebar .mtm-nav-list,
.mtm-nav-list {
    display: flex !important;
    flex-direction: column !important;
}

/* Use > * selector to target direct children, ignoring intermediate <p> wrappers */
.mtm-app,
.mtm-dashboard {
    display: flex !important;
}

/* For grid containers - ensure grid is not broken by <p> elements */
.mtm-stats-grid,
.mtm-grid,
.mtm-grid-2,
.mtm-grid-3,
.mtm-grid-4,
.mtm-quick-actions-grid {
    display: grid !important;
}

/* Target direct flex/grid children using CSS :not() to skip <p> and <br> */
.mtm-app > *:not(p):not(br),
.mtm-dashboard > *:not(p):not(br) {
    /* Ensure proper flex item behavior */
    flex-shrink: 0;
}

/* Fusion Builder specific - extra high specificity */
.fusion-body .mtm-app,
.fusion-body .mtm-dashboard,
.fusion-builder-live .mtm-app,
.fusion-builder-live .mtm-dashboard,
body.flavor-developer .mtm-app,
body.flavor-developer .mtm-dashboard {
    display: flex !important;
    flex-direction: row !important;
    width: 100% !important;
}

/* Ensure sidebar stays on left regardless of injected elements */
/* CRITICAL: Sidebar must remain flex-direction: column for internal layout */
.fusion-body .mtm-app > .mtm-sidebar,
.fusion-body .mtm-dashboard > .mtm-sidebar,
body .mtm-app > .mtm-sidebar,
body .mtm-dashboard > .mtm-sidebar,
.mtm-sidebar {
    order: -1 !important;
    flex-shrink: 0 !important;
    display: flex !important;
    flex-direction: column !important;
}

/* Ensure main content takes remaining space */
.fusion-body .mtm-app > .mtm-main,
.fusion-body .mtm-dashboard > .mtm-main,
body .mtm-app > .mtm-main,
body .mtm-dashboard > .mtm-main {
    order: 0 !important;
    flex: 1 !important;
    min-width: 0 !important;
}

/* Hide any parasitic elements that appear between sidebar and main */
.mtm-app > p:not(.mtm-card):not([class*="mtm-"]),
.mtm-dashboard > p:not(.mtm-card):not([class*="mtm-"]) {
    position: absolute !important;
    width: 0 !important;
    height: 0 !important;
    overflow: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
}