@import "https://fonts.googleapis.com/css2?family=Lexend:wght@300;400;500;600;700;800&display=swap";:root{--bg:#f6f9fe;--surface:#fff;--surface-soft:#f1f7ff;--border:#d7e6f7;--border-strong:#aac9eb;--blue:#2563eb;--blue-dark:#174ea6;--blue-soft:#e8f2ff;--green:#0f8f63;--green-soft:#e8f8f1;--text:#132238;--text-2:#42556f;--text-3:#70819a;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;font-family:Lexend,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*,:before,:after{box-sizing:border-box}body{background:var(--bg);min-width:320px;min-height:100vh;margin:0}button,input,select{font:inherit}#root{min-height:100vh}.app-shell,.container{width:min(1200px,100%);margin:0 auto;padding:24px 20px 48px}.app-topbar{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;padding-bottom:16px;display:flex}.brand-lockup{align-items:center;min-width:0;display:flex}.brand-title{color:var(--blue-dark);margin:0;font-size:20px;font-weight:700}.topbar-link{border:1px solid var(--border);min-height:38px;color:var(--blue-dark);background:var(--surface);border-radius:8px;justify-content:center;align-items:center;padding:0 16px;font-size:14px;font-weight:600;text-decoration:none;display:inline-flex}.topbar-link:hover{border-color:var(--border-strong);background:var(--surface-soft)}.hero-band{border:1px solid var(--border);border-left:5px solid var(--blue);background:var(--surface);border-radius:10px;justify-content:space-between;align-items:center;gap:18px;margin-bottom:18px;padding:22px 24px;display:flex}.eyebrow{color:var(--blue);text-transform:uppercase;margin:0 0 6px;font-size:12px;font-weight:700}h1,h2{color:var(--text);margin:0;line-height:1.1}h1{font-size:clamp(30px,4vw,46px);font-weight:800}h2{font-size:22px;font-weight:700}.hero-pill,.scanner-state,.table-count,.session-badge{white-space:nowrap;min-height:30px;color:var(--blue-dark);border:1px solid var(--border);background:var(--blue-soft);border-radius:999px;justify-content:center;align-items:center;padding:0 12px;font-size:12px;font-weight:600;display:inline-flex}.hero-pill.is-ready,.scanner-state.is-live,.scanner-state.is-confirmed{color:var(--green);background:var(--green-soft);border-color:#bfe8d7}.live-dot{background:currentColor;border-radius:50%;width:7px;height:7px;margin-right:6px;display:inline-block}.card{border:1px solid var(--border);background:var(--surface);border-radius:10px;margin-bottom:14px;padding:18px;box-shadow:0 8px 20px #174ea60d}.compact-card{padding:12px 16px}.row{gap:10px;display:grid}.split{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}label{color:var(--text-2);margin-bottom:8px;font-size:13px;font-weight:600;display:block}input,select{border:1px solid var(--border);width:100%;min-height:44px;color:var(--text);background:var(--surface);border-radius:8px;outline:none;padding:10px 12px}input::placeholder{color:var(--text-3)}input:focus,select:focus{border-color:var(--blue);box-shadow:0 0 0 3px #2563eb1f}button{color:#fff;background:var(--blue);cursor:pointer;border:0;border-radius:8px;width:100%;min-height:44px;padding:10px 16px;font-weight:700}button:hover:not(:disabled){background:var(--blue-dark)}button.secondary{color:var(--blue-dark);border:1px solid var(--border);background:var(--surface)}button.secondary:hover:not(:disabled){background:var(--surface-soft)}button:disabled{opacity:.55;cursor:not-allowed}.auth-card{gap:18px;width:min(420px,100%);display:grid}.volunteer-workflow{gap:14px;display:grid}.volunteer-toolbar-card{padding:20px 22px}.volunteer-toolbar{grid-template-columns:1fr minmax(220px,280px);align-items:end;gap:20px;display:grid}.toolbar-copy{gap:6px;display:grid}.session-name-muted{color:var(--text-3);font-size:16px;font-weight:400}.scan-meta{color:var(--text-3);margin:0;font-size:13px}.scan-meta span{color:var(--green);font-weight:700}.session-control{min-width:0}.scanner-card{padding:0;overflow:hidden}.scanner-card.is-confirmed{border-color:#8bd7b9;box-shadow:0 0 0 3px #0f8f6324,0 8px 20px #174ea60d}.scanner-card .section-heading{border-bottom:1px solid var(--border);margin:0;padding:18px}.section-heading{justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.scanner-frame{background:#0f1f33;position:relative}.scanner-frame:before{z-index:10;pointer-events:none;content:"";border:1px solid #ffffff38;border-radius:8px;position:absolute;inset:20px}.scanner-frame.is-active:before{border-color:#60a5fabf}.scanner-frame.is-confirmed:before{border-color:#0f8f63f2;box-shadow:0 0 0 5px #0f8f632e}.scanner-box{background:#0f1f33;width:100%;min-height:360px;position:relative;overflow:hidden}.scanner-video{object-fit:cover;background:#0f1f33;display:block;width:100%!important;height:360px!important}.scanner-guide{pointer-events:none;border-radius:18px;width:min(72vw,280px);height:min(72vw,280px);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 9999px #040f1c42,inset 0 0 0 1px #ffffff38}.scanner-guide:before,.scanner-guide:after{content:"";border-radius:18px;position:absolute;inset:0}.scanner-guide:before{border:3px solid #0000;border-color:#60a5faf2 #0000 #0000 #60a5faf2}.scanner-guide:after{border-bottom:3px solid #60a5faf2;border-right:3px solid #60a5faf2;width:56px;height:56px;inset:auto 0 0 auto}.scanner-placeholder{z-index:5;pointer-events:none;place-items:center;gap:10px;display:grid;position:absolute;inset:0}.scanner-placeholder p{color:#ffffffad;text-transform:uppercase;margin:0;font-size:13px;font-weight:600}.qr-placeholder-icon{border:2px solid #ffffff5c;border-radius:8px;width:44px;height:44px}.scan-actions{border-top:1px solid var(--border);background:var(--surface);padding:16px 18px 18px}.qr-file-input{display:none}.scanner-fallback{border-top:1px solid var(--border);background:var(--surface);padding:16px 18px 18px}.status{color:var(--text-2);margin:0;font-size:14px;line-height:1.55}.status-footer{margin-top:14px}.metric-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:14px;display:grid}.metric-card{border:1px solid var(--border);background:var(--surface);border-radius:10px;padding:18px}.metric-card p{color:var(--text-3);margin:0 0 10px;font-size:13px;font-weight:600}.metric-card strong{color:var(--text);font-size:30px;line-height:1;display:block}.metric-time{font-size:20px!important}.admin-actions{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.table-card{padding:0;overflow:hidden}.table-card .section-heading{border-bottom:1px solid var(--border);margin:0;padding:18px}.table-count{min-width:32px}.table-wrap{width:100%;overflow:auto}table{border-collapse:collapse;background:var(--surface);width:100%;min-width:960px}th,td{text-align:left;border-bottom:1px solid #e7eff8;padding:12px 14px;font-size:13px}th{color:var(--blue-dark);background:#f2f7fd;font-weight:700}td{color:var(--text-2)}td:first-child{color:var(--text);font-weight:600}tr:last-child td{border-bottom:0}.empty-cell{height:100px;color:var(--text-3);text-align:center}@media (width<=780px){.app-shell,.container{padding:16px 14px 40px}.hero-band{flex-direction:column;align-items:stretch}.hero-pill{align-self:flex-start}.volunteer-toolbar,.metric-grid,.admin-actions{grid-template-columns:1fr}.scanner-box,.scanner-video{min-height:300px;height:300px!important}.scanner-guide{width:min(78vw,240px);height:min(78vw,240px)}h1{font-size:30px}}
