@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--bg-body:#eef2f7;--bg-container:#fff;--header-bg:#1a202c;--header-accent:#3b82f6;--text-main:#1e293b;--text-muted:#64748b;--border-color:#e2e8f0;--primary:#3b82f6;--primary-hover:#2563eb;--success:#16a34a;--success-bg:#dcfce7;--success-border:#bbf7d0;--danger:#dc2626;--danger-bg:#fee2e2;--danger-border:#fecaca;--warning:#d97706;--warning-bg:#fef3c7;--warning-border:#fde68a;--exit-done:#0ea5e9;--exit-done-bg:#e0f2fe;--exit-pending:#9333ea;--exit-pending-bg:#f3e8ff}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-body);color:var(--text-main);min-height:100vh;padding:1rem;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.5;overflow-y:auto}.app-container{background:var(--bg-container);border-radius:16px;flex-direction:column;max-width:1350px;min-height:calc(100vh - 2rem);margin:0 auto;display:flex;box-shadow:0 8px 32px #0000001a,0 2px 8px #0000000f}.header{color:#fff;border-bottom:3px solid var(--header-accent);background:linear-gradient(135deg,#1a202c 0%,#2d3748 60%,#1e3a5f 100%);flex-shrink:0;padding:1.25rem 2rem;position:relative;overflow:hidden}.header:before{content:"";pointer-events:none;background:#3b82f61f;border-radius:50%;width:200px;height:200px;position:absolute;top:-40px;right:-40px}.header-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.5rem;display:flex}.header-right{align-items:center;gap:1.5rem;display:flex}.real-time-clock{color:#fff;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;align-items:center;gap:.75rem;padding:.5rem 1rem;font-family:Courier New,Courier,monospace;font-size:1.1rem;font-weight:700;display:flex;box-shadow:inset 0 2px 4px #0000001a}.real-time-clock span{text-align:center;min-width:105px}.header h1{letter-spacing:-.01em;margin-bottom:.25rem;font-size:1.75rem;font-weight:800}.header p{color:#94a3b8;font-size:.9rem}.header-date{color:#cbd5e1;white-space:nowrap;background:#ffffff14;border:1px solid #ffffff1f;border-radius:8px;padding:.5rem 1rem;font-size:.825rem}.tabs-nav{border-bottom:1px solid var(--border-color);background:#f8fafc;flex-shrink:0;gap:.75rem;padding:.25rem 2rem;display:flex}.tab-link{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:all .2s;display:flex}.tab-link:hover{color:var(--text-main);background:#edf2f7}.tab-link.active{background:var(--primary);color:#fff;box-shadow:0 4px 12px #3b82f64d}.history-container{background:#fff;padding:1.5rem 2.5rem}.history-header{border:1px solid var(--border-color);background:#f1f5f9;border-radius:12px;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:1rem;padding:1.5rem;display:flex}.date-picker-group{flex-direction:column;gap:.5rem;display:flex}.date-picker-group label{color:var(--text-main);font-size:.85rem;font-weight:700}.date-input{cursor:pointer;width:200px!important;font-weight:600!important}.history-summary{color:var(--text-main);font-size:1rem}.history-summary strong{color:var(--primary);font-size:1.1rem}.stats-container{border-bottom:1px solid var(--border-color);background:#f8fafc;flex-shrink:0;padding:1rem 2rem}.stats-grid{grid-template-columns:repeat(4,1fr);gap:1.25rem;display:grid}.stat-card{border:1px solid var(--border-color);text-align:center;background:#fff;border-radius:12px;padding:1.5rem 1.25rem;transition:transform .18s,box-shadow .18s,border-color .18s;position:relative;overflow:hidden}.stat-card:after{content:"";width:100%;height:3px;position:absolute;top:0;left:0}.stat-card:first-child:after{background:var(--text-muted)}.stat-card:nth-child(2):after{background:var(--success)}.stat-card:nth-child(3):after{background:var(--warning)}.stat-card:nth-child(4):after{background:var(--danger)}.stat-card:hover{border-color:#cbd5e1;transform:translateY(-3px);box-shadow:0 8px 20px #00000014}.stat-icon{opacity:.7;margin-bottom:.5rem}.icon-total{color:var(--text-muted)}.icon-present{color:var(--success)}.icon-late{color:var(--warning)}.icon-absent{color:var(--danger)}.stat-value{margin-bottom:.35rem;font-size:2.5rem;font-weight:800;line-height:1.1}.val-total{color:var(--text-main)}.val-present{color:var(--success)}.val-late{color:var(--warning)}.val-absent{color:var(--danger)}.stat-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;font-size:.72rem;font-weight:600}.controls-bar{border-bottom:1px solid var(--border-color);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 2rem;display:flex}.controls-left{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.refresh-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:.45rem;padding:.5rem 1.1rem;font-family:inherit;font-size:.85rem;font-weight:600;transition:background .18s,transform .12s;display:flex}.refresh-btn:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.refresh-btn:disabled{opacity:.65;cursor:not-allowed}.filter-select{width:auto!important;padding:.5rem .9rem!important;font-size:.85rem!important}.search-wrapper{min-width:240px;position:relative}.search-input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'%3E%3C/line%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;background-size:14px;padding-left:1rem!important;font-size:.85rem!important}.last-updated{color:var(--text-muted);font-size:.82rem}.controls-right{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.delete-all-btn{color:var(--danger);border:1.5px solid var(--danger);cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:.4rem;padding:.48rem 1rem;font-family:inherit;font-size:.82rem;font-weight:600;transition:background .18s,color .18s,transform .12s;display:flex}.delete-all-btn:hover:not(:disabled){background:var(--danger);color:#fff;transform:translateY(-1px)}.delete-all-btn:disabled{opacity:.4;cursor:not-allowed}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:#0000008c;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-box{text-align:center;background:#fff;border-radius:16px;width:100%;max-width:420px;padding:2.25rem 2rem;animation:.18s slideUp;box-shadow:0 20px 60px #00000040}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-icon{margin-bottom:.75rem;font-size:2.5rem}.modal-title{color:var(--text-main);margin-bottom:.75rem;font-size:1.25rem;font-weight:800}.modal-desc{color:var(--text-muted);margin-bottom:1.5rem;font-size:.875rem;line-height:1.6}.modal-desc strong{color:var(--danger)}.modal-confirm-label{color:var(--text-muted);text-align:left;margin-bottom:.5rem;font-size:.82rem}.modal-confirm-label code{color:var(--danger);background:#fee2e2;border-radius:4px;padding:.1rem .4rem;font-size:.82rem;font-weight:700}.modal-input{border:2px solid var(--border-color);text-align:center;letter-spacing:.1em;border-radius:8px;width:100%;margin-bottom:1.25rem;padding:.65rem 1rem;font-family:inherit;font-size:.9rem;font-weight:700;transition:border-color .18s}.modal-input:focus{border-color:var(--danger);outline:none;box-shadow:0 0 0 3px #dc26261f}.modal-actions{gap:.75rem;display:flex}.modal-cancel-btn{border:1.5px solid var(--border-color);cursor:pointer;color:var(--text-muted);background:#fff;border-radius:8px;flex:1;padding:.65rem;font-family:inherit;font-size:.875rem;font-weight:600;transition:background .15s,border-color .15s}.modal-cancel-btn:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.modal-confirm-btn{background:var(--danger);color:#fff;cursor:pointer;border:none;border-radius:8px;flex:1;padding:.65rem;font-family:inherit;font-size:.875rem;font-weight:700;transition:background .15s,opacity .15s,transform .12s}.modal-confirm-btn:hover:not(:disabled){background:#b91c1c;transform:translateY(-1px)}.modal-confirm-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.modal-result{border-radius:8px;margin-top:.5rem;padding:1rem;font-size:.875rem;font-weight:600}.modal-result.success{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.modal-result.error{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border)}.table-wrapper{width:100%;height:50vh;padding-bottom:2rem;overflow-x:auto}.attendance-table{border-collapse:collapse;text-align:left;width:100%}.attendance-table thead th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:2px solid var(--border-color);white-space:nowrap;vertical-align:middle;z-index:10;background:#f8fafc;padding:.9rem 1rem;font-size:.72rem;font-weight:700;position:sticky;top:0}.attendance-table thead th:nth-child(2),.attendance-table thead th:nth-child(5),.attendance-table thead th:nth-child(6),.attendance-table thead th:nth-child(7){text-align:center}.attendance-table tbody td{color:var(--text-main);vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:.85rem 1rem;font-size:.875rem}.attendance-table tbody td:nth-child(2),.attendance-table tbody td:nth-child(5),.attendance-table tbody td:nth-child(6),.attendance-table tbody td:nth-child(7){text-align:center}.attendance-table tbody tr:last-child td{border-bottom:1px solid #f5f5f5}.table-row{transition:background .12s}.table-row:hover td{background:#f8fafc}.row-num{color:var(--text-muted);width:40px;font-size:.78rem;font-weight:500}.roll-cell{color:var(--primary);letter-spacing:.03em;font-family:Courier New,monospace;font-weight:700}.branch-chip{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe;border-radius:20px;padding:.2rem .75rem;font-size:.78rem;font-weight:600}.time-inner{white-space:nowrap;font-variant-numeric:tabular-nums;align-items:center;gap:.35rem;display:inline-flex}.empty-dash{color:var(--text-muted)}.status-cell{text-align:center;width:140px}.time-icon{opacity:.6}.entry-icon{color:var(--success)}.exit-chip{white-space:nowrap;border-radius:20px;align-items:center;gap:.3rem;padding:.25rem .7rem;font-size:.75rem;font-weight:600;display:inline-flex}.exit-done{background:var(--exit-done-bg);color:var(--exit-done);border:1px solid #bae6fd}.exit-pending{background:var(--exit-pending-bg);color:var(--exit-pending);border:1px solid #e9d5ff;font-size:.7rem}.exit-na{color:var(--text-muted);font-size:.85rem}.badge{text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;border-radius:9999px;justify-content:center;align-items:center;padding:.32rem .9rem;font-size:.68rem;font-weight:700;display:inline-flex}.badge-present{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.badge-absent{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border)}.badge-late{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning-border)}.table-msg{color:var(--text-muted);font-size:.9rem;text-align:center!important;padding:3rem 1rem!important}.error-msg{color:var(--danger)!important}.loader-dots{gap:4px;margin-right:6px;display:inline-flex}.loader-dots span{background:var(--primary);border-radius:50%;width:6px;height:6px;animation:1.2s infinite blink}.loader-dots span:nth-child(2){animation-delay:.2s}.loader-dots span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,80%,to{opacity:.2}40%{opacity:1}}.form-control{border:1px solid var(--border-color);width:100%;color:var(--text-main);background:#fff;border-radius:8px;padding:.65rem 1rem;font-family:inherit;font-size:.875rem;transition:border-color .18s,box-shadow .18s}.form-control:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #3b82f626}.spin-icon{animation:.9s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.rules-footer{border-bottom:1px solid var(--border-color);background:#f8fafc;flex-wrap:wrap;flex-shrink:0;gap:.5rem 1.5rem;padding:.75rem 2rem;display:flex}.rule-item{color:var(--text-muted);align-items:center;gap:.5rem;font-size:.8rem;display:flex}.dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.dot-present{background:var(--success)}.dot-late{background:var(--warning)}.dot-absent{background:var(--danger)}.dot-exit{background:var(--exit-done)}@media (width<=1024px){.app-container{max-width:95%}.stats-grid{grid-template-columns:repeat(2,1fr);gap:1rem}}@media (width<=768px){body{height:auto;padding:.5rem;overflow:auto}.app-container{border-radius:0;height:auto;min-height:100vh}.header-right{justify-content:center;width:100%;margin-top:1rem}.controls-bar{flex-direction:column;align-items:stretch;padding:1rem}.controls-left,.controls-right{justify-content:center;width:100%}.refresh-btn,.filter-select,.search-wrapper{flex:1}.search-wrapper{min-width:100%}.delete-all-btn{justify-content:center;width:100%}.stat-value{font-size:2rem}}@media (width<=480px){.header h1{font-size:1.4rem}.header p{font-size:.8rem}.real-time-clock{padding:.4rem .75rem;font-size:.9rem}.header-date{display:none}.stats-grid{grid-template-columns:1fr}.stat-card{padding:1rem}.rules-footer{justify-content:center;padding:.75rem 1rem}.rule-item{font-size:.75rem}.table-wrapper{border-radius:0;flex:none;height:auto;min-height:400px;margin:0}.attendance-table thead th,.attendance-table tbody td{padding:.6rem .5rem;font-size:.8rem}.badge{padding:.25rem .6rem;font-size:.6rem}.modal-box{margin:0 1rem;padding:1.5rem}.modal-title{font-size:1.1rem}.modal-actions{flex-direction:column}}@media (height<=500px){.header{padding:.5rem 1rem}.stats-container{display:none}}
