/* M365 AI Assistant - Custom styles */
body { font-family: system-ui, -apple-system, sans-serif; }
.nav-link.active { background-color: rgb(37 99 235); color: white; }
.nav-link:not(.active):hover { background-color: rgb(243 244 246); }
.status-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; }
.status-dot.green { background-color: #22c55e; }
.status-dot.red { background-color: #ef4444; }
.status-dot.yellow { background-color: #f59e0b; }
table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 0.5rem 0.75rem; border-bottom: 1px solid #e5e7eb; }
th { background: #f9fafb; font-weight: 600; font-size: 0.875rem; }
tr:hover td { background: #f9fafb; }
.badge { display: inline-flex; align-items: center; padding: 0.125rem 0.5rem; border-radius: 9999px; font-size: 0.75rem; font-weight: 500; }
.badge-blue { background: #dbeafe; color: #1d4ed8; }
.badge-green { background: #dcfce7; color: #166534; }
.badge-red { background: #fee2e2; color: #991b1b; }
.badge-yellow { background: #fef9c3; color: #713f12; }
.badge-gray { background: #f3f4f6; color: #374151; }
.modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 50; display: flex; align-items: center; justify-content: center; }
.modal-box { background: white; border-radius: 0.5rem; padding: 1.5rem; max-width: 42rem; width: 100%; max-height: 80vh; overflow-y: auto; }
pre.meta { background: #1e293b; color: #e2e8f0; padding: 1rem; border-radius: 0.375rem; font-size: 0.75rem; overflow-x: auto; white-space: pre-wrap; }
