:root{
  --bg:#f3f6fb;
  --card:#ffffff;
  --text:#0f172a;
  --muted:#64748b;
  --primary:#1d4ed8;
  --primary2:#2563eb;
  --ring:rgba(37,99,235,.25);
  --border:rgba(15,23,42,.10);
}
*{box-sizing:border-box;}
html,body{height:100%;}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;background:var(--bg);color:var(--text);}
a{color:inherit;text-decoration:none;}

.app{max-width:460px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;}

/* Header (fixo, cor padrão do sistema) */
.topbar{position:sticky;top:0;z-index:20;background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff;border-bottom:0;}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;}
.brand-mini{display:flex;align-items:center;gap:10px;min-width:0;}
.brand-mini-logo{width:42px;height:42px;border-radius:14px;object-fit:contain;background:rgba(255,255,255,.95);padding:6px;border:1px solid rgba(255,255,255,.35);}
.brand-mini-fallback{width:42px;height:42px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.25);font-weight:1000;color:#fff;}
.brand-mini-txt{min-width:0;}
.brand-mini-name{font-weight:1000;font-size:14px;line-height:1.05;color:#fff;}
.brand-mini-addr{margin-top:3px;display:flex;align-items:center;gap:6px;font-size:12px;color:rgba(255,255,255,.90);font-weight:900;min-width:0;}
.brand-mini-addr .sub{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px;}

.actions{display:flex;align-items:center;gap:8px;}
.iconbtn{width:40px;height:40px;border-radius:14px;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;}
.iconbtn:active{transform:scale(.98);}
.svgicon{width:20px;height:20px;}

.content{padding:12px 14px 100px;}

/* Busca estilo app (iFood-like) */
.searchbar{margin:0 0 12px;display:flex;align-items:center;gap:10px;padding:12px 12px;border-radius:14px;background:#f3f4f6;}
.searchbar .sicon{width:36px;height:36px;border-radius:12px;background:#e9eefc;color:var(--primary);display:flex;align-items:center;justify-content:center;}
.searchbar .stext{font-weight:900;font-size:13px;color:rgba(15,23,42,.70);}

/* Slides */
.hero{border-radius:16px;overflow:hidden;background:#fff;border:1px solid rgba(15,23,42,.08);}
.carousel{display:flex;overflow:auto;scroll-snap-type:x mandatory;scrollbar-width:none;}
.carousel::-webkit-scrollbar{display:none;}
.slide-imgonly{min-width:100%;scroll-snap-align:start;position:relative;}
.slide-imgonly img{width:100%;height:170px;object-fit: contain;
  background:#fff;
  padding:6px;display:block;}
.slide-link{display:block;}
.slide-imgonly .placeholder{height:170px;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:16px;background:linear-gradient(135deg, rgba(29,78,216,.08), rgba(37,99,235,.04));}
.slide-imgonly .ph-title{font-weight:1000;font-size:18px;line-height:1.15;}
.slide-imgonly .ph-sub{margin-top:6px;color:var(--muted);font-size:13px;font-weight:800;}
.dots{display:flex;justify-content:center;gap:7px;padding:10px 0 12px;background:#fff;}
.dot{width:7px;height:7px;border-radius:999px;background:rgba(15,23,42,.18);}
.dot.active{width:18px;background:rgba(29,78,216,.75);}

.section{margin-top:14px;}
.section-header{display:flex;align-items:flex-end;justify-content:space-between;gap:10px;margin-bottom:10px;}
.section-header h3{margin:0;font-size:13px;letter-spacing:.02em;font-weight:1000;color:rgba(15,23,42,.85);}
.section-header .link{color:var(--primary);font-weight:900;font-size:13px;}
.subhint{margin-top:2px;color:var(--muted);font-size:12px;font-weight:700;}

/* Categorias (carrossel) */
.cats{display:flex;gap:10px;overflow-x:auto;padding:2px 2px 8px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;}
.cats::-webkit-scrollbar{height:6px;}
.cats::-webkit-scrollbar-thumb{background:rgba(0,0,0,.12);border-radius:999px;}
.cat{background:transparent;border:0;padding:6px 2px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;min-width:86px;flex:0 0 auto;scroll-snap-align:start;}
.cat .ico{width:44px;height:44px;border-radius:16px;background:#fff;border:1px solid rgba(15,23,42,.08);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.cat .ico img{width:70%;height:70%;object-fit:contain;}
.cat .name{font-size:12px;font-weight:900;text-align:center;line-height:1.1;color:rgba(15,23,42,.85);}

/* Destaques / Promoções */
.hscroll{display:flex;gap:12px;overflow:auto;scroll-snap-type:x mandatory;scrollbar-width:none;padding-bottom:2px;}
.hscroll::-webkit-scrollbar{display:none;}
.mini-card{scroll-snap-align:start;min-width:160px;max-width:160px;background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:16px;padding:10px;display:flex;flex-direction:column;gap:8px;}
.hscroll.clean .mini-card{border:0;background:transparent;padding:0;min-width:140px;max-width:140px;}
.mini-thumb{position:relative;width:100%;height:78px;border-radius:16px;background:#fff;border:1px solid rgba(15,23,42,.08);overflow:hidden;display:flex;align-items:center;justify-content:center;}
.hscroll.clean .mini-thumb{border:1px solid rgba(15,23,42,.08);}
.mini-thumb img{width:100%;height:100%;object-fit:cover;background:transparent;padding:0;border-radius:0;}
.mini-title{font-weight:1000;font-size:13px;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.mini-sub{font-size:12px;color:var(--muted);font-weight:800;display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.mini-sub .price{font-weight:1000;color:rgba(15,23,42,.85);}
.mini-sub .old{text-decoration:line-through;color:rgba(100,116,139,.9);font-weight:900;}

/* Badges (promo/destaque) */
.ribbon{position:absolute;left:-34px;top:10px;transform:rotate(-35deg);width:140px;text-align:center;padding:6px 0;font-weight:1000;font-size:11px;letter-spacing:.02em;color:#fff;box-shadow:0 10px 18px rgba(0,0,0,.12);}
.ribbon.promo{background:#ef4444;}
.badge{position:absolute;right:8px;top:8px;display:inline-flex;align-items:center;justify-content:center;padding:4px 8px;border-radius:999px;font-weight:1000;font-size:11px;border:1px solid rgba(255,255,255,.75);backdrop-filter: blur(6px);}
.badge.destaque{background:rgba(245,158,11,.92);color:#111827;}
.badge.pct{top:auto;bottom:8px;background:rgba(239,68,68,.92);color:#fff;}

/* Listas */
.list{display:flex;flex-direction:column;gap:10px;}
.card-row{display:flex;gap:12px;align-items:center;}
.list.clean .card-row{background:transparent;border:0;padding:0;}

/* CARD VISÍVEL SÓ PARA EMPRESAS */
.empresa-card{background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:16px;padding:12px;box-shadow:0 6px 16px rgba(15,23,42,.06);}
.thumb{width:66px;height:56px;border-radius:14px;background:#f3f4f6;border:1px solid rgba(15,23,42,.08);overflow:hidden;flex:0 0 auto;display:flex;align-items:center;justify-content:center;}
.thumb img{width:100%;height:100%;object-fit: contain;
  background:#fff;
  padding:6px;}
.row-main{min-width:0;flex:1;}
.row-title{font-weight:1000;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.row-sub{margin-top:4px;color:var(--muted);font-size:12px;display:flex;flex-direction:column;gap:2px;}
.chip{display:inline-flex;align-items:center;gap:6px;font-weight:900;font-size:12px;}
.chip-free{color:#16a34a;font-weight:1000;}

/* Status aberto/fechado */
.status-dot{width:10px;height:10px;border-radius:999px;display:inline-block;box-shadow:0 0 0 0 rgba(0,0,0,0);}
.status-dot.open{background:#22c55e;animation:pulseOpen 1.4s infinite;}
.status-dot.closed{background:#ef4444;animation:pulseClosed 1.4s infinite;}
@keyframes pulseOpen{0%{box-shadow:0 0 0 0 rgba(34,197,94,.55);}70%{box-shadow:0 0 0 10px rgba(34,197,94,0);}100%{box-shadow:0 0 0 0 rgba(34,197,94,0);}}
@keyframes pulseClosed{0%{box-shadow:0 0 0 0 rgba(239,68,68,.55);}70%{box-shadow:0 0 0 10px rgba(239,68,68,0);}100%{box-shadow:0 0 0 0 rgba(239,68,68,0);}}

/* Bottom bar (fixo, cor padrão do sistema) */
.bottombar{position:fixed;left:0;right:0;bottom:0;z-index:30;display:flex;justify-content:center;background:linear-gradient(135deg,var(--primary),var(--primary2));border-top:0;}
.bottombar-inner{width:min(460px, 100%);display:flex;justify-content:space-around;align-items:center;padding:7px 12px calc(7px + env(safe-area-inset-bottom));}
.navitem{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-weight:900;font-size:10px;color:rgba(255,255,255,.85);}
.navitem .ni{width:24px;height:24px;display:flex;align-items:center;justify-content:center;}
.navicon{width:24px;height:24px;}
.navbadge{position:absolute;top:-7px;right:-11px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#ef4444;color:#fff;font-weight:1000;font-size:11px;display:flex;align-items:center;justify-content:center;line-height:1;}
.navitem.active{color:#fff;}
.navitem.active::after{content:"";width:18px;height:3px;border-radius:999px;background:rgba(255,255,255,.95);margin-top:2px;}

/* Login */
.login-wrap{padding:18px 14px 24px;}
.brand{display:flex;align-items:center;gap:12px;margin:16px 0 18px;}
.brand .logo{width:54px;height:54px;border-radius:18px;background:#fff;border:1px solid rgba(15,23,42,.10);overflow:hidden;display:flex;align-items:center;justify-content:center;}
.brand .logo img{width:100%;height:100%;object-fit: contain;
  background:#fff;
  padding:6px;}
.brand .t{min-width:0;}
.brand .t .n{font-size:18px;font-weight:1000;line-height:1.1;}
.brand .t .s{margin-top:2px;font-size:12px;color:var(--muted);font-weight:800;}

.panel{background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:18px;padding:14px;box-shadow:0 16px 40px rgba(15,23,42,.06);}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:10px;}
.field label{font-size:12px;font-weight:1000;color:rgba(15,23,42,.75);}
.field input{height:44px;border-radius:14px;border:1px solid rgba(15,23,42,.10);padding:0 12px;font-size:14px;font-weight:800;outline:none;background:#fff;}
.field input:focus{border-color:rgba(37,99,235,.55);box-shadow:0 0 0 4px var(--ring);}

.btn-primary{width:100%;height:46px;border-radius:16px;border:0;background:linear-gradient(135deg, var(--primary), var(--primary2));color:#fff;font-weight:1000;font-size:14px;cursor:pointer;}
.mutetxt{margin-top:10px;color:var(--muted);font-size:12px;font-weight:700;line-height:1.35;}
.notice{margin:10px 0 0;padding:10px 12px;border-radius:14px;font-weight:900;font-size:13px;}
.notice.err{background:#fee2e2;border:1px solid #fecaca;color:#991b1b;}


/* ===== AJUSTE LARGURA EMPRESAS RECOMENDADAS ===== */
.empresa-card {
    background: transparent;
    border: none;
    box-shadow: none;
    border-radius: 0;
    padding: 14px 0;
    width: 100%;
    max-width: 920px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    gap: 14px;
    border-bottom: 1px solid #eee;
}

.empresa-card:last-child {
    border-bottom: none;
}

.lista-empresas {
    max-width: 920px;
    margin: 0 auto;
}



/* Ícone relógio (tempo médio) */
.ico-clock{width:14px;height:14px;display:inline-block;vertical-align:-2px;margin-right:4px;opacity:.75;}
.time{display:inline-flex;align-items:center;gap:0;}

/* Busca (categoria) */
.searchbar{padding:10px 14px;}
.searchbar .search{
  width:100%;
  border:1px solid rgba(15,23,42,.12);
  border-radius:14px;
  padding:12px 12px;
  outline:none;
  font-size:14px;
  background:#fff;
}
.searchbar .hint{font-size:12px;color:rgba(15,23,42,.55);margin-top:6px;}

/* ===== Busca (tabs) ===== */
.tabs{
  display:flex;
  gap:10px;
  margin:12px 0;
}
.tabs .tab{
  flex:1;
  border:1px solid rgba(0,0,0,.10);
  background:#fff;
  padding:10px 12px;
  border-radius:14px;
  font-weight:900;
  font-size:13px;
}
.tabs .tab.active{
  border-color: rgba(29,78,216,.35);
  box-shadow: 0 6px 18px rgba(29,78,216,.10);
}
.tab-panel{ display:none; }
.tab-panel.active{ display:block; }

/* ===== Busca - abas bonitas (igual app) ===== */
.seg-tabs{
  display:flex;
  gap:8px;
  padding: 0 16px 14px 16px;
}
.seg-tab{
  flex:1;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.10);
  background:#fff;
  font-weight:900;
  font-size:13px;
}

/* ==============================
   Página da Empresa (perfil)
   ============================== */
.empresa-page .content{padding-left:14px;padding-right:14px;}
.empresa-hero{position:relative;height:190px;background-size:cover;background-position:center;border-bottom-left-radius:0;border-bottom-right-radius:0;overflow:visible;}
.empresa-hero-overlay{
  position:absolute;
  inset:0;
  /* Efeito suave na capa: só um fade bem leve pro fundo */
  background:linear-gradient(180deg,
    rgba(0,0,0,0) 0%,
    rgba(0,0,0,0) 70%,
    rgba(243,246,251,.86) 100%
  );
}
.empresa-hero-top{position:absolute;left:0;right:0;top:0;display:flex;justify-content:space-between;align-items:center;padding:12px 14px;z-index:2;}
.empresa-hero-actions{display:flex;gap:10px;}
.empresa-hero-btn{width:40px;height:40px;border-radius:14px;border:1px solid rgba(255,255,255,.55);background:rgba(255,255,255,.20);backdrop-filter: blur(8px);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:1000;cursor:pointer;}
.empresa-hero-btn:active{transform:scale(.98);}
.empresa-hero-logo{position:absolute;left:50%;bottom:-32px;transform:translateX(-50%);width:84px;height:84px;border-radius:999px;border:4px solid #000;background:#fff;overflow:hidden;z-index:3;box-shadow:0 10px 22px rgba(15,23,42,.18);display:flex;align-items:center;justify-content:center;padding:10px;}
.empresa-hero-logo img{width:100%;height:100%;object-fit:contain;}
.empresa-hero-logo-fb{font-size:30px;}

.empresa-title{margin-top:10px;text-align:center;}
.empresa-name{font-weight:1000;font-size:20px;line-height:1.1;}
.empresa-meta{margin-top:6px;color:rgba(15,23,42,.70);font-weight:900;font-size:13px;display:flex;justify-content:center;align-items:center;gap:8px;flex-wrap:wrap;}

/* Abas da página da empresa */
.empresa-tabs{
  margin: 14px auto 6px;
  width: min(460px, 100%);
  display:flex;
  gap:8px;
  overflow:auto;
  scrollbar-width:none;
  padding: 4px 4px 8px;
}
.empresa-tabs::-webkit-scrollbar{display:none;}
.empresa-tab{
  flex:0 0 auto;
  padding:10px 12px;
  border-radius:16px;
  border:1px solid rgba(15,23,42,.10);
  background:#fff;
  font-weight:1000;
  font-size:13px;
  color:rgba(15,23,42,.80);
  cursor:pointer;
  white-space:nowrap;
}
.empresa-tab.active{
  border-color: rgba(29,78,216,.45);
  background: rgba(29,78,216,.08);
  color:var(--primary);
  box-shadow: 0 10px 20px rgba(29,78,216,.10);
}
.empresa-panel{display:none;margin-top:10px;}
.empresa-panel.active{display:block;}

.empresa-seg{margin:14px 0 8px;display:flex;gap:10px;overflow:auto;scrollbar-width:none;padding:2px 2px 8px;}
.empresa-seg::-webkit-scrollbar{display:none;}
.empresa-chip{flex:0 0 auto;padding:11px 14px;border-radius:16px;border:1px solid rgba(29,78,216,.45);background:#fff;font-weight:1000;color:var(--primary);}
.empresa-chip.active{background:var(--primary);color:#fff;border-color:var(--primary);}

.empresa-info{background:transparent;border:0;border-radius:0;padding:0;box-shadow:none;display:flex;flex-wrap:wrap;gap:6px;align-items:center;}
.empresa-info-row{display:flex;gap:12px;align-items:center;padding:10px 0;border-bottom:1px solid rgba(15,23,42,.06);}
.empresa-info-row:last-child{border-bottom:0;}
.empresa-info-label{width:102px;flex:0 0 auto;font-size:13px;color:rgba(15,23,42,.60);font-weight:1000;}
.empresa-info-val{flex:1;min-width:0;font-size:14px;font-weight:900;color:rgba(15,23,42,.88);}
.empresa-info-val .muted{color:rgba(15,23,42,.55);font-weight:800;}
.empresa-info-val .link{color:var(--primary);font-weight:1000;}
.pay-chip{display:inline-flex;align-items:center;gap:8px;padding:7px 10px;border-radius:999px;border:1px solid rgba(15,23,42,.10);background:#fff;font-weight:1000;font-size:12px;margin-right:8px;margin-bottom:6px;}
.pay-chip .ico{font-size:15px;line-height:1;}

/* Botão WhatsApp (contato) */
.btn-zap{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 14px;
  border-radius:14px;
  background:#25D366;
  color:#fff;
  font-weight:1000;
  text-decoration:none;
  box-shadow:0 10px 20px rgba(37,211,102,.25);
}
.btn-zap:active{transform:scale(.99);}
.btn-zap .zap-ico{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;}
.btn-zap .zap-ico svg{width:22px;height:22px;display:block;fill:#fff;}

/* Aba: Grupo do zap (full width + tipografia maior) */
.zap-grupo-card{padding:16px 14px;margin:0 -14px;border-radius:0;}
.zap-grupo-title{font-weight:1000;font-size:22px;line-height:1.1;color:rgba(15,23,42,.92);}
.zap-grupo-sub{font-size:15px;line-height:1.35;font-weight:850;color:rgba(15,23,42,.78);}
.zap-grupo-card .btn-zap{padding:10px 14px;border-radius:12px;font-size:14px;}

/* Redes sociais */
.social-buttons{display:flex;flex-wrap:wrap;gap:10px;}
.btn-social{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(15,23,42,.10);
  background:#fff;
  text-decoration:none;
  font-weight:1000;
  color:rgba(15,23,42,.88);
  box-shadow:0 10px 20px rgba(15,23,42,.05);
}
.btn-social:active{transform:scale(.99);}
.btn-social .ico{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;}
.btn-social .ico svg{width:20px;height:20px;display:block;fill:currentColor;}
.btn-social.ig{color:#e11d48;}
.btn-social.fb{color:#2563eb;}

/* Descrição da empresa (layout editorial / Medium) */
.empresa-desc-hero{
  margin: 6px 0 18px;
}
.empresa-desc-titleline{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:1000;
  font-size:16px;
  color:rgba(15,23,42,.92);
  margin: 0 0 10px;
}
.empresa-desc-ico{
  width:22px;
  height:22px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:rgba(15,23,42,.65);
}
.empresa-desc-ico svg{width:22px;height:22px;display:block;fill:currentColor;}
.empresa-desc-body{
  color:rgba(15,23,42,.88);
  font-size:16px;
  line-height:1.9;
  letter-spacing:.01em;
}
.empresa-desc-body p{margin:0 0 14px;}
.empresa-desc-body p:last-child{margin-bottom:0;}
.empresa-desc-body ul,.empresa-desc-body ol{margin:0 0 14px 20px;}
.empresa-desc-body a{text-decoration:underline;font-weight:1000;}
/* Drop cap (primeira letra estilo revista) */
.empresa-desc-body p:first-of-type::first-letter{
  float:left;
  font-size:56px;
  line-height:.92;
  padding-right:10px;
  padding-top:4px;
  font-weight:1000;
  color:rgba(15,23,42,.92);
}


/* Modal Galeria (carousel simples) */
.gal-modal{position:fixed;inset:0;background:rgba(15,23,42,.55);display:none;align-items:center;justify-content:center;padding:18px;z-index:9999;}
.gal-modal.open{display:flex;}
.gal-card{width:min(520px, 100%);background:#fff;border-radius:18px;overflow:hidden;position:relative;box-shadow:0 24px 60px rgba(0,0,0,.35);}
.gal-close{position:absolute;top:10px;right:10px;width:38px;height:38px;border-radius:14px;border:1px solid rgba(15,23,42,.12);background:#fff;font-size:22px;font-weight:1000;cursor:pointer;z-index:3;}
.gal-stage{width:100%;aspect-ratio: 1 / 1;max-height:72vh;background:#0b1020;display:flex;align-items:center;justify-content:center;}
.gal-stage img{max-width:100%;max-height:100%;object-fit:contain;display:block;}
.gal-nav{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:16px;border:1px solid rgba(255,255,255,.35);background:rgba(255,255,255,.15);backdrop-filter: blur(8px);color:#fff;font-size:24px;font-weight:1000;cursor:pointer;z-index:2;}
.gal-nav.prev{left:10px;}
.gal-nav.next{right:10px;}
.gal-thumbs{display:flex;gap:8px;overflow:auto;padding:10px 12px;background:#fff;scrollbar-width:none;}
.gal-thumbs::-webkit-scrollbar{display:none;}
.gal-thumb{flex:0 0 auto;width:58px;height:58px;border-radius:14px;overflow:hidden;border:2px solid transparent;cursor:pointer;background:#f3f6fb;}
.gal-thumb.active{border-color:rgba(15,23,42,.75);}
.gal-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.empresa-comods{display:flex;flex-wrap:wrap;gap:8px;}
.comod-chip{display:inline-flex;align-items:center;gap:8px;padding:7px 10px;border-radius:999px;background:rgba(29,78,216,.08);border:1px solid rgba(29,78,216,.18);font-weight:1000;font-size:12px;color:rgba(15,23,42,.85);}
.empresa-divider{height:14px;}

.empresa-section{margin:14px 0 10px;font-size:16px;font-weight:1000;color:rgba(15,23,42,.88);}
.empresa-list{display:flex;flex-direction:column;gap:10px;}
.empresa-item{width:100%;text-align:left;border:1px solid rgba(15,23,42,.08);background:#fff;border-radius:18px;padding:12px;display:flex;gap:12px;align-items:stretch;cursor:pointer;box-shadow:0 8px 18px rgba(15,23,42,.04);text-decoration:none;color:inherit;}
.empresa-item:active{transform:scale(.995);}
.empresa-item.empty{cursor:default;box-shadow:none;opacity:.85;}
.empresa-item-main{flex:1;min-width:0;}
.empresa-item-title{font-weight:1000;font-size:14px;line-height:1.2;}
.empresa-item-desc{margin-top:4px;color:rgba(15,23,42,.62);font-weight:800;font-size:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.empresa-item-price{margin-top:8px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.empresa-item-price .old{text-decoration:line-through;color:rgba(100,116,139,.95);font-weight:900;font-size:12px;}
.empresa-item-price .now{font-weight:1000;font-size:13px;}
.empresa-item-price .pct{font-weight:1000;font-size:12px;background:rgba(29,78,216,.10);border:1px solid rgba(29,78,216,.18);color:var(--primary);padding:4px 8px;border-radius:999px;}
.empresa-item-side{display:flex;flex-direction:column;align-items:flex-end;gap:10px;}
.empresa-item-thumb{width:92px;height:72px;border-radius:16px;border:1px solid rgba(15,23,42,.08);background:#f3f4f6;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.empresa-item-thumb img{width:100%;height:100%;object-fit:cover;}
.empresa-item-thumb .fb{font-size:22px;}
.empresa-item-cta{font-weight:1000;color:var(--primary);font-size:13px;}
.empresa-item.pulse{outline:3px solid rgba(29,78,216,.25);}

/* Modal */
.empresa-modal{position:fixed;inset:0;background:rgba(15,23,42,.50);display:none;align-items:flex-end;justify-content:center;z-index:60;padding:16px;}
.empresa-modal.open{display:flex;}
.empresa-modal-card{width:min(460px, 100%);background:#fff;border-radius:22px;padding:14px 14px 16px;box-shadow:0 24px 60px rgba(0,0,0,.25);position:relative;}
.empresa-modal-close{position:absolute;right:10px;top:10px;width:40px;height:40px;border-radius:14px;border:1px solid rgba(15,23,42,.10);background:#fff;font-weight:1000;font-size:22px;cursor:pointer;}
.empresa-modal-head{display:flex;gap:12px;align-items:center;}
.empresa-modal-thumb{width:76px;height:76px;border-radius:18px;border:1px solid rgba(15,23,42,.08);background:#f3f4f6;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.empresa-modal-thumb img{width:100%;height:100%;object-fit:cover;}
.empresa-modal-thumb .fb{font-size:22px;}
.empresa-modal-title{font-weight:1000;font-size:16px;line-height:1.2;}
.empresa-modal-price{margin-top:6px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-weight:1000;}
.empresa-modal-price .old{text-decoration:line-through;color:rgba(100,116,139,.95);font-weight:900;font-size:12px;}
.empresa-modal-price .now{font-weight:1000;font-size:14px;}
.empresa-modal-price .pct{font-weight:1000;font-size:12px;background:rgba(29,78,216,.10);border:1px solid rgba(29,78,216,.18);color:var(--primary);padding:4px 8px;border-radius:999px;}
.empresa-modal-desc{margin-top:12px;color:rgba(15,23,42,.70);font-weight:800;font-size:13px;line-height:1.35;white-space:pre-wrap;}
.empresa-modal-actions{margin-top:14px;}

/* ===== Modal genérico (offline / avisos) ===== */
.app-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:18px;background:rgba(15,23,42,.55);z-index:9999;}
.app-modal.open{display:flex;}
.app-modal-card{width:min(460px,100%);background:#fff;border-radius:22px;padding:16px 14px 14px;box-shadow:0 24px 60px rgba(0,0,0,.25);}
.app-modal-title{font-weight:1000;font-size:17px;line-height:1.2;color:#0f172a;}
.app-modal-text{margin-top:8px;color:rgba(15,23,42,.75);font-weight:800;font-size:13px;line-height:1.35;}
.app-modal-actions{margin-top:14px;display:flex;gap:10px;}
.app-modal-actions .btn{margin-top:0;}
.app-modal-illustration{display:flex;justify-content:center;align-items:center;margin:6px 0 10px;}

.app-modal-illustration img.app-modal-img{width:140px;height:auto;max-width:65vw;}
.app-modal-illustration svg{width:140px;height:auto;max-width:65vw;}

/* Encartes */
.encartes-wrap{display:flex;flex-direction:column;gap:12px;}
.encarte-card{background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:18px;padding:12px;box-shadow:0 10px 24px rgba(15,23,42,.05);}
.encarte-title{font-weight:1000;font-size:14px;margin-bottom:10px;}
.encarte-grid{display:grid;grid-template-columns: repeat(2, 1fr);gap:10px;}
.encarte-media{display:block;border-radius:16px;overflow:hidden;border:1px solid rgba(15,23,42,.08);background:#f8fafc;min-height:110px;}
.encarte-media img{width:100%;height:100%;object-fit:cover;display:block;}
.encarte-media.pdf{display:flex;align-items:center;justify-content:center;font-weight:1000;color:var(--primary);background:rgba(29,78,216,.06);min-height:110px;}

/* Galeria */
.galeria-grid{display:grid;grid-template-columns: repeat(3, 1fr);gap:10px;}
@media (min-width: 520px){ .galeria-grid{ grid-template-columns: repeat(4, 1fr);} }
.galeria-img{display:block;border-radius:16px;overflow:hidden;border:1px solid rgba(15,23,42,.08);background:#fff;aspect-ratio:1/1;padding:0;cursor:pointer;}
.galeria-img:focus{outline:3px solid rgba(29,78,216,.22);outline-offset:2px;}
.galeria-img img{width:100%;height:100%;object-fit:cover;display:block;}

/* Localização */
.local-card{background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:18px;padding:12px;box-shadow:0 10px 24px rgba(15,23,42,.05);}
.local-title{font-weight:1000;font-size:14px;}
.local-addr{margin-top:6px;color:rgba(15,23,42,.70);font-weight:800;font-size:13px;line-height:1.35;}
.map-wrap{margin-top:10px;border-radius:18px;overflow:hidden;border:1px solid rgba(15,23,42,.08);background:#f3f4f6;}
.map-wrap iframe{width:100%;height:260px;border:0;display:block;}
.btn-map{margin-top:10px;display:inline-flex;align-items:center;justify-content:center;width:100%;height:46px;border-radius:16px;border:0;background:linear-gradient(135deg, var(--primary), var(--primary2));color:#fff;font-weight:1000;font-size:14px;}
.seg-tab.active{
  border-color: rgba(29,78,216,.35);
  box-shadow: 0 6px 18px rgba(29,78,216,.10);
}


/* ===== Busca (segmented tabs bonitas) ===== */
.seg-tabs{
  display:flex;
  gap:0;
  background: rgba(0,0,0,.05);
  border-radius: 16px;
  padding: 4px;
  margin: 12px 0 8px;
  border: 1px solid rgba(0,0,0,.06);
}
.seg-tab{
  flex:1;
  border:0;
  background: transparent;
  padding: 10px 12px;
  border-radius: 12px;
  font-weight: 900;
  font-size: 13px;
  color: rgba(0,0,0,.65);
  cursor:pointer;
}
.seg-tab.active{
  background: #fff;
  color: rgba(0,0,0,.92);
  box-shadow: 0 6px 18px rgba(0,0,0,.08);
}
/* garantia: painel nunca fica invisível */
.tab-panel{ display:block !important; }


/* ===== SYSTEM_WHITE_BG_FORCE ===== */
html, body{
  background:#ffffff !important;
}

/* ===== LOGO EMPRESA QUADRADA ===== */
.empresa-card .thumb img,
.card-row .thumb img,
.top-lojas img{
  width:60px;
  height:60px;
  object-fit: contain;
  background:#fff;
  padding:6px;
  border-radius:5px !important; /* levemente arredondado */
}

/* ===== BUTTON_HEIGHT_ADJUST ===== */
button,
.btn,
.seg-tab{
  padding:8px 12px !important;
  height:auto !important;
  font-size:13px !important;
  border-radius:10px;
}

/* ===== ENSURE BOTTOM NAV VISIBLE ON SEARCH PAGES ===== */
.bottom-nav{
  display:flex !important;
}

/* ===== Empresa card: 3 linhas (bairro / categoria / infos) ===== */
.empresa-bairro{
  font-size:13px;
  font-weight:700;
  color: rgba(0,0,0,.92);
  line-height: 1.2;
}
.empresa-categoria{
  font-size:12px;
  font-weight:800;
  color: var(--primary);
  margin-top:2px;
  line-height: 1.2;
}
.empresa-info{background:transparent;border:0;border-radius:0;padding:0;box-shadow:none;display:flex;flex-wrap:wrap;gap:6px;align-items:center;}
.empresa-info .status-dot{ margin-right:6px; }


/* ===== Card empresa alinhamento refinado ===== */
.card-row.empresa-card{
  align-items: center;
}

.card-row .thumb{
  width: 70px;
  height: 70px;
  min-width: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.card-row .thumb img{
  width: 60px;
  height: 60px;
  object-fit: contain;
  border-radius: 5px;
  background: #fff;
}

/* Categoria com ícone */
.empresa-categoria{
  font-size:12px;
  font-weight:800;
  color: var(--primary);
  margin-top:3px;
  display:flex;
  align-items:center;
  gap:6px;
}


/* ===== Página Categorias (grid + busca) ===== */
.page-title{ padding: 10px 16px 0; }
.page-title h2{ margin:0; font-size:18px; }
.page-title .subhint{ margin-top:4px; font-size:12px; color: rgba(0,0,0,.55); }

.searchbar{ padding: 12px 16px; }
.searchbar input{
  width:100%;
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 14px;
  padding: 11px 12px;
  font-size: 14px;
  outline:none;
  background:#fff;
}

.grid-categorias{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  padding: 0 16px 18px;
}
@media (min-width: 520px){
  .grid-categorias{ grid-template-columns: repeat(4, 1fr); }
}
.cat-tile{
  display:block;
  text-decoration:none;
  color: inherit;
}
.cat-img{
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 14px;
  overflow:hidden;
  border: 1px solid rgba(0,0,0,.06);
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
}
.cat-img img{
  width:100%;
  height:100%;
  object-fit: cover;
}
.cat-emoji{ font-size: 26px; }
.cat-name{
  margin-top: 8px;
  font-size: 12px;
  font-weight: 900;
  line-height: 1.1;
  text-align:center;
  color: rgba(0,0,0,.88);
}

/* Header estilo Home */
.home-header{ padding: 10px 16px 8px; background:#fff; }
.home-brand{ display:flex; align-items:center; gap:12px; }
.home-logo{
  width:44px; height:44px; object-fit:contain;
  border-radius: 10px;
  background:#fff;
  border: 1px solid rgba(0,0,0,.06);
  padding:4px;
}
.home-logo-fallback{
  width:44px; height:44px;
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-weight:900; background: rgba(0,0,0,.06);
}
.home-brand-name{ font-weight: 900; font-size: 14px; }
.home-brand-addr{ font-size: 12px; color: rgba(0,0,0,.62); text-decoration:none; }

/* ===== Página Destaques (grid) ===== */
.grid-high{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  padding: 0 16px 18px;
}
@media (min-width: 520px){
  .grid-high{ grid-template-columns: repeat(3, 1fr); }
}
.high-tile{ display:block; text-decoration:none; color:inherit; }
.high-img{
  width:100%;
  aspect-ratio: 1 / 1;
  border-radius: 14px;
  overflow:hidden;
  border: 1px solid rgba(0,0,0,.06);
  background:#fff;
  position:relative;
  display:flex; align-items:center; justify-content:center;
}
.high-img img{ width:100%; height:100%; object-fit:cover; }
.high-name{ margin-top:8px; font-size:12px; font-weight:900; line-height:1.1; }
.high-sub{ margin-top:4px; font-size:12px; color: rgba(0,0,0,.62); }

.badge{
  position:absolute;
  top:8px;
  left:8px;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius: 999px;
  padding:4px 8px;
  font-size:11px;
  font-weight:900;
}
.badge-off{ left:auto; right:8px; }
.badge-dest{}


/* ===== Ajuste tamanho porcentagem Home (destaques horizontal) ===== */
.hscroll .badge,
.hscroll .badge-off{
  font-size:10px !important;
  padding:3px 6px !important;
  border-radius:999px;
}



/* ===== HOME - diminuir % dentro dos cards mini (destaques horizontal) ===== */
.mini-card .badge,
.mini-card .badge-off{
  font-size:9px !important;
  padding:2px 5px !important;
  top:6px !important;
  right:6px !important;
}



/* ===== HOME - porcentagem bem pequena (mini-card slider) ===== */
.mini-card .badge,
.mini-card .badge-off{
  font-size:7px !important;
  padding:1px 4px !important;
  line-height:1 !important;
  border-radius:999px !important;
  top:4px !important;
  right:4px !important;
  min-width:auto !important;
}



/* ===== HOME - corrigir badge grande (mini-card) ===== */
.mini-card .badge,
.mini-card .badge-off{
  font-size:7px !important;
  padding:1px 4px !important;
  line-height:1 !important;
  border-radius:999px !important;
  top:4px !important;
  right:4px !important;
  min-width:unset !important;
  width:auto !important;
  height:auto !important;
  display:inline-block !important;
}



/* ===== HOME - remover badge e porcentagem dos destaques ===== */
.mini-card .badge,
.mini-card .badge-off{
  display:none !important;
}


/* ===== Botão buscar endereço ===== */
.btn-locate{
  width:100%;
  margin-bottom:12px;
  background:#fff !important;
  color: var(--primary) !important;
  border: 1px solid rgba(0,0,0,.10) !important;
}
.btn-locate.is-loading{
  opacity:.7;
}

/* ===== Endereço: número + sem número ===== */
.field-row{
  display:flex;
  gap:10px;
  align-items:center;
}
.check-inline{
  display:flex;
  gap:6px;
  align-items:center;
  font-size:12px;
  color: rgba(0,0,0,.65);
  white-space:nowrap;
}
.check-inline input{ width:16px; height:16px; }
.hint{
  margin-top:6px;
  font-size:12px;
  color: rgba(0,0,0,.55);
}

/* Correção extra: endereço nunca estoura a lateral */
.brand-mini-addr{max-width:100%;}
.brand-mini-addr .sub{max-width: min(240px, calc(100vw - 190px));}


/* ===== Encartes (Stories) ===== */
.stories-list{display:flex;flex-direction:column;gap:12px}
.story-card{width:100%;display:flex;gap:12px;align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:10px;text-align:left;box-shadow:0 8px 20px rgba(0,0,0,.05)}
.story-thumb{width:62px;height:62px;border-radius:16px;overflow:hidden;background:#f3f4f6;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.story-thumb img{width:100%;height:100%;object-fit:cover}
.story-thumb-fallback{font-size:26px}
.story-meta{flex:1;min-width:0}
.story-title{font-weight:900;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.story-sub{margin-top:4px;color:#6b7280;font-size:12px;display:flex;gap:6px;align-items:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.story-sub .dot{opacity:.6}

.story-viewer{position:fixed;inset:0;background:#000;z-index:9999;display:none}
.story-viewer.open{display:block}
.story-top{position:absolute;left:0;right:0;top:0;padding:10px 12px 0 12px}
.story-bars{display:flex;gap:6px}
.story-bars .bar{flex:1;height:3px;background:rgba(255,255,255,.25);border-radius:999px;overflow:hidden}
.story-bars .bar .fill{height:100%;width:0;background:#fff;border-radius:999px}
.story-head{display:flex;justify-content:space-between;align-items:center;margin-top:10px;color:#fff}
.story-head-left{display:flex;gap:10px;align-items:center;min-width:0}
.story-avatar{width:34px;height:34px;border-radius:12px;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center}
.story-head-txt{min-width:0}
.story-head-title{font-weight:900;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:56vw}
.story-head-sub{font-size:12px;opacity:.85;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:56vw}
.story-head-right{display:flex;gap:10px;align-items:center}
.story-timer{font-size:12px;opacity:.9}
.story-close{border:none;background:rgba(255,255,255,.15);color:#fff;width:34px;height:34px;border-radius:12px;font-size:16px}

.story-stage{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.story-media{max-width:100%;max-height:100%;object-fit:contain}
.story-pdf{display:none;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:#fff;text-align:center;padding:20px}
.story-pdf-ico{font-size:56px}
.story-pdf-btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 16px;border-radius:14px;background:#ff6b00;border:none;color:#fff;text-decoration:none;font-weight:900}

.story-tap{position:absolute;top:0;bottom:0;width:35%}
.story-tap-left{left:0}
.story-tap-right{right:0}

.story-products-btn{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);border:none;background:rgba(255,255,255,.15);color:#fff;padding:12px 16px;border-radius:16px;font-weight:900;backdrop-filter:blur(8px)}

.prod-sheet{position:absolute;left:0;right:0;bottom:-100%;background:#fff;border-top-left-radius:18px;border-top-right-radius:18px;box-shadow:0 -10px 30px rgba(0,0,0,.35);transition:bottom .2s ease;max-height:65%;display:flex;flex-direction:column}
.prod-sheet.open{bottom:0}
.prod-sheet-top{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid #e5e7eb}
.prod-sheet-title{font-weight:900}
.prod-sheet-close{border:none;background:#f3f4f6;border-radius:12px;padding:8px 12px;font-weight:900}
.prod-sheet-list{padding:12px 14px;overflow:auto;display:flex;flex-direction:column;gap:10px}
.prod-card{border:1px solid #e5e7eb;border-radius:14px;padding:10px;display:flex;gap:10px;align-items:flex-start}
.prod-card.clickable{cursor:pointer}
.prod-img{width:62px;height:62px;border-radius:14px;background:#f3f4f6;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:26px;flex:0 0 auto}
.prod-img img{width:100%;height:100%;object-fit:cover}
.prod-meta{flex:1;min-width:0}
.prod-name{font-weight:900}
.prod-price{margin-top:4px;font-weight:900;color:#16a34a}
.prod-desc{margin-top:6px;color:#6b7280;font-size:12px;line-height:1.25}

/* ===== Encarte Modal (feed/instagram: swipe + bolinhas + X) ===== */
.encarte-modal{position:fixed;inset:0;background:#0b0b0b;z-index:9999;display:none;flex-direction:column}
.encarte-modal.open{display:flex}
.encarte-modal-top{display:flex;justify-content:space-between;align-items:center;padding:12px 12px 10px;color:#fff;gap:10px}
.encarte-modal-title{font-weight:1000;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:62vw}
.encarte-modal-right{display:flex;align-items:center;gap:10px}
.encarte-modal-countdown{font-size:12px;opacity:.9;white-space:nowrap}
.encarte-modal-close{border:none;background:rgba(255,255,255,.14);color:#fff;width:36px;height:36px;border-radius:14px;font-size:22px;line-height:1;cursor:pointer}

.encarte-modal-stage{position:relative;flex:1;min-height:0;display:flex;flex-direction:column}
.encarte-carousel{flex:1;min-height:0;display:flex;overflow:auto;scroll-snap-type:x mandatory;scrollbar-width:none}
.encarte-carousel::-webkit-scrollbar{display:none}
.encarte-slide{flex:0 0 100%;scroll-snap-align:start;display:flex;align-items:center;justify-content:center;position:relative}
.encarte-slide img{max-width:100%;max-height:100%;object-fit:contain}
.encarte-slide .encarte-pdf{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#fff;text-align:center;padding:20px}
.encarte-slide .encarte-pdf .ico{font-size:54px}
.encarte-slide .encarte-pdf a{display:inline-flex;align-items:center;justify-content:center;padding:12px 16px;border-radius:14px;background:#ff6b00;border:none;color:#fff;text-decoration:none;font-weight:900}

.encarte-dots{display:flex;justify-content:center;gap:8px;padding:10px 0 12px}
.encarte-dot{width:7px;height:7px;border-radius:999px;background:rgba(255,255,255,.35)}
.encarte-dot.active{width:18px;background:rgba(255,255,255,.95)}

.encarte-modal-products{background:#fff;border-top-left-radius:18px;border-top-right-radius:18px;padding:12px 12px 18px;max-height:42vh;overflow:auto}
.encarte-products-title{font-weight:1000;margin-bottom:10px}
.encarte-products-grid{display:flex;flex-direction:column;gap:10px}
