:root{
  --verde:#2e7d32; --verde2:#43a047; --bg:#f4f6f4; --card:#fff;
  --gris:#6b7280; --linea:#e5e7eb; --rojo:#e53935;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);color:#1f2937;padding-bottom:150px}
header{position:sticky;top:0;z-index:20;background:var(--verde);color:#fff;
  padding:12px 14px;display:flex;align-items:center;justify-content:space-between;
  box-shadow:0 2px 8px rgba(0,0,0,.15)}
header h1{font-size:20px;margin:0}
.acciones{display:flex;gap:6px}
.pill{border:none;border-radius:20px;padding:9px 14px;font-size:14px;font-weight:600;
  background:rgba(255,255,255,.2);color:#fff}
.pill.primario,.pill.primario:active{background:#fff;color:var(--verde)}
.pill.ancho{width:100%;margin-top:10px;padding:14px}
.menu{position:absolute;right:10px;top:56px;z-index:30;background:#fff;border-radius:12px;
  box-shadow:0 8px 24px rgba(0,0,0,.2);overflow:hidden;min-width:250px}
.menu button{display:block;width:100%;text-align:left;padding:14px 16px;border:none;
  background:#fff;font-size:15px;border-bottom:1px solid var(--linea)}
.menu button.peligro{color:var(--rojo)}
.oculto{display:none !important}

main{padding:8px 10px}
.cat{margin:14px 4px 6px;font-size:13px;font-weight:700;color:var(--verde);
  text-transform:uppercase;letter-spacing:.5px;display:flex;justify-content:space-between}
.cat .subt{color:var(--gris);font-weight:600}
.item{background:var(--card);border-radius:12px;padding:10px 12px;margin-bottom:8px;
  display:flex;align-items:center;gap:10px;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.item.ok{opacity:.55}
.item.ok .nom{text-decoration:line-through}
.check{width:30px;height:30px;border-radius:50%;border:2px solid var(--verde2);
  flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:18px;
  color:#fff;background:#fff}
.item.ok .check{background:var(--verde2)}
.cuerpo{flex:1;min-width:0}
.nom{font-weight:600;font-size:16px;line-height:1.2}
.detalle{display:flex;align-items:center;gap:6px;margin-top:5px;flex-wrap:wrap}
.detalle input{border:1px solid var(--linea);border-radius:8px;padding:6px;font-size:14px}
.iCant{width:52px;text-align:center}
.iUnidad{width:74px}
.iPrecio{width:96px}
.mult{color:var(--gris);font-size:13px}
.sub{margin-left:auto;font-weight:700;color:var(--verde);font-size:15px;white-space:nowrap}
.del{border:none;background:transparent;color:var(--rojo);font-size:20px;padding:4px 6px}
.vacio{text-align:center;color:var(--gris);margin-top:40px}
.cta{display:block;margin:16px auto;background:var(--verde);color:#fff;border:none;
  padding:14px 20px;border-radius:12px;font-size:16px;font-weight:600}

footer#totalBar{position:fixed;bottom:0;left:0;right:0;z-index:20;background:#fff;
  border-top:1px solid var(--linea);box-shadow:0 -2px 12px rgba(0,0,0,.12);
  padding:10px 14px calc(10px + env(safe-area-inset-bottom))}
.barra{height:8px;background:var(--linea);border-radius:6px;overflow:hidden;margin-bottom:8px}
#barraFill{height:100%;width:0;background:var(--verde2);transition:width .3s}
.cifras{display:flex;justify-content:space-between;align-items:flex-end}
.cifras .lbl{display:block;font-size:11px;color:var(--gris);text-transform:uppercase}
.cifras strong{font-size:17px}
.cifras .grande strong{font-size:24px;color:var(--verde)}
.prog{font-size:12px;color:var(--gris);text-align:center;margin-top:4px}

.modal{position:fixed;inset:0;z-index:40;background:rgba(0,0,0,.45);
  display:flex;align-items:flex-end;justify-content:center}
.modal-card{background:#fff;width:100%;max-width:480px;border-radius:16px 16px 0 0;
  padding:18px 16px calc(18px + env(safe-area-inset-bottom));animation:up .2s}
.modal-card.alto{max-height:80vh;display:flex;flex-direction:column}
@keyframes up{from{transform:translateY(40px)}to{transform:translateY(0)}}
.modal-card h3{margin:0 0 12px}
.modal-card input,.modal-card select{width:100%;padding:13px;font-size:16px;
  border:1px solid var(--linea);border-radius:10px;margin-bottom:10px}
.modal-card .fila{display:flex;gap:8px}
.modal-card .fila input,.modal-card .fila select{margin-bottom:10px}
.modal-card .fila .pill{flex:1;padding:14px;border:1px solid var(--linea);color:#333;background:#f3f4f6}
.modal-card .fila .pill.primario{background:var(--verde);color:#fff;border:none}
#sugContenido{overflow-y:auto;flex:1}
.sugCat{font-size:13px;font-weight:700;color:var(--verde);margin:12px 0 6px;text-transform:uppercase}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{background:#eef5ee;border:1px solid #cfe3cf;border-radius:18px;padding:9px 14px;
  font-size:14px;color:#245e27}
.chip.added{background:var(--verde2);color:#fff;border-color:var(--verde2)}
