@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600&family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{--color-primary:#8b5cf6;--color-primary-dark:#7c3aed;--color-primary-light:#a78bfa;--color-secondary:#06b6d4;--color-accent:#f472b6;--color-success:#10b981;--color-warning:#f59e0b;--color-error:#ef4444;--color-bg-dark:#0f0f23;--color-bg-card:#1a1a2e;--color-bg-elevated:#252545;--color-bg-input:#16213e;--color-text-primary:#f8fafc;--color-text-secondary:#94a3b8;--color-text-muted:#64748b;--color-border:#334155;--color-border-light:#475569;--gradient-primary:linear-gradient(135deg,#8b5cf6 0%,#06b6d4 100%);--gradient-accent:linear-gradient(135deg,#f472b6 0%,#8b5cf6 100%);--gradient-bg:linear-gradient(135deg,#0f0f23 0%,#1a1a2e 50%,#16213e 100%);--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-2xl:48px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--shadow-sm:0 1px 2px rgba(0,0,0,.3);--shadow-md:0 4px 6px rgba(0,0,0,.3);--shadow-lg:0 10px 15px rgba(0,0,0,.4);--shadow-xl:0 20px 25px rgba(0,0,0,.5);--shadow-glow:0 0 20px rgba(139,92,246,.3);--font-family:"JetBrains Mono","Fira Code","SF Mono",Consolas,monospace;--font-family-display:"Space Grotesk","Inter",system-ui,sans-serif;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-md:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:2rem;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.35s ease;--z-dropdown:100;--z-modal:200;--z-overlay:150}.error-icon{flex-shrink:0;justify-content:center;align-items:center;display:flex}.error-icon svg{width:100%;height:100%}.error-icon.error{color:var(--color-error)}.error-icon.warning{color:var(--color-warning)}.error-icon.notfound{color:var(--color-text-muted)}.error-icon.auth{color:var(--color-error)}.error-icon.network{color:var(--color-warning)}.error-dismiss{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.error-dismiss:hover{color:var(--color-text-primary);background:rgba(255,255,255,.1)}.error-dismiss svg{width:16px;height:16px}.error-inline{align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-lg);margin-bottom:var(--spacing-md);animation:slideUp var(--transition-normal);background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.3);display:flex}.error-inline .error-icon{width:24px;height:24px;margin-top:2px}.error-inline-content{flex:1;min-width:0}.error-inline-content strong{font-size:var(--font-size-sm);color:var(--color-error);margin-bottom:2px;font-weight:600;display:block}.error-inline-content span{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.5;display:block}.error-card{align-items:flex-start;gap:var(--spacing-lg);padding:var(--spacing-lg);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);animation:slideUp var(--transition-normal);display:flex}.error-card .error-icon{width:48px;height:48px;padding:var(--spacing-sm);border-radius:var(--radius-lg);background:rgba(239,68,68,.1)}.error-card-content{flex:1;min-width:0}.error-card-content h3{font-size:var(--font-size-lg);color:var(--color-text-primary);margin-bottom:var(--spacing-xs);font-weight:600}.error-card-content p{font-size:var(--font-size-md);color:var(--color-text-secondary);margin:0;line-height:1.6}.error-fullpage{min-height:100vh;padding:var(--spacing-xl);background:radial-gradient(circle at 20% 20%,rgba(239,68,68,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(139,92,246,.1) 0%,transparent 50%),var(--gradient-bg);justify-content:center;align-items:center;display:flex}.error-fullpage-content{text-align:center;max-width:480px;animation:slideUp var(--transition-slow)}.error-fullpage .error-icon{width:96px;height:96px;margin:0 auto var(--spacing-xl);padding:var(--spacing-lg);background:var(--color-bg-card);border:1px solid var(--color-border);box-shadow:var(--shadow-xl);border-radius:50%}.error-fullpage h1{font-family:var(--font-family-display);font-size:var(--font-size-3xl);color:var(--color-text-primary);margin-bottom:var(--spacing-md);font-weight:700}.error-fullpage p{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin-bottom:var(--spacing-xl);line-height:1.6}.error-fullpage .btn{min-width:160px}.form-error{margin-top:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-error);display:block}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}.error-shake{animation:.5s ease-in-out shake}.login-page{min-height:100vh;padding:var(--spacing-md);background:radial-gradient(circle at 20% 20%,rgba(139,92,246,.15) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(6,182,212,.15) 0%,transparent 50%),var(--gradient-bg);justify-content:center;align-items:center;display:flex}.login-container{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:420px;box-shadow:var(--shadow-xl),var(--shadow-glow);animation:slideUp var(--transition-slow);overflow:hidden}.login-header{padding:var(--spacing-2xl)var(--spacing-xl);background:var(--gradient-primary);text-align:center}.login-logo{width:64px;height:64px;margin:0 auto var(--spacing-md);display:block}.login-header h1{font-family:var(--font-family-display);font-size:var(--font-size-3xl);color:#fff;margin-bottom:var(--spacing-xs);font-weight:700}.login-header p{color:rgba(255,255,255,.8);font-size:var(--font-size-sm)}.auth-selection,.email-form,.enroll-section{padding:var(--spacing-xl)}.enroll-section{text-align:center}.passkey-icon{margin-bottom:var(--spacing-md);font-size:64px}.enroll-section h2{margin-bottom:var(--spacing-sm)}.enroll-section p{color:var(--color-text-secondary);margin-bottom:var(--spacing-xl)}.enroll-section .enroll-hint{margin-top:var(--spacing-md);font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:0}form{padding:var(--spacing-xl)}.auth-selection .btn{margin-bottom:var(--spacing-md)}.btn.google svg{width:18px;height:18px}.signup-link{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border);text-align:center}.signup-link p{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0}.signup-link a{color:var(--color-primary);transition:color var(--transition-fast);font-weight:500;text-decoration:none}.signup-link a:hover{color:var(--color-primary-light);text-decoration:underline}.login-footer{padding:var(--spacing-md)var(--spacing-xl);text-align:center;border-top:1px solid var(--color-border);background:var(--color-bg-elevated)}.login-footer a{color:var(--color-text-muted);font-size:var(--font-size-sm);transition:color var(--transition-fast);text-decoration:none}.login-footer a:hover{color:var(--color-primary)}.login-footer .separator{color:var(--color-text-muted);margin:0 var(--spacing-sm)}.session-banner{padding:var(--spacing-md)var(--spacing-xl);background:linear-gradient(135deg,rgba(102,126,234,.1) 0%,rgba(118,75,162,.1) 100%);border-bottom:1px solid rgba(102,126,234,.2)}.session-user{align-items:center;gap:var(--spacing-md);display:flex}.session-avatar{object-fit:cover;border:2px solid var(--color-primary);border-radius:50%;width:48px;height:48px}.session-avatar-placeholder{background:var(--gradient-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.25rem;font-weight:600;display:flex}.session-info{flex-direction:column;display:flex}.session-name{color:var(--color-text);font-weight:600}.session-email{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.session-hint{margin-top:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.loading-spinner{border:4px solid rgba(139,92,246,.2);border-top-color:var(--color-primary);width:48px;height:48px;margin:var(--spacing-xl)auto;border-radius:50%;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.signed-in-section{padding-bottom:var(--spacing-xl)}.signed-in-section .session-banner{border-bottom:none;border-radius:0}.signed-in-actions{padding:0 var(--spacing-xl);gap:var(--spacing-md);flex-direction:column;display:flex}.signout-btn{color:var(--color-text-secondary)!important;border-color:var(--color-border)!important}.signout-btn:hover{color:var(--color-error)!important;border-color:var(--color-error)!important;background:rgba(239,68,68,.1)!important}.connected-orgs{padding:var(--spacing-lg)var(--spacing-xl)0;margin-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.connected-orgs h3{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-sm)}.connected-orgs ul{margin:0;padding:0;list-style:none}.connected-orgs li{padding:var(--spacing-sm)0;align-items:center;gap:var(--spacing-sm);display:flex}.connected-orgs li:before{content:"🏢";font-size:var(--font-size-sm)}.connected-orgs .org-name{font-size:var(--font-size-sm);color:var(--color-text)}.connecting-section{padding-bottom:var(--spacing-xl)}.connecting-section .session-banner{border-bottom:none}.recovery-section{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.recovery-hint{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center;margin-bottom:var(--spacing-md)}.recovery-link{margin-top:var(--spacing-sm);font-size:var(--font-size-sm)!important;color:var(--color-text-secondary)!important}.recovery-link:hover{color:var(--color-primary)!important}.signup-page{background:linear-gradient(135deg,#0f0f1a 0%,#1a1a2e 50%,#16213e 100%);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex;position:relative;overflow:hidden}.signup-page:before{content:"";pointer-events:none;background:radial-gradient(circle at 30% 30%,rgba(99,102,241,.1) 0%,transparent 50%),radial-gradient(circle at 70% 70%,rgba(139,92,246,.08) 0%,transparent 50%);width:200%;height:200%;animation:20s ease-in-out infinite gradientShift;position:absolute;top:-50%;left:-50%}@keyframes gradientShift{0%{transform:translate(0,0)scale(1.05)}50%{transform:translate(-4%,-2%)scale(1.1)}to{transform:translate(0,0)scale(1.05)}}.signup-container{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:1;background:rgba(30,30,46,.95);border-radius:16px;width:100%;max-width:480px;padding:2.5rem;position:relative;box-shadow:0 25px 50px -12px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.05)}.signup-header{text-align:center;margin-bottom:2rem}.signup-header .logo{justify-content:center;align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.signup-header .logo-img{object-fit:contain;width:48px;height:48px}.signup-header .logo-icon{font-size:2rem}.signup-header .logo h1{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#fff 0%,#94a3b8 100%);-webkit-background-clip:text;background-clip:text;margin:0;font-size:1.75rem;font-weight:700}.signup-header .badge{color:#a5b4fc;text-transform:uppercase;letter-spacing:.05em;background:linear-gradient(135deg,rgba(99,102,241,.2) 0%,rgba(139,92,246,.2) 100%);border:1px solid rgba(99,102,241,.3);border-radius:20px;margin-bottom:1rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.signup-header h2{color:#f1f5f9;margin:0 0 .5rem;font-size:1.5rem;font-weight:600}.signup-header p{color:#94a3b8;margin:0;font-size:.9rem}.signup-header .user-email{color:#a5b4fc;font-weight:500}.signup-mode-toggle{background:rgba(15,15,26,.6);border:1px solid rgba(99,102,241,.15);border-radius:10px;gap:0;margin-bottom:1.5rem;padding:4px;display:flex}.signup-mode-toggle .mode-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:.75rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.signup-mode-toggle .mode-btn:hover:not(.active){color:#cbd5e1;background:rgba(99,102,241,.1)}.signup-mode-toggle .mode-btn.active{color:#fff;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);box-shadow:0 2px 8px rgba(99,102,241,.3)}.signup-form{flex-direction:column;gap:1.25rem;display:flex}.signup-form .form-group{flex-direction:column;gap:.5rem;display:flex}.signup-form label{color:#cbd5e1;font-size:.875rem;font-weight:500}.signup-form input{color:#f1f5f9;background:rgba(15,15,26,.6);border:1px solid rgba(99,102,241,.2);border-radius:8px;padding:.875rem 1rem;font-size:1rem;transition:all .2s}.signup-form input:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px rgba(99,102,241,.2)}.signup-form input::placeholder{color:#64748b}.auth-buttons{flex-direction:column;gap:.75rem;margin-top:.5rem;display:flex}.btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.75rem;padding:.875rem 1.5rem;font-size:.95rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.btn.primary{color:#fff;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);box-shadow:0 4px 15px rgba(99,102,241,.4)}.btn.primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px rgba(99,102,241,.5)}.btn.primary:disabled{opacity:.6;cursor:not-allowed}.btn.secondary{color:#a5b4fc;background:rgba(99,102,241,.15);border:1px solid rgba(99,102,241,.3)}.btn.secondary:hover{background:rgba(99,102,241,.25);border-color:rgba(99,102,241,.5)}.btn.google{color:#374151;background:#fff;font-weight:500;box-shadow:0 2px 8px rgba(0,0,0,.1)}.btn.google:hover:not(:disabled){background:#f9fafb;box-shadow:0 4px 12px rgba(0,0,0,.15)}.btn.google:disabled{opacity:.7;cursor:not-allowed}.btn.text{color:#94a3b8;background:0 0;padding:.5rem}.btn.text:hover{color:#f1f5f9}.btn-icon{font-size:1.25rem}.divider{color:#64748b;align-items:center;gap:1rem;font-size:.85rem;display:flex}.message{border-radius:8px;margin-bottom:1rem;padding:.875rem 1rem;font-size:.875rem}.message.success{color:#86efac;background:rgba(34,197,94,.15);border:1px solid rgba(34,197,94,.3)}.message.error{color:#fca5a5;background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.3)}.message.info{color:#93c5fd;background:rgba(59,130,246,.15);border:1px solid rgba(59,130,246,.3)}.signup-footer{text-align:center;border-top:1px solid rgba(100,116,139,.2);margin-top:1rem;padding-top:1rem}.signup-footer p{color:#94a3b8;margin:0;font-size:.875rem}.signup-footer a{color:#a5b4fc;font-weight:500;text-decoration:none}.signup-footer a:hover{color:#c4b5fd;text-decoration:underline}.features-list{border-top:1px solid rgba(100,116,139,.2);margin-top:2rem;padding-top:1.5rem}.features-list h3{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin:0 0 1rem;font-size:.875rem;font-weight:600}.features-list ul{flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none;display:flex}.features-list li{color:#cbd5e1;align-items:center;gap:.75rem;font-size:.9rem;display:flex}.features-list .feature-icon{font-size:1.1rem}.admin-setup .admin-logo{flex-direction:column;gap:.5rem}.setup-info{background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.2);border-radius:8px;margin-top:1.5rem;padding:1rem}.setup-info h4{color:#a5b4fc;margin:0 0 .5rem;font-size:.9rem;font-weight:600}.setup-info p{color:#94a3b8;margin:0;font-size:.85rem;line-height:1.5}.admin-features{border-top:1px solid rgba(100,116,139,.2);margin-top:2rem;padding-top:1.5rem}.admin-features h3{color:#94a3b8;margin:0 0 1rem;font-size:.875rem;font-weight:600}.admin-features ul{flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none;display:flex}.admin-features li{color:#cbd5e1;align-items:center;gap:.75rem;font-size:.9rem;display:flex}.passkey-enroll .signup-container{max-width:520px}.passkey-auto-status{color:#94a3b8;margin:0 0 .75rem;font-size:.9rem}.passkey-retry-hint{color:#cbd5e1;margin-top:.75rem;font-size:.85rem;line-height:1.45}.passkey-setup{text-align:center}.passkey-illustration{margin-bottom:1.5rem}.passkey-icon-large{font-size:4rem;animation:3s ease-in-out infinite float;display:inline-block}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.passkey-info{margin-bottom:1.5rem}.passkey-info h3{color:#f1f5f9;margin:0 0 .5rem;font-size:1.1rem;font-weight:600}.passkey-info p{color:#94a3b8;margin:0;font-size:.9rem;line-height:1.6}.passkey-benefits{text-align:left;flex-direction:column;gap:1rem;margin-bottom:2rem;display:flex}.passkey-benefits .benefit{background:rgba(99,102,241,.08);border-radius:8px;align-items:flex-start;gap:.75rem;padding:.75rem;display:flex}.passkey-benefits .benefit-icon{flex-shrink:0;font-size:1.25rem}.passkey-benefits .benefit strong{color:#f1f5f9;margin-bottom:.25rem;font-size:.9rem;display:block}.passkey-benefits .benefit p{color:#94a3b8;margin:0;font-size:.8rem}.security-note{color:#64748b;margin-top:1rem;font-size:.8rem;line-height:1.5}.spinner{border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin;display:inline-block}.loading{text-align:center;color:#94a3b8;padding:2rem}@media (max-width:640px){.signup-page{padding:1rem}.signup-container{padding:1.5rem}.signup-header h2{font-size:1.25rem}.passkey-benefits .benefit{text-align:center;flex-direction:column}}.landing-page{background:var(--gradient-bg);min-height:100vh;color:var(--color-text-primary);font-family:var(--font-family);position:relative;overflow-x:hidden}.landing-content{z-index:2;position:relative}.landing-background{z-index:0;pointer-events:none;filter:blur(var(--landing-bg-blur,0px));transition:filter .2s;position:fixed;top:0;bottom:0;left:0;right:0}.landing-gradient{opacity:.9;background:linear-gradient(120deg,rgba(15,15,35,.8),rgba(22,33,62,.8),rgba(139,92,246,.2));animation:18s ease-in-out infinite gradientShift;position:absolute;top:-20%;bottom:-20%;left:-20%;right:-20%}.landing-canvas{width:100%;height:100%;position:absolute;top:0;bottom:0;left:0;right:0}.landing-canvas.bg{opacity:.6}.landing-canvas.pulse{opacity:.9}@media (prefers-reduced-motion:reduce){.landing-gradient{animation:none}}.landing-nav{z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:rgba(15,15,35,.8);justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto;padding:1rem 2rem;display:flex;position:-webkit-sticky;position:sticky;top:0}.nav-logo{color:var(--color-text-primary);align-items:center;gap:.75rem;text-decoration:none;display:flex}.nav-logo-img{width:40px;height:40px}.nav-logo-text{font-size:1.5rem;font-weight:700;font-family:var(--font-family-display)}.nav-links{align-items:center;gap:2rem;display:flex}.nav-link{color:var(--color-text-secondary);transition:color var(--transition-fast);font-size:.9rem;text-decoration:none}.nav-link:hover{color:var(--color-text-primary)}.mobile-menu-btn{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:4px;padding:.5rem;display:none}.mobile-menu-btn span{background:var(--color-text-primary);width:24px;height:2px;transition:var(--transition-fast);display:block}.hero{grid-template-columns:1fr 1fr;align-items:center;gap:4rem;max-width:1400px;margin:0 auto;padding:4rem 2rem 6rem;display:grid}.hero-badge{border-radius:var(--radius-full);color:var(--color-primary-light);background:rgba(139,92,246,.15);border:1px solid rgba(139,92,246,.3);align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.5rem 1rem;font-size:.85rem;display:inline-flex}.badge-icon{font-size:1rem}.hero-title{font-family:var(--font-family-display);margin:0 0 1.5rem;font-size:3.5rem;font-weight:700;line-height:1.1}.gradient-text{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:var(--color-text-secondary);max-width:540px;margin:0 0 2rem;font-size:1.2rem;line-height:1.7}.hero-cta{gap:1rem;margin-bottom:3rem;display:flex}.btn{border-radius:var(--radius-md);font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);border:none;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.95rem;font-weight:500;text-decoration:none;display:inline-flex}.btn.primary:hover{box-shadow:var(--shadow-lg),0 0 30px rgba(139,92,246,.4);transform:translateY(-2px)}.btn.secondary{color:var(--color-text-primary);border:1px solid var(--color-border);background:rgba(255,255,255,.05)}.btn.secondary:hover{border-color:var(--color-primary);background:rgba(255,255,255,.1)}.btn.large{padding:1rem 2rem;font-size:1rem}.btn-arrow{transition:transform var(--transition-fast)}.btn:hover .btn-arrow{transform:translate(4px)}.hero-stats{align-items:center;gap:2rem;display:flex}.stat{flex-direction:column;gap:.25rem;display:flex}.stat-value{color:var(--color-primary-light);font-size:1.1rem;font-weight:600}.stat-divider{background:var(--color-border);width:1px;height:40px}.hero-visual{justify-content:center;display:flex}.code-window{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl),0 0 60px rgba(139,92,246,.1);width:100%;max-width:520px;overflow:hidden}.code-header{border-bottom:1px solid var(--color-border);background:rgba(0,0,0,.3);align-items:center;gap:1rem;padding:.75rem 1rem;display:flex}.code-dots{gap:6px;display:flex}.code-dots span{border-radius:50%;width:12px;height:12px}.code-dots span:first-child{background:#ef4444}.code-dots span:nth-child(2){background:#f59e0b}.code-dots span:nth-child(3){background:#10b981}.code-title{color:var(--color-text-muted);font-size:.8rem}.code-content{color:var(--color-text-secondary);white-space:pre-wrap;word-break:break-word;margin:0;padding:1.5rem;font-size:.8rem;line-height:1.6}.features{max-width:1400px;margin:0 auto;padding:6rem 2rem}.section-header{text-align:center;margin-bottom:4rem}.section-badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;color:var(--color-secondary);background:rgba(6,182,212,.15);border:1px solid rgba(6,182,212,.3);margin-bottom:1rem;padding:.5rem 1rem;font-size:.8rem;font-weight:600;display:inline-block}.section-header h2{font-family:var(--font-family-display);margin:0 0 1rem;font-size:2.5rem;font-weight:700}.section-header p{color:var(--color-text-secondary);margin:0;font-size:1.1rem}.features-grid{grid-template-columns:repeat(3,1fr);gap:2rem;display:grid}.feature-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-normal);padding:2rem}.feature-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-lg),var(--shadow-glow);transform:translateY(-4px)}.feature-icon{margin-bottom:1rem;font-size:2.5rem}.feature-card h3{font-family:var(--font-family-display);margin:0 0 .75rem;font-size:1.25rem}.feature-card p{color:var(--color-text-secondary);margin:0;font-size:.95rem;line-height:1.6}.integration{background:rgba(0,0,0,.2);padding:6rem 2rem}.integration-content{grid-template-columns:1.5fr 1fr;align-items:start;gap:4rem;max-width:1200px;margin:0 auto;display:grid}.tab-list{gap:.5rem;margin-bottom:1rem;display:flex}.tab{border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;font-family:var(--font-family);transition:all var(--transition-fast);background:0 0;padding:.75rem 1.5rem;font-size:.9rem}.tab.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.tab:hover:not(.active){border-color:var(--color-primary);color:var(--color-text-primary)}.code-example{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:720px;min-height:180px;max-height:220px;overflow:hidden}.code-example pre{color:var(--color-text-secondary);white-space:pre-wrap;word-break:break-word;margin:0;padding:1.25rem;font-size:.85rem;line-height:1.6;overflow:auto}.integration-features{flex-direction:column;gap:1.5rem;display:flex}.int-feature{align-items:flex-start;gap:1rem;display:flex}.check{width:24px;height:24px;color:var(--color-success);background:rgba(16,185,129,.2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;font-size:.8rem;display:flex}.int-feature strong{margin-bottom:.25rem;font-size:1rem;display:block}.int-feature p{color:var(--color-text-secondary);margin:0;font-size:.9rem}.security{max-width:1400px;margin:0 auto;padding:6rem 2rem}.security-grid{grid-template-columns:1.5fr 1fr;gap:2rem;display:grid}.security-card.main{border-radius:var(--radius-lg);background:linear-gradient(135deg,rgba(139,92,246,.1) 0%,rgba(6,182,212,.1) 100%);border:1px solid rgba(139,92,246,.3);padding:2.5rem}.security-card h3{font-family:var(--font-family-display);margin:0 0 1rem;font-size:1.5rem}.security-card p{color:var(--color-text-secondary);margin:0 0 1.5rem;font-size:1rem;line-height:1.7}.security-card ul{margin:0;padding:0;list-style:none}.security-card li{color:var(--color-text-secondary);margin-bottom:.75rem;padding-left:1.5rem;font-size:.95rem;position:relative}.security-card li:before{content:"→";color:var(--color-primary);position:absolute;left:0}.security-features{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.sec-feature{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.25rem}.sec-icon{margin-bottom:.75rem;font-size:1.5rem;display:block}.sec-feature h4{margin:0 0 .5rem;font-size:.95rem}.sec-feature p{color:var(--color-text-secondary);margin:0;font-size:.85rem;line-height:1.5}.cta-section{text-align:center;background:linear-gradient(135deg,rgba(139,92,246,.15) 0%,rgba(6,182,212,.15) 100%);padding:6rem 2rem}.cta-content{max-width:600px;margin:0 auto}.cta-content h2{font-family:var(--font-family-display);margin:0 0 1rem;font-size:2.5rem;font-weight:700}.cta-content p{color:var(--color-text-secondary);margin:0 0 2rem;font-size:1.1rem}.cta-buttons{justify-content:center;gap:1rem;display:flex}.landing-footer{border-top:1px solid var(--color-border);padding:4rem 2rem 2rem}.footer-content{grid-template-columns:1fr 2fr;gap:4rem;max-width:1200px;margin:0 auto;display:grid}.footer-brand{flex-direction:column;gap:.5rem;display:flex}.footer-logo{width:48px;height:48px}.footer-brand span{font-size:1.25rem;font-weight:600;font-family:var(--font-family-display)}.footer-brand p{color:var(--color-text-secondary);margin:0;font-size:.9rem}.footer-links{grid-template-columns:repeat(3,1fr);gap:2rem;display:grid}.footer-column h4{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin:0 0 1rem;font-size:.85rem;font-weight:600}.footer-column a{color:var(--color-text-secondary);transition:color var(--transition-fast);padding:.35rem 0;font-size:.9rem;text-decoration:none;display:block}.footer-column a:hover{color:var(--color-text-primary)}.footer-bottom{border-top:1px solid var(--color-border);text-align:center;max-width:1200px;margin:3rem auto 0;padding-top:2rem}.footer-bottom p{color:var(--color-text-muted);margin:0;font-size:.85rem}@media (max-width:1024px){.hero{text-align:center;grid-template-columns:1fr;gap:3rem}.hero-content{flex-direction:column;align-items:center;display:flex}.hero-subtitle{max-width:100%}.hero-stats{justify-content:center}.features-grid{grid-template-columns:repeat(2,1fr)}.integration-content,.security-grid{grid-template-columns:1fr}.security-features{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.landing-nav{padding:1rem}.nav-links{background:var(--color-bg-card);border-bottom:1px solid var(--color-border);flex-direction:column;gap:.5rem;padding:1rem;display:none;position:absolute;top:100%;left:0;right:0}.nav-links.open{display:flex}.nav-links .btn{justify-content:center;width:100%}.mobile-menu-btn{display:flex}.hero{padding:2rem 1rem 4rem}.hero-title{font-size:2.25rem}.hero-subtitle{font-size:1rem}.hero-cta{flex-direction:column;width:100%}.hero-cta .btn{justify-content:center;width:100%}.hero-stats{flex-direction:column;gap:1rem}.stat-divider{display:none}.features-grid{grid-template-columns:1fr}.section-header h2{font-size:1.75rem}.security-features{grid-template-columns:1fr}.cta-content h2{font-size:1.75rem}.cta-buttons{flex-direction:column}.cta-buttons .btn{width:100%}.footer-content{grid-template-columns:1fr;gap:2rem}.footer-links{grid-template-columns:1fr;gap:1.5rem}}.layout{min-height:100vh;display:flex}.sidebar{background:var(--color-bg-card);border-right:1px solid var(--color-border);width:260px;z-index:var(--z-dropdown);transition:transform var(--transition-normal);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.logo-link{align-items:center;gap:var(--spacing-sm);text-decoration:none;display:flex}.logo-img{object-fit:contain;width:32px;height:32px}.logo-text,.sidebar-header .logo{font-family:var(--font-family-display);font-size:var(--font-size-xl);background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700}.menu-close{color:var(--color-text-secondary);font-size:var(--font-size-lg);cursor:pointer;background:0 0;border:none;display:none}.sidebar-nav{padding:var(--spacing-md)0;flex:1;overflow-y:auto}.sidebar-nav ul{list-style:none}.sidebar-nav a{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm)var(--spacing-lg);color:var(--color-text-secondary);transition:all var(--transition-fast);display:flex}.sidebar-nav a:hover{color:var(--color-text-primary);background:rgba(139,92,246,.1)}.sidebar-nav a.active{color:var(--color-primary-light);border-right:3px solid var(--color-primary);background:rgba(139,92,246,.15)}.nav-icon{font-size:var(--font-size-lg)}.nav-label{font-size:var(--font-size-sm)}.nav-divider{padding:var(--spacing-lg)var(--spacing-lg)var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em;border-top:1px solid var(--color-border);margin-top:var(--spacing-sm)}.sidebar-footer{padding:var(--spacing-md)var(--spacing-lg);border-top:1px solid var(--color-border)}.user-info{align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);display:flex}.user-avatar{border-radius:var(--radius-full);object-fit:cover;width:40px;height:40px}.user-avatar.placeholder{background:var(--gradient-primary);color:#fff;justify-content:center;align-items:center;font-weight:600;display:flex}.user-avatar.small{width:32px;height:32px;font-size:var(--font-size-sm)}.user-details{flex:1;min-width:0}.user-name{font-size:var(--font-size-sm);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:500;display:block;overflow:hidden}.user-email{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;display:block;overflow:hidden}.logout-btn{width:100%;padding:var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-family:var(--font-family);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0}.logout-btn:hover{border-color:var(--color-error);color:var(--color-error)}.main-content{flex-direction:column;flex:1;min-height:100vh;margin-left:260px;display:flex}.mobile-header{padding:var(--spacing-md);background:var(--color-bg-card);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:none}.menu-toggle{color:var(--color-text-primary);font-size:var(--font-size-xl);cursor:pointer;background:0 0;border:none}.mobile-header .logo{font-family:var(--font-family-display);font-size:var(--font-size-lg);background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700}.content-wrapper{padding:var(--spacing-xl);flex:1}.sidebar-overlay{display:none}@media (max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.menu-close{display:block}.main-content{margin-left:0}.mobile-header{display:flex}.content-wrapper{padding:var(--spacing-md)}.sidebar-overlay{z-index:calc(var(--z-dropdown) - 1);background:rgba(0,0,0,.5);display:block;position:fixed;top:0;bottom:0;left:0;right:0}}.dashboard{animation:fadeIn var(--transition-normal)}.dashboard-header{margin-bottom:var(--spacing-xl)}.dashboard-header h1{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-xs)}.dashboard-header p{color:var(--color-text-secondary)}.dashboard-cards{gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));display:grid}.tenant-card .tenant-info{margin-bottom:var(--spacing-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md)}.tenant-name{font-size:var(--font-size-lg);margin-bottom:var(--spacing-xs);color:var(--color-text-primary);font-weight:600;display:block}.tenant-id{font-size:var(--font-size-xs);color:var(--color-text-muted);font-family:var(--font-family);display:block}.roles{gap:var(--spacing-xs);flex-wrap:wrap;display:flex}.quick-links .links-grid{gap:var(--spacing-sm);grid-template-columns:repeat(3,1fr);display:grid}.quick-link{align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast);flex-direction:column;display:flex}.quick-link:hover{border-color:var(--color-primary);color:var(--color-primary-light);background:rgba(139,92,246,.1);transform:translateY(-2px)}.quick-link .icon{font-size:var(--font-size-xl)}.quick-link span:last-child{font-size:var(--font-size-xs)}.stats .stat-items{gap:var(--spacing-md);flex-direction:column;display:flex}.stat-item{justify-content:space-between;align-items:center;display:flex}.stat-label{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.stat-value{font-weight:500}.stat-value.verified{color:var(--color-success)}.stat-value.unverified{color:var(--color-warning)}.organizations .org-list{list-style:none}.organizations li{padding:var(--spacing-sm)var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-xs);justify-content:space-between;align-items:center;display:flex}.organizations li.active{background:rgba(139,92,246,.1)}.org-name{font-weight:500}.current-badge{font-size:var(--font-size-xs);background:var(--color-primary);color:#fff;border-radius:var(--radius-full);padding:2px 8px}.profile-loading{padding:var(--spacing-xl);color:var(--color-text-secondary)}.profile-fetch-error{margin-bottom:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-md);border:1px solid var(--color-error);background:rgba(239,68,68,.08)}.profile-fetch-error p{margin:0 0 var(--spacing-sm)}.profile-content{gap:var(--spacing-lg);grid-template-columns:1fr 1fr;max-width:800px;display:grid}@media (max-width:768px){.profile-content{grid-template-columns:1fr}}.profile-card{grid-column:1}.profile-avatar{text-align:center;margin-bottom:var(--spacing-lg)}.profile-avatar img{border-radius:var(--radius-full);object-fit:cover;border:3px solid var(--color-primary);width:100px;height:100px}.field-status{margin-top:var(--spacing-xs)}.verified{color:var(--color-success);font-size:var(--font-size-sm)}.unverified{color:var(--color-warning);font-size:var(--font-size-sm)}.account-info{grid-column:2}@media (max-width:768px){.account-info{grid-column:1}}.info-item{padding:var(--spacing-sm)0;border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.info-item:last-child{border-bottom:none}.info-item .label{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.info-item code{font-size:var(--font-size-xs)}.status-active{color:var(--color-success)}.status-inactive{color:var(--color-warning)}.connected-apps,.active-sessions{margin-top:var(--spacing-md);grid-column:1/-1}.section-header{margin-bottom:var(--spacing-xs);justify-content:space-between;align-items:center;display:flex}.section-header h3{margin:0}.consents-list,.sessions-list,.pending-list{margin:0;padding:0;list-style:none}.consent-item,.session-item,.pending-item{padding:var(--spacing-md);border-radius:var(--radius-md);background:var(--color-background);margin-bottom:var(--spacing-sm);justify-content:space-between;align-items:center;display:flex}.consent-item:last-child,.session-item:last-child,.pending-item:last-child{margin-bottom:0}.consent-info,.session-info{align-items:center;gap:var(--spacing-md);display:flex}.tenant-icon,.device-icon{font-size:1.5rem}.consent-details,.session-details{flex-direction:column;display:flex}.tenant-name,.device-name{color:var(--color-text);font-weight:500}.consent-meta,.session-meta{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.consent-meta .roles{color:var(--color-primary)}.current-badge{background:var(--color-primary-light);color:var(--color-primary);border-radius:var(--radius-full);font-size:var(--font-size-xs);margin-left:var(--spacing-xs);padding:.125rem .5rem;font-weight:500;display:inline-block}.session-item.current{background:linear-gradient(135deg,rgba(102,126,234,.05) 0%,rgba(118,75,162,.05) 100%);border:1px solid rgba(102,126,234,.2)}.pending-section{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.pending-section h4{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.empty-state{text-align:center;padding:var(--spacing-xl);color:var(--color-text-secondary)}.empty-state .empty-icon{margin-bottom:var(--spacing-sm);font-size:2rem;display:block}.btn.small{font-size:var(--font-size-sm);padding:.375rem .75rem}.btn.danger{color:var(--color-error);border:1px solid var(--color-error);background:0 0}.btn.danger:hover{background:var(--color-error);color:#fff}.passkeys-info{margin-bottom:var(--spacing-lg)}.info-card{align-items:flex-start;gap:var(--spacing-md);border:1px solid var(--color-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);background:rgba(6,182,212,.1);display:flex}.info-card .icon{font-size:var(--font-size-2xl)}.info-card h3{margin-bottom:var(--spacing-xs);color:var(--color-secondary)}.info-card p{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0}.passkeys-list{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.passkey-name{align-items:center;gap:var(--spacing-sm);display:flex}.passkey-name .icon{font-size:var(--font-size-lg)}.passkey-illustration{margin-bottom:var(--spacing-md);font-size:64px}.device-support{background:var(--color-bg-elevated);border-radius:var(--radius-md);padding:var(--spacing-md);margin:var(--spacing-lg)0;text-align:left}.device-support h4{margin-bottom:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.device-support ul{list-style:none}.device-support li{padding:var(--spacing-xs)0;font-size:var(--font-size-sm);color:var(--color-text-muted)}.users-page,.api-keys-page,.passkeys-page,.email-domain-page,.settings-page,.profile-page{animation:fadeIn var(--transition-normal)}.page-header{margin-bottom:var(--spacing-xl);justify-content:space-between;align-items:center;display:flex}.page-header h1{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-xs)}.page-header h1 .tenant-badge{font-size:var(--font-size-lg);color:var(--color-primary);font-weight:400}.page-header p{color:var(--color-text-secondary)}.users-table{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.user-row-actions{align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.pending-invitation-row{background:rgba(139,92,246,.06)}.pending-invitation-row .muted{color:var(--color-text-muted);font-size:var(--font-size-xs)}.avatar-placeholder.invite{background:var(--color-bg-elevated);color:var(--color-text-secondary);font-size:var(--font-size-xs)}.status.invite-pending{color:var(--color-warning);border-color:rgba(245,158,11,.35)}.user-cell{align-items:center;gap:var(--spacing-sm);display:flex}.avatar{border-radius:var(--radius-full);object-fit:cover;width:32px;height:32px}.avatar-placeholder{border-radius:var(--radius-full);background:var(--gradient-primary);color:#fff;width:32px;height:32px;font-weight:600;font-size:var(--font-size-sm);justify-content:center;align-items:center;display:flex}.avatar-placeholder.large{width:80px;height:80px;font-size:var(--font-size-xl)}.roles-select{gap:var(--spacing-sm);flex-direction:column;display:flex}.role-checkbox{align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm)var(--spacing-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);display:flex}.role-checkbox:hover{border-color:var(--color-primary)}.role-checkbox input{margin-top:2px}.role-checkbox .role-name{font-weight:500;display:block}.role-checkbox .role-desc{font-size:var(--font-size-xs);color:var(--color-text-muted);display:block}.edit-user-info{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-lg)}.edit-user-info p{margin:var(--spacing-xs)0;color:var(--color-text-secondary)}.edit-user-info p strong{color:var(--color-text-primary);margin-right:var(--spacing-xs)}.empty-state{text-align:center;padding:var(--spacing-2xl);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.empty-state h3{margin-bottom:var(--spacing-sm)}.empty-state p{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.roles-page{max-width:1200px;margin:0 auto;padding:2rem}.roles-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-top:1.5rem;display:grid}.role-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem;transition:all .2s}.role-card:hover{border-color:var(--color-primary);box-shadow:0 4px 12px rgba(0,0,0,.1)}.role-card.system{border-color:var(--color-secondary);background:linear-gradient(135deg,rgba(6,182,212,.05) 0%,transparent 100%)}.role-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.role-header h3{color:var(--color-text);text-transform:capitalize;margin:0;font-size:1.25rem}.system-badge{text-transform:uppercase;background:var(--color-secondary);color:#fff;border-radius:4px;padding:.25rem .5rem;font-size:.7rem;font-weight:600}.role-description{color:var(--color-text-secondary);margin:0 0 1rem;font-size:.9rem;line-height:1.5}.role-permissions h4{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin:0 0 .75rem;font-size:.75rem}.permissions-list{flex-wrap:wrap;gap:.5rem;display:flex}.permission-badge{color:var(--color-primary);background:rgba(139,92,246,.1);border-radius:4px;padding:.25rem .5rem;font-family:monospace;font-size:.75rem}.no-permissions{color:var(--color-text-secondary);font-size:.85rem;font-style:italic}.role-actions{border-top:1px solid var(--color-border);gap:.5rem;margin-top:1rem;padding-top:1rem;display:flex}.role-actions .btn.text.danger{color:var(--color-error);font-family:var(--font-family);background:0 0}.role-actions .btn.text.danger:hover{background:rgba(239,68,68,.1)}.permissions-select{background:var(--color-bg);border-radius:8px;flex-direction:column;gap:.5rem;max-height:300px;padding:.5rem;display:flex;overflow-y:auto}.permission-checkbox{cursor:pointer;border-radius:6px;align-items:center;gap:.75rem;padding:.5rem;transition:background .2s;display:flex}.permission-checkbox:hover{background:var(--color-surface)}.permission-checkbox input[type=checkbox]{width:18px;min-width:18px;height:18px;accent-color:var(--color-primary);margin-right:.5rem}.perm-name{color:var(--color-text);white-space:nowrap;font-family:monospace;font-size:.85rem}.perm-desc{color:var(--color-text-secondary);margin-left:.5rem;font-size:.8rem}.permission-checkbox.custom{border:1px dashed var(--color-border);background:rgba(139,92,246,.05)}@media (max-width:768px){.roles-page{padding:1rem}.roles-grid{grid-template-columns:1fr}.permission-checkbox{flex-wrap:wrap}.perm-desc{flex-basis:100%;margin-left:calc(18px + .75rem)}}.tenants-page{max-width:1200px;margin:0 auto;padding:2rem}.tenants-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-top:1.5rem;display:grid}.tenant-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem;transition:all .2s}.tenant-card:hover{border-color:var(--color-primary);box-shadow:0 4px 12px rgba(0,0,0,.1)}.tenant-card.platform{border-color:var(--color-accent);background:linear-gradient(135deg,rgba(245,158,11,.05) 0%,transparent 100%)}.tenant-header{align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.tenant-icon{font-size:2rem;line-height:1}.tenant-info{flex:1;min-width:0}.tenant-info h3{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;margin:0 0 .25rem;font-size:1.15rem;overflow:hidden}.tenant-id{color:var(--color-text-secondary);background:var(--color-bg);border-radius:4px;padding:.15rem .4rem;font-family:monospace;font-size:.75rem}.tenant-meta{border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);gap:1.5rem;padding:1rem 0;display:flex}.meta-item{flex-direction:column;gap:.25rem;display:flex}.meta-label{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);font-size:.7rem}.meta-value{color:var(--color-text);font-size:.9rem}.status-badge{text-transform:capitalize;border-radius:4px;padding:.2rem .5rem;font-size:.75rem;font-weight:500}.status-badge.active{color:var(--color-success);background:rgba(34,197,94,.1)}.status-badge.suspended{color:var(--color-error);background:rgba(239,68,68,.1)}.status-badge.pending{color:var(--color-accent);background:rgba(245,158,11,.1)}.tenant-actions{flex-wrap:wrap;gap:.5rem;margin-top:1rem;display:flex}.tenant-actions .btn{text-align:center;flex:none;padding:.4rem .6rem;font-size:.8rem}.empty-state{text-align:center;background:var(--color-surface);border:1px dashed var(--color-border);border-radius:12px;margin-top:1.5rem;padding:4rem 2rem}.empty-icon{margin-bottom:1rem;font-size:3rem}.empty-state h3{color:var(--color-text);margin:0 0 .5rem}.empty-state p{color:var(--color-text-secondary);margin:0 0 1.5rem}.header-actions{align-items:center;gap:1rem;display:flex}.view-toggle{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;display:flex;overflow:hidden}.toggle-btn{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;padding:.5rem 1rem;font-size:.85rem;transition:all .2s}.toggle-btn:hover{background:var(--color-bg)}.toggle-btn.active{background:var(--color-primary);color:#fff}.tenants-tree{margin-top:1.5rem}.tenant-tree-node{margin-bottom:.75rem}.tenant-tree-node .tenant-card{border-left:3px solid var(--color-border)}.tenant-tree-node .tenant-card.subtenant{background:var(--color-bg);border-left-color:var(--color-primary-light)}.expand-btn{background:var(--color-bg);cursor:pointer;width:24px;height:24px;color:var(--color-text-secondary);border:none;border-radius:4px;flex-shrink:0;font-size:.7rem;transition:all .2s}.expand-btn:hover{background:var(--color-primary-light);color:var(--color-primary)}.expand-placeholder{flex-shrink:0;width:24px}.subtenants-container{border-left:2px solid var(--color-border);margin-top:.5rem;margin-left:12px;padding-left:.5rem}.loading-subtenants{color:var(--color-text-secondary);padding:1rem;font-size:.9rem}.tenant-card.subtenant{border-left:3px solid var(--color-primary)}.parent-info{color:var(--color-text-secondary);margin-top:.25rem;font-size:.7rem;font-style:italic;display:block}.create-subtenant-btn{color:var(--color-primary)!important}.create-subtenant-btn:hover{background:var(--color-primary-light)!important}.modal-subtitle{color:var(--color-text-secondary);margin-top:-.5rem;margin-bottom:1.5rem;font-size:.9rem}.info-box{color:var(--color-text-secondary);background:rgba(59,130,246,.05);border:1px solid rgba(59,130,246,.2);border-radius:8px;align-items:flex-start;gap:.75rem;margin:1rem 0;padding:1rem;font-size:.85rem;line-height:1.5;display:flex}.info-icon{flex-shrink:0;font-size:1rem}.inherited-notice{color:var(--color-text-secondary);background:rgba(245,158,11,.05);border:1px solid rgba(245,158,11,.2);border-radius:8px;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.75rem 1rem;font-size:.85rem;display:flex}.notice-icon{flex-shrink:0}.toggle.disabled{opacity:.6;cursor:not-allowed}.toggle.disabled input{cursor:not-allowed}.checkbox-label.disabled{opacity:.6;cursor:not-allowed}@media (max-width:768px){.tenants-page{padding:1rem}.tenants-grid{grid-template-columns:1fr}.tenant-meta{flex-direction:column;gap:.75rem}.header-actions{flex-direction:column;align-items:stretch;gap:.75rem}.view-toggle{width:100%}.toggle-btn{flex:1}}.keys-table{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.key-name{font-weight:500}.key-prefix code{font-size:var(--font-size-sm)}tr.revoked{opacity:.5}.actions{gap:var(--spacing-xs);display:flex}.warning-message{border:1px solid var(--color-warning);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);background:rgba(245,158,11,.1)}.key-display{background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);display:flex}.key-display code{word-break:break-all;font-size:var(--font-size-sm);background:0 0;flex:1;padding:0}.domain-content{gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));display:grid}.current-config .config-item{padding:var(--spacing-sm)0;border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.current-config .config-item:last-of-type{margin-bottom:var(--spacing-md);border-bottom:none}.config-item .label{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.config-item .value{font-weight:500}.config-item .status.default{color:var(--color-text-muted)}.config-item .status.verified{color:var(--color-success)}.config-item .status.pending{color:var(--color-warning)}.action-section p{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-md)}.test-email-card .test-form{gap:var(--spacing-sm);margin-top:var(--spacing-md);display:flex}.test-email-card input{flex:1}.dns-records{background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);overflow:hidden}.dns-records table{margin:0}.dns-records code{background:0 0}.record-name,.record-value{word-break:break-all;max-width:200px;font-size:var(--font-size-xs)}.dns-instructions{border:1px solid var(--color-secondary);border-radius:var(--radius-md);padding:var(--spacing-md);background:rgba(6,182,212,.1)}.dns-instructions h4{margin-bottom:var(--spacing-sm);color:var(--color-secondary)}.dns-instructions ol{margin-left:var(--spacing-lg);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.dns-instructions li{margin-bottom:var(--spacing-xs)}.embed-docs-page{padding:var(--spacing-lg);max-width:1400px;margin:0 auto}.embed-docs-page .page-header{margin-bottom:var(--spacing-xl)}.embed-docs-page .page-header h1{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-xs)}.embed-docs-page .page-header p{color:var(--color-text-secondary)}.docs-layout{gap:var(--spacing-xl);grid-template-columns:260px 1fr;display:grid}@media (max-width:900px){.docs-layout{grid-template-columns:1fr}}.docs-sidebar{top:var(--spacing-lg);height:-webkit-fit-content;height:fit-content;position:-webkit-sticky;position:sticky}.sidebar-section{background:var(--color-surface);border-radius:var(--border-radius);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.sidebar-section h3{font-size:var(--font-size-sm);text-transform:uppercase;color:var(--color-text-secondary);margin-bottom:var(--spacing-sm);letter-spacing:.05em}.sidebar-link{align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm)var(--spacing-md);border-radius:var(--border-radius-sm);color:var(--color-text);font-size:var(--font-size-sm);text-align:left;cursor:pointer;background:0 0;border:none;transition:all .15s;display:flex}.sidebar-link:hover{color:var(--color-primary);background:rgba(139,92,246,.1)}.sidebar-link.active{background:var(--color-primary);color:#fff}.sidebar-link .icon{font-size:1.1em}.tenant-info-sidebar{margin-bottom:var(--spacing-sm)}.tenant-info-sidebar label{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-bottom:2px;display:block}.tenant-info-sidebar code{font-size:var(--font-size-xs);background:var(--color-bg);padding:var(--spacing-xs);border-radius:var(--border-radius-sm);word-break:break-all;display:block}.tenant-info-sidebar code.small{font-size:10px}.docs-content{min-width:0}.doc-section{background:var(--color-surface);border-radius:var(--border-radius);padding:var(--spacing-xl)}.doc-section h2{font-size:var(--font-size-xl);margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.doc-section h3{font-size:var(--font-size-lg);margin-top:var(--spacing-xl);margin-bottom:var(--spacing-md);color:var(--color-text)}.doc-section h4{font-size:var(--font-size-md);margin-top:var(--spacing-lg);margin-bottom:var(--spacing-sm);color:var(--color-text-secondary)}.doc-section p{color:var(--color-text-secondary);margin-bottom:var(--spacing-md);line-height:1.7}.doc-section .intro{font-size:var(--font-size-md);color:var(--color-text)}.doc-section ul,.doc-section ol{margin-bottom:var(--spacing-md);padding-left:var(--spacing-lg)}.doc-section li{color:var(--color-text-secondary);margin-bottom:var(--spacing-xs);line-height:1.6}.doc-section a{color:var(--color-primary);text-decoration:none}.doc-section a:hover{text-decoration:underline}.info-box,.warning-box{border-left:4px solid var(--color-primary);border-radius:var(--border-radius-sm);padding:var(--spacing-md);margin:var(--spacing-lg)0;background:rgba(139,92,246,.1)}.info-box h4,.warning-box h4{margin-top:0;margin-bottom:var(--spacing-sm);color:var(--color-text)}.info-box ul,.warning-box ul{margin-bottom:0}.warning-box{background:rgba(245,158,11,.1);border-left-color:#f59e0b}.integration-cards{gap:var(--spacing-lg);margin:var(--spacing-lg)0;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));display:grid}.integration-cards .card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:var(--spacing-lg);transition:all .2s}.integration-cards .card:hover{border-color:var(--color-primary);transform:translateY(-2px)}.card-icon{margin-bottom:var(--spacing-sm);font-size:2rem}.integration-cards .card h4{margin-top:0;margin-bottom:var(--spacing-sm);color:var(--color-text)}.integration-cards .card p{font-size:var(--font-size-sm);margin-bottom:var(--spacing-sm)}.integration-cards .card ul{font-size:var(--font-size-sm);margin-bottom:0}.code-block{border:1px solid var(--color-border);border-radius:var(--border-radius);padding:var(--spacing-md);white-space:pre;color:#e2e8f0;margin:var(--spacing-md)0;background:#1a1a2e;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:13px;line-height:1.5;overflow-x:auto}.architecture-diagram{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:var(--spacing-md);margin:var(--spacing-lg)0;overflow-x:auto}.architecture-diagram pre{color:var(--color-text-secondary);white-space:pre;margin:0;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:12px;line-height:1.4}.docs-table{border-collapse:collapse;width:100%;margin:var(--spacing-md)0;font-size:var(--font-size-sm)}.docs-table th,.docs-table td{padding:var(--spacing-sm)var(--spacing-md);text-align:left;border-bottom:1px solid var(--color-border)}.docs-table th{background:var(--color-bg);color:var(--color-text-secondary);text-transform:uppercase;font-weight:500;font-size:var(--font-size-xs);letter-spacing:.05em}.docs-table td{color:var(--color-text)}.docs-table code{background:var(--color-bg);border-radius:4px;padding:2px 6px;font-size:12px}.endpoint{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:var(--spacing-lg);margin:var(--spacing-lg)0}.endpoint-header{align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);display:flex}.endpoint-header .method{font-size:var(--font-size-xs);text-transform:uppercase;border-radius:4px;padding:4px 8px;font-weight:600}.endpoint-header .method.get{color:#22c55e;background:rgba(34,197,94,.2)}.endpoint-header .method.post{color:#3b82f6;background:rgba(59,130,246,.2)}.endpoint-header .method.put{color:#f59e0b;background:rgba(245,158,11,.2)}.endpoint-header .method.delete{color:#ef4444;background:rgba(239,68,68,.2)}.endpoint-header code{font-size:var(--font-size-md);background:0 0;padding:0}.endpoint p{margin-bottom:var(--spacing-sm)}.endpoint h4{margin-top:var(--spacing-md);margin-bottom:var(--spacing-xs)}.endpoint .code-block{margin:var(--spacing-xs)0}.security-item{background:var(--color-bg);border-radius:var(--border-radius);padding:var(--spacing-lg);margin:var(--spacing-lg)0}.security-item h4{margin-top:0}.security-item h4:nth-of-type(2){margin-top:var(--spacing-lg);color:#ef4444}.doc-section code{background:var(--color-bg);border-radius:4px;padding:2px 6px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.9em}@media (max-width:900px){.embed-docs-page{padding:var(--spacing-md)}.docs-sidebar{gap:var(--spacing-sm);flex-wrap:wrap;display:flex;position:static}.sidebar-section{flex:1;min-width:200px}.doc-section{padding:var(--spacing-md)}.integration-cards{grid-template-columns:1fr}.code-block{padding:var(--spacing-sm);font-size:11px}.architecture-diagram pre{font-size:10px}}.tabs{gap:var(--spacing-sm);margin:var(--spacing-lg)0;border-bottom:1px solid var(--color-border);padding-bottom:var(--spacing-sm);display:flex}.tab{padding:var(--spacing-sm)var(--spacing-md);border-radius:var(--border-radius-sm);color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;transition:all .15s}.tab:hover{color:var(--color-text);background:rgba(255,255,255,.05)}.tab.active{color:var(--color-primary);background:rgba(139,92,246,.1)}.events-table{border-collapse:collapse;width:100%;margin:var(--spacing-md)0}.events-table th,.events-table td{padding:var(--spacing-sm);text-align:left;border-bottom:1px solid var(--color-border)}.events-table th{color:var(--color-text-secondary);font-weight:500}.events-table code{background:var(--color-bg);border-radius:4px;padding:2px 6px;font-size:12px}.quick-start{margin-bottom:var(--spacing-xl)}.tenant-info,.embed-url{background:var(--color-bg);padding:var(--spacing-md);border-radius:var(--border-radius);margin:var(--spacing-sm)0}.tenant-info code,.embed-url code{background:var(--color-surface);padding:var(--spacing-xs)var(--spacing-sm);border-radius:var(--border-radius-sm);margin-left:var(--spacing-sm)}.customization,.security{margin-top:var(--spacing-xl);padding-top:var(--spacing-xl);border-top:1px solid var(--color-border)}.integration-method h4{margin-top:var(--spacing-lg);margin-bottom:var(--spacing-sm)}.integration-method ul{margin-bottom:var(--spacing-lg)}.settings-content{max-width:720px}.settings-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);margin-bottom:var(--spacing-lg)}.settings-section h2{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.section-description{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-md)}.toggle-group{margin-bottom:var(--spacing-lg)}.toggle{align-items:center;gap:var(--spacing-md);cursor:pointer;display:flex}.toggle input{display:none}.toggle-slider{background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-full);width:48px;height:24px;transition:all var(--transition-fast);position:relative}.toggle-slider:after{content:"";background:var(--color-text-muted);border-radius:var(--radius-full);width:18px;height:18px;transition:all var(--transition-fast);position:absolute;top:2px;left:2px}.toggle input:checked+.toggle-slider{background:var(--color-primary);border-color:var(--color-primary)}.toggle input:checked+.toggle-slider:after{background:#fff;transform:translate(24px)}.toggle-label{font-weight:500}.toggle-description{margin-top:var(--spacing-xs);margin-left:calc(48px + var(--spacing-md));color:var(--color-text-muted);font-size:var(--font-size-sm)}.origins-list{gap:var(--spacing-sm);margin-bottom:var(--spacing-md);flex-wrap:wrap;display:flex}.origin-item{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs)var(--spacing-sm);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex}.origin-item code{background:0 0}.add-origin{gap:var(--spacing-sm);display:flex}.add-origin input{flex:1}.settings-actions{margin-top:var(--spacing-xl)}.saved-badge{background:var(--color-success);color:#fff;padding:var(--spacing-xs)var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-sm);animation:fadeIn var(--transition-fast)}.input-with-toggle{gap:var(--spacing-sm);display:flex}.input-with-toggle input{flex:1}.webhook-events{gap:var(--spacing-sm);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);flex-direction:column;display:flex}.checkbox-label{align-items:flex-start;gap:var(--spacing-sm);cursor:pointer;display:flex}.checkbox-text{flex-direction:column;display:flex}.checkbox-text strong{font-weight:500}.checkbox-text small{color:var(--color-text-muted);font-size:var(--font-size-xs)}.webhook-test{margin-top:var(--spacing-md)}.webhook-deliveries{margin-top:var(--spacing-lg)}.webhook-deliveries h4{margin-bottom:var(--spacing-md)}.deliveries-list{gap:var(--spacing-sm);flex-direction:column;display:flex}.delivery-item{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sm)var(--spacing-md)}.delivery-item.success{border-left:3px solid var(--color-success)}.delivery-item.error{border-left:3px solid var(--color-error)}.delivery-header{margin-bottom:var(--spacing-xs);justify-content:space-between;align-items:center;display:flex}.delivery-event{font-weight:500;font-family:var(--font-family-mono);font-size:var(--font-size-sm)}.delivery-status{border-radius:var(--radius-sm);font-size:var(--font-size-xs);padding:2px 8px;font-weight:500}.delivery-status.success{color:var(--color-success);background:rgba(34,197,94,.2)}.delivery-status.error{color:var(--color-error);background:rgba(239,68,68,.2)}.delivery-meta{gap:var(--spacing-md);font-size:var(--font-size-xs);color:var(--color-text-muted);display:flex}.delivery-error{margin-top:var(--spacing-xs);padding:var(--spacing-xs);border-radius:var(--radius-sm);font-size:var(--font-size-xs);color:var(--color-error);background:rgba(239,68,68,.1)}.legal-page{background:var(--color-bg-primary);min-height:100vh;color:var(--color-text-primary)}.legal-header{padding:var(--spacing-xl)var(--spacing-2xl);text-align:center;border-bottom:1px solid var(--color-border);background:var(--color-bg-card)}.legal-header .logo-link{text-decoration:none}.legal-header .logo-text{font-family:var(--font-family-display);font-size:var(--font-size-2xl);background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700}.legal-header .subtitle{color:var(--color-text-muted);margin-top:var(--spacing-xs);font-size:var(--font-size-sm)}.legal-content{max-width:800px;padding:var(--spacing-2xl);margin:0 auto}.legal-content h1{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-sm);font-weight:700}.legal-content .last-updated{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-bottom:var(--spacing-xl)}.legal-content section{margin-bottom:var(--spacing-xl)}.legal-content h2{font-size:var(--font-size-xl);margin-bottom:var(--spacing-md);margin-top:var(--spacing-xl);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border);font-weight:600}.legal-content h3{font-size:var(--font-size-lg);margin-bottom:var(--spacing-sm);margin-top:var(--spacing-lg);color:var(--color-text-secondary);font-weight:600}.legal-content p{margin-bottom:var(--spacing-md);color:var(--color-text-secondary);line-height:1.7}.legal-content .important-notice{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-left:4px solid var(--color-primary);padding:var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:var(--spacing-lg)}.legal-content ul{margin-bottom:var(--spacing-md);padding-left:var(--spacing-xl)}.legal-content li{margin-bottom:var(--spacing-sm);color:var(--color-text-secondary);line-height:1.6}.legal-content a{color:var(--color-primary);text-decoration:none}.legal-content a:hover{text-decoration:underline}.legal-footer{padding:var(--spacing-xl)var(--spacing-2xl);text-align:center;border-top:1px solid var(--color-border);background:var(--color-bg-card)}.legal-footer p{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-bottom:var(--spacing-md)}.footer-links{justify-content:center;gap:var(--spacing-lg);display:flex}.footer-links a{color:var(--color-text-secondary);font-size:var(--font-size-sm);text-decoration:none}.footer-links a:hover{color:var(--color-primary)}@media (max-width:768px){.legal-content{padding:var(--spacing-lg)}.legal-content h1{font-size:var(--font-size-2xl)}.legal-content h2{font-size:var(--font-size-lg)}}.oauth-clients-page{padding:var(--spacing-xl);max-width:1200px;margin:0 auto}.clients-grid{gap:var(--spacing-lg);margin-top:var(--spacing-xl);grid-template-columns:repeat(auto-fill,minmax(380px,1fr));display:grid}.client-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:border-color var(--transition-fast)}.client-card:hover{border-color:var(--color-primary)}.client-header{margin-bottom:var(--spacing-md);justify-content:space-between;align-items:flex-start;display:flex}.client-header h3{color:var(--color-text-primary);font-size:var(--font-size-lg);margin:0}.client-type{padding:var(--spacing-xs)var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);text-transform:capitalize;font-weight:500}.client-type.confidential{color:var(--color-primary);background:rgba(139,92,246,.1)}.client-type.public{color:var(--color-warning);background:rgba(245,158,11,.1)}.client-id{margin-bottom:var(--spacing-md)}.client-id .label{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:var(--spacing-xs);text-transform:uppercase;letter-spacing:.05em;display:block}.client-id code{background:var(--color-bg-elevated);padding:var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);word-break:break-all;display:block}.client-details{border-top:1px solid var(--color-border);padding-top:var(--spacing-md)}.detail-group{margin-bottom:var(--spacing-md)}.detail-group .label{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:var(--spacing-xs);text-transform:uppercase;letter-spacing:.05em;display:block}.uri-list{gap:var(--spacing-xs);flex-direction:column;display:flex}.uri-list code{background:var(--color-bg-elevated);padding:var(--spacing-xs)var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);word-break:break-all}.badge-list{gap:var(--spacing-xs);flex-wrap:wrap;display:flex}.badge{padding:var(--spacing-xs)var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500}.badge.scope{color:var(--color-success);background:rgba(34,197,94,.1)}.badge.grant{color:#3b82f6;background:rgba(59,130,246,.1)}.client-meta{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);font-size:var(--font-size-sm);color:var(--color-text-muted)}.client-actions{margin-top:var(--spacing-md);justify-content:flex-end;display:flex}.empty-state{text-align:center;padding:var(--spacing-2xl);background:var(--color-bg-card);border:1px dashed var(--color-border);border-radius:var(--radius-lg);margin-top:var(--spacing-xl)}.empty-state .icon{margin-bottom:var(--spacing-md);font-size:3rem}.empty-state h3{margin:0 0 var(--spacing-sm)0;color:var(--color-text-primary)}.empty-state p{margin:0 0 var(--spacing-lg)0;color:var(--color-text-muted)}.modal.large{max-width:600px;max-height:90vh;overflow-y:auto}.radio-group{gap:var(--spacing-sm);flex-direction:column;display:flex}.radio-label{align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-bg-elevated);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);display:flex}.radio-label:has(input:checked){border-color:var(--color-primary);background:rgba(139,92,246,.05)}.radio-label input{margin-top:4px}.radio-label span{flex-direction:column;display:flex}.radio-label strong{color:var(--color-text-primary)}.radio-label small{color:var(--color-text-muted);font-size:var(--font-size-sm)}.uri-input-row{gap:var(--spacing-sm);margin-bottom:var(--spacing-sm);display:flex}.uri-input-row input{flex:1}.checkbox-grid{gap:var(--spacing-sm);grid-template-columns:repeat(auto-fill,minmax(250px,1fr));display:grid}.checkbox-label{align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-bg-elevated);border-radius:var(--radius-sm);cursor:pointer;display:flex}.checkbox-label input{margin-top:4px}.checkbox-label span{flex-direction:column;display:flex}.checkbox-label strong{color:var(--color-text-primary);font-size:var(--font-size-sm)}.checkbox-label small{color:var(--color-text-muted);font-size:var(--font-size-xs)}.credentials-display{margin:var(--spacing-lg)0}.credential{margin-bottom:var(--spacing-md)}.credential .label{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--spacing-xs);display:block}.value-row{gap:var(--spacing-sm);align-items:center;display:flex}.value-row code{background:var(--color-bg-elevated);padding:var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);word-break:break-all;flex:1}.value-row code.secret{font-family:var(--font-family-mono)}.warning-message{border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.3)}.warning-message strong{color:var(--color-warning);margin-bottom:var(--spacing-xs);display:block}.warning-message p{color:var(--color-text-muted);font-size:var(--font-size-sm);margin:0}@media (max-width:768px){.oauth-clients-page{padding:var(--spacing-md)}.clients-grid,.checkbox-grid{grid-template-columns:1fr}}.consent-page{color:#111827;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.consent-card{color:#111827;background:#fff;border-radius:16px;width:100%;max-width:440px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.3)}.consent-card.loading{text-align:center;color:#374151;padding:3rem}.consent-card.loading p{color:#4b5563}.consent-card.loading .spinner{border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;width:48px;height:48px;margin:0 auto 1rem;animation:1s linear infinite spin}.consent-card.error,.consent-card.success{text-align:center;color:#111827;padding:2rem}.consent-card.error h2,.consent-card.error p,.consent-card.success h2,.consent-card.success p{color:#111827}.consent-card.error p:not(.help-text),.consent-card.success p{color:#374151}.consent-card .error-icon,.consent-card .success-icon{margin-bottom:1rem;font-size:3rem}.consent-card.success .success-icon{color:#10b981;background:#d1fae5;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 1rem;display:flex}.consent-header{text-align:center;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:1.5rem}.authnme-logo{color:#fff;justify-content:center;align-items:center;gap:.5rem;display:flex}.authnme-logo .logo-icon{font-size:1.5rem}.authnme-logo .logo-text{color:#fff;font-size:1.5rem;font-weight:700}.consent-body{padding:1.5rem 2rem}.consent-body h2{color:#111827;margin:0 0 .5rem;font-size:1.25rem}.consent-body p{color:#4b5563;margin:.5rem 0}.consent-body strong{color:#111827;font-weight:600}.tenant-request{text-align:center;margin-bottom:1.5rem}.tenant-request .tenant-icon{margin-bottom:.5rem;font-size:3rem}.tenant-request h2{color:#111827;font-size:1.5rem}.tenant-request .subtitle{color:#4b5563;font-size:1rem}.user-info{background:#f3f4f6;border-radius:8px;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:.75rem 1rem;display:flex}.user-avatar{border-radius:50%;flex-shrink:0;width:40px;height:40px;overflow:hidden}.user-avatar img{object-fit:cover;width:100%;height:100%}.user-avatar .avatar-initial{color:#fff;background:#667eea;justify-content:center;align-items:center;width:100%;height:100%;font-size:1.25rem;font-weight:600;display:flex}.user-details{flex-direction:column;display:flex}.user-name{color:#1f2937;font-weight:600}.user-email{color:#6b7280;font-size:.875rem}.permissions-section{margin-bottom:1.5rem}.permissions-section h3{color:#6b7280;margin-bottom:.75rem;font-size:.875rem;font-weight:500}.permissions-list{margin:0;padding:0;list-style:none}.permissions-list li{color:#374151;border-bottom:1px solid #e5e7eb;align-items:flex-start;gap:.75rem;padding:.625rem 0;font-size:.9375rem;line-height:1.45;display:flex}.permission-text{color:#374151;flex:1;min-width:0}.permissions-list li:last-child{border-bottom:none}.permission-icon{flex-shrink:0}.roles-section{background:#f0fdf4;border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem}.roles-section h4{color:#166534;margin:0 0 .5rem;font-size:.875rem;font-weight:500}.roles-list{flex-wrap:wrap;gap:.5rem;display:flex}.role-badge{color:#166534;background:#dcfce7;border-radius:9999px;padding:.25rem .75rem;font-size:.875rem;font-weight:500}.invited-by{color:#6b7280;text-align:center;margin-bottom:1rem;font-size:.875rem}.privacy-notice{color:#4b5563;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;align-items:flex-start;gap:.5rem;padding:.75rem;font-size:.8125rem;display:flex}.privacy-notice span:last-child{color:#4b5563}.privacy-notice .info-icon{flex-shrink:0}.consent-actions{gap:.75rem;padding:1rem 2rem 2rem;display:flex}.consent-actions button{cursor:pointer;border-radius:8px;flex:1;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s}.consent-actions .btn-primary{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none}.consent-actions .btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px rgba(102,126,234,.4)}.consent-actions .btn-primary:disabled{opacity:.7;cursor:not-allowed}.consent-actions .btn-secondary{color:#6b7280;background:#fff;border:1px solid #d1d5db}.consent-actions .btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.consent-actions .btn-secondary:disabled{opacity:.7;cursor:not-allowed}.tenant-info{background:#f3f4f6;border-radius:8px;margin-top:1rem;padding:1rem}.help-text{color:#6b7280;margin-top:1rem;font-size:.875rem}.integration-tests-page,.integration-callback-page{background:var(--gradient-bg);min-height:100vh;color:var(--color-text-primary);font-family:var(--font-family);padding:2rem}.integration-tests-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:2rem;margin-bottom:2rem;display:flex}.integration-brand{align-items:center;gap:1rem;display:flex}.integration-logo{width:48px;height:48px}.integration-brand h1{font-family:var(--font-family-display);margin:0 0 .35rem;font-size:1.8rem}.integration-brand p{color:var(--color-text-secondary);margin:0}.integration-actions{gap:.75rem;display:flex}.integration-section{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:rgba(0,0,0,.2);margin-bottom:1.5rem;padding:1.5rem}.integration-section h2{font-family:var(--font-family-display);margin:0 0 .5rem}.section-header p{color:var(--color-text-secondary);margin:0}.integration-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:1.25rem;display:grid}.form-group label{margin-bottom:.35rem;display:block}.form-group small{color:var(--color-text-muted);margin-top:.35rem;display:block}.form-actions{gap:.75rem;margin-top:.5rem;display:flex}.checkbox-group{flex-direction:column;gap:.25rem;display:flex}.checkbox-group label{cursor:pointer;align-items:center;gap:.5rem;display:flex}.checkbox-group label input[type=checkbox]{width:auto;margin:0}.widget-preview{border:1px dashed var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-card);justify-content:center;align-items:center;min-height:420px;padding:.75rem;display:flex}.widget-iframe{border-radius:var(--radius-md);background:#fff;border:none;width:100%;min-height:520px}.empty-state{color:var(--color-text-muted);text-align:center}.info-panel{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem}.info-panel .label{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:.5rem;font-size:.8rem;display:block}.info-panel ol{color:var(--color-text-secondary);margin:0;padding-left:1.25rem}.mono,.mono-block{color:var(--color-text-secondary);word-break:break-word;margin:0;font-family:JetBrains Mono,Fira Code,monospace;font-size:.85rem}.mono-block{border-radius:var(--radius-sm);background:rgba(0,0,0,.2);padding:.75rem;overflow-x:auto}.status-panel{border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);background:rgba(148,163,184,.1);padding:1rem}.status-panel.success{color:var(--color-success);border-color:rgba(16,185,129,.5)}.status-panel.error{color:var(--color-error);border-color:rgba(239,68,68,.6)}.error-text{color:var(--color-error);margin-top:.5rem}@media (max-width:768px){.integration-tests-page,.integration-callback-page{padding:1.25rem}.integration-actions{flex-direction:column;width:100%}.integration-actions .btn{justify-content:center;width:100%}.form-actions{flex-direction:column}}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-family);background:var(--gradient-bg);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:var(--font-family-display);font-weight:600;line-height:1.3}a{color:var(--color-primary-light);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary)}.btn{justify-content:center;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm)var(--spacing-md);border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;font-weight:500;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md),var(--shadow-glow)}.btn.primary:hover:not(:disabled){box-shadow:var(--shadow-lg),0 0 30px rgba(139,92,246,.4);transform:translateY(-2px)}.btn.secondary{background:var(--color-bg-elevated);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn.secondary:hover:not(:disabled){background:var(--color-bg-card);border-color:var(--color-primary)}.btn.outline{color:var(--color-text-primary);border:1px solid var(--color-border);background:0 0}.btn.outline:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary-light)}.btn.text{color:var(--color-text-secondary);padding:var(--spacing-xs)var(--spacing-sm);background:0 0}.btn.text:hover:not(:disabled){color:var(--color-text-primary)}.btn.danger{background:var(--color-error);color:#fff}.btn.danger:hover:not(:disabled){background:#dc2626}.btn.text.danger{color:var(--color-error);background:0 0}.btn.text.danger:hover:not(:disabled){color:#f87171;background:rgba(239,68,68,.12)}.btn.google{color:#333;background:#fff;border:1px solid #ddd}.btn.google:hover:not(:disabled){border-color:var(--color-primary);background:#f8f8f8}.btn.small{padding:var(--spacing-xs)var(--spacing-sm);font-size:var(--font-size-xs)}.btn.full-width{width:100%}.form-group{margin-bottom:var(--spacing-md)}.form-group label{margin-bottom:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary);display:block}textarea,select{width:100%;padding:var(--spacing-sm)var(--spacing-md);background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-md);transition:all var(--transition-fast)}input[type=text]{width:100%;padding:var(--spacing-sm)var(--spacing-md);background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-md);transition:all var(--transition-fast)}input[type=email]{width:100%;padding:var(--spacing-sm)var(--spacing-md);background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-md);transition:all var(--transition-fast)}input[type=password]{width:100%;padding:var(--spacing-sm)var(--spacing-md);background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-md);transition:all var(--transition-fast)}input[type=number]{width:100%;padding:var(--spacing-sm)var(--spacing-md);background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-md);transition:all var(--transition-fast)}input[type=url]{width:100%;padding:var(--spacing-sm)var(--spacing-md);background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-md);transition:all var(--transition-fast)}input:focus,textarea:focus,select:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px rgba(139,92,246,.2)}input:disabled{opacity:.6;cursor:not-allowed}input::placeholder{color:var(--color-text-muted)}small{margin-top:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-text-muted);display:block}.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md)}.card h3{margin-bottom:var(--spacing-md);color:var(--color-text-primary)}.message{padding:var(--spacing-sm)var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:var(--spacing-md)}.message.success{border:1px solid var(--color-success);color:var(--color-success);background:rgba(16,185,129,.1)}.message.error{border:1px solid var(--color-error);color:var(--color-error);background:rgba(239,68,68,.1)}.message.info{border:1px solid var(--color-secondary);color:var(--color-secondary);background:rgba(6,182,212,.1)}.loading{padding:var(--spacing-2xl);color:var(--color-text-muted);justify-content:center;align-items:center;display:flex}table{border-collapse:collapse;width:100%}th,td{padding:var(--spacing-sm)var(--spacing-md);text-align:left;border-bottom:1px solid var(--color-border)}th{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:500}tbody tr:hover{background:rgba(139,92,246,.05)}.role-badge{border-radius:var(--radius-full);font-size:var(--font-size-xs);background:var(--color-bg-elevated);color:var(--color-text-secondary);border:1px solid var(--color-border);padding:2px 8px;font-weight:500;display:inline-block}.role-badge.owner{color:var(--color-primary-light);border-color:var(--color-primary);background:rgba(139,92,246,.2)}.role-badge.admin{color:var(--color-secondary);border-color:var(--color-secondary);background:rgba(6,182,212,.2)}.status{align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);display:inline-flex}.status.active,.status.verified{color:var(--color-success)}.status.pending{color:var(--color-warning)}.status.revoked,.status.failed{color:var(--color-error)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-overlay);padding:var(--spacing-md);background:rgba(0,0,0,.7);justify-content:center;align-items:center;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.modal{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-xl);width:100%;max-width:480px;max-height:90vh;box-shadow:var(--shadow-xl);overflow-y:auto}.modal.large{max-width:640px}.modal h2{margin-bottom:var(--spacing-lg)}.modal-actions{gap:var(--spacing-md);margin-top:var(--spacing-xl);justify-content:flex-end;display:flex}.divider{margin:var(--spacing-lg)0;color:var(--color-text-muted);font-size:var(--font-size-sm);align-items:center;display:flex}.divider:before,.divider:after{content:"";background:var(--color-border);flex:1;height:1px}.divider span{padding:0 var(--spacing-md)}code{font-family:var(--font-family);background:var(--color-bg-input);border-radius:var(--radius-sm);font-size:var(--font-size-sm);padding:2px 6px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-dark)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-border-light)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-fadeIn{animation:fadeIn var(--transition-normal)}.animate-slideUp{animation:slideUp var(--transition-normal)}.back-link{font-size:var(--font-size-sm);color:var(--color-primary);margin-bottom:var(--spacing-sm);display:inline-block}.back-link:hover{color:var(--color-primary-light);text-decoration:underline}.tenant-badge{font-size:var(--font-size-lg);color:var(--color-primary);margin-left:var(--spacing-xs);font-weight:500}