@import"https://fonts.googleapis.com/css2?family=Work+Sans:wght@200;300;400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #FFFFFF;--color-bg-secondary: #F8F9FA;--color-bg-card: #F4F4F4;--color-primary: #081A2B;--color-text: #081A2B;--color-text-muted: rgba(8, 26, 43, .6);--color-border: #EBEBEB;--color-divider: rgba(8, 26, 43, .1);--color-cta-start: #B93C42;--color-cta-end: #99034F;--gradient-cta: linear-gradient(90deg, #B93C42 0%, #99034F 100%);--gradient-sparkle: linear-gradient(90deg, #05B1D3 0%, #566BDD 27.88%, #9720DD 50%, #FA6D3F 74.52%, #F8DB00 100%);--gradient-ring: linear-gradient(90deg, #F8DB00 .24%, #FA6D3F 24.56%, #CE409B 41.44%, #9720DD 61.3%, #566BDD 82.81%, #204FB4 100%);--font-primary: "Work Sans", system-ui, -apple-system, sans-serif;--spacing-xs: .5rem;--spacing-sm: 1rem;--spacing-md: 1.5rem;--spacing-lg: 2rem;--spacing-xl: 3rem;--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);--container-max: 480px;--container-padding: 1.5rem}html{overscroll-behavior:none}html,body,#root{height:100%;margin:0;padding:0}body{font-family:var(--font-primary);font-weight:400;background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;min-height:-webkit-fill-available;-webkit-user-select:none;user-select:none;overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch}input,textarea{-webkit-user-select:text;user-select:text}*{-webkit-tap-highlight-color:transparent}.app,.login-page,.countdown-page,.settings-page,.jahresprogramm-page,.voice-chat-page,.payment-page,.jp-snap-page,.call-booking-page{width:100%;max-width:var(--container-max);min-height:100vh;margin:0 auto;background:var(--color-bg);display:flex;flex-direction:column;position:relative}@media (min-width: 768px){body{background:var(--color-bg);padding:var(--spacing-lg) 0}.app,.login-page,.countdown-page,.settings-page,.jahresprogramm-page,.voice-chat-page,.payment-page,.jp-snap-page,.call-booking-page{min-height:calc(100vh - 4rem);border-radius:24px;box-shadow:0 4px 24px #081a2b14;overflow:hidden}}.header,.page-header,.login-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--container-padding);padding-top:calc(var(--spacing-sm) + var(--safe-area-top));position:relative;z-index:10}.login-header{justify-content:center}.logo-group{display:flex;align-items:center;gap:.75rem}.logo-sparkle{width:40px;height:40px;background:var(--gradient-sparkle);-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 256 256'%3E%3Cpath d='M208,144a15.78,15.78,0,0,1-10.42,14.94L146,178l-19.06,51.62a15.92,15.92,0,0,1-29.88,0L78,178l-51.62-19a15.92,15.92,0,0,1,0-29.88L78,110l19.06-51.62a15.92,15.92,0,0,1,29.88,0L146,110l51.62,19.06A15.78,15.78,0,0,1,208,144Z'/%3E%3C/svg%3E") center/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 256 256'%3E%3Cpath d='M208,144a15.78,15.78,0,0,1-10.42,14.94L146,178l-19.06,51.62a15.92,15.92,0,0,1-29.88,0L78,178l-51.62-19a15.92,15.92,0,0,1,0-29.88L78,110l19.06-51.62a15.92,15.92,0,0,1,29.88,0L146,110l51.62,19.06A15.78,15.78,0,0,1,208,144Z'/%3E%3C/svg%3E") center/contain no-repeat}.logo-text{font-weight:700;font-size:1.25rem;color:var(--color-primary)}.menu-btn,.back-btn{background:none;border:none;padding:.5rem;cursor:pointer;color:var(--color-primary);display:flex;align-items:center;justify-content:center}.menu-btn svg,.back-btn svg{width:24px;height:24px}.page-title{font-size:1.25rem;font-weight:500;letter-spacing:.5px;color:var(--color-primary);text-align:center;flex:1}.divider{height:1px;background:var(--color-divider);margin:0 var(--container-padding)}.snowflakes{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;overflow:hidden;z-index:1}.snowflake-animated{position:absolute;top:-60px;color:#9bcdf51f;pointer-events:none;animation:snowfall linear infinite;will-change:transform}.snowflake-animated svg{width:100%;height:100%;fill:currentColor;animation:snowflakeSpin 8s linear infinite}@keyframes snowfall{0%{transform:translateY(-60px) translate(0)}to{transform:translateY(110vh) translate(0)}}@keyframes snowflakeSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hero-image{width:100%;height:320px;overflow:hidden;position:relative;z-index:2}.hero-image img{width:100%;height:100%;object-fit:contain;object-position:center;-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 15%,black 85%,transparent 100%);mask-image:linear-gradient(to bottom,transparent 0%,black 15%,black 85%,transparent 100%)}.hero-content{padding:var(--spacing-md) var(--container-padding);text-align:center;position:relative;z-index:5}.hero-title{font-size:1.75rem;font-weight:500;line-height:1.2;letter-spacing:.5px;color:var(--color-primary);margin-bottom:var(--spacing-sm)}.hero-description{font-size:.9rem;font-weight:300;line-height:1.6;color:var(--color-text-muted);max-width:320px;margin:0 auto var(--spacing-md)}.swipe-cta{position:relative;width:calc(100% - 3rem);max-width:320px;height:56px;margin:0 auto var(--spacing-lg);background:var(--color-bg-card);border-radius:28px;border:none;overflow:hidden;cursor:pointer;touch-action:pan-x;z-index:10;-webkit-user-select:none;user-select:none}.swipe-cta-completed{pointer-events:none}.swipe-cta-slider{position:absolute;left:4px;top:4px;bottom:4px;width:80px;background:var(--gradient-cta);border-radius:24px;display:flex;align-items:center;justify-content:center;cursor:grab;z-index:2;will-change:transform;transition:box-shadow .2s ease}.swipe-cta-slider-dragging{cursor:grabbing;transform:scale(1.02)}.swipe-cta-arrow{display:flex;align-items:center;justify-content:center;color:#fff}.swipe-cta-arrow svg{width:24px;height:24px}.swipe-cta-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;color:var(--color-primary);padding-left:2.5rem;z-index:1;transition:opacity .1s ease;pointer-events:none}.cta-button,.jp-cta-button,.jp-snap-cta,.checkout-cta-button,.login-submit-btn,.payment-result-button{display:flex;align-items:center;justify-content:center;width:calc(100% - 3rem);max-width:320px;height:52px;margin:var(--spacing-sm) auto;background:var(--gradient-cta);border:none;border-radius:26px;font-family:var(--font-primary);font-size:1rem;font-weight:500;letter-spacing:.02em;color:#fff;cursor:pointer;transition:transform .2s,box-shadow .2s}.cta-button:hover:not(:disabled),.jp-cta-button:hover:not(:disabled),.jp-snap-cta:hover:not(:disabled),.checkout-cta-button:hover:not(:disabled),.login-submit-btn:hover:not(:disabled),.payment-result-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #b93c4259}.cta-button:active:not(:disabled),.login-submit-btn:active:not(:disabled){transform:translateY(0)}.cta-button:disabled,.login-submit-btn:disabled,.checkout-cta-button:disabled{opacity:.6;cursor:not-allowed}.countdown-page{overflow-y:auto}.profile-circle-container{display:flex;justify-content:center;padding:var(--spacing-lg) 0;position:relative;z-index:5}.profile-ring-wrapper{position:relative;width:220px;height:220px}.progress-ring{position:absolute;top:-8px;left:-8px;width:calc(100% + 16px);height:calc(100% + 16px);pointer-events:none}.progress-ring-fill{z-index:1}.progress-ring-circle{transition:stroke-dashoffset 1s ease-out}.profile-circle{width:100%;height:100%;border-radius:50%;overflow:hidden;background:var(--color-bg)}.profile-circle img{width:100%;height:100%;object-fit:cover;object-position:center top}.countdown-content{text-align:center;padding:var(--spacing-sm) var(--container-padding);position:relative;z-index:5}.countdown-label-small,.countdown-label-large{font-size:.9rem;font-weight:400;color:var(--color-primary);margin-bottom:var(--spacing-xs)}.countdown-timer-large{display:flex;justify-content:center;align-items:flex-start;gap:.25rem;margin:var(--spacing-sm) auto}.countdown-unit{display:flex;flex-direction:column;align-items:center;min-width:60px}.countdown-number{font-size:2.5rem;font-weight:500;line-height:1.2;letter-spacing:1px;color:var(--color-primary)}.countdown-label{font-size:.85rem;font-weight:400;color:var(--color-text-muted)}.countdown-separator{font-size:2.5rem;font-weight:500;color:var(--color-primary);margin-top:.1rem}.menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;z-index:100}.menu-backdrop-open{opacity:1;visibility:visible}.menu-panel{position:fixed;top:0;right:0;bottom:0;width:100%;max-width:360px;background:var(--color-bg);transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:101;display:flex;flex-direction:column;overflow-y:auto}.menu-panel-open{transform:translate(0)}.menu-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--container-padding);padding-top:calc(var(--spacing-sm) + var(--safe-area-top))}.menu-close-btn{background:none;border:none;padding:.5rem;cursor:pointer;color:var(--color-primary);display:flex;align-items:center;justify-content:center}.menu-close-btn svg{width:24px;height:24px}.menu-nav{flex:1;display:flex;flex-direction:column;padding:var(--spacing-lg) var(--container-padding);gap:var(--spacing-md)}.menu-item{display:flex;align-items:center;gap:.75rem;padding:0;background:none;border:none;cursor:pointer;text-align:left;transition:opacity .2s ease}.menu-item:hover{opacity:.7}.menu-item-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-primary)}.menu-item-icon svg{width:28px;height:28px;stroke:var(--color-primary)}.menu-item-label{font-size:1.25rem;font-weight:500;letter-spacing:.5px;color:var(--color-primary)}.menu-footer{padding:var(--spacing-md) var(--container-padding);padding-bottom:calc(var(--spacing-md) + var(--safe-area-bottom))}.menu-footer-links{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-sm)}.menu-footer-links a{font-size:.875rem;color:var(--color-text-muted);text-decoration:none;transition:color .2s}.menu-footer-links a:hover{color:var(--color-primary)}.menu-footer-separator{display:none}.menu-footer-copyright{font-size:.875rem;color:var(--color-text-muted)}.settings-content{flex:1;padding:var(--spacing-md) var(--container-padding);overflow-y:auto}.settings-section{margin-bottom:var(--spacing-lg)}.settings-section-title{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:1px;color:var(--color-text-muted);margin-bottom:var(--spacing-xs);padding-left:.5rem}.settings-group{background:var(--color-bg-card);border-radius:16px;overflow:hidden}.settings-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:1rem 1.25rem;background:none;border:none;border-bottom:1px solid var(--color-divider);cursor:pointer;text-align:left;transition:background .2s}.settings-item:last-child{border-bottom:none}.settings-item:hover{background:#00000005}.settings-item-label{font-size:1rem;font-weight:400;color:var(--color-primary)}.settings-toggle{width:52px;height:28px;background:#0000001a;border-radius:14px;position:relative;transition:background .2s}.settings-toggle-on{background:var(--gradient-cta)}.settings-toggle-thumb{position:absolute;top:2px;left:2px;width:24px;height:24px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 2px 4px #0003}.settings-toggle-on .settings-toggle-thumb{transform:translate(24px)}.settings-logout-btn{width:100%;padding:1rem;margin-top:var(--spacing-sm);background:#b93c421a;border:1px solid var(--color-cta-start);border-radius:12px;font-family:var(--font-primary);font-size:1rem;font-weight:500;color:var(--color-cta-start);cursor:pointer;transition:background .2s}.settings-logout-btn:hover{background:#b93c4233}.settings-version{text-align:center;font-size:.75rem;color:var(--color-text-muted);margin-top:var(--spacing-lg);padding-bottom:var(--spacing-lg)}.jp-snap-page{height:100vh;overflow:hidden}@media (min-width: 768px){.jp-snap-page{height:calc(100vh - 4rem)}}.jp-snap-header{position:absolute;top:0;left:0;right:0;z-index:20;display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--container-padding);padding-top:calc(var(--spacing-sm) + var(--safe-area-top));background:linear-gradient(180deg,var(--color-bg) 0%,rgba(255,255,255,.9) 70%,transparent 100%)}.jp-snap-indicators{position:fixed;right:calc(50% - min(50vw,240px) + 12px);top:50%;transform:translateY(-50%);z-index:15;display:flex;flex-direction:column;gap:8px}@media (max-width: 767px){.jp-snap-indicators{right:12px}}.jp-snap-dot{width:8px;height:8px;border-radius:50%;background:#081a2b33;border:none;cursor:pointer;transition:all .3s ease;padding:0}.jp-snap-dot-active{background:var(--color-primary);transform:scale(1.25)}.jp-snap-container{flex:1;overflow-y:auto;scroll-snap-type:y mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.jp-snap-container::-webkit-scrollbar{display:none}.jp-snap-slide{height:100vh;scroll-snap-align:start;scroll-snap-stop:always;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:80px var(--container-padding) 60px;position:relative}@media (min-width: 768px){.jp-snap-slide{height:calc(100vh - 4rem)}}.jp-snap-content{display:flex;flex-direction:column;align-items:center;text-align:center;width:100%;max-width:340px}.jp-snap-title{font-size:1.75rem;font-weight:500;line-height:1.2;letter-spacing:.5px;color:var(--color-primary);margin-bottom:.5rem}.jp-snap-subtitle{font-size:1rem;font-weight:400;color:var(--color-text-muted);margin-bottom:var(--spacing-md)}.jp-snap-section-title{font-size:1.5rem;font-weight:500;letter-spacing:.5px;color:var(--color-primary);margin-bottom:var(--spacing-md)}.jp-snap-text{display:flex;flex-direction:column;gap:1rem;margin-bottom:var(--spacing-md)}.jp-snap-text p{font-size:.9rem;line-height:1.6;color:var(--color-primary);margin:0}.jp-snap-highlight{font-weight:500;background:var(--color-bg-card);padding:.75rem 1rem;border-radius:8px;border-left:3px solid var(--color-cta-start)}.jp-snap-image{width:100%;max-width:280px;margin:var(--spacing-sm) 0;border-radius:12px;overflow:hidden}.jp-snap-image img{width:100%;height:auto;object-fit:contain;display:block}.jp-snap-scroll-hint{position:absolute;bottom:24px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:4px;background:none;border:none;cursor:pointer;color:var(--color-text-muted);animation:bounceHint 2s ease-in-out infinite}.jp-snap-scroll-hint span{font-size:.75rem}@keyframes bounceHint{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(8px)}}.jp-snap-benefits{background:var(--color-bg-card);border-radius:12px;padding:1rem 1.25rem;margin-bottom:var(--spacing-md);width:100%;text-align:left}.jp-snap-benefits-intro{font-size:.85rem;color:var(--color-text-muted);margin-bottom:.75rem}.jp-snap-benefits ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.jp-snap-benefits li{font-size:.9rem;color:var(--color-primary);padding-left:1.25rem;position:relative}.jp-snap-benefits li:before{content:"✓";position:absolute;left:0;color:#4caf50;font-weight:500}.jp-snap-intro{font-size:.9rem;color:var(--color-text-muted);margin-bottom:var(--spacing-sm)}.jp-snap-steps{display:flex;flex-direction:column;gap:12px;width:100%;margin-bottom:var(--spacing-md)}.jp-snap-step{display:flex;align-items:flex-start;gap:12px;background:var(--color-bg-card);border-radius:10px;padding:12px 14px;text-align:left}.jp-snap-step-num{width:28px;height:28px;min-width:28px;border-radius:50%;background:var(--gradient-cta);display:flex;align-items:center;justify-content:center;font-weight:500;font-size:.875rem;color:#fff}.jp-snap-step h3{font-size:1rem;font-weight:500;color:var(--color-primary);margin:0 0 2px}.jp-snap-step p{font-size:.8rem;line-height:1.4;color:var(--color-text-muted);margin:0}.jp-snap-final-cta{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);width:100%}.jp-snap-price{font-size:1rem;color:var(--color-primary);margin:0}.jp-header-logo{display:flex;align-items:center;gap:.5rem}.voice-chat-content{flex:1;display:flex;flex-direction:column;align-items:center;padding:var(--spacing-lg) var(--container-padding)}.voice-avatar-container{margin-bottom:var(--spacing-md)}.voice-avatar-ring{width:160px;height:160px;border-radius:50%;padding:4px;background:linear-gradient(135deg,#ffffff1a,#ffffff0d);transition:all .3s ease}.voice-avatar-ring-listening{padding:6px;background:var(--gradient-sparkle);animation:pulseRing 1s ease-in-out infinite}.voice-avatar-ring-speaking{padding:6px;background:linear-gradient(90deg,#f8db00,#fa6d3f,#9720dd);animation:pulseRing 1.5s ease-in-out infinite}@keyframes pulseRing{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}.voice-avatar{width:100%;height:100%;border-radius:50%;overflow:hidden;background:var(--color-bg)}.voice-avatar img{width:100%;height:100%;object-fit:cover;object-position:center top}.voice-status{text-align:center;margin-bottom:var(--spacing-lg)}.voice-name{font-size:1.5rem;font-weight:500;color:var(--color-primary);margin-bottom:.25rem}.voice-subtitle{font-size:.9rem;color:var(--color-text-muted)}.voice-instructions{text-align:center;max-width:300px;margin-bottom:var(--spacing-lg)}.voice-instructions p{font-size:.9rem;color:var(--color-text-muted);line-height:1.6;margin-bottom:var(--spacing-md)}.voice-tips{list-style:none;padding:0;margin:0;text-align:left}.voice-tips li{font-size:.85rem;color:var(--color-primary);padding:.5rem 0 .5rem 1.5rem;position:relative}.voice-tips li:before{content:"•";position:absolute;left:0;color:var(--color-cta-start)}.voice-mic-btn{position:relative;width:80px;height:80px;border-radius:50%;background:var(--gradient-cta);border:none;cursor:pointer;transition:transform .2s,box-shadow .2s;margin:var(--spacing-sm) 0 var(--spacing-lg);overflow:hidden}.voice-mic-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 8px 32px #b93c4280}.voice-mic-btn:disabled{opacity:.7;cursor:not-allowed}.voice-mic-btn-active{animation:micPulse 1s ease-in-out infinite}.voice-mic-btn-processing{background:linear-gradient(90deg,#566bdd,#9720dd);animation:micProcessing 1.5s linear infinite}@keyframes micPulse{0%,to{box-shadow:0 0 #c41e3a99}50%{box-shadow:0 0 0 20px #c41e3a00}}@keyframes micProcessing{0%{filter:hue-rotate(0deg)}to{filter:hue-rotate(360deg)}}.voice-mic-btn-icon{display:flex;align-items:center;justify-content:center;position:relative;z-index:2}.voice-mic-btn-ripple{position:absolute;top:50%;left:50%;width:100%;height:100%;transform:translate(-50%,-50%);border-radius:50%;background:#fff3;opacity:0;pointer-events:none}.voice-mic-btn-active .voice-mic-btn-ripple{animation:rippleEffect 1s ease-out infinite}@keyframes rippleEffect{0%{transform:translate(-50%,-50%) scale(.8);opacity:.4}to{transform:translate(-50%,-50%) scale(1.5);opacity:0}}.voice-subtitle-container{max-width:320px;padding:1rem 1.5rem;background:var(--color-bg-card);border-radius:16px;animation:subtitleFadeIn .4s ease-out}.voice-subtitle-text{font-size:.9rem;color:var(--color-primary);line-height:1.5;text-align:center;margin:0}@keyframes subtitleFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.checkout-content{flex:1;display:flex;flex-direction:column;padding:var(--spacing-sm) var(--container-padding) var(--spacing-lg);overflow-y:auto}.checkout-product-card{display:flex;gap:1rem;background:var(--color-bg-card);border-radius:12px;padding:1rem;margin-bottom:var(--spacing-md)}.checkout-product-image{width:80px;height:80px;border-radius:8px;overflow:hidden;flex-shrink:0}.checkout-product-image img{width:100%;height:100%;object-fit:cover}.checkout-product-info{flex:1;display:flex;flex-direction:column;justify-content:center}.checkout-product-title{font-size:1rem;font-weight:500;color:var(--color-primary);margin:0 0 4px}.checkout-product-desc{font-size:.85rem;color:var(--color-text-muted);margin:0}.checkout-price-section{background:var(--color-bg-card);border-radius:12px;padding:1rem;margin-bottom:var(--spacing-md)}.checkout-price-row{display:flex;justify-content:space-between;font-size:.9rem;color:var(--color-text-muted);padding:.5rem 0}.checkout-price-row:not(:last-child){border-bottom:1px solid var(--color-border)}.checkout-price-total{font-weight:500;font-size:1.1rem;color:var(--color-primary);padding-top:.75rem}.checkout-features{margin-bottom:var(--spacing-md)}.checkout-features h3{font-size:1rem;font-weight:500;color:var(--color-primary);margin:0 0 .75rem}.checkout-features ul{list-style:none;padding:0;margin:0}.checkout-features li{font-size:.9rem;color:var(--color-primary);padding:.5rem 0 .5rem 1.5rem;position:relative}.checkout-features li:before{content:"✓";position:absolute;left:0;color:#4caf50;font-weight:500}.checkout-secure-info{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.75rem;color:var(--color-text-muted);margin-bottom:var(--spacing-sm)}.checkout-secure-info svg{opacity:.7;color:var(--color-primary)}.checkout-spinner{width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.checkout-terms{font-size:.7rem;color:var(--color-text-muted);text-align:center;margin:0}.payment-result-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.payment-result-modal{background:var(--color-bg);border-radius:20px;padding:var(--spacing-lg);max-width:300px;width:90%;text-align:center;animation:slideUp .3s ease-out;box-shadow:0 10px 40px #0003}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.payment-result-icon{margin-bottom:var(--spacing-md);animation:iconPop .5s cubic-bezier(.68,-.55,.265,1.55)}.payment-result-title{font-size:1.5rem;font-weight:500;color:var(--color-primary);margin:0 0 var(--spacing-sm) 0}.payment-result-message{font-size:.9rem;line-height:1.6;color:var(--color-text-muted);margin:0 0 var(--spacing-md) 0}.login-content{flex:1;display:flex;flex-direction:column;padding:var(--spacing-lg) var(--container-padding);position:relative;z-index:2}.login-title{font-size:1.75rem;font-weight:500;text-align:center;color:var(--color-primary);margin-bottom:var(--spacing-sm)}.login-description{font-size:.9rem;text-align:center;color:var(--color-text-muted);line-height:1.6;margin-bottom:var(--spacing-md)}.login-mode-toggle{display:flex;background:var(--color-bg-card);border-radius:25px;padding:4px;margin-bottom:var(--spacing-md)}.login-mode-btn{flex:1;padding:10px 16px;border:none;border-radius:22px;font-family:var(--font-primary);font-size:.9rem;color:var(--color-text-muted);background:transparent;cursor:pointer;transition:all .2s ease}.login-mode-btn.active{background:var(--color-primary);color:#fff;font-weight:500;box-shadow:0 2px 8px #081a2b33}.login-form{display:flex;flex-direction:column;gap:var(--spacing-sm)}.login-input{width:100%;padding:14px 18px;border:1px solid var(--color-border);border-radius:12px;font-family:var(--font-primary);font-size:1rem;color:var(--color-primary);background:var(--color-bg-card);transition:border-color .2s,box-shadow .2s}.login-input:focus{outline:none;border-color:#081a2b4d;box-shadow:0 0 0 3px #081a2b1a}.login-input::placeholder{color:var(--color-text-muted)}.login-error{color:#ff6b6b;font-size:.85rem;text-align:center;margin:0}.login-sent{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-lg) 0;animation:loginFadeIn .4s ease-out forwards}@keyframes loginFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-sent-icon{width:80px;height:80px;background:var(--color-bg-card);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-md);animation:iconPop .5s cubic-bezier(.68,-.55,.265,1.55) forwards}@keyframes iconPop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.login-sent-icon svg{width:48px;height:48px}.login-sent-icon svg path{fill:var(--color-primary)}.login-sent-title{font-size:1.5rem;font-weight:500;color:var(--color-primary);margin-bottom:var(--spacing-sm)}.login-sent-text{font-size:.9rem;line-height:1.6;color:var(--color-text-muted);margin-bottom:var(--spacing-md)}.login-sent-text strong{font-weight:500;color:var(--color-primary)}.login-reset-btn{padding:10px 20px;background:transparent;border:1px solid var(--color-border);border-radius:20px;font-family:var(--font-primary);font-size:.9rem;color:var(--color-text-muted);cursor:pointer;transition:all .2s}.login-reset-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.login-toggle-btn{margin-top:var(--spacing-sm);padding:8px 16px;background:transparent;border:none;font-family:var(--font-primary);font-size:.9rem;color:var(--color-text-muted);cursor:pointer;text-decoration:underline;transition:color .2s}.login-toggle-btn:hover{color:var(--color-primary)}.call-booking-content{flex:1;display:flex;flex-direction:column;padding:var(--spacing-md) var(--container-padding);padding-bottom:calc(var(--spacing-xl) + var(--safe-area-bottom));overflow-y:auto;background:var(--color-bg);min-height:0}.call-booking-page{background:var(--color-bg)}.booking-intro{text-align:center;margin-bottom:var(--spacing-md)}.booking-intro h2{font-size:1.5rem;font-weight:500;color:var(--color-primary);margin:0 0 var(--spacing-xs) 0}.booking-intro p{font-size:.9rem;color:var(--color-text-muted);margin:0}.booking-back-link{background:none;border:none;font-family:var(--font-primary);font-size:.85rem;color:var(--color-text-muted);cursor:pointer;padding:0;margin-bottom:var(--spacing-sm);transition:color .2s}.booking-back-link:hover{color:var(--color-primary)}.booking-dates{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}.booking-date-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--spacing-sm);background:var(--color-bg-card);border:2px solid transparent;border-radius:12px;cursor:pointer;transition:all .2s ease}.booking-date-card:hover{border-color:var(--color-primary);transform:translateY(-2px)}.booking-date-day{font-size:1rem;font-weight:500;color:var(--color-primary)}.booking-date-slots{font-size:.8rem;color:var(--color-text-muted)}.booking-unified{display:flex;flex-direction:column;gap:var(--spacing-md)}.booking-section{border-bottom:1px solid var(--color-divider);padding-bottom:var(--spacing-sm)}.booking-section:last-of-type{border-bottom:none}.booking-section-label{font-size:.7rem;font-weight:600;letter-spacing:1.5px;color:var(--color-cta-start);margin-bottom:4px}.booking-section-value{font-size:1rem;font-weight:500;color:var(--color-primary)}.calendar-container{background:var(--color-bg);border-radius:12px;padding:var(--spacing-xs) 0}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm)}.calendar-month{font-size:1rem;font-weight:500;color:var(--color-primary)}.calendar-nav{background:none;border:none;padding:8px;cursor:pointer;color:var(--color-text-muted);border-radius:8px;transition:all .2s}.calendar-nav:hover{background:var(--color-bg-card);color:var(--color-primary)}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:8px}.calendar-weekday{font-size:.75rem;font-weight:500;color:var(--color-text-muted);text-align:center;padding:4px 0}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:400;color:var(--color-text-muted);background:none;border:none;border-radius:50%;cursor:pointer;transition:all .15s}.calendar-day-empty{cursor:default}.calendar-day-past{color:#081a2b40;cursor:not-allowed}.calendar-day-future{color:var(--color-text-muted);cursor:pointer}.calendar-day-future:hover{background:var(--color-bg-card)}.calendar-day-available{color:var(--color-primary);font-weight:500}.calendar-day-available:hover{background:var(--color-bg-card)}.calendar-day-selected{background:var(--color-cta-start);color:#fff;font-weight:600}.calendar-day-selected:hover{background:var(--color-cta-start)}.calendar-day-today{position:relative}.calendar-day-today:after{content:"";position:absolute;bottom:4px;left:50%;transform:translate(-50%);width:4px;height:4px;background:var(--color-cta-start);border-radius:50%}.calendar-day-selected.calendar-day-today:after{background:#fff}.time-slots-wrapper{display:flex;flex-direction:column;align-items:center;gap:8px}.time-slots-scroll-btn{width:100%;padding:6px;background:var(--color-bg-card);border:none;border-radius:8px;color:var(--color-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.time-slots-scroll-btn:hover{background:var(--color-divider)}.time-slots-scroll-btn:active{background:var(--color-cta-start);color:#fff}.time-slots-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;max-height:180px;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;width:100%}.time-slots-grid::-webkit-scrollbar{display:none}.time-slot-btn{padding:10px 8px;background:var(--color-bg-card);border:2px solid transparent;border-radius:8px;font-family:var(--font-primary);font-size:.85rem;font-weight:500;color:var(--color-primary);cursor:pointer;transition:all .15s}.time-slot-btn:hover{border-color:var(--color-primary)}.time-slot-btn-selected{background:var(--color-cta-start);color:#fff;border-color:var(--color-cta-start)}.time-slot-btn-selected:hover{border-color:var(--color-cta-start)}.no-slots-msg{font-size:.9rem;color:var(--color-text-muted);text-align:center;padding:var(--spacing-sm) 0}.booking-notes{width:100%;padding:12px 14px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:10px;font-family:var(--font-primary);font-size:.9rem;color:var(--color-primary);resize:none;transition:border-color .2s}.booking-notes:focus{outline:none;border-color:var(--color-primary)}.booking-notes::placeholder{color:var(--color-text-muted)}.booking-unified .cta-button{margin-top:var(--spacing-sm)}.booking-form{display:flex;flex-direction:column;gap:var(--spacing-sm)}.booking-form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}.booking-input{width:100%;padding:14px 16px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;font-family:var(--font-primary);font-size:1rem;color:var(--color-primary);transition:border-color .2s,box-shadow .2s}.booking-input:focus{outline:none;border-color:#081a2b4d;box-shadow:0 0 0 3px #081a2b1a}.booking-input::placeholder{color:var(--color-text-muted)}.booking-textarea{resize:none;min-height:80px}.booking-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-xl) 0}.booking-loading p{font-size:.9rem;color:var(--color-text-muted)}.booking-spinner{width:40px;height:40px;border:3px solid var(--color-bg-card);border-top-color:var(--color-cta-start);border-radius:50%;animation:spin .8s linear infinite}.booking-success,.booking-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--spacing-lg) 0}.booking-success-icon,.booking-error-icon{margin-bottom:var(--spacing-md);animation:iconPop .5s cubic-bezier(.68,-.55,.265,1.55)}.booking-success-title,.booking-error-title{font-size:1.5rem;font-weight:500;color:var(--color-primary);margin:0 0 var(--spacing-sm) 0}.booking-success-text,.booking-error-text{font-size:.9rem;color:var(--color-text-muted);line-height:1.6;margin:0 0 var(--spacing-xs) 0}.booking-success-subtext{font-size:.85rem;color:var(--color-text-muted);margin:0 0 var(--spacing-md) 0}.booking-no-slots{text-align:center;padding:var(--spacing-lg) 0}.booking-no-slots p{color:var(--color-text-muted);margin-bottom:var(--spacing-md)}.booking-refresh-btn{padding:10px 20px;background:transparent;border:1px solid var(--color-border);border-radius:20px;font-family:var(--font-primary);font-size:.9rem;color:var(--color-text-muted);cursor:pointer;transition:all .2s}.booking-refresh-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.booking-error-msg{color:#ff6b6b;font-size:.85rem;text-align:center;margin-bottom:var(--spacing-sm)}.page-enter{animation:pageEnter .4s ease-out forwards}.page-exit{animation:pageExit .3s ease-in forwards}@keyframes pageEnter{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes pageExit{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-20px)}}.auth-enter{animation:authEnter .5s cubic-bezier(.22,1,.36,1) forwards}@keyframes authEnter{0%{opacity:0;transform:scale(.98) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.spacer{flex:1}.profile-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;animation:fadeIn .2s ease}.profile-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:calc(100% - 32px);max-width:480px;max-height:calc(100vh - 64px);background:var(--color-bg);border-radius:16px;z-index:1001;display:flex;flex-direction:column;animation:modalSlideIn .3s ease;overflow:hidden}@keyframes modalSlideIn{0%{opacity:0;transform:translate(-50%,-48%)}to{opacity:1;transform:translate(-50%,-50%)}}.profile-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-divider)}.profile-modal-header h2{font-size:1.1rem;font-weight:600;color:var(--color-primary);margin:0}.profile-modal-close{width:36px;height:36px;border:none;background:var(--color-bg-card);border-radius:50%;color:var(--color-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.profile-modal-close:hover{background:var(--color-divider)}.profile-modal-content{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.profile-loading,.profile-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-xl) 0;text-align:center}.profile-loading p,.profile-error p{color:var(--color-text-muted);font-size:.9rem}.profile-retry-btn{padding:10px 20px;background:var(--color-cta-start);color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer}.profile-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.profile-form-row{display:flex;gap:var(--spacing-sm)}.profile-form-group{flex:1;display:flex;flex-direction:column;gap:4px}.profile-form-group-large{flex:2}.profile-form-group label{font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.profile-form-group input{padding:12px;background:var(--color-bg-card);border:1px solid transparent;border-radius:8px;font-family:var(--font-primary);font-size:.95rem;color:var(--color-primary);transition:border-color .2s,box-shadow .2s}.profile-form-group input:focus{outline:none;border-color:var(--color-cta-start);box-shadow:0 0 0 3px #b93c421a}.profile-form-group input::placeholder{color:var(--color-text-muted)}.profile-input-disabled{opacity:.6;cursor:not-allowed}.profile-input-hint{font-size:.7rem;color:var(--color-text-muted)}.profile-message{padding:10px 12px;border-radius:8px;font-size:.85rem;text-align:center}.profile-message-error{background:#ff6b6b1a;color:#ff6b6b}.profile-message-success{background:#4caf501a;color:#4caf50}.profile-save-btn{padding:14px;background:linear-gradient(135deg,var(--color-cta-start),var(--color-cta-end));color:#fff;border:none;border-radius:12px;font-family:var(--font-primary);font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:var(--spacing-sm)}.profile-save-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #b93c424d}.profile-save-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.desktop-qr-block{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#0a0a0a,#1a1a2e,#0a0a0a);display:flex;align-items:center;justify-content:center;z-index:9999}.desktop-qr-content{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-xl);max-width:400px}.desktop-qr-logo{display:flex;align-items:center;gap:.75rem;margin-bottom:var(--spacing-xl)}.desktop-qr-logo .logo-sparkle{width:48px;height:48px}.desktop-qr-logo .logo-text{font-size:1.5rem;color:#fff}.desktop-qr-title{font-size:1.5rem;font-weight:500;color:#fff;margin:0 0 var(--spacing-sm) 0;line-height:1.3}.desktop-qr-description{font-size:1rem;color:#ffffffb3;margin:0 0 var(--spacing-lg) 0;line-height:1.5}.desktop-qr-code{width:200px;height:200px;background:#fff;border-radius:16px;padding:16px;margin-bottom:var(--spacing-md);box-shadow:0 8px 32px #0000004d}.desktop-qr-code img{width:100%;height:100%;object-fit:contain}.desktop-qr-url{font-size:.85rem;color:#ffffff80;margin:0;word-break:break-all}
