.login-page-container{display:flex;height:100vh;width:100%;background-color:#fff;overflow:hidden}.login-hero-section{flex:1;background-color:#f5f5f5;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:40px}.login-hero-section:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(120deg,#ffffff24,#0078d42e);mix-blend-mode:screen;animation:shimmerMove 8s linear infinite}.login-hero-image{width:100%;height:100%;object-fit:cover;transform:scale(1.03);animation:heroFloat 9s ease-in-out infinite}.hero-glow-orb{position:absolute;width:240px;height:240px;border-radius:999px;background:radial-gradient(circle,#00a4ef59,#00a4ef00 70%);right:8%;bottom:12%;filter:blur(4px);animation:pulseGlow 5s ease-in-out infinite}.login-form-section{flex:1;display:flex;align-items:center;justify-content:center;padding:40px;background-color:#fafafa}.login-form-card{width:100%;max-width:480px;background:#fff;padding:40px;border-radius:12px;box-shadow:0 2px 8px #0000000d;border:1px solid rgba(0,0,0,.05);animation:cardReveal .7s ease both}.login-form-header{margin-bottom:40px;text-align:center}.login-intro-badge{display:inline-flex;align-items:center;justify-content:center;padding:6px 14px;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#0078d4;background:#0078d41a;border:1px solid rgba(0,120,212,.22);border-radius:999px;margin-bottom:14px}.login-form-title{font-size:32px;font-weight:700;color:#000;margin-bottom:12px}.login-form-subtitle{font-size:14px;color:#666;line-height:1.5}.login-form-content{display:flex;flex-direction:column;gap:20px}.microsoft-login-button{padding:14px 24px;background:linear-gradient(135deg,#00a4ef,#0078d4);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:12px;position:relative;overflow:hidden}.microsoft-login-button:before{content:"";position:absolute;top:0;left:-120%;width:70%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);transition:left .6s ease}.microsoft-login-button:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0078d44d}.microsoft-login-button:hover:before{left:130%}.microsoft-login-button:active{transform:translateY(0)}.microsoft-login-button svg{flex-shrink:0}.login-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:#999;font-size:13px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background-color:#e0e0e0}.guest-login-button{padding:12px 24px;border:1px solid #e0e0e0;background-color:#fff;border-radius:8px;font-size:14px;font-weight:500;color:#333;cursor:pointer;transition:all .2s}.guest-login-button:hover{background-color:#f9f9f9;border-color:#ccc}.login-form-footer{font-size:12px;color:#999;text-align:center;line-height:1.5}@keyframes cardReveal{0%{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes heroFloat{0%,to{transform:scale(1.03) translateY(0)}50%{transform:scale(1.04) translateY(-8px)}}@keyframes pulseGlow{0%,to{opacity:.6;transform:scale(1)}50%{opacity:.95;transform:scale(1.08)}}@keyframes shimmerMove{0%{transform:translate(-10%)}to{transform:translate(10%)}}@media (prefers-reduced-motion: reduce){.login-form-card,.login-hero-image,.hero-glow-orb,.login-hero-section:before{animation:none}.microsoft-login-button,.microsoft-login-button:before{transition:none}}@media (max-width: 1024px){.login-page-container{flex-direction:column}.login-hero-section{min-height:300px}.login-form-section{padding:30px 20px}}@media (max-width: 768px){.login-form-card{padding:30px 20px}.login-form-title{font-size:24px}.login-form-subtitle{font-size:13px}}@media (max-width: 480px){.login-form-section{padding:20px}.login-form-card{padding:24px 16px}.login-form-title{font-size:20px}.microsoft-login-button,.guest-login-button{font-size:14px;padding:12px 16px}}.login-container{display:flex;height:100vh;width:100%;background-color:#fff}.hero-section{flex:1;background-color:#f5f5f5;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:40px;min-width:0}.hero-section:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#ffffff24,#1a3a5233);pointer-events:none}.hero-image{width:100%;height:100%;object-fit:cover;transform:scale(1.02);animation:bookingHeroFloat 10s ease-in-out infinite}.login-section{flex:1;display:flex;align-items:center;justify-content:center;padding:24px;background-color:#fafafa;min-width:0;overflow-y:auto}.login-card{width:100%;max-width:420px}.login-header{margin-bottom:24px;display:flex;justify-content:space-between;align-items:center}.header-actions{display:flex;align-items:center;gap:12px}.back-button{display:flex;align-items:center;gap:8px;background:none;border:none;color:#666;cursor:pointer;font-size:14px;padding:0;transition:color .2s}.scan-button{display:inline-flex;align-items:center;justify-content:center;background:#4a90e2;border:none;color:#fff;padding:10px 14px;border-radius:10px;font-size:14px;cursor:pointer;transition:background .2s,transform .2s}.scan-button:hover{background:#3b78c1;transform:translateY(-1px)}.back-button:hover{color:#333}.login-form-content{background:#fff;padding:28px;border-radius:12px;box-shadow:0 2px 8px #0000000d;border:1px solid rgba(0,0,0,.05);animation:revealUp .65s ease both}.intro-badge{display:inline-flex;align-items:center;justify-content:center;padding:6px 14px;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#0078d4;background:#0078d41a;border:1px solid rgba(0,120,212,.22);border-radius:999px;margin-bottom:10px}.intro-badge-booking{margin-top:2px}.login-title{font-size:24px;font-weight:700;color:#000;margin-bottom:8px}.login-subtitle{font-size:13px;color:#666;margin-bottom:20px;line-height:1.5}.login-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:13px;font-weight:600;color:#000}.form-input{padding:10px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:13px;transition:all .2s;background-color:#f9f9f9;color:#000}.form-input::placeholder{color:#999}.form-input:focus{outline:none;background-color:#fff;border-color:#1a3a52;box-shadow:0 0 0 3px #1a3a521a}.form-textarea{width:100%;padding:10px 12px;border:1px solid #e0e0e0;border-radius:8px;font-size:13px;font-family:inherit;resize:vertical;min-height:72px;background-color:#f9f9f9;color:#000;transition:all .2s}.form-textarea::placeholder{color:#999}.form-textarea:focus{outline:none;background-color:#fff;border-color:#1a3a52;box-shadow:0 0 0 3px #1a3a521a}.submit-status{font-size:12px;padding:10px 12px;border-radius:8px;border:1px solid transparent;line-height:1.4;animation:fadeInSoft .3s ease}.submit-status.success{background-color:#eaf7ef;border-color:#b9e2c5;color:#1f6b39}.submit-status.error{background-color:#fdeeee;border-color:#f5c2c2;color:#a12c2c}.booking-input-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.form-group-pill{gap:8px}.pill-field-wrapper{position:relative;width:100%;height:40px}.pill-display{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#d6d2c6;color:#4b4842;border-radius:999px;display:flex;align-items:center;justify-content:flex-start;padding:0 42px 0 16px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;z-index:1;box-shadow:0 2px 4px #0000000d;transition:all .2s ease}.pill-display:after{content:"›";position:absolute;right:8px;top:50%;transform:translateY(-50%);width:26px;height:26px;border-radius:50%;background-color:#fff;color:#eb8f6a;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700}.pill-input-hidden{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:2;border:none;background:transparent;-webkit-appearance:none;-moz-appearance:none;appearance:none}.pill-field-wrapper:not(:has(.pill-input-hidden:disabled)):hover .pill-display{background-color:#dcd8cc;transform:translateY(-1px);box-shadow:0 4px 8px #00000014}.pill-field-wrapper:not(:has(.pill-input-hidden:disabled)):active .pill-display{transform:translateY(0)}.pill-input-hidden:not(:disabled):focus+.pill-display,.pill-input-hidden:not(:disabled):focus-visible+.pill-display{background-color:#dcd8cc;box-shadow:0 0 0 2px #c8c3b5}.pill-input-hidden:disabled{cursor:default;pointer-events:none}.pill-field-wrapper:has(.pill-input-hidden:disabled) .pill-display{background-color:#e5e2da;color:#7c786e;box-shadow:none;cursor:default}.pill-field-wrapper:has(.pill-input-hidden:disabled) .pill-display:after{content:"🔒";background-color:transparent;color:#a8a29e;font-size:12px;box-shadow:none}.zones-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}.zone-box{padding:16px 12px;border:2px solid;border-radius:8px;background-color:transparent;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;min-height:70px;font-weight:600;position:relative;overflow:hidden}.zone-box:before{content:"";position:absolute;top:0;left:-100%;width:70%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);transition:left .45s ease}.zone-box:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.zone-box:hover:before{left:130%}.zone-box.selected{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.zone-label{font-size:14px;font-weight:600}.selected-zones{background-color:#f9f9f9;padding:12px;border-radius:6px;margin-bottom:16px;animation:fadeInSoft .35s ease}.selected-label{font-size:12px;font-weight:600;color:#666;margin-bottom:6px}.selected-tags{display:flex;gap:6px;flex-wrap:wrap}.zone-tag{background-color:#1a3a52;color:#fff;padding:5px 10px;border-radius:14px;font-size:12px;font-weight:600;animation:popIn .25s ease}.user-info{background-color:#e8f4f8;padding:10px 12px;border-radius:6px;margin-bottom:16px;border-left:4px solid #0078D4}.user-greeting{font-size:13px;color:#1a3a52;margin:0}.user-greeting strong{font-weight:700}.login-button{padding:11px 20px;background:linear-gradient(135deg,#1a1a1a,#333);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:4px;position:relative;overflow:hidden}.login-button:before{content:"";position:absolute;top:0;left:-110%;width:65%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);transition:left .55s ease}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 12px #1a1a1a4d}.login-button:hover:not(:disabled):before{left:130%}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.5;cursor:not-allowed}@keyframes revealUp{0%{opacity:0;transform:translateY(18px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes bookingHeroFloat{0%,to{transform:scale(1.02) translateY(0)}50%{transform:scale(1.03) translateY(-7px)}}@keyframes fadeInSoft{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes popIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@media (prefers-reduced-motion: reduce){.hero-image,.login-form-content,.selected-zones,.zone-tag,.submit-status{animation:none}.zone-box,.zone-box:before,.login-button,.login-button:before{transition:none}}@media (max-width: 1024px){.login-container{flex-direction:column}.hero-section{min-height:280px;padding:30px}.login-section{padding:20px;flex:0 1 auto}.login-card{max-width:100%}.login-form-content{padding:24px}.login-title{font-size:22px}.zones-grid{gap:8px}.zone-box{min-height:65px;padding:14px 10px}.zone-label{font-size:13px}}@media (max-width: 768px){.login-form-content{padding:20px}.login-title{font-size:20px;margin-bottom:6px}.login-subtitle{font-size:12px;margin-bottom:16px}.zones-grid{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:14px}.zone-box{min-height:60px;padding:12px 8px}.zone-label{font-size:13px}.login-form{gap:14px}.form-group{gap:5px}.form-input{padding:9px 10px;font-size:12px}.form-textarea{padding:9px 10px;font-size:12px;min-height:66px}.submit-status{font-size:11px}.booking-input-row{gap:10px}.pill-input{height:38px;font-size:11px}.pill-field:after{width:24px;height:24px;font-size:16px}.login-button{padding:10px 18px;font-size:13px}.user-info{padding:8px 10px;margin-bottom:14px}.user-greeting{font-size:12px}}@media (max-width: 480px){.login-section{padding:16px}.login-card{max-width:100%}.login-form-content{padding:18px;border-radius:10px}.login-header{margin-bottom:20px}.back-button{font-size:13px}.login-title{font-size:18px;margin-bottom:4px}.login-subtitle{font-size:11px;margin-bottom:14px}.zones-grid{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:12px}.zone-box{min-height:55px;padding:10px 6px}.zone-label{font-size:12px}.login-form{gap:12px}.form-group{gap:4px}.form-label{font-size:12px}.form-input{padding:8px 10px;font-size:11px;border-radius:5px}.form-textarea{padding:8px 10px;font-size:11px;border-radius:5px;min-height:62px}.submit-status{font-size:11px;padding:8px 10px;border-radius:6px}.booking-input-row{grid-template-columns:1fr;gap:8px}.pill-input{height:36px;padding:0 38px 0 14px;border-radius:999px;font-size:11px}.pill-field:after{right:7px;width:22px;height:22px;font-size:14px}.login-button{padding:10px 16px;font-size:13px;border-radius:5px}.selected-zones{padding:10px;margin-bottom:12px;border-radius:5px}.selected-label{font-size:11px;margin-bottom:5px}.zone-tag{padding:4px 8px;font-size:11px;border-radius:12px}.user-info{padding:8px 10px;margin-bottom:12px;border-radius:5px}.user-greeting{font-size:11px}}.language-switcher{display:flex;align-items:center;gap:8px;margin-left:auto}.language-switcher label{font-size:14px;color:#666;font-weight:500}.language-switcher select{padding:4px 8px;border:1px solid #ddd;border-radius:4px;background-color:#fff;font-size:14px;color:#333;cursor:pointer}.language-switcher select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.qr-data-section{background-color:#f0f7ff;padding:16px;border-radius:8px;border:1px solid #d0e8ff;margin-bottom:16px}.qr-summary{background-color:#fff;padding:12px;border-radius:6px;border-left:4px solid #4a90e2}.qr-summary p{margin:6px 0;font-size:13px;color:#333;display:flex;justify-content:space-between;gap:12px}.qr-summary strong{color:#1a3a52;font-weight:600;min-width:120px}.section-title{font-size:14px;font-weight:700;color:#1a3a52;margin:0 0 12px;display:flex;align-items:center}.section-subtitle{font-size:13px;font-weight:600;color:#1a3a52;margin:14px 0 10px}.qr-scanner-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}.qr-scanner-modal{background:#fff;border-radius:12px;width:90%;max-width:500px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0000004d;overflow:hidden;animation:slideUp .3s ease}.qr-scanner-header{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid #e0e0e0;background-color:#f8f9fa}.qr-back-button{display:flex;align-items:center;gap:6px;background:none;border:none;color:#666;cursor:pointer;font-size:14px;padding:0;transition:color .2s}.qr-back-button:hover{color:#333}.qr-scanner-title{font-size:18px;font-weight:700;color:#1a3a52;margin:0;flex:1}.qr-scanner-body{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 20px;background-color:#fafafa}.qr-scanner-placeholder{text-align:center;display:flex;flex-direction:column;align-items:center;gap:20px}.qr-scanner-icon{font-size:64px;animation:pulse 2s infinite}.qr-scanner-text{font-size:16px;color:#666;margin:0;font-weight:500}.manual-qr-form{display:flex;flex-direction:column;gap:10px;width:100%;max-width:320px;margin-top:15px;padding:16px;background-color:#fff;border-radius:12px;border:1px solid rgba(0,0,0,.06);box-shadow:0 4px 15px #00000008;animation:revealUp .45s ease both}.manual-qr-label{font-size:12px;font-weight:600;color:#1a3a52;text-align:left;margin:0}.manual-qr-textarea{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:12px;font-family:monospace;background-color:#f8fafc;color:#334155;resize:none;transition:all .2s ease}.manual-qr-textarea:focus{outline:none;background-color:#fff;border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e226}.manual-qr-submit{width:100%;padding:10px;background:linear-gradient(135deg,#4a90e2,#357abd);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.manual-qr-submit:hover{transform:translateY(-1px);box-shadow:0 4px 12px #4a90e240}.manual-qr-submit:active{transform:translateY(0)}.qr-scanner-error{width:100%;max-width:320px;padding:10px 12px;background-color:#fef2f2;border:1px solid #fecaca;color:#b91c1c;font-size:11px;font-weight:500;border-radius:8px;text-align:left;margin-top:10px;animation:fadeInSoft .3s ease}.qr-scan-trigger{padding:12px 28px;background:#4a90e2;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.qr-scan-trigger:hover{background:#3b78c1;transform:translateY(-2px);box-shadow:0 4px 12px #4a90e24d}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.scanner-app-layout{display:flex;flex-direction:column;min-height:100vh;width:100%;background-color:#fff;color:#1f2937;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden;position:relative}.scan-navbar{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background-color:#fff;border-bottom:1px solid rgba(0,0,0,.04);position:sticky;top:0;z-index:10}.scan-nav-back{background:none;border:none;color:#374151;cursor:pointer;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease}.scan-nav-back:hover{background-color:#f3f4f6}.scan-navbar-title{font-size:18px;font-weight:700;color:#111827;margin:0;letter-spacing:-.01em;flex:1;text-align:center;padding-left:20px}.scan-navbar-actions{display:flex;align-items:center;gap:8px}.scan-action-btn{background:none;border:none;color:#4b5563;cursor:pointer;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.scan-action-btn:hover{background-color:#f3f4f6;color:#111827;transform:scale(1.05)}.scan-action-btn.active{color:#d97706;background-color:#fffbeb}.scan-action-btn.disabled{opacity:.5;cursor:not-allowed}.scan-viewport-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;position:relative;gap:35px}.scan-instruction-text{font-size:14px;line-height:1.6;color:#4b5563;text-align:center;margin:0;font-weight:500;letter-spacing:-.01em;max-width:320px}.scan-target-area{position:relative;width:260px;height:260px;display:flex;align-items:center;justify-content:center;background-color:transparent;border-radius:24px}.target-frame-bracket{position:absolute;width:32px;height:32px;border-color:#eb2f96;border-style:solid;border-width:0;transition:all .3s ease}.target-frame-bracket.top-left{top:0;left:0;border-top-width:6px;border-left-width:6px;border-top-left-radius:16px}.target-frame-bracket.top-right{top:0;right:0;border-top-width:6px;border-right-width:6px;border-top-right-radius:16px}.target-frame-bracket.bottom-left{bottom:0;left:0;border-bottom-width:6px;border-left-width:6px;border-bottom-left-radius:16px}.target-frame-bracket.bottom-right{bottom:0;right:0;border-bottom-width:6px;border-right-width:6px;border-bottom-right-radius:16px}.qr-code-vector-graphic{width:190px;height:190px;display:flex;align-items:center;justify-content:center;opacity:.95;animation:qrReveal .8s cubic-bezier(.16,1,.3,1) both}.qr-svg-mesh{width:100%;height:100%}.active-scanning-laser{position:absolute;left:15px;right:15px;height:3px;background:linear-gradient(90deg,transparent,#eb2f96,#ff85c0,#eb2f96,transparent);box-shadow:0 0 10px 1.5px #eb2f9699;z-index:2;animation:mockupLaserSweep 3s infinite ease-in-out}.floating-feedback-card{position:absolute;bottom:40px;display:flex;align-items:center;gap:10px;padding:12px 20px;border-radius:12px;font-size:13px;font-weight:600;box-shadow:0 10px 25px #0000001a;animation:slideUpIn .35s cubic-bezier(.175,.885,.32,1.275) both;max-width:320px}.floating-feedback-card.feedback-error{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626}.floating-feedback-card.feedback-success{background-color:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.completely-hidden-scanner-field{position:absolute;top:-100px;left:-100px;width:10px;height:10px;opacity:0;border:none;background:transparent;pointer-events:none}@keyframes mockupLaserSweep{0%{top:20px}50%{top:235px}to{top:20px}}@keyframes qrReveal{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:.95}}@keyframes slideUpIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}html,body,#root{height:100%;width:100%}
