*{margin:0;padding:0;box-sizing:border-box}.scroll-lock{overflow:hidden!important;overscroll-behavior:none!important;height:100%!important}.scroll-lock::-webkit-scrollbar{display:none}:root{color-scheme:light dark;--vh: 100vh;--primary: #0097FF;--primary-hover: #0088e6;--primary-light: #e0f2ff;--bg: #fafbfc;--bg-secondary: #ffffff;--bg-tertiary: #f8f9fa;--text-primary: #1a1d29;--text-secondary: #6b7280;--text-tertiary: #9ca3af;--border: #e5e7eb;--border-light: #f3f4f6;--shadow: 0 1px 3px rgba(0, 0, 0, .05), 0 1px 2px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--radius-xl: 20px}@supports (height: 100lvh){:root{--vh: 100lvh}}.light{color-scheme:light;--primary: #0097FF;--primary-hover: #0088e6;--primary-light: #e0f2ff;--bg: #fafbfc;--bg-secondary: #ffffff;--bg-tertiary: #f8f9fa;--text-primary: #1a1d29;--text-secondary: #6b7280;--text-tertiary: #9ca3af;--border: #e5e7eb;--border-light: #f3f4f6;--shadow: 0 1px 3px rgba(0, 0, 0, .05), 0 1px 2px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05)}.dark{color-scheme:dark;--primary: #0097FF;--primary-hover: #0088e6;--primary-light: #003d66;--bg: #1a1a1a;--bg-secondary: #1a1a1a;--bg-tertiary: #2a2a2a;--text-primary: #f8fafc;--text-secondary: #e2e8f0;--text-tertiary: #cbd5e1;--border: #333333;--border-light: #404040;--shadow: 0 1px 3px rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -2px rgba(0, 0, 0, .4)}@media(prefers-color-scheme:dark){:root:not(.light):not(.dark){--primary: #0097FF;--primary-hover: #0088e6;--primary-light: #003d66;--bg: #1a1a1a;--bg-secondary: #1a1a1a;--bg-tertiary: #2a2a2a;--text-primary: #f8fafc;--text-secondary: #e2e8f0;--text-tertiary: #cbd5e1;--border: #333333;--border-light: #404040;--shadow: 0 1px 3px rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -2px rgba(0, 0, 0, .4)}}html,body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,var(--bg) 0%,var(--bg-tertiary) 100%);background-attachment:fixed;color:var(--text-primary);line-height:1.6;overflow-x:hidden;overflow-y:auto;overscroll-behavior-y:contain;min-height:var(--vh);scroll-behavior:smooth;-webkit-overflow-scrolling:touch;transition:background-color .15s ease,color .15s ease;width:100%}.dark body{background:#000}#root{min-height:var(--vh);width:100%}@media(max-width:768px){body{font-size:16px;-webkit-tap-highlight-color:transparent;touch-action:manipulation}@supports (-webkit-touch-callout: none){body,#root{min-height:-webkit-fill-available}}}@media(min-width:1025px){body{max-width:100%}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-tertiary)}::-webkit-scrollbar-thumb{background:var(--text-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}input,textarea{font-family:inherit;font-size:inherit;outline:none}button{font-family:inherit;cursor:pointer;border:none;outline:none;-webkit-tap-highlight-color:transparent}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.fade-in{animation:fadeIn .3s ease-out}.slide-up{animation:slideUp .4s ease-out}.scale-in{animation:scaleIn .3s ease-out}.membership-card{color:var(--fg-color);border-radius:18px;cursor:pointer;position:relative;overflow:hidden;transition:all .2s cubic-bezier(.4,0,.2,1);user-select:none;-webkit-user-select:none;touch-action:manipulation;display:block;background:var(--bottom-color);width:100%;aspect-ratio:1.58 / 1;box-shadow:0 1px 2px #0000000a,0 1px 3px #0000000f}.membership-card:before{content:"";position:absolute;top:0;left:0;right:0;height:50px;background:var(--top-color);z-index:0}.card-inner{width:100%;height:50px;padding:0 18px;position:relative;z-index:10;box-sizing:border-box;display:flex;flex-direction:column;top:0;left:0;align-items:center;justify-content:center}.card-logo-container{position:absolute;top:50%;left:18px;transform:translateY(-50%);height:36px;display:flex;align-items:center;justify-content:flex-start;z-index:11}.card-logo{height:36px;width:auto;max-width:115px;object-fit:contain;object-position:left center;transition:transform .15s ease;display:block}.card-add-container{position:absolute;top:50%;right:18px;transform:translateY(-50%);z-index:11;display:flex;align-items:center;justify-content:flex-end;gap:4px;height:36px}.card-add-text{font-size:16px;font-weight:600;letter-spacing:-.3px;line-height:36px;color:var(--fg-color);white-space:nowrap}.card-add-arrow{color:var(--fg-color);flex-shrink:0;margin-top:2px}.card-strip-container{position:absolute;inset:50px 0 0;width:100%;display:flex;align-items:flex-end;justify-content:center;z-index:2;overflow:hidden;padding:8px 18px;background:var(--bottom-color);box-sizing:border-box}.card-strip{width:100%;height:calc(100% - 16px);max-height:80%;object-fit:contain;object-position:center center;display:block;transform:translateY(-15px)}.membership-card:active{transform:none}.dark-mode-toggle{background:var(--bg-tertiary);border:none;padding:6px;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .15s ease;cursor:pointer;margin-right:8px}.dark-mode-toggle:hover{background:var(--border-light);color:var(--text-primary);transform:scale(1.05)}.dark-mode-toggle:active{transform:scale(.95)}.dark .dark-mode-toggle{color:#e2e8f0}.dark .dark-mode-toggle:hover{color:#f8fafc}.home{width:100%;min-height:var(--vh);background:linear-gradient(to bottom,var(--bg) 0%,#ffffff 100%);padding-top:calc(56px + env(safe-area-inset-top));padding-bottom:env(safe-area-inset-bottom);overflow:visible;overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch}.dark .home{background:linear-gradient(to bottom,var(--bg) 0%,var(--bg) 60%,#000000 100%);background-attachment:fixed}.home-header{position:fixed;top:0;left:0;right:0;z-index:100;background:#ffffffd9;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--border-light);padding:10px 16px;padding-top:max(10px,env(safe-area-inset-top));transition:background-color .2s ease,border-color .2s ease;-webkit-transform:translateZ(0);transform:translateZ(0);overscroll-behavior:contain}.dark .home-header{background:#000!important;backdrop-filter:none;-webkit-backdrop-filter:none;border-bottom-color:var(--border)}.header-content{display:flex;align-items:center;justify-content:space-between;max-width:375px;margin:0 auto}.header-title{display:flex;align-items:center;height:100%}.logo-link{display:inline-block;background:none;border:none;padding:0;margin:0;cursor:pointer;transition:opacity .2s ease}.logo-link:hover{opacity:.8}.logo-link:active{opacity:.6}.logo-icon-img{height:16px;width:auto;max-width:72px;object-fit:contain;object-position:left center;display:block;vertical-align:middle;transform:translateY(-3px)}.logo-icon-fallback{width:36px;height:36px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-hover) 100%);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px}.header-title h1{font-size:28px;font-weight:700;color:var(--text-primary);margin:0;line-height:1.2;letter-spacing:-.6px}.dark .header-title h1{color:#f8fafc}.subtitle{font-size:15px;color:var(--text-secondary);margin:2px 0 0;font-weight:400;letter-spacing:-.3px}.dark .subtitle{color:#e2e8f0}.header-actions{display:flex;align-items:center;gap:10px}.social-link{background:var(--bg-tertiary);border:none;padding:6px;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .15s ease;cursor:pointer;text-decoration:none}.social-link:hover{background:var(--border-light);transform:scale(1.05)}.social-link:active{transform:scale(.95)}.social-icon,.dark .social-icon{color:#e1306c;stroke:#e1306c}.dark .social-link{color:#e2e8f0}.dark .social-link:hover{color:#f8fafc}.social-icon{display:block}.settings-btn{background:var(--bg-tertiary);border:none;padding:11px;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s ease;cursor:pointer}.dark .settings-btn{color:#e2e8f0}.settings-btn:hover{background:var(--border-light);color:var(--text-primary);transform:scale(1.05)}.dark .settings-btn:hover{color:#f8fafc}.settings-btn:active{transform:scale(.95)}.splash-section{position:fixed;inset:0;width:100%;max-width:375px;margin:0 auto;padding:0 16px;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.splash-section>*{pointer-events:auto}.splash-content{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;width:100%}.splash-title{font-size:32px;font-weight:700;color:var(--text-primary);margin:0;line-height:1.3;letter-spacing:-.8px}.dark .splash-title{color:#f8fafc}.splash-content .splash-title:first-child{margin-bottom:8px}.splash-subtitle{margin-top:16px;margin-bottom:0;padding:0 16px;font-size:14px;line-height:1.6;color:var(--text-secondary);font-weight:400;letter-spacing:-.2px}.dark .splash-subtitle{color:#94a3b8}.splash-add-button{margin-top:20px;padding:16px 32px;font-size:18px;font-weight:600;color:#fff;background:var(--primary);border:none;border-radius:16px;cursor:pointer;transition:all .2s ease;letter-spacing:-.3px}.splash-add-button:hover{background:var(--primary-hover)}.splash-add-button:active{opacity:.9}.dark .splash-add-button{background:var(--primary)}.dark .splash-add-button:hover{background:var(--primary-hover)}.splash-copyright{position:absolute;bottom:24px;left:0;right:0;font-size:12px;color:var(--text-secondary);text-align:center;white-space:nowrap}.dark .splash-copyright{color:#94a3b8}.membership-list{margin-top:12px;max-width:375px;margin-left:auto;margin-right:auto;padding:32px 0 0;display:grid;grid-template-columns:1fr;gap:18px;position:relative;z-index:1}.membership-list>*{width:94.5%;max-width:94.5%;min-width:0;margin:0 auto}.version-info{max-width:375px;margin:32px auto 0;text-align:center;padding:0 0 120px;font-size:12px;color:var(--text-tertiary);letter-spacing:-.2px}.dark .version-info{color:#64748b}.home-bottom-spacer{height:40px}.modal-overlay{position:fixed;inset:0;background:#0006;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:flex-end;padding:0;transition:background-color .3s ease}.dark .modal-overlay{background:#0009}.modal-content{background:var(--bg-secondary);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-height:80vh;overflow-y:auto;padding:28px 24px;padding-bottom:max(28px,env(safe-area-inset-bottom));transition:background-color .3s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.modal-header h2{font-size:22px;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.5px}.dark .modal-header h2{color:#f8fafc}.modal-header button{background:var(--bg-tertiary);border:none;font-size:20px;color:var(--text-secondary);width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s;cursor:pointer}.modal-header button:hover{background:var(--border-light);color:var(--text-primary)}.modal-header button:active{transform:scale(.95)}.modal-body{color:var(--text-primary)}.info-text{font-size:14px;line-height:1.7;color:var(--text-secondary);margin-bottom:28px;padding:20px;background:var(--bg-tertiary);border-radius:var(--radius);border-left:3px solid var(--primary)}.dark .info-text{color:#e2e8f0}.info-section h3{font-size:18px;font-weight:600;margin-bottom:16px;color:var(--text-primary);letter-spacing:-.3px}.dark .info-section h3{color:#f8fafc}.info-section ol{padding-left:24px;margin:0}.info-section li{font-size:15px;line-height:1.8;color:var(--text-secondary);margin-bottom:10px}.dark .info-section li{color:#e2e8f0}@media(min-width:769px){.modal-overlay{align-items:center;justify-content:center}.modal-content{border-radius:var(--radius-xl);max-width:520px;max-height:75vh;padding:36px}}@media(min-width:1025px){.modal-content{max-width:600px;padding:44px}}.barcode-preview{display:flex;flex-direction:column;align-items:center;gap:16px}.barcode-canvas-container{width:100%;max-width:100%;height:120px;display:flex;justify-content:center;align-items:center;padding:0;background:#fff;border-radius:var(--radius);position:relative;overflow:hidden;transition:background-color .15s ease;box-sizing:border-box}.dark .barcode-canvas-container{background:transparent}.barcode-canvas{max-width:100%;width:100%;height:120px;display:block;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;object-fit:contain}.barcode-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:14px;color:var(--text-secondary);z-index:1;font-weight:500}.barcode-display-value{font-size:15px;font-weight:600;color:var(--text-primary);letter-spacing:1.5px;font-family:SF Mono,Monaco,Courier New,monospace;text-align:center;padding:8px 16px;background:var(--bg-tertiary);border-radius:var(--radius-sm)}@media(min-width:769px){.barcode-display-value{font-size:16px;padding:10px 20px}}.membership-add{width:100%;min-height:var(--vh);background:linear-gradient(to bottom,var(--bg) 0%,#ffffff 100%);overflow:hidden;padding-top:calc(56px + env(safe-area-inset-top));padding-bottom:env(safe-area-inset-bottom);overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch}.dark .membership-add{background:linear-gradient(to bottom,var(--bg) 0%,var(--bg) 60%,#000000 100%);background-attachment:fixed}.add-header{position:fixed;top:0;left:0;right:0;z-index:100;background:#ffffffd9;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--border-light);padding:10px 16px;padding-top:max(10px,env(safe-area-inset-top));transition:background-color .2s ease,border-color .2s ease;-webkit-transform:translateZ(0);transform:translateZ(0);overscroll-behavior:contain}.add-header-content{display:flex;align-items:center;justify-content:space-between;max-width:375px;margin:0 auto}.dark .add-header{background:#000!important;backdrop-filter:none;-webkit-backdrop-filter:none;border-bottom-color:var(--border)}.back-btn{background:none;border:none;padding:6px;color:var(--text-primary);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s ease;cursor:pointer}.dark .back-btn{color:#f8fafc}.back-btn:hover{background:#0000000d;transform:scale(1.05)}.dark .back-btn:hover{background:#ffffff1a}.back-btn:active{transform:scale(.95)}.add-header h1{font-size:18px;font-weight:700;color:var(--text-primary);margin:0;flex:1;text-align:center;letter-spacing:-.5px;line-height:1;display:flex;align-items:center;justify-content:center}.dark .add-header h1{color:#f8fafc}.add-content-wrapper{display:flex;flex-direction:column;gap:24px;max-width:375px;margin:0 auto;padding:16px;padding-bottom:env(safe-area-inset-bottom);overflow:visible}.add-content{flex:1;min-width:0;max-width:100%;display:flex;flex-direction:column;justify-content:flex-start;min-height:calc(var(--vh) - 200px);padding-top:16px;overflow:visible}.pass-preview-sidebar{display:none}@media(min-width:1025px){.pass-preview-sidebar{display:block;flex-shrink:0;width:380px;position:sticky;top:100px;max-height:calc(100vh - 120px);overflow-y:auto}}.form-section{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:24px;margin-bottom:20px;border:1px solid var(--border-light);transition:background-color .2s ease,border-color .2s ease;overflow:hidden}.dark .form-section{background:var(--bg-secondary);border-color:var(--border)}.section-title{font-size:17px;font-weight:600;color:var(--text-primary);margin:0 0 20px;letter-spacing:-.3px}.dark .section-title{color:#f8fafc}.input-group{margin-bottom:20px}.input-group:last-child{margin-bottom:0}.form-section .input-group:has(.step-picker){margin-bottom:0}.input-group label{display:block;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:10px;letter-spacing:-.2px}.dark .input-group label{color:#f1f5f9}.step-label{display:block;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:10px;letter-spacing:-.2px}.dark .step-label{color:#f1f5f9}.form-input{width:100%;padding:16px 20px;font-size:16px;border:2px solid var(--border);border-radius:var(--radius);background:#fff;color:var(--text-primary);transition:all .2s ease;-webkit-appearance:none;appearance:none}.form-input:focus{border-color:var(--primary);background:#fff;outline:none}.form-input::placeholder{color:var(--text-tertiary)}.dark .form-input{background:#000;color:#f8fafc}.dark .form-input:focus{background:#000}.dark .form-input::placeholder{color:#94a3b8;opacity:.7}.input-hint{margin-top:8px;font-size:12px;color:var(--text-tertiary);line-height:1.5}.dark .input-hint{color:#94a3b8}.picker-group{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.picker-btn{padding:16px 20px;font-size:15px;font-weight:500;border:2px solid var(--border);border-radius:var(--radius);background:var(--bg-tertiary);color:var(--text-secondary);transition:all .2s ease;cursor:pointer}.dark .picker-btn{color:#e2e8f0}.dark .picker-btn:hover:not(.active){color:var(--primary)}.picker-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.picker-btn:active{transform:scale(.98)}@media(min-width:769px){.picker-btn:hover:not(.active){background:var(--bg-secondary);border-color:var(--primary);color:var(--primary)}.picker-btn.active:hover{background:var(--primary-hover)}}.section-divider{width:100%;height:1px;background:var(--border-light);margin:16px 0}.dark .section-divider{background:var(--border)}.barcode-preview-section{margin-bottom:1px}.barcode-preview-container{padding:1px 0;background:transparent;border-radius:0;border:none;transition:background-color .15s ease,border-color .15s ease;overflow:hidden;max-width:100%;box-sizing:border-box;width:100%}.dark .barcode-preview-container{background:transparent;border-color:transparent}.card-number-preview{margin-top:10px;padding:16px 20px;background:var(--bg-tertiary);border-radius:var(--radius-lg);border:2px solid var(--border-light);text-align:center;font-size:15px;color:var(--text-primary);transition:background-color .15s ease,border-color .15s ease;box-sizing:border-box;width:100%;display:flex;align-items:center;justify-content:center;line-height:1.2;height:54px}.card-number-preview-editable{margin-top:10px;padding:16px 20px;background:#fff;border-radius:var(--radius-lg);border:2px solid var(--border-light);text-align:center;font-size:15px;color:var(--text-primary);transition:background-color .15s ease,border-color .15s ease;box-sizing:border-box;width:100%;display:block;font-family:inherit;-webkit-appearance:none;appearance:none;cursor:text;line-height:1.2;height:54px}.card-number-preview-editable:focus{outline:none;border-color:var(--primary);background:#fff}.dark .card-number-preview{background:var(--bg-secondary);border-color:var(--border);color:#f8fafc}.dark .card-number-preview-editable{background:#000;border-color:var(--border);color:#f8fafc}.dark .card-number-preview-editable:focus{background:#000;border-color:var(--primary)}.card-number-custom-hint{font-size:13px;color:var(--text-tertiary);text-align:center;line-height:1.4;overflow:hidden}.dark .card-number-custom-hint{color:#94a3b8}.info-box{display:flex;gap:14px;padding:16px;background:#fef3c7;border:1px solid #fde68a;border-left:4px solid #f59e0b;border-radius:var(--radius);margin-top:24px;margin-bottom:0}.dark .info-box{background:#78350f;border-color:#92400e;border-left-color:#f59e0b}.dark .info-box svg{color:#fbbf24}.dark .info-box p{color:#fef3c7}.info-box svg{color:#d97706;flex-shrink:0;margin-top:2px}.info-box p{font-size:14px;line-height:1.7;color:#92400e;margin:0}.error-box{display:flex;gap:14px;padding:20px;background:#fee2e2;border:1px solid #fecaca;border-left:4px solid #dc2626;border-radius:var(--radius);margin-bottom:20px}.dark .error-box{background:#7f1d1d;border-color:#991b1b;border-left-color:#dc2626}.dark .error-box svg{color:#fca5a5}.dark .error-box p{color:#fee2e2}.error-box svg{color:#dc2626;flex-shrink:0;margin-top:2px}.error-box p{font-size:14px;line-height:1.7;color:#991b1b;margin:0}.submit-btn{width:100%;padding:20px 28px;font-size:17px;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-hover) 100%);border:none;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;gap:10px;cursor:pointer;transition:all .2s ease;margin-top:16px;letter-spacing:-.3px}.submit-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-hover) 0%,#007acc 100%);transform:translateY(-2px)}.submit-btn:active:not(:disabled){transform:translateY(0)}.submit-btn:disabled{opacity:.5;cursor:not-allowed;background:var(--text-tertiary);transform:none;pointer-events:none}.submit-btn span{display:flex;align-items:center;gap:8px}@media(max-width:768px){.form-input{font-size:16px}}.step-indicator{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:32px;padding:0;width:100%}.step-indicator-text{font-size:14px;font-weight:600;color:var(--text-secondary);letter-spacing:-.2px}.dark .step-indicator-text{color:var(--text-tertiary)}.step-indicator-dots{display:flex;justify-content:center;align-items:center;gap:8px}.step-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:all .3s ease}.step-dot.active{width:24px;height:8px;border-radius:4px;background:var(--primary)}.step-dot.completed{background:var(--primary)}.dark .step-dot{background:var(--border)}.dark .step-dot.active,.dark .step-dot.completed{background:var(--primary)}.step-content{min-height:400px;display:flex;flex-direction:column}.step-title{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 32px;letter-spacing:-.5px;text-align:center}.dark .step-title{color:#f8fafc}.step-subtitle{font-size:14px;font-weight:600;color:var(--text-secondary);margin:0 0 12px;letter-spacing:-.2px}.dark .step-subtitle{color:#e2e8f0}.step-input{font-size:18px;padding:20px;text-align:center}.step-preview{margin:16px 0 8px;padding:16px 16px 8px}.step-buttons{display:flex;gap:12px;margin-top:auto;padding-top:32px}.step-next-btn,.step-prev-btn{flex:1;padding:18px 24px;font-size:16px;font-weight:600;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.step-buttons-fixed{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:375px;display:flex;gap:12px;padding:12px 16px;padding-bottom:max(12px,env(safe-area-inset-bottom) + 12px);background:transparent;z-index:50}.step-buttons-row{display:flex;gap:12px;align-items:center;width:100%}.card-number-warning{font-size:12px;color:#9ca3af;text-align:center;margin:8px 0 0;padding:0;line-height:1.5}.dark .card-number-warning{color:#6b7280}.step-prev-btn-circle{width:48px;height:48px;border-radius:50%;background:var(--bg-tertiary);border:2px solid var(--border);color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;padding:0;flex-shrink:0}.step-prev-btn-circle:hover{background:var(--bg-secondary);border-color:var(--border-light)}.step-prev-btn-circle:active{opacity:.8}.dark .step-prev-btn-circle{background:var(--bg-tertiary);border-color:var(--border);color:#f8fafc}.dark .step-prev-btn-circle:hover{background:var(--bg-secondary)}.step-next-btn-fixed{flex:1;height:48px;padding:0 24px;font-size:16px;font-weight:600;border:none;border-radius:50px;background:var(--primary);color:#fff;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.step-next-btn-fixed.full-width{width:100%}.step-next-btn-fixed:hover:not(:disabled){background:var(--primary-hover)}.step-next-btn-fixed:active:not(:disabled){opacity:.9}.step-next-btn-fixed:disabled{opacity:.5;cursor:not-allowed;transform:none}.step-next-btn{background:var(--primary);color:#fff}.step-next-btn:hover:not(:disabled){background:var(--primary-hover)}.step-next-btn:active:not(:disabled){opacity:.9}.step-next-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.step-prev-btn{background:var(--bg-tertiary);color:var(--text-primary);border:2px solid var(--border)}.step-prev-btn:hover{background:var(--bg-secondary);border-color:var(--border-light)}.dark .step-prev-btn{background:var(--bg-tertiary);color:#f8fafc;border-color:var(--border)}.dark .step-prev-btn:hover{background:var(--bg-secondary)}.step-picker{margin-bottom:0}.form-section .input-group:has(.step-picker:only-child){margin-bottom:0}.step-submit{margin-top:24px;width:100%}.step-content-complete{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;padding:8px 0 200px}.pass-complete-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;gap:12px}.step-content-complete .step-title{margin:0 16px 12px;font-size:20px;font-weight:700;text-align:center;line-height:1.4}.step-complete-buttons-fixed{width:100%;display:flex;flex-direction:column;gap:12px;margin-top:24px;padding:16px 0 24px}.safari-notice{font-size:13px;color:#9ca3af;text-align:center;margin:0;padding:0 16px;line-height:1.5}.safari-notice.warning{margin-top:8px;font-size:12px}.dark .safari-notice{color:#6b7280}.step-submit-btn-complete{width:100%;height:48px;padding:0 24px;font-size:16px;font-weight:600;border:none;border-radius:50px;background:var(--primary);color:#fff;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.step-submit-btn-complete:hover:not(:disabled){background:var(--primary-hover)}.step-submit-btn-complete:active:not(:disabled){opacity:.9}.step-submit-btn-complete:disabled{opacity:.5;cursor:not-allowed;transform:none}.step-complete-btn{width:100%;height:48px;padding:0 24px;font-size:16px;font-weight:600;border:2px solid var(--border);border-radius:50px;background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.step-complete-btn:hover{background:#0000000d}.step-complete-btn:active{opacity:.8}.dark .step-complete-btn{background:var(--bg-tertiary);border-color:var(--border);color:#f8fafc}.dark .step-complete-btn:hover{background:#ffffff1a}.pass-preview-complete{background:var(--bg-color);color:var(--text-color);border-radius:18px;position:relative;overflow:hidden;display:flex;flex-direction:column;width:100%;max-width:300px;margin:0 auto;padding:16px 16px 12px;min-height:320px;border:1px solid rgba(255,255,255,.1)}.dark .pass-preview-complete{border-color:#ffffff26}.pass-complete-logo{display:flex;align-items:center;justify-content:flex-start;margin-top:-4px;margin-bottom:12px;z-index:10}.pass-complete-logo img{height:32px;width:auto;max-width:120px;object-fit:contain;object-position:left center;display:block}.pass-complete-strip{width:100%;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;z-index:1}.pass-complete-strip img{width:100%;max-width:240px;height:auto;object-fit:contain;display:block;border-radius:12px}.pass-complete-info{display:flex;flex-direction:row;justify-content:flex-start;align-items:flex-start;gap:10px;margin-bottom:12px;z-index:2}.pass-complete-info-col{display:flex;flex-direction:column;gap:6px}.pass-complete-info-col:first-child{flex:0 0 auto;min-width:80px}.pass-complete-info-col:last-child{flex:1}.pass-complete-label{font-size:11px;opacity:.8;font-weight:500;letter-spacing:.2px}.pass-complete-value{font-size:14px;font-weight:600;letter-spacing:-.2px;text-align:left}.pass-complete-barcode{display:flex;align-items:center;justify-content:center;width:100%;margin-top:auto;padding:0 24px;background:transparent;border-radius:12px;z-index:3}.pass-complete-barcode .barcode-canvas-container{width:100%;max-width:200px}.app{width:100%;min-height:100vh;background:var(--bg);position:relative}
