:root{
  --ean-gap: 14px;
}
.wrap{
  max-width: 980px;
  margin: 0 auto;
  padding: 16px;
}
.topbar{
  display:flex;
  align-items:center;
  gap:12px;
  margin: 4px 0 14px;
}
.topbar .back{
  width:40px;height:40px;
  display:grid;place-items:center;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  text-decoration:none;
}
.topbar .title .h1{ font-weight: 800; font-size: 18px; line-height: 1.1; }
.topbar .title .h2{ opacity:.72; font-size: 13px; margin-top: 2px; }
.card{
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  padding: 16px;
  background: rgba(255,255,255,.04);
}
.row{ display:flex; flex-direction:column; gap: 8px; }
.lbl{ font-weight: 700; opacity:.9; }
.inputwrap{ display:flex; gap: 10px; flex-wrap: wrap; }
.input{
  flex: 1 1 260px;
  min-width: 220px;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.18);
  color: inherit;
  outline: none;
}
.help{ opacity:.65; font-size: 13px; }
.actions{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: var(--ean-gap);
}
.btn{
  border-radius: 14px;
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: inherit;
  cursor: pointer;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap: 8px;
}
.btn.primary{ background: rgba(0,153,255,.18); border-color: rgba(0,153,255,.30); }
.btn.danger{ background: rgba(255,60,90,.14); border-color: rgba(255,60,90,.30); }
.file{ display:none; }
.filebtn{ user-select:none; }
.scanbox{
  margin-top: var(--ean-gap);
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  overflow:hidden;
}
.scanhead{ padding: 12px 12px 8px; }
.scanstatus{ font-weight: 700; }
.scanmini{ opacity:.7; font-size: 13px; margin-top: 2px; }
.viewport{
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  background: #000;
}
#video{
  width:100%;
  height:100%;
  object-fit: cover;
}
.overlay{
  position:absolute; inset:0;
  display:grid; place-items:center;
  pointer-events:none;
}
.reticle{
  width:min(76vw, 340px);
  height:min(44vw, 190px);
  border-radius: 16px;
  border: 2px solid rgba(255,255,255,.76);
  box-shadow: 0 0 0 2000px rgba(0,0,0,.25);
}
.msg{
  margin-top: var(--ean-gap);
  padding: 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
}
.results{ margin-top: var(--ean-gap); display:grid; gap: 10px; }
.res{
  display:flex; gap: 12px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 16px;
  padding: 10px;
  background: rgba(255,255,255,.04);
}
.res img{
  width: 64px; height: 96px; object-fit: cover;
  border-radius: 12px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
}
.res .meta{ flex:1; min-width: 0; }
.res .t{ font-weight: 800; }
.res .y{ opacity:.7; font-size: 13px; margin-top: 2px; }
.res .a{ margin-top: 8px; display:flex; gap: 8px; flex-wrap:wrap; }
.foot{ margin-top: 14px; opacity:.6; font-size: 12px; padding: 0 4px; }
