:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{width:100%;margin:0;padding:0}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;padding:0;min-width:320px;min-height:100vh;width:100%}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.dashboard-container{background-color:#f8f9fa;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.page-title{font-size:32px;font-weight:700;margin:0;color:#1a1a1a;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.date-text{font-size:16px;font-weight:500;color:#666;background-color:#f0f0f0;padding:8px 16px;border-radius:20px}.report-btn{background-color:#fff;border:2px solid #667eea;border-radius:8px;padding:10px 20px;font-size:14px;cursor:pointer;display:flex;align-items:center;gap:6px;color:#667eea;font-weight:500;transition:all .3s ease}.report-btn:hover{background-color:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 4px 15px #667eea4d}.add-btn{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border:none;border-radius:8px;padding:10px 20px;font-size:14px;cursor:pointer;font-weight:500;transition:all .3s ease}.add-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #4caf504d}.controls-section{background-color:#fff;border-radius:12px;padding:20px;margin-bottom:32px;box-shadow:0 2px 10px #0000001a}.control-select{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;min-width:200px;background-color:#fff;transition:border-color .3s ease}.control-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.error-message{background-color:#fee;color:#c33;padding:16px;border-radius:8px;margin-bottom:24px;border:1px solid #fcc;font-size:14px;font-weight:500}.dashboard-summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:40px}.dashboard-summary-cards .summary-card{text-align:center;padding:32px 24px;background:#fff;border-radius:16px;box-shadow:0 4px 20px #0000001a;transition:all .3s ease;border:2px solid transparent;position:relative;overflow:hidden}.dashboard-summary-cards .summary-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(135deg,#667eea,#764ba2)}.dashboard-summary-cards .summary-card:hover{transform:translateY(-8px);box-shadow:0 8px 30px #00000026;border-color:#667eea}.summary-card-title{font-size:14px;font-weight:600;margin:0 0 16px;color:#666;text-transform:uppercase;letter-spacing:1px}.summary-value{font-size:48px;font-weight:700;margin:12px 0 8px;line-height:1;color:#333}.summary-value.present{color:#4caf50}.summary-value.late{color:#ff9800}.summary-value.absent{color:#f44336}.summary-value.rate{color:#2196f3}.summary-label{font-size:12px;color:#999;text-transform:uppercase;letter-spacing:1px;font-weight:500}.employee-spotlight{margin-bottom:40px}.section-title{font-size:28px;font-weight:700;margin-bottom:24px;color:#333;position:relative;padding-left:20px}.section-title:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:30px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:2px}.spotlight-card{background-color:#fff;border-radius:16px;padding:32px;box-shadow:0 4px 20px #0000001a;display:flex;align-items:center;gap:32px;transition:transform .3s ease}.spotlight-card:hover{transform:translateY(-4px)}.employee-photo{flex-shrink:0}.photo-image{width:100px;height:100px;border-radius:50%;object-fit:cover;border:4px solid #4CAF50;box-shadow:0 4px 15px #4caf504d}.photo-placeholder{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,#4caf50,#45a049);display:flex;align-items:center;justify-content:center;color:#fff;font-size:36px;font-weight:700;box-shadow:0 4px 15px #4caf504d}.employee-spotlight-info{flex:1}.employee-spotlight-name{font-size:28px;font-weight:700;margin:0 0 8px;color:#333}.employee-spotlight-nip{font-size:16px;color:#666;margin:0 0 24px;font-weight:500}.employee-stats{display:flex;gap:40px}.employee-stats .stat-item{text-align:center}.employee-stats .stat-label{display:block;font-size:12px;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-weight:600}.employee-stats .stat-value{display:block;font-size:32px;font-weight:700;color:#4caf50}.stat-item.today-attendance .stat-value{font-weight:700;font-size:18px}.stat-item.morning-time{background:linear-gradient(135deg,#e3f2fd,#bbdefb);padding:12px 16px;border-radius:8px;border-left:4px solid #2196f3;margin-top:8px}.stat-item.morning-time .stat-label{color:#1976d2;font-weight:600;font-size:11px}.stat-item.morning-time .stat-value{color:#0d47a1;font-weight:700;font-size:20px}.employee-list-today{margin-bottom:40px}.employee-list-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden;max-height:600px;overflow-y:auto}.employee-list-item{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid #f0f0f0;transition:background-color .2s ease}.employee-list-item:hover{background-color:#f8f9fa}.employee-list-item:last-child{border-bottom:none}.employee-rank{font-weight:700;font-size:18px;color:#666;width:50px;text-align:center;margin-right:16px}.employee-info-compact{display:flex;align-items:center;flex:1;gap:12px}.employee-avatar-small{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0}.avatar-image-small{width:100%;height:100%;object-fit:cover}.avatar-placeholder-small{width:100%;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px}.employee-details-compact{flex:1}.employee-name-compact{font-size:16px;font-weight:600;color:#333;margin:0 0 4px}.employee-nip-compact{font-size:12px;color:#666;margin:0}.attendance-status-today{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.status-badge .status{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}.status-badge .status.present{background-color:#e8f5e8;color:#2e7d32;border:1px solid #4caf50}.status-badge .status.late{background-color:#fff3e0;color:#f57c00;border:1px solid #ff9800}.status-badge .status.absent{background-color:#ffebee;color:#d32f2f;border:1px solid #f44336}.check-in-time{font-size:12px;color:#1976d2;font-weight:600;background:#e3f2fd;padding:2px 8px;border-radius:12px}.charts-section{margin-bottom:40px}.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}@media (max-width: 1024px){.charts-grid{grid-template-columns:1fr}}.chart-card{background-color:#fff;border-radius:16px;padding:32px;box-shadow:0 4px 20px #0000001a;transition:transform .3s ease}.chart-card:hover{transform:translateY(-4px)}.chart-title{font-size:20px;font-weight:700;margin:0 0 24px;color:#333}.chart-container{min-height:350px;display:flex;align-items:center;justify-content:center;flex-direction:column}.chart-legend{display:flex;flex-direction:column;gap:8px;width:100%;max-width:250px;flex-shrink:0}.legend-item{display:flex;align-items:center;gap:16px;font-size:16px;color:#333;font-weight:500}.legend-color{width:20px;height:20px;border-radius:50%;box-shadow:0 2px 8px #0003}.legend-color.present{background-color:#4caf50}.legend-color.late{background-color:#ff9800}.legend-color.absent{background-color:#f44336}.trend-chart{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.trend-bars{display:flex;align-items:end;gap:12px;height:180px}.trend-bar-container{display:flex;flex-direction:column;align-items:center;gap:12px}.trend-bar{width:32px;background:linear-gradient(135deg,#4caf50,#45a049);border-radius:6px 6px 0 0;min-height:8px;transition:all .3s ease;cursor:pointer;box-shadow:0 2px 8px #4caf504d}.trend-bar:hover{background:linear-gradient(135deg,#45a049,#4caf50);transform:scaleY(1.1) scaleX(1.1);box-shadow:0 4px 15px #4caf5080}.trend-label{font-size:14px;color:#666;font-weight:600}.quick-actions{margin-bottom:40px}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px}.action-card{background:#fff;border:2px solid #e0e0e0;border-radius:16px;padding:24px;text-align:center;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:12px}.action-card:hover{border-color:#667eea;transform:translateY(-4px);box-shadow:0 8px 25px #667eea26}.action-icon{font-size:32px;margin-bottom:8px}.action-title{font-size:18px;font-weight:600;color:#333;margin:0}.action-description{font-size:14px;color:#666;margin:0}@media (max-width: 768px){.page-header{flex-direction:column;align-items:flex-start;gap:16px}.page-title{font-size:24px}.dashboard-summary-cards{grid-template-columns:repeat(2,1fr);gap:16px}.summary-value{font-size:36px}.spotlight-card{flex-direction:column;text-align:center;gap:24px}.employee-stats{justify-content:center;gap:24px}.charts-grid,.actions-grid{grid-template-columns:1fr}.main-content{padding:16px}}@media (max-width: 480px){.dashboard-summary-cards{grid-template-columns:1fr}.employee-stats{flex-direction:column;gap:16px}.employee-list-item{flex-direction:column;align-items:flex-start;gap:12px}.employee-rank{width:auto;margin-right:0;font-size:16px}.attendance-status-today{align-items:flex-start;width:100%}}.pie-chart-wrapper{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:32px;width:100%}@media (max-width: 768px){.pie-chart-wrapper{flex-direction:column;gap:24px}}.pie-chart-visual{width:300px;height:300px}.pie-svg{width:100%;height:100%;transform:rotate(-90deg)}.pie-slice{transition:opacity .3s ease;cursor:pointer}.pie-slice:hover{opacity:.8}.pie-center{stroke:#e0e0e0;stroke-width:2}.pie-center-text{font-size:12px;font-weight:700;fill:#333;transform:rotate(90deg);transform-origin:50px 50px}.trend-bars-container{display:flex;flex-direction:column;gap:16px;width:100%}.trend-bars{display:flex;align-items:flex-end;justify-content:space-around;gap:12px;height:200px;padding:16px 8px 0;border-bottom:2px solid #e0e0e0;border-left:2px solid #e0e0e0;position:relative;background:linear-gradient(to top,rgba(0,0,0,.02) 0%,transparent 100%)}.trend-bar-wrapper{display:flex;flex-direction:column;justify-content:flex-end;height:150px;width:40px;border-radius:6px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .3s ease;background:#f5f5f5;border:1px solid #e0e0e0}.trend-bar-wrapper:hover{transform:scale(1.05)}.trend-bar{width:100%;transition:all .3s ease;border:none;position:relative;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;text-shadow:1px 1px 1px rgba(0,0,0,.3)}.present-bar{background-color:#4caf50!important;border-bottom:1px solid #45a049}.late-bar{background-color:#ff9800!important;border-bottom:1px solid #f57c00}.absent-bar{background-color:#f44336!important;border-bottom:1px solid #d32f2f}.trend-info{display:flex;flex-direction:column;align-items:center;gap:4px;margin-top:12px;min-width:50px}.trend-percentage{font-size:14px;font-weight:700;color:#333}.trend-day-name{font-size:11px;color:#666;text-transform:uppercase;letter-spacing:.5px}.trend-legend{display:flex;justify-content:center;gap:20px;flex-wrap:wrap;margin-top:16px}.trend-legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:#666;padding:6px 12px;border-radius:20px;background:#f8f9fa;transition:background-color .2s ease}.trend-legend-item:hover{background:#e9ecef}.trend-legend-color{width:12px;height:12px;border-radius:50%;flex-shrink:0}.time-management-header{background-color:#1a1a1a;color:#fff;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.header-left{display:flex;align-items:center;gap:32px}.brand{display:flex;align-items:center;gap:8px}.brand-logo{color:gold;font-size:18px;font-weight:700}.brand-text{color:#888;font-size:14px}.nav-tabs{display:flex;gap:24px}.nav-tab{padding:6px 12px;border-radius:6px;font-size:14px;text-decoration:none;color:#888;transition:all .2s}.nav-tab.active{background-color:#333;color:#fff;font-weight:500}.nav-tab:hover{color:#fff}.header-add-btn{background-color:#4caf50;color:#fff;border:none;border-radius:6px;padding:8px 16px;font-size:14px;cursor:pointer;font-weight:500}.attendance-container{background-color:#f8f9fa;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.main-content{padding:24px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-title-section{display:flex;align-items:center;gap:16px}.page-title{font-size:24px;font-weight:600;margin:0;color:#1a1a1a}.date-navigation{display:flex;align-items:center;gap:8px}.date-nav-btn{background:none;border:none;font-size:16px;cursor:pointer;color:#666;padding:4px}.date-nav-btn:hover{color:#333}.date-text{font-size:16px;font-weight:500;color:#333;margin:0 8px}.page-actions{display:flex;gap:12px}.report-btn{background-color:#fff;border:1px solid #ddd;border-radius:6px;padding:8px 16px;font-size:14px;cursor:pointer;display:flex;align-items:center;gap:6px;color:#333}.report-btn:hover{background-color:#f5f5f5}.add-btn{background-color:#4caf50;color:#fff;border:none;border-radius:6px;padding:8px 16px;font-size:14px;cursor:pointer;font-weight:500}.add-btn:hover{background-color:#45a049}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:16px;margin-bottom:24px}.summary-card{background-color:#fff;border-radius:8px;padding:20px;box-shadow:0 1px 3px #0000001a}.summary-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.summary-card-title{margin:0;font-size:16px;font-weight:600;color:#333;display:flex;align-items:center;gap:8px}.summary-card-menu{background:none;border:none;font-size:16px;color:#999;cursor:pointer}.summary-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.stat-item{text-align:left}.stat-label{color:#666;font-size:12px;margin-bottom:4px;font-weight:400}.stat-value{font-size:28px;font-weight:700;color:#333;line-height:1.2;margin-bottom:2px}.stat-change{font-size:12px;color:#666}.stat-change.positive{color:#4caf50}.stat-change.negative{color:#f44336}.employee-table-container{background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden;max-height:70vh;display:flex;flex-direction:column}.table-wrapper{overflow-x:auto;overflow-y:visible;width:100%;position:relative;flex:1;max-height:calc(70vh - 60px)}.table-controls{padding:16px 20px;border-bottom:1px solid #eee;display:flex;align-items:center;gap:16px}.search-container{position:relative;display:inline-block}.search-input{border:1px solid #ddd;border-radius:6px;padding:8px 36px;font-size:14px;width:250px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23999' viewBox='0 0 24 24'%3E%3Cpath d='M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:12px center;background-size:16px}.clear-search-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:#999;cursor:pointer;font-size:16px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.clear-search-btn:hover{background-color:#f0f0f0;color:#666}.search-input::placeholder{color:#999}.search-results{color:#666;font-size:12px;margin-left:12px;padding:4px 8px;background-color:#f0f8ff;border-radius:4px;border:1px solid #e0e8f0}.no-results{text-align:center;padding:40px 20px;background-color:#fafafa}.no-results-content{display:flex;flex-direction:column;align-items:center;gap:12px}.no-results-icon{font-size:32px;opacity:.5}.no-results-text{color:#666;font-size:14px}.clear-search-link{background:none;border:none;color:#007bff;cursor:pointer;font-size:12px;text-decoration:underline}.clear-search-link:hover{color:#0056b3}.filter-btn{border:1px solid #ddd;border-radius:6px;padding:8px 12px;font-size:14px;background-color:#fff;cursor:pointer;display:flex;align-items:center;gap:6px;color:#333}.filter-btn:hover{background-color:#f5f5f5}.employee-table{width:100%;border-collapse:collapse;min-width:3800px;white-space:nowrap}.employee-table th:first-child,.employee-table td:first-child{position:sticky;left:0;width:320px;min-width:320px;max-width:320px;background-color:#fff;border-right:3px solid #ddd;padding-right:20px;z-index:10;box-shadow:4px 0 8px #00000026}.employee-table thead th:first-child{background-color:#f8f9fa;z-index:15}.employee-table .date-header,.employee-table .attendance-cell{width:100px;min-width:100px;max-width:100px;text-align:center;padding-left:12px;padding-right:12px}.employee-table th:nth-child(2),.employee-table td:nth-child(2){padding-left:32px;border-left:1px solid #f0f0f0}.employee-table th:nth-last-child(3),.employee-table td:nth-last-child(3){width:80px;min-width:80px}.employee-table th:nth-last-child(2),.employee-table td:nth-last-child(2){width:80px;min-width:80px}.employee-table th:nth-last-child(1),.employee-table td:nth-last-child(1){width:110px;min-width:110px}.employee-table thead{background-color:#f8f9fa;position:sticky;top:0;z-index:12}.employee-table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;color:#666;border-bottom:1px solid #eee;text-transform:uppercase;letter-spacing:.5px;background-color:#f8f9fa;position:sticky;top:0;z-index:12}.employee-table tbody tr{border-bottom:1px solid #eee}.employee-table tbody tr:hover{background-color:#f8f9fa}.employee-table td{padding:16px;vertical-align:middle}.employee-info{display:flex;align-items:center;gap:16px;justify-content:flex-start;text-align:left;padding:8px 0}.employee-avatar{width:40px;height:40px;border-radius:50%;background-color:#4caf50;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:600;flex-shrink:0}.employee-details{min-width:0;text-align:left;flex:1;display:flex;flex-direction:column;gap:2px}.employee-name{font-weight:600;font-size:14px;color:#333;margin:0;text-align:left;line-height:1.2}.employee-nip{color:#666;font-size:12px;font-weight:400;margin:0;opacity:.8;text-align:left;line-height:1.2}.clock-info{display:flex;align-items:center;gap:8px}.clock-time{font-weight:600;font-size:14px}.clock-time.on-time{color:#4caf50}.clock-time.late{color:#ff5722}.clock-time.absent{color:#f44336}.clock-separator{color:#ccc;font-size:12px}.clock-duration,.clock-out-time{color:#666;font-size:12px}.overtime-value{font-size:14px;color:#666}.table-link{color:#4caf50;font-size:12px;text-decoration:underline;cursor:pointer}.table-link:hover{color:#45a049}.note-text{font-size:12px;color:#666;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.date-header{text-align:center;min-width:60px;padding:8px 4px!important}.date-info{display:flex;flex-direction:column;align-items:center;gap:2px}.day-number{font-size:14px;font-weight:600;color:#333}.day-name{font-size:10px;color:#666;text-transform:uppercase}.date-header.weekend{background-color:#fff5f5;color:#999}.date-header.weekend .day-number{color:#999}.attendance-cell{text-align:center;padding:8px 4px;min-width:60px;vertical-align:middle}.attendance-cell.multi-status{padding:4px 2px}.status-row{display:flex;justify-content:center;gap:2px;margin-bottom:4px}.status-indicator{display:inline-block;color:#fff;font-size:10px;font-weight:600;padding:2px 4px;border-radius:3px;min-width:16px;text-align:center}.status-indicator.large{font-size:12px;padding:4px 6px;min-width:24px}.time-display{font-size:9px;color:#666;line-height:1.2}.time-display.single{display:flex;flex-direction:column;gap:1px}.time-item{margin:0}.weekend-cell{background-color:#f5f5f5;color:#999;text-align:center;font-weight:500}.no-data-cell{text-align:center;color:#999;font-weight:500}.work-days-cell{text-align:center;vertical-align:middle}.work-days-info{display:flex;flex-direction:column;align-items:center;gap:2px}.work-days-number{font-size:16px;font-weight:600;color:#333}.work-days-label{font-size:10px;color:#666;text-transform:uppercase}.average-cell{text-align:center;vertical-align:middle}.average-info{display:flex;flex-direction:column;align-items:center;gap:2px}.average-number{font-size:14px;font-weight:600;color:#4caf50}.average-label{font-size:10px;color:#666;text-transform:uppercase}.employee-table .summary-stats{display:flex;flex-direction:column;gap:2px;font-size:11px}.employee-table .stat{margin:0;padding:1px 0}@media (max-width: 768px){.header-left{gap:16px}.nav-tabs{gap:12px}.nav-tab{padding:4px 8px;font-size:12px}.page-header{flex-direction:column;align-items:flex-start;gap:16px}.summary-cards{grid-template-columns:1fr}.table-controls{flex-wrap:wrap;gap:12px}.search-input{width:100%}.date-header{min-width:40px;padding:4px 2px!important}.day-number{font-size:12px}.day-name{font-size:8px}.status-indicator{font-size:8px;padding:1px 2px;min-width:12px}.time-display{font-size:8px}}.controls-section{background-color:#fff;border-radius:8px;padding:16px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a}.controls-row{display:flex;gap:16px;align-items:center;flex-wrap:wrap}.control-select{padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;min-width:150px;background-color:#fff}.generate-btn{background-color:#4caf50;color:#fff;border:none;border-radius:6px;padding:8px 16px;font-size:14px;cursor:pointer;font-weight:500}.generate-btn:disabled{background-color:#ccc;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:6px;margin-bottom:24px;border:1px solid #fcc;font-size:14px}.problematic-container{min-height:100vh;background:#f5f7fa;padding:24px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;background:#fff;padding:24px 32px;border-radius:16px;box-shadow:0 2px 8px #0000001a}.page-title-section{flex:1}.page-title{font-size:32px;font-weight:700;color:#d32f2f;margin:0 0 8px}.date-text{font-size:16px;color:#666;font-weight:500}.page-actions{display:flex;gap:16px}.refresh-btn,.export-btn{padding:12px 24px;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease}.refresh-btn{background:#2196f3;color:#fff}.refresh-btn:hover{background:#1976d2;transform:translateY(-2px)}.export-btn{background:#4caf50;color:#fff}.export-btn:hover{background:#45a049;transform:translateY(-2px)}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px;margin-bottom:32px}.summary-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 2px 8px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.summary-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.summary-card.total{border-left:6px solid #ff5722}.summary-card.late{border-left:6px solid #ff9800}.summary-card.absent{border-left:6px solid #f44336}.summary-card.organizations{border-left:6px solid #9c27b0}.summary-card-header{margin-bottom:16px}.summary-card-title{font-size:16px;font-weight:600;color:#333;margin:0}.summary-value{font-size:48px;font-weight:700;color:#333;line-height:1;margin-bottom:8px}.summary-label{font-size:14px;color:#666;text-transform:uppercase;letter-spacing:.5px}.controls-section{background:#fff;border-radius:16px;padding:24px 32px;margin-bottom:24px;box-shadow:0 2px 8px #0000001a}.controls-row{display:flex;gap:16px;align-items:center;flex-wrap:wrap;margin-bottom:16px}.search-container{position:relative;flex:1;min-width:300px}.search-input{width:100%;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s ease}.search-input:focus{outline:none;border-color:#2196f3}.clear-search-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:#666;cursor:pointer;padding:4px;border-radius:4px}.clear-search-btn:hover{background:#f0f0f0}.filter-select,.sort-select{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;background:#fff;cursor:pointer}.sort-order-btn{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;font-size:18px;font-weight:700;color:#2196f3}.sort-order-btn:hover{background:#f0f8ff}.results-info{font-size:14px;color:#666;font-style:italic}.auth-message,.loading-message,.error-message{text-align:center;padding:48px 24px;background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000001a}.loading-message{color:#2196f3}.loading-spinner{width:40px;height:40px;border:4px solid #e3f2fd;border-top:4px solid #2196f3;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}.error-message{color:#d32f2f;background:#ffebee;border:1px solid #ffcdd2}.employees-table-container{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.employees-table{width:100%;border-collapse:collapse}.employees-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.employees-table th{padding:16px 20px;text-align:left;font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.employees-table tbody tr{border-bottom:1px solid #f0f0f0;transition:background-color .2s ease}.employees-table tbody tr:hover{background-color:#f8f9fa}.employees-table td{padding:16px 20px;vertical-align:middle}.employee-info{display:flex;align-items:center;gap:12px}.employee-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px}.employee-details{flex:1}.employee-name{font-weight:600;color:#333;margin-bottom:4px}.employee-nip{font-size:12px;color:#666}.status-badge{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}.status-badge.late{background-color:#fff3e0;color:#f57c00;border:1px solid #ff9800}.status-badge.absent{background-color:#ffebee;color:#d32f2f;border:1px solid #f44336}.check-in-time{font-weight:600;color:#f57c00;background:#fff3e0;padding:4px 8px;border-radius:12px;font-size:12px}.no-time{color:#999;font-style:italic}.count-cell{text-align:center;font-weight:600;font-size:18px}.late-count{color:#f57c00}.absent-count{color:#d32f2f}.actions-cell{text-align:center}.action-btn{background:none;border:1px solid #e0e0e0;border-radius:6px;padding:8px 12px;margin:0 4px;cursor:pointer;transition:all .3s ease;font-size:14px}.action-btn:hover{background:#f0f0f0;transform:translateY(-2px)}.view-btn:hover{background:#e3f2fd;border-color:#2196f3}.contact-btn:hover{background:#e8f5e8;border-color:#4caf50}.no-results{text-align:center;padding:64px 24px;color:#666}.no-results-icon{font-size:64px;margin-bottom:16px}.no-results h3{color:#4caf50;margin-bottom:8px}.no-results p{font-size:16px;color:#666}@media (max-width: 1024px){.page-header{flex-direction:column;gap:16px;text-align:center}.controls-row{flex-direction:column;align-items:stretch}.search-container{min-width:auto}}@media (max-width: 768px){.problematic-container{padding:16px}.summary-cards{grid-template-columns:1fr}.employees-table-container{overflow-x:auto}.employees-table{min-width:800px}.page-actions{flex-direction:column;width:100%}.refresh-btn,.export-btn{width:100%}}@media (max-width: 480px){.page-title{font-size:24px}.date-text{font-size:14px}.summary-value{font-size:36px}}*{box-sizing:border-box}html,body{margin:0;padding:0;width:100%;overflow-x:hidden}#root{width:100%}.app{min-height:100vh;width:100%;background-color:#f5f5f5}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem;text-align:center;box-shadow:0 2px 10px #0000001a}.app-header h1{margin:0 0 .5rem;font-size:2.5rem;font-weight:600}.app-header p{margin:0;opacity:.9;font-size:1.1rem}.app-main{width:100%;padding:2rem;box-sizing:border-box}.filter-container{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;width:100%;box-sizing:border-box}.filter-container h3{margin:0 0 1rem;color:#333}.filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;width:100%}.filter-item{display:flex;flex-direction:column}.filter-item label{margin-bottom:.5rem;font-weight:500;color:#555}.filter-item input,.filter-item select{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.filter-item input:focus,.filter-item select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.stats-container{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;width:100%;box-sizing:border-box}.stats-container h3{margin:0 0 1rem;color:#333}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;width:100%}.stat-card{display:flex;align-items:center;padding:1rem;background:#f8f9fa;border-radius:6px;border-left:4px solid #667eea}.stat-icon{margin-right:1rem;color:#667eea}.stat-value{font-size:1.5rem;font-weight:600;color:#333}.stat-label{font-size:.875rem;color:#666}.table-section{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden;width:100%;box-sizing:border-box}.section-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #eee}.section-header h2{margin:0;color:#333}.refresh-btn{padding:.5rem 1rem;background:#667eea;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;transition:background-color .2s}.refresh-btn:hover{background:#5a6fd8}.table-container{overflow-x:auto;width:100%}.attendance-table{width:100%;min-width:800px;border-collapse:collapse}.attendance-table th,.attendance-table td{padding:1rem;text-align:left;border-bottom:1px solid #eee}.attendance-table th{background:#f8f9fa;font-weight:600;color:#555}.status-badge{padding:.25rem .5rem;border-radius:12px;color:#fff;font-size:.75rem;font-weight:500;text-transform:uppercase}.loading,.no-data{text-align:center;padding:2rem;color:#666}.error-message{background:#fee;color:#c33;padding:1rem;border-radius:4px;margin-bottom:1rem;border-left:4px solid #c33}@media (max-width: 768px){.app-main{padding:1rem}.filter-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}.section-header{flex-direction:column;gap:1rem;align-items:stretch}.attendance-table{min-width:600px}}@media (max-width: 480px){.app-main{padding:.5rem}.stats-grid{grid-template-columns:1fr}.filter-container,.stats-container,.table-section{margin-bottom:1rem}}.error-boundary{padding:2rem;text-align:center;background:#fee;border:1px solid #fcc;border-radius:8px;margin:2rem}.error-boundary h2{color:#c33;margin-bottom:1rem}.error-boundary details{margin:1rem 0;text-align:left;background:#f9f9f9;padding:1rem;border-radius:4px}.error-boundary pre{font-size:.875rem;overflow-x:auto;white-space:pre-wrap}.retry-btn{padding:.75rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;margin-top:1rem}.retry-btn:hover{background:#5a6fd8}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.login-form{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 10px 25px #0003;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{color:#333;margin-bottom:.5rem;font-size:1.8rem}.login-header p{color:#666;margin:0}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.login-btn{width:100%;padding:.75rem;background:#667eea;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background-color .2s}.login-btn:hover:not(:disabled){background:#5a6fd8}.login-btn:disabled{opacity:.6;cursor:not-allowed}.demo-credentials{margin-top:2rem;padding:1rem;background:#f8f9fa;border-radius:4px;font-size:.875rem}.demo-credentials h4{margin:0 0 .5rem;color:#333}.demo-credentials p{margin:.25rem 0;color:#666}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem 2rem;box-shadow:0 2px 10px #0000001a}.header-content{display:flex;justify-content:space-between;align-items:center;width:100%;box-sizing:border-box}.header-left h1{margin:0 0 .25rem;font-size:1.8rem;font-weight:600}.header-left p{margin:0;opacity:.9;font-size:1rem}.user-info{display:flex;align-items:center;gap:1rem}.user-details{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.username{font-weight:600;font-size:1rem}.organization{font-size:.875rem;opacity:.8}.role-badge{padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500}.role-badge.admin{background:#fff3;color:#fff}.role-badge.organization{background:#ffffff26;color:#fff}.logout-btn{padding:.5rem 1rem;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:4px;cursor:pointer;font-size:.875rem;transition:background-color .2s}.logout-btn:hover{background:#ffffff4d}@media (max-width: 768px){.header-content{flex-direction:column;gap:1rem;text-align:center}.user-details{align-items:center}.login-container{padding:1rem}}.navigation-tabs{display:flex;gap:.5rem;margin-top:1rem}.nav-tab{padding:.5rem 1rem;background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:4px;cursor:pointer;font-size:.875rem;transition:all .2s}.nav-tab:hover{background:#fff3}.nav-tab.active{background:#ffffff4d;border-color:#ffffff80}.organization-management{width:100%}.organizations-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.organizations-table-section{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden;width:100%;box-sizing:border-box}.organizations-table{width:100%;min-width:800px;border-collapse:collapse}.organizations-table th,.organizations-table td{padding:1rem;text-align:left;border-bottom:1px solid #eee}.organizations-table th{background:#f8f9fa;font-weight:600;color:#555}.organizations-table tr:hover{background:#f8f9fa}.sync-btn{padding:.5rem 1rem;background:#28a745;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;transition:background-color .2s;margin-right:.5rem}.header-actions{display:flex;gap:.5rem}.status-badge.active{background:#28a745}.status-badge.inactive{background:#6c757d}.success-message{background:#d4edda;color:#155724;padding:1rem;border-radius:4px;margin-bottom:1rem;border-left:4px solid #28a745}.access-denied{text-align:center;padding:2rem;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.access-denied h3{color:#dc3545;margin-bottom:1rem}.access-denied p{color:#666}@media (max-width: 768px){.navigation-tabs{flex-direction:column;gap:.25rem}.nav-tab{text-align:center}.header-actions{flex-direction:column;gap:.25rem}.organizations-table{min-width:600px}}.internal-id{font-family:Courier New,monospace;background:#e3f2fd;padding:.25rem .5rem;border-radius:3px;font-size:.875rem;color:#1976d2}.external-id{font-family:Courier New,monospace;background:#f3e5f5;padding:.25rem .5rem;border-radius:3px;font-size:.875rem;color:#7b1fa2}.organizations-table th:nth-child(1),.organizations-table td:nth-child(1){width:80px;text-align:center}.organizations-table th:nth-child(2),.organizations-table td:nth-child(2){width:100px;text-align:center}.organizations-table th:nth-child(3),.organizations-table td:nth-child(3){width:100px}.organizations-table th:nth-child(6),.organizations-table td:nth-child(6){width:80px;text-align:center}.organizations-table th:nth-child(7),.organizations-table td:nth-child(7){width:120px}.attendance-management{width:100%}.sync-section,.filter-section,.stats-section,.records-section{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;width:100%;box-sizing:border-box}.sync-section h2,.filter-section h3,.stats-section h3,.records-section h3{margin:0 0 1rem;color:#333}.sync-form,.filter-form{width:100%}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;align-items:end}.form-group{display:flex;flex-direction:column}.form-group label{margin-bottom:.5rem;font-weight:500;color:#555}.form-group input,.form-group select{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.sync-btn{padding:.75rem 1.5rem;background:#28a745;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s;height:fit-content}.sync-btn:hover:not(:disabled){background:#218838}.sync-btn:disabled{opacity:.6;cursor:not-allowed}.attendance-table{width:100%;min-width:1000px;border-collapse:collapse}.attendance-table th,.attendance-table td{padding:.75rem;text-align:left;border-bottom:1px solid #eee;vertical-align:top}.attendance-table th{background:#f8f9fa;font-weight:600;color:#555;position:sticky;top:0}.attendance-table tr:hover{background:#f8f9fa}.status-badge{padding:.25rem .5rem;border-radius:12px;color:#fff;font-size:.75rem;font-weight:500;text-transform:uppercase;display:inline-block;min-width:60px;text-align:center}.time{font-size:.75rem;color:#666;margin-top:.25rem;font-weight:500}.status-badge.late{animation:pulse 2s infinite;font-weight:600}.stats-section .stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.stats-section .stat-card{display:flex;flex-direction:column;align-items:center;padding:1rem;background:#f8f9fa;border-radius:6px;border-left:4px solid #667eea}.stats-section .stat-value{font-size:2rem;font-weight:600;color:#333;margin-bottom:.5rem}.stats-section .stat-label{font-size:.875rem;color:#666;text-align:center}@media (max-width: 768px){.form-row{grid-template-columns:1fr}.attendance-table{min-width:800px}.stats-section .stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.stats-section .stats-grid{grid-template-columns:1fr}.sync-section,.filter-section,.stats-section,.records-section{padding:1rem;margin-bottom:1rem}}.horizontal-attendance-report{width:100%}.report-controls{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.report-controls h2{margin:0 0 1rem;color:#333}.controls-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;align-items:end}.control-group{display:flex;flex-direction:column}.control-group label{margin-bottom:.5rem;font-weight:500;color:#555}.generate-btn{padding:.75rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s;height:fit-content}.generate-btn:hover:not(:disabled){background:#5a6fd8}.generate-btn:disabled{opacity:.6;cursor:not-allowed}.search-btn{padding:.75rem 1.5rem;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;margin-right:.5rem}.search-btn:hover:not(:disabled){background:#0056b3}.search-btn:disabled{opacity:.6;cursor:not-allowed}.clear-btn{padding:.75rem 1.5rem;background:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.clear-btn:hover:not(:disabled){background:#545b62}.clear-btn:disabled{opacity:.6;cursor:not-allowed}.employee-search-container{position:relative}.employee-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #ddd;border-top:none;border-radius:0 0 4px 4px;max-height:300px;overflow-y:auto;z-index:1000;box-shadow:0 2px 8px #0000001a}.employee-option{padding:.75rem;cursor:pointer;border-bottom:1px solid #f0f0f0;transition:background-color .2s}.employee-option:hover{background-color:#f8f9fa}.employee-option:last-child{border-bottom:none}.employee-name{font-weight:500;color:#333;margin-bottom:.25rem}.employee-nip{font-size:.85rem;color:#666}.employee-more{padding:.5rem .75rem;font-size:.85rem;color:#666;font-style:italic;background-color:#f8f9fa;border-top:1px solid #e9ecef}.report-content{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.report-header{padding:1.5rem;border-bottom:1px solid #eee;text-align:center}.report-header h3{margin:0 0 .5rem;color:#333;font-size:1.5rem}.report-header p{margin:0 0 1rem;color:#666;font-size:1.1rem}.report-summary{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap}.report-summary span{font-size:.9rem;color:#555;font-weight:500}.legend{display:flex;justify-content:center;gap:2rem;padding:1rem;background:#f8f9fa;border-bottom:1px solid #eee;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-color{width:16px;height:16px;border-radius:3px}.report-table-container{overflow-x:auto;max-height:70vh;overflow-y:auto}.horizontal-attendance-table{width:100%;min-width:800px;border-collapse:collapse;font-size:.875rem}.horizontal-attendance-table th,.horizontal-attendance-table td{border:1px solid #e0e0e0;text-align:center;vertical-align:middle}.horizontal-attendance-table th{background:#f5f5f5;font-weight:600;color:#333;position:sticky;top:0;z-index:10}.employee-header,.employee-name{min-width:150px;text-align:left;padding:.75rem;position:sticky;left:0;background:#fff;z-index:5}.employee-header{background:#f5f5f5!important;z-index:15}.nip-header,.employee-nip{min-width:120px;text-align:center;padding:.5rem;position:sticky;left:150px;background:#fff;z-index:5}.nip-header{background:#f5f5f5!important;z-index:15}.date-header{width:80px;padding:.5rem .25rem}.date-header.weekend{background:#ffebee}.date-info{display:flex;flex-direction:column;align-items:center}.day-number{font-weight:600;font-size:.9rem}.day-name{font-size:.7rem;color:#666}.summary-header,.summary-cell{min-width:100px;position:sticky;right:0;background:#fff;z-index:5}.summary-header{background:#f5f5f5!important;z-index:15}.attendance-cell{width:80px;height:80px;padding:.25rem;position:relative;vertical-align:top}.attendance-cell.single-status{border:2px solid transparent}.weekend-cell{background:#f5f5f5;color:#999}.no-data-cell{background:#fff3e0;color:#ff9800}.status-row{display:flex;flex-direction:row;gap:1px;height:24px;margin-bottom:3px}.status-indicator{color:#fff;font-weight:700;font-size:.7rem;border-radius:2px;display:flex;align-items:center;justify-content:center;min-height:18px;flex:1}.status-indicator.large{font-size:1rem;border-radius:50%;width:28px;height:28px;margin:0 auto 4px}.status-indicator.late{animation:pulse 2s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}.multi-status .status-indicator{font-size:.6rem;min-width:18px}.time-display{font-size:.6rem;color:#333;line-height:1}.time-display .time-item{margin:1px 0;padding:0 1px;background:#fffc;border-radius:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.multi-status .time-display{display:flex;flex-direction:row;gap:1px}.multi-status .time-item{flex:1;font-size:.55rem;text-align:center}.time-info{padding:1rem;background:#e3f2fd;border-left:4px solid #2196f3;margin:1rem 0;border-radius:4px}.time-info p{margin:.5rem 0;font-size:.9rem;color:#1565c0}.time-info strong{color:#0d47a1}.attendance-cell .time-display{display:block!important;visibility:visible!important;opacity:1!important;background:#ffff001a;border:1px dashed rgba(255,0,0,.3)}.summary-stats{display:flex;flex-direction:column;gap:.25rem;font-size:.75rem}.summary-stats .stat{display:flex;justify-content:space-between;padding:.125rem .25rem;background:#f8f9fa;border-radius:2px}@media (max-width: 768px){.controls-row{grid-template-columns:1fr}.report-summary,.legend{flex-direction:column;gap:.5rem}.horizontal-attendance-table{font-size:.75rem}.employee-header,.employee-name{min-width:120px}.nip-header,.employee-nip{min-width:100px;left:120px}}@media (max-width: 480px){.report-controls,.report-header{padding:1rem}.horizontal-attendance-table{font-size:.7rem}.date-header{width:50px}.attendance-cell{width:50px;height:50px}}.time-display{font-size:.65rem;color:#333;line-height:1.1;margin-top:3px;width:100%}.time-display.single{text-align:center}.time-display .time-item{margin:1px 0;padding:1px 2px;background:#fffffff2;border-radius:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600;border:1px solid rgba(0,0,0,.15);color:#444;text-shadow:0 1px 1px rgba(255,255,255,.8)}.multi-status .time-display{display:flex;flex-direction:row;gap:1px;justify-content:space-between;width:100%}.multi-status .time-item{flex:1;font-size:.6rem;text-align:center;min-width:20px;font-weight:600}.attendance-cell .time-display{display:block!important;visibility:visible!important;opacity:1!important}.sync-btn{background:linear-gradient(135deg,#007bff,#0056b3)!important;color:#fff!important;border:none!important;padding:.75rem 1.5rem!important;border-radius:8px!important;cursor:pointer!important;font-size:.9rem!important;font-weight:500!important;transition:all .3s ease!important;display:flex!important;align-items:center!important;gap:8px!important;box-shadow:0 2px 8px #007bff4d!important}.sync-btn:hover:not(:disabled){background:linear-gradient(135deg,#0056b3,#007bff)!important;transform:translateY(-2px)!important;box-shadow:0 4px 15px #007bff66!important}.sync-btn:disabled{background:#6c757d!important;cursor:not-allowed!important;transform:none!important;box-shadow:none!important;opacity:1!important}.sync-btn.syncing{background:linear-gradient(135deg,#28a745,#20c997)!important;box-shadow:0 2px 8px #28a7454d!important}.sync-spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sync-icon{font-size:1rem}.sync-description{color:#666;font-size:.95rem;margin-bottom:1.5rem;line-height:1.5;background-color:#f8f9fa;padding:1rem;border-radius:6px;border-left:4px solid #007bff}.label-text{font-weight:500;color:#333}.label-required{color:#dc3545;margin-left:4px}.field-required{border-color:#dc3545!important;box-shadow:0 0 0 2px #dc35451a!important}.field-hint{display:block;font-size:.8rem;color:#dc3545;margin-top:4px;font-style:italic}.sync-info{margin-top:1.5rem;padding:1rem;background-color:#f8f9fa;border-radius:6px;border:1px solid #e9ecef}.info-item{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:.9rem}.info-item:last-child{margin-bottom:0}.info-icon{font-size:1rem;width:20px;text-align:center}.info-text{color:#666}.success-message{background-color:#d4edda!important;color:#155724!important;padding:1rem!important;border-radius:8px!important;border:1px solid #c3e6cb!important;margin-bottom:1rem!important;white-space:pre-line!important;font-family:Courier New,monospace!important;font-size:.9rem!important;line-height:1.4!important}.error-message{background-color:#f8d7da!important;color:#721c24!important;padding:1rem!important;border-radius:8px!important;border:1px solid #f5c6cb!important;margin-bottom:1rem!important;font-weight:500!important}.test-btn{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff;border:none;border-radius:8px;padding:10px 20px;font-size:14px;cursor:pointer;font-weight:500;transition:all .3s ease}.test-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #ff98004d}.photo-test-status{background-color:#e7f3ff;color:#06c;padding:12px 16px;border-radius:8px;border:1px solid #b3d9ff;margin-bottom:1rem;text-align:center;font-weight:500;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.test-success{background-color:#d4edda;color:#155724;padding:12px 16px;border-radius:6px;border:1px solid #c3e6cb;font-weight:500;text-align:center;margin-top:16px}
