@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Orbitron:wght@700;800;900&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--apple-blue: #2563EB;--apple-pink: #FF2D55;--apple-red: #FF3B30;--apple-orange: #FF9500;--apple-yellow: #FFCC00;--apple-green: #34C759;--apple-teal: #5AC8FA;--apple-indigo: #5856D6;--apple-cyan: #32ADE6;--gradient-dawn: linear-gradient(135deg, #2563EB 0%, #1d4ed8 50%, #1e40af 100%);--gradient-ocean: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-sunset: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--gradient-aurora: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%);--glass-white: rgba(255, 255, 255, .75);--glass-white-strong: rgba(255, 255, 255, .95);--glass-dark: rgba(30, 30, 46, .75);--glass-blur: blur(24px);--glass-blur-strong: blur(40px);--bg-primary: #F8FAFC;--bg-secondary: #FFFFFF;--bg-dark: #0F172A;--text-primary: #0F172A;--text-secondary: #475569;--text-tertiary: #94a3b8;--text-white: #FFFFFF;--border-light: rgba(0, 0, 0, .06);--border-glass: rgba(255, 255, 255, .2);--shadow-soft: 0 8px 32px rgba(0, 0, 0, .08);--shadow-medium: 0 12px 48px rgba(0, 0, 0, .12);--shadow-strong: 0 20px 60px rgba(0, 0, 0, .16);--shadow-glow-blue: 0 8px 32px rgba(0, 122, 255, .25);--shadow-glow-pink: 0 8px 32px rgba(255, 45, 85, .25);--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 28px;--radius-full: 9999px;--ease-fast: .15s cubic-bezier(.4, 0, .2, 1);--ease-base: .25s cubic-bezier(.4, 0, .2, 1);--ease-slow: .35s cubic-bezier(.4, 0, .2, 1);--spring: cubic-bezier(.68, -.55, .265, 1.55)}body{font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,system-ui,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);line-height:1.5;overflow-x:hidden}.enterprise-portal{display:flex;min-height:100vh;position:relative;overflow:hidden}.enterprise-portal:before{content:"";position:fixed;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(102,126,234,.03) 0%,transparent 70%);animation:float 20s ease-in-out infinite;pointer-events:none;z-index:0}.enterprise-portal:after{content:"";position:fixed;bottom:-50%;left:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(200,200,220,.02) 0%,transparent 70%);animation:float 25s ease-in-out infinite reverse;pointer-events:none;z-index:0}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-50px) scale(1.1)}66%{transform:translate(-20px,30px) scale(.9)}}.sidebar{width:280px;min-width:280px;min-height:100vh;height:auto;position:sticky;top:0;padding:var(--sp-6);background:var(--glass-white);backdrop-filter:var(--glass-blur-strong);-webkit-backdrop-filter:var(--glass-blur-strong);border-right:1px solid var(--border-light);display:flex;flex-direction:column;z-index:100;overflow-y:auto}.logo-section{text-align:center;padding:var(--sp-4) 0;margin-bottom:var(--sp-4)}.logo-img{display:none!important}.logo-section:before{content:"PASSREXX";font-family:Orbitron,monospace;font-size:34px;font-weight:900;padding:8px 0;letter-spacing:1.5px;color:#2563eb;background:linear-gradient(135deg,#2563eb,#1d4ed8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-fill-color:transparent;display:inline-block;line-height:1.2;width:100%}.main-nav{flex:1;display:flex;flex-direction:column;gap:var(--sp-2)}.nav-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-radius:var(--radius-lg);color:var(--text-secondary);text-decoration:none;font-weight:500;font-size:14px;transition:all var(--ease-base);cursor:pointer;border:1px solid transparent;position:relative;overflow:hidden}.nav-item:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#007aff1a;transform:translate(-50%,-50%);transition:width .6s,height .6s}.nav-item:hover:before{width:300px;height:300px}.nav-item:hover{background:#007aff0f;color:var(--apple-blue);border-color:#007aff1a;transform:translate(4px)}.nav-item.active{background:var(--gradient-dawn);color:#fff;box-shadow:var(--shadow-glow-blue);font-weight:600;transform:translate(0)}.nav-item.active:before{display:none}.nav-icon{font-size:20px;width:24px;text-align:center;z-index:1;position:relative}.nav-label{z-index:1;position:relative}.sidebar-footer{margin-top:var(--sp-6);padding-top:var(--sp-6);border-top:1px solid var(--border-light)}.user-profile{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3);background:#00000005;border-radius:var(--radius-md);flex:1}.user-avatar,.profile-avatar{width:40px;height:40px;border-radius:50%;background:var(--gradient-dawn);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px;flex-shrink:0}.user-info,.profile-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.user-name,.profile-name{font-weight:600;font-size:14px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email,.profile-email{font-size:12px;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-btn{width:40px;height:40px;border-radius:var(--radius-full);border:1px solid var(--border-light);background:#fff9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--ease-base);flex-shrink:0}.logout-btn:hover{background:var(--apple-red);color:#fff;border-color:var(--apple-red);transform:scale(1.1);box-shadow:0 4px 16px #ff3b304d}.logout-btn svg{width:20px;height:20px}.header-logout-btn{margin-left:var(--sp-2)}.main-wrapper{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden;position:relative;z-index:1}.top-header,.main-header{padding:var(--sp-6) var(--sp-8);background:var(--glass-white);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--border-light);position:sticky;top:0;z-index:50;display:flex;justify-content:space-between;align-items:center;gap:var(--sp-6)}.header-title{font-size:32px;font-weight:800;color:#1d1d1f;letter-spacing:-.5px}.header-actions{display:flex;align-items:center;gap:var(--sp-3)}.header-icon-btn{width:40px;height:40px;border-radius:var(--radius-full);border:1px solid var(--border-light);background:#fff9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--ease-base);position:relative}.header-icon-btn:hover{background:var(--apple-blue);color:#fff;border-color:var(--apple-blue);transform:scale(1.1);box-shadow:var(--shadow-glow-blue)}.header-icon-btn svg{width:20px;height:20px}.header-icon-btn:after{content:"";position:absolute;top:8px;right:8px;width:8px;height:8px;background:var(--apple-red);border-radius:50%;border:2px solid white;opacity:0;transform:scale(0);transition:all var(--ease-base)}.header-icon-btn.has-notification:after{opacity:1;transform:scale(1)}.header-content{max-width:1400px;margin:0 auto}.page-title{font-size:36px;font-weight:900;color:#1d1d1f;letter-spacing:-.5px;margin-bottom:var(--sp-2)}.page-subtitle{color:var(--text-secondary);font-size:15px;font-weight:500}.main-content{flex:1;overflow-y:auto;padding:var(--sp-8)}.content-inner{max-width:1400px;margin:0 auto}.dashboard{display:flex;flex-direction:column;gap:var(--sp-6)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-6)}@media(max-width:1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.stats-grid{grid-template-columns:1fr}}.stat-card{background:var(--glass-white);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--border-glass);border-radius:var(--radius-2xl);padding:var(--sp-6);transition:all var(--ease-base);cursor:pointer;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-dawn);opacity:0;transition:opacity var(--ease-fast)}.stat-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:var(--shadow-medium);border-color:#fff6}.stat-card:hover:before{opacity:1}.stat-card-body{display:flex;align-items:flex-start;gap:var(--sp-4)}.stat-icon-wrapper{width:56px;height:56px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:28px;position:relative;flex-shrink:0}.stat-icon-wrapper:before{content:"";position:absolute;inset:0;border-radius:var(--radius-lg);opacity:.12}.stat-icon-wrapper.navy{color:var(--bg-dark)}.stat-icon-wrapper.navy:before{background:var(--bg-dark)}.stat-icon-wrapper.blue{color:var(--apple-blue)}.stat-icon-wrapper.blue:before{background:var(--apple-blue)}.stat-icon-wrapper.purple{color:var(--apple-blue)}.stat-icon-wrapper.purple:before{background:var(--apple-blue)}.stat-icon-wrapper.pink{color:var(--apple-pink)}.stat-icon-wrapper.pink:before{background:var(--apple-pink)}.stat-icon-wrapper.green{color:var(--apple-green)}.stat-icon-wrapper.green:before{background:var(--apple-green)}.stat-content{flex:1;min-width:0}.stat-label{font-size:13px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--sp-2)}.stat-value{font-size:40px;font-weight:900;color:var(--text-primary);line-height:1;letter-spacing:-1.5px;margin-bottom:var(--sp-2)}.stat-subtitle{font-size:13px;color:var(--text-tertiary);font-weight:500}.passes-section{background:#fffffff2;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--border-glass);border-radius:var(--radius-2xl);overflow:hidden;box-shadow:var(--shadow-soft);position:relative;z-index:1}.section-header{padding:var(--sp-6);border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;align-items:center;gap:var(--sp-4);flex-wrap:wrap}.section-title{font-size:20px;font-weight:700;color:var(--text-primary)}.section-actions{display:flex;gap:var(--sp-3);align-items:center;flex-wrap:wrap}.search-input{padding:var(--sp-2) var(--sp-4);padding-left:var(--sp-8);background:#fff9;border:1px solid var(--border-light);border-radius:var(--radius-full);font-size:14px;color:var(--text-primary);min-width:250px;transition:all var(--ease-fast)}.filter-select{padding:var(--sp-2) var(--sp-4);background:#fff9;border:1px solid var(--border-light);border-radius:var(--radius-full);font-size:14px;color:var(--text-primary);cursor:pointer;transition:all var(--ease-fast);min-width:150px}.filter-select:focus{outline:none;border-color:var(--apple-blue);box-shadow:0 0 0 4px #007aff1a;background:#fff}.passes-table-container{overflow-x:auto;border-radius:var(--radius-2xl);overflow:hidden;border:1px solid var(--border-light);background:#fff}.passes-table{width:100%;border-collapse:separate;border-spacing:0}.passes-table thead{background:#00000005;position:sticky;top:0;z-index:10}.passes-table th{padding:var(--sp-4) var(--sp-6);text-align:left;font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.6px;border-bottom:1px solid var(--border-light)}.passes-table th:first-child{border-top-left-radius:var(--radius-2xl)}.passes-table th:last-child{border-top-right-radius:var(--radius-2xl)}.passes-table td{padding:var(--sp-4) var(--sp-6);border-bottom:1px solid var(--border-light);font-size:14px;color:var(--text-primary)}.passes-table tbody tr{transition:all var(--ease-fast)}.passes-table tbody tr:hover{background:#007aff0a}.passes-table tbody tr:last-child td{border-bottom:none}.passes-table tbody tr:last-child td:first-child{border-bottom-left-radius:var(--radius-2xl)}.passes-table tbody tr:last-child td:last-child{border-bottom-right-radius:var(--radius-2xl)}.pass-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:700;letter-spacing:.3px;text-transform:uppercase}.pass-badge.apple{background:#0000000f;color:var(--text-primary)}.pass-badge.google{background:#4285f41a;color:#4285f4}.pass-type-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;background:#007aff1a;color:var(--apple-blue)}.pass-actions{display:flex;gap:var(--sp-2);align-items:center;justify-content:flex-end}.action-btn.action-generate:hover{background:var(--apple-green);color:#fff;border-color:var(--apple-green)}.btn{padding:var(--sp-3) var(--sp-6);border-radius:var(--radius-full);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--ease-base);border:none;display:inline-flex;align-items:center;gap:var(--sp-2);position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn:hover:before{width:300px;height:300px}.btn:hover{transform:scale(1.05);box-shadow:var(--shadow-medium)}.btn:active{transform:scale(.98)}.btn-primary{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;box-shadow:0 4px 12px #2563eb4d}.btn-primary:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:scale(1.05);box-shadow:0 6px 20px #2563eb80}.btn-secondary{background:#0000000d;color:var(--text-primary);border:1px solid var(--border-light)}.btn-secondary:hover{background:#00000014}.btn>*{position:relative;z-index:1}.modal,.modal-overlay{position:fixed;inset:0;background:#00000059;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--sp-6);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-dialog,.modal-panel{background:var(--glass-white-strong);backdrop-filter:var(--glass-blur-strong);-webkit-backdrop-filter:var(--glass-blur-strong);border:1px solid var(--border-glass);border-radius:var(--radius-2xl);max-width:600px;width:100%;max-height:90vh;overflow:hidden;box-shadow:var(--shadow-strong);animation:modalSlideIn .3s var(--spring);display:flex;flex-direction:column}.modal-panel-generate{max-width:640px}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{padding:var(--sp-6);border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;align-items:center}.modal-title{font-size:24px;font-weight:700;color:var(--text-primary)}.modal-close{width:32px;height:32px;border-radius:50%;border:none;background:#0000000d;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--ease-fast);font-size:20px}.modal-close:hover{background:#0000001a;transform:scale(1.1) rotate(90deg)}.modal-body{padding:var(--sp-6);overflow-y:auto;flex:1}.modal-footer{padding:var(--sp-6);border-top:1px solid var(--border-light);display:flex;gap:var(--sp-3);justify-content:flex-end}.form-group{margin-bottom:var(--sp-5)}.form-label{display:block;font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:var(--sp-2)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--sp-3) var(--sp-4);background:#fff9;border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:14px;color:var(--text-primary);font-family:inherit;transition:all var(--ease-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--apple-blue);box-shadow:0 0 0 4px #007aff1a;background:#fff}.form-input::-moz-placeholder,.form-textarea::-moz-placeholder{color:var(--text-tertiary)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-tertiary)}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background:#00000005;color:var(--text-tertiary);cursor:not-allowed}.loading-state,.empty-state{padding:var(--sp-12);text-align:center}.text-center{text-align:center}.mt-4{margin-top:var(--sp-4)}.mb-4{margin-bottom:var(--sp-4)}.form-input:disabled{background:#00000005!important;color:var(--text-secondary)!important}.form-textarea{resize:vertical;min-height:100px}.pass-actions,.action-buttons{display:flex;gap:var(--sp-2);align-items:center;justify-content:flex-end}.action-btn{width:32px;height:32px;border-radius:var(--radius-md);border:1px solid var(--border-light);background:#fff9;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--ease-fast);font-size:16px}.action-btn:hover{transform:scale(1.1);box-shadow:var(--shadow-soft)}.action-btn.action-edit:hover{background:var(--apple-blue);color:#fff;border-color:var(--apple-blue)}.action-btn.action-generate:hover,.action-btn.action-view:hover{background:var(--apple-green);color:#fff;border-color:var(--apple-green)}.action-btn.action-delete:hover{background:var(--apple-red);color:#fff;border-color:var(--apple-red)}.type-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;background:#007aff1a;color:var(--apple-blue);text-transform:capitalize}.platform-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600}.platform-apple{background:#0000000f;color:var(--text-primary)}.platform-google{background:#4285f41a;color:#4285f4}.client-id-chip{font-family:SF Mono,Fira Code,monospace;font-size:11px;font-weight:500;color:var(--apple-blue);background:#007aff0f;border:1px solid rgba(0,122,255,.15);padding:3px 8px;border-radius:6px;white-space:nowrap;display:inline-block}.date-cell{color:var(--text-secondary);font-size:13px}.empty-state{text-align:center;padding:var(--sp-12)}.empty-icon{font-size:64px;color:var(--text-tertiary);margin-bottom:var(--sp-4)}.empty-state h3{font-size:20px;font-weight:700;color:var(--text-primary);margin-bottom:var(--sp-2)}.empty-state p{color:var(--text-secondary);margin-bottom:var(--sp-6)}.loading-state{padding:var(--sp-12);text-align:center}.spinner{width:48px;height:48px;border:4px solid rgba(0,122,255,.1);border-top-color:var(--apple-blue);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto var(--sp-4)}.pass-name{font-weight:600;color:var(--text-primary)}.toolbar{display:flex;justify-content:space-between;align-items:center;gap:var(--sp-4);flex-wrap:wrap;margin-bottom:var(--sp-6)}.toolbar-left{display:flex;align-items:center;gap:var(--sp-4);flex-wrap:wrap;flex:1}.search-box{position:relative;flex:1;min-width:250px;max-width:400px}.search-icon{position:absolute;left:var(--sp-4);top:50%;transform:translateY(-50%);color:var(--text-tertiary);pointer-events:none;display:flex;align-items:center;font-size:18px}.search-input{width:100%;padding:var(--sp-3) var(--sp-4);padding-left:var(--sp-8);background:#fff9;border:1px solid var(--border-light);border-radius:var(--radius-full);font-size:14px;color:var(--text-primary);transition:all var(--ease-fast)}.search-input:focus{outline:none;border-color:var(--apple-blue);box-shadow:0 0 0 4px #007aff1a;background:#fff}.search-input::-moz-placeholder{color:var(--text-tertiary)}.search-input::placeholder{color:var(--text-tertiary)}.filter-dropdown{display:flex;align-items:center;gap:var(--sp-2)}.client-filter-select,.filter-select{padding:var(--sp-2) var(--sp-4);background:#fff9;border:1px solid var(--border-light);border-radius:var(--radius-full);font-size:14px;color:var(--text-primary);cursor:pointer;transition:all var(--ease-fast);min-width:150px}.client-filter-select:focus,.filter-select:focus{outline:none;border-color:var(--apple-blue);box-shadow:0 0 0 4px #007aff1a;background:#fff}.modal-header-info{flex:1;min-width:0}.modal-subtitle{font-size:13px;color:var(--text-secondary);margin-top:4px}.modal-pass-chips{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:var(--sp-4)}.chip{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:20px;border:1px solid var(--border-light);background:#00000005;color:var(--text-secondary)}.chip-device{color:var(--apple-blue);background:#007aff0f;border-color:#007aff26}.chip-type{color:var(--apple-green);background:#34c7590f;border-color:#34c75926}.chip-id{font-family:SF Mono,monospace;font-size:11px}.modal-section{margin-bottom:var(--sp-6)}.modal-section-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--sp-3)}.modal-section-title{font-size:12px;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.modal-section-hint{font-size:12px;color:var(--text-tertiary)}.ph-inline-grid{display:flex;flex-direction:column;gap:var(--sp-4)}.ph-inline-row{display:flex;flex-direction:column;gap:var(--sp-2)}.ph-inline-label-wrap{display:flex;justify-content:space-between;align-items:baseline}.ph-inline-label{font-size:13px;font-weight:600;color:var(--text-primary)}.ph-inline-meta{display:flex;align-items:center;gap:var(--sp-2);font-size:11px;color:var(--text-tertiary)}.ph-inline-section{font-size:11px;color:var(--text-tertiary)}.ph-row-key-chip{font-family:SF Mono,monospace;font-size:10px;padding:2px 6px;background:#0000000d;border-radius:4px;color:var(--text-secondary)}.ph-inline-input{width:100%;padding:var(--sp-3) var(--sp-4);background:#fff9;border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:14px;color:var(--text-primary);transition:all var(--ease-fast)}.ph-inline-input:focus{outline:none;border-color:var(--apple-blue);box-shadow:0 0 0 4px #007aff1a;background:#fff}.ph-loading{display:flex;align-items:center;gap:10px;padding:var(--sp-4);background:#00000005;border:1px dashed var(--border-light);border-radius:var(--radius-md);font-size:13px;color:var(--text-secondary)}.ph-empty-notice{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-4);background:#ffcc000f;border:1px solid rgba(255,204,0,.2);border-radius:var(--radius-md);font-size:13px;color:var(--text-secondary)}.spinner-sm{width:14px;height:14px;border:2px solid rgba(0,0,0,.1);border-top-color:var(--apple-blue);border-radius:50%;animation:spin .8s linear infinite}.spinner-dark{border-color:#0003;border-top-color:var(--text-primary)}.modal-error{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-4);background:#ff3b300f;border:1px solid rgba(255,59,48,.2);border-radius:var(--radius-md);color:var(--apple-red);font-size:13px;font-weight:500}.modal-result{padding:var(--sp-4);background:#34c7590f;border:1px solid rgba(52,199,89,.2);border-radius:var(--radius-lg)}.result-label{display:flex;align-items:center;gap:var(--sp-2);color:var(--apple-green);font-weight:600;font-size:14px;margin-bottom:var(--sp-3)}.result-url-row{display:flex;gap:var(--sp-2);align-items:center}.result-url-box{flex:1;padding:var(--sp-3);background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-md);overflow:hidden}.result-url-text{font-size:12px;font-family:SF Mono,monospace;color:var(--text-secondary);word-break:break-all}.btn-copy{padding:var(--sp-3) var(--sp-4);background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--ease-fast);display:flex;align-items:center;gap:var(--sp-2)}.btn-copy:hover{background:var(--apple-blue);color:#fff;border-color:var(--apple-blue)}.btn-copy.copied{background:var(--apple-green);color:#fff;border-color:var(--apple-green)}.btn-download{padding:var(--sp-3) var(--sp-4);text-decoration:none;white-space:nowrap}.email-share-section{margin-top:var(--sp-6);padding:var(--sp-4);background:#007aff0a;border:1px solid rgba(0,122,255,.1);border-radius:var(--radius-lg)}.email-share-header{display:flex;align-items:center;gap:var(--sp-2);font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:var(--sp-4)}.email-share-body{display:flex;flex-direction:column;gap:var(--sp-3)}.email-share-field{display:flex;flex-direction:column;gap:var(--sp-2)}.email-share-label{font-size:13px;font-weight:600;color:var(--text-primary)}.email-share-input{padding:var(--sp-3) var(--sp-4);background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:14px;color:var(--text-primary);transition:all var(--ease-fast)}.email-share-input:focus{outline:none;border-color:var(--apple-blue);box-shadow:0 0 0 4px #007aff1a}.email-share-hint{font-size:12px;color:var(--text-tertiary)}.email-share-success{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-3);background:#34c7591a;border-radius:var(--radius-md);color:var(--apple-green);font-size:13px;font-weight:500}.email-share-error{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-3);background:#ff3b301a;border-radius:var(--radius-md);color:var(--apple-red);font-size:13px;font-weight:500}.btn-share-email{padding:var(--sp-3) var(--sp-6);background:var(--apple-blue);color:#fff;border:none;border-radius:var(--radius-full);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--ease-fast)}.btn-share-email:hover{background:#1e40af;transform:scale(1.02)}.btn-share-email:disabled{opacity:.5;cursor:not-allowed}.btn-share-email.btn-loading{opacity:.7;cursor:wait}.btn-danger{background:var(--apple-red)!important;color:#fff!important}.btn-danger:hover{background:#e02020!important}.modal-warning{color:var(--apple-red);font-size:13px;margin-top:var(--sp-2)}@media(max-width:968px){.sidebar{width:72px;min-width:72px}.logo-section{text-align:center}.logo-img{height:28px}.nav-label,.sidebar-footer{display:none}.main-header{padding:var(--sp-6)}.page-title{font-size:28px}.main-content{padding:var(--sp-6)}}@media(max-width:768px){.sidebar{display:none}.stats-grid{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:stretch}.section-actions{flex-direction:column}.search-input,.filter-select{width:100%}}.analytics-container{padding:24px;background:var(--bg-primary);min-height:calc(100vh - 120px)}.analytics-filters{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:24px;padding:20px;background:var(--glass-white);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:16px;border:1px solid var(--border-light);box-shadow:var(--shadow-soft)}.filter-group{display:flex;flex-direction:column;gap:6px;flex:1;min-width:180px}.filter-group label{font-size:12px;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:6px;text-transform:uppercase;letter-spacing:.5px}.filter-group label svg{opacity:.7}.filter-select{padding:10px 14px;border:1px solid var(--border-light);border-radius:8px;background:#fff;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:Inter,sans-serif}.filter-select:hover{border-color:var(--apple-blue);box-shadow:0 2px 8px #2563eb1a}.filter-select:focus{outline:none;border-color:var(--apple-blue);box-shadow:0 0 0 3px #2563eb1a}.analytics-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:24px}.analytics-kpi-card{background:#fff;border-radius:16px;padding:24px;display:flex;align-items:flex-start;gap:16px;border:1px solid var(--border-light);box-shadow:var(--shadow-soft);transition:all .3s ease;position:relative;overflow:hidden}.analytics-kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;transition:all .3s ease}.analytics-kpi-card.kpi-primary:before{background:linear-gradient(90deg,#2563eb,#1d4ed8)}.analytics-kpi-card.kpi-success:before{background:linear-gradient(90deg,#10b981,#059669)}.analytics-kpi-card.kpi-accent:before{background:linear-gradient(90deg,#8b5cf6,#7c3aed)}.analytics-kpi-card:hover{transform:translateY(-4px);box-shadow:0 12px 48px #00000026}.kpi-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.kpi-primary .kpi-icon{background:linear-gradient(135deg,#2563eb1a,#2563eb0d);color:#2563eb}.kpi-success .kpi-icon{background:linear-gradient(135deg,#10b9811a,#10b9810d);color:#10b981}.kpi-accent .kpi-icon{background:linear-gradient(135deg,#8b5cf61a,#8b5cf60d);color:#8b5cf6}.kpi-content{flex:1;display:flex;flex-direction:column;gap:4px}.kpi-label{font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.kpi-value{font-size:36px;font-weight:800;color:var(--text-primary);line-height:1;margin:4px 0}.kpi-trend{font-size:12px;font-weight:600;display:flex;align-items:center;gap:4px}.kpi-trend.positive{color:#10b981}.kpi-trend.negative{color:#ef4444}.analytics-charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}.analytics-chart-card{background:#fff;border-radius:16px;padding:24px;border:1px solid var(--border-light);box-shadow:var(--shadow-soft);transition:all .3s ease}.analytics-chart-card:hover{box-shadow:var(--shadow-medium)}.chart-full-width{grid-column:1 / -1}.chart-header{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-light)}.chart-header h3{font-size:16px;font-weight:700;color:var(--text-primary);margin:0 0 4px}.chart-subtitle{font-size:13px;color:var(--text-tertiary);font-weight:500}.adoption-circle-container{display:flex;flex-direction:column;align-items:center;gap:20px}.adoption-circle{width:200px;height:200px}.adoption-stats{display:flex;gap:24px;justify-content:center;flex-wrap:wrap}.adoption-stat{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary)}.stat-dot{width:12px;height:12px;border-radius:50%}.bar-chart-modern{display:flex;flex-direction:column;gap:16px}.bar-item{display:flex;flex-direction:column;gap:6px}.bar-label-row{display:flex;justify-content:space-between;align-items:center;font-size:13px}.bar-label{font-weight:600;color:var(--text-primary)}.bar-value{font-weight:600;color:var(--text-tertiary);font-size:12px}.bar-track{height:32px;background:#f1f5f9;border-radius:8px;position:relative;overflow:hidden}.bar-fill{height:100%;border-radius:8px;transition:width .8s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:flex-end;padding-right:12px}.bar-percentage{font-size:12px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2)}.platform-distribution{display:flex;flex-direction:column;gap:20px}.platform-bar{display:flex;flex-direction:column;gap:10px}.platform-info{display:flex;align-items:center;gap:12px}.platform-icon-large{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:#f8fafc}.platform-icon-large svg{width:24px;height:24px}.platform-name{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:2px}.platform-stats-text{font-size:13px;color:var(--text-tertiary)}.platform-percentage-bar{height:40px;background:#f1f5f9;border-radius:8px;position:relative;overflow:hidden}.platform-percentage-fill{height:100%;border-radius:8px;transition:width .8s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:flex-end;padding-right:16px}.platform-percentage-text{font-size:14px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.line-chart-container{display:flex;flex-direction:column;gap:20px}.chart-legend{display:flex;gap:24px;justify-content:center}.legend-item{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text-secondary)}.legend-color{width:16px;height:16px;border-radius:4px}.line-chart{display:flex;align-items:flex-end;gap:20px;height:240px;padding:20px;background:#f8fafc;border-radius:12px}.chart-column{flex:1;display:flex;flex-direction:column;align-items:center;gap:12px;height:100%}.chart-bars{flex:1;width:100%;display:flex;gap:8px;align-items:flex-end;justify-content:center}.chart-bar{flex:1;min-width:0;border-radius:6px 6px 0 0;transition:all .3s ease;position:relative;display:flex;align-items:flex-start;justify-content:center;padding-top:8px}.chart-bar-label{font-size:11px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);background:#00000026;padding:2px 6px;border-radius:4px;white-space:nowrap}.chart-bar.issued{background:linear-gradient(180deg,#2563eb,#1d4ed8)}.chart-bar.downloaded{background:linear-gradient(180deg,#10b981,#059669)}.chart-bar:hover{opacity:.8;transform:translateY(-4px)}.chart-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-align:center}@media(max-width:1024px){.analytics-kpi-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.analytics-charts-grid{grid-template-columns:1fr}}@media(max-width:768px){.analytics-filters{flex-direction:column}.filter-group{min-width:100%}.analytics-kpi-grid{grid-template-columns:1fr}.kpi-value{font-size:28px}.line-chart{padding:12px}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%}:root{--color-navy: #2563EB;--color-navy-dark: #1d4ed8;--bg-primary: #F8FAFC;--bg-surface: #FFFFFF;--border: #e5e7eb;--text-primary: #0F172A;--text-secondary: #475569;--text-muted: #9ca3af;--text-inverse: #ffffff}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);font-size:14px;-webkit-font-smoothing:antialiased}.app{height:100%}.pass-configurator{display:flex;flex-direction:column;height:100vh;overflow:hidden}.configurator-topbar{height:64px;background:#1e2a4ae6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;align-items:center;padding:0 24px;gap:16px;flex-shrink:0;z-index:100;border-bottom:1px solid rgba(255,255,255,.15);box-shadow:0 4px 24px #0000004d}.topbar-logo{height:48px;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 0 10px rgba(0,229,255,.3))}.topbar-title{font-size:16px;font-weight:600;color:var(--text-primary);font-family:Space Grotesk,sans-serif}.configurator-topbar{height:64px;background:#0f172a;display:flex;align-items:center;padding:0 24px;gap:16px;box-shadow:0 2px 8px #0000001a}.topbar-logo{height:48px;-o-object-fit:contain;object-fit:contain}.topbar-divider{width:1px;height:24px;background:#fff3}.topbar-title{font-size:16px;font-weight:600;color:var(--text-inverse)}.topbar-meta{background:#ffffff26;border:1px solid rgba(255,255,255,.2);color:var(--text-inverse);font-size:11px;font-weight:700;padding:4px 12px;border-radius:20px;font-family:monospace}.topbar-back{margin-left:auto;display:flex;align-items:center;gap:8px;color:#fffc;font-size:13px;text-decoration:none;padding:8px 16px;border-radius:8px;border:1px solid rgba(255,255,255,.2);transition:all .2s}.topbar-back:hover{color:var(--text-inverse);background:#ffffff1a;border-color:#ffffff4d}.configurator-container{display:flex;flex:1;overflow:hidden;min-height:0}.config-panel{width:56%;min-width:480px;background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.config-header{padding:24px 28px 0}.config-header h1{font-size:22px;font-weight:700;color:var(--text-primary)}.config-header p{font-size:13px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-top:4px}.tabs-container{display:flex;flex-direction:column;flex:1;overflow:hidden}.tabs-header{display:flex;padding:20px 32px 0;border-bottom:1px solid var(--border);flex-shrink:0;gap:4px}.tab-button{display:flex;align-items:center;gap:8px;padding:12px 18px;background:none;border:none;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .3s;font-family:Inter,sans-serif;border-radius:8px 8px 0 0}.tab-button:hover{color:var(--text-primary);background:#f3f4f6}.tab-button.active{color:var(--color-navy);border-bottom-color:var(--color-navy);font-weight:600}.tab-icon{display:flex;align-items:center}.tab-label{white-space:nowrap}.tabs-content{flex:1;overflow-y:auto}.tabs-content::-webkit-scrollbar{width:6px}.tabs-content::-webkit-scrollbar-track{background:#ffffff0d}.tabs-content::-webkit-scrollbar-thumb{background:#00e5ff4d;border-radius:3px}.tabs-content::-webkit-scrollbar-thumb:hover{background:#00e5ff80}.tab-content{padding:24px 32px}.tab-description{background:linear-gradient(135deg,#00e5ff1a,#7c4dff1a);border-left:3px solid #00e5ff;padding:12px 16px;border-radius:0 8px 8px 0;margin-bottom:24px;font-size:13px;color:var(--text-secondary);box-shadow:0 0 20px #00e5ff1a}.info-section,.fields-section,.design-section,.image-section{background:#ffffffb3;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);border-radius:12px;padding:20px 24px;margin-bottom:20px;box-shadow:0 8px 32px #0000001a,inset 0 1px #ffffffe6}.section-header h3{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--color-navy)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.form-row:last-child{margin-bottom:0}.form-group{display:flex;flex-direction:column;gap:6px}.form-group.full-width{grid-column:1 / -1}.form-group label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-secondary);font-family:Space Grotesk,sans-serif}.form-group input,.form-group select,.form-group textarea{padding:10px 14px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:Inter,sans-serif;color:var(--text-primary);background:var(--bg-surface);transition:all .2s;outline:none}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-navy);box-shadow:0 0 0 3px #2e3a871a}.form-group input:disabled,.form-group select:disabled{background:#f3f4f6;color:#6b7280;cursor:not-allowed;border-color:#e5e7eb}.form-group small{font-size:11px;color:var(--text-muted)}.form-group.checkbox{flex-direction:row;align-items:flex-start;gap:12px}.form-group.checkbox label{display:flex;align-items:center;gap:8px;text-transform:none;letter-spacing:0;font-weight:500;font-size:13px;color:#1e293b;cursor:pointer}.form-group.checkbox input[type=checkbox]{width:16px;height:16px;accent-color:#1e40af;flex-shrink:0;padding:0}.field-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.field-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:12px;margin-bottom:10px}.field-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.field-index{font-size:11px;font-weight:700;color:#94a3b8;background:#e2e8f0;padding:2px 7px;border-radius:4px}.images-sections{display:flex;flex-direction:column;gap:16px}.image-count{font-size:11px;color:#94a3b8;background:#f1f5f9;padding:2px 7px;border-radius:10px}.images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:10px;margin-top:8px}.image-item{border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;background:#f8fafc}.image-preview{height:70px;display:flex;align-items:center;justify-content:center;background:#f1f5f9}.image-preview img{max-width:100%;max-height:100%;-o-object-fit:contain;object-fit:contain}.image-info{padding:6px 8px;display:flex;align-items:center;justify-content:space-between;gap:4px}.image-name{font-size:10px;color:#64748b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.image-upload .upload-label{cursor:pointer;display:block}.upload-box{height:90px;border:2px dashed #e2e8f0;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:#94a3b8;font-size:11px;transition:all .15s}.upload-box:hover{border-color:#3b82f6;color:#3b82f6;background:#eff6ff}.colors-list{display:flex;flex-direction:column;gap:10px;margin-top:8px}.color-item{display:flex;align-items:center;gap:12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:10px 12px}.color-swatch-wrap{position:relative;width:36px;height:36px;cursor:pointer;flex-shrink:0}.color-native-picker{position:absolute;inset:0;opacity:0;width:100%;height:100%;cursor:pointer;border:none;padding:0}.color-swatch{width:36px;height:36px;border-radius:7px;border:1px solid rgba(0,0,0,.1);pointer-events:none}.color-meta{display:flex;flex-direction:column;gap:3px;flex:1}.color-type-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#64748b}.color-hex-input{font-size:12px;color:#1e293b;background:transparent;border:none;outline:none;font-family:SF Mono,monospace;padding:0;width:80px}.barcode-config{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap;margin-top:8px}.no-barcode{margin-top:8px}.review-sections{margin-bottom:20px}.review-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:18px 20px;margin-bottom:16px}.review-section h3{font-size:13px;font-weight:600;color:#1e293b;margin-bottom:12px}.review-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.review-item{display:flex;flex-direction:column;gap:2px}.review-item .label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:#94a3b8;font-weight:600}.review-item .value{font-size:13px;font-weight:600;color:#1e293b}.review-item .value.badge{display:inline-flex;align-items:center;justify-content:center;background:#eff6ff;color:#1e40af;border-radius:4px;padding:2px 8px;font-size:12px}.review-actions{margin-top:20px}.tabs-footer{display:flex;justify-content:flex-end;align-items:center;gap:10px;padding:14px 28px;border-top:1px solid #e2e8f0;background:#fff;flex-shrink:0}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:7px;font-size:13px;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;border:none;transition:all .15s}.btn-primary{background:#1e40af;color:#fff;padding:12px 28px;font-size:14px;border-radius:8px;width:100%;justify-content:center;border:none;cursor:pointer;font-family:Inter,sans-serif;font-weight:600;transition:background .15s;display:flex;align-items:center}.btn-primary:hover{background:#1d4ed8}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;padding:9px 18px;border-radius:7px;font-size:13px;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;transition:all .15s}.btn-secondary:hover{background:#e2e8f0}.btn-add{background:#eff6ff;color:#1e40af;border:1px solid #bfdbfe;padding:5px 12px;border-radius:6px;font-size:12px;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;transition:all .15s}.btn-add:hover{background:#dbeafe}.btn-delete{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;transition:all .15s}.btn-delete:hover{background:#fee2e2}.btn-icon-delete{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;background:#fef2f2;color:#dc2626;border:1px solid #fecaca;cursor:pointer;transition:all .15s;flex-shrink:0}.btn-icon-delete:hover{background:#fee2e2}.alert{display:flex;align-items:center;gap:10px;padding:11px 16px;border-radius:8px;font-size:13px;margin-bottom:14px}.alert-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.preview-panel{flex:1;background:#f8fafc;display:flex;flex-direction:column;overflow:hidden}.preview-header{padding:16px 20px;background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0}.preview-header-row{display:flex;align-items:center;justify-content:space-between}.preview-header h2{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:#64748b}.device-selector{display:flex;gap:6px}.device-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:7px;font-size:12px;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;border:1px solid #e2e8f0;background:#f1f5f9;color:#64748b;transition:all .15s}.device-btn:hover{background:#e2e8f0;color:#1e293b}.device-btn.active{background:#1e40af;color:#fff;border-color:#1e40af}.preview-scroll{flex:1;overflow-y:auto;display:flex;justify-content:center;align-items:flex-start;padding:24px 16px}.preview-scroll::-webkit-scrollbar{width:4px}.preview-scroll::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:2px}.preview-scroll.pass-preview-empty{align-items:center}.preview-placeholder{display:flex;flex-direction:column;align-items:center;gap:12px;color:#94a3b8;text-align:center;padding:60px 20px}.preview-placeholder svg{color:#c7d2fe}.preview-placeholder p{font-size:13px;font-weight:500}.phone-wrapper{display:inline-flex;position:relative;flex-shrink:0}.phone-wrapper.iphone-wrapper:before{content:"";position:absolute;left:-3px;top:100px;width:3px;height:26px;background:#3a3a3c;border-radius:2px 0 0 2px;box-shadow:0 38px #3a3a3c,0 72px #3a3a3c;z-index:2}.phone-wrapper.iphone-wrapper:after{content:"";position:absolute;right:-3px;top:130px;width:3px;height:52px;background:#3a3a3c;border-radius:0 2px 2px 0;z-index:2}.phone-frame.iphone{width:290px;height:600px;background:#131416;border-radius:46px;box-shadow:0 0 0 1px #2f3135,0 0 0 3px #050507,0 24px 70px #0000008c,inset 0 0 0 1px #ffffff14;display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.iphone-notch{width:90px;height:26px;background:#000;border-radius:0 0 18px 18px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:8px;flex-shrink:0}.notch-speaker{width:32px;height:4px;background:#1c1c1e;border-radius:2px}.notch-camera{width:9px;height:9px;background:#111;border-radius:50%;border:1.5px solid #2a2a2a}.phone-status-bar{display:flex;justify-content:space-between;align-items:center;padding:3px 16px;font-size:11px;font-weight:700;color:#000;height:24px;flex-shrink:0;background:#fff}.status-icons{display:flex;align-items:center;gap:4px;color:#000}.wallet-app-header{display:flex;justify-content:space-between;align-items:center;padding:4px 18px 10px;background:#fff;flex-shrink:0;border-bottom:1px solid rgba(0,0,0,.06)}.wallet-back{color:#007aff;font-size:13px}.wallet-title{color:#000;font-weight:700;font-size:18px}.wallet-more{color:#007aff;font-size:15px;letter-spacing:2px}.iphone-screen-scroll{flex:1;background:#f2f2f7;display:flex;flex-direction:column;align-items:stretch;padding:0 14px 12px;overflow:hidden}.android-screen-scroll{flex:1;background:#f2f2f7;display:flex;flex-direction:column;align-items:stretch;overflow-y:auto;min-height:0}.iphone-home-indicator{width:80px;height:4px;background:#0000002e;border-radius:3px;margin:6px auto 5px;flex-shrink:0}.phone-frame.android{width:260px;height:563px;background:#1a1a1a;border-radius:34px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 0 0 1px #333,0 24px 60px #00000073;flex-shrink:0}.phone-status-bar.android-status{background:#1a1a1a;color:#fff;padding:5px 14px;font-size:11px;height:24px;display:flex;align-items:center}.gpay-header{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;background:#1a1a1a;color:#fff;font-weight:600;font-size:13px;flex-shrink:0}.android-screen-scroll{flex:1;background:#f2f2f7;display:flex;flex-direction:column;overflow-y:auto;min-height:0}.android-screen-scroll::-webkit-scrollbar{display:none}.android-nav-bar{height:20px;background:#1a1a1a;display:flex;align-items:center;justify-content:center;flex-shrink:0}.nav-pill{width:72px;height:4px;background:#ffffff4d;border-radius:2px}.aw-pass{margin:14px 0 0;border-radius:18px;overflow:hidden;display:flex;flex-direction:column;font-family:-apple-system,SF Pro Display,Helvetica Neue,sans-serif;box-shadow:0 8px 24px #00000059;border:1px solid rgba(255,255,255,.15);background:linear-gradient(145deg,#d4d4d8,#a5adb8);color:#0f172a;--aw-label-color: rgba(15,23,42,.65);flex:1;min-height:320px}.aw-header{padding:14px 16px 10px;display:flex;align-items:flex-start;justify-content:space-between}.aw-logo-wrap{display:flex;align-items:center;gap:6px;overflow:hidden;max-width:58%}.aw-logo-img{height:28px;max-width:120px;-o-object-fit:contain;object-fit:contain;flex-shrink:0}.aw-logo-text{font-size:17px;font-weight:800;letter-spacing:-.4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.aw-header-fields{display:flex;gap:8px;overflow:visible;flex-shrink:0;max-width:45%;justify-content:flex-end}.aw-hfield{text-align:right;min-width:0;overflow:visible}.aw-hfield-value{font-size:13px;font-weight:600;white-space:normal;word-break:break-word;display:block}.aw-field-label{font-size:8px;text-transform:uppercase;letter-spacing:.6px;font-weight:700;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;color:var(--aw-label-color, rgba(0,0,0,.55))}.aw-field-value{font-size:11px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.aw-aux-value{font-size:10px}.aw-secondary-row{display:flex;flex-wrap:nowrap;overflow:hidden;padding:8px 16px;width:100%;box-sizing:border-box;border-top:1px solid rgba(0,0,0,.08)}.aw-aux-row{display:flex;flex-wrap:nowrap;overflow:hidden;padding:6px 16px;width:100%;box-sizing:border-box;border-top:1px solid rgba(0,0,0,.06)}.aw-field-cell{flex:1 1 0;min-width:0;width:0;overflow:hidden;padding-right:6px}.aw-field-cell:last-child{padding-right:0}.aw-generic-primary{display:flex;align-items:flex-start;justify-content:space-between;padding:10px 16px 8px;gap:8px;overflow:hidden}.aw-primary-fields{flex:1;min-width:0;overflow:hidden}.aw-primary-field{min-width:0;overflow:hidden}.aw-primary-value{font-size:19px;font-weight:400;letter-spacing:-.3px;line-height:1.3;white-space:normal;word-break:break-word;display:block}.aw-thumbnail{width:50px;height:50px;border-radius:8px;overflow:hidden;flex-shrink:0}.aw-thumbnail img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.aw-strip{width:100%;height:84px;overflow:hidden;flex-shrink:0}.aw-strip img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.aw-strip-placeholder{background:#ffffff1a}.aw-strip-primary{padding:8px 12px 4px;overflow:hidden}.aw-event-primary{display:flex;align-items:flex-start;padding:8px 12px 6px;gap:8px;overflow:hidden}.aw-event{position:relative;overflow:hidden}.aw-event-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.5) saturate(1.2);z-index:0}.aw-event-overlay{position:relative;z-index:1}.aw-boarding-primary{display:flex;align-items:center;justify-content:space-between;padding:10px 12px 8px;overflow:hidden}.aw-boarding-city{flex:1;min-width:0}.aw-boarding-right{text-align:right}.aw-boarding-code{font-size:22px;font-weight:800;letter-spacing:-1px;line-height:1;margin-bottom:2px;white-space:nowrap}.aw-boarding-transit{flex-shrink:0;text-align:center;padding:0 8px}.aw-transit-icon{font-size:18px}.aw-footer-img{padding:0 12px;height:24px;overflow:hidden}.aw-footer-img img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.aw-boarding-sep{height:1px;margin:4px 12px;background:repeating-linear-gradient(to right,rgba(255,255,255,.15) 0,rgba(255,255,255,.15) 5px,transparent 5px,transparent 10px)}.aw-barcode-wrap{border-top:1px solid rgba(255,255,255,.12);border-radius:0 0 18px 18px;padding:10px 8px 8px;display:flex;flex-direction:column;align-items:center;gap:4px}.aw-barcode-inner{display:flex;flex-direction:column;align-items:center;gap:3px}.aw-barcode-alt{font-size:8px;color:#1c1c1e;font-family:SF Mono,monospace;letter-spacing:1px}.google-pass-wrapper{padding:10px}.google-pass-card{border-radius:14px;overflow:hidden;box-shadow:0 4px 18px #0003;display:flex;flex-direction:column;width:100%}.google-pass-header-bar{display:flex;align-items:center;gap:8px;padding:10px 12px}.google-pass-logo{width:26px;height:26px;border-radius:6px;-o-object-fit:contain;object-fit:contain;flex-shrink:0}.google-pass-issuer{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.google-pass-title-area{padding:6px 12px 8px}.google-pass-title{font-size:14px;font-weight:700;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.google-pass-subtitle{font-size:11px;opacity:.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.google-hero-img{width:100%;height:78px;-o-object-fit:cover;object-fit:cover;display:block}.google-pass-fields-section{padding:4px 12px}.google-field-row{display:flex;justify-content:space-between;align-items:baseline;padding:4px 0;border-bottom:1px solid rgba(255,255,255,.08);overflow:hidden}.google-field-label{font-size:10px;opacity:.6;white-space:nowrap;flex-shrink:0;margin-right:8px}.google-field-value{font-size:11px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:right;min-width:0}.google-pass-divider{height:1px;background:#ffffff1a;margin:2px 0}.google-pass-barcode{background:#fff;padding:8px;display:flex;flex-direction:column;align-items:center;gap:3px}.barcode-alt-text{font-size:8px;color:#1c1c1e;letter-spacing:1px}.barcode-placeholder{background:#fff;border-radius:8px;padding:8px 12px;border:1px solid rgba(0,0,0,.08)}.barcode-placeholder svg{width:100%;height:auto;display:block}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#cbd5e1}@media(max-width:900px){.config-panel{min-width:100%;width:100%}.preview-panel{display:none}.form-row,.field-row{grid-template-columns:1fr}.tab-label{display:none}}:root{--apple-blue: #2563EB;--apple-pink: #FF2D55;--apple-green: #34C759;--gradient-dawn: linear-gradient(135deg, #2563EB 0%, #1d4ed8 50%, #1e40af 100%);--glass-white: rgba(255, 255, 255, .75);--glass-white-strong: rgba(255, 255, 255, .95);--glass-blur: blur(24px);--glass-blur-strong: blur(40px);--bg-primary: #F8FAFC;--text-primary: #0F172A;--text-secondary: #475569;--text-tertiary: #94a3b8;--border-light: rgba(0, 0, 0, .06);--border-glass: rgba(255, 255, 255, .2);--shadow-soft: 0 8px 32px rgba(0, 0, 0, .08);--shadow-medium: 0 12px 48px rgba(0, 0, 0, .12);--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-6: 24px;--sp-8: 32px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 28px;--radius-full: 9999px;--ease-base: .25s cubic-bezier(.4, 0, .2, 1)}.configurator-topbar{background:var(--glass-white)!important;backdrop-filter:var(--glass-blur)!important;-webkit-backdrop-filter:var(--glass-blur)!important;border-bottom:1px solid var(--border-light)!important;box-shadow:var(--shadow-soft)!important}.topbar-title{font-size:24px!important;font-weight:800!important;color:#0f172a!important}.topbar-meta{background:#2563eb1a!important;border:1px solid rgba(37,99,235,.2)!important;color:var(--apple-blue)!important}.topbar-back{background:#fff9!important;border:1px solid var(--border-light)!important;color:var(--text-primary)!important;backdrop-filter:blur(12px)!important;-webkit-backdrop-filter:blur(12px)!important}.topbar-back:hover{background:var(--apple-blue)!important;color:#fff!important;border-color:var(--apple-blue)!important;transform:scale(1.05)}.topbar-divider{background:var(--border-light)!important}.topbar-logo{display:none!important}.configurator-topbar:before{content:"PASSREXX";font-family:Orbitron,monospace;font-size:32px;font-weight:900;letter-spacing:2px;background:linear-gradient(135deg,#2563eb,#1d4ed8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-right:var(--sp-4)}.pass-configurator{display:flex!important;flex-direction:column!important;height:100vh!important;max-height:100vh!important;overflow:hidden!important}.configurator-topbar{flex-shrink:0!important;height:64px!important}.configurator-container{flex:1!important;display:flex!important;flex-direction:row!important;min-height:0!important;overflow:hidden!important}.config-panel{display:flex!important;flex-direction:column!important;overflow:hidden!important}.config-header{flex-shrink:0!important}.tabs-container{display:flex!important;flex-direction:column!important;flex:1!important;min-height:0!important;overflow:hidden!important}.tabs-header{flex-shrink:0!important}.tabs-content{flex:1!important;overflow-y:auto!important;overflow-x:hidden!important;min-height:0!important}.tab-content{padding:24px!important;min-height:auto!important}.tabs-footer{position:sticky!important;bottom:0!important;left:0!important;right:0!important;z-index:999!important;background:#fffffff2!important;backdrop-filter:blur(24px)!important;-webkit-backdrop-filter:blur(24px)!important;border-top:1px solid var(--border-light)!important;padding:20px 28px!important;display:flex!important;justify-content:space-between!important;align-items:center!important;gap:12px!important;flex-shrink:0!important;margin:0!important;box-shadow:0 -4px 24px #00000014!important}.tabs-footer .btn{flex-shrink:0!important;min-width:120px!important}.app{min-height:100vh;background:var(--bg-primary)}.configurator-container,.pass-configurator{min-height:100vh;background:var(--bg-primary);position:relative;display:flex!important;flex-direction:column!important;height:100vh!important;overflow:hidden!important}.preview-panel .preview-body,.preview-panel .preview-scroll{flex:1!important;overflow-y:auto!important}.config-panel,.preview-panel,.tabs-container{background:var(--glass-white);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--border-glass);border-radius:var(--radius-2xl);box-shadow:var(--shadow-soft);transition:all var(--ease-base)}.config-panel:hover,.preview-panel:hover{transform:translateY(-4px);box-shadow:var(--shadow-medium)}.tab-description{background:linear-gradient(135deg,#007aff1a,#0051d51a)!important;border-left:3px solid var(--apple-blue)!important;box-shadow:0 0 20px #007aff26!important}.tabs-nav,.tab-group{display:flex;gap:var(--sp-2);padding:var(--sp-4);background:#00000005;border-radius:var(--radius-lg);margin-bottom:var(--sp-6)}.tab-button,.tab{flex:1;padding:var(--sp-3);background:transparent;border:none;border-radius:var(--radius-md);font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--ease-base);font-size:14px}.tab-button.active,.tab.active{background:#fff;color:var(--text-primary);box-shadow:var(--shadow-soft)}.tab-button:hover:not(.active){color:var(--apple-blue)}.device-selector{display:flex;gap:var(--sp-2)}.device-btn{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);background:#fff9;border:1px solid var(--border-light);border-radius:var(--radius-full);font-size:13px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--ease-base)}.device-btn:hover{background:#007aff14;border-color:var(--apple-blue);color:var(--apple-blue)}.device-btn.active{background:var(--gradient-dawn);color:#fff;border-color:transparent;box-shadow:0 4px 16px #007aff66}.preview-header{padding:var(--sp-6);border-bottom:1px solid var(--border-light);background:#00000005}.preview-header-row{display:flex;justify-content:space-between;align-items:center}.preview-header h2{font-size:18px;font-weight:700;color:var(--text-primary)}.tabs-footer{display:flex;justify-content:space-between;gap:var(--sp-3);padding:var(--sp-6);border-top:1px solid var(--border-light);background:var(--glass-white)!important;backdrop-filter:var(--glass-blur)!important;-webkit-backdrop-filter:var(--glass-blur)!important;position:sticky!important;bottom:0!important;z-index:10!important;margin-top:auto!important;flex-shrink:0!important}.tabs-container{display:flex;flex-direction:column;height:100%;overflow:hidden}.tab-content-wrapper{flex:1;overflow-y:auto;padding:var(--sp-6)}.configurator-main{flex:1!important;display:flex!important;overflow:hidden!important}.tabs-wrapper{flex:1!important;display:flex!important;flex-direction:column!important;overflow:hidden!important}.tab-content{flex:1!important;overflow-y:auto!important;padding:var(--sp-6)!important}.form-input,.form-select,.form-textarea,input[type=text],input[type=email],input[type=number],input[type=url],select,textarea{background:#fff9!important;border:1px solid var(--border-light)!important;border-radius:var(--radius-md)!important;padding:var(--sp-3) var(--sp-4)!important;transition:all .2s!important;font-family:inherit!important}input:focus,select:focus,textarea:focus{outline:none!important;border-color:var(--apple-blue)!important;box-shadow:0 0 0 4px #007aff1a!important;background:#fff!important}input:disabled,select:disabled{background:#00000005!important;color:var(--text-secondary)!important}.btn{padding:var(--sp-3) var(--sp-6);border-radius:var(--radius-full);font-weight:600;cursor:pointer;transition:all var(--ease-base);border:none;font-size:14px;display:inline-flex;align-items:center;gap:var(--sp-2);width:auto!important;min-width:auto!important}.btn-primary{background:linear-gradient(135deg,#2563eb,#1d4ed8)!important;color:#fff!important;box-shadow:0 4px 12px #2563eb4d;width:auto!important;min-width:120px!important;justify-content:center!important}.btn-primary:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af)!important;transform:scale(1.05);box-shadow:0 6px 20px #2563eb80}.btn-secondary{background:#0000000d!important;color:var(--text-primary)!important;border:1px solid var(--border-light)}.btn-secondary:hover{background:#00000014!important}.color-swatch,.color-picker-swatch{border-radius:var(--radius-md);border:2px solid var(--border-light);transition:all .2s;cursor:pointer}.color-swatch:hover,.color-picker-swatch:hover{transform:scale(1.1);box-shadow:var(--shadow-soft)}.image-upload-area,.upload-zone{border:2px dashed var(--border-light);border-radius:var(--radius-lg);padding:var(--sp-6);background:#00000003;transition:all .2s;cursor:pointer;text-align:center}.image-upload-area:hover,.upload-zone:hover{border-color:var(--apple-blue);background:#007aff05}.field-item,.config-field,.text-field-item{background:#00000005;border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--sp-4);transition:all .2s;margin-bottom:var(--sp-3)}.field-item:hover,.config-field:hover,.text-field-item:hover{border-color:var(--apple-blue);box-shadow:var(--shadow-soft)}.field-actions{display:flex;gap:var(--sp-2);align-items:center}.add-field-btn,.add-btn{width:100%;padding:var(--sp-3);background:#007aff14;border:1px dashed var(--apple-blue);border-radius:var(--radius-lg);color:var(--apple-blue);font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:var(--sp-2)}.add-field-btn:hover,.add-btn:hover{background:#007aff1f;transform:scale(1.02)}.remove-field-btn,.remove-btn{width:28px;height:28px;border-radius:50%;border:none;background:#ff3b301a;color:var(--apple-red);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.remove-field-btn:hover,.remove-btn:hover{background:var(--apple-red);color:#fff;transform:scale(1.1)}.modal{background:#00000059;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.modal-dialog,.modal-content{background:var(--glass-white-strong)!important;backdrop-filter:var(--glass-blur-strong);-webkit-backdrop-filter:var(--glass-blur-strong);border:1px solid var(--border-glass);border-radius:var(--radius-2xl);box-shadow:0 20px 60px #00000029}.form-label,label{font-weight:600;color:var(--text-primary);font-size:13px;margin-bottom:var(--sp-2);display:block}.section-title,.panel-title,h1,h2,h3{font-weight:700;color:var(--text-primary)}.page-title{background:var(--gradient-dawn);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#0003;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#0000004d}.spinner{border:4px solid rgba(0,122,255,.1);border-top-color:var(--apple-blue);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(min-width:901px){.configurator-container{flex-direction:row!important;flex-wrap:nowrap!important}.config-panel{flex:0 0 56%!important;width:56%!important;max-width:56%!important;min-width:480px!important}.preview-panel{flex:1!important;width:44%!important;max-width:44%!important;display:flex!important}}@media(max-width:900px){.configurator-container{flex-direction:column!important}.config-panel{width:100%!important;max-width:100%!important;min-width:100%!important;flex:0 0 auto!important}.preview-panel{display:none!important}.tabs-footer{flex-direction:row!important;justify-content:space-between!important}.device-selector{flex-direction:row!important}.form-row{grid-template-columns:1fr!important}}@media(max-width:768px){.config-panel,.preview-panel{padding:var(--sp-4)}.tabs-footer{padding:var(--sp-4)!important}}.designer-page{padding:40px;text-align:center}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-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:#f8fafc;color:#0f172a}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}
