.attendance-filters[data-v-f723fbc0]{position:sticky;top:60px;z-index:10;margin-bottom:16px}.attendance-filters .filters-card[data-v-f723fbc0]{background:#fff;border-radius:12px;padding:20px;-webkit-box-shadow:0 2px 8px rgba(0,0,0,.08);box-shadow:0 2px 8px rgba(0,0,0,.08);border:1px solid #e8eaec;-webkit-transition:all .3s ease;transition:all .3s ease}.attendance-filters .filters-card[data-v-f723fbc0]:hover{-webkit-box-shadow:0 3px 12px rgba(0,0,0,.12);box-shadow:0 3px 12px rgba(0,0,0,.12)}@media(max-width:768px){.attendance-filters .filters-card[data-v-f723fbc0]{padding:16px;border-radius:8px}}.attendance-filters .filter-group[data-v-f723fbc0]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.attendance-filters .filter-group .filter-label[data-v-f723fbc0]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:6px;font-weight:600;margin-bottom:8px;font-size:13px;color:#17233d}.attendance-filters .filter-group .filter-label i[data-v-f723fbc0]{color:#667eea}.attendance-filters .filter-group .filter-label.required[data-v-f723fbc0]:after{content:"*";color:#ed4014;margin-left:4px}.attendance-filters .quick-filters[data-v-f723fbc0]{margin-top:16px;padding-top:16px;border-top:2px dashed #e8eaec;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:12px;-ms-flex-wrap:wrap;flex-wrap:wrap}.attendance-filters .quick-filters .quick-filters-label[data-v-f723fbc0]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#515a6e}.attendance-filters .quick-filters .quick-filters-label i[data-v-f723fbc0]{color:#667eea}.attendance-filters .quick-filters .quick-filter-buttons[data-v-f723fbc0]{display:-webkit-box;display:-ms-flexbox;display:flex;gap:8px;-ms-flex-wrap:wrap;flex-wrap:wrap}.attendance-filters .quick-filters .quick-filter-buttons button[data-v-f723fbc0]{border-radius:20px;padding:6px 16px;font-size:12px;font-weight:600;-webkit-transition:all .2s ease;transition:all .2s ease;border:2px solid #e8eaec;background:#fff;color:#515a6e}.attendance-filters .quick-filters .quick-filter-buttons button[data-v-f723fbc0]:hover{border-color:#667eea;color:#667eea;-webkit-transform:translateY(-2px);transform:translateY(-2px);-webkit-box-shadow:0 4px 8px rgba(102,126,234,.2);box-shadow:0 4px 8px rgba(102,126,234,.2)}.attendance-filters .quick-filters .quick-filter-buttons button[data-v-f723fbc0]:active{-webkit-transform:translateY(0);transform:translateY(0)}.attendance-filters[data-v-f723fbc0] .date-picker-custom .ivu-input{border-radius:8px;border:2px solid #e8eaec;padding:8px 12px;-webkit-transition:all .2s ease;transition:all .2s ease}.attendance-filters[data-v-f723fbc0] .date-picker-custom .ivu-input:hover{border-color:#c5c8ce}.attendance-filters[data-v-f723fbc0] .date-picker-custom .ivu-input:focus{border-color:#667eea;-webkit-box-shadow:0 0 0 3px rgba(102,126,234,.1);box-shadow:0 0 0 3px rgba(102,126,234,.1)}.attendance-filters[data-v-f723fbc0] .select-custom .ivu-select-selection{border-radius:8px;border:2px solid #e8eaec;-webkit-transition:all .2s ease;transition:all .2s ease}.attendance-filters[data-v-f723fbc0] .select-custom .ivu-select-selection:hover{border-color:#c5c8ce}.attendance-filters[data-v-f723fbc0] .select-custom.ivu-select-focused .ivu-select-selection{border-color:#667eea;-webkit-box-shadow:0 0 0 3px rgba(102,126,234,.1);box-shadow:0 0 0 3px rgba(102,126,234,.1)}.attendance-filters[data-v-f723fbc0] .search-button{border-radius:8px;font-weight:600;height:40px;border:none;-webkit-box-shadow:0 4px 12px rgba(102,126,234,.3);box-shadow:0 4px 12px rgba(102,126,234,.3);-webkit-transition:all .3s ease;transition:all .3s ease}.attendance-filters[data-v-f723fbc0] .search-button:hover{-webkit-transform:translateY(-2px);transform:translateY(-2px);-webkit-box-shadow:0 6px 16px rgba(102,126,234,.4);box-shadow:0 6px 16px rgba(102,126,234,.4)}.attendance-filters[data-v-f723fbc0] .search-button:active{-webkit-transform:translateY(0);transform:translateY(0)}[data-v-f723fbc0] .ivu-date-picker-transfer,[data-v-f723fbc0] .ivu-select-dropdown{z-index:20!important}[data-v-f723fbc0] .ivu-select-dropdown{border-radius:8px;-webkit-box-shadow:0 4px 16px rgba(0,0,0,.15);box-shadow:0 4px 16px rgba(0,0,0,.15);border:1px solid #e8eaec}[data-v-f723fbc0] .ivu-select-dropdown .ivu-select-item{padding:8px 12px;-webkit-transition:all .2s ease;transition:all .2s ease}[data-v-f723fbc0] .ivu-select-dropdown .ivu-select-item:hover{background:#f7f8fa;color:#667eea}[data-v-f723fbc0] .ivu-select-dropdown .ivu-select-item.ivu-select-item-selected{color:#fff;font-weight:600}[data-v-f723fbc0] .ivu-date-picker-transfer .ivu-picker-panel-body{border-radius:8px}[data-v-f723fbc0] .ivu-date-picker-transfer .ivu-date-picker-cells-cell-selected div{color:#fff}[data-v-f723fbc0] .ivu-date-picker-transfer .ivu-date-picker-cells-cell:hover{background:#f7f8fa}[data-v-f723fbc0] .ivu-date-picker-transfer .ivu-date-picker-cells-cell:hover div{color:#667eea}.photo-card[data-v-893b5028]{background:#fff;border-radius:8px;overflow:hidden;-webkit-box-shadow:0 1px 4px rgba(0,0,0,.08);box-shadow:0 1px 4px rgba(0,0,0,.08);-webkit-transition:all .3s cubic-bezier(.4,0,.2,1);transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.photo-card[data-v-893b5028]:hover{-webkit-box-shadow:0 4px 12px rgba(102,126,234,.25);box-shadow:0 4px 12px rgba(102,126,234,.25);-webkit-transform:translateY(-2px);transform:translateY(-2px)}.photo-card:hover .photo-image[data-v-893b5028]{-webkit-transform:scale(1.08);transform:scale(1.08)}.photo-card:hover .photo-overlay[data-v-893b5028]{opacity:1}.photo-card[data-v-893b5028]:active{-webkit-transform:translateY(0);transform:translateY(0)}.photo-card .photo-wrapper[data-v-893b5028]{position:relative;width:100%;padding-top:100%;overflow:hidden}.photo-card .photo-wrapper .photo-image[data-v-893b5028]{position:absolute;top:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;-webkit-transition:-webkit-transform .4s cubic-bezier(.4,0,.2,1);transition:-webkit-transform .4s cubic-bezier(.4,0,.2,1);transition:transform .4s cubic-bezier(.4,0,.2,1);transition:transform .4s cubic-bezier(.4,0,.2,1),-webkit-transform .4s cubic-bezier(.4,0,.2,1)}.photo-card .photo-wrapper .photo-overlay[data-v-893b5028]{position:absolute;top:0;left:0;right:0;bottom:0;background:-webkit-gradient(linear,left top,left bottom,from(rgba(102,126,234,.6)),to(rgba(118,75,162,.7)));background:linear-gradient(180deg,rgba(102,126,234,.6) 0,rgba(118,75,162,.7));display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;opacity:0;-webkit-transition:opacity .3s ease;transition:opacity .3s ease}.photo-card .photo-wrapper .photo-overlay .expand-icon[data-v-893b5028]{color:#fff;-webkit-filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.photo-card .card-info[data-v-893b5028]{padding:8px;background:#fafafa;-webkit-box-flex:1;-ms-flex:1;flex:1;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;gap:4px}.photo-card .card-info .employee-name[data-v-893b5028]{font-weight:600;font-size:11px;color:#17233d;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}.photo-card .card-info .info-row[data-v-893b5028]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:4px;font-size:10px;color:#808695;line-height:1.2}.photo-card .card-info .info-row i[data-v-893b5028]{-ms-flex-negative:0;flex-shrink:0;color:#667eea}.photo-card .card-info .info-row span[data-v-893b5028]{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}@media(max-width:768px){.photo-card[data-v-893b5028]:hover{-webkit-transform:none;transform:none}.photo-card .card-info[data-v-893b5028]{padding:6px;gap:3px}.photo-card .card-info .employee-name[data-v-893b5028]{font-size:10px}.photo-card .card-info .info-row[data-v-893b5028]{font-size:9px}}.date-group[data-v-3b480dce]{margin-bottom:16px;position:relative}.date-group .date-header[data-v-3b480dce]{background:#f7f8fa;border-bottom:1px solid #e8eaec;position:sticky;top:236px;z-index:8;-webkit-transition:all .3s cubic-bezier(.4,0,.2,1);transition:all .3s cubic-bezier(.4,0,.2,1)}.date-group .date-header .header-content[data-v-3b480dce]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;-webkit-box-align:center;-ms-flex-align:center;align-items:center;padding:8px 16px;-webkit-transition:all .3s ease;transition:all .3s ease}@media(max-width:768px){.date-group .date-header .header-content[data-v-3b480dce]{padding:6px 12px}}.date-group .date-header .date-text[data-v-3b480dce]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:8px}.date-group .date-header .date-text .date-icon[data-v-3b480dce]{color:#667eea;-ms-flex-negative:0;flex-shrink:0}.date-group .date-header .date-text .date-title[data-v-3b480dce]{font-size:13px;font-weight:600;color:#17233d;letter-spacing:.2px}@media(max-width:768px){.date-group .date-header .date-text .date-title[data-v-3b480dce]{font-size:12px}}.date-group .date-header .count-badge[data-v-3b480dce]{display:-webkit-inline-box;display:-ms-inline-flexbox;display:inline-flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:4px;padding:3px 10px;background:rgba(102,126,234,.1);border-radius:12px;font-size:11px;font-weight:600;color:#667eea;-webkit-transition:all .2s ease;transition:all .2s ease}.date-group .date-header .count-badge i[data-v-3b480dce]{-ms-flex-negative:0;flex-shrink:0}@media(max-width:768px){.date-group .date-header .count-badge[data-v-3b480dce]{font-size:10px;padding:2px 8px}}.date-group .date-header.is-stuck[data-v-3b480dce]{background:hsla(0,0%,100%,.98);-webkit-backdrop-filter:blur(12px) saturate(180%);backdrop-filter:blur(12px) saturate(180%);-webkit-box-shadow:0 2px 12px rgba(102,126,234,.15);box-shadow:0 2px 12px rgba(102,126,234,.15);border-bottom:2px solid #667eea}.date-group .date-header.is-stuck .header-content[data-v-3b480dce]{padding:6px 16px}@media(max-width:768px){.date-group .date-header.is-stuck .header-content[data-v-3b480dce]{padding:5px 12px}}.date-group .date-header.is-stuck .date-text .date-title[data-v-3b480dce]{font-size:12px}@media(max-width:768px){.date-group .date-header.is-stuck .date-text .date-title[data-v-3b480dce]{font-size:11px}}.date-group .date-header.is-stuck .count-badge[data-v-3b480dce]{-webkit-box-shadow:0 2px 6px rgba(102,126,234,.3);box-shadow:0 2px 6px rgba(102,126,234,.3)}.date-group .photo-grid[data-v-3b480dce]{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;padding:12px;background:#fff}@media(max-width:1400px){.date-group .photo-grid[data-v-3b480dce]{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}}@media(max-width:1024px){.date-group .photo-grid[data-v-3b480dce]{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}@media(max-width:768px){.date-group .photo-grid[data-v-3b480dce]{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px;padding:8px}}@media(max-width:480px){.date-group .photo-grid[data-v-3b480dce]{grid-template-columns:repeat(3,1fr);gap:6px;padding:6px}}[data-v-3b480dce] .viewer-backdrop{background-color:rgba(0,0,0,.9)}[data-v-3b480dce] .viewer-title{color:#fff;font-size:16px;font-weight:600}[data-v-3b480dce] .viewer-toolbar>li{background-color:hsla(0,0%,100%,.1);border-radius:4px}[data-v-3b480dce] .viewer-toolbar>li:hover{background-color:hsla(0,0%,100%,.2)}[data-v-3b480dce] .viewer-button{background-color:hsla(0,0%,100%,.1)}[data-v-3b480dce] .viewer-button:hover{background-color:hsla(0,0%,100%,.2)}.attendance-grid[data-v-d5d3ca72]{min-height:60vh}.attendance-grid .loading-container[data-v-d5d3ca72]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;min-height:400px;border-radius:16px;-webkit-box-shadow:0 10px 30px rgba(102,126,234,.3);box-shadow:0 10px 30px rgba(102,126,234,.3)}.attendance-grid .loading-container .loading-content[data-v-d5d3ca72]{text-align:center;color:#fff}.attendance-grid .loading-container .loading-content .loading-text[data-v-d5d3ca72]{margin-top:16px;font-size:16px;font-weight:500;letter-spacing:.5px}.attendance-grid .date-groups-wrapper .date-groups[data-v-d5d3ca72]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;gap:16px}.attendance-grid .empty-state[data-v-d5d3ca72]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;min-height:500px;padding:40px 20px}.attendance-grid .empty-state .empty-state-content[data-v-d5d3ca72]{text-align:center;max-width:500px}.attendance-grid .empty-state .empty-state-content .empty-icon-wrapper[data-v-d5d3ca72]{display:-webkit-inline-box;display:-ms-inline-flexbox;display:inline-flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;width:140px;height:140px;border-radius:50%;margin-bottom:32px;-webkit-box-shadow:0 10px 40px rgba(102,126,234,.3);box-shadow:0 10px 40px rgba(102,126,234,.3)}.attendance-grid .empty-state .empty-state-content .empty-icon-wrapper .empty-icon[data-v-d5d3ca72]{color:#fff}.attendance-grid .empty-state .empty-state-content .empty-title[data-v-d5d3ca72]{font-size:24px;color:#17233d;margin-bottom:12px;font-weight:700}.attendance-grid .empty-state .empty-state-content .empty-description[data-v-d5d3ca72]{color:#808695;font-size:15px;line-height:1.6;margin-bottom:32px}.attendance-grid .empty-state .empty-state-content .empty-suggestions[data-v-d5d3ca72]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;gap:12px;text-align:left;background:#f7f8fa;padding:24px;border-radius:12px;border:2px dashed #dcdee2}.attendance-grid .empty-state .empty-state-content .empty-suggestions .suggestion-item[data-v-d5d3ca72]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:12px;color:#515a6e;font-size:14px;font-weight:500}.attendance-grid .empty-state .empty-state-content .empty-suggestions .suggestion-item i[data-v-d5d3ca72]{color:#667eea}.attendance-grid .fade-slide-enter-active[data-v-d5d3ca72],.attendance-grid .fade-slide-leave-active[data-v-d5d3ca72]{-webkit-transition:all .4s ease;transition:all .4s ease}.attendance-grid .fade-slide-enter[data-v-d5d3ca72]{opacity:0;-webkit-transform:translateY(20px);transform:translateY(20px)}.attendance-grid .fade-slide-leave-to[data-v-d5d3ca72]{opacity:0;-webkit-transform:translateY(-20px);transform:translateY(-20px)}.attendance-gallery-container[data-v-c7d29c6e]{min-height:100vh;background:#f0f2f5;padding:0 16px 16px 16px}[data-v-c7d29c6e] .viewer-backdrop{background-color:rgba(0,0,0,.92)}[data-v-c7d29c6e] .viewer-container{z-index:9999}[data-v-c7d29c6e] .viewer-canvas>img{max-width:90%;max-height:90%}[data-v-c7d29c6e] .viewer-toolbar{border-radius:8px;padding:8px}[data-v-c7d29c6e] .viewer-toolbar>li{background-color:hsla(0,0%,100%,.1);border-radius:6px;margin:0 4px;-webkit-transition:all .2s ease;transition:all .2s ease}[data-v-c7d29c6e] .viewer-toolbar>li:hover{background-color:hsla(0,0%,100%,.25);-webkit-transform:scale(1.1);transform:scale(1.1)}[data-v-c7d29c6e] .viewer-toolbar>li:before{color:#fff}[data-v-c7d29c6e] .viewer-title{font-weight:600;padding:12px 20px;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}[data-v-c7d29c6e] .viewer-button{border-radius:50%;width:48px;height:48px;-webkit-transition:all .2s ease;transition:all .2s ease}[data-v-c7d29c6e] .viewer-button:hover{-webkit-transform:scale(1.1);transform:scale(1.1)}[data-v-c7d29c6e] .viewer-button:before{color:#fff}[data-v-c7d29c6e] .viewer-navbar{border-radius:8px;padding:8px}[data-v-c7d29c6e] .viewer-navbar>ul>li{border-radius:6px;overflow:hidden;border:2px solid transparent;-webkit-transition:all .2s ease;transition:all .2s ease}[data-v-c7d29c6e] .viewer-navbar>ul>li.viewer-active,[data-v-c7d29c6e] .viewer-navbar>ul>li:hover{border-color:#fff}[data-v-c7d29c6e] .viewer-loading:after{border-color:#667eea transparent transparent}[data-v-c7d29c6e]::-webkit-scrollbar{width:10px;height:10px}[data-v-c7d29c6e]::-webkit-scrollbar-track{background:#f0f2f5;border-radius:5px}[data-v-c7d29c6e]::-webkit-scrollbar-thumb{border-radius:5px}