/* Fora D'Horas — menu público (direção "Azulejo & Bocage") */

/* ===== CABEÇALHO ===== */
.cabecalho{
  position:relative;
  color:#fff;
  text-align:center;
  padding:46px 20px 40px;
  overflow:hidden;
  background:
    repeating-linear-gradient(45deg,transparent 0 15px,rgba(255,255,255,.05) 15px 16px),
    repeating-linear-gradient(-45deg,transparent 0 15px,rgba(255,255,255,.05) 15px 16px),
    linear-gradient(140deg,var(--c-azul),var(--c-azulejo));
}
.cabecalho::after{content:"";position:absolute;left:0;right:0;bottom:0;height:4px;background:var(--c-dourado)}
/* Com foto da praça: véu azul por cima (ativado por JS quando a imagem existe) */
.cabecalho.com-foto{
  background:
    linear-gradient(160deg,rgba(20,48,77,.50),rgba(20,48,77,.78)),
    url('../fundo.jpg') center 42%/cover no-repeat;
}
.cab-overlay{position:absolute;inset:0;pointer-events:none}
.cab-conteudo{position:relative;z-index:2}
.cabecalho h1{font-size:2.4rem;font-weight:700;letter-spacing:.3px;text-shadow:0 2px 12px rgba(0,0,0,.25)}
.cab-sub{margin-top:6px;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;opacity:.9}

.lang-switch{position:absolute;top:-30px;right:0;display:flex;gap:6px}
.lang-switch button{
  border:1px solid rgba(255,255,255,.45);background:rgba(255,255,255,.12);color:#fff;
  padding:6px 11px;border-radius:8px;font-weight:600;font-size:.8rem;transition:var(--tr);backdrop-filter:blur(4px);
}
.lang-switch button.ativo{background:var(--c-dourado);border-color:var(--c-dourado);color:var(--c-azul)}

/* ===== WRAPPER ===== */
.wrapper{max-width:var(--wrap);margin:0 auto;padding:22px 14px 90px}

/* ===== PESQUISA ===== */
.search-box{position:relative;margin-bottom:20px}
.search-box input{
  width:100%;padding:14px 16px 14px 46px;border:1px solid var(--c-linha);border-radius:var(--r-pill);
  font-size:16px;background:#fff;box-shadow:var(--sh);outline:none;transition:var(--tr);color:var(--c-txt);
}
.search-box input:focus{border-color:var(--c-azulejo);box-shadow:0 0 0 3px rgba(41,92,138,.15)}
.search-ic{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:1rem;opacity:.6;pointer-events:none}

/* ===== LOADING ===== */
.loading{text-align:center;padding:40px 0;color:var(--c-txt2);font-size:.95rem}
.loading.erro{color:var(--c-del)}

/* ===== ACORDEÃO — SECÇÃO (nível 1) ===== */
.sec{margin-bottom:16px;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh);background:#fff}
.sec-cab{
  display:flex;align-items:center;gap:11px;width:100%;text-align:left;
  background:linear-gradient(135deg,var(--c-azul),var(--c-azulejo));color:#fff;
  padding:16px 18px;font-family:var(--f-titulo);font-size:1.25rem;font-weight:600;
}
.sec-cab .ic{font-size:1.1rem}
.sec-cab .chev{margin-left:auto;transition:transform var(--tr);opacity:.85;font-size:.8rem}
.sec.aberta .sec-cab .chev{transform:rotate(180deg)}
.sec-corpo{display:grid;grid-template-rows:0fr;transition:grid-template-rows var(--tr);background:var(--c-creme)}
.sec.aberta>.sec-corpo{grid-template-rows:1fr}
.sec-corpo>.inner{overflow:hidden;min-height:0}

/* ===== ACORDEÃO — CATEGORIA (nível 2) ===== */
.cat{border-bottom:1px solid var(--c-linha)}
.cat:last-child{border-bottom:none}
.cat-cab{
  display:flex;align-items:center;gap:10px;width:100%;text-align:left;
  background:var(--c-azulejo);color:#fff;padding:13px 18px;font-size:1.02rem;font-weight:600;
  transition:filter .2s;
}
.cat-cab:hover{filter:brightness(1.07)}
.cat-cab .ic{font-size:1rem}
.cat-cab .chev{margin-left:auto;transition:transform var(--tr);opacity:.85;font-size:.75rem}
.cat.aberta .cat-cab .chev{transform:rotate(180deg)}
.cat-corpo{display:grid;grid-template-rows:0fr;transition:grid-template-rows var(--tr);background:#fff}
.cat.aberta>.cat-corpo{grid-template-rows:1fr}
.cat-corpo>.inner{overflow:hidden;min-height:0}

/* ===== ITEM ===== */
.item{padding:14px 18px;border-bottom:1px dashed var(--c-linha)}
.item:last-child{border-bottom:none}
.item.com-foto{display:flex;gap:13px;align-items:flex-start}
.item-thumb{flex:0 0 66px;width:66px;height:66px;border-radius:11px;object-fit:cover;background:var(--c-creme)}
.item-corpo{flex:1;min-width:0}
.item-topo{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.item-nome{font-family:var(--f-titulo);font-weight:600;font-size:1.05rem;color:var(--c-azul)}
.item-desc{font-size:.86rem;line-height:1.45;color:var(--c-txt2);margin-top:4px}

/* preço único */
.item-preco{margin-left:auto;display:flex;align-items:center;gap:10px}
.preco-val{font-family:var(--f-titulo);font-weight:700;font-size:1.05rem;color:var(--c-azulejo);white-space:nowrap}
.add-btn{
  flex:0 0 auto;width:32px;height:32px;border-radius:50%;background:var(--c-azul);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:1.2rem;line-height:1;transition:var(--tr);
}
.add-btn:active{transform:scale(.9)}

/* etiquetas */
.tag{font-size:.62rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:3px 8px;border-radius:var(--r-pill);white-space:nowrap}
.tag-especialidade{background:var(--c-dourado);color:#fff}
.tag-novo{background:var(--c-azulejo);color:#fff}
.tag-vegetariano{background:#5b8c5a;color:#fff}
.tag-picante{background:#d9534f;color:#fff}

/* variantes (multi-preço) */
.variantes{display:flex;flex-wrap:wrap;gap:8px;margin-top:11px}
.variante{
  display:flex;align-items:center;gap:7px;border:1.5px solid var(--c-azulejo);color:var(--c-azulejo);
  background:#fff;border-radius:var(--r-pill);padding:7px 13px;font-size:.82rem;font-weight:600;transition:var(--tr);
}
.variante:active{background:var(--c-azulejo);color:#fff}
.variante .v-mais{background:var(--c-azulejo);color:#fff;border-radius:50%;width:17px;height:17px;display:inline-flex;align-items:center;justify-content:center;font-size:.8rem;line-height:1}

/* esgotado */
.item.esgotado{opacity:.6}
.item.esgotado .item-nome{text-decoration:line-through;color:var(--c-esgotado)}
.item.esgotado .preco-val{color:var(--c-esgotado);text-decoration:line-through}
.tag-esgotado{background:var(--c-linha);color:#8a7d5c;font-size:.62rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:3px 8px;border-radius:var(--r-pill)}

/* ===== FAB CARRINHO ===== */
.cart-fab{
  position:fixed;bottom:18px;right:18px;background:var(--c-dourado);color:var(--c-azul);
  padding:13px 20px;border-radius:var(--r-pill);box-shadow:var(--sh-lg);
  display:flex;align-items:center;gap:10px;font-weight:700;font-size:.95rem;z-index:1000;
  transform:translateY(160%);transition:transform var(--tr);
}
.cart-fab.visivel{transform:translateY(0)}
.cart-fab:active{transform:scale(.96)}
.cart-ic{position:relative;font-size:1.15rem}
.cart-badge{
  position:absolute;top:-8px;left:-10px;background:var(--c-azul);color:#fff;
  min-width:21px;height:21px;padding:0 5px;border-radius:var(--r-pill);
  font-size:.72rem;font-weight:700;display:flex;align-items:center;justify-content:center;
}

/* ===== MODAL CARRINHO ===== */
.modal{position:fixed;inset:0;background:rgba(20,48,77,.55);backdrop-filter:blur(3px);z-index:2000;display:none;justify-content:center;align-items:flex-end;opacity:0;transition:opacity var(--tr)}
.modal.aberto{display:flex;opacity:1}
.modal-box{background:#fff;width:100%;max-width:520px;border-radius:18px 18px 0 0;max-height:82vh;display:flex;flex-direction:column;box-shadow:var(--sh-lg);animation:subir .3s ease}
@media(min-width:560px){.modal{align-items:center}.modal-box{border-radius:18px}}
@keyframes subir{from{transform:translateY(40px)}to{transform:translateY(0)}}
.modal-top{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,var(--c-azul),var(--c-azulejo));color:#fff;padding:16px 18px}
.modal-top h2{font-size:1.25rem}
.modal-close{color:#fff;font-size:1.3rem;width:32px;height:32px;border-radius:50%}
.modal-body{padding:8px 18px;overflow-y:auto;flex:1}
.modal-vazio{text-align:center;color:var(--c-txt2);padding:34px 0}
.cart-linha{display:flex;align-items:center;gap:10px;padding:12px 0;border-bottom:1px solid var(--c-linha)}
.cart-linha:last-child{border-bottom:none}
.cart-info{flex:1;min-width:0}
.cart-nome{font-weight:600;color:var(--c-azul)}
.cart-var{font-weight:400;font-size:.85em;color:var(--c-txt2)}
.cart-preco{font-size:.85rem;color:var(--c-txt2);margin-top:2px}
.cart-remover{color:var(--c-del);font-size:1.05rem;padding:6px;flex:0 0 auto}
.modal-foot{padding:14px 18px;background:var(--c-creme);border-top:1px solid var(--c-linha)}
.modal-note{font-size:.82rem;color:var(--c-txt2);text-align:center;margin-bottom:12px}
.btn-clear{width:100%;padding:12px;border:1px solid var(--c-linha);background:#fff;color:var(--c-txt2);border-radius:10px;font-weight:600;transition:var(--tr)}
.btn-clear:active{background:var(--c-linha)}

/* ===== TOAST ===== */
.toast{position:fixed;left:50%;bottom:86px;transform:translateX(-50%) translateY(20px);background:var(--c-azul);color:#fff;padding:11px 22px;border-radius:var(--r-pill);font-size:.9rem;z-index:3000;opacity:0;pointer-events:none;transition:var(--tr)}
.toast.mostra{opacity:1;transform:translateX(-50%) translateY(0)}

/* ===== RESPONSIVO ===== */
@media(max-width:560px){
  .cabecalho{padding:40px 18px 34px}
  .cabecalho h1{font-size:2rem}
  .cart-fab-label{display:none}
}
@media print{.lang-switch,.cart-fab,.search-box{display:none}.sec-corpo,.cat-corpo{grid-template-rows:1fr!important}}
