/* Desktop optimizado */
@media (min-width: 1025px) {
    #mesa-modal .modal-content {
        margin: 2.5vh auto;
        height: 94vh;
        max-height: 94vh;
        width: min(1680px, 97vw);
        max-width: 1680px;
        border-radius: 20px;
        display: flex;
        flex-direction: column;
        overflow: hidden;
        background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
    }

    #mesa-modal .modal-header {
        padding: 16px 22px;
        border-bottom: 1px solid rgba(148, 163, 184, 0.26);
        background: rgba(255, 255, 255, 0.92);
        backdrop-filter: blur(10px);
    }

    #mesa-modal .mesa-header-info {
        display: flex;
        align-items: center;
        gap: 10px;
        min-width: 0;
    }

    #mesa-modal .mesa-header-copy {
        display: grid;
        gap: 8px;
        min-width: 0;
    }

    #mesa-modal .mesa-header-info h2 {
        margin: 0;
        display: flex;
        align-items: center;
        gap: 8px;
        min-width: 0;
        font-size: 1.1rem;
        letter-spacing: 0.01em;
    }

    #mesa-modal .mesa-etiqueta-display {
        background: rgba(var(--primary-rgb), 0.1);
        color: var(--primary-color);
        font-size: 0.74rem;
        font-weight: 600;
        padding: 5px 10px;
    }

    #mesa-modal .mesa-mobile-status-chip {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 5px 11px;
        border-radius: 999px;
        font-size: 0.68rem;
        letter-spacing: 0.06em;
        font-weight: 700;
        text-transform: uppercase;
        background: rgba(47, 185, 119, 0.14);
        color: #1e8a57;
    }

    #mesa-modal .mesa-mobile-status-chip.ocupada {
        background: rgba(224, 88, 88, 0.14);
        color: #b73c3c;
    }

    #mesa-modal .mesa-header-stats {
        display: flex;
        align-items: center;
        gap: 8px;
        flex-wrap: wrap;
    }

    #mesa-modal .mesa-header-chip {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-height: 28px;
        padding: 4px 10px;
        border-radius: 999px;
        border: 1px solid rgba(148, 163, 184, 0.26);
        background: rgba(248, 250, 252, 0.92);
        color: #475569;
        font-size: 0.74rem;
        font-weight: 700;
        letter-spacing: 0.04em;
        white-space: nowrap;
    }

    #mesa-modal .mesa-header-chip--total {
        background: rgba(var(--primary-rgb), 0.1);
        border-color: rgba(var(--primary-rgb), 0.18);
        color: var(--primary-color-dark);
    }

    #mesa-modal .modal-body {
        padding: 0;
        gap: 0;
        min-height: 0;
        max-height: none;
        overflow: hidden;
        background: transparent;
    }

    #mesa-modal .modal-footer {
        display: none;
    }

    #mesa-modal .modal-body-grid {
        flex: 1 1 auto;
        min-height: 0;
        display: grid;
        grid-template-columns: minmax(0, 1fr) 400px;
        gap: 18px;
        padding: 18px;
        overflow: hidden;
    }

    #mesa-modal .modal-column-seleccion {
        min-width: 0;
        min-height: 0;
        display: flex;
        flex-direction: column;
        overflow: hidden;
        border: 1px solid rgba(226, 232, 240, 0.95);
        border-radius: 16px;
        background: rgba(255, 255, 255, 0.92);
        box-shadow: 0 8px 24px -20px rgba(15, 23, 42, 0.4);
    }

    #mesa-modal .modal-column-seleccion .modal-body {
        flex: 1 1 auto;
        min-height: 0;
        display: flex;
        flex-direction: column;
        gap: 10px;
        background: transparent;
        overflow: hidden;
        padding: 0;
    }

    #mesa-modal .top-controls {
        margin: 0;
        padding: 12px 16px 10px;
        border: none;
        border-bottom: 1px solid rgba(226, 232, 240, 0.9);
        border-radius: 0;
        box-shadow: none;
        background: transparent;
        display: flex;
        align-items: center;
        gap: 10px;
    }

    #mesa-modal .search-container {
        flex: 1 1 auto;
        position: relative;
        min-width: 0;
    }

    #mesa-modal #buscador-articulos {
        width: 100%;
        height: 42px;
        padding: 10px 38px 10px 38px;
        border-radius: 11px;
        border: 1px solid #d4dde8;
        background: #ffffff;
        box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.06);
        font-size: 0.92rem;
    }

    #mesa-modal #buscador-articulos:focus {
        border-color: rgba(var(--primary-rgb), 0.56);
        box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.14);
    }

    #mesa-modal .search-clear {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        position: absolute;
        top: 50%;
        right: 8px;
        transform: translateY(-50%);
        width: 26px;
        height: 26px;
        border-radius: 999px;
        border: none;
        background: #edf2f7;
        color: #475569;
        cursor: pointer;
        transition: background-color var(--transition-fast), color var(--transition-fast);
    }

    #mesa-modal #buscador-articulos:placeholder-shown ~ .search-clear {
        opacity: 0;
        pointer-events: none;
    }

    #mesa-modal .search-clear:hover {
        background: #dbe4ee;
        color: #1f2937;
    }

    #mesa-modal .tag-button {
        width: auto;
        min-width: 42px;
        height: 42px;
        border-radius: 11px;
        border: 1px solid #d4dde8;
        background: #ffffff;
        color: var(--primary-color);
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
        padding: 0 12px;
    }

    #mesa-modal .tag-button:hover {
        background: rgba(var(--primary-rgb), 0.08);
        border-color: rgba(var(--primary-rgb), 0.25);
    }

    #mesa-modal .tag-button-label {
        font-size: 0.78rem;
        font-weight: 700;
        letter-spacing: 0.02em;
    }

    #mesa-modal .etiqueta-mesa-container {
        margin: 0 16px;
        padding: 10px 12px;
        border-radius: 12px;
        border: 1px solid rgba(148, 163, 184, 0.3);
        background: rgba(248, 250, 252, 0.9);
    }

    #mesa-modal .etiqueta-mesa-container label {
        color: #64748b;
        font-size: 0.78rem;
        margin: 0;
    }

    #mesa-modal .etiqueta-mesa-container input {
        height: 36px;
        border-radius: 8px;
        border: 1px solid #d4dde8;
        padding: 0 10px;
        background: #ffffff;
    }

    #mesa-modal .etiqueta-mesa-container .btn-sm {
        height: 36px;
        padding: 0 12px;
    }

    #mesa-modal .categorias-section {
        flex: 0 0 auto;
        padding: 0 16px;
    }

    #mesa-modal .categorias-container {
        margin: 0;
        padding: 2px 0 8px;
        display: flex;
        gap: 10px;
        overflow-x: auto;
        overflow-y: hidden;
        align-items: center;
        scrollbar-gutter: stable;
        border: none;
        background: transparent;
    }

    #mesa-modal .categorias-container::-webkit-scrollbar {
        height: 6px;
    }

    #mesa-modal .categorias-container::-webkit-scrollbar-thumb {
        background: rgba(148, 163, 184, 0.46);
        border-radius: 999px;
    }

    #mesa-modal .category-button {
        flex: 0 0 auto;
        width: auto;
        min-width: max-content;
        min-height: 40px;
        height: 40px;
        padding: 0 16px;
        border-radius: 999px;
        background: #ffffff;
        color: #475569;
        border: 1px solid #d9e1ea;
        box-shadow: none;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
        white-space: nowrap;
        position: relative;
    }

    #mesa-modal .category-button:hover {
        background: #f1f5f9;
        color: #1f2937;
        border-color: #cbd5e1;
    }

    #mesa-modal .category-button.active {
        background: linear-gradient(135deg, var(--primary-color), var(--primary-color-light));
        border-color: transparent;
        color: #ffffff;
        box-shadow: 0 8px 14px -8px rgba(var(--primary-rgb), 0.55);
    }

    #mesa-modal .category-button .icon {
        display: inline-flex;
        font-size: 0.95rem;
    }

    #mesa-modal .category-button .category-name {
        font-size: 0.84rem;
        font-weight: 600;
    }

    #mesa-modal .category-button .category-count {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-width: 22px;
        height: 22px;
        padding: 0 6px;
        border-radius: 999px;
        background: rgba(71, 85, 105, 0.1);
        color: #64748b;
        font-size: 0.72rem;
        font-weight: 700;
        letter-spacing: 0;
    }

    #mesa-modal .category-button.active .category-count {
        background: rgba(255, 255, 255, 0.18);
        color: #ffffff;
    }

    #mesa-modal .category-button--empty .category-count {
        background: rgba(148, 163, 184, 0.14);
        color: #94a3b8;
    }

    #mesa-modal .articulos-section {
        flex: 1 1 auto;
        min-height: 0;
        overflow: hidden;
        display: flex;
        flex-direction: column;
        padding: 0 16px 16px;
    }

    #mesa-modal .articulos-container {
        flex: 1 1 auto;
        min-height: 0;
        margin-top: 2px;
        padding: 4px 2px 6px;
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
        gap: 12px;
        overflow-y: auto;
        max-height: none;
        border: none;
        background: transparent;
        scrollbar-gutter: stable;
    }

    #mesa-modal .articulos-container.articulos-container--sparse {
        grid-template-columns: repeat(auto-fit, minmax(280px, 340px));
        justify-content: center;
    }

    #mesa-modal .articulos-container.articulos-container--single {
        grid-template-columns: minmax(320px, 420px);
        justify-content: center;
    }

    #mesa-modal .articulos-container::-webkit-scrollbar {
        width: 8px;
    }

    #mesa-modal .articulos-container::-webkit-scrollbar-thumb {
        background: rgba(148, 163, 184, 0.45);
        border-radius: 999px;
    }

    #mesa-modal .articulo-btn {
        min-height: 112px;
        border-radius: 14px;
        border: 1px solid #e2e8f0;
        background: #ffffff;
        box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
        padding: 14px 14px 12px;
        display: flex;
        align-items: center;
        gap: 10px;
        transition: transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);
        cursor: pointer;
        width: 100%;
        justify-self: stretch;
    }

    #mesa-modal .articulo-btn:hover {
        transform: translateY(-2px);
        border-color: rgba(var(--primary-rgb), 0.3);
        box-shadow: 0 12px 18px -14px rgba(15, 23, 42, 0.45);
    }

    #mesa-modal .articulo-btn:focus-visible {
        outline: none;
        border-color: rgba(var(--primary-rgb), 0.6);
        box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.14);
    }

    #mesa-modal .articulo-btn:active {
        transform: scale(0.985);
    }

    #mesa-modal .articulo-btn-leading {
        display: none;
    }

    #mesa-modal .articulo-btn-body {
        flex: 1 1 auto;
        min-width: 0;
        display: flex;
        flex-direction: column;
        gap: 4px;
    }

    #mesa-modal .articulo-nombre {
        margin: 0;
        font-size: 0.92rem;
        font-weight: 600;
        color: #0f172a;
        line-height: 1.25;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    #mesa-modal .articulo-meta {
        font-size: 0.74rem;
        color: #64748b;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    #mesa-modal .articulo-btn-side {
        margin-left: 0;
        min-width: 74px;
        display: flex;
        flex-direction: column;
        align-items: flex-end;
        gap: 6px;
    }

    #mesa-modal .articulo-btn-price {
        align-self: flex-start;
        padding: 4px 8px;
        border-radius: 8px;
        background: rgba(var(--primary-rgb), 0.09);
        color: var(--primary-color-dark);
        font-size: 0.78rem;
        font-weight: 700;
    }

    #mesa-modal .articulo-add-control {
        width: 38px;
        height: 38px;
        border-radius: 12px;
        font-size: 1.05rem;
        box-shadow: 0 8px 14px -10px rgba(var(--primary-rgb), 0.5);
    }

    #mesa-modal .articulo-option-icon {
        top: 10px;
        right: 10px;
        font-size: 0.82rem;
        opacity: 0.62;
    }
}
