*,:before,:after{box-sizing:border-box;margin:0;font-weight:400}:root{--primary:#4f46e5;--primary-hover:#4338ca;--primary-text:#fff;--bg:#f1f5f9;--card-bg:#fff;--card-shadow:0 4px 24px #0000001a;--border:#e2e8f0;--text:#0f172a;--muted:#64748b;--error:#ef4444;--input-bg:#f8fafc;--radius:10px;--radius-sm:6px;--font:system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}@media (prefers-color-scheme:dark){:root{--bg:#0f172a;--card-bg:#1e293b;--border:#334155;--text:#f1f5f9;--muted:#94a3b8;--input-bg:#0f172a;--card-shadow:0 4px 24px #0006}}html,body{min-height:100vh;font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.5}.page{justify-content:center;align-items:center;min-height:100vh;padding:24px 16px;display:flex}.card{background:var(--card-bg);width:100%;max-width:420px;box-shadow:var(--card-shadow);border:1px solid var(--border);border-radius:16px;padding:40px 36px 36px}.card-logo{justify-content:center;margin-bottom:32px;display:flex}.brand-logo{object-fit:contain;max-width:160px;max-height:44px}.brand-logo-sm{object-fit:contain;max-width:100px;max-height:28px}.step{position:relative}.step-title{color:var(--text);letter-spacing:-.02em;margin-bottom:6px;font-size:1.5rem;font-weight:700}.step-subtitle{color:var(--muted);margin-bottom:28px;font-size:.9rem}.login-name-badge{background:var(--input-bg);border:1px solid var(--border);color:var(--text);border-radius:99px;align-items:center;gap:6px;margin-bottom:24px;padding:3px 14px;font-size:.85rem;display:inline-flex}.form{flex-direction:column;gap:16px;display:flex}.field{flex-direction:column;gap:6px;display:flex}.label{color:var(--text);font-size:.85rem;font-weight:600}.input{background:var(--input-bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);font-size:1rem;font-family:var(--font);outline:none;padding:10px 14px;transition:border-color .15s}.input:focus{border-color:var(--primary);background:var(--card-bg)}.input-otp{letter-spacing:.35em;text-align:center;font-size:1.5rem;font-weight:600}.input-wrap{position:relative}.input-wrap .input{padding-right:44px}.show-btn{cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:4px;padding:4px;line-height:0;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.show-btn:hover{color:var(--text)}.btn{border-radius:var(--radius-sm);cursor:pointer;width:100%;font-size:.95rem;font-weight:600;font-family:var(--font);border:1.5px solid #0000;justify-content:center;align-items:center;gap:8px;padding:11px 20px;line-height:1;transition:background .15s,border-color .15s,opacity .15s;display:flex}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);color:var(--primary-text)}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{color:var(--text);border-color:var(--border);background:0 0}.btn-secondary:hover:not(:disabled){background:var(--input-bg)}.btn-idp{color:var(--text);border-color:var(--border);background:0 0;font-weight:500}.btn-idp:hover:not(:disabled){background:var(--input-bg)}.idp-list{flex-direction:column;gap:10px;display:flex}.oauth-step{text-align:center}.oauth-step .step-title{margin-bottom:8px}.oauth-step .step-subtitle{margin-bottom:32px}.btn-oauth-main{background:var(--primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;width:100%;font-size:1rem;font-weight:600;font-family:var(--font);border:none;justify-content:center;align-items:center;gap:10px;padding:14px 24px;transition:background .15s,opacity .15s;display:flex}.btn-oauth-main:hover:not(:disabled){background:var(--primary-hover)}.btn-oauth-main:disabled{opacity:.6;cursor:not-allowed}.spinner-dark{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin;display:inline-block}.back-btn{cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:6px;padding:4px;line-height:0;position:absolute;top:0;left:-6px;transform:translateY(-4px)}.back-btn:hover{color:var(--text)}.step:has(.back-btn) .step-title{margin-top:28px}.divider{color:var(--muted);align-items:center;gap:12px;margin:20px 0;font-size:.8rem;display:flex}.divider:before,.divider:after{content:"";background:var(--border);flex:1;height:1px}.spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.7s linear infinite spin;display:inline-block}.btn-secondary .spinner{border-color:#0003;border-top-color:var(--text)}.spinner-lg{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.passkey-center{text-align:center;flex-direction:column;align-items:center;padding:8px 0;display:flex}.passkey-icon{background:color-mix(in srgb, var(--primary) 10%, transparent);width:80px;height:80px;color:var(--primary);border-radius:50%;justify-content:center;align-items:center;margin-bottom:24px;display:flex}.passkey-icon.spinning{animation:1.4s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.95)}}.center-fill{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:120px;display:flex}.redirect-hint{color:var(--muted);font-size:.875rem}.error-block{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:8px 0;display:flex}.error-block .step-title{color:var(--error)}.field-error{color:var(--error);margin-top:-4px;font-size:.85rem}.portal{background:var(--bg);flex-direction:column;min-height:100vh;display:flex}.portal-nav{background:var(--card-bg);border-bottom:1px solid var(--border);z-index:10;position:sticky;top:0}.portal-nav-inner{justify-content:space-between;align-items:center;gap:16px;max-width:1200px;height:60px;margin:0 auto;padding:0 24px;display:flex}.portal-brand{align-items:center;gap:10px;display:flex}.portal-brand-name{color:var(--text);font-size:1rem;font-weight:700}.portal-user{align-items:center;gap:12px;display:flex}.portal-user-name{color:var(--muted);font-size:.875rem;display:none}@media (width>=640px){.portal-user-name{display:block}}.avatar{background:color-mix(in srgb, var(--primary) 15%, transparent);width:34px;height:34px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex;overflow:hidden}.avatar img{object-fit:cover;width:100%;height:100%}.logout-btn{border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--muted);cursor:pointer;font-size:.85rem;font-family:var(--font);background:0 0;align-items:center;gap:6px;padding:6px 12px;transition:color .15s,border-color .15s;display:flex}.logout-btn:hover{color:var(--error);border-color:var(--error)}.portal-main{flex:1;padding:40px 24px 60px}.portal-content{max-width:1200px;margin:0 auto}.portal-greeting{margin-bottom:32px}.portal-greeting h1{color:var(--text);letter-spacing:-.02em;margin-bottom:4px;font-size:1.75rem;font-weight:700}.portal-greeting p{color:var(--muted);font-size:.95rem}.role-badges{flex-wrap:wrap;gap:6px;margin-top:12px;display:flex}.role-badge{background:color-mix(in srgb, var(--primary) 12%, transparent);color:var(--primary);letter-spacing:.02em;text-transform:lowercase;border-radius:99px;align-items:center;padding:3px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.portal-search-wrap{max-width:400px;margin-bottom:32px;position:relative}.search-icon{color:var(--muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.portal-search{background:var(--card-bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);font-size:.9rem;font-family:var(--font);outline:none;padding:10px 14px 10px 38px;transition:border-color .15s}.portal-search:focus{border-color:var(--primary)}.app-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.app-tile{background:var(--card-bg);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text);align-items:center;gap:16px;padding:20px;text-decoration:none;transition:border-color .15s,box-shadow .15s,transform .1s;display:flex}.app-tile:hover{border-color:var(--primary);transform:translateY(-1px);box-shadow:0 2px 12px #4f46e51f}.app-tile:hover .app-tile-arrow{color:var(--primary);transform:translate(3px)}.app-tile-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.app-emoji{font-size:1.5rem;line-height:1}.app-icon-img{object-fit:contain;width:32px;height:32px}.app-tile-info{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.app-tile-name{color:var(--text);font-size:.95rem;font-weight:600}.app-tile-desc{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;overflow:hidden}.app-tile-arrow{color:var(--muted);flex-shrink:0;transition:color .15s,transform .15s}.app-tile--no-url{cursor:default;opacity:.7}.app-tile--no-url:hover{border-color:var(--border);box-shadow:none;transform:none}.app-tile-no-url{color:var(--muted);font-size:.72rem;font-style:italic}.app-tile-roles{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.app-tile-role{background:color-mix(in srgb, currentColor 10%, transparent);color:inherit;opacity:.75;text-transform:lowercase;border-radius:99px;padding:1px 6px;font-size:.65rem;font-weight:600}.portal-empty{color:var(--muted);text-align:center;flex-direction:column;align-items:center;gap:8px;padding:48px 0;font-size:.9rem;display:flex}.portal-empty svg{opacity:.3}.portal-empty-hint{opacity:.7;font-size:.8rem}
