:root{--primary-color:#4338ca;--primary-hover:#3730a3;--secondary-color:#6b7280;--danger-color:#dc2626;--danger-hover:#b91c1c;--success-color:#16a34a;--warning-color:#f59e0b;--background-color:#f3f4f6;--card-background:#fff;--text-color:#1f2937;--text-secondary:#4b5563;--border-color:#d1d5db;--border-radius:.5rem;--box-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a}body,html{height:100%;margin:0;padding:0;overflow:hidden}body{background-color:var(--background-color);color:var(--text-color);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif}#root,.app-layout{width:100%;height:100%;display:flex}.main-content{flex-direction:column;flex-grow:1;height:100%;display:flex;overflow:hidden}.content-body{flex-grow:1;padding:1.5rem;overflow-y:auto}.main-header{background-color:var(--card-background);border-bottom:1px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.main-header h2{margin:0;font-size:1.5rem;font-weight:600}.user-profile{align-items:center;gap:.75rem;display:flex}.sidebar{background-color:var(--card-background);border-right:1px solid var(--border-color);box-sizing:border-box;flex-direction:column;width:250px;max-height:100vh;padding:1.5rem 1rem;transition:width .3s,transform .3s;display:flex}.sidebar-header{text-align:center;flex-direction:column;flex-shrink:0;align-items:center;gap:.5rem;margin-bottom:2rem;padding:0 .5rem;display:flex}.sidebar-header img{object-fit:contain;width:45px;height:45px}.sidebar-header h1{word-break:break-word;margin:0;font-size:1.125rem;font-weight:600;line-height:1.3}.nav-menu{flex-direction:column;flex-grow:1;gap:.2rem;padding-bottom:1rem;display:flex;overflow:hidden auto}.nav-item{border-radius:var(--border-radius);cursor:pointer;color:var(--text-secondary);flex-shrink:0;align-items:center;gap:.65rem;padding:.65rem;font-weight:500;text-decoration:none;transition:background-color .2s,color .2s;display:flex}.nav-item:hover{background-color:var(--background-color);color:var(--text-color)}.nav-item.active{background-color:var(--primary-color);color:#fff}.nav-item svg{flex-shrink:0;width:20px;height:20px}.nav-item span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.nav-item-parent{justify-content:space-between}.nav-arrow{color:var(--text-secondary);font-size:1rem;transition:transform .2s ease-in-out}.nav-item-parent:hover .nav-arrow{color:var(--text-color)}.nav-arrow.expanded{transform:rotate(-180deg)}.sub-menu{background-color:#f9fafb;flex-direction:column;display:flex;overflow:hidden}.sub-nav-item{padding-top:.6rem;padding-bottom:.6rem;padding-left:calc(1.5rem + 20px);font-size:.875rem}.sub-nav-item.active,.sub-nav-item.active:hover{font-weight:600;background-color:var(--primary-color)!important;color:#fff!important}.nav-item-parent.active,.nav-item-parent.active:hover{color:var(--primary-color);background-color:#eef2ff;font-weight:600}.nav-item-parent.active .nav-arrow{color:var(--primary-color)}.sidebar-footer{border-top:1px solid var(--border-color);flex-shrink:0;margin-top:auto;padding-top:1rem}.login-container{box-sizing:border-box;justify-content:center;align-items:center;width:100%;height:100%;padding:1rem;display:flex}.login-form{background-color:var(--card-background);border-radius:var(--border-radius);width:100%;max-width:400px;box-shadow:var(--box-shadow);padding:2.5rem 2rem}.login-title{text-align:center;margin-bottom:.5rem;font-size:1.5rem;font-weight:700}.login-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:2rem}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.summary-card{background-color:var(--card-background);border-radius:var(--border-radius);box-shadow:var(--box-shadow);padding:1.5rem}.btn{border-radius:var(--border-radius);cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1rem;font-size:.875rem;font-weight:600;line-height:1.25;text-decoration:none;transition:all .2s ease-in-out;display:inline-flex}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover);border-color:var(--primary-hover)}.btn-secondary{background-color:var(--card-background);color:var(--text-color);border-color:var(--border-color)}.btn-secondary:hover:not(:disabled){background-color:var(--background-color)}.btn-danger{background-color:var(--danger-color);color:#fff;border-color:var(--danger-color)}.btn-danger:hover:not(:disabled){background-color:var(--danger-hover);border-color:var(--danger-hover)}.btn-sm{padding:.25rem .5rem;font-size:.75rem}.form-group{margin-bottom:1.25rem}.form-group label{margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.form-control{border:1px solid var(--border-color);border-radius:var(--border-radius);box-sizing:border-box;width:100%;padding:.625rem .75rem;font-size:.875rem;line-height:1.5;transition:border-color .2s,box-shadow .2s}.form-control:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 2px #4338ca33}.filter-container{flex-wrap:wrap;align-items:flex-end;gap:1rem;margin-bottom:1.5rem;display:flex}.filter-container .form-group{margin-bottom:0}.table-wrapper{background-color:var(--card-background);border-radius:var(--border-radius);box-shadow:var(--box-shadow);overflow:auto}table{border-collapse:collapse;width:100%}th,td{text-align:left;border-bottom:1px solid var(--border-color);vertical-align:middle;padding:.75rem 1rem;font-size:.875rem}th{color:var(--text-secondary);text-transform:uppercase;z-index:1;background-color:#f9fafb;font-size:.75rem;font-weight:600;position:sticky;top:0}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background-color:var(--background-color)}.action-buttons{align-items:center;gap:.5rem;display:flex}.modal-backdrop{z-index:1000;background-color:#11182780;justify-content:center;align-items:center;width:100%;height:100%;padding:1rem;display:flex;position:fixed;top:0;left:0}.modal-content{background-color:var(--card-background);border-radius:var(--border-radius);flex-direction:column;width:100%;max-width:500px;max-height:90vh;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-title{margin:0;font-size:1.25rem;font-weight:600}.modal-close-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:0;font-size:1.75rem;line-height:1}.modal-close-btn:hover{color:var(--text-color)}.modal-body{flex-grow:1;padding:1.5rem;overflow-y:auto}.modal-footer{border-top:1px solid var(--border-color);flex-shrink:0;justify-content:flex-end;gap:.75rem;padding:1rem;display:flex}.loader-container{box-sizing:border-box;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;width:100%;height:100%;padding:2.5rem;display:flex}.loader{border:4px solid #e5e7eb;border-top:4px solid var(--primary-color);border-radius:50%;width:30px;height:30px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hamburger-btn,.close-btn{cursor:pointer;color:var(--text-color);background:0 0;border:none;padding:.5rem;display:none}.hamburger-btn svg{width:28px;height:28px}.close-btn{z-index:102;font-size:2.5rem;line-height:1;position:absolute;top:10px;right:15px}.overlay{display:none}@media (max-width:768px){.sidebar{z-index:101;height:100%;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0);box-shadow:0 0 15px #0003}.overlay{z-index:100;background-color:#00000080;width:100%;height:100%;display:block;position:fixed;top:0;left:0}.hamburger-btn,.close-btn{display:block}.main-header h2{font-size:1.25rem}.content-body,.main-header{padding:1rem}.user-profile{display:none}.table-wrapper{box-shadow:none;border:1px solid var(--border-color)}.table-wrapper table th[style*="position: sticky"],.table-wrapper table td[style*="position: sticky"]{z-index:auto!important;position:static!important;left:auto!important}.modal-content{max-width:90vw}}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}@media print{.sidebar,.main-header,.app-footer,.no-print{display:none!important}body,html,#root,.app-layout,.main-content,.content-body,.cetak-rapor-page,.cetak-leger-page,.cetak-buku-induk-page,.cetak-qr-page,.cetak-cover-page,.cetak-identitas-page,.cetak-mutasi-page{width:100%!important;height:auto!important;box-shadow:none!important;background:#fff!important;border:none!important;margin:0!important;padding:0!important;display:block!important;overflow:visible!important}body>:not(#root),#root>:not(.app-layout),.app-layout>.sidebar{display:none!important}.app-layout,.main-content{flex:none!important;flex-direction:unset!important}.main-content>.main-header,.main-content>.app-footer{border:none!important;height:0!important;min-height:0!important;margin:0!important;padding:0!important}.main-content>.content-body{flex:none!important;position:static!important}.content-body>:not(.cetak-qr-page):not(.cetak-rapor-page):not(.cetak-leger-page):not(.cetak-buku-induk-page):not(.cetak-cover-page):not(.cetak-identitas-page):not(.cetak-mutasi-page){display:none!important}.content-body>.cetak-qr-page,.content-body>.cetak-rapor-page,.content-body>.cetak-leger-page,.content-body>.cetak-buku-induk-page,.content-body>.cetak-cover-page,.content-body>.cetak-identitas-page,.content-body>.cetak-mutasi-page{margin:0!important;padding:0!important}.cetak-rapor-page .leger-preview,.cetak-rapor-page .buku-induk-preview,.cetak-rapor-page .cover-preview,.cetak-rapor-page .identitas-preview,.cetak-rapor-page .mutasi-preview,.cetak-leger-page .rapor-page,.cetak-leger-page .buku-induk-preview,.cetak-leger-page .cover-preview,.cetak-leger-page .identitas-preview,.cetak-leger-page .mutasi-preview,.cetak-buku-induk-page .rapor-page,.cetak-buku-induk-page .leger-preview,.cetak-buku-induk-page .cover-preview,.cetak-buku-induk-page .identitas-preview,.cetak-buku-induk-page .mutasi-preview,.cetak-cover-page .rapor-page,.cetak-cover-page .leger-preview,.cetak-cover-page .buku-induk-preview,.cetak-cover-page .identitas-preview,.cetak-cover-page .mutasi-preview,.cetak-identitas-page .rapor-page,.cetak-identitas-page .leger-preview,.cetak-identitas-page .buku-induk-preview,.cetak-identitas-page .cover-preview,.cetak-identitas-page .mutasi-preview,.cetak-mutasi-page .rapor-page,.cetak-mutasi-page .leger-preview,.cetak-mutasi-page .buku-induk-preview,.cetak-mutasi-page .cover-preview,.cetak-mutasi-page .identitas-preview,.cetak-qr-page .rapor-page,.cetak-qr-page .leger-preview,.cetak-qr-page .buku-induk-preview,.cetak-qr-page .cover-preview,.cetak-qr-page .identitas-preview,.cetak-qr-page .mutasi-preview{display:none!important}@page{size:A4;margin:1.5cm 1.5cm 1cm}@page leger-page{size:A4 landscape;margin:1cm .5cm}@page buku-induk-page{size:A4;margin:1cm}@page cover-page{size:A4 portrait;margin:1.5cm}@page identitas-page{size:A4 portrait;margin:1.5cm 2cm 1cm}@page mutasi-page{size:A4 portrait;margin:1.5cm}.rapor-preview,#rapor-container.rapor-preview{color:#000!important;width:100%!important;box-shadow:none!important;background:#fff!important;border:none!important;margin:0!important;padding:0!important;font-family:Arial,sans-serif!important;font-size:11pt!important}.rapor-main-wrapper-table,#rapor-container.rapor-preview>.rapor-main-wrapper-table{border-collapse:collapse;width:100%;border:none!important}.rapor-main-wrapper-table>tbody>tr>td,#rapor-container.rapor-preview>.rapor-main-wrapper-table>tbody>tr>td{vertical-align:top!important;border:none!important;padding:0!important}.rapor-page{box-sizing:border-box;width:100%;height:auto;padding-bottom:0;position:relative;border:none!important}.ttd-page{page-break-inside:avoid!important}.rapor-page:after{content:"";background-image:var(--watermark-logo-url);opacity:.1;z-index:-1;background-position:50%;background-repeat:no-repeat;background-size:contain;width:50%;height:50%;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.rapor-page:last-child{page-break-after:avoid}.force-page-break-before{page-break-before:always!important}.page-break{page-break-after:avoid;height:0;display:block}.rapor-info-table{border-collapse:collapse;width:100%;margin-bottom:1.5rem;border:none!important}.rapor-info-table td{vertical-align:top;padding:4px 5px;font-size:10pt;border:none!important}.rapor-info-table td:first-child{width:15%;font-weight:400}.rapor-info-table td:nth-child(2){text-align:center;width:2%;padding-left:0;padding-right:0}.rapor-info-table td:nth-child(3){width:53%}.rapor-info-table td:nth-child(4){width:16%;font-weight:400}.rapor-info-table td:nth-child(5){text-align:center;width:2%;padding-left:0;padding-right:0}.rapor-info-table td:nth-child(6){width:12%}.rapor-nilai-table,.rapor-ekstra-table{border-collapse:collapse;border:1px solid #000;width:100%;margin-bottom:0}.rapor-nilai-table th,.rapor-nilai-table td,.rapor-ekstra-table th,.rapor-ekstra-table td{vertical-align:top;border:1px solid #000;padding:.3rem .5rem;border-right:1px solid #000!important}.rapor-ekstra-table td:first-child{vertical-align:middle!important;text-align:center!important}.rapor-ekstra-table td:nth-child(2){vertical-align:middle!important}.rapor-nilai-table td:last-child{border-right:1px solid #000!important}.rapor-nilai-table td:first-child,.rapor-nilai-table td:nth-child(2),.rapor-nilai-table td:nth-child(3){vertical-align:middle!important}.rapor-nilai-table th,.rapor-ekstra-table th{text-align:center;vertical-align:middle;background-color:#363232;font-weight:700}.rapor-nilai-table th:first-child{width:5%}.rapor-nilai-table th:nth-child(2){text-align:center;width:25%}.rapor-nilai-table th:nth-child(3){width:10%}.rapor-nilai-table th:nth-child(4){text-align:center}.rapor-nilai-table td{vertical-align:top;border:1px solid #000;padding:.3rem .5rem;font-size:10pt;line-height:1.3}.rapor-nilai-table tbody tr{page-break-inside:avoid!important;break-inside:avoid!important}.rapor-absensi-table{border-collapse:collapse;border:1px solid #000;width:auto;margin-bottom:1rem;margin-left:0}.rapor-absensi-table td{vertical-align:top;border:1px solid #000;padding:2px 5px}.rapor-absensi-table td:first-child{width:120px}.rapor-section{margin-bottom:1rem;padding:.5rem}div#rapor-container div.rapor-page div.rapor-koku,div#rapor-container div.rapor-page div.rapor-catatan-guru{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;background-color:#fff!important;background-image:none!important;border:1px solid #000!important;min-height:4em!important;padding:.5rem 1rem!important}.rapor-ttd-section{width:100%;margin-top:2rem;font-size:10pt}.ttd-row-top{justify-content:space-between;align-items:center;gap:2%;width:100%;margin-bottom:2rem;display:flex}.ttd-row-bottom{text-align:center;width:100%;margin-top:2rem}.ttd-block{text-align:center;flex:1}.ttd-kepsek{text-align:center;width:auto;display:inline-block}.signature-space{height:5.5em}.cetak-buku-induk-page .signature-space{height:4em}.ttd-ortu .signature-line{border-top:1px solid #000;width:50%;min-width:100px;max-width:300px;margin:5px auto 0}.rapor-footer{color:#000;z-index:90;background-color:#fff;border-top:1px solid #ccc;justify-content:space-between;width:100%;margin-top:2rem;padding-top:3px;font-size:6pt;display:flex;position:fixed;bottom:0}.leger-preview{color:#000;page:leger-page;max-width:100%;font-size:9pt;box-shadow:none!important;border:none!important;margin:0!important;padding:0!important;font-family:Arial,sans-serif!important}.leger-header{text-align:center}.leger-info-table{width:100%;margin:1rem 0;font-size:10pt}.leger-info-table td{border:none;padding:2px 5px}.leger-info-table td:first-child{width:15%}.leger-info-table td:nth-child(2){width:35%}.leger-info-table td:nth-child(3){width:15%}.leger-info-table td:nth-child(4){width:35%}.leger-nilai-table{border-collapse:separate;border-spacing:0;text-align:center;border:1px solid #000;width:100%}.leger-nilai-table th,.leger-nilai-table td{vertical-align:middle;text-align:center;border:1px solid #000;padding:4px 2px}.leger-nilai-table thead th{background-color:#f2f2f2;padding:5px 2px;font-weight:700}.leger-nilai-table thead tr:nth-child(3) th{writing-mode:vertical-rl;white-space:nowrap;padding:8px 2px;transform:rotate(180deg);border-right:1px solid #000!important}.leger-ttd-section{justify-content:space-between;width:100%;margin-top:2rem;font-size:10pt;display:flex}.leger-ttd-section .ttd-block{text-align:center;width:45%}.leger-ttd-section .signature-space{height:5em}.cetak-buku-induk-page{page:buku-induk-page}.identitas-preview .force-page-break-before{border-top:none!important;margin-top:0!important;padding-top:0!important}.cover-preview{page:cover-page;max-width:100%;box-shadow:none!important;border:none!important;margin:0!important;padding:0!important}.identitas-preview{page:identitas-page;color:#000;max-width:100%;font-size:12pt;box-shadow:none!important;border:none!important;margin:0!important;padding:0!important;font-family:Arial,serif!important}.identitas-page{box-sizing:border-box;width:100%;height:26.7cm;padding:0;position:relative}.identitas-info{width:100%!important}.identitas-info-table{border-collapse:collapse;width:100%;margin-top:1rem}.identitas-info-table td{vertical-align:top;padding:2px 4px;font-size:11pt;line-height:1.3;border:none!important}.identitas-info-table tr:last-child td{border-bottom:none}.identitas-info-table td:first-child{text-align:right;border-bottom:none;width:4%}.identitas-info-table td:nth-child(2){width:28%}.identitas-info-table td:nth-child(3){width:2%}.identitas-info-table td:nth-child(4){width:66%}.identitas-info-table td:first-child:empty{border-bottom:none}.mutasi-preview{page:mutasi-page;color:#000;max-width:100%;font-size:11pt;box-shadow:none!important;border:none!important;margin:0!important;padding:0!important;font-family:Arial,sans-serif!important}.mutasi-header{text-align:center;margin-bottom:1rem;font-size:14pt;font-weight:700}.mutasi-siswa-name{margin-bottom:2rem;font-size:11pt}.mutasi-table-keluar{border-collapse:collapse;border:2px solid #000;width:100%;margin-bottom:2rem}.mutasi-table-keluar th,.mutasi-table-keluar td{vertical-align:top;text-align:left;border:1px solid #000;padding:.5rem}.mutasi-table-keluar th{text-align:center;background-color:#f2f2f2;font-weight:700}.mutasi-table-keluar tbody tr{height:7cm}.mutasi-table-keluar td:first-child,.mutasi-table-keluar td:nth-child(2){width:15%}.mutasi-table-keluar td:nth-child(3){width:30%}.mutasi-table-keluar td:nth-child(4){width:40%}.mutasi-table-keluar .ttd-space{height:5em}.mutasi-table-keluar .ttd-line{border-bottom:1px solid #000;width:80%;margin:.5rem 0}.mutasi-table-masuk{border-collapse:collapse;border:2px solid #000;width:100%}.mutasi-table-masuk th,.mutasi-table-masuk td{vertical-align:top;text-align:left;border:1px solid #000;padding:.5rem;line-height:1.5}.mutasi-table-masuk th{text-align:center;background-color:#f2f2f2;font-weight:700}.mutasi-table-masuk tbody tr{height:7cm}.mutasi-table-masuk td:first-child{width:25%;font-weight:700}.mutasi-table-masuk td:nth-child(2){width:35%}.mutasi-table-masuk td:nth-child(3){vertical-align:top;width:40%}.mutasi-table-masuk .ttd-space{height:4em}}.mutasi-preview{color:#000;background:#fff;border:1px solid #ccc;max-width:210mm;margin:1rem auto;padding:1.5cm;font-size:11pt;box-shadow:0 0 10px #0000001a;font-family:Arial,sans-serif!important}.mutasi-preview .force-page-break-before{border-top:2px dashed var(--primary-color);margin-top:2rem;padding-top:1rem}.mutasi-header{text-align:center;margin-bottom:1rem;font-size:14pt;font-weight:700}.mutasi-siswa-name{margin-bottom:2rem;font-size:11pt}.mutasi-table-keluar{border-collapse:collapse;border:2px solid #000;width:100%;margin-bottom:2rem}.mutasi-table-keluar th,.mutasi-table-keluar td{vertical-align:top;text-align:left;border:1px solid #000;padding:.5rem}.mutasi-table-keluar th{text-align:center;background-color:#f2f2f2;font-weight:700}.mutasi-table-keluar tbody tr{height:7cm}.mutasi-table-keluar td:first-child,.mutasi-table-keluar td:nth-child(2){width:15%}.mutasi-table-keluar td:nth-child(3){width:30%}.mutasi-table-keluar td:nth-child(4){width:40%}.mutasi-table-keluar .ttd-space{height:5em}.mutasi-table-keluar .ttd-line{border-bottom:1px solid #000;width:80%;margin:.5rem 0}.mutasi-table-masuk{border-collapse:collapse;border:2px solid #000;width:100%}.mutasi-table-masuk th,.mutasi-table-masuk td{vertical-align:top;text-align:left;border:1px solid #000;padding:.5rem;line-height:1.5}.mutasi-table-masuk th{text-align:center;background-color:#f2f2f2;font-weight:700}.mutasi-table-masuk tbody tr{height:7cm}.mutasi-table-masuk td:first-child{width:25%;font-weight:700}.mutasi-table-masuk td:nth-child(2){width:35%}.mutasi-table-masuk td:nth-child(3){vertical-align:top;width:40%}.mutasi-table-masuk .ttd-space{height:4em}
