@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";*{box-sizing:border-box}:root{--gp-brand-50: #dedee0;--gp-brand-100: #c8c9cb;--gp-brand-200: #a7a8ac;--gp-brand-300: #85888d;--gp-brand-400: #595c64;--gp-brand-500: #222630;--gp-brand-600: #1d2029;--gp-brand-700: #181b22;--gp-brand-800: #13151a;--gp-brand-900: #0e0f13;--gp-bg: #fdfdfc;--gp-surface: #DFD8F7;--gp-bg-dark: #1f2126;--gp-surface-dark: #383c46;--gp-text: #222630;--gp-text-inverse: #fdfdfc;--gp-accent: #DFD8F7;--gp-accent-700: #9c97ad;--gp-danger: #d23f31;--gp-danger-400: #ee5f4f;--gp-info: #2563eb;--gp-success: #198754;--gp-warning: #a16207;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:var(--gp-text);background-color:var(--gp-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}@media (prefers-color-scheme: dark){:root{--gp-bg: var(--gp-bg-dark);--gp-surface: var(--gp-surface-dark)}}body{margin:0;padding:0;min-width:320px;min-height:100vh;font-family:inherit}*:focus{outline:2px solid var(--gp-brand-500);outline-offset:2px}button{font-family:inherit;font-size:inherit;border:none;background:none;cursor:pointer}img{max-width:100%;height:auto;display:block}::selection{background-color:var(--gp-brand-500);color:var(--gp-text-inverse)}@media (prefers-reduced-motion: no-preference){html{scroll-behavior:smooth}}#root{width:100%;margin:0;padding:0;min-height:100vh}.home-page-container{min-height:100vh;background:linear-gradient(135deg,var(--gp-brand-500) 0%,var(--gp-brand-700) 100%);display:flex;align-items:center;justify-content:center;padding:20px}.home-content{background:var(--gp-bg);border-radius:20px;padding:3rem;max-width:800px;width:100%;box-shadow:0 20px 40px #0000001a;text-align:center}.home-header{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:2.5rem}.home-logo-icon{width:64px;height:64px}.home-brand-name{font-size:2.5rem;font-weight:700;color:var(--gp-brand-800);margin:0}.home-brand-tagline{font-size:1.1rem;color:var(--gp-brand-400);margin:.25rem 0 0}.home-welcome{margin-bottom:3rem}.welcome-title{font-size:2rem;font-weight:600;color:var(--gp-brand-800);margin-bottom:1rem}.welcome-description{font-size:1.1rem;color:var(--gp-brand-400);line-height:1.6;max-width:600px;margin:0 auto}.home-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:3rem}.feature-item{padding:1.5rem;border-radius:16px;background:var(--gp-surface);border:1px solid var(--gp-brand-200);transition:transform .2s ease,box-shadow .2s ease}.feature-item:hover{transform:translateY(-2px);box-shadow:0 10px 20px #0000001a}.feature-icon{width:48px;height:48px;color:var(--gp-brand-500);margin:0 auto 1rem}.feature-title{font-size:1.25rem;font-weight:600;color:var(--gp-brand-800);margin-bottom:.5rem}.feature-description{font-size:.9rem;color:var(--gp-brand-400);line-height:1.5;margin:0}.home-demo{padding:2rem;background:var(--gp-accent);border-radius:16px;border:2px dashed var(--gp-accent-700)}.demo-title{font-size:1.25rem;font-weight:600;color:var(--gp-brand-600);margin-bottom:1rem}.demo-links{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.demo-link{display:inline-block;padding:.75rem 1.5rem;background:var(--gp-brand-500);color:var(--gp-text-inverse);text-decoration:none;border-radius:8px;font-weight:500;transition:background-color .2s ease,transform .2s ease}.demo-link:hover{background:var(--gp-brand-600);transform:translateY(-1px)}.demo-link:active{transform:translateY(0)}@media (max-width: 768px){.home-content{padding:2rem}.home-header{flex-direction:column;text-align:center}.home-brand-name{font-size:2rem}.welcome-title{font-size:1.5rem}.home-features{grid-template-columns:1fr;gap:1rem}.feature-item{padding:1rem}.demo-links{flex-direction:column;align-items:center}.demo-link{width:200px;text-align:center}}@media (max-width: 480px){.home-page-container{padding:10px}.home-content{padding:1.5rem}.home-brand-name{font-size:1.75rem}.welcome-title{font-size:1.25rem}.welcome-description{font-size:1rem}}.qr-pass-container{min-height:100vh;background:linear-gradient(135deg,var(--gp-brand-100) 0%,var(--gp-brand-200) 100%);padding:20px;display:flex;align-items:center;justify-content:center;font-family:Inter,system-ui,-apple-system,sans-serif}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:24px}.loading-spinner{width:48px;height:48px;border:4px solid var(--gp-brand-200);border-top:4px solid var(--gp-brand-500);border-radius:50%;animation:spin 1s linear infinite}.loading-text{font-size:18px;font-weight:500;color:var(--gp-brand-400);margin:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.qr-pass-card{background:var(--gp-bg);border-radius:20px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:400px;width:100%;overflow:hidden;animation:slideUp .6s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.company-header{text-align:center;padding:32px 24px 24px;background:linear-gradient(135deg,var(--gp-brand-500) 0%,var(--gp-brand-700) 100%);color:var(--gp-text-inverse);position:relative}.company-logo-container{margin-bottom:16px}.company-logo{width:64px;height:64px;border-radius:12px;border:3px solid rgba(255,255,255,.2);background:var(--gp-bg);padding:8px;object-fit:contain}.company-name{font-size:28px;font-weight:700;margin:0 0 4px;line-height:1.2}.access-pass-subtitle{font-size:14px;margin:0;opacity:.9;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.qr-section{padding:32px 24px;text-align:center;background:var(--gp-accent);border-bottom:1px solid var(--gp-brand-200)}.qr-code-container{display:flex;justify-content:center;margin-bottom:16px}.qr-code-placeholder{width:200px;height:200px;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a;background:var(--gp-bg)}.qr-code-svg{width:100%;height:100%}.qr-code-text{font-size:12px;color:var(--gp-brand-400);margin:0;font-family:Courier New,monospace;letter-spacing:.5px}.access-info{padding:24px;background:var(--gp-bg);border-bottom:1px solid var(--gp-brand-200)}.info-item{display:flex;flex-direction:column;gap:4px;margin-bottom:20px}.info-item:last-child{margin-bottom:0}.info-label{font-size:14px;font-weight:600;color:var(--gp-brand-50);text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:18px;font-weight:600;color:var(--gp-brand-200)}.access-count{color:var(--gp-success)}.expiration-info{display:flex;flex-direction:column;gap:4px}.info-value.warning{color:var(--gp-warning)}.info-value.expired{color:var(--gp-danger)}.days-remaining{font-size:14px;color:var(--gp-brand-400);font-weight:500}.wallet-buttons{padding:24px;background:var(--gp-bg);display:flex;flex-direction:column;gap:12px}.wallet-button{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 24px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none;min-height:56px}.wallet-button:hover{transform:translateY(-2px);box-shadow:0 8px 16px #00000026}.wallet-button:active{transform:translateY(0);box-shadow:0 4px 8px #0000001a}.apple-wallet{background:var(--gp-brand-800);color:var(--gp-text-inverse)}.apple-wallet:hover{background:var(--gp-brand-900)}.google-wallet{background:var(--gp-info);color:var(--gp-text-inverse)}.google-wallet:hover{background:#1d4ed8}.wallet-icon{width:24px;height:24px;flex-shrink:0}.gatepassify-footer{padding:24px;background:var(--gp-accent);border-top:1px solid var(--gp-brand-200)}.gatepassify-branding{display:flex;align-items:center;justify-content:center;gap:12px}.gatepassify-logo{flex-shrink:0}.gatepassify-icon{width:32px;height:32px}.gatepassify-text{display:flex;flex-direction:column;gap:2px}.gatepassify-name{font-size:16px;font-weight:700;color:var(--gp-brand-800);line-height:1}.gatepassify-tagline{font-size:12px;color:var(--gp-brand-400);line-height:1}@media (max-width: 480px){.qr-pass-container{padding:12px}.qr-pass-card{max-width:none;border-radius:16px}.company-header{padding:24px 20px 20px}.company-name{font-size:24px}.company-logo{width:56px;height:56px}.qr-section{padding:24px 20px}.qr-code-placeholder{width:180px;height:180px}.access-info,.wallet-buttons,.gatepassify-footer{padding:20px}}@media (max-width: 360px){.qr-code-placeholder{width:160px;height:160px}.wallet-button{font-size:15px;padding:14px 20px;min-height:52px}}.error-page-container{min-height:100vh;background:linear-gradient(135deg,var(--gp-danger-400) 0%,var(--gp-danger) 100%);padding:20px;display:flex;align-items:center;justify-content:center;font-family:Inter,system-ui,-apple-system,sans-serif}.error-card{background:var(--gp-bg);border-radius:20px;box-shadow:0 20px 25px -5px #d23f311a,0 10px 10px -5px #d23f310a;max-width:480px;width:100%;overflow:hidden;animation:fadeIn .6s ease-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.error-header{padding:32px 24px 24px;background:linear-gradient(135deg,var(--gp-brand-500) 0%,var(--gp-brand-700) 100%);color:var(--gp-text-inverse);text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px}.error-logo-icon{width:64px;height:64px}.error-brand-name{font-size:28px;font-weight:700;margin:0;line-height:1.2}.error-brand-tagline{font-size:14px;margin:0;opacity:.9;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.error-content{padding:32px 24px;text-align:center}.error-icon-container{display:flex;justify-content:center;margin-bottom:24px}.error-icon{width:80px;height:80px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.error-title{font-size:24px;font-weight:700;color:var(--gp-brand-200);margin:0 0 16px;line-height:1.3}.error-message{margin-bottom:32px}.error-description{font-size:16px;color:var(--gp-brand-200);margin:0 0 16px;line-height:1.6}.error-reasons{text-align:left;background:var(--gp-accent);border-left:4px solid var(--gp-danger);padding:16px 20px;margin:0;border-radius:0 8px 8px 0;list-style:none}.error-reasons li{font-size:14px;color:var(--gp-brand-400);margin-bottom:8px;position:relative;padding-left:20px;line-height:1.5}.error-reasons li:last-child{margin-bottom:0}.error-reasons li:before{content:"•";color:var(--gp-danger);font-size:16px;position:absolute;left:0;top:0}.error-actions{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.retry-button,.contact-button{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px 24px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none;min-height:56px}.retry-button{background:var(--gp-brand-500);color:var(--gp-text-inverse)}.retry-button:hover{background:var(--gp-brand-600);transform:translateY(-2px);box-shadow:0 8px 16px #2226304d}.contact-button{background:var(--gp-accent);color:var(--gp-brand-600);border:2px solid var(--gp-brand-200)}.contact-button:hover{background:var(--gp-brand-100);border-color:var(--gp-brand-300);transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.retry-icon,.contact-icon{width:30px;height:30px;flex-shrink:0}.error-help{padding:24px;background:var(--gp-accent);border-top:1px solid var(--gp-brand-200)}.help-title{font-size:18px;font-weight:600;color:var(--gp-brand-800);margin:0 0 8px;text-align:center}.help-description{font-size:14px;color:var(--gp-brand-400);margin:0;line-height:1.6;text-align:center}@media (max-width: 480px){.error-page-container{padding:12px}.error-card{max-width:none;border-radius:16px}.error-header{padding:24px 20px 20px}.error-brand-name{font-size:24px}.error-logo-icon{width:56px;height:56px}.error-content{padding:24px 20px}.error-title{font-size:20px}.error-icon{width:64px;height:64px}.error-help{padding:20px}.retry-button,.contact-button{font-size:15px;min-height:52px}}@media (max-width: 360px){.error-actions{gap:10px}.retry-button,.contact-button{padding:14px 20px;font-size:14px;min-height:48px}.retry-icon,.contact-icon{width:18px;height:18px}}
