*,:after,:before{box-sizing:border-box}body,html{overflow-x:hidden}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;max-width:100vw}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.app-loading{align-items:center;color:#666;display:flex;font-size:1.1rem;justify-content:center;min-height:100vh}.app-main{margin:0 auto;max-width:1200px;min-height:calc(100vh - 56px);padding:1rem}.app-modal-overlay{align-items:center;background:#0006;box-sizing:border-box;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1000}.app-modal-card{max-width:360px;position:relative;width:100%}.app-modal-close{background:none;border:none;color:#666;cursor:pointer;font-size:1.5rem;height:2rem;line-height:1;padding:0;position:absolute;right:.5rem;top:.5rem;width:2rem;z-index:1}.app-modal-close:hover{color:#333}.camera-scanner-wrap{background:#111;border:2px solid #333;border-radius:8px;margin-bottom:20px;overflow:hidden}.camera-scanner-header{align-items:center;background:#222;border-bottom:1px solid #444;display:flex;justify-content:space-between;padding:10px 14px}.camera-scanner-header-text{display:flex;flex-direction:column;gap:2px}.camera-scanner-title{color:#eee;font-size:.9375rem;font-weight:600}.camera-scanner-hint{color:#999;font-size:.75rem;font-weight:400}.camera-scanner-close{background:#444;border:1px solid #555;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;padding:6px 12px}.camera-scanner-close:hover{background:#555}.camera-scanner-container{align-items:center;display:flex;justify-content:center;min-height:200px;position:relative}.camera-reader{max-width:100%;width:100%}.camera-reader video{display:block;max-height:320px;width:100%}.camera-scanner-starting{color:#aaa;font-size:.875rem;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.camera-scanner-error{background:#1a1a1a;color:#ddd;padding:20px;text-align:center}.camera-scanner-error p{font-size:.9375rem;line-height:1.4;margin:0 0 14px}.camera-scanner-error-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.camera-scanner-retry-btn{background:#15803d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;padding:8px 18px}.camera-scanner-retry-btn:hover{background:#166534}.camera-scanner-close-btn{background:#06c;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;padding:8px 18px}.camera-scanner-close-btn:hover{background:#0052a3}@media (min-width:768px){.scan-area-with-camera{grid-gap:20px;align-items:start;display:grid;gap:20px;grid-template-columns:1fr 1fr}.scan-area-with-camera.camera-above-only .camera-scanner-wrap{grid-column:1/-1}}@media (min-width:992px){.scan-area-with-camera{grid-template-columns:320px 1fr}.scan-area-with-camera .camera-scanner-wrap{position:-webkit-sticky;position:sticky;top:24px}}.app-layout{display:flex;min-height:100vh;text-align:left}.main-panel{flex:1 1;max-width:600px;min-width:0;padding:24px}.main-panel h1{font-size:1.5rem;margin:0}.history-panel{background:#f5f5f5;border-left:1px solid #ddd;max-height:100vh;min-width:280px;overflow-y:auto;padding:24px;position:-webkit-sticky;position:sticky;top:0;width:320px}.history-panel h2{font-size:1.125rem;margin:0 0 16px}.no-history{color:#666;font-size:.875rem;font-style:italic}.current-scan-section{margin-top:24px}.current-scan-section h2{color:#444;font-size:1rem;margin:0 0 12px}.current-scan-card{background:#fff;border:2px solid #15803d;border-radius:8px;padding:16px}.current-scan-card.scan-blocked{background:#fef2f2;border-color:#b91c1c}.current-scan-card.scan-potential{background:#fffbeb;border-color:#d97706}.scan-blocked-wrap{margin:-16px -16px 16px}.scan-blocked-banner{align-items:center;background:#b91c1c;border-radius:6px 6px 0 0;color:#fff;display:flex;font-size:1rem;font-weight:700;gap:8px;justify-content:center;padding:8px;text-align:center}.scan-blocked-banner.potential-banner{background:#d97706}.reason-toggle-light{font-size:.75rem;opacity:.8}.scan-blocked-reason{animation:slideDown .2s ease-out;background:#991b1b;color:#fff;padding:12px 16px}.scan-blocked-reason.potential-reason{background:#b45309}.match-warning{border-bottom:1px solid #ffffff4d;font-size:.85rem;font-weight:600;margin-bottom:8px;padding-bottom:8px}.reason-label-light{font-size:.75rem;margin-bottom:4px;opacity:.8}.reason-text-light{font-size:.875rem;line-height:1.5;white-space:pre-wrap}.scan-detail{border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:6px 0}.scan-detail:last-child{border-bottom:none}.scan-label{color:#666;font-size:.75rem;font-weight:500}.scan-value{font-size:.875rem;font-weight:600;text-align:right}.scan-value.mono{font-family:ui-monospace,monospace}.scan-attendance-indicator{border-radius:6px;font-size:.9rem;font-weight:600;margin-top:12px;padding:8px 10px}.scan-attendance-indicator.signed{background:#dcfce7;border:1px solid #86efac;color:#166534}.scan-attendance-indicator.not-signed{background:#fef9c3;border:1px solid #fde047;color:#854d0e}.scan-forms-link-wrap{margin-top:8px}.scan-forms-link-btn{background:#0000;border:1px solid #15803d;border-radius:6px;color:#15803d;cursor:pointer;font-size:.875rem;padding:6px 12px;text-decoration:none}.scan-forms-link-btn:hover{background:#15803d;color:#fff}.scan-fill-attendance-btn{background:#06c;border-color:#06c;color:#fff;margin-right:8px}.scan-fill-attendance-btn:hover{background:#0052a3;border-color:#0052a3;color:#fff}.scan-history-section{margin-top:20px}.scan-history-section h3{color:#444;font-size:.875rem;margin:0 0 10px}.scan-history-list{display:flex;flex-direction:column;gap:6px;list-style:none;margin:0;padding:0}.scan-history-list li{align-items:center;background:#fff;border:1px solid #ddd;border-radius:4px;display:flex;font-size:.75rem;gap:8px;padding:8px 10px}.scan-history-list li.history-blocked{background:#fef2f2;border-color:#fca5a5}.history-number{color:#666;font-weight:600;min-width:24px}.history-datetime{color:#333;flex:1 1}.history-blocked-tag{background:#b91c1c;border-radius:3px;color:#fff;font-size:.625rem;font-weight:600;padding:2px 6px}.header-row{gap:12px;justify-content:space-between;margin-bottom:8px}.header-actions,.header-row{align-items:center;display:flex;flex-wrap:wrap}.header-actions{gap:16px}.connection-test{align-items:center;display:flex;gap:8px}.attendance-link{border:1px solid #1a5fb4;border-radius:4px;color:#1a5fb4;font-size:.8rem;padding:6px 12px;text-decoration:none}.attendance-link:hover{background:#e8f0fe;color:#155a9e}.logout-btn{background:#f5f5f5;border:1px solid #ddd;border-radius:6px;color:#666;cursor:pointer;font-size:.8rem;padding:6px 12px}.logout-btn:hover{background:#eee;color:#333}.test-conn-btn{background:#f0f0f0;border:1px solid #ccc;border-radius:4px;cursor:pointer;font-size:.75rem;padding:6px 12px}.test-conn-btn:hover:not(:disabled){background:#e0e0e0}.test-conn-btn:disabled{cursor:not-allowed;opacity:.6}.conn-status{border-radius:4px;font-size:.75rem;font-weight:600;padding:4px 8px}.conn-ok{background:#dcfce7;color:#15803d}.conn-error{background:#fee2e2;color:#b91c1c}.scan-hint{color:#555;font-size:.875rem;margin-bottom:16px}.scan-box-wrap{margin-bottom:24px}.scan-input{border:2px solid #333;border-radius:8px;box-sizing:border-box;font-family:ui-monospace,monospace;font-size:.8125rem;padding:12px;resize:vertical;width:100%}.scan-input:focus{border-color:#06c;box-shadow:0 0 0 3px #06c3;outline:none}.scan-input-summary{background:#0a7c420f;border-color:#0a7c42;font-family:inherit;font-size:1rem;resize:none}.clear-btn{background:#f0f0f0;border:1px solid #ccc;border-radius:6px;cursor:pointer;font-size:.875rem;margin-top:8px;padding:6px 14px}.clear-btn:hover{background:#e0e0e0}.scan-camera-btn{background:#06c;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;margin-left:8px;margin-top:8px;padding:6px 14px}.scan-camera-btn:hover{background:#0052a3}.scan-photo-btn{background:#15803d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;margin-left:8px;margin-top:8px;padding:6px 14px}.scan-photo-btn:hover:not(:disabled){background:#166534}.scan-photo-btn:disabled{cursor:not-allowed;opacity:.7}.camera-error-inline{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#b91c1c;font-size:.875rem;margin-top:8px;padding:10px 12px}.status-section{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.status-bar{border-radius:8px;color:#fff;font-size:1.25rem;font-weight:700;padding:16px 20px;text-align:center;text-transform:uppercase}.age-under{background:#b91c1c}.age-21-plus{background:#15803d}.blocked-yes{background:#b91c1c}.blocked-no{background:#15803d}.clickable{cursor:pointer}.clickable:hover{opacity:.9}.clickable:active{opacity:.8}.blocked-status-wrap{border-radius:8px;overflow:hidden}.blocked-status-wrap .status-bar{align-items:center;border-radius:8px;display:flex;gap:10px;justify-content:center}.blocked-status-wrap .status-bar.blocked-yes{border-radius:8px 8px 0 0}.reason-toggle{font-size:.875rem;opacity:.8}.blocked-reason-panel{animation:slideDown .2s ease-out;background:#991b1b;border-radius:0 0 8px 8px;color:#fff;padding:16px 20px}.reason-label{font-size:.75rem;letter-spacing:.05em;margin-bottom:6px;opacity:.8;text-transform:uppercase}.reason-text{font-size:1rem;line-height:1.6;white-space:pre-wrap}@keyframes slideDown{0%{max-height:0;opacity:0;padding-bottom:0;padding-top:0}to{max-height:200px;opacity:1;padding-bottom:16px;padding-top:16px}}.blocked-manager-section{border-top:1px solid #ddd;margin-top:32px;padding-top:24px}.toggle-blocked-btn{background:#333;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;padding:8px 16px}.toggle-blocked-btn:hover{background:#444}.blocked-manager{margin-top:16px}.add-blocked-form{flex-wrap:wrap;gap:8px;margin-bottom:16px}.add-blocked-form input{flex:1 1;min-width:120px;padding:8px 10px}.add-blocked-form button{padding:8px 14px}.block-person-btn{background:#dc2626;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;margin-top:12px;padding:10px 16px;width:100%}.block-person-btn:hover{background:#b91c1c}.manual-add-hint{color:#666;font-size:.75rem;margin-bottom:8px}.no-blocked{color:#666;font-size:.875rem;font-style:italic}.blocked-table td,.blocked-table th{padding:8px 10px}.remove-btn{background:#f0f0f0;border:1px solid #ccc;padding:4px 10px}.remove-btn:hover{background:#e0e0e0}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.block-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.block-modal{background:#fff;border-radius:10px;box-shadow:0 4px 20px #0000004d;max-width:400px;padding:1.5rem;width:90%}.block-modal h3{color:#c0392b;font-size:1.25rem;margin:0 0 .75rem}.block-modal-name{color:#333;font-size:1.1rem;font-weight:600;margin:0}.block-modal-license{color:#666;font-size:.9rem;margin:.25rem 0 1rem}.block-modal-label{color:#333;display:block;font-size:.9rem;margin-bottom:1rem}.block-modal-textarea{border:1px solid #ccc;border-radius:6px;box-sizing:border-box;display:block;font-family:inherit;font-size:.95rem;margin-top:.5rem;min-height:80px;padding:.75rem;resize:vertical;width:100%}.block-modal-textarea:focus{border-color:#c0392b;box-shadow:0 0 0 2px #c0392b33;outline:none}.block-modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.block-modal-cancel{background:#f5f5f5;border:1px solid #ccc;border-radius:6px;cursor:pointer;font-size:.95rem;padding:.6rem 1.25rem}.block-modal-cancel:hover{background:#e8e8e8}.block-modal-confirm{background:#c0392b;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:.6rem 1.25rem}.block-modal-confirm:hover{background:#a93226}.forms-modal .forms-modal-empty{color:#666;margin:.5rem 0}.forms-modal-list{list-style:none;margin:.75rem 0 0;max-height:280px;overflow-y:auto;padding:0}.forms-modal-item{align-items:center;border-bottom:1px solid #eee;display:flex;gap:10px;padding:8px 0}.forms-modal-item:last-child{border-bottom:none}.forms-modal-date{color:#444;flex:0 0 140px;font-size:.875rem}.forms-modal-id{color:#666;flex:1 1;font-size:.85rem}.forms-modal-view-btn{background:#15803d;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.85rem;padding:4px 10px}.forms-modal-view-btn:hover{background:#166534}@media (max-width:900px){.app-layout{flex-direction:column}.main-panel{max-width:none;padding:16px}.history-panel{border-left:none;border-top:1px solid #ddd;max-height:none;min-width:0;padding:16px;position:static;width:100%}}@media (max-width:640px){.main-panel{padding:12px}.main-panel h1{font-size:1.25rem}.header-row{align-items:flex-start;flex-direction:column;gap:10px}.header-actions{width:100%}.scan-hint{font-size:.8125rem}.scan-input{font-size:16px;min-height:48px;padding:14px}.clear-btn,.logout-btn,.test-conn-btn{min-height:44px;padding:10px 16px}.block-person-btn{min-height:44px;padding:12px 16px}.age-bar{min-height:44px;padding:10px 12px}.current-scan-card{padding:12px}.scan-detail{flex-wrap:wrap;gap:4px;padding:8px 0}.scan-label{flex:0 0 100%}.block-modal{margin:12px;max-width:none;width:calc(100% - 24px)}.block-modal-actions{flex-direction:column}.block-modal-actions button{min-height:44px;width:100%}}@supports (padding:env(safe-area-inset-top)){.app-layout{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.block-modal-overlay{padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}}.admin-container{margin:0 auto;max-width:900px;padding:24px}.admin-header{align-items:center;border-bottom:2px solid #ddd;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:32px;padding-bottom:16px}.admin-header h1{font-size:1.5rem;margin:0}.admin-header-connection{align-items:center;display:flex;gap:8px}.admin-header-connection .test-conn-btn{background:#f0f0f0;border:1px solid #ccc;border-radius:6px;cursor:pointer;font-size:.8rem;padding:6px 12px}.admin-header-connection .test-conn-btn:hover:not(:disabled){background:#e0e0e0}.admin-header-connection .test-conn-btn:disabled{cursor:not-allowed;opacity:.6}.admin-header-connection .conn-status{font-size:.85rem}.admin-header-connection .conn-ok{color:#166534}.admin-header-connection .conn-error{color:#b91c1c}.admin-connection-section{margin-bottom:24px}.admin-connection-actions{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.admin-connection-actions .test-conn-btn{background:#f0f0f0;border:1px solid #ccc;border-radius:6px;cursor:pointer;font-size:.9rem;padding:8px 16px}.admin-connection-actions .test-conn-btn:hover:not(:disabled){background:#e0e0e0}.admin-connection-actions .test-conn-btn:disabled{cursor:not-allowed;opacity:.6}.admin-connection-actions .conn-status{font-size:.9rem}.admin-connection-actions .conn-ok{color:#166534}.admin-connection-actions .conn-error{color:#b91c1c}.admin-tabs{border-bottom:2px solid #e5e7eb;display:flex;gap:0;margin-bottom:24px}.admin-tab{align-items:center;background:#0000;border:none;border-bottom:3px solid #0000;color:#6b7280;cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:.4rem;margin-bottom:-2px;padding:.6rem 1.25rem;transition:color .2s,border-color .2s}.admin-tab:hover{color:#374151}.admin-tab.active{border-bottom-color:#2d6a4f;color:#2d6a4f}.admin-tab-count{background:#e5e7eb;border-radius:999px;color:#4b5563;font-size:.75rem;padding:.15rem .45rem}.admin-tab.active .admin-tab-count{background:#2d6a4f;color:#fff}.back-link{color:#06c;font-size:.875rem;text-decoration:none}.back-link:hover{text-decoration:underline}.admin-header-links{align-items:center;display:flex;gap:16px}.admin-header .logout-btn{background:#f5f5f5;border:1px solid #ddd;border-radius:6px;color:#666;cursor:pointer;font-size:.8rem;padding:6px 12px}.admin-header .logout-btn:hover{background:#eee;color:#333}.add-blocked-section{background:#f9f9f9;border-radius:8px;margin-bottom:32px;padding:20px}.add-blocked-section h2{font-size:1rem;margin:0 0 16px}.block-methods{align-items:flex-start;display:flex;gap:24px}.block-method{flex:1 1;min-width:280px}.block-method h3{color:#444;font-size:.9rem;margin:0 0 12px}.block-divider{align-items:center;color:#888;display:flex;font-size:.85rem;font-weight:600;padding:40px 0}.search-wrapper{position:relative}.search-name-row{display:flex;gap:10px}.search-name-row .search-input{flex:1 1;min-width:0}.search-input{border:1px solid #ccc;border-radius:6px;box-sizing:border-box;font-size:.875rem;padding:10px 12px;width:100%}.search-input:focus{border-color:#06c;box-shadow:0 0 0 2px #0066cc26;outline:none}.search-spinner{color:#888;display:block;font-size:.75rem;font-style:italic;margin-top:8px}.search-error{color:#c00;display:block;font-size:.875rem;margin-top:8px}.search-results{background:#fff;border:1px solid #ddd;border-radius:6px;list-style:none;margin:8px 0 0;max-height:200px;overflow-y:auto;padding:0}.search-result-item{align-items:center;border-bottom:1px solid #eee;cursor:pointer;display:flex;flex-wrap:wrap;gap:8px;padding:10px 12px}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:#f0f7ff}.result-name{color:#333;font-weight:600}.result-license{color:#666;font-family:ui-monospace,monospace;font-size:.8rem}.result-dob{color:#888;font-size:.75rem}.selected-person-card{background:#fff;border:2px solid #b91c1c;border-radius:8px;margin-top:12px;padding:16px}.selected-person-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.selected-label{color:#888;font-size:.75rem;letter-spacing:.5px;text-transform:uppercase}.clear-selection{background:none;border:none;color:#888;cursor:pointer;font-size:1.25rem;line-height:1;padding:0}.clear-selection:hover{color:#333}.selected-person-name{color:#333;font-size:1.1rem;font-weight:600}.selected-person-license{color:#666;font-family:ui-monospace,monospace;font-size:.85rem;margin-bottom:12px}.reason-label{color:#444;display:block;font-size:.85rem;margin-bottom:12px}.reason-textarea{border:1px solid #ccc;border-radius:6px;box-sizing:border-box;display:block;font-family:inherit;font-size:.875rem;margin-top:6px;min-height:60px;padding:10px 12px;resize:vertical;width:100%}.reason-textarea:focus{border-color:#b91c1c;box-shadow:0 0 0 2px #b91c1c26;outline:none}.block-selected-btn{background:#b91c1c;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:10px 20px;width:100%}.block-selected-btn:hover{background:#991b1b}.add-blocked-form{display:flex;flex-direction:column;gap:10px}.add-blocked-form input{border:1px solid #ccc;border-radius:6px;box-sizing:border-box;font-size:.875rem;padding:10px 12px;width:100%}.add-blocked-form button{background:#b91c1c;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:10px 20px}.add-blocked-form button:hover{background:#991b1b}@media (max-width:700px){.block-methods{flex-direction:column}.block-divider{padding:16px 0}}@media (max-width:640px){.admin-container{padding:12px}.admin-header{align-items:flex-start;flex-direction:column;gap:12px}.admin-header-links{flex-wrap:wrap;width:100%}.add-blocked-section{padding:14px}.blocked-table{-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}.blocked-table td,.blocked-table th{font-size:.8125rem;padding:10px 8px}.add-blocked-form input,.reason-textarea,.search-input{font-size:16px;min-height:44px}.add-blocked-form button,.block-selected-btn{min-height:44px}}.blocked-list-section h2,.checkins-section h2{font-size:1rem;margin:0 0 8px}.admin-list-search{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px}.admin-search-input{border:1px solid #ccc;border-radius:6px;font-size:.9rem;max-width:320px;min-width:200px;padding:8px 12px}.admin-search-input:focus{border-color:#2d6a4f;box-shadow:0 0 0 2px #2d6a4f33;outline:none}.admin-search-hint{color:#6b7280;font-size:.85rem}.loading,.no-blocked{color:#666;font-size:.875rem;font-style:italic}.blocked-table{border-collapse:collapse;font-size:.875rem;width:100%}.blocked-table td,.blocked-table th{border-bottom:1px solid #ddd;padding:12px 10px;text-align:left}.blocked-table th{background:#f5f5f5;font-weight:600}.blocked-table .mono{font-family:ui-monospace,monospace}.admin-scans-section{margin-bottom:32px}.admin-scans-section h2{font-size:1.1rem;margin:0 0 .5rem}.scan-blocked-row{background:#fef2f2}.scan-blocked-badge{border-radius:4px;display:inline-block;font-size:.7rem;padding:2px 6px}.remove-btn,.scan-blocked-badge{background:#fee2e2;color:#b91c1c;font-weight:600}.remove-btn{border:1px solid #fca5a5;border-radius:4px;cursor:pointer;font-size:.75rem;padding:6px 12px}.remove-btn:hover{background:#fecaca}.form-hint{color:#666;font-size:.8rem;font-style:italic;margin-bottom:12px}.name-row{display:flex;gap:10px}.name-row input{flex:1 1;min-width:0}.match-badge{border-radius:4px;display:inline-block;font-size:.7rem;font-weight:600;padding:3px 8px;text-transform:uppercase}.match-badge.exact{background:#dcfce7;color:#15803d}.match-badge.name-only{background:#fef3c7;color:#d97706}.name-only-row{background:#fffbeb}.reason-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.checkins-section{margin-bottom:32px}.checkins-section h2{font-size:1rem;margin:0 0 8px}.section-hint{color:#666;font-size:.8125rem;margin:0 0 12px}.view-checkin-btn{background:#1a5fb4;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.8rem;padding:6px 12px}.view-checkin-btn:hover{background:#155a9e}.checkin-modal-overlay{align-items:center;background:#00000080;box-sizing:border-box;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1000}.checkin-modal{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;max-height:95vh;max-width:95vw;overflow:auto}.checkin-modal-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:12px 16px}.checkin-modal-header h3{font-size:1rem;margin:0}.checkin-modal-close{background:none;border:none;color:#666;cursor:pointer;font-size:1.5rem;line-height:1;padding:0 4px}.checkin-modal-close:hover{color:#333}.checkin-modal-body{padding:16px}.checkin-document-image{border:1px solid #ddd;border-radius:4px;display:block;height:auto;max-width:100%}.checkin-modal-actions{margin-top:12px}.checkin-download-btn{background:#1a5fb4;border-radius:4px;color:#fff;display:inline-block;font-size:.875rem;padding:8px 16px;text-decoration:none}.checkin-download-btn:hover{background:#155a9e;color:#fff}.admin-users-section{margin-bottom:32px}.admin-users-section h2{font-size:1.1rem;margin:0 0 .5rem}.admin-users-add{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.admin-users-add h3{font-size:.95rem;margin:0 0 .75rem}.admin-users-add-row{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.admin-user-input{min-width:120px}.admin-user-input,.admin-user-select{border:1px solid #ccc;border-radius:6px;font-size:.9rem;padding:8px 10px}.admin-user-add-btn{background:#2d6a4f;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:8px 14px}.admin-user-add-btn:hover{background:#1b4332}.admin-user-error{color:#b91c1c;font-size:.875rem;margin:.5rem 0 0}.admin-user-cancel-role,.admin-user-edit-role,.admin-user-save-role{background:#fff;border:1px solid #ccc;border-radius:4px;cursor:pointer;font-size:.75rem;margin-left:6px;padding:4px 8px}.admin-user-save-role{background:#2d6a4f;border-color:#2d6a4f;color:#fff}.admin-user-select-inline{font-size:.85rem;margin-right:4px;padding:4px 6px}.admin-must-change-badge{background:#fef3c7;border-radius:4px;color:#b45309;font-size:.75rem;padding:2px 6px}.admin-set-pw-inline{align-items:center;display:inline-flex;flex-wrap:wrap;gap:6px}.admin-set-pw-input{border:1px solid #ccc;border-radius:4px;font-size:.85rem;padding:4px 8px;width:120px}:root{--login-green:#2d6a4f;--login-green-hover:#1b4332;--login-green-focus:#2d6a4f40}.login-page{align-items:center;background:linear-gradient(160deg,#0d2818,#1b4332 40%,#2d6a4f);box-sizing:border-box;display:flex;justify-content:center;min-height:100vh;min-height:100dvh;padding:20px}.login-card{background:#fff;border-radius:12px;box-shadow:0 12px 40px #00000040,0 0 0 1px #ffffff14;max-width:360px;overflow:hidden;position:relative;width:100%}.login-card-accent{background:linear-gradient(90deg,#2d6a4f,#40916c);background:linear-gradient(90deg,var(--login-green) 0,#40916c 100%);height:4px}.login-card-body{padding:2rem 2rem 2.25rem}.login-title{color:#1a1a1a;font-size:1.5rem;font-weight:700;letter-spacing:.02em;margin:0 0 .25rem}.login-subtitle{color:#666;font-size:.9rem;margin:0 0 1.5rem}.login-form input{border:1px solid #d1d5db;border-radius:8px;box-sizing:border-box;display:block;font-size:16px;margin-bottom:12px;min-height:48px;padding:14px;transition:border-color .2s,box-shadow .2s;width:100%}.login-form input:focus{border-color:#2d6a4f;border-color:var(--login-green);box-shadow:0 0 0 3px #2d6a4f40;box-shadow:0 0 0 3px var(--login-green-focus);outline:none}.login-form button{background:#2d6a4f;background:var(--login-green);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:8px;min-height:48px;padding:14px;transition:background .2s;width:100%}.login-form button:hover:not(:disabled){background:#1b4332;background:var(--login-green-hover)}.login-form button:disabled{cursor:not-allowed;opacity:.7}.login-error{color:#b91c1c;font-size:.9rem;margin:0 0 12px}.login-code-input{font-size:1.5rem;letter-spacing:.25em;text-align:center}.login-back-btn{background:#0000!important;color:#666!important;font-weight:500!important;margin-top:12px!important}.login-back-btn:hover:not(:disabled){background:#f3f4f6!important;color:#333!important}.login-qr-wrap{display:flex;justify-content:center;margin:1rem 0}.login-qr-wrap img{border:1px solid #e5e7eb;border-radius:8px}.login-secret-hint{color:#666;font-size:.8rem;margin:0 0 1rem;word-break:break-all}.login-secret-code{background:#f3f4f6;border-radius:4px;font-family:ui-monospace,monospace;font-size:.75rem;padding:2px 6px}.attendance-form-page{font-family:inherit;margin:0 auto;max-width:1000px;padding:1rem}.attendance-form-layout{align-items:flex-start;display:flex;flex-wrap:wrap;gap:1.5rem}.attendance-form-layout .attendance-form-capture{flex:1 1 480px;margin-bottom:0;min-width:0}.attendance-scan-sidebar{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex:0 1 280px;min-width:260px;padding:1rem;position:-webkit-sticky;position:sticky;top:1rem}.attendance-sidebar-title{color:#334;font-size:.95rem;margin:0 0 .75rem}.attendance-header{margin-bottom:1.5rem}.attendance-header h1{font-size:1.5rem;margin:0 0 .25rem}.attendance-subtitle{color:#555;font-size:.875rem;margin:0 0 1rem}.attendance-header-actions{align-items:center;display:flex;gap:.75rem}.attendance-back-btn{background:#333;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;padding:.4rem .75rem}.attendance-back-btn:hover{background:#555}.attendance-form-capture{background:#fff;border:1px solid #ddd;border-radius:8px;margin-bottom:1rem;padding:1.25rem}.office-use{margin-bottom:1.25rem}.office-use label{display:block;font-size:.85rem;margin-bottom:.25rem}.office-use-input{border:1px solid #ccc;border-radius:4px;max-width:240px;padding:.4rem .5rem;width:100%}.guest-section-title{background:#e85c00;border-radius:0 0 4px 4px;color:#fff;font-size:1rem;margin:0 -1.25rem 1rem;padding:.5rem .75rem}.form-row{margin-bottom:.75rem}.form-row.full{grid-column:1/-1}.form-row label{display:block;font-size:.85rem;margin-bottom:.2rem}.form-row input{border:1px solid #ccc;border-radius:4px;max-width:280px;padding:.4rem .5rem;width:100%}.form-row.full input{max-width:none}.signature-block{margin:1rem 0}.signature-block>label{display:block;font-size:.85rem;margin-bottom:.35rem}.signature-pad-wrap{margin:.5rem 0}.signature-canvas{background:#fafafa;border:1px solid #999;border-radius:4px;cursor:crosshair;display:block;height:auto;max-width:100%;touch-action:none}.signature-clear-btn{background:#eee;border:1px solid #ccc;border-radius:4px;cursor:pointer;font-size:.8rem;margin-top:.35rem;padding:.3rem .6rem}.signature-date,.signature-print-name{margin-top:.75rem}.signature-date label,.signature-print-name label{display:block;font-size:.85rem;margin-bottom:.2rem}.signature-date input,.signature-print-name input{border:1px solid #ccc;border-radius:4px;max-width:280px;padding:.4rem .5rem;width:100%}.waiver-section{border-top:1px solid #ddd;margin:1.5rem 0;padding-top:1rem}.waiver-section h3{font-size:1rem;margin:0 0 .5rem}.signature-section{border-top:1px solid #ddd;margin:1.5rem 0;padding-top:1rem}.signature-section-title{font-size:1rem;margin:0 0 .35rem}.signature-instruction{color:#444;font-size:.9rem;margin:0 0 .75rem}.waiver-text{background:#f8f8f8;border-radius:4px;font-size:.8rem;line-height:1.4;padding:.5rem;white-space:pre-wrap}.attendance-form-capture.capturing .waiver-text{max-height:none;overflow:visible}.capture-field-display{background:#fff;border:1px solid #ccc;border-radius:4px;box-sizing:border-box;color:#000;display:block;font-family:inherit;font-size:inherit;line-height:1.5;max-width:100%;min-height:2.6rem;overflow:visible;padding:.5rem .5rem .6rem;vertical-align:middle;white-space:pre-wrap;width:100%;word-break:break-word}.attendance-form-capture.capturing .form-row .capture-field-display{max-width:100%}.attendance-form-capture.capturing .form-row.full .capture-field-display{max-width:none}.attendance-form-capture.capturing .form-row,.attendance-form-capture.capturing .office-use{overflow:visible}.admin-fields{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr 1fr;margin-top:1rem}.form-revision{color:#888;font-size:.75rem;margin:.5rem 0 0}.attendance-actions{border-top:1px solid #ddd;margin-top:1rem;padding-top:1rem;width:100%}.attendance-scan-sidebar .paste-scan-for-testing{background:#fff;border:1px solid #cce;border-radius:6px;margin-bottom:1rem;padding:.75rem}.paste-scan-for-testing label{color:#334;display:block;font-size:.85rem;font-weight:600;margin-bottom:.35rem}.paste-scan-textarea{border:1px solid #ccc;border-radius:4px;box-sizing:border-box;font-family:inherit;font-size:.85rem;min-height:4rem;padding:.5rem;resize:vertical;width:100%}.fill-from-paste-btn{background:#2a7c6e;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.85rem;margin-top:.5rem;padding:.4rem .75rem}.fill-from-paste-btn:hover:not(:disabled){background:#1f5d52}.fill-from-paste-btn:disabled{cursor:not-allowed;opacity:.6}.attendance-scan-sidebar .scan-actions-inline{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.scan-license-btn,.scan-photo-btn-inline{background:#2a7c6e;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;padding:.5rem .75rem}.scan-license-btn:hover,.scan-photo-btn-inline:hover:not(:disabled){background:#1f5d52}.scan-photo-btn-inline:disabled{cursor:not-allowed;opacity:.7}.attendance-camera-error,.attendance-submit-error{color:#c00;font-size:.9rem;margin:.5rem 0}.attendance-submit-success{color:#0a0;font-size:.9rem;margin:.5rem 0}.attendance-camera-overlay{margin:1rem 0}.attendance-submit-btn{background:#1a5fb4;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;margin-top:.75rem;padding:.6rem 1.25rem}.attendance-submit-btn:hover{background:#155a9e}@media (max-width:799px){.attendance-form-layout{flex-direction:column}.attendance-form-layout .attendance-form-capture{order:1}.attendance-scan-sidebar{flex:1 1 auto;min-width:0;order:-1;position:static}}@media (min-width:600px){.guest-section .form-row:not(.full){display:inline-block;margin-right:.5rem;vertical-align:top;width:calc(50% - .5rem)}}:root{--topbar-green:#2d6a4f;--topbar-green-hover:#1b4332;--topbar-form-orange:#e85c00;--topbar-form-orange-hover:#d35400}.topbar{background:#2d6a4f;background:var(--topbar-green);box-shadow:0 2px 8px #00000026;color:#fff;position:-webkit-sticky;position:sticky;top:0;z-index:100}.topbar-inner{align-items:center;display:flex;flex-direction:column;gap:.5rem;margin:0 auto;max-width:1200px;padding:.5rem 1rem .75rem}.topbar-logo{color:#fff;font-size:1.25rem;font-weight:700;letter-spacing:.02em;text-decoration:none}.topbar-nav-row{align-items:center;display:flex;justify-content:space-between;width:100%}.topbar-logo:hover{color:#fffffff2}.topbar-nav{align-items:center;display:flex;gap:.25rem}.topbar-link{border-radius:6px;color:#fffffff2;font-size:.9rem;font-weight:500;padding:.5rem .875rem;text-decoration:none;transition:background .2s,color .2s}.topbar-link:hover{background:#ffffff1f;color:#fff}.topbar-link.active{background:#fff3;color:#fff}.topbar-link-form{color:#ffb380}.topbar-link-form:hover{background:#e85c0040;color:#fff}.topbar-link-form.active{background:#e85c00;background:var(--topbar-form-orange);color:#fff}.topbar-link-form.active:hover{background:#d35400;background:var(--topbar-form-orange-hover);color:#fff}.topbar-profile-wrap{position:relative}.topbar-profile-btn{align-items:center;background:#ffffff1f;border:1px solid #fff3;border-radius:50%;color:#fffffff2;cursor:pointer;display:flex;height:40px;justify-content:center;padding:0;transition:background .2s,color .2s;width:40px}.topbar-profile-btn:hover{background:#fff3;color:#fff}.topbar-profile-icon{align-items:center;display:flex;justify-content:center}.topbar-profile-dropdown{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026,0 0 0 1px #0000000f;min-width:180px;padding:.25rem 0;position:absolute;right:0;top:calc(100% + 6px);z-index:200}.topbar-profile-dropdown-header{border-bottom:1px solid #eee;color:#555;font-size:.8rem;font-weight:600;margin-bottom:.25rem;padding:.5rem 1rem .35rem}.topbar-profile-dropdown-item{background:none;border:none;color:#333;cursor:pointer;display:block;font-size:.9rem;padding:.5rem 1rem;text-align:left;transition:background .15s;width:100%}.topbar-profile-dropdown-item:hover{background:#f3f4f6}@media (max-width:640px){.topbar-inner{padding:.6rem .75rem}.topbar-logo{font-size:1rem}.topbar-link{font-size:.85rem;padding:.5rem .6rem}}
/*# sourceMappingURL=main.65e3a10b.css.map*/