:root{--brand:#117a68;--brand-dark:#0d6356;--brand-light:#1aab8e;--brand-bg:#e8f5f1;--brand-border:#a8d8cc;--sidebar-from:#0c2233;--sidebar-to:#0d3529;--sidebar-text:#ffffffad;--sidebar-text-bright:#fffffff2;--sidebar-divider:#ffffff1a;--sidebar-active-bg:#ffffff1a;--sidebar-accent:#3dd6b0;--danger:#dc2626;--danger-hover:#b91c1c;--danger-bg:#fef2f2;--danger-border:#fecaca;--danger-text:#991b1b;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;color:var(--gray-800);background:#eaf0f5;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5}*,:before,:after{box-sizing:border-box}body{margin:0}button,input,select,textarea{font:inherit}button{transition:background .15s,border-color .15s,box-shadow .15s,transform 80ms}.app-shell{grid-template-columns:256px minmax(0,1fr);gap:10px;height:100vh;padding:10px;display:grid;overflow:hidden}.sidebar{background:linear-gradient(175deg, var(--sidebar-from) 0%, var(--sidebar-to) 100%);color:var(--sidebar-text);border-radius:16px;flex-direction:column;gap:18px;padding:18px 12px;display:flex;overflow:auto;box-shadow:0 8px 28px #0c223352,0 2px 8px #0c223329}.brand{border-bottom:1px solid var(--sidebar-divider);align-items:center;gap:12px;padding:0 6px 18px;display:flex}.brand-logo{object-fit:contain;filter:brightness(1.1);flex:none;width:52px;height:52px}.brand strong{color:#fff;font-size:14px;font-weight:800;line-height:1.3;display:block}.brand span{color:var(--sidebar-text);margin-top:1px;font-size:11px;display:block}nav{gap:2px;display:grid}.nav-item{color:var(--sidebar-text);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:7px;justify-content:flex-start;align-items:center;gap:10px;width:100%;min-height:40px;padding:9px 10px;font-size:14px;transition:background .15s,color .15s,box-shadow .15s;display:flex}.nav-item:hover{color:var(--sidebar-text-bright);background:#ffffff12}.nav-item.active{background:var(--sidebar-active-bg);box-shadow:inset 3px 0 0 var(--sidebar-accent);color:#fff;font-weight:700}.nav-item svg{opacity:.8;flex:none}.nav-item.active svg{opacity:1;color:var(--sidebar-accent)}.user-box{border-top:1px solid var(--sidebar-divider);gap:4px;margin-top:auto;padding:16px 6px 0;display:grid}.user-box>span{color:#fff;font-size:14px;font-weight:700}.user-box>small{color:var(--sidebar-text);font-size:12px}.user-box button{color:#ffffffd1;cursor:pointer;background:#ffffff12;border:1px solid #ffffff1f;border-radius:6px;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:8px;padding:8px 10px;transition:background .15s,border-color .15s;display:flex}.user-box button:hover{color:#fff;background:#ffffff21;border-color:#ffffff38}.user-box button+button{margin-top:4px}main{min-width:0;height:100%;overflow:auto}.topbar{border:1px solid var(--gray-200);z-index:5;background:#fff;border-radius:14px;justify-content:space-between;align-items:center;gap:18px;min-height:60px;margin:0 22px 14px;padding:10px 22px;display:flex;position:sticky;top:0;box-shadow:0 2px 10px #0f172a12,0 1px 2px #0f172a0a}h1,h2,h3,p{margin:0}h1{letter-spacing:-.3px;font-size:21px;font-weight:800;line-height:1.2}h2{font-size:18px;font-weight:700}h3{color:var(--gray-700);align-items:center;gap:8px;font-size:14px;font-weight:700;display:flex}.topbar p,.detail-header p{color:var(--gray-500);margin-top:3px;font-size:13px}.primary-action,.secondary-action,.danger-action{cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:7px;justify-content:center;align-items:center;gap:7px;min-height:36px;padding:7px 15px;font-weight:700;display:flex}.primary-action{background:linear-gradient(135deg, var(--brand) 0%, var(--brand-light) 100%);color:#fff;box-shadow:0 2px 6px #117a6859}.primary-action:hover{background:linear-gradient(135deg, var(--brand-dark) 0%, var(--brand) 100%);transform:translateY(-1px);box-shadow:0 3px 10px #117a6873}.primary-action:active{box-shadow:none;transform:translateY(0)}.primary-action:disabled{background:var(--gray-300);box-shadow:none;color:var(--gray-500);cursor:not-allowed;transform:none}.secondary-action{border-color:var(--gray-300);color:var(--gray-700);background:#fff;box-shadow:0 1px 2px #0f172a0d}.secondary-action:hover{background:var(--gray-50);border-color:var(--gray-400)}.danger-action{color:#fff;background:linear-gradient(135deg,#dc2626 0%,#ef4444 100%);box-shadow:0 2px 6px #dc26264d}.danger-action:hover{background:linear-gradient(135deg,#b91c1c 0%,#dc2626 100%);transform:translateY(-1px);box-shadow:0 3px 10px #dc262666}.danger-action:active{box-shadow:none;transform:translateY(0)}.compact-action{min-height:30px;padding:4px 10px;font-size:13px}.header-actions,.modal-actions,.row-actions{align-items:center;gap:8px;display:flex}.header-actions,.modal-actions{justify-content:flex-end}.row-actions{flex-wrap:wrap}.workspace{grid-template-columns:310px minmax(0,1fr);gap:16px;padding:0 22px 26px;display:grid}.resident-list,.detail,.login-panel,.page-panel,.modal-panel,.confirm-panel,.table-card{border:1px solid var(--gray-200);background:#fff;border-radius:12px;box-shadow:0 2px 8px #0f172a0f,0 1px 2px #0f172a0a}.inline-form{background:var(--gray-50);border:1px solid var(--gray-100);border-radius:10px}.resident-list{flex-direction:column;gap:10px;height:calc(100vh - 122px);padding:14px;display:flex}.search-box{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:7px;align-items:center;gap:8px;min-height:38px;padding:0 10px;transition:border-color .15s,box-shadow .15s;display:flex}.search-box:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px #117a6824}.search-box input,.login-panel input{background:0 0;border:0;outline:0;width:100%}select,textarea,.inline-form input,.embedded-form input,.modal-panel input{border:1px solid var(--gray-300);color:var(--gray-900);background:#fff;border-radius:7px;outline:0;width:100%;min-width:0;min-height:36px;padding:7px 10px;transition:border-color .15s,box-shadow .15s}select:focus,textarea:focus,input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #117a6824}input:disabled,select:disabled,textarea:disabled{background:var(--gray-50);color:var(--gray-500);cursor:default}textarea{resize:vertical;min-height:88px}.list-scroll{gap:5px;display:grid;overflow:auto}.resident-row{border:1px solid var(--gray-200);cursor:pointer;text-align:left;background:#fff;border-radius:9px;gap:2px;padding:10px 12px;transition:border-color .15s,box-shadow .15s,transform 80ms;display:grid}.resident-row:hover{border-color:var(--brand-border);transform:translate(2px);box-shadow:0 2px 8px #117a681a}.resident-row.selected{border-color:var(--brand-border);box-shadow:inset 3px 0 0 var(--brand), 0 2px 8px #117a681a;background:linear-gradient(135deg,#f0faf6 0%,#e8f5f1 100%)}.resident-row strong{color:var(--gray-900);font-size:14px}.resident-row span{color:var(--gray-500);font-size:12px}.resident-row small{color:var(--gray-400);font-size:12px}.detail,.page-panel{gap:20px;padding:20px;display:grid}.page-panel{margin:0 22px 26px}.detail-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.service-pill,.status-active,.status-inactive,.badge-danger,.badge-warning,.badge-homecare,.badge-daycare{letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;border-radius:999px;padding:4px 11px;font-size:11px;font-weight:800}.service-pill{color:#0a5c4a;background:linear-gradient(135deg,#e8f5f1,#d4ede6)}.status-active{color:#15803d;background:linear-gradient(135deg,#dcfce7,#bbf7d0)}.status-inactive{color:#dc2626;background:linear-gradient(135deg,#fef2f2,#fee2e2)}.badge-danger{border:1px solid var(--danger-border);color:var(--danger-text);background:linear-gradient(135deg,#fef2f2,#fee2e2)}.badge-warning{color:#92400e;background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fde68a}.allergy-badge{color:var(--danger);font-size:11px;font-weight:800}.summary-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.info-item{background:linear-gradient(135deg, var(--gray-50) 0%, #eef6f3 100%);border:1px solid var(--gray-200);border-radius:10px;gap:4px;min-height:68px;padding:11px 13px;transition:box-shadow .15s;display:grid}.info-item:hover{box-shadow:0 3px 10px #117a681a}.info-item span{color:var(--gray-500);letter-spacing:.04em;text-transform:uppercase;font-size:11px;font-weight:600}.info-item strong{color:var(--gray-800);overflow-wrap:anywhere;font-size:13px}.two-column{grid-template-columns:1fr 1fr;gap:16px;display:grid}.two-column section,.doctors-strip{gap:10px;display:grid}.record-card{border:1px solid var(--gray-200);background:#fff;border-radius:10px;gap:4px;padding:13px;transition:border-color .15s,box-shadow .15s,transform 80ms;display:grid}.record-card:hover{border-color:var(--brand-border);transform:translateY(-2px);box-shadow:0 4px 12px #117a681a}.record-card strong{color:var(--gray-900);font-size:14px}.record-card span{color:var(--gray-500);font-size:12px}.record-card small{color:var(--gray-400);font-size:12px}.doctor-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.note-block{background:linear-gradient(135deg, var(--gray-50) 0%, #eef6f3 100%);border:1px solid var(--gray-200);border-left:3px solid var(--brand-border);color:var(--gray-700);border-radius:0 10px 10px 0;padding:13px 15px;font-size:14px;line-height:1.65}.inline-form,.embedded-form{align-content:start;gap:12px;padding:18px;display:grid}.inline-form label,.embedded-form label,.modal-panel label{color:var(--gray-700);gap:5px;font-size:13px;font-weight:600;display:grid}.embedded-form{border:1px solid var(--gray-200);border-radius:10px}.form-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.wide-field{grid-column:span 3}.form-section-header{border-bottom:1px solid var(--gray-200);color:var(--brand);letter-spacing:.06em;text-transform:uppercase;grid-column:span 3;align-items:center;gap:6px;margin-top:6px;padding-bottom:8px;font-size:11px;font-weight:800;display:flex}.modal-backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:20;background:#0f172a99;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-panel{gap:16px;width:100%;max-width:960px;max-height:calc(100vh - 48px);padding:22px;display:grid;overflow:auto}.confirm-panel{gap:14px;width:100%;max-width:440px;padding:22px;display:grid}.confirm-panel p{color:var(--gray-600);font-size:14px;line-height:1.55}.filter-bar{border:1px solid var(--gray-200);background:#fff;border-radius:12px;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;padding:14px;display:grid;box-shadow:0 2px 8px #0f172a0f}.table-card{overflow:hidden}.table-row{background:#fff;border-top:1px solid #f1f5f9;grid-template-columns:1.5fr .8fr 1.4fr .7fr 1fr;align-items:center;gap:12px;min-height:56px;padding:10px 16px;transition:background .12s;display:grid}.table-row:hover{background:#fafcff}.table-row:nth-child(2n){background:#fafbfd}.table-row:nth-child(2n):hover{background:#f4f7fc}.audit-table .table-row{grid-template-columns:.9fr 1.4fr .7fr 1.2fr .8fr 1.4fr}.ip-address{color:var(--gray-500);font-family:monospace;font-size:.78rem}.table-row:first-child{border-top:0}.table-row span{min-width:0}.table-row strong,.table-row small{overflow-wrap:anywhere;display:block}.table-row small{color:var(--gray-400);margin-top:1px;font-size:12px}.table-head{background:linear-gradient(180deg, var(--gray-50) 0%, #f1f5f9 100%);border-bottom:1px solid var(--gray-200);color:var(--gray-500);letter-spacing:.05em;text-transform:uppercase;border-top:0;min-height:38px;font-size:11px;font-weight:800}.table-head:hover{background:linear-gradient(180deg, var(--gray-50) 0%, #f1f5f9 100%)}.timeline-item{border:1px solid var(--gray-200);border-left:3px solid var(--gray-300);background:#fff;border-radius:0 10px 10px 0;gap:6px;margin-top:8px;padding:13px 15px;transition:border-left-color .15s,box-shadow .15s;display:grid}.timeline-item:hover{box-shadow:0 3px 10px #0f172a12}.note-type-incident{border-left-color:#dc2626}.note-type-medical{border-left-color:#2563eb}.note-type-medication{border-left-color:#ea580c}.note-type-appointment{border-left-color:#7c3aed}.note-type-diet{border-left-color:#16a34a}.note-type-family_communication{border-left-color:#0891b2}.note-type-general{border-left-color:var(--gray-300)}.timeline-item span{color:var(--gray-500);font-size:12px}.timeline-item strong{color:var(--gray-800)}.timeline-item p{color:var(--gray-700);font-size:14px;line-height:1.65}.audit-details{color:var(--gray-500);white-space:pre-wrap;word-break:break-all;max-height:80px;margin:0;font-family:ui-monospace,SFMono-Regular,Cascadia Code,monospace;font-size:11px;line-height:1.5;overflow:auto}.page-panel>.empty-state,.page-panel>.detail.empty-state{box-shadow:none;background:0 0;border:none}.empty-state{text-align:center;align-content:center;justify-items:center;min-height:300px;padding:32px}.empty-state svg{color:var(--gray-300)}.empty-state h2{color:var(--gray-600);margin-top:14px;font-size:17px}.empty-state p{color:var(--gray-400);max-width:260px;margin-top:6px;font-size:13px}.muted{color:var(--gray-400);font-size:13px}.pagination-bar{justify-content:center;align-items:center;gap:12px;padding:4px 0 2px;display:flex}.pagination-label{color:var(--gray-500);text-align:center;min-width:100px;font-size:13px;font-weight:600}.login-screen{background:linear-gradient(135deg,#0c2233 0%,#0d3a2a 45%,#117a68 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex;position:relative;overflow:hidden}.login-screen:before{content:"";pointer-events:none;background:radial-gradient(at 30% 20%,#3dd6b01f 0%,#0000 60%),radial-gradient(at 80% 80%,#117a6826 0%,#0000 50%);position:absolute;inset:0}.login-panel{gap:16px;width:100%;max-width:400px;padding:32px;display:grid;position:relative}.login-logo{object-fit:contain;justify-self:center;width:auto;height:80px}.login-panel h1{color:var(--gray-900);text-align:center;font-size:20px}.login-panel>p{color:var(--gray-500);text-align:center;font-size:14px}.login-panel label{color:var(--gray-700);gap:6px;font-size:13px;font-weight:600;display:grid}.login-panel input{border:1px solid var(--gray-300);background:#fff;border-radius:7px;padding:10px 12px}.error{border:1px solid var(--danger-border);color:var(--danger-text);background:linear-gradient(135deg,#fef2f2,#fee2e2);border-radius:7px;padding:10px 12px;font-size:13px}.field-error{color:var(--danger);margin-top:3px;font-size:11px;font-weight:600}input.input-error{border-color:var(--danger)!important;box-shadow:0 0 0 3px #dc262624!important}.toast{color:#fff;z-index:50;background:linear-gradient(135deg,#0c2233,#0d3a2a);border-radius:9px;padding:12px 18px;font-size:13px;font-weight:600;position:fixed;bottom:20px;right:20px;box-shadow:0 8px 24px #0c223359}.loading-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:100;background:#ffffffb3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.spinner{border:3px solid var(--gray-200);border-top-color:var(--brand);border-radius:50%;width:44px;height:44px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.stat-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.stat-card{border-radius:14px;gap:8px;padding:22px 22px 20px;display:grid;position:relative;overflow:hidden}.stat-icon{color:#fff3;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.stat-number{color:#fff;z-index:1;font-size:42px;font-weight:900;line-height:1;position:relative}.stat-label{color:#ffffffd1;z-index:1;font-size:13px;font-weight:600;position:relative}.stat-card-teal{background:linear-gradient(135deg,#0e7a67 0%,#1aab8e 100%);box-shadow:0 4px 18px #0e7a6761}.stat-card-blue{background:linear-gradient(135deg,#1d4ed8 0%,#3b82f6 100%);box-shadow:0 4px 18px #1d4ed852}.stat-card-purple{background:linear-gradient(135deg,#6d28d9 0%,#8b5cf6 100%);box-shadow:0 4px 18px #6d28d952}.stat-card-amber{background:linear-gradient(135deg,#b45309 0%,#f59e0b 100%);box-shadow:0 4px 18px #b4530952}.dashboard-alert{color:#991b1b;background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fecaca;border-left:4px solid #dc2626;border-radius:0 10px 10px 0;align-items:center;gap:10px;padding:13px 16px;font-size:14px;font-weight:600;display:flex}.dashboard-list-panel{border:1px solid var(--gray-200);background:#fff;border-radius:12px;gap:12px;padding:18px;display:grid;box-shadow:0 2px 8px #0f172a0f}.activity-list{gap:7px;display:grid}.activity-item{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:9px;gap:3px;padding:10px 13px;transition:border-color .15s,box-shadow .15s;display:grid}.activity-item:hover{border-color:var(--brand-border);box-shadow:0 2px 6px #117a6814}.activity-item-discharge{border-left:3px solid #fecaca}.activity-item-discharge:hover{border-color:#fecaca;border-left-color:var(--danger)}.activity-item-main{justify-content:space-between;align-items:center;gap:8px;display:flex}.activity-item-main strong{color:var(--gray-900);font-size:14px}.activity-item small{color:var(--gray-500);font-size:12px}.activity-date{align-items:center;gap:4px;display:flex;color:var(--gray-400)!important}@media (width<=1100px){.app-shell,.workspace,.two-column,.doctor-grid,.form-grid{grid-template-columns:1fr}.app-shell,main{height:auto;overflow:visible}.app-shell{gap:0;padding:0}.wide-field,.form-section-header{grid-column:auto}.sidebar{box-shadow:none;border-radius:0;height:auto}.resident-list{height:auto}.summary-grid,.stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.table-row,.audit-table .table-row,.filter-bar{grid-template-columns:1fr;align-items:start}}.chart-panel{border:1px solid var(--gray-100);background:#fff;border-radius:14px;padding:20px 24px 16px;box-shadow:0 1px 3px #0000000a}.chart-panel h3{color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:7px;margin:0 0 16px;font-size:.75rem;font-weight:700;display:flex}.recharts-tooltip-wrapper{outline:none}@media (width<=640px){.topbar,.detail-header{flex-direction:column;align-items:stretch;gap:12px}.summary-grid{grid-template-columns:1fr}.page-panel,.workspace{margin:0;padding:14px}.login-panel{padding:22px}}
