:root{--nf-primary:#1e40af;--nf-primary-dark:#1e3a8a;--nf-primary-soft:#1e40af24;--nf-accent:#0f766e;--nf-bg:#f6f8f9;--nf-bg-alt:#eef2f3;--nf-surface:#fff;--nf-border:#e3e8ea;--nf-border-strong:#cbd5d8;--nf-text:#0f172a;--nf-text-muted:#475569;--nf-text-faint:#94a3b8;--nf-danger:#b91c1c;--nf-danger-soft:#fef2f2;--nf-danger-border:#fecaca;--nf-success:#15803d;--nf-warning:#b45309;--nf-warning-soft:#fffbeb;--nf-warning-border:#fde68a;--nf-shadow-sm:0 1px 2px #0f172a0f;--nf-shadow:0 4px 16px #0f172a14;--nf-sans:system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;font-family:var(--nf-sans);color:var(--nf-text);background:var(--nf-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{min-height:100vh;margin:0;padding:0}body{background:var(--nf-bg)}button{cursor:pointer;font-family:inherit}input,textarea,select{font:inherit;color:inherit}a{color:var(--nf-primary)}:root{--emr-primary:var(--nf-primary);--emr-primary-dark:var(--nf-primary-dark);--emr-primary-light:#dbeafe;--emr-surface:var(--nf-surface);--emr-bg:var(--nf-bg);--emr-border:var(--nf-border);--emr-border-strong:var(--nf-border-strong);--emr-text-primary:var(--nf-text);--emr-text-secondary:var(--nf-text-muted);--emr-text-muted:var(--nf-text-faint);--emr-accent:var(--nf-accent);--emr-accent-light:#f0fdfa;--emr-error:var(--nf-danger);--emr-success:var(--nf-success);--emr-warn:var(--nf-warning);--emr-shadow-sm:0 1px 2px #0000000d;--emr-shadow:0 1px 3px #00000014, 0 1px 2px #0000000f;--emr-shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--emr-radius:6px;--emr-radius-lg:8px}.login-shell{background:linear-gradient(135deg, var(--nf-bg) 0%, var(--nf-bg-alt) 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--nf-surface);border:1px solid var(--nf-border);border-radius:16px;width:100%;max-width:400px;padding:36px 32px;box-shadow:0 12px 40px #0f172a1f}.login-brand{text-align:center;margin-bottom:28px}.login-logo{letter-spacing:3px;color:var(--nf-surface);background:var(--nf-primary);border-radius:8px;margin-bottom:16px;padding:6px 14px;font-size:13px;font-weight:800;display:inline-block}.login-title{color:var(--nf-text);margin:0 0 4px;font-size:22px;font-weight:700}.login-subtitle{color:var(--nf-text-muted);margin:0;font-size:13px}.login-form{flex-direction:column;gap:16px;display:flex}.login-field{flex-direction:column;gap:6px;display:flex}.login-label{color:var(--nf-text-muted);font-size:12px;font-weight:600}.login-field input{box-sizing:border-box;border:1px solid var(--nf-border);background:var(--nf-bg);width:100%;color:var(--nf-text);border-radius:9px;padding:11px 12px;font-size:14px;transition:border-color .15s,box-shadow .15s}.login-field input:focus{border-color:var(--nf-primary);box-shadow:0 0 0 3px var(--nf-primary-soft);outline:none}.login-password-wrap{align-items:center;display:flex;position:relative}.login-password-wrap input{padding-right:58px}.login-toggle{color:var(--nf-primary);cursor:pointer;background:0 0;border:none;padding:4px 6px;font-size:12px;font-weight:600;position:absolute;right:8px}.login-error{color:var(--nf-danger);background:var(--nf-danger-soft);border:1px solid var(--nf-danger-border);border-radius:8px;padding:9px 11px;font-size:13px}.login-submit{width:100%;color:var(--nf-surface);background:var(--nf-primary);cursor:pointer;border:none;border-radius:9px;margin-top:4px;padding:12px;font-size:14px;font-weight:600;transition:background .15s,opacity .15s}.login-submit:hover:not(:disabled){background:var(--nf-primary-dark)}.login-submit:disabled{opacity:.65;cursor:not-allowed}.login-foot{text-align:center;color:var(--nf-text-faint);margin:22px 0 0;font-size:12px}.dash{background:var(--emr-bg);flex-direction:column;min-height:100vh;display:flex}.dash-topbar{background:var(--emr-surface);width:100%;box-shadow:0 1px 0 var(--emr-border);z-index:1000;flex-shrink:0;position:sticky;top:0}.dash-topbar-inner{justify-content:space-between;align-items:center;gap:16px;max-width:1400px;margin:0 auto;padding:6px 24px;display:flex}.dash-logo-pill{background:var(--emr-primary);border-radius:var(--emr-radius);align-items:center;gap:8px;padding:5px 12px;text-decoration:none;transition:background .15s;display:flex}.dash-logo-pill:hover{background:var(--emr-primary-dark)}.dash-logo-pill-text{color:#fff;letter-spacing:.3px;font-size:13px;font-weight:700}.dash-topbar-right{align-items:center;gap:8px;display:flex}.dash-search{background:var(--emr-surface);border:1px solid var(--emr-border-strong);border-radius:var(--emr-radius);color:var(--emr-text-muted);align-items:center;gap:6px;width:320px;padding:5px 10px;transition:border-color .15s,box-shadow .15s;display:flex}.dash-search:focus-within{border-color:var(--emr-primary);box-shadow:0 0 0 2px var(--emr-primary-light)}.dash-search svg{flex-shrink:0}.dash-search input{color:var(--emr-text-primary);background:0 0;border:none;outline:none;flex:1;font-size:12px;font-weight:500}.dash-search input::placeholder{color:var(--emr-text-muted);font-weight:400}.dash-search-clear{background:var(--emr-bg);width:18px;height:18px;color:var(--emr-text-muted);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:10px;transition:background .12s,color .12s;display:flex}.dash-search-clear:hover{background:var(--emr-border-strong);color:var(--emr-text-primary)}.dash-main{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:16px 24px 32px}.dash-section-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:12px;display:flex}.dash-section-head-left{min-width:0}.dash-h1{letter-spacing:-.2px;color:var(--emr-text-primary);margin:0 0 2px;font-size:14px;font-weight:600}.dash-sub{color:var(--emr-text-muted);margin:0;font-size:11px}.dash-count{background:var(--emr-primary-light);color:var(--emr-primary);border-radius:10px;margin-left:6px;padding:1px 7px;font-size:10px;font-weight:600;display:inline-block}.dash-date-filter{flex-shrink:0;position:relative}.dash-date-chip{border-radius:var(--emr-radius);border:1px solid var(--emr-border-strong);background:var(--emr-surface);color:var(--emr-text-primary);cursor:pointer;white-space:nowrap;align-items:center;gap:5px;padding:5px 12px;font-size:12px;font-weight:500;transition:all .15s;display:flex}.dash-date-chip:hover{background:var(--emr-bg);border-color:var(--emr-primary);color:var(--emr-primary)}.dash-date-chip--active,.dash-date-chip--open{background:var(--emr-primary-light);border-color:var(--emr-primary);color:var(--emr-primary)}.dash-chip-arrow{color:var(--emr-text-muted);transition:transform .2s}.dash-chip-arrow--up{transform:rotate(180deg)}.cal-popup{background:var(--emr-surface);border:1px solid var(--emr-border);border-radius:var(--emr-radius-lg);z-index:500;width:256px;animation:.12s cal-appear;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden;box-shadow:0 8px 24px #0f172a1f,0 2px 6px #0f172a0f}@keyframes cal-appear{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.cal-header{border-bottom:1px solid var(--emr-border);justify-content:space-between;align-items:center;padding:10px 12px 8px;display:flex}.cal-month-title{color:var(--emr-text-primary);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.cal-nav-btn{color:var(--emr-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:3px;justify-content:center;align-items:center;min-width:22px;height:22px;padding:3px 6px;font-size:13px;transition:background .1s,color .1s;display:flex}.cal-nav-btn:hover{background:var(--emr-bg);color:var(--emr-primary)}.cal-grid{grid-template-columns:repeat(7,1fr);gap:1px;padding:8px 10px 6px;display:grid}.cal-weekday{text-align:center;color:var(--emr-text-muted);text-transform:uppercase;letter-spacing:.3px;padding:2px 0;font-size:9px;font-weight:600}.cal-day{aspect-ratio:1;color:var(--emr-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:3px;flex-direction:column;justify-content:center;align-items:center;gap:1px;font-size:11px;font-weight:500;transition:background .1s,color .1s;display:flex;position:relative}.cal-day:hover{background:var(--emr-bg);color:var(--emr-primary)}.cal-day--today{color:var(--emr-primary);background:#eff6ff;font-weight:700}.cal-day--today:hover{background:var(--emr-primary-light)}.cal-day--appt{background:var(--emr-accent-light);color:var(--emr-accent);border:1px solid #99f6e4;font-weight:700}.cal-day--appt:hover{border-color:var(--emr-accent);background:#ccfbf1}.cal-day--selected{background:var(--emr-primary)!important;color:#fff!important;border:none!important;font-weight:700!important}.cal-day--selected:hover{background:var(--emr-primary-dark)!important}.cal-dot{background:var(--emr-accent);border-radius:50%;width:4px;height:4px;display:block;position:absolute;bottom:2px;left:50%;transform:translate(-50%)}.cal-day--selected .cal-dot{display:none}.cal-footer{border-top:1px solid var(--emr-border);gap:6px;padding:8px 10px 10px;display:flex}.cal-footer-btn{border-radius:var(--emr-radius);border:1px solid var(--emr-border-strong);background:var(--emr-surface);color:var(--emr-text-primary);cursor:pointer;flex:1;padding:5px 0;font-size:11px;font-weight:500;transition:all .15s}.cal-footer-btn:hover{background:var(--emr-bg);border-color:var(--emr-primary);color:var(--emr-primary)}.cal-footer-btn--muted{color:var(--emr-text-muted)}.cal-footer-btn--muted:hover{color:var(--emr-text-primary);border-color:var(--emr-border-strong)}.dash-state{text-align:center;background:var(--emr-surface);border:1px solid var(--emr-border);border-radius:var(--emr-radius-lg);box-shadow:var(--emr-shadow);color:var(--emr-text-muted);padding:40px 24px;font-size:12px;font-weight:500}.dash-state--error{color:var(--emr-error);background:#fef2f2;border-color:#fecaca}.dash-state--empty{color:var(--emr-text-muted)}.appt-table-wrap{background:var(--emr-surface);border:1px solid var(--emr-border);border-radius:var(--emr-radius-lg);box-shadow:var(--emr-shadow);overflow:hidden}.appt-table{border-collapse:collapse;width:100%;font-size:13px}.appt-table thead tr{background:var(--emr-bg);border-bottom:1px solid var(--emr-border)}.appt-table th{text-align:left;color:var(--emr-text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;padding:10px 16px;font-size:10px;font-weight:600}.appt-table th.col-action{text-align:right}.appt-row{border-bottom:1px solid var(--emr-border);background:var(--emr-surface);cursor:pointer;border-left:2px solid #0000;transition:background .1s}.appt-row:last-child{border-bottom:none}.appt-row:hover{border-left-color:var(--emr-primary);background:#f8fafc}.appt-table td{vertical-align:middle;padding:12px 16px}.col-patient{min-width:130px}.col-doctor{min-width:120px;color:var(--emr-text-secondary);font-size:12px}.col-time{width:96px}.col-date{width:148px}.col-reason{min-width:140px;max-width:220px}.col-action{text-align:right;width:140px}.appt-patient-name{color:var(--emr-text-primary);font-size:13px;font-weight:600}.appt-time-badge{background:var(--emr-accent-light);color:var(--emr-accent);white-space:nowrap;border:1px solid #99f6e4;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:700;display:inline-block}.appt-date-btn{border-radius:var(--emr-radius);color:var(--emr-text-secondary);cursor:pointer;background:0 0;border:1px solid #0000;align-items:center;gap:5px;margin:-3px -7px;padding:3px 7px;font-size:12px;font-weight:500;transition:all .15s;display:inline-flex}.appt-date-btn svg{color:var(--emr-text-muted);flex-shrink:0}.appt-date-btn:hover{background:var(--emr-primary-light);border-color:var(--emr-primary);color:var(--emr-primary)}.appt-date-btn:hover svg{color:var(--emr-primary)}.appt-reason-text{text-overflow:ellipsis;white-space:nowrap;color:var(--emr-text-secondary);max-width:200px;font-size:12px;display:block;overflow:hidden}.appt-reason-empty{color:var(--emr-text-muted)}.appt-record-btn{border-radius:var(--emr-radius);border:1px solid var(--emr-border-strong);background:var(--emr-surface);color:var(--emr-text-primary);cursor:pointer;white-space:nowrap;align-items:center;gap:4px;padding:4px 12px;font-size:11px;font-weight:500;transition:all .15s;display:inline-flex}.appt-record-btn:hover{background:var(--emr-bg);border-color:var(--emr-primary);color:var(--emr-primary)}.appt-record-btn:active{background:var(--emr-primary-light)}@media (width<=1200px){.dash-main{padding:12px 16px 24px}.dash-topbar-inner{padding:6px 16px}}@media (width<=768px){.col-doctor,.col-reason{display:none}.dash-search{width:220px}}@media (width<=600px){.dash-topbar-inner{padding:6px 12px}.dash-main{padding:10px 12px 20px}.dash-search{width:160px}}.dash-brand{flex-shrink:0;align-items:center;gap:10px;display:flex}.dash-brand-mark{letter-spacing:2px;color:var(--nf-surface);background:var(--nf-primary);border-radius:6px;padding:4px 9px;font-size:11px;font-weight:800}.dash-brand-text{color:var(--nf-text);font-size:14px;font-weight:600}.dash-user{flex-shrink:0;align-items:center;gap:12px;display:flex}.dash-user-name{color:var(--nf-text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:13px;font-weight:600;overflow:hidden}.dash-logout{border:1px solid var(--nf-border-strong);background:var(--nf-surface);color:var(--nf-text-muted);border-radius:8px;padding:7px 12px;font-size:12px;font-weight:600;transition:background .15s,color .15s,border-color .15s}.dash-logout:hover{background:var(--nf-danger-soft);border-color:var(--nf-danger-border);color:var(--nf-danger)}.dash-ticket-btn{border:1px solid var(--nf-primary);background:var(--nf-primary);color:var(--nf-surface);white-space:nowrap;border-radius:8px;padding:7px 12px;font-size:12px;font-weight:600;transition:background .15s}.dash-ticket-btn:hover{background:var(--nf-primary-dark)}.vit{background:var(--emr-bg);flex-direction:column;min-height:100vh;display:flex}.vit-topbar{background:var(--emr-surface);width:100%;box-shadow:0 1px 0 var(--emr-border);z-index:1000;flex-shrink:0;position:sticky;top:0}.vit-topbar-inner{grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;max-width:1100px;height:48px;margin:0 auto;padding:0 24px;display:grid}.vit-back{border-radius:var(--emr-radius);border:1px solid var(--emr-border-strong);background:var(--emr-surface);color:var(--emr-text-primary);justify-self:start;align-items:center;gap:4px;padding:5px 12px;font-size:12px;font-weight:500;transition:all .15s;display:inline-flex}.vit-back:hover{background:var(--emr-bg);border-color:var(--emr-primary);color:var(--emr-primary)}.vit-back:active{background:var(--emr-primary-light)}.vit-brand-pill{background:var(--emr-primary);border-radius:var(--emr-radius);align-items:center;gap:8px;padding:5px 12px;display:flex}.vit-brand-pill-text{color:#fff;letter-spacing:.3px;font-size:13px;font-weight:700}.vit-topbar-right{justify-self:end}.vit-saved{color:var(--emr-success);background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;padding:3px 10px;font-size:11px;font-weight:600}.vit-main{flex-direction:column;gap:12px;width:100%;max-width:1100px;margin:0 auto;padding:16px 24px 40px;display:flex}.vit-patient{background:var(--emr-surface);border:1px solid var(--emr-border);border-radius:var(--emr-radius-lg);box-shadow:var(--emr-shadow);justify-content:space-between;align-items:flex-start;gap:16px;padding:14px 18px;display:flex;position:relative;overflow:hidden}.vit-patient:before{content:"";background:var(--emr-primary);border-radius:var(--emr-radius-lg) var(--emr-radius-lg) 0 0;height:2px;position:absolute;top:0;left:0;right:0}.vit-patient-name{letter-spacing:-.2px;color:var(--emr-text-primary);font-size:15px;font-weight:700}.vit-patient-meta{color:var(--emr-text-muted);flex-wrap:wrap;gap:6px;margin-top:3px;font-size:11px;font-weight:500;display:flex}.vit-dot{color:var(--emr-border-strong)}.vit-reason{color:var(--emr-text-secondary);margin-top:6px;font-size:12px}.vit-reason strong{color:var(--emr-text-muted);margin-right:4px;font-weight:600}.vit-reason--special{color:var(--emr-warn)}.vit-status{letter-spacing:.3px;border-radius:10px;flex-shrink:0;align-items:center;padding:3px 9px;font-size:10px;font-weight:600;line-height:1.4;display:inline-flex}.vit-status--existing{color:var(--emr-success);background:#f0fdf4;border:1px solid #bbf7d0}.vit-status--new{color:#92400e;background:#fffbeb;border:1px solid #fde68a}.vit-mode-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.vit-mode-toggle{background:var(--emr-surface);border:1px solid var(--emr-border);border-radius:var(--emr-radius-lg);gap:2px;padding:3px;display:inline-flex}.vit-mode-btn{color:var(--emr-text-muted);border-radius:var(--emr-radius);background:0 0;border:none;padding:5px 14px;font-size:12px;font-weight:500;transition:background .12s,color .12s}.vit-mode-btn.active{background:var(--emr-primary);color:#fff;font-weight:600}.vit-mode-hint{color:var(--emr-text-muted);margin:0;font-size:12px}.vit-capture{background:var(--emr-surface);border:1px solid var(--emr-border);border-radius:var(--emr-radius-lg);box-shadow:var(--emr-shadow);flex-direction:column;align-items:center;gap:14px;padding:24px;display:flex}.vit-mic{background:var(--emr-primary-light);width:80px;height:80px;color:var(--emr-primary);cursor:pointer;border-radius:50%;place-items:center;transition:transform .12s,background .12s;display:grid}.vit-mic:hover{transform:scale(1.04)}.vit-mic--on{color:var(--emr-error);background:#fee2e2;animation:1.4s ease-in-out infinite vit-pulse}@keyframes vit-pulse{0%,to{box-shadow:0 0 #b91c1c59}50%{box-shadow:0 0 0 14px #b91c1c00}}.vit-capture-text{color:var(--emr-text-muted);font-size:12px;font-weight:500}.vit-upload-btn{background:var(--emr-surface);border:1px dashed var(--emr-border-strong);border-radius:var(--emr-radius-lg);color:var(--emr-text-muted);padding:12px 20px;font-size:12px;font-weight:600;transition:border-color .15s,color .15s}.vit-upload-btn:hover{border-color:var(--emr-primary);color:var(--emr-primary)}.vit-file-row{background:var(--emr-bg);border:1px solid var(--emr-border);border-radius:var(--emr-radius-lg);align-items:center;gap:10px;padding:8px 12px;display:flex}.vit-file-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.vit-file-name{color:var(--emr-text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:600;overflow:hidden}.vit-file-size{color:var(--emr-text-muted);font-size:11px}.vit-fields{background:var(--emr-surface);border:1px solid var(--emr-border);border-radius:var(--emr-radius-lg);box-shadow:var(--emr-shadow);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;padding:16px;display:grid}.vit-field{flex-direction:column;gap:5px;display:flex}.vit-field-label{color:var(--emr-text-primary);text-transform:uppercase;letter-spacing:.4px;flex-direction:column;gap:1px;font-size:11px;font-weight:600;display:flex}.vit-field-hint{color:var(--emr-text-muted);text-transform:none;letter-spacing:0;font-size:10px;font-weight:400}.vit-field-input{border:1px solid var(--emr-border-strong);border-radius:var(--emr-radius);background:var(--emr-surface);align-items:stretch;transition:border-color .15s,box-shadow .15s;display:flex;overflow:hidden}.vit-field-input:focus-within{border-color:var(--emr-primary);box-shadow:0 0 0 2px var(--emr-primary-light)}.vit-field-input input{background:0 0;border:none;outline:none;flex:1;min-width:0;padding:8px 10px;font-size:13px}.vit-field-input--ftIn{gap:0}.vit-field-input--ftIn input{text-align:center;max-width:60px}.vit-field-input--ftIn .vit-field-unit{border-right:1px solid var(--emr-border-strong);padding:0 8px}.vit-field-input--ftIn .vit-field-unit:last-child{border-right:none}.vit-field-input--readonly{background:var(--emr-bg);cursor:default}.vit-field-input--readonly input{cursor:default;color:var(--emr-text-secondary)}.vit-field-unit{color:var(--emr-text-muted);background:var(--emr-bg);border-left:1px solid var(--emr-border);place-items:center;padding:0 10px;font-size:11px;font-weight:600;display:grid}.vit-blood-group-wrap{flex:1;align-items:stretch;display:flex;position:relative}.vit-blood-group-wrap:after{content:"";background-color:var(--emr-text-muted);clip-path:polygon(0 0,100% 0,50% 100%);pointer-events:none;width:10px;height:6px;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.vit-blood-group-select{color:inherit;cursor:pointer;appearance:none;background:0 0;border:none;outline:none;flex:1;width:100%;padding:8px 32px 8px 10px;font-size:13px}.vit-blood-group-select.is-placeholder{color:var(--emr-text-muted)}.vit-blood-group-select option{color:initial}.vit-actions{justify-content:flex-end;gap:8px;display:flex}.vit-primary-btn{background:var(--emr-primary);color:#fff;border-radius:var(--emr-radius);border:none;align-items:center;gap:4px;padding:7px 16px;font-size:12px;font-weight:600;transition:background .15s;display:inline-flex}.vit-primary-btn:hover:not(:disabled){background:var(--emr-primary-dark)}.vit-primary-btn:disabled{opacity:.6;cursor:not-allowed}.vit-primary-btn--lg{padding:9px 22px;font-size:13px}.vit-secondary-btn{background:var(--emr-surface);color:var(--emr-text-primary);border:1px solid var(--emr-border-strong);border-radius:var(--emr-radius);align-items:center;gap:4px;padding:7px 16px;font-size:12px;font-weight:500;transition:all .15s;display:inline-flex}.vit-secondary-btn:hover:not(:disabled){background:var(--emr-bg);border-color:var(--emr-primary);color:var(--emr-primary)}.vit-secondary-btn:disabled{opacity:.6;cursor:not-allowed}.vit-hwb-card{background:var(--emr-surface);border:1px solid var(--emr-border);border-radius:var(--emr-radius-lg);box-shadow:var(--emr-shadow);padding:16px 20px}.vit-hwb-title{text-transform:uppercase;letter-spacing:.5px;color:var(--emr-text-muted);margin-bottom:12px;font-size:11px;font-weight:700}.vit-hwb-row{flex-wrap:wrap;gap:28px;display:flex}.vit-hwb-item{flex-direction:column;align-items:flex-start;gap:1px;min-width:72px;display:flex}.vit-hwb-value{letter-spacing:-.5px;color:var(--emr-text-primary);font-size:22px;font-weight:700;line-height:1}.vit-hwb-unit{color:var(--emr-text-muted);margin-top:1px;font-size:10px;font-weight:600}.vit-hwb-label{color:var(--emr-text-secondary);margin-top:4px;font-size:11px;font-weight:500}.vit-hwb-cat{border-radius:8px;margin-top:4px;padding:2px 7px;font-size:10px;font-weight:700}.vit-hwb-bmi--low{color:#0369a1}.vit-hwb-bmi--normal{color:var(--emr-success)}.vit-hwb-bmi--high{color:#d97706}.vit-hwb-bmi--very-high{color:var(--emr-error)}.vit-hwb-cat.vit-hwb-bmi--low{background:#e0f2fe}.vit-hwb-cat.vit-hwb-bmi--normal{background:#f0fdf4}.vit-hwb-cat.vit-hwb-bmi--high{background:#fffbeb}.vit-hwb-cat.vit-hwb-bmi--very-high{background:#fef2f2}.vit-special-alert{border-radius:var(--emr-radius-lg);color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-left:3px solid #f59e0b;align-items:flex-start;gap:9px;padding:12px 16px;font-size:12px;display:flex}.vit-special-alert svg{color:#f59e0b;flex-shrink:0;margin-top:1px}.vit-special-alert strong{margin-right:4px;font-weight:700}.vit-error{color:var(--emr-error);font-size:12px;font-weight:500}.vit-error--block{border:1px solid #fecaca;border-left:3px solid var(--emr-error);border-radius:var(--emr-radius);background:#fef2f2;padding:10px 12px}.vit-brand{justify-content:center;align-items:center;display:flex}.vit-brand-mark{letter-spacing:2px;color:var(--nf-surface);background:var(--nf-primary);border-radius:6px;padding:4px 9px;font-size:11px;font-weight:800}:root{--emr-primary:#1e40af;--emr-primary-dark:#1e3a8a;--emr-primary-light:#dbeafe;--emr-primary-bg:#eff6ff;--emr-success:#15803d;--emr-error:#b91c1c;--emr-error-bg:#fef2f2;--emr-error-border:#fecaca;--emr-surface:#fff;--emr-bg:#f1f5f9;--emr-surface-light:#f8fafc;--emr-text:#0f172a;--emr-text-sec:#475569;--emr-text-muted:#94a3b8;--emr-border:#e2e8f0;--emr-border-strong:#cbd5e1;--emr-radius:6px;--emr-radius-lg:8px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 1px 3px #00000014, 0 1px 2px #0000000f;--shadow-lg:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d}.tk-page{background:var(--emr-bg);flex-direction:column;min-height:100vh;display:flex}.tk-topbar{background:var(--emr-surface);border-bottom:1px solid var(--emr-border);box-shadow:var(--shadow-sm);z-index:50;position:sticky;top:0}.tk-topbar-inner{justify-content:space-between;align-items:center;max-width:760px;height:48px;margin:0 auto;padding:0 24px;display:flex}.tk-logo{align-items:center;gap:8px;display:flex}.tk-logo-mark{color:var(--emr-primary);letter-spacing:.5px;font-size:13px;font-weight:700}.tk-logo-sep{color:var(--emr-border-strong)}.tk-logo-title{color:var(--emr-text-sec);font-size:13px;font-weight:500}.tk-helptext{color:var(--emr-text-muted);font-size:12px}.tk-helptext strong{color:var(--emr-text-sec);font-weight:600}.tk-content{flex:1;width:100%;max-width:760px;margin:0 auto;padding:28px 24px 48px}.tk-progress-wrap{justify-content:center;margin-bottom:20px;display:flex}.tk-progress{align-items:center;display:flex}.tk-step{color:var(--emr-text-muted);align-items:center;gap:8px;font-size:13px;font-weight:500;display:flex}.tk-step.active{color:var(--emr-primary)}.tk-step.done{color:var(--emr-success)}.tk-step-circle{border:2px solid var(--emr-border-strong);background:var(--emr-surface);width:28px;height:28px;color:var(--emr-text-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:600;transition:background .2s,border-color .2s;display:flex}.tk-step.active .tk-step-circle{border-color:var(--emr-primary);background:var(--emr-primary);color:#fff}.tk-step.done .tk-step-circle{border-color:var(--emr-success);background:var(--emr-success);color:#fff}.tk-progress-line{background:var(--emr-border);flex-shrink:0;width:72px;height:2px;margin:0 12px;transition:background .3s}.tk-progress-line.done{background:var(--emr-success)}.tk-card{background:var(--emr-surface);border:1px solid var(--emr-border);border-radius:var(--emr-radius-lg);box-shadow:var(--shadow-md);animation:.3s fadeUp;overflow:hidden}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.tk-card-header{border-bottom:1px solid var(--emr-border);background:var(--emr-surface-light);padding:18px 24px 14px}.tk-card-title{color:var(--emr-text);margin-bottom:3px;font-size:15px;font-weight:700}.tk-card-subtitle{color:var(--emr-text-sec);font-size:12px}.tk-form{flex-direction:column;gap:16px;padding:20px 24px 24px;display:flex}.tk-field-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.tk-field{flex-direction:column;gap:4px;display:flex;position:relative}.tk-label{color:var(--emr-text-sec);text-transform:uppercase;letter-spacing:.8px;justify-content:space-between;align-items:center;font-size:10px;font-weight:600;display:flex}.tk-label-note,.tk-label-optional,.tk-char-count{color:var(--emr-text-muted);text-transform:none;letter-spacing:0;font-size:10px;font-weight:400}.tk-input{border:1px solid var(--emr-border-strong);border-radius:var(--emr-radius);background:var(--emr-surface);height:40px;color:var(--emr-text);outline:none;width:100%;padding:0 12px;font-family:inherit;font-size:13px;transition:border-color .15s,box-shadow .15s}.tk-input::placeholder{color:var(--emr-text-muted)}.tk-input:focus{border-color:var(--emr-primary);box-shadow:0 0 0 3px #1e40af14}.tk-input.error{border-color:var(--emr-error);box-shadow:0 0 0 3px #b91c1c0f}.tk-input[type=date]{cursor:pointer}.tk-textarea{border:1px solid var(--emr-border-strong);border-radius:var(--emr-radius);background:var(--emr-surface);color:var(--emr-text);resize:vertical;outline:none;width:100%;min-height:100px;padding:10px 12px;font-family:inherit;font-size:13px;line-height:1.6;transition:border-color .15s,box-shadow .15s}.tk-textarea::placeholder{color:var(--emr-text-muted)}.tk-textarea:focus{border-color:var(--emr-primary);box-shadow:0 0 0 3px #1e40af14}.tk-textarea.error{border-color:var(--emr-error)}.tk-hint{color:var(--emr-text-sec);font-size:11px}.tk-error{color:var(--emr-error);font-size:11px}.tk-avail-days{gap:6px;margin-bottom:6px;display:flex}.tk-day-badge{letter-spacing:.3px;-webkit-user-select:none;user-select:none;border-radius:4px;padding:3px 8px;font-size:11px;font-weight:600}.tk-day-badge.avail{color:#15803d;background:#dcfce7;border:1px solid #bbf7d0}.tk-day-badge.unavail{color:#94a3b8;opacity:.6;background:#f1f5f9;border:1px solid #e2e8f0;text-decoration:line-through}.tk-dropdown{position:relative}.tk-dropdown.disabled .tk-dropdown-trigger{background:var(--emr-bg);color:var(--emr-text-muted);cursor:not-allowed;border-color:var(--emr-border)}.tk-dropdown.error .tk-dropdown-trigger{border-color:var(--emr-error)}.tk-dropdown-trigger{border:1px solid var(--emr-border-strong);border-radius:var(--emr-radius);background:var(--emr-surface);cursor:pointer;outline:none;justify-content:space-between;align-items:center;width:100%;height:40px;padding:0 12px;font-family:inherit;font-size:13px;transition:border-color .15s,box-shadow .15s;display:flex}.tk-dropdown-trigger:hover:not(:disabled),.tk-dropdown-trigger:focus{border-color:var(--emr-primary)}.tk-val{color:var(--emr-text);font-weight:500}.tk-placeholder{color:var(--emr-text-muted)}.tk-chevron{color:var(--emr-text-muted);flex-shrink:0;transition:transform .15s}.tk-chevron.open{transform:rotate(180deg)}.tk-menu{background:var(--emr-surface);border:1px solid var(--emr-border);border-radius:var(--emr-radius-lg);z-index:200;animation:.12s menuDrop;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden;box-shadow:0 8px 24px #0000001a,0 2px 8px #0000000f}@keyframes menuDrop{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.tk-menu-item{border:none;border-bottom:1px solid var(--emr-border);cursor:pointer;width:100%;color:var(--emr-text);text-align:left;background:0 0;justify-content:space-between;align-items:center;padding:10px 12px;font-family:inherit;font-size:13px;transition:background .1s;display:flex}.tk-menu-item:last-child{border-bottom:none}.tk-menu-item:hover{background:var(--emr-surface-light)}.tk-menu-item.selected{background:var(--emr-primary-bg);color:var(--emr-primary);font-weight:600}.tk-menu-item.doctor-item{align-items:flex-start}.tk-doc-info{flex-direction:column;gap:2px;display:flex}.tk-doc-name{color:var(--emr-text);font-size:13px;font-weight:500}.tk-menu-item.selected .tk-doc-name{color:var(--emr-primary)}.tk-doc-spec{color:var(--emr-text-muted);font-size:11px}.tk-doc-chip{background:var(--emr-primary-bg);border:1px solid var(--emr-primary-light);border-radius:var(--emr-radius);align-items:center;gap:10px;margin-top:4px;padding:8px 12px;animation:.2s fadeUp;display:flex}.tk-doc-chip-avatar{background:var(--emr-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:flex}.tk-doc-chip-name{color:var(--emr-primary);font-size:13px;font-weight:600}.tk-doc-chip-spec{color:var(--emr-text-sec);font-size:11px}.tk-time-placeholder{background:var(--emr-surface-light);border:1px dashed var(--emr-border);border-radius:var(--emr-radius);color:var(--emr-text-muted);text-align:center;padding:14px;font-size:12px}.tk-time-grid{grid-template-columns:repeat(auto-fill,minmax(88px,1fr));gap:8px;display:grid}.tk-time-slot{border:1px solid var(--emr-border);border-radius:var(--emr-radius);background:var(--emr-surface);height:36px;color:var(--emr-text-sec);cursor:pointer;white-space:nowrap;padding:0 8px;font-family:inherit;font-size:12px;font-weight:500;transition:all .1s}.tk-time-slot:hover{border-color:var(--emr-primary);color:var(--emr-primary);background:var(--emr-primary-bg)}.tk-time-slot.selected{background:var(--emr-primary);border-color:var(--emr-primary);color:#fff;font-weight:600}.tk-summary{background:var(--emr-primary-bg);border-bottom:1px solid var(--emr-primary-light);flex-wrap:wrap;align-items:center;gap:8px;padding:12px 24px;display:flex}.tk-summary-item{flex-direction:column;flex:1;gap:2px;min-width:90px;display:flex}.tk-summary-label{text-transform:uppercase;letter-spacing:.5px;color:var(--emr-primary);opacity:.7;font-size:10px;font-weight:600}.tk-summary-value{color:var(--emr-primary);font-size:12px;font-weight:600}.tk-summary-div{background:var(--emr-primary-light);flex-shrink:0;align-self:stretch;width:1px}.tk-footer{justify-content:flex-end;margin-top:4px;display:flex}.tk-footer.two-actions{justify-content:space-between}.tk-btn-primary{background:var(--emr-primary);color:#fff;border-radius:var(--emr-radius);cursor:pointer;border:none;outline:none;align-items:center;gap:6px;height:40px;padding:0 16px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s;display:inline-flex}.tk-btn-primary:hover{background:var(--emr-primary-dark)}.tk-btn-primary:active{background:#172554}.tk-btn-primary:disabled{opacity:.7;cursor:not-allowed}.tk-btn-secondary{background:var(--emr-surface);height:40px;color:var(--emr-text-sec);border:1px solid var(--emr-border-strong);border-radius:var(--emr-radius);cursor:pointer;outline:none;align-items:center;gap:6px;padding:0 16px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.tk-btn-secondary:hover{background:var(--emr-surface-light);border-color:var(--emr-primary);color:var(--emr-primary)}.tk-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.tk-page-note{text-align:center;color:var(--emr-text-muted);margin-top:16px;font-size:11px}@media (width<=600px){.tk-content{padding:16px 12px 32px}.tk-topbar-inner{padding:0 12px}.tk-helptext{display:none}.tk-field-row{grid-template-columns:1fr}.tk-progress-line{width:40px}.tk-summary{padding:10px 16px}.tk-summary-div{display:none}.tk-form{padding:16px}.tk-card-header{padding:14px 16px 12px}.tk-footer{flex-direction:column;gap:8px}.tk-footer.two-actions{flex-direction:row}.tk-btn-primary,.tk-btn-secondary{justify-content:center;width:100%}.tk-footer.two-actions .tk-btn-primary,.tk-footer.two-actions .tk-btn-secondary{width:auto}}.tk-input:disabled,select.tk-input:disabled{background:var(--emr-surface-light);color:var(--emr-text-sec);border-color:var(--emr-border);cursor:not-allowed;-webkit-text-fill-color:var(--emr-text-sec);opacity:1}.tk-locked-field{background:var(--emr-surface-light);border:1px solid var(--emr-border);border-radius:var(--emr-radius);min-height:40px;color:var(--emr-text);align-items:center;padding:0 12px;font-size:13px;display:flex}.tk-edit-link{color:var(--emr-primary);text-transform:none;letter-spacing:0;cursor:pointer;background:0 0;border:none;padding:0;font-size:11px;font-weight:600}.tk-edit-link:hover{text-decoration:underline}.tk-welcome{background:var(--emr-primary-bg);border:1px solid var(--emr-primary-light);border-radius:var(--emr-radius);color:var(--emr-text-sec);align-items:flex-start;gap:10px;margin:18px 24px 0;padding:12px 14px;font-size:12px;line-height:1.5;display:flex}.tk-welcome strong{color:var(--emr-text);font-weight:600}.tk-brand{align-items:center;gap:10px;display:flex}.tk-brand-mark{letter-spacing:2px;color:var(--emr-surface);background:var(--emr-primary);border-radius:6px;padding:4px 9px;font-size:11px;font-weight:800}.tk-brand-text{color:var(--emr-text-primary);font-size:14px;font-weight:600}.tk-nav{align-items:center;gap:12px;display:flex}.tk-nav-link{border:1px solid var(--emr-border-strong);background:var(--emr-surface);color:var(--emr-primary);border-radius:8px;padding:7px 12px;font-size:12px;font-weight:600}.tk-nav-link:hover{background:var(--emr-primary-light)}.tk-nav-user{color:var(--emr-text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:150px;font-size:13px;font-weight:600;overflow:hidden}.tk-nav-signout{border:1px solid var(--emr-border-strong);background:var(--emr-surface);color:var(--emr-text-secondary);border-radius:8px;padding:7px 12px;font-size:12px;font-weight:600}.tk-nav-signout:hover{color:#b91c1c;background:#fef2f2;border-color:#fecaca}.tk-error--block{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-top:4px;padding:9px 11px;display:block}.gate-choice{grid-template-columns:1fr 1fr;gap:12px;display:grid}.gate-choice-btn{border:1.5px solid var(--emr-border-strong);border-radius:var(--emr-radius);background:var(--emr-surface);cursor:pointer;text-align:left;flex-direction:column;align-items:flex-start;gap:3px;padding:14px 16px;transition:border-color .15s,background .15s;display:flex}.gate-choice-btn:hover{border-color:var(--emr-primary-light)}.gate-choice-btn.active{border-color:var(--emr-primary);background:var(--emr-primary-bg)}.gate-choice-title{color:var(--emr-text);font-size:14px;font-weight:700}.gate-choice-sub{color:var(--emr-text-sec);font-size:11px;line-height:1.4}.gate-form-error{color:var(--emr-error);background:var(--emr-error-bg);border:1px solid var(--emr-error-border);border-radius:var(--emr-radius);padding:10px 12px;font-size:12px}@media (width<=560px){.gate-choice{grid-template-columns:1fr}}:root{--emr-primary:#1e40af;--emr-primary-dark:#1e3a8a;--emr-primary-light:#dbeafe;--emr-primary-bg:#eff6ff;--emr-success:#15803d;--emr-success-bg:#f0fdf4;--emr-success-light:#bbf7d0;--emr-surface:#fff;--emr-bg:#f1f5f9;--emr-surface-light:#f8fafc;--emr-text:#0f172a;--emr-text-sec:#475569;--emr-text-muted:#94a3b8;--emr-border:#e2e8f0;--emr-border-strong:#cbd5e1;--emr-radius:6px;--emr-radius-lg:8px;--shadow-md:0 1px 3px #00000014, 0 1px 2px #0000000f}.cf-page{background:var(--emr-bg);flex-direction:column;min-height:100vh;display:flex}.cf-topbar{background:var(--emr-surface);border-bottom:1px solid var(--emr-border);z-index:50;position:sticky;top:0;box-shadow:0 1px 2px #0000000d}.cf-topbar-inner{align-items:center;max-width:640px;height:48px;margin:0 auto;padding:0 24px;display:flex}.cf-logo{align-items:center;gap:8px;display:flex}.cf-logo-mark{color:var(--emr-primary);letter-spacing:.5px;font-size:13px;font-weight:700}.cf-logo-sep{color:var(--emr-border-strong)}.cf-logo-title{color:var(--emr-text-sec);font-size:13px;font-weight:500}.cf-content{width:100%;max-width:640px;margin:0 auto;padding:32px 24px 48px}.cf-card{background:var(--emr-surface);border:1px solid var(--emr-border);border-radius:var(--emr-radius-lg);box-shadow:var(--shadow-md);animation:.35s fadeUp;overflow:hidden}.cf-success-header{background:var(--emr-success-bg);border-bottom:1px solid var(--emr-success-light);text-align:center;flex-direction:column;align-items:center;padding:32px 24px 24px;display:flex}.cf-success-icon{background:var(--emr-success);border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:14px;animation:.4s cubic-bezier(.34,1.56,.64,1) .1s both iconPop;display:flex}@keyframes iconPop{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.cf-title{color:var(--emr-text);margin-bottom:5px;font-size:18px;font-weight:700}.cf-subtitle{color:var(--emr-text-sec);margin-bottom:18px;font-size:13px}.cf-ticket-badge{background:var(--emr-surface);border:1px solid var(--emr-success-light);border-radius:var(--emr-radius);flex-direction:column;align-items:center;gap:2px;padding:10px 24px;display:flex}.cf-ticket-label{text-transform:uppercase;letter-spacing:.8px;color:var(--emr-text-muted);font-size:10px;font-weight:600}.cf-ticket-num{color:var(--emr-primary);letter-spacing:1px;font-size:20px;font-weight:700}.cf-details{padding:20px 24px}.cf-section{flex-direction:column;gap:12px;display:flex}.cf-section-title{text-transform:uppercase;letter-spacing:.8px;color:var(--emr-text-muted);font-size:10px;font-weight:600}.cf-grid{grid-template-columns:1fr 1fr;gap:12px 24px;display:grid}.cf-item{flex-direction:column;gap:3px;display:flex}.cf-item-full{grid-column:1/-1}.cf-item-label{text-transform:uppercase;letter-spacing:.5px;color:var(--emr-text-muted);font-size:10px;font-weight:600}.cf-item-value{color:var(--emr-text);font-size:13px;font-weight:500}.cf-reason{color:var(--emr-text-sec);font-weight:400;line-height:1.5}.cf-divider{background:var(--emr-border);height:1px;margin:16px 0}.cf-notice{background:var(--emr-primary-bg);border:1px solid var(--emr-primary-light);border-radius:var(--emr-radius);color:var(--emr-primary);align-items:flex-start;gap:8px;margin:0 24px;padding:10px 14px;font-size:12px;line-height:1.6;display:flex}.cf-actions{border-top:1px solid var(--emr-border);justify-content:space-between;align-items:center;margin-top:20px;padding:16px 24px;display:flex}.cf-btn-primary{background:var(--emr-primary);color:#fff;border-radius:var(--emr-radius);cursor:pointer;border:none;align-items:center;gap:6px;height:40px;padding:0 16px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s;display:inline-flex}.cf-btn-primary:hover{background:var(--emr-primary-dark)}.cf-btn-secondary{background:var(--emr-surface);height:40px;color:var(--emr-text-sec);border:1px solid var(--emr-border-strong);border-radius:var(--emr-radius);cursor:pointer;align-items:center;gap:6px;padding:0 16px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.cf-btn-secondary:hover{background:var(--emr-surface-light);border-color:var(--emr-primary);color:var(--emr-primary)}.cf-empty{color:var(--emr-text-sec);flex-direction:column;align-items:center;gap:16px;padding:48px 24px;font-size:13px;display:flex}.cf-footer-note{text-align:center;color:var(--emr-text-muted);margin-top:16px;font-size:11px}@media print{.cf-topbar,.cf-actions,.cf-footer-note,.cf-notice{display:none}.cf-page{background:#fff}.cf-content{max-width:100%;padding:0}.cf-card{box-shadow:none;border:none}}@media (width<=600px){.cf-content{padding:16px 12px 32px}.cf-grid{grid-template-columns:1fr}.cf-actions{flex-direction:column;gap:8px}.cf-btn-primary,.cf-btn-secondary{justify-content:center;width:100%}.cf-success-header{padding:24px 16px 20px}.cf-details{padding:16px}.cf-notice{margin:0 16px}}
