:root{
  --bg:#f4f6f9; --card:#fff; --ink:#1c2733; --muted:#6b7a8d;
  --line:#e3e8ef; --brand:#0d6e6e; --brand-d:#0a5757; --accent:#1565c0;
  --warn:#b54708; --warn-bg:#fff4e5; --danger:#c0392b; --ok:#1a7f5a;
  --radius:10px; --shadow:0 1px 3px rgba(16,24,40,.08),0 1px 2px rgba(16,24,40,.04);
}
*{box-sizing:border-box}
body{margin:0;font:15px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--ink)}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
h1{font-size:1.5rem;margin:0}
h2{font-size:1.1rem;margin:0 0 .6rem}
.muted{color:var(--muted)}
.small{font-size:.85rem}
.center{text-align:center}
.nowrap{white-space:nowrap}
.hidden{display:none}
.push-top{margin-top:1rem}
.push-right{margin-left:auto}
.inline{display:inline}

/* Top bar */
.topbar{display:flex;align-items:center;gap:1.5rem;background:var(--card);
  padding:.6rem 1.25rem;border-bottom:1px solid var(--line);box-shadow:var(--shadow);
  position:sticky;top:0;z-index:10;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:.6rem}
.brand small{display:block;color:var(--muted);font-size:.75rem}
.logo{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:8px;
  background:var(--brand);color:#fff;font-weight:700}
.logo-lg{width:52px;height:52px;font-size:1.6rem;margin:0 auto .5rem}
.topbar nav{display:flex;gap:.25rem;flex-wrap:wrap}
.topbar nav a{color:var(--ink);padding:.4rem .7rem;border-radius:7px;font-weight:500}
.topbar nav a:hover{background:#eef2f7;text-decoration:none}
.user-menu{margin-left:auto;display:flex;align-items:center;gap:.75rem}
.who{color:var(--ink);font-weight:500}

/* Layout */
.container{max-width:1080px;margin:1.5rem auto;padding:0 1.25rem}
.page-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}
.actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:1.1rem 1.25rem;margin-bottom:1.25rem}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.75rem;flex-wrap:wrap}
.form-card{max-width:760px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.35rem;border:1px solid transparent;
  border-radius:8px;padding:.5rem .9rem;font-size:.9rem;font-weight:600;cursor:pointer;
  background:#eef2f7;color:var(--ink);line-height:1}
.btn:hover{text-decoration:none;filter:brightness(.97)}
.btn-sm{padding:.35rem .6rem;font-size:.82rem}
.btn-primary{background:var(--brand);color:#fff}
.btn-primary:hover{background:var(--brand-d)}
.btn-secondary{background:#e7f0ff;color:var(--accent)}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{background:#f1f5f9}
.btn-danger{background:#fbe9e7;color:var(--danger)}
.btn-danger:hover{background:#f8d7d4}
.btn-block{width:100%;justify-content:center;margin-top:.5rem}
.btn[disabled]{opacity:.45;cursor:not-allowed}

/* Stats */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.25rem}
.stat{text-align:center;padding:1rem}
.stat-num{display:block;font-size:2rem;font-weight:700;color:var(--brand)}
.stat-label{color:var(--muted);font-size:.85rem}
.stat-warn .stat-num{color:var(--warn)}

/* Tables */
.table{width:100%;border-collapse:collapse}
.table th,.table td{text-align:left;padding:.6rem .5rem;border-bottom:1px solid var(--line);vertical-align:top}
.table th{font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.table tbody tr:hover{background:#f9fbfd}
.row-actions{white-space:nowrap;text-align:right}
.row-muted{opacity:.55}
.empty{color:var(--muted);padding:.5rem 0}
.msg-cell{max-width:420px}

/* Badges & statuses */
.badge{display:inline-block;font-size:.72rem;font-weight:700;padding:.12rem .45rem;border-radius:999px;vertical-align:middle}
.badge-warn{background:var(--warn-bg);color:var(--warn)}
.badge-ok{background:#e6f6ef;color:var(--ok)}
.badge-urgent{background:#fbe9e7;color:var(--danger)}
.status{display:inline-block;font-size:.75rem;font-weight:700;padding:.18rem .5rem;border-radius:999px;text-transform:capitalize}
.status-booked{background:#eef2f7;color:#475569}
.status-confirmed{background:#e6f6ef;color:var(--ok)}
.status-completed{background:#e7f0ff;color:var(--accent)}
.status-cancelled{background:#fbe9e7;color:var(--danger)}
.status-dna{background:var(--warn-bg);color:var(--warn)}
.status-sms-sent{background:#e6f6ef;color:var(--ok)}
.status-sms-draft{background:var(--warn-bg);color:var(--warn)}
.status-sms-failed{background:#fbe9e7;color:var(--danger)}
.status-select{border:1px solid var(--line);border-radius:7px;padding:.25rem .4rem;font-size:.8rem;font-weight:600}

/* Forms */
label{display:block;margin-bottom:.8rem;font-weight:600;font-size:.9rem}
input,select,textarea{width:100%;margin-top:.25rem;padding:.55rem .65rem;border:1px solid var(--line);
  border-radius:8px;font:inherit;background:#fff;font-weight:400}
input:focus,select:focus,textarea:focus{outline:2px solid #bcd6ff;border-color:var(--accent)}
fieldset{border:1px solid var(--line);border-radius:10px;padding:1rem 1.1rem;margin:0 0 1.1rem}
legend{font-weight:700;padding:0 .4rem;color:var(--brand)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:0 1rem}
.form-actions{display:flex;align-items:center;gap:.6rem;margin-top:.5rem}
.search{display:flex;gap:.4rem;align-items:center}
.search input{margin-top:0;min-width:240px}
.date-jump{margin-top:0;width:auto}
.new-patient{margin-top:.5rem;padding-top:.5rem;border-top:1px dashed var(--line)}

/* Login */
.login-wrap{max-width:380px;margin:6vh auto}
.login-card{padding:1.75rem}
.login-head{text-align:center;margin-bottom:1rem}
.login-head h1{font-size:1.25rem}

/* Flash */
.flashes{margin-bottom:1rem;display:grid;gap:.5rem}
.flash{padding:.65rem .9rem;border-radius:8px;font-size:.9rem;border:1px solid transparent}
.flash-success{background:#e6f6ef;color:var(--ok);border-color:#bce6d3}
.flash-error{background:#fbe9e7;color:var(--danger);border-color:#f3c6c0}
.flash-info{background:#e7f0ff;color:var(--accent);border-color:#c5dcff}

/* Calendar */
.calendar{width:100%;border-collapse:collapse;table-layout:fixed}
.calendar th{padding:.4rem;font-size:.78rem;color:var(--muted);text-transform:uppercase}
.cal-cell{border:1px solid var(--line);height:84px;vertical-align:top;padding:0}
.cal-link{display:flex;flex-direction:column;height:100%;padding:.35rem .45rem;color:var(--ink)}
.cal-link:hover{background:#f1f7f7;text-decoration:none}
.cal-out{background:#fafbfc}
.cal-out .cal-date{color:#b4bfcc}
.cal-today{outline:2px solid var(--brand);outline-offset:-2px}
.cal-date{font-weight:600;font-size:.85rem}
.cal-counts{margin-top:auto;display:flex;gap:.25rem;flex-wrap:wrap}
.cal-count{align-self:flex-start;background:var(--brand);color:#fff;
  font-size:.72rem;font-weight:700;padding:.1rem .45rem;border-radius:999px}
.cal-count-biopsy{background:#6a3fb5}

/* Print */
.only-print{display:none}
@media print{
  .no-print{display:none !important}
  .only-print{display:block}
  body{background:#fff}
  .container{margin:0;max-width:none}
  .card{box-shadow:none;border:none;padding:0}
  .print-head{margin-bottom:.5rem}
  .print-head h2{margin:0}
  .table th,.table td{border-bottom:1px solid #ccc;padding:.4rem .3rem}
  .day-table{font-size:12px}
  /* each list (E26 / E4) prints on its own sheet with its own header */
  .list-section + .list-section{page-break-before:always}
  .list-section{break-inside:auto}
  .day-table tr{break-inside:avoid}
}

@media (max-width:720px){
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .grid-2{grid-template-columns:1fr}
}

/* --- list capacity bar --- */
.cap-bar{display:flex;flex-wrap:wrap;gap:.5rem;margin:0 0 1.1rem}
.cap-pill{display:inline-flex;align-items:center;gap:.35rem;font-size:.82rem;
  background:var(--card);border:1px solid var(--line);border-radius:999px;
  padding:.3rem .7rem;color:var(--muted)}
.cap-pill strong{color:var(--ink);font-weight:700}
.cap-pill.cap-full{background:#e7f0ff;border-color:#bcd3f5;color:var(--accent)}
.cap-pill.cap-full strong{color:var(--accent)}
.cap-pill.cap-over{background:var(--warn-bg);border-color:#f3c98b;color:var(--warn)}
.cap-pill.cap-over strong{color:var(--warn)}
.cap-tag{display:inline-block;font-size:.68rem;color:var(--muted);background:#f1f4f8;
  border-radius:5px;padding:.05rem .35rem;margin-top:.15rem}

/* --- duplicate flag + day-list sections --- */
.badge-dup{background:#fde8e8;color:#b42318;border:1px solid #f3c0c0}
.list-section{margin-bottom:2rem}
.section-head{font-size:1rem;margin:0 0 .6rem;padding-bottom:.35rem;
  border-bottom:2px solid var(--brand);color:var(--ink)}
.section-loc{font-weight:700;color:var(--brand);font-size:1.1rem}
.section-sub{font-weight:600;color:var(--ink)}
.section-count{font-weight:400;font-size:.85rem}
.resched-summary{margin:0 0 1rem;line-height:1.5}
.resched-note{font-size:.82rem;margin:.4rem 0 0}

/* --- public holidays --- */
.holiday-banner{background:#fbe9e7;border:1px solid #f3c0c0;color:#b42318;
  border-radius:var(--radius);padding:.6rem .9rem;margin:0 0 1.1rem;font-size:.9rem}
.cal-holiday{background:#fdecea}
.cal-hol{display:block;font-size:.62rem;color:#b42318;line-height:1.1;margin-top:.1rem;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* --- dashboard: downtime countdown + biopsy stat --- */
.downtime-banner{background:#e6f3f3;border:1px solid #bfe0e0;color:#0a5757;
  border-radius:var(--radius);padding:.7rem .95rem;margin:0 0 1.25rem;font-size:.92rem}
.stat-biopsy .stat-num{color:#6a3fb5}

/* --- checkbox line (reschedule notify, etc.) --- */
.check-line{display:flex;gap:.5rem;align-items:center;font-weight:500;margin-bottom:.8rem}
.check-line input{width:auto;margin:0}

/* --- theatre booking list (PD 714) print form --- */
.section-staff{margin:-.2rem 0 .7rem;font-size:.88rem;color:var(--muted);
  display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}
.theatre-form{background:#fff;border:1px solid #000;border-radius:4px;padding:.6rem .8rem;
  margin:0 0 1.5rem;color:#000}
.tf-head{display:flex;justify-content:space-between;align-items:baseline;
  border-bottom:2px solid #000;padding-bottom:.25rem}
.tf-title{font-weight:700;font-size:1rem;letter-spacing:.02em}
.tf-code{font-weight:700}
.tf-meta{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin:.4rem 0}
.tf-staff{display:flex;gap:1.4rem;align-items:center;flex-wrap:wrap;margin-bottom:.45rem;font-size:.9rem}
.tf-table{width:100%;border-collapse:collapse;font-size:.8rem}
.tf-table th,.tf-table td{border:1px solid #000;padding:.28rem .35rem;text-align:left;vertical-align:top}
.tf-table th{font-size:.62rem;text-transform:uppercase;background:#eee;font-weight:700}
.tf-table td{height:1.6rem}
.tf-num{width:1.5rem;text-align:center}
.tf-table th:nth-child(2),.tf-table td:nth-child(2){width:28%}
.tf-table th:nth-child(3),.tf-table td:nth-child(3){width:12%}
.tf-table th:nth-child(4),.tf-table td:nth-child(4){width:30%}
.tf-table th:nth-child(5),.tf-table td:nth-child(5){width:18%}
.tf-table th:nth-child(6),.tf-table td:nth-child(6){width:8%}
.tf-table input{width:100%;margin:0;border:none;border-radius:0;padding:.1rem .15rem;
  font:inherit;font-size:.8rem;background:transparent}
.tf-table input:focus{outline:1px solid var(--accent);background:#fff}
.tf-footer{margin:.45rem 0 .15rem;padding-left:1.2rem;font-size:.72rem;color:#000}
.tf-nb{font-weight:700;font-size:.78rem;margin:.2rem 0 0}
@media print{
  .theatre-form{border:1px solid #000;margin:0;border-radius:0}
  .theatre-form + .theatre-form{page-break-before:always}
}

/* --- dashboard patient lookup --- */
.mini-head{font-size:.9rem;color:var(--brand);margin:.8rem 0 .3rem;font-weight:700}
.past-details{margin-top:.6rem}
.past-details summary{cursor:pointer;color:var(--accent);font-weight:600;padding:.2rem 0}
.ok-text{color:var(--ok)}
.err-text{color:var(--danger)}

/* --- deceased tag --- */
.badge-deceased{background:#3a3f44;color:#fff}
