  /* ===== RESET ===== */
  *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  html,body{height:100%}
  body{
    font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
    font-size:13px;
    line-height:1.35;
    color:#111827;
    background:#f3f4f6;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
  }
  .mono{font-family:'JetBrains Mono',ui-monospace,monospace;font-variant-numeric:tabular-nums}

  /* ===== TOKENS ===== */
  :root{
    --navy:#0f172a;
    --navy-2:#1e293b;
    --navy-3:#334155;
    --line:#e5e7eb;
    --line-2:#d1d5db;
    --line-d:#1f2937;
    --text:#111827;
    --text-2:#374151;
    --text-3:#6b7280;
    --text-4:#9ca3af;
    --bg:#ffffff;
    --bg-alt:#f9fafb;
    --bg-alt-2:#f3f4f6;
    --bg-alt-3:#eef2ff;
    --red:#dc2626;
    --red-bg:#fee2e2;
    --red-bg-soft:#fef2f2;
    --amber:#d97706;
    --amber-bg:#fef3c7;
    --green:#16a34a;
    --green-bg:#dcfce7;
    --blue:#2563eb;
    --blue-bg:#dbeafe;
    --purple:#7c3aed;
  }

  /* ===== SCREEN SHELL ===== */
  .screen{
    max-width:1366px;
    margin:0 auto 24px;
    background:#fff;
    border:1px solid var(--line-2);
    box-shadow:0 1px 2px rgba(0,0,0,.04);
  }
  .screen-tag{
    background:var(--navy);
    color:#cbd5e1;
    font-family:'JetBrains Mono',monospace;
    font-size:10px;
    letter-spacing:.08em;
    padding:4px 10px;
    text-transform:uppercase;
    display:flex;justify-content:space-between;align-items:center;
  }
  .screen-tag span:last-child{color:#64748b}

  /* =================================================
     SCREEN 1 — LOGIN
     ================================================= */
  .login-page{
    min-height:680px;
    background:var(--navy);
    background-image:
      linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
      linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
    background-size:32px 32px;
    background-position:-1px -1px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    padding:24px;
    color:#e2e8f0;
    position:relative;
  }
  .login-page::before{
    content:'';
    position:absolute;inset:0;
    background:radial-gradient(ellipse at 50% 40%, rgba(37,99,235,.12), transparent 60%);
    pointer-events:none;
  }
  .login-meta-top{
    position:absolute;top:8px;left:12px;right:12px;
    display:flex;justify-content:space-between;
    font-family:'JetBrains Mono',monospace;
    font-size:10px;color:#64748b;letter-spacing:.05em;
  }
  .login-card{
    width:420px;
    background:#0b1220;
    border:1px solid #1e293b;
    box-shadow:0 8px 24px rgba(0,0,0,.4);
    padding:22px 24px 18px;
    position:relative;
    z-index:1;
  }
  .login-brand{
    display:flex;align-items:center;gap:10px;
    padding-bottom:14px;margin-bottom:16px;
    border-bottom:1px solid #1e293b;
  }
  .login-brand .logo{
    width:32px;height:32px;
    background:#2563eb;
    display:flex;align-items:center;justify-content:center;
    font-weight:700;font-size:13px;color:#fff;
    border:1px solid #3b82f6;
  }
  .login-brand .title{font-size:14px;font-weight:600;color:#f1f5f9;letter-spacing:.01em}
  .login-brand .subtitle{font-size:10px;color:#64748b;font-family:'JetBrains Mono',monospace;letter-spacing:.05em;margin-top:1px}
  .login-brand .ver{
    margin-left:auto;
    font-family:'JetBrains Mono',monospace;font-size:10px;
    color:#475569;
    border:1px solid #1e293b;padding:2px 6px;
  }

  .login-label{
    font-family:'JetBrains Mono',monospace;
    font-size:10px;color:#64748b;
    letter-spacing:.08em;text-transform:uppercase;
    margin-bottom:8px;
  }
  .login-btns{
    display:grid;grid-template-columns:1fr 1fr;gap:8px;
    margin-bottom:14px;
  }
  .login-btn{
    background:#0f172a;
    border:1px solid #334155;
    color:#e2e8f0;
    padding:10px 12px;
    font-family:'Inter',sans-serif;
    font-size:12px;font-weight:500;
    cursor:pointer;
    display:flex;align-items:center;gap:8px;
    justify-content:center;
    transition:background .12s, border-color .12s;
  }
  .login-btn:hover{background:#1e293b;border-color:#475569}
  .login-btn.primary{
    background:#06c755;border-color:#06c755;color:#fff;
  }
  .login-btn.primary:hover{background:#05b14b;border-color:#05b14b}
  .login-btn svg{width:14px;height:14px;flex-shrink:0}

  .login-divider{
    display:flex;align-items:center;gap:8px;
    font-family:'JetBrains Mono',monospace;font-size:9px;
    color:#475569;letter-spacing:.15em;
    margin:10px 0;
  }
  .login-divider::before,.login-divider::after{
    content:'';flex:1;height:1px;background:#1e293b;
  }
  .login-checklist{
    font-family:'JetBrains Mono',monospace;
    font-size:10px;color:#64748b;
    line-height:1.7;
    padding-top:8px;border-top:1px solid #1e293b;
    margin-top:8px;
  }
  .login-checklist .ok{color:#22c55e}
  .login-checklist .warn{color:#fbbf24}

  .login-status{
    margin-top:16px;
    font-family:'JetBrains Mono',monospace;
    font-size:10px;color:#475569;
    letter-spacing:.04em;
    display:flex;gap:14px;
  }
  .login-status .dot{width:6px;height:6px;background:#22c55e;display:inline-block;margin-right:5px;animation:pulse 1.8s infinite}
  @keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

  /* =================================================
     SCREEN 2 — MAIN / SEARCH
     ================================================= */
  .topbar{
    background:var(--navy);
    color:#e2e8f0;
    display:flex;align-items:center;
    padding:0 12px;
    height:44px;
    gap:12px;
    border-bottom:1px solid #1e293b;
  }
  .topbar .brand{
    display:flex;align-items:center;gap:8px;
    padding-right:12px;border-right:1px solid #1e293b;
    height:100%;
  }
  .topbar .brand .logo{
    width:24px;height:24px;background:#2563eb;
    display:flex;align-items:center;justify-content:center;
    font-weight:700;font-size:11px;color:#fff;
  }
  .topbar .brand .name{font-size:12px;font-weight:600;color:#f1f5f9}
  .topbar .brand .ver{
    font-family:'JetBrains Mono',monospace;font-size:10px;color:#64748b;
    margin-left:4px;
  }

  .search-wrap{flex:1;position:relative}
  .search-input{
    width:100%;
    background:#1e293b;
    border:1px solid #334155;
    color:#f1f5f9;
    padding:6px 10px 6px 30px;
    font-family:'Inter',sans-serif;font-size:13px;
    height:30px;
    outline:none;
  }
  .search-input:focus{border-color:#3b82f6;background:#0b1220}
  .search-input::placeholder{color:#64748b}
  .search-icon{
    position:absolute;left:8px;top:50%;transform:translateY(-50%);
    width:14px;height:14px;color:#64748b;pointer-events:none;
  }
  .search-kbd{
    position:absolute;right:6px;top:50%;transform:translateY(-50%);
    font-family:'JetBrains Mono',monospace;font-size:10px;
    color:#64748b;
    border:1px solid #334155;padding:1px 5px;
    background:#0f172a;
  }

  .search-dropdown{
    position:absolute;left:0;right:0;top:34px;
    background:#fff;
    border:1px solid var(--line-2);
    box-shadow:0 8px 16px rgba(0,0,0,.12);
    z-index:10;
    max-height:320px;overflow:auto;
  }
  .sdd-head{
    display:grid;
    grid-template-columns:80px 1fr 50px 70px 60px 100px;
    gap:0;
    background:#f3f4f6;
    border-bottom:1px solid var(--line);
    font-family:'JetBrains Mono',monospace;
    font-size:10px;color:#6b7280;
    padding:5px 10px;letter-spacing:.05em;
    text-transform:uppercase;
  }
  .sdd-row{
    display:grid;
    grid-template-columns:80px 1fr 50px 70px 60px 100px;
    gap:0;
    padding:5px 10px;
    border-bottom:1px solid var(--bg-alt-2);
    font-size:12px;
    cursor:pointer;
    align-items:center;
  }
  .sdd-row:hover{background:var(--bg-alt-3)}
  .sdd-row.active{background:#dbeafe;border-left:2px solid #2563eb;padding-left:8px}
  .sdd-row .hn{font-family:'JetBrains Mono',monospace;font-weight:600;color:#1f2937}
  .sdd-row .age{font-family:'JetBrains Mono',monospace;color:#374151}
  .sdd-row .sex{font-family:'JetBrains Mono',monospace;color:#6b7280}
  .sdd-row .last{font-family:'JetBrains Mono',monospace;color:#6b7280;font-size:11px}
  .sdd-row .dx{color:#374151;font-size:11px}
  .sdd-row .dx code{font-family:'JetBrains Mono',monospace;color:#dc2626;background:#fef2f2;padding:0 4px;border:1px solid #fecaca;font-size:10px;margin-right:3px}

  .topbar .user-menu{
    display:flex;align-items:center;gap:8px;
    padding-left:12px;border-left:1px solid #1e293b;
    height:100%;
  }
  .topbar .user-menu .avatar{
    width:24px;height:24px;background:#475569;
    display:flex;align-items:center;justify-content:center;
    color:#fff;font-size:11px;font-weight:600;
  }
  .topbar .user-menu .name-block{display:flex;flex-direction:column;line-height:1.15}
  .topbar .user-menu .nm{font-size:11px;color:#f1f5f9;font-weight:500}
  .topbar .user-menu .role{font-family:'JetBrains Mono',monospace;font-size:9px;color:#64748b;letter-spacing:.05em}

  /* keyboard hints bar */
  .kbd-bar{
    background:#0b1220;
    color:#94a3b8;
    border-bottom:1px solid #1f2937;
    padding:4px 12px;
    font-family:'JetBrains Mono',monospace;font-size:10px;
    display:flex;gap:14px;
    letter-spacing:.04em;
  }
  .kbd-bar kbd{
    background:#1e293b;border:1px solid #334155;
    padding:1px 5px;color:#cbd5e1;
    font-family:'JetBrains Mono',monospace;font-size:10px;
    margin-right:4px;
  }

  /* main body — recent patients */
  .main-body{
    padding:12px;
    background:#fff;
    min-height:520px;
  }
  .section-head{
    display:flex;align-items:center;gap:10px;
    margin-bottom:8px;
  }
  .section-head h3{
    font-size:11px;font-weight:600;
    color:#374151;letter-spacing:.08em;text-transform:uppercase;
    font-family:'JetBrains Mono',monospace;
  }
  .section-head .count{
    font-family:'JetBrains Mono',monospace;font-size:10px;
    color:#6b7280;
    background:#f3f4f6;border:1px solid var(--line);
    padding:1px 6px;
  }
  .section-head .actions{margin-left:auto;display:flex;gap:6px}
  .mini-btn{
    background:#fff;border:1px solid var(--line-2);
    padding:3px 8px;font-size:11px;color:#374151;
    cursor:pointer;font-family:'Inter',sans-serif;
    display:inline-flex;align-items:center;gap:4px;
  }
  .mini-btn:hover{background:#f9fafb;border-color:#9ca3af}
  .mini-btn svg{width:11px;height:11px}

  /* main-grid: 2 sections (recent + pinned/quick) */
  .main-grid{
    display:grid;
    grid-template-columns:2fr 1fr;
    gap:12px;
  }

  .data-table{
    width:100%;
    border-collapse:collapse;
    font-size:12px;
  }
  .data-table thead th{
    background:#f3f4f6;
    color:#374151;
    font-family:'JetBrains Mono',monospace;
    font-size:10px;font-weight:600;
    letter-spacing:.05em;text-transform:uppercase;
    padding:6px 8px;text-align:left;
    border-bottom:1px solid var(--line-2);
    border-right:1px solid var(--line);
  }
  .data-table thead th:last-child{border-right:none}
  .data-table tbody td{
    padding:5px 8px;
    border-bottom:1px solid var(--bg-alt-2);
    border-right:1px solid var(--bg-alt-2);
    vertical-align:middle;
  }
  .data-table tbody td:last-child{border-right:none}
  .data-table tbody tr{cursor:pointer}
  .data-table tbody tr:hover{background:var(--bg-alt-3)}
  .data-table tbody tr.active{background:#dbeafe;box-shadow:inset 2px 0 0 #2563eb}
  .data-table .hn{font-family:'JetBrains Mono',monospace;font-weight:600;color:#0f172a}
  .data-table .num{font-family:'JetBrains Mono',monospace;color:#374151}
  .data-table .muted{color:#6b7280;font-size:11px}
  .data-table .icd{font-family:'JetBrains Mono',monospace;color:#dc2626;background:#fef2f2;padding:0 4px;border:1px solid #fecaca;font-size:10px;margin-right:3px}
  .data-table .pill-ok{font-family:'JetBrains Mono',monospace;color:#16a34a;background:#dcfce7;padding:0 4px;border:1px solid #bbf7d0;font-size:10px}

  /* quick panel right side of main */
  .qpanel{
    border:1px solid var(--line);
    background:#fafbfc;
  }
  .qpanel-head{
    display:flex;align-items:center;justify-content:space-between;
    padding:6px 10px;border-bottom:1px solid var(--line);
    background:#f3f4f6;
  }
  .qpanel-head h4{
    font-size:10px;font-weight:600;
    letter-spacing:.08em;color:#374151;text-transform:uppercase;
    font-family:'JetBrains Mono',monospace;
  }
  .qpanel-body{padding:8px 10px}
  .qstat-row{
    display:flex;align-items:baseline;justify-content:space-between;
    padding:4px 0;border-bottom:1px dashed var(--line);
    font-size:12px;
  }
  .qstat-row:last-child{border-bottom:none}
  .qstat-row .label{color:#6b7280;font-size:11px}
  .qstat-row .value{font-family:'JetBrains Mono',monospace;font-weight:600;color:#111827}
  .qstat-row .value.warn{color:#dc2626}
  .qstat-row .value.ok{color:#16a34a}

  .pin-list{font-size:12px}
  .pin-row{
    display:flex;align-items:center;justify-content:space-between;
    padding:5px 0;border-bottom:1px dashed var(--line);
    cursor:pointer;
  }
  .pin-row:hover{background:#eef2ff}
  .pin-row:last-child{border-bottom:none}
  .pin-row .hn{font-family:'JetBrains Mono',monospace;font-weight:600;color:#0f172a;font-size:11px}
  .pin-row .name{font-size:11px;color:#374151;flex:1;margin-left:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .pin-row .star{color:#d97706;font-size:11px}

  /* =================================================
     SCREEN 3 — PATIENT DETAIL POWER USER
     ================================================= */
  /* patient header — 1 line dense */
  .pt-header{
    background:#0f172a;
    color:#e2e8f0;
    padding:6px 12px;
    display:flex;align-items:center;
    gap:14px;flex-wrap:nowrap;
    font-size:12px;
    border-bottom:2px solid #1e40af;
    overflow:hidden;
  }
  .pt-header > div{display:flex;align-items:center;gap:6px;white-space:nowrap}
  .pt-header .pt-label{font-family:'JetBrains Mono',monospace;font-size:9px;color:#64748b;text-transform:uppercase;letter-spacing:.06em}
  .pt-header .pt-val{font-weight:500;color:#f1f5f9}
  .pt-header .pt-val.hn{font-family:'JetBrains Mono',monospace;font-weight:700;color:#fff;background:#1e40af;padding:1px 6px}
  .pt-header .pt-val.name{font-weight:600;font-size:13px}
  .pt-header .alert-pill{
    background:#dc2626;color:#fff;
    padding:1px 6px;font-family:'JetBrains Mono',monospace;
    font-size:10px;letter-spacing:.05em;font-weight:600;
  }
  .pt-header .ok-pill{
    background:#15803d;color:#fff;
    padding:1px 6px;font-family:'JetBrains Mono',monospace;
    font-size:10px;letter-spacing:.05em;font-weight:600;
  }
  .pt-header .dx-pill{
    background:#1e293b;color:#fbbf24;
    padding:1px 6px;font-family:'JetBrains Mono',monospace;
    font-size:10px;letter-spacing:.05em;
    border:1px solid #334155;
  }
  .pt-header .dx-pill code{color:#f1f5f9;margin-right:4px;font-size:9px}
  .pt-header .sep{color:#475569;margin:0 -4px}

  .pt-tabs{
    background:#1e293b;
    color:#cbd5e1;
    display:flex;
    padding:0 6px;
    border-bottom:1px solid #0f172a;
  }
  .pt-tabs .tab{
    padding:6px 12px;
    font-size:11px;font-weight:500;
    color:#94a3b8;cursor:pointer;
    border-right:1px solid #334155;
    font-family:'Inter',sans-serif;
    display:flex;align-items:center;gap:6px;
  }
  .pt-tabs .tab.active{
    background:#fff;color:#0f172a;
    border-right-color:transparent;
    font-weight:600;
  }
  .pt-tabs .tab .badge{
    font-family:'JetBrains Mono',monospace;font-size:9px;
    background:#dc2626;color:#fff;padding:0 4px;
    border-radius:8px;
  }
  .pt-tabs .tab.active .badge{background:#dc2626}
  .pt-tabs .tab:hover:not(.active){background:#334155;color:#f1f5f9}

  /* 3-panel layout */
  .pt-grid{
    display:grid;
    grid-template-columns:300px 1fr 240px;
    background:#fff;
    min-height:560px;
  }
  .pt-col{
    border-right:1px solid var(--line);
    display:flex;flex-direction:column;
  }
  .pt-col:last-child{border-right:none}

  .pt-section{
    border-bottom:1px solid var(--line);
  }
  .pt-section-head{
    display:flex;align-items:center;justify-content:space-between;
    padding:5px 10px;
    background:#f3f4f6;
    border-bottom:1px solid var(--line);
  }
  .pt-section-head h4{
    font-family:'JetBrains Mono',monospace;
    font-size:10px;font-weight:600;
    color:#374151;letter-spacing:.06em;
    text-transform:uppercase;
  }
  .pt-section-head .meta{
    font-family:'JetBrains Mono',monospace;font-size:9px;
    color:#6b7280;letter-spacing:.04em;
  }
  .pt-section-head .ic{
    display:inline-flex;gap:3px;
  }
  .pt-section-head .ic svg{width:11px;height:11px;color:#6b7280;cursor:pointer}
  .pt-section-head .ic svg:hover{color:#0f172a}

  /* --- LEFT col: drugs + visits --- */
  .drug-list,.visit-list{font-size:11px}
  .drug-row{
    display:grid;
    grid-template-columns:1fr 60px 50px;
    gap:6px;
    padding:5px 10px;
    border-bottom:1px solid #f3f4f6;
    align-items:start;
  }
  .drug-row:hover{background:#fafbfc}
  .drug-row .name-cell{font-weight:500;color:#111827;line-height:1.3}
  .drug-row .name-cell .gen{display:block;font-family:'JetBrains Mono',monospace;font-size:10px;color:#6b7280;font-weight:400}
  .drug-row .dose{font-family:'JetBrains Mono',monospace;color:#374151;font-size:11px}
  .drug-row .freq{font-family:'JetBrains Mono',monospace;color:#374151;font-size:11px;text-align:right}
  .drug-row .start{
    grid-column:1/-1;
    font-family:'JetBrains Mono',monospace;font-size:9px;color:#9ca3af;
    margin-top:1px;
    display:flex;justify-content:space-between;
  }
  .drug-row .start .new-flag{color:#16a34a;font-weight:600}

  .visit-row{
    display:grid;
    grid-template-columns:60px 1fr 30px;
    gap:6px;
    padding:5px 10px;
    border-bottom:1px solid #f3f4f6;
    align-items:center;
    cursor:pointer;
    font-size:11px;
  }
  .visit-row:hover{background:#fafbfc}
  .visit-row .date{font-family:'JetBrains Mono',monospace;color:#374151;font-weight:500;font-size:10px}
  .visit-row .info{color:#374151;line-height:1.3}
  .visit-row .info .dx-line{font-family:'JetBrains Mono',monospace;font-size:10px;color:#dc2626}
  .visit-row .info .dr-line{font-size:10px;color:#6b7280;margin-top:1px}
  .visit-row .type{
    font-family:'JetBrains Mono',monospace;font-size:9px;
    text-align:center;padding:1px 0;
  }
  .visit-row .type.opd{background:#dbeafe;color:#1d4ed8;border:1px solid #93c5fd}
  .visit-row .type.ipd{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}
  .visit-row .type.er{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}

  /* allergy + risk small */
  .alr-block{padding:6px 10px;font-size:11px}
  .alr-empty{color:#16a34a;font-family:'JetBrains Mono',monospace;font-size:10px}
  .risk-grid{
    display:grid;grid-template-columns:1fr 1fr;gap:4px;
    padding:6px 10px;
  }
  .risk-cell{
    border:1px solid var(--line);
    padding:4px 6px;
    background:#fff;
  }
  .risk-cell .lbl{font-family:'JetBrains Mono',monospace;font-size:9px;color:#6b7280;letter-spacing:.05em;text-transform:uppercase}
  .risk-cell .val{font-family:'JetBrains Mono',monospace;font-size:14px;font-weight:600;color:#dc2626}
  .risk-cell .val.ok{color:#16a34a}
  .risk-cell .val.warn{color:#d97706}
  .risk-cell .sub{font-family:'JetBrains Mono',monospace;font-size:9px;color:#9ca3af}

  /* --- CENTER col: lab pivot --- */
  .lab-toolbar{
    display:flex;align-items:center;gap:6px;
    padding:5px 10px;
    background:#f3f4f6;
    border-bottom:1px solid var(--line);
    font-size:11px;
  }
  .lab-toolbar .seg{
    display:inline-flex;border:1px solid var(--line-2);background:#fff;
  }
  .lab-toolbar .seg button{
    background:transparent;border:none;
    padding:3px 8px;font-size:11px;cursor:pointer;
    color:#6b7280;
    border-right:1px solid var(--line);
    font-family:'Inter',sans-serif;
  }
  .lab-toolbar .seg button:last-child{border-right:none}
  .lab-toolbar .seg button.on{background:#0f172a;color:#fff}
  .lab-toolbar .legend{margin-left:auto;display:flex;gap:10px;font-family:'JetBrains Mono',monospace;font-size:10px;color:#6b7280}
  .lab-toolbar .legend .swatch{display:inline-block;width:10px;height:10px;margin-right:3px;vertical-align:-1px;border:1px solid var(--line-2)}

  .lab-wrap{
    overflow:auto;
    max-height:540px;
  }
  table.lab-pivot{
    border-collapse:separate;
    border-spacing:0;
    font-size:11px;
    width:100%;
    font-family:'JetBrains Mono',monospace;
  }
  table.lab-pivot thead th{
    background:#1f2937;
    color:#f1f5f9;
    font-family:'JetBrains Mono',monospace;
    font-size:10px;font-weight:600;
    padding:4px 6px;
    text-align:center;
    border-right:1px solid #374151;
    border-bottom:1px solid #111827;
    white-space:nowrap;
    position:sticky;top:0;z-index:3;
  }
  table.lab-pivot thead th.lab-name-col{
    text-align:left;
    background:#111827;
    position:sticky;left:0;z-index:5;min-width:170px;
  }
  table.lab-pivot thead th.ref-col{
    background:#1f2937;
    position:sticky;left:170px;z-index:5;min-width:80px;
    font-weight:400;color:#cbd5e1;
  }
  table.lab-pivot thead th.unit-col{
    background:#1f2937;color:#cbd5e1;font-weight:400;
    position:sticky;left:250px;z-index:5;min-width:50px;
  }
  table.lab-pivot tbody td{
    padding:3px 6px;
    border-right:1px solid #f3f4f6;
    border-bottom:1px solid #f3f4f6;
    text-align:center;
    white-space:nowrap;
    color:#111827;
    font-size:11px;
    background:#fff;
    min-width:48px;
  }
  table.lab-pivot tbody td.lab-name-col{
    text-align:left;
    background:#fff;
    position:sticky;left:0;z-index:2;
    font-weight:500;
    border-right:1px solid var(--line);
    color:#0f172a;
    min-width:170px;
  }
  table.lab-pivot tbody td.lab-name-col .lab-code{
    font-size:9px;color:#9ca3af;font-weight:400;margin-left:4px;
  }
  table.lab-pivot tbody td.ref-col{
    background:#fafbfc;
    color:#6b7280;font-size:10px;
    position:sticky;left:170px;z-index:2;
    border-right:1px solid var(--line);
    min-width:80px;
  }
  table.lab-pivot tbody td.unit-col{
    background:#fafbfc;color:#6b7280;font-size:10px;
    position:sticky;left:250px;z-index:2;
    border-right:1px solid var(--line);
    min-width:50px;
  }
  table.lab-pivot tbody tr:hover td:not(.lab-name-col):not(.ref-col):not(.unit-col){background:#eef2ff}
  table.lab-pivot tbody tr:hover td.lab-name-col,
  table.lab-pivot tbody tr:hover td.ref-col,
  table.lab-pivot tbody tr:hover td.unit-col{background:#eef2ff}
  table.lab-pivot tbody td.hi{background:#fee2e2;color:#991b1b;font-weight:700}
  table.lab-pivot tbody td.lo{background:#dbeafe;color:#1e40af;font-weight:700}
  table.lab-pivot tbody td.crit{background:#dc2626;color:#fff;font-weight:700}
  table.lab-pivot tbody td.trend-bad{font-style:italic;text-decoration:underline;text-decoration-style:dotted}
  table.lab-pivot tbody td.empty{color:#d1d5db}
  table.lab-pivot tbody td .arrow{font-size:9px;margin-left:2px}
  table.lab-pivot tbody td.hi .arrow{color:#dc2626}
  table.lab-pivot tbody td.lo .arrow{color:#1e40af}

  /* group header rows */
  table.lab-pivot tbody tr.group-row td{
    background:#e5e7eb !important;
    color:#374151;font-weight:600;
    text-transform:uppercase;letter-spacing:.06em;
    font-size:9px;font-family:'JetBrains Mono',monospace;
    padding:3px 8px;
    border-top:1px solid #9ca3af;
  }
  table.lab-pivot tbody tr.group-row td.lab-name-col{
    position:sticky;left:0;z-index:2;
  }
  table.lab-pivot tbody tr.group-row td.ref-col{
    position:sticky;left:170px;z-index:2;background:#e5e7eb !important;
  }
  table.lab-pivot tbody tr.group-row td.unit-col{
    position:sticky;left:250px;z-index:2;background:#e5e7eb !important;
  }

  /* --- RIGHT col: vitals + appt + orders --- */
  .vital-mini{
    padding:6px 10px;
    border-bottom:1px solid #f3f4f6;
  }
  .vital-mini-head{
    display:flex;align-items:baseline;justify-content:space-between;
    margin-bottom:3px;
  }
  .vital-mini-head .lbl{font-family:'JetBrains Mono',monospace;font-size:10px;color:#6b7280;letter-spacing:.04em;text-transform:uppercase}
  .vital-mini-head .val{font-family:'JetBrains Mono',monospace;font-size:14px;font-weight:600;color:#111827}
  .vital-mini-head .val.warn{color:#dc2626}
  .vital-mini-head .val.ok{color:#16a34a}
  .vital-mini-head .val .unit{font-size:9px;color:#9ca3af;margin-left:2px;font-weight:400}
  .vital-mini-head .delta{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:500}
  .vital-mini-head .delta.up{color:#dc2626}
  .vital-mini-head .delta.down{color:#16a34a}
  .vital-mini .spark{
    width:100%;height:30px;
    display:block;
  }
  .vital-mini .meta{
    font-family:'JetBrains Mono',monospace;font-size:9px;color:#9ca3af;
    margin-top:1px;display:flex;justify-content:space-between;
  }

  .appt-box{
    padding:8px 10px;
    background:#eff6ff;
    border-bottom:1px solid var(--line);
    border-left:3px solid #2563eb;
  }
  .appt-box .date{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:600;color:#1e40af}
  .appt-box .when{font-family:'JetBrains Mono',monospace;font-size:10px;color:#3b82f6}
  .appt-box .what{font-size:11px;color:#1e293b;margin-top:3px}
  .appt-box .where{font-family:'JetBrains Mono',monospace;font-size:10px;color:#64748b;margin-top:2px}

  .order-row{
    padding:5px 10px;
    border-bottom:1px solid #f3f4f6;
    font-size:11px;
    display:flex;align-items:center;justify-content:space-between;
    gap:8px;
  }
  .order-row .label{color:#374151;flex:1;line-height:1.3}
  .order-row .label .source{display:block;font-family:'JetBrains Mono',monospace;font-size:9px;color:#9ca3af;margin-top:1px}
  .order-row .status{
    font-family:'JetBrains Mono',monospace;font-size:9px;
    padding:1px 5px;letter-spacing:.04em;text-transform:uppercase;
    flex-shrink:0;
  }
  .order-row .status.pending{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}
  .order-row .status.ordered{background:#dbeafe;color:#1d4ed8;border:1px solid #93c5fd}
  .order-row .status.collected{background:#e0e7ff;color:#4338ca;border:1px solid #a5b4fc}

  /* bottom status bar */
  .status-bar{
    background:#0f172a;
    color:#94a3b8;
    padding:4px 12px;
    display:flex;align-items:center;
    gap:14px;
    font-family:'JetBrains Mono',monospace;font-size:10px;
    letter-spacing:.04em;
    border-top:1px solid #1e40af;
  }
  .status-bar .dot{width:6px;height:6px;background:#22c55e;display:inline-block;margin-right:4px}
  .status-bar .dot.warn{background:#fbbf24}
  .status-bar .sep{color:#475569}
  .status-bar .right{margin-left:auto;color:#64748b}
  .status-bar .key{color:#cbd5e1}

  /* responsive */
  @media (max-width:1100px){
    .pt-grid{grid-template-columns:260px 1fr 220px}
  }
  @media (max-width:900px){
    .pt-grid{grid-template-columns:1fr}
    .pt-col{border-right:none;border-bottom:1px solid var(--line)}
    .main-grid{grid-template-columns:1fr}
    .login-card{width:100%;max-width:420px}
    .pt-header{flex-wrap:wrap}
  }

  /* ====== misc compact look ====== */
  .badge-red{background:#dc2626;color:#fff;font-family:'JetBrains Mono',monospace;font-size:9px;padding:1px 5px;letter-spacing:.04em}
  .badge-amber{background:#d97706;color:#fff;font-family:'JetBrains Mono',monospace;font-size:9px;padding:1px 5px;letter-spacing:.04em}
  .badge-blue{background:#2563eb;color:#fff;font-family:'JetBrains Mono',monospace;font-size:9px;padding:1px 5px;letter-spacing:.04em}

  /* page bg */
  .page-wrap{
    padding:16px 12px;
    background:linear-gradient(180deg,#e5e7eb 0%,#f3f4f6 100%);
    min-height:100vh;
  }
