@import url(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,#06b6d4);--gradient-accent:linear-gradient(135deg,#f472b6,#8b5cf6);--gradient-bg:linear-gradient(135deg,#0f0f23,#1a1a2e 50%,#16213e);--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 #0000004d;--shadow-md:0 4px 6px #0000004d;--shadow-lg:0 10px 15px #0006;--shadow-xl:0 20px 25px #00000080;--shadow-glow:0 0 20px #8b5cf64d;--font-family:"JetBrains Mono","Fira Code","SF Mono",Consolas,monospace;--font-family-display:"Space Grotesk","Inter",system-ui,sans-serif;--font-size-xs:0.75rem;--font-size-sm:0.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:150ms ease;--transition-normal:250ms ease;--transition-slow:350ms ease;--z-dropdown:100;--z-modal:200;--z-overlay:150}.error-icon{align-items:center;display:flex;flex-shrink:0;justify-content:center}.error-icon svg{height:100%;width: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{align-items:center;background:#0000;border:none;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;display:flex;flex-shrink:0;height:28px;justify-content:center;transition:all var(--transition-fast);width:28px}.error-dismiss:hover{background:#ffffff1a;color:var(--color-text-primary)}.error-dismiss svg{height:16px;width:16px}.error-inline{align-items:flex-start;animation:slideUp var(--transition-normal);background:#ef444414;border:1px solid #ef44444d;border-radius:var(--radius-lg);display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md);padding:var(--spacing-md)}.error-inline .error-icon{height:24px;margin-top:2px;width:24px}.error-inline-content{flex:1 1;min-width:0}.error-inline-content strong{color:var(--color-error);display:block;font-size:var(--font-size-sm);font-weight:600;margin-bottom:2px}.error-inline-content span{color:var(--color-text-secondary);display:block;font-size:var(--font-size-sm);line-height:1.5}.error-card{align-items:flex-start;animation:slideUp var(--transition-normal);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);display:flex;gap:var(--spacing-lg);padding:var(--spacing-lg)}.error-card .error-icon{background:#ef44441a;border-radius:var(--radius-lg);height:48px;padding:var(--spacing-sm);width:48px}.error-card-content{flex:1 1;min-width:0}.error-card-content h3{color:var(--color-text-primary);font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-xs)}.error-card-content p{color:var(--color-text-secondary);font-size:var(--font-size-md);line-height:1.6;margin:0}.error-fullpage{align-items:center;background:radial-gradient(circle at 20% 20%,#ef44441a 0,#0000 50%),radial-gradient(circle at 80% 80%,#8b5cf61a 0,#0000 50%),var(--gradient-bg);display:flex;justify-content:center;min-height:100vh;padding:var(--spacing-xl)}.error-fullpage-content{animation:slideUp var(--transition-slow);max-width:480px;text-align:center}.error-fullpage .error-icon{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:50%;box-shadow:var(--shadow-xl);height:96px;margin:0 auto var(--spacing-xl);padding:var(--spacing-lg);width:96px}.error-fullpage h1{color:var(--color-text-primary);font-family:var(--font-family-display);font-size:var(--font-size-3xl);font-weight:700;margin-bottom:var(--spacing-md)}.error-fullpage p{color:var(--color-text-secondary);font-size:var(--font-size-lg);line-height:1.6;margin-bottom:var(--spacing-xl)}.error-fullpage .btn{min-width:160px}.form-error{color:var(--color-error);display:block;font-size:var(--font-size-sm);margin-top:var(--spacing-xs)}@keyframes shake{0%,to{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-4px)}20%,40%,60%,80%{transform:translateX(4px)}}.error-shake{animation:shake .5s ease-in-out}.login-page{align-items:center;background:radial-gradient(circle at 20% 20%,#8b5cf626 0,#0000 50%),radial-gradient(circle at 80% 80%,#06b6d426 0,#0000 50%),var(--gradient-bg);display:flex;justify-content:center;min-height:100vh;padding:var(--spacing-md)}.login-container{animation:slideUp var(--transition-slow);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl),var(--shadow-glow);max-width:420px;overflow:hidden;width:100%}.login-header{background:var(--gradient-primary);padding:var(--spacing-2xl) var(--spacing-xl);text-align:center}.login-logo{display:block;height:64px;margin:0 auto var(--spacing-md);width:64px}.login-header h1{color:#fff;font-family:var(--font-family-display);font-size:var(--font-size-3xl);font-weight:700;margin-bottom:var(--spacing-xs)}.login-header p{color:#fffc;font-size:var(--font-size-sm)}.auth-selection,.email-form,.enroll-section{padding:var(--spacing-xl)}.enroll-section{text-align:center}.passkey-icon{font-size:64px;margin-bottom:var(--spacing-md)}.enroll-section h2{margin-bottom:var(--spacing-sm)}.enroll-section p{color:var(--color-text-secondary);margin-bottom:var(--spacing-xl)}form{padding:var(--spacing-xl)}.auth-selection .btn{margin-bottom:var(--spacing-md)}.btn.google svg{height:18px;width:18px}.signup-link{border-top:1px solid var(--color-border);margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);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);font-weight:500;text-decoration:none;transition:color var(--transition-fast)}.signup-link a:hover{color:var(--color-primary-light);text-decoration:underline}.login-footer{background:var(--color-bg-elevated);border-top:1px solid var(--color-border);padding:var(--spacing-md) var(--spacing-xl);text-align:center}.login-footer a{color:var(--color-text-muted);font-size:var(--font-size-sm);text-decoration:none;transition:color var(--transition-fast)}.login-footer a:hover{color:var(--color-primary)}.login-footer .separator{color:var(--color-text-muted);margin:0 var(--spacing-sm)}.session-banner{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-bottom:1px solid #667eea33;padding:var(--spacing-md) var(--spacing-xl)}.session-user{align-items:center;display:flex;gap:var(--spacing-md)}.session-avatar{border:2px solid var(--color-primary);border-radius:50%;height:48px;object-fit:cover;width:48px}.session-avatar-placeholder{align-items:center;background:var(--gradient-primary);border-radius:50%;color:#fff;display:flex;font-size:1.25rem;font-weight:600;height:48px;justify-content:center;width:48px}.session-info{display:flex;flex-direction:column}.session-name{color:var(--color-text);font-weight:600}.session-email,.session-hint{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.session-hint{margin-top:var(--spacing-sm)}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #8b5cf633;border-radius:50%;border-top:4px solid var(--color-primary);height:48px;margin:var(--spacing-xl) auto;width:48px}.signed-in-section{padding-bottom:var(--spacing-xl)}.signed-in-section .session-banner{border-bottom:none;border-radius:0}.signed-in-actions{display:flex;flex-direction:column;gap:var(--spacing-md);padding:0 var(--spacing-xl)}.signout-btn{border-color:var(--color-border)!important;color:var(--color-text-secondary)!important}.signout-btn:hover{background:#ef44441a!important;border-color:var(--color-error)!important;color:var(--color-error)!important}.connected-orgs{border-top:1px solid var(--color-border);margin-top:var(--spacing-lg);padding:var(--spacing-lg) var(--spacing-xl) 0}.connected-orgs h3{color:var(--color-text-secondary);font-size:var(--font-size-sm);letter-spacing:.05em;margin-bottom:var(--spacing-sm);text-transform:uppercase}.connected-orgs ul{list-style:none;margin:0;padding:0}.connected-orgs li{align-items:center;display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm) 0}.connected-orgs li:before{content:"🏢";font-size:var(--font-size-sm)}.connected-orgs .org-name{color:var(--color-text);font-size:var(--font-size-sm)}.connecting-section{padding-bottom:var(--spacing-xl)}.connecting-section .session-banner{border-bottom:none}.recovery-section{border-top:1px solid var(--color-border);margin-top:var(--spacing-lg);padding-top:var(--spacing-lg)}.recovery-hint{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-md);text-align:center}.recovery-link{color:var(--color-text-secondary)!important;font-size:var(--font-size-sm)!important;margin-top:var(--spacing-sm)}.recovery-link:hover{color:var(--color-primary)!important}.signup-page{align-items:center;background:linear-gradient(135deg,#0f0f1a,#1a1a2e 50%,#16213e);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:2rem;position:relative}.signup-page:before{animation:gradientShift 20s ease-in-out infinite;background:radial-gradient(circle at 30% 30%,#6366f11a 0,#0000 50%),radial-gradient(circle at 70% 70%,#8b5cf614 0,#0000 50%);content:"";height:200%;left:-50%;pointer-events:none;position:absolute;top:-50%;width:200%}.signup-container{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#1e1e2ef2;border-radius:16px;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #ffffff0d;max-width:480px;padding:2.5rem;position:relative;width:100%;z-index:1}.signup-header{margin-bottom:2rem;text-align:center}.signup-header .logo{align-items:center;display:flex;gap:.75rem;justify-content:center;margin-bottom:1.5rem}.signup-header .logo-img{height:48px;object-fit:contain;width:48px}.signup-header .logo-icon{font-size:2rem}.signup-header .logo h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#94a3b8);-webkit-background-clip:text;background-clip:text;font-size:1.75rem;font-weight:700;margin:0}.signup-header .badge{background:linear-gradient(135deg,#6366f133,#8b5cf633);border:1px solid #6366f14d;border-radius:20px;color:#a5b4fc;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:1rem;padding:.25rem .75rem;text-transform:uppercase}.signup-header h2{color:#f1f5f9;font-size:1.5rem;font-weight:600;margin:0 0 .5rem}.signup-header p{color:#94a3b8;font-size:.9rem;margin:0}.signup-header .user-email{color:#a5b4fc;font-weight:500}.signup-mode-toggle{background:#0f0f1a99;border:1px solid #6366f126;border-radius:10px;display:flex;gap:0;margin-bottom:1.5rem;padding:4px}.signup-mode-toggle .mode-btn{background:#0000;border:none;border-radius:8px;color:#94a3b8;cursor:pointer;flex:1 1;font-size:.875rem;font-weight:500;padding:.75rem 1rem;transition:all .2s ease}.signup-mode-toggle .mode-btn:hover:not(.active){background:#6366f11a;color:#cbd5e1}.signup-mode-toggle .mode-btn.active{background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 2px 8px #6366f14d;color:#fff}.signup-form{display:flex;flex-direction:column;gap:1.25rem}.signup-form .form-group{display:flex;flex-direction:column;gap:.5rem}.signup-form label{color:#cbd5e1;font-size:.875rem;font-weight:500}.signup-form input{background:#0f0f1a99;border:1px solid #6366f133;border-radius:8px;color:#f1f5f9;font-size:1rem;padding:.875rem 1rem;transition:all .2s ease}.signup-form input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f133;outline:none}.signup-form input::placeholder{color:#64748b}.auth-buttons{display:flex;flex-direction:column;gap:.75rem;margin-top:.5rem}.btn{border-radius:8px;gap:.75rem;padding:.875rem 1.5rem;transition:all .2s ease}.btn.large{padding:1rem 1.75rem}.btn.primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 4px 15px #6366f166}.btn.primary:hover:not(:disabled){box-shadow:0 6px 20px #6366f180;transform:translateY(-1px)}.btn.primary:disabled{cursor:not-allowed;opacity:.6}.btn.secondary{background:#6366f126;border:1px solid #6366f14d;color:#a5b4fc}.btn.secondary:hover{background:#6366f140;border-color:#6366f180}.btn.google{box-shadow:0 2px 8px #0000001a;color:#374151;font-weight:500}.btn.google:hover:not(:disabled){background:#f9fafb;box-shadow:0 4px 12px #00000026}.btn.google:disabled{cursor:not-allowed;opacity:.7}.btn.text{color:#94a3b8;padding:.5rem}.btn.text:hover{color:#f1f5f9}.btn-icon{font-size:1.25rem}.divider{color:#64748b;font-size:.85rem;gap:1rem}.divider:after,.divider:before{background:#64748b4d}.message{border-radius:8px;font-size:.875rem;margin-bottom:1rem;padding:.875rem 1rem}.message.success{background:#22c55e26;border:1px solid #22c55e4d;color:#86efac}.message.error{background:#ef444426;border:1px solid #ef44444d;color:#fca5a5}.message.info{background:#3b82f626;border:1px solid #3b82f64d;color:#93c5fd}.signup-footer{border-top:1px solid #64748b33;margin-top:1rem;padding-top:1rem;text-align:center}.signup-footer p{color:#94a3b8;font-size:.875rem;margin:0}.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 #64748b33;margin-top:2rem;padding-top:1.5rem}.features-list h3{color:#94a3b8;font-size:.875rem;font-weight:600;letter-spacing:.05em;margin:0 0 1rem;text-transform:uppercase}.features-list ul{display:flex;flex-direction:column;gap:.75rem;list-style:none;margin:0;padding:0}.features-list li{align-items:center;color:#cbd5e1;display:flex;font-size:.9rem;gap:.75rem}.features-list .feature-icon{font-size:1.1rem}.admin-setup .admin-logo{flex-direction:column;gap:.5rem}.setup-info{background:#6366f11a;border:1px solid #6366f133;border-radius:8px;margin-top:1.5rem;padding:1rem}.setup-info h4{color:#a5b4fc;font-size:.9rem;font-weight:600;margin:0 0 .5rem}.setup-info p{color:#94a3b8;font-size:.85rem;line-height:1.5;margin:0}.admin-features{border-top:1px solid #64748b33;margin-top:2rem;padding-top:1.5rem}.admin-features h3{color:#94a3b8;font-size:.875rem;font-weight:600;margin:0 0 1rem}.admin-features ul{display:flex;flex-direction:column;gap:.75rem;list-style:none;margin:0;padding:0}.admin-features li{align-items:center;color:#cbd5e1;display:flex;font-size:.9rem;gap:.75rem}.passkey-enroll .signup-container{max-width:520px}.passkey-setup{text-align:center}.passkey-illustration{margin-bottom:1.5rem}.passkey-icon-large{animation:float 3s ease-in-out infinite;display:inline-block;font-size:4rem}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.passkey-info{margin-bottom:1.5rem}.passkey-info h3{color:#f1f5f9;font-size:1.1rem;font-weight:600;margin:0 0 .5rem}.passkey-info p{color:#94a3b8;font-size:.9rem;line-height:1.6;margin:0}.passkey-benefits{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem;text-align:left}.passkey-benefits .benefit{align-items:flex-start;background:#6366f114;border-radius:8px;display:flex;gap:.75rem;padding:.75rem}.passkey-benefits .benefit-icon{flex-shrink:0;font-size:1.25rem}.passkey-benefits .benefit strong{color:#f1f5f9;display:block;font-size:.9rem;margin-bottom:.25rem}.passkey-benefits .benefit p{color:#94a3b8;font-size:.8rem;margin:0}.security-note{color:#64748b;font-size:.8rem;line-height:1.5;margin-top:1rem}.spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:16px;width:16px}.loading{color:#94a3b8;padding:2rem;text-align:center}@media (max-width:640px){.signup-page{padding:1rem}.signup-container{padding:1.5rem}.signup-header h2{font-size:1.25rem}.passkey-benefits .benefit{flex-direction:column;text-align:center}}.landing-page{background:var(--gradient-bg);color:var(--color-text-primary);font-family:var(--font-family);min-height:100vh;overflow-x:hidden;position:relative}.landing-content{position:relative;z-index:2}.landing-background{filter:blur(0);filter:blur(var(--landing-bg-blur,0));inset:0;pointer-events:none;position:fixed;transition:filter .2s ease;z-index:0}.landing-gradient{animation:gradientShift 18s ease-in-out infinite;background:linear-gradient(120deg,#0f0f23cc,#16213ecc,#8b5cf633);inset:-20%;opacity:.9;position:absolute}.landing-canvas{height:100%;inset:0;position:absolute;width:100%}.landing-canvas.bg{opacity:.6}.landing-canvas.pulse{opacity:.9}@keyframes gradientShift{0%{transform:translateZ(0) scale(1.05)}50%{transform:translate3d(-4%,-2%,0) scale(1.1)}to{transform:translateZ(0) scale(1.05)}}@media (prefers-reduced-motion:reduce){.landing-gradient{animation:none}}.landing-nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f0f23cc;justify-content:space-between;margin:0 auto;max-width:1400px;padding:1rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.landing-nav,.nav-logo{align-items:center;display:flex}.nav-logo{color:var(--color-text-primary);gap:.75rem;text-decoration:none}.nav-logo-img{height:40px;width:40px}.nav-logo-text{font-family:var(--font-family-display);font-size:1.5rem;font-weight:700}.nav-links{align-items:center;display:flex;gap:2rem}.nav-link{color:var(--color-text-secondary);font-size:.9rem;text-decoration:none;transition:color var(--transition-fast)}.nav-link:hover{color:var(--color-text-primary)}.mobile-menu-btn{background:#0000;border:none;cursor:pointer;display:none;flex-direction:column;gap:4px;padding:.5rem}.mobile-menu-btn span{background:var(--color-text-primary);display:block;height:2px;transition:var(--transition-fast);width:24px}.hero{grid-gap:4rem;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1400px;padding:4rem 2rem 6rem}.hero,.hero-badge{align-items:center}.hero-badge{background:#8b5cf626;border:1px solid #8b5cf64d;border-radius:var(--radius-full);color:var(--color-primary-light);display:inline-flex;font-size:.85rem;gap:.5rem;margin-bottom:1.5rem;padding:.5rem 1rem}.badge-icon{font-size:1rem}.hero-title{font-family:var(--font-family-display);font-size:3.5rem;font-weight:700;line-height:1.1;margin:0 0 1.5rem}.gradient-text{-webkit-text-fill-color:#0000;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:var(--color-text-secondary);font-size:1.2rem;line-height:1.7;margin:0 0 2rem;max-width:540px}.hero-cta{display:flex;gap:1rem;margin-bottom:3rem}.btn{font-size:.95rem;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none}.btn.primary:hover{box-shadow:var(--shadow-lg),0 0 30px #8b5cf666;transform:translateY(-2px)}.btn.secondary{background:#ffffff0d}.btn.secondary:hover{background:#ffffff1a;border-color:var(--color-primary)}.btn.large{font-size:1rem;padding:1rem 2rem}.btn-arrow{transition:transform var(--transition-fast)}.btn:hover .btn-arrow{transform:translateX(4px)}.hero-stats{align-items:center;display:flex;gap:2rem}.stat{display:flex;flex-direction:column;gap:.25rem}.stat-value{color:var(--color-primary-light);font-size:1.1rem;font-weight:600}.stat-label{color:var(--color-text-muted);font-size:.8rem}.stat-divider{background:var(--color-border);height:40px;width:1px}.hero-visual{display:flex;justify-content:center}.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 #8b5cf61a;max-width:520px;overflow:hidden;width:100%}.code-header{align-items:center;background:#0000004d;border-bottom:1px solid var(--color-border);display:flex;gap:1rem;padding:.75rem 1rem}.code-dots{display:flex;gap:6px}.code-dots span{border-radius:50%;height:12px;width: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);font-size:.8rem;line-height:1.6;margin:0;padding:1.5rem;white-space:pre-wrap;word-break:break-word}.features{margin:0 auto;max-width:1400px;padding:6rem 2rem}.section-header{margin-bottom:4rem;text-align:center}.section-badge{background:#06b6d426;border:1px solid #06b6d44d;border-radius:var(--radius-full);color:var(--color-secondary);display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.05em;margin-bottom:1rem;padding:.5rem 1rem;text-transform:uppercase}.section-header h2{font-family:var(--font-family-display);font-size:2.5rem;font-weight:700;margin:0 0 1rem}.section-header p{font-size:1.1rem}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(3,1fr)}.feature-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2rem;transition:all var(--transition-normal)}.feature-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-lg),var(--shadow-glow);transform:translateY(-4px)}.feature-icon{font-size:2.5rem;margin-bottom:1rem}.feature-card h3{font-family:var(--font-family-display);font-size:1.25rem;margin:0 0 .75rem}.feature-card p{color:var(--color-text-secondary);font-size:.95rem;line-height:1.6;margin:0}.integration{background:#0003;padding:6rem 2rem}.integration-content{grid-gap:4rem;align-items:start;display:grid;gap:4rem;grid-template-columns:1.5fr 1fr;margin:0 auto;max-width:1200px}.tab-list{display:flex;gap:.5rem;margin-bottom:1rem}.tab{border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-family);font-size:.9rem;padding:.75rem 1.5rem;transition:all var(--transition-fast)}.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);max-height:220px;max-width:720px;min-height:180px;overflow:hidden;width:100%}.code-example pre{color:var(--color-text-secondary);font-size:.85rem;line-height:1.6;margin:0;overflow:auto;padding:1.25rem;white-space:pre-wrap;word-break:break-word}.integration-features{display:flex;flex-direction:column;gap:1.5rem}.int-feature{align-items:flex-start;display:flex;gap:1rem}.check{align-items:center;background:#10b98133;border-radius:50%;color:var(--color-success);display:flex;flex-shrink:0;font-size:.8rem;height:24px;justify-content:center;margin-top:2px;width:24px}.int-feature strong{display:block;font-size:1rem;margin-bottom:.25rem}.int-feature p{color:var(--color-text-secondary);font-size:.9rem;margin:0}.security{margin:0 auto;max-width:1400px;padding:6rem 2rem}.security-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1.5fr 1fr}.security-card.main{background:linear-gradient(135deg,#8b5cf61a,#06b6d41a);border:1px solid #8b5cf64d;border-radius:var(--radius-lg);padding:2.5rem}.security-card h3{font-family:var(--font-family-display);font-size:1.5rem;margin:0 0 1rem}.security-card p{color:var(--color-text-secondary);font-size:1rem;line-height:1.7;margin:0 0 1.5rem}.security-card ul{list-style:none;margin:0;padding:0}.security-card li{color:var(--color-text-secondary);font-size:.95rem;margin-bottom:.75rem;padding-left:1.5rem;position:relative}.security-card li:before{color:var(--color-primary);content:"→";left:0;position:absolute}.security-features{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.sec-feature{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.25rem}.sec-icon{display:block;font-size:1.5rem;margin-bottom:.75rem}.sec-feature h4{font-size:.95rem;margin:0 0 .5rem}.sec-feature p{color:var(--color-text-secondary);font-size:.85rem;line-height:1.5;margin:0}.cta-section{background:linear-gradient(135deg,#8b5cf626,#06b6d426);padding:6rem 2rem;text-align:center}.cta-content{margin:0 auto;max-width:600px}.cta-content h2{font-family:var(--font-family-display);font-size:2.5rem;font-weight:700;margin:0 0 1rem}.cta-content p{color:var(--color-text-secondary);font-size:1.1rem;margin:0 0 2rem}.cta-buttons{display:flex;gap:1rem;justify-content:center}.landing-footer{border-top:1px solid var(--color-border);padding:4rem 2rem 2rem}.footer-content{grid-gap:4rem;display:grid;gap:4rem;grid-template-columns:1fr 2fr;margin:0 auto;max-width:1200px}.footer-brand{display:flex;flex-direction:column;gap:.5rem}.footer-logo{height:48px;width:48px}.footer-brand span{font-family:var(--font-family-display);font-size:1.25rem;font-weight:600}.footer-brand p{color:var(--color-text-secondary);font-size:.9rem;margin:0}.footer-links{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(3,1fr)}.footer-column h4{color:var(--color-text-secondary);font-size:.85rem;font-weight:600;letter-spacing:.05em;margin:0 0 1rem;text-transform:uppercase}.footer-column a{color:var(--color-text-secondary);display:block;font-size:.9rem;padding:.35rem 0;text-decoration:none;transition:color var(--transition-fast)}.footer-column a:hover{color:var(--color-text-primary)}.footer-bottom{border-top:1px solid var(--color-border);margin:3rem auto 0;max-width:1200px;padding-top:2rem;text-align:center}.footer-bottom p{color:var(--color-text-muted);font-size:.85rem;margin:0}@media (max-width:1024px){.hero{gap:3rem;grid-template-columns:1fr;text-align:center}.hero-content{align-items:center;display:flex;flex-direction:column}.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,.nav-links{padding:1rem}.nav-links{background:var(--color-bg-card);border-bottom:1px solid var(--color-border);display:none;flex-direction:column;gap:.5rem;left:0;position:absolute;right:0;top:100%}.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{gap:2rem;grid-template-columns:1fr}.footer-links{gap:1.5rem;grid-template-columns:1fr}}.layout{display:flex;min-height:100vh}.sidebar{background:var(--color-bg-card);border-right:1px solid var(--color-border);bottom:0;display:flex;flex-direction:column;left:0;position:fixed;top:0;transition:transform var(--transition-normal);width:260px;z-index:var(--z-dropdown)}.sidebar-header{border-bottom:1px solid var(--color-border);justify-content:space-between;padding:var(--spacing-lg)}.logo-link,.sidebar-header{align-items:center;display:flex}.logo-link{gap:var(--spacing-sm);text-decoration:none}.logo-img{height:32px;object-fit:contain;width:32px}.logo-text,.sidebar-header .logo{-webkit-text-fill-color:#0000;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;font-family:var(--font-family-display);font-size:var(--font-size-xl);font-weight:700}.menu-close{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;display:none;font-size:var(--font-size-lg)}.sidebar-nav{flex:1 1;overflow-y:auto;padding:var(--spacing-md) 0}.sidebar-nav ul{list-style:none}.sidebar-nav a{align-items:center;color:var(--color-text-secondary);display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);transition:all var(--transition-fast)}.sidebar-nav a:hover{background:#8b5cf61a;color:var(--color-text-primary)}.sidebar-nav a.active{background:#8b5cf626;border-right:3px solid var(--color-primary);color:var(--color-primary-light)}.nav-icon{font-size:var(--font-size-lg)}.nav-label{font-size:var(--font-size-sm)}.nav-divider{color:var(--color-text-muted);font-size:var(--font-size-xs);letter-spacing:.1em;margin-top:var(--spacing-sm);padding:var(--spacing-lg) var(--spacing-lg) var(--spacing-sm);text-transform:uppercase}.nav-divider,.sidebar-footer{border-top:1px solid var(--color-border)}.sidebar-footer{padding:var(--spacing-md) var(--spacing-lg)}.user-info{gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.user-avatar{border-radius:var(--radius-full);object-fit:cover}.user-avatar.placeholder{align-items:center;background:var(--gradient-primary);color:#fff;display:flex;font-weight:600;justify-content:center}.user-avatar.small{font-size:var(--font-size-sm);height:32px;width:32px}.user-details{flex:1 1;min-width:0}.user-name{color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:500}.user-email,.user-name{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-email{color:var(--color-text-muted);font-size:var(--font-size-xs)}.logout-btn{background:#0000;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-sm);padding:var(--spacing-sm);transition:all var(--transition-fast);width:100%}.logout-btn:hover{border-color:var(--color-error);color:var(--color-error)}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:260px;min-height:100vh}.mobile-header{align-items:center;background:var(--color-bg-card);border-bottom:1px solid var(--color-border);display:none;justify-content:space-between;padding:var(--spacing-md)}.menu-toggle{background:none;border:none;color:var(--color-text-primary);cursor:pointer;font-size:var(--font-size-xl)}.mobile-header .logo{-webkit-text-fill-color:#0000;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;font-family:var(--font-family-display);font-size:var(--font-size-lg);font-weight:700}.content-wrapper{flex:1 1;padding:var(--spacing-xl)}.sidebar-overlay{display:none}@media (max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.menu-close{display:block}.main-content{margin-left:0}.mobile-header{display:flex}.content-wrapper{padding:var(--spacing-md)}.sidebar-overlay{background:#00000080;display:block;inset:0;position:fixed;z-index:calc(var(--z-dropdown) - 1)}}.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{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.tenant-card .tenant-info{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);padding:var(--spacing-md)}.tenant-name{color:var(--color-text-primary);display:block;font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-xs)}.tenant-id{color:var(--color-text-muted);display:block;font-family:var(--font-family);font-size:var(--font-size-xs)}.roles{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.quick-links .links-grid{grid-gap:var(--spacing-sm);display:grid;gap:var(--spacing-sm);grid-template-columns:repeat(3,1fr)}.quick-link{align-items:center;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-md);transition:all var(--transition-fast)}.quick-link:hover{background:#8b5cf61a;border-color:var(--color-primary);color:var(--color-primary-light);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{display:flex;flex-direction:column;gap:var(--spacing-md)}.stat-item{align-items:center;display:flex;justify-content:space-between}.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{align-items:center;border-radius:var(--radius-md);display:flex;justify-content:space-between;margin-bottom:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md)}.organizations li.active{background:#8b5cf61a}.org-name{font-weight:500}.current-badge{background:var(--color-primary);color:#fff;padding:2px 8px}.profile-content{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:1fr 1fr;max-width:800px}@media (max-width:768px){.profile-content{grid-template-columns:1fr}}.profile-card{grid-column:1}.profile-avatar{margin-bottom:var(--spacing-lg);text-align:center}.profile-avatar img{border:3px solid var(--color-primary);border-radius:var(--radius-full);height:100px;object-fit:cover;width:100px}.field-status{margin-top:var(--spacing-xs)}.verified{color:var(--color-success)}.unverified,.verified{font-size:var(--font-size-sm)}.unverified{color:var(--color-warning)}.account-info{grid-column:2}@media (max-width:768px){.account-info{grid-column:1}}.info-item{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:var(--spacing-sm) 0}.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)}.active-sessions,.connected-apps{grid-column:1/-1;margin-top:var(--spacing-md)}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-xs)}.section-header h3{margin:0}.consents-list,.pending-list,.sessions-list{list-style:none;margin:0;padding:0}.consent-item,.pending-item,.session-item{align-items:center;background:var(--color-background);border-radius:var(--radius-md);display:flex;justify-content:space-between;margin-bottom:var(--spacing-sm);padding:var(--spacing-md)}.consent-item:last-child,.pending-item:last-child,.session-item:last-child{margin-bottom:0}.consent-info,.session-info{align-items:center;display:flex;gap:var(--spacing-md)}.device-icon,.tenant-icon{font-size:1.5rem}.consent-details,.session-details{display:flex;flex-direction:column}.device-name,.tenant-name{color:var(--color-text);font-weight:500}.consent-meta,.session-meta{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.consent-meta .roles,.current-badge{color:var(--color-primary)}.current-badge{background:var(--color-primary-light);border-radius:var(--radius-full);display:inline-block;font-size:var(--font-size-xs);font-weight:500;margin-left:var(--spacing-xs);padding:.125rem .5rem}.session-item.current{background:linear-gradient(135deg,#667eea0d,#764ba20d);border:1px solid #667eea33}.pending-section{border-top:1px solid var(--color-border);margin-top:var(--spacing-lg);padding-top:var(--spacing-lg)}.pending-section h4{font-size:var(--font-size-sm);margin-bottom:var(--spacing-sm)}.empty-state,.pending-section h4{color:var(--color-text-secondary)}.empty-state{padding:var(--spacing-xl)}.empty-state .empty-icon{display:block;font-size:2rem;margin-bottom:var(--spacing-sm)}.btn.small{font-size:var(--font-size-sm);padding:.375rem .75rem}.btn.danger{background:#0000;border:1px solid var(--color-error);color:var(--color-error)}.btn.danger:hover{background:var(--color-error);color:#fff}.passkeys-info{margin-bottom:var(--spacing-lg)}.info-card{align-items:flex-start;background:#06b6d41a;border:1px solid var(--color-secondary);border-radius:var(--radius-lg);display:flex;gap:var(--spacing-md);padding:var(--spacing-lg)}.info-card .icon{font-size:var(--font-size-2xl)}.info-card h3{color:var(--color-secondary);margin-bottom:var(--spacing-xs)}.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;display:flex;gap:var(--spacing-sm)}.passkey-name .icon{font-size:var(--font-size-lg)}.passkey-illustration{font-size:64px;margin-bottom:var(--spacing-md)}.device-support{background:var(--color-bg-elevated);border-radius:var(--radius-md);margin:var(--spacing-lg) 0;padding:var(--spacing-md);text-align:left}.device-support h4{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-sm)}.device-support ul{list-style:none}.device-support li{color:var(--color-text-muted);font-size:var(--font-size-sm);padding:var(--spacing-xs) 0}.api-keys-page,.email-domain-page,.passkeys-page,.profile-page,.settings-page,.users-page{animation:fadeIn var(--transition-normal)}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-xl)}.page-header h1{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-xs)}.page-header h1 .tenant-badge{color:var(--color-primary);font-size:var(--font-size-lg);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-cell{align-items:center;display:flex;gap:var(--spacing-sm)}.avatar{object-fit:cover}.avatar,.avatar-placeholder{border-radius:var(--radius-full);height:32px;width:32px}.avatar-placeholder{align-items:center;background:var(--gradient-primary);color:#fff;display:flex;font-size:var(--font-size-sm);font-weight:600;justify-content:center}.avatar-placeholder.large{font-size:var(--font-size-xl);height:80px;width:80px}.roles-select{flex-direction:column}.role-checkbox,.roles-select{display:flex;gap:var(--spacing-sm)}.role-checkbox{align-items:flex-start;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;padding:var(--spacing-sm) var(--spacing-md);transition:all var(--transition-fast)}.role-checkbox:hover{border-color:var(--color-primary)}.role-checkbox input{margin-top:2px}.role-checkbox .role-name{display:block;font-weight:500}.role-checkbox .role-desc{color:var(--color-text-muted);display:block;font-size:var(--font-size-xs)}.edit-user-info{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md)}.edit-user-info p{color:var(--color-text-secondary);margin:var(--spacing-xs) 0}.edit-user-info p strong{color:var(--color-text-primary);margin-right:var(--spacing-xs)}.empty-state{border:1px solid var(--color-border)}.empty-state .icon{font-size:64px}.empty-state h3{margin-bottom:var(--spacing-sm)}.empty-state p{margin-bottom:var(--spacing-lg)}.roles-page{margin:0 auto;max-width:1200px;padding:2rem}.roles-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-top:1.5rem}.role-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem;transition:all .2s ease}.role-card:hover{border-color:var(--color-primary);box-shadow:0 4px 12px #0000001a}.role-card.system{background:linear-gradient(135deg,#06b6d40d,#0000);border-color:var(--color-secondary)}.role-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.role-header h3{color:var(--color-text);font-size:1.25rem;margin:0;text-transform:capitalize}.system-badge{background:var(--color-secondary);border-radius:4px;color:#fff;font-size:.7rem;font-weight:600;padding:.25rem .5rem;text-transform:uppercase}.role-description{color:var(--color-text-secondary);font-size:.9rem;line-height:1.5;margin:0 0 1rem}.role-permissions h4{color:var(--color-text-secondary);font-size:.75rem;letter-spacing:.05em;margin:0 0 .75rem;text-transform:uppercase}.permissions-list{display:flex;flex-wrap:wrap;gap:.5rem}.permission-badge{background:#8b5cf61a;border-radius:4px;color:var(--color-primary);font-family:monospace;font-size:.75rem;padding:.25rem .5rem}.no-permissions{color:var(--color-text-secondary);font-size:.85rem;font-style:italic}.role-actions{border-top:1px solid var(--color-border);display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem}.role-actions .btn.text.danger{background:#0000;color:var(--color-error);font-family:var(--font-family)}.role-actions .btn.text.danger:hover{background:#ef44441a}.permissions-select{background:var(--color-bg);border-radius:8px;display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto;padding:.5rem}.permission-checkbox{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:.75rem;padding:.5rem;transition:background .2s ease}.permission-checkbox:hover{background:var(--color-surface)}.permission-checkbox input[type=checkbox]{accent-color:var(--color-primary);height:18px;margin-right:.5rem;min-width:18px;width:18px}.perm-name{color:var(--color-text);font-family:monospace;font-size:.85rem;white-space:nowrap}.perm-desc{color:var(--color-text-secondary);font-size:.8rem;margin-left:.5rem}.permission-checkbox.custom{background:#8b5cf60d;border:1px dashed var(--color-border)}@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{margin:0 auto;max-width:1200px;padding:2rem}.tenants-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-top:1.5rem}.tenant-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem;transition:all .2s ease}.tenant-card:hover{border-color:var(--color-primary);box-shadow:0 4px 12px #0000001a}.tenant-card.platform{background:linear-gradient(135deg,#f59e0b0d,#0000);border-color:var(--color-accent)}.tenant-header{align-items:flex-start;display:flex;gap:1rem;margin-bottom:1.25rem}.tenant-icon{font-size:2rem;line-height:1}.tenant-info{flex:1 1;min-width:0}.tenant-info h3{color:var(--color-text);font-size:1.15rem;margin:0 0 .25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tenant-id{background:var(--color-bg);border-radius:4px;color:var(--color-text-secondary);font-family:monospace;font-size:.75rem;padding:.15rem .4rem}.tenant-meta{border-bottom:1px solid var(--color-border);border-top:1px solid var(--color-border);display:flex;gap:1.5rem;padding:1rem 0}.meta-item{display:flex;flex-direction:column;gap:.25rem}.meta-label{color:var(--color-text-secondary);font-size:.7rem;letter-spacing:.05em;text-transform:uppercase}.meta-value{color:var(--color-text);font-size:.9rem}.status-badge{border-radius:4px;font-size:.75rem;font-weight:500;padding:.2rem .5rem;text-transform:capitalize}.status-badge.active{background:#22c55e1a;color:var(--color-success)}.status-badge.suspended{background:#ef44441a;color:var(--color-error)}.status-badge.pending{background:#f59e0b1a;color:var(--color-accent)}.tenant-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.tenant-actions .btn{flex:0 0 auto;font-size:.8rem;padding:.4rem .6rem;text-align:center}.empty-state{background:var(--color-surface);border-radius:12px;margin-top:1.5rem;padding:4rem 2rem}.empty-icon{font-size:3rem;margin-bottom:1rem}.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;display:flex;gap:1rem}.view-toggle{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;display:flex;overflow:hidden}.toggle-btn{background:#0000;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:.85rem;padding:.5rem 1rem;transition:all .2s ease}.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);border:none;border-radius:4px;color:var(--color-text-secondary);cursor:pointer;flex-shrink:0;font-size:.7rem;height:24px;transition:all .2s ease;width:24px}.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-left:12px;margin-top:.5rem;padding-left:.5rem}.loading-subtenants{color:var(--color-text-secondary);font-size:.9rem;padding:1rem}.tenant-card.subtenant{border-left:3px solid var(--color-primary)}.parent-info{color:var(--color-text-secondary);display:block;font-size:.7rem;font-style:italic;margin-top:.25rem}.create-subtenant-btn{color:var(--color-primary)!important}.create-subtenant-btn:hover{background:var(--color-primary-light)!important}.modal-subtitle{font-size:.9rem;margin-bottom:1.5rem;margin-top:-.5rem}.info-box,.modal-subtitle{color:var(--color-text-secondary)}.info-box{align-items:flex-start;background:#3b82f60d;border:1px solid #3b82f633;border-radius:8px;display:flex;font-size:.85rem;gap:.75rem;line-height:1.5;margin:1rem 0;padding:1rem}.info-icon{flex-shrink:0;font-size:1rem}.inherited-notice{align-items:center;background:#f59e0b0d;border:1px solid #f59e0b33;border-radius:8px;color:var(--color-text-secondary);display:flex;font-size:.85rem;gap:.75rem;margin-bottom:1rem;padding:.75rem 1rem}.notice-icon{flex-shrink:0}.toggle.disabled{opacity:.6}.toggle.disabled,.toggle.disabled input{cursor:not-allowed}.checkbox-label.disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.tenants-page{padding:1rem}.tenants-grid{grid-template-columns:1fr}.header-actions,.tenant-meta{flex-direction:column;gap:.75rem}.header-actions{align-items:stretch}.view-toggle{width:100%}.toggle-btn{flex:1 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{display:flex;gap:var(--spacing-xs)}.warning-message{border:1px solid var(--color-warning)}.warning-message p{color:var(--color-text-secondary)}.key-display{align-items:center;background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md)}.key-display code{background:#0000;flex:1 1;font-size:var(--font-size-sm);padding:0;word-break:break-all}.domain-content{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.current-config .config-item{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:var(--spacing-sm) 0}.current-config .config-item:last-of-type{border-bottom:none;margin-bottom:var(--spacing-md)}.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{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.test-email-card input{flex:1 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:#0000}.record-name,.record-value{font-size:var(--font-size-xs);max-width:200px;word-break:break-all}.dns-instructions{background:#06b6d41a;border:1px solid var(--color-secondary);border-radius:var(--radius-md);padding:var(--spacing-md)}.dns-instructions h4{color:var(--color-secondary);margin-bottom:var(--spacing-sm)}.dns-instructions ol{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-left:var(--spacing-lg)}.dns-instructions li{margin-bottom:var(--spacing-xs)}.embed-docs-page{margin:0 auto;max-width:1400px;padding:var(--spacing-lg)}.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{grid-gap:var(--spacing-xl);display:grid;gap:var(--spacing-xl);grid-template-columns:260px 1fr}@media (max-width:900px){.docs-layout{grid-template-columns:1fr}}.docs-sidebar{height:-webkit-fit-content;height:fit-content;position:-webkit-sticky;position:sticky;top:var(--spacing-lg)}.sidebar-section{background:var(--color-surface);border-radius:var(--border-radius);margin-bottom:var(--spacing-md);padding:var(--spacing-md)}.sidebar-section h3{color:var(--color-text-secondary);font-size:var(--font-size-sm);letter-spacing:.05em;margin-bottom:var(--spacing-sm);text-transform:uppercase}.sidebar-link{align-items:center;background:#0000;border:none;border-radius:var(--border-radius-sm);color:var(--color-text);cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);text-align:left;transition:all .15s ease;width:100%}.sidebar-link:hover{background:#8b5cf61a;color:var(--color-primary)}.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{color:var(--color-text-secondary);display:block;font-size:var(--font-size-xs);margin-bottom:2px}.tenant-info-sidebar code{background:var(--color-bg);border-radius:var(--border-radius-sm);display:block;font-size:var(--font-size-xs);padding:var(--spacing-xs);word-break:break-all}.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{border-bottom:1px solid var(--color-border);font-size:var(--font-size-xl);margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-sm)}.doc-section h3{color:var(--color-text);font-size:var(--font-size-lg);margin-bottom:var(--spacing-md);margin-top:var(--spacing-xl)}.doc-section h4{font-size:var(--font-size-md);margin-bottom:var(--spacing-sm);margin-top:var(--spacing-lg)}.doc-section h4,.doc-section p{color:var(--color-text-secondary)}.doc-section p{line-height:1.7;margin-bottom:var(--spacing-md)}.doc-section .intro{color:var(--color-text);font-size:var(--font-size-md)}.doc-section ol,.doc-section ul{margin-bottom:var(--spacing-md);padding-left:var(--spacing-lg)}.doc-section li{color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--spacing-xs)}.doc-section a{color:var(--color-primary);text-decoration:none}.doc-section a:hover{text-decoration:underline}.info-box,.warning-box{background:#8b5cf61a;border-left:4px solid var(--color-primary);border-radius:var(--border-radius-sm);margin:var(--spacing-lg) 0;padding:var(--spacing-md)}.info-box h4,.warning-box h4{color:var(--color-text);margin-bottom:var(--spacing-sm);margin-top:0}.info-box ul,.warning-box ul{margin-bottom:0}.warning-box{background:#f59e0b1a;border-left-color:#f59e0b}.integration-cards{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:var(--spacing-lg) 0}.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 ease}.integration-cards .card:hover{border-color:var(--color-primary);transform:translateY(-2px)}.card-icon{font-size:2rem;margin-bottom:var(--spacing-sm)}.integration-cards .card h4{color:var(--color-text);margin-bottom:var(--spacing-sm);margin-top:0}.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{background:#1a1a2e;color:#e2e8f0;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:13px;line-height:1.5;margin:var(--spacing-md) 0;white-space:pre}.architecture-diagram,.code-block{border:1px solid var(--color-border);border-radius:var(--border-radius);overflow-x:auto;padding:var(--spacing-md)}.architecture-diagram{background:var(--color-bg);margin:var(--spacing-lg) 0}.architecture-diagram pre{color:var(--color-text-secondary);font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:12px;line-height:1.4;margin:0;white-space:pre}.docs-table{border-collapse:collapse;font-size:var(--font-size-sm);margin:var(--spacing-md) 0;width:100%}.docs-table td,.docs-table th{border-bottom:1px solid var(--color-border);padding:var(--spacing-sm) var(--spacing-md);text-align:left}.docs-table th{background:var(--color-bg);color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:500;letter-spacing:.05em;text-transform:uppercase}.docs-table td{color:var(--color-text)}.docs-table code{background:var(--color-bg);border-radius:4px;font-size:12px;padding:2px 6px}.endpoint{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--border-radius);margin:var(--spacing-lg) 0;padding:var(--spacing-lg)}.endpoint-header{align-items:center;display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.endpoint-header .method{border-radius:4px;font-size:var(--font-size-xs);font-weight:600;padding:4px 8px;text-transform:uppercase}.endpoint-header .method.get{background:#22c55e33;color:#22c55e}.endpoint-header .method.post{background:#3b82f633;color:#3b82f6}.endpoint-header .method.put{background:#f59e0b33;color:#f59e0b}.endpoint-header .method.delete{background:#ef444433;color:#ef4444}.endpoint-header code{background:#0000;font-size:var(--font-size-md);padding:0}.endpoint p{margin-bottom:var(--spacing-sm)}.endpoint h4{margin-bottom:var(--spacing-xs);margin-top:var(--spacing-md)}.endpoint .code-block{margin:var(--spacing-xs) 0}.security-item{background:var(--color-bg);border-radius:var(--border-radius);margin:var(--spacing-lg) 0;padding:var(--spacing-lg)}.security-item h4{margin-top:0}.security-item h4:nth-of-type(2){color:#ef4444;margin-top:var(--spacing-lg)}.doc-section code{background:var(--color-bg);border-radius:4px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.9em;padding:2px 6px}@media (max-width:900px){.embed-docs-page{padding:var(--spacing-md)}.docs-sidebar{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);position:static}.sidebar-section{flex:1 1;min-width:200px}.doc-section{padding:var(--spacing-md)}.integration-cards{grid-template-columns:1fr}.code-block{font-size:11px;padding:var(--spacing-sm)}.architecture-diagram pre{font-size:10px}}.tabs{border-bottom:1px solid var(--color-border);display:flex;gap:var(--spacing-sm);margin:var(--spacing-lg) 0;padding-bottom:var(--spacing-sm)}.tab{background:#0000;border:none;border-radius:var(--border-radius-sm);color:var(--color-text-secondary);cursor:pointer;padding:var(--spacing-sm) var(--spacing-md);transition:all .15s ease}.tab:hover{background:#ffffff0d;color:var(--color-text)}.tab.active{background:#8b5cf61a;color:var(--color-primary)}.events-table{border-collapse:collapse;margin:var(--spacing-md) 0;width:100%}.events-table td,.events-table th{border-bottom:1px solid var(--color-border);padding:var(--spacing-sm);text-align:left}.events-table th{color:var(--color-text-secondary);font-weight:500}.events-table code{background:var(--color-bg);border-radius:4px;font-size:12px;padding:2px 6px}.quick-start{margin-bottom:var(--spacing-xl)}.embed-url,.tenant-info{background:var(--color-bg);border-radius:var(--border-radius);margin:var(--spacing-sm) 0;padding:var(--spacing-md)}.embed-url code,.tenant-info code{background:var(--color-surface);border-radius:var(--border-radius-sm);margin-left:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm)}.customization,.security{border-top:1px solid var(--color-border);margin-top:var(--spacing-xl);padding-top:var(--spacing-xl)}.integration-method h4{margin-bottom:var(--spacing-sm);margin-top:var(--spacing-lg)}.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);margin-bottom:var(--spacing-lg);padding:var(--spacing-xl)}.settings-section h2{border-bottom:1px solid var(--color-border);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md)}.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;cursor:pointer;display:flex;gap:var(--spacing-md)}.toggle input{display:none}.toggle-slider{background:var(--color-bg-input);border:1px solid var(--color-border);height:24px;position:relative;width:48px}.toggle-slider,.toggle-slider:after{border-radius:var(--radius-full);transition:all var(--transition-fast)}.toggle-slider:after{background:var(--color-text-muted);content:"";height:18px;left:2px;position:absolute;top:2px;width:18px}.toggle input:checked+.toggle-slider{background:var(--color-primary);border-color:var(--color-primary)}.toggle input:checked+.toggle-slider:after{background:#fff;transform:translateX(24px)}.toggle-label{font-weight:500}.toggle-description{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-left:calc(48px + var(--spacing-md));margin-top:var(--spacing-xs)}.origins-list{flex-wrap:wrap;margin-bottom:var(--spacing-md)}.origin-item,.origins-list{display:flex;gap:var(--spacing-sm)}.origin-item{align-items:center;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-xs) var(--spacing-sm)}.origin-item code{background:#0000}.add-origin{display:flex;gap:var(--spacing-sm)}.add-origin input{flex:1 1}.settings-actions{margin-top:var(--spacing-xl)}.saved-badge{animation:fadeIn var(--transition-fast);background:var(--color-success);border-radius:var(--radius-full);color:#fff;font-size:var(--font-size-sm);padding:var(--spacing-xs) var(--spacing-sm)}.input-with-toggle{display:flex;gap:var(--spacing-sm)}.input-with-toggle input{flex:1 1}.webhook-events{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);gap:var(--spacing-sm);padding:var(--spacing-md)}.checkbox-text,.webhook-events{display:flex;flex-direction:column}.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{display:flex;flex-direction:column;gap:var(--spacing-sm)}.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{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-xs)}.delivery-event{font-family:var(--font-family-mono);font-size:var(--font-size-sm);font-weight:500}.delivery-status{border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500;padding:2px 8px}.delivery-status.success{background:#22c55e33;color:var(--color-success)}.delivery-status.error{background:#ef444433;color:var(--color-error)}.delivery-meta{color:var(--color-text-muted);display:flex;font-size:var(--font-size-xs);gap:var(--spacing-md)}.delivery-error{background:#ef44441a;border-radius:var(--radius-sm);color:var(--color-error);font-size:var(--font-size-xs);margin-top:var(--spacing-xs);padding:var(--spacing-xs)}.legal-page{background:var(--color-bg-primary);color:var(--color-text-primary);min-height:100vh}.legal-header{background:var(--color-bg-card);border-bottom:1px solid var(--color-border);padding:var(--spacing-xl) var(--spacing-2xl);text-align:center}.legal-header .logo-link{text-decoration:none}.legal-header .logo-text{-webkit-text-fill-color:#0000;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;font-family:var(--font-family-display);font-size:var(--font-size-2xl);font-weight:700}.legal-header .subtitle{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-top:var(--spacing-xs)}.legal-content{margin:0 auto;max-width:800px;padding:var(--spacing-2xl)}.legal-content h1{font-size:var(--font-size-3xl);font-weight:700;margin-bottom:var(--spacing-sm)}.legal-content .last-updated{color:var(--color-text-muted);font-size:var(--font-size-sm)}.legal-content .last-updated,.legal-content section{margin-bottom:var(--spacing-xl)}.legal-content h2{border-bottom:1px solid var(--color-border);font-size:var(--font-size-xl);font-weight:600;margin-bottom:var(--spacing-md);margin-top:var(--spacing-xl);padding-bottom:var(--spacing-sm)}.legal-content h3{color:var(--color-text-secondary);font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-sm);margin-top:var(--spacing-lg)}.legal-content p{color:var(--color-text-secondary);line-height:1.7;margin-bottom:var(--spacing-md)}.legal-content .important-notice{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-left:4px solid var(--color-primary);border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:var(--spacing-lg);padding:var(--spacing-md)}.legal-content ul{margin-bottom:var(--spacing-md);padding-left:var(--spacing-xl)}.legal-content li{color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--spacing-sm)}.legal-content a{color:var(--color-primary);text-decoration:none}.legal-content a:hover{text-decoration:underline}.legal-footer{background:var(--color-bg-card);border-top:1px solid var(--color-border);padding:var(--spacing-xl) var(--spacing-2xl);text-align:center}.legal-footer p{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-bottom:var(--spacing-md)}.footer-links{display:flex;gap:var(--spacing-lg);justify-content:center}.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{margin:0 auto;max-width:1200px;padding:var(--spacing-xl)}.clients-grid{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(380px,1fr));margin-top:var(--spacing-xl)}.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{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:var(--spacing-md)}.client-header h3{color:var(--color-text-primary);font-size:var(--font-size-lg);margin:0}.client-type{border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500;padding:var(--spacing-xs) var(--spacing-sm);text-transform:capitalize}.client-type.confidential{background:#8b5cf61a;color:var(--color-primary)}.client-type.public{background:#f59e0b1a;color:var(--color-warning)}.client-id{margin-bottom:var(--spacing-md)}.client-id .label{color:var(--color-text-muted);display:block;font-size:var(--font-size-xs);letter-spacing:.05em;margin-bottom:var(--spacing-xs);text-transform:uppercase}.client-id code{background:var(--color-bg-elevated);border-radius:var(--radius-sm);display:block;font-size:var(--font-size-sm);padding:var(--spacing-sm);word-break:break-all}.client-details{border-top:1px solid var(--color-border);padding-top:var(--spacing-md)}.detail-group{margin-bottom:var(--spacing-md)}.detail-group .label{color:var(--color-text-muted);display:block;font-size:var(--font-size-xs);letter-spacing:.05em;margin-bottom:var(--spacing-xs);text-transform:uppercase}.uri-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.uri-list code{background:var(--color-bg-elevated);border-radius:var(--radius-sm);font-size:var(--font-size-sm);padding:var(--spacing-xs) var(--spacing-sm);word-break:break-all}.badge-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.badge{border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500;padding:var(--spacing-xs) var(--spacing-sm)}.badge.scope{background:#22c55e1a;color:var(--color-success)}.badge.grant{background:#3b82f61a;color:#3b82f6}.client-meta{border-top:1px solid var(--color-border);color:var(--color-text-muted);font-size:var(--font-size-sm);margin-top:var(--spacing-md);padding-top:var(--spacing-md)}.client-actions{display:flex;justify-content:flex-end;margin-top:var(--spacing-md)}.empty-state{background:var(--color-bg-card);border:1px dashed var(--color-border);border-radius:var(--radius-lg);margin-top:var(--spacing-xl);padding:var(--spacing-2xl)}.empty-state .icon{font-size:3rem;margin-bottom:var(--spacing-md)}.empty-state h3{color:var(--color-text-primary);margin:0 0 var(--spacing-sm) 0}.empty-state p{color:var(--color-text-muted);margin:0 0 var(--spacing-lg) 0}.modal.large{max-height:90vh;max-width:600px;overflow-y:auto}.radio-group{flex-direction:column}.radio-group,.radio-label{display:flex;gap:var(--spacing-sm)}.radio-label{align-items:flex-start;background:var(--color-bg-elevated);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;padding:var(--spacing-md);transition:all var(--transition-fast)}.radio-label:has(input:checked){background:#8b5cf60d;border-color:var(--color-primary)}.radio-label input{margin-top:4px}.radio-label span{display:flex;flex-direction:column}.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{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.uri-input-row input{flex:1 1}.checkbox-grid{grid-gap:var(--spacing-sm);display:grid;gap:var(--spacing-sm);grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.checkbox-label{align-items:flex-start;background:var(--color-bg-elevated);border-radius:var(--radius-sm);cursor:pointer;display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm)}.checkbox-label input{margin-top:4px}.checkbox-label span{display:flex;flex-direction:column}.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{color:var(--color-text-muted);display:block;font-size:var(--font-size-sm);margin-bottom:var(--spacing-xs)}.value-row{align-items:center;display:flex;gap:var(--spacing-sm)}.value-row code{background:var(--color-bg-elevated);border-radius:var(--radius-sm);flex:1 1;font-size:var(--font-size-sm);padding:var(--spacing-sm);word-break:break-all}.value-row code.secret{font-family:var(--font-family-mono)}.warning-message{background:#f59e0b1a;border:1px solid #f59e0b4d;border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md)}.warning-message strong{color:var(--color-warning);display:block;margin-bottom:var(--spacing-xs)}.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)}.checkbox-grid,.clients-grid{grid-template-columns:1fr}}.consent-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:1rem}.consent-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:440px;overflow:hidden;width:100%}.consent-card.loading{padding:3rem;text-align:center}.consent-card.loading .spinner{animation:spin 1s linear infinite;border:4px solid #e5e7eb;border-radius:50%;border-top-color:#667eea;height:48px;margin:0 auto 1rem;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.consent-card.error,.consent-card.success{padding:2rem;text-align:center}.consent-card .error-icon,.consent-card .success-icon{font-size:3rem;margin-bottom:1rem}.consent-card.success .success-icon{align-items:center;background:#d1fae5;border-radius:50%;color:#10b981;display:flex;height:64px;justify-content:center;margin:0 auto 1rem;width:64px}.consent-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:1.5rem;text-align:center}.authnme-logo{align-items:center;color:#fff;display:flex;gap:.5rem;justify-content:center}.authnme-logo .logo-icon{font-size:1.5rem}.authnme-logo .logo-text{font-size:1.5rem;font-weight:700}.consent-body{padding:1.5rem 2rem}.consent-body h2{color:#1f2937;font-size:1.25rem;margin:0 0 .5rem}.consent-body p{color:#6b7280;margin:.5rem 0}.tenant-request{margin-bottom:1.5rem;text-align:center}.tenant-request .tenant-icon{font-size:3rem;margin-bottom:.5rem}.tenant-request h2{color:#1f2937;font-size:1.5rem}.tenant-request .subtitle{color:#6b7280;font-size:1rem}.user-info{align-items:center;background:#f3f4f6;border-radius:8px;display:flex;gap:.75rem;margin-bottom:1.5rem;padding:.75rem 1rem}.user-avatar{border-radius:50%;flex-shrink:0;height:40px;overflow:hidden;width:40px}.user-avatar img{height:100%;object-fit:cover;width:100%}.user-avatar .avatar-initial{align-items:center;background:#667eea;color:#fff;display:flex;font-size:1.25rem;font-weight:600;height:100%;justify-content:center;width:100%}.user-details{display:flex;flex-direction:column}.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;font-size:.875rem;font-weight:500;margin-bottom:.75rem}.permissions-list{list-style:none;margin:0;padding:0}.permissions-list li{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;gap:.75rem;padding:.625rem 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;font-size:.875rem;font-weight:500;margin:0 0 .5rem}.roles-list{display:flex;flex-wrap:wrap;gap:.5rem}.role-badge{background:#dcfce7;border-radius:9999px;color:#166534;font-size:.875rem;padding:.25rem .75rem}.invited-by{color:#6b7280;font-size:.875rem;margin-bottom:1rem;text-align:center}.privacy-notice{align-items:flex-start;background:#f9fafb;border-radius:8px;color:#6b7280;display:flex;font-size:.8125rem;gap:.5rem;padding:.75rem}.privacy-notice .info-icon{flex-shrink:0}.consent-actions{display:flex;gap:.75rem;padding:1rem 2rem 2rem}.consent-actions button{border-radius:8px;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.consent-actions .btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff}.consent-actions .btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.consent-actions .btn-primary:disabled{cursor:not-allowed;opacity:.7}.consent-actions .btn-secondary{background:#fff;border:1px solid #d1d5db;color:#6b7280}.consent-actions .btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.consent-actions .btn-secondary:disabled{cursor:not-allowed;opacity:.7}.tenant-info{background:#f3f4f6;border-radius:8px;margin-top:1rem;padding:1rem}.help-text{color:#9ca3af;font-size:.875rem;margin-top:1rem}.integration-callback-page,.integration-tests-page{background:var(--gradient-bg);color:var(--color-text-primary);font-family:var(--font-family);min-height:100vh;padding:2rem}.integration-tests-header{align-items:center;display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between;margin-bottom:2rem}.integration-brand{align-items:center;display:flex;gap:1rem}.integration-logo{height:48px;width:48px}.integration-brand h1{font-family:var(--font-family-display);font-size:1.8rem;margin:0 0 .35rem}.integration-brand p{color:var(--color-text-secondary);margin:0}.integration-actions{display:flex;gap:.75rem}.integration-section{background:#0003;border:1px solid var(--color-border);border-radius:var(--radius-lg);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-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:1.25rem}.form-group label{margin-bottom:.35rem}.form-group small{color:var(--color-text-muted);display:block;margin-top:.35rem}.form-actions{display:flex;gap:.75rem;margin-top:.5rem}.checkbox-group{display:flex;flex-direction:column;gap:.25rem}.checkbox-group label{align-items:center;cursor:pointer;display:flex;gap:.5rem}.checkbox-group label input[type=checkbox]{margin:0;width:auto}.widget-preview{align-items:center;background:var(--color-bg-card);border:1px dashed var(--color-border);border-radius:var(--radius-lg);display:flex;justify-content:center;min-height:420px;padding:.75rem}.widget-iframe{background:#fff;border:none;border-radius:var(--radius-md);min-height:520px;width:100%}.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{color:var(--color-text-muted);display:block;font-size:.8rem;letter-spacing:.05em;margin-bottom:.5rem;text-transform:uppercase}.info-panel ol{padding-left:1.25rem}.info-panel ol,.mono,.mono-block{color:var(--color-text-secondary);margin:0}.mono,.mono-block{font-family:JetBrains Mono,Fira Code,monospace;font-size:.85rem;word-break:break-word}.mono-block{background:#0003;border-radius:var(--radius-sm);overflow-x:auto;padding:.75rem}.status-panel{background:#94a3b81a;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);padding:1rem}.status-panel.success{border-color:#10b98180;color:var(--color-success)}.status-panel.error{border-color:#ef444499;color:var(--color-error)}.error-text{color:var(--color-error);margin-top:.5rem}@media (max-width:768px){.integration-callback-page,.integration-tests-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{font-size:16px;scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--gradient-bg);color:var(--color-text-primary);font-family:var(--font-family);line-height:1.6;min-height:100vh}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);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary)}.btn{align-items:center;border:none;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:500;gap:var(--spacing-sm);justify-content:center;padding:var(--spacing-sm) var(--spacing-md);transition:all var(--transition-fast);white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.5}.btn.primary{background:var(--gradient-primary);box-shadow:var(--shadow-md),var(--shadow-glow);color:#fff}.btn.primary:hover:not(:disabled){box-shadow:var(--shadow-lg),0 0 30px #8b5cf666;transform:translateY(-2px)}.btn.secondary{background:var(--color-bg-elevated);border:1px solid var(--color-border);color:var(--color-text-primary)}.btn.secondary:hover:not(:disabled){background:var(--color-bg-card);border-color:var(--color-primary)}.btn.outline{background:#0000;border:1px solid var(--color-border);color:var(--color-text-primary)}.btn.outline:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary-light)}.btn.text{background:#0000;color:var(--color-text-secondary);padding:var(--spacing-xs) var(--spacing-sm)}.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.google{background:#fff;border:1px solid #ddd;color:#333}.btn.google:hover:not(:disabled){background:#f8f8f8;border-color:var(--color-primary)}.btn.small{font-size:var(--font-size-xs);padding:var(--spacing-xs) var(--spacing-sm)}.btn.full-width{width:100%}.form-group{margin-bottom:var(--spacing-md)}.form-group label{color:var(--color-text-secondary);display:block;font-size:var(--font-size-sm);margin-bottom:var(--spacing-xs)}input[type=email],input[type=number],input[type=password],input[type=text],input[type=url],select,textarea{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);padding:var(--spacing-sm) var(--spacing-md);transition:all var(--transition-fast);width:100%}input:focus,select:focus,textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #8b5cf633;outline:none}input:disabled{cursor:not-allowed;opacity:.6}input::placeholder,small{color:var(--color-text-muted)}small{display:block;font-size:var(--font-size-xs);margin-top:var(--spacing-xs)}.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-lg)}.card h3{color:var(--color-text-primary)}.card h3,.message{margin-bottom:var(--spacing-md)}.message{border-radius:var(--radius-md);font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-md)}.message.success{background:#10b9811a;border:1px solid var(--color-success);color:var(--color-success)}.message.error{background:#ef44441a;border:1px solid var(--color-error);color:var(--color-error)}.message.info{background:#06b6d41a;border:1px solid var(--color-secondary);color:var(--color-secondary)}.loading{align-items:center;color:var(--color-text-muted);display:flex;justify-content:center;padding:var(--spacing-2xl)}table{border-collapse:collapse;width:100%}td,th{border-bottom:1px solid var(--color-border);padding:var(--spacing-sm) var(--spacing-md);text-align:left}th{color:var(--color-text-muted);font-size:var(--font-size-xs);font-weight:500;letter-spacing:.05em;text-transform:uppercase}tbody tr:hover{background:#8b5cf60d}.role-badge{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);display:inline-block;font-size:var(--font-size-xs);font-weight:500;padding:2px 8px}.role-badge.owner{background:#8b5cf633;border-color:var(--color-primary);color:var(--color-primary-light)}.role-badge.admin{background:#06b6d433;border-color:var(--color-secondary);color:var(--color-secondary)}.status{align-items:center;display:inline-flex;font-size:var(--font-size-sm);gap:var(--spacing-xs)}.status.active,.status.verified{color:var(--color-success)}.status.pending{color:var(--color-warning)}.status.failed,.status.revoked{color:var(--color-error)}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;display:flex;inset:0;justify-content:center;padding:var(--spacing-md);position:fixed;z-index:var(--z-overlay)}.modal{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-height:90vh;max-width:480px;overflow-y:auto;padding:var(--spacing-xl);width:100%}.modal.large{max-width:640px}.modal h2{margin-bottom:var(--spacing-lg)}.modal-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;margin-top:var(--spacing-xl)}.divider{align-items:center;color:var(--color-text-muted);display:flex;font-size:var(--font-size-sm);margin:var(--spacing-lg) 0}.divider:after,.divider:before{background:var(--color-border);content:"";flex:1 1;height:1px}.divider span{padding:0 var(--spacing-md)}code{background:var(--color-bg-input);border-radius:var(--radius-sm);font-family:var(--font-family);font-size:var(--font-size-sm);padding:2px 6px}::-webkit-scrollbar{height:8px;width: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{color:var(--color-primary);display:inline-block;font-size:var(--font-size-sm);margin-bottom:var(--spacing-sm)}.back-link:hover{color:var(--color-primary-light);text-decoration:underline}.tenant-badge{color:var(--color-primary);font-size:var(--font-size-lg);font-weight:500;margin-left:var(--spacing-xs)}
/*# sourceMappingURL=main.ca43e46c.css.map*/