*,:before,:after{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;background:#f0f4f8;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}#root{flex-direction:column;width:100%;min-height:100svh;display:flex}@media (width>=640px){body{justify-content:center;align-items:flex-start;min-height:100svh;padding:32px 16px;display:flex}#root{border-radius:20px;width:100%;max-width:560px;min-height:calc(100svh - 64px);overflow:hidden;box-shadow:0 8px 40px #0000001f,0 2px 8px #0000000f}}h1,h2,h3,p{margin:0}:root{--red:#c8102e;--red-dark:#a00d24;--red-light:#fef2f4;--red-mid:#fccdd4;--green:#0e7c4a;--green-light:#ecfdf5;--green-mid:#a7f3d0;--gray-50:#fafafa;--gray-100:#f4f4f5;--gray-200:#e4e4e7;--gray-400:#a1a1aa;--gray-600:#52525b;--gray-800:#27272a;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 16px #00000014, 0 2px 6px #0000000a;--shadow-lg:0 10px 32px #0000001a, 0 4px 12px #0000000f}*{box-sizing:border-box;margin:0;padding:0}body{color:var(--gray-800);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif}.app{background:#fff;flex-direction:column;min-height:100vh;display:flex}@media (width>=640px){.app{min-height:unset}}.app-header{border-bottom:3px solid var(--red);background:#fff;align-items:center;gap:14px;padding:16px 24px 14px;display:flex}.header-logo{background:var(--red);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.header-logo svg{fill:#fff;width:24px;height:24px}.header-text h1{color:var(--gray-800);letter-spacing:-.3px;font-size:1.15rem;font-weight:800;line-height:1.2}.header-text .subtitle{color:var(--red);letter-spacing:.2px;margin-top:1px;font-size:.78rem;font-weight:600}.app-main{background:var(--gray-100);flex:1;justify-content:center;align-items:flex-start;padding:20px 16px 32px;display:flex}@media (width>=640px){.app-main{padding:24px 20px 36px}}.center-block{text-align:center;flex-direction:column;align-items:center;gap:0;width:100%;max-width:360px;padding-top:32px;display:flex}.idle-card{box-shadow:var(--shadow-md);background:#fff;border-radius:20px;flex-direction:column;align-items:center;gap:0;width:100%;padding:36px 28px 28px;display:flex}.scan-circle{background:var(--red-light);border-radius:50%;justify-content:center;align-items:center;width:96px;height:96px;margin-bottom:20px;display:flex}.scan-circle svg{width:44px;height:44px;stroke:var(--red);fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round}.idle-title{color:var(--gray-800);margin-bottom:6px;font-size:1.15rem;font-weight:700}.hint-text{color:var(--gray-400);margin-bottom:24px;font-size:.85rem;line-height:1.5}.scanner-wrap{flex-direction:column;align-items:center;gap:0;width:100%;max-width:440px;display:flex}.scan-label{color:var(--gray-600);letter-spacing:.5px;text-transform:uppercase;margin-bottom:10px;font-size:.8rem;font-weight:600}.scanner-box{width:100%;box-shadow:var(--shadow-lg);background:#000;border-radius:16px;overflow:hidden}#qr-reader{width:100%!important}#qr-reader video{border-radius:16px;width:100%!important}#qr-reader__scan_region{background:0 0!important}#qr-reader__dashboard_section_csr button,#qr-reader__header_message,#qr-reader__status_span{display:none!important}.loading-block{flex-direction:column;align-items:center;gap:14px;padding-top:60px;display:flex}.spinner{border:3px solid var(--gray-200);border-top-color:var(--red);border-radius:50%;width:44px;height:44px;animation:.75s linear infinite spin}.loading-text{color:var(--gray-600);font-size:.9rem}@keyframes spin{to{transform:rotate(360deg)}}.result-card{width:100%;max-width:480px;box-shadow:var(--shadow-lg);background:#fff;border-radius:20px;overflow:hidden}.card-banner{flex-direction:column;align-items:center;gap:8px;padding:20px 20px 16px;display:flex}.found-card .card-banner{background:var(--gray-50);border-bottom:1px solid var(--gray-200)}.success-card .card-banner{background:var(--green-light);border-bottom:1px solid var(--green-mid)}.error-card .card-banner{background:var(--red-light);border-bottom:1px solid var(--red-mid)}.status-badge{letter-spacing:.8px;text-transform:uppercase;border-radius:99px;align-items:center;gap:5px;padding:4px 12px;font-size:.7rem;font-weight:700;display:inline-flex}.status-badge.pending{color:#92600a;background:#fff3cd;border:1px solid #fde68a}.status-badge.success{background:var(--green-light);color:var(--green);border:1px solid var(--green-mid)}.status-badge.notfound{background:var(--red-light);color:var(--red);border:1px solid var(--red-mid)}.avatar{border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin-top:4px;font-size:1.6rem;display:flex}.found-card .avatar{background:var(--gray-200)}.success-card .avatar{background:#d1fae5}.error-card .avatar{background:var(--red-mid)}.participant-name{color:var(--gray-800);text-align:center;font-size:1.25rem;font-weight:700;line-height:1.3}.participant-id{color:var(--gray-400);letter-spacing:.3px;font-size:.78rem;font-weight:500}.card-body{padding:16px 20px 20px}.info-grid{border:1px solid var(--gray-200);border-radius:12px;flex-direction:column;gap:0;margin-bottom:18px;display:flex;overflow:hidden}.info-row{border-bottom:1px solid var(--gray-200);align-items:center;gap:12px;padding:10px 14px;display:flex}.info-row:last-child{border-bottom:none}.info-row:nth-child(2n){background:var(--gray-50)}.info-label{color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;min-width:72px;font-size:.72rem;font-weight:700}.info-value{color:var(--gray-800);word-break:break-word;flex:1;font-size:.9rem;font-weight:500}.email-val{font-size:.82rem}.remark{color:var(--red);font-weight:600}.badge-pill{letter-spacing:.3px;border-radius:99px;padding:3px 10px;font-size:.72rem;font-weight:700;display:inline-block}.badge-picked{color:#065f46;background:#d1fae5}.badge-not-picked{background:var(--red-light);color:var(--red-dark)}.badge-pending{color:#92600a;background:#fff3cd}.error-title{color:var(--gray-800);margin-bottom:4px;font-size:1.1rem;font-weight:700}.error-msg{color:var(--gray-600);text-align:center;font-size:.85rem;line-height:1.5}.action-row{gap:8px;display:flex}.btn{cursor:pointer;letter-spacing:.1px;border:none;border-radius:12px;flex:1;padding:13px 16px;font-size:.9rem;font-weight:700;transition:transform .1s,box-shadow .15s,background .15s}.btn:active{transform:scale(.97)}.btn-primary{background:var(--red);color:#fff;box-shadow:0 3px 10px #c8102e4d}.btn-primary:hover{background:var(--red-dark);box-shadow:0 4px 14px #c8102e66}.btn-success{background:var(--green);color:#fff;box-shadow:0 3px 10px #0e7c4a40}.btn-success:hover{background:#0a6340}.btn-outline{color:var(--gray-600);border:1.5px solid var(--gray-200);background:#fff}.btn-outline:hover{background:var(--gray-50);border-color:var(--gray-400)}.btn-sm{margin-top:10px;padding:10px 16px;font-size:.85rem}.divider{background:var(--gray-200);height:1px;margin:0 -20px 18px}.mode-tabs{border-bottom:1px solid var(--gray-200);background:#fff;padding:0 16px;display:flex}.mode-tab{color:var(--gray-400);cursor:pointer;letter-spacing:.1px;background:0 0;border:none;border-bottom:2.5px solid #0000;flex:1;justify-content:center;align-items:center;gap:7px;padding:12px 8px;font-size:.85rem;font-weight:600;transition:color .15s,border-color .15s;display:flex}.mode-tab.active{color:var(--red);border-bottom-color:var(--red)}.mode-tab:hover:not(.active){color:var(--gray-600)}.manual-wrap{width:100%;max-width:480px}.search-card{box-shadow:var(--shadow-md);background:#fff;border-radius:16px;padding:20px}.search-label{color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;font-size:.78rem;font-weight:700}.search-input-wrap{border:1.5px solid var(--gray-200);background:var(--gray-50);border-radius:12px;align-items:center;transition:border-color .15s;display:flex;overflow:hidden}.search-input-wrap:focus-within{border-color:var(--red);background:#fff}.search-icon{color:var(--gray-400);flex-shrink:0;align-items:center;padding:0 10px 0 14px;display:flex}.search-input{color:var(--gray-800);background:0 0;border:none;outline:none;flex:1;padding:13px 8px 13px 0;font-family:inherit;font-size:.92rem}.search-input::placeholder{color:var(--gray-400)}.search-clear{color:var(--gray-400);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 14px;font-size:.85rem}.search-clear:hover{color:var(--gray-600)}.search-status{color:var(--gray-400);align-items:center;gap:8px;margin-top:14px;font-size:.85rem;display:flex}.spinner-sm{border:2px solid var(--gray-200);border-top-color:var(--red);border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.7s linear infinite spin}.search-empty{text-align:center;color:var(--gray-400);margin-top:16px;padding:12px 0;font-size:.85rem}.result-list{border:1px solid var(--gray-200);border-radius:12px;margin-top:12px;list-style:none;overflow:hidden}.result-list-item{cursor:pointer;border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;gap:12px;padding:13px 16px;transition:background .12s;display:flex}.result-list-item:last-child{border-bottom:none}.result-list-item:nth-child(2n){background:var(--gray-50)}.result-list-item:hover{background:var(--red-light)}.rli-left{flex-direction:column;gap:2px;min-width:0;display:flex}.rli-name{color:var(--gray-800);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.rli-meta{color:var(--gray-400);font-size:.75rem}.rli-status{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;font-weight:700;display:flex}.rli-checked{color:var(--green);border:1.5px solid var(--green-mid);background:#d1fae5}.rli-pending{background:var(--gray-100);color:var(--gray-400);border:1.5px solid var(--gray-200)}
