/* Home Health Intake Tracker — styles */
:root{
  --bg:#f4f6f9; --panel:#fff; --ink:#1c2733; --muted:#6b7886; --line:#e2e8f0;
  --blue:#2563eb; --blue-d:#1e40af;
  --amber:#b45309; --amber-bg:#fef3c7;
  --green:#15803d; --green-bg:#dcfce7;
  --red:#b91c1c; --red-bg:#fee2e2;
  --gray:#64748b;
  --shadow:0 1px 2px rgba(16,24,40,.06),0 1px 3px rgba(16,24,40,.1);
}
*{box-sizing:border-box}
body{margin:0;font:14px/1.5 -apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink)}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
h1{font-size:22px;margin:0 0 4px}
h2{font-size:15px}
h3{font-size:15px;margin:0 0 10px}
h4{font-size:14px;margin:0}
.muted{color:var(--muted)}
.small{font-size:12px}
.ok{color:var(--green);font-weight:600}

/* top bar */
.topbar{display:flex;justify-content:space-between;align-items:center;background:#0f172a;color:#fff;padding:10px 20px}
.topbar a{color:#fff}
.brand a{font-weight:700;font-size:16px}
.brand .agency{color:#94a3b8;margin-left:10px;font-size:12px}
.topbar nav{display:flex;gap:16px;align-items:center}
.topbar nav .btn-primary{color:#fff}
.linkbtn{background:none;border:0;color:#cbd5e1;cursor:pointer;font:inherit}
.linkbtn:hover{color:#fff}
.inline{display:inline}

.wrap{max-width:1200px;margin:20px auto;padding:0 20px}
.foot{max-width:1200px;margin:30px auto;padding:0 20px;color:var(--muted);font-size:12px}
.page-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.back{font-size:13px}
.section-h{margin:26px 0 12px;padding-top:14px;border-top:1px solid var(--line)}

/* buttons */
.btn{display:inline-block;border:1px solid var(--line);background:#fff;color:var(--ink);padding:7px 12px;border-radius:7px;cursor:pointer;font:inherit;text-decoration:none}
.btn:hover{background:#f8fafc;text-decoration:none}
.btn[disabled]{opacity:.5;cursor:not-allowed}
.btn-primary{background:var(--blue);border-color:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-d)}
.btn-danger{background:var(--red);border-color:var(--red);color:#fff}
.btn.sm{padding:4px 9px;font-size:12px}

/* flash */
.flash{padding:10px 14px;border-radius:8px;margin-bottom:12px;border:1px solid}
.flash-success{background:var(--green-bg);border-color:#86efac;color:var(--green)}
.flash-danger{background:var(--red-bg);border-color:#fca5a5;color:var(--red)}
.flash-warn{background:var(--amber-bg);border-color:#fcd34d;color:var(--amber)}
.flash-info{background:#e0f2fe;border-color:#7dd3fc;color:#075985}

/* board */
.board{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.col{background:#eef2f7;border-radius:10px;padding:12px;min-height:120px}
.col h2{display:flex;justify-content:space-between;align-items:center;margin:2px 4px 12px;color:#334155}
.col .count{background:#cbd5e1;color:#334155;border-radius:20px;padding:1px 9px;font-size:12px}
.col-referral h2{color:var(--blue-d)}
.col-pending h2{color:var(--amber)}
.col-admit h2{color:var(--green)}
.card{display:block;background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:11px;margin-bottom:10px;box-shadow:var(--shadow);color:var(--ink)}
.card:hover{text-decoration:none;border-color:#cbd5e1}
.card-top{display:flex;justify-content:space-between;gap:8px}
.card .mrn{color:var(--muted);font-size:12px;font-weight:600}
.empty{color:var(--muted);text-align:center;padding:10px;font-size:13px}

/* progress bar */
.bar{height:6px;background:#e2e8f0;border-radius:6px;overflow:hidden;margin:9px 0 6px}
.bar span{display:block;height:100%;background:var(--green)}
.bar.big{height:9px;margin:10px 0}

.meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;font-size:12px}
.pill{background:#eef2f7;border:1px solid var(--line);border-radius:20px;padding:1px 8px;font-size:12px}
.pill.danger{background:var(--red-bg);border-color:#fca5a5;color:var(--red)}
.owner{color:var(--muted)}

/* flags */
.flag{display:block;margin-top:6px;font-size:12px;padding:3px 8px;border-radius:6px}
.flags-row{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0 16px}
.flags-row .flag{display:inline-block;margin:0}
.flag-info{background:#e0f2fe;color:#075985}
.flag-warn{background:var(--amber-bg);color:var(--amber)}
.flag-danger{background:var(--red-bg);color:var(--red)}

/* stage badges */
.stage-badge{display:inline-block;padding:2px 10px;border-radius:20px;font-size:12px;font-weight:600}
.stage-referral{background:#dbeafe;color:var(--blue-d)}
.stage-pending{background:var(--amber-bg);color:var(--amber)}
.stage-admit{background:var(--green-bg);color:var(--green)}
.stage-ntuc{background:#e2e8f0;color:var(--gray)}

/* detail */
.detail-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}
.detail-head .mrn{font-size:14px;color:var(--muted);font-weight:600}
.badges{display:flex;gap:8px;align-items:center;margin-top:6px}
.cols2{display:grid;grid-template-columns:1.3fr 1fr;gap:16px;margin-top:8px}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:16px;box-shadow:var(--shadow)}
.kv{display:grid;grid-template-columns:130px 1fr;gap:6px 10px;margin:0}
.kv dt{color:var(--muted)}
.kv dd{margin:0}
.notes{margin-top:12px;padding-top:10px;border-top:1px solid var(--line)}
.ntuc-banner{background:#f1f5f9;border-radius:8px;padding:12px;font-weight:600}
.ntuc-form{margin-top:14px}
.ntuc-form summary{cursor:pointer;color:var(--muted);font-size:13px}
.ntuc-form form{margin-top:10px;display:flex;flex-direction:column;gap:8px;max-width:360px}

/* checklist */
.stage-block{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:14px;margin-bottom:14px;box-shadow:var(--shadow)}
.stage-block.is-current{border-color:var(--blue);box-shadow:0 0 0 1px var(--blue)}
.stage-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.stage-head .now{background:var(--blue);color:#fff;border-radius:20px;padding:1px 9px;font-size:11px;margin-left:6px}
.task{border-top:1px solid var(--line);padding:7px 0}
.task:first-of-type{border-top:0}
.task-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.task-label{flex:1 1 280px;min-width:220px}
.task-label .small{display:block}
.task-form select,.task-form input{padding:5px 7px;border:1px solid var(--line);border-radius:6px;font:inherit}
.task-form input.sm{width:110px}
.task-form input.grow{flex:1 1 160px}
.task.st-complete{background:#f6fef9}
.task.st-complete .task-label{color:var(--green)}
.task.st-na{opacity:.55}
.st-select{min-width:120px}

/* tables */
table.grid,table.tasks{width:100%;border-collapse:collapse;background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:hidden}
table.grid th,table.grid td{padding:9px 12px;text-align:left;border-bottom:1px solid var(--line);font-size:13px}
table.grid th{background:#f8fafc;color:var(--muted);font-weight:600}
table.grid tr:last-child td{border-bottom:0}
.dots{white-space:nowrap}
.dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:3px}
.dot-info{background:#38bdf8}
.dot-warn{background:#f59e0b}
.dot-danger{background:#ef4444}

/* filters */
.filters{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.filters input,.filters select{padding:7px 9px;border:1px solid var(--line);border-radius:7px;font:inherit}
.filters input[name=q]{min-width:240px}

/* forms */
.bigform{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:18px;box-shadow:var(--shadow)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px 16px}
.bigform label{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--muted)}
.bigform label.full{margin-top:12px}
.bigform input,.bigform select,.bigform textarea{padding:8px 10px;border:1px solid var(--line);border-radius:7px;font:inherit;color:var(--ink)}
.form-actions{display:flex;gap:10px;margin-top:16px}

/* activity */
.activity{list-style:none;padding:0;margin:0}
.activity li{padding:6px 0;border-bottom:1px solid var(--line);font-size:13px}

/* login */
.login-body{display:flex;min-height:100vh;align-items:center;justify-content:center}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:28px;width:340px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:10px}
.login-card label{display:flex;flex-direction:column;gap:5px;font-size:13px;color:var(--muted)}
.login-card input{padding:9px 11px;border:1px solid var(--line);border-radius:7px;font:inherit}

/* checkbox checklist (overrides the old per-row form layout) */
.task{display:flex;align-items:center;gap:10px;border-top:1px solid var(--line);padding:9px 0;flex-wrap:wrap}
.task:first-of-type{border-top:0}
.chk{display:flex;align-items:center;gap:10px;flex:1 1 auto;min-width:240px;cursor:pointer}
.task-check{width:18px;height:18px;flex:0 0 auto;cursor:pointer;accent-color:var(--green)}
.task-label{line-height:1.35}
.task.st-complete{background:#f6fef9}
.task.st-complete .task-label{color:var(--green);text-decoration:line-through;text-decoration-color:#9ae6b4}
.task.st-na{opacity:.55}
.task.st-na .task-label{text-decoration:line-through}
.task-side{display:flex;align-items:center;gap:8px;margin-left:auto}
.done-at{color:var(--muted);font-size:11px;white-space:nowrap}
.na-toggle,.more-toggle{font-size:12px;border:1px solid var(--line);background:#fff;border-radius:6px;padding:3px 8px;cursor:pointer;color:var(--muted);line-height:1}
.na-toggle:hover,.more-toggle:hover{background:#f8fafc}
.na-toggle.active{background:#e2e8f0;color:#334155;border-color:#cbd5e1;font-weight:600}
.task-more{flex-basis:100%;display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end;padding:8px 0 4px 28px}
.task-more label{display:flex;flex-direction:column;gap:3px;font-size:12px;color:var(--muted)}
.task-more input{padding:5px 7px;border:1px solid var(--line);border-radius:6px;font:inherit;color:var(--ink)}
.save-state{font-size:12px;color:var(--green);opacity:0;transition:opacity .2s;padding-bottom:6px}
.save-state.show{opacity:1}
.task.just-saved{background:#ecfdf5;transition:background .2s}
.task.saving{opacity:.65}

/* top-bar name box + last-updated line */
.namebox{display:inline-flex;align-items:center;margin:0}
.name-input{background:#1e293b;border:1px solid #334155;color:#fff;border-radius:6px;padding:5px 9px;font:inherit;width:130px}
.name-input::placeholder{color:#94a3b8}
.name-input:focus{outline:none;border-color:#60a5fa}
.name-input.saved-flash{border-color:#22c55e;box-shadow:0 0 0 1px #22c55e;transition:border-color .2s,box-shadow .2s}
.lu-line{margin:2px 0 12px}

@media(max-width:900px){
  .board{grid-template-columns:1fr}
  .cols2{grid-template-columns:1fr}
  .grid2{grid-template-columns:1fr}
  .task-side{margin-left:0}
}
