*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,sans-serif;background:#0f172a;color:#e2e8f0;min-height:100vh;line-height:1.6}a{color:#2dd4bf;text-decoration:none}a:hover{text-decoration:underline}.header{background:#1e293b;border-bottom:2px solid #14b8a6;padding:0 1.5rem}.header-content{max-width:960px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:60px}.header-brand{display:flex;align-items:center;gap:.75rem}.header-logo{background:#14b8a6;color:#0f172a;font-weight:800;font-size:.85rem;padding:.2rem .5rem;border-radius:4px;letter-spacing:.05em}.header-title{font-size:1.15rem;font-weight:600;color:#f1f5f9}.auth-status{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.status-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.status-dot.authenticated{background:#22c55e;box-shadow:0 0 6px #22c55e88}.status-dot.unauthenticated{background:#94a3b8}.status-label{color:#94a3b8}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1.5rem}.spinner{width:40px;height:40px;border:3px solid #334155;border-top-color:#14b8a6;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:#94a3b8;font-size:1rem}.landing-container{max-width:520px;margin:4rem auto;padding:0 1.5rem}.landing-card{background:#1e293b;border-radius:12px;padding:2.5rem;text-align:center}.landing-card h2{font-size:1.5rem;margin-bottom:1rem;color:#f1f5f9}.landing-description{color:#94a3b8;margin-bottom:2rem;font-size:.95rem}.dam-link{color:#2dd4bf;font-weight:500}.btn-login{background:#14b8a6;color:#0f172a;border:none;padding:.75rem 2rem;font-size:1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:background .2s}.btn-login:hover{background:#0d9488}.error-banner{background:#7f1d1d;border:1px solid #dc2626;border-radius:8px;padding:.75rem 1rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#fecaca}.error-icon{font-size:1.1rem}.dashboard-container{max-width:960px;margin:2rem auto;padding:0 1.5rem}.sso-banner{border-radius:8px;padding:.75rem 1.25rem;margin-bottom:2rem;font-weight:600;font-size:.95rem;text-align:center}.sso-banner-success{background:#14532d;border:1px solid #22c55e;color:#bbf7d0}.sso-banner-info{background:#1e3a5f;border:1px solid #3b82f6;color:#bfdbfe}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:2rem}.card{background:#1e293b;border-radius:12px;padding:1.5rem}.card-title{font-size:1rem;color:#14b8a6;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.05em;font-weight:700}.profile-list{display:grid;grid-template-columns:auto 1fr;gap:.5rem 1rem}.profile-list dt{color:#64748b;font-size:.85rem;font-weight:500}.profile-list dd{color:#e2e8f0;font-size:.9rem;word-break:break-all}.role-badges{display:flex;flex-wrap:wrap;gap:.5rem}.role-badge{background:#334155;color:#2dd4bf;padding:.25rem .75rem;border-radius:999px;font-size:.8rem;font-weight:500;border:1px solid #475569}.no-roles{color:#64748b;font-size:.85rem}.dashboard-actions{display:flex;gap:1rem;align-items:center}.btn-logout{background:#dc2626;color:#fff;border:none;padding:.6rem 1.5rem;font-size:.9rem;font-weight:600;border-radius:8px;cursor:pointer;transition:background .2s}.btn-logout:hover{background:#b91c1c}.btn-dam-link{color:#2dd4bf;font-weight:500;font-size:.9rem;padding:.6rem 1rem;border:1px solid #334155;border-radius:8px;transition:border-color .2s;display:inline-block}.btn-dam-link:hover{border-color:#14b8a6;text-decoration:none}.callback-error{max-width:480px;margin:4rem auto;text-align:center;padding:0 1.5rem}.callback-error h2{color:#f87171;margin-bottom:1rem}.callback-error .error-message{color:#94a3b8;margin-bottom:1.5rem}.btn-home{display:inline-block;background:#334155;color:#e2e8f0;padding:.6rem 1.5rem;border-radius:8px;font-weight:500;transition:background .2s}.btn-home:hover{background:#475569;text-decoration:none}.callback-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1.5rem;color:#94a3b8}@media(max-width:640px){.dashboard-grid{grid-template-columns:1fr}.header-title{font-size:.95rem}.dashboard-actions{flex-direction:column;align-items:stretch}.btn-dam-link{text-align:center}}
