/* ============================================================
   LOJA (CLIENTE) — visual moderno · paleta roxo + rosa + verde
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800&display=swap');

:root{
  --plum:#4b005f;       /* roxo profundo */
  --roxo:#6e0fcd;       /* roxo vivo */
  --pink:#ff64cd;       /* rosa vibrante */
  --verde:#aafb95;      /* verde fresco */
  --verde-txt:#2f8f1f;  /* verde legível para texto */

  --bg:#f8f1fb;
  --texto:#34123f;
  --cinza:#9a8aa6;
  --borda:#eee2f5;
  --ok:#2f9e44;
  --erro:#e53935;

  --grad:linear-gradient(135deg,#6e0fcd 0%,#ff64cd 100%);
  --grad-escuro:linear-gradient(135deg,#4b005f 0%,#6e0fcd 55%,#ff64cd 130%);
  --sombra:0 12px 30px rgba(110,15,205,.14);
  --sombra-sm:0 6px 16px rgba(110,15,205,.10);
  --sombra-pink:0 10px 22px rgba(255,100,205,.34);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:'Poppins',system-ui,sans-serif;background:var(--bg);color:var(--texto);padding-bottom:96px;line-height:1.45}
a{color:var(--roxo);text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{margin:0}

.container{max-width:560px;margin:0 auto;padding:0 18px}

/* ---------- Cabeçalho ---------- */
.topo-app{padding:18px 0 6px}
.topo-app .container{display:flex;align-items:center;justify-content:space-between}
.topo-app .ola{font-size:13px;color:var(--cinza)}
.topo-app .nome-loja{font-size:20px;font-weight:800;color:var(--plum);display:flex;align-items:center;gap:8px;margin-top:2px}
.topo-app .status{font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px;vertical-align:middle}
.status.aberta{background:#e9fce1;color:var(--verde-txt)}
.status.fechada{background:#ffe7e7;color:var(--erro)}
.topo-acoes{display:flex;align-items:center;gap:10px}
.icone-btn{width:46px;height:46px;border-radius:16px;background:#fff;box-shadow:var(--sombra-sm);display:flex;align-items:center;justify-content:center;font-size:20px;position:relative;color:var(--texto)}
.icone-btn .badge{position:absolute;top:-5px;right:-5px;background:var(--pink);color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 5px;border:2px solid var(--bg)}
.avatar{width:46px;height:46px;border-radius:16px;background:var(--grad);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px;overflow:hidden}
.avatar img{width:100%;height:100%;object-fit:cover}

/* ---------- Busca ---------- */
.busca{margin:14px 0 4px}
.busca .campo-busca{display:flex;align-items:center;gap:10px;background:#fff;border-radius:18px;padding:14px 16px;box-shadow:var(--sombra-sm)}
.busca input{border:0;outline:0;flex:1;font-size:15px;font-family:inherit;background:transparent;color:var(--texto)}
.busca .ico{color:var(--cinza);font-size:18px}

/* ---------- Banner hero ---------- */
.hero{margin:16px 0 8px}
.hero-card{background:var(--grad-escuro);border-radius:26px;padding:24px;color:#fff;position:relative;overflow:hidden;box-shadow:0 16px 36px rgba(75,0,95,.34)}
.hero-card::after{content:"";position:absolute;right:-40px;top:-40px;width:180px;height:180px;background:rgba(255,255,255,.12);border-radius:50%}
.hero-card::before{content:"";position:absolute;right:30px;bottom:-50px;width:120px;height:120px;background:rgba(170,251,149,.22);border-radius:50%}
.hero-card .selo-promo{display:inline-block;background:var(--verde);color:var(--plum);font-size:12px;font-weight:700;padding:4px 12px;border-radius:999px;margin-bottom:10px}
.hero-card h2{font-size:23px;font-weight:800;line-height:1.2;max-width:75%;position:relative;z-index:1}
.hero-card p{font-size:13px;opacity:.92;margin:8px 0 16px;max-width:70%}
.hero-card .btn-hero{background:#fff;color:var(--roxo);border:0;font-weight:700;padding:11px 22px;border-radius:999px;font-size:14px;position:relative;z-index:1;display:inline-block}
.hero-emoji{position:absolute;right:18px;bottom:10px;font-size:90px;z-index:0;filter:drop-shadow(0 8px 14px rgba(0,0,0,.25));transform:rotate(8deg)}

/* ---------- Categorias / seções ---------- */
.titulo-secao{display:flex;align-items:center;justify-content:space-between;margin:22px 0 12px}
.titulo-secao h3{font-size:18px;font-weight:700;color:var(--plum)}
.titulo-secao a{font-size:13px;color:var(--cinza);font-weight:500}
.cats{display:flex;gap:10px;overflow-x:auto;padding:4px 0 8px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.cats::-webkit-scrollbar{display:none}
.cats a{flex-shrink:0;background:#fff;color:var(--texto);padding:10px 18px;border-radius:14px;font-size:14px;font-weight:600;box-shadow:var(--sombra-sm);display:flex;align-items:center;gap:7px}
.cats a.ativa{background:var(--grad);color:#fff;box-shadow:var(--sombra-pink)}

/* ---------- Grade de produtos ---------- */
.produtos-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.p-card{background:#fff;border-radius:22px;padding:12px;box-shadow:var(--sombra);position:relative;display:flex;flex-direction:column}
.p-card .foto{height:124px;border-radius:18px;background:linear-gradient(135deg,#f1d9ff,#ffd6f4);display:flex;align-items:center;justify-content:center;font-size:54px;overflow:hidden;margin-bottom:10px}
.p-card .foto img{width:100%;height:100%;object-fit:cover}
.p-card h4{font-size:15px;font-weight:700;line-height:1.25;color:var(--plum)}
.p-card .desc{font-size:12px;color:var(--cinza);margin-top:3px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:32px}
.p-card .rodape{display:flex;align-items:center;justify-content:space-between;margin-top:10px}
.p-card .preco{font-weight:800;font-size:17px;color:var(--pink)}
.p-card .preco small{font-size:11px;color:var(--cinza);font-weight:500;display:block;line-height:1}
.p-card .add{width:38px;height:38px;border-radius:14px;background:var(--grad);color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:600;box-shadow:var(--sombra-pink);flex-shrink:0}
.p-card.indisponivel{opacity:.55}
.p-card.indisponivel .add{background:#cbd5e1;box-shadow:none}

/* lista horizontal (destaques) */
.destaques{display:flex;gap:14px;overflow-x:auto;padding:4px 0 10px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.destaques::-webkit-scrollbar{display:none}
.d-card{flex-shrink:0;width:230px;background:var(--grad);border-radius:24px;padding:16px;color:#fff;position:relative;overflow:hidden;box-shadow:var(--sombra-pink);min-height:120px}
.d-card .foto-d{position:absolute;right:-6px;bottom:-6px;width:96px;height:96px;border-radius:50%;background:rgba(255,255,255,.22);display:flex;align-items:center;justify-content:center;font-size:46px;overflow:hidden}
.d-card .foto-d img{width:100%;height:100%;object-fit:cover}
.d-card h4{font-size:16px;font-weight:700;max-width:62%}
.d-card .desc-d{font-size:11px;opacity:.9;margin-top:4px;max-width:60%;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.d-card .preco-d{font-size:18px;font-weight:800;margin-top:14px}

/* ---------- Página do produto ---------- */
.produto-hero{position:relative;background:linear-gradient(135deg,#f1d9ff,#ffd6f4);border-radius:0 0 32px 32px;height:280px;display:flex;align-items:center;justify-content:center;font-size:120px;overflow:hidden}
.produto-hero img{width:100%;height:100%;object-fit:cover}
.produto-hero .voltar{position:absolute;top:16px;left:16px;width:44px;height:44px;border-radius:14px;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--plum);box-shadow:var(--sombra-sm)}
.produto-corpo{background:var(--bg);border-radius:32px 32px 0 0;margin-top:-28px;position:relative;padding-top:8px}
.produto-corpo .cabecalho{padding:20px 18px 4px}
.produto-corpo h1{font-size:24px;font-weight:800;color:var(--plum)}
.produto-corpo .desc{color:var(--cinza);font-size:14px;margin-top:6px}
.produto-corpo .preco-base{font-size:22px;font-weight:800;color:var(--pink);margin-top:10px}

.bloco{background:#fff;border-radius:22px;margin:14px 18px;padding:16px;box-shadow:var(--sombra-sm)}
.bloco .bloco-cab{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.bloco .bloco-cab h3{font-size:16px;font-weight:700;color:var(--plum)}
.bloco .obrig{font-size:11px;background:#ffe7f9;color:var(--pink);padding:3px 10px;border-radius:999px;font-weight:700}
.bloco .opcional{font-size:12px;color:var(--cinza)}
.opcao{display:flex;align-items:center;gap:12px;padding:12px 2px;border-bottom:1px solid var(--borda)}
.opcao:last-child{border-bottom:0}
.opcao label{flex:1;display:flex;justify-content:space-between;cursor:pointer;font-size:15px}
.opcao .extra{color:var(--verde-txt);font-weight:700;font-size:14px}
.opcao input{width:22px;height:22px;accent-color:var(--roxo);flex-shrink:0}

/* ---------- Botões ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--grad);color:#fff;border:0;padding:15px 22px;border-radius:18px;font-size:16px;font-weight:700;cursor:pointer;font-family:inherit;box-shadow:var(--sombra-pink)}
.btn:hover{filter:brightness(1.04)}
.btn.bloco-btn,.btn.bloco{width:100%}
.btn.sec{background:#fff;color:var(--roxo);box-shadow:var(--sombra-sm)}
.btn.peq{padding:9px 16px;font-size:14px;border-radius:13px}
.btn:disabled,.btn.off{background:#cbd5e1;box-shadow:none;cursor:not-allowed;pointer-events:none}

/* ---------- Barra inferior fixa ---------- */
.barra-fixa{position:fixed;bottom:0;left:0;right:0;background:#fff;padding:14px 18px calc(14px + env(safe-area-inset-bottom));z-index:50;box-shadow:0 -8px 24px rgba(110,15,205,.12);border-radius:28px 28px 0 0}
.barra-fixa .container{display:flex;gap:14px;align-items:center;padding:0}
.qtd-ctrl{display:flex;align-items:center;gap:6px;background:var(--bg);border-radius:16px;padding:8px}
.qtd-ctrl button{background:#fff;border:0;width:34px;height:34px;border-radius:11px;font-size:20px;color:var(--roxo);cursor:pointer;font-weight:700;box-shadow:var(--sombra-sm);display:flex;align-items:center;justify-content:center}
.qtd-ctrl span{font-weight:700;min-width:24px;text-align:center;font-size:16px}

/* ---------- Carrinho / pedido ---------- */
.titulo-pagina{font-size:22px;font-weight:800;color:var(--plum);margin:20px 0 16px}
.item-carrinho{background:#fff;border-radius:20px;padding:14px;margin-bottom:14px;box-shadow:var(--sombra-sm);display:flex;gap:14px}
.item-carrinho .thumb{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,#f1d9ff,#ffd6f4);display:flex;align-items:center;justify-content:center;font-size:30px;flex-shrink:0;overflow:hidden}
.item-carrinho .thumb img{width:100%;height:100%;object-fit:cover}
.item-carrinho .info{flex:1;min-width:0}
.item-carrinho h4{font-size:15px;font-weight:700;color:var(--plum)}
.item-carrinho .ops{color:var(--cinza);font-size:12px;margin:4px 0}
.item-carrinho .linha-baixo{display:flex;justify-content:space-between;align-items:center;margin-top:6px}
.item-carrinho .preco-i{font-weight:800;color:var(--pink);font-size:16px}
.btn-remover{background:#ffe7f9;color:var(--pink);border:0;border-radius:10px;padding:6px 10px;font-size:13px;font-weight:600;cursor:pointer}

.resumo{background:#fff;border-radius:22px;padding:18px;margin-bottom:16px;box-shadow:var(--sombra-sm)}
.resumo .linha-r{display:flex;justify-content:space-between;padding:7px 0;font-size:15px;color:var(--texto)}
.resumo .linha-r span:first-child{color:var(--cinza)}
.resumo .total{font-size:20px;font-weight:800;border-top:1.5px dashed var(--borda);margin-top:8px;padding-top:14px}
.resumo .total span:first-child{color:var(--texto)}
.resumo .total span:last-child{color:var(--pink)}

/* ---------- Campos ---------- */
.campo{margin-bottom:14px}
.campo label{display:block;font-weight:600;font-size:14px;margin-bottom:7px}
.campo input,.campo select,.campo textarea{width:100%;padding:14px 16px;border:1.5px solid var(--borda);border-radius:16px;font-size:16px;font-family:inherit;background:#fff;color:var(--texto)}
.campo input:focus,.campo select:focus,.campo textarea:focus{outline:0;border-color:var(--roxo)}

/* ---------- Fidelidade ---------- */
.fidelidade-card{background:var(--grad-escuro);color:#fff;border-radius:26px;padding:22px;margin-bottom:18px;box-shadow:0 16px 32px rgba(75,0,95,.30)}
.fidelidade-card h3{font-size:17px;font-weight:700;display:flex;align-items:center;gap:8px}
.fidelidade-card .selos{display:flex;flex-wrap:wrap;gap:9px;margin:16px 0}
.fidelidade-card .selo{width:36px;height:36px;border-radius:50%;border:2px dashed rgba(255,255,255,.45);display:flex;align-items:center;justify-content:center;font-size:16px}
.fidelidade-card .selo.cheio{background:var(--verde);border-color:var(--verde);color:var(--plum)}
.fidelidade-card .premio{background:rgba(255,255,255,.16);border-radius:14px;padding:12px;font-size:14px;margin-top:8px}

/* ---------- Avisos / estados ---------- */
.aviso{padding:14px 16px;border-radius:16px;margin-bottom:14px;font-size:14px;font-weight:500}
.aviso.sucesso{background:#e9fce1;color:var(--verde-txt)}
.aviso.erro{background:#ffe7e7;color:var(--erro)}
.aviso.info{background:#f6e9ff;color:var(--roxo)}
.vazio{text-align:center;color:var(--cinza);padding:54px 20px}
.vazio .emoji{font-size:56px;margin-bottom:10px}

/* ---------- Etiquetas de status ---------- */
.tag{display:inline-block;padding:5px 13px;border-radius:999px;font-size:13px;font-weight:700}
.tag.novo{background:#ffe7f9;color:#d6189c}
.tag.aceito,.tag.preparando{background:#fff4e0;color:#c97a08}
.tag.a_caminho,.tag.pronto{background:#f1e3ff;color:var(--roxo)}
.tag.concluido{background:#e9fce1;color:var(--verde-txt)}
.tag.cancelado{background:#ffe7e7;color:var(--erro)}

/* ---------- Rodapé / avisos topo ---------- */
.fechada-aviso{background:#ffe7e7;color:var(--erro);text-align:center;padding:12px;font-weight:600;font-size:14px;margin:8px 18px;border-radius:16px}
.rodape-loja{text-align:center;color:var(--cinza);font-size:13px;margin:34px 0 10px;line-height:1.8}

/* ---------- Rodapé moderno ---------- */
.rodape-moderno{background:var(--grad-escuro);color:#fff;border-radius:30px 30px 0 0;margin-top:36px;padding:30px 22px calc(26px + env(safe-area-inset-bottom));position:relative;overflow:hidden}
.rodape-moderno::before{content:"";position:absolute;right:-30px;top:-30px;width:140px;height:140px;background:rgba(170,251,149,.16);border-radius:50%}
.rodape-moderno .container{padding:0;position:relative;z-index:1}
.rf-marca{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.rf-marca .rf-logo{width:52px;height:52px;border-radius:16px;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:28px;overflow:hidden}
.rf-marca .rf-logo img{width:100%;height:100%;object-fit:cover}
.rf-marca h3{font-size:18px;font-weight:800;line-height:1.2}
.rf-marca .rf-tag{font-size:12px;opacity:.85}
.rf-item{display:flex;gap:12px;align-items:flex-start;padding:11px 0;border-top:1px solid rgba(255,255,255,.12)}
.rf-item .rf-ic{font-size:18px;width:24px;text-align:center;flex-shrink:0;margin-top:1px}
.rf-item .rf-txt{font-size:14px;line-height:1.5}
.rf-item .rf-txt a{color:#fff;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.4)}
.rf-item .rf-txt .rf-label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.05em;opacity:.7;margin-bottom:2px}
.rf-redes{display:flex;gap:10px;margin:18px 0 6px;flex-wrap:wrap}
.rf-redes a{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.14);color:#fff;text-decoration:none;padding:11px 16px;border-radius:14px;font-size:14px;font-weight:600}
.rf-redes a.maps{background:var(--verde);color:var(--plum)}
.rf-redes a:hover{filter:brightness(1.08)}
.rf-base{text-align:center;font-size:12px;opacity:.7;margin-top:18px;border-top:1px solid rgba(255,255,255,.12);padding-top:16px}

/* progresso do pedido */
.passo{display:flex;align-items:center;gap:14px;padding:10px 0}
.passo .bolinha{width:32px;height:32px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}
.passo .bolinha.feito{background:var(--grad);color:#fff}
.passo .bolinha.aguardando{background:#efe2f7;color:#b59cc6}
