/* Static detail styles for Jarvis Portal pages. */
/* Extracted from templates so the web suite has no inline CSS blocks. */

/* ---- jarvis/web/portal/templates/portal.html ---- */
.login-card { max-width: 380px; margin: 28px auto 0; }
.login-card label { display: block; font-size: 12px; color: var(--muted); margin: 12px 0 4px; }
.login-card input { width: 100%; min-height: 40px; border: 1px solid var(--line); border-radius: var(--radius-sm); padding: 8px 10px; }
.login-card .login-check { display: flex; align-items: flex-start; gap: 8px; margin-top: 12px; color: var(--ink); }
.login-card .login-check input { width: 16px; min-height: 16px; height: 16px; margin: 1px 0 0; }
.login-card .login-hint { margin: 5px 0 0; font-size: 12px; color: var(--muted); line-height: 1.4; }
.login-card button { width: 100%; margin-top: 16px; }
.portal-access-denied { border-top: 3px solid #528bff; }
.portal-access-denied .panel-heading {
  align-items: flex-start;
  gap: 14px;
}
.portal-access-denied .panel-heading h2 {
  margin-top: 8px;
}
.portal-denied-meta {
  display: grid;
  gap: 4px;
  margin: 14px 0 18px;
  border: 1px solid var(--ops-line, #d9e0ea);
  border-radius: 8px;
  background: #f8fafc;
  padding: 10px 12px;
}
.portal-denied-meta span {
  color: var(--ops-muted, #667085);
  font-size: 11px;
  font-weight: 750;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.portal-denied-meta strong {
  overflow-wrap: anywhere;
  color: var(--ops-ink, #111827);
  font-size: 13px;
}
.portal-denied-links {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}
@media (max-width: 560px) {
  .portal-wrap { max-width: 100%; }
  .portal-access-denied .panel-heading {
    align-items: stretch;
  }
  .portal-access-denied .panel-heading > .btn {
    align-self: flex-start;
  }
  .portal-denied-links {
    grid-template-columns: minmax(0, 1fr);
  }
}
