.loadSpinner-overlay{z-index:9998;background:#ffffffb3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.loadSpinner{border:8px solid #0000001a;border-top:8px solid var(--accent-color);border-radius:50%;width:50px;height:50px;animation:2s linear infinite spin}.loadSpinner-overlay p{color:var(--text-color);margin-top:20px;font-size:16px;font-weight:500}@keyframes spin{to{transform:rotate(360deg)}}.login-page-wrapper{flex-direction:column;min-height:100vh;display:flex}.login-page{flex:1;justify-content:center;align-items:center;display:flex}.login-container{width:100%;max-width:480px;margin:0 auto;padding:0;position:relative}.login-title{text-align:center;color:#1e293b;background:linear-gradient(135deg,#337ab7 0%,#2a6495 100%);-webkit-text-fill-color:transparent;letter-spacing:-.5px;background-clip:text;margin:0 0 24px;font-size:32px;font-weight:700}.login-form-container{width:100%;max-width:400px;margin:0 auto}.login-form{flex-direction:column;gap:24px;display:flex}.login-button,.passkey-login-button,.login-button.secondary{color:#fff;cursor:pointer;background:linear-gradient(135deg,#337ab7 0%,#2a6495 100%);border:none;border-radius:14px;justify-content:center;align-items:center;gap:12px;width:100%;padding:18px 24px;font-size:17px;font-weight:600;transition:transform .3s,box-shadow .3s;display:flex;position:relative}.login-button:hover:not(:disabled),.passkey-login-button:hover:not(:disabled),.login-button.secondary:hover:not(:disabled){transform:scale(1.02)translateY(-3px);box-shadow:0 12px 35px #337ab766}.login-button:active:not(:disabled),.passkey-login-button:active:not(:disabled),.login-button.secondary:active:not(:disabled){transform:scale(.98)translateY(-1px)}.login-button:disabled,.passkey-login-button:disabled,.login-button.secondary:disabled{opacity:.6;cursor:not-allowed}.divider{color:#64748b;align-items:center;margin:28px 0;font-size:15px;display:flex}.divider:before,.divider:after{content:"";background:#337ab733;flex:1;height:1px}.divider span{z-index:1;background:0 0;padding:0 20px;position:relative}.resend-section{text-align:center;margin:16px 0}.loading-spinner{animation:1s linear infinite spin}@keyframes fadeIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.login-form{animation:.4s ease-out fadeIn}.method-grid-compact{flex-direction:column;gap:12px;margin-top:8px;margin-bottom:24px;display:flex}.login-button-group{flex-direction:column;gap:12px;display:flex}.method-card-compact{margin:0}.login-layout-title{margin-bottom:32px}@media (width<=480px){.login-page{padding:30px 15px}.login-title{margin-bottom:28px;font-size:28px}.login-button,.passkey-login-button,.login-button.secondary{padding:16px 20px;font-size:16px}.login-button:hover:not(:disabled),.passkey-login-button:hover:not(:disabled),.login-button.secondary:hover:not(:disabled){transform:scale(1.01)translateY(-2px)}.method-grid-compact{margin-top:12px;margin-bottom:20px}}.login-button:focus-visible,.passkey-login-button:focus-visible,.login-button.secondary:focus-visible{outline-offset:2px;outline:3px solid #337ab766}.footer-container{background-color:var(--primary-color);border-top:1px solid var(--border-color);z-index:1100;height:4em;margin:0;padding:.75em 1.5em;position:fixed;bottom:0;left:0;right:0}.footer-content{justify-content:space-between;align-items:center;width:100%;margin:.5em auto;display:flex}.footer-item{align-items:center;display:flex}.footer-center span{cursor:pointer;align-items:center;display:flex}.footer-center span:after{content:"↗";opacity:.5;margin-left:6px;font-size:.75em;transition:all .2s}.footer-left{justify-content:flex-start;width:33%}.footer-center{text-align:center;justify-content:center;width:33%}.footer-right{justify-content:flex-end;width:33%}.footer-section:hover{background-color:#0000000a}.footer-section:hover:after{opacity:1;transform:translate(1px,-1px)}.portal-title{color:#333;font-weight:500}.imprint-text{color:#333;font-weight:500;text-decoration:none}.popup-content-container{text-align:center;padding:8px}.popup-grs-image{max-width:200px;height:auto;margin:0 auto}.popup-logo-row{justify-content:center;align-items:center;gap:12px;margin-bottom:16px;display:flex}.popup-portal-logo{width:auto;height:32px}.popup-portal-title{color:#333;font-size:1.5em;font-weight:600}.popup-text{color:#555;margin-bottom:16px;line-height:1.5}.popup-buttons-container{flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;margin-top:16px;display:flex}.popup-button{margin:4px}.contentLoadSpinner-overlay{z-index:9998;background:0 0;flex-direction:column;justify-content:center;align-items:center;display:flex}.contentLoadSpinner{border:8px solid #0000001a;border-top:8px solid var(--accent-color);border-radius:50%;width:50px;height:50px;animation:2s linear infinite spin}.contentLoadSpinner-overlay p{color:var(--text-color);margin-top:20px;font-size:16px;font-weight:500}.required-indicator{color:red;margin-left:4px;font-weight:700}.image-preview-container{text-align:center;margin-bottom:8px}.image-preview{object-fit:contain;border:1px solid #ccc;border-radius:4px;max-width:200px;max-height:200px}.required-field-error .form-label{font-weight:700;color:#f44!important}.required-field-error .dx-texteditor,.required-field-error .dx-numberbox,.required-field-error .dx-datebox,.required-field-error .dx-selectbox,.required-field-error .dx-textarea,.required-field-error .dx-checkbox{border-width:2px!important;border-color:#f44!important}.required-field-error .dx-texteditor.dx-state-focused{border-color:#f44!important;box-shadow:0 0 0 1px #ff44444d!important}.required-field-error .dx-fileuploader{border-radius:4px;border:2px solid #f44!important}.required-field-error .image-upload-section>div:last-child{border-radius:8px;border:2px solid #f44!important}.required-field-error .dx-datagrid,.required-field-error .dx-datagrid-rowsview,.required-field-error .dx-treelist-container{border:2px solid #f44!important}.required-field-error .dx-checkbox-container{border-radius:4px;padding:4px;border:2px solid #f44!important}.required-field-error .dx-dropdowneditor,.required-field-error .dx-tagbox{border:2px solid #f44!important}.validation-error-message{color:red;margin-top:4px;font-size:12px;display:block}.image-popup-container{cursor:grab;touch-action:none;scrollbar-width:none;-ms-overflow-style:none;justify-content:center;align-items:center;height:100%;padding:20px;display:flex;overflow:auto}.image-popup-container::-webkit-scrollbar{display:none}.passkey-popup .dx-overlay-content{border-radius:12px;box-shadow:0 10px 40px #00000026;width:500px!important;max-width:500px!important}.popup-content{min-height:auto;max-height:70vh;padding:24px;position:relative;overflow-y:auto}.passkey-form .form-group{margin-bottom:24px}.passkey-form .form-label{color:#495057;margin-bottom:8px;font-size:.95em;font-weight:500;display:block}.passkey-form .info-text{color:#495057;background:#f8f9fa;border-left:3px solid #337ab7;border-radius:4px;margin:24px 0 0;padding:12px 15px;font-size:.9em;line-height:1.5}.passkey-list{max-height:400px;overflow-y:auto}.passkey-item{border-bottom:1px solid #eee;align-items:flex-start;padding:12px;transition:background-color .2s;display:flex}.passkey-item:hover{background:#f8f9fa}.passkey-item input[type=checkbox]{cursor:pointer;width:18px;height:18px;margin-top:3px}.passkey-item span{flex:1;margin-left:12px;line-height:1.5}.passkey-item strong{color:#212529;font-size:1.05em}.passkey-item small{color:#6c757d;margin-top:4px;font-size:.85em;display:block}.loading-overlay{backdrop-filter:blur(2px);z-index:1000;background:#fffc;border-radius:12px;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.web-authn-warning{color:#856404;background-color:#fff3cd;border:1px solid #ffeeba;border-radius:6px;margin:20px 0;padding:15px;font-size:.95em}.popup-actions{background:0 0;border:none;justify-content:flex-end;gap:12px;padding:16px 24px 24px;display:flex}.popup-actions .dx-button{min-width:100px}.popup-actions .dx-button.dx-button-danger{color:#fff;background-color:#dc3545;border-color:#dc3545}.popup-actions .dx-button.dx-button-danger:hover{background-color:#c82333;border-color:#bd2130}.popup-actions .dx-button.dx-button-default{color:#495057;background-color:#f8f9fa;border-color:#ced4da}.popup-actions .dx-button.dx-button-default:hover{background-color:#e9ecef;border-color:#adb5bd}.selection-info{color:#004085;background:#e7f3ff;border-radius:4px;margin-top:15px;padding:10px}@media (width<=768px){.passkey-popup .dx-overlay-content{margin:10px;width:95vw!important;max-width:95vw!important}.popup-content{max-height:60vh;padding:20px}.passkey-list{max-height:300px}.passkey-item{padding:10px}.popup-actions{flex-wrap:wrap;padding:12px 20px 20px}.popup-actions .dx-button{flex:1;min-width:auto}.passkey-form .info-text{padding:10px;font-size:.85em}}@media (width<=480px){.popup-actions{flex-direction:column}.popup-actions .dx-button{width:100%}.passkey-item{flex-direction:column;gap:8px}.passkey-item input[type=checkbox]{align-self:flex-start}.passkey-item span{margin-left:0}}.passkey-item:first-child{animation:.3s ease-out fadeIn}.passkey-list::-webkit-scrollbar{width:8px}.popup-content::-webkit-scrollbar{width:8px}.passkey-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.popup-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.passkey-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.popup-content::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.passkey-list::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.popup-content::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.qr-landing-page-wrapper{flex-direction:column;min-height:100vh;display:flex}.qr-landing-page{background:linear-gradient(135deg,#f8fafc 0%,#f1f5f9 100%);flex:1;justify-content:center;align-items:center;padding:40px 20px;display:flex}.qr-landing-container{background:#fff;border:1px solid #337ab71a;border-radius:20px;width:100%;max-width:520px;padding:40px;box-shadow:0 10px 40px #00000014}.qr-landing-header{text-align:center;margin-bottom:32px}.qr-landing-logo h1{color:#337ab7;background:linear-gradient(135deg,#337ab7 0%,#2a6495 100%);-webkit-text-fill-color:transparent;letter-spacing:-.5px;background-clip:text;margin:0 0 16px;font-size:32px;font-weight:700}.qr-landing-subtitle{color:#475569;margin:0;font-size:16px;font-weight:400;line-height:1.5}.status-card{background:#fff;border:2px solid;border-radius:16px;padding:32px;transition:all .3s;animation:.4s ease-out fadeIn}.status-card.success{background:linear-gradient(135deg,#f0fdf4 0%,#dcfce7 100%);border-color:#10b981}.status-card.error{background:linear-gradient(135deg,#fef2f2 0%,#fee2e2 100%);border-color:#ef4444}.status-card.not_mobile{background:linear-gradient(135deg,#eff6ff 0%,#dbeafe 100%);border-color:#3b82f6}.status-card.processing{background:linear-gradient(135deg,#fffbeb 0%,#fef3c7 100%);border-color:#f59e0b}.status-card.default{border-color:#e2e8f0}.status-icon{text-align:center;margin-bottom:24px;font-size:64px;animation:1s infinite alternate bounce}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-8px)}}.status-title{text-align:center;color:#1e293b;margin:0 0 20px;font-size:24px;font-weight:600;line-height:1.4}.status-details,.error-details,.success-details,.processing-info,.loading-info{margin-top:20px}.status-details p,.error-details p,.success-details p,.processing-info p,.loading-info p{color:#475569;text-align:center;margin-bottom:16px;font-size:15px;line-height:1.6}.device-info-box{text-align:left;background:#f8fafc;border-left:4px solid #3b82f6;border-radius:12px;margin:20px 0;padding:16px}.device-info-box strong{color:#1e293b;margin-right:8px;font-weight:600}.loading-spinner{flex-direction:column;align-items:center;gap:20px;display:flex}.loading-spinner .spinner{border:4px solid #e2e8f0;border-top-color:#337ab7;border-radius:50%;width:60px;height:60px;animation:1s linear infinite spin}.loading-spinner p{color:#475569;text-align:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:12px 16px;font-family:Courier New,monospace;font-size:14px}.processing-info{flex-direction:column;align-items:center;gap:16px;display:flex}.spinner-small{border:3px solid #e2e8f0;border-top-color:#337ab7;border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}.session-info{color:#475569;text-align:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:10px 14px;font-size:13px}.session-info code{color:#337ab7;font-family:Courier New,monospace;font-weight:600}.error-details .error-actions{justify-content:center;gap:16px;margin-top:24px;display:flex}.success-details .closing-info{color:#64748b;text-align:center;border-top:1px solid #e2e8f0;margin-top:16px;padding-top:16px;font-size:14px;font-style:italic}.btn-retry,.btn-close{cursor:pointer;border:none;border-radius:12px;min-width:120px;padding:14px 28px;font-size:15px;font-weight:600;transition:transform .3s,box-shadow .3s;position:relative}.btn-retry{color:#fff;background:linear-gradient(135deg,#337ab7 0%,#2a6495 100%);box-shadow:0 8px 25px #337ab74d}.btn-retry:hover:not(:disabled){transform:scale(1.02)translateY(-3px);box-shadow:0 12px 35px #337ab766}.btn-retry:active:not(:disabled){transform:scale(.98)translateY(-1px)}.btn-retry:disabled{opacity:.6;cursor:not-allowed}.btn-close{color:#475569;background:#fff;border:2px solid #e2e8f0;box-shadow:0 4px 12px #0000000d}.btn-close:hover:not(:disabled){background:#f8fafc;transform:scale(1.02)translateY(-2px);box-shadow:0 8px 20px #00000014}.btn-close:active:not(:disabled){transform:scale(.98)translateY(0)}.btn-close:disabled{opacity:.6;cursor:not-allowed}.btn-retry:focus-visible,.btn-close:focus-visible{outline-offset:2px;outline:3px solid #337ab766}.qr-landing-footer{text-align:center;color:#64748b;border-top:1px solid #e2e8f0;margin-top:32px;padding-top:24px;font-size:14px}.mobile-detected{color:#0369a1;background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;margin:12px 0;padding:10px 16px;display:inline-block}.api-info{color:#94a3b8;background:#f8fafc;border-radius:6px;margin-top:12px;padding:6px 12px;font-family:Courier New,monospace;font-size:12px;display:inline-block}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 8px 25px #10b9814d}50%{transform:scale(1.01);box-shadow:0 12px 35px #10b98166}}.status-card.success{animation:2s infinite pulse}@media (width<=640px){.qr-landing-page{padding:20px 15px}.qr-landing-container{max-width:100%;padding:30px 20px}.qr-landing-logo h1{font-size:28px}.qr-landing-subtitle{font-size:15px}.status-card{padding:24px 20px}.status-icon{margin-bottom:20px;font-size:56px}.status-title{margin-bottom:16px;font-size:22px}.error-details .error-actions{flex-direction:column;align-items:stretch;gap:12px}.btn-retry,.btn-close{width:100%;padding:16px}.loading-spinner .spinner{width:50px;height:50px}}
