*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#3d5c5c;--primary-hover:#ffb366;--primary-light:#8fd6ce;--success:#16a34a;--error:#dc2626;--warning:#d97706;--bg:#f8fafc;--surface:#fff;--border:#e2e8f0;--text:#3d5c5c;--text-muted:#64748b;--radius:5px;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Figtree,sans-serif}#root{flex-direction:column;align-items:center;min-height:100vh;display:flex}.app-header{background:var(--surface);border-bottom:1px solid var(--border);width:100%;box-shadow:var(--shadow);z-index:100;position:sticky;top:0}.app-header-inner{justify-content:space-between;align-items:center;max-width:600px;height:60px;margin:0 auto;padding:0 16px;display:flex}.header-logo{flex-shrink:0;width:auto;height:36px}.header-spacer{flex-shrink:0;width:88px}.header-back-btn{padding:8px 14px}.header-user-wrap{flex-shrink:0;justify-content:flex-end;width:88px;display:flex;position:relative}.header-user-btn{border:1.5px solid var(--border);background:var(--bg);width:36px;height:36px;color:var(--text-muted);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.header-user-btn:hover{background:var(--primary-light);color:var(--primary);border-color:var(--primary-light)}.header-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);z-index:200;flex-direction:column;gap:10px;min-width:200px;padding:12px;display:flex;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 4px 16px #0000001f}.header-dropdown-info{border-bottom:1px solid var(--border);flex-direction:column;gap:6px;padding-bottom:10px;display:flex}.header-dropdown-email{color:var(--text-muted);word-break:break-all;font-size:13px}.role-badge{letter-spacing:.04em;text-transform:uppercase;border-radius:20px;width:fit-content;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.role-badge--administrator{background:var(--primary-light);color:var(--primary)}.role-badge--staff{color:var(--text-muted);background:#f1f5f9}.header-dropdown-signout{width:100%;font-size:14px}.login-page{background:var(--bg);justify-content:center;align-items:center;width:100%;min-height:100vh;padding:24px 16px;display:flex}.login-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:400px;box-shadow:var(--shadow);flex-direction:column;align-items:center;padding:40px 32px;display:flex}.login-logo{width:auto;height:40px;margin-bottom:24px}.login-title{color:var(--text);margin-bottom:6px;font-size:22px;font-weight:800}.login-subtitle{color:var(--text-muted);text-align:center;margin-bottom:28px;font-size:14px}.login-box form{width:100%}.turnstile-wrap{justify-content:center;margin-bottom:16px;display:flex}.page{flex:1;width:100%;max-width:520px;padding:24px 16px}.scanner-page{max-width:600px}@media (width>=640px){.page{padding:36px 24px}}@media (width>=1024px){.page{padding:48px 32px}}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;padding:12px 20px;font-size:15px;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff;width:100%}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{color:var(--text-muted);border:1px solid var(--border);background:0 0}.btn-ghost:hover{background:var(--border);color:var(--text)}.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);padding:24px}.page-header{text-align:center;margin-bottom:32px}.page-header h1{color:var(--text);margin-bottom:6px;font-size:28px;font-weight:700}.page-header p{color:var(--text-muted);font-size:14px}.page-header-icon{margin-bottom:12px;font-size:48px}@media (width>=640px){.page-header h1{font-size:32px}}.form-group{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.form-group label{color:var(--text);text-transform:uppercase;letter-spacing:.05em;font-size:13px;font-weight:600}.form-group input,.form-group select{border:1px solid var(--border);color:var(--text);background:var(--surface);appearance:none;border-radius:8px;width:100%;padding:12px 14px;font-size:16px;transition:border-color .15s}.form-group input:focus,.form-group select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #1d4ed826}.form-group select{cursor:pointer;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 10px center;background-repeat:no-repeat;background-size:20px;padding-right:36px}.form-error{color:var(--error);margin-bottom:12px;font-size:13px}.form-actions{gap:8px;display:flex}.form-actions .btn-primary{flex:1;width:auto}.status-text{text-align:center;color:var(--text-muted);margin-top:24px;font-size:14px}.divider{color:var(--text-muted);align-items:center;gap:12px;margin:24px 0;font-size:13px;display:flex}.divider:before,.divider:after{content:"";background:var(--border);flex:1;height:1px}.scanner-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.scanner-title-group{flex:1;min-width:0}.scanner-title-group h1{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:20px;font-weight:700;overflow:hidden}@media (width>=640px){.scanner-title-group h1{font-size:22px}}.scanner-wrapper{border-radius:var(--radius);border:1px solid var(--border);aspect-ratio:4/3;background:#000;width:100%;position:relative;overflow:hidden}.scanner-video{object-fit:cover;width:100%;height:100%;display:block}.scanner-hint{text-align:center;color:var(--text-muted);margin-top:12px;font-size:13px}.scanner-aim{pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.aim-box{aspect-ratio:1;border:3px solid #ffffffe6;border-radius:16px;width:min(65%,260px);position:relative;box-shadow:0 0 0 9999px #00000073,inset 0 0 0 2px #ffffff26}.aim-box:before,.aim-box:after{content:"";border-style:solid;border-color:#60a5fa;width:22px;height:22px;position:absolute}.aim-box:before{border-width:4px 0 0 4px;border-radius:14px 0 0;top:-3px;left:-3px}.aim-box:after{border-width:0 4px 4px 0;border-radius:0 0 14px;bottom:-3px;right:-3px}.scanner-overlay{border-radius:var(--radius);z-index:10;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:20px 16px;display:flex;position:absolute;inset:0;overflow-y:auto}.scanner-overlay.loading{background:#fffffff2}.scanner-overlay.success{background:#dcfce7f7}.scanner-overlay.duplicate{background:#fef3c7f7}.scanner-overlay.error{background:#fee2e2f7}.scanner-overlay.invalid{background:#f1f5f9f7}.scanner-overlay .overlay-icon{font-size:48px;line-height:1}.scanner-overlay h3{color:var(--text);font-size:19px;font-weight:800}.scanner-overlay p{color:var(--text-muted);max-width:280px;font-size:14px}.status-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;display:flex}.success-bg{background:var(--success)}.warning-bg{background:var(--warning)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:4px solid var(--primary-light);border-top-color:var(--primary);border-radius:50%;width:52px;height:52px;animation:.8s linear infinite spin}.camera-error{text-align:center;background:var(--surface);flex-direction:column;justify-content:center;align-items:center;gap:10px;height:100%;padding:32px 24px;display:flex}.camera-error-icon{font-size:40px}.camera-error h3{font-size:17px;font-weight:700}.camera-error p{color:var(--text-muted);max-width:280px;font-size:14px}.camera-error-sub{margin-top:4px;font-size:13px!important}.camera-error-hint{background:var(--primary-light);color:var(--primary);border-radius:8px;max-width:300px;margin-top:8px;padding:10px 14px;font-size:13px;line-height:1.5}.camera-error-hint code{background:#00000014;border-radius:4px;padding:1px 5px;font-family:monospace}.ticket-card{text-align:left;background:#fff;border-radius:10px;width:100%;max-width:300px;padding:12px 16px;box-shadow:0 1px 4px #00000014}.ticket-name{color:var(--text);margin-bottom:2px;font-size:17px;font-weight:700}.ticket-company{color:var(--text-muted);margin-bottom:8px;font-size:13px}.ticket-fields{border-top:1px solid var(--border);flex-direction:column;gap:5px;margin-top:8px;padding-top:8px;display:flex}.ticket-field{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.ticket-field-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0;font-size:11px;font-weight:700}.ticket-field-value{color:var(--text);text-align:right;word-break:break-word;font-size:13px;font-weight:500}.ticket-raw{color:var(--text-muted);word-break:break-all;max-width:260px;font-size:12px}.scan-counter{background:var(--primary-light);cursor:pointer;border:none;border-radius:5px;flex-direction:column;flex-shrink:0;align-items:center;min-width:60px;padding:6px 14px;transition:opacity .15s;display:flex}.scan-counter:hover{opacity:.8}.scan-counter-number{color:var(--primary);font-size:22px;font-weight:800;line-height:1}.scan-counter-label{color:var(--primary);text-transform:uppercase;letter-spacing:.06em;margin-top:2px;font-size:10px;font-weight:600}.checkins-page{max-width:720px}.checkins-toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.checkins-search{border:1px solid var(--border);border-radius:var(--radius);color:var(--text);background:var(--surface);flex:1;padding:10px 14px;font-family:inherit;font-size:14px;transition:border-color .15s}.checkins-search:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #3d5c5c1f}.checkins-per-page{border:1px solid var(--border);border-radius:var(--radius);color:var(--text);background:var(--surface);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 8px center;background-repeat:no-repeat;background-size:18px;flex-shrink:0;padding:10px 32px 10px 12px;font-family:inherit;font-size:14px}.checkins-per-page:focus{border-color:var(--primary);outline:none}.btn-secondary{background:var(--surface-alt,#e5e7eb);color:var(--text,#111827)}.btn-secondary:hover:not(:disabled){background:#d1d5db}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-full{width:100%}.btn-export{background:var(--primary);color:#fff;white-space:nowrap;flex-shrink:0;padding:10px 16px;font-size:14px}.btn-export:hover:not(:disabled){background:var(--primary-hover);color:var(--text)}.btn-export:disabled{opacity:.4;cursor:not-allowed}.checkins-table-wrap{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);overflow-x:auto}.checkins-table{border-collapse:collapse;width:100%;font-size:14px}.checkins-table thead{background:var(--bg);border-bottom:1px solid var(--border)}.checkins-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);white-space:nowrap;padding:11px 14px;font-size:11px;font-weight:700}.checkins-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 14px}.checkins-table tbody tr:last-child td{border-bottom:none}.checkins-table tbody tr:hover{background:var(--bg)}.col-num{color:var(--text-muted);width:36px;font-size:12px}.col-name{font-weight:600}.col-email{color:var(--text-muted);word-break:break-all}.col-time{white-space:nowrap;color:var(--text-muted);font-size:13px}.col-empty{color:var(--border)}.checkins-pagination{justify-content:center;align-items:center;gap:16px;margin-top:20px;display:flex}.pag-btn{padding:8px 16px;font-size:14px}.pag-info{color:var(--text-muted);font-size:13px}.home-events-card{margin-top:12px}.users-section-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:12px;font-size:13px;font-weight:700}.users-list-heading{margin-top:28px}.users-list{flex-direction:column;gap:10px;display:flex}.user-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex}.user-row-email{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:14px;font-weight:600;overflow:hidden}.user-row-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.user-role-select{border:1px solid var(--border);border-radius:var(--radius);color:var(--text);background:var(--bg);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 6px center;background-repeat:no-repeat;background-size:16px;padding:7px 28px 7px 10px;font-family:inherit;font-size:13px}.events-list{flex-direction:column;gap:10px;display:flex}.event-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.event-row-info{flex:1;min-width:0}.event-row-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:16px;font-weight:700;overflow:hidden}.event-row-count{color:var(--text-muted);margin-top:3px;font-size:13px}.event-row-actions{flex-shrink:0;gap:8px;display:flex}.event-btn{padding:8px 16px;font-size:14px}
