:root{--spacing-xs:.5rem;--spacing-sm:.75rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-full:9999px;--active-ring:0 0 0 4px #3aa6ff24}button,.btn,a{-webkit-tap-highlight-color:transparent}button:focus-visible,.btn:focus-visible,a:focus-visible{box-shadow:var(--active-ring);outline:none;border-color:var(--n-primary-focus)!important}.absensi-header{background:linear-gradient(135deg,var(--n-primary)0%,#c2185b 100%);color:#fff;border-radius:28px;justify-content:space-between;align-items:center;margin-bottom:24px;padding:22px 32px;transition:background .3s;display:flex;position:relative;overflow:hidden;box-shadow:0 15px 45px -10px #0038a840}.dark .absensi-header{background:#001f5c;border:1px solid #ffffff1a;box-shadow:0 10px 40px -10px #00000080}.absensi-title-area{z-index:1;align-items:center;gap:16px;display:flex}.absensi-icon-wrapper{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #ffffff1a;border-radius:14px;justify-content:center;align-items:center;width:52px;height:52px;font-size:22px;display:flex}.absensi-header h1{letter-spacing:-.02em;margin:0;font-size:1.6rem;font-weight:800}.absensi-header p{opacity:.8;margin:2px 0 0;font-size:.85rem}.filter-card{background:var(--n-card);border:1px solid var(--n-border);margin-bottom:var(--spacing-lg);border-radius:16px;padding:1.25rem;transition:all .3s;box-shadow:0 10px 30px -5px #0038a80d}.dark .filter-card{background:#0f172a;border-color:#ffffff14}.filter-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--n-muted);margin-bottom:var(--spacing-md);align-items:center;gap:.55rem;font-size:.75rem;font-weight:700;display:flex}.filter-section-label:before{content:"";border-radius:var(--radius-full);background:#0038a8;width:4px;height:16px}.form-group{margin-bottom:0}.form-label{color:var(--n-muted);margin-bottom:.5rem;font-size:.875rem;font-weight:600;display:block}.form-input,.form-select{background:var(--n-bg);border:1.5px solid var(--n-border);border-radius:var(--radius-md);width:100%;color:var(--n-ink);box-sizing:border-box;padding:.6rem .9rem;font-size:.875rem;font-weight:500;line-height:1.25rem;transition:all .18s}div.form-select,div.form-input{height:40px;padding:0 .9rem;align-items:center!important;display:flex!important}input[type=date].form-input{padding-right:.5rem}.form-input:hover,.form-select:hover{border-color:var(--n-primary);opacity:.9}.form-input:focus,.form-select:focus{border-color:var(--n-primary);background:var(--n-card);box-shadow:var(--active-ring);outline:none}.dark .form-input,.dark .form-select{color:var(--n-ink);background:#ffffff0a;border-color:#ffffff1a}.dark .form-input:focus,.dark .form-select:focus{border-color:var(--n-primary);background:#ffffff14}.btn{border-radius:var(--radius-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:.5rem;height:40px;padding:0 1rem;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex}.btn:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:var(--shadow-sm)!important;transform:none!important}.btn-primary{background:var(--n-primary);color:#fff}.btn-primary:hover:not(:disabled){background:#1e56d3}.btn-success{color:#10b981;background:#10b9811a;border:1.5px solid #10b9814d}.btn-success:hover:not(:disabled){border-color:var(--accent-green);background:#10b9811a}.btn-dark{background:var(--n-primary-dark);color:#fff}.btn-dark:hover:not(:disabled){background:#00287a}.btn-outline{background:var(--n-soft);color:var(--n-ink);border:1.5px solid var(--n-border)}.btn-outline:hover:not(:disabled){background:var(--n-border)}.data-table{background:var(--n-card);border-radius:var(--radius-xl);box-shadow:var(--n-shadow);border:1px solid var(--n-border);transition:all .3s;overflow:hidden}.dark .data-table{background:#0f172a;border-color:#ffffff1f}.data-table table{border-collapse:collapse;width:100%}.data-table thead{background:var(--n-soft)}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.08em;color:var(--n-muted);border-bottom:2px solid var(--tb-border);background:var(--tb-th-bg);padding:14px 16px;font-size:.72rem;font-weight:700}.data-table th:last-child{border-right:none}.data-table td{border-bottom:1px solid var(--tb-border);color:var(--n-ink);vertical-align:middle;height:var(--tb-row-h);padding:12px 16px;font-size:.9rem}.data-table tr:hover td{background:var(--tb-hover)}.data-table .col-no{text-align:center;width:50px}.data-table .col-nisn{text-align:center;width:120px}.nisn-pill{color:var(--n-muted);font-family:JetBrains Mono,monospace;font-size:.8rem;font-weight:600;display:inline-block}.data-table td:last-child{border-right:none}.data-table tbody tr{transition:background .15s}.data-table tbody tr:hover{background:var(--n-soft)}.data-table tbody tr:last-child td{border-bottom:none}.status-radio-group{background:var(--n-bg);border-radius:var(--radius-full);border:1.5px solid var(--n-border);gap:.5rem;padding:.4rem;display:flex}.status-radio-item{flex:1}.status-radio-item input{display:none}.status-radio-label{text-align:center;text-transform:uppercase;letter-spacing:.03em;border-radius:var(--radius-full);cursor:pointer;color:var(--n-muted);background:0 0;padding:.52rem .75rem;font-size:.74rem;font-weight:700;transition:all .2s;display:block}.status-radio-label:hover{background:var(--n-soft);color:var(--n-ink);box-shadow:var(--shadow-sm)}.dark .status-radio-label:hover{background:#ffffff0d}.status-radio-item input:checked+.status-radio-label{background:var(--n-card);color:var(--n-ink);box-shadow:0 4px 12px #0000001a}.dark .status-radio-item input:checked+.status-radio-label{background:var(--n-primary);color:#fff;box-shadow:0 4px 12px #0000004d}.dark .status-radio-group{background:#020617;border-color:#ffffff1a}.status-radio-item input:disabled+.status-radio-label{opacity:.55;cursor:not-allowed}.status-radio-item input:checked+.status-radio-label[data-status=HADIR]{color:#fff;background:#3b82f6;box-shadow:0 4px 12px #3b82f64d}.status-radio-item input:checked+.status-radio-label[data-status=IZIN]{color:#fff;background:#10b981;box-shadow:0 4px 12px #10b9814d}.status-radio-item input:checked+.status-radio-label[data-status=SAKIT]{color:#fff;background:#f59e0b;box-shadow:0 4px 12px #f59e0b4d}.status-radio-item input:checked+.status-radio-label[data-status=ALPHA]{color:#fff;background:#ef4444;box-shadow:0 4px 12px #ef44444d}.dark .data-table th,.dark .data-table td{border-color:#ffffff1a}.dark .data-table thead{background:#ffffff08}.row-hadir{background:#3b82f60a}.row-izin{background:#f59e0b0a}.row-sakit{background:#fb923c0a}.row-alpha{background:#ef44440a}.dark .row-hadir{background:#3b82f61a}.dark .row-izin{background:#f59e0b1a}.dark .row-sakit{background:#fb923c1a}.dark .row-alpha{background:#ef44441a}.row-changed{position:relative}.badge{border-radius:var(--radius-full);background:var(--n-soft);color:var(--n-muted);align-items:center;gap:.375rem;padding:.25rem .625rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-success{color:#10b981;background:#10b98126}.badge-warning{color:#f59e0b;background:#f59e0b26}.session-info{background:var(--n-soft);border-radius:var(--radius-md);color:var(--n-muted);border:1px solid var(--n-border);margin-top:var(--spacing-md);padding:.875rem 1rem;font-size:.8125rem}@media (max-width:576px){.absensi-header{border-radius:16px;padding:1.25rem 1rem}.absensi-title{font-size:1.15rem}.absensi-subtitle{font-size:.8rem}.form-label{font-size:.825rem}.form-input,.form-select{padding:.75rem .9rem;font-size:.95rem}.max-w-7xl{padding:.75rem!important}.filter-card{border-radius:16px;padding:1.25rem}.form-label[style*="opacity: 0"]{display:none}.filter-card .grid{flex-direction:column;gap:.85rem;display:flex}.md\:col-span-3,.md\:col-span-2,.md\:col-span-1{width:100%}.data-table thead{display:none}.data-table table,.data-table tbody,.data-table tr,.data-table td{width:100%;display:block}.data-table tbody tr{border:1px solid var(--n-border);background:var(--n-card);box-shadow:var(--shadow-sm);border-radius:16px;margin-bottom:1rem;position:relative}.data-table td:first-child{border-radius:8px;flex-direction:row;justify-content:center;align-items:center;gap:0;min-height:auto;font-size:.9rem;font-weight:700;color:#fff!important;z-index:5!important;opacity:1!important;background:#1e90ff!important;border-bottom:none!important;width:auto!important;padding:.25rem .75rem!important;position:absolute!important;top:1rem!important;right:1rem!important;box-shadow:0 4px 10px #1e90ff4d!important}.data-table td:first-child:before{display:none}.data-table td{text-align:left;border-bottom:1px solid var(--n-border);box-sizing:border-box;background:0 0;flex-direction:column;justify-content:center;align-items:flex-start;gap:.35rem;width:100%;height:auto;min-height:auto;padding:1rem;font-size:.9rem;display:flex;position:relative}.data-table td:nth-child(4){align-items:stretch}.data-table td:last-child{background:var(--n-soft);border-bottom:none;justify-content:flex-end;padding-top:.75rem;padding-bottom:.75rem}.data-table td:last-child .jt__iconBtn{color:var(--n-primary);box-shadow:none;background:0 0;border:none;font-size:1.1rem}.data-table td:last-child:before{display:none}.data-table td:before{content:attr(data-label);text-transform:uppercase;color:var(--n-muted);letter-spacing:.05em;text-align:left;margin-bottom:0;font-size:.75rem;font-weight:700}.status-radio-group{border-radius:14px;flex-wrap:wrap;justify-content:space-between;gap:.4rem;width:100%;padding:.4rem;display:flex}.status-radio-item{flex:1 0 45%;min-width:60px}.status-radio-label{border-radius:10px;justify-content:center;align-items:center;height:100%;padding:.5rem;font-size:.7rem;display:flex}}@media (min-width:577px) and (max-width:768px){.absensi-header{padding:1.5rem}.absensi-title{font-size:1.25rem}}
