/* ============================================================
   Clinic Booking — shared design system (SINGLE SOURCE OF TRUTH)
   Palette + components extracted verbatim from Mockups_v2_AllPersonas.html.
   EVERY screen (patient, kiosk, front-desk, doctor, admin) must use these tokens
   so the whole product adheres to the mock standard. Do not hardcode colors in pages.
   ============================================================ */
:root{
  --bg:#f5f7f9; --card:#ffffff; --ink:#0f172a; --muted:#667085; --line:#e6e9ef;
  --brand:#0e7c66; --brand-soft:#e6f3ef; --accent:#2563eb; --accent-soft:#e8f0fe;
  --amber:#b45309; --amber-soft:#fdf2e0; --red:#dc2626; --red-soft:#fdeaea;
  --ok:#15803d; --ok-soft:#e7f5ec; --cfg:#7c3aed; --cfg-soft:#f1e9fd;
  --r:18px; --r2:12px; --r3:11px;
  --shadow:0 1px 2px rgba(16,24,40,.04),0 6px 20px rgba(16,24,40,.06);
}
*{box-sizing:border-box}
html{font-size:16px;-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:ui-sans-serif,system-ui,'Segoe UI',Inter,Roboto,'Noto Sans Malayalam',Arial,sans-serif;
  line-height:1.45}
/* Malayalam (or other) second line — muted on light surfaces */
.ml{display:block;font-size:.8em;color:var(--muted);font-weight:500;line-height:1.3;margin-top:1px}

/* layout + header (mock .top) */
.wrap{max-width:560px;margin:0 auto;padding:max(env(safe-area-inset-top),14px) 16px 96px}
.top{position:sticky;top:0;z-index:9;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);padding:14px 16px;display:flex;align-items:center;gap:10px}
.brandlogo{width:34px;height:34px;border-radius:9px;background:var(--brand);color:#fff;display:flex;
  align-items:center;justify-content:center;font-weight:800;flex:0 0 auto}
.top h1{font-size:1.05rem;margin:0;font-weight:650}
.top p{margin:1px 0 0;font-size:.72rem;color:var(--muted)}

/* cards + headings (mock .frame/.pad) */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:16px;margin-top:14px}
h2{font-size:1rem;margin:0 0 10px;font-weight:650}
h3{margin:0 0 3px;font-size:.95rem}
.muted{color:var(--muted);font-size:.78rem}

/* stats (mock .stat) */
.stats{display:flex;gap:10px;margin-top:6px}
.stat{flex:1;background:#fbfcfd;border:1px solid var(--line);border-radius:var(--r2);padding:12px;text-align:center}
.stat b{display:block;font-size:1.45rem;color:var(--brand)} .stat span{font-size:.7rem;color:var(--muted)}

/* list rows (mock .li / doctor row) */
.doc{display:flex;justify-content:space-between;align-items:center;padding:12px;border:1px solid var(--line);
  border-radius:var(--r2);margin-bottom:8px;gap:10px}
.doc .meta{font-size:.78rem;color:var(--muted)}

/* fields (mock .field/.input) */
.field{margin-bottom:12px}
.field label{display:block;font-size:.74rem;color:var(--muted);margin-bottom:5px;font-weight:600}
.input{width:100%;border:1px solid var(--line);border-radius:10px;padding:13px;font-size:1rem;background:#fff;color:var(--ink);min-height:48px}
.input:focus{outline:2px solid var(--brand-soft);border-color:var(--brand)}

/* buttons (mock .btn / .btn.ghost) — bilingual stacks, light on colored bg */
.btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;
  width:100%;border:none;border-radius:13px;padding:14px;font-size:1rem;font-weight:700;
  background:var(--brand);color:#fff;cursor:pointer;min-height:52px;text-align:center}
.btn:disabled{opacity:.55}
.btn .ml{color:#fff;opacity:.85}
.btn.ghost{background:#fff;color:var(--brand);border:1.6px solid var(--brand)}
.btn.ghost .ml{color:var(--brand);opacity:.7}
.btn.accent{background:var(--accent)} .btn.red{background:var(--red)} .btn.amber{background:var(--amber)}
.btn.sm{min-height:44px;padding:10px 14px;font-size:.9rem;width:auto}

/* segmented control (mock .seg) */
.seg{display:flex;border:1px solid var(--line);border-radius:12px;overflow:hidden;margin-bottom:12px}
.seg button{flex:1;border:none;background:#fff;padding:12px;font-weight:600;font-size:.9rem;color:var(--muted);min-height:48px;cursor:pointer}
.seg button.on{background:var(--brand-soft);color:var(--brand)}
.seg button .ml{color:inherit;opacity:.75}

/* consent + add patient (mock) */
.consent{display:flex;gap:10px;align-items:flex-start;font-size:.82rem;color:var(--muted);margin:6px 0 12px}
.consent input{width:22px;height:22px;margin-top:1px;flex:0 0 auto;accent-color:var(--brand)}
.addbtn{background:none;border:1px dashed var(--brand);color:var(--brand);border-radius:var(--r3);padding:10px;width:100%;font-weight:600;font-size:.85rem;min-height:46px;cursor:pointer}
.patientblock{border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:10px}

/* token (mock .token) */
.token{border:2px dashed var(--brand);border-radius:16px;padding:20px;text-align:center}
.token .n{font-size:3rem;font-weight:800;color:var(--brand);line-height:1}
.token .code{margin-top:6px;font-size:.8rem;color:var(--muted);letter-spacing:.05em}

/* pills (mock .pill + variants) */
.pill{display:inline-block;font-size:.72rem;border-radius:20px;padding:3px 10px;font-weight:600;background:var(--accent-soft);color:var(--accent)}
.pill.g{background:var(--ok-soft);color:var(--ok)} .pill.a{background:var(--amber-soft);color:var(--amber)}
.pill.r{background:var(--red-soft);color:var(--red)} .pill.n{background:#eef1f5;color:#475569}

/* error banner (mock .banner.red) */
.err{background:var(--red-soft);color:#a4262c;border:1px solid #f3c6c6;border-radius:var(--r3);padding:11px;font-size:.82rem;margin-top:10px}
.hidden{display:none}
@media(min-width:600px){ .wrap{padding-bottom:40px} }

/* ---- landing/discovery components (mock screen 1-2) ---- */
.ident{display:flex;justify-content:space-between;align-items:center;gap:8px}
.ident b{color:var(--brand);font-size:1rem}
.subtitle{font-size:.82rem;color:var(--muted);margin:6px 0 0;font-weight:500}
.cfg{display:inline-flex;align-items:center;gap:3px;font-size:.62rem;font-weight:600;color:var(--cfg);
  background:var(--cfg-soft);border-radius:20px;padding:2px 8px;flex:0 0 auto}
.row2{display:flex;gap:8px;margin-top:10px}
.row2 .btn{flex:1}
.foot{font-size:.74rem;color:var(--muted);margin-top:12px}
.livecard{display:flex;justify-content:space-between;align-items:center;padding:12px;border:1px solid #bfe6cf;
  background:var(--ok-soft);border-radius:12px;gap:10px;cursor:pointer;margin-bottom:8px}
.livecard .meta{font-size:.76rem;color:var(--muted)}
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.chip{font-size:.74rem;border:1px solid var(--line);border-radius:20px;padding:6px 11px;color:#475569;background:#fff}
.chip.on{background:var(--brand);color:#fff;border-color:var(--brand)}
.chip.off{opacity:.5}
.note{font-size:.78rem;color:var(--muted);margin:8px 0 0}

/* ---- admin / platform config ---- */
.adminwrap{max-width:780px;margin:0 auto;padding:14px 16px 80px}
.grid2{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:760px){ .grid2{grid-template-columns:1fr 1fr} }
.kv{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--line);font-size:.82rem}
.kv:last-child{border-bottom:none}
.select{width:100%;border:1px solid var(--line);border-radius:10px;padding:12px;font-size:1rem;background:#fff;min-height:48px}
.result{font-size:.8rem;border-radius:10px;padding:10px;margin-top:8px}
.result.ok{background:var(--ok-soft);color:var(--ok);border:1px solid #bfe6cf}
.result.bad{background:var(--red-soft);color:#a4262c;border:1px solid #f3c6c6}
.hint{font-size:.72rem;color:var(--muted);margin:-4px 0 8px}
.cardhead{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
