:root{--bg: #0f172a;--bg-2: #111827;--panel: #1e293b;--panel-2: #334155;--text: #e2e8f0;--muted: #94a3b8;--accent: #22d3ee;--success: #10b981;--danger: #ef4444;--warn: #f59e0b}*{box-sizing:border-box}html,body,#app{margin:0;padding:0;height:100%;width:100%;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;overflow:hidden;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-ms-touch-action:manipulation}#app{display:flex;flex-direction:column}.hd{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:.75rem 1.25rem;background:var(--bg-2);border-bottom:1px solid #233047;gap:1rem}.hd-left{display:flex;align-items:center;gap:.75rem;min-width:0}.hd-title{font-weight:700;font-size:1.1rem;white-space:nowrap}.hd-pending{background:var(--warn);color:#1f1300;font-weight:700;border-radius:999px;padding:.15rem .65rem;font-size:.85rem}.hd-time{display:flex;flex-direction:column;gap:.15rem;align-items:center;font-variant-numeric:tabular-nums}.hd-time-row{display:flex;gap:.5rem;align-items:baseline}.hd-label{color:var(--muted);font-size:.7rem;text-transform:uppercase;letter-spacing:.05em}.hd-clock{font-weight:600;font-size:.95rem}.hd-warn{color:var(--warn);font-weight:700}.hd-right{display:flex;gap:.6rem;align-items:center;justify-content:flex-end}.hd-pill{padding:.2rem .65rem;border-radius:999px;font-size:.8rem}.hd-pill-ok{background:#10b98126;color:#6ee7b7}.hd-pill-warn{background:#f59e0b26;color:#fcd34d}.hd-logout{background:transparent;border:1px solid #475569;color:var(--text);padding:.3rem .7rem;border-radius:.4rem;cursor:pointer;font-size:.85rem}.hd-logout:active{background:#475569}.hd-install{background:transparent;border:1px solid var(--accent);color:var(--accent);padding:.3rem .7rem;border-radius:.4rem;cursor:pointer;font-size:.85rem}.hd-install:active{background:#22d3ee26}.ft{display:flex;justify-content:space-between;padding:.4rem 1rem;background:var(--bg-2);border-top:1px solid #233047;font-size:.75rem;color:var(--muted);font-variant-numeric:tabular-nums}.screen{flex:1 1 auto;display:flex;align-items:center;justify-content:center;padding:1rem}.muted{color:var(--muted)}.gps-banner{position:absolute;bottom:2.5rem;left:0;right:0;margin:0 auto;width:max-content;max-width:90%;background:#f59e0b2e;color:#fcd34d;padding:.4rem 1rem;border-radius:999px;font-size:.85rem}.enroll-card{background:var(--panel);border-radius:1rem;padding:2rem 2.5rem;width:min(540px,96vw);display:flex;flex-direction:column;gap:1rem;box-shadow:0 10px 40px #00000073}.enroll-card h1{margin:0;font-size:1.6rem}.enroll-actions{display:flex;flex-direction:column;gap:1rem;margin-top:.5rem}.enroll-or{text-align:center;color:var(--muted)}.enroll-manual{display:flex;gap:.75rem}.enroll-code{flex:1;padding:.9rem 1rem;font-size:1.6rem;letter-spacing:.25em;text-align:center;background:var(--bg);border:1px solid #475569;color:var(--text);border-radius:.5rem;font-family:ui-monospace,monospace}.enroll-msg{margin-top:.5rem;color:var(--warn)}.btn-primary,.btn-success,.btn-danger,.btn-secondary{border:none;cursor:pointer;border-radius:.6rem;font-weight:700;padding:.85rem 1.2rem;font-size:1rem;color:#fff}.btn-primary{background:var(--accent);color:#0f172a}.btn-success{background:var(--success)}.btn-danger{background:var(--danger)}.btn-secondary{background:var(--panel-2);color:var(--text)}.big{font-size:1.3rem;padding:1.2rem 1.5rem;min-width:200px}button:active{transform:scale(.98)}.screen-keypad{padding:1.5rem}.keypad{width:min(640px,96vw);display:flex;flex-direction:column;gap:1rem}.keypad-label{color:var(--muted);font-size:1rem;text-align:center}.keypad-display{background:var(--bg-2);color:var(--accent);font-family:ui-monospace,monospace;font-size:clamp(2rem,6vw,3.5rem);line-height:1;font-weight:700;text-align:center;padding:1rem;border-radius:.75rem;letter-spacing:.15em;height:calc(clamp(2rem,6vw,3.5rem) + 2rem);display:flex;align-items:center;justify-content:center;font-variant-numeric:tabular-nums}.keypad-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem}.keypad-key{background:var(--panel);color:var(--text);border:1px solid #334155;border-radius:.75rem;font-size:clamp(1.6rem,4vw,2.2rem);font-weight:700;padding:1rem 0;cursor:pointer;min-height:64px}.keypad-key:active{background:var(--panel-2)}.keypad-key.is-action{background:#475569}.keypad-submit{background:var(--success);color:#fff;border:none;border-radius:.75rem;font-size:1.4rem;font-weight:700;padding:1.2rem;cursor:pointer}.confirm-card{background:var(--panel);padding:2rem 2.5rem;border-radius:1rem;text-align:center;width:min(700px,96vw);display:flex;flex-direction:column;gap:.75rem}.confirm-name{font-size:2.4rem;font-weight:800}.confirm-id{font-size:1.3rem;color:var(--muted);font-family:ui-monospace,monospace}.confirm-actions{display:flex;gap:1rem;justify-content:center;margin-top:1rem;flex-wrap:wrap}.feedback-card{background:var(--panel);padding:2rem 2.5rem;border-radius:1rem;text-align:center;width:min(540px,96vw)}.feedback-card.is-ok{border:2px solid var(--success)}.feedback-card.is-err{border:2px solid var(--danger)}.feedback-icon{font-size:4rem}.feedback-text{font-size:1.4rem;margin-top:.5rem}.blocked-card{background:var(--panel);padding:2.5rem;border-radius:1rem;text-align:center;width:min(540px,96vw)}.blocked-icon{font-size:4rem}.scanner-overlay{position:fixed;inset:0;background:#000;z-index:1000;display:flex;align-items:center;justify-content:center}.scanner-video{max-width:100%;max-height:100%;object-fit:contain}.scanner-close{position:absolute;top:1rem;right:1rem;background:#ffffffd9;color:#0f172a;border:none;padding:.6rem 1rem;border-radius:.5rem;font-weight:700;cursor:pointer}.scanner-hint{position:absolute;bottom:1.5rem;left:0;right:0;text-align:center;color:#fff;font-size:1rem}
