:root{--bg: #f4f6f8;--surface: #ffffff;--fg: #111;--muted: #555;--accent: #0a4d8c;--accent-hover: #083968;--border: #d8dde2;--ok: #1b7f3b;--ok-bg: #e7f5ec;--warn: #8a5a00;--warn-bg: #fbf1dd;--error: #b00020;--error-bg: #fbe7ea;--radius: 14px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--fg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;overscroll-behavior-y:none}button{font:inherit;cursor:pointer}.app{display:flex;flex-direction:column;height:100%;max-width:480px;margin:0 auto;background:var(--bg)}.app-header{padding:calc(var(--safe-top) + 12px) 16px 12px;background:var(--accent);color:#fff;display:flex;align-items:baseline;justify-content:space-between;gap:8px}.app-header h1{font-size:17px;margin:0;font-weight:650}.app-header .who{font-size:13px;opacity:.85}.app-main{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px}.tabbar{display:flex;border-top:1px solid var(--border);background:var(--surface);padding-bottom:var(--safe-bottom)}.tabbar button{flex:1;border:0;background:none;padding:10px 4px 12px;color:var(--muted);font-size:12px;display:flex;flex-direction:column;align-items:center;gap:3px}.tabbar button.active{color:var(--accent);font-weight:600}.tabbar .icon{font-size:20px;line-height:1}.tabbar .badge{position:absolute;transform:translate(14px,-6px);background:var(--error);color:#fff;border-radius:9px;font-size:10px;padding:1px 5px;font-weight:700}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px}.card.current{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.card .resort{font-size:17px;font-weight:650;margin:0 0 4px}.card .dates{color:var(--muted);font-size:14px}.now-badge{display:inline-block;background:var(--accent);color:#fff;font-size:11px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;border-radius:999px;padding:2px 8px;margin-bottom:8px}.screen{min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:32px 24px calc(32px + var(--safe-bottom));gap:16px}.screen .logo{width:64px;height:64px}.screen h2{margin:0;font-size:22px}.screen p{margin:0;color:var(--muted);line-height:1.5;max-width:30ch}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--accent);color:#fff;border:0;border-radius:var(--radius);padding:14px 20px;font-size:16px;font-weight:600;width:100%;max-width:320px;min-height:50px}.btn:active{background:var(--accent-hover)}.btn.secondary{background:transparent;color:var(--accent);border:1px solid var(--accent)}.btn:disabled{opacity:.55}.banner{border-radius:10px;padding:8px 12px;font-size:13px;margin-bottom:12px;display:flex;align-items:center;gap:8px}.banner.offline{background:var(--warn-bg);color:var(--warn)}.banner.muted{background:#eef1f4;color:var(--muted)}.scanner-frame{position:relative;width:100%;aspect-ratio:1 / 1;background:#000;border-radius:var(--radius);overflow:hidden;margin-bottom:16px}.scanner-frame video{width:100%;height:100%;object-fit:cover}.scanner-frame .reticle{position:absolute;top:18%;right:18%;bottom:18%;left:18%;border:3px solid rgba(255,255,255,.9);border-radius:16px;pointer-events:none}.result{border-radius:var(--radius);padding:20px;margin-bottom:16px;text-align:center}.result.ok{background:var(--ok-bg);color:var(--ok)}.result.expired{background:var(--warn-bg);color:var(--warn)}.result.invalid,.result.error{background:var(--error-bg);color:var(--error)}.result.pending{background:var(--warn-bg);color:var(--warn)}.result .result-status{font-size:13px;text-transform:uppercase;letter-spacing:.05em;font-weight:700}.result .result-name{font-size:22px;font-weight:700;margin:6px 0 2px;color:var(--fg)}.result .result-number{font-size:13px;color:var(--muted)}.history h3{font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:8px 0}.scan-row{display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px 12px;margin-bottom:8px}.scan-row .num{font-weight:600;font-size:14px}.scan-row .meta{font-size:12px;color:var(--muted)}.pill{font-size:11px;font-weight:700;text-transform:uppercase;border-radius:999px;padding:2px 8px;white-space:nowrap}.pill.verified{background:var(--ok-bg);color:var(--ok)}.pill.expired{background:var(--warn-bg);color:var(--warn)}.pill.invalid,.pill.error{background:var(--error-bg);color:var(--error)}.pill.pending{background:#eef1f4;color:var(--muted)}.spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.muted{color:var(--muted)}
