/* ===== La Ganexa — Conferência (identidade da marca) ===== */
:root{
  --bg:#120F0C;          /* fundo */
  --surface:#1D1814;     /* superfície */
  --surface-2:#241D17;
  --chocolate:#1C0602;
  --gold:#DA9B2F;        /* dourado principal */
  --gold-light:#DBB870;
  --gold-dark:#AA6D18;
  --caramel:#F09A46;
  --cream:#FFE5B7;
  --white-warm:#F0E9DD;
  --gray-warm:#8C8278;
  --ok:#2EB85C;          /* verde sucesso */
  --err:#E5484D;         /* erro */
  --warn:#F2B43A;
  --radius:18px;
  --tap:64px;            /* alvo de toque grande p/ luva/pressa */
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{
  background:var(--bg);color:var(--white-warm);
  font-family:"DM Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  overscroll-behavior:none;user-select:none;
}
h1,h2,h3,.brand{font-family:"Playfair Display",Georgia,serif}

/* layout */
.app{display:flex;flex-direction:column;min-height:100dvh;max-width:560px;margin:0 auto}
.topbar{
  display:flex;align-items:center;gap:12px;padding:14px 16px;
  background:linear-gradient(180deg,var(--chocolate),transparent);
  position:sticky;top:0;z-index:20;backdrop-filter:blur(4px)
}
.topbar .back{
  background:var(--surface);border:1px solid #3a2f25;color:var(--cream);
  width:44px;height:44px;border-radius:12px;font-size:20px;flex:0 0 auto
}
.brand{color:var(--gold);font-weight:700;font-size:20px;letter-spacing:.3px}
.brand small{display:block;font-family:"DM Sans";color:var(--gray-warm);font-size:11px;letter-spacing:2px;text-transform:uppercase}
.spacer{flex:1}
.pill{font-size:12px;color:var(--gold-light);background:var(--surface);padding:6px 10px;border-radius:999px;border:1px solid #3a2f25}

.view{flex:1;display:none;flex-direction:column;padding:8px 16px 24px}
.view.active{display:flex}

/* home */
.hero{padding:18px 4px 6px}
.hero h1{margin:.2em 0;font-size:30px;color:var(--cream)}
.hero p{color:var(--gray-warm);margin:0}
.menu{display:grid;gap:16px;margin-top:18px}
.card-btn{
  display:flex;align-items:center;gap:16px;text-align:left;cursor:pointer;
  background:var(--surface);border:1px solid #3a2f25;border-radius:var(--radius);
  padding:22px 18px;color:var(--white-warm);min-height:96px
}
.card-btn .ico{font-size:34px;width:56px;height:56px;display:grid;place-items:center;
  background:var(--surface-2);border-radius:14px;border:1px solid #3a2f25}
.card-btn b{font-size:19px;display:block;font-family:"Playfair Display",serif;color:var(--cream)}
.card-btn span{color:var(--gray-warm);font-size:13px}
.card-btn:active{transform:scale(.99);border-color:var(--gold)}

/* scanner */
.scanwrap{position:relative;border-radius:var(--radius);overflow:hidden;background:#000;
  aspect-ratio:3/4;border:2px solid #3a2f25;margin-bottom:12px}
.scanwrap video{width:100%;height:100%;object-fit:cover;display:block}
.scanwrap .frame{position:absolute;inset:18% 12%;border:3px solid var(--gold);border-radius:14px;
  box-shadow:0 0 0 100vmax rgba(0,0,0,.35);pointer-events:none}
.scanwrap .laser{position:absolute;left:12%;right:12%;height:2px;background:var(--caramel);
  animation:scan 1.8s ease-in-out infinite;box-shadow:0 0 12px var(--caramel)}
@keyframes scan{0%,100%{top:20%}50%{top:78%}}
.scanwrap .flash{position:absolute;inset:0;opacity:0;pointer-events:none}
.scanwrap.ok .flash{background:var(--ok);animation:flash .35s}
.scanwrap.err .flash{background:var(--err);animation:flash .45s}
@keyframes flash{0%{opacity:.0}30%{opacity:.55}100%{opacity:0}}
.scan-hint{text-align:center;color:var(--gray-warm);font-size:13px;margin:-4px 0 10px}
.nocam{padding:20px;text-align:center;color:var(--warn);font-size:14px}

/* progress + lists */
.bigstat{display:flex;align-items:baseline;gap:10px;margin:4px 2px 10px}
.bigstat b{font-size:40px;font-family:"Playfair Display",serif;color:var(--cream);line-height:1}
.bigstat span{color:var(--gray-warm)}
.bar{height:10px;border-radius:999px;background:var(--surface-2);overflow:hidden;margin:0 2px 14px}
.bar>i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold-dark),var(--gold));transition:width .25s}
.bar.full>i{background:var(--ok)}

.order-head{background:var(--surface);border:1px solid #3a2f25;border-radius:14px;padding:12px 14px;margin-bottom:12px}
.order-head .num{font-size:22px;color:var(--gold);font-family:"Playfair Display",serif}
.order-head .cli{color:var(--white-warm)}
.order-head .meta{color:var(--gray-warm);font-size:12px;margin-top:2px}

ul.items{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.item{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid #3a2f25;
  border-radius:12px;padding:12px 14px}
.item.done{border-color:var(--ok);background:linear-gradient(90deg,rgba(46,184,92,.12),var(--surface))}
.item.over{border-color:var(--err)}
.item .qtd{flex:0 0 64px;text-align:center;font-size:18px;font-weight:700;font-family:"Playfair Display",serif}
.item .qtd small{display:block;font-family:"DM Sans";font-weight:400;font-size:11px;color:var(--gray-warm)}
.item.done .qtd{color:var(--ok)}
.item .desc{flex:1;min-width:0}
.item .desc b{display:block;font-size:15px;color:var(--cream);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.item .desc span{font-size:12px;color:var(--gray-warm)}
.item .chk{font-size:22px;width:28px;text-align:center;color:var(--gray-warm)}
.item.done .chk{color:var(--ok)}

/* toast */
.toast{position:fixed;left:50%;bottom:96px;transform:translateX(-50%);z-index:60;
  padding:14px 20px;border-radius:14px;font-weight:700;font-size:16px;max-width:90%;
  text-align:center;box-shadow:0 10px 30px rgba(0,0,0,.5);opacity:0;transition:opacity .2s,transform .2s}
.toast.show{opacity:1}
.toast.ok{background:var(--ok);color:#06210f}
.toast.err{background:var(--err);color:#2a0708}
.toast.warn{background:var(--warn);color:#2a1f04}

/* bottom actions */
.actions{position:sticky;bottom:0;display:flex;gap:10px;padding:12px 0 4px;
  background:linear-gradient(0deg,var(--bg) 70%,transparent)}
.btn{flex:1;min-height:var(--tap);border-radius:14px;border:1px solid #3a2f25;font-size:16px;font-weight:700;
  background:var(--surface);color:var(--cream)}
.btn.primary{background:linear-gradient(180deg,var(--gold),var(--gold-dark));color:#241400;border:none}
.btn.success{background:var(--ok);color:#06210f;border:none}
.btn.ghost{background:transparent}
.btn:disabled{opacity:.45}
.btn:active{transform:scale(.99)}

/* selection list (escolher pedido / dia) */
.search{width:100%;min-height:54px;border-radius:12px;border:1px solid #3a2f25;background:var(--surface);
  color:var(--cream);padding:0 14px;font-size:16px;margin-bottom:12px}
.row{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid #3a2f25;
  border-radius:12px;padding:14px;margin-bottom:8px;cursor:pointer}
.row:active{border-color:var(--gold)}
.row .n{font-family:"Playfair Display",serif;color:var(--gold);font-size:18px;flex:0 0 auto}
.row .c{flex:1;min-width:0}
.row .c b{display:block;color:var(--cream)}
.row .c span{color:var(--gray-warm);font-size:12px}
.row .st{font-size:12px;padding:4px 8px;border-radius:999px;border:1px solid #3a2f25;color:var(--gray-warm)}
.row .st.ok{color:var(--ok);border-color:var(--ok)}
.row .st.pend{color:var(--warn);border-color:var(--warn)}

.empty{text-align:center;color:var(--gray-warm);padding:40px 10px}
.banner{padding:8px 12px;border-radius:10px;font-size:12px;text-align:center;margin-bottom:10px}
.banner.mock{background:rgba(242,180,58,.12);color:var(--warn);border:1px solid rgba(242,180,58,.3)}
