:root{--navy: #002f47;--navy-2: #013a59;--green: #00d878;--green-d: #00b866;--rose: #ff0048;--amber: #b8860b;--ink: #0c1b24;--muted: #5a6b75;--faint: #8a99a3;--line: #e3e9ed;--bg: #eef3f6;--card: #ffffff;font-family:IBM Plex Sans,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;-webkit-text-size-adjust:100%}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--ink);overscroll-behavior:none}button{font:inherit;cursor:pointer}input,select{font:inherit}h1,h2,h3,.brandmark{font-family:Space Grotesk,system-ui,sans-serif}.small{font-size:13px}.muted{color:var(--muted)}.center{text-align:center}.splash{height:100%;display:grid;place-items:center;color:var(--faint)}.screen{min-height:100%;display:flex;flex-direction:column}.logo{display:grid;place-items:center;flex:none;width:44px;height:44px;border-radius:12px;background:var(--navy);color:#fff;font-family:Space Grotesk,sans-serif;font-weight:700}.logo.sm{width:32px;height:32px;border-radius:9px;font-size:13px}.brandmark{font-weight:700;font-size:19px}.brandmark .accent{color:var(--green)}.sub{color:var(--faint);font-size:12px}.login{padding:28px 20px;gap:22px;justify-content:center;max-width:460px;margin:0 auto;width:100%}.brand{display:flex;align-items:center;gap:14px}.card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:20px;box-shadow:0 6px 24px #002f470f}.field-label{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--faint);font-weight:600;margin:12px 2px 6px}.select,.text-input{width:100%;height:52px;border:1px solid var(--line);border-radius:12px;padding:0 14px;background:#fff;color:var(--ink);font-size:16px}.text-input{height:50px}.pin-display{height:56px;border:1px solid var(--line);border-radius:12px;background:#f7fafb;display:flex;align-items:center;justify-content:center;letter-spacing:8px;font-size:26px;color:var(--navy)}.pin-display .placeholder{letter-spacing:normal;font-size:15px;color:var(--faint)}.error{color:var(--rose);font-size:13.5px;font-weight:600;margin-top:10px;text-align:center}.keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:16px}.key{height:62px;border:1px solid var(--line);border-radius:14px;background:#fff;font-size:23px;font-weight:600;color:var(--ink);transition:transform .05s,background .1s}.key:active{transform:scale(.96);background:#f1f5f7}.key.ghost{color:var(--muted);font-size:20px}.key.go{background:var(--green);border-color:var(--green-d);color:#042}.key.go:disabled{opacity:.4}.hint{text-align:center}.empty-title{font-family:Space Grotesk,sans-serif;font-weight:700;font-size:18px;color:var(--navy);margin:2px 0 8px}.topbar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--navy);color:#fff}.topbar .who{line-height:1.1;display:flex;flex-direction:column}.topbar .who b{font-size:14px}.topbar .who .sub{color:#9fb6c2}.topbar .spacer{flex:1}.pill{font-size:12px;font-weight:700;padding:5px 10px;border-radius:999px}.pill.ok{background:#ffffff24;color:#cfe0e8}.pill.warn{background:var(--amber);color:#fff}.link{background:none;border:none;color:#cfe0e8;font-size:13px;text-decoration:underline;padding:4px}.link.center{display:block;margin:14px auto 0;color:var(--muted)}.body{flex:1;padding:20px 18px 36px;max-width:520px;width:100%;margin:0 auto}.big{width:100%;min-height:64px;border-radius:16px;border:1px solid var(--line);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:18px;font-weight:700;background:#fff;color:var(--ink);padding:14px;margin-top:14px}.big:active{transform:scale(.99)}.big:disabled{opacity:.45}.big.primary{background:var(--green);border-color:var(--green-d);color:#043}.big.ghost{background:#fff;color:var(--navy)}.big .ico{font-size:26px}.big .small{font-weight:500;color:inherit;opacity:.85}.home .prompt{font-family:Space Grotesk,sans-serif;font-size:22px;font-weight:700;color:var(--navy);margin:8px 2px 4px}.scanning{position:relative}.cam{width:100%;height:62vh;max-height:520px;object-fit:cover;border-radius:16px;background:#000}.reticle{position:absolute;right:10%;bottom:12%;left:10%;top:18%;height:38%;border:3px solid var(--green);border-radius:12px;box-shadow:0 0 0 100vmax #00000040;pointer-events:none}.scan-hint{text-align:center;color:var(--muted);font-size:14px;margin:14px 0 6px}.scan-actions{display:flex;flex-direction:column;align-items:center}.banner{background:#eaf6ff;border:1px solid #cfe6f6;color:var(--navy);border-radius:12px;padding:10px 12px;font-size:14px}.banner.warn{background:#fff6e8;border-color:#f1d9a8;color:#7a5a00}.reg-input{width:100%;height:70px;border:2px solid var(--navy);border-radius:14px;text-align:center;font-family:IBM Plex Mono,monospace;font-size:32px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--navy)}.disc-info{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:12px}.disc-info span{background:#eef3f6;border:1px solid var(--line);border-radius:999px;padding:4px 12px;font-size:13px;color:var(--muted)}.classify-label{text-align:center;color:var(--faint);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600;margin-top:22px}.classify{display:grid;gap:12px;margin-top:6px}.classify-btn{min-height:76px}.classify-btn.site{background:var(--green);border-color:var(--green-d);color:#043}.classify-btn.visitor{background:var(--navy);border-color:var(--navy-2);color:#fff}.classify-btn .small{opacity:.9}.saved{text-align:center;padding-top:34px}.saved .check{width:92px;height:92px;margin:0 auto 16px;border-radius:50%;background:var(--green);color:#fff;font-size:52px;display:grid;place-items:center}.saved-reg{font-family:IBM Plex Mono,monospace;font-size:30px;font-weight:600;color:var(--navy);letter-spacing:2px}
