:root{--color-bg-primary:#0a0a0a;--color-bg-secondary:#111;--color-bg-tertiary:#1a1a1a;--color-bg-elevated:#222;--color-accent-primary:#2379f0;--color-accent-secondary:#3b8bf5;--color-accent-glow:#2379f066;--color-accent-gold:#fbb040;--color-success:#10b981;--color-success-glow:#10b98166;--color-warning:#f59e0b;--color-error:#ef4444;--color-text-primary:#fff;--color-text-secondary:#ffffffb3;--color-text-tertiary:#ffffff80;--color-text-muted:#ffffff4d;--glass-bg:#ffffff0d;--glass-border:#ffffff1a;--glass-blur:blur(20px);--gradient-primary:linear-gradient(135deg,#2379f0,#3b8bf5);--gradient-success:linear-gradient(135deg,#10b981,#059669);--gradient-dark:linear-gradient(180deg,#0a0a0a,#1a1a2e);--gradient-card:linear-gradient(145deg,#ffffff0d,#ffffff05);--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:2rem;--font-size-4xl:2.5rem;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-extrabold:800;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 40px var(--color-accent-glow);--shadow-success-glow:0 0 30px var(--color-success-glow);--transition-fast:150ms cubic-bezier(0.4,0,0.2,1);--transition-normal:250ms cubic-bezier(0.4,0,0.2,1);--transition-slow:350ms cubic-bezier(0.4,0,0.2,1);--transition-spring:500ms cubic-bezier(0.34,1.56,0.64,1);--sat:env(safe-area-inset-top,0px);--sar:env(safe-area-inset-right,0px);--sab:env(safe-area-inset-bottom,0px);--sal:env(safe-area-inset-left,0px);--bottom-nav-height:64px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;scroll-behavior:smooth}body,html{-webkit-overflow-scrolling:touch;height:100%;overscroll-behavior:none}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0a0a0a;background:var(--color-bg-primary);color:#fff;color:var(--color-text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-size:1rem;font-size:var(--font-size-base);font-weight:400;font-weight:var(--font-weight-normal);line-height:1.5;overflow-x:hidden}#root{display:flex;flex-direction:column;isolation:isolate;min-height:100vh;min-height:100dvh}h1,h2,h3,h4,h5,h6{font-weight:700;font-weight:var(--font-weight-bold);letter-spacing:-.02em;line-height:1.2}h1{font-size:2rem;font-size:var(--font-size-3xl)}h2{font-size:1.5rem;font-size:var(--font-size-2xl)}h3{font-size:1.25rem;font-size:var(--font-size-xl)}h4{font-size:1.125rem;font-size:var(--font-size-lg)}p{color:#ffffffb3;color:var(--color-text-secondary);line-height:1.6}button{-webkit-tap-highlight-color:transparent;background:none;border:none;cursor:pointer;font-family:inherit;font-size:inherit;touch-action:manipulation}.btn{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:inline-flex;font-size:1rem;font-size:var(--font-size-base);font-weight:600;font-weight:var(--font-weight-semibold);gap:8px;gap:var(--space-sm);justify-content:center;min-height:48px;min-width:48px;padding:16px 24px;padding:var(--space-md) var(--space-lg);transition:all .25s cubic-bezier(.4,0,.2,1);transition:all var(--transition-normal)}.btn-primary{background:linear-gradient(135deg,#2379f0,#3b8bf5);background:var(--gradient-primary);box-shadow:0 4px 16px #0006,0 0 40px #2379f066;box-shadow:var(--shadow-md),var(--shadow-glow);color:#fff}.btn-primary:active{box-shadow:0 2px 8px #0000004d;box-shadow:var(--shadow-sm);transform:scale(.96)}.btn-success{background:linear-gradient(135deg,#10b981,#059669);background:var(--gradient-success);box-shadow:0 4px 16px #0006,0 0 30px #10b98166;box-shadow:var(--shadow-md),var(--shadow-success-glow);color:#fff}.btn-success:active{transform:scale(.96)}.btn-glass{backdrop-filter:blur(20px);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:blur(20px);-webkit-backdrop-filter:var(--glass-blur);background:#ffffff0d;background:var(--glass-bg);border:1px solid #ffffff1a;border:1px solid var(--glass-border);color:#fff;color:var(--color-text-primary)}.btn-glass:active{background:#ffffff1a}.card{backdrop-filter:blur(20px);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:blur(20px);-webkit-backdrop-filter:var(--glass-blur);background:linear-gradient(145deg,#ffffff0d,#ffffff05);background:var(--gradient-card);border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:16px;border-radius:var(--radius-lg);padding:24px;padding:var(--space-lg);transition:all .25s cubic-bezier(.4,0,.2,1);transition:all var(--transition-normal)}.card:active{border-color:#2379f0;border-color:var(--color-accent-primary);transform:scale(.98)}.card-elevated{background:#222;background:var(--color-bg-elevated);box-shadow:0 4px 16px #0006;box-shadow:var(--shadow-md)}input,select,textarea{background:#ffffff0d;background:var(--glass-bg);border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:12px;border-radius:var(--radius-md);color:#fff;color:var(--color-text-primary);font-family:inherit;font-size:16px;min-height:48px;padding:16px;padding:var(--space-md);transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);width:100%}input:focus,select:focus,textarea:focus{border-color:#2379f0;border-color:var(--color-accent-primary);box-shadow:0 0 0 3px #2379f066;box-shadow:0 0 0 3px var(--color-accent-glow);outline:none}input::placeholder{color:#ffffff4d;color:var(--color-text-muted)}a{color:#3b8bf5;color:var(--color-accent-secondary);text-decoration:none;transition:color .15s cubic-bezier(.4,0,.2,1);transition:color var(--transition-fast)}a:active{color:#2379f0;color:var(--color-accent-primary)}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-primary{color:#fff;color:var(--color-text-primary)}.text-secondary{color:#ffffffb3;color:var(--color-text-secondary)}.text-muted{color:#ffffff4d;color:var(--color-text-muted)}.text-accent{color:#2379f0;color:var(--color-accent-primary)}.text-success{color:#10b981;color:var(--color-success)}.text-warning{color:#f59e0b;color:var(--color-warning)}.text-error{color:#ef4444;color:var(--color-error)}.bg-glass{backdrop-filter:blur(20px);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:blur(20px);-webkit-backdrop-filter:var(--glass-blur);background:#ffffff0d;background:var(--glass-bg)}@keyframes slideInBottom{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes glow{0%,to{box-shadow:0 0 20px #2379f066;box-shadow:0 0 20px var(--color-accent-glow)}50%{box-shadow:0 0 40px #2379f066,0 0 60px #2379f066;box-shadow:0 0 40px var(--color-accent-glow),0 0 60px var(--color-accent-glow)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fade-in{animation:fadeIn ease-out .25s cubic-bezier(.4,0,.2,1);animation:fadeIn var(--transition-normal) ease-out}.animate-fade-in-up{animation:fadeInUp ease-out .35s cubic-bezier(.4,0,.2,1);animation:fadeInUp var(--transition-slow) ease-out}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-glow{animation:glow 2s ease-in-out infinite}.skeleton{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#1a1a1a 25%,#222 50%,#1a1a1a 75%);background:linear-gradient(90deg,var(--color-bg-tertiary) 25%,var(--color-bg-elevated) 50%,var(--color-bg-tertiary) 75%);background-size:200% 100%;border-radius:8px;border-radius:var(--radius-sm)}.loading-spinner{animation:spin .8s linear infinite;border:3px solid #ffffff1a;border-top-color:#2379f0;border:3px solid var(--glass-border);border-radius:50%;border-top-color:var(--color-accent-primary);height:40px;width:40px}@supports (padding:env(safe-area-inset-top)){.safe-top{padding-top:env(safe-area-inset-top,0);padding-top:var(--sat)}.safe-bottom{padding-bottom:calc(env(safe-area-inset-bottom, 0px) + 16px);padding-bottom:calc(var(--sab) + var(--space-md))}.safe-left{padding-left:env(safe-area-inset-left,0);padding-left:var(--sal)}.safe-right{padding-right:env(safe-area-inset-right,0);padding-right:var(--sar)}}::-webkit-scrollbar{height:4px;width:4px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#ffffff4d;background:var(--color-text-muted);border-radius:9999px;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#ffffff80;background:var(--color-text-tertiary)}.hide-scrollbar{-ms-overflow-style:none;scrollbar-width:none}.hide-scrollbar::-webkit-scrollbar{display:none}::selection{background:#2379f0;background:var(--color-accent-primary);color:#fff}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}:focus-visible{outline:2px solid #2379f0;outline:2px solid var(--color-accent-primary);outline-offset:2px}:focus:not(:focus-visible){outline:none}@media (display-mode:standalone){body{padding-top:env(safe-area-inset-top,0);padding-top:var(--sat)}}@media (hover:none) and (pointer:coarse){.btn:hover,.card:hover{transform:none}.card:hover{border-color:#ffffff1a;border-color:var(--glass-border)}}.toast{align-items:center;animation:slideInBottom ease-out .25s cubic-bezier(.4,0,.2,1);animation:slideInBottom var(--transition-normal) ease-out;backdrop-filter:blur(20px);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:blur(20px);-webkit-backdrop-filter:var(--glass-blur);background:#222;background:var(--color-bg-elevated);border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:12px;border-radius:var(--radius-md);bottom:calc(80px + env(safe-area-inset-bottom, 0px));bottom:calc(var(--bottom-nav-height) + var(--sab) + var(--space-md));color:#fff;color:var(--color-text-primary);display:flex;gap:8px;gap:var(--space-sm);left:16px;left:var(--space-md);padding:16px;padding:var(--space-md);position:fixed;right:16px;right:var(--space-md);z-index:10000}.toast-success{border-color:#10b981;border-color:var(--color-success);box-shadow:0 0 20px #10b98166;box-shadow:0 0 20px var(--color-success-glow)}.toast-error{border-color:#ef4444;border-color:var(--color-error)}.offline-banner{background:#f59e0b;background:var(--color-warning);color:#0a0a0a;color:var(--color-bg-primary);font-size:.875rem;font-size:var(--font-size-sm);font-weight:500;font-weight:var(--font-weight-medium);left:0;padding:8px 16px;padding:var(--space-sm) var(--space-md);position:fixed;right:0;text-align:center;top:env(safe-area-inset-top,0);top:var(--sat);z-index:10001}@media print{.bottom-nav,.offline-banner,.toast{display:none!important}}.landing-hero{align-items:center;background:#000;display:flex;flex-direction:column;inset:0;justify-content:center;overflow:hidden;position:fixed;z-index:100}.hero-ambient{inset:0;overflow:hidden;pointer-events:none;position:absolute}.ambient-orb{animation:ambientFloat 8s ease-in-out infinite;border-radius:50%;filter:blur(80px);opacity:.4;position:absolute}.orb-1{animation-delay:0s;background:radial-gradient(circle,#2379f0 0,#0000 70%);height:400px;left:-10%;top:-10%;width:400px}.orb-2{animation-delay:-4s;background:radial-gradient(circle,#fbb040 0,#0000 70%);bottom:-5%;height:300px;right:-5%;width:300px}@keyframes ambientFloat{0%,to{opacity:.3;transform:translate(0) scale(1)}50%{opacity:.5;transform:translate(20px,-20px) scale(1.1)}}.hero-content{align-items:center;display:flex;flex-direction:column;justify-content:center;max-width:480px;padding:0 32px;text-align:center;z-index:10}.hero-logo-container{margin-bottom:48px;opacity:0;transform:translateY(20px) scale(.95);transition:all .8s cubic-bezier(.16,1,.3,1)}.hero-logo-container.visible{opacity:1;transform:translateY(0) scale(1)}.hero-logo{filter:drop-shadow(0 0 30px rgba(35,121,240,.3));height:56px;width:auto}.hero-tagline{color:#fff;font-size:32px;font-weight:700;letter-spacing:-.02em;line-height:1.2;margin:0 0 20px;opacity:0;transform:translateY(20px);transition:all .8s cubic-bezier(.16,1,.3,1)}.hero-tagline.visible{opacity:1;transform:translateY(0)}.hero-tagline .highlight{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#2379f0,#fbb040);-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:#fff9;font-size:16px;font-weight:400;line-height:1.5;margin:0 0 40px;opacity:0;transform:translateY(20px);transition:all .8s cubic-bezier(.16,1,.3,1);transition-delay:.1s}.hero-subtitle.visible{opacity:1;transform:translateY(0)}.hero-cta{align-items:center;background:linear-gradient(135deg,#2379f0,#3b8bf5);border:none;border-radius:100px;box-shadow:0 4px 24px #2379f066,0 0 0 0 #2379f066;color:#000;cursor:pointer;display:flex;font-size:18px;font-weight:600;gap:12px;justify-content:center;min-height:60px;min-width:200px;opacity:0;overflow:hidden;padding:18px 48px;position:relative;transform:translateY(20px);transition:all .8s cubic-bezier(.16,1,.3,1)}.hero-cta.visible{animation:ctaPulse 3s ease-in-out infinite;animation-delay:1.5s;opacity:1;transform:translateY(0)}@keyframes ctaPulse{0%,to{box-shadow:0 4px 24px #2379f066,0 0 0 0 #2379f066}50%{box-shadow:0 4px 32px #2379f099,0 0 0 8px #2379f000}}.hero-cta:active{transform:scale(.96)}.hero-cta:disabled{cursor:wait}.cta-text{color:#fff;font-weight:600}.cta-arrow{color:#fff;font-size:20px;transition:transform .3s ease}.hero-cta:not(:disabled):hover .cta-arrow{transform:translateX(4px)}.cta-loading{align-items:center;color:#fff;display:flex;gap:12px}.cta-spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:20px;width:20px}.hero-trust{color:#fff6;font-size:13px;letter-spacing:.02em;margin-top:24px;opacity:0;transform:translateY(10px);transition:all .8s cubic-bezier(.16,1,.3,1);transition-delay:.2s}.hero-trust.visible{opacity:1;transform:translateY(0)}.hero-charging-indicator{align-items:center;bottom:48px;display:flex;gap:16px;justify-content:center;left:0;opacity:0;padding-bottom:env(safe-area-inset-bottom,0);position:absolute;right:0;transform:translateY(20px);transition:all .8s cubic-bezier(.16,1,.3,1);transition-delay:.3s}.hero-charging-indicator.visible{opacity:1;transform:translateY(0)}.charging-line{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);height:1px;width:40px}.charging-text{color:#fff6;font-size:12px;letter-spacing:.1em;text-transform:uppercase}@media (min-width:390px){.hero-tagline{font-size:36px}.hero-logo{height:64px}}@media (min-width:768px){.hero-tagline{font-size:48px}.hero-subtitle{font-size:18px}.hero-logo{height:72px}.hero-cta{font-size:20px;padding:20px 56px}}@media (prefers-reduced-motion:reduce){.ambient-orb,.hero-cta.visible{animation:none}.hero-charging-indicator,.hero-cta,.hero-logo-container,.hero-subtitle,.hero-tagline,.hero-trust{transform:none!important;transition:opacity .3s ease}.hero-charging-indicator.visible,.hero-cta.visible,.hero-logo-container.visible,.hero-subtitle.visible,.hero-tagline.visible,.hero-trust.visible{opacity:1}}@media (orientation:landscape) and (max-height:500px){.hero-logo-container{margin-bottom:24px}.hero-logo{height:40px}.hero-tagline{font-size:24px;margin-bottom:12px}.hero-subtitle{font-size:14px;margin-bottom:24px}.hero-cta{font-size:16px;min-height:48px;padding:14px 40px}.hero-charging-indicator{bottom:16px}}.service-categories{padding:var(--space-md) 0}.categories-title{display:none}.categories-grid{-webkit-overflow-scrolling:touch;-ms-overflow-style:none;display:flex;gap:var(--space-sm);overflow-x:auto;padding:0 var(--space-md);scroll-snap-type:x proximity;scrollbar-width:none}.categories-grid::-webkit-scrollbar{display:none}.category-card{align-items:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-full);color:var(--color-text-secondary);cursor:pointer;display:flex;flex-shrink:0;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--space-sm);min-height:44px;padding:var(--space-sm) var(--space-md);position:relative;scroll-snap-align:start;transition:all var(--transition-fast)}.category-card:active{transform:scale(.95)}.category-card.active{background:var(--gradient-primary);border-color:var(--color-accent-primary);box-shadow:var(--shadow-glow);color:#fff}.category-icon{font-size:1.25rem;line-height:1}.category-content{align-items:center;display:flex;gap:var(--space-sm)}.category-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);white-space:nowrap}.category-description{display:none}.category-count{align-items:center;background:#ffffff26;display:inline-flex;font-weight:var(--font-weight-semibold);height:20px;justify-content:center;min-width:24px;padding:0 var(--space-sm)}.category-card.active .category-count{background:#ffffff40}.active-indicator,.category-tips{display:none}.category-card:focus-visible{outline:2px solid var(--color-accent-primary);outline-offset:2px}.category-card:focus:not(:focus-visible){outline:none}@media (prefers-reduced-motion:reduce){.category-card{transition:none}.category-card:active{transform:none}}@media (min-width:768px){.categories-title{color:var(--color-text-primary);display:block;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-lg);padding:0 var(--space-md);text-align:center}.categories-grid{flex-wrap:wrap;gap:var(--space-md);justify-content:center;overflow-x:visible}.category-card{padding:var(--space-md) var(--space-lg)}.category-description{color:var(--color-text-tertiary);display:block;font-size:var(--font-size-xs);margin-left:var(--space-xs)}.category-card.active .category-description{color:#fffc}}.vendor-card{position:relative}.vendor-card.active{border-color:#10b9814d}.vendor-card.inactive{opacity:.6}.inactive-overlay{background:#0000004d;bottom:0;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:10}.inactive-badge{background:var(--color-error);border-radius:var(--radius-sm);color:#fff;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);left:var(--space-md);padding:var(--space-sm) var(--space-md);position:absolute;top:var(--space-md);z-index:11}.vendor-image-container{background:var(--color-bg-tertiary);height:140px;overflow:hidden;position:relative}.image-placeholder{align-items:center;background:var(--color-bg-tertiary);display:flex;inset:0;justify-content:center;position:absolute}.category-icon-large{font-size:2.5rem;opacity:.3}.vendor-image{height:100%;object-fit:cover;transition:opacity var(--transition-normal);width:100%}.vendor-image.loading{opacity:0}.vendor-image.loaded{opacity:1}.image-overlay{align-items:flex-start;background:linear-gradient(180deg,#00000080 0,#0000 40%,#0000 60%,#000c);display:flex;inset:0;justify-content:space-between;padding:var(--space-sm);position:absolute}.category-badge,.distance-badge{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-full);color:#fff;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:var(--space-xs) var(--space-sm)}.distance-badge{align-self:flex-end}.category-badge{background:#6366f1cc;border-color:#0000;text-transform:capitalize}.vendor-content{padding:var(--space-md)}.vendor-header{align-items:flex-start;display:flex;gap:var(--space-sm);justify-content:space-between;margin-bottom:var(--space-sm)}.vendor-name{flex:1 1}.vendor-rating{white-space:nowrap}.toggle-description{background:none;border:none;color:var(--color-accent-secondary);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-left:var(--space-xs);padding:0}.vendor-details{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-md)}.detail-item{align-items:center;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);display:inline-flex;font-size:var(--font-size-xs);gap:var(--space-xs);padding:var(--space-xs) var(--space-sm)}.detail-icon{font-size:.875rem}.charge-time{font-weight:var(--font-weight-semibold)}.charge-time.green{color:var(--color-success)}.charge-time.orange{color:var(--color-warning)}.charge-time.blue{color:var(--color-accent-secondary)}.commission-rate{background:#10b98126;border-color:#10b98133;border-radius:var(--radius-sm);color:var(--color-success)}.commission-rate,.conversion-rate{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:var(--space-xs) var(--space-sm)}.conversion-rate{background:#6366f126;border-color:#6366f133;border-radius:var(--radius-sm);color:var(--color-accent-secondary)}.vendor-address{align-items:flex-start;color:var(--color-text-muted);display:flex;font-size:var(--font-size-xs);gap:var(--space-sm);line-height:1.4;margin-bottom:var(--space-md)}.address-icon{flex-shrink:0;font-size:.875rem}.vendor-actions{display:flex;gap:var(--space-sm)}.action-button{-webkit-tap-highlight-color:transparent;align-items:center;border:none;border-radius:var(--radius-md);cursor:pointer;display:flex;flex:1 1;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);gap:var(--space-xs);justify-content:center;min-height:44px;padding:var(--space-sm) var(--space-md);touch-action:manipulation;transition:all var(--transition-fast)}.action-button:disabled{cursor:not-allowed;opacity:.4}.action-button:active:not(:disabled){transform:scale(.95)}.action-button.primary{background:var(--gradient-success);color:#fff}.action-button.secondary{background:var(--gradient-primary);color:#fff}.action-button.tertiary{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.button-icon{font-size:1rem}@media (min-width:414px){.vendor-image-container{height:160px}}.action-button:focus-visible{outline:2px solid var(--color-accent-primary);outline-offset:2px}.action-button:focus:not(:focus-visible){outline:none}@media (prefers-reduced-motion:reduce){.action-button,.vendor-card{transition:none}.action-button:active,.vendor-card:active{transform:none}}.vendor-list{padding:0}.list-header{padding:var(--space-md);padding-top:0}.list-header h2{align-items:center;color:var(--color-text-primary);display:flex;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);gap:var(--space-sm);margin-bottom:var(--space-xs)}.vendor-count{background:var(--gradient-primary);border-radius:var(--radius-full);color:#fff;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:var(--space-xs) var(--space-sm)}.location-note{align-items:center;color:var(--color-text-muted);display:flex;font-size:var(--font-size-sm);gap:var(--space-xs);margin:0}.vendors-container{display:flex;flex-direction:column;gap:var(--space-md);padding:0 var(--space-md)}.list-footer{margin-top:var(--space-md);padding:var(--space-lg) var(--space-md)}.disclaimer{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:var(--font-size-xs);line-height:1.5;margin:0;padding:var(--space-md);text-align:center}@media (min-width:768px){.vendors-container{grid-gap:var(--space-lg);display:grid;gap:var(--space-lg);grid-template-columns:repeat(2,1fr);padding:0 var(--space-lg)}.list-header{padding:var(--space-lg);padding-top:0}}.loading-container{inset:0;overflow:hidden;position:fixed;z-index:9999}.loading-container:before{animation:backgroundPulse 4s ease-in-out infinite;background:radial-gradient(ellipse at 30% 20%,#6366f133 0,#0000 50%),radial-gradient(ellipse at 70% 80%,#8b5cf626 0,#0000 50%);content:"";inset:0;position:absolute}@keyframes backgroundPulse{0%,to{opacity:.5}50%{opacity:1}}.loading-content{animation:fadeInUp .5s ease-out;color:var(--color-text-primary);max-width:320px;padding:var(--space-xl);position:relative;text-align:center;z-index:10}.loading-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#a5b4fc 50%,#6366f1);-webkit-background-clip:text;background-clip:text;font-size:var(--font-size-3xl);font-weight:var(--font-weight-extrabold);letter-spacing:-.03em;margin-bottom:var(--space-sm)}.loading-message{color:var(--color-text-secondary);font-size:var(--font-size-base);line-height:1.5;margin-bottom:var(--space-2xl)}.charging-animation{align-items:center;display:flex;height:80px;justify-content:center;margin-bottom:var(--space-xl);position:relative}.battery{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--glass-bg);border:2px solid var(--glass-border);border-radius:var(--radius-sm);height:35px;position:relative;width:70px}.battery-tip{background:var(--glass-border);border-radius:0 2px 2px 0;height:14px;position:absolute;right:-7px;top:50%;transform:translateY(-50%);width:5px}.battery-level{animation:charging 2s ease-in-out infinite;background:var(--gradient-success);border-radius:4px;bottom:3px;box-shadow:0 0 20px var(--color-success-glow);left:3px;position:absolute;top:3px}@keyframes charging{0%{width:10%}50%{width:85%}to{width:10%}}.lightning-bolt{animation:electricPulse 1.5s ease-in-out infinite;filter:drop-shadow(0 0 10px #fbbf24);font-size:2rem;margin-left:var(--space-md)}@keyframes electricPulse{0%,to{opacity:1;transform:scale(1)}25%{opacity:.8;transform:scale(1.1)}50%{opacity:1;transform:scale(1.2)}75%{opacity:.8;transform:scale(1.1)}}.loading-steps{flex-direction:column}.loading-steps,.step{align-items:center;display:flex;gap:var(--space-sm)}.step{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-full);color:var(--color-text-muted);font-size:var(--font-size-sm);padding:var(--space-sm) var(--space-md);transition:all var(--transition-normal)}.step.active{background:#6366f11a;border-color:var(--color-accent-primary);color:var(--color-text-primary)}.step-icon{font-size:1rem;line-height:1}.loading-background{inset:0;overflow:hidden;pointer-events:none;position:absolute;z-index:1}.floating-icon{animation:floatUp 8s ease-in-out infinite;font-size:2rem;opacity:.05;position:absolute}.floating-icon:first-child{animation-delay:0s;left:10%;top:15%}.floating-icon:nth-child(2){animation-delay:2s;right:15%;top:65%}.floating-icon:nth-child(3){animation-delay:4s;bottom:25%;left:20%}.floating-icon:nth-child(4){animation-delay:6s;right:10%;top:25%}@keyframes floatUp{0%,to{opacity:.05;transform:translateY(0) rotate(0deg)}50%{opacity:.1;transform:translateY(-30px) rotate(10deg)}}@media (prefers-reduced-motion:reduce){.charging-animation,.floating-icon,.lightning-bolt,.loading-container:before{animation:none}.battery-level{animation:none;width:70%}.loading-content{animation:none}}.install-prompt-overlay{align-items:center;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;left:0;padding:1rem;right:0;top:0;z-index:10000}.install-prompt{animation:slideInUp .4s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 40px #0003;max-width:400px;overflow:hidden;position:relative;width:100%}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.dismiss-button{align-items:center;background:#f3f4f6;border:none;border-radius:50%;color:#6b7280;cursor:pointer;display:flex;font-size:1rem;height:32px;justify-content:center;position:absolute;right:1rem;top:1rem;transition:all .2s ease;width:32px;z-index:10}.dismiss-button:hover{background:#e5e7eb;color:#374151}.install-content{padding:2rem;text-align:center}.install-icon{display:block;font-size:3rem;margin-bottom:1rem}.install-content h3{color:#1f2937;font-size:1.5rem;font-weight:700;margin-bottom:1rem}.install-content p{color:#6b7280;line-height:1.6;margin-bottom:2rem}.install-benefits{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr);margin-bottom:2rem}.benefit{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-direction:column;gap:.5rem;padding:1rem .5rem}.benefit-icon{font-size:1.5rem}.benefit span:last-child{color:#4b5563;font-size:.85rem;font-weight:600;text-align:center}.install-actions{display:flex;gap:.8rem;padding:1rem 2rem 2rem}.install-button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-size:.95rem;font-weight:600;gap:.5rem;justify-content:center;min-height:44px;padding:.8rem 1rem;transition:all .2s ease}.install-button.primary{background:linear-gradient(135deg,#3b82f6,#1d4ed8);box-shadow:0 4px 12px #3b82f64d;color:#fff}.install-button.primary:hover{box-shadow:0 6px 20px #3b82f666;transform:translateY(-2px)}.install-button.primary:active{transform:translateY(0)}.install-button.secondary{background:#f3f4f6;border:1px solid #d1d5db;color:#6b7280}.install-button.secondary:hover{background:#e5e7eb;color:#374151}.button-icon{font-size:1.1rem}@media (max-width:768px){.install-prompt-overlay{padding:.5rem}.install-prompt{max-width:350px}.install-content{padding:1.5rem}.install-content h3{font-size:1.3rem}.install-benefits{gap:.8rem;grid-template-columns:1fr}.benefit{flex-direction:row;padding:.8rem;text-align:left}.benefit span:last-child{font-size:.9rem;text-align:left}.install-actions{flex-direction:column;padding:1rem 1.5rem 1.5rem}}@media (max-width:480px){.install-prompt{margin:.5rem}.install-content{padding:1.2rem}.install-icon{font-size:2.5rem}.install-content h3{font-size:1.2rem}.install-content p{font-size:.9rem}}.dismiss-button:focus,.install-button:focus{outline:3px solid #3b82f6;outline-offset:2px}.dismiss-button:focus:not(:focus-visible),.install-button:focus:not(:focus-visible){outline:none}@media (prefers-contrast:high){.install-prompt{border:2px solid #000}.install-button.primary{background:#000;border:2px solid #000}.install-button.secondary{background:#fff;border:2px solid #000;color:#000}}@media (prefers-reduced-motion:reduce){.install-prompt,.install-prompt-overlay{animation:none}.install-button{transition:none}.install-button:hover{transform:none}}@media (prefers-color-scheme:dark){.install-prompt{background:#1f2937;color:#f9fafb}.install-content h3{color:#f9fafb}.install-content p{color:#d1d5db}.benefit{background:#374151;border-color:#4b5563}.benefit span:last-child{color:#d1d5db}.install-button.secondary{background:#374151;border-color:#4b5563;color:#d1d5db}.install-button.secondary:hover{background:#4b5563;color:#f3f4f6}.dismiss-button{background:#374151;color:#d1d5db}.dismiss-button:hover{background:#4b5563;color:#f3f4f6}}.bottom-nav{align-items:stretch}.nav-item{-webkit-tap-highlight-color:transparent;background:#0000;border:none;cursor:pointer;flex:1 1;padding:var(--space-sm) 0;padding-bottom:calc(var(--space-sm) + var(--sab));position:relative;touch-action:manipulation}.nav-icon{transition:transform var(--transition-fast)}.nav-item.active .nav-icon{transform:scale(1.1)}.nav-label{letter-spacing:.01em}.nav-indicator{background:var(--color-accent-primary);border-radius:50%;box-shadow:0 0 8px var(--color-accent-glow);height:4px;left:50%;position:absolute;top:6px;transform:translateX(-50%);width:4px}.nav-item:nth-child(2){position:relative}.nav-item:nth-child(2) .nav-icon{align-items:center;background:var(--gradient-primary);border:3px solid var(--color-bg-primary);border-radius:50%;box-shadow:var(--shadow-md),var(--shadow-glow);display:flex;font-size:1.25rem;height:48px;justify-content:center;margin-top:-20px;width:48px}.nav-item:nth-child(2).active .nav-icon{transform:scale(1.05)}.nav-item:nth-child(2) .nav-label{color:var(--color-accent-secondary);font-weight:var(--font-weight-semibold)}.nav-item:focus-visible{outline:2px solid var(--color-accent-primary);outline-offset:-2px}.nav-item:focus:not(:focus-visible){outline:none}@media (prefers-reduced-motion:reduce){.nav-icon,.nav-item{transition:none}.nav-item:active{transform:none}}@media (display-mode:standalone){.bottom-nav{padding-bottom:calc(var(--sab) + 4px)}}@media (orientation:landscape) and (max-height:500px){.bottom-nav{height:56px}.nav-item{flex-direction:row;gap:var(--space-sm);padding:var(--space-xs) var(--space-md)}.nav-icon{font-size:1.25rem}.nav-item:nth-child(2) .nav-icon{font-size:1rem;height:40px;margin-top:0;width:40px}}.station-code-overlay{align-items:center;animation:fadeIn .2s ease-out;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#000000e6;display:flex;inset:0;justify-content:center;padding:var(--space-md);position:fixed;z-index:2000}.station-code-modal{animation:fadeInUp .3s ease-out;background:var(--color-bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-xl);max-width:360px;padding:var(--space-xl);position:relative;text-align:center;width:100%}.close-button{align-items:center;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-full);color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:1.5rem;height:36px;justify-content:center;position:absolute;right:var(--space-md);top:var(--space-md);transition:all var(--transition-fast);width:36px}.close-button:active{transform:scale(.9)}.modal-icon{animation:pulse 2s ease-in-out infinite;font-size:3rem;margin-bottom:var(--space-md)}.station-code-modal h2{color:var(--color-text-primary);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-sm)}.modal-description{color:var(--color-text-tertiary);font-size:var(--font-size-sm);line-height:1.5;margin-bottom:var(--space-xl)}.code-input-container{margin-bottom:var(--space-lg)}.code-input{background:var(--glass-bg);border:2px solid var(--glass-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:SF Mono,Monaco,Consolas,monospace;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);letter-spacing:.2em;padding:var(--space-md);text-align:center;transition:all var(--transition-fast);width:100%}.code-input::placeholder{color:var(--color-text-muted);font-weight:var(--font-weight-normal);letter-spacing:.1em}.code-input:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px var(--color-accent-glow);outline:none}.code-input.error{border-color:var(--color-error);box-shadow:0 0 0 3px #ef444433}.error-message{color:var(--color-error);display:block;font-size:var(--font-size-sm);margin-top:var(--space-sm)}.submit-button{align-items:center;background:var(--gradient-primary);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:flex;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);gap:var(--space-sm);justify-content:center;min-height:52px;padding:var(--space-md);transition:all var(--transition-normal);width:100%}.submit-button:disabled{cursor:not-allowed;opacity:.5}.submit-button:not(:disabled):active{transform:scale(.98)}.spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:18px;width:18px}@keyframes spin{to{transform:rotate(1turn)}}.demo-hint{align-items:center;background:#6366f11a;border:1px solid #6366f133;border-radius:var(--radius-md);color:var(--color-text-secondary);display:flex;font-size:var(--font-size-sm);gap:var(--space-sm);justify-content:center;margin-top:var(--space-lg);padding:var(--space-sm) var(--space-md)}.hint-icon{font-size:1rem}.demo-hint strong{color:var(--color-accent-secondary);font-family:SF Mono,Monaco,Consolas,monospace;letter-spacing:.1em}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.App{background:var(--color-bg-primary);display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;overflow-x:hidden;position:relative}.App:before{background:radial-gradient(ellipse at 20% 0,#6366f126 0,#0000 50%),radial-gradient(ellipse at 80% 100%,#8b5cf61a 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.app-header{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#000000e6;border-bottom:1px solid #ffffff0f;padding:var(--space-md);padding-top:calc(var(--sat) + var(--space-md));position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-content{margin:0 auto;max-width:600px}.header-top{align-items:center;display:flex;justify-content:space-between}.header-logo{filter:drop-shadow(0 0 20px rgba(35,121,240,.3));height:32px;width:auto}.location-badge{align-items:center;background:#2379f01a;border:1px solid #2379f033;border-radius:100px;color:#2379f0;display:flex;font-size:11px;font-weight:600;gap:6px;letter-spacing:.05em;padding:6px 12px}.location-dot{animation:locationPulse 2s ease-in-out infinite;background:#2379f0;border-radius:50%;height:6px;width:6px}@keyframes locationPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.qr-scan-button{align-items:center;background:var(--gradient-success);border-radius:var(--radius-full);box-shadow:var(--shadow-md),var(--shadow-success-glow);color:#fff;display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);gap:var(--space-sm);justify-content:center;min-height:48px;padding:var(--space-md) var(--space-xl);transition:all var(--transition-normal)}.qr-scan-button:active{box-shadow:var(--shadow-sm);transform:scale(.96)}.session-indicator{align-items:center;background:#10b9811a;border:1px solid #10b9814d;border-radius:var(--radius-full);color:var(--color-success);display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);gap:var(--space-sm);padding:var(--space-sm) var(--space-md)}.session-icon{animation:pulse 2s ease-in-out infinite}.app-main{flex:1 1;padding-bottom:calc(var(--bottom-nav-height) + var(--sab) + var(--space-md));position:relative;z-index:1}.categories-container{-webkit-overflow-scrolling:touch;-ms-overflow-style:none;overflow-x:auto;padding:var(--space-md) 0;scrollbar-width:none}.categories-container::-webkit-scrollbar{display:none}.categories-list{display:flex;gap:var(--space-sm);padding:0 var(--space-md)}.category-chip{align-items:center;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-full);color:var(--color-text-secondary);display:flex;flex-shrink:0;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--space-xs);min-height:40px;padding:var(--space-sm) var(--space-md);transition:all var(--transition-fast)}.category-chip.active{background:var(--gradient-primary);border-color:var(--color-accent-primary);box-shadow:var(--shadow-glow);color:#fff}.category-chip:active{transform:scale(.95)}.category-count{background:#fff3;border-radius:var(--radius-full);font-size:var(--font-size-xs);padding:2px 8px}.vendor-list{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-md)}.vendor-card{animation:fadeInUp .4s ease-out backwards;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:var(--gradient-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-normal)}.vendor-card:first-child{animation-delay:0ms}.vendor-card:nth-child(2){animation-delay:50ms}.vendor-card:nth-child(3){animation-delay:.1s}.vendor-card:nth-child(4){animation-delay:.15s}.vendor-card:nth-child(5){animation-delay:.2s}.vendor-card:active{border-color:var(--color-accent-primary);transform:scale(.98)}.vendor-card-image{background:var(--color-bg-tertiary);height:140px;object-fit:cover;width:100%}.vendor-card-content{padding:var(--space-md)}.vendor-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:var(--space-sm)}.vendor-name{color:var(--color-text-primary);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);line-height:1.3}.vendor-rating{align-items:center;background:#fbbf2426;border-radius:var(--radius-sm);color:#fbbf24;display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);gap:var(--space-xs);padding:var(--space-xs) var(--space-sm)}.vendor-description{color:var(--color-text-tertiary);font-size:var(--font-size-sm);line-height:1.5;margin-bottom:var(--space-md)}.vendor-meta{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.vendor-tag{align-items:center;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);display:inline-flex;font-size:var(--font-size-xs);gap:var(--space-xs);padding:var(--space-xs) var(--space-sm)}.vendor-tag-success{background:#10b9811a;border-color:#10b98133;color:var(--color-success)}.vendor-cta{align-items:center;background:var(--gradient-primary);border-radius:var(--radius-md);color:#fff;display:flex;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);gap:var(--space-sm);justify-content:center;margin-top:var(--space-md);padding:var(--space-md);transition:all var(--transition-normal);width:100%}.vendor-cta:active{transform:scale(.98)}.no-results{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:var(--space-3xl) var(--space-lg);text-align:center}.no-results h3{color:var(--color-text-primary);font-size:var(--font-size-xl);margin-bottom:var(--space-sm)}.no-results p{color:var(--color-text-tertiary);margin-bottom:var(--space-lg);max-width:280px}.show-all-button{background:var(--gradient-primary);border-radius:var(--radius-full);color:#fff;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);padding:var(--space-md) var(--space-xl);transition:all var(--transition-normal)}.show-all-button:active{transform:scale(.96)}.error-container{align-items:center;background:var(--color-bg-primary);display:flex;flex-direction:column;justify-content:center;min-height:100vh;min-height:100dvh;padding:var(--space-xl);text-align:center}.error-container h2{color:var(--color-error);font-size:var(--font-size-2xl);margin-bottom:var(--space-md)}.error-container p{color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--space-xl);max-width:300px}.retry-button{background:var(--color-error);border-radius:var(--radius-full);color:#fff;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);padding:var(--space-md) var(--space-xl);transition:all var(--transition-normal)}.retry-button:active{opacity:.9;transform:scale(.96)}.app-footer{background:#0000;padding:var(--space-lg) var(--space-md);padding-bottom:calc(var(--bottom-nav-height) + var(--sab) + var(--space-lg));text-align:center}.footer-tagline{color:#ffffff4d;font-size:11px;font-weight:500;letter-spacing:.1em;margin:0 0 4px;text-transform:uppercase}.footer-count{color:#2379f0b3;font-size:12px;margin:0}.bottom-nav{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#0a0a0af2;border-top:1px solid var(--glass-border);bottom:0;height:var(--bottom-nav-height);justify-content:space-around;left:0;padding-bottom:var(--sab);position:fixed;right:0;z-index:1000}.bottom-nav,.nav-item{align-items:center;display:flex}.nav-item{color:var(--color-text-muted);flex-direction:column;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);gap:var(--space-xs);justify-content:center;min-width:64px;padding:var(--space-sm) var(--space-md);transition:all var(--transition-fast)}.nav-item.active{color:var(--color-accent-primary)}.nav-item:active{transform:scale(.9)}.nav-icon{font-size:1.5rem;line-height:1}.qr-overlay{align-items:center;animation:fadeIn .2s ease-out;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#000000e6;display:flex;inset:0;justify-content:center;padding:var(--space-md);position:fixed;z-index:2000}.qr-modal{animation:fadeInUp .3s ease-out;background:var(--color-bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-xl);max-width:360px;padding:var(--space-xl);text-align:center;width:100%}.qr-close{align-items:center;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-full);color:var(--color-text-secondary);display:flex;font-size:1.5rem;height:40px;justify-content:center;position:absolute;right:var(--space-md);top:var(--space-md);width:40px}.qr-scanner-frame{border:2px solid var(--color-accent-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-glow);height:200px;margin:var(--space-lg) auto;overflow:hidden;position:relative;width:200px}.qr-scanner-line{animation:scan 2s linear infinite;background:var(--color-accent-primary);box-shadow:0 0 10px var(--color-accent-primary);height:2px;left:0;position:absolute;right:0}@keyframes scan{0%{top:0}50%{top:calc(100% - 2px)}to{top:0}}.loading-container{align-items:center;background:var(--color-bg-primary);display:flex;flex-direction:column;justify-content:center;min-height:100vh;min-height:100dvh;padding:var(--space-xl)}.loading-spinner-large{animation:spin .8s linear infinite;border:3px solid var(--glass-border);border-radius:50%;border-top-color:var(--color-accent-primary);height:60px;margin-bottom:var(--space-lg);width:60px}.loading-text{color:var(--color-text-secondary);font-size:var(--font-size-base);max-width:250px;text-align:center}.install-prompt-overlay{align-items:flex-end;animation:fadeIn .2s ease-out;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#000c;display:flex;inset:0;justify-content:center;padding:var(--space-md);position:fixed;z-index:3000}.install-prompt-card{animation:slideInBottom .3s ease-out;background:var(--color-bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-width:400px;padding:var(--space-xl);padding-bottom:calc(var(--sab) + var(--space-xl));text-align:center;width:100%}.install-prompt-icon{align-items:center;background:var(--gradient-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-glow);display:flex;font-size:2rem;height:64px;justify-content:center;margin:0 auto var(--space-md);width:64px}.install-prompt-title{color:var(--color-text-primary);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-sm)}.install-prompt-desc{color:var(--color-text-tertiary);font-size:var(--font-size-sm);line-height:1.5;margin-bottom:var(--space-lg)}.install-prompt-buttons{display:flex;flex-direction:column;gap:var(--space-sm)}.install-button{background:var(--gradient-primary);border-radius:var(--radius-md);color:#fff;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);padding:var(--space-md);transition:all var(--transition-normal)}.install-button:active{transform:scale(.98)}.install-later{background:#0000;color:var(--color-text-tertiary);font-size:var(--font-size-sm);padding:var(--space-md)}.stagger-1{animation-delay:0ms}.stagger-2{animation-delay:50ms}.stagger-3{animation-delay:.1s}.stagger-4{animation-delay:.15s}.stagger-5{animation-delay:.2s}@media (min-width:414px){.header-content h1{font-size:var(--font-size-3xl)}.vendor-card-image{height:160px}}.loading-inline{align-items:center;display:flex;flex-direction:column;gap:var(--space-md);justify-content:center;padding:var(--space-3xl) var(--space-lg)}.loading-inline .loading-spinner{animation:spin .8s linear infinite;border:3px solid var(--glass-border);border-radius:50%;border-top-color:var(--color-accent-primary);height:40px;width:40px}.loading-inline p{color:var(--color-text-tertiary);font-size:var(--font-size-sm)}.station-code-badge{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);font-family:SF Mono,Monaco,Consolas,monospace;font-size:var(--font-size-xs);letter-spacing:.05em;margin-left:var(--space-sm);padding:var(--space-xs) var(--space-sm)}.enter-code-button{align-items:center;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-full);color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--space-sm);padding:var(--space-sm) var(--space-md);transition:all var(--transition-fast)}.enter-code-button:active{background:#ffffff1a;transform:scale(.95)}.app-footer .location-note{color:var(--color-accent-secondary)!important;font-size:var(--font-size-xs)!important;margin-top:var(--space-xs)}@media (min-width:768px){.vendor-list{grid-gap:var(--space-lg);display:grid;gap:var(--space-lg);grid-template-columns:repeat(2,1fr);padding:var(--space-lg)}.vendor-card{animation-delay:0ms!important}}
/*# sourceMappingURL=main.77b9c18a.css.map*/