/* ── MenuPlay — Kitchen Display ─────────────────────────────────────────── */
:root {
    --k-bg:      #0A0A0A;
    --k-surface: #141414;
    --k-card:    #1A1A1A;
    --k-gold:    #E8A020;
    --k-green:   #4caf50;
    --k-orange:  #FF6B35;
    --k-red:     #ef5350;
    --k-text:    #F0F0F0;
    --k-muted:   #666;
    --k-border:  rgba(255,255,255,.07);
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body.mp-kitchen-body { background: var(--k-bg); color: var(--k-text); font-family: 'Inter', -apple-system, sans-serif; min-height: 100dvh; overflow-x: hidden; }

/* ── Header ─────────────────────────────────────────────────────────────── */
.mp-kitchen-header { display: flex; align-items: center; justify-content: space-between; padding: 14px 24px; background: var(--k-surface); border-bottom: 1px solid var(--k-border); position: sticky; top: 0; z-index: 100; }
.mp-kitchen-title  { display: flex; align-items: center; gap: 12px; font-size: 20px; font-weight: 700; }
.mp-logo-small     { color: var(--k-gold); }
.mp-kitchen-restaurant { font-size: 14px; color: var(--k-muted); font-weight: 400; }
.mp-kitchen-clock  { font-size: 28px; font-weight: 700; font-variant-numeric: tabular-nums; color: var(--k-gold); letter-spacing: 2px; }

/* ── Grid de pedidos ─────────────────────────────────────────────────────── */
.mp-kitchen-orders { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 16px; padding: 20px 24px; }

.mp-loading { grid-column: 1/-1; text-align: center; padding: 60px; color: var(--k-muted); font-size: 18px; }
.mp-no-orders { grid-column: 1/-1; text-align: center; padding: 80px; color: var(--k-muted); }
.mp-no-orders-icon { font-size: 64px; margin-bottom: 16px; }
.mp-no-orders p { font-size: 20px; }

/* ── Tarjeta de pedido ───────────────────────────────────────────────────── */
.mp-k-order { background: var(--k-card); border-radius: 16px; overflow: hidden; border: 2px solid var(--k-border); transition: border-color .3s; }
.mp-k-order.status-confirmed { border-color: var(--k-gold); }
.mp-k-order.status-preparing { border-color: var(--k-orange); }
.mp-k-order.status-ready     { border-color: var(--k-green); }

.mp-k-order-header { display: flex; align-items: center; justify-content: space-between; padding: 14px 16px; border-bottom: 1px solid var(--k-border); }
.mp-k-table { font-size: 20px; font-weight: 800; }
.mp-k-timer { font-size: 13px; font-weight: 600; padding: 4px 10px; border-radius: 12px; background: rgba(255,255,255,.05); font-variant-numeric: tabular-nums; }
.mp-k-timer.urgent { background: rgba(239,83,80,.15); color: var(--k-red); }

.mp-k-status-badge { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; padding: 3px 10px; border-radius: 12px; }
.status-badge-confirmed { background: rgba(232,160,32,.15); color: var(--k-gold); }
.status-badge-preparing { background: rgba(255,107,53,.15); color: var(--k-orange); }
.status-badge-ready     { background: rgba(76,175,80,.15); color: var(--k-green); }

/* ── Ítems del pedido ────────────────────────────────────────────────────── */
.mp-k-items { padding: 12px 16px; display: flex; flex-direction: column; gap: 8px; }
.mp-k-item { display: flex; align-items: center; gap: 10px; padding: 10px 12px; background: var(--k-surface); border-radius: 10px; border: 1px solid var(--k-border); transition: background .2s; }
.mp-k-item.done { opacity: .4; }
.mp-k-item-qty  { font-size: 18px; font-weight: 800; color: var(--k-gold); min-width: 28px; }
.mp-k-item-name { flex: 1; font-size: 15px; font-weight: 600; }
.mp-k-item-note { font-size: 11px; color: var(--k-muted); margin-top: 2px; }
.mp-k-ready-btn { background: var(--k-surface); border: 1.5px solid var(--k-border); color: var(--k-muted); width: 32px; height: 32px; border-radius: 50%; cursor: pointer; font-size: 14px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: all .2s; }
.mp-k-ready-btn:hover { border-color: var(--k-green); color: var(--k-green); background: rgba(76,175,80,.1); }
.mp-k-ready-btn.done { background: rgba(76,175,80,.2); border-color: var(--k-green); color: var(--k-green); cursor: default; }

.mp-k-order-footer { padding: 12px 16px; border-top: 1px solid var(--k-border); display: flex; justify-content: space-between; align-items: center; }
.mp-k-note { font-size: 12px; color: var(--k-muted); font-style: italic; }
.mp-k-confirm-btn { background: var(--k-green); color: #000; border: none; padding: 8px 16px; border-radius: 20px; font-size: 13px; font-weight: 700; cursor: pointer; transition: opacity .2s; }
.mp-k-confirm-btn:hover { opacity: .85; }
.mp-k-confirm-btn:disabled { background: var(--k-muted); cursor: not-allowed; }

/* ── Badge nuevo pedido ─────────────────────────────────────────────────── */
@keyframes mp-slide-in { from { transform: translateY(-20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.mp-k-order.new-order { animation: mp-slide-in .4s ease; }

/* ── Overlay de alerta ────────────────────────────────────────────────────── */
@keyframes mp-pulse-border {
    0%,100% { box-shadow: 0 0 0 0 rgba(232,160,32,.6); }
    50%      { box-shadow: 0 0 0 16px rgba(232,160,32,0); }
}
@keyframes mp-shake {
    0%,100% { transform: translateX(0); }
    20%,60% { transform: translateX(-6px); }
    40%,80% { transform: translateX(6px); }
}

#mp-k-alert-overlay {
    display: none;
    position: fixed; inset: 0; z-index: 9999;
    background: rgba(0,0,0,.85);
    align-items: center; justify-content: center;
    backdrop-filter: blur(4px);
}
#mp-k-alert-overlay.active { display: flex; }

#mp-k-alert-modal {
    background: var(--k-card);
    border: 2px solid var(--k-gold);
    border-radius: 20px;
    width: min(480px, 94vw);
    padding: 28px;
    animation: mp-pulse-border 1.6s ease-in-out infinite;
}

.mp-k-alert-header {
    display: flex; align-items: center; gap: 12px;
    margin-bottom: 16px;
}
.mp-k-alert-icon { font-size: 28px; animation: mp-shake .5s ease infinite; display: inline-block; }
.mp-k-alert-tag {
    font-size: 13px; font-weight: 800; letter-spacing: 1.5px;
    color: var(--k-gold); text-transform: uppercase;
}

.mp-k-alert-table {
    font-size: 32px; font-weight: 800; margin-bottom: 14px;
    color: var(--k-text);
}

.mp-k-alert-items {
    display: flex; flex-direction: column; gap: 6px;
    margin-bottom: 12px;
}
.mp-k-al-item {
    background: var(--k-surface); border-radius: 10px;
    padding: 10px 14px; font-size: 16px;
    border: 1px solid var(--k-border);
}
.mp-k-al-qty { color: var(--k-gold); font-weight: 800; margin-right: 6px; }

.mp-k-alert-customer-note {
    font-size: 13px; color: var(--k-muted); font-style: italic;
    margin-bottom: 20px; padding: 8px 12px;
    background: rgba(255,255,255,.04); border-radius: 8px;
}

.mp-k-alert-actions {
    display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
    margin-bottom: 12px;
}
.mp-k-alert-btn {
    padding: 14px; border: none; border-radius: 12px;
    font-size: 16px; font-weight: 700; cursor: pointer;
    transition: opacity .2s;
}
.mp-k-alert-btn:hover { opacity: .85; }
.mp-k-btn-accept { background: var(--k-green); color: #000; }
.mp-k-btn-reject { background: rgba(239,83,80,.2); color: var(--k-red); border: 1.5px solid var(--k-red); }

#mp-k-reject-form {
    display: flex; flex-direction: column; gap: 8px;
    border-top: 1px solid var(--k-border); padding-top: 14px;
}
#mp-k-reject-reason {
    background: var(--k-surface); border: 1px solid var(--k-border);
    color: var(--k-text); border-radius: 10px;
    padding: 10px 14px; font-size: 14px;
    font-family: inherit;
}
#mp-k-reject-reason::placeholder { color: var(--k-muted); }
.mp-k-btn-reject-confirm {
    width: 100%;
    background: var(--k-red); color: #fff;
}
