:root{--cp-blue-50:#eff6ff;--cp-blue-100:#dbeafe;--cp-blue-200:#bfdbfe;--cp-blue-500:#3b82f6;--cp-blue-600:#2563eb;--cp-blue-700:#1d4ed8;--cp-blue-850:#2a4a72;--cp-blue-875:#1e3a6e;--cp-blue-900:#1e3a5f;--cp-slate-50:#f8fafc;--cp-slate-100:#f1f5f9;--cp-slate-200:#e2e8f0;--cp-slate-300:#cbd5e1;--cp-slate-400:#94a3b8;--cp-slate-500:#64748b;--cp-slate-700:#334155;--cp-slate-900:#0f172a;--cp-green-50:#ecfdf5;--cp-green-100:#d1fae5;--cp-green-500:#10b981;--cp-green-600:#059669;--cp-amber-50:#fffbeb;--cp-amber-100:#fef3c7;--cp-amber-500:#f59e0b;--cp-amber-600:#d97706;--cp-red-50:#fef2f2;--cp-red-100:#fee2e2;--cp-red-500:#ef4444;--cp-red-600:#dc2626;--cp-teal-50:#f0fdfa;--cp-teal-100:#ccfbf1;--cp-teal-500:#14b8a6;--cp-purple-100:#ede9fe;--cp-purple-500:#8b5cf6;--color-nav-bg:var(--cp-blue-900);--color-nav-hover:var(--cp-blue-850);--color-nav-active:var(--cp-blue-875);--color-nav-text:var(--cp-slate-400);--color-nav-text-active:#fff;--color-nav-accent:var(--cp-amber-500);--color-bg:var(--cp-slate-100);--color-surface:#fff;--color-surface-hover:var(--cp-slate-50);--color-input-bg:var(--cp-slate-50);--color-overlay:#00000073;--color-text:var(--cp-slate-900);--color-text-soft:var(--cp-slate-700);--color-text-muted:var(--cp-slate-500);--color-text-placeholder:var(--cp-slate-400);--color-text-inverse:#fff;--color-border:var(--cp-slate-300);--color-border-focus:var(--cp-blue-500);--color-divider:var(--cp-slate-200);--color-primary:var(--cp-blue-500);--color-primary-dark:var(--cp-blue-700);--color-primary-light:var(--cp-blue-50);--color-primary-mid:var(--cp-blue-100);--color-success:var(--cp-green-500);--color-success-light:var(--cp-green-100);--color-success-dark:var(--cp-green-600);--color-warning:var(--cp-amber-500);--color-warning-light:var(--cp-amber-100);--color-warning-dark:var(--cp-amber-600);--color-danger:var(--cp-red-500);--color-danger-light:var(--cp-red-100);--color-danger-dark:var(--cp-red-600);--color-info:var(--cp-blue-500);--color-info-light:var(--cp-blue-100);--color-teal:var(--cp-teal-500);--color-teal-light:var(--cp-teal-100);--color-purple:var(--cp-purple-500);--color-purple-light:var(--cp-purple-100);--font-ui:"IBM Plex Sans",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:"JetBrains Mono","DM Mono",ui-monospace,monospace;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-7:28px;--space-8:32px;--space-9:36px;--space-10:40px;--space-11:44px;--space-12:48px;--touch-target:44px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 3px #00000012,0 1px 2px #0000000a;--shadow-md:0 4px 12px #00000014,0 2px 4px #0000000a;--shadow-lg:0 10px 30px #0000001f;--sidebar-width:220px;--topbar-height:56px;--duration-base:150ms;--ease-default:ease;--transition-color:color var(--duration-base) var(--ease-default),background var(--duration-base) var(--ease-default)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}#root,body,html{-webkit-font-smoothing:antialiased;background:var(--color-bg);color:var(--color-text);height:100%}::placeholder{color:var(--color-text-placeholder)}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}body{-webkit-font-smoothing:antialiased;color:var(--color-text);font-family:var(--font-ui);font-size:14px;font-weight:400;line-height:1.5}.app-shell{height:100vh}.app-shell,.sidebar{display:flex;overflow:hidden}.sidebar{background:var(--color-nav-bg);flex-direction:column;flex-shrink:0;width:220px;z-index:100}.sidebar-logo{align-items:center;border-bottom:1px solid #ffffff0f;display:flex;gap:10px;padding:16px 20px}.sidebar-logo .logo-name{color:#fff;font-size:15px;font-weight:700;letter-spacing:-.3px}.sidebar-logo .logo-sub{color:var(--color-nav-text);font-size:10px;margin-top:1px}.sidebar-nav{flex:1 1;overflow-y:auto;padding:12px 10px}.sidebar-nav a,.sidebar-nav button.nav-item{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--color-nav-text);cursor:pointer;display:flex;font-size:13.5px;font-weight:500;gap:10px;margin-bottom:2px;padding:9px 12px;text-align:left;text-decoration:none;transition:background var(--duration-base) var(--ease-default),color var(--duration-base) var(--ease-default);width:100%}.sidebar-nav a:hover,.sidebar-nav button.nav-item:hover{background:var(--color-nav-hover);color:#e2e8f0}.sidebar-nav a.active,.sidebar-nav button.nav-item.active{background:var(--color-nav-active);border-left:3px solid var(--color-nav-accent);color:var(--color-nav-text-active);padding-left:9px}.sidebar-nav a.active svg,.sidebar-nav button.nav-item.active svg{color:var(--color-nav-accent)}.sidebar-nav .nav-icon-wrap{align-items:center;border-radius:6px;display:inline-flex;flex-shrink:0;height:28px;justify-content:center;transition:background var(--duration-base) var(--ease-default);width:28px}.sidebar-nav a:hover .nav-icon-wrap,.sidebar-nav button.nav-item:hover .nav-icon-wrap{background:#ffffff14}.sidebar-nav a.active .nav-icon-wrap,.sidebar-nav button.nav-item.active .nav-icon-wrap{background:#60a5fa26}.sidebar-nav .nav-icon{flex-shrink:0}.sidebar-section-label{border-top:1px solid #ffffff0f;color:#94a3b873;font-size:11px;font-weight:600;letter-spacing:.06em;margin-top:10px;padding:16px 12px 4px;text-transform:uppercase}.sidebar-section-label:first-child{border-top:none;margin-top:0;padding-top:4px}.sidebar-bottom{border-top:1px solid #ffffff0f;padding:12px 10px}.user-pill{align-items:center;border-radius:var(--radius-sm);cursor:pointer;display:flex;gap:10px;padding:10px 12px}.user-pill:hover{background:var(--color-nav-hover)}.user-avatar{align-items:center;background:var(--color-nav-active);border-radius:50%;color:#93c5fd;display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:30px;justify-content:center;width:30px}.user-info .user-name{color:#e2e8f0;font-size:13px;font-weight:600}.user-info .user-role{color:var(--color-nav-text);font-size:11px}.main-content{zoom:1.1;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.top-bar{align-items:center;background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;flex-shrink:0;gap:16px;height:56px;padding:0 24px}.top-bar-title{color:var(--color-text);font-size:16px;font-weight:600}.top-bar-sub{color:var(--color-text-soft);font-size:13px}.top-bar-actions{align-items:center;display:flex;gap:8px;margin-left:auto}.page-body{flex:1 1;overflow-y:auto;padding:24px}.resident-page-layout{grid-gap:20px;align-items:start;display:grid;gap:20px;grid-template-columns:280px 1fr}.resident-sidebar-card{position:sticky;top:0}@media (max-width:767px){.resident-page-layout{gap:12px;grid-template-columns:1fr}.resident-sidebar-card{position:static}}.app-shell-mobile{background:var(--color-bg);display:flex;flex-direction:column;height:100dvh;overflow:hidden}.mobile-content{display:flex;flex:1 1;flex-direction:column;min-width:0;overflow:hidden}.mobile-header{background:var(--color-nav-bg);height:52px;justify-content:space-between;padding:env(safe-area-inset-top) 12px 0;position:relative;z-index:200}.mobile-back-btn,.mobile-header{align-items:center;display:flex;flex-shrink:0}.mobile-back-btn{background:none;border:none;border-radius:8px;color:#94a3b8;cursor:pointer;height:40px;justify-content:center;width:40px}.mobile-back-btn:active{background:var(--color-nav-hover)}.mobile-header-title{flex:1 1;text-align:center}.mobile-logo-text{color:#fff;font-size:15px;font-weight:700;letter-spacing:-.2px}.mobile-header-resident-name{color:#fff;font-size:15px;font-weight:600;letter-spacing:-.2px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-menu-btn{align-items:center;background:none;border:none;border-radius:8px;cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.mobile-menu-btn:active{background:var(--color-nav-hover)}.user-avatar-sm{align-items:center;border-radius:50%;color:#fff;display:flex;font-size:11px;font-weight:700;height:30px;justify-content:center;width:30px}.mobile-user-menu{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;position:fixed;right:10px;top:52px;width:220px;z-index:300}.mobile-user-menu-header{align-items:center;border-bottom:1px solid var(--color-divider);display:flex;gap:12px;padding:14px 16px}.mobile-user-menu-btn{align-items:center;background:none;border:none;color:#ef4444;cursor:pointer;display:flex;font-family:var(--font-ui);font-size:14px;font-weight:500;gap:10px;padding:12px 16px;text-align:left;width:100%}.mobile-user-menu-btn:active{background:var(--color-danger-light)}.mobile-menu-overlay{inset:0;position:fixed;z-index:299}.bottom-nav{align-items:stretch;background:var(--color-nav-bg);border-top:1px solid #ffffff12;display:flex;flex-shrink:0;padding-bottom:env(safe-area-inset-bottom)}.bottom-nav-item{align-items:center;color:var(--color-nav-text);display:flex;flex:1 1;flex-direction:column;font-family:var(--font-ui);font-size:10px;font-weight:500;gap:3px;justify-content:center;min-height:56px;padding:8px 4px;text-decoration:none;transition:color var(--duration-base) var(--ease-default),background var(--duration-base) var(--ease-default)}.bottom-nav-item:active{background:var(--color-nav-hover)}.bottom-nav-item.active,.bottom-nav-item.active svg{color:var(--color-nav-accent)}.bottom-nav-more-overlay{-webkit-overflow-scrolling:touch;background:var(--color-surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;border-top:1px solid var(--color-border);bottom:calc(56px + env(safe-area-inset-bottom));box-shadow:0 -4px 24px #0000001f;left:0;max-height:calc(100dvh - 72px - env(safe-area-inset-bottom) - env(safe-area-inset-top));overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;padding:8px 0 4px;position:fixed;right:0;z-index:400}.bottom-nav-more-header{color:var(--color-text-muted);font-size:11px;font-weight:600;letter-spacing:.08em;padding:4px 16px 8px;text-transform:uppercase}.bottom-nav-more-item{align-items:center;background:none;border:none;color:var(--color-text);cursor:pointer;display:flex;font-family:var(--font-ui);font-size:15px;font-weight:500;gap:14px;min-height:44px;padding:14px 20px;text-align:left;transition:background var(--duration-base) var(--ease-default);width:100%}.bottom-nav-more-item:active{background:var(--color-surface-hover)}.bottom-nav-more-backdrop{background:#0000004d;inset:0;position:fixed;z-index:399}.bottom-nav-more-btn{background:none;border:none;cursor:pointer;font-family:var(--font-ui)}.mobile-grid-stack{display:grid;grid-template-columns:1fr 1fr}.incident-detail-layout{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 380px}@media (max-width:767px){.mobile-content *{box-sizing:border-box;max-width:100%}.page-body{-webkit-overflow-scrolling:touch;flex:1 1;overflow-x:hidden;overflow-y:auto;padding:12px}.incident-detail-layout,.mobile-grid-stack{grid-template-columns:1fr}.incident-detail-layout{gap:12px}.resident-detail-content{overflow-x:hidden}.dashboard-row-item{flex-wrap:wrap;min-width:0}.dashboard-row-item>*{min-width:0}.inline-flex-row{flex-wrap:wrap;gap:6px}.login-outer{padding:16px}}.admin-layout{grid-gap:20px;display:grid;gap:20px;grid-template-columns:200px 1fr}@media (max-width:767px){.admin-layout{gap:12px;grid-template-columns:1fr}}.admin-tab-strip{align-self:start;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;flex-direction:column;padding:12px 8px}@media (max-width:767px){.admin-tab-strip{-webkit-overflow-scrolling:touch;background:var(--color-surface);border-bottom:1px solid var(--color-border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;flex-direction:row;gap:0;overflow-x:auto;padding:0;scrollbar-width:none}.admin-tab-strip::-webkit-scrollbar{display:none}.admin-tab-strip-group-label{display:none}.admin-tab-strip-btn{border-radius:0;flex-shrink:0;font-family:var(--font-ui);font-size:13px;min-height:44px;padding:0 14px;white-space:nowrap}}.analytics-grid{display:grid;grid-template-columns:1fr 1fr}@media (max-width:767px){.analytics-grid{grid-template-columns:1fr}}@media print{.no-print{display:none!important}.print-only{display:block!important}*{height:auto!important;max-height:none!important;overflow:visible!important}body{background:#fff!important;font-size:12px!important}.app-shell,.app-shell-mobile{display:block!important;overflow:visible!important}.main-content{margin:0!important;overflow:visible!important;padding:0!important}.bottom-nav,.mobile-header,.sidebar,.tab-bar{display:none!important}.page-body{padding:0!important}.card{border:1px solid #ddd!important;box-shadow:none!important;break-inside:avoid;margin-bottom:8px!important;page-break-inside:avoid}.card-header{background:#f9f9f9!important}}@media screen{.print-only{display:none!important}}.card{background:var(--color-surface);border:1.75px solid var(--color-border);border-radius:4px;overflow:hidden}.card-header{align-items:center;border-bottom:1px solid var(--color-divider);display:flex;justify-content:space-between;padding:16px 20px}.card-title{color:var(--color-text);font-size:14px;font-weight:600}.card-subtitle{color:var(--color-text-soft);font-size:12px;margin-top:2px}.card-body{padding:20px}.card-footer{border-top:1px solid var(--color-divider);padding:12px 20px}@media (max-width:767px){.card-header{flex-wrap:wrap;gap:6px;padding:10px 12px}.card-body{padding:12px}}.stat-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:24px}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:4px;box-shadow:var(--shadow-sm);padding:20px}.stat-label{color:var(--color-text-soft);font-size:12px;font-weight:500;margin-bottom:8px}.stat-value{color:var(--color-text);font-size:28px;font-weight:700;line-height:1}.stat-sub{color:var(--color-text-soft);font-size:12px;margin-top:6px}.stat-icon{align-items:center;border-radius:8px;display:flex;height:36px;justify-content:center;margin-bottom:12px;width:36px}@media (max-width:767px){.stat-grid{grid-template-columns:1fr 1fr}}.data-table{border-collapse:collapse;width:100%}.data-table th{background:var(--color-bg);border-bottom:1px solid var(--color-border);color:var(--color-text-muted);font-size:11px;font-weight:600;letter-spacing:.04em;padding:10px 16px;text-align:left;text-transform:uppercase}.data-table td{border-bottom:1px solid var(--color-divider);color:var(--color-text);font-size:13.5px;padding:12px 16px}.data-table tbody tr{transition:background var(--duration-base) var(--ease-default)}.data-table tbody tr:hover{background:var(--color-surface-hover)}.data-table tbody tr:last-child td{border-bottom:none}@media (max-width:767px){.data-table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}table.data-table{min-width:0;width:100%}}.badge{align-items:center;border-radius:3px;display:inline-flex;font-size:10.5px;font-weight:500;gap:4px;padding:2px 7px;white-space:nowrap}.badge-blue{background:#dbeafe;color:#1d4ed8}.badge-green{background:#dcfce7;color:#065f46}.badge-orange{background:#fef3c7;color:#92400e}.badge-red{background:#fee2e2;color:#991b1b}.badge-grey{background:#f1f5f9;color:#64748b}@media (max-width:767px){.badge{max-width:100%;overflow:hidden;text-overflow:ellipsis}}.btn{align-items:center;border:none;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-family:var(--font-ui);font-size:13.5px;font-weight:600;gap:6px;padding:8px 16px;text-decoration:none;transition:background var(--duration-base) var(--ease-default),color var(--duration-base) var(--ease-default),box-shadow var(--duration-base) var(--ease-default);white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark)}.btn-secondary{background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text)}.btn-secondary:hover:not(:disabled){background:var(--color-border)}.btn-danger{background:var(--color-danger-light);color:#991b1b}.btn-danger:hover:not(:disabled){background:#fecaca}.btn-ghost{background:#0000;color:var(--color-text-soft)}.btn-ghost:hover:not(:disabled){background:var(--color-bg);color:var(--color-text)}.btn-sm{font-size:12.5px;padding:5px 11px}.btn-icon{border-radius:var(--radius-md);padding:7px}.btn-success{background:var(--color-success-light);color:#065f46}.btn-success:hover:not(:disabled){background:#a7f3d0}.btn--loading{color:#0000;cursor:wait;pointer-events:none;position:relative}.btn--loading:after{animation:spin .6s linear infinite;border:2px solid #fff6;border-radius:50%;border-top-color:#fff;content:"";height:14px;inset:0;margin:auto;position:absolute;width:14px}.btn-ghost.btn--loading:after,.btn-secondary.btn--loading:after{border-color:#00000026;border-top-color:var(--color-text-soft)}@media (max-width:767px){.btn{font-size:14px;min-height:var(--touch-target)}.btn-sm{min-height:32px}.btn-icon{min-width:var(--touch-target)}.btn-danger.btn-sm,.btn-icon,.btn-primary.btn-sm{min-height:var(--touch-target)}}.detail-field-row{border-bottom:1px solid var(--color-divider);display:flex;font-size:13px;padding:10px 20px}@media (max-width:767px){.detail-field-row{flex-direction:column;gap:2px;padding:8px 12px}.detail-field-label{font-size:11px;letter-spacing:.03em;text-transform:uppercase;width:auto}.incident-breadcrumb{flex-wrap:wrap;gap:6px}}.form-group{margin-bottom:16px}.form-label{color:var(--color-text-soft);display:block;font-size:12.5px;font-weight:600;margin-bottom:6px}.form-label.required:after{color:var(--color-danger);content:" *"}.form-control{background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);display:block;font-family:var(--font-ui);font-size:13.5px;outline:none;padding:9px 12px;transition:border-color var(--duration-base) var(--ease-default),box-shadow var(--duration-base) var(--ease-default);width:100%}.form-control:focus{background:#fff;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f626}textarea.form-control{min-height:80px;resize:vertical}select.form-control{cursor:pointer}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.form-row-3{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr 1fr}.form-check{align-items:center;cursor:pointer;display:flex;gap:8px}.form-check input{accent-color:var(--color-primary);cursor:pointer;height:15px;width:15px}.form-hint{color:var(--color-text-muted);font-size:12px;margin-top:4px}.form-control--error,.form-control--error:focus{border-color:var(--color-danger)}.form-control--error:focus{box-shadow:0 0 0 3px #ef444426}.form-error-msg{align-items:center;color:var(--color-danger);display:flex;font-size:12px;gap:4px;margin-top:4px}@media (max-width:767px){.form-control{font-size:14px}.form-check,.form-control{min-height:var(--touch-target)}.form-check{align-items:center;display:flex}.form-row{flex-direction:column;gap:0}.form-row>.form-group{min-width:0;width:100%}input,select,textarea{font-size:16px!important}}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172980;inset:0;justify-content:center;padding:24px;position:fixed;touch-action:none;z-index:1000}.modal,.modal-overlay{display:flex;overflow:hidden}.modal{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);flex-direction:column;max-height:calc(100vh - 48px);width:100%}.modal-body{-webkit-overflow-scrolling:touch;flex:1 1;min-height:0;overflow-y:auto;padding:24px}.modal-footer{align-items:center;background:var(--color-surface);border-top:1px solid var(--color-border);display:flex;flex-shrink:0;gap:12px;justify-content:center;padding:16px 24px}.modal-sm{max-width:420px}.modal-md{max-width:600px}.modal-lg{max-width:800px}.modal-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;flex-shrink:0;justify-content:space-between;padding:20px 24px}.modal-title{font-size:16px;font-weight:700}@media (max-width:767px){.modal-overlay{align-items:flex-end;padding:0 0 calc(56px + env(safe-area-inset-bottom))}.modal,.modal-box{border-radius:16px 16px 0 0;display:flex;flex-direction:column;max-height:80dvh;max-width:100%;min-height:30dvh;overflow:hidden;width:100%}.modal-body{-webkit-overflow-scrolling:touch;flex:1 1;min-height:0;overflow-y:auto;padding:16px}.modal-footer{flex-shrink:0;padding:12px 16px}}.tab-bar{background:#e2e8f0;border-radius:8px;display:flex;gap:2px;margin-bottom:20px;overflow-x:visible;padding:3px}.tab-item{align-items:center;background:#0000;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:inline-flex;flex:0 0 auto;font-family:var(--font-ui);font-size:13px;font-weight:500;line-height:1.4;padding:8px 14px;transition:all .15s ease;white-space:nowrap}.tab-item:hover{background:#ffffff80;color:#64748b}.tab-item.active{background:#fff;box-shadow:0 1px 3px #00000014;color:#1d4ed8;font-weight:600}@media (max-width:767px){.tab-bar{-webkit-overflow-scrolling:touch;border-radius:0;flex-shrink:0;flex-wrap:nowrap;gap:0;overflow-x:auto;padding:4px 10px;scrollbar-width:none}.tab-bar::-webkit-scrollbar{display:none}.tab-item{align-items:center;display:flex;flex-shrink:0;font-size:13px;height:var(--touch-target);padding:10px 14px;white-space:nowrap}}.resident-nav-stuck-sentinel{display:none}@media (max-width:767px){.resident-nav-row{display:contents!important}.resident-nav-header{flex-shrink:1!important;margin-bottom:10px;width:100%!important}.resident-nav-tabbar{-webkit-overflow-scrolling:touch;box-shadow:0 2px 6px #0f172a0f;flex:none!important;margin-bottom:12px;overflow-x:auto!important;overflow-y:hidden;position:sticky;scrollbar-width:none;top:0;width:100%;z-index:20}.resident-nav-tabbar::-webkit-scrollbar{display:none}.resident-nav-stuck-sentinel{display:block;height:1px;margin-bottom:-1px;width:100%}.resident-nav-tabbar.is-stuck{border-radius:0!important;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);-webkit-mask-image:none!important;mask-image:none!important;max-width:100vw;padding-top:15px;top:-12px;width:100vw}.resident-nav-tabbar.fade-right{-webkit-mask-image:linear-gradient(90deg,#000 0,#000 calc(100% - 28px),#0000);mask-image:linear-gradient(90deg,#000 0,#000 calc(100% - 28px),#0000)}.resident-nav-tabbar.fade-left{-webkit-mask-image:linear-gradient(90deg,#0000 0,#000 28px,#000);mask-image:linear-gradient(90deg,#0000 0,#000 28px,#000)}.resident-nav-tabbar.fade-left.fade-right{-webkit-mask-image:linear-gradient(90deg,#0000 0,#000 28px,#000 calc(100% - 28px),#0000);mask-image:linear-gradient(90deg,#0000 0,#000 28px,#000 calc(100% - 28px),#0000)}.resident-nav-tabbar>span{align-items:center;display:inline-flex!important;flex:0 0 auto!important;min-height:var(--touch-target);padding-bottom:0!important;padding-top:0!important}}.resident-avatar{align-items:center;background:var(--color-primary-mid);border-radius:50%;color:var(--color-primary-dark);display:flex;flex-shrink:0;font-weight:700;justify-content:center;object-fit:cover}.alert-banner{align-items:flex-start;border-radius:var(--radius-md);display:flex;font-size:13px;font-weight:500;gap:10px;margin-bottom:12px;padding:12px 16px}.alert-banner.info{background:var(--color-primary-light);border:1px solid var(--color-primary-mid);color:#1e40af}.alert-banner.warning{background:var(--color-warning-light);border:1px solid #fcd34d;color:#78350f}.alert-banner.danger{background:var(--color-danger-light);border:1px solid #fca5a5;color:#7f1d1d}.alert-banner.success{background:var(--color-success-light);border:1px solid #6ee7b7;color:#064e3b}.empty-state{align-items:center;color:var(--color-text-muted);display:flex;flex-direction:column;justify-content:center;padding:48px 24px;text-align:center}.empty-state svg{margin-bottom:12px;opacity:.4}.empty-state p{font-size:13.5px}.empty-state-action{margin-top:16px}.pagination{align-items:center;border-top:1px solid var(--color-divider);color:var(--color-text-soft);display:flex;font-size:13px;justify-content:space-between;padding:12px 20px}.pagination-btns{display:flex;gap:4px}.search-bar{align-items:center;display:flex;position:relative}.search-bar svg{color:var(--color-text-muted);left:10px;position:absolute}.search-bar .form-control{padding-left:34px}@media (max-width:767px){.search-bar{flex:1 1 100%;min-width:0}}.updated-highlight{background:#fefce8;border:1px solid #fde047;border-radius:var(--radius-sm);color:#78350f;font-size:11px;font-weight:600;margin-left:8px;padding:2px 6px}.drag-handle{color:var(--color-text-muted);cursor:grab;padding:4px}.drag-handle:active{cursor:grabbing}.spinner{animation:spin .6s linear infinite;border:2px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}.hover-row:hover,a.hover-row:hover{background:var(--color-bg)}a.hover-row,a.hover-row:visited{color:inherit;text-decoration:none}@media (max-width:767px){.mobile-wrap-row{flex-wrap:wrap;gap:8px}}.sidebar-logo-img{border-radius:var(--radius-sm);flex-shrink:0;height:36px;object-fit:contain;width:36px}.sidebar-nav-badge{background:var(--color-danger);border-radius:9999px;color:var(--color-text-inverse);font-size:11px;font-weight:600;line-height:16px;margin-left:auto;min-width:16px;padding:1px 6px;text-align:center}.sidebar-section-label--admin{margin-top:8px}.sidebar-user-info{flex:1 1;min-width:0}.sidebar-user-name,.sidebar-user-role{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-role{font-size:12px;text-transform:capitalize}.sidebar-logout-btn{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:var(--color-nav-text);cursor:pointer;display:flex;font-family:var(--font-ui);font-size:14px;font-weight:400;gap:8px;margin-top:4px;padding:9px 12px;text-align:left;transition:var(--transition-color);width:100%}.sidebar-logout-btn:hover{background:#ef44441f;color:#f87171}.sidebar-logout-btn svg{flex-shrink:0}.bottom-nav-icon-wrap{display:inline-flex;position:relative}.bottom-nav-badge{background:var(--color-danger);border-radius:9999px;color:var(--color-text-inverse);font-size:9px;font-weight:600;line-height:14px;min-width:14px;padding:1px 4px;position:absolute;right:-7px;text-align:center;top:-5px}.mobile-header-spacer{flex-shrink:0;width:40px}.mobile-header-logo-img{border-radius:var(--radius-sm);height:20px;object-fit:contain;position:absolute;right:34%;top:50%;transform:translateY(-50%);width:20px}.mobile-menu-avatar{align-items:center;border-radius:9999px;color:var(--color-text-inverse);display:flex;font-size:14px;font-weight:600;height:40px;justify-content:center;width:40px}.mobile-menu-user-info{display:flex;flex-direction:column;gap:2px}.mobile-menu-user-name{font-size:14px;font-weight:600}.mobile-menu-user-role{color:var(--color-text-soft);font-size:12px;text-transform:capitalize}.confirm-overlay{z-index:1100}.confirm-message{color:var(--color-text-soft);font-size:14px}.toast-container{bottom:24px;display:flex;flex-direction:column;gap:8px;position:fixed;right:24px;z-index:9999}.toast{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;gap:8px;max-width:360px;min-width:260px;padding:14px 18px}.toast-icon{flex-shrink:0}.toast-message{color:var(--color-text);flex:1 1;font-size:14px}.form-check-label{font-size:14px}.link-row{color:inherit;display:block;text-decoration:none}.text-sm{font-size:12px}.text-muted{color:var(--color-text-soft)}.text-xs{font-size:11px}.text-danger{color:var(--color-danger)}.text-green{color:var(--color-success)}.text-orange{color:var(--color-warning)}.font-mono{font-family:var(--font-mono)}.divider{background:var(--color-divider);height:1px;margin:16px 0}.row{align-items:center;gap:8px}.col,.row{display:flex}.col{flex-direction:column;gap:4px}.ml-auto{margin-left:auto}.gap-8{gap:8px}.flex-1{flex:1 1}.bold{font-weight:700}.loading{align-items:center;color:var(--color-text-muted);display:flex;justify-content:center;padding:48px}@media (max-width:767px){.dashboard-tasks-panel{order:-1}.hide-mobile{display:none}.filter-full-mobile{width:100%}}.fp-tabs{background:var(--color-divider);border-radius:var(--radius-md);display:flex;gap:2px;margin-bottom:16px;padding:3px}.fp-tab{align-items:center;background:#0000;border:none;border-radius:var(--radius-sm);color:var(--color-text-soft);cursor:pointer;display:inline-flex;flex:1 1;font-family:inherit;font-size:13px;font-weight:500;gap:6px;justify-content:center;min-width:0;padding:8px 12px;transition:background var(--duration-base) var(--ease-default),color var(--duration-base) var(--ease-default),box-shadow var(--duration-base) var(--ease-default);white-space:nowrap}.fp-tab:hover{color:var(--color-text)}.fp-tab:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}.fp-tab.active{background:var(--color-surface);box-shadow:var(--shadow-xs);color:var(--color-primary-dark);font-weight:600}.fp-tab-icon{display:inline-flex;flex-shrink:0}.fp-tab-label{overflow:hidden;text-overflow:ellipsis}.fp-tab-label-short{display:none}.fp-tab-label-full{display:inline}.fp-field-list{display:flex;flex-direction:column;gap:8px;margin:8px 0 0}.fp-field-row{grid-gap:4px 12px;align-items:baseline;display:grid;gap:4px 12px;grid-template-columns:160px 1fr}.fp-field-label{color:var(--color-text-muted);font-size:13px;margin:0}.fp-field-value{word-wrap:break-word;color:var(--color-text);font-size:13px;font-weight:500;margin:0}.fp-resident-row{align-items:flex-start;display:flex;gap:20px}.fp-resident-photo{flex-shrink:0}.fp-resident-meta{flex:1 1;min-width:0}.fp-meds-list{display:none}.fp-meds-table{display:table}@media (max-width:640px){.fp-tabs{background:var(--color-surface);border-radius:0;border-top:1px solid var(--color-border);bottom:0;box-shadow:0 -2px 8px #0000000f;left:0;margin:0;padding:4px 4px calc(4px + env(safe-area-inset-bottom));position:fixed;right:0;z-index:50}.fp-tab{flex-direction:column;font-size:11px;font-weight:500;gap:2px;min-height:52px;padding:8px 4px}.fp-tab.active{background:#0000;box-shadow:none}.fp-tab.active,.fp-tab.active .fp-tab-icon{color:var(--color-primary)}.fp-tab-label-full{display:none}.fp-tab-label-short{display:inline}.fp-content{padding-bottom:72px}.fp-meds-table{display:none}.fp-meds-list{display:flex;flex-direction:column;list-style:none;margin:0;padding:0}.fp-meds-list-item{border-top:1px solid var(--color-divider);padding:12px 16px}.fp-meds-list-item:first-child{border-top:none}.fp-field-row{gap:2px;grid-template-columns:1fr}.fp-field-label{font-size:12px}.fp-resident-row{align-items:center;flex-direction:column;gap:14px;text-align:center}.fp-resident-meta{width:100%}.fp-resident-meta .fp-resident-quickfacts{justify-content:center}.fp-resident-meta h1{text-align:center}}
/*# sourceMappingURL=main.3cad8d4b.css.map*/