:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--accent: #3b82f6;--accent-glow: rgba(59, 130, 246, .4);--success: #10b981;--success-glow: rgba(16, 185, 129, .3);--warning: #f59e0b;--danger: #ef4444;--gradient-primary: linear-gradient(135deg, #3b82f6 0%, #8b5cf6 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #059669 100%);--gradient-scanner: linear-gradient(180deg, transparent 0%, rgba(59, 130, 246, .1) 50%, transparent 100%);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px var(--accent-glow);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: .375rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-full: 9999px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;min-height:100dvh;overflow-x:hidden;line-height:1.5}.app{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;max-width:600px;margin:0 auto;position:relative}.header{background:var(--bg-secondary);padding:var(--spacing-md) var(--spacing-lg);display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--bg-tertiary);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header h1{font-size:1.1rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-right{display:flex;align-items:center;gap:var(--spacing-sm)}.current-user{background:var(--accent);color:#fff;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:.75rem;font-weight:600;cursor:pointer}.stats{background:var(--bg-tertiary);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:.875rem;color:var(--text-secondary)}.stats #scanCount{font-weight:700;color:var(--success);font-size:1.1rem}.main{flex:1;display:flex;flex-direction:column;padding:var(--spacing-md);gap:var(--spacing-md)}.scanner-container{position:relative;width:100%;aspect-ratio:4 / 3;background:var(--bg-secondary);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg),var(--shadow-glow);border:2px solid var(--bg-tertiary)}#reader{width:100%;height:100%}#reader video{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-lg)}.scanner-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;display:flex;align-items:center;justify-content:center}.scan-line{position:absolute;width:80%;height:3px;background:var(--gradient-primary);box-shadow:0 0 10px var(--accent),0 0 20px var(--accent-glow);border-radius:var(--radius-full);animation:scanLine 2s ease-in-out infinite}@keyframes scanLine{0%,to{transform:translateY(-60px);opacity:.5}50%{transform:translateY(60px);opacity:1}}.last-scan{background:var(--gradient-success);padding:var(--spacing-md);border-radius:var(--radius-md);text-align:center;animation:slideUp .3s ease-out;box-shadow:var(--shadow-md)}.last-scan.hidden{display:none}.last-scan-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;opacity:.8;margin-bottom:var(--spacing-xs)}.last-scan-code{font-family:var(--font-mono);font-size:1.25rem;font-weight:700;letter-spacing:.1em}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.status{text-align:center;color:var(--text-secondary);font-size:.875rem;padding:var(--spacing-sm)}.status.error{color:var(--danger)}.status.success{color:var(--success)}.confirm-panel{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:500;padding:var(--spacing-lg)}.confirm-panel.hidden{display:none}.confirm-panel.show{animation:fadeIn .2s ease-out}.confirm-content{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);width:100%;max-width:400px;box-shadow:var(--shadow-lg);animation:scaleIn .2s ease-out}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirm-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.confirm-label{font-size:.875rem;color:var(--text-secondary)}.confirm-count{background:var(--accent);color:#fff;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:.75rem;font-weight:700}.confirm-code{font-family:var(--font-mono);font-size:1rem;color:var(--text-muted);margin-bottom:var(--spacing-sm)}.confirm-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-xs);line-height:1.3}.confirm-author{font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.confirm-actions{display:flex;gap:var(--spacing-sm)}.confirm-btn{flex:1;padding:var(--spacing-md);border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.confirm-btn.ok{background:var(--gradient-success);color:#fff}.confirm-btn.ok:hover{transform:translateY(-2px);box-shadow:0 4px 15px var(--success-glow)}.confirm-btn.cancel{background:var(--bg-tertiary);color:var(--text-secondary)}.confirm-btn.cancel:hover{background:var(--bg-primary)}.history-panel{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:600px;max-height:50vh;background:var(--bg-secondary);border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:0 -4px 20px #00000080;z-index:200;transition:transform .3s ease-out;display:flex;flex-direction:column}.history-panel.hidden{transform:translate(-50%) translateY(calc(100% - 60px))}.history-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--bg-tertiary);flex-shrink:0}.history-header h2{font-size:1rem;font-weight:600}.clear-btn{background:transparent;border:1px solid var(--danger);color:var(--danger);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-sm);font-size:.75rem;cursor:pointer;transition:all .2s ease}.clear-btn:hover{background:var(--danger);color:#fff}.close-history-btn{background:var(--bg-tertiary);border:none;color:var(--text-primary);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-sm);font-size:.75rem;cursor:pointer;transition:all .2s ease}.close-history-btn:hover{background:var(--accent)}.history-list{list-style:none;overflow-y:auto;flex:1;padding:var(--spacing-sm)}.history-item{display:flex;flex-direction:column;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--radius-sm);margin-bottom:var(--spacing-xs);animation:fadeIn .2s ease-out}.history-item-main{display:flex;flex-direction:column;gap:2px}.history-item-title{font-size:.875rem;font-weight:600;color:var(--text-primary)}.history-item-code{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted)}.history-item-meta{display:flex;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-xs)}.user-badge{background:var(--accent);color:#fff;padding:2px 6px;border-radius:var(--radius-sm);font-size:.625rem;font-weight:600}.count-badge{background:var(--warning);color:#000;padding:2px 6px;border-radius:var(--radius-sm);font-size:.625rem;font-weight:700}.history-item-time{font-size:.625rem;color:var(--text-muted);margin-left:auto}.history-empty{text-align:center;color:var(--text-muted);padding:var(--spacing-xl);font-size:.875rem}.footer{display:flex;gap:var(--spacing-sm);padding:var(--spacing-md);padding-bottom:calc(var(--spacing-md) + env(safe-area-inset-bottom));background:var(--bg-secondary);border-top:1px solid var(--bg-tertiary);position:sticky;bottom:0}.action-btn{flex:1;padding:var(--spacing-sm) var(--spacing-xs);border:none;border-radius:var(--radius-md);font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs)}.export-btn{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md)}.export-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.custom-btn{background:var(--warning);color:#000}.history-btn{background:var(--bg-tertiary);color:var(--text-primary)}.history-btn:hover{background:var(--bg-primary)}.undo-btn{background:var(--danger);color:#fff}.undo-btn:disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed;opacity:.5}.undo-btn:not(:disabled):hover{opacity:.9}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:600;padding:var(--spacing-lg)}.modal.hidden{display:none}.modal-content{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-xl);width:100%;max-width:360px;text-align:center}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.modal-header h3{font-size:1.125rem}.modal-close{background:none;border:none;color:var(--text-muted);font-size:1.25rem;cursor:pointer;padding:var(--spacing-xs)}.modal-content h3{font-size:1.25rem;margin-bottom:var(--spacing-sm)}.modal-desc{font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.modal-input{width:100%;padding:var(--spacing-md);border:2px solid var(--bg-tertiary);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:1rem;margin-bottom:var(--spacing-md);text-align:center}.modal-input:focus{outline:none;border-color:var(--accent)}.modal-btn{width:100%;padding:var(--spacing-md);background:var(--gradient-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.modal-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow)}.generated-barcode{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--bg-tertiary)}.generated-barcode canvas{background:#fff;border-radius:var(--radius-sm);max-width:100%}.download-btn{margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-lg);background:var(--success);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer}.barcode-hint{font-size:.75rem;color:var(--text-muted);margin-top:var(--spacing-sm)}.toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);background:var(--bg-tertiary);color:var(--text-primary);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);font-size:.875rem;box-shadow:var(--shadow-lg);z-index:700;animation:toastIn .3s ease-out}.toast.warning{background:var(--warning);color:#000}.toast.success{background:var(--success);color:#fff}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.hidden{display:none!important}@media (min-width: 640px){.scanner-container{aspect-ratio:16 / 9}}@media (prefers-reduced-motion: reduce){.scan-line{animation:none;opacity:.7}*{animation-duration:.01ms!important;transition-duration:.01ms!important}}
