/* Cliniways prototype — design system */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,600;12..96,800&family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Sans+Devanagari:wght@400;500;600&display=swap');

:root{
  --bg:#f4f6f8; --panel:#ffffff; --ink:#0f2230; --muted:#5b7185; --line:#e3e9ef;
  --teal:#0e8f8f; --teal-d:#0a6f6f; --indigo:#3a4cc4; --green:#1a9d6a; --amber:#d98a14; --red:#d2483f;
  --pwa:#13845b;
  --shadow:0 1px 2px rgba(15,34,48,.06),0 8px 24px rgba(15,34,48,.06);
  --radius:14px;
  --accent:var(--teal); /* overridden per role */
}
*{box-sizing:border-box}
body{margin:0;font-family:'IBM Plex Sans','IBM Plex Sans Devanagari',sans-serif;background:var(--bg);color:var(--ink);font-size:15px;line-height:1.5}
h1,h2,h3{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;letter-spacing:-.02em;margin:0}
.dev{font-family:'IBM Plex Sans Devanagari',sans-serif}
a{color:var(--accent);text-decoration:none}

/* ---------- login ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;background:
  radial-gradient(1200px 600px at 80% -10%, #d8efef 0%, transparent 60%),
  radial-gradient(900px 500px at -10% 110%, #e6e9fb 0%, transparent 55%), var(--bg)}
.login-card{width:min(420px,92vw);background:var(--panel);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);padding:34px}
.brand{display:flex;align-items:center;gap:11px;margin-bottom:6px}
.brand .mark{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--teal),var(--indigo));display:grid;place-items:center;color:#fff;font-family:'Bricolage Grotesque';font-weight:800}
.brand b{font-family:'Bricolage Grotesque';font-size:22px}
.sub{color:var(--muted);font-size:13.5px;margin:2px 0 22px}
.field{margin-bottom:13px}
.field label{display:block;font-size:12.5px;color:var(--muted);margin-bottom:5px;font-weight:500}
.field input{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:10px;font:inherit;background:#fafcfd}
.field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(14,143,143,.12)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 16px;border-radius:10px;border:1px solid transparent;background:var(--accent);color:#fff;font:inherit;font-weight:600;cursor:pointer;transition:.15s}
.btn:hover{filter:brightness(.96)}
.btn.full{width:100%}
.btn.ghost{background:transparent;border-color:var(--line);color:var(--ink)}
.btn.sm{padding:7px 11px;font-size:13px;border-radius:8px}
.quick{margin-top:18px;border-top:1px solid var(--line);padding-top:16px}
.quick h4{font-family:'IBM Plex Sans';font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:0 0 10px}
.qrow{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 11px;border:1px solid var(--line);border-radius:10px;margin-bottom:8px;cursor:pointer;background:#fafcfd}
.qrow:hover{border-color:var(--accent)}
.qrow .who{font-weight:600;font-size:13.5px}
.qrow .role{font-size:11.5px;color:var(--muted)}
.dot{width:9px;height:9px;border-radius:50%}

/* ---------- app shell ---------- */
.shell{display:grid;grid-template-columns:236px 1fr;min-height:100vh}
.side{background:var(--panel);border-right:1px solid var(--line);padding:18px 14px;position:sticky;top:0;height:100vh;overflow:auto}
.side .brand{margin-bottom:18px}
.side .brand b{font-size:18px}
.navsec{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:16px 8px 7px}
.nav{display:flex;flex-direction:column;gap:3px}
.nav a{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:9px;color:var(--ink);font-size:14px;font-weight:500;cursor:pointer}
.nav a:hover{background:#f1f5f7}
.nav a.active{background:color-mix(in srgb,var(--accent) 12%,#fff);color:var(--accent);font-weight:600}
.nav a .ic{width:18px;text-align:center;opacity:.8}
.main{display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 22px;background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}
.topbar .clinic{font-weight:600}
.topbar .clinic small{display:block;color:var(--muted);font-weight:400;font-size:12px}
.topbar .tools{display:flex;align-items:center;gap:8px}
.chip{padding:5px 10px;border:1px solid var(--line);border-radius:999px;font-size:12.5px;color:var(--muted);background:#fafcfd;cursor:pointer}
.chip:hover{border-color:var(--accent);color:var(--accent)}
.role-badge{display:flex;align-items:center;gap:8px;padding:5px 10px;border-radius:999px;background:color-mix(in srgb,var(--accent) 12%,#fff);color:var(--accent);font-weight:600;font-size:12.5px}
.content{padding:22px;max-width:1180px;width:100%}
.page-h{display:flex;align-items:end;justify-content:space-between;gap:14px;margin-bottom:16px}
.page-h h2{font-size:24px}
.page-h p{color:var(--muted);margin:3px 0 0;font-size:13.5px}

/* cards / grid */
.grid{display:grid;gap:14px}
.g2{grid-template-columns:repeat(2,1fr)} .g3{grid-template-columns:repeat(3,1fr)} .g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.g2,.g3,.g4{grid-template-columns:1fr}.shell{grid-template-columns:1fr}.side{display:none}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}
.card h3{font-size:15px;font-family:'IBM Plex Sans';font-weight:700;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.stat{display:flex;flex-direction:column;gap:3px}
.stat .k{font-size:12px;color:var(--muted);font-weight:500}
.stat .v{font-family:'Bricolage Grotesque';font-size:27px;font-weight:800}
.stat .sub{font-size:12px;color:var(--muted)}
.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:999px;font-size:11.5px;font-weight:600}
.pill.ok{background:#e7f6ef;color:var(--green)} .pill.warn{background:#fdf2e2;color:var(--amber)} .pill.bad{background:#fbeae9;color:var(--red)}
.pill.info{background:#eef0fb;color:var(--indigo)} .pill.neut{background:#eef3f6;color:var(--muted)}

/* tables */
table{width:100%;border-collapse:collapse;font-size:13.5px}
th{text-align:left;color:var(--muted);font-weight:600;font-size:12px;padding:9px 10px;border-bottom:1px solid var(--line)}
td{padding:10px;border-bottom:1px solid var(--line)}
tr:last-child td{border-bottom:none}
.tok{display:inline-grid;place-items:center;width:30px;height:30px;border-radius:9px;background:color-mix(in srgb,var(--accent) 14%,#fff);color:var(--accent);font-weight:800;font-family:'Bricolage Grotesque'}

/* queue / list rows */
.qcard{display:flex;align-items:center;gap:13px;padding:12px;border:1px solid var(--line);border-radius:12px;margin-bottom:9px;background:#fff}
.qcard.em{border-color:#f3c9c5;background:#fff8f7}
.qcard .meta{flex:1;min-width:0}
.qcard .nm{font-weight:600}
.qcard .mut{color:var(--muted);font-size:12.5px}

/* bars */
.bar{height:9px;border-radius:999px;background:#eef3f6;overflow:hidden}
.bar > i{display:block;height:100%;background:var(--accent);border-radius:999px}
.barrow{display:grid;grid-template-columns:130px 1fr 70px;align-items:center;gap:10px;margin-bottom:9px;font-size:13px}

/* spark */
.spark{display:flex;align-items:end;gap:7px;height:120px}
.spark > div{flex:1;background:linear-gradient(180deg,var(--accent),color-mix(in srgb,var(--accent) 55%,#fff));border-radius:7px 7px 0 0;position:relative;min-height:6px}
.spark > div span{position:absolute;top:-18px;left:0;right:0;text-align:center;font-size:10.5px;color:var(--muted)}
.spark > div b{position:absolute;bottom:-19px;left:0;right:0;text-align:center;font-size:10.5px;color:var(--muted);font-weight:500}

/* whatsapp */
.wa{background:#e9ede8;border-radius:12px;padding:14px;max-height:380px;overflow:auto}
.bub{max-width:78%;padding:8px 11px;border-radius:12px;margin-bottom:8px;font-size:13.5px;box-shadow:0 1px 1px rgba(0,0,0,.06)}
.bub.in{background:#fff;border-top-left-radius:3px}
.bub.out{background:#d6f5c6;margin-left:auto;border-top-right-radius:3px}
.bub .tk{font-size:10px;color:#5a8a45;float:right;margin:3px 0 -3px 8px}
.bub.sms{background:#fff4d6}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(15,34,48,.45);display:none;place-items:center;z-index:50;padding:18px}
.modal-bg.show{display:grid}
.modal{background:#fff;border-radius:16px;padding:22px;width:min(440px,94vw);box-shadow:var(--shadow)}
.modal h3{font-family:'Bricolage Grotesque';font-size:19px;margin-bottom:6px}
.qr{width:170px;height:170px;margin:14px auto;border-radius:12px;background:
  repeating-conic-gradient(#0f2230 0 25%, #fff 0 50%) 50%/22px 22px;border:8px solid #fff;box-shadow:0 0 0 1px var(--line)}
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:11px 16px;border-radius:10px;font-size:13.5px;opacity:0;transition:.25s;z-index:80}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.flag{padding:10px 12px;border-radius:10px;font-size:13px;margin-bottom:9px;display:flex;gap:9px;align-items:flex-start}
.flag.bad{background:#fbeae9;color:#962a23} .flag.warn{background:#fdf2e2;color:#7a4d08} .flag.ok{background:#e7f6ef;color:#0c5e3f}
.kv{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px dashed var(--line);font-size:13.5px}
.kv:last-child{border:none}
.muted{color:var(--muted)} .right{text-align:right} .center{text-align:center}
.row{display:flex;gap:9px;flex-wrap:wrap;align-items:center}
.sep{height:1px;background:var(--line);margin:14px 0}
.input{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:10px;font:inherit;background:#fafcfd}
.input:focus{outline:none;border-color:var(--accent)}
textarea.input{min-height:74px;resize:vertical}
.tag{font-size:11px;padding:2px 8px;border-radius:999px;background:#eef3f6;color:var(--muted);font-weight:600}
.tag.chronic{background:#fdf2e2;color:var(--amber)} .tag.VIP{background:#eef0fb;color:var(--indigo)} .tag.insurance{background:#e7f6ef;color:var(--green)}
