/* ============ Pedeaí PDV — sistema visual (rosa delivery) ============ */
:root{
  /* brand */
  --brand:#FF2D72;
  --brand-hover:#EC195F;
  --brand-press:#D40E52;
  --brand-soft:#FFE5EE;
  --brand-soft-2:#FFD3E2;
  --accent:#FF8A3D;      /* warm orange for combos */
  --accent-soft:#FFE9D6;

  /* neutrals */
  --ink:#1C1620;
  --ink-2:#4A4350;
  --muted:#8C8693;
  --faint:#B7B2BC;
  --bg:#F5F4F7;
  --card:#FFFFFF;
  --line:#ECEAEF;
  --line-2:#E2DFE6;
  --sunken:#F2F0F5;

  /* status */
  --ok:#1F9D57; --ok-soft:#E3F6EC;
  --warn:#E8930C; --warn-soft:#FCEFD7;
  --info:#2C6BE5; --info-soft:#E4ECFD;
  --pending:#7A3CE8; --pending-soft:#EFE6FD;
  --danger:#E23838; --danger-soft:#FBE6E6;

  /* radii */
  --r-xl:28px; --r-lg:22px; --r-md:16px; --r-sm:12px; --r-pill:999px;

  /* shadow */
  --sh-card:0 10px 26px -14px rgba(28,12,30,.20);
  --sh-pop:0 18px 40px -16px rgba(28,12,30,.30);
  --sh-sm:0 4px 12px -6px rgba(28,12,30,.18);

  /* type */
  --f-ui:"Plus Jakarta Sans", system-ui, sans-serif;
  --f-num:"Space Grotesk", system-ui, sans-serif;
  --f-display:"Fredoka", system-ui, sans-serif;

  --dur:200ms; --ease:cubic-bezier(.22,.61,.36,1);
}

/* roundness tweak hooks */
.rounding-soft{ --r-xl:34px; --r-lg:28px; --r-md:20px; --r-sm:14px; }
.rounding-sharp{ --r-xl:16px; --r-lg:14px; --r-md:10px; --r-sm:8px; }

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

/* ---------- App shell inside the phone ---------- */
.app{
  position:relative; height:100%; width:100%;
  background:var(--bg); color:var(--ink);
  font-family:var(--f-ui); -webkit-font-smoothing:antialiased;
  display:flex; flex-direction:column; overflow:hidden;
}
.scroll{ flex:1; overflow-y:auto; overflow-x:hidden; -webkit-overflow-scrolling:touch; }
.scroll::-webkit-scrollbar{ width:0; height:0; }
.pad{ padding:0 20px; }
.stack{ display:flex; flex-direction:column; }

/* ---------- App header ---------- */
.appbar{
  padding:calc(env(safe-area-inset-top,0px) + 18px) 20px 14px; background:var(--card);
  border-bottom-left-radius:24px; border-bottom-right-radius:24px;
  position:relative; z-index:5;
}
.appbar--brand{ background:var(--brand); color:#fff; }
.appbar-row{ display:flex; align-items:center; gap:12px; }
.icon-btn{
  width:42px; height:42px; border-radius:var(--r-md); border:none;
  background:var(--sunken); color:var(--ink);
  display:flex; align-items:center; justify-content:center; cursor:pointer;
  transition:transform var(--dur) var(--ease), background var(--dur);
}
.icon-btn:active{ transform:scale(.94); }
.icon-btn--ghost-light{ background:rgba(255,255,255,.16); color:#fff; }
.icon-btn--ghost-light:active{ background:rgba(255,255,255,.28); }
.badge-dot{ position:absolute; top:-3px; right:-3px; min-width:18px; height:18px; padding:0 5px;
  border-radius:999px; background:var(--brand); color:#fff; font-size:11px; font-weight:700;
  display:flex; align-items:center; justify-content:center; border:2px solid var(--card); font-family:var(--f-num);}
.appbar--brand .badge-dot{ background:#fff; color:var(--brand); border-color:var(--brand); }

.greet-eyebrow{ font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; opacity:.7; }
.greet-title{ font-size:21px; font-weight:800; margin-top:2px; letter-spacing:-.01em; }

/* company pill */
.co-brand{ display:flex; align-items:center; gap:12px; background:none; border:none; padding:0; cursor:pointer; max-width:75%; }
.co-brand .co-logo{ box-shadow:var(--sh-sm); }
.co-brand-name{ display:flex; align-items:center; gap:5px; font-family:var(--f-display); font-weight:700;
  font-size:18px; letter-spacing:-.01em; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.co-brand-tag{ font-size:12px; font-weight:600; color:var(--muted); margin-top:1px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; display:flex; align-items:center; }
.co-city{ display:inline-flex; align-items:center; gap:3px; white-space:nowrap; }
.co-city svg{ flex-shrink:0; }
.co-addr{ display:inline-flex; align-items:center; gap:4px; }
.co-addr svg{ flex-shrink:0; }
.co-dot{ margin:0 5px; opacity:.5; }
.co-maplink{ display:inline-flex; align-items:center; gap:5px; color:var(--brand); font-weight:700;
  font-size:13px; text-decoration:none; white-space:nowrap; }
.co-maplink:active{ opacity:.7; }

/* card de localização (loja pública) */
.store-loc{ display:flex; align-items:center; gap:12px; padding:13px 14px; box-shadow:var(--sh-card); }
.store-loc__ico{ width:40px; height:40px; flex-shrink:0; border-radius:var(--r-sm); background:var(--brand-soft);
  display:flex; align-items:center; justify-content:center; }
.store-loc__addr{ font-weight:700; font-size:14px; color:var(--ink); line-height:1.3; }
.store-loc__city{ font-size:12.5px; font-weight:600; color:var(--muted); margin-top:2px; }
.store-loc__map{ display:inline-flex; align-items:center; gap:5px; flex-shrink:0; background:var(--brand-soft);
  color:var(--brand); font-weight:700; font-size:12.5px; text-decoration:none; padding:8px 11px; border-radius:var(--r-pill); }
.store-loc__map:active{ transform:translateY(1px); }
.co-pill{ display:flex; align-items:center; gap:10px; background:var(--sunken);
  border:none; border-radius:var(--r-pill); padding:7px 14px 7px 7px; cursor:pointer; max-width:100%;
  transition:background var(--dur);}
.co-pill:active{ background:var(--line); }
.co-logo{ width:30px; height:30px; border-radius:var(--r-pill); display:flex; align-items:center;
  justify-content:center; color:#fff; flex-shrink:0; }
.co-name{ font-weight:700; font-size:14px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

/* ---------- Search ---------- */
.search{ display:flex; align-items:center; gap:10px; background:var(--card);
  border:1px solid var(--line); border-radius:var(--r-md); padding:12px 14px; }
.search input{ border:none; outline:none; background:none; font-family:var(--f-ui);
  font-size:15px; width:100%; color:var(--ink); }
.search input::placeholder{ color:var(--faint); }

/* ---------- Segmented / order type ---------- */
.seg{ display:flex; gap:8px; overflow-x:auto; padding:2px; scrollbar-width:none; }
.seg::-webkit-scrollbar{ display:none; }
.seg-btn{ flex:0 0 auto; display:flex; align-items:center; gap:7px; border:1px solid var(--line-2);
  background:var(--card); color:var(--ink-2); border-radius:var(--r-pill); padding:9px 15px;
  font-family:var(--f-ui); font-weight:700; font-size:13.5px; cursor:pointer; white-space:nowrap;
  transition:all var(--dur) var(--ease); }
.seg-btn[data-on="true"]{ background:var(--ink); color:#fff; border-color:var(--ink); }

/* category chips */
.chips{ display:flex; gap:9px; overflow-x:auto; padding:2px; scrollbar-width:none; }
.chips::-webkit-scrollbar{ display:none; }
.chip{ flex:0 0 auto; border:1px solid var(--line-2); background:var(--card); color:var(--ink-2);
  border-radius:var(--r-pill); padding:9px 16px; font-weight:700; font-size:13.5px; cursor:pointer;
  display:flex; align-items:center; gap:7px; transition:all var(--dur) var(--ease); }
.chip[data-on="true"]{ background:var(--brand-soft); color:var(--brand-press); border-color:var(--brand-soft-2); }

/* ---------- Buttons ---------- */
.btn{ border:none; border-radius:var(--r-md); font-family:var(--f-ui); font-weight:700; cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center; gap:9px; font-size:15px; white-space:nowrap;
  transition:transform var(--dur) var(--ease), background var(--dur), box-shadow var(--dur); padding:14px 20px; }
.btn:active{ transform:translateY(1px) scale(.99); }
.btn--primary{ background:var(--brand); color:#fff; box-shadow:0 10px 22px -10px var(--brand); }
.btn--primary:active{ background:var(--brand-press); }
.btn--block{ width:100%; }
.btn--lg{ padding:17px 22px; font-size:16px; }
.btn--ghost{ background:var(--sunken); color:var(--ink); }
.btn--ghost:active{ background:var(--line); }
.btn--outline{ background:var(--card); color:var(--ink); border:1.5px solid var(--line-2); }
.btn[disabled]{ opacity:.45; pointer-events:none; }

/* ---------- Cards ---------- */
.card{ background:var(--card); border-radius:var(--r-lg); box-shadow:var(--sh-card); }
.card-pad{ padding:16px; }

/* food tile placeholder */
.tile{ position:relative; border-radius:var(--r-md); overflow:hidden; display:flex;
  align-items:center; justify-content:center; color:rgba(255,255,255,.92); }
.tile::after{ content:""; position:absolute; inset:0;
  background:radial-gradient(120% 90% at 25% 15%, rgba(255,255,255,.34), rgba(255,255,255,0) 55%); }
.tile svg{ position:relative; z-index:1; filter:drop-shadow(0 4px 8px rgba(0,0,0,.18)); }

/* discount / promo banner */
.promo{ position:relative; border-radius:var(--r-lg); overflow:hidden; padding:20px;
  background:linear-gradient(120deg,#2A1430,#52183F 60%,var(--brand)); color:#fff; }
.promo .tile{ position:absolute; right:-30px; bottom:-30px; width:150px; height:150px; opacity:.9; }

/* ---------- Menu item row / card ---------- */
.food-card{ background:var(--card); border-radius:var(--r-lg); box-shadow:var(--sh-card);
  overflow:hidden; cursor:pointer; transition:transform var(--dur) var(--ease), box-shadow var(--dur); }
.food-card:active{ transform:translateY(1px); }
.food-name{ font-weight:800; font-size:14.5px; line-height:1.2; letter-spacing:-.01em; }
.food-sub{ color:var(--muted); font-size:12px; margin-top:2px; }
.price{ font-family:var(--f-num); font-weight:700; letter-spacing:-.02em; white-space:nowrap; }
.price-from{ font-size:11px; color:var(--muted); font-weight:600; font-family:var(--f-ui); }

.add-fab{ width:34px; height:34px; border-radius:var(--r-sm); background:var(--brand); color:#fff;
  border:none; display:flex; align-items:center; justify-content:center; cursor:pointer;
  box-shadow:0 8px 16px -8px var(--brand); transition:transform var(--dur) var(--ease);}
.add-fab:active{ transform:scale(.9); }

/* list-style food row */
.food-row{ display:flex; gap:13px; align-items:center; background:var(--card);
  border-radius:var(--r-lg); box-shadow:var(--sh-card); padding:12px; cursor:pointer;
  transition:transform var(--dur) var(--ease); }
.food-row:active{ transform:translateY(1px); }

/* ---------- Section headers ---------- */
.sec-head{ display:flex; align-items:baseline; justify-content:space-between; }
.sec-title{ font-size:17px; font-weight:800; letter-spacing:-.01em; white-space:nowrap; }
.sec-link{ font-size:13px; font-weight:700; color:var(--brand); cursor:pointer; }

/* ---------- Bottom nav ---------- */
.tabbar{ display:flex; align-items:center; justify-content:space-around; background:var(--card);
  padding:10px 8px calc(env(safe-area-inset-bottom,0px) + 16px); box-shadow:0 -8px 24px -18px rgba(28,12,30,.4);
  border-top-left-radius:24px; border-top-right-radius:24px; position:relative; z-index:5; }
.tab{ border:none; background:none; display:flex; flex-direction:column; align-items:center; gap:4px;
  color:var(--faint); font-family:var(--f-ui); font-weight:700; font-size:11px; cursor:pointer;
  padding:4px 10px; transition:color var(--dur); position:relative; }
.tab[data-on="true"]{ color:var(--brand); }
.tab .tab-ico{ position:relative; }
.tab .badge-dot{ border-color:var(--card); }

/* ---------- Stepper ---------- */
.stepper{ display:flex; align-items:center; gap:0; background:var(--sunken); border-radius:var(--r-pill); padding:4px; }
.stepper button{ width:34px; height:34px; border-radius:var(--r-pill); border:none; background:var(--card);
  color:var(--ink); font-size:20px; cursor:pointer; display:flex; align-items:center; justify-content:center;
  box-shadow:var(--sh-sm); transition:transform var(--dur) var(--ease); }
.stepper button:active{ transform:scale(.9); }
.stepper .qv{ min-width:40px; text-align:center; font-family:var(--f-num); font-weight:700; font-size:16px; }

/* ---------- Option rows (sizes, flavors, extras) ---------- */
.opt{ display:flex; align-items:center; gap:12px; padding:14px; border-radius:var(--r-md);
  border:1.5px solid var(--line); background:var(--card); cursor:pointer; transition:all var(--dur) var(--ease); }
.opt[data-on="true"]{ border-color:var(--brand); background:var(--brand-soft); }
.opt-check{ width:22px; height:22px; border-radius:var(--r-pill); border:2px solid var(--line-2);
  display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:all var(--dur); }
.opt-check svg{ opacity:0; transition:opacity var(--dur); }
.opt[data-on="true"] .opt-check svg, .pay[data-on="true"] .opt-check svg{ opacity:1; }
.opt[data-on="true"] .opt-check{ border-color:var(--brand); background:var(--brand); color:#fff; }
.pay[data-on="true"] .opt-check{ border-color:var(--brand); background:var(--brand); color:#fff; }
.opt-name{ font-weight:700; font-size:14.5px; }
.opt-sub{ color:var(--muted); font-size:12px; }

/* size selector grid */
.size-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:9px; }
.size-cell{ border:1.5px solid var(--line); background:var(--card); border-radius:var(--r-md);
  padding:12px 6px; text-align:center; cursor:pointer; transition:all var(--dur) var(--ease); }
.size-cell[data-on="true"]{ border-color:var(--brand); background:var(--brand-soft); }
.size-cell .sz{ font-weight:800; font-size:16px; }
.size-cell .szsub{ font-size:10.5px; color:var(--muted); margin-top:2px; }
.size-cell .szprice{ font-family:var(--f-num); font-size:11.5px; font-weight:700; margin-top:4px; color:var(--ink-2); }

/* ---------- Status pills ---------- */
.pill{ display:inline-flex; align-items:center; gap:6px; border-radius:var(--r-pill);
  padding:5px 11px; font-size:12px; font-weight:700; }
.pill .dot{ width:7px; height:7px; border-radius:999px; background:currentColor; }
.pill--ok{ background:var(--ok-soft); color:var(--ok); }
.pill--warn{ background:var(--warn-soft); color:var(--warn); }
.pill--info{ background:var(--info-soft); color:var(--info); }
.pill--pending{ background:var(--pending-soft); color:var(--pending); }
.pill--danger{ background:var(--danger-soft); color:var(--danger); }
.pill--neutral{ background:var(--sunken); color:var(--ink-2); }

/* order cards (operador) */
.order-card{ transition:transform var(--dur) var(--ease), box-shadow var(--dur); }
.order-card:active{ transform:scale(.99); }
.order-edit{ display:inline-flex; align-items:center; gap:4px; font-size:11px; font-weight:700;
  color:var(--brand); background:var(--brand-soft); border-radius:var(--r-pill); padding:4px 9px; white-space:nowrap; }
.status-opt{ align-items:center; }

/* dados do cliente (painel do operador) */
.cust-row{ display:flex; align-items:flex-start; gap:12px; padding:12px 14px; }
.cust-ico{ width:34px; height:34px; flex-shrink:0; border-radius:var(--r-sm); background:var(--sunken);
  color:var(--ink-2); display:flex; align-items:center; justify-content:center; }
.cust-k{ font-size:11px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--muted); }
.cust-v{ font-weight:700; font-size:14.5px; color:var(--ink); margin-top:2px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cust-div{ height:1px; background:var(--line); margin-left:60px; }
.cust-wa{ width:38px; height:38px; flex-shrink:0; border-radius:999px; background:#25D366; text-decoration:none;
  display:flex; align-items:center; justify-content:center; box-shadow:0 6px 14px -6px rgba(37,211,102,.6); }
.cust-wa:active{ transform:translateY(1px); }

/* editor de pedido */
.seg--wrap{ flex-wrap:wrap; }
.editbar{ position:absolute; left:0; right:0; bottom:0; z-index:5; display:flex; align-items:center; gap:14px;
  background:var(--card); padding:14px 18px 26px; border-top-left-radius:24px; border-top-right-radius:24px;
  box-shadow:0 -10px 30px -18px rgba(28,12,30,.4); }
.editbar__k{ font-size:11px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--muted); white-space:nowrap; }
.editbar__v{ font-family:var(--f-num); font-weight:800; font-size:20px; color:var(--brand); margin-top:2px; }

/* acompanhamento do pedido (cliente) */
.track{ display:flex; flex-direction:column; gap:0; }
.track-step{ display:flex; align-items:center; gap:12px; position:relative; padding:7px 0; }
.track-step:not(:last-child)::before{ content:""; position:absolute; left:12px; top:30px; bottom:-7px; width:2px; background:var(--line-2); }
.track-step[data-done="true"]:not(:last-child)::before{ background:var(--ok); }
.track-mark{ width:26px; height:26px; border-radius:999px; flex-shrink:0; background:var(--line-2);
  display:flex; align-items:center; justify-content:center; z-index:1; transition:background var(--dur); }
.track-step[data-done="true"] .track-mark{ background:var(--ok); }
.track-step[data-current="true"] .track-mark{ background:var(--brand); box-shadow:0 0 0 4px var(--brand-soft); }
.track-label{ font-weight:700; font-size:14px; color:var(--muted); }
.track-step[data-done="true"] .track-label{ color:var(--ink); }
.track-step[data-current="true"] .track-label{ color:var(--brand); }

/* loja pública / link */
.preview-bar{ display:flex; align-items:center; gap:8px; background:var(--ink); color:#fff;
  font-size:12.5px; font-weight:700; padding:9px 16px; }
.preview-bar button{ border:none; background:rgba(255,255,255,.18); color:#fff; font-weight:700;
  font-size:12.5px; padding:6px 12px; border-radius:var(--r-pill); cursor:pointer; }
.store-link{ padding:16px; box-shadow:var(--sh-card); }
.store-link__top{ display:flex; align-items:flex-start; gap:12px; }
.store-link__url{ display:flex; align-items:center; gap:9px; background:var(--sunken); border-radius:var(--r-md);
  padding:12px 14px; margin-top:14px; }
.store-link__txt{ font-family:var(--f-num); font-weight:700; font-size:14px; color:var(--ink);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.store-link__actions{ display:flex; gap:10px; margin-top:12px; }

/* rodapé "powered by apressa AI" (capta clientes) */
.powered{ background:linear-gradient(160deg,#1D3358 0%, #15294A 60%, #0F1E38 100%);
  border-radius:var(--r-xl); padding:22px 20px; text-align:center; }
.powered__eyebrow{ font-size:11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  color:rgba(255,255,255,.6); }
.powered__logo{ display:block; background:#fff; border-radius:var(--r-md); padding:14px 18px; margin:12px auto 0;
  max-width:260px; box-shadow:0 8px 20px -10px rgba(0,0,0,.5); }
.powered__logo img{ width:100%; height:auto; display:block; }
.powered--compact .powered__logo{ max-width:210px; padding:11px 14px; }
.powered__pitch{ color:rgba(255,255,255,.88); font-size:13.5px; font-weight:600; margin-top:14px; line-height:1.4;
  max-width:280px; margin-left:auto; margin-right:auto; }
.powered__cta{ display:inline-flex; align-items:center; justify-content:center; gap:8px; margin-top:16px;
  background:#25D366; color:#fff; font-family:var(--f-ui); font-weight:700; font-size:13.5px; white-space:nowrap;
  padding:12px 16px; border-radius:var(--r-pill); text-decoration:none; box-shadow:0 8px 18px -8px rgba(37,211,102,.6);
  transition:transform var(--dur) var(--ease); }
.powered__cta:active{ transform:translateY(1px); }

/* botão WhatsApp (acompanhamento do pedido) */
.btn--wa{ background:#25D366; color:#fff; box-shadow:0 10px 22px -10px rgba(37,211,102,.65); text-decoration:none; }
.btn--wa:active{ transform:translateY(1px); }

/* validação de formulário (checkout da loja) */
.search[data-err="true"]{ box-shadow:0 0 0 2px var(--danger) inset; }
.field-err{ display:flex; align-items:center; gap:6px; color:var(--danger); font-size:12.5px; font-weight:600;
  margin:2px 2px 12px; }
.btn[data-soft-disabled="true"]{ opacity:.92; }

/* ---------- Sheets / overlay ---------- */
.scrim{ position:absolute; inset:0; background:rgba(20,8,22,.45); z-index:40;
  opacity:0; pointer-events:none; transition:opacity var(--dur); }
.scrim[data-on="true"]{ opacity:1; pointer-events:auto; }
.sheet{ position:absolute; left:0; right:0; bottom:0; z-index:41; background:var(--card);
  border-top-left-radius:var(--r-xl); border-top-right-radius:var(--r-xl); box-shadow:var(--sh-pop);
  transform:translateY(110%); transition:transform var(--dur) var(--ease); max-height:88%;
  display:flex; flex-direction:column; }
.sheet[data-on="true"]{ transform:translateY(0); }
.sheet-grip{ width:42px; height:5px; border-radius:999px; background:var(--line-2); margin:12px auto 4px; }

/* ---------- Summary rows ---------- */
.sum-row{ display:flex; align-items:center; justify-content:space-between; font-size:14px; padding:7px 0; }
.sum-row .k{ color:var(--ink-2); }
.sum-row .v{ font-family:var(--f-num); font-weight:600; }
.sum-total{ font-size:19px; font-weight:800; }
.sum-total .v{ font-family:var(--f-num); }
.divider{ height:1px; background:var(--line); margin:10px 0; }
.dashed{ height:1px; background:repeating-linear-gradient(90deg,var(--line-2) 0 6px, transparent 6px 12px); margin:12px 0; }

/* payment method tiles */
.pay{ display:flex; align-items:center; gap:14px; padding:16px; border-radius:var(--r-md);
  border:1.5px solid var(--line); background:var(--card); cursor:pointer; transition:all var(--dur) var(--ease); }
.pay[data-on="true"]{ border-color:var(--brand); background:var(--brand-soft); }
.pay-ico{ width:44px; height:44px; border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center; flex-shrink:0; }

/* numeric pad */
.numpad{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.numkey{ background:var(--sunken); border:none; border-radius:var(--r-md); padding:16px 0; font-family:var(--f-num);
  font-size:22px; font-weight:700; color:var(--ink); cursor:pointer; transition:transform var(--dur) var(--ease); }
.numkey:active{ transform:scale(.95); background:var(--line); }

/* ---------- toast ---------- */
.toast{ position:absolute; left:20px; right:20px; bottom:96px; z-index:70; background:var(--ink); color:#fff;
  border-radius:var(--r-md); padding:14px 16px; display:flex; align-items:center; gap:10px; font-weight:600;
  font-size:14px; box-shadow:var(--sh-pop); transform:translateY(140%); opacity:0; transition:all var(--dur) var(--ease); }
.toast[data-on="true"]{ transform:translateY(0); opacity:1; }

/* receipt success */
.success-badge{ width:96px; height:96px; border-radius:999px; background:var(--ok-soft); color:var(--ok);
  display:flex; align-items:center; justify-content:center; margin:0 auto; }

/* misc */
.eyebrow{ font-size:11px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.tag{ display:inline-flex; align-items:center; gap:5px; background:var(--brand-soft); color:var(--brand-press);
  font-size:11px; font-weight:800; padding:4px 9px; border-radius:var(--r-pill); }
.tag--accent{ background:var(--accent-soft); color:#B85C12; }
.rating{ display:inline-flex; align-items:center; gap:4px; font-family:var(--f-num); font-weight:700; font-size:12.5px; }
.hide{ display:none !important; }

@keyframes pop-in{ from{ opacity:0; transform:translateY(8px) scale(.98);} to{ opacity:1; transform:none; } }
.animate-in{ animation:pop-in var(--dur) var(--ease) both; }

/* ============ Login ============ */
.login-screen{ background:var(--bg); }
.login-hero{ position:relative; overflow:hidden; color:#fff;
  background:linear-gradient(150deg,#2A1430 0%, #52183F 52%, var(--brand) 130%);
  padding:calc(env(safe-area-inset-top,0px) + 46px) 26px 64px;
  border-bottom-left-radius:34px; border-bottom-right-radius:34px; }
.login-hero__glow{ position:absolute; width:300px; height:300px; right:-90px; top:-120px;
  background:radial-gradient(circle, rgba(255,45,114,.55), rgba(255,45,114,0) 68%); pointer-events:none; }
.login-brand{ display:flex; align-items:center; gap:13px; position:relative; z-index:1; }
.login-logo{ width:52px; height:52px; border-radius:18px; flex-shrink:0;
  background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.22);
  display:flex; align-items:center; justify-content:center; backdrop-filter:blur(4px); }
.login-wordmark{ font-family:var(--f-display); font-weight:700; font-size:27px; line-height:1; letter-spacing:-.01em; }
.login-tagline{ font-size:12.5px; font-weight:600; color:rgba(255,255,255,.82); margin-top:3px; }
.login-hero__title{ position:relative; z-index:1; font-size:24px; font-weight:800; letter-spacing:-.02em; margin-top:30px; }
.login-hero__sub{ position:relative; z-index:1; font-size:14px; color:rgba(255,255,255,.82); margin-top:7px; max-width:80%; line-height:1.4; }

.login-body{ padding:0 22px 32px; }
.login-card{ margin-top:-34px; position:relative; z-index:2; padding:22px 20px; box-shadow:var(--sh-pop); }
.field-label{ display:block; font-size:12.5px; font-weight:700; color:var(--ink-2); margin-bottom:7px; }
.login-input{ border-radius:var(--r-md); }
.login-input input{ font-size:15px; }
.eye-btn{ border:none; background:none; color:var(--faint); cursor:pointer; padding:4px; display:flex;
  border-radius:var(--r-sm); transition:color var(--dur); }
.eye-btn:active{ color:var(--ink-2); }

.login-err{ display:flex; align-items:center; gap:7px; color:var(--danger); background:var(--danger-soft);
  border-radius:var(--r-sm); padding:9px 12px; font-size:12.5px; font-weight:600; margin-top:14px; }

.login-row{ display:flex; align-items:center; justify-content:space-between; margin-top:16px; }
.check-row{ display:flex; align-items:center; gap:9px; border:none; background:none; cursor:pointer;
  font-size:13.5px; font-weight:600; color:var(--ink-2); padding:0; white-space:nowrap; }
.check-box{ width:21px; height:21px; border-radius:7px; border:2px solid var(--line-2); background:var(--card);
  display:flex; align-items:center; justify-content:center; transition:all var(--dur) var(--ease); }
.check-box svg{ opacity:0; transition:opacity var(--dur); }
.check-box[data-on="true"]{ background:var(--brand); border-color:var(--brand); }
.check-box[data-on="true"] svg{ opacity:1; }

.login-or{ display:flex; align-items:center; gap:12px; margin:18px 0; color:var(--faint); font-size:12px; font-weight:700; }
.login-or::before, .login-or::after{ content:""; flex:1; height:1px; background:var(--line); }

.login-foot{ display:flex; gap:10px; justify-content:center; margin-top:20px; }
.login-chip{ display:flex; align-items:center; gap:6px; background:var(--card); border:1px solid var(--line);
  border-radius:var(--r-pill); padding:7px 13px; font-size:12px; font-weight:700; color:var(--ink-2); }

.login-signup{ text-align:center; margin-top:18px; font-size:13.5px; color:var(--muted); font-weight:500; }
.login-signup button{ border:none; background:none; color:var(--brand); font-weight:800; font-size:13.5px; cursor:pointer; }

.spinner{ width:20px; height:20px; border-radius:999px; border:2.5px solid rgba(255,255,255,.4);
  border-top-color:#fff; animation:spin .7s linear infinite; }
@keyframes spin{ to{ transform:rotate(360deg); } }

/* ============ Gerenciador de cardápio ============ */
.mm-sec-head{ display:flex; align-items:center; gap:10px; margin-bottom:12px; }
.mm-sec-head .eyebrow{ margin:0; }
.mm-count{ font-family:var(--f-num); font-weight:700; font-size:12px; color:var(--muted);
  background:var(--sunken); border-radius:999px; padding:2px 9px; }
.mm-row{ display:flex; align-items:center; gap:12px; background:var(--card); border-radius:var(--r-lg);
  box-shadow:var(--sh-card); padding:11px 12px; transition:opacity var(--dur); }
.mm-row[data-off="true"]{ opacity:.55; }
.mm-row .mm-info{ flex:1; min-width:0; cursor:pointer; }
.mm-name{ font-weight:800; font-size:14.5px; letter-spacing:-.01em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mm-desc{ color:var(--muted); font-size:12px; margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mm-meta{ display:flex; align-items:center; gap:8px; margin-top:6px; flex-wrap:wrap; }
.mm-meta .tag{ white-space:nowrap; }
.mm-price{ font-family:var(--f-num); font-weight:700; font-size:13.5px; }
.switch{ width:46px; height:27px; border-radius:999px; background:var(--line-2); position:relative;
  cursor:pointer; border:none; flex-shrink:0; transition:background var(--dur) var(--ease); padding:0; }
.switch[data-on="true"]{ background:var(--ok); }
.switch i{ position:absolute; top:3px; left:3px; width:21px; height:21px; border-radius:999px; background:#fff;
  box-shadow:var(--sh-sm); transition:transform var(--dur) var(--ease); }
.switch[data-on="true"] i{ transform:translateX(19px); }
.mm-add{ width:100%; border:1.5px dashed var(--line-2); background:var(--card); color:var(--brand);
  border-radius:var(--r-lg); padding:14px; font-family:var(--f-ui); font-weight:800; font-size:14px;
  display:flex; align-items:center; justify-content:center; gap:8px; cursor:pointer; transition:all var(--dur) var(--ease); }
.mm-add:active{ transform:translateY(1px); background:var(--brand-soft); border-color:var(--brand-soft-2); }

/* editor de item */
.btn--sm{ padding:9px 15px; font-size:13.5px; }
.photo-edit{ display:flex; align-items:center; gap:14px; }
.photo-thumb{ position:relative; width:72px; height:72px; flex-shrink:0; border:none; padding:0;
  border-radius:var(--r-md); overflow:hidden; cursor:pointer; background:var(--sunken); }
.photo-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.photo-cam{ position:absolute; right:5px; bottom:5px; width:24px; height:24px; border-radius:999px;
  background:var(--brand); display:flex; align-items:center; justify-content:center; box-shadow:var(--sh-sm); }
.extra-dot{ width:34px; height:34px; flex-shrink:0; border-radius:var(--r-sm); background:var(--brand-soft);
  display:flex; align-items:center; justify-content:center; }

/* editor de empresa */
.co-hero{ display:flex; align-items:center; gap:16px; border-radius:var(--r-xl); padding:20px 22px; color:#fff;
  box-shadow:var(--sh-card); }
.co-hero .co-logo{ box-shadow:0 4px 14px rgba(0,0,0,.18); border:2px solid rgba(255,255,255,.5); }
.co-hero-name{ font-family:var(--f-display); font-weight:700; font-size:22px; letter-spacing:-.01em;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.co-hero-tag{ font-size:13px; font-weight:600; color:rgba(255,255,255,.88); margin-top:3px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.co-swatch{ width:44px; height:44px; border-radius:999px; border:3px solid transparent; cursor:pointer;
  display:flex; align-items:center; justify-content:center; transition:transform var(--dur) var(--ease);
  box-shadow:var(--sh-sm); }
.co-swatch[data-on="true"]{ border-color:var(--ink); transform:scale(1.06); }
.field-area{ align-items:flex-start; }
.field-area textarea{ border:none; outline:none; background:none; font-family:var(--f-ui); font-size:15px;
  width:100%; color:var(--ink); resize:none; line-height:1.45; min-height:56px; }
.field-area textarea::placeholder{ color:var(--faint); }
.price-prefix{ font-family:var(--f-num); font-weight:700; color:var(--muted); font-size:15px; }
