.absensi-page{gap:var(--page-gap);flex-direction:column;max-width:100%;margin:0;padding:0;display:flex}: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:1px solid #ffffff1f;border-radius:24px;justify-content:space-between;align-items:center;padding:20px 40px 40px;transition:background .3s;display:flex;position:relative;overflow:hidden;box-shadow:0 20px 40px #00000026}.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:"";background:var(--n-primary);border-radius:var(--radius-full);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{appearance:none;box-sizing:border-box;width:100%;min-width:0;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){background:#10b98126;border-color:#10b981}.dark .btn-success{color:#34d399;background:#10b98126;border-color:#10b98166}.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-surface)}.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-surface)}.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}.dark .data-table tbody tr td{background:var(--n-card);border-bottom-color:var(--n-border)}.dark .data-table tbody tr:hover td{background:var(--n-surface)}.dark .data-table tbody tr:last-child td{border-bottom:none}.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}.dark .badge-success{color:#34d399;background:#10b98133}.badge-warning{color:#f59e0b;background:#f59e0b26}.dark .badge-warning{color:#fbbf24;background:#f59e0b33}.session-info{background:var(--n-surface);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}.dark .session-info{background:#ffffff0a}@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:0!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}}.admin-toggle-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;cursor:pointer;background:#ffffff1a;border:1.5px solid #ffffff4d;border-radius:50px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.8rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;box-shadow:0 2px 8px #0000001a}.admin-toggle-btn:hover{background:#fff3;border-color:#ffffff80;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.admin-toggle-btn.active{background:linear-gradient(135deg,#7c3aed 0%,#a855f7 100%);border-color:#0000;box-shadow:0 4px 15px #7c3aed66,0 0 0 1px #a855f74d,inset 0 1px #fff3}.admin-toggle-btn.active:hover{background:linear-gradient(135deg,#6d28d9 0%,#9333ea 100%);transform:translateY(-2px);box-shadow:0 6px 20px #7c3aed80,0 0 0 1px #a855f766,inset 0 1px #fff3}.admin-toggle-icon{justify-content:center;align-items:center;font-size:1rem;display:flex}.admin-toggle-text{letter-spacing:.02em}@media (max-width:640px){.admin-toggle-btn{gap:.4rem;padding:.4rem .75rem;font-size:.75rem}.admin-toggle-icon{font-size:.9rem}}.admin-mode-container{background:var(--n-card);border:1px solid var(--n-border);margin-bottom:var(--spacing-lg);border-radius:20px;overflow:hidden;box-shadow:0 20px 50px -10px #7c3aed26}.admin-header{color:#fff;background:linear-gradient(135deg,#7c3aed 0%,#a855f7 50%,#c084fc 100%);justify-content:space-between;align-items:center;padding:1.5rem 1.75rem;display:flex}.admin-icon-wrapper{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:1px solid #fff3;border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;display:flex}.admin-title{letter-spacing:-.02em;margin:0;font-size:1.25rem;font-weight:800}.admin-subtitle{opacity:.85;margin:2px 0 0;font-size:.8rem}.admin-close-btn{color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #ffffff40;border-radius:10px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:600;transition:all .2s;display:inline-flex}.admin-close-btn:hover{background:#ffffff40;border-color:#fff6}.admin-close-btn i{font-size:16px}.admin-filters{background:var(--n-surface);border-bottom:1px solid var(--n-border);padding:1.5rem}.admin-filters .form-group{flex-direction:column;gap:6px;display:flex}.admin-filters .form-label{color:var(--n-muted);align-items:center;gap:4px;font-size:.75rem;font-weight:600;display:flex}.admin-filters .form-label i{font-size:.875rem}.admin-filters .form-select,.admin-filters .form-input{border:1px solid var(--n-border);background:var(--n-bg);width:100%;color:var(--n-text);border-radius:8px;outline:none;padding:10px 12px;font-size:.875rem;font-weight:500;transition:border-color .2s}.admin-filters .form-select:focus,.admin-filters .form-input:focus{border-color:var(--n-primary)}.dark .admin-filters{background:#ffffff08}.admin-actions{background:var(--n-bg);border-bottom:1px solid var(--n-border);justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.admin-table-container{min-height:300px;padding:1.5rem}.admin-loading{color:var(--n-muted);flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem 2rem;display:flex}.admin-spinner{border:3px solid var(--n-border);border-top-color:#7c3aed;border-radius:50%;width:40px;height:40px;animation:.8s linear infinite admin-spin}@keyframes admin-spin{to{transform:rotate(360deg)}}.admin-empty{color:var(--n-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:4rem 2rem;display:flex}.admin-empty i{opacity:.4;margin-bottom:.75rem;font-size:3rem}.admin-empty p{margin:0;font-size:1rem;font-weight:600}.admin-empty span{opacity:.7;margin-top:.25rem;font-size:.85rem}.admin-table{border-collapse:collapse;width:100%}.admin-table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--n-muted);border-bottom:2px solid var(--n-border);background:var(--n-surface);padding:12px 14px;font-size:.72rem;font-weight:700}.dark .admin-table th{background:#ffffff08}.admin-table td{border-bottom:1px solid var(--n-border);color:var(--n-ink);vertical-align:middle;padding:14px;font-size:.875rem}.admin-table tbody tr{transition:all .15s}.admin-table tbody tr:hover{background:var(--n-surface)}.admin-table tbody tr.selected{background:#7c3aed14}.dark .admin-table tbody tr.selected{background:#7c3aed26}.admin-table tbody tr:last-child td{border-bottom:none}.session-checkbox{cursor:pointer;accent-color:#7c3aed;border-radius:4px;width:18px;height:18px}.date-badge{background:var(--n-surface);border:1px solid var(--n-border);white-space:nowrap;border-radius:8px;padding:.35rem .75rem;font-size:.8rem;font-weight:600;display:inline-block}.kelas-badge{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#60a5fa 100%);border-radius:8px;padding:.35rem .75rem;font-size:.75rem;font-weight:700;display:inline-block;box-shadow:0 2px 8px #3b82f64d}.guru-info{flex-direction:column;gap:.35rem;display:flex}.guru-name{font-size:.875rem;font-weight:600}.pengganti-badge{color:#f59e0b;background:#f59e0b1a;border:1px solid #f59e0b33;border-radius:6px;align-items:center;gap:.35rem;padding:.2rem .6rem;font-size:.7rem;font-weight:600;display:inline-flex}.dark .pengganti-badge{color:#fbbf24;background:#f59e0b26}.jam-badge{color:#fff;background:linear-gradient(135deg,#10b981 0%,#34d399 100%);border-radius:8px;padding:.35rem .75rem;font-size:.75rem;font-weight:700;display:inline-block;box-shadow:0 2px 8px #10b9814d}.status-badge{border-radius:10px;align-items:center;gap:.4rem;padding:.4rem .8rem;font-size:.75rem;font-weight:700;display:inline-flex}.status-badge.final{color:#10b981;background:#10b9811f;border:1px solid #10b98140}.dark .status-badge.final{color:#34d399;background:#10b98126}.status-badge.draft{color:#f59e0b;background:#f59e0b1f;border:1px solid #f59e0b40}.dark .status-badge.draft{color:#fbbf24;background:#f59e0b26}.action-buttons{gap:.5rem;display:flex}.action-btn{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;width:34px;height:34px;font-size:.95rem;transition:all .2s;display:flex}.action-btn:hover:not(:disabled){transform:translateY(-2px)}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn.edit{color:#3b82f6;background:#3b82f61a;border:1px solid #3b82f633}.action-btn.edit:hover{background:#3b82f633;box-shadow:0 4px 12px #3b82f640}.action-btn.delete{color:#ef4444;background:#ef44441a;border:1px solid #ef444433}.action-btn.delete:hover{background:#ef444433;box-shadow:0 4px 12px #ef444440}.btn-danger{color:#fff;background:linear-gradient(135deg,#dc2626 0%,#ef4444 100%);border:none;box-shadow:0 4px 14px #dc26264d}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#b91c1c 0%,#dc2626 100%);box-shadow:0 6px 20px #dc262666}@media (min-width:641px) and (max-width:1024px){.admin-filters .grid{grid-template-columns:repeat(2,1fr);gap:.875rem}}@media (max-width:640px){.admin-filters{padding:.75rem}.admin-filters .grid{grid-template-columns:1fr;gap:.625rem;display:grid}.admin-filters .form-select,.admin-filters .form-input{padding:12px 14px;font-size:.875rem}}@media (max-width:768px){.admin-header{flex-direction:column;align-items:flex-start;gap:1rem;padding:1rem 1.25rem}.admin-filters{padding:1rem}.admin-filters .grid{grid-template-columns:1fr;gap:.75rem;display:grid}.admin-filters .form-select,.admin-filters .form-input{padding:12px 14px}.admin-table-container{padding:1rem;overflow-x:auto}.admin-table{min-width:600px}.admin-table th,.admin-table td{padding:10px 8px;font-size:.8rem}.admin-actions{flex-direction:column;align-items:stretch;gap:1rem}.action-buttons{justify-content:center}.admin-close-btn span{display:none}.admin-close-btn{padding:10px}}
