.svelte-x2v86b{box-sizing:border-box;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.container.svelte-x2v86b{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#e2e8f0);display:flex;align-items:center;justify-content:center;padding:2rem 1rem;position:relative}.login-card.svelte-x2v86b{background:#fff;border-radius:16px;box-shadow:0 10px 25px #00000014;border:1px solid #e5e7eb;width:100%;max-width:420px;overflow:hidden;position:relative;animation:svelte-x2v86b-slideUp .6s ease-out}@keyframes svelte-x2v86b-slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.card-header.svelte-x2v86b{padding:3rem 2.5rem 2rem;text-align:center;background:#fafafa}.icon-wrapper.svelte-x2v86b{display:inline-flex;padding:1rem;background:linear-gradient(135deg,#2563eb,#1d4ed8);border-radius:50%;margin-bottom:1.5rem;box-shadow:0 4px 12px #2563eb40}.lock-icon.svelte-x2v86b,.user-plus-icon.svelte-x2v86b{width:2rem;height:2rem;color:#fff}h1.svelte-x2v86b{font-size:2rem;font-weight:800;color:#111827;margin:0 0 .5rem;letter-spacing:-.025em}.subtitle.svelte-x2v86b{color:#6b7280;font-size:1rem;margin:0;font-weight:400}.auth-form.svelte-x2v86b{padding:0 2.5rem 2rem}.input-group.svelte-x2v86b{margin-bottom:1.5rem}label.svelte-x2v86b{display:block;font-weight:600;color:#374151;margin-bottom:.5rem;font-size:.95rem}.input-wrapper.svelte-x2v86b{position:relative}input.svelte-x2v86b{width:100%;padding:1rem 0;border:none;background:transparent;font-size:1.1rem;color:#1f2937;font-weight:500;outline:none;transition:all .3s ease;border-bottom:2px solid #e5e7eb}input.svelte-x2v86b::placeholder{color:#9ca3af;font-weight:400}input.svelte-x2v86b:focus,input.svelte-x2v86b:not(:placeholder-shown){border-bottom-color:transparent}input.error.svelte-x2v86b{border-bottom-color:#ef4444}.input-underline.svelte-x2v86b{position:absolute;bottom:0;left:0;height:2px;width:0;background:linear-gradient(135deg,#2563eb,#1d4ed8);transition:width .3s ease}input.svelte-x2v86b:focus+.input-underline:where(.svelte-x2v86b),input.svelte-x2v86b:not(:placeholder-shown)+.input-underline:where(.svelte-x2v86b){width:100%}input.error.svelte-x2v86b+.input-underline:where(.svelte-x2v86b){background:#ef4444;width:100%}.pin-hint.svelte-x2v86b{margin:.5rem 0 0;font-size:.8rem;color:#6b7280;line-height:1.4}.role-selector.svelte-x2v86b{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-top:.5rem}.role-option.svelte-x2v86b{position:relative;cursor:pointer}.role-option.svelte-x2v86b input[type=radio]:where(.svelte-x2v86b){position:absolute;opacity:0;pointer-events:none}.role-label.svelte-x2v86b{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;border:2px solid #e5e7eb;border-radius:8px;background:#fafafa;transition:all .2s cubic-bezier(.4,0,.2,1);font-weight:500;color:#6b7280}.role-option.svelte-x2v86b input[type=radio]:where(.svelte-x2v86b):checked+.role-label:where(.svelte-x2v86b){border-color:#2563eb;background:#2563eb0d;color:#2563eb}.role-option.svelte-x2v86b:hover .role-label:where(.svelte-x2v86b){border-color:#d1d5db;background:#f3f4f6}.role-option.svelte-x2v86b input[type=radio]:where(.svelte-x2v86b):checked:hover+.role-label:where(.svelte-x2v86b){border-color:#1d4ed8;background:#2563eb14}.role-icon.svelte-x2v86b{font-size:1.5rem}.error-message.svelte-x2v86b{display:flex;align-items:center;gap:.5rem;color:#ef4444;font-size:.9rem;font-weight:500;margin-bottom:1.5rem;padding:.75rem 1rem;background:#ef44441a;border-radius:.5rem;border:1px solid rgba(239,68,68,.2);animation:svelte-x2v86b-shake .5s ease-in-out}@keyframes svelte-x2v86b-shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.error-icon.svelte-x2v86b{width:1.25rem;height:1.25rem;flex-shrink:0}.mode-switch.svelte-x2v86b{margin-top:1.5rem;text-align:center}.switch-button.svelte-x2v86b{background:transparent;border:none;color:#6b7280;font-size:.9rem;cursor:pointer;transition:color .2s ease;text-decoration:underline;text-underline-offset:2px}.switch-button.svelte-x2v86b:hover:not(:disabled){color:#2563eb}.switch-button.svelte-x2v86b:disabled{opacity:.5;cursor:not-allowed}.auth-button.svelte-x2v86b{width:100%;padding:1rem 1.5rem;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 1px 3px #2563eb1f;position:relative;overflow:hidden;letter-spacing:-.01em}.auth-button.svelte-x2v86b:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.auth-button.svelte-x2v86b:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb40}.auth-button.svelte-x2v86b:hover:not(:disabled):before{left:100%}.auth-button.svelte-x2v86b:active:not(:disabled){transform:translateY(0)}.auth-button.svelte-x2v86b:disabled{opacity:.7;cursor:not-allowed;transform:none}.loading-spinner.svelte-x2v86b{width:1.25rem;height:1.25rem;animation:svelte-x2v86b-spin 1s linear infinite}@keyframes svelte-x2v86b-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.card-footer.svelte-x2v86b{padding:1.5rem 2.5rem;background:#f9fafb;border-top:1px solid #f3f4f6;text-align:center}.help-text.svelte-x2v86b{color:#6b7280;font-size:.85rem;margin:0}@media (max-width: 480px){.container.svelte-x2v86b{padding:1rem}.login-card.svelte-x2v86b{border-radius:1rem}.card-header.svelte-x2v86b{padding:2rem 1.5rem 1.5rem}.auth-form.svelte-x2v86b{padding:0 1.5rem 1.5rem}.role-selector.svelte-x2v86b{grid-template-columns:1fr;gap:.5rem}.role-label.svelte-x2v86b{flex-direction:row;justify-content:center;padding:.75rem}.card-footer.svelte-x2v86b{padding:1rem 1.5rem}h1.svelte-x2v86b{font-size:1.75rem}.icon-wrapper.svelte-x2v86b{padding:.75rem}.lock-icon.svelte-x2v86b,.user-plus-icon.svelte-x2v86b{width:1.5rem;height:1.5rem}}.auth-button.svelte-x2v86b:focus-visible,.switch-button.svelte-x2v86b:focus-visible,.role-option.svelte-x2v86b:focus-within .role-label:where(.svelte-x2v86b){outline:2px solid #2563eb;outline-offset:2px}input.svelte-x2v86b:focus{outline:none}
