/* =====================================================
   ALPHA DELIVERY — Folha de estilo global
   ===================================================== */

:root {
    --primaria: #FF3D00;
    --primaria-escura: #E03000;
    --primaria-suave: #FFF0EB;
    --gradiente: linear-gradient(135deg, #FF3D00 0%, #FF7A00 100%);
    --roxo: #241B4D;
    --roxo-claro: #37296E;
    --texto: #241B4D;
    --texto-suave: #6B6685;
    --fundo: #F7F6FB;
    --branco: #FFFFFF;
    --borda: #E8E6F0;
    --verde: #16A34A;
    --verde-suave: #DCFCE7;
    --vermelho: #DC2626;
    --vermelho-suave: #FEE2E2;
    --amarelo: #F59E0B;
    --sombra: 0 2px 12px rgba(36, 27, 77, .08);
    --sombra-alta: 0 8px 30px rgba(36, 27, 77, .16);
    --raio: 14px;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; }

html, body { overflow-x: hidden; }

body {
    font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
    background: var(--fundo);
    color: var(--texto);
    font-size: 15px;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}
body > .painel-layout { flex: 1; }

/* body é flex (rodapé no fim da tela): filhos com margin:auto perdem o "stretch"
   e encolheriam para a largura do conteúdo interno — força largura total sempre */
body > * { width: 100%; }
.hero-inner > * { min-width: 0; }

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
svg { flex-shrink: 0; vertical-align: middle; }

.container { max-width: 1440px; margin: 0 auto; padding: 0 clamp(16px, 3vw, 48px); }

h1, h2, h3, h4 { font-weight: 800; line-height: 1.25; letter-spacing: -.02em; }

/* ---------- Botões ---------- */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    padding: 11px 20px; border-radius: 12px; border: none; cursor: pointer;
    font: 700 14.5px/1 'Inter', sans-serif; transition: all .18s ease;
    white-space: nowrap;
}
.btn-primario { background: var(--gradiente); color: #fff; box-shadow: 0 4px 14px rgba(255, 61, 0, .35); }
.btn-primario:hover { transform: translateY(-1px); box-shadow: 0 6px 20px rgba(255, 61, 0, .45); }
.btn-roxo { background: var(--roxo); color: #fff; }
.btn-roxo:hover { background: var(--roxo-claro); }
.btn-branco { background: #fff; color: var(--roxo); border: 1.5px solid var(--borda); }
.btn-branco:hover { border-color: var(--primaria); color: var(--primaria); }
.btn-suave { background: var(--primaria-suave); color: var(--primaria); }
.btn-suave:hover { background: #FFE3D8; }
.btn-verde { background: var(--verde); color: #fff; }
.btn-verde:hover { background: #15803D; }
.btn-vermelho { background: var(--vermelho-suave); color: var(--vermelho); }
.btn-vermelho:hover { background: #FECACA; }
.btn-sm { padding: 8px 14px; font-size: 13px; border-radius: 10px; }
.btn-bloco { width: 100%; }
.btn:disabled { opacity: .55; cursor: not-allowed; transform: none !important; }

/* ---------- Formulários ---------- */
label.campo { display: block; margin-bottom: 14px; }
label.campo > span { display: block; font-weight: 600; font-size: 13.5px; margin-bottom: 6px; color: var(--roxo); }
.input, select.input, textarea.input {
    width: 100%; padding: 11px 14px; border: 1.5px solid var(--borda); border-radius: 12px;
    font: 500 14.5px 'Inter', sans-serif; color: var(--texto); background: #fff;
    transition: border-color .15s, box-shadow .15s; outline: none;
}
.input:focus { border-color: var(--primaria); box-shadow: 0 0 0 3px rgba(255, 61, 0, .12); }
textarea.input { resize: vertical; min-height: 80px; }
.form-linha { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-linha-3 { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 12px; }
.dica { font-size: 12.5px; color: var(--texto-suave); margin-top: 4px; }

/* ---------- Toggle (interruptor) ---------- */
.toggle { position: relative; display: inline-flex; align-items: center; gap: 10px; cursor: pointer; font-weight: 600; font-size: 14px; }
.toggle input { position: absolute; opacity: 0; }
.toggle .pista {
    width: 46px; height: 26px; background: #D5D2E3; border-radius: 99px; position: relative;
    transition: background .2s; flex-shrink: 0;
}
.toggle .pista::after {
    content: ''; position: absolute; top: 3px; left: 3px; width: 20px; height: 20px;
    background: #fff; border-radius: 50%; transition: transform .2s; box-shadow: 0 1px 4px rgba(0,0,0,.25);
}
.toggle input:checked + .pista { background: var(--verde); }
.toggle input:checked + .pista::after { transform: translateX(20px); }

/* ---------- Badges e flash ---------- */
.badge {
    display: inline-flex; align-items: center; gap: 5px; padding: 5px 11px;
    border-radius: 99px; font-size: 12.5px; font-weight: 700;
}
.badge-verde { background: var(--verde-suave); color: #15803D; }
.badge-vermelho { background: var(--vermelho-suave); color: var(--vermelho); }
.badge-cinza { background: #EEECF5; color: var(--texto-suave); }
.flash {
    display: flex; align-items: center; gap: 10px; padding: 13px 16px; border-radius: 12px;
    font-weight: 600; font-size: 14px; margin: 14px 0;
}
.flash-ok { background: var(--verde-suave); color: #15803D; }
.flash-erro { background: var(--vermelho-suave); color: var(--vermelho); }

/* ---------- Navbar pública ---------- */
.navbar {
    background: #fff; border-bottom: 1px solid var(--borda); position: sticky; top: 0; z-index: 50;
}
.navbar-inner { display: flex; align-items: center; gap: 16px; height: 64px; }
.logo { display: flex; align-items: center; gap: 9px; font-size: 20px; font-weight: 800; color: var(--roxo); }
.logo .logo-icone {
    width: 38px; height: 38px; border-radius: 11px; background: var(--gradiente);
    display: flex; align-items: center; justify-content: center; color: #fff;
    box-shadow: 0 4px 12px rgba(255, 61, 0, .35);
}
.logo b { color: var(--primaria); }
.navbar-acoes { margin-left: auto; display: flex; align-items: center; gap: 10px; }
.btn-carrinho { position: relative; }
.btn-carrinho .contador {
    position: absolute; top: -6px; right: -6px; min-width: 20px; height: 20px; padding: 0 5px;
    background: var(--roxo); color: #fff; border-radius: 99px; font-size: 11.5px; font-weight: 800;
    display: flex; align-items: center; justify-content: center;
}

/* ---------- Hero ---------- */
.hero {
    background: var(--roxo);
    background-image: radial-gradient(ellipse 60% 90% at 85% 10%, rgba(255, 61, 0, .35), transparent),
                      radial-gradient(ellipse 40% 70% at 10% 90%, rgba(255, 122, 0, .22), transparent);
    color: #fff; padding: 52px 0 64px; position: relative; overflow: hidden;
}
.hero-inner { display: flex; align-items: center; gap: 56px; }
.hero-texto { flex: 1; max-width: 660px; }
.hero h1 { font-size: clamp(28px, 3.4vw, 52px); }
.hero h1 em { font-style: normal; color: #FF8A5C; }
.hero p { margin: 14px 0 28px; font-size: clamp(15px, 1.2vw, 18px); color: #CFC9E8; max-width: 540px; }
.hero .busca {
    display: flex; background: #fff; border-radius: 16px; padding: 6px; max-width: 580px;
    box-shadow: var(--sombra-alta);
}
.hero .busca input {
    flex: 1; border: none; outline: none; padding: 10px 14px; font: 500 15px 'Inter', sans-serif;
    color: var(--texto); background: transparent; min-width: 0;
}
.hero-arte { display: none; flex: 1; justify-content: center; }
.hero-arte svg { animation: flutua 5s ease-in-out infinite; }
@keyframes flutua {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    50% { transform: translateY(-18px) rotate(2deg); }
}
@media (min-width: 980px) {
    .hero { padding: 72px 0 86px; }
    .hero-arte { display: flex; }
}

/* ---------- Chips de segmento ---------- */
.chips { display: flex; gap: 9px; overflow-x: auto; padding: 4px 0 10px; scrollbar-width: none; }
.chips::-webkit-scrollbar { display: none; }
.chip {
    padding: 9px 17px; border-radius: 99px; background: #fff; border: 1.5px solid var(--borda);
    font-weight: 600; font-size: 13.5px; color: var(--texto-suave); white-space: nowrap; transition: all .15s;
    display: inline-flex; align-items: center; gap: 6px;
}
.chip:hover { border-color: var(--primaria); color: var(--primaria); }
.chip.ativo { background: var(--roxo); border-color: var(--roxo); color: #fff; }

/* ---------- Grade de lojas ---------- */
.secao-titulo { display: flex; align-items: center; gap: 10px; margin: 28px 0 16px; }
.secao-titulo h2 { font-size: 21px; }
.secao-titulo .icone-titulo {
    width: 38px; height: 38px; border-radius: 11px; background: var(--primaria-suave); color: var(--primaria);
    display: flex; align-items: center; justify-content: center;
}
.grade-lojas { display: grid; grid-template-columns: repeat(auto-fill, minmax(255px, 1fr)); gap: 16px; }
.card-loja {
    background: #fff; border-radius: var(--raio); box-shadow: var(--sombra); overflow: hidden;
    transition: transform .18s, box-shadow .18s; display: block;
}
.card-loja:hover { transform: translateY(-3px); box-shadow: var(--sombra-alta); }
.card-loja .capa { height: 110px; background: linear-gradient(135deg, #37296E, #241B4D); position: relative; }
.card-loja .capa img { width: 100%; height: 100%; object-fit: cover; }
.card-loja .logo-loja {
    width: 62px; height: 62px; border-radius: 14px; background: #fff; border: 3px solid #fff;
    position: absolute; left: 16px; bottom: -24px; box-shadow: var(--sombra);
    display: flex; align-items: center; justify-content: center; color: var(--texto-suave); overflow: hidden;
}
.card-loja .logo-loja img { width: 100%; height: 100%; object-fit: cover; }
.card-loja .corpo { padding: 32px 16px 16px; }
.card-loja h3 { font-size: 16px; display: flex; align-items: center; gap: 8px; }
.card-loja .meta { display: flex; flex-wrap: wrap; gap: 5px 14px; margin-top: 8px; font-size: 13px; color: var(--texto-suave); }
.card-loja .meta span { display: inline-flex; align-items: center; gap: 5px; }
.card-loja .meta .estrela { color: var(--amarelo); font-weight: 700; }
.fechada { position: absolute; inset: 0; background: rgba(20, 15, 45, .55); display: flex; align-items: center; justify-content: center; }
.fechada span { background: #fff; color: var(--roxo); font-weight: 800; font-size: 12.5px; padding: 6px 14px; border-radius: 99px; }

/* ---------- Página da loja ---------- */
.loja-topo { background: #fff; border-bottom: 1px solid var(--borda); }
.loja-banner { height: 170px; background: linear-gradient(135deg, #37296E, #241B4D); }
.loja-banner img { width: 100%; height: 100%; object-fit: cover; }
.loja-info { display: flex; gap: 18px; align-items: flex-start; padding: 0 0 20px; margin-top: -34px; position: relative; }
.loja-info .logo-loja {
    width: 92px; height: 92px; border-radius: 20px; background: #fff; border: 4px solid #fff;
    box-shadow: var(--sombra); overflow: hidden; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center; color: var(--texto-suave);
}
.loja-info .logo-loja img { width: 100%; height: 100%; object-fit: cover; }
.loja-info .dados { padding-top: 42px; }
.loja-info h1 { font-size: 24px; }
.loja-info .meta { display: flex; flex-wrap: wrap; gap: 6px 18px; margin-top: 8px; font-size: 13.5px; color: var(--texto-suave); }
.loja-info .meta span { display: inline-flex; align-items: center; gap: 6px; }

/* ---------- Cardápio ---------- */
.nav-categorias {
    display: flex; gap: 8px; overflow-x: auto; position: sticky; top: 64px; z-index: 40;
    background: var(--fundo); padding: 12px 0; scrollbar-width: none;
}
.nav-categorias::-webkit-scrollbar { display: none; }
.cardapio h2 { font-size: 18px; margin: 26px 0 12px; scroll-margin-top: 130px; }
.grade-produtos { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.card-produto {
    background: #fff; border-radius: var(--raio); box-shadow: var(--sombra); padding: 14px;
    display: flex; gap: 13px; cursor: pointer; transition: transform .15s, box-shadow .15s; text-align: left; border: none; font-family: inherit;
}
.card-produto:hover { transform: translateY(-2px); box-shadow: var(--sombra-alta); }
.card-produto .info { flex: 1; min-width: 0; }
.card-produto h4 { font-size: 15px; }
.card-produto .desc { font-size: 12.8px; color: var(--texto-suave); margin: 5px 0 8px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.card-produto .preco { font-weight: 800; color: var(--verde); font-size: 15px; }
.card-produto .preco s { color: var(--texto-suave); font-weight: 500; font-size: 12.5px; margin-left: 7px; }
.card-produto .foto {
    width: 92px; height: 92px; border-radius: 12px; object-fit: cover; flex-shrink: 0;
    background: var(--primaria-suave);
}
.foto-vazia { display: flex; align-items: center; justify-content: center; color: var(--primaria); }

/* ---------- Barra flutuante do carrinho ---------- */
.barra-carrinho {
    position: fixed; left: 50%; transform: translateX(-50%); bottom: 18px; z-index: 60;
    background: var(--roxo); color: #fff; border-radius: 16px; padding: 14px 20px;
    display: flex; align-items: center; gap: 22px; width: min(560px, calc(100% - 28px));
    box-shadow: var(--sombra-alta); transition: transform .2s;
}
.barra-carrinho:hover { transform: translateX(-50%) translateY(-2px); }
.barra-carrinho .qtd { font-size: 13px; color: #CFC9E8; }
.barra-carrinho .total { font-weight: 800; font-size: 16px; }
.barra-carrinho .ver { margin-left: auto; display: flex; align-items: center; gap: 8px; font-weight: 700; }

/* ---------- Modal ---------- */
.modal-fundo {
    position: fixed; inset: 0; background: rgba(20, 15, 45, .6); z-index: 100;
    display: none; align-items: flex-end; justify-content: center; padding: 0;
}
.modal-fundo.aberto { display: flex; }
.modal {
    background: #fff; width: 100%; max-width: 480px; border-radius: 22px 22px 0 0;
    max-height: 92vh; overflow-y: auto; animation: sobe .22s ease;
}
@keyframes sobe { from { transform: translateY(60px); opacity: 0; } to { transform: none; opacity: 1; } }
.modal-cab { display: flex; align-items: center; justify-content: space-between; padding: 18px 20px 0; }
.modal-corpo { padding: 14px 20px 22px; }
.modal .fechar { background: var(--fundo); border: none; width: 36px; height: 36px; border-radius: 50%; cursor: pointer; display: flex; align-items: center; justify-content: center; color: var(--texto); }
@media (min-width: 640px) {
    .modal-fundo { align-items: center; padding: 20px; }
    .modal { border-radius: 22px; }
}

/* ---------- Contador de quantidade ---------- */
.qtd-controle { display: inline-flex; align-items: center; gap: 4px; border: 1.5px solid var(--borda); border-radius: 12px; padding: 4px; }
.qtd-controle button {
    width: 34px; height: 34px; border: none; background: var(--fundo); border-radius: 9px;
    cursor: pointer; display: flex; align-items: center; justify-content: center; color: var(--primaria);
}
.qtd-controle button:hover { background: var(--primaria-suave); }
.qtd-controle .num { min-width: 34px; text-align: center; font-weight: 800; font-size: 15px; }

/* ---------- Carrinho / checkout ---------- */
.pagina-estreita { max-width: 760px; margin: 0 auto; padding: 24px 16px 60px; }
.grade-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.cartao { background: #fff; border-radius: var(--raio); box-shadow: var(--sombra); padding: 20px; margin-bottom: 16px; }
.cartao h3 { font-size: 16px; margin-bottom: 14px; display: flex; align-items: center; gap: 9px; color: var(--roxo); }
.item-carrinho { display: flex; align-items: center; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--borda); }
.item-carrinho:last-child { border-bottom: none; }
.item-carrinho .nome { font-weight: 700; font-size: 14.5px; }
.item-carrinho .obs { font-size: 12.5px; color: var(--texto-suave); }
.item-carrinho .preco-item { margin-left: auto; font-weight: 800; white-space: nowrap; }
.linha-total { display: flex; justify-content: space-between; padding: 7px 0; font-size: 14.5px; color: var(--texto-suave); }
.linha-total.destaque { font-weight: 800; font-size: 17px; color: var(--texto); border-top: 1.5px dashed var(--borda); margin-top: 8px; padding-top: 13px; }

/* ---------- Opções de pagamento ---------- */
.opcao-radio {
    display: flex; align-items: center; gap: 13px; border: 1.5px solid var(--borda); border-radius: 13px;
    padding: 14px 16px; cursor: pointer; margin-bottom: 10px; transition: all .15s;
}
.opcao-radio:hover { border-color: #C9C3E0; }
.opcao-radio input { accent-color: var(--primaria); width: 18px; height: 18px; }
.opcao-radio.marcada { border-color: var(--primaria); background: var(--primaria-suave); }
.opcao-radio .icone-pg {
    width: 42px; height: 42px; border-radius: 11px; background: var(--fundo);
    display: flex; align-items: center; justify-content: center; color: var(--roxo);
}
.opcao-radio.marcada .icone-pg { background: #fff; color: var(--primaria); }
.opcao-radio b { font-size: 14.5px; }
.opcao-radio small { display: block; color: var(--texto-suave); font-size: 12.5px; }

/* ---------- Timeline do pedido ---------- */
.timeline { position: relative; padding-left: 4px; }
.timeline-passo { display: flex; gap: 15px; position: relative; padding-bottom: 26px; }
.timeline-passo:last-child { padding-bottom: 0; }
.timeline-passo::before {
    content: ''; position: absolute; left: 19px; top: 40px; bottom: 0; width: 2.5px;
    background: var(--borda); border-radius: 2px;
}
.timeline-passo:last-child::before { display: none; }
.timeline-passo.feito::before { background: var(--verde); }
.timeline-passo .bola {
    width: 40px; height: 40px; border-radius: 50%; background: #EEECF5; color: #A8A3C2;
    display: flex; align-items: center; justify-content: center; flex-shrink: 0; z-index: 1;
}
.timeline-passo.feito .bola { background: var(--verde); color: #fff; }
.timeline-passo.atual .bola { background: var(--gradiente); color: #fff; box-shadow: 0 0 0 6px rgba(255, 61, 0, .18); animation: pulsa 1.6s infinite; }
@keyframes pulsa { 50% { box-shadow: 0 0 0 10px rgba(255, 61, 0, .08); } }
.timeline-passo b { font-size: 14.5px; display: block; }
.timeline-passo small { color: var(--texto-suave); font-size: 12.5px; }

/* ---------- Caixa PIX ---------- */
.caixa-pix { border: 2px dashed #32BCAD; border-radius: 14px; padding: 18px; background: #F0FBFA; }
.caixa-pix .chave {
    display: flex; align-items: center; gap: 10px; background: #fff; border-radius: 11px;
    padding: 11px 14px; margin: 12px 0; border: 1px solid #C9EAE6;
}
.caixa-pix .chave code { flex: 1; font-size: 14px; font-weight: 700; word-break: break-all; color: #0F766E; }

/* ---------- Mapa ---------- */
.mapa-rastreio { height: 320px; border-radius: var(--raio); overflow: hidden; z-index: 1; }

/* ---------- Tabelas ---------- */
.tabela { width: 100%; border-collapse: collapse; font-size: 14px; }
.tabela th { text-align: left; padding: 11px 12px; color: var(--texto-suave); font-size: 12px; text-transform: uppercase; letter-spacing: .04em; border-bottom: 1.5px solid var(--borda); }
.tabela td { padding: 13px 12px; border-bottom: 1px solid var(--borda); vertical-align: middle; }
.tabela tr:last-child td { border-bottom: none; }
.tabela tr:hover td { background: #FBFAFE; }

/* ---------- Layout dos painéis (empresa/admin/entregador) ---------- */
.painel-layout { display: flex; min-height: 100vh; }
.sidebar {
    width: 248px; background: var(--roxo); color: #fff; padding: 22px 14px; flex-shrink: 0;
    display: flex; flex-direction: column; gap: 4px; position: sticky; top: 0; height: 100vh; overflow-y: auto;
}
.sidebar .logo { color: #fff; padding: 0 10px 20px; }
.sidebar a.item {
    display: flex; align-items: center; gap: 12px; padding: 11px 13px; border-radius: 11px;
    color: #B9B2D8; font-weight: 600; font-size: 14px; transition: all .15s;
}
.sidebar a.item:hover { background: rgba(255, 255, 255, .07); color: #fff; }
.sidebar a.item.ativo { background: var(--gradiente); color: #fff; box-shadow: 0 4px 12px rgba(255, 61, 0, .3); }
.sidebar .rodape-sb { margin-top: auto; border-top: 1px solid rgba(255,255,255,.12); padding-top: 12px; }
.painel-main { flex: 1; padding: 26px 28px 60px; min-width: 0; }
.painel-cab { display: flex; align-items: center; gap: 14px; margin-bottom: 22px; flex-wrap: wrap; }
.painel-cab h1 { font-size: 23px; }
.painel-cab .acoes { margin-left: auto; display: flex; gap: 10px; flex-wrap: wrap; }

/* Estatísticas — auto-adaptável: quantas colunas couberem, encolhe sem estourar */
.grade-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(160px, 100%), 1fr)); gap: 14px; margin-bottom: 22px; }
.stat { background: #fff; border-radius: var(--raio); box-shadow: var(--sombra); padding: 18px; display: flex; gap: 14px; align-items: center; min-width: 0; }
.stat > div { min-width: 0; }
.stat .icone-stat { width: 46px; height: 46px; border-radius: 13px; display: flex; align-items: center; justify-content: center; }
.stat .valor { font-size: 21px; font-weight: 800; line-height: 1.1; }
.stat .rotulo { font-size: 12.5px; color: var(--texto-suave); font-weight: 600; }

/* Abas */
.abas { display: flex; gap: 8px; overflow-x: auto; margin-bottom: 18px; scrollbar-width: none; }
.abas::-webkit-scrollbar { display: none; }
.aba {
    padding: 9px 16px; border-radius: 11px; background: #fff; border: 1.5px solid var(--borda);
    font-weight: 700; font-size: 13.5px; color: var(--texto-suave); white-space: nowrap;
    display: inline-flex; align-items: center; gap: 7px;
}
.aba .cont { background: var(--fundo); border-radius: 99px; padding: 1px 8px; font-size: 11.5px; }
.aba.ativa { background: var(--roxo); border-color: var(--roxo); color: #fff; }
.aba.ativa .cont { background: rgba(255,255,255,.18); }

/* Card de pedido no painel */
.card-pedido { background: #fff; border-radius: var(--raio); box-shadow: var(--sombra); padding: 18px; margin-bottom: 14px; }
.card-pedido .cab { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.card-pedido .cab .codigo { font-weight: 800; font-size: 16px; }
.card-pedido .cab .quando { color: var(--texto-suave); font-size: 13px; }
.card-pedido .cab .direita { margin-left: auto; display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.card-pedido .detalhes { border-top: 1px dashed var(--borda); margin-top: 14px; padding-top: 14px; }
.card-pedido .itens li { display: flex; justify-content: space-between; padding: 4px 0; font-size: 14px; list-style: none; }
.card-pedido .acoes-pedido { display: flex; gap: 9px; flex-wrap: wrap; margin-top: 14px; }

/* ---------- Seja parceiro ---------- */
.beneficios { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 16px; margin: 30px 0; }
.beneficio { background: #fff; border-radius: var(--raio); box-shadow: var(--sombra); padding: 22px; }
.beneficio .icone-b {
    width: 48px; height: 48px; border-radius: 13px; background: var(--primaria-suave); color: var(--primaria);
    display: flex; align-items: center; justify-content: center; margin-bottom: 14px;
}
.beneficio h3 { font-size: 16px; margin-bottom: 6px; }
.beneficio p { font-size: 13.5px; color: var(--texto-suave); }

/* ---------- Auth ---------- */
.auth-wrap { min-height: calc(100vh - 64px); display: flex; align-items: center; justify-content: center; padding: 30px 16px; }
.auth-card { background: #fff; border-radius: 20px; box-shadow: var(--sombra-alta); padding: 34px 30px; width: 100%; max-width: 420px; }
.auth-card h1 { font-size: 22px; margin-bottom: 4px; }
.auth-card .sub { color: var(--texto-suave); font-size: 14px; margin-bottom: 22px; }

/* ---------- Faixa CTA parceiro ---------- */
.cta-parceiro {
    background: var(--gradiente); border-radius: 22px; color: #fff; padding: 38px 40px;
    display: flex; align-items: center; gap: 28px; flex-wrap: wrap; margin: 46px 0 8px;
    box-shadow: 0 14px 40px rgba(255, 61, 0, .30);
}
.cta-parceiro h2 { font-size: clamp(20px, 2vw, 27px); }
.cta-parceiro p { color: #FFE3D8; font-size: 14.5px; margin-top: 6px; max-width: 560px; }
.cta-parceiro .btn { margin-left: auto; background: #fff; color: var(--primaria); padding: 14px 26px; }
.cta-parceiro .btn:hover { transform: translateY(-2px); }

/* ---------- Rodapé ---------- */
.rodape { background: var(--roxo); color: #B9B2D8; margin-top: auto; padding: 36px 0; font-size: 13.5px; }
.rodape .container { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.rodape .logo { color: #fff; font-size: 17px; }

/* Textos longos (e-mails, endereços, chaves PIX) quebram em vez de estourar a tela */
.cartao, .card-pedido, .flash, .opcao-radio, .caixa-pix, .item-carrinho { overflow-wrap: anywhere; min-width: 0; }

/* Preços nunca quebram no meio (ex.: "R$ 54,40" virar "54,4 / 0") */
.card-pedido .itens li > span:last-child,
.linha-total > span:last-child,
.item-carrinho .preco-item { white-space: nowrap; padding-left: 10px; }

/* ---------- Vazio ---------- */
.vazio { text-align: center; padding: 50px 20px; color: var(--texto-suave); }
.vazio .icone-vazio {
    width: 74px; height: 74px; border-radius: 22px; background: #fff; box-shadow: var(--sombra);
    display: inline-flex; align-items: center; justify-content: center; color: #C9C3E0; margin-bottom: 16px;
}
.vazio h3 { color: var(--texto); margin-bottom: 6px; }

/* ---------- Responsivo ---------- */
@media (max-width: 860px) {
    .painel-layout { flex-direction: column; }
    .sidebar {
        width: 100%; height: auto; flex-direction: row; align-items: center;
        overflow-x: auto; padding: 10px 12px; gap: 6px;
        position: sticky; top: 0; z-index: 60;
    }
    .sidebar .logo { padding: 0 10px 0 0; }
    .sidebar .logo span.texto { display: none; }
    .sidebar a.item { padding: 9px 12px; white-space: nowrap; }
    .sidebar .rodape-sb { margin: 0 0 0 auto; border: none; padding: 0; display: flex; }
    .painel-main { padding: 18px 12px 60px; }
    .painel-cab h1 { font-size: 19px; }

    /* tabelas largas rolam dentro do cartão, sem estourar a tela */
    .cartao { overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .tabela { min-width: 560px; }
    .grade-2 { grid-template-columns: 1fr; }
    .card-pedido .cab .direita { margin-left: 0; width: 100%; }
    .card-pedido .acoes-pedido form[style*="margin-left"] { margin-left: 0 !important; width: 100%; }
}
@media (max-width: 640px) {
    .grade-produtos { grid-template-columns: 1fr; }
    .form-linha, .form-linha-3 { grid-template-columns: 1fr; }
    .navbar-acoes .esconde-mobile { display: none; }
    .loja-info .dados { padding-top: 40px; }
    .card-produto .foto { width: 78px; height: 78px; }
    .painel-cab .acoes { margin-left: 0; width: 100%; }
    /* estatísticas compactas: 2 por linha sem estourar */
    .grade-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
    .stat { padding: 13px; gap: 10px; }
    .stat .icone-stat { width: 38px; height: 38px; border-radius: 11px; }
    .stat .valor { font-size: 17px; }
    .stat .rotulo { font-size: 11.5px; }
    .navbar-inner { gap: 10px; }
    .navbar-inner > .navbar-acoes { flex-shrink: 0; }
}
