/* Mirrion Health — app styles */

.nav-link {
  display: flex;
  align-items: center;
  padding: 0.375rem 0.5rem;
  border-radius: 0.375rem;
  color: #4b5563;
  transition: background-color 0.15s, color 0.15s;
  text-decoration: none;
}
.nav-link:hover {
  background-color: #eff6ff;
  color: #1d4ed8;
}
.nav-link.active {
  background-color: #dbeafe;
  color: #1d4ed8;
  font-weight: 600;
}

/* Status badges */
.badge-optimal  { background: #d1fae5; color: #065f46; }
.badge-normal   { background: #dbeafe; color: #1e40af; }
.badge-borderline { background: #fef3c7; color: #92400e; }
.badge-abnormal { background: #fee2e2; color: #991b1b; }
.badge {
  display: inline-block;
  padding: 0.125rem 0.5rem;
  border-radius: 9999px;
  font-size: 0.7rem;
  font-weight: 600;
}

/* HTMX loading indicator */
.htmx-indicator { display: none; }
.htmx-request .htmx-indicator { display: inline-block; }
.htmx-request.htmx-indicator { display: inline-block; }

/* Markdown rendered content */
.markdown-body h1 { font-size: 1.5rem; font-weight: 700; margin: 1rem 0 0.5rem; }
.markdown-body h2 { font-size: 1.25rem; font-weight: 700; margin: 0.875rem 0 0.5rem; }
.markdown-body h3 { font-size: 1.1rem; font-weight: 600; margin: 0.75rem 0 0.375rem; }
.markdown-body p  { margin: 0.5rem 0; line-height: 1.6; }
.markdown-body ul { list-style: disc; padding-left: 1.5rem; margin: 0.5rem 0; }
.markdown-body ol { list-style: decimal; padding-left: 1.5rem; margin: 0.5rem 0; }
.markdown-body li { margin: 0.25rem 0; }
.markdown-body strong { font-weight: 700; }
.markdown-body em { font-style: italic; }
.markdown-body code { background: #f3f4f6; padding: 0.1rem 0.3rem; border-radius: 0.25rem; font-size: 0.875rem; }
.markdown-body blockquote { border-left: 3px solid #d1d5db; padding-left: 1rem; color: #6b7280; margin: 0.5rem 0; }

/* Spinner */
@keyframes spin { to { transform: rotate(360deg); } }
.spinner { width: 1.25rem; height: 1.25rem; border: 2px solid #e5e7eb; border-top-color: #3b82f6; border-radius: 50%; animation: spin 0.7s linear infinite; display: inline-block; }

/* Drop zone */
.drop-zone {
  border: 2px dashed #93c5fd;
  border-radius: 0.75rem;
  padding: 3rem;
  text-align: center;
  cursor: pointer;
  transition: background 0.2s;
}
.drop-zone:hover, .drop-zone.drag-over {
  background: #eff6ff;
}

/* Table */
.data-table { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
.data-table th { background: #f9fafb; text-align: left; padding: 0.5rem 0.75rem; border-bottom: 1px solid #e5e7eb; font-weight: 600; color: #374151; }
.data-table td { padding: 0.5rem 0.75rem; border-bottom: 1px solid #f3f4f6; vertical-align: top; }
.data-table tr:hover td { background: #f9fafb; }

/* Form inputs */
.form-input {
  width: 100%;
  padding: 0.375rem 0.75rem;
  border: 1px solid #d1d5db;
  border-radius: 0.375rem;
  font-size: 0.875rem;
  background: white;
}
.form-input:focus { outline: none; border-color: #3b82f6; box-shadow: 0 0 0 2px rgba(59,130,246,0.2); }

/* Buttons */
.btn { display: inline-flex; align-items: center; padding: 0.375rem 0.875rem; border-radius: 0.375rem; font-size: 0.875rem; font-weight: 500; cursor: pointer; transition: background 0.15s; border: none; }
.btn-primary { background: #2563eb; color: white; }
.btn-primary:hover { background: #1d4ed8; }
.btn-secondary { background: #f3f4f6; color: #374151; border: 1px solid #e5e7eb; }
.btn-secondary:hover { background: #e5e7eb; }
.btn-danger { background: #fee2e2; color: #991b1b; }
.btn-danger:hover { background: #fecaca; }
.btn-sm { padding: 0.25rem 0.625rem; font-size: 0.75rem; }
