*{box-sizing:border-box;margin:0;padding:0}:root{--color-primary:#2563eb;--color-primary-hover:#1d4ed8;--color-success:#16a34a;--color-success-hover:#15803d;--color-error:#dc2626;--color-error-hover:#b91c1c;--color-bg:#f8fafc;--color-surface:#fff;--color-text:#1e293b;--color-text-muted:#64748b;--color-border:#e2e8f0;--color-input-bg:#fff;--radius:8px;--shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a}html{color:var(--color-text);background-color:var(--color-bg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:16px;line-height:1.5}body{min-height:100dvh}.container{max-width:480px;margin:0 auto;padding:16px}h1{margin-bottom:8px;font-size:1.5rem;font-weight:600}h2{margin-bottom:8px;font-size:1.25rem;font-weight:600}.card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:16px;padding:20px}.form-group{margin-bottom:16px}.form-label{color:var(--color-text);margin-bottom:6px;font-size:.875rem;font-weight:500;display:block}.form-input,.form-textarea{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-input-bg);width:100%;color:var(--color-text);padding:12px;font-size:16px;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-textarea:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #2563eb1a}.form-textarea{resize:vertical;min-height:80px}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-muted)}.btn{border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px 24px;font-size:1rem;font-weight:500;text-decoration:none;transition:background-color .15s,transform .1s;display:inline-flex}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-success{background:var(--color-success);color:#fff}.btn-success:hover:not(:disabled){background:var(--color-success-hover)}.btn-secondary{background:var(--color-border);color:var(--color-text)}.btn-secondary:hover:not(:disabled){background:#cbd5e1}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background:var(--color-error-hover)}.btn-row{gap:12px;margin-top:16px;display:flex}.btn-row .btn{flex:1}.scanner-container{aspect-ratio:1;border-radius:var(--radius);background:#000;width:100%;max-height:400px;margin-bottom:12px;position:relative;overflow:hidden}.scanner-container video{object-fit:cover;width:100%;height:100%}.scanner-hint{text-align:center;color:var(--color-text-muted);margin-top:8px;font-size:.875rem}.scanner-instructions{color:var(--color-text-muted);text-align:left;margin-top:12px;padding-left:20px;font-size:.875rem;line-height:1.6}.status{border-radius:var(--radius);text-align:center;margin-bottom:12px;padding:12px;font-size:.875rem}.status-info{color:#1e40af;background:#dbeafe}.status-success{color:#166534;background:#dcfce7}.status-error{color:#991b1b;background:#fee2e2}.toast{color:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:1000;background:#1e293b;padding:14px 24px;animation:.2s ease-out toast-in;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.toast-success{background:var(--color-success)}.toast-error{background:var(--color-error)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.passcode-page{flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.passcode-card{text-align:center;width:100%;max-width:320px}.passcode-logo{margin-bottom:16px;font-size:3rem}.admin-page{flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.admin-card{text-align:center;width:100%;max-width:400px}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.text-center{text-align:center}.text-muted{color:var(--color-text-muted)}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.main-page{min-height:100dvh;padding:16px}.header{text-align:center;margin-bottom:20px}@media (max-width:380px){.container{padding:12px}.card{padding:16px}.btn{padding:12px 20px}}
