/* ===== Carrito + checkout + mapa — Pizza Italia ===== */
.pi-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:opacity .2s;z-index:1000}
.pi-overlay.open{opacity:1;pointer-events:auto}
.pi-drawer{position:fixed;top:0;right:0;height:100vh;height:100dvh;width:min(440px,94vw);background:var(--crema);z-index:1001;transform:translateX(100%);transition:transform .25s ease;display:flex;flex-direction:column;box-shadow:-12px 0 50px rgba(0,0,0,.25)}
.pi-drawer.open{transform:translateX(0)}
.pi-drawer header{padding:18px;background:var(--rojo);color:#fff;display:flex;align-items:center;gap:10px}
.pi-drawer header h3{margin:0;font-size:1.2rem;font-weight:800}
.pi-drawer .pi-close{margin-left:auto;background:rgba(255,255,255,.2);border:0;color:#fff;font-size:1.4rem;width:36px;height:36px;border-radius:50%;cursor:pointer;line-height:1}
.pi-content{flex:1;overflow-y:auto;overscroll-behavior:contain;padding:16px 18px}
/* Con el carrito abierto, congelar el scroll del fondo (no “doble scroll” en móvil) */
body.pi-open{overflow:hidden}
.pi-foot{padding:16px 18px calc(16px + env(safe-area-inset-bottom));border-top:1px solid #ecdcc4;background:#fff}
@media(max-width:480px){ .pi-drawer{width:100vw} }

.pi-line{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid #ecdcc4;align-items:center}
.pi-line img{width:56px;height:56px;border-radius:10px;object-fit:cover;flex:none;background:#fff}
.pi-line .pi-emoji{width:56px;height:56px;border-radius:10px;display:grid;place-items:center;font-size:28px;background:#fff;flex:none}
.pi-line .pi-info{flex:1;min-width:0}
.pi-line .pi-info h4{margin:0 0 2px;font-size:.95rem;font-weight:700}
.pi-line .pi-info small{display:block;color:var(--gris);line-height:1.35}
.pi-qty{display:flex;align-items:center;gap:8px;margin-top:6px}
.pi-qty button{width:30px;height:30px;border-radius:8px;border:1px solid #e2d4bd;background:#fff;color:var(--oscuro);font-size:1.1rem;line-height:1;font-weight:800;cursor:pointer}
.pi-qty .pi-lt{margin-left:auto;font-weight:800;color:var(--rojo)}
.pi-extras{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.pi-extra{display:inline-flex;align-items:center;gap:5px;background:#fff3df;border:1px solid #ecdcc0;color:var(--oscuro);font-size:.74rem;font-weight:700;padding:3px 8px;border-radius:50px}
.pi-extra button{border:0;background:none;color:var(--rojo);font-weight:900;cursor:pointer;font-size:.95rem;line-height:1;padding:0}
.pi-addextra{margin-top:8px;background:none;border:1.5px dashed #d9b88f;color:var(--rojo-osc);font-weight:800;font-size:.78rem;padding:7px 12px;border-radius:50px;cursor:pointer;font-family:inherit}
.pi-addextra:hover{background:#fff3df}
.pi-empty{text-align:center;color:var(--gris);padding:60px 12px;line-height:1.8}
.pi-empty svg{width:54px;height:54px;fill:#e2d4bd}

.pi-srow{display:flex;justify-content:space-between;margin:6px 0;color:var(--gris);font-size:.95rem}
.pi-srow.total{color:var(--oscuro);font-weight:900;font-size:1.4rem;margin-top:8px}
/* Pie fijo del checkout compacto para dejar más área al formulario */
#piCheckoutFoot .pi-srow{margin:2px 0;font-size:.9rem}
#piCheckoutFoot .pi-srow.total{font-size:1.2rem;margin-top:4px;margin-bottom:8px}
#piCheckoutFoot .pi-btn{padding:14px}
.pi-btn{width:100%;border:0;background:var(--rojo);color:#fff;font-weight:800;font-size:1rem;padding:15px;border-radius:50px;cursor:pointer;font-family:inherit;box-shadow:0 8px 22px rgba(226,18,27,.32);transition:transform .12s}
.pi-btn:active{transform:scale(.99)}
.pi-btn:disabled{opacity:.5;box-shadow:none;cursor:default}
.pi-btn.alt{background:#fff;color:var(--rojo);border:2px solid var(--rojo);box-shadow:none;margin-top:8px}
.pi-btn svg{width:18px;height:18px;fill:currentColor;vertical-align:-3px;margin-right:6px}

.pi-field{margin:12px 0}
.pi-field label{display:block;font-size:.82rem;color:var(--gris);margin-bottom:6px;font-weight:700}
.pi-field input,.pi-field textarea{width:100%;padding:13px;border-radius:12px;border:1px solid #e2d4bd;background:#fff;color:var(--oscuro);font-size:.95rem;font-family:inherit}
.pi-field input:focus,.pi-field textarea:focus{outline:2px solid var(--amarillo);border-color:var(--amarillo)}
.pi-field textarea{resize:vertical;min-height:58px}
.pi-seg{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.pi-seg.two{grid-template-columns:1fr 1fr}
.pi-opt{border:1px solid #e2d4bd;background:#fff;color:var(--oscuro);padding:12px 6px;border-radius:12px;font-weight:800;font-size:.85rem;text-align:center;cursor:pointer;font-family:inherit}
.pi-opt .sub{display:block;font-size:.68rem;color:var(--gris);font-weight:600;margin-top:2px}
.pi-opt.on{border-color:var(--rojo);background:#fdecec;color:var(--rojo)}

#piMap{height:200px;border-radius:14px;border:1px solid #e2d4bd;margin-top:6px;z-index:0}
.pi-maphint{font-size:.78rem;color:var(--gris);margin:6px 0 0}
.pi-geo{margin-top:8px;background:var(--amarillo);color:var(--oscuro);border:0;border-radius:50px;padding:10px 14px;font-weight:800;cursor:pointer;font-family:inherit;font-size:.85rem;display:inline-flex;align-items:center;gap:6px}

.pi-back{background:none;border:0;color:var(--rojo);font-weight:800;padding:0;margin-bottom:6px;cursor:pointer;font-family:inherit;font-size:.9rem}
.pi-err{color:#c0121b;font-size:.85rem;margin:8px 0 0;font-weight:600}
.pi-minwarn{background:#fff3df;border:1px solid #e8d09a;color:#8a5a00;font-size:.82rem;font-weight:700;padding:9px 12px;border-radius:10px;margin:8px 0 0}
.pi-hidden{display:none!important}

.pi-confirm{text-align:center;padding:24px 8px}
.pi-confirm .pi-check{font-size:60px}
.pi-confirm h3{margin:8px 0 2px}
.pi-confirm .pi-num{font-size:2.2rem;font-weight:900;color:var(--rojo)}
.pi-badge{display:inline-block;padding:9px 18px;border-radius:50px;font-weight:800;margin-top:12px;border:1px solid #e2d4bd;background:#fff}
.st-pendiente{color:var(--amarillo-osc)}
.st-en_preparacion{color:#2b7fd6}
.st-listo{color:#1f9d57}
.st-entregado{color:var(--gris)}
.st-cancelado{color:var(--rojo)}

/* pointer-events:none → el toast NUNCA intercepta toques del botón que tiene debajo (bug móvil de "Comprar") */
.pi-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--oscuro);color:#fff;font-weight:800;padding:13px 20px;border-radius:50px;opacity:0;transition:all .25s;z-index:1300;font-size:.9rem;max-width:92vw;pointer-events:none}
.pi-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.pi-toast.ok{background:#1f9d57;display:flex;align-items:center;gap:9px;padding:14px 22px;box-shadow:0 14px 34px rgba(31,157,87,.45)}
.pi-toast .pi-toast-ic{display:inline-flex;flex:none}
.pi-toast .pi-toast-ic svg{width:22px;height:22px;fill:#fff}
/* Animación del botón del carrito al agregar algo */
@keyframes piCartBump{0%{transform:none}25%{transform:scale(1.15)}55%{transform:scale(.95)}100%{transform:none}}
#cartBtn.bump{animation:piCartBump .45s ease}
#cartBtn.bump .cart-count{background:#fff;color:var(--rojo)}

/* ===== Modal de selección (tamaño / combo) ===== */
.pi-pick-ov{position:fixed;inset:0;background:rgba(0,0,0,.55);display:none;align-items:center;justify-content:center;z-index:1200;padding:18px}
.pi-pick-ov.open{display:flex}
.pi-pick{background:var(--crema);border-radius:20px;width:min(420px,100%);max-height:90vh;overflow:auto;box-shadow:0 30px 70px rgba(0,0,0,.4)}
.pi-pick header{display:flex;align-items:center;padding:16px 18px;background:var(--rojo);color:#fff}
.pi-pick header h4{margin:0;font-size:1.1rem;font-weight:800}
.pi-pick header .pi-close{margin-left:auto}
.pi-pick #piPickBody{padding:18px}
.pi-pickname{font-size:1.25rem;font-weight:900;margin-bottom:4px}
.pi-combodesc{color:var(--gris);font-size:.9rem;line-height:1.5;margin-bottom:14px}
.pi-sizes{display:grid;gap:10px;margin-top:6px}
.pi-size{display:flex;align-items:center;justify-content:space-between;border:1.5px solid #e2d4bd;background:#fff;border-radius:14px;padding:14px 18px;cursor:pointer;font-family:inherit;transition:border-color .15s,transform .12s}
.pi-size:hover{border-color:var(--rojo);transform:translateY(-1px)}
.pi-size b{font-size:1.05rem}
.pi-size span{font-weight:900;color:var(--rojo);font-size:1.1rem}
.pi-plabel{display:block;font-size:.82rem;color:var(--gris);font-weight:700;margin:14px 0 8px}
.pi-chips{display:flex;flex-wrap:wrap;gap:8px}
.pi-chip{border:1.5px solid #e2d4bd;background:#fff;color:var(--oscuro);padding:9px 14px;border-radius:50px;font-weight:700;font-size:.85rem;cursor:pointer;font-family:inherit}
.pi-chip.on{background:var(--rojo);border-color:var(--rojo);color:#fff}
.pi-pinput{width:100%;padding:12px;border-radius:12px;border:1px solid #e2d4bd;background:#fff;font-size:.92rem;font-family:inherit;margin-bottom:4px}
.pi-pinput:focus{outline:2px solid var(--amarillo);border-color:var(--amarillo)}

/* ===== Bebidas compactas (botón pequeño con costo) ===== */
.mini-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px}
.mini{display:flex;align-items:center;gap:10px;background:#fff;border:1.5px solid #ecdcc0;border-radius:50px;padding:8px 8px 8px 14px;cursor:pointer;font-family:inherit;transition:transform .12s,border-color .14s,box-shadow .14s;text-align:left;width:100%}
.mini:hover{border-color:var(--rojo);transform:translateY(-2px);box-shadow:0 8px 18px rgba(226,18,27,.12)}
.mini:active{transform:scale(.98)}
.mini-ic{font-size:1.4rem;line-height:1;flex:none}
.mini-name{font-weight:700;color:var(--oscuro);font-size:.95rem;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-price{font-weight:900;color:var(--rojo);font-size:.95rem;flex:none}
.mini-plus{flex:none;width:30px;height:30px;border-radius:50%;background:var(--rojo);color:#fff;display:grid;place-items:center;font-size:1.1rem;font-weight:900}
@media(max-width:480px){ .mini-grid{grid-template-columns:1fr} }

/* ===== Tarjetas con tamaños (toda la info de precios) ===== */
.size-row{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-top:auto}
.size-add{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;min-height:48px;border:1.5px solid #ecdcc0;background:#fff8ee;color:var(--oscuro);border-radius:12px;padding:9px 4px;cursor:pointer;font-family:inherit;transition:all .14s;line-height:1.1}
.size-add span{font-size:.72rem;font-weight:700;color:#574e44}
.size-add b{font-size:.95rem;font-weight:900;color:var(--rojo);white-space:nowrap}
.size-add:hover{border-color:var(--rojo);background:#fff;transform:translateY(-2px);box-shadow:0 6px 14px rgba(226,18,27,.14)}
.size-add:active{transform:scale(.96)}
@media(max-width:480px){
  .size-add{min-height:50px;padding:9px 3px}
  .size-add span{font-size:.64rem}
  .size-add b{font-size:.84rem}
}
@media(max-width:360px){ .size-row{gap:5px} .size-add span{font-size:.6rem} }

@media(max-width:520px){
  .btn-order{padding:10px 14px;font-size:.85rem}
}

/* ===== Agotado / tienda cerrada (estado EN VIVO) ===== */
.sold-badge{position:absolute;inset:0;display:grid;place-items:center;background:rgba(20,10,6,.55);color:#fff;font-weight:900;font-size:1.15rem;letter-spacing:2px;border-radius:inherit;pointer-events:none}
.size-add:disabled,.card .add:disabled,.slide .cta:disabled,.mini:disabled{opacity:.45;pointer-events:none;box-shadow:none;transform:none}
.mini.sold{opacity:.5;pointer-events:none}
.card.sold .size-row,.card.sold .row{opacity:.55}
.pi-line.sold{opacity:.9}
.pi-sold-tag{display:block;color:var(--rojo);font-weight:800}
.pi-cart-note{background:#fff3df;border:1px solid #e8d09a;color:#8a5a00;font-size:.82rem;font-weight:700;padding:9px 12px;border-radius:10px;margin:8px 0 0}
/* Banner en flujo al tope (NO sticky) para que no choque con el header sticky */
.pi-closed-banner{position:relative;z-index:70;background:var(--rojo,#e2121b);color:#fff;text-align:center;font-weight:700;font-size:.92rem;padding:11px 14px;box-shadow:0 4px 14px rgba(0,0,0,.2)}
