:root{--bg-dark: #0a1828;--bg-dark-2: #0e2238;--bg-dark-3: #14304d;--ink-on-dark: #f5f7fa;--ink-on-dark-muted: #94a3b8;--bg: #f1f5f9;--bg-2: #e2e8f0;--surface: #ffffff;--surface-2: #f8fafc;--line: #e2e8f0;--line-soft: #f1f5f9;--ink: #0f172a;--ink-2: #334155;--ink-3: #64748b;--ink-4: #94a3b8;--blue: #3b82f6;--blue-2: #2563eb;--blue-soft: #dbeafe;--blue-on-dark:#60a5fa;--critical: #ef4444;--critical-soft: #fee2e2;--critical-dark: #7f1d1d;--stable: #10b981;--stable-soft: #d1fae5;--stable-dark: #065f46;--review: #f59e0b;--review-soft: #fef3c7;--review-dark: #92400e;--orange: #f97316;--orange-soft: #ffedd5;--discharged: #6b7280;--discharged-soft:#e5e7eb;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);--shadow: 0 2px 8px rgba(15, 23, 42, .08);--shadow-lg: 0 12px 32px rgba(15, 23, 42, .18);--r-sm: 8px;--r: 12px;--r-lg: 16px}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100%}body{font-family:Inter,IBM Plex Sans,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,select,textarea{font-family:inherit;font-size:14px;color:var(--ink)}::placeholder{color:var(--ink-4)}a{color:var(--blue);text-decoration:none}.font-display{font-family:Inter,sans-serif;font-weight:600;letter-spacing:-.015em}.font-mono{font-family:IBM Plex Mono,monospace}.app-shell{min-height:100vh;display:flex;flex-direction:column;max-width:520px;margin:0 auto;background:var(--bg);position:relative;box-shadow:0 0 40px #0f172a14}.main{padding:0;display:flex;flex-direction:column;min-width:0;flex:1}.content{padding:14px 14px 80px;flex:1;min-width:0}.app-header{background:var(--bg-dark);color:var(--ink-on-dark);padding:14px 16px 16px;position:sticky;top:0;z-index:50}.app-header .header-top{display:flex;justify-content:space-between;align-items:center;gap:10px}.app-header .brand{font-size:18px;font-weight:700;letter-spacing:-.01em}.app-header .brand .accent{color:var(--blue-on-dark)}.app-header .brand-sub{font-size:11px;color:var(--ink-on-dark-muted);margin-top:2px;letter-spacing:.02em}.app-header .header-right{display:flex;gap:8px;align-items:center}.menu-btn{width:36px;height:36px;border-radius:8px;background:#ffffff14;color:var(--ink-on-dark);display:flex;align-items:center;justify-content:center}.menu-btn:hover{background:#ffffff26}.menu-btn .icon{width:18px;height:18px}.clinic-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:#f59e0b26;color:#fbbf24;border-radius:999px;font-size:11.5px;font-weight:500;border:1px solid rgba(245,158,11,.25)}.clinic-chip .dot{width:6px;height:6px;border-radius:50%;background:#fbbf24}.header-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:16px}.header-stat{text-align:center}.header-stat .value{font-size:26px;font-weight:700;letter-spacing:-.02em;line-height:1.1}.header-stat .label{font-size:10.5px;color:var(--ink-on-dark-muted);margin-top:2px;letter-spacing:.02em}.header-stat.blue .value{color:var(--blue-on-dark)}.header-stat.critical .value{color:#f87171}.header-stat.orange .value{color:#fb923c}.header-stat.review .value{color:#fbbf24}.header-stat.stable .value{color:#34d399}.critical-banner{margin-top:14px;background:#ef44441f;border:1px solid rgba(239,68,68,.35);border-radius:var(--r);padding:10px 12px}.critical-banner .label{font-size:10.5px;font-weight:700;color:#f87171;letter-spacing:.05em;margin-bottom:6px;display:flex;align-items:center;gap:6px}.critical-banner .label .icon{width:14px;height:14px;flex-shrink:0}.critical-banner .patient{background:#7f1d1d66;border-radius:8px;padding:8px 10px;display:flex;justify-content:space-between;align-items:center;gap:8px}.critical-banner .name{font-weight:600;color:#fecaca;font-size:13px}.critical-banner .vitals{font-size:11px;color:#fca5a5;margin-top:2px;font-family:IBM Plex Mono,monospace}.critical-banner .bed{font-size:11px;color:#fca5a5;flex-shrink:0}.tabs{display:flex;gap:0;background:var(--surface);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}.tab{flex:1;padding:14px 12px;text-align:center;font-size:13.5px;font-weight:500;color:var(--ink-3);border-bottom:2px solid transparent;transition:all .15s}.tab.active{color:var(--blue);border-bottom-color:var(--blue);font-weight:600}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:14px;box-shadow:var(--shadow-sm)}.card-title{font-size:14px;font-weight:600;margin:0 0 12px;letter-spacing:-.01em;display:flex;align-items:center;gap:8px}.card-title .icon{width:16px;height:16px}.section-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);font-weight:600;margin-bottom:6px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 14px;border-radius:10px;font-size:13px;font-weight:500;border:1px solid var(--line);background:var(--surface);color:var(--ink);transition:all .15s}.btn:hover,.btn:active{background:var(--bg-2)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--bg-dark);color:#fff;border-color:var(--bg-dark)}.btn-primary:hover,.btn-primary:active{background:var(--bg-dark-2);border-color:var(--bg-dark-2)}.btn-blue{background:var(--blue);color:#fff;border-color:var(--blue)}.btn-blue:hover,.btn-blue:active{background:var(--blue-2);border-color:var(--blue-2)}.btn-stable{background:var(--stable-soft);color:var(--stable-dark);border-color:var(--stable-soft)}.btn-review{background:var(--review-soft);color:var(--review-dark);border-color:var(--review-soft)}.btn-critical{background:var(--critical-soft);color:var(--critical-dark);border-color:var(--critical-soft)}.btn-ghost{background:transparent;border-color:transparent;color:var(--ink-2)}.btn-ghost:hover{background:var(--bg-2)}.btn-danger{color:var(--critical);border-color:var(--critical-soft)}.btn-danger:hover{background:var(--critical-soft)}.btn-sm{padding:6px 10px;font-size:12px;border-radius:8px}.btn-lg{padding:13px 18px;font-size:14px;border-radius:12px}.btn-full{width:100%}.btn .icon{width:14px;height:14px}.btn-lg .icon{width:16px;height:16px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);font-weight:600}.input,.select,.textarea{width:100%;padding:11px 12px;border-radius:10px;border:1px solid var(--line);background:var(--surface);font-size:14px;transition:border-color .15s}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft)}.textarea{resize:vertical;min-height:72px}.select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.search-input{width:100%;padding:11px 14px 11px 38px;background:var(--surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E") 14px center no-repeat;border:1px solid var(--line);border-radius:10px;font-size:14px}.segmented{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;background:var(--bg-2);border-radius:10px;padding:3px;gap:2px}.segmented button{padding:9px 8px;border-radius:8px;font-size:13px;font-weight:500;color:var(--ink-2);transition:all .15s}.segmented button.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.segmented.status button.active.stable{background:var(--stable-soft);color:var(--stable-dark)}.segmented.status button.active.review{background:var(--review-soft);color:var(--review-dark)}.segmented.status button.active.critical{background:var(--critical-soft);color:var(--critical-dark)}.chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.02em;background:var(--bg-2);color:var(--ink-2)}.chip-blue{background:var(--blue-soft);color:var(--blue-2)}.chip-stable{background:var(--stable-soft);color:var(--stable-dark)}.chip-review{background:var(--review-soft);color:var(--review-dark)}.chip-critical{background:var(--critical-soft);color:var(--critical-dark)}.chip-discharged{background:var(--discharged-soft);color:var(--discharged)}.chip-orange{background:var(--orange-soft);color:#c2410c}.status-pill{display:inline-block;padding:4px 12px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.status-pill.stable{background:var(--stable-soft);color:var(--stable-dark)}.status-pill.review{background:var(--review-soft);color:var(--review-dark)}.status-pill.critical{background:var(--critical-soft);color:var(--critical-dark)}.status-pill.discharged{background:var(--discharged-soft);color:var(--discharged)}.status-pill.muted{background:var(--bg-2);color:var(--ink-4)}.status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.status-dot.stable{background:var(--stable)}.status-dot.review{background:var(--review)}.status-dot.critical{background:var(--critical)}.status-dot.discharged{background:var(--discharged)}.patient-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:12px 14px;margin-bottom:10px;display:flex;align-items:flex-start;gap:10px;transition:all .12s;color:inherit}.patient-card:active{transform:scale(.99);background:var(--surface-2)}.patient-card .pc-dot{margin-top:6px}.patient-card .pc-body{flex:1;min-width:0}.patient-card .pc-name{display:flex;align-items:center;gap:6px;font-weight:600;font-size:14.5px;color:var(--ink)}.patient-card .pc-name .age{color:var(--ink-3);font-weight:400;font-size:12.5px}.patient-card .pc-meta{font-size:12.5px;color:var(--ink-2);margin-top:3px;display:flex;gap:4px;flex-wrap:wrap}.patient-card .pc-bed{font-family:IBM Plex Mono,monospace;font-weight:600;color:var(--blue-2);font-size:12.5px}.patient-card .pc-badges{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}.patient-card .pc-side{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.patient-card .pc-tag{font-size:10.5px;color:var(--ink-3)}.patient-card .pc-drips{font-size:11.5px;color:#0369a1;background:#e0f2fe;padding:4px 8px;border-radius:6px;margin-top:8px}.filter-bar{display:flex;gap:8px;align-items:center;margin-bottom:12px}.filter-bar .select{flex:0 1 auto;padding:8px 28px 8px 12px;font-size:12.5px}.filter-bar .btn{margin-left:auto}.patient-header{background:var(--bg-dark);color:var(--ink-on-dark);border-radius:var(--r);padding:16px;margin-bottom:14px}.patient-header .ph-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.patient-header .ph-name{font-size:22px;font-weight:700;letter-spacing:-.02em;color:var(--ink-on-dark)}.patient-header .ph-meta{font-size:12.5px;color:var(--ink-on-dark-muted);margin-top:4px}.patient-header .ph-bed{font-size:14px;font-weight:600;color:var(--blue-on-dark);font-family:IBM Plex Mono,monospace}.patient-header .ph-id{font-size:11px;color:var(--ink-on-dark-muted);margin-top:2px;font-family:IBM Plex Mono,monospace}.patient-header .ph-status-row{display:flex;gap:6px;margin-top:12px;flex-wrap:wrap}.patient-header .ph-status{padding:4px 10px;border-radius:999px;font-size:10.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;background:#ffffff14;color:#ffffff80;border:1px solid rgba(255,255,255,.1)}.patient-header .ph-status.active.stable{background:var(--stable-soft);color:var(--stable-dark);border-color:transparent}.patient-header .ph-status.active.review{background:var(--review-soft);color:var(--review-dark);border-color:transparent}.patient-header .ph-status.active.critical{background:var(--critical-soft);color:var(--critical-dark);border-color:transparent}.patient-header .ph-status.active.discharged{background:var(--discharged-soft);color:var(--discharged);border-color:transparent}.patient-header .ph-edit{background:#ffffff1a;color:var(--ink-on-dark);padding:4px 10px;border-radius:6px;font-size:12px;display:inline-flex;align-items:center;gap:4px;border:1px solid rgba(255,255,255,.1)}.action-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:14px}.action-btn{padding:10px 6px;border-radius:10px;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:4px;border:1px solid;text-align:center}.action-btn.blue{background:var(--blue-soft);color:var(--blue-2);border-color:var(--blue-soft)}.action-btn.stable{background:var(--stable-soft);color:var(--stable-dark);border-color:var(--stable-soft)}.action-btn.review{background:var(--review-soft);color:var(--review-dark);border-color:var(--review-soft)}.action-btn.orange{background:var(--orange-soft);color:#c2410c;border-color:var(--orange-soft)}.vitals-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.vital{background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:10px 12px}.vital .label{font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);font-weight:600}.vital .value{font-size:18px;font-weight:700;margin-top:4px;letter-spacing:-.02em;color:var(--ink)}.vital .unit{font-size:10.5px;color:var(--ink-3);font-weight:400;margin-left:2px}.vital.alert{background:var(--critical-soft);border-color:#ef444433}.vital.alert .value{color:var(--critical)}.vital-input{border:1px solid var(--line);background:var(--surface);border-radius:10px;padding:9px 12px}.vital-input .label{font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);font-weight:600}.vital-input input{width:100%;border:none;background:transparent;padding:2px 0 0;font-size:16px;font-weight:600}.vital-input input:focus{outline:none}.vital-input:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft)}.vitals-trend{width:100%;border-collapse:collapse;font-size:12px}.vitals-trend th{text-align:left;padding:8px 6px;font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);font-weight:600;border-bottom:1px solid var(--line)}.vitals-trend td{padding:8px 6px;border-bottom:1px solid var(--line-soft);color:var(--ink-2);font-family:IBM Plex Mono,monospace}.vitals-trend td.alert{color:var(--critical);font-weight:600}.vitals-trend tr:last-child td{border-bottom:none}.vitals-trend-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:flex-end;justify-content:center;z-index:100;animation:backdrop-in .2s ease-out}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:18px 18px 0 0;padding:18px 16px 24px;width:100%;max-width:520px;max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:sheet-in .25s cubic-bezier(.16,1,.3,1)}@keyframes sheet-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.modal-title{font-size:17px;font-weight:700;margin:0;letter-spacing:-.01em}.modal-close{width:30px;height:30px;border-radius:8px;background:var(--bg-2);color:var(--ink-2);display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--line)}.modal-actions{display:flex;gap:8px;margin-top:16px}.modal-actions .btn{flex:1}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;z-index:90;animation:backdrop-in .2s}.drawer{position:fixed;top:0;right:0;bottom:0;width:280px;max-width:85vw;background:var(--bg-dark);color:var(--ink-on-dark);z-index:91;padding:18px 16px;display:flex;flex-direction:column;gap:4px;animation:drawer-in .25s cubic-bezier(.16,1,.3,1)}@keyframes drawer-in{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-brand{padding:4px 8px 16px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:12px}.drawer-brand .name{font-size:17px;font-weight:700}.drawer-brand .sub{font-size:11px;color:var(--ink-on-dark-muted);margin-top:2px;letter-spacing:.03em}.drawer .nav-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;color:#ffffffbf;font-size:14px;font-weight:500;width:100%;text-align:left;transition:all .12s}.drawer .nav-item:hover{background:#ffffff0f;color:#fff}.drawer .nav-item.active{background:var(--blue);color:#fff}.drawer .nav-item .icon{width:18px;height:18px;flex-shrink:0}.drawer-footer{margin-top:auto;padding-top:14px;border-top:1px solid rgba(255,255,255,.1);font-size:11.5px;color:var(--ink-on-dark-muted)}.qr-holder{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:14px;display:inline-block;text-align:center}.qr-holder canvas,.qr-holder img{display:block}.qr-label{font-family:IBM Plex Mono,monospace;font-size:11px;color:var(--ink-3);margin-top:8px;letter-spacing:.04em}.toast-host{position:fixed;bottom:80px;left:50%;transform:translate(-50%);z-index:200;display:flex;flex-direction:column;gap:8px;width:calc(100% - 32px);max-width:460px}.toast{background:var(--bg-dark);color:#fff;padding:11px 16px;border-radius:10px;font-size:13px;box-shadow:var(--shadow-lg);animation:toast-in .2s ease-out}.toast.success{background:var(--stable)}.toast.error{background:var(--critical)}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.empty-state{text-align:center;padding:40px 20px;color:var(--ink-3)}.empty-state .title{font-size:15px;color:var(--ink-2);margin-bottom:4px;font-weight:600}.med-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:var(--surface);margin-bottom:8px}.med-item:hover{border-color:var(--blue)}.med-item.constant{border-left:3px solid var(--stable)}.med-item-info{flex:1;min-width:0}.med-item-info .name{font-weight:600;font-size:13.5px}.med-item-info .dose{font-size:12px;color:var(--ink-3);margin-top:2px}.med-item-actions{display:flex;gap:4px}.rx-list{display:flex;flex-direction:column;gap:8px}.rx-row{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:10px;display:grid;gap:6px}.rx-row.constant{border-left:3px solid var(--stable);background:var(--stable-soft)}.rx-row .rx-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.rx-row input{border:1px solid var(--line);background:var(--surface);padding:7px 9px;border-radius:7px;font-size:13px;width:100%}.rx-row input:focus{border-color:var(--blue);outline:none}.rx-row .rx-name{grid-column:span 2;font-weight:500}.visit-item{border-left:2px solid var(--line);padding:0 0 18px 18px;position:relative;margin-left:6px}.visit-item:before{content:"";position:absolute;left:-6px;top:4px;width:10px;height:10px;border-radius:50%;background:var(--blue);border:2px solid var(--surface)}.visit-item:last-child{border-left-color:transparent}.visit-card{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:12px}.visit-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;flex-wrap:wrap;gap:6px}.visit-date{font-size:14px;font-weight:600}.visit-id{font-family:IBM Plex Mono,monospace;font-size:11px;color:var(--ink-3)}.hr{height:1px;background:var(--line);margin:14px 0;border:none}.hr-soft{height:1px;background:var(--line-soft);margin:12px 0;border:none}.banner-warn{background:var(--review-soft);color:var(--review-dark);padding:10px 16px;font-size:12.5px;border-bottom:1px solid var(--review)}.back-link{display:inline-flex;align-items:center;gap:4px;color:var(--blue);font-size:13.5px;font-weight:500;padding:6px 0;margin-bottom:8px}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.grid{display:grid}.grid-cols-2{grid-template-columns:1fr 1fr}.grid-cols-3{grid-template-columns:1fr 1fr 1fr}.mt-0{margin-top:0}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.w-full{width:100%}.text-sm{font-size:12.5px}.text-xs{font-size:11.5px}.text-muted{color:var(--ink-3)}.text-soft{color:var(--ink-2)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.rounded{border-radius:8px}.hidden{display:none!important}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--ink-4)}#qr-reader{border-radius:10px;overflow:hidden}#qr-reader video{border-radius:10px}.loading-screen{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--bg);z-index:1000;flex-direction:column;gap:12px}.spinner{width:28px;height:28px;border:3px solid var(--line);border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (min-width: 640px){.app-shell{max-width:600px}.content{padding:16px 18px 80px}.vitals-grid{grid-template-columns:repeat(4,1fr)}}@media (min-width: 1024px){.app-shell{max-width:720px}.vitals-grid{grid-template-columns:repeat(4,1fr)}}.opd-sheet{background:#fff;width:210mm;min-height:297mm;padding:20mm 18mm;margin:0 auto;font-family:IBM Plex Sans,sans-serif;color:#111;position:relative}.opd-sheet .header{text-align:center;padding-bottom:12px;border-bottom:2px solid #111;margin-bottom:14px}.opd-sheet .clinic-name{font-size:26px;font-weight:700;letter-spacing:-.02em;margin:0}.opd-sheet .clinic-sub{font-size:11px;color:#555;margin-top:2px;letter-spacing:.04em;text-transform:uppercase}.opd-sheet .doctor-line{font-size:12.5px;margin-top:8px}.opd-sheet .patient-block{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:12px;padding:10px 0;border-bottom:1px solid #888;font-size:12.5px}.opd-sheet .patient-block .label{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:#888;font-weight:600}.opd-sheet .patient-block .val{font-weight:500;margin-top:2px}.opd-sheet .vitals-row{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;padding:8px 0;border-bottom:1px solid #ccc;font-size:11.5px}.opd-sheet .vitals-row .label{font-size:9.5px;text-transform:uppercase;letter-spacing:.1em;color:#888;font-weight:600}.opd-sheet .vitals-row .val{font-weight:600;margin-top:2px;font-size:13px}.opd-sheet .sect{margin-top:14px}.opd-sheet .sect-label{font-size:10px;text-transform:uppercase;letter-spacing:.12em;font-weight:700;color:#333;margin-bottom:4px;border-bottom:1px dotted #888;padding-bottom:2px}.opd-sheet .sect-body{font-size:13px;line-height:1.55}.opd-sheet .rx-symbol{font-size:30px;font-weight:700;color:#111;float:left;margin:-4px 10px 0 0;line-height:1}.opd-sheet .rx-table{width:100%;border-collapse:collapse;font-size:12.5px}.opd-sheet .rx-table th,.opd-sheet .rx-table td{text-align:left;padding:5px 6px;border-bottom:1px solid #ddd}.opd-sheet .rx-table th{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:#555;font-weight:700;border-bottom:1px solid #888}.opd-sheet .rx-table .constant-marker{display:inline-block;width:6px;height:6px;border-radius:50%;background:#10b981;margin-right:5px;vertical-align:middle}.opd-sheet .footer{position:absolute;bottom:20mm;left:18mm;right:18mm;display:flex;justify-content:space-between;align-items:flex-end;padding-top:16px;border-top:1px solid #888;font-size:11px;color:#555}.opd-sheet .sign-line{border-top:1px solid #111;padding-top:4px;min-width:180px;text-align:center;font-size:11px}.opd-sheet .qr-block{text-align:center}.opd-sheet .qr-block .qr-id{font-family:IBM Plex Mono,monospace;font-size:10px;margin-top:4px;letter-spacing:.04em}.opd-sheet.sheet{padding:14mm 14mm 18mm;font-family:IBM Plex Sans,Arial,sans-serif;font-size:12px;color:#111}.opd-sheet.sheet .sheet-head{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:1px solid #999;padding-bottom:10px}.opd-sheet.sheet .sheet-clinic{font-size:18px;font-weight:700;color:#111;letter-spacing:-.01em}.opd-sheet.sheet .sheet-clinic-sub{font-size:11px;color:#444;margin-top:2px}.opd-sheet.sheet .sheet-meta-line{font-size:11px;color:#333;margin-top:6px}.opd-sheet.sheet .sheet-head-right{text-align:right;min-width:180px}.opd-sheet.sheet .sheet-doctor{font-weight:700;font-size:14px}.opd-sheet.sheet .sheet-doctor-sub{font-size:10.5px;color:#444}.opd-sheet.sheet .sheet-consult{background:#f1eef8;padding:6px 10px;margin:10px 0 8px;text-align:center;font-size:13px;border:1px solid #d6cde8}.opd-sheet.sheet .sheet-patient{display:flex;justify-content:space-between;align-items:baseline;font-size:12.5px;margin-top:4px}.opd-sheet.sheet .sheet-patient strong{font-size:13px}.opd-sheet.sheet .sheet-date{color:#333;font-size:12px}.opd-sheet.sheet .sheet-patient-sub{display:flex;justify-content:space-between;font-size:11px;color:#555;margin-top:2px;border-bottom:1px solid #ccc;padding-bottom:6px}.opd-sheet.sheet .sheet-allergy{margin:8px 0;padding:5px 8px;background:#fce8df;border-left:3px solid #b53a1f;font-size:11.5px}.opd-sheet.sheet .sheet-line{margin:8px 0;font-size:12px;line-height:1.5}.opd-sheet.sheet .sheet-label{font-weight:700;color:#6a3aa8;text-transform:uppercase;letter-spacing:.04em;margin-right:6px}.opd-sheet.sheet .sheet-section-title{text-align:center;color:#6a3aa8;font-weight:700;text-decoration:underline;margin:14px 0 6px;font-size:13px}.opd-sheet.sheet .sheet-rx{width:100%;border-collapse:collapse;font-size:11.5px;border:1px solid #888}.opd-sheet.sheet .sheet-rx th,.opd-sheet.sheet .sheet-rx td{border:1px solid #aaa;padding:6px 8px;vertical-align:top;text-align:left}.opd-sheet.sheet .sheet-rx th{background:#f1eef8;font-weight:700;font-size:11px}.opd-sheet.sheet .sheet-rx-sub{font-size:10px;color:#555;margin-top:2px}.opd-sheet.sheet .sheet-foot{display:flex;justify-content:space-between;align-items:flex-end;margin-top:26px;border-top:1px solid #999;padding-top:8px}.opd-sheet.sheet .sheet-disclaimer{font-size:10.5px;color:#888}.opd-sheet.sheet .sheet-page{font-size:10.5px;color:#555;margin-top:2px;font-weight:600}.opd-sheet.sheet .sheet-sign{text-align:center;min-width:180px}.opd-sheet.sheet .sheet-sign-line{border-top:1px solid #111;margin-bottom:4px;height:36px}.opd-sheet.sheet .sheet-sign-name{font-size:12px;font-weight:600}@media print{body{background:#fff}.app-shell{box-shadow:none;max-width:100%}.app-header,.tabs,.no-print,.drawer,.drawer-backdrop{display:none!important}.content{padding:0}.opd-sheet{margin:0;border:none;box-shadow:none;page-break-inside:avoid}@page{size:A4;margin:0}}
