:root{--color-bg-base: #f4f6fb;--color-bg-elevated: #ffffff;--color-bg-muted: #f8fafc;--color-border: #e2e8f0;--color-border-strong: #cbd5e1;--color-text: #0f172a;--color-text-secondary: #334155;--color-text-muted: #64748b;--color-accent: #6366f1;--color-accent-strong: #4f46e5;--color-accent-soft: #eef2ff;--color-input-bg: #ffffff;--color-input-border: #cbd5e1;--color-error-bg: #fef2f2;--color-error-border: #fecaca;--color-error-text: #b91c1c;--color-success-text: #15803d;--color-header-bg: rgba(255, 255, 255, .88);--shadow-card: 0 1px 3px rgba(15, 23, 42, .06), 0 8px 24px rgba(15, 23, 42, .08)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh;font-family:Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;color:var(--color-text);background-color:var(--color-bg-base);background-image:radial-gradient(ellipse 100% 80% at 50% -20%,rgba(99,102,241,.1),transparent 55%),radial-gradient(ellipse 70% 50% at 100% 0%,rgba(56,189,248,.07),transparent 50%),radial-gradient(ellipse 60% 45% at 0% 100%,rgba(167,139,250,.06),transparent 50%),linear-gradient(180deg,#f8faff,#f1f5f9,#eef2f7);background-attachment:fixed;-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(15,23,42,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(15,23,42,.035) 1px,transparent 1px);background-size:72px 72px;-webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,black 0%,transparent 100%);mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,black 0%,transparent 100%);pointer-events:none;z-index:0}#root{position:relative;z-index:1;min-height:100vh}.login-page,.dashboard-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem}.login-card,.dashboard-card{width:100%;max-width:400px;padding:2.5rem 2rem;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:16px;-webkit-backdrop-filter:blur(20px) saturate(1.2);backdrop-filter:blur(20px) saturate(1.2);box-shadow:var(--shadow-card);text-align:center}.login-brand,.dashboard-header{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-bottom:.5rem}.login-logo{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:14px;background:linear-gradient(135deg,#818cf8,#6366f1,#4f46e5);box-shadow:0 8px 24px #6366f159;font-size:1.75rem;font-weight:700;color:#fff}.login-brand h1,.dashboard-header h1{font-size:1.75rem;font-weight:600;letter-spacing:-.02em}.login-subtitle{color:var(--color-text-muted);margin-bottom:1.75rem;font-size:.95rem}.auth-actions{display:flex;flex-direction:column;gap:.75rem}.auth-divider{color:var(--color-text-muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.microsoft-btn{display:inline-flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.875rem 1.25rem;border:1px solid var(--color-border-strong);border-radius:8px;background:#fff;color:var(--color-text);font-size:.95rem;font-weight:600;cursor:pointer;box-shadow:0 1px 2px #0f172a0f;transition:background .15s,transform .1s}.microsoft-btn:hover{background:#f8fafc}.microsoft-btn:active{transform:scale(.98)}.microsoft-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.microsoft-btn:disabled:hover{background:#fff}.microsoft-btn-outline:disabled:hover{background:transparent}.microsoft-btn svg{width:20px;height:20px;flex-shrink:0}.microsoft-btn-outline{background:transparent;border:1px solid var(--color-border-strong);color:var(--color-text);box-shadow:none}.microsoft-btn-outline:hover{background:var(--color-bg-muted)}.user-info{margin:1.5rem 0 2rem;padding:1rem;background:var(--color-bg-muted);border:1px solid var(--color-border);border-radius:10px}.user-name{font-size:1.1rem;font-weight:600;margin-bottom:.25rem}.user-email{font-size:.875rem;color:var(--color-text-muted)}.logout-btn{width:100%;padding:.75rem 1.25rem;border:1px solid var(--color-border-strong);border-radius:8px;background:transparent;color:var(--color-text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:background .15s}.logout-btn:hover{background:var(--color-bg-muted)}.setup-card{text-align:left}.setup-errors{margin:1rem 0;padding:.75rem 1rem;border-radius:8px;background:var(--color-error-bg);border:1px solid var(--color-error-border)}.setup-errors p{color:var(--color-error-text);font-size:.875rem;margin-bottom:.25rem}.setup-errors p:last-child{margin-bottom:0}.setup-steps{padding-left:1.25rem;color:var(--color-text-secondary);font-size:.9rem;line-height:1.7}.setup-steps code{background:#f1f5f9;padding:.1rem .35rem;border-radius:4px;font-size:.85rem}.auth-error{margin-bottom:1rem;padding:.75rem 1rem;border-radius:8px;background:var(--color-error-bg);border:1px solid var(--color-error-border);color:var(--color-error-text);font-size:.875rem;text-align:left}.user-role,.user-apps{margin-top:.5rem;font-size:.8rem;color:var(--color-text-muted)}.loading-spinner{width:32px;height:32px;margin:1rem auto 0;border:3px solid var(--color-border);border-top-color:var(--color-accent-strong);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
