@import url('https://fonts.googleapis.com/css2?family=Nunito+Sans:ital,opsz,wght@0,6..12,400;0,6..12,600;0,6..12,700;0,6..12,800;0,6..12,900&display=swap');

:root{
  --red:#EA1D2C; --red-dark:#C20C18; --red-soft:#FEF0F0;
  --bg:#F7F7F7; --surface:#FFFFFF; --text:#3F3E3E; --muted:#717171; --soft:#A5A5A5;
  --line:#EEEEEE; --line2:#E2E2E2; --green:#157A4A; --green-soft:#EAF6EF;
  --star:#E7A74E;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Nunito Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  background:var(--bg); color:var(--text); -webkit-font-smoothing:antialiased; line-height:1.45}
a{color:inherit}
.wrap{max-width:760px;margin:0 auto;padding:0 16px}

.btn{cursor:pointer;border:none;font-family:inherit;font-weight:800;border-radius:8px;
  transition:transform .1s ease,background .15s ease,box-shadow .15s ease}
.btn:active{transform:scale(.98)}
.btn:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible{outline:2.5px solid var(--red);outline-offset:2px}
.btn-primary{background:var(--red);color:#fff;padding:15px 18px}
.btn-primary:disabled{background:#D9D9D9;color:#fff;cursor:not-allowed}
.btn-dark{background:var(--red);color:#fff;padding:12px 18px}
.btn-ghost{background:#fff;color:var(--red);padding:9px 16px;border:1.5px solid var(--line2)}

/* topo estilo app (branco, fixo) */
.appbar{position:sticky;top:0;z-index:30;background:#fff;border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:12px;padding:12px 16px}
.appbar .back{display:grid;place-items:center;width:34px;height:34px;flex-shrink:0;text-decoration:none;color:var(--text)}
.appbar .loc{flex:1;min-width:0}
.appbar .loc .lbl{font-size:11px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.03em}
.appbar .loc .val{font-size:14px;font-weight:800;display:flex;align-items:center;gap:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.appbar .adm{font-size:12.5px;font-weight:800;color:var(--red);text-decoration:none;white-space:nowrap}

/* cabeçalho do restaurante */
.resto{background:#fff;padding:18px 0 8px}
.resto .head{display:flex;align-items:center;gap:14px}
.resto .avatar{width:62px;height:62px;border-radius:14px;background:var(--red-soft);display:grid;place-items:center;
  flex-shrink:0;border:1px solid var(--line)}
.resto h1{margin:0;font-size:22px;font-weight:900;letter-spacing:-.01em}
.resto .tags{margin:3px 0 0;font-size:13px;color:var(--muted);font-weight:700;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.resto .star{color:var(--star);font-weight:900;display:inline-flex;align-items:center;gap:3px}
.infobar{display:flex;gap:8px;margin-top:14px;overflow-x:auto;padding-bottom:2px}
.infochip{flex-shrink:0;background:#fff;border:1px solid var(--line2);border-radius:10px;padding:8px 12px;
  font-size:12.5px;font-weight:800;display:flex;align-items:center;gap:7px;white-space:nowrap}
.infochip .k{color:var(--muted);font-weight:700}
.infochip.open{border-color:#BDE3CD;color:var(--green);background:var(--green-soft)}
.infochip .free{color:var(--green)}

/* busca */
.searchwrap{background:#fff;padding:12px 0 16px;position:sticky;top:59px;z-index:20}
.search{display:flex;align-items:center;gap:9px;background:var(--bg);border:1px solid var(--line2);
  border-radius:10px;padding:11px 14px}
.search input{border:none;background:none;outline:none;font-family:inherit;font-size:15px;width:100%;color:var(--text)}
.search input::placeholder{color:var(--soft)}

/* categorias */
.catnav{position:sticky;top:124px;z-index:15;background:var(--bg);padding:12px 0;display:flex;gap:8px;overflow-x:auto}
.chip{display:flex;align-items:center;gap:7px;white-space:nowrap;padding:9px 15px;border-radius:999px;
  font-size:13.5px;font-weight:800;background:#fff;color:var(--text);border:1px solid var(--line2);text-decoration:none}
.chip.on,.chip:hover{background:var(--red);color:#fff;border-color:var(--red)}
.chip svg{flex-shrink:0}

/* seções e itens (lista estilo app) */
.section{margin-top:8px}
.section h2{font-size:18px;font-weight:900;letter-spacing:-.01em;margin:18px 0 6px;padding-top:6px;scroll-margin-top:170px}
.menu-list{background:#fff;border-radius:12px;overflow:hidden;border:1px solid var(--line)}
.card{display:flex;gap:12px;background:#fff;padding:14px;border-bottom:1px solid var(--line)}
.card:last-child{border-bottom:none}
.card.off{opacity:.5}
.card .info{flex:1;min-width:0}
.card h3{margin:0;font-size:15.5px;font-weight:800}
.card .desc{margin:4px 0 8px;font-size:13px;color:var(--muted);font-weight:600;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card .price{font-size:15px;font-weight:800}
.card .tag-out{margin-left:8px;font-size:12px;font-weight:800;color:var(--red)}
.aside{position:relative;width:96px;height:96px;flex-shrink:0}
.thumb{width:96px;height:96px;border-radius:10px;background:var(--red-soft);display:grid;place-items:center;border:1px solid var(--line)}
.thumb svg{transform:scale(1.9);opacity:.85}
.add{position:absolute;right:-7px;bottom:-7px;width:34px;height:34px;border-radius:9px;background:#fff;
  border:1px solid var(--line2);color:var(--red);display:grid;place-items:center;cursor:pointer;
  box-shadow:0 2px 8px rgba(0,0,0,.12)}
.add span{display:none}
.stepper{position:absolute;right:-7px;bottom:-7px;display:flex;align-items:center;gap:2px;background:#fff;
  border:1px solid var(--line2);border-radius:9px;padding:3px 4px;box-shadow:0 2px 8px rgba(0,0,0,.12)}
.stepper button{background:none;border:none;cursor:pointer;display:grid;place-items:center;padding:2px}
.stepper .q{font-weight:900;font-size:14px;min-width:16px;text-align:center;color:var(--red)}

/* sacola flutuante */
.cartbar{position:fixed;left:0;right:0;bottom:0;padding:12px 16px;display:flex;justify-content:center;pointer-events:none;z-index:40}
.cartbar a{pointer-events:auto;width:100%;max-width:728px;background:var(--red);color:#fff;border-radius:10px;
  padding:15px 18px;display:flex;align-items:center;justify-content:space-between;font-size:15px;font-weight:800;
  text-decoration:none;box-shadow:0 6px 18px rgba(234,29,44,.4)}
.cartbar .badge{background:rgba(255,255,255,.25);border-radius:7px;padding:2px 9px;font-size:14px;margin-right:9px}
.cartbar .tot{font-weight:900}

/* página de sacola / checkout */
.page-head{display:flex;align-items:center;gap:12px;padding:16px 0}
.page-head .back{background:#fff;border:1px solid var(--line2);border-radius:10px;width:38px;height:38px;display:grid;place-items:center;text-decoration:none;color:var(--text)}
.page-head h1{margin:0;font-size:20px;font-weight:900}
.panel{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px;margin-bottom:14px}
.line{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--line)}
.line:last-child{border-bottom:none}
.line .lt{flex:1;min-width:0}
.line .lt .n{font-size:14.5px;font-weight:800}
.line .lt .p{font-size:13px;color:var(--muted);font-weight:700}
.qbox{display:flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--line2);border-radius:9px;padding:4px 8px}
.qbox button{background:none;border:none;cursor:pointer;display:grid;place-items:center}
.qbox .q{font-weight:900;font-size:14px;min-width:16px;text-align:center;color:var(--red)}
.row{display:flex;justify-content:space-between;align-items:baseline;font-size:14px;padding:4px 0;font-weight:700}
.row .k{color:var(--muted)}
.row .v{font-weight:800}
.total{display:flex;justify-content:space-between;align-items:baseline;margin:10px 0 14px}
.total .k{font-size:16px;font-weight:900}
.total .v{font-size:22px;font-weight:900}
.note{font-size:12.5px;font-weight:800;margin:6px 0 0}
.note.green{color:var(--green)} .note.red{color:var(--red)}

#map{width:100%;height:300px;border-radius:12px;border:1px solid var(--line2);overflow:hidden;background:#eee}
.legend{display:flex;gap:12px;flex-wrap:wrap;font-size:12px;color:var(--muted);margin-top:10px;font-weight:700}
.legend span{display:flex;align-items:center;gap:5px}
.legend .sw{width:9px;height:9px;border-radius:9px;display:inline-block}

label.fld{display:block;margin-bottom:12px}
label.fld>span{font-size:13px;font-weight:800;display:block;margin-bottom:6px}
.inp{font-family:inherit;font-size:15px;padding:11px 12px;border:1px solid var(--line2);border-radius:9px;
  background:#fff;color:var(--text);width:100%;font-weight:600}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* admin */
.adminbar{background:#fff;border-bottom:1px solid var(--line);padding:12px 0;position:sticky;top:0;z-index:30}
.adminbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.adminbar nav{display:flex;gap:4px;flex-wrap:wrap}
.adminbar nav a{padding:8px 13px;border-radius:8px;font-size:13.5px;font-weight:800;text-decoration:none;color:var(--muted)}
.adminbar nav a.on{background:var(--red);color:#fff}
.adminbar .brand{font-weight:900;font-size:17px;display:flex;align-items:center;gap:8px;color:var(--red)}
.h1{font-size:25px;font-weight:900;letter-spacing:-.01em;margin:22px 0 4px}
.sub{color:var(--muted);font-size:14.5px;margin:0 0 18px;font-weight:600}
.panel h3{margin:0;font-size:16px;font-weight:900}
.panel .phint{margin:4px 0 14px;font-size:13px;color:var(--muted);font-weight:600}
table.tbl{width:100%;border-collapse:collapse;font-size:14px}
table.tbl th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--soft);
  padding:8px;border-bottom:1px solid var(--line2);font-weight:800}
table.tbl td{padding:11px 8px;border-bottom:1px solid var(--line);font-weight:700}
.toggle{width:46px;height:26px;border-radius:999px;border:none;cursor:pointer;position:relative}
.toggle .knob{position:absolute;top:3px;width:20px;height:20px;border-radius:999px;background:#fff;transition:left .15s ease}
.toggle.on{background:var(--green)} .toggle.on .knob{left:23px}
.toggle.off{background:#D2D2D2} .toggle.off .knob{left:3px}
.icon-btn{background:#fff;border:1px solid var(--line2);border-radius:8px;width:34px;height:34px;display:grid;place-items:center;cursor:pointer;color:var(--red)}
.flash{background:var(--green-soft);color:var(--green);border-radius:9px;padding:11px 14px;font-size:14px;font-weight:800;margin-bottom:14px}

@media (max-width:520px){.grid2{grid-template-columns:1fr}.resto h1{font-size:20px}}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
