/* =============================================
   Mi Negocio - Metronic v8 Inspired Design System
   ============================================= */

/* ---- CSS Variables / Design Tokens ---- */
:root {
    --mg-primary: #3E97FF;
    --mg-primary-light: rgba(62, 151, 255, 0.1);
    --mg-success: #50CD89;
    --mg-success-light: rgba(80, 205, 137, 0.1);
    --mg-warning: #FFC700;
    --mg-warning-light: rgba(255, 199, 0, 0.1);
    --mg-danger: #F1416C;
    --mg-danger-light: rgba(241, 65, 108, 0.1);
    --mg-info: #7239EA;
    --mg-info-light: rgba(114, 57, 234, 0.1);
    --mg-dark: #181C32;
    --mg-gray-100: #F5F8FA;
    --mg-gray-200: #EFF2F5;
    --mg-gray-300: #E4E6EF;
    --mg-gray-400: #B5B5C3;
    --mg-gray-500: #A1A5B7;
    --mg-gray-600: #7E8299;
    --mg-gray-700: #5E6278;
    --mg-gray-800: #3F4254;
    --mg-gray-900: #181C32;
    --mg-sidebar-width: 260px;
    --mg-sidebar-width-collapsed: 70px;
    --mg-topbar-height: 65px;
    --mg-border-radius: 0.75rem;
    --mg-font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --mg-body-bg: #F5F8FA;
    --mg-card-bg: #fff;
    --mg-topbar-bg: #fff;
    --mg-sidebar-bg: #181C32;
    --mg-text-color: #3F4254;
    --mg-text-muted: #A1A5B7;
    --mg-border-color: #EFF2F5;
    --mg-card-shadow: 0 0 20px rgba(0, 0, 0, 0.04);
    --mg-gradient-primary-end: #7239EA;
    --mg-gradient-danger-end: #D9214E;
    --mg-gradient-success-end: #2DBE6C;
}

/* ---- Dark Theme ---- */
[data-theme="dark"] {
    --mg-primary: #5BA7FF;
    --mg-primary-light: rgba(91, 167, 255, 0.15);
    --mg-success-light: rgba(80, 205, 137, 0.15);
    --mg-warning-light: rgba(255, 199, 0, 0.15);
    --mg-danger-light: rgba(241, 65, 108, 0.15);
    --mg-info-light: rgba(114, 57, 234, 0.15);
    --mg-dark: #f5f5f5;
    --mg-gray-100: #1e1e2d;
    --mg-gray-200: #2B2B40;
    --mg-gray-300: #323248;
    --mg-gray-400: #474761;
    --mg-gray-500: #6D6D80;
    --mg-gray-600: #92929F;
    --mg-gray-700: #CDCDDE;
    --mg-gray-800: #E4E4F0;
    --mg-gray-900: #f5f5f5;
    --mg-body-bg: #151521;
    --mg-card-bg: #1E1E2D;
    --mg-topbar-bg: #1E1E2D;
    --mg-sidebar-bg: #1A1A27;
    --mg-text-color: #CDCDDE;
    --mg-text-muted: #6D6D80;
    --mg-border-color: #2B2B40;
    --mg-card-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
    --mg-gradient-primary-end: #9b59b6;
    --mg-gradient-danger-end: #c0392b;
    --mg-gradient-success-end: #27ae60;
}

/* ---- Ocean Theme ---- */
[data-theme="ocean"] {
    --mg-primary: #0EA5E9;
    --mg-primary-light: rgba(14, 165, 233, 0.1);
    --mg-info: #06B6D4;
    --mg-info-light: rgba(6, 182, 212, 0.1);
    --mg-dark: #0C4A6E;
    --mg-gray-100: #F0F9FF;
    --mg-gray-200: #E0F2FE;
    --mg-gray-300: #BAE6FD;
    --mg-gray-400: #7DD3FC;
    --mg-gray-500: #38BDF8;
    --mg-gray-600: #0284C7;
    --mg-gray-700: #0369A1;
    --mg-gray-800: #075985;
    --mg-gray-900: #0C4A6E;
    --mg-body-bg: #F0F9FF;
    --mg-card-bg: #fff;
    --mg-topbar-bg: #fff;
    --mg-sidebar-bg: #0C4A6E;
    --mg-text-color: #075985;
    --mg-text-muted: #0284C7;
    --mg-border-color: #E0F2FE;
    --mg-card-shadow: 0 0 20px rgba(14, 165, 233, 0.08);
    --mg-gradient-primary-end: #06B6D4;
    --mg-gradient-danger-end: #DB2777;
    --mg-gradient-success-end: #059669;
}

/* ---- Sunset Theme ---- */
[data-theme="sunset"] {
    --mg-primary: #F97316;
    --mg-primary-light: rgba(249, 115, 22, 0.1);
    --mg-info: #EF4444;
    --mg-info-light: rgba(239, 68, 68, 0.1);
    --mg-warning: #FBBF24;
    --mg-warning-light: rgba(251, 191, 36, 0.1);
    --mg-dark: #7C2D12;
    --mg-gray-100: #FFF7ED;
    --mg-gray-200: #FFEDD5;
    --mg-gray-300: #FED7AA;
    --mg-gray-400: #FDBA74;
    --mg-gray-500: #FB923C;
    --mg-gray-600: #EA580C;
    --mg-gray-700: #C2410C;
    --mg-gray-800: #9A3412;
    --mg-gray-900: #7C2D12;
    --mg-body-bg: #FFF7ED;
    --mg-card-bg: #fff;
    --mg-topbar-bg: #fff;
    --mg-sidebar-bg: #7C2D12;
    --mg-text-color: #9A3412;
    --mg-text-muted: #EA580C;
    --mg-border-color: #FFEDD5;
    --mg-card-shadow: 0 0 20px rgba(249, 115, 22, 0.08);
    --mg-gradient-primary-end: #EF4444;
    --mg-gradient-danger-end: #DC2626;
    --mg-gradient-success-end: #16A34A;
}

/* ---- Base ---- */
body {
    font-family: var(--mg-font-family);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    background-color: var(--mg-body-bg);
    color: var(--mg-text-color);
}

/* ---- Sidebar ---- */
.mg-sidebar {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: var(--mg-sidebar-width);
    background: var(--mg-sidebar-bg);
    z-index: 1040;
    display: flex;
    flex-direction: column;
    transition: transform 0.3s ease;
}

.mg-sidebar-brand {
    height: var(--mg-topbar-height);
    display: flex;
    align-items: center;
    padding: 0 1.5rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}

.mg-sidebar-brand h4 {
    color: #fff;
    margin: 0;
    font-weight: 700;
    font-size: 1.25rem;
}

.mg-sidebar-brand i {
    color: var(--mg-primary);
    font-size: 1.5rem;
    margin-right: 0.75rem;
}

.mg-sidebar-menu {
    flex: 1;
    overflow-y: auto;
    padding: 1rem 0;
}

.mg-sidebar-menu .nav-link {
    display: flex;
    align-items: center;
    padding: 0.75rem 1.5rem;
    color: var(--mg-gray-500);
    font-weight: 500;
    font-size: 0.925rem;
    transition: all 0.2s ease;
    border-radius: 0;
    margin: 0 0.75rem;
    border-radius: 0.5rem;
}

.mg-sidebar-menu .nav-link:hover {
    color: #fff;
    background: rgba(255, 255, 255, 0.04);
}

.mg-sidebar-menu .nav-link.active {
    color: #fff;
    background: var(--mg-primary);
}

.mg-sidebar-menu .nav-link i {
    width: 24px;
    margin-right: 0.75rem;
    font-size: 1.1rem;
    text-align: center;
}

.mg-sidebar-footer {
    padding: 1rem 1.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.07);
}

.mg-sidebar-footer .nav-link {
    color: var(--mg-danger) !important;
}

.mg-sidebar-footer .nav-link:hover {
    background: var(--mg-danger-light) !important;
}

/* ---- Topbar ---- */
.mg-topbar {
    height: var(--mg-topbar-height);
    background: var(--mg-topbar-bg);
    border-bottom: 1px solid var(--mg-border-color);
    display: flex;
    align-items: center;
    padding: 0 1.5rem;
    margin-left: var(--mg-sidebar-width);
    position: sticky;
    top: 0;
    z-index: 1030;
}

.mg-topbar-left {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.mg-topbar-right {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-left: auto;
}

.mg-hamburger {
    display: none;
    background: none;
    border: none;
    font-size: 1.5rem;
    color: var(--mg-gray-700);
    padding: 0.25rem;
    cursor: pointer;
}

/* ---- Notification Bell ---- */
.mg-bell {
    position: relative;
    background: var(--mg-gray-100);
    border: none;
    border-radius: 0.5rem;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s;
}

.mg-bell:hover {
    background: var(--mg-gray-200);
}

.mg-bell .badge {
    position: absolute;
    top: 2px;
    right: 2px;
    font-size: 0.65rem;
    padding: 0.2rem 0.4rem;
    border-radius: 50%;
    background: var(--mg-danger);
    color: #fff;
    min-width: 18px;
}

/* Notification Dropdown */
.mg-notification-dropdown {
    width: 350px;
    max-width: calc(100vw - 1rem);
    max-height: 400px;
    overflow-y: auto;
    border: none;
    box-shadow: 0 0 50px rgba(0, 0, 0, 0.15);
    border-radius: var(--mg-border-radius);
    padding: 0;
    background: var(--mg-card-bg);
}

.mg-notification-header {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--mg-border-color);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.mg-notification-item {
    padding: 0.875rem 1.25rem;
    border-bottom: 1px solid var(--mg-gray-100);
    cursor: pointer;
    transition: background 0.2s;
}

.mg-notification-item:hover {
    background: var(--mg-gray-100);
}

.mg-notification-item.unread {
    background: rgba(62, 151, 255, 0.03);
    border-left: 3px solid var(--mg-primary);
}

/* ---- Main Content ---- */
.mg-content {
    margin-left: var(--mg-sidebar-width);
    min-height: 100vh;
    padding: 1.5rem;
}

/* ---- Cards ---- */
.mg-card {
    background: var(--mg-card-bg);
    border-radius: var(--mg-border-radius);
    box-shadow: var(--mg-card-shadow);
    border: none;
}

.mg-card .card-header {
    background: transparent;
    border-bottom: 1px solid var(--mg-border-color);
    padding: 1.25rem 1.5rem;
}

.mg-card .card-body {
    padding: 1.5rem;
}

/* ---- Stat Cards ---- */
.mg-stat-card {
    background: var(--mg-card-bg);
    border-radius: var(--mg-border-radius);
    box-shadow: var(--mg-card-shadow);
    border: none;
    padding: 1.25rem 1.5rem;
    transition: transform 0.2s ease;
}

.mg-stat-card:hover {
    transform: translateY(-2px);
}

.mg-stat-card .stat-label {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--mg-gray-500);
    margin-bottom: 0.5rem;
}

.mg-stat-card .stat-value {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--mg-dark);
}

.mg-stat-card .stat-icon {
    width: 48px;
    height: 48px;
    border-radius: 0.625rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
}

/* ---- Inventory Product Cards ---- */
.inv-card {
    background: var(--mg-card-bg, #fff);
    border: 1px solid var(--mg-border, #E4E6EF);
    border-radius: 0.75rem;
    padding: 1rem;
    text-align: center;
    position: relative;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.inv-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(0,0,0,0.08);
}
.inv-card-selling {
    animation: inv-pulse 0.3s ease;
}
@keyframes inv-pulse {
    0% { transform: scale(1); }
    50% { transform: scale(0.95); background: #E8FFF3; }
    100% { transform: scale(1); }
}
.inv-card-actions {
    position: absolute;
    top: 0.4rem;
    right: 0.4rem;
    display: flex;
    gap: 2px;
    opacity: 0;
    transition: opacity 0.15s ease;
}
.inv-card:hover .inv-card-actions { opacity: 1; }
.inv-card-action-btn {
    background: none;
    border: none;
    padding: 2px 5px;
    cursor: pointer;
    color: var(--mg-gray-600, #7E8299);
    font-size: 0.8rem;
    border-radius: 4px;
    transition: background 0.15s;
}
.inv-card-action-btn:hover { background: var(--mg-gray-200, #F1F1F2); }
.inv-card-action-delete:hover { color: var(--mg-danger, #F1416C); }
.inv-card-name {
    font-weight: 700;
    font-size: 0.9rem;
    margin-bottom: 0.15rem;
    color: var(--mg-dark, #181C32);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.inv-card-price {
    color: var(--mg-gray-600, #7E8299);
    font-size: 0.8rem;
    margin-bottom: 0.5rem;
}
.inv-card-stock-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}
.inv-card-stock {
    font-size: 1.75rem;
    font-weight: 800;
    min-width: 2.5rem;
    line-height: 1;
}
.inv-arrow {
    background: none;
    border: 2px solid var(--mg-border, #E4E6EF);
    border-radius: 50%;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 1rem;
    transition: all 0.15s ease;
    color: var(--mg-gray-600, #7E8299);
}
.inv-arrow:active { transform: scale(0.9); }
.inv-arrow-up:hover {
    background: var(--mg-primary-light, #F1FAFF);
    border-color: var(--mg-primary, #3E97FF);
    color: var(--mg-primary, #3E97FF);
}
.inv-arrow-down:hover {
    background: var(--mg-success-light, #E8FFF3);
    border-color: var(--mg-success, #50CD89);
    color: var(--mg-success, #50CD89);
}
.inv-arrow.disabled {
    opacity: 0.3;
    cursor: not-allowed;
    pointer-events: none;
}
.inv-card-alert {
    display: block;
    margin-top: 0.4rem;
    color: var(--mg-danger, #F1416C);
    font-size: 0.7rem;
    font-weight: 600;
}

/* ---- Light Backgrounds ---- */
.bg-light-primary { background-color: var(--mg-primary-light) !important; }
.bg-light-success { background-color: var(--mg-success-light) !important; }
.bg-light-warning { background-color: var(--mg-warning-light) !important; }
.bg-light-danger { background-color: var(--mg-danger-light) !important; }
.bg-light-info { background-color: var(--mg-info-light) !important; }

.text-primary { color: var(--mg-primary) !important; }
.text-success { color: var(--mg-success) !important; }
.text-warning { color: var(--mg-warning) !important; }
.text-danger { color: var(--mg-danger) !important; }
.text-info { color: var(--mg-info) !important; }

.bg-primary { background-color: var(--mg-primary) !important; }
.bg-success { background-color: var(--mg-success) !important; }
.bg-warning { background-color: var(--mg-warning) !important; }
.bg-danger { background-color: var(--mg-danger) !important; }

/* ---- Badges ---- */
.badge-light-primary { background-color: var(--mg-primary-light); color: var(--mg-primary); }
.badge-light-success { background-color: var(--mg-success-light); color: var(--mg-success); }
.badge-light-warning { background-color: var(--mg-warning-light); color: var(--mg-warning); }
.badge-light-danger { background-color: var(--mg-danger-light); color: var(--mg-danger); }
.badge-light-info { background-color: var(--mg-info-light); color: var(--mg-info); }

/* ---- Buttons ---- */
.btn-primary {
    background-color: var(--mg-primary);
    border-color: var(--mg-primary);
}

.btn-primary:hover {
    background-color: #2684ff;
    border-color: #2684ff;
}

.btn-success {
    background-color: var(--mg-success);
    border-color: var(--mg-success);
}

.btn-danger {
    background-color: var(--mg-danger);
    border-color: var(--mg-danger);
}

.btn-light-primary { background-color: var(--mg-primary-light); color: var(--mg-primary); border: none; }
.btn-light-success { background-color: var(--mg-success-light); color: var(--mg-success); border: none; }
.btn-light-warning { background-color: var(--mg-warning-light); color: var(--mg-warning); border: none; }
.btn-light-danger { background-color: var(--mg-danger-light); color: var(--mg-danger); border: none; }

.btn-light-primary:hover { background-color: var(--mg-primary); color: #fff; }
.btn-light-success:hover { background-color: var(--mg-success); color: #fff; }
.btn-light-warning:hover { background-color: var(--mg-warning); color: #fff; }
.btn-light-danger:hover { background-color: var(--mg-danger); color: #fff; }

/* ---- Icon Buttons ---- */
.btn-icon {
    width: 35px;
    height: 35px;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.5rem;
    min-height: 35px;
}

/* ---- Font Sizes ---- */
.fs-7 { font-size: 0.85rem; }
.fs-2x { font-size: 1.75rem; }

/* ---- Required Label ---- */
.required:after { content: " *"; color: var(--mg-danger); }

/* ---- Tab Styling ---- */
.nav-tabs-line .nav-link {
    border: none;
    border-bottom: 3px solid transparent;
    padding: 1rem 1.5rem;
    font-weight: 500;
    color: var(--mg-gray-500);
}

.nav-tabs-line .nav-link.active {
    border-bottom-color: var(--mg-primary);
    color: var(--mg-primary);
}

.nav-tabs-line .nav-link:hover {
    color: var(--mg-primary);
}

/* ---- Symbol (avatar container) ---- */
.symbol {
    display: inline-block;
    flex-shrink: 0;
    position: relative;
    border-radius: 0.475rem;
}

.symbol-label {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.symbol-45px .symbol-label {
    width: 45px;
    height: 45px;
}

/* ---- Border Dashed ---- */
.border-dashed { border-style: dashed !important; }

/* ---- Hide Footer in Dashboard ---- */
.mg-dashboard footer.footer { display: none !important; }

/* ---- Sidebar Overlay for mobile ---- */
.mg-sidebar-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.4);
    z-index: 1035;
}

/* =============================================
   Responsive: Mobile First (iPhone 12+: 390px)
   ============================================= */

/* --- Mobile (< 576px) --- */
@media (max-width: 575.98px) {
    /* Touch-friendly tap targets */
    .btn { min-height: 44px; }
    .form-control, .form-select { min-height: 44px; font-size: 16px !important; }

    /* Topbar compact */
    .mg-topbar {
        height: 52px;
        padding: 0 0.75rem;
    }

    .mg-topbar-left h5 {
        font-size: 0.95rem;
    }

    .mg-topbar-left small {
        font-size: 0.7rem;
    }

    .mg-topbar-right {
        gap: 0.375rem;
    }

    .mg-bell, .mg-theme-btn {
        width: 36px;
        height: 36px;
    }

    .mg-topbar-right .d-md-flex { display: none !important; }

    /* Content padding */
    .mg-content {
        padding: 0.75rem;
        padding-bottom: calc(0.75rem + env(safe-area-inset-bottom, 0px));
    }

    /* Cards compact */
    .mg-card .card-body {
        padding: 0.875rem;
    }

    .mg-card .card-header {
        padding: 0.75rem 0.875rem;
    }

    .mg-card .card-header h5 {
        font-size: 0.9rem;
    }

    /* Stat cards compact */
    .mg-stat-card {
        padding: 0.75rem;
    }

    .mg-stat-card .stat-label {
        font-size: 0.7rem;
        margin-bottom: 0.2rem;
    }

    .mg-stat-card .stat-value {
        font-size: 1.2rem;
    }

    .mg-stat-card .stat-icon {
        width: 34px;
        height: 34px;
        font-size: 0.95rem;
        border-radius: 0.5rem;
    }

    /* Inventory cards mobile */
    .inv-card { padding: 0.75rem; }
    .inv-card-name { font-size: 0.8rem; }
    .inv-card-stock { font-size: 1.4rem; }
    .inv-arrow { width: 32px; height: 32px; font-size: 0.85rem; }
    .inv-card-actions { opacity: 1; }

    /* Gradient card values */
    .fs-2x {
        font-size: 1.3rem;
    }

    .fs-3 {
        font-size: 1.1rem !important;
    }

    /* Buttons compact */
    .btn {
        font-size: 0.8125rem;
        padding: 0.5rem 0.75rem;
    }

    .btn-lg {
        font-size: 0.875rem;
        padding: 0.5rem 0.875rem;
    }

    .btn-sm {
        font-size: 0.75rem;
        padding: 0.35rem 0.5rem;
        min-height: 36px;
    }

    .btn-icon {
        width: 38px;
        height: 38px;
        min-height: 38px;
    }

    /* ---- DataTables Mobile ---- */
    .dataTables_wrapper {
        font-size: 0.8125rem;
    }

    /* Hide length selector */
    .dataTables_wrapper .dt-length,
    .dataTables_wrapper .dataTables_length {
        display: none !important;
    }

    /* Full-width search */
    .dataTables_wrapper .dt-search,
    .dataTables_wrapper .dataTables_filter {
        width: 100% !important;
        text-align: left !important;
        float: none !important;
        margin-bottom: 0.75rem;
    }

    .dataTables_wrapper .dt-search input,
    .dataTables_wrapper .dataTables_filter input {
        width: 100% !important;
        max-width: 100% !important;
        margin-left: 0 !important;
        min-height: 40px;
        font-size: 14px !important;
        border-radius: 0.5rem;
    }

    .dataTables_wrapper .dt-search label,
    .dataTables_wrapper .dataTables_filter label {
        width: 100%;
        display: flex;
        flex-direction: column;
        gap: 0.25rem;
    }

    /* Compact table cells */
    .table {
        font-size: 0.8125rem;
    }

    .table > :not(caption) > * > * {
        padding: 0.5rem 0.35rem;
    }

    .table thead th {
        font-size: 0.7rem;
        text-transform: uppercase;
        letter-spacing: 0.025em;
        white-space: nowrap;
    }

    /* ---- Hide non-essential columns ---- */
    /* Clientes: hide Precio(2), Fecha Inicio(3), Vencimiento(4) */
    #clientesTable th:nth-child(2),
    #clientesTable td:nth-child(2),
    #clientesTable th:nth-child(3),
    #clientesTable td:nth-child(3),
    #clientesTable th:nth-child(4),
    #clientesTable td:nth-child(4) {
        display: none !important;
    }

    /* Logs: hide Cliente(2) */
    #logsTable th:nth-child(2),
    #logsTable td:nth-child(2) {
        display: none !important;
    }

    /* Usuarios diarios: hide Fecha(3) */
    #tablaUsuariosDiarios th:nth-child(3),
    #tablaUsuariosDiarios td:nth-child(3) {
        display: none !important;
    }

    /* Admin negociosTable: hide Dueño(2), Contacto(3), Estado(5), Tipo(6), Fecha(7) */
    #negociosTable th:nth-child(2),
    #negociosTable td:nth-child(2),
    #negociosTable th:nth-child(3),
    #negociosTable td:nth-child(3),
    #negociosTable th:nth-child(5),
    #negociosTable td:nth-child(5),
    #negociosTable th:nth-child(6),
    #negociosTable td:nth-child(6),
    #negociosTable th:nth-child(7),
    #negociosTable td:nth-child(7) {
        display: none !important;
    }

    /* Admin table: compact negocio name cell */
    #negociosTable .symbol-45px {
        display: none !important;
    }

    /* Admin table: stack action buttons */
    #negociosTable .d-flex.justify-content-end {
        flex-wrap: wrap;
        gap: 0.25rem !important;
        justify-content: flex-start !important;
    }

    #negociosTable .btn-icon {
        width: 34px;
        height: 34px;
        min-height: 34px;
    }

    /* Pagination compact + centered */
    .dataTables_wrapper .dt-paging,
    .dataTables_wrapper .dataTables_paginate {
        margin-top: 0.75rem;
        text-align: center !important;
        float: none !important;
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        gap: 0.25rem;
    }

    .dataTables_wrapper .dt-paging button,
    .dataTables_wrapper .dataTables_paginate .paginate_button {
        padding: 0.35rem 0.6rem !important;
        font-size: 0.8125rem !important;
        min-width: 36px;
        min-height: 36px;
        border-radius: 0.375rem !important;
    }

    .dataTables_wrapper .dt-info,
    .dataTables_wrapper .dataTables_info {
        font-size: 0.75rem;
        text-align: center !important;
        float: none !important;
        padding-top: 0.5rem;
    }

    /* DT layout rows stack */
    .dataTables_wrapper .dt-layout-row {
        flex-direction: column !important;
        gap: 0.5rem;
    }

    .dataTables_wrapper .dt-layout-cell {
        width: 100% !important;
        justify-content: center !important;
    }

    /* ---- Resumen tab mobile ---- */
    #resumenTab > .d-flex:first-child {
        flex-direction: column;
        gap: 0.75rem;
    }

    #resumenTab h3 {
        font-size: 1.15rem;
    }

    #resumenTab .card-body {
        padding: 0.75rem;
    }

    #resumenTab .card-body .opacity-75.small {
        font-size: 0.7rem;
    }

    /* Próximos a vencer */
    #proximosVencerList > div {
        padding: 0.5rem 0.75rem !important;
    }

    #proximosVencerList .fw-semibold {
        font-size: 0.8125rem;
    }

    /* ---- Clientes tab mobile ---- */
    #clientesTab > .d-flex.flex-wrap {
        width: 100%;
    }

    #clientesTab > .d-flex.flex-wrap .btn {
        flex: 1;
        font-size: 0.75rem;
        padding: 0.5rem 0.375rem;
        white-space: nowrap;
    }

    /* ---- Logs form mobile ---- */
    #logsTab .row.g-3.align-items-end {
        gap: 0.5rem !important;
    }

    #logsTab .form-control-lg {
        font-size: 0.875rem !important;
        min-height: 44px;
    }

    /* Logs info bar */
    #logsTab > .d-flex.flex-wrap {
        flex-direction: column;
        gap: 0.5rem !important;
    }

    #logsTab > .d-flex.flex-wrap .ms-auto {
        margin-left: 0 !important;
        width: 100%;
    }

    #logsTab > .d-flex.flex-wrap .ms-auto .btn {
        flex: 1;
    }

    /* ---- Ventas tab mobile ---- */
    #ventasTab .row.g-3.mb-4 .col-md-4 {
        flex: 0 0 100%;
        max-width: 100%;
    }

    #ventasTab .card-body.text-center i.fs-1 {
        font-size: 1.5rem !important;
        margin-bottom: 0.25rem !important;
    }

    #ventasTab .card-body.text-center h6 {
        font-size: 0.75rem;
        margin-bottom: 0.25rem;
    }

    /* Charts smaller on mobile */
    #chartBarVentas, #chartClientes, #chartResumen, #chartResumenOverview {
        min-height: 220px !important;
    }

    /* ---- Notificaciones mobile ---- */
    #notificacionesTab > .d-flex {
        flex-direction: column;
        gap: 0.75rem !important;
        align-items: stretch !important;
    }

    #notificacionesTab > .d-flex h4 {
        font-size: 1.1rem;
    }

    #notificacionesTab > .d-flex > .d-flex.gap-2 {
        width: 100%;
    }

    #notificacionesTab > .d-flex > .d-flex.gap-2 .btn {
        flex: 1;
        font-size: 0.75rem;
        padding: 0.5rem;
    }

    /* Notification card compact */
    #notificacionesList .mg-card {
        padding: 0.625rem !important;
    }

    #notificacionesList .stat-icon {
        width: 32px !important;
        height: 32px !important;
        min-width: 32px !important;
    }

    /* ---- Modals fullscreen on mobile ---- */
    .modal-dialog {
        max-width: 100%;
        margin: 0;
    }

    .modal-content {
        border-radius: 0;
        min-height: 100vh;
    }

    .modal-header h3 {
        font-size: 1.1rem;
    }

    .modal-body .row .col-md-6,
    .modal-body .row .col-md-4 {
        flex: 0 0 100%;
        max-width: 100%;
    }

    /* ---- Landing page mobile fixes (375px) ---- */
    /* Stats cards in hero: prevent cramping */
    .hero-gradient .col-4 .card {
        padding: 0.5rem 0.25rem !important;
    }

    .hero-gradient .col-4 .fs-2 {
        font-size: 1.1rem !important;
    }

    .hero-gradient .col-4 .small {
        font-size: 0.7rem;
    }

    .hero-gradient .col-4 i.fs-2 {
        font-size: 1.25rem !important;
        margin-bottom: 0.25rem !important;
    }

    /* Floating buttons: avoid overlap on 375px */
    #btnWhatsApp {
        width: 48px !important;
        height: 48px !important;
        right: 14px !important;
        bottom: 72px !important;
    }

    #btnTop {
        width: 40px !important;
        height: 40px !important;
        right: 14px !important;
        bottom: 14px !important;
    }

    /* ---- Create.cshtml mobile ---- */
    .container-fluid.px-5 {
        padding-left: 0.75rem !important;
        padding-right: 0.75rem !important;
    }

    /* Radio buttons: stack vertically */
    .d-flex.gap-4 .form-check {
        flex: 0 0 100%;
    }

    .d-flex.gap-4 {
        flex-wrap: wrap;
        gap: 0.75rem !important;
    }

    /* ---- Admin table touch targets ---- */
    #negociosTable .btn-icon {
        width: 38px;
        height: 38px;
        min-height: 38px;
    }

    /* ---- WhatsApp diarios modal mobile ---- */
    #whatsappDiariosModal .modal-body {
        padding: 1rem;
    }

    #whatsappDiariosModal .btn-lg {
        font-size: 0.9rem;
        padding: 0.75rem 1rem;
    }

    /* ---- Ventas admin tab stat cards ---- */
    #ventasTab .col-6 {
        padding-left: 0.375rem;
        padding-right: 0.375rem;
    }

    /* SweetAlert mobile */
    .mg-swal-popup {
        padding: 1.25rem !important;
        width: calc(100vw - 2rem) !important;
        max-width: calc(100vw - 2rem) !important;
    }

    .mg-swal-popup .swal2-title {
        font-size: 1.1rem !important;
    }

    .mg-swal-popup .swal2-html-container {
        font-size: 0.85rem !important;
    }

    /* ---- Landing page mobile ---- */
    .hero-gradient {
        min-height: auto !important;
    }

    .hero-gradient .container {
        padding-top: 4rem !important;
        padding-bottom: 5rem !important;
    }

    .hero-gradient .display-2 {
        font-size: 1.75rem !important;
    }

    .hero-gradient .fs-4 {
        font-size: 1rem !important;
    }

    .hero-gradient .btn-lg {
        font-size: 0.875rem;
        padding: 0.625rem 1.25rem;
    }

    .hero-gradient .fs-2 {
        font-size: 1.25rem !important;
    }

    /* Landing sections compact */
    .py-7 {
        padding-top: 3rem !important;
        padding-bottom: 3rem !important;
    }

    .py-6 {
        padding-top: 2.5rem !important;
        padding-bottom: 2.5rem !important;
    }

    .display-4 {
        font-size: 1.5rem !important;
    }

    .display-5 {
        font-size: 1.35rem !important;
    }

    .display-6 {
        font-size: 1.2rem !important;
    }

    /* Pricing cards mobile: remove scale on popular plan */
    #planes .card[style*="scale"] {
        transform: none !important;
    }

    #planes .card-body {
        padding: 1.25rem !important;
    }

    /* Pricing card compact */
    .display-3 {
        font-size: 2rem !important;
    }

    /* Accordion mobile */
    .accordion-button {
        font-size: 0.875rem;
        padding: 0.875rem 1rem;
    }

    .accordion-body {
        font-size: 0.8125rem;
        padding: 0.75rem 1rem;
    }

    /* Back to top - smaller on mobile */
    #btnTop {
        width: 44px !important;
        height: 44px !important;
        right: 12px !important;
        bottom: 12px !important;
    }

    /* Safe area (notch phones) */
    .mg-sidebar {
        padding-bottom: env(safe-area-inset-bottom, 0px);
    }

    /* Import zone compact */
    #importZone .card-body {
        padding: 1.5rem 1rem !important;
    }

    #importZone h5 {
        font-size: 0.95rem;
    }

    /* Table responsive - prevent double scroll */
    .table-responsive {
        -webkit-overflow-scrolling: touch;
    }
}

/* --- Tablet & Mobile: sidebar off-canvas --- */
@media (max-width: 991.98px) {
    .mg-sidebar {
        transform: translateX(-100%);
    }

    .mg-sidebar.show {
        transform: translateX(0);
    }

    .mg-sidebar-overlay.show {
        display: block;
    }

    .mg-topbar {
        margin-left: 0;
    }

    .mg-content {
        margin-left: 0;
    }

    .mg-hamburger {
        display: block;
    }

    .mg-notification-dropdown {
        width: 100vw;
        max-width: 100vw;
        position: fixed !important;
        left: 0 !important;
        right: 0 !important;
        top: var(--mg-topbar-height) !important;
        border-radius: 0;
        transform: none !important;
    }
}

/* --- Tablet portrait (576px - 767px) --- */
@media (min-width: 576px) and (max-width: 767.98px) {
    .btn { min-height: 44px; }
    .form-control { min-height: 44px; }

    .mg-content {
        padding: 1rem;
    }

    .mg-stat-card .stat-value {
        font-size: 1.5rem;
    }

    .fs-2x {
        font-size: 1.5rem;
    }

    .table {
        font-size: 0.875rem;
    }

    /* Hide some columns on tablet portrait */
    #clientesTable th:nth-child(3),
    #clientesTable td:nth-child(3) {
        display: none !important;
    }

    /* Admin table: hide Contacto(3), Tipo(6), Fecha(7) on tablet */
    #negociosTable th:nth-child(3),
    #negociosTable td:nth-child(3),
    #negociosTable th:nth-child(6),
    #negociosTable td:nth-child(6),
    #negociosTable th:nth-child(7),
    #negociosTable td:nth-child(7) {
        display: none !important;
    }

    /* Modals: restore non-fullscreen */
    .modal-dialog {
        max-width: 500px;
        margin: 1.75rem auto;
    }

    .modal-lg {
        max-width: 800px;
    }

    .modal-content {
        border-radius: var(--mg-border-radius);
        min-height: auto;
    }
}

/* --- Tablet landscape+ (768px+): restore modal --- */
@media (min-width: 768px) {
    .modal-dialog {
        max-width: 500px;
        margin: 1.75rem auto;
    }

    .modal-lg {
        max-width: 800px;
    }

    .modal-content {
        border-radius: var(--mg-border-radius);
        min-height: auto;
    }
}

/* --- Desktop (992px+): sidebar visible --- */
@media (min-width: 992px) {
    .mg-sidebar {
        transform: translateX(0);
    }

    .mg-hamburger {
        display: none;
    }
}

/* ---- Period Pill Tabs ---- */
.mg-period-pills {
    display: inline-flex;
    background: var(--mg-gray-200);
    border-radius: 0.5rem;
    padding: 3px;
    gap: 2px;
}

.mg-period-pills .mg-pill {
    padding: 0.4rem 1rem;
    border: none;
    background: transparent;
    color: var(--mg-gray-600);
    font-weight: 600;
    font-size: 0.825rem;
    border-radius: 0.4rem;
    cursor: pointer;
    transition: all 0.2s ease;
    white-space: nowrap;
}

.mg-period-pills .mg-pill:hover {
    color: var(--mg-gray-800);
}

.mg-period-pills .mg-pill.active {
    background: var(--mg-card-bg);
    color: var(--mg-primary);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.08);
}

@media (max-width: 575.98px) {
    .mg-period-pills {
        width: 100%;
    }
    .mg-period-pills .mg-pill {
        flex: 1;
        text-align: center;
        padding: 0.5rem 0.25rem;
        font-size: 0.75rem;
        min-height: 38px;
        display: flex;
        align-items: center;
        justify-content: center;
    }
}

/* ---- Impersonation Banner ---- */
.mg-impersonation-banner {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1060;
    background: linear-gradient(135deg, #FFC700 0%, #ff9800 100%);
    color: #000;
    padding: 0.5rem 1rem;
    text-align: center;
    font-weight: 600;
    font-size: 0.875rem;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.is-impersonating .mg-sidebar { top: 42px; }
.is-impersonating .mg-topbar { top: 42px; }
.is-impersonating .mg-content { padding-top: calc(var(--mg-topbar-height) + 42px); }
@media (max-width: 991.98px) {
    .is-impersonating .mg-sidebar { top: 42px; }
    .is-impersonating .mg-content { padding-top: calc(var(--mg-topbar-height) + 42px); }
}

/* ---- SweetAlert2 Metronic Theme ---- */
.mg-swal-popup {
    font-family: var(--mg-font-family) !important;
    border-radius: var(--mg-border-radius) !important;
    padding: 2rem !important;
}

.mg-swal-popup .swal2-title {
    font-weight: 700 !important;
    color: var(--mg-dark) !important;
    font-size: 1.25rem !important;
}

.mg-swal-popup .swal2-html-container {
    color: var(--mg-gray-600) !important;
    font-size: 0.925rem !important;
}

.mg-swal-confirm {
    border-radius: 0.5rem !important;
    font-weight: 600 !important;
    padding: 0.6rem 1.5rem !important;
    font-size: 0.9rem !important;
}

.mg-swal-cancel {
    border-radius: 0.5rem !important;
    font-weight: 600 !important;
    padding: 0.6rem 1.5rem !important;
    font-size: 0.9rem !important;
    color: var(--mg-gray-700) !important;
}

/* ---- Form Check Custom (Radio Cards) ---- */
.form-check-custom .form-check-input {
    width: 2.75rem;
    height: 1.5rem;
}

/* ---- Theme Switcher ---- */
.mg-theme-btn {
    position: relative;
    background: var(--mg-gray-100);
    border: none;
    border-radius: 0.5rem;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s;
    color: var(--mg-text-color);
}

.mg-theme-btn:hover {
    background: var(--mg-gray-200);
}

.mg-theme-dropdown {
    min-width: 180px;
    border: none;
    box-shadow: 0 0 50px rgba(0, 0, 0, 0.15);
    border-radius: var(--mg-border-radius);
    padding: 0.5rem;
    background: var(--mg-card-bg);
}

.mg-theme-option {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.5rem 0.75rem;
    border-radius: 0.5rem;
    cursor: pointer;
    transition: background 0.2s;
    border: none;
    background: transparent;
    width: 100%;
    color: var(--mg-text-color);
    font-size: 0.9rem;
    font-weight: 500;
}

.mg-theme-option:hover {
    background: var(--mg-gray-100);
}

.mg-theme-option.active {
    background: var(--mg-primary-light);
    color: var(--mg-primary);
}

.mg-theme-option .theme-swatch {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    border: 2px solid var(--mg-border-color);
    flex-shrink: 0;
}

.mg-theme-option .bi-check2 {
    margin-left: auto;
    font-size: 1.1rem;
}

/* ---- Dark Mode Overrides ---- */
[data-theme="dark"] .table {
    --bs-table-color: var(--mg-text-color);
    --bs-table-bg: transparent;
    --bs-table-border-color: var(--mg-border-color);
    --bs-table-striped-color: var(--mg-text-color);
    --bs-table-hover-color: var(--mg-text-color);
    --bs-table-hover-bg: rgba(255, 255, 255, 0.05);
    color: var(--mg-text-color);
}

[data-theme="dark"] .form-control {
    background-color: var(--mg-gray-200);
    border-color: var(--mg-gray-300);
    color: var(--mg-text-color);
}

[data-theme="dark"] .form-control:focus {
    background-color: var(--mg-gray-200);
    border-color: var(--mg-primary);
    color: var(--mg-text-color);
}

[data-theme="dark"] .form-control::placeholder {
    color: var(--mg-gray-500);
}

[data-theme="dark"] .modal-content {
    background-color: var(--mg-card-bg);
    color: var(--mg-text-color);
}

[data-theme="dark"] .modal-header {
    background-color: var(--mg-gray-200) !important;
    border-bottom-color: var(--mg-border-color);
}

[data-theme="dark"] .modal-footer {
    background-color: var(--mg-gray-200) !important;
    border-top-color: var(--mg-border-color);
}

[data-theme="dark"] .btn-close {
    filter: invert(1);
}

[data-theme="dark"] .dropdown-menu {
    background-color: var(--mg-card-bg);
    border-color: var(--mg-border-color);
}

[data-theme="dark"] .text-muted {
    color: var(--mg-text-muted) !important;
}

[data-theme="dark"] .bg-light {
    background-color: var(--mg-gray-200) !important;
}

[data-theme="dark"] .form-label {
    color: var(--mg-text-color);
}

[data-theme="dark"] .form-check-label {
    color: var(--mg-text-color);
}

[data-theme="dark"] .card-header.bg-white {
    background-color: var(--mg-card-bg) !important;
}

[data-theme="dark"] .fw-bold, [data-theme="dark"] h5, [data-theme="dark"] h4, [data-theme="dark"] h3 {
    color: var(--mg-text-color);
}

[data-theme="dark"] .mg-swal-popup {
    background-color: var(--mg-card-bg) !important;
}

[data-theme="dark"] .mg-swal-popup .swal2-title {
    color: var(--mg-text-color) !important;
}

[data-theme="dark"] .mg-swal-popup .swal2-html-container {
    color: var(--mg-text-muted) !important;
}

[data-theme="dark"] .dataTables_wrapper .dataTables_info,
[data-theme="dark"] .dataTables_wrapper .dataTables_length label,
[data-theme="dark"] .dataTables_wrapper .dataTables_filter label {
    color: var(--mg-text-muted);
}

[data-theme="dark"] .dataTables_wrapper .dataTables_paginate .paginate_button {
    color: var(--mg-text-color) !important;
}

[data-theme="dark"] .dataTables_wrapper select,
[data-theme="dark"] .dataTables_wrapper input[type="search"] {
    background-color: var(--mg-gray-200);
    border-color: var(--mg-gray-300);
    color: var(--mg-text-color);
}
