.login-page{display:flex;justify-content:center;align-items:center;min-height:100vh;background:#f9f9f9;padding:16px}.login-page .main{width:100%;max-width:450px;background:#fff;padding:30px;border-radius:12px;box-shadow:0 4px 10px #0000001a}@media(max-width:576px){.login-page .main{padding:24px 16px}}.login-page .heading{margin-bottom:20px}.login-page .heading .text-large{font-size:20px;font-weight:700;color:#000}@media(min-width:576px){.login-page .heading .text-large{font-size:22px}}@media(min-width:768px){.login-page .heading .text-large{font-size:24px}}@media(min-width:992px){.login-page .heading .text-large{font-size:26px}}.login-page .ant-form{width:100%}.login-page .ant-form-item-label label{font-weight:700;color:#444;font-size:13px}@media(min-width:576px){.login-page .ant-form-item-label label{font-size:14px}}.login-page .ant-input,.login-page .ant-input-password{border-radius:6px;height:40px;font-size:14px}@media(max-width:576px){.login-page .ant-input,.login-page .ant-input-password{height:44px;font-size:16px}}.login-page .ant-btn-primary{width:100%;height:40px;font-size:16px;border-radius:6px;background:#4c6ef5;border:none;transition:.3s ease-in-out}@media(max-width:576px){.login-page .ant-btn-primary{height:44px}}.login-page .text-normal{font-size:12px;color:#666}@media(min-width:576px){.login-page .text-normal{font-size:14px}}.login-page .text-link{color:#4c6ef5;font-weight:700;text-decoration:none;transition:.3s ease-in-out}.login-page .ant-divider{color:#666}.work-schedule-calendar .calendar-grid{border:1px solid #f0f0f0;border-radius:8px;overflow:hidden}.work-schedule-calendar .calendar-grid .calendar-header-row{background-color:#fafafa;border-bottom:1px solid #f0f0f0}.work-schedule-calendar .calendar-grid .calendar-header-row .calendar-header-cell{padding:12px;text-align:center;font-weight:600;color:#a90000;border-right:1px solid #f0f0f0;-webkit-user-select:none;user-select:none;transition:all .2s}.work-schedule-calendar .calendar-grid .calendar-header-row .calendar-header-cell.filterable{cursor:pointer}.work-schedule-calendar .calendar-grid .calendar-header-row .calendar-header-cell.filterable:hover{background-color:#fff5f0}.work-schedule-calendar .calendar-grid .calendar-header-row .calendar-header-cell.filterable.active{background-color:#a90000;color:#fff}.work-schedule-calendar .calendar-grid .calendar-header-row .calendar-header-cell:last-child{border-right:none}.work-schedule-calendar .calendar-grid .calendar-body-row .calendar-cell{min-height:150px;border-right:1px solid #f0f0f0;border-bottom:1px solid #f0f0f0;padding:8px;transition:all .2s}.work-schedule-calendar .calendar-grid .calendar-body-row .calendar-cell:nth-child(7n){border-right:none}.work-schedule-calendar .calendar-grid .calendar-body-row .calendar-cell.other-month{background-color:#fbfbfb}.work-schedule-calendar .calendar-grid .calendar-body-row .calendar-cell.other-month .day-number{color:#bfbfbf}.work-schedule-calendar .calendar-grid .calendar-body-row .calendar-cell .cell-header{display:flex;justify-content:flex-end;margin-bottom:8px}.work-schedule-calendar .calendar-grid .calendar-body-row .calendar-cell .cell-header .day-number{font-weight:500;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%}.work-schedule-calendar .calendar-grid .calendar-body-row .calendar-cell .cell-header .day-number.today{background-color:#a90000;color:#fff}.work-schedule-calendar .calendar-grid .calendar-body-row .calendar-cell .cell-content{height:calc(100% - 32px);display:flex;flex-direction:column;justify-content:center}.work-schedule-calendar .calendar-grid .calendar-body-row .calendar-cell .cell-content .shift-selector,.work-schedule-calendar .calendar-grid .calendar-body-row .calendar-cell .cell-content .shift-display{width:100%;height:100%;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:4px}.work-schedule-calendar .calendar-grid .calendar-body-row .calendar-cell .cell-content .shift-selector:hover,.work-schedule-calendar .calendar-grid .calendar-body-row .calendar-cell .cell-content .shift-display:hover{background-color:#fff1f0}.work-schedule-calendar .calendar-grid .calendar-body-row .calendar-cell .cell-content .shift-selector .empty-slot,.work-schedule-calendar .calendar-grid .calendar-body-row .calendar-cell .cell-content .shift-display .empty-slot{color:#d9d9d9;font-size:20px;display:none}.work-schedule-calendar .calendar-grid .calendar-body-row .calendar-cell .cell-content .shift-selector:hover .empty-slot,.work-schedule-calendar .calendar-grid .calendar-body-row .calendar-cell .cell-content .shift-display:hover .empty-slot{display:block}.work-schedule-calendar .calendar-grid .calendar-body-row .calendar-cell .cell-content .shift-selector .shift-tag,.work-schedule-calendar .calendar-grid .calendar-body-row .calendar-cell .cell-content .shift-display .shift-tag{text-align:center;background-color:#fff2e8;border:1px solid #ffbb96;color:#d4380d;padding:4px 8px;border-radius:4px;width:100%}.check-in-out-card .today-text{display:block;color:#fff}.check-in-out-card .check-in-btn{background-color:#ff9a9e;border-color:#ff9a9e;color:#fff;min-width:120px}.check-in-out-card .check-in-btn:hover{background-color:#ff7a80;border-color:#ff7a80;color:#fff}.check-in-out-card .check-out-btn{background-color:#c44569;border-color:#c44569;color:#fff;min-width:120px}.check-in-out-card .check-out-btn:hover{background-color:#b03a5a;border-color:#b03a5a;color:#fff}.attendance-calendar{width:100%;background:#fff;border-radius:8px;padding:16px;box-shadow:0 2px 8px #0000001a}.attendance-calendar .weekday-filter-info,.attendance-calendar .calendar-header{margin-bottom:8px}.attendance-calendar .calendar-header .calendar-header-cell{text-align:center;font-weight:600;padding:8px;color:#595959;font-size:14px;-webkit-user-select:none;user-select:none;transition:all .2s}.attendance-calendar .calendar-header .calendar-header-cell.filterable{cursor:pointer}.attendance-calendar .calendar-header .calendar-header-cell.filterable:hover{background:#f0f5ff}.attendance-calendar .calendar-header .calendar-header-cell.filterable.active{background:#1890ff;color:#fff;border-radius:4px}.attendance-calendar .calendar-body .calendar-day{min-height:80px;border:1px solid #f0f0f0;border-radius:4px;padding:8px;background:#fff;transition:all .2s;position:relative}.attendance-calendar .calendar-body .calendar-day:hover{background:#f5f5f5;border-color:#d9d9d9}.attendance-calendar .calendar-body .calendar-day.other-month{opacity:.4;background:#fff}.attendance-calendar .calendar-body .calendar-day.today{border-color:#1890ff;background:#fff;font-weight:600}.attendance-calendar .calendar-body .calendar-day.today .day-number{color:#1890ff}.attendance-calendar .calendar-body .calendar-day.has-attendance{border-color:#52c41a;background:#fff}.attendance-calendar .calendar-body .calendar-day.has-attendance:hover{background:#f5f5f5;border-color:#1890ff}.attendance-calendar .calendar-body .calendar-day.absent{border-color:#ff4d4f;background:#fff}.attendance-calendar .calendar-body .calendar-day .day-number{font-size:16px;font-weight:500;margin-bottom:4px}.attendance-calendar .calendar-body .calendar-day .day-attendance{display:flex;flex-direction:column;gap:4px;margin-top:4px}.attendance-calendar .calendar-body .calendar-day .day-attendance .time-info{display:flex;align-items:center;gap:4px;font-size:11px;color:#1890ff;font-weight:500}.attendance-calendar .calendar-body .calendar-day .day-attendance .time-info span{line-height:1.2}.attendance-calendar .calendar-body .calendar-day .day-attendance .ant-badge{font-size:11px;line-height:1.2}@media(max-width:768px){.check-in-out-card .ant-card-body{padding:16px 12px}.check-in-out-card .check-in-btn,.check-in-out-card .check-out-btn{min-width:100%;height:44px;font-size:14px}.attendance-calendar{padding:8px}.attendance-calendar .calendar-body .calendar-day{min-height:60px;padding:4px}.attendance-calendar .calendar-body .calendar-day .day-number{font-size:14px}.attendance-calendar .calendar-body .calendar-day .day-attendance .time-info,.attendance-calendar .calendar-body .calendar-day .day-attendance .ant-badge{font-size:9px}}:global .ant-layout-content:has(.chat-layout){padding:0;margin:0;height:calc(100vh - 64px);max-height:calc(100vh - 64px);overflow:hidden}:global .ant-layout-content .chat-content{padding:0;margin:0}.chat-layout{display:flex;height:100%;max-height:100%;overflow:hidden;width:100%}.chat-layout .chat-sidebar{width:300px;border-right:1px solid #f0f0f0;background:#fff;display:flex;flex-direction:column;height:100%;overflow:hidden}.chat-layout .chat-sidebar .ant-tabs{height:100%;display:flex;flex-direction:column}.chat-layout .chat-sidebar .ant-tabs .ant-tabs-content-holder{flex:1;overflow-y:auto}.chat-layout .chat-sidebar .ant-tabs .ant-tabs-tab{padding:12px 16px}.chat-layout .chat-sidebar .ant-list{flex:1;overflow-y:auto}.chat-layout .chat-sidebar .chat-room-item{cursor:pointer;padding:12px 16px;border-bottom:1px solid #f0f0f0;transition:background-color .2s}.chat-layout .chat-sidebar .chat-room-item:hover{background-color:#f5f5f5}.chat-layout .chat-sidebar .chat-room-item.active{background-color:#e6f7ff;border-left:3px solid #1890ff}.chat-layout .chat-sidebar .chat-room-item .ant-list-item-meta-title{margin-bottom:4px}.chat-layout .chat-content{flex:1;display:flex;flex-direction:column;height:100%;max-height:100%;background:#fff;overflow:hidden;min-height:0;position:relative}.chat-layout .chat-content .chat-header{padding:16px 24px;border-bottom:1px solid #f0f0f0;background:#fff;flex-shrink:0;flex-grow:0;flex-basis:auto;display:flex;align-items:center;gap:12px;height:auto;min-height:auto}.chat-layout .chat-content .chat-header .back-button{flex-shrink:0}.chat-layout .chat-content .chat-header h3{margin:0;font-size:18px;font-weight:500;color:#262626;flex:1}.chat-layout .chat-content .chat-messages{flex:1;overflow-y:auto;overflow-x:hidden;padding:16px 24px;background:#fafafa;min-height:0;position:relative;-webkit-overflow-scrolling:touch}.chat-layout .chat-content .chat-messages::-webkit-scrollbar{width:8px}.chat-layout .chat-content .chat-messages::-webkit-scrollbar-track{background:#f0f0f0;border-radius:4px}.chat-layout .chat-content .chat-messages::-webkit-scrollbar-thumb{background:#bfbfbf;border-radius:4px}.chat-layout .chat-content .chat-messages::-webkit-scrollbar-thumb:hover{background:#999}.chat-layout .chat-content .chat-messages .chat-message{display:flex;margin-bottom:16px;align-items:flex-start}.chat-layout .chat-content .chat-messages .chat-message.own{flex-direction:row-reverse}.chat-layout .chat-content .chat-messages .chat-message.own .message-content{background:#1890ff;color:#fff;margin-right:8px}.chat-layout .chat-content .chat-messages .chat-message.own .message-content .message-header .sender-name{color:#ffffffe6}.chat-layout .chat-content .chat-messages .chat-message.own .message-content .message-header .message-time{color:#ffffffb3}.chat-layout .chat-content .chat-messages .chat-message.other .message-content{background:#fff;margin-left:8px;border:1px solid #e8e8e8}.chat-layout .chat-content .chat-messages .chat-message .ant-avatar{flex-shrink:0}.chat-layout .chat-content .chat-messages .chat-message .message-content{max-width:70%;padding:10px 14px;border-radius:12px;box-shadow:0 1px 2px #0000000d}.chat-layout .chat-content .chat-messages .chat-message .message-content .message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:12px}.chat-layout .chat-content .chat-messages .chat-message .message-content .message-header .sender-name{font-weight:500;margin-right:8px}.chat-layout .chat-content .chat-messages .chat-message .message-content .message-header .message-time{opacity:.7;white-space:nowrap}.chat-layout .chat-content .chat-messages .chat-message .message-content .message-text{word-wrap:break-word;white-space:pre-wrap;line-height:1.5}.chat-layout .chat-content .chat-messages .typing-indicator{padding:8px 16px;font-style:italic;color:#999;font-size:12px}.chat-layout .chat-content .chat-input{padding:16px 24px;border-top:1px solid #f0f0f0;background:#fff;display:flex;gap:12px;align-items:flex-end;flex-shrink:0;flex-grow:0;flex-basis:auto;height:auto;min-height:auto}.chat-layout .chat-content .chat-input .ant-input{flex:1}.chat-layout .chat-content .chat-input .ant-btn{height:auto;padding:4px 16px}@media(max-width:992px){.chat-layout .chat-sidebar{width:250px}}@media(max-width:768px){.chat-layout.mobile{position:relative;height:calc(100vh - 64px);max-height:calc(100vh - 64px);overflow:hidden;width:100%;display:block}.chat-layout.mobile .chat-sidebar{width:100%;height:100%;max-height:100%;border-right:none;position:absolute;top:0;left:0;z-index:1;transition:transform .3s ease-in-out;transform:translate(0);display:flex;flex-direction:column}.chat-layout.mobile .chat-sidebar.hidden{transform:translate(-100%)}.chat-layout.mobile .chat-sidebar .ant-tabs-content-holder{overflow-y:auto;flex:1;min-height:0}.chat-layout.mobile .chat-content{width:100%;height:100%;max-height:100%;position:absolute;top:0;left:0;z-index:2;transition:transform .3s ease-in-out;transform:translate(100%);display:flex;flex-direction:column}.chat-layout.mobile .chat-content.hidden{transform:translate(100%)}.chat-layout.mobile.show-chat-view .chat-sidebar{transform:translate(-100%)}.chat-layout.mobile.show-chat-view .chat-content{transform:translate(0)}.chat-layout.mobile .chat-messages{padding:12px 16px;min-height:0;flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.chat-layout.mobile .chat-messages::-webkit-scrollbar{width:6px}.chat-layout.mobile .chat-messages::-webkit-scrollbar-track{background:#f0f0f0}.chat-layout.mobile .chat-messages::-webkit-scrollbar-thumb{background:#bfbfbf;border-radius:3px}.chat-layout.mobile .chat-messages::-webkit-scrollbar-thumb:hover{background:#999}.chat-layout.mobile .chat-input,.chat-layout.mobile .chat-header{padding:12px 16px;flex-shrink:0}.chat-layout.mobile .chat-header h3{font-size:16px}}@media(max-width:576px){.chat-layout.mobile .chat-messages{padding:8px 12px}.chat-layout.mobile .chat-messages .chat-message{margin-bottom:12px}.chat-layout.mobile .chat-messages .chat-message .message-content{max-width:85%;padding:8px 12px;font-size:14px}.chat-layout.mobile .chat-input{padding:8px 12px}.chat-layout.mobile .chat-input .ant-input{font-size:14px}}.notification-dropdown{width:420px;max-width:90vw;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;overflow:hidden}.notification-dropdown .notification-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #f0f0f0}.notification-dropdown .notification-tabs-wrapper{padding:0 20px;border-bottom:1px solid #f0f0f0}.notification-dropdown .notification-tabs-wrapper .notification-tabs .ant-tabs-nav{margin:0;padding:0}.notification-dropdown .notification-tabs-wrapper .notification-tabs .ant-tabs-nav:before{border-bottom:1px solid #f0f0f0}.notification-dropdown .notification-tabs-wrapper .notification-tabs .ant-tabs-nav .ant-tabs-tab{padding:12px 0;margin:0 16px 0 0}.notification-dropdown .notification-tabs-wrapper .notification-tabs .ant-tabs-content-holder{display:none}.notification-dropdown .notification-list-container{min-height:200px;max-height:450px;display:flex;flex-direction:column}.notification-dropdown .notification-loading{text-align:center;padding:40px 20px}.notification-dropdown .notification-empty{padding:40px 20px}.notification-dropdown .notification-list{flex:1;overflow-y:auto;padding:0}.notification-dropdown .notification-list .ant-list-item{padding:12px 20px;margin:0;border-bottom:1px solid #f0f0f0;transition:background-color .2s}.notification-dropdown .notification-list .ant-list-item:hover{background-color:#f5f5f5}.notification-dropdown .notification-list .ant-list-item.unread{background-color:#fff1f0}.notification-dropdown .notification-list .ant-list-item.unread:hover{background-color:#ffe7e5}.notification-dropdown .notification-list .ant-list-item .notification-item-title{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:4px}.notification-dropdown .notification-list .ant-list-item .notification-item-title .notification-title-text{flex:1;font-size:14px;line-height:1.5}.notification-dropdown .notification-list .ant-list-item .notification-item-title .notification-time{font-size:12px;white-space:nowrap;flex-shrink:0}.notification-dropdown .notification-list .ant-list-item .notification-item-content .notification-content-text{font-size:13px;line-height:1.5;color:#666;display:block;margin-bottom:6px}.notification-dropdown .notification-list .ant-list-item .notification-item-content .notification-type-badge{margin-top:4px}.notification-dropdown .notification-list .ant-list-item .notification-item-content .notification-type-badge .notification-type-text{font-size:11px;font-weight:500;text-transform:uppercase}.notification-dropdown .notification-pagination{padding:12px 20px;border-top:1px solid #f0f0f0;display:flex;justify-content:center;background:#fafafa}.notification-dropdown .notification-pagination .ant-pagination{margin:0}.notification-popover-overlay .ant-popover-inner,.notification-popover-overlay .ant-popover-inner-content{padding:0}.notification-detail-modal,.notification-detail-modal.ant-modal{z-index:1050}.notification-detail-modal .ant-modal-mask{z-index:1049}.notification-detail-modal .ant-modal-wrap{z-index:1050}@media(max-width:768px){.notification-popover-overlay .ant-popover{left:50%!important;transform:translate(-50%)!important;right:auto!important}.notification-dropdown{width:calc(100vw - 24px);max-width:calc(100vw - 24px);margin:0 auto}.notification-dropdown .notification-header{padding:14px 16px}.notification-dropdown .notification-tabs-wrapper{padding:0 16px}.notification-dropdown .notification-tabs-wrapper .notification-tabs .ant-tabs-nav .ant-tabs-tab{margin:0 12px 0 0;padding:10px 0}.notification-dropdown .notification-list .ant-list-item{padding:12px 16px}.notification-dropdown .notification-pagination{padding:10px 16px}}@media(max-width:576px){.notification-popover-overlay .ant-popover{left:50%!important;transform:translate(-50%)!important;right:auto!important;max-width:calc(100vw - 16px)}.notification-dropdown{width:100%;max-width:100%;margin:0;border-radius:4px}.notification-dropdown .notification-header{padding:12px 14px;font-size:14px}.notification-dropdown .notification-tabs-wrapper{padding:0 14px}.notification-dropdown .notification-tabs-wrapper .notification-tabs .ant-tabs-nav .ant-tabs-tab{margin:0 8px 0 0;padding:8px 0;font-size:13px}.notification-dropdown .notification-list-container{max-height:60vh}.notification-dropdown .notification-list .ant-list-item{padding:10px 14px}.notification-dropdown .notification-list .ant-list-item .notification-item-title .notification-title-text{font-size:13px}.notification-dropdown .notification-list .ant-list-item .notification-item-title .notification-time{font-size:11px}.notification-dropdown .notification-list .ant-list-item .notification-item-content .notification-content-text{font-size:12px}.notification-dropdown .notification-pagination{padding:8px 14px}.notification-dropdown .notification-pagination .ant-pagination{font-size:12px}.notification-dropdown .notification-pagination .ant-pagination .ant-pagination-item,.notification-dropdown .notification-pagination .ant-pagination .ant-pagination-prev,.notification-dropdown .notification-pagination .ant-pagination .ant-pagination-next{min-width:28px;height:28px;line-height:26px}}@media(max-width:375px){.notification-popover-overlay .ant-popover{left:50%!important;transform:translate(-50%)!important;right:auto!important;max-width:calc(100vw - 12px)}.notification-dropdown{width:100%;max-width:100%;margin:0}.notification-dropdown .notification-header{padding:10px 12px}.notification-dropdown .notification-tabs-wrapper{padding:0 12px}.notification-dropdown .notification-tabs-wrapper .notification-tabs .ant-tabs-nav .ant-tabs-tab{margin:0 6px 0 0;padding:6px 0;font-size:12px}.notification-dropdown .notification-list .ant-list-item{padding:8px 12px}}.app-header{background:#fff;padding:0 16px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px 4px #00152914;flex-wrap:wrap;gap:8px;position:fixed;top:0;left:0;right:0;width:100%;height:64px;z-index:1000}.app-header .header-left{display:flex;align-items:center;gap:16px}.app-header .menu-toggle-btn{font-size:18px;display:flex;align-items:center;justify-content:center}.app-header .header-title{font-size:18px;color:#1890ff;flex-shrink:0}@media(max-width:768px){.app-header .header-title{font-size:14px}}.app-header .header-right{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.app-header .notification-btn{display:flex;align-items:center;justify-content:center}.app-header .user-dropdown{cursor:pointer}.app-header .profile-modal{max-width:600px}.app-sidebar{background:#fff;box-shadow:2px 0 8px #1d23290d;position:fixed;left:0;top:64px;height:calc(100vh - 64px);overflow:hidden;z-index:100;transition:width .2s}.app-sidebar .sidebar-header{height:64px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid #f0f0f0;font-weight:700;font-size:16px;color:#1890ff;padding:0 12px}.app-sidebar .sidebar-menu{height:calc(100vh - 128px);border-right:0;overflow-y:auto}.app-sidebar-drawer{z-index:1000}.app-sidebar-drawer :global(.ant-drawer-body){padding:0}*{margin:0}
