html,body,#app{width:100%;min-width:320px;min-height:100%;margin:0}:root{color:#1f2937;background:#f3f5f8;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{background:#f3f5f8}.login-page{background:#f3f5f8;place-items:center;min-height:100vh;padding:24px;display:grid}.login-panel{background:#fff;border:1px solid #e5e7eb;border-radius:8px;width:100%;max-width:380px;padding:32px;box-shadow:0 18px 44px #1118271a}.login-brand-mark{color:#fff;background:#111827;border-radius:6px;place-items:center;width:42px;height:42px;margin:0 auto 16px;font-size:22px;font-weight:700;display:grid;overflow:hidden}.login-brand-mark img{object-fit:cover;width:100%;height:100%}.login-panel h1{color:#111827;text-align:center;margin:0;font-size:20px;font-weight:700}.login-subtitle{color:#6b7280;text-align:center;margin:8px 0 24px;font-size:14px}.login-hint{color:#6b7280;text-align:center;margin:18px 0 0;font-size:12px}.login-footer{color:#6b7280;text-align:center;align-self:end;font-size:12px}.footer-content{flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;display:inline-flex}.footer-icp{color:inherit;text-decoration:none}.footer-icp:hover{color:#111827}.footer-divider{background:#d1d5db;width:1px;height:12px}.footer-copyright{color:inherit}.admin-layout{background:var(--admin-page-bg,#f3f5f8);min-height:100vh}.admin-sider{z-index:100;height:100vh;top:0;bottom:0;left:0;overflow:auto;background:var(--admin-sider-bg,#111827)!important;position:fixed!important}.admin-sider .ant-layout-sider-children,.admin-sider .ant-menu-dark{background:0 0}.admin-main{min-height:100vh;margin-left:232px;transition:margin-left .2s}.admin-layout.sider-collapsed .admin-main{margin-left:72px}.brand{height:64px;color:var(--admin-sider-text,#fff);justify-content:flex-start;align-items:center;gap:12px;padding:0 20px;display:flex;overflow:hidden}.brand-mark{width:34px;height:34px;color:var(--admin-sider-bg,#111827);background:var(--admin-sider-text,#fff);border-radius:6px;place-items:center;font-weight:700;display:grid;overflow:hidden}.brand-mark img{object-fit:cover;width:100%;height:100%}.brand-title{font-size:16px;font-weight:650;line-height:20px}.brand-subtitle{color:color-mix(in srgb, var(--admin-sider-text,#fff) 72%, transparent);font-size:12px;line-height:18px}.ant-layout-sider-collapsed .brand{justify-content:center;padding:0}.admin-layout .admin-header{z-index:90;height:56px;color:var(--admin-header-text,#111827);background:var(--admin-header-bg,#fff);border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:0 24px;transition:left .2s;display:flex;position:fixed;top:0;left:232px;right:0}.admin-layout.sider-collapsed .admin-header{left:72px}.admin-header .header-title{color:var(--admin-header-text,#111827);font-size:16px;font-weight:650}.admin-header .sider-toggle{width:32px;height:32px;color:var(--admin-header-text,#374151);justify-content:center;align-items:center;display:inline-flex}.header-actions{flex:none;align-items:center;gap:10px;display:flex}.header-env,.header-user,.header-action-btn,.header-logout-btn{color:#374151;white-space:nowrap;background:#f8fafc;border:1px solid #e5e7eb;border-radius:6px;justify-content:center;align-items:center;gap:7px;height:32px;padding:0 12px;font-size:13px;line-height:32px;display:inline-flex}.header-env{color:#047857;background:#ecfdf5;border-color:#bbf7d0}.env-dot{background:#10b981;border-radius:50%;width:7px;height:7px;box-shadow:0 0 0 3px #10b98126}.header-action-btn.ant-btn,.header-logout-btn.ant-btn{padding:0 12px}.header-action-btn.ant-btn{color:#374151}.header-action-btn.ant-btn:hover,.header-user:hover{color:#1677ff;background:#eff6ff;border-color:#bfdbfe}.header-logout-btn.ant-btn{color:#b42318;background:#fff;border-color:#fecaca}.header-logout-btn.ant-btn:hover{color:#991b1b;background:#fef2f2;border-color:#fca5a5}.header-actions .ant-badge{line-height:1}.admin-content{background:var(--admin-page-bg,#f3f5f8);flex-direction:column;min-height:100vh;padding:76px 20px 20px;display:flex}.admin-page-body{flex:1 0 auto}.admin-footer{color:#6b7280;text-align:center;flex:none;padding:18px 0 4px;font-size:12px}.admin-footer a{color:inherit;text-decoration:none}.admin-footer a:hover{color:#111827}.page{max-width:1440px;margin:0 auto}.metric-row{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:16px;display:grid}.metric-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;min-height:92px;padding:18px}.metric-card span{color:#6b7280;font-size:13px;display:block}.metric-card strong{color:#111827;margin-top:8px;font-size:30px;line-height:1;display:block}.dashboard-shell{gap:18px;display:grid}.dashboard-shell.loading{opacity:.72}.dashboard-hero{color:#fff;background:linear-gradient(135deg,#111827f5,#185063f0),linear-gradient(90deg,#111827,#0f766e);border:1px solid #ffffff1f;border-radius:8px;grid-template-columns:minmax(0,1fr) 320px;align-items:end;gap:18px;min-height:210px;padding:26px;display:grid;box-shadow:0 20px 50px #0f172a2e}.dashboard-kicker{color:#a7f3d0;background:#ffffff14;border:1px solid #ffffff24;border-radius:999px;margin-bottom:14px;padding:5px 10px;font-size:12px;font-weight:700;display:inline-flex}.dashboard-hero h2{margin:0;font-size:42px;line-height:1.1}.dashboard-hero p{color:#d1fae5;margin:12px 0 0;font-size:14px}.dashboard-period{background:#ffffff1a;border:1px solid #ffffff29;border-radius:8px;padding:18px}.dashboard-period span,.dashboard-period small,.dashboard-card span,.dashboard-card small{display:block}.dashboard-period span{color:#bae6fd;font-size:13px}.dashboard-period strong{margin:8px 0;font-size:28px;line-height:1;display:block}.dashboard-period small{color:#dbeafe}.dashboard-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.dashboard-card,.dashboard-panel{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 30px #0f172a0d}.dashboard-card{min-height:132px;padding:18px}.dashboard-card span{color:#64748b;font-size:13px}.dashboard-card strong{color:#0f172a;margin:12px 0 10px;font-size:30px;line-height:1;display:block}.dashboard-card small{color:#64748b}.dashboard-card.primary{background:#f0fdfa;border-color:#99f6e4}.dashboard-card.attention{background:#fff7ed;border-color:#fed7aa}.dashboard-lower{grid-template-columns:minmax(0,1.45fr) minmax(320px,.75fr);gap:18px;display:grid}.dashboard-panel{padding:18px}.dashboard-panel.compact{padding-bottom:20px}.dashboard-panel-title{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.dashboard-panel-title h3{color:#0f172a;margin:0;font-size:17px}.dashboard-panel-title p{color:#64748b;margin:5px 0 0;font-size:13px}.trend-list{gap:13px;display:grid}.trend-row{grid-template-columns:54px minmax(0,1fr) 120px;align-items:center;gap:12px;display:grid}.trend-row span{color:#64748b;font-size:13px}.trend-row strong{color:#0f172a;text-align:right;font-size:13px}.trend-track{background:#e5e7eb;border-radius:999px;height:10px;overflow:hidden}.trend-track i{border-radius:inherit;background:linear-gradient(90deg,#14b8a6,#0ea5e9);height:100%;display:block}.health-list{gap:12px;display:grid}.health-item{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;justify-content:space-between;align-items:center;padding:14px;display:flex}.health-item span{color:#475569;font-size:13px}.health-item strong{color:#0f172a;font-size:20px}.health-item.tone-positive{background:#f0fdf4;border-color:#bbf7d0}.health-item.tone-warning{background:#fff7ed;border-color:#fed7aa}.module-stat-grid{grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;display:grid}.module-stat-grid div{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;padding:14px}.module-stat-grid span{color:#64748b;font-size:12px;display:block}.module-stat-grid strong{color:#111827;margin-top:8px;font-size:24px;display:block}.table-panel{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px}.table-toolbar{grid-template-columns:minmax(180px,1fr) auto auto;align-items:center;gap:16px;margin-bottom:18px;display:grid}.table-toolbar>:first-child{min-width:0}.performance-toolbar{grid-template-columns:minmax(260px,1fr) auto}.toolbar-title-actions{gap:10px;min-width:0;display:grid}.table-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.table-toolbar h3{color:#111827;margin:0;font-size:18px}.table-toolbar p{color:#6b7280;margin:4px 0 0;font-size:13px}.clickable-row{cursor:pointer}.clickable-row:hover>td{background:#f8fafc!important}.empty-panel{background:#fff;border:1px solid #e5e7eb;border-radius:8px;min-height:220px;padding:24px}.empty-panel h3{color:#111827;margin:0;font-size:18px}.empty-panel p{color:#6b7280;margin:8px 0 0;font-size:14px}.empty-panel.loading{opacity:.72}.upload-file-name{color:#374151;margin:-4px 0 14px;font-size:13px}.upload-alert{margin-bottom:14px}.upload-toolbar{margin-bottom:12px}.upload-file-row{min-height:28px}.attachment-name{color:#374151;text-overflow:ellipsis;vertical-align:middle;white-space:nowrap;max-width:140px;display:inline-block;overflow:hidden}.setting-brand-preview{border:1px solid #e5e7eb;border-radius:6px;place-items:center;min-width:32px;height:32px;font-weight:700;display:inline-grid;overflow:hidden}.setting-brand-preview img,.setting-image-preview img{object-fit:cover;width:100%;height:100%}.setting-color-cell{align-items:center;gap:8px;display:inline-flex}.setting-color-dot{border:1px solid #d1d5db;border-radius:4px;width:16px;height:16px}.setting-image-field{align-items:center;gap:12px;display:flex}.setting-image-preview{color:#111827;cursor:pointer;background:#f8fafc;border:1px solid #e5e7eb;border-radius:6px;place-items:center;width:48px;height:48px;padding:0;font-weight:700;display:grid;overflow:hidden}.setting-image-preview.uploading{color:#6b7280;cursor:wait;opacity:.75}.setting-image-field.compact{gap:8px}.setting-image-preview.small{width:36px;height:36px;font-size:12px}.setting-color-input{grid-template-columns:42px 1fr;align-items:center;gap:8px;display:grid}.setting-color-input input[type=color]{background:0 0;border:1px solid #d9d9d9;border-radius:6px;width:42px;height:32px;padding:0}.bulk-delete-confirm p{margin:0 0 12px}.import-failure-list{max-height:260px;margin:8px 0 0;padding-left:20px;overflow:auto}.asset-photo-cell{color:#6b7280;background:#f8fafc;border:1px solid #e5e7eb;border-radius:6px;place-items:center;width:48px;height:48px;font-size:12px;display:grid;overflow:hidden}.asset-photo-cell img,.asset-photo-picker img{object-fit:cover;width:100%;height:100%}.asset-photo-picker{color:#6b7280;cursor:pointer;background:#f8fafc;border:1px solid #d1d5db;border-radius:8px;place-items:center;width:96px;height:96px;padding:0;display:grid;overflow:hidden}.asset-photo-clear{margin-left:12px}.list-filters{flex-wrap:nowrap;justify-content:flex-end;align-items:center;gap:12px;margin-left:auto;display:flex}.list-filters .ant-input,.list-filters .ant-picker,.list-filters .ant-select{width:168px}.employee-keyword-filter{width:220px!important}.section-card{margin-top:16px}.table-toolbar.compact{margin-bottom:12px}.summary-filter-panel{margin-bottom:16px}.summary-filters{width:100%}.summary-employee-select,.summary-batch-select{min-width:260px}.employee-status-filter{width:108px}.full-width{width:100%}.avatar-picker{color:#6b7280;cursor:pointer;background:#f8fafc;border:1px solid #d1d5db;border-radius:8px;flex:none;place-items:center;width:104px;height:104px;padding:0;font-size:36px;display:grid;overflow:hidden}.avatar-picker:hover{color:#1677ff;background:#eff6ff;border-color:#93c5fd}.avatar-picker img{object-fit:cover;width:100%;height:100%}.employee-resume{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:18px}.employee-resume-head{border-bottom:1px solid #e5e7eb;align-items:center;gap:18px;margin-bottom:18px;padding-bottom:18px;display:flex}.employee-resume-title{gap:8px;min-width:0;display:grid}.employee-resume-title span{color:#6b7280;font-size:13px}.employee-resume-title strong{color:#111827;text-overflow:ellipsis;white-space:nowrap;font-size:28px;font-weight:700;line-height:1.15;overflow:hidden}.employee-resume-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:0 14px;display:grid}.employee-resume-stat{align-content:center;min-height:56px;display:grid}.employee-resume-stat span{color:#6b7280;font-size:13px}.employee-resume-stat strong{color:#111827;font-size:22px;line-height:1.2}.employee-detail-section{border-top:1px solid #e5e7eb;margin-top:16px;padding-top:16px}.detail-section-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.detail-section-header h4{color:#111827;margin:0;font-size:15px}.detail-section-header p{color:#6b7280;margin:4px 0 0;font-size:13px}.deposit-date-picker{width:150px}.deposit-type-select{width:90px}.deposit-amount-input{width:140px}.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:16px;display:grid}.summary-total-row td{color:#111827;font-weight:650;background:#f8fafc!important}@media (width<=900px){.admin-layout .admin-header{gap:12px;padding:0 14px}.admin-header .header-title{text-overflow:ellipsis;white-space:nowrap;max-width:28vw;overflow:hidden}.header-actions{gap:6px}.header-env,.header-user,.header-action-btn,.header-logout-btn{padding:0 9px}.employee-resume-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-hero,.dashboard-lower{grid-template-columns:1fr}.dashboard-grid,.module-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=760px){.login-panel{padding:28px 22px}.metric-row{grid-template-columns:1fr}.dashboard-hero{padding:22px}.dashboard-hero h2{font-size:30px}.dashboard-grid,.module-stat-grid{grid-template-columns:1fr}.trend-row{grid-template-columns:48px minmax(0,1fr)}.trend-row strong{text-align:left;grid-column:2}.table-toolbar{flex-direction:column;align-items:flex-start;display:flex}.table-actions,.list-filters{flex-wrap:wrap;justify-content:flex-start;width:100%}.summary-grid{grid-template-columns:1fr}.employee-resume-head{flex-direction:column;align-items:flex-start}.employee-resume-grid{grid-template-columns:1fr}.summary-employee-select,.summary-batch-select{width:100%;min-width:0}.employee-keyword-filter,.list-filters .ant-input,.list-filters .ant-picker{width:100%!important}}
