:root{--brand: #5c6ac4;--brand-dark: #3e4a9c;--brand-light: #8b95e6;--brand-muted: rgba(92, 106, 196, .12);--surface: #f8fafc;--surface-elevated: #ffffff;--text: #0f172a;--text-muted: #64748b;--border: #e2e8f0;--radius: 12px;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color-scheme:light;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;min-height:100%;font-family:inherit;background:radial-gradient(circle at top,#eef2ff,#f8fafc 55%,#f1f5f9);color:var(--text)}#root{min-height:100vh}.app-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--text-muted)}.center{text-align:center}.muted{color:var(--text-muted);font-size:.9rem}.subtle{color:#475569;font-size:.85rem}.tiny{font-size:.75rem}.error{color:#c00}.field-error{color:#b91c1c;font-size:.85rem;margin:0 0 .5rem}.toast{position:fixed;top:1rem;left:50%;transform:translate(-50%);background:var(--brand-dark);color:#fff;padding:.6rem 1rem;border-radius:var(--radius);z-index:200;font-size:.9rem;box-shadow:0 10px 40px #0f172a33}.login-page{min-height:100vh;position:relative;display:flex;flex-direction:column;background:linear-gradient(165deg,#eef2ff,#f8fafc 42%,#e8edff)}.login-page:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 90% 55% at 50% -15%,rgba(92,106,196,.18),transparent 55%);pointer-events:none;z-index:0}.login-main{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;justify-content:center;padding:2rem 1.25rem 3rem;width:100%}.login-shell{width:100%;max-width:420px;margin:0 auto}.login-brand-block{text-align:center;margin-bottom:1.75rem}.brand-logo-img{display:block;width:auto;max-width:200px;height:auto;margin:0 auto}.login-product-label{margin:.75rem 0 0;font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted)}.login-brand-block .brand-logo-img{max-height:52px;max-width:240px;width:auto}.login-card{background:#ffffffeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(226,232,240,.95);border-radius:22px;padding:2rem 1.75rem 1.75rem;box-shadow:0 0 0 1px #fffc inset,0 2px 4px #0f172a0a,0 24px 48px -12px #3e4a9c24,0 12px 32px #0f172a0f}.login-card-head{margin-bottom:1.5rem}.login-kicker{margin:0 0 .35rem;font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--brand)}.login-title{font-size:1.625rem;margin:0 0 .5rem;font-weight:700;color:var(--text);letter-spacing:-.03em}.login-sub{margin:0;font-size:.9rem;line-height:1.55;color:var(--text-muted)}.login-form{display:flex;flex-direction:column}.login-alert{margin-bottom:1.25rem;padding:.75rem .9rem;font-size:.875rem;line-height:1.45;color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:10px}.field-group{margin-bottom:1.125rem}.field-group:last-of-type{margin-bottom:1.5rem}.field-label{display:block;font-size:.8125rem;font-weight:600;color:var(--text);margin-bottom:.4rem}.field-input{width:100%;padding:.8rem .95rem;border:1px solid var(--border);border-radius:11px;background:#fff;font-size:.95rem;color:var(--text);transition:border-color .15s ease,box-shadow .15s ease}.field-input::placeholder{color:#94a3b8}.field-input:hover{border-color:#cbd5e1}.field-input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-muted)}.password-wrap{position:relative}.password-wrap .field-input{padding-right:2.75rem}.eye-btn{position:absolute;right:.2rem;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border:none;border-radius:8px;background:transparent;cursor:pointer;color:var(--text-muted);transition:background .15s,color .15s}.eye-btn:hover{background:#f1f5f9;color:var(--brand-dark)}.btn-login-submit{min-height:3rem;font-size:.95rem;letter-spacing:.02em}.btn-loading{display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-spinner{width:1rem;height:1rem;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:login-spin .65s linear infinite}@keyframes login-spin{to{transform:rotate(360deg)}}.link-plain{display:block;width:100%;margin-top:1.25rem;padding:.35rem;background:none;border:none;font-size:.875rem;font-weight:600;cursor:pointer;color:var(--brand-dark);text-align:center;text-decoration:none;transition:color .15s}.link-plain:hover{color:var(--brand);text-decoration:underline}.recaptcha-note{margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--border);font-size:.6875rem;line-height:1.55;color:var(--text-muted);text-align:center}.recaptcha-note a{color:var(--brand-dark);text-decoration:none;font-weight:500}.recaptcha-note a:hover{text-decoration:underline}.scan-layout{min-height:100vh;display:flex;flex-direction:column}.top-bar{display:flex;align-items:center;justify-content:space-between;padding:.65rem 1rem;border-bottom:1px solid var(--border);background:var(--surface-elevated);box-shadow:0 1px #0f172a0a}.top-bar-brand{display:flex;align-items:center;min-height:36px}.top-bar-brand .brand-logo-img{margin:0;max-height:34px;width:auto;max-width:160px;object-fit:contain;object-position:left center}.brand{font-weight:700;color:var(--brand);letter-spacing:-.02em}.icon-btn{border:none;background:transparent;font-size:1.25rem;cursor:pointer;color:var(--text-muted);border-radius:8px;padding:.25rem .5rem}.icon-btn:hover{background:var(--brand-muted);color:var(--brand-dark)}.home-main{flex:1;padding:1.5rem 1.25rem 2.5rem;display:flex;flex-direction:column;justify-content:center;align-items:center}.home-shell{width:100%;max-width:420px;display:flex;flex-direction:column;align-items:center}.home-card{width:100%;text-align:center;background:#ffffffe6;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(226,232,240,.95);border-radius:22px;padding:1.85rem 1.4rem 1.9rem;box-shadow:0 0 0 1px #ffffffbf inset,0 2px 4px #0f172a0a,0 20px 44px -14px #3e4a9c1f}.home-kicker{margin:0 0 .35rem;font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted)}.biz-name{font-size:1.5rem;margin:0 0 .35rem;font-weight:700;line-height:1.25;color:var(--text);letter-spacing:-.02em}.email{color:var(--text-muted);margin:0 0 1rem;font-size:.95rem}.hint{color:#475569;margin:0 0 1.5rem;font-size:.9rem;line-height:1.5;text-align:left}.hint strong{color:var(--brand-dark);font-weight:600}.home-actions{display:flex;flex-direction:column;gap:.85rem;width:100%;max-width:100%;margin:0}.btn{border:none;border-radius:var(--radius);padding:.9rem 1rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s,transform .1s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--brand);color:#fff;box-shadow:0 4px 14px #5c6ac459}.btn-primary:hover:not(:disabled){background:var(--brand-dark)}.btn-accent{background:var(--brand-dark);color:#fff;box-shadow:0 4px 14px #3e4a9c59}.btn-accent:hover:not(:disabled){filter:brightness(1.05)}.btn-secondary{background:#e2e8f0;color:var(--text)}.btn-secondary:hover:not(:disabled){background:#cbd5e1}.wide{width:100%}.member-main{flex:1;padding:1rem 1.25rem 2rem;max-width:420px;margin:0 auto;width:100%}.link-back{background:none;border:none;color:var(--brand);font-weight:600;cursor:pointer;margin-bottom:.5rem}.member-name{margin:.25rem 0 0;font-size:1.35rem;font-weight:700}.member-id{color:var(--text-muted);margin:0 0 1rem}.balance-block{text-align:center;padding:1rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:1rem}.balance-label{font-size:.7rem;letter-spacing:.06em;color:var(--text-muted)}.balance-value{font-size:2rem;font-weight:700;color:var(--brand)}.segment{display:flex;background:#e2e8f0;border-radius:10px;padding:4px;margin-bottom:1rem}.seg{flex:1;border:none;background:transparent;padding:.6rem;border-radius:8px;font-weight:600;cursor:pointer;color:var(--text-muted)}.seg.active{background:var(--surface-elevated);color:var(--brand-dark);box-shadow:0 1px 3px #0f172a1a}.keypad{margin-bottom:1rem}.keypad-display{background:linear-gradient(180deg,#eef2ff,#e2e8f0);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;text-align:right;font-size:2rem;margin-bottom:.75rem;min-height:3.5rem;color:var(--text)}.keypad-grid{display:flex;flex-direction:column;gap:.5rem}.keypad-row{display:flex;gap:.5rem}.keypad-key{flex:1;padding:.85rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-elevated);box-shadow:0 1px 2px #0f172a0f;font-size:1.25rem;cursor:pointer;color:var(--text)}.keypad-key:hover{background:#f8fafc}.keypad-clear{background:#ef4444;color:#fff;border-color:#dc2626}.keypad-clear:hover{filter:brightness(1.05)}.keypad-back{background:#fbbf24;border-color:#f59e0b;color:#1a1a1a}.redeem-list{display:flex;flex-direction:column;gap:.75rem}.offer-card{display:flex;justify-content:space-between;align-items:center;padding:1rem;border:none;border-radius:var(--radius);background:linear-gradient(135deg,var(--brand) 0%,var(--brand-dark) 100%);color:#fff;cursor:pointer;text-align:left;box-shadow:0 6px 20px #5c6ac459}.offer-card:hover:not(:disabled){filter:brightness(1.05)}.offer-card-selectable{background:var(--surface-elevated);color:var(--text);border:2px solid var(--border);box-shadow:0 2px 8px #0f172a0f}.offer-card-selectable:hover:not(:disabled){filter:none;border-color:var(--brand-light)}.offer-card-selected{background:linear-gradient(135deg,var(--brand) 0%,var(--brand-dark) 100%);color:#fff;border-color:transparent;box-shadow:0 6px 20px #5c6ac459}.offer-card-selected .offer-title,.offer-card-selected .offer-cost{color:#fff}.offer-card-selectable:not(.offer-card-selected) .offer-title{color:var(--text);font-size:.95rem}.offer-card-selectable:not(.offer-card-selected) .offer-cost{color:var(--brand);font-weight:700}.redeem-keypad-label{font-size:.8rem;font-weight:600;color:var(--text-muted);margin:1rem 0 .35rem}.redeem-add-with-btn{margin-top:.35rem}.offer-title{font-weight:700}.offer-cost{font-size:.9rem;opacity:.95}.summary-footer{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border);font-size:.9rem;color:#475569}.summary-row{display:flex;justify-content:space-between;margin:.35rem 0}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:1.25rem;max-width:400px;width:100%;max-height:90vh;overflow:auto;box-shadow:0 20px 45px #0f172a2e}.modal-title{margin:0 0 .5rem;text-align:center;font-weight:700;color:var(--text)}.modal-hint{text-align:center;color:var(--text-muted);font-size:.85rem;margin:0 0 1rem}.search-results{display:flex;flex-direction:column;gap:.5rem;margin:.75rem 0;max-height:40vh;overflow-y:auto}.result-card{width:100%;text-align:left;border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;background:var(--surface-elevated);cursor:pointer;transition:border-color .15s,box-shadow .15s}.result-card:hover{border-color:var(--brand-light);box-shadow:0 0 0 2px var(--brand-muted)}.result-name{font-weight:700}.result-meta{font-size:.85rem;color:#475569}.result-meta.subtle{color:var(--text-muted);font-size:.8rem}.badge{font-weight:500;font-size:.85rem;color:var(--brand-dark)}.modal-actions{display:flex;gap:.75rem;margin-top:1rem}.modal-actions .btn{flex:1}.scan-mode-wrap{padding:1rem;flex:1}.scan-capture{background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;text-align:center;box-shadow:0 4px 20px #5c6ac414}.scan-capture-title{font-weight:700;margin:0 0 .5rem;color:var(--brand-dark)}.scan-hidden-input{position:absolute;left:-9999px;opacity:0;height:0;width:0}.scan-pick-list{list-style:none;padding:0;margin:.5rem 0 0}.scan-pick-list li{margin:.35rem 0}.scan-pick .result-card{text-align:center}
