:root{--brand: #0e7c7b;--accent: #f59e0b;--bg: #f4f6f8;--card: #ffffff;--text: #1e2433;--muted: #6b7280;--border: #e5e7eb;--danger: #dc2626;--ok: #2f855a}*{box-sizing:border-box}html,body{margin:0}body{font-family:ui-sans-serif,system-ui,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);-webkit-text-size-adjust:100%}#root{min-height:100vh;display:flex;flex-direction:column}a{color:var(--brand)}img{max-width:100%}.muted{color:var(--muted)}.small{font-size:12px}.ltr{direction:ltr;unicode-bidi:isolate}.strong{font-weight:700}.auth-shell{flex:1;display:grid;place-items:center;padding:32px 16px}.auth-card{background:var(--card);border-radius:12px;box-shadow:0 4px 24px #0e7c7b1a;padding:28px;width:100%;max-width:380px}.auth-brand{display:flex;align-items:center;gap:12px}.auth-brand h1{margin:0;color:var(--brand);font-size:24px;letter-spacing:.5px}.auth-logo{display:grid;place-items:center;height:44px;width:44px;border-radius:10px;background:var(--brand);color:#fff;font-size:24px;font-weight:700}.auth-card form{display:flex;flex-direction:column;gap:12px;margin-top:18px}.auth-card label{display:flex;flex-direction:column;gap:4px;font-size:13px}.auth-card input{font-size:16px;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:#fff}.auth-card input:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}.auth-card button[type=submit]{margin-top:4px;background:var(--brand);color:#fff;border:none;border-radius:8px;padding:12px 16px;font-size:15px;font-weight:600;cursor:pointer}.auth-card button[type=submit]:disabled{opacity:.6;cursor:default}.auth-card details{margin-top:16px;font-size:13px;color:var(--muted)}.auth-card details ul{margin:8px 0 0;padding-left:20px}.shell{flex:1;display:flex;flex-direction:column;min-height:100vh}.shell-header{background:var(--brand);color:#fff;padding:10px 16px;display:flex;align-items:center;gap:12px}.brand{display:inline-flex;align-items:center;gap:8px;color:#fff;font-weight:700;letter-spacing:.4px;text-decoration:none;font-size:16px;margin-right:auto}.brand-logo{height:28px;width:28px;object-fit:contain;border-radius:6px;background:#fff;padding:2px}.brand-name{color:#fff;white-space:nowrap}.shell-header-right{display:flex;align-items:center;gap:10px}.btn-ghost{background:#ffffff1f;color:#fff;border:1px solid rgba(255,255,255,.28);border-radius:8px;padding:6px 12px;font-size:13px;cursor:pointer}.btn-ghost:hover{background:#ffffff38}.hamburger{display:none;place-items:center;width:40px;height:40px;background:#ffffff1f;color:#fff;border:1px solid rgba(255,255,255,.28);border-radius:8px;font-size:18px;cursor:pointer}.shell-body{flex:1;display:flex;align-items:stretch}.sidebar{width:220px;flex-shrink:0;background:#fff;border-right:1px solid var(--border);padding:16px 12px;display:flex;flex-direction:column}.sidebar-nav{display:flex;flex-direction:column;gap:4px;flex:1}.sidebar-nav a{display:block;color:var(--text);text-decoration:none;font-size:14px;padding:10px 12px;border-radius:8px;border:1px solid transparent}.sidebar-nav a:hover{background:#f1f5f9}.sidebar-nav a.active{background:#0e7c7b1f;border-color:#0e7c7b66;color:var(--brand);font-weight:600}.sidebar-backdrop{display:none}.nav-group{display:flex;flex-direction:column;gap:4px}.nav-group-header{display:flex;align-items:center;justify-content:space-between;width:100%;min-height:44px;padding:10px 12px;font-size:14px;color:var(--text);background:none;border:1px solid transparent;border-radius:8px;cursor:pointer;text-align:left}.nav-group-header:hover{background:#f1f5f9}.nav-chevron{display:inline-block;font-size:16px;line-height:1;color:var(--muted);transition:transform .18s ease}.nav-chevron.open{transform:rotate(90deg)}.nav-group-items{display:flex;flex-direction:column;gap:4px;padding-left:10px}.nav-bottom{margin-top:auto;display:flex;flex-direction:column;gap:4px;padding-top:8px;border-top:1px solid var(--border)}.nav-logout{display:block;width:100%;text-align:left;font-size:14px;padding:10px 12px;border-radius:8px;border:1px solid transparent;background:none;color:var(--text);cursor:pointer}.nav-logout:hover{background:#f1f5f9}.shell-main{flex:1;min-width:0;max-width:960px;width:100%;margin:0 auto;padding:24px 24px 64px;display:flex;flex-direction:column}.page-head{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px}.page-head h1{margin:0;color:var(--brand);font-size:22px}.badge{display:inline-block;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#fff}.role-owner{background:var(--brand)}.role-doctor{background:#1d4ed8}.role-receptionist{background:#6b7280}.badge-link{text-decoration:none;cursor:pointer;transition:filter .15s ease}.badge-link:hover,.badge-link:focus-visible{filter:brightness(1.12);outline:none}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin:8px 0 20px}.dash-card{display:flex;flex-direction:column;gap:4px;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:16px 18px;text-decoration:none;color:inherit;transition:box-shadow .15s,border-color .15s}.dash-card:hover{box-shadow:0 4px 16px #0e7c7b1a;border-color:var(--brand)}.dash-card-title{font-weight:600;color:var(--brand)}.stage-note{margin-top:8px}.form{display:flex;flex-direction:column;gap:16px}.form-section{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:16px 20px}.form-section h2{margin:0 0 12px;color:var(--brand);font-size:15px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px 16px}.form-grid .span-2{grid-column:span 2}.form-grid label{display:flex;flex-direction:column;gap:4px;font-size:12px}.form-grid input,.form-grid select,.form-grid textarea{padding:9px 11px;font-size:14px;border:1px solid var(--border);border-radius:8px;background:#fff;font-family:inherit}.form-grid input:focus,.form-grid select:focus,.form-grid textarea:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}.form-grid textarea{resize:vertical}.form-grid input:disabled{background:#f8fafc;color:var(--muted)}.field-error{color:var(--danger);font-size:12px;display:block;margin-top:2px}.error{background:#fef2f2;color:var(--danger);border:1px solid #fecaca;padding:10px 12px;border-radius:8px;font-size:13px}.banner{padding:10px 14px;border-radius:8px;font-size:13px}.banner-ok{background:#d1fae5;color:#065f46;border:1px solid #6ee7b7}.form-actions{display:flex;justify-content:flex-end;gap:12px}.btn-primary{background:var(--brand);color:#fff;border:none;border-radius:8px;padding:10px 18px;font-size:14px;font-weight:600;cursor:pointer}.btn-primary:hover{filter:brightness(1.08)}.btn-primary:disabled{opacity:.6;cursor:default}.form-actions .btn-ghost{background:#fff;color:var(--text);border:1px solid var(--border)}.form-actions .btn-ghost:hover{background:#f1f5f9}.color-picker-row{display:flex;gap:8px;align-items:center}.color-picker-row input[type=color]{width:48px;height:38px;border:1px solid var(--border);border-radius:8px;background:#fff;cursor:pointer;padding:2px}.color-hex{flex:1;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;text-transform:uppercase}.system-info-grid{display:grid;grid-template-columns:140px 1fr;row-gap:8px;column-gap:16px;margin:0}.system-info-grid dt{color:var(--muted);font-size:13px}.system-info-grid dd{margin:0;font-size:14px}.back-button{align-self:flex-start;display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--brand);border:1px solid var(--border);border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;margin-bottom:12px;min-height:40px}.back-button:hover{background:#f8fafc;border-color:var(--brand)}.back-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.back-arrow{font-size:16px;line-height:1}.app-footer{margin-top:auto;padding-top:24px;display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)}.app-footer-sep{opacity:.5}.app-footer-link{color:var(--brand);text-decoration:none}.app-footer-link:hover{text-decoration:underline}@media (hover: none) and (pointer: coarse){.btn-primary,.btn-ghost,.back-button,input,select,textarea{min-height:44px}input,select,textarea{font-size:16px}}@media (max-width: 640px){.hamburger{display:grid}.sidebar{position:fixed;top:0;left:0;bottom:0;width:240px;z-index:60;transform:translate(-100%);transition:transform .2s ease;box-shadow:0 0 32px #0f172a40;padding-top:64px}.sidebar.mobile-open{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;z-index:55}.brand-name{font-size:14px;overflow:hidden;text-overflow:ellipsis}.shell-header-right .badge{max-width:42vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shell-main{padding:16px 14px 80px}.page-head{flex-direction:column;align-items:stretch;gap:8px}.page-head h1{font-size:18px}.form-grid{grid-template-columns:1fr}.form-grid .span-2{grid-column:span 1}}.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:14px;flex-wrap:wrap}.search-input{flex:1;min-width:180px;padding:10px 12px;font-size:16px;border:1px solid var(--border);border-radius:8px;background:#fff}.search-input:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}.data-table{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--border);border-radius:10px;overflow:hidden}.data-table th,.data-table td{padding:10px 12px;text-align:left;font-size:14px;border-bottom:1px solid var(--border)}.data-table th{background:#f8fafc;color:var(--muted);text-transform:uppercase;font-size:11px;letter-spacing:.5px}.data-table tbody tr{cursor:pointer}.data-table tbody tr:hover{background:#f8fafc}.num{text-align:right;font-variant-numeric:tabular-nums}.empty{padding:28px 16px;text-align:center;color:var(--muted);background:var(--card);border:1px dashed var(--border);border-radius:10px}.loading{display:flex;align-items:center;gap:10px;padding:20px 4px}.route-fallback{display:grid;place-items:center;min-height:60vh}.spinner{display:inline-block;width:18px;height:18px;border-radius:50%;border:2px solid rgba(14,124,123,.25);border-top-color:var(--brand);animation:spin .7s linear infinite}.spinner-lg{width:34px;height:34px;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){.spinner{animation-duration:1.6s}}.att-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-top:8px}.att-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:46px;padding:4px;gap:2px;border:1px solid var(--border);border-radius:8px;background:#fff;cursor:pointer;font-family:inherit}.att-cell:disabled{opacity:.6;cursor:default}.att-day{font-size:11px;color:var(--muted)}.att-mark{font-size:15px;font-weight:700;line-height:1}.att-present{background:#0e7c7b1f;border-color:#0e7c7b66}.att-present .att-mark{color:var(--brand)}.att-absent{background:#dc262614;border-color:#dc262659}.att-absent .att-mark{color:var(--danger)}.att-leave{background:#2563eb14;border-color:#2563eb59}.att-leave .att-mark{color:#1d4ed8}.att-half{background:#ca8a041a;border-color:#ca8a0466}.att-half .att-mark{color:#a16207}.att-disabled{background:#f1f5f9;border-style:dashed;opacity:.55}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:16px}.sheet{background:var(--card);border-radius:12px;padding:18px;width:100%;max-width:360px;box-shadow:0 8px 40px #0f172a4d}.sheet h3{color:var(--brand);font-size:16px}.sheet-options{display:flex;flex-direction:column;gap:8px}.sheet-options .btn-primary,.sheet-options .btn-ghost{width:100%}.sheet-opt{background:#fff;color:var(--text);border:1px solid var(--border)}.sheet-opt:hover{background:#f1f5f9;filter:none}@media (max-width: 640px){.sheet-backdrop{align-items:flex-end;padding:0}.sheet{max-width:none;border-radius:14px 14px 0 0;padding-bottom:24px}}.fab{position:fixed;right:20px;bottom:20px;width:56px;height:56px;border-radius:50%;background:var(--brand);color:#fff;font-size:30px;line-height:56px;text-align:center;text-decoration:none;box-shadow:0 4px 16px #0f172a47;z-index:50}.fab:hover{filter:brightness(1.08)}.fab:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.pager{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:14px}.pager .btn-ghost{background:#fff;color:var(--text);border:1px solid var(--border)}.pager .btn-ghost:disabled{opacity:.5;cursor:default}.balance-pill{display:inline-flex;flex-direction:column;gap:2px;padding:12px 18px;border-radius:10px;background:#0e7c7b14;border:1px solid rgba(14,124,123,.3)}.balance-pill .label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}.balance-pill .value{font-size:22px;font-weight:700;color:var(--brand);font-variant-numeric:tabular-nums}.balance-pill.owing{background:#dc26260f;border-color:#dc26264d}.balance-pill.owing .value{color:var(--danger)}.kv{display:grid;grid-template-columns:130px 1fr;row-gap:8px;column-gap:14px;margin:0}.kv dt{color:var(--muted);font-size:13px}.kv dd{margin:0;font-size:14px}.entry-debit{color:var(--danger);font-weight:600}.entry-credit{color:var(--ok);font-weight:600}.inline-form{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}.inline-form label{display:flex;flex-direction:column;gap:4px;font-size:12px}.inline-form input,.inline-form select{padding:9px 11px;font-size:14px;border:1px solid var(--border);border-radius:8px;background:#fff;font-family:inherit}@media (max-width: 640px){.data-table,.data-table thead,.data-table tbody,.data-table tr,.data-table td{display:block}.data-table{border:none;background:transparent}.data-table thead{display:none}.data-table tr{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:10px 14px;margin-bottom:8px}.data-table td{display:flex;justify-content:space-between;gap:12px;row-gap:6px;flex-wrap:wrap;padding:4px 0;border:none;text-align:right}.data-table td.num{text-align:right}.data-table td[data-label=Actions]{justify-content:flex-start}.data-table td[data-label=Actions] .btn-primary,.data-table td[data-label=Actions] .btn-ghost{margin-bottom:4px}.data-table td:before{content:attr(data-label);color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.5px;font-weight:600;text-align:left}.kv{grid-template-columns:1fr}.kv dt{margin-top:6px}.inline-form{flex-direction:column;align-items:stretch}}.rx-line{display:grid;grid-template-columns:1.6fr .8fr .8fr .8fr 1.4fr auto;gap:8px;align-items:center;padding:8px 0;border-bottom:1px solid var(--border)}.rx-line input{padding:8px 10px;font-size:14px;border:1px solid var(--border);border-radius:8px;background:#fff;width:100%}.rx-line-actions{display:flex;gap:4px}.rx-line-actions button{border:1px solid var(--border);background:#fff;border-radius:6px;padding:4px 8px;cursor:pointer;font-size:13px}@media (max-width: 640px){.rx-line{grid-template-columns:1fr 1fr}}.print-screen{background:#e9edf0;min-height:100vh;padding:16px}.print-toolbar{max-width:800px;margin:0 auto 14px;display:flex;justify-content:space-between;gap:10px}.rx-sheet{background:#fff;max-width:800px;margin:0 auto;padding:28px 32px;box-shadow:0 2px 16px #0000001f;min-height:60vh}.rx-header{border-bottom:3px solid var(--brand);padding-bottom:12px;margin-bottom:14px}.rx-brand{display:flex;gap:14px;align-items:center}.rx-logo{height:56px;width:56px;object-fit:contain}.rx-header h1{margin:0;font-size:22px}.rx-sub{font-size:12px;color:#444}.rx-meta{display:grid;grid-template-columns:1fr 1fr;gap:4px 24px;font-size:14px;margin-bottom:10px}.rx-label{color:#666}.rx-symbol{font-size:34px;font-weight:700;line-height:1;margin:4px 0 8px}.rx-table{width:100%;border-collapse:collapse;font-size:14px}.rx-table th,.rx-table td{text-align:left;padding:7px 8px;border-bottom:1px solid #e5e7eb;vertical-align:top}.rx-table th{font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:#666}.rx-drug{font-weight:600}.rx-advice{margin-top:16px}.rx-advice h3{margin:0 0 4px;font-size:14px}.rx-advice p{margin:0;font-size:14px;white-space:pre-wrap}.rx-followup{margin-top:14px;font-size:14px}.rx-footer{margin-top:48px;display:flex;justify-content:flex-end}.rx-sign{text-align:center;font-size:13px}.rx-sign-line{width:180px;border-top:1px solid #333;margin-bottom:4px}.cert-body{margin:18px 0 8px;font-size:15px;line-height:1.7}.cert-body p{margin:0}.logo-upload-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.logo-preview{height:48px;width:48px;object-fit:contain;border:1px solid var(--border);border-radius:6px;background:#fff;padding:2px}.receipt-sheet{max-width:600px}.receipt-title{font-size:18px;margin:8px 0 14px}.receipt-amount{display:flex;justify-content:space-between;align-items:center;border:2px solid var(--brand);border-radius:8px;padding:12px 16px;margin:16px 0 8px;font-size:16px}.receipt-amount strong{font-size:24px;font-variant-numeric:tabular-nums}.receipt-balance{font-size:14px}.bill-badge{font-size:11px;color:var(--ok);font-weight:600}.src-visit_charge{color:var(--danger)}.src-payment{color:var(--ok)}.src-discount{color:#7c3aed}.src-adjustment{color:var(--muted)}.pay-void{text-decoration:line-through;opacity:.6}.bar-row{display:grid;grid-template-columns:140px 1fr 120px;gap:10px;align-items:center;margin:6px 0}.bar-label{font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar-track{background:#eef2f4;border-radius:6px;height:16px;overflow:hidden}.bar-fill{background:var(--brand);height:100%;border-radius:6px;min-width:2px}.bar-right{font-size:13px;text-align:right;font-variant-numeric:tabular-nums}@media (max-width: 640px){.bar-row{grid-template-columns:1fr;gap:2px}.bar-right{text-align:left}}@media print{@page{size:A4;margin:14mm}.print-screen{background:#fff;padding:0}.no-print{display:none!important}.rx-sheet{box-shadow:none;margin:0;max-width:none;padding:0;min-height:0}.shell-header,.sidebar,.app-footer{display:none!important}.rx-table{page-break-inside:auto}.rx-table tr{page-break-inside:avoid}.rx-table thead{display:table-header-group}}.video-join{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--bg, #f4f6f8)}.video-join-card{width:100%;max-width:440px;background:#fff;border:1px solid var(--border, #e2e6ea);border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000000f;text-align:center}.video-join-card h1{font-size:20px;margin:4px 0 12px}.video-join-clinic{font-weight:600;color:var(--brand, #0E7C7B);text-transform:uppercase;letter-spacing:.04em;font-size:13px;margin:0}.video-join-meta{line-height:1.6;margin:0 0 16px}.video-join-note{text-align:left;background:#f7f9fa;border:1px solid var(--border, #e2e6ea);border-radius:8px;padding:14px 16px}.video-join-note p{margin:0 0 6px}.video-join-note p:last-child{margin-bottom:0}.video-join-note-ok{background:#eefcf6;border-color:#b6e8d4}.video-call{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;background:#000}.video-call-bar{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#111;color:#fff;flex:0 0 auto}.video-call-hint{font-size:12px;color:#cbd5e1}.video-call-frame{flex:1 1 auto;width:100%;border:0}.video-call-msg{flex:1 1 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:#fff;text-align:center;padding:24px}
