/* ================================================================
   Magrathea Compliance — Premium Module Styles v1
   Work Orders | HR Employees | Incidents | Risk Assessments
   ================================================================ */

/* ── Breadcrumb ────────────────────────────────────────────────── */
.pm-breadcrumb { display:flex; align-items:center; gap:.5rem; font-size:.8rem; color:#6b7280; margin-bottom:1.5rem; flex-wrap:wrap; }
.pm-breadcrumb a { color:#6366f1; text-decoration:none; }
.pm-breadcrumb a:hover { text-decoration:underline; }
.pm-breadcrumb-sep { color:#d1d5db; }

/* ── Hero ──────────────────────────────────────────────────────── */
.pm-hero { background:linear-gradient(135deg,#1e1b4b 0%,#312e81 60%,#4338ca 100%); border-radius:1rem; padding:2rem; color:#fff; margin-bottom:1.5rem; position:relative; overflow:hidden; }
.pm-hero::before { content:""; position:absolute; inset:0; background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") repeat; pointer-events:none; }
.pm-hero-inner { position:relative; z-index:1; display:flex; align-items:flex-start; gap:1.5rem; flex-wrap:wrap; }
.pm-hero-icon { width:4rem; height:4rem; border-radius:.75rem; background:rgba(255,255,255,.15); display:flex; align-items:center; justify-content:center; font-size:1.6rem; flex-shrink:0; border:2px solid rgba(255,255,255,.2); filter:grayscale(1); }
.pm-hero-avatar { width:4rem; height:4rem; border-radius:50%; background:rgba(255,255,255,.2); display:flex; align-items:center; justify-content:center; font-size:1.4rem; font-weight:700; color:#fff; flex-shrink:0; border:2px solid rgba(255,255,255,.3); }
.pm-hero-body { flex:1; min-width:0; }
.pm-hero-ref { font-size:.75rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.6); margin-bottom:.25rem; }
.pm-hero-title { font-size:1.6rem; font-weight:700; color:#fff; line-height:1.2; margin:0 0 .5rem; word-break:break-word; }
.pm-hero-meta { display:flex; flex-wrap:wrap; gap:.5rem; align-items:center; }
.pm-hero-chip { background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.18); border-radius:2rem; padding:.25rem .75rem; font-size:.78rem; color:rgba(255,255,255,.85); }
.pm-hero-actions { display:flex; flex-wrap:wrap; gap:.5rem; margin-top:1rem; }

/* ── Page-level action bar (below the hero) ───────────────────── */
.pm-page-actions { display:flex; flex-wrap:wrap; align-items:center; gap:.5rem; margin-bottom:1.25rem; }
.pm-hero-tag { background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.15); border-radius:.375rem; padding:.15rem .55rem; font-size:.72rem; color:rgba(255,255,255,.7); }

/* Variant heroes */
.pm-hero-wo   { background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 60%,#1d4ed8 100%); }
.pm-hero-hr   { background:linear-gradient(135deg,#1e1b4b 0%,#312e81 60%,#6d28d9 100%); }
.pm-hero-hs   { background:linear-gradient(135deg,#14532d 0%,#15803d 60%,#16a34a 100%); }
.pm-hero-assets { background:linear-gradient(135deg,#0c4a6e 0%,#075985 60%,#0ea5e9 100%); }
.pm-hero-contractors { background:linear-gradient(135deg,#1c1917 0%,#44403c 60%,#78716c 100%); }
.pm-hero-inc  { background:linear-gradient(135deg,#450a0a 0%,#7f1d1d 60%,#dc2626 100%); }
.pm-hero-inc-warn { background:linear-gradient(135deg,#431407 0%,#7c2d12 60%,#ea580c 100%); }
.pm-hero-inc-mod  { background:linear-gradient(135deg,#422006 0%,#78350f 60%,#d97706 100%); }
.pm-hero-inc-minor{ background:linear-gradient(135deg,#172554 0%,#1e3a8a 60%,#2563eb 100%); }
.pm-hero-ra   { background:linear-gradient(135deg,#0c4a6e 0%,#075985 60%,#0284c7 100%); }
.pm-hero-ra-high { background:linear-gradient(135deg,#450a0a 0%,#7f1d1d 60%,#dc2626 100%); }
.pm-hero-ra-med  { background:linear-gradient(135deg,#422006 0%,#78350f 60%,#d97706 100%); }
.pm-hero-ra-low  { background:linear-gradient(135deg,#052e16 0%,#14532d 60%,#15803d 100%); }

/* ── Status/Priority/Severity badges ──────────────────────────── */
.pm-badge { display:inline-flex; align-items:center; gap:.3rem; border-radius:2rem; padding:.25rem .75rem; font-size:.75rem; font-weight:600; letter-spacing:.03em; white-space:nowrap; }
.pm-badge-open       { background:#dbeafe; color:#1d4ed8; }
.pm-badge-draft      { background:#f3f4f6; color:#374151; }
.pm-badge-inprogress { background:#d1fae5; color:#065f46; }
.pm-badge-on-hold    { background:#fef3c7; color:#92400e; }
.pm-badge-completed  { background:#d1fae5; color:#065f46; }
.pm-badge-cancelled  { background:#fee2e2; color:#991b1b; }
.pm-badge-rejected   { background:#fee2e2; color:#991b1b; }
.pm-badge-closed     { background:#e5e7eb; color:#374151; }
.pm-badge-approved   { background:#d1fae5; color:#065f46; }
.pm-badge-active     { background:#d1fae5; color:#065f46; }
.pm-badge-suspended  { background:#fee2e2; color:#991b1b; }
.pm-badge-overdue    { background:#fee2e2; color:#991b1b; }
.pm-badge-underreview{ background:#ede9fe; color:#5b21b6; }
.pm-badge-pending    { background:#fef3c7; color:#92400e; }
/* Priority */
.pm-badge-critical   { background:#fef2f2; color:#dc2626; border:1px solid #fca5a5; }
.pm-badge-high       { background:#fff7ed; color:#c2410c; border:1px solid #fed7aa; }
.pm-badge-medium     { background:#fefce8; color:#854d0e; border:1px solid #fde68a; }
.pm-badge-low        { background:#f0fdf4; color:#15803d; border:1px solid #bbf7d0; }
/* Severity */
.pm-badge-fatal      { background:#fef2f2; color:#dc2626; border:1px solid #fca5a5; }
.pm-badge-major      { background:#fff7ed; color:#c2410c; border:1px solid #fed7aa; }
.pm-badge-serious    { background:#fff7ed; color:#c2410c; border:1px solid #fed7aa; }
.pm-badge-moderate   { background:#fefce8; color:#854d0e; border:1px solid #fde68a; }
.pm-badge-minor      { background:#eff6ff; color:#1d4ed8; border:1px solid #bfdbfe; }
/* Risk ratings */
.pm-badge-veryhigh   { background:#fef2f2; color:#dc2626; border:1px solid #fca5a5; }
.pm-badge-tolerable  { background:#eff6ff; color:#1d4ed8; border:1px solid #bfdbfe; }
.pm-badge-acceptable { background:#f0fdf4; color:#15803d; border:1px solid #bbf7d0; }
/* Employment */
.pm-badge-part-time  { background:#ede9fe; color:#6d28d9; }
.pm-badge-on-leave   { background:#fef3c7; color:#92400e; }
.pm-badge-leaver     { background:#f3f4f6; color:#6b7280; }
.pm-badge-contractor { background:#fdf4ff; color:#86198f; }

/* ── Stat strip ────────────────────────────────────────────────── */
.pm-stat-strip { display:flex; gap:.875rem; flex-wrap:wrap; margin-bottom:1.5rem; }
.pm-stat { background:#fff; border:1px solid #e5e7eb; border-radius:.75rem; padding:.75rem 1.25rem; display:flex; flex-direction:column; gap:.15rem; min-width:7.5rem; flex:1; text-decoration:none; transition:box-shadow .15s,border-color .15s; }
.pm-stat:hover { border-color:#6366f1; box-shadow:0 0 0 3px rgba(99,102,241,.08); }
.pm-stat-val   { font-size:1.5rem; font-weight:700; color:#1e1b4b; line-height:1; }
.pm-stat-label { font-size:.75rem; color:#6b7280; font-weight:500; margin-top:.2rem; }
.pm-stat-sub   { font-size:.72rem; color:#9ca3af; }
.pm-stat-active{ border-color:#6366f1; }
.pm-stat-warn  { border-color:#f59e0b; }
.pm-stat-ok    { border-color:#10b981; }
.pm-stat-danger{ border-color:#ef4444; }

/* ── Two-column form layout ────────────────────────────────────── */
.pm-form-layout  { display:grid; grid-template-columns:1fr 340px; gap:1.5rem; align-items:start; }
.pm-form-main    { display:flex; flex-direction:column; gap:1.25rem; }
.pm-form-sidebar { display:flex; flex-direction:column; gap:1.25rem; position:sticky; top:1rem; }

/* ── Detail two-column layout ──────────────────────────────────── */
.pm-detail-layout  { display:grid; grid-template-columns:1fr 300px; gap:1.5rem; align-items:start; }
.pm-detail-main    { display:flex; flex-direction:column; gap:1.25rem; }
.pm-detail-sidebar { display:flex; flex-direction:column; gap:1.25rem; position:sticky; top:1rem; }

/* ── Cards ─────────────────────────────────────────────────────── */
.pm-card         { background:#fff; border:1px solid #e5e7eb; border-radius:.875rem; overflow:hidden; }
.pm-card-header  { display:flex; align-items:center; justify-content:space-between; padding:.875rem 1.25rem; border-bottom:1px solid #f3f4f6; background:#fafafa; }
.pm-card-title   { font-size:.875rem; font-weight:700; color:#1f2937; display:flex; align-items:center; gap:.5rem; }
.pm-card-icon    { font-size:1rem; filter:grayscale(1); opacity:.58; }
.pm-card-body    { padding:1.25rem; }
.pm-card-footer  { padding:.875rem 1.25rem; border-top:1px solid #f3f4f6; background:#fafafa; }

/* ── Form fields ───────────────────────────────────────────────── */
.pm-field     { display:flex; flex-direction:column; gap:.3rem; }
.pm-label     { font-size:.8rem; font-weight:600; color:#374151; display:flex; align-items:center; gap:.4rem; }
.pm-label-req { color:#ef4444; }
.pm-input, .pm-select, .pm-textarea { width:100%; padding:.5rem .75rem; border:1.5px solid #e5e7eb; border-radius:.5rem; font-size:.875rem; color:#111827; background:#fff; transition:border-color .15s; box-sizing:border-box; font-family:inherit; }
.pm-input:focus, .pm-select:focus, .pm-textarea:focus { outline:none; border-color:#6366f1; box-shadow:0 0 0 3px rgba(99,102,241,.1); }
.pm-input:disabled, .pm-input[disabled] { background:#f9fafb; color:#6b7280; cursor:default; }
.pm-hint    { font-size:.73rem; color:#9ca3af; }
.pm-field-row   { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.pm-field-row-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:1rem; }
.pm-field-grid  { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.pm-fields-block { display:flex; flex-direction:column; gap:.875rem; }

/* ── Alert / urgency banner ────────────────────────────────────── */
.pm-alert        { border-radius:.75rem; padding:.875rem 1.25rem; font-size:.875rem; font-weight:500; display:flex; align-items:flex-start; gap:.75rem; }
.pm-alert-danger { background:#fef2f2; border:1px solid #fca5a5; color:#991b1b; }
.pm-alert-warn   { background:#fffbeb; border:1px solid #fde68a; color:#92400e; }
.pm-alert-info   { background:#eff6ff; border:1px solid #bfdbfe; color:#1e40af; }
.pm-alert-success{ background:#f0fdf4; border:1px solid #bbf7d0; color:#065f46; }
.pm-alert-icon   { font-size:1.2rem; flex-shrink:0; line-height:1.4; }

/* ── DL (definition list) rows ─────────────────────────────────── */
.pm-dl      { display:grid; grid-template-columns:1fr 1fr; gap:.875rem; }
.pm-dl-wide { grid-column:1 / -1; }
.pm-dl-row  { display:flex; flex-direction:column; gap:.2rem; }
.pm-dt      { font-size:.72rem; color:#9ca3af; font-weight:600; text-transform:uppercase; letter-spacing:.06em; }
.pm-dd      { font-size:.875rem; color:#111827; font-weight:500; line-height:1.4; }
.pm-dd pre  { margin:0; white-space:pre-wrap; font-family:inherit; }

/* ── Narrative text block ──────────────────────────────────────── */
.pm-narrative { background:#f9fafb; border:1px solid #f3f4f6; border-radius:.625rem; padding:1rem 1.1rem; font-size:.875rem; color:#374151; line-height:1.75; white-space:pre-wrap; word-break:break-word; }
.pm-narrative-empty { color:#9ca3af; font-style:italic; }

/* ── Buttons ───────────────────────────────────────────────────── */
.pm-btn          { display:inline-flex; align-items:center; gap:.4rem; border:none; border-radius:.5rem; padding:.5rem 1.1rem; font-size:.85rem; font-weight:600; cursor:pointer; transition:all .15s; text-decoration:none; white-space:nowrap; }
.pm-btn-primary  { background:#6366f1; color:#fff; }
.pm-btn-primary:hover  { background:#4f46e5; }
.pm-btn-secondary{ background:#f3f4f6; color:#374151; border:1px solid #e5e7eb; }
.pm-btn-secondary:hover{ background:#e5e7eb; }
.pm-btn-danger   { background:#ef4444; color:#fff; }
.pm-btn-danger:hover   { background:#dc2626; }
.pm-btn-warn     { background:#f59e0b; color:#fff; }
.pm-btn-warn:hover     { background:#d97706; }
.pm-btn-success  { background:#10b981; color:#fff; }
.pm-btn-success:hover  { background:#059669; }
.pm-btn-ghost    { background:transparent; color:#6366f1; border:1px solid #c7d2fe; }
.pm-btn-ghost:hover    { background:#eef2ff; }
.pm-btn-sm  { padding:.3rem .7rem; font-size:.78rem; }
.pm-btn-lg  { padding:.7rem 1.5rem; font-size:.95rem; }
.pm-btn-full{ width:100%; justify-content:center; }
.pm-btn:disabled, .pm-btn[disabled] { opacity:.5; cursor:not-allowed; }
.pm-btn-link { background:none; border:none; color:#6366f1; font-size:.83rem; cursor:pointer; padding:0; text-decoration:underline; }

/* ── Toolbar ───────────────────────────────────────────────────── */
.pm-toolbar { display:flex; flex-wrap:wrap; gap:.625rem; align-items:center; margin-bottom:1.25rem; }
.pm-toolbar-spacer { flex:1; }

/* ── Save sidebar card ─────────────────────────────────────────── */
.pm-save-card { background:linear-gradient(135deg,#312e81,#4338ca); border-radius:.875rem; padding:1.25rem; color:#fff; }
.pm-save-card-title { font-size:.8rem; font-weight:700; color:#c7d2fe; margin:0 0 .875rem; text-transform:uppercase; letter-spacing:.06em; }
.pm-save-card .pm-btn-primary  { background:#fff; color:#4338ca; width:100%; justify-content:center; margin-bottom:.5rem; }
.pm-save-card .pm-btn-primary:hover  { background:#e0e7ff; }
.pm-save-card .pm-btn-secondary{ background:rgba(255,255,255,.1); color:#fff; border-color:rgba(255,255,255,.2); width:100%; justify-content:center; margin-bottom:.5rem; }
.pm-save-card .pm-btn-secondary:hover{ background:rgba(255,255,255,.2); }
.pm-save-card .pm-btn-danger   { background:rgba(239,68,68,.75); width:100%; justify-content:center; margin-top:.25rem; }
.pm-save-card .pm-btn-danger:hover { background:rgba(220,38,38,.9); }
.pm-save-card-error { font-size:.8rem; color:#fca5a5; margin-top:.5rem; }

/* ── Quick actions sidebar card ────────────────────────────────── */
.pm-actions-card { background:#fff; border:1px solid #e5e7eb; border-radius:.875rem; overflow:hidden; }
.pm-actions-card-title { font-size:.8rem; font-weight:700; color:#6b7280; text-transform:uppercase; letter-spacing:.06em; padding:.875rem 1.25rem; border-bottom:1px solid #f3f4f6; }
.pm-actions-card-body  { padding:.75rem 1.25rem; display:flex; flex-direction:column; gap:.5rem; }
.pm-actions-card .pm-btn { width:100%; justify-content:flex-start; }

/* ── Risk matrix pair ──────────────────────────────────────────── */
.pm-risk-pair { display:grid; grid-template-columns:1fr 1fr; gap:.75rem; }
.pm-risk-chip { border-radius:.625rem; padding:.75rem 1rem; display:flex; flex-direction:column; gap:.25rem; }
.pm-risk-chip-label { font-size:.7rem; font-weight:600; text-transform:uppercase; letter-spacing:.05em; opacity:.8; }
.pm-risk-chip-val   { font-size:1rem; font-weight:700; }
.pm-risk-vh  { background:#fef2f2; color:#dc2626; border:1px solid #fca5a5; }
.pm-risk-high{ background:#fff7ed; color:#c2410c; border:1px solid #fed7aa; }
.pm-risk-med { background:#fefce8; color:#854d0e; border:1px solid #fde68a; }
.pm-risk-tol { background:#eff6ff; color:#1d4ed8; border:1px solid #bfdbfe; }
.pm-risk-acc { background:#f0fdf4; color:#15803d; border:1px solid #bbf7d0; }
.pm-risk-none{ background:#f9fafb; color:#6b7280; border:1px solid #e5e7eb; }

/* ── Health checklist ──────────────────────────────────────────── */
.pm-health-list { display:flex; flex-direction:column; gap:0; }
.pm-health-item { display:flex; align-items:center; gap:.625rem; padding:.5rem 0; border-bottom:1px solid #f3f4f6; font-size:.83rem; color:#374151; }
.pm-health-item:last-child { border-bottom:none; }
.pm-health-dot { width:.55rem; height:.55rem; border-radius:50%; flex-shrink:0; }
.pm-health-ok  { background:#10b981; }
.pm-health-warn{ background:#f59e0b; }
.pm-health-bad { background:#ef4444; }
.pm-health-none{ background:#d1d5db; }

/* ── Table ─────────────────────────────────────────────────────── */
.pm-table-wrap { overflow-x:auto; border-radius:.625rem; border:1px solid #e5e7eb; }
.pm-table      { width:100%; border-collapse:collapse; font-size:.83rem; min-width:500px; }
.pm-table th   { padding:.625rem 1rem; text-align:left; font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:#6b7280; background:#f9fafb; border-bottom:2px solid #e5e7eb; white-space:nowrap; }
.pm-table td   { padding:.625rem 1rem; border-bottom:1px solid #f3f4f6; color:#374151; vertical-align:middle; }
.pm-table tr:last-child td { border-bottom:none; }
.pm-table tr:hover td { background:#fafafa; }
.pm-table a    { color:#6366f1; text-decoration:none; font-weight:500; }
.pm-table a:hover { text-decoration:underline; }
.pm-table-empty{ text-align:center; padding:2.5rem 1rem; color:#9ca3af; font-size:.875rem; }

/* ── Messages ──────────────────────────────────────────────────── */
.pm-msg         { border-radius:.625rem; padding:.75rem 1rem; font-size:.875rem; margin-bottom:1rem; }
.pm-msg-success { background:#f0fdf4; border:1px solid #bbf7d0; color:#065f46; }
.pm-msg-error   { background:#fef2f2; border:1px solid #fca5a5; color:#991b1b; }
.pm-msg-warn    { background:#fffbeb; border:1px solid #fde68a; color:#92400e; }
.pm-msg-info    { background:#eff6ff; border:1px solid #bfdbfe; color:#1e40af; }

/* ── Loading ───────────────────────────────────────────────────── */
.pm-loading { display:flex; align-items:center; justify-content:center; min-height:14rem; flex-direction:column; gap:.875rem; color:#6b7280; font-size:.875rem; }
.pm-spinner { width:2.25rem; height:2.25rem; border:3px solid #e5e7eb; border-top-color:#6366f1; border-radius:50%; animation:pm-spin .8s linear infinite; }
@keyframes pm-spin { to { transform:rotate(360deg); } }

/* ── AI assist inline button ───────────────────────────────────── */
.pm-ai-btn { display:inline-flex; align-items:center; gap:.3rem; background:linear-gradient(135deg,#7c3aed,#6366f1); color:#fff; border:none; border-radius:.375rem; padding:.2rem .6rem; font-size:.72rem; font-weight:600; cursor:pointer; transition:opacity .15s; vertical-align:middle; }
.pm-ai-btn:hover { opacity:.85; }

/* ── Severity accent bar (left border on incident forms) ───────── */
.pm-sev-card-fatal   { border-left:4px solid #dc2626 !important; }
.pm-sev-card-major   { border-left:4px solid #ef4444 !important; }
.pm-sev-card-serious { border-left:4px solid #f97316 !important; }
.pm-sev-card-moderate{ border-left:4px solid #f59e0b !important; }
.pm-sev-card-minor   { border-left:4px solid #3b82f6 !important; }

/* ── Completion checklist sidebar ──────────────────────────────── */
.pm-checklist { display:flex; flex-direction:column; gap:0; }
.pm-check-item { display:flex; align-items:center; gap:.625rem; padding:.45rem 0; border-bottom:1px solid #f3f4f6; font-size:.81rem; color:#374151; }
.pm-check-item:last-child { border-bottom:none; }
.pm-check-icon { font-size:.875rem; flex-shrink:0; }
.pm-check-done { color:#10b981; }
.pm-check-miss { color:#d1d5db; }
.pm-progress-bar-wrap { background:#f3f4f6; border-radius:2rem; height:.5rem; overflow:hidden; margin:.5rem 0; }
.pm-progress-bar { height:100%; background:linear-gradient(90deg,#6366f1,#818cf8); border-radius:2rem; transition:width .4s; }

/* ── Simple form page (no sidebar needed) ──────────────────────── */
.pm-simple-form { display:flex; flex-direction:column; gap:1.25rem; max-width:860px; }
.pm-form-actions { display:flex; gap:.625rem; flex-wrap:wrap; padding-top:.25rem; }

/* ── Toggle/checkbox label helper ──────────────────────────────── */
.pm-toggle-label { display:inline-flex; align-items:center; gap:.5rem; cursor:pointer; font-size:.875rem; color:#374151; }
.pm-toggle-input { width:1rem; height:1rem; accent-color:#6366f1; cursor:pointer; flex-shrink:0; }

/* ── Responsive ────────────────────────────────────────────────── */
@media(max-width:960px) {
  .pm-form-layout, .pm-detail-layout { grid-template-columns:1fr; }
  .pm-form-sidebar, .pm-detail-sidebar { position:static; }
  .pm-dl  { grid-template-columns:1fr 1fr; }
  .pm-field-row, .pm-field-row-3, .pm-field-grid { grid-template-columns:1fr; }
  .pm-hero-title { font-size:1.25rem; }
}
@media(max-width:600px) {
  .pm-stat-strip { gap:.5rem; }
  .pm-stat { min-width:6rem; padding:.625rem 1rem; }
  .pm-dl { grid-template-columns:1fr; }
}

/* ── Task List ─────────────────────────────────────────────────── */
.task-list { display:flex; flex-direction:column; gap:.5rem; margin:.5rem 0 1rem; }
.task-item { display:flex; align-items:center; gap:.75rem; background:#fff; border:1px solid #e5e7eb; border-radius:.625rem; padding:.625rem .875rem; transition:background .15s, border-color .15s; }
.task-item:hover { border-color:#a5b4fc; background:#fafafa; }
.task-item-done { background:#f0fdf4; border-color:#bbf7d0; }
.task-check-label { display:flex; align-items:center; gap:.625rem; flex:1; cursor:pointer; font-size:.9rem; color:#374151; }
.task-check-label input[type=checkbox] { width:1.1rem; height:1.1rem; accent-color:#6366f1; cursor:pointer; flex-shrink:0; }
.task-title { flex:1; }
.task-item-done .task-title { text-decoration:line-through; color:#9ca3af; }
.task-done-stamp { font-size:.75rem; color:#10b981; font-weight:500; white-space:nowrap; }
.task-delete { background:transparent; border:none; color:#d1d5db; cursor:pointer; font-size:1rem; padding:.1rem .3rem; border-radius:.3rem; transition:color .15s, background .15s; flex-shrink:0; }
.task-delete:hover { color:#dc2626; background:#fee2e2; }
.task-progress { display:flex; align-items:center; gap:.75rem; margin-top:.5rem; }
.task-progress-bar { flex:1; height:.4rem; background:#e5e7eb; border-radius:2rem; overflow:hidden; }
.task-progress-fill { height:100%; background:linear-gradient(90deg,#6366f1,#818cf8); border-radius:2rem; transition:width .4s; }
.task-progress-label { font-size:.78rem; color:#6b7280; white-space:nowrap; font-weight:500; }

/* ── Activity Timeline ─────────────────────────────────────────── */
.timeline { display:flex; flex-direction:column; gap:0; padding-left:.5rem; border-left:2px solid #e5e7eb; margin:.5rem 0; }
.timeline-item { display:flex; gap:1rem; padding:.75rem 0 .75rem 1.25rem; position:relative; }
.timeline-dot { position:absolute; left:-1.3rem; top:1rem; width:.75rem; height:.75rem; border-radius:50%; border:2px solid #fff; flex-shrink:0; }
.dot-created   { background:#6366f1; }
.dot-updated   { background:#3b82f6; }
.dot-status    { background:#f59e0b; }
.dot-closed    { background:#6b7280; }
.dot-assigned  { background:#10b981; }
.dot-default   { background:#d1d5db; }
.timeline-body { flex:1; }
.timeline-header { display:flex; flex-wrap:wrap; align-items:center; gap:.5rem; margin-bottom:.2rem; }
.timeline-action { font-weight:600; font-size:.83rem; color:#374151; }
.timeline-who    { font-size:.8rem; color:#6b7280; }
.timeline-when   { font-size:.78rem; color:#9ca3af; margin-left:auto; }
.timeline-ai-badge { background:#ede9fe; color:#6d28d9; font-size:.72rem; font-weight:600; border-radius:.3rem; padding:.1rem .45rem; }
.timeline-summary { font-size:.875rem; color:#374151; }

/* ── Permit to Work card ───────────────────────────────────────── */
.permit-card { background:#fff; border:1px solid #e5e7eb; border-radius:.875rem; padding:1.25rem 1.5rem; }
.permit-open   { border-left:4px solid #f59e0b; }
.permit-signed { border-left:4px solid #10b981; }
.permit-header { display:flex; align-items:center; gap:.875rem; margin-bottom:1rem; }
.permit-ref    { font-size:.8rem; font-weight:600; letter-spacing:.06em; color:#6b7280; text-transform:uppercase; }
.permit-badge  { display:inline-flex; align-items:center; gap:.3rem; border-radius:2rem; padding:.25rem .75rem; font-size:.78rem; font-weight:700; }
.permit-badge-open   { background:#fef3c7; color:#92400e; }
.permit-badge-closed { background:#d1fae5; color:#065f46; }

/* ── Tab section heading ───────────────────────────────────────── */
.tab-section { display:flex; flex-direction:column; }
.tab-section-title { font-size:1rem; font-weight:600; color:#1e1b4b; margin:0; }

/* ── Reports attention strip ──────────────────────────────────── */
.report-attention-strip { display:flex; flex-wrap:wrap; align-items:center; gap:.5rem; background:#fff8ed; border:1px solid #fed7aa; border-radius:.75rem; padding:.75rem 1.1rem; margin-bottom:1.25rem; }
.report-attention-title { font-size:.83rem; font-weight:700; color:#c2410c; white-space:nowrap; }
.report-attention-chip { display:inline-block; border-radius:2rem; padding:.2rem .7rem; font-size:.78rem; font-weight:600; text-decoration:none; transition:opacity .15s; }
.report-attention-chip:hover { opacity:.8; }
.report-chip-red   { background:#fee2e2; color:#dc2626; border:1px solid #fca5a5; }
.report-chip-amber { background:#fef3c7; color:#92400e; border:1px solid #fde68a; }

/* ── Tab group (list page view switcher) ──────────────────────── */
.pm-tab-group { display:flex; gap:.25rem; }
.pm-tab { padding:.38rem .85rem; border:1px solid #e5e7eb; border-radius:.5rem; background:#fff; color:#6b7280; font-size:.82rem; font-weight:600; cursor:pointer; transition:background .12s,color .12s,border-color .12s; }
.pm-tab:hover { background:#f3f4f6; color:#374151; }
.pm-tab.pm-tab-active { background:#6366f1; color:#fff; border-color:#6366f1; }

/* ── Search input ─────────────────────────────────────────────── */
.pm-search { padding:.45rem .75rem; border:1.5px solid #e5e7eb; border-radius:.5rem; font-size:.86rem; color:#111827; background:#fff; flex:1; min-width:160px; max-width:340px; transition:border-color .15s; font-family:inherit; box-sizing:border-box; }
.pm-search:focus { outline:none; border-color:#6366f1; box-shadow:0 0 0 3px rgba(99,102,241,.1); }

/* ── Clickable table rows ─────────────────────────────────────── */
.pm-row-link { cursor:pointer; }
.pm-row-link:hover td { background:#f5f5ff !important; }

/* ── Row count footer ─────────────────────────────────────────── */
.pm-row-count { font-size:.8rem; color:#9ca3af; margin:.4rem 0 0; text-align:right; }

/* ── AI dashboard two-column layout ──────────────────────────── */
.ai-dash-two-col { display:grid; gap:1rem; grid-template-columns:1fr 1fr; margin-bottom:1rem; }
@media(max-width:800px) { .ai-dash-two-col { grid-template-columns:1fr; } }
.ai-dash-value-grid { display:grid; gap:.5rem; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); }
.ai-dash-value-grid > div { display:flex; flex-direction:column; gap:.1rem; font-size:.88rem; }
.ai-dash-label { font-size:.76rem; text-transform:uppercase; letter-spacing:.03em; color:#8a9ab8; }
.ai-dash-warn { color:#b33030; font-weight:700; }

/* ── AI test console ──────────────────────────────────────────── */
.ai-result-box { background:#f8fafd; border:1px solid #dfe5f1; border-radius:8px; padding:.8rem 1rem; overflow-x:auto; margin-bottom:.75rem; }
.ai-result-box pre { margin:0; white-space:pre-wrap; font-size:.88rem; color:#1a2d50; font-family:monospace; }
.ai-action-list { list-style:none; margin:.7rem 0 0; padding:0; display:flex; flex-direction:column; gap:.4rem; }
.ai-action-list li { display:flex; align-items:center; gap:.5rem; font-size:.88rem; padding:.35rem 0; border-bottom:1px solid #f0f3f9; }
.ai-action-list li:last-child { border-bottom:none; }
.pm-badge { padding:.18rem .55rem; border-radius:999px; background:#edf4ff; color:#1a4a8a; font-size:.75rem; font-weight:700; }
.ai-result-meta { display:flex; gap:1.5rem; flex-wrap:wrap; margin-top:.7rem; font-size:.82rem; color:#8a9ab8; }
.ai-result-meta strong { color:#1a2d50; }

/* ── Provider status banner (shared across AI pages) ─────────── */
.provider-status { display:flex; align-items:center; gap:.6rem; padding:.6rem .9rem; border-radius:8px; font-size:.88rem; flex-wrap:wrap; }
.status-ok   { background:#f0fff4; border:1px solid #6ee7b7; color:#145c35; }
.status-warn { background:#fffbea; border:1px solid #f5c242; color:#7a5200; }
.status-note { color:#8a9ab8; font-size:.82rem; }
.badge { padding:.18rem .55rem; border-radius:999px; font-size:.75rem; font-weight:700; }
.badge-success { background:#d4f5e2; color:#145c35; }
.badge-warning { background:#fff3cd; color:#7a5200; }

/* ── KPI cards (shared dashboard metric strip) ────────────────── */
.kpi-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:.85rem; margin-bottom:1.35rem; }
.kpi-card { display:flex; flex-direction:column; align-items:flex-start; justify-content:center; gap:.28rem; min-height:6.1rem; background:#fff; border:1px solid #dce4f1; border-left:3px solid #c8d4e8; border-radius:12px; padding:.95rem 1rem; text-decoration:none; text-align:left; transition:box-shadow .15s,border-color .15s,transform .15s; color:inherit; }
.kpi-card:hover { border-color:#b8c7de; box-shadow:0 4px 14px rgba(30,58,120,.10); transform:translateY(-1px); text-decoration:none; }
.kpi-icon { display:none !important; }
.kpi-value { font-size:1.9rem; font-weight:800; line-height:1.05; color:#17243d; }
.kpi-label { order:-1; font-size:.72rem; font-weight:700; color:#697996; line-height:1.25; letter-spacing:.04em; text-transform:uppercase; }
.kpi-blue  { border-left-color:#9fb4d6; }
.kpi-green { border-left-color:#9dbca8; }
.kpi-amber { border-left-color:#d4bd84; }
.kpi-red   { border-left-color:#c98e8e; }
.kpi-purple{ border-left-color:#aaa0c4; }
.kpi-alert, .kpi-card-warn { border-left-color:#c98e8e; }

