:root{--bg: #0b1220;--bg-2: #111a2e;--card: #18223b;--line: #25304d;--text: #e7ecf6;--muted: #8a96b3;--accent: #22d3ee;--accent-2: #06b6d4;--green: #10b981;--red: #ef4444;--amber: #f59e0b}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{margin:0;padding:0;width:100%;height:100%;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,Roboto,system-ui,sans-serif;overscroll-behavior:none;overflow:hidden;position:fixed;top:0;left:0}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit;font-size:16px}a{color:var(--accent)}.app{max-width:460px;margin:0 auto;height:100%;display:flex;flex-direction:column;position:relative;background:var(--bg);overflow:hidden;padding-top:env(safe-area-inset-top)}@media (min-width: 600px){html,body,#root{position:static;overflow:auto;height:auto;min-height:100%}body{background:#050810;padding:24px 0}.app{height:auto;min-height:90vh;max-height:900px;border-radius:28px;box-shadow:0 30px 80px #0009;border:1px solid #1a2236;padding-top:0}}.topbar{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 12px}.brand{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.3px}.brand .dot{width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--accent)}.brand .brand-mark{width:24px;height:24px;object-fit:contain;flex-shrink:0}.brand-wordmark{display:block;max-width:200px;height:auto;margin:0 auto 18px}.brand .small{font-size:11px;color:var(--muted);font-weight:500}.net{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:6px}.net .pulse{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}.net.offline .pulse{background:var(--red);box-shadow:0 0 8px var(--red)}.screen{flex:1 1 0;min-height:0;display:flex;flex-direction:column;padding:8px 20px 20px;overflow-y:auto;-webkit-overflow-scrolling:touch}.screen h1{margin:0 0 6px;font-size:26px}.screen h2{margin:8px 0 14px;font-size:18px}.sub{color:var(--muted);font-size:14px;margin:0 0 18px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.field input,.field select{background:var(--card);border:1px solid var(--line);color:var(--text);padding:14px 16px;border-radius:12px;outline:none}.field input:focus,.field select:focus{border-color:var(--accent)}.btn-primary{background:linear-gradient(180deg,var(--accent),var(--accent-2));color:#062028;border:none;padding:16px;border-radius:14px;font-size:16px;font-weight:700;letter-spacing:.3px;box-shadow:0 6px 20px #22d3ee40}.btn-primary:disabled{opacity:.5;box-shadow:none}.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--line);padding:14px;border-radius:12px;font-size:14px}.btn-danger{background:#ef444426;color:var(--red);border:1px solid var(--red);padding:14px;border-radius:12px;font-size:14px}.scanner-wrap{position:relative;flex:1 1 0;min-height:0;background:#000;overflow:hidden}#reader{width:100%!important;height:100%!important;position:relative!important;padding:0!important;border:0!important}#reader>*{width:100%!important;height:100%!important}#reader video{width:100%!important;height:100%!important;object-fit:cover!important;display:block}.reader-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--muted);gap:12px;padding:20px;text-align:center;background:linear-gradient(180deg,#0b1220,#04070d)}.reader-placeholder .icon{font-size:56px;opacity:.85}.scan-overlay{position:absolute;inset:0;pointer-events:none;display:flex;align-items:center;justify-content:center}.scan-frame{width:70%;aspect-ratio:1/1;max-width:280px;border-radius:24px;position:relative}.scan-frame:before,.scan-frame:after,.scan-frame>.br:before,.scan-frame>.br:after{content:"";position:absolute;width:32px;height:32px;border-color:var(--accent);border-style:solid;border-width:0}.scan-frame:before{top:0;left:0;border-top-width:4px;border-left-width:4px;border-top-left-radius:18px}.scan-frame:after{top:0;right:0;border-top-width:4px;border-right-width:4px;border-top-right-radius:18px}.scan-frame>.br{position:absolute;inset:0}.scan-frame>.br:before{bottom:0;left:0;border-bottom-width:4px;border-left-width:4px;border-bottom-left-radius:18px;top:auto}.scan-frame>.br:after{bottom:0;right:0;border-bottom-width:4px;border-right-width:4px;border-bottom-right-radius:18px;top:auto}.scan-line{position:absolute;left:8%;right:8%;height:2px;top:10%;background:linear-gradient(90deg,transparent,var(--accent),transparent);box-shadow:0 0 12px var(--accent);animation:scan 2.4s ease-in-out infinite}@keyframes scan{0%{top:10%}50%{top:86%}to{top:10%}}.hint{position:absolute;left:0;right:0;bottom:18px;text-align:center;color:#cbd5e1;font-size:13px;text-shadow:0 1px 4px rgba(0,0,0,.6)}.scan-status{position:absolute;top:16px;left:50%;transform:translate(-50%);background:#02060e99;backdrop-filter:blur(6px);border:1px solid var(--line);color:var(--text);padding:8px 14px;border-radius:999px;font-size:12px}.controls{display:flex;flex-shrink:0;gap:10px;padding:14px 16px;background:var(--bg-2);border-top:1px solid var(--line)}.controls button{flex:1;background:var(--card);color:var(--text);border:1px solid var(--line);padding:14px;border-radius:12px;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px}.controls button svg{font-size:18px;flex-shrink:0}.controls button.primary{background:linear-gradient(180deg,var(--accent),var(--accent-2));color:#062028;border-color:transparent}.controls button:disabled{opacity:.5}.quickbar{display:flex;flex-shrink:0;justify-content:space-around;padding:10px 16px 12px;background:var(--bg-2)}.quick{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--muted);font-size:11px;background:transparent;border:none;padding:6px 12px;min-width:0;max-width:50%}.quick .num{font-size:18px;font-weight:700;color:var(--text)}.quick .num.branch-name{font-size:14px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quick.active .num{color:var(--accent)}.sheet-mask{position:absolute;inset:0;background:#02060eb3;backdrop-filter:blur(4px);display:flex;align-items:flex-end;z-index:30}.sheet{width:100%;background:var(--bg-2);border-top-left-radius:24px;border-top-right-radius:24px;padding:22px 22px calc(22px + env(safe-area-inset-bottom));border-top:1px solid var(--line);animation:sheet-up .25s ease;max-height:85vh;overflow-y:auto}@keyframes sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet h2{margin:0 0 4px;font-size:22px}.sheet .booking{color:var(--muted);font-size:13px;margin-bottom:16px}.pat-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px;margin-bottom:14px}.pat-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dashed var(--line);font-size:14px;gap:12px}.pat-row:last-child{border-bottom:none}.pat-row .k{color:var(--muted);flex-shrink:0}.pat-row .v{color:var(--text);font-weight:600;text-align:right}.pat-name{font-size:18px;font-weight:700;margin-bottom:2px}.pat-mrn{color:var(--muted);font-size:12px;margin-bottom:12px}.actions{display:flex;gap:10px}.btn-confirm{flex:2;background:var(--green);border:none;color:#04241a;padding:16px;border-radius:14px;font-size:16px;font-weight:700}.btn-cancel{flex:1;background:var(--card);border:1px solid var(--line);color:var(--text);padding:16px;border-radius:14px;font-weight:600}.toast{position:absolute;left:50%;top:80px;transform:translate(-50%);background:var(--card);border:1px solid var(--line);padding:12px 16px;border-radius:12px;color:var(--text);font-size:14px;z-index:50;box-shadow:0 10px 30px #00000080;max-width:90%;text-align:center;animation:pop .25s ease}.toast.success{border-color:var(--green)}.toast.error{border-color:var(--red)}.toast.info{border-color:var(--accent)}@keyframes pop{0%{opacity:0;transform:translate(-50%,-10px)}to{opacity:1;transform:translate(-50%)}}.tabs{display:flex;flex-shrink:0;background:var(--bg-2);border-top:1px solid var(--line);padding:4px 4px max(6px,calc(env(safe-area-inset-bottom)*.6))}.tab{flex:1;background:none;border:none;color:var(--muted);padding:6px 4px 4px;font-size:11px;display:flex;flex-direction:column;align-items:center;gap:3px}.tab.active{color:var(--accent)}.tab .ico{font-size:22px}.tab svg.ico{display:block}.recent-item{display:flex;justify-content:space-between;align-items:center;padding:14px;background:var(--card);border:1px solid var(--line);border-radius:14px;margin-bottom:10px;gap:10px}.recent-item .l{min-width:0}.recent-item .l .name{font-weight:600;font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recent-item .l .meta{color:var(--muted);font-size:12px;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge{font-size:11px;padding:4px 10px;border-radius:999px;font-weight:600;flex-shrink:0}.badge.ok{background:#10b98126;color:var(--green)}.badge.err{background:#ef444426;color:var(--red)}.modal-mask{position:absolute;inset:0;background:#02060eb3;display:flex;align-items:center;justify-content:center;z-index:40;padding:20px}.modal{background:var(--bg-2);border:1px solid var(--line);border-radius:18px;padding:22px;width:100%;max-width:360px}.modal h3{margin:0 0 12px;font-size:18px}.modal input,.modal select{width:100%;background:var(--card);border:1px solid var(--line);color:var(--text);padding:14px;border-radius:12px;outline:none;margin-bottom:14px}.modal input:focus,.modal select:focus{border-color:var(--accent)}.modal .row{display:flex;gap:10px}.list-row{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--card);border:1px solid var(--line);border-radius:12px;margin-bottom:8px;gap:12px}.list-row .l{min-width:0}.list-row .l .t{font-weight:600;font-size:15px}.list-row .l .d{color:var(--muted);font-size:12px;margin-top:2px}.toggle{position:relative;width:50px;height:28px;background:var(--line);border-radius:999px;flex-shrink:0;cursor:pointer;transition:background .18s}.toggle.on{background:var(--accent)}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:24px;height:24px;border-radius:50%;background:#fff;transition:transform .18s}.toggle.on:after{transform:translate(22px)}.branch-pill{display:inline-flex;align-items:center;gap:6px;background:#22d3ee1f;color:var(--accent);border:1px solid rgba(34,211,238,.4);border-radius:999px;padding:4px 10px;font-size:11px;font-weight:600}.branch-pill svg{flex-shrink:0}.empty{text-align:center;color:var(--muted);padding:60px 20px}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.2);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
