/* ============================================================
   style.css – Barcode Item Verification System
   Dark glassmorphism design with emerald accent
   ============================================================ */

/* ── Design Tokens ── */
:root {
  --clr-bg:           #0a0f1e;
  --clr-surface:      #111827;
  --clr-surface-2:    #1a2235;
  --clr-glass:        rgba(255,255,255,0.05);
  --clr-glass-border: rgba(255,255,255,0.10);
  --clr-glass-hover:  rgba(255,255,255,0.08);

  --clr-accent:       #10b981;   /* emerald-500  */
  --clr-accent-light: #34d399;   /* emerald-400  */
  --clr-accent-glow:  rgba(16,185,129,0.25);
  --clr-accent-dark:  #059669;   /* emerald-600  */

  --clr-error:        #ef4444;   /* red-500       */
  --clr-error-light:  #f87171;   /* red-400       */
  --clr-error-glow:   rgba(239,68,68,0.20);

  --clr-warn:         #f59e0b;
  --clr-blue:         #3b82f6;

  --clr-text:         #f1f5f9;
  --clr-text-muted:   #94a3b8;
  --clr-text-faint:   #475569;

  --clr-blob-1:       rgba(16,185,129,0.15);
  --clr-blob-2:       rgba(59,130,246,0.10);
  --clr-blob-3:       rgba(139,92,246,0.08);

  --radius-sm:        8px;
  --radius-md:        14px;
  --radius-lg:        20px;
  --radius-xl:        28px;

  --shadow-card:      0 4px 24px rgba(0,0,0,0.4), 0 1px 3px rgba(0,0,0,0.5);
  --shadow-glow-ok:   0 0 40px rgba(16,185,129,0.20);
  --shadow-glow-err:  0 0 40px rgba(239,68,68,0.18);

  --transition-fast:  160ms cubic-bezier(.4,0,.2,1);
  --transition-med:   280ms cubic-bezier(.4,0,.2,1);
  --transition-slow:  420ms cubic-bezier(.4,0,.2,1);

  --header-h:         68px;
  --max-w:            780px;
}

/* ── Reset & Base ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }

body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  background-color: var(--clr-bg);
  color: var(--clr-text);
  min-height: 100dvh;
  overflow-x: hidden;
}

/* ── Ambient Background Blobs ── */
.bg-blob {
  position: fixed;
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
  z-index: 0;
  animation: blobFloat 12s ease-in-out infinite alternate;
}
.blob-1 {
  width: 500px; height: 500px;
  background: var(--clr-blob-1);
  top: -150px; right: -80px;
  animation-duration: 13s;
}
.blob-2 {
  width: 400px; height: 400px;
  background: var(--clr-blob-2);
  bottom: 80px; left: -120px;
  animation-duration: 17s; animation-delay: -4s;
}
.blob-3 {
  width: 350px; height: 350px;
  background: var(--clr-blob-3);
  top: 40%; left: 50%;
  transform: translateX(-50%);
  animation-duration: 20s; animation-delay: -8s;
}
@keyframes blobFloat {
  from { transform: translate(0,0) scale(1); }
  to   { transform: translate(30px, 20px) scale(1.06); }
}

/* ── Glass Card ── */
.glass-card {
  background:    var(--clr-glass);
  border:        1px solid var(--clr-glass-border);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border-radius: var(--radius-lg);
  box-shadow:    var(--shadow-card);
}

/* ── Utility ── */
.hidden { display: none !important; }

/* ══════════════════════════════════════════
   HEADER
══════════════════════════════════════════ */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  height: var(--header-h);
  background: rgba(10,15,30,0.85);
  border-bottom: 1px solid var(--clr-glass-border);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
}

.header-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.logo-group {
  display: flex;
  align-items: center;
  gap: 14px;
}

.logo-icon {
  width: 40px; height: 40px;
  color: var(--clr-accent);
  flex-shrink: 0;
  animation: scanline 2.4s ease-in-out infinite;
}
@keyframes scanline {
  0%,100% { opacity:1; transform: scaleY(1); }
  50%      { opacity:.7; transform: scaleY(.97); }
}

.logo-text h1 {
  font-size: 1.15rem;
  font-weight: 700;
  line-height: 1.2;
  background: linear-gradient(135deg, #fff 30%, var(--clr-accent-light));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.logo-sub {
  font-size: .70rem;
  color: var(--clr-text-muted);
  letter-spacing: .06em;
  text-transform: uppercase;
}

.header-meta {
  display: flex;
  align-items: center;
  gap: 12px;
}

/* Server status pill */
.status-pill {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 5px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--clr-glass-border);
  font-size: .75rem;
  color: var(--clr-text-muted);
  transition: var(--transition-med);
}
.status-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--clr-text-faint);
  transition: var(--transition-med);
}
.status-pill.online .status-dot  { background: var(--clr-accent);  box-shadow: 0 0 6px var(--clr-accent); }
.status-pill.online #status-label { color: var(--clr-accent-light); }
.status-pill.offline .status-dot { background: var(--clr-error);   box-shadow: 0 0 6px var(--clr-error); }
.status-pill.offline #status-label{ color: var(--clr-error-light); }

/* Icon buttons */
.btn-icon {
  width: 38px; height: 38px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--clr-glass-border);
  background: var(--clr-glass);
  color: var(--clr-text-muted);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: var(--transition-fast);
  flex-shrink: 0;
}
.btn-icon svg { width: 18px; height: 18px; }
.btn-icon:hover { background: var(--clr-glass-hover); color: var(--clr-text); border-color: var(--clr-accent); }
.btn-icon:active { transform: scale(.94); }

/* ══════════════════════════════════════════
   MAIN CONTENT
══════════════════════════════════════════ */
.main-content {
  position: relative;
  z-index: 1;
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 40px 20px 80px;
  display: flex;
  flex-direction: column;
  gap: 28px;
}

/* ══════════════════════════════════════════
   SCANNER CARD
══════════════════════════════════════════ */
.scanner-section { width: 100%; }

.scanner-card {
  padding: 28px 28px 20px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  transition: box-shadow var(--transition-med);
}
.scanner-card:focus-within {
  box-shadow: var(--shadow-card), 0 0 0 2px var(--clr-accent), var(--shadow-glow-ok);
}

.scanner-label-row {
  display: flex;
  align-items: center;
  gap: 16px;
}
.scanner-icon-wrap {
  width: 48px; height: 48px;
  border-radius: var(--radius-md);
  background: var(--clr-accent-glow);
  border: 1px solid rgba(16,185,129,0.35);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.scanner-icon {
  width: 24px; height: 24px;
  color: var(--clr-accent-light);
  animation: iconPulse 2.8s ease-in-out infinite;
}
@keyframes iconPulse {
  0%,100% { opacity:1; }
  50%      { opacity:.55; }
}
.scanner-label-title  { font-size: .95rem; font-weight: 600; }
.scanner-label-hint   { font-size: .80rem; color: var(--clr-text-muted); margin-top: 2px; }

/* Input wrapper */
.input-wrap {
  position: relative;
  display: flex;
  align-items: center;
}
.input-icon {
  position: absolute;
  left: 16px;
  color: var(--clr-text-faint);
  pointer-events: none;
  transition: color var(--transition-fast);
}
.input-icon svg { width: 20px; height: 20px; }
.input-wrap:focus-within .input-icon { color: var(--clr-accent); }

.barcode-input {
  width: 100%;
  padding: 16px 48px 16px 48px;
  border-radius: var(--radius-md);
  border: 2px solid var(--clr-glass-border);
  background: rgba(255,255,255,0.04);
  color: var(--clr-text);
  font-family: 'JetBrains Mono', monospace;
  font-size: 1.15rem;
  letter-spacing: .04em;
  outline: none;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);
  caret-color: var(--clr-accent);
}
.barcode-input::placeholder { color: var(--clr-text-faint); font-family: 'Inter', sans-serif; font-size: 1rem; letter-spacing: 0; }
.barcode-input:focus {
  border-color: var(--clr-accent);
  background: rgba(16,185,129,0.04);
  box-shadow: 0 0 0 4px var(--clr-accent-glow);
}

.clear-btn {
  position: absolute;
  right: 12px;
  width: 30px; height: 30px;
  border-radius: 50%;
  border: none;
  background: rgba(255,255,255,0.08);
  color: var(--clr-text-muted);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  opacity: 0;
  transition: opacity var(--transition-fast), background var(--transition-fast);
}
.clear-btn svg { width: 14px; height: 14px; }
.clear-btn:hover { background: rgba(255,255,255,0.15); color: var(--clr-text); }
.input-wrap:focus-within .clear-btn,
.barcode-input:not(:placeholder-shown) ~ .clear-btn { opacity: 1; }

/* Hint row */
.hint-row {
  font-size: .73rem;
  color: var(--clr-text-faint);
  letter-spacing: .02em;
}
.kbd {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 4px;
  border: 1px solid var(--clr-text-faint);
  font-family: 'JetBrains Mono', monospace;
  font-size: .70rem;
  color: var(--clr-text-muted);
  line-height: 1.6;
  vertical-align: middle;
}

/* ══════════════════════════════════════════
   RESULT CARDS
══════════════════════════════════════════ */
.result-section { width: 100%; }

.result-card {
  padding: 32px;
  transition: opacity var(--transition-med), transform var(--transition-med);
  animation: cardIn var(--transition-slow) both;
}

@keyframes cardIn {
  from { opacity:0; transform: translateY(12px); }
  to   { opacity:1; transform: translateY(0); }
}

/* ── Idle card ── */
.idle-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  text-align: center;
  padding: 52px 32px;
}
.idle-illustration { width: 160px; opacity: .5; }
.idle-scan-line { animation: scanMove 2.4s ease-in-out infinite; }
@keyframes scanMove {
  0%,100% { transform: translateY(-20px); opacity:.3; }
  50%      { transform: translateY(20px); opacity:1; }
}
.idle-title { font-size: 1.05rem; font-weight: 600; color: var(--clr-text-muted); }
.idle-body  { font-size: .85rem; color: var(--clr-text-faint); max-width: 340px; line-height: 1.6; }
.idle-body strong { color: var(--clr-text-muted); }

/* ── Loading card ── */
.loading-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  padding: 48px 32px;
}
.spinner { position: relative; width: 56px; height: 56px; }
.spinner-ring {
  width: 100%; height: 100%;
  border-radius: 50%;
  border: 3px solid rgba(255,255,255,0.06);
  border-top-color: var(--clr-accent);
  animation: spin 0.9s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.loading-text { font-size: .90rem; color: var(--clr-text-muted); }

/* ── Result header (shared) ── */
.result-header {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  margin-bottom: 28px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--clr-glass-border);
}

.result-status-icon {
  width: 52px; height: 52px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.result-status-icon svg { width: 26px; height: 26px; }

.success-icon { background: rgba(16,185,129,0.15); color: var(--clr-accent-light); border: 2px solid rgba(16,185,129,0.4); }
.error-icon   { background: rgba(239,68,68,0.12);  color: var(--clr-error-light);  border: 2px solid rgba(239,68,68,0.35); }

.result-status-text { flex: 1; }
.status-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.status-success { background: rgba(16,185,129,0.15); color: var(--clr-accent-light); border: 1px solid rgba(16,185,129,0.35); }
.status-error   { background: rgba(239,68,68,0.12);  color: var(--clr-error-light);  border: 1px solid rgba(239,68,68,0.30); }

.result-item-name {
  font-size: 1.45rem;
  font-weight: 700;
  line-height: 1.25;
  color: var(--clr-text);
}

/* Image area */
.result-image-wrap {
  width: 80px; height: 80px;
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1px solid var(--clr-glass-border);
  flex-shrink: 0;
}
.result-image { width: 100%; height: 100%; object-fit: cover; }
.result-image-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  background: var(--clr-glass);
  color: var(--clr-text-faint);
}
.result-image-placeholder svg { width: 28px; height: 28px; }

/* Detail grid */
.result-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 14px;
}

.result-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 14px 16px;
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--clr-glass-border);
  transition: background var(--transition-fast);
}
.result-field:hover { background: rgba(255,255,255,0.06); }
.result-field.full-width { grid-column: 1 / -1; }

.field-label {
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--clr-text-faint);
}
.field-value {
  font-size: .90rem;
  font-weight: 500;
  color: var(--clr-text);
  word-break: break-word;
}
.field-value.mono {
  font-family: 'JetBrains Mono', monospace;
  font-size: .85rem;
  color: var(--clr-accent-light);
}
.field-value .chip {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 999px;
  background: rgba(16,185,129,0.12);
  border: 1px solid rgba(16,185,129,0.25);
  color: var(--clr-accent-light);
  font-size: .75rem;
}

/* Success card glow on visible */
.success-card:not(.hidden) {
  box-shadow: var(--shadow-card), var(--shadow-glow-ok);
  border-color: rgba(16,185,129,0.25);
}
.error-card:not(.hidden) {
  box-shadow: var(--shadow-card), var(--shadow-glow-err);
  border-color: rgba(239,68,68,0.20);
}

/* Error message text */
.error-message-text {
  font-size: .88rem;
  color: var(--clr-text-muted);
  line-height: 1.6;
}

/* ══════════════════════════════════════════
   ADMIN PANEL
══════════════════════════════════════════ */
.admin-backdrop {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.55);
  z-index: 190;
  backdrop-filter: blur(2px);
  animation: fadeIn var(--transition-fast) both;
}
@keyframes fadeIn { from{opacity:0} to{opacity:1} }

.admin-panel {
  position: fixed;
  top: 0; right: 0;
  width: min(480px, 95vw);
  height: 100dvh;
  border-radius: 0;
  border-right: none;
  z-index: 200;
  display: flex;
  flex-direction: column;
  gap: 0;
  transform: translateX(110%);
  transition: transform var(--transition-slow);
  overflow: hidden;
}
.admin-panel.open {
  transform: translateX(0);
  box-shadow: -8px 0 60px rgba(0,0,0,0.6);
}

.admin-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 20px 16px;
  border-bottom: 1px solid var(--clr-glass-border);
  flex-shrink: 0;
}
.admin-title {
  display: flex; align-items: center; gap: 10px;
  font-size: 1rem; font-weight: 700;
}

.admin-search-row {
  padding: 16px 20px;
  border-bottom: 1px solid var(--clr-glass-border);
  flex-shrink: 0;
}
.admin-search-input {
  width: 100%;
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--clr-glass-border);
  background: rgba(255,255,255,0.04);
  color: var(--clr-text);
  font-family: 'Inter', sans-serif;
  font-size: .85rem;
  outline: none;
  transition: border-color var(--transition-fast);
}
.admin-search-input:focus { border-color: var(--clr-accent); }
.admin-search-input::placeholder { color: var(--clr-text-faint); }

.admin-table-wrap {
  flex: 1;
  overflow-y: auto;
  padding: 0;
  scrollbar-width: thin;
  scrollbar-color: var(--clr-text-faint) transparent;
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .80rem;
}
.admin-table thead th {
  padding: 10px 12px;
  text-align: left;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--clr-text-faint);
  background: rgba(255,255,255,0.03);
  position: sticky; top: 0; z-index: 2;
  border-bottom: 1px solid var(--clr-glass-border);
}
.admin-table tbody tr {
  border-bottom: 1px solid rgba(255,255,255,0.04);
  transition: background var(--transition-fast);
}
.admin-table tbody tr:hover { background: rgba(255,255,255,0.04); }
.admin-table tbody td {
  padding: 10px 12px;
  vertical-align: middle;
  color: var(--clr-text-muted);
  max-width: 140px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.admin-table tbody td:first-child { font-family: 'JetBrains Mono', monospace; font-size: .75rem; color: var(--clr-accent-light); }
.col-actions { text-align: right; }
.admin-empty { padding: 40px; text-align: center; color: var(--clr-text-faint); font-size: .85rem; }

.admin-action-btn {
  padding: 4px 8px;
  border-radius: 5px;
  border: 1px solid var(--clr-glass-border);
  background: transparent;
  color: var(--clr-text-muted);
  font-size: .72rem;
  cursor: pointer;
  transition: var(--transition-fast);
  margin-left: 4px;
}
.admin-action-btn:hover { background: rgba(255,255,255,0.08); color: var(--clr-text); }
.admin-action-btn.del:hover { border-color: var(--clr-error); color: var(--clr-error-light); background: rgba(239,68,68,0.08); }

.admin-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px;
  border-top: 1px solid var(--clr-glass-border);
  flex-shrink: 0;
}
.admin-count { font-size: .78rem; color: var(--clr-text-faint); }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 9px 18px;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  font-family: 'Inter', sans-serif;
  font-size: .83rem;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition-fast);
  outline: none;
  text-decoration: none;
}
.btn-primary {
  background: var(--clr-accent);
  color: #fff;
  border-color: var(--clr-accent);
}
.btn-primary:hover  { background: var(--clr-accent-light); border-color: var(--clr-accent-light); box-shadow: 0 0 18px var(--clr-accent-glow); }
.btn-primary:active { transform: scale(.96); }

.btn-ghost {
  background: transparent;
  color: var(--clr-text-muted);
  border-color: var(--clr-glass-border);
}
.btn-ghost:hover  { background: var(--clr-glass-hover); color: var(--clr-text); }
.btn-ghost:active { transform: scale(.96); }

/* ══════════════════════════════════════════
   MODAL
══════════════════════════════════════════ */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.65);
  z-index: 300;
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
  backdrop-filter: blur(4px);
  animation: fadeIn var(--transition-fast) both;
}
.modal {
  width: min(520px, 100%);
  max-height: 90dvh;
  overflow-y: auto;
  padding: 28px;
  border-radius: var(--radius-xl);
  animation: modalIn var(--transition-med) both;
}
@keyframes modalIn {
  from { opacity:0; transform: scale(.94) translateY(12px); }
  to   { opacity:1; transform: scale(1) translateY(0); }
}

.modal-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 24px;
}
.modal-title { font-size: 1.1rem; font-weight: 700; }

.modal-form { display: flex; flex-direction: column; gap: 16px; }

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 400px) { .form-row { grid-template-columns: 1fr; } }

.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-group label {
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--clr-text-muted);
}
.req { color: var(--clr-accent); }
.form-group input,
.form-group textarea {
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--clr-glass-border);
  background: rgba(255,255,255,0.04);
  color: var(--clr-text);
  font-family: 'Inter', sans-serif;
  font-size: .87rem;
  outline: none;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  resize: vertical;
}
.form-group input:focus,
.form-group textarea:focus {
  border-color: var(--clr-accent);
  box-shadow: 0 0 0 3px var(--clr-accent-glow);
}

.form-error {
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  background: rgba(239,68,68,0.10);
  border: 1px solid rgba(239,68,68,0.30);
  color: var(--clr-error-light);
  font-size: .82rem;
}

.modal-actions {
  display: flex; gap: 12px; justify-content: flex-end;
  padding-top: 8px;
}

/* ══════════════════════════════════════════
   TOAST NOTIFICATIONS
══════════════════════════════════════════ */
.toast-container {
  position: fixed;
  bottom: 28px; left: 50%;
  transform: translateX(-50%);
  z-index: 400;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: center;
  pointer-events: none;
}

.toast {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 20px;
  border-radius: 999px;
  background: rgba(30,42,60,0.95);
  border: 1px solid var(--clr-glass-border);
  backdrop-filter: blur(16px);
  font-size: .83rem;
  font-weight: 500;
  color: var(--clr-text);
  box-shadow: 0 4px 24px rgba(0,0,0,0.5);
  pointer-events: all;
  animation: toastIn 0.3s cubic-bezier(.34,1.56,.64,1) both;
}
.toast.removing { animation: toastOut 0.25s ease-in both; }
.toast-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.toast.success .toast-dot { background: var(--clr-accent); }
.toast.error   .toast-dot { background: var(--clr-error);  }
.toast.info    .toast-dot { background: var(--clr-blue);   }

@keyframes toastIn  { from{opacity:0;transform:translateY(16px) scale(.9)} to{opacity:1;transform:translateY(0) scale(1)} }
@keyframes toastOut { from{opacity:1;transform:scale(1)} to{opacity:0;transform:scale(.88)} }

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media (max-width: 600px) {
  .main-content { padding: 24px 14px 60px; gap: 18px; }
  .scanner-card { padding: 20px 16px 16px; }
  .result-card  { padding: 22px 16px; }
  .result-item-name { font-size: 1.2rem; }
  .result-image-wrap { width: 60px; height: 60px; }
  .logo-sub { display: none; }
  .admin-panel { width: 100vw; }
}

@media (min-width: 1024px) {
  :root { --max-w: 860px; }
}
