:root{
  --bg:#0f172a; --panel:#ffffff; --ink:#0f172a; --muted:#64748b; --line:#e2e8f0;
  --accent:#2563eb; --accent2:#1d4ed8; --ok:#059669; --warn:#b45309; --chip:#eff6ff;
}
*{box-sizing:border-box}
body{margin:0;font:15px/1.45 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:#f1f5f9}
header{position:sticky;top:0;z-index:20;background:linear-gradient(180deg,#0f172a,#1e293b);
  color:#fff;padding:14px 22px 16px;box-shadow:0 2px 10px rgba(0,0,0,.15)}
header h1{margin:0 0 10px;font-size:18px;font-weight:700;letter-spacing:.2px}
header h1 span{color:#93c5fd;font-weight:500}
header h1 small{color:#64748b;font-weight:400;font-size:12px;margin-left:4px}
.userarea{position:absolute;top:14px;right:22px;display:flex;align-items:center;gap:10px;color:#cbd5e1;font-size:13px}
.userarea .who{opacity:.85}
.userarea .out{background:transparent;border:1px solid #475569;color:#e2e8f0;padding:4px 10px;
  border-radius:6px;font-size:12px;cursor:pointer}
.userarea .out:hover{background:#1e293b;border-color:#64748b;color:#fff}

/* ---- Login page -------------------------------------------------------- */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;margin:0;
  background:linear-gradient(180deg,#0f172a,#1e293b)}
.login-card{background:#fff;border-radius:14px;padding:30px 30px 24px;min-width:340px;max-width:380px;
  box-shadow:0 20px 50px rgba(0,0,0,.25);display:flex;flex-direction:column;gap:14px}
.login-card h1{margin:0;font-size:18px}
.login-card h1 small{font-weight:400;color:#64748b;font-size:13px;display:block;margin-top:4px}
.login-sub{margin:0;color:var(--muted);font-size:13px}
.login-card label{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--muted);
  text-transform:uppercase;letter-spacing:.4px;font-weight:600}
.login-card input{padding:10px 12px;font-size:15px;border:1px solid var(--line);border-radius:8px;
  color:var(--ink);font-weight:500;text-transform:none;letter-spacing:0}
.login-card input:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}
.login-card button{margin-top:4px;background:var(--accent);color:#fff;border:0;padding:11px;
  border-radius:8px;font-size:15px;font-weight:600;cursor:pointer}
.login-card button:hover{background:var(--accent2)}
.login-error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca;border-radius:7px;padding:8px 10px;font-size:13px}
.login-note{margin:6px 0 0;color:var(--muted);font-size:11px;line-height:1.35}
.searchwrap{position:relative;max-width:780px}
#search{width:100%;padding:13px 16px;font-size:17px;border:0;border-radius:10px;outline:none;
  box-shadow:0 2px 8px rgba(0,0,0,.2)}
.results{position:absolute;left:0;right:0;top:54px;background:#fff;border-radius:10px;overflow:hidden;
  color:var(--ink);box-shadow:0 12px 30px rgba(0,0,0,.25);max-height:62vh;overflow-y:auto}
.result{display:grid;grid-template-columns:minmax(160px,1.3fr) 122px 34px 66px minmax(150px,1.5fr);
  gap:14px;align-items:center;padding:9px 16px;cursor:pointer;border-bottom:1px solid var(--line)}
.result:last-child{border-bottom:0}
.result:hover,.result.active{background:var(--chip)}
.result .nm{font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.result .dob{color:var(--muted);font-size:13px;white-space:nowrap;font-variant-numeric:tabular-nums}
.result .status{font-size:11px}
.result .addr{color:var(--muted);font-size:13px;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sex{display:inline-block;font-size:11px;font-weight:700;padding:1px 6px;border-radius:8px;justify-self:center}
.sex.M{background:#dbeafe;color:#1e40af}.sex.F{background:#fce7f3;color:#9d174d}.sex.U{background:#e5e7eb;color:#374151}
.inactive-badge{font-size:11px;color:var(--warn);border:1px solid #fcd34d;background:#fffbeb;border-radius:8px;padding:0 6px}

main{max-width:1100px;margin:22px auto;padding:0 18px 60px}
.empty{color:var(--muted);text-align:center;padding:60px 0;font-size:16px}

.phead{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 20px;margin-bottom:18px;
  box-shadow:0 1px 3px rgba(0,0,0,.05)}
.phead .top{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.phead h2{margin:0;font-size:22px}
.phead .pid{color:var(--muted);font-size:13px}
.demo{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px 28px;margin-top:14px}
.demo .col{display:flex;flex-direction:column;gap:10px;min-width:0}
.demo .f{font-size:14px;min-width:0}
.demo .k{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.4px}
.demo .v{font-weight:500;overflow-wrap:anywhere}
@media (max-width:760px){.demo{grid-template-columns:repeat(2,minmax(0,1fr))}}

.card{background:#fff;border:1px solid var(--line);border-radius:14px;margin-bottom:14px;overflow:hidden;
  box-shadow:0 1px 3px rgba(0,0,0,.05)}
.card>h3{margin:0;padding:12px 18px;font-size:15px;cursor:pointer;display:flex;align-items:center;gap:10px;
  background:#f8fafc;border-bottom:1px solid var(--line)}
.card>h3 .count{background:var(--accent);color:#fff;border-radius:20px;font-size:12px;padding:1px 9px;font-weight:600}
.card>h3 .count.zero{background:#cbd5e1}
.card>h3 .chev{margin-left:auto;color:var(--muted);transition:transform .15s}
.card.collapsed .chev{transform:rotate(-90deg)}
.card.collapsed .body{display:none}
.card.attach>h3{background:#ecfdf5;border-bottom-color:#a7f3d0}
.card.attach>h3 .count{background:var(--ok)}
.card>h3 .dlall + .chev{margin-left:8px}
.dlall{margin-left:auto;background:var(--ok);color:#fff;text-decoration:none;font-size:12px;font-weight:600;
  padding:5px 12px;border-radius:7px;white-space:nowrap}
.dlall:hover{background:#047857}
.card.sec-letters .dlall{background:#7c3aed}
.card.sec-letters .dlall:hover{background:#6d28d9}
/* pastel-coded section headers */
.card.sec-appointments>h3{background:#eff6ff;border-bottom-color:#bfdbfe}
.card.sec-appointments>h3 .count{background:#3b82f6}
.card.sec-invoices>h3{background:#fffbeb;border-bottom-color:#fde68a}
.card.sec-invoices>h3 .count{background:#d97706}
.card.sec-payments>h3{background:#f0fdfa;border-bottom-color:#99f6e4}
.card.sec-payments>h3 .count{background:#0d9488}
.card.sec-letters>h3{background:#f5f3ff;border-bottom-color:#ddd6fe}
.card.sec-letters>h3 .count{background:#7c3aed}
.card.sec-results>h3{background:#ecfeff;border-bottom-color:#a5f3fc}
.card.sec-results>h3 .count{background:#0891b2}
.card.sec-encounters>h3{background:#fff1f2;border-bottom-color:#fecdd3}
.card.sec-encounters>h3 .count{background:#e11d48}
.card.sec-notes>h3{background:#fff7ed;border-bottom-color:#fed7aa}
.card.sec-notes>h3 .count{background:#ea580c}
.card.sec-prescriptions>h3{background:#f7fee7;border-bottom-color:#d9f99d}
.card.sec-prescriptions>h3 .count{background:#65a30d}
.card.sec-allergies>h3{background:#fef2f2;border-bottom-color:#fecaca}
.card.sec-allergies>h3 .count{background:#dc2626}
.card.sec-path_requests>h3{background:#eef2ff;border-bottom-color:#c7d2fe}
.card.sec-path_requests>h3 .count{background:#4f46e5}
.card.sec-radiology>h3{background:#fdf4ff;border-bottom-color:#f5d0fe}
.card.sec-radiology>h3 .count{background:#c026d3}
.card.sec-operations>h3{background:#f1f5f9;border-bottom-color:#cbd5e1}
.card.sec-operations>h3 .count{background:#475569}
.card.sec-reminders>h3{background:#fefce8;border-bottom-color:#fef08a}
.card.sec-reminders>h3 .count{background:#ca8a04}
.card.sec-account>h3{background:#fafaf9;border-bottom-color:#e7e5e4}
.card.sec-account>h3 .count{background:#78716c}
.body{padding:4px 0}
.tablewrap{overflow-x:auto}
table{border-collapse:collapse;width:100%;font-size:13px}
th,td{text-align:left;padding:7px 14px;border-bottom:1px solid #f1f5f9;vertical-align:top}
th{color:var(--muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}
td{max-width:520px}
tr:hover td{background:#f8fafc}
.note{color:var(--muted);font-size:12px;padding:6px 14px}
.actcol{text-align:right;white-space:nowrap;width:1%}
.openbtn{display:inline-flex;align-items:center;gap:5px;background:var(--accent);color:#fff;text-decoration:none;
  padding:5px 11px;border-radius:7px;font-size:12px;font-weight:600;white-space:nowrap}
.openbtn:hover{background:var(--accent2)}
.ftype{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;background:#e2e8f0;color:#475569;
  padding:1px 6px;border-radius:6px}
.money{font-variant-numeric:tabular-nums;text-align:right}
.loading{color:var(--muted);text-align:center;padding:40px}
