:root{
  --brand:#0E7C7B; --brand-dark:#0B5E5D; --brand-light:#14b8a6;
  --ink:#0F172A; --muted:#64748B; --line:#E2E8F0; --bg:#F1F5F9; --card:#FFFFFF;
  --ok:#16A34A; --warn:#D97706; --prio:#7C3AED; --danger:#DC2626;
  --shadow:0 1px 3px rgba(15,23,42,.08),0 8px 24px rgba(15,23,42,.06);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{font-family:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;background:var(--bg);color:var(--ink)}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.simbadge{position:fixed;top:8px;right:8px;z-index:2000;font-size:11px;font-weight:700;padding:5px 10px;border-radius:20px}
.simbadge.sim{background:#DCFCE7;color:#166534;border:1px solid #86EFAC}
.simbadge.real{background:#FEE2E2;color:#991B1B;border:1px solid #FCA5A5}
.live{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--ok);font-weight:600;background:#F0FDF4;border:1px solid #BBF7D0;padding:5px 12px;border-radius:20px}
.live.off{color:var(--danger);background:#FEF2F2;border-color:#FECACA}
.live .blip{width:8px;height:8px;border-radius:50%;background:currentColor;animation:blip 1.6s infinite}
@keyframes blip{0%,100%{opacity:1}50%{opacity:.3}}

/* ---------- TOTEM ---------- */
#totem{background:linear-gradient(160deg,#0E7C7B 0%,#0B5E5D 100%);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.totem-card{background:#fff;border-radius:28px;box-shadow:0 24px 60px rgba(0,0,0,.25);width:min(560px,100%);padding:40px 36px;min-height:580px;display:flex;flex-direction:column}
.totem-logo{display:flex;align-items:center;gap:10px;color:var(--brand);font-weight:800;font-size:18px;margin-bottom:auto}
.totem-logo .dot{width:34px;height:34px;border-radius:9px;background:var(--brand);display:grid;place-items:center;color:#fff;font-size:18px}
.t-welcome{text-align:center;margin:auto 0}
.t-welcome h1{font-size:40px;line-height:1.1;margin-bottom:14px}
.t-welcome p{font-size:20px;color:var(--muted);margin-bottom:36px}
.bigbtn{background:var(--brand);color:#fff;font-size:24px;font-weight:700;padding:22px;border-radius:18px;width:100%;box-shadow:0 10px 24px rgba(14,124,123,.35);transition:transform .08s}
.bigbtn:active{transform:scale(.98)}
.bigbtn.ghost{background:#fff;color:var(--brand);border:2px solid var(--brand);box-shadow:none}
.bigbtn:disabled{opacity:.5}
.t-label{font-size:22px;font-weight:600;text-align:center;margin-bottom:8px}
.t-sub{font-size:16px;color:var(--muted);text-align:center;margin-bottom:20px}
.cpf-display{font-size:34px;font-weight:700;letter-spacing:2px;text-align:center;height:54px;border-bottom:3px solid var(--line);margin-bottom:20px;color:var(--ink)}
.cpf-display.empty{color:#CBD5E1}
.keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.keypad button{background:#F8FAFC;border:1px solid var(--line);border-radius:14px;font-size:28px;font-weight:600;padding:18px 0;color:var(--ink)}
.keypad button:active{background:#E2E8F0}
.keypad button.act{background:var(--brand);color:#fff;border-color:var(--brand);font-size:20px}
.keypad button.clr{color:var(--danger);font-size:20px}
.recog .name{font-size:34px;font-weight:800;text-align:center;margin-bottom:6px}
.appt{border:2px solid var(--line);border-radius:16px;padding:18px;margin:12px 0;display:flex;gap:14px;align-items:center}
.appt .ico{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-size:22px;flex:none}
.appt.consulta .ico{background:#E0F2F1;color:var(--brand)}
.appt.exame .ico{background:#EDE9FE;color:var(--prio)}
.appt .ttl{font-weight:700;font-size:19px}
.appt .meta{color:var(--muted);font-size:15px}
.t-success{text-align:center;margin:auto 0}
.t-success .check{width:96px;height:96px;border-radius:50%;background:var(--ok);color:#fff;font-size:54px;display:grid;place-items:center;margin:0 auto 22px}
.t-success h1{font-size:32px;margin-bottom:10px}
.t-success .pos{background:#F0FDF4;border:1px solid #BBF7D0;color:#166534;border-radius:14px;padding:16px;font-size:19px;margin:18px 0;font-weight:600}
.t-err{text-align:center;margin:auto 0}
.t-err .x{width:90px;height:90px;border-radius:50%;background:#FEF2F2;color:var(--danger);font-size:50px;display:grid;place-items:center;margin:0 auto 20px}
.lgpd{font-size:12px;color:#94A3B8;text-align:center;margin-top:auto;padding-top:20px;line-height:1.5}
.prio-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:6px;margin:14px 0}
.prio-grid button{background:#fff;border:2px solid var(--line);border-radius:20px;padding:10px 16px;font-size:15px;font-weight:600;color:var(--muted)}
.prio-grid button.on{background:#F5F3FF;border-color:var(--prio);color:var(--prio)}
.priochip{display:inline-flex;align-items:center;gap:6px;background:#F5F3FF;color:var(--prio);border:1px solid #DDD6FE;border-radius:20px;padding:8px 14px;font-size:14px;font-weight:600;margin:4px}

/* ---------- MÉDICO ---------- */
#med{max-width:760px;margin:0 auto;padding:18px 16px 40px}
.med-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.med-head select{font-size:18px;font-weight:700;padding:8px 12px;border:1px solid var(--line);border-radius:10px;background:#fff}
.med-head .modo{font-size:12px;color:var(--muted)}
.med-now{background:linear-gradient(135deg,#0E7C7B,#0B5E5D);color:#fff;border-radius:20px;padding:26px;text-align:center;margin-bottom:16px;box-shadow:var(--shadow)}
.med-now .lab{font-size:13px;letter-spacing:3px;text-transform:uppercase;opacity:.8;margin-bottom:10px}
.med-now .pname{font-size:38px;font-weight:800;line-height:1.05}
.med-now .psub{opacity:.85;margin-top:8px;font-size:15px}
.med-now.idle{background:#E2E8F0;color:#64748B}
.med-now .acts{display:flex;gap:10px;justify-content:center;margin-top:18px;flex-wrap:wrap}
.med-now .acts button{background:rgba(255,255,255,.18);color:#fff;border:1px solid rgba(255,255,255,.3);padding:12px 20px;border-radius:12px;font-weight:700;font-size:16px}
.med-now.idle .acts button{background:#fff;color:var(--brand);border-color:var(--line)}
.callnext{width:100%;background:var(--brand);color:#fff;font-size:20px;font-weight:800;padding:18px;border-radius:16px;margin-bottom:18px;box-shadow:0 8px 20px rgba(14,124,123,.3)}
.callnext:disabled{background:#CBD5E1;box-shadow:none}
.qsec-title{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin:6px 4px 10px;font-weight:700}
.qitem{display:flex;align-items:center;gap:12px;padding:14px;border-radius:14px;margin-bottom:8px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow)}
.qitem.prio{border-color:#DDD6FE}
.qitem.called{background:#FFFBEB;border-color:#FDE68A}
.qitem.serving{background:#EFF6FF;border-color:#BFDBFE}
.qitem .qpos{width:34px;height:34px;border-radius:50%;background:var(--brand);color:#fff;font-weight:800;font-size:15px;display:grid;place-items:center;flex:none}
.qitem.prio .qpos{background:var(--prio)}
.qitem .qinfo{flex:1;min-width:0}
.qitem .qname{font-weight:700;font-size:17px}
.qitem .qmeta{font-size:13px;color:var(--muted);margin-top:2px}
.qitem .qtag{font-size:11px;font-weight:700;color:var(--prio);background:#F5F3FF;border-radius:6px;padding:2px 7px;display:inline-block;margin-top:4px}
.qitem .qacts{display:flex;gap:6px;flex:none}
.qitem .qacts button{font-size:14px;font-weight:700;padding:9px 12px;border-radius:10px;background:#F1F5F9;color:var(--ink);border:1px solid var(--line)}
.qitem .qacts button.go{background:var(--brand);color:#fff;border-color:var(--brand)}
.empty-q{text-align:center;color:#94A3B8;padding:24px;font-size:14px}

/* ---------- PAINEL ---------- */
#painel{background:radial-gradient(1200px 600px at 50% -10%, #122036 0%, #0B1220 60%);color:#fff;min-height:100vh;padding:32px 44px 18px;display:flex;flex-direction:column}
.pnl-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px;border-bottom:1px solid rgba(255,255,255,.07);padding-bottom:18px}
.pnl-brand{display:flex;align-items:center;gap:14px}
.pnl-brand .logo{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#14b8a6,#0E7C7B);display:grid;place-items:center;font-size:24px;font-weight:800;color:#04201F}
.pnl-brand .clinic{font-size:24px;font-weight:800;letter-spacing:.3px}
.pnl-brand .clinic small{display:block;font-size:13px;font-weight:500;color:#5EEAD4;letter-spacing:2px;text-transform:uppercase}
.pnl-top .clock{font-size:34px;font-weight:800;font-variant-numeric:tabular-nums;color:#CBD5E1}
.pnl-stage{flex:1;display:flex;flex-direction:column;justify-content:center}
.pnl-lab{font-size:16px;letter-spacing:5px;color:#64748B;text-transform:uppercase;text-align:center;margin-bottom:22px}
.pnl-grid{display:grid;gap:22px;grid-template-columns:1fr}
.pnl-grid.n2{grid-template-columns:1fr 1fr}
.pnl-grid.n3,.pnl-grid.n4{grid-template-columns:1fr 1fr}
.call-card{background:linear-gradient(135deg,rgba(94,234,212,.14),rgba(94,234,212,.03));border:2px solid rgba(94,234,212,.28);border-radius:26px;padding:44px 36px;text-align:center;box-shadow:0 20px 50px rgba(0,0,0,.35)}
.call-card .cname{font-weight:800;line-height:1.02;letter-spacing:.5px}
.call-card .croom{color:#5EEAD4;font-weight:700;margin-top:16px;display:inline-block;background:rgba(94,234,212,.1);border:1px solid rgba(94,234,212,.3);border-radius:14px;padding:8px 22px}
.call-card .ctag{display:inline-block;margin-top:14px;font-size:18px;font-weight:700;color:#C4B5FD;background:rgba(124,58,237,.18);border:1px solid rgba(167,139,250,.4);border-radius:20px;padding:6px 16px}
.pnl-grid.n1 .call-card .cname{font-size:96px}
.pnl-grid.n1 .call-card .croom{font-size:36px}
.pnl-grid.n2 .call-card .cname{font-size:60px}
.pnl-grid.n2 .call-card .croom{font-size:26px}
.pnl-grid.n3 .call-card .cname,.pnl-grid.n4 .call-card .cname{font-size:46px}
.pnl-grid.n3 .call-card .croom,.pnl-grid.n4 .call-card .croom{font-size:22px}
.pnl-idle{text-align:center;color:#475569;font-size:40px;font-weight:700;padding:60px 0}
@keyframes cardflash{0%,100%{border-color:rgba(94,234,212,.28);box-shadow:0 20px 50px rgba(0,0,0,.35)}50%{border-color:#5EEAD4;box-shadow:0 0 0 4px rgba(94,234,212,.35),0 20px 60px rgba(0,0,0,.45)}}
.call-card.flash{animation:cardflash 1s ease-in-out 4}
.pnl-recent{margin-top:22px}
.pnl-recent h3{font-size:14px;color:#64748B;text-transform:uppercase;letter-spacing:2px;margin-bottom:10px}
.pnl-recent .rows{display:flex;gap:10px;flex-wrap:wrap}
.pnl-recent .row{display:flex;align-items:center;gap:10px;font-size:20px;padding:10px 16px;border-radius:12px;background:rgba(255,255,255,.04)}
.pnl-recent .row .r-room{color:#94A3B8;font-size:15px}
.pnl-footer{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding-top:12px;border-top:1px solid rgba(255,255,255,.07);font-size:13px;color:#475569}
.pnl-footer a{color:#5EEAD4;text-decoration:none;font-weight:600}
.soundbtn{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:7px 16px;font-size:13px;font-weight:600}
.soundbtn.on{background:rgba(94,234,212,.15);color:#5EEAD4;border-color:rgba(94,234,212,.4)}
