@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;700;800;900&display=swap');
:root{--ib-p:#FFD000;--ib-pd:#E6BB00;--bg:#111;--card:#1c1c1c;--bd:#2a2a2a;--t:#fff;--m:#aaa}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
.ib-body,.ib-wrap *{margin:0;padding:0}
.ib-body{background:#111}
.ib-wrap{background:var(--bg);color:var(--t);font-family:'Nunito',sans-serif;min-height:100vh;overflow-x:hidden;padding-bottom:88px}

/* BANNER */
.ib-banner{width:100%;height:220px;overflow:hidden;position:relative}
.ib-banner-img{width:100%;height:100%;object-fit:cover;display:block}
.ib-banner-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:20px;pointer-events:none}
.ib-banner-overlay .ib-brand{width:100%;text-shadow:0 2px 12px rgba(0,0,0,.85),0 1px 3px rgba(0,0,0,.95)}
.ib-banner-ph{width:100%;height:100%;background:linear-gradient(135deg,#1a0f00,#2a1800);display:flex;align-items:center;justify-content:center;gap:20px;padding:20px;position:relative;overflow:hidden}
.ib-banner-ph::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at top right,rgba(255,208,0,.15),transparent 60%);pointer-events:none}
.ib-mascote{height:160px;width:auto;filter:drop-shadow(0 6px 24px rgba(255,208,0,.5));animation:fl 4s ease-in-out infinite;z-index:1}
@keyframes fl{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.ib-brand{z-index:1;width:100%}
.ib-brand h1{font-size:clamp(30px,8vw,56px);font-weight:900;color:#fff;text-shadow:0 0 40px rgba(255,208,0,.5),0 4px 12px rgba(0,0,0,.7);line-height:1}
.ib-brand p{font-size:14px;color:var(--ib-p);font-weight:700;margin-top:8px}

/* NAV */
.ib-nav{display:flex;overflow-x:auto;scrollbar-width:none;background:var(--ib-p);position:sticky;top:0;z-index:300}
.ib-nav::-webkit-scrollbar{display:none}
.ib-nav-btn{flex-shrink:0;display:flex;align-items:center;gap:8px;padding:9px 22px;font-size:14px;font-weight:900;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;color:#000;white-space:nowrap;border:none;background:transparent;border-right:1px solid rgba(0,0,0,.1);font-family:'Nunito',sans-serif;transition:background .2s}
.ib-nav-btn.ativo{background:#111;color:var(--ib-p)}

/* BAIRRO */
.ib-bairro-box{background:var(--card);border-radius:14px;margin:14px 12px;padding:16px;border:1px solid var(--bd)}
.ib-bairro-label{text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}
.ib-sel-wrap{position:relative}
.ib-sel-wrap::after{content:'▾';position:absolute;right:16px;top:50%;transform:translateY(-50%);font-size:18px;color:var(--m);pointer-events:none}
.ib-sel{width:100%;background:#111;border:1.5px solid var(--bd);border-radius:10px;padding:14px 40px 14px 16px;font-size:15px;font-weight:700;color:var(--t);cursor:pointer;appearance:none;-webkit-appearance:none;outline:none;font-family:'Nunito',sans-serif;transition:border-color .2s,box-shadow .2s}
.ib-sel:focus{border-color:var(--ib-p)}
.ib-sel option{background:#111}
@keyframes ib-shk{0%,100%{transform:translateX(0)}20%{transform:translateX(-8px)}40%{transform:translateX(8px)}60%{transform:translateX(-6px)}80%{transform:translateX(6px)}}
.ib-shake{animation:ib-shk .5s ease;border-color:#ff5252!important;box-shadow:0 0 0 4px rgba(255,82,82,.18)}

/* SECOES */
.ib-sec{display:none}
.ib-sec.show{display:block}
.ib-sec-tit{letter-spacing:1px;text-transform:uppercase;line-height:1.1;margin:14px 14px 6px;padding:0}
.ib-list{display:flex;flex-direction:column;gap:14px;padding:4px 12px 10px}

/* CARD */
.ib-card{background:var(--card);border-radius:14px;padding:16px;border:1px solid var(--bd)}
.ib-card-top{display:flex;gap:14px;margin-bottom:14px}
.ib-thumb{width:155px;height:145px;border-radius:10px;overflow:hidden;flex-shrink:0;background:linear-gradient(135deg,#1a0f00,#111);display:flex;align-items:center;justify-content:center}
.ib-thumb img{width:100%;height:100%;object-fit:cover}
.ib-thumb span{font-size:64px}
.ib-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}
.ib-nome{font-size:16px;font-weight:900;color:#fff;text-transform:uppercase;line-height:1.2;letter-spacing:.5px;border-left:3px solid var(--ib-p);padding-left:10px;margin-bottom:2px;text-shadow:0 0 20px rgba(255,208,0,.15)}
.ib-desc{font-size:13px;color:var(--m);line-height:1.5;margin-top:2px}
.ib-preco{font-size:22px;font-weight:900;color:var(--ib-p);margin-top:6px}

/* CONTROLES */
.ib-controles{display:flex;flex-direction:column;gap:10px}
.ib-ctrl-linha1{display:flex;align-items:center;gap:16px;width:100%}
.ib-ctrl-linha2{display:flex;align-items:center;gap:10px}
.ib-qty-grp{display:flex;align-items:center;background:#111;border-radius:10px;border:1.5px solid var(--bd);overflow:hidden;flex-shrink:0}
.ib-qbtn{background:var(--ib-p);color:#000;border:none;width:44px;height:44px;font-size:22px;font-weight:900;cursor:pointer;font-family:'Nunito',sans-serif}
.ib-qbtn:active{background:var(--ib-pd)}
.ib-qval{font-size:18px;font-weight:900;color:#fff;min-width:40px;text-align:center;padding:0 4px}
.ib-btn-opcoes{background:var(--ib-p);color:#000;border:none;padding:0 20px;height:44px;border-radius:10px;font-size:13px;font-weight:900;text-transform:uppercase;cursor:pointer;font-family:'Nunito',sans-serif;white-space:nowrap;flex-shrink:0}
.ib-btn-opcoes:active{background:var(--ib-pd)}
.ib-obs-label{font-size:13px;font-weight:900;color:var(--m);text-transform:uppercase;letter-spacing:1px;flex-shrink:0}
.ib-btn-obs{background:#333;color:#fff;border:none;padding:0 16px;height:44px;border-radius:10px;font-size:13px;font-weight:900;text-transform:uppercase;cursor:pointer;font-family:'Nunito',sans-serif;flex-shrink:0}
.ib-btn-obs:active{background:#444}
.ib-btn-obs.tem-obs{background:var(--ib-p);color:#000;position:relative}
.ib-btn-add{flex:1;background:var(--btn-add,#fff);color:var(--btn-add-txt,#000);border:none;padding:0 14px;height:44px;border-radius:10px;font-size:13px;font-weight:900;text-transform:uppercase;cursor:pointer;font-family:'Nunito',sans-serif;transition:filter .15s}
.ib-btn-add:hover{filter:brightness(.95)}
.ib-btn-add:active{filter:brightness(.85)}

/* BARRA INFERIOR */
.ib-bar{position:fixed;bottom:0;left:0;right:0;background:#111;border-top:2px solid var(--ib-p);display:flex;align-items:center;justify-content:space-between;padding:12px 16px;z-index:400;box-shadow:0 -4px 20px rgba(0,0,0,.5)}
.ib-bar-label{font-size:11px;font-weight:700;color:var(--m);text-transform:uppercase;letter-spacing:1px;margin-bottom:2px}
.ib-bar-val{font-size:26px;font-weight:900;color:var(--ib-p);line-height:1}
.ib-bar-btn{background:var(--ib-p);color:#000;border:none;padding:14px 20px;border-radius:50px;font-size:14px;font-weight:900;text-transform:uppercase;cursor:pointer;display:flex;align-items:center;gap:8px;position:relative;font-family:'Nunito',sans-serif;box-shadow:0 4px 14px rgba(255,208,0,.4)}
.ib-bar-btn:active{background:var(--ib-pd)}
.ib-badge{position:absolute;top:-8px;right:-8px;background:var(--badge-bg,#e00);color:var(--badge-txt,#fff);font-size:12px;font-weight:900;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid #111}

/* DRAWER */
.ib-drawer-ov{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:500;display:none;align-items:flex-end;justify-content:center;backdrop-filter:blur(4px)}
.ib-drawer-ov.aberto{display:flex}
.ib-drawer{background:var(--card);width:100%;max-width:640px;border-radius:24px 24px 0 0;border-top:4px solid var(--ib-p);max-height:85vh;display:flex;flex-direction:column;animation:su .3s ease}
@keyframes su{from{transform:translateY(100%)}to{transform:translateY(0)}}
.ib-drawer-alca{width:44px;height:4px;background:#555;border-radius:2px;margin:14px auto 0}
.ib-drawer-topo{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--bd);font-size:18px;font-weight:900;text-transform:uppercase}
.ib-drawer-x{background:#333;border:none;color:#fff;width:34px;height:34px;border-radius:50%;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.ib-drawer-corpo{flex:1;overflow-y:auto;padding:16px 20px}
.ib-item-carrinho{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--bd)}
.ib-item-carrinho:last-child{border-bottom:none}
.ib-ic-emoji{font-size:28px;flex-shrink:0;width:40px;text-align:center}
.ib-ic-info{flex:1;min-width:0}
.ib-ic-nome{font-size:15px;font-weight:800;color:#fff}
.ib-ic-obs{font-size:12px;color:#888;margin-top:3px;font-style:italic}
.ib-ic-preco{font-size:14px;font-weight:700;color:var(--ib-p);margin-top:3px}
.ib-ic-ctrl{display:flex;align-items:center;gap:8px;flex-shrink:0}
.ib-ic-btn{background:#333;border:1px solid #444;color:#fff;width:30px;height:30px;border-radius:6px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:900}
.ib-ic-qty{font-size:16px;font-weight:900;min-width:22px;text-align:center}
.ib-ic-del{background:none;border:none;color:#666;font-size:18px;cursor:pointer;padding:4px}
.ib-ic-del:hover{color:#d63638}
.ib-vazio{text-align:center;padding:40px 20px;color:var(--m)}
.ib-vazio-icon{font-size:52px;display:block;margin-bottom:12px;opacity:.5}
.ib-drawer-rodape{padding:18px 20px;border-top:1px solid var(--bd)}
.ib-total-linha{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.ib-total-linha span:first-child{font-size:13px;font-weight:700;color:var(--m);text-transform:uppercase;letter-spacing:1px}
.ib-total-val{font-size:28px;font-weight:900;color:var(--ib-p)}
.ib-btn-finalizar{width:100%;background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;border:none;padding:16px;border-radius:50px;font-size:15px;font-weight:900;text-transform:uppercase;letter-spacing:1px;cursor:pointer;font-family:'Nunito',sans-serif;box-shadow:0 4px 14px rgba(37,211,102,.4)}
.ib-btn-finalizar:active{opacity:.9}

/* OBS */
.ib-obs-ov{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:600;display:none;align-items:flex-end;justify-content:center;backdrop-filter:blur(4px)}
.ib-obs-ov.aberto{display:flex}
.ib-obs-box{background:var(--card);width:100%;max-width:640px;border-radius:24px 24px 0 0;border-top:4px solid var(--ib-p);padding:22px;animation:su .3s ease}
.ib-obs-titulo{font-size:16px;font-weight:900;text-transform:uppercase;margin-bottom:14px;color:#fff}
.ib-obs-ta{width:100%;background:#111;border:1.5px solid var(--bd);border-radius:10px;padding:14px;font-size:15px;color:#fff;font-family:'Nunito',sans-serif;resize:none;outline:none;min-height:100px}
.ib-obs-ta:focus{border-color:var(--ib-p)}
.ib-obs-btns{display:flex;gap:10px;margin-top:14px}
.ib-obs-cancel{flex:1;background:#333;border:none;color:#fff;padding:14px;border-radius:10px;font-size:14px;font-weight:800;cursor:pointer;font-family:'Nunito',sans-serif}
.ib-obs-ok{flex:2;background:var(--ib-p);border:none;color:#000;padding:14px;border-radius:10px;font-size:14px;font-weight:900;text-transform:uppercase;cursor:pointer;font-family:'Nunito',sans-serif}

/* TOAST */
.ib-toast{position:fixed;top:20px;left:50%;transform:translateX(-50%) translateY(-80px);background:var(--ib-p);color:#000;padding:12px 24px;border-radius:50px;font-size:14px;font-weight:900;z-index:9999;transition:transform .35s ease;white-space:nowrap;box-shadow:0 4px 24px rgba(255,208,0,.5);font-family:'Nunito',sans-serif;pointer-events:none}
.ib-toast.show{transform:translateX(-50%) translateY(0)}

/* PARTICULA FLUTUANTE */
.ib-particula{position:fixed;z-index:9998;font-size:28px;pointer-events:none;transition:none;will-change:transform,opacity}
.ib-particula.voando{transition:transform .7s cubic-bezier(.2,.8,.4,1),opacity .7s ease}

@media(max-width:480px){
  .ib-banner-ph{flex-direction:column;gap:8px;text-align:center}
  .ib-mascote{height:110px}
  .ib-thumb{width:120px;height:110px}
}.ib-ctrl-adicionals{margin-top:10px}

/* ADICIONAIS MODAL */
.ib-add-item{display:flex;align-items:center;justify-content:space-between;padding:12px 4px;border-bottom:1px solid var(--bd)}
.ib-add-item:last-child{border-bottom:none}
.ib-add-item label{display:flex;align-items:center;gap:10px;cursor:pointer;flex:1;font-size:15px;font-weight:700;color:#fff}
.ib-add-item input[type=checkbox]{width:20px;height:20px;accent-color:var(--ib-p);cursor:pointer;flex-shrink:0}
.ib-add-preco{font-size:13px;color:var(--ib-p);font-weight:700;flex-shrink:0}
.ib-add-vazio{text-align:center;padding:20px;color:var(--m);font-size:14px}

/* ════════════════════════════════════════
   MODAL CADASTRO DO CLIENTE
═══════════════════════════════════════════ */
.ib-cad-ov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:99996;align-items:flex-end;justify-content:center}
.ib-cad-ov.aberto{display:flex}
.ib-cad-box{background:#fff;width:100%;max-width:540px;max-height:92vh;border-radius:16px 16px 0 0;display:flex;flex-direction:column;animation:ib-cad-up .25s ease}
@keyframes ib-cad-up{from{transform:translateY(100%)}to{transform:translateY(0)}}
.ib-cad-header{padding:18px 20px;border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.ib-cad-header h2{margin:0;font-size:18px;color:#1d2327;font-family:'Nunito',sans-serif}
.ib-cad-fechar{background:#f0f0f0;border:0;width:32px;height:32px;border-radius:50%;font-size:16px;cursor:pointer;color:#666;display:flex;align-items:center;justify-content:center}
.ib-cad-fechar:hover{background:#e5e5e5}
.ib-cad-body{padding:18px 20px;overflow-y:auto;flex:1}
.ib-cad-info{margin:0 0 16px;font-size:13px;color:#666;line-height:1.5}
.ib-cad-campo{margin-bottom:14px}
.ib-cad-campo label{display:block;font-size:12px;font-weight:700;color:#1d2327;margin-bottom:5px;text-transform:uppercase;letter-spacing:.4px}
.ib-cad-campo input,.ib-cad-campo textarea{width:100%;padding:10px 12px;border:1.5px solid #ddd;border-radius:8px;font-size:14px;font-family:'Nunito',sans-serif;color:#1d2327;background:#fff;box-sizing:border-box}
.ib-cad-campo input:focus,.ib-cad-campo textarea:focus{outline:none;border-color:var(--ib-p,#FFD000);box-shadow:0 0 0 3px rgba(255,208,0,.15)}
.ib-cad-campo input.invalido{border-color:#d63638}
.ib-cad-campo textarea{resize:vertical;min-height:60px}
.ib-cad-row{display:flex;gap:10px;flex-wrap:wrap}
.ib-cad-row .ib-cad-campo{margin-bottom:14px}
.ib-cad-pgto{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.ib-cad-footer{padding:14px 20px;border-top:1px solid #eee;display:flex;gap:10px;flex-shrink:0;background:#fafafa;border-radius:0}
.ib-cad-footer .ib-obs-cancel,.ib-cad-footer .ib-obs-ok{flex:1;padding:14px;border-radius:10px;font-size:14px;font-weight:900;cursor:pointer;border:0;font-family:'Nunito',sans-serif;text-transform:uppercase}
.ib-cad-footer .ib-obs-cancel{background:#f0f0f0;color:#1d2327}
.ib-cad-footer .ib-obs-ok{background:var(--btn-add,#FFD000);color:var(--btn-add-txt,#000)}
.ib-cad-footer .ib-obs-ok:hover{filter:brightness(.95)}
.ib-cad-footer .ib-obs-ok:disabled{opacity:.6;cursor:not-allowed;filter:none}
@media(min-width:600px){
  .ib-cad-ov{align-items:center;padding:20px}
  .ib-cad-box{border-radius:16px;max-width:540px}
}

/* TOTAL DO MODAL DE CADASTRO */
/* PREVIEW DO TROCO — card destacado abaixo do input */
.ib-troco-prev{margin-top:14px;background:var(--bg-input);border:1.5px solid var(--bd);border-radius:12px;padding:14px 16px;animation:ib-troco-fade .2s ease}
@keyframes ib-troco-fade{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.ib-troco-prev-linha{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:14px}
.ib-troco-prev-linha span{color:var(--t-suave);font-weight:600}
.ib-troco-prev-linha strong{color:var(--t);font-weight:700;font-family:'Nunito',sans-serif}
.ib-troco-prev-divider{height:1px;background:var(--bd);margin:6px 0}
.ib-troco-prev-final{padding-top:8px}
.ib-troco-prev-final span{color:var(--t)!important;font-weight:800;font-size:15px}
.ib-troco-prev-final strong{color:#22c55e!important;font-weight:900;font-size:22px}
.ib-troco-prev-final.insuficiente strong{color:#ef4444!important}
.ib-troco-prev-final.insuficiente span::after{content:' (faltando)';color:#ef4444;font-weight:600;font-size:12px;text-transform:none}
.ib-troco-prev-final.exato strong{color:var(--ib-p)!important;font-size:18px}
.ib-troco-prev-final.exato span::after{content:' (valor exato — sem troco)';color:#22c55e;font-weight:600;font-size:12px;text-transform:none}
