.auth-page{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:var(--space-8) var(--space-4) var(--space-8);padding-top:calc(var(--safe-top) + var(--space-8));padding-bottom:calc(var(--safe-bottom) + var(--space-8));background:var(--color-bg)}.auth-container{width:100%;max-width:420px}.auth-brand{text-align:center;margin-bottom:var(--space-8)}.auth-logo{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:var(--radius-xl);background:var(--color-primary);margin-bottom:var(--space-4)}.auth-logo svg{width:28px;height:28px;fill:var(--color-text-inverse)}.auth-tenant-logo{display:block;max-height:56px;max-width:200px;width:auto;object-fit:contain;margin:0 auto var(--space-4)}.auth-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text);margin-bottom:var(--space-1)}.auth-subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:var(--line-height-normal)}.auth-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:var(--space-6)}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-1);background:var(--color-bg-tertiary);border-radius:var(--radius-lg);padding:var(--space-1);margin-bottom:var(--space-6)}.auth-tab{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);border:none;border-radius:var(--radius-md);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);min-height:44px}.auth-tab[aria-selected=true]{background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-xs)}.auth-tab:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.auth-form{display:flex;flex-direction:column;gap:var(--space-4)}.auth-divider{display:flex;align-items:center;gap:var(--space-3);margin:var(--space-4) 0;color:var(--color-text-tertiary);font-size:var(--font-size-xs)}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.auth-footer{margin-top:var(--space-4);text-align:center;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.auth-footer a,.auth-footer button{color:var(--color-primary);font-weight:var(--font-weight-medium);background:none;border:none;cursor:pointer;padding:var(--space-1) 0;min-height:44px;font-size:inherit;vertical-align:middle}.auth-error{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--color-error-light);border:1px solid var(--color-error);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-error);animation:slideDown var(--transition-base) ease-out}.auth-success{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-4);background:var(--color-success-light);border:1px solid var(--color-success);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-success);animation:scaleIn var(--transition-base) ease-out}.otp-row{display:flex;gap:var(--space-2);justify-content:center}.otp-input{width:48px;height:56px;text-align:center;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text);caret-color:var(--color-primary);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.otp-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle)}.invite-badge{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-primary-light);border-radius:var(--radius-lg);margin-bottom:var(--space-5)}.invite-badge-icon{width:40px;height:40px;border-radius:var(--radius-md);background:var(--color-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:var(--font-size-lg)}.invite-badge-text{flex:1;font-size:var(--font-size-sm)}.invite-badge-name{font-weight:var(--font-weight-semibold);color:var(--color-text)}.invite-badge-label{color:var(--color-text-secondary)}.auth-steps{display:flex;gap:var(--space-2);justify-content:center;margin-bottom:var(--space-6)}.auth-step{width:8px;height:8px;border-radius:var(--radius-full);background:var(--color-border);transition:background var(--transition-fast),transform var(--transition-spring)}.auth-step[aria-current=true]{background:var(--color-primary);transform:scale(1.25)}.auth-step[data-done=true]{background:var(--color-success)}.auth-addr-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}@media(max-width:359px){.auth-addr-grid{grid-template-columns:1fr}.otp-input{width:38px;height:46px;font-size:var(--font-size-base)}.otp-row{gap:var(--space-1)}}@media(min-width:640px){.auth-page{justify-content:center}.auth-card{padding:var(--space-8)}}:root{--color-primary: #6366F1;--color-primary-hover: #4F46E5;--color-primary-light: #EEF2FF;--color-primary-subtle: rgba(99, 102, 241, .08);--color-secondary: #0EA5E9;--color-secondary-hover: #0284C7;--color-accent: #F59E0B;--color-accent-hover: #D97706;--color-success: #10B981;--color-success-light: #D1FAE5;--color-success-dark: #065F46;--color-warning: #F59E0B;--color-warning-light: #FEF3C7;--color-warning-dark: #854D0E;--color-error: #EF4444;--color-error-hover: #DC2626;--color-error-light: #FEE2E2;--color-error-dark: #B91C1C;--color-info: #3B82F6;--color-info-light: #DBEAFE;--color-bg: #FFFFFF;--color-bg-secondary: #F8FAFC;--color-bg-tertiary: #F1F5F9;--color-surface: #FFFFFF;--color-surface-raised: #FFFFFF;--color-border: #E2E8F0;--color-border-light: #F1F5F9;--color-text: #0F172A;--color-text-secondary: #44566C;--color-text-tertiary: #94A3B8;--color-text-inverse: #FFFFFF;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .8125rem;--font-size-base: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-light: 300;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold: 800;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .08), 0 2px 4px -2px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .04);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .06);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--transition-spring: .4s cubic-bezier(.34, 1.56, .64, 1);--z-dropdown: 100;--z-sticky: 200;--z-overlay: 300;--z-modal: 400;--z-toast: 500;--container-max: 1280px;--sidebar-width: 260px;--header-height: 64px;--bottom-nav-height: 64px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}[data-theme=dark]{--color-bg: #0F172A;--color-bg-secondary: #1E293B;--color-bg-tertiary: #334155;--color-surface: #1E293B;--color-surface-raised: #283548;--color-border: #334155;--color-border-light: #1E293B;--color-text: #F8FAFC;--color-text-secondary: #94A3B8;--color-text-tertiary: #64748B;--color-primary-light: rgba(99, 102, 241, .15);--color-success-light: rgba(16, 185, 129, .15);--color-warning-light: rgba(245, 158, 11, .15);--color-error-light: rgba(239, 68, 68, .15);--color-info-light: rgba(59, 130, 246, .15);--color-success-dark: #6EE7B7;--color-warning-dark: #FCD34D;--color-error-dark: #FCA5A5;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .3)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}@media(prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}body{font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100dvh;overflow:hidden}#root{height:100dvh;overflow:hidden;display:flex;flex-direction:column}img,video{max-width:100%;height:auto;display:block}button,input,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit;color:inherit}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);color:var(--color-text)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}.container{width:100%;max-width:var(--container-max);margin:0 auto;padding:0 var(--space-4)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);line-height:1;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;user-select:none;-webkit-user-select:none;touch-action:manipulation;min-height:44px}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:var(--shadow-md)}.btn-secondary{background:transparent;color:var(--color-primary);border-color:var(--color-primary)}.btn-secondary:hover:not(:disabled){background:var(--color-primary-light)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--color-bg-tertiary);color:var(--color-text)}.btn-danger{background:var(--color-error);color:var(--color-text-inverse)}.btn-danger:hover:not(:disabled){background:var(--color-error-hover, #DC2626);box-shadow:var(--shadow-md)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);min-height:44px;min-width:44px}.btn-lg{padding:var(--space-4) var(--space-6);font-size:var(--font-size-md);min-height:52px;border-radius:var(--radius-lg)}.btn-full{width:100%}.btn-icon{padding:var(--space-3);min-height:44px;min-width:44px}.input-group{display:flex;flex-direction:column;gap:var(--space-1)}.input-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.input-hint{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:var(--space-1)}.input{width:100%;padding:var(--space-3) var(--space-4);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);min-height:44px}.input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle)}.input::placeholder{color:var(--color-text-tertiary)}.input-error{border-color:var(--color-error)}.input-error:focus{box-shadow:0 0 0 3px #ef44441a}.error-text{font-size:var(--font-size-xs);color:var(--color-error)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);transition:box-shadow var(--transition-base),transform var(--transition-base)}.card-interactive{cursor:pointer}.card-interactive:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.card-interactive:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.card-elevated{border:none;box-shadow:var(--shadow-sm)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);border-radius:var(--radius-full);line-height:1}.badge-success{background:var(--color-success-light);color:var(--color-success)}.alert-success{display:flex;align-items:center;gap:var(--space-2);background:var(--color-success-light);border:1px solid var(--color-success);border-radius:var(--radius-md);padding:var(--space-3);font-size:var(--font-size-sm);color:#065f46}.badge-warning{background:var(--color-warning-light);color:#92400e}.badge-error{background:var(--color-error-light);color:var(--color-error)}.badge-info{background:var(--color-info-light);color:var(--color-info)}.status-dot{width:8px;height:8px;border-radius:var(--radius-full);display:inline-block;flex-shrink:0}.status-dot-success{background:var(--color-success)}.status-dot-warning{background:var(--color-warning)}.status-dot-error{background:var(--color-error)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fade-in{animation:fadeIn var(--transition-slow) ease-out}.animate-slide-up{animation:slideUp var(--transition-slow) ease-out}.animate-slide-down{animation:slideDown var(--transition-slow) ease-out}.animate-scale-in{animation:scaleIn var(--transition-base) ease-out}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-spin{animation:spin 1s linear infinite}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.skeleton{background:linear-gradient(90deg,var(--color-bg-tertiary) 25%,var(--color-bg-secondary) 50%,var(--color-bg-tertiary) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:var(--radius-md)}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}[data-theme=dark] .skeleton{background:linear-gradient(90deg,var(--color-bg-tertiary) 25%,#475569 50%,var(--color-bg-tertiary) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite}@media(prefers-reduced-motion:reduce){.skeleton,.skeleton-text{animation:none;background:var(--color-border)}}.toast-container{position:fixed;top:calc(var(--safe-top) + var(--space-4));right:var(--space-4);left:var(--space-4);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-2);pointer-events:none}.toast{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-lg);pointer-events:auto;animation:slideDown var(--transition-slow) ease-out}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:color-mix(in srgb,var(--color-text) 50%,transparent);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-overlay);animation:fadeIn var(--transition-fast)}.modal{position:fixed;bottom:0;left:0;right:0;z-index:var(--z-modal);background:var(--color-surface);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;padding:var(--space-6);padding-bottom:calc(var(--space-6) + var(--safe-bottom));max-height:90vh;max-height:90dvh;overflow-y:auto;animation:slideUp var(--transition-slow) ease-out}.modal-handle{width:36px;height:4px;background:var(--color-border);border-radius:var(--radius-full);margin:0 auto var(--space-5)}.secure-content{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}@media print{.secure-content{visibility:hidden;position:relative}.secure-content:after{content:"Content is protected and cannot be printed.";visibility:visible;position:absolute;top:0;left:0;display:block;font-size:var(--font-size-lg);text-align:center;padding:var(--space-8)}}.install-banner{position:fixed;bottom:calc(var(--bottom-nav-height, 64px) + var(--safe-bottom, 0px) + var(--space-2));left:var(--space-4);right:var(--space-4);z-index:var(--z-sticky);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:var(--color-text-inverse);border-radius:var(--radius-xl);padding:var(--space-4) var(--space-5) calc(var(--space-4) + var(--safe-bottom));box-shadow:var(--shadow-xl);display:flex;align-items:center;gap:var(--space-4);animation:slideUp var(--transition-slow) ease-out}.install-banner-text{flex:1}.install-banner-title{font-weight:var(--font-weight-semibold);font-size:var(--font-size-base)}.install-banner-subtitle{font-size:var(--font-size-xs);opacity:.85;margin-top:var(--space-1)}@media(min-width:1024px){.install-banner{bottom:var(--space-4)}}@media(min-width:640px){.container{padding:0 var(--space-6)}.modal{bottom:auto;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:var(--radius-2xl);max-width:480px;width:calc(100% - var(--space-8));animation:scaleIn var(--transition-base) ease-out}.toast-container{left:auto;width:380px}}@media(min-width:1024px){.container{padding:0 var(--space-8)}h1{font-size:var(--font-size-4xl)}}.sw-update-banner{position:fixed;bottom:calc(var(--bottom-nav-height, 60px) + var(--space-3));left:50%;transform:translate(-50%);background:var(--color-primary);color:#fff;padding:var(--space-3) var(--space-4);border-radius:var(--radius-full);display:flex;align-items:center;gap:var(--space-3);z-index:400;box-shadow:var(--shadow-lg);white-space:nowrap;font-size:var(--font-size-sm)}@media(min-width:1024px){.sw-update-banner{display:none}}.sw-update-banner .btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.4)}.sw-update-banner .btn:hover:not(:disabled){background:#ffffff59}.skip-to-content{position:absolute;top:-100%;left:var(--space-4);z-index:9999;padding:var(--space-2) var(--space-4);background:var(--color-primary);color:var(--color-text-inverse);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-decoration:none;transition:top var(--transition-fast)}.skip-to-content:focus{top:var(--space-2)}
