:root{--app-font-size:15px;--radius:0.625rem;--background:oklch(1 0 0);--foreground:oklch(0.145 0 0);--card:oklch(1 0 0);--card-foreground:oklch(0.145 0 0);--primary:oklch(0.69 0.21 41.42);--primary-hover:oklch(0.63 0.21 41.42);--primary-foreground:oklch(1 0 0);--muted-foreground:oklch(0.556 0 0);--destructive:oklch(0.577 0.245 27.325);--input:oklch(0.922 0 0);--border:oklch(0.922 0 0);--accent:oklch(0.96 0 0);--accent-foreground:oklch(0.145 0 0);--ring:oklch(0.69 0.21 41.42/0.35)}*{box-sizing:border-box}body,html{margin:0;padding:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif;font-size:var(--app-font-size);line-height:1.5;color:var(--foreground);background:var(--background)}main.auth-shell{min-height:100vh;flex-direction:column;padding:14px;background:var(--background)}.auth-org-logo-wrap,main.auth-shell{display:flex;align-items:center;justify-content:center}.auth-org-logo-wrap{width:100%;padding:0 24px 10px;margin:0 0 26px}.auth-org-logo{display:block;width:auto;height:auto;max-width:min(19rem,100%);max-height:3.8rem;object-fit:contain}@media (max-width:640px){main.auth-shell{padding:12px}.auth-org-logo-wrap{padding:0 20px 6px;margin-bottom:20px}.auth-org-logo{max-width:min(16rem,100%);max-height:3.2rem}}section.auth-card{width:100%;max-width:28rem;border:1px solid oklch(.922 0 0/.5);border-radius:.75rem;background:var(--card);color:var(--card-foreground);box-shadow:0 1px 3px oklch(0 0 0/.08),0 1px 2px oklch(0 0 0/.12);padding:24px 0}.auth-card-header{padding:0 24px;margin-bottom:12px}h1.auth-title{margin:0 0 4px;font-size:1.5rem;font-weight:600;line-height:1.1}p.auth-subtitle{margin:0;color:var(--muted-foreground);font-size:.875rem}.auth-card-content{padding:0 24px}div.auth-form,form.auth-form{display:flex;flex-direction:column;gap:12px}.auth-card-content>*+*{margin-top:16px}.auth-card-content>form>*+*{margin-top:0}.auth-field{display:flex;flex-direction:column}.auth-forgot-link{margin-top:6px;align-self:flex-end;font-size:.8125rem;color:var(--primary);text-decoration:none;transition:-webkit-text-decoration .1s ease;transition:text-decoration .1s ease;transition:text-decoration .1s ease,-webkit-text-decoration .1s ease}.auth-forgot-link:hover{text-decoration:underline}.auth-field label{display:block;margin-bottom:6px;font-size:.875rem;font-weight:500;line-height:1}.auth-field input:not(.auth-phone-input){width:100%;height:36px;border:1px solid var(--input);border-radius:8px;background:transparent;color:var(--foreground);padding:0 12px;font-size:.875rem;box-shadow:0 1px 2px oklch(0 0 0/.04);transition:color .15s ease,box-shadow .15s ease,border-color .15s ease;outline:none}.auth-field input:not(.auth-phone-input)::placeholder{color:var(--muted-foreground)}.auth-field input:not(.auth-phone-input):focus-visible{border-color:var(--primary);box-shadow:0 0 0 3px var(--ring)}.auth-grid-2{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.auth-phone-group{display:flex;align-items:stretch;height:36px;border:1px solid var(--input);border-radius:8px;box-shadow:0 1px 2px oklch(0 0 0/.04);transition:border-color .15s ease,box-shadow .15s ease;overflow:visible}.auth-phone-group:focus-within{border-color:var(--input);box-shadow:0 1px 2px oklch(0 0 0/.04)}.auth-country-btn{flex-shrink:0;height:100%;border:none;border-right:1px solid var(--input);border-radius:0;background:transparent;color:var(--foreground);display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 10px;font-size:.875rem;cursor:pointer;transition:background-color .15s ease;white-space:nowrap}.auth-country-btn:hover{background:var(--accent)}.auth-country-btn:focus,.auth-country-btn:focus-visible{outline:none}.auth-country-btn .chevron{width:12px;height:12px;opacity:.5;transition:opacity .15s ease;flex-shrink:0}.auth-country-btn:hover .chevron{opacity:.8}.auth-phone-input{flex:1 1;min-width:0;height:100%;border:none;border-radius:0;background:transparent;color:var(--foreground);padding:0 12px;font-size:.875rem;position:relative;z-index:1;transition:box-shadow .15s ease}.auth-phone-input:focus,.auth-phone-input:focus-visible{outline:none;border-top-right-radius:7px;border-bottom-right-radius:7px;box-shadow:inset 0 0 0 1px var(--primary),0 0 0 3px var(--ring)}.auth-phone-input::placeholder{color:var(--muted-foreground)}.auth-country-dropdown-wrap{position:relative}.auth-country-dropdown{position:absolute;top:calc(100% + 4px);left:0;z-index:50;width:260px;max-height:240px;overflow-y:auto;background:var(--card);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px oklch(0 0 0/.12),0 2px 4px oklch(0 0 0/.08);padding:4px}.auth-country-dropdown-search{width:100%;height:32px;border:1px solid var(--input);border-radius:6px;background:transparent;color:var(--foreground);padding:0 8px;font-size:.8125rem;outline:none;margin-bottom:4px;transition:border-color .15s ease,box-shadow .15s ease}.auth-country-dropdown-search:focus-visible{border-color:var(--primary);box-shadow:0 0 0 3px var(--ring)}.auth-country-dropdown-search::placeholder{color:var(--muted-foreground)}.auth-country-option{display:flex;align-items:center;gap:8px;width:100%;padding:6px 8px;border:none;border-radius:4px;background:none;color:var(--foreground);font-size:.8125rem;cursor:pointer;text-align:left;transition:background-color .1s ease}.auth-country-option:hover{background:var(--accent)}.auth-country-option.selected{background:var(--accent);font-weight:500}.auth-country-option .dial-code{color:var(--muted-foreground);margin-left:auto;font-size:.8125rem}.auth-button{width:100%;height:36px;border:0;border-radius:8px;background:var(--primary);color:var(--primary-foreground);font-size:.875rem;font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;text-decoration:none;transition:background-color .15s ease,box-shadow .15s ease,opacity .15s ease;outline:none}.auth-button:hover{background:var(--primary-hover)}.auth-button:focus-visible{box-shadow:0 0 0 3px var(--ring)}.auth-button:active{opacity:.92}.auth-button:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.auth-button-outline{border:1px solid var(--input);background:transparent;color:var(--foreground);box-shadow:0 1px 2px oklch(0 0 0/.04)}.auth-button-outline:hover{background:var(--accent);color:var(--accent-foreground)}.auth-button-outline:focus-visible{border-color:var(--primary);box-shadow:0 0 0 3px var(--ring)}@keyframes auth-spin{to{transform:rotate(1turn)}}.auth-spinner{width:16px;height:16px;animation:auth-spin .6s linear infinite;flex-shrink:0}.auth-divider{position:relative;margin:8px 0;text-align:center;font-size:.75rem;letter-spacing:.04em;text-transform:uppercase;color:var(--muted-foreground)}.auth-divider:before{content:"";position:absolute;left:0;right:0;top:50%;border-top:1px solid oklch(.922 0 0/.5)}.auth-divider span{position:relative;background:var(--card);padding:0 8px}.auth-inline-links{text-align:center;font-size:.875rem}.auth-inline-links a{color:var(--primary);text-decoration:none;transition:-webkit-text-decoration .1s ease;transition:text-decoration .1s ease;transition:text-decoration .1s ease,-webkit-text-decoration .1s ease}.auth-inline-links a:hover{text-decoration:underline}.auth-copy{margin:8px 0 0;text-align:center;color:var(--muted-foreground);font-size:.875rem}.auth-copy-org{color:var(--foreground);font-weight:500;opacity:.88}.auth-copy a{color:var(--primary);text-decoration:none;transition:-webkit-text-decoration .1s ease;transition:text-decoration .1s ease;transition:text-decoration .1s ease,-webkit-text-decoration .1s ease}.auth-copy a:hover{text-decoration:underline}.auth-error{color:var(--destructive)}.auth-error,.auth-notice{margin:0;font-size:.875rem}.auth-notice{color:var(--foreground)}.auth-font-medium{font-weight:500}.auth-pw-rules{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.auth-pw-rule{display:flex;align-items:center;gap:6px;font-size:.8125rem;color:var(--muted-foreground);transition:color .2s ease}.auth-pw-rule.met{color:oklch(.55 .17 145)}.auth-pw-rule-icon{width:14px;height:14px;flex-shrink:0}pre.auth-debug{margin:1rem 0 0;padding:.75rem;border-radius:10px;background:var(--accent);color:var(--foreground);font-size:.8rem;overflow:auto}