.dashboard{min-height:100vh;display:flex;flex-direction:column}.user-controls{position:absolute;top:1.5rem;right:2rem;display:flex;justify-content:flex-end;align-items:center;z-index:2}.logout-avatar-button{width:42px;height:42px;border:1px solid #e5e7eb;border-radius:999px;background:#fff;padding:0;cursor:pointer;overflow:hidden;display:inline-flex;align-items:center;justify-content:center}.logout-avatar-button:hover{border-color:#ff84ff}.logout-avatar-image{width:100%;height:100%;object-fit:cover}.logout-avatar-fallback{width:100%;height:100%;display:inline-flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:600;color:#4b5563;background:#f3f4f6}.hero{text-align:center;margin-bottom:3rem;padding:2rem 1rem}.hero-logo{height:72px;width:auto;margin-bottom:1.5rem}.hero-title{font-size:2.25rem;font-weight:700;color:#1a1a2e;margin-bottom:.75rem;letter-spacing:-.03em}.hero-subtitle{font-size:1.1rem;color:#6b7280;max-width:560px;margin:0 auto;line-height:1.6}.login-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;margin:0 auto 2.5rem;max-width:520px;text-align:center}.login-title{font-size:1.25rem;font-weight:600;color:#1a1a2e;margin-bottom:.5rem}.login-subtitle{font-size:.95rem;color:#6b7280;margin-bottom:1rem}.login-button-wrap{display:flex;justify-content:center;margin-bottom:.75rem}.login-error{font-size:.9rem;color:#b91c1c;margin-top:.5rem}.main{position:relative;flex:1;max-width:1200px;width:100%;margin:0 auto;padding:3rem 2rem}.category-section{margin-bottom:2.5rem}.category-title{font-size:1.2rem;font-weight:600;color:#1a1a2e;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #f3f4f6}.app-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.25rem}.app-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#fff;border-radius:12px;border:1px solid #e5e7eb;text-decoration:none;color:inherit;transition:all .2s ease;cursor:pointer}.app-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #ff84ff26;border-color:#ff84ff}.app-card:hover .app-arrow{transform:translate(4px);color:#ff84ff}.app-icon{font-size:2rem;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border-radius:12px;flex-shrink:0}.app-icon img{width:56px;height:56px}.app-icon-image{width:28px;height:28px;object-fit:contain}.app-info{flex:1;min-width:0}.app-name{font-size:1rem;font-weight:600;color:#1a1a2e;margin-bottom:.25rem}.app-badge{display:inline-block;margin-top:.5rem;font-size:.7rem;font-weight:600;color:#a21caf;background:#ff84ff2e;border:1px solid #ff84ff;border-radius:999px;padding:.1rem .45rem;white-space:nowrap}.app-description{font-size:.85rem;color:#6b7280;line-height:1.4}.app-arrow{font-size:1.25rem;color:#9ca3af;transition:all .2s ease;flex-shrink:0}.footer{padding:1.5rem 2rem;text-align:center;color:#9ca3af;font-size:.8rem;border-top:1px solid #e5e7eb}@media (max-width: 768px){.header{padding:1rem}.main{padding:2rem 1rem}.user-controls{top:1rem;right:1rem}.app-grid{grid-template-columns:1fr}.welcome h2{font-size:1.5rem}}:root{font-family:Inter,sans-serif;line-height:1.5;font-weight:400;color:#1a1a2e;background-color:#f8f9fc;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body,#root{min-height:100vh}
