:root{--app-bg: #ffffff;--brand-green: #009966;--brand-accent: #00B473;--text-primary: #1A1A1A;--text-secondary: #0B0A0A;--text-muted: #5b6e8c;--text-grey: #9FA8B5;--surface-soft: #f1f5f9;--border-soft: #e2e8f0;--border-card: #EDF0F3;--danger-bg: #fee2e2;--danger-text: #b91c1c}.app-container{width:100%;margin:0;background:#fff;font-family:Open Sans,system-ui,Segoe UI,Roboto,sans-serif;min-height:100dvh;display:flex;flex-direction:column;border-bottom-left-radius:0;border-bottom-right-radius:0;position:relative;z-index:1;gap:16px}.app-header{min-height:156px;padding:6px 16px;padding-top:max(20px,env(safe-area-inset-top));margin:0;color:#fff;font-family:Cervo,Open Sans,system-ui,Segoe UI,Roboto,sans-serif;display:flex;flex-direction:column;align-items:center;justify-content:space-between;background:var(--brand-green)}.logo-container{height:44px;width:137px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:4px}.header-h1{font-weight:600;color:#fff;font-size:40px;display:flex;align-items:center;justify-content:center;gap:10px;margin:0;height:100%}.app-logo{height:28px;width:auto}.header-bottom{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;margin-top:16px}.club-title{font-weight:700;color:#fff;font-size:40px;line-height:40px;text-transform:uppercase;text-align:center;letter-spacing:1px}.balance-qr-label{font-size:18px;font-weight:300;color:#fff;letter-spacing:.6px}.app-content{padding:0 16px 24px;flex:1;width:100%;max-width:470px;margin:0 auto;display:flex;flex-direction:column}.auth-back-button{width:fit-content;margin:0 16px;padding:0;border:0;background:transparent;color:var(--text-primary);font-family:Open Sans,system-ui,Segoe UI,Roboto,sans-serif;font-size:48px;line-height:.4;cursor:pointer}.app-footer{font-size:.65rem;text-align:center;padding:12px 16px;background:var(--app-bg);color:var(--text-muted);border-top:1px solid #e9eef3}.bottom-bar{position:fixed;bottom:0;left:0;width:100%;padding-bottom:env(safe-area-inset-bottom);background-color:#fff;box-shadow:0 -2px 5px #0000001a;z-index:1002}button{font-family:Open Sans,system-ui,Segoe UI,Roboto,sans-serif}.safe-area-top{position:fixed;top:0;left:0;width:100vw;height:env(safe-area-inset-top);background:var(--brand-green);z-index:1000;pointer-events:none}.safe-area-bottom{position:fixed;bottom:0;left:0;width:100vw;height:env(safe-area-inset-bottom);background:#fff;z-index:1000;pointer-events:none}body{margin:0;padding:0;background:#fff}.bottom-bar{position:fixed;bottom:0;left:0;width:100vw;background:#fff;z-index:1100;box-shadow:0 -2px 5px #0000001a;padding-bottom:env(safe-area-inset-bottom)}.login-stage{flex:1;width:100%;max-width:400px;margin:0 auto;display:flex;flex-direction:column;justify-content:center;transition:padding-top .2s ease,justify-content .2s ease}.login-stage.keyboard-open{justify-content:flex-start;padding-top:8px}.auth-form{display:flex;flex-direction:column;gap:20px}.auth-form-code{max-width:400px;margin:0 auto}.code-title{font-size:20px;line-height:28px;font-weight:600;color:var(--text-primary);text-align:center}.code-subtitle{font-size:16px;line-height:24px;color:var(--text-secondary);text-align:center}.code-error-banner{color:#e3003f;border-radius:10px;font-size:16px;line-height:24px;text-align:center;padding:8px 12px}.error-message{color:#e3003f;font-size:14px;line-height:20px;text-align:center;margin-top:8px}.code-boxes{display:flex;justify-content:center;flex-wrap:nowrap;gap:8px;width:100%;margin:0 auto;cursor:text}.code-box{width:51px;height:60px;border-radius:12px;border:1px solid transparent;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:600;color:var(--text-primary);background:#f1f5f9}.code-box.filled,.code-box.active{border:2px solid #00b473}.code-box.code-error{background:#ffe8ef;border-color:transparent}.code-hidden-input{position:fixed;left:-9999px;top:-9999px;opacity:0;pointer-events:none;width:1px;height:1px;font-size:16px}.sms-fallback-button:disabled{background:#edfcf5;color:#96d9b6;font-size:16px;opacity:1}.repeat-call-button:disabled{background:#edfcf5;color:#96d9b6;opacity:1}.input-group{display:flex;flex-direction:column;gap:16px}.input-label{font-weight:600;color:var(--text-primary);font-size:16px}.input-label-center{text-align:center}.app-input{padding:12px 16px;border:2px solid var(--border-soft);border-radius:28px;font-size:20px;outline:none;transition:.2s;width:100%}.app-button{background:var(--brand-accent);color:#fff;border:none;padding:12px 20px;border-radius:40px;font-weight:600;font-size:18px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:.2s;width:100%;min-height:52px}.app-button.is-disabled{opacity:.6;cursor:not-allowed}.app-button-outline{background:transparent;border:2px solid var(--brand-accent);color:var(--brand-accent)}.error-msg{background:var(--danger-bg);color:var(--danger-text);padding:12px;border-radius:60px;font-size:.85rem;text-align:center;margin-top:12px}.info-text{font-size:.75rem;color:var(--text-muted);text-align:center;margin-top:16px}.login-bottom-hint{margin-top:auto;padding-top:20px;padding-bottom:max(8px,env(safe-area-inset-bottom));font-size:.75rem;color:var(--text-muted);text-align:center}.center-state{text-align:center;padding:40px 0;color:var(--text-muted)}.center-state.compact{padding:20px}.center-state.muted{color:#888}.user-info{font-family:Cervo,Open Sans,system-ui,Segoe UI,Roboto,sans-serif;background:var(--surface-soft);border-radius:20px;padding:14px 18px;margin-bottom:16px;font-size:16px;color:var(--text-secondary);line-height:1.5;font-weight:200}.qr-container{background:#fff;border-radius:20px;padding:16px;text-align:center;border:1px solid var(--border-card);box-shadow:0 6px 12px -6px #0000000d}.qr-container.qr-container-clickable{cursor:pointer}.qr-container.qr-container-clickable:active{transform:scale(.995)}.qr-image{max-width:150px}.profile-actions{display:flex;flex-direction:column;gap:16px;margin-top:20px}.profile-actions button{font-family:Cervo,Open Sans,system-ui,Segoe UI,Roboto,sans-serif;font-weight:300}.qr-sheet-backdrop{position:fixed;top:calc(10px + env(safe-area-inset-top));bottom:0;left:0;right:0;display:flex;align-items:stretch;justify-content:center;z-index:2000;animation:qrSheetBackdropIn .22s ease-out}.qr-sheet{width:100%;max-width:100%;background:#fff;height:100%;border-top-left-radius:20px;border-top-right-radius:20px;padding:10px 16px 24px;padding-bottom:max(24px,env(safe-area-inset-bottom));transition:transform .2s ease;touch-action:none;animation:qrSheetIn .26s cubic-bezier(.22,.9,.3,1);display:flex;flex-direction:column}.qr-sheet-handle{width:42px;height:5px;border-radius:999px;background:#cbd5e1;margin:2px auto 12px}.qr-sheet-header{position:relative}.qr-sheet-header-title{text-align:center;color:#000;font-family:Cervo,Open Sans,system-ui,Segoe UI,Roboto,sans-serif;font-size:18px;line-height:24px;font-weight:400;margin-bottom:14px}.qr-sheet-close{position:absolute;top:-2px;right:0;width:36px;height:36px;border:0;border-radius:999px;background:#f1f5f9;color:#334155;font-size:28px;line-height:1;cursor:pointer;display:none;align-items:center;justify-content:center}.qr-sheet-close:hover{background:#e2e8f0}@media (min-width: 768px){.qr-sheet-close{display:inline-flex}}.qr-sheet-content{display:grid;grid-template-rows:1fr auto;flex:1;min-height:0;width:100%}.qr-sheet-image{max-width:300px;width:100%}.qr-sheet-main{grid-row:1;display:flex;flex-direction:column;align-items:center;justify-self:center;align-self:center}.qr-sheet-refresh{margin-top:48px;border:0;background:transparent;color:var(--text-grey);font-family:Cervo,Open Sans,system-ui,Segoe UI,Roboto,sans-serif;font-size:24px;line-height:32px;cursor:pointer}.qr-sheet-refresh:disabled{opacity:.5;cursor:not-allowed}.qr-sheet-bonuses{grid-row:2;margin-bottom:24px;width:100%;text-align:center;color:var(--text-primary);font-family:Cervo,Open Sans,system-ui,Segoe UI,Roboto,sans-serif}.qr-sheet-bonuses-label,.qr-sheet-bonuses-value{font-size:24px;line-height:32px}@keyframes qrSheetIn{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes qrSheetBackdropIn{0%{opacity:0}to{opacity:1}}@keyframes splash-fade-out{0%{opacity:1}to{opacity:0}}@keyframes splash-scale-in{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.splash-container{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#fff;display:flex;align-items:center;justify-content:center;z-index:9999;animation:splash-fade-out .3s ease-in-out forwards}.splash-logo-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}.splash-logo{width:250px;height:auto;animation:splash-scale-in .6s ease-out}html,body{margin:0;padding:0}
