html,body,#root{margin:0;min-height:100vh}body{background:#f3f5f9;font-family:Inter,Segoe UI,Arial,sans-serif}.app-shell{min-height:100vh}.app-shell .ant-layout-sider{position:sticky;top:0;height:100vh;overflow:auto}.sider-brand{display:flex;align-items:center;gap:10px;padding:14px 14px 10px;color:#fff}.sider-brand.collapsed{justify-content:center;padding:14px 8px 10px}.sider-brand-logo{width:38px;height:38px;border-radius:8px;object-fit:contain;background:#fff;border:1px solid rgba(255,255,255,.45)}.sider-brand-fallback{width:38px;height:38px;border-radius:8px;background:#ffffff24;border:1px solid rgba(255,255,255,.3);display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}.sider-brand-meta{min-width:0;display:flex;flex-direction:column;gap:1px}.sider-brand-title{color:#fff;font-size:13px;line-height:1.2;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:164px}.sider-brand-subtitle{color:#ffffffb8;font-size:11px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:164px}.app-header{background:#fff;border-bottom:1px solid #e7ebf3;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px 16px;padding:12px 16px;min-height:72px;height:auto;line-height:normal;position:sticky;top:0;z-index:20}.app-header-left{min-width:0;display:flex;align-items:center}.app-header-title-wrap{min-width:0;display:flex;flex-direction:column;gap:2px}.app-header-title{margin:0!important;font-size:24px!important;line-height:1.2!important;color:#111827}.app-header-subtitle{color:#64748b;font-size:12px;line-height:1.2}.app-header-right{margin-left:auto;display:flex;align-items:center;gap:10px}.topbar-icon-btn{width:38px;height:38px;border-radius:10px}.user-menu-trigger{height:40px!important;border-radius:999px;padding-inline:8px!important}.user-meta{display:inline-flex;flex-direction:column;align-items:flex-start;line-height:1.1}.user-name{font-size:13px;font-weight:600;color:#111827}.user-role{font-size:11px;color:#64748b}.app-content{padding:20px}.page-card{border-radius:12px}.stat-card .ant-statistic-title{font-weight:600}.live-indicator{display:inline-flex;align-items:center;gap:6px;margin-left:8px;color:#16a34a;font-size:12px;font-weight:600}.live-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;box-shadow:0 0 #22c55eb3;animation:pulse-green 1.5s infinite}.dashboard-table .ant-table{min-height:280px}.employee-row-inactive td{color:#9ca3af!important;background:#f9fafb!important}.tag-overdue-pulse{animation:pulse-red 1.5s infinite}.overdue-summary-card{cursor:pointer;border-color:#fecaca;background:#fef2f2}.overdue-summary-card .ant-statistic-title{color:#991b1b;font-weight:700}.overdue-summary-card .ant-statistic-content{color:#dc2626}.notification-dropdown{width:420px;max-width:calc(100vw - 24px);background:#fff;border:1px solid #e7ebf3;border-radius:12px;box-shadow:0 16px 36px #10182824;overflow:hidden}.notification-dropdown-header{padding:12px 14px;border-bottom:1px solid #eef2f7;display:flex;align-items:center;justify-content:space-between}.notification-item{align-items:flex-start!important;padding:10px 14px!important}.notification-item.unread{background:#f8fbff}.audit-diff-changed td{background:#fffbeb!important}.row-actions-trigger{min-width:34px;padding-inline:8px!important}.row-actions-inline{display:inline-flex;flex-wrap:nowrap!important;white-space:nowrap}.row-actions-inline-btn{min-width:28px;padding-inline:6px!important}.screen-loader-wrap{display:flex;justify-content:center;align-items:center;min-height:260px}.filter-row{width:100%}.camera-preview-wrap{width:100%;max-width:440px;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden;background:#0f172a}.camera-preview-video{width:100%;height:auto;display:block}.login-page-wrap{min-height:100vh;display:grid;place-items:center;padding:16px}.login-card{width:100%;max-width:440px}.login-brand-wrap{width:100%;margin-bottom:18px;display:flex;align-items:center;justify-content:center}.login-brand-logo{width:112px;height:112px;object-fit:contain}.login-brand-fallback{border:1px solid #dbe1ec;background:#f8fafc!important;color:#0f172a!important;font-weight:700;font-size:24px!important;box-shadow:0 6px 16px #0f172a14}.page-card .ant-table-wrapper{width:100%;overflow-x:auto}@media(max-width:1024px){.app-header-title{font-size:20px!important}}@media(max-width:768px){.app-header{padding:10px 12px;min-height:64px;gap:8px 10px}.app-header-title{font-size:18px!important}.app-header-subtitle{display:none}.app-header-right{margin-left:0}.user-meta{display:none}.app-content{padding:12px}.filter-row>.ant-space-item{width:100%}.filter-row .ant-picker,.filter-row .ant-select,.filter-row .ant-input-search,.filter-row .ant-btn{width:100%}.login-card{max-width:96vw}.login-brand-logo{width:96px;height:96px}}@keyframes pulse-green{0%{box-shadow:0 0 #22c55eb3}70%{box-shadow:0 0 0 8px #22c55e00}to{box-shadow:0 0 #22c55e00}}@keyframes pulse-red{0%{box-shadow:0 0 #dc262673}70%{box-shadow:0 0 0 8px #dc262600}to{box-shadow:0 0 #dc262600}}html,body{width:100%;height:100%}input::-ms-clear,input::-ms-reveal{display:none}*,*:before,*:after{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:rgba(0,0,0,0)}@-ms-viewport{width:device-width}body{margin:0}[tabindex="-1"]:focus{outline:none}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5em;font-weight:500}p{margin-top:0;margin-bottom:1em}abbr[title],abbr[data-original-title]{-webkit-text-decoration:underline dotted;text-decoration:underline dotted;border-bottom:0;cursor:help}address{margin-bottom:1em;font-style:normal;line-height:inherit}input[type=text],input[type=password],input[type=number],textarea{-webkit-appearance:none}ol,ul,dl{margin-top:0;margin-bottom:1em}ol ol,ul ul,ol ul,ul ol{margin-bottom:0}dt{font-weight:500}dd{margin-bottom:.5em;margin-left:0}blockquote{margin:0 0 1em}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}pre,code,kbd,samp{font-size:1em;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace}pre{margin-top:0;margin-bottom:1em;overflow:auto}figure{margin:0 0 1em}img{vertical-align:middle;border-style:none}a,area,button,[role=button],input:not([type=range]),label,select,summary,textarea{touch-action:manipulation}table{border-collapse:collapse}caption{padding-top:.75em;padding-bottom:.3em;text-align:left;caption-side:bottom}input,button,select,optgroup,textarea{margin:0;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}button,html [type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{padding:0;border-style:none}input[type=radio],input[type=checkbox]{box-sizing:border-box;padding:0}input[type=date],input[type=time],input[type=datetime-local],input[type=month]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;margin:0;padding:0;border:0}legend{display:block;width:100%;max-width:100%;margin-bottom:.5em;padding:0;color:inherit;font-size:1.5em;line-height:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item}template{display:none}[hidden]{display:none!important}mark{padding:.2em;background-color:#feffe6}
