.navbar{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:#2563eb;color:#fff}.navbar-title{font-size:18px;font-weight:700}.navbar-links{display:flex;gap:20px}.navbar-link{color:#dbeafe;text-decoration:none;font-size:14px;font-weight:600}.navbar-link.active{color:#fff;text-decoration:underline}.navbar-user{display:flex;align-items:center;gap:12px;font-size:14px}.navbar-user button{background:#1d4ed8;color:#fff;border:none;border-radius:6px;padding:6px 12px;cursor:pointer;font-size:13px}.navbar-user button:hover{background:#1e40af}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f3f4f6}.login-card{background:#fff;border-radius:12px;padding:32px;width:360px;box-shadow:0 2px 12px #00000014}.login-title{font-size:22px;font-weight:700;color:#111827;margin-bottom:24px;text-align:center}.login-label{display:block;font-size:14px;font-weight:600;color:#111827;margin-bottom:6px;margin-top:14px}.login-input{width:100%;border:1px solid #d1d5db;border-radius:8px;padding:10px 12px;font-size:15px;box-sizing:border-box}.login-error{color:#dc2626;font-size:13px;margin-top:12px}.login-button{width:100%;background:#2563eb;color:#fff;border:none;border-radius:8px;height:44px;font-size:15px;font-weight:600;margin-top:24px;cursor:pointer}.login-button:disabled{background:#93c5fd;cursor:not-allowed}.ticket-print{display:none}@media print{@page{size:80mm auto;margin:4mm}body *{visibility:hidden}.ticket-print,.ticket-print *{visibility:visible}.ticket-print{display:block;position:absolute;top:0;left:0;width:72mm;font-family:Courier New,monospace;text-align:center}.ticket-print-header{font-size:12px;font-weight:700;margin-bottom:6px}.ticket-print-number{font-size:48px;font-weight:700;margin:8px 0}.ticket-print-row{font-size:12px;margin-bottom:4px}}.queue-page{padding:24px;max-width:480px;margin:0 auto}.queue-loading{padding:48px;text-align:center;color:#6b7280}.queue-title{font-size:24px;font-weight:700;color:#111827;margin-bottom:20px}.queue-controls{display:flex;gap:16px;margin-bottom:20px}.queue-controls>div{flex:1}.queue-label{display:block;font-size:13px;font-weight:600;color:#374151;margin-bottom:6px}.queue-select{width:100%;border:1px solid #d1d5db;border-radius:8px;padding:8px 10px;font-size:14px;box-sizing:border-box}.queue-quay-display{width:100%;border:1px solid #bfdbfe;border-radius:8px;padding:8px 10px;font-size:14px;font-weight:600;color:#1d4ed8;background:#eff6ff;box-sizing:border-box}.queue-label-auto{font-weight:400;color:#6b7280;font-size:12px}.queue-status-card{background:#eff6ff;border:1px solid #2563eb;border-radius:12px;padding:24px;text-align:center;margin-bottom:20px}.queue-status-number{font-size:56px;font-weight:700;color:#2563eb}.queue-status-label{font-size:13px;color:#6b7280;margin-top:4px}.queue-status-waiting{font-size:14px;color:#374151;margin-top:12px}.queue-error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;border-radius:8px;padding:10px 14px;font-size:14px;margin-bottom:16px}.queue-actions{display:flex;gap:12px;flex-wrap:wrap}.queue-button{flex:1;min-width:120px;height:44px;border-radius:8px;border:none;font-size:15px;font-weight:600;cursor:pointer}.queue-button:disabled{opacity:.6;cursor:not-allowed}.queue-button-primary{background:#2563eb;color:#fff}.queue-button-secondary{background:#e5e7eb;color:#111827}.scan-page{padding:24px;max-width:480px;margin:0 auto}.scan-title{font-size:24px;font-weight:700;color:#111827;margin-bottom:20px}.scan-viewport{width:100%;min-height:280px;background:#111827;border-radius:8px;margin-bottom:16px;overflow:hidden}.scan-button{width:100%;height:44px;border-radius:8px;border:none;background:#2563eb;color:#fff;font-size:15px;font-weight:600;cursor:pointer;margin-top:8px}.scan-button-stop{background:#dc2626}.scan-error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;border-radius:8px;padding:10px 14px;font-size:14px;margin-top:16px}.scan-result{margin-top:20px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;padding:16px}.scan-result-row{font-size:14px;color:#166534;margin-bottom:8px}.upload-page{padding:24px;max-width:480px;margin:0 auto}.upload-title{font-size:24px;font-weight:700;color:#111827;margin-bottom:16px}.upload-hint{background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8;border-radius:8px;padding:10px 14px;font-size:14px;margin-bottom:16px}.upload-label{display:block;font-size:14px;font-weight:600;color:#111827;margin-top:16px;margin-bottom:6px}.upload-required{color:#dc2626}.upload-input{width:100%;border:1px solid #d1d5db;border-radius:8px;padding:10px 12px;font-size:14px;box-sizing:border-box}.upload-error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;border-radius:8px;padding:10px 14px;font-size:14px;margin-top:16px}.upload-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534;border-radius:8px;padding:10px 14px;font-size:14px;margin-top:16px}.upload-button{width:100%;height:44px;border-radius:8px;border:none;background:#2563eb;color:#fff;font-size:15px;font-weight:600;margin-top:24px;cursor:pointer}.upload-button:disabled{background:#93c5fd;cursor:not-allowed}.stats-page{padding:24px;max-width:480px;margin:0 auto}.stats-title{font-size:24px;font-weight:700;color:#111827;margin-bottom:16px}.stats-placeholder{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;font-size:14px;color:#6b7280;line-height:1.5}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#fff;color:#111827}.app-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;color:#6b7280}
