@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*{margin:0;padding:0;box-sizing:border-box;font-family:Inter,sans-serif}body{background-color:#f3f4f6;color:#1f2937;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}button{cursor:pointer;transition:all .2s ease-in-out}input{transition:border-color .2s ease-in-out,box-shadow .2s ease-in-out}input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.glass-panel{background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.3);box-shadow:0 8px 32px #1f268726}.admin-container{display:flex;flex-direction:row;min-height:100vh;background-color:#f0f0f0;font-family:Arial,sans-serif;background-image:url('data:image/svg+xml,%3Csvg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"%3E%3Cg fill="%23e5e5e5" fill-opacity="0.4" fill-rule="evenodd"%3E%3Ccircle cx="3" cy="3" r="3"/%3E%3Ccircle cx="13" cy="13" r="3"/%3E%3C/g%3E%3C/svg%3E')}.main-wrapper{flex:1;display:flex;flex-direction:column;min-width:0}.admin-header{background-color:#fff;color:#333;display:flex;justify-content:space-between;align-items:center;padding:0 2rem;height:60px;border-bottom:1px solid #e5e7eb}.admin-logo h1{font-size:1.5rem;font-weight:700;margin:0;text-transform:uppercase}.admin-user-menu{display:flex;align-items:center;gap:1rem;font-size:.9rem}.logout-btn-small{background:#e74c3c;color:#fff;border:none;padding:.4rem 1rem;border-radius:4px;cursor:pointer;font-size:.85rem;font-weight:700;transition:background .2s}.logout-btn-small:hover{background:#c0392b}.admin-main{flex:1;padding:2rem;display:flex;flex-direction:column;align-items:center;gap:2rem;overflow-y:auto}.admin-sidebar{width:260px;background-color:#fff;color:#333;display:flex;flex-direction:column;box-shadow:2px 0 10px #00000014;z-index:100;border-right:1px solid #e5e7eb;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar-menu{display:flex;flex-direction:column;padding:1rem 0}.sidebar-item{display:flex;align-items:center;padding:12px 20px;cursor:pointer;transition:all .2s ease;border-left:4px solid transparent;color:#555;gap:15px}.sidebar-item:hover{background-color:#f0fdf4;color:#1a7134}.sidebar-item.active{background-color:#f0fdf4;color:#1a7134;border-left-color:#10b981;font-weight:700}.sidebar-item.cetak-kartu{margin-top:10px;border-top:1px solid #e5e7eb;padding-top:20px}.sidebar-item.cetak-kartu.active,.sidebar-item.cetak-kartu:hover{background-color:#fef2f2;color:#f24333}.sidebar-item.cetak-kartu.active{border-left-color:#f24333!important}.sidebar-icon-wrapper{display:flex;align-items:center;justify-content:center;width:24px}.sidebar-text{font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.admin-grid-container{width:100%;max-width:1100px;background-color:#fff;padding:1.5rem;border-radius:4px;box-shadow:0 2px 4px #0000001a;border:1px solid #e0e0e0}.admin-grid{display:flex;flex-wrap:nowrap;gap:.8rem;justify-content:center;overflow-x:auto}.admin-card{width:90px;height:90px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;border-radius:4px;cursor:pointer;transition:transform .2s,filter .2s;box-shadow:inset 0 -2px #0003}.admin-card:hover{filter:brightness(1.1);transform:translateY(-2px)}.admin-card-icon{display:flex;align-items:center;justify-content:center;margin-bottom:.5rem}.admin-card-title{font-size:.65rem;font-weight:700;text-align:center}.admin-welcome-box,.admin-table-box{width:100%;max-width:1100px;background-color:#fff;border-radius:4px;box-shadow:0 2px 4px #0000001a;border:1px solid #e0e0e0;overflow:hidden}.admin-welcome-header{background-color:#f8dbdb;color:#a94442;padding:.75rem 1rem;font-weight:700;border-bottom:1px solid #ebccd1;font-size:.9rem}.admin-welcome-body{padding:1rem}.admin-alert{background-color:#dff0d8;color:#3c763d;padding:1rem;border:1px solid #d6e9c6;border-radius:4px;font-size:.9rem}.admin-table-header{background-color:#f5f5f5;border-bottom:2px solid #ddd;padding:.75rem 1rem;display:flex;justify-content:space-between;align-items:center}.admin-table-header.siswa-header{background-color:#dff0d8;border:1px solid #d6e9c6;border-radius:4px 4px 0 0}.admin-table-header.guru-header{background-color:#fcf8e3;border:1px solid #faebcc;border-radius:4px 4px 0 0}.admin-table-header.warning-header{background-color:#fcf8e3;border-bottom:1px solid #faebcc}.admin-table-header.danger-header{background-color:#f8dbdb;border-bottom:1px solid #ebccd1}.admin-table-header.orange-header{background-color:#fcf8e3;border-bottom:1px solid #faebcc}.admin-table-actions-top{display:flex;gap:.5rem}.btn-success{background-color:#5cb85c;color:#fff;border:1px solid #4cae4c;padding:.35rem .75rem;border-radius:3px;cursor:pointer;font-size:.8rem;display:flex;align-items:center;gap:.3rem}.btn-warning{background-color:#f0ad4e;color:#fff;border:1px solid #eea236;padding:.35rem .75rem;border-radius:3px;cursor:pointer;font-size:.8rem;display:flex;align-items:center;gap:.3rem}.btn-danger{background-color:#d9534f;color:#fff;border:1px solid #d43f3a;padding:.35rem .75rem;border-radius:3px;cursor:pointer;font-size:.8rem;display:flex;align-items:center;gap:.3rem}.btn-info{background-color:#5bc0de;color:#fff;border:1px solid #46b8da;padding:.35rem .75rem;border-radius:3px;cursor:pointer;font-size:.8rem;display:flex;align-items:center;gap:.3rem}.btn-primary-bulk{background-color:#337ab7;color:#fff;border:1px solid #2e6da4;padding:.35rem .75rem;border-radius:3px;cursor:pointer;font-size:.8rem;display:flex;align-items:center;gap:.3rem}.btn-danger-bulk{background-color:#d9534f;color:#fff;border:1px solid #d43f3a;padding:.35rem .75rem;border-radius:3px;cursor:pointer;font-size:.8rem;display:flex;align-items:center;gap:.3rem}.btn-action{padding:2px 8px;font-size:11px;border-radius:3px;border:none;cursor:pointer;color:#fff;display:inline-flex;align-items:center;gap:3px}.btn-edit-siswa{background-color:#337ab7}.btn-hapus-siswa{background-color:#d9534f}.btn-aktifkan-siswa{background-color:#5bc0de}.admin-table-body{padding:1rem}.admin-table-bulk-actions{display:flex;gap:.5rem;margin-bottom:1rem}.btn-primary-bulk{background-color:#3b82f6;color:#fff;border:none;padding:.35rem .75rem;border-radius:3px;cursor:pointer;font-size:.8rem;display:flex;align-items:center;gap:.3rem}.admin-table-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:.9rem;color:#4b5563}.table-search input{border:1px solid #d1d5db;border-radius:3px}.table-search input:focus{outline:none;border-color:#3b82f6}.data-table{width:100%;border-collapse:collapse;margin-bottom:1rem;font-size:.9rem}.data-table th{background-color:#e5e7eb;border:1px solid #d1d5db;padding:.75rem;text-align:left;color:#374151;font-weight:700}.data-table td{border:1px solid #d1d5db;padding:.75rem;color:#4b5563}.action-buttons-group{display:flex;gap:.25rem;justify-content:center}.btn-action{color:#fff;border:none;padding:.25rem .5rem;border-radius:3px;cursor:pointer;font-size:.75rem;display:flex;align-items:center;gap:.25rem}.btn-info-action{background-color:#0ea5e9}.btn-danger-action{background-color:#ef4444}.btn-success-action{background-color:#10b981}.btn-warning-action{background-color:#f59e0b}.admin-table-footer{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;color:#4b5563}.pagination{display:flex}.page-btn{background:#fff;border:1px solid #d1d5db;padding:.35rem .75rem;cursor:pointer}.page-btn:first-child{border-top-left-radius:4px;border-bottom-left-radius:4px}.page-btn:last-child{border-top-right-radius:4px;border-bottom-right-radius:4px;border-left:none}.page-btn.active{background-color:#0ea5e9;color:#fff;border-color:#0ea5e9}.page-btn.disabled{color:#9ca3af;cursor:not-allowed;background-color:#f9fafb}.admin-footer{background-color:#fff;color:#555;text-align:center;padding:1rem;font-size:.8rem;border-top:1px solid #e5e7eb}.footer-title{font-weight:700;color:#333;margin-bottom:.25rem}.footer-time{color:#888}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:flex-start;padding-top:5rem;z-index:1000}.modal-content{background:#fff;width:600px;border-radius:4px;box-shadow:0 5px 15px #00000080;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #e5e5e5}.modal-header h4{margin:0;font-size:1.1rem;color:#333;font-weight:400}.modal-close{background:transparent;border:none;font-size:1.5rem;font-weight:700;color:#000;opacity:.2;cursor:pointer}.modal-close:hover{opacity:.5}.modal-body{padding:1.5rem}.form-group-horizontal{display:flex;align-items:center;margin-bottom:1rem}.form-group-horizontal label{width:150px;font-size:.9rem;color:#333}.form-group-horizontal input,.form-group-horizontal select{flex:1;padding:.5rem;border:1px solid #66afe9;border-radius:4px;outline:none;box-shadow:inset 0 1px 1px #00000013,0 0 8px #66afe999;font-size:.9rem;font-family:inherit;box-sizing:border-box;height:38px}.modal-footer{padding:1rem;border-top:1px solid #e5e5e5;display:flex;justify-content:flex-end;gap:.5rem}.btn-primary{background-color:#0275d8;color:#fff;border:none;padding:.5rem 1rem;border-radius:3px;cursor:pointer;display:flex;align-items:center;gap:.3rem;font-size:.9rem}.btn-default{background-color:#f4f4f4;color:#333;border:1px solid #ddd;padding:.5rem 1rem;border-radius:3px;cursor:pointer;display:flex;align-items:center;gap:.3rem;font-size:.9rem}.btn-default:hover{background-color:#e6e6e6}.ql-container{box-sizing:border-box;font-family:Helvetica,Arial,sans-serif;font-size:13px;height:100%;margin:0;position:relative}.ql-container.ql-disabled .ql-tooltip{visibility:hidden}.ql-container:not(.ql-disabled) li[data-list=checked]>.ql-ui,.ql-container:not(.ql-disabled) li[data-list=unchecked]>.ql-ui{cursor:pointer}.ql-clipboard{left:-100000px;height:1px;overflow-y:hidden;position:absolute;top:50%}.ql-clipboard p{margin:0;padding:0}.ql-editor{box-sizing:border-box;counter-reset:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;line-height:1.42;height:100%;outline:none;overflow-y:auto;padding:12px 15px;tab-size:4;-moz-tab-size:4;text-align:left;white-space:pre-wrap;word-wrap:break-word}.ql-editor>*{cursor:text}.ql-editor p,.ql-editor ol,.ql-editor pre,.ql-editor blockquote,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{margin:0;padding:0}@supports (counter-set:none){.ql-editor p,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{counter-set:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor p,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{counter-reset:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor table{border-collapse:collapse}.ql-editor td{border:1px solid #000;padding:2px 5px}.ql-editor ol{padding-left:1.5em}.ql-editor li{list-style-type:none;padding-left:1.5em;position:relative}.ql-editor li>.ql-ui:before{display:inline-block;margin-left:-1.5em;margin-right:.3em;text-align:right;white-space:nowrap;width:1.2em}.ql-editor li[data-list=checked]>.ql-ui,.ql-editor li[data-list=unchecked]>.ql-ui{color:#777}.ql-editor li[data-list=bullet]>.ql-ui:before{content:"•"}.ql-editor li[data-list=checked]>.ql-ui:before{content:"☑"}.ql-editor li[data-list=unchecked]>.ql-ui:before{content:"☐"}@supports (counter-set:none){.ql-editor li[data-list]{counter-set:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list]{counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered]{counter-increment:list-0}.ql-editor li[data-list=ordered]>.ql-ui:before{content:counter(list-0,decimal) ". "}.ql-editor li[data-list=ordered].ql-indent-1{counter-increment:list-1}.ql-editor li[data-list=ordered].ql-indent-1>.ql-ui:before{content:counter(list-1,lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-1{counter-set:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-1{counter-reset:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-2{counter-increment:list-2}.ql-editor li[data-list=ordered].ql-indent-2>.ql-ui:before{content:counter(list-2,lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-2{counter-set:list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-2{counter-reset:list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-3{counter-increment:list-3}.ql-editor li[data-list=ordered].ql-indent-3>.ql-ui:before{content:counter(list-3,decimal) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-3{counter-set:list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-3{counter-reset:list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-4{counter-increment:list-4}.ql-editor li[data-list=ordered].ql-indent-4>.ql-ui:before{content:counter(list-4,lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-4{counter-set:list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-4{counter-reset:list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-5{counter-increment:list-5}.ql-editor li[data-list=ordered].ql-indent-5>.ql-ui:before{content:counter(list-5,lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-5{counter-set:list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-5{counter-reset:list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-6{counter-increment:list-6}.ql-editor li[data-list=ordered].ql-indent-6>.ql-ui:before{content:counter(list-6,decimal) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-6{counter-set:list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-6{counter-reset:list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-7{counter-increment:list-7}.ql-editor li[data-list=ordered].ql-indent-7>.ql-ui:before{content:counter(list-7,lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-7{counter-set:list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-7{counter-reset:list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-8{counter-increment:list-8}.ql-editor li[data-list=ordered].ql-indent-8>.ql-ui:before{content:counter(list-8,lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-8{counter-set:list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-8{counter-reset:list-9}}.ql-editor li[data-list=ordered].ql-indent-9{counter-increment:list-9}.ql-editor li[data-list=ordered].ql-indent-9>.ql-ui:before{content:counter(list-9,decimal) ". "}.ql-editor .ql-indent-1:not(.ql-direction-rtl){padding-left:3em}.ql-editor li.ql-indent-1:not(.ql-direction-rtl){padding-left:4.5em}.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:3em}.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:4.5em}.ql-editor .ql-indent-2:not(.ql-direction-rtl){padding-left:6em}.ql-editor li.ql-indent-2:not(.ql-direction-rtl){padding-left:7.5em}.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:6em}.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:7.5em}.ql-editor .ql-indent-3:not(.ql-direction-rtl){padding-left:9em}.ql-editor li.ql-indent-3:not(.ql-direction-rtl){padding-left:10.5em}.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:9em}.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:10.5em}.ql-editor .ql-indent-4:not(.ql-direction-rtl){padding-left:12em}.ql-editor li.ql-indent-4:not(.ql-direction-rtl){padding-left:13.5em}.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:12em}.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:13.5em}.ql-editor .ql-indent-5:not(.ql-direction-rtl){padding-left:15em}.ql-editor li.ql-indent-5:not(.ql-direction-rtl){padding-left:16.5em}.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:15em}.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:16.5em}.ql-editor .ql-indent-6:not(.ql-direction-rtl){padding-left:18em}.ql-editor li.ql-indent-6:not(.ql-direction-rtl){padding-left:19.5em}.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:18em}.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:19.5em}.ql-editor .ql-indent-7:not(.ql-direction-rtl){padding-left:21em}.ql-editor li.ql-indent-7:not(.ql-direction-rtl){padding-left:22.5em}.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:21em}.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:22.5em}.ql-editor .ql-indent-8:not(.ql-direction-rtl){padding-left:24em}.ql-editor li.ql-indent-8:not(.ql-direction-rtl){padding-left:25.5em}.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:24em}.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:25.5em}.ql-editor .ql-indent-9:not(.ql-direction-rtl){padding-left:27em}.ql-editor li.ql-indent-9:not(.ql-direction-rtl){padding-left:28.5em}.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:27em}.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:28.5em}.ql-editor li.ql-direction-rtl{padding-right:1.5em}.ql-editor li.ql-direction-rtl>.ql-ui:before{margin-left:.3em;margin-right:-1.5em;text-align:left}.ql-editor table{table-layout:fixed;width:100%}.ql-editor table td{outline:none}.ql-editor .ql-code-block-container{font-family:monospace}.ql-editor .ql-video{display:block;max-width:100%}.ql-editor .ql-video.ql-align-center{margin:0 auto}.ql-editor .ql-video.ql-align-right{margin:0 0 0 auto}.ql-editor .ql-bg-black{background-color:#000}.ql-editor .ql-bg-red{background-color:#e60000}.ql-editor .ql-bg-orange{background-color:#f90}.ql-editor .ql-bg-yellow{background-color:#ff0}.ql-editor .ql-bg-green{background-color:#008a00}.ql-editor .ql-bg-blue{background-color:#06c}.ql-editor .ql-bg-purple{background-color:#93f}.ql-editor .ql-color-white{color:#fff}.ql-editor .ql-color-red{color:#e60000}.ql-editor .ql-color-orange{color:#f90}.ql-editor .ql-color-yellow{color:#ff0}.ql-editor .ql-color-green{color:#008a00}.ql-editor .ql-color-blue{color:#06c}.ql-editor .ql-color-purple{color:#93f}.ql-editor .ql-font-serif{font-family:Georgia,Times New Roman,serif}.ql-editor .ql-font-monospace{font-family:Monaco,Courier New,monospace}.ql-editor .ql-size-small{font-size:.75em}.ql-editor .ql-size-large{font-size:1.5em}.ql-editor .ql-size-huge{font-size:2.5em}.ql-editor .ql-direction-rtl{direction:rtl;text-align:inherit}.ql-editor .ql-align-center{text-align:center}.ql-editor .ql-align-justify{text-align:justify}.ql-editor .ql-align-right{text-align:right}.ql-editor .ql-ui{position:absolute}.ql-editor.ql-blank:before{color:#0009;content:attr(data-placeholder);font-style:italic;left:15px;pointer-events:none;position:absolute;right:15px}.ql-snow.ql-toolbar:after,.ql-snow .ql-toolbar:after{clear:both;content:"";display:table}.ql-snow.ql-toolbar button,.ql-snow .ql-toolbar button{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:28px}.ql-snow.ql-toolbar button svg,.ql-snow .ql-toolbar button svg{float:left;height:100%}.ql-snow.ql-toolbar button:active:hover,.ql-snow .ql-toolbar button:active:hover{outline:none}.ql-snow.ql-toolbar input.ql-image[type=file],.ql-snow .ql-toolbar input.ql-image[type=file]{display:none}.ql-snow.ql-toolbar button:hover,.ql-snow .ql-toolbar button:hover,.ql-snow.ql-toolbar button:focus,.ql-snow .ql-toolbar button:focus,.ql-snow.ql-toolbar button.ql-active,.ql-snow .ql-toolbar button.ql-active,.ql-snow.ql-toolbar .ql-picker-label:hover,.ql-snow .ql-toolbar .ql-picker-label:hover,.ql-snow.ql-toolbar .ql-picker-label.ql-active,.ql-snow .ql-toolbar .ql-picker-label.ql-active,.ql-snow.ql-toolbar .ql-picker-item:hover,.ql-snow .ql-toolbar .ql-picker-item:hover,.ql-snow.ql-toolbar .ql-picker-item.ql-selected,.ql-snow .ql-toolbar .ql-picker-item.ql-selected{color:#06c}.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow .ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button:focus .ql-fill,.ql-snow .ql-toolbar button:focus .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill{fill:#06c}.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow .ql-toolbar button:hover .ql-stroke,.ql-snow.ql-toolbar button:focus .ql-stroke,.ql-snow .ql-toolbar button:focus .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke,.ql-snow .ql-toolbar button.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow.ql-toolbar button:hover .ql-stroke-miter,.ql-snow .ql-toolbar button:hover .ql-stroke-miter,.ql-snow.ql-toolbar button:focus .ql-stroke-miter,.ql-snow .ql-toolbar button:focus .ql-stroke-miter,.ql-snow.ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter{stroke:#06c}@media(pointer:coarse){.ql-snow.ql-toolbar button:hover:not(.ql-active),.ql-snow .ql-toolbar button:hover:not(.ql-active){color:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill{fill:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter{stroke:#444}}.ql-snow,.ql-snow *{box-sizing:border-box}.ql-snow .ql-hidden{display:none}.ql-snow .ql-out-bottom,.ql-snow .ql-out-top{visibility:hidden}.ql-snow .ql-tooltip{position:absolute;transform:translateY(10px)}.ql-snow .ql-tooltip a{cursor:pointer;text-decoration:none}.ql-snow .ql-tooltip.ql-flip{transform:translateY(-10px)}.ql-snow .ql-formats{display:inline-block;vertical-align:middle}.ql-snow .ql-formats:after{clear:both;content:"";display:table}.ql-snow .ql-stroke{fill:none;stroke:#444;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.ql-snow .ql-stroke-miter{fill:none;stroke:#444;stroke-miterlimit:10;stroke-width:2}.ql-snow .ql-fill,.ql-snow .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-empty{fill:none}.ql-snow .ql-even{fill-rule:evenodd}.ql-snow .ql-thin,.ql-snow .ql-stroke.ql-thin{stroke-width:1}.ql-snow .ql-transparent{opacity:.4}.ql-snow .ql-direction svg:last-child{display:none}.ql-snow .ql-direction.ql-active svg:last-child{display:inline}.ql-snow .ql-direction.ql-active svg:first-child{display:none}.ql-snow .ql-editor h1{font-size:2em}.ql-snow .ql-editor h2{font-size:1.5em}.ql-snow .ql-editor h3{font-size:1.17em}.ql-snow .ql-editor h4{font-size:1em}.ql-snow .ql-editor h5{font-size:.83em}.ql-snow .ql-editor h6{font-size:.67em}.ql-snow .ql-editor a{text-decoration:underline}.ql-snow .ql-editor blockquote{border-left:4px solid #ccc;margin-bottom:5px;margin-top:5px;padding-left:16px}.ql-snow .ql-editor code,.ql-snow .ql-editor .ql-code-block-container{background-color:#f0f0f0;border-radius:3px}.ql-snow .ql-editor .ql-code-block-container{margin-bottom:5px;margin-top:5px;padding:5px 10px}.ql-snow .ql-editor code{font-size:85%;padding:2px 4px}.ql-snow .ql-editor .ql-code-block-container{background-color:#23241f;color:#f8f8f2;overflow:visible}.ql-snow .ql-editor img{max-width:100%}.ql-snow .ql-picker{color:#444;display:inline-block;float:left;font-size:14px;font-weight:500;height:24px;position:relative;vertical-align:middle}.ql-snow .ql-picker-label{cursor:pointer;display:inline-block;height:100%;padding-left:8px;padding-right:2px;position:relative;width:100%}.ql-snow .ql-picker-label:before{display:inline-block;line-height:22px}.ql-snow .ql-picker-options{background-color:#fff;display:none;min-width:100%;padding:4px 8px;position:absolute;white-space:nowrap}.ql-snow .ql-picker-options .ql-picker-item{cursor:pointer;display:block;padding-bottom:5px;padding-top:5px}.ql-snow .ql-picker.ql-expanded .ql-picker-label{color:#ccc;z-index:2}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-fill{fill:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke{stroke:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-options{display:block;margin-top:-1px;top:100%;z-index:1}.ql-snow .ql-color-picker,.ql-snow .ql-icon-picker{width:28px}.ql-snow .ql-color-picker .ql-picker-label,.ql-snow .ql-icon-picker .ql-picker-label{padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-label svg,.ql-snow .ql-icon-picker .ql-picker-label svg{right:4px}.ql-snow .ql-icon-picker .ql-picker-options{padding:4px 0}.ql-snow .ql-icon-picker .ql-picker-item{height:24px;width:24px;padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-options{padding:3px 5px;width:152px}.ql-snow .ql-color-picker .ql-picker-item{border:1px solid transparent;float:left;height:16px;margin:2px;padding:0;width:16px}.ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg{position:absolute;margin-top:-9px;right:0;top:50%;width:18px}.ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=""]):before{content:attr(data-label)}.ql-snow .ql-picker.ql-header{width:98px}.ql-snow .ql-picker.ql-header .ql-picker-label:before,.ql-snow .ql-picker.ql-header .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{content:"Heading 1"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{content:"Heading 2"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{content:"Heading 3"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{content:"Heading 4"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{content:"Heading 5"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{content:"Heading 6"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{font-size:2em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{font-size:1.5em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{font-size:1.17em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{font-size:1em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{font-size:.83em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{font-size:.67em}.ql-snow .ql-picker.ql-font{width:108px}.ql-snow .ql-picker.ql-font .ql-picker-label:before,.ql-snow .ql-picker.ql-font .ql-picker-item:before{content:"Sans Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{content:"Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=monospace]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{content:"Monospace"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{font-family:Georgia,Times New Roman,serif}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{font-family:Monaco,Courier New,monospace}.ql-snow .ql-picker.ql-size{width:98px}.ql-snow .ql-picker.ql-size .ql-picker-label:before,.ql-snow .ql-picker.ql-size .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{content:"Small"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{content:"Large"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=huge]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{content:"Huge"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{font-size:10px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{font-size:18px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{font-size:32px}.ql-snow .ql-color-picker.ql-background .ql-picker-item{background-color:#fff}.ql-snow .ql-color-picker.ql-color .ql-picker-item{background-color:#000}.ql-code-block-container{position:relative}.ql-code-block-container .ql-ui{right:5px;top:5px}.ql-toolbar.ql-snow{border:1px solid #ccc;box-sizing:border-box;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;padding:8px}.ql-toolbar.ql-snow .ql-formats{margin-right:15px}.ql-toolbar.ql-snow .ql-picker-label{border:1px solid transparent}.ql-toolbar.ql-snow .ql-picker-options{border:1px solid transparent;box-shadow:#0003 0 2px 8px}.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label,.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options{border-color:#ccc}.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected,.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover{border-color:#000}.ql-toolbar.ql-snow+.ql-container.ql-snow{border-top:0}.ql-snow .ql-tooltip{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 5px #ddd;color:#444;padding:5px 12px;white-space:nowrap}.ql-snow .ql-tooltip:before{content:"Visit URL:";line-height:26px;margin-right:8px}.ql-snow .ql-tooltip input[type=text]{display:none;border:1px solid #ccc;font-size:13px;height:26px;margin:0;padding:3px 5px;width:170px}.ql-snow .ql-tooltip a.ql-preview{display:inline-block;max-width:200px;overflow-x:hidden;text-overflow:ellipsis;vertical-align:top}.ql-snow .ql-tooltip a.ql-action:after{border-right:1px solid #ccc;content:"Edit";margin-left:16px;padding-right:8px}.ql-snow .ql-tooltip a.ql-remove:before{content:"Remove";margin-left:8px}.ql-snow .ql-tooltip a{line-height:26px}.ql-snow .ql-tooltip.ql-editing a.ql-preview,.ql-snow .ql-tooltip.ql-editing a.ql-remove{display:none}.ql-snow .ql-tooltip.ql-editing input[type=text]{display:inline-block}.ql-snow .ql-tooltip.ql-editing a.ql-action:after{border-right:0;content:"Save";padding-right:0}.ql-snow .ql-tooltip[data-mode=link]:before{content:"Enter link:"}.ql-snow .ql-tooltip[data-mode=formula]:before{content:"Enter formula:"}.ql-snow .ql-tooltip[data-mode=video]:before{content:"Enter video:"}.ql-snow a{color:#06c}.ql-container.ql-snow{border:1px solid #ccc}.siswa-container{display:flex;flex-direction:column;min-height:100vh;background-color:#f4f6f9;font-family:Segoe UI,Arial,sans-serif}.siswa-header{background:linear-gradient(135deg,#1a7134,#10b981);color:#fff;display:flex;justify-content:space-between;align-items:center;padding:12px 16px;position:sticky;top:0;z-index:1001;box-shadow:0 2px 8px #00000026}.siswa-header-logo{display:flex;align-items:center;gap:10px}.siswa-header-logo h1{font-size:1rem;margin:0;font-weight:700;letter-spacing:.5px}.siswa-header-user{display:flex;align-items:center;gap:10px;font-size:.8rem}.siswa-header-user span{display:none}.siswa-logout-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.4);padding:6px 14px;border-radius:6px;cursor:pointer;font-size:.8rem;font-weight:600;display:flex;align-items:center;gap:5px;transition:background .2s}.siswa-logout-btn:hover{background:#ffffff59}.siswa-main{flex:1;padding:16px;display:flex;flex-direction:column;gap:16px;max-width:900px;width:100%;margin:0 auto;box-sizing:border-box}.siswa-grid-container{width:100%}.siswa-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.siswa-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px 12px;border-radius:12px;cursor:pointer;color:#fff;transition:transform .2s,box-shadow .2s;box-shadow:0 3px 10px #0000001f;min-height:100px}.siswa-card:hover{transform:translateY(-3px);box-shadow:0 6px 16px #0000002e}.siswa-card:active{transform:scale(.97)}.siswa-card-icon{margin-bottom:8px}.siswa-card-title{font-size:.8rem;font-weight:700;text-align:center;text-transform:uppercase;letter-spacing:.5px}.siswa-welcome-box{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #00000014;border:1px solid #e8e8e8}.siswa-welcome-header{background:linear-gradient(135deg,#1a7134,#10b981);color:#fff;padding:14px 16px;font-weight:700;font-size:.9rem;letter-spacing:.5px}.siswa-welcome-body{padding:16px}.siswa-alert{background-color:#f0fdf4;color:#166534;padding:14px 16px;border:1px solid #bbf7d0;border-radius:8px;font-size:.9rem;line-height:1.6}.siswa-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}.siswa-info-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:12px}.siswa-info-label{font-size:.7rem;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.siswa-info-value{font-weight:700;color:#1e293b;font-size:.85rem}.siswa-guide-box{background:#fffbeb;border:1px solid #fde68a;border-radius:8px;padding:14px;margin-top:14px}.siswa-guide-title{font-weight:700;color:#92400e;margin-bottom:8px;font-size:.85rem}.siswa-guide-list{margin:0;padding-left:18px;color:#78350f;line-height:1.8;font-size:.82rem}.siswa-table-box{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #00000014;border:1px solid #e8e8e8;width:100%}.siswa-table-header{background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff;padding:14px 16px;font-weight:700;font-size:.9rem}.siswa-table-body{padding:16px}.siswa-ujian-list{display:flex;flex-direction:column;gap:14px}.siswa-ujian-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:16px;box-shadow:0 1px 4px #0000000f;transition:box-shadow .2s}.siswa-ujian-card:hover{box-shadow:0 4px 12px #0000001a}.siswa-ujian-card-name{font-weight:700;font-size:.95rem;color:#1e293b;margin-bottom:8px}.siswa-ujian-card-info{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}.siswa-ujian-card-item{font-size:.78rem;color:#64748b}.siswa-ujian-card-item strong{color:#334155}.siswa-ujian-card-status{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:600}.siswa-ujian-card-status.selesai{background:#dcfce7;color:#166534}.siswa-ujian-card-status.belum{background:#fef3c7;color:#92400e}.siswa-ujian-card-action{margin-top:10px}.siswa-btn-ikuti{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px;background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:700;cursor:pointer;transition:opacity .2s}.siswa-btn-ikuti:hover{opacity:.9}.siswa-btn-ikuti:active{transform:scale(.98)}.siswa-btn-selesai-label{display:flex;align-items:center;justify-content:center;gap:6px;color:#16a34a;font-weight:700;font-size:.85rem;padding:10px;background:#f0fdf4;border-radius:8px;border:1px solid #bbf7d0}.siswa-konfirmasi-box{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #00000014;border:1px solid #e8e8e8;width:100%}.siswa-konfirmasi-header{background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff;padding:14px 16px;font-weight:700;font-size:.9rem;text-transform:uppercase}.siswa-konfirmasi-body{padding:16px}.siswa-konfirmasi-data{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.siswa-konfirmasi-row{display:flex;border-bottom:1px dashed #e5e7eb;padding-bottom:8px}.siswa-konfirmasi-label{width:90px;flex-shrink:0;font-size:.75rem;color:#94a3b8;text-transform:uppercase;font-weight:600;padding-top:2px}.siswa-konfirmasi-value{flex:1;font-weight:700;color:#1e293b;font-size:.9rem}.siswa-token-input{width:100%;padding:12px;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;text-align:center;font-weight:700;letter-spacing:2px;transition:border-color .2s;box-sizing:border-box}.siswa-token-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.siswa-konfirmasi-warning{background:#f0fdf4;color:#166534;padding:14px;border-radius:8px;margin-top:14px;border:1px solid #bbf7d0;text-align:center;font-weight:600;font-size:.85rem;line-height:1.6}.siswa-countdown-info{background:#fef2f2;color:#991b1b;padding:10px 14px;border-radius:8px;margin-top:12px;text-align:center;font-size:.85rem;border:1px solid #fecaca}.siswa-btn-mulai{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff;border:none;border-radius:10px;font-size:1.1rem;font-weight:700;cursor:pointer;margin-top:16px;transition:opacity .2s;box-shadow:0 4px 12px #16a34a4d}.siswa-btn-mulai:hover{opacity:.9}.siswa-btn-mulai:active{transform:scale(.98)}.siswa-btn-kembali{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px;background:#f1f5f9;color:#64748b;border:1px solid #e2e8f0;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;margin-top:10px}.siswa-footer{background-color:#fff;color:#64748b;text-align:center;padding:14px 16px;font-size:.75rem;border-top:1px solid #e5e7eb;margin-top:auto}.siswa-footer-title{font-weight:700;color:#334155;margin-bottom:3px;font-size:.8rem}.siswa-footer-time{color:#94a3b8;font-size:.7rem}.siswa-dashboard{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;touch-action:pan-x pan-y}.hamburger-nav-btn-soal{display:none!important}.img-responsive-soal{max-width:90%;height:auto;max-height:200px;border-radius:8px;box-shadow:0 2px 8px #0000001a;border:1px solid #f0f0f0;display:block;margin:8px 0;transition:transform .3s ease,box-shadow .3s ease;cursor:zoom-in}.img-responsive-soal:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.soal-image-wrapper{display:flex;justify-content:flex-start;align-items:center;width:100%;margin:8px 0}.lightbox-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000e6;display:flex;justify-content:center;align-items:center;z-index:9999;cursor:zoom-out;padding:20px}.lightbox-content{max-width:95%;max-height:95%;object-fit:contain;border-radius:8px;box-shadow:0 0 30px #00000080}.siswa-empty-state{text-align:center;padding:40px 20px;color:#94a3b8}.siswa-empty-state-icon{font-size:2.5rem;margin-bottom:10px}.siswa-empty-state-text{font-size:.9rem}@media screen and (max-width:768px){.siswa-header-logo h1{font-size:.9rem}.siswa-main{padding:12px;gap:12px}.siswa-grid{gap:10px}.siswa-card{min-height:85px;padding:16px 10px}.hamburger-nav-btn-soal{display:flex!important;align-items:center;justify-content:center;min-width:44px;min-height:44px;z-index:2000;pointer-events:auto!important}.ujian-layout-container{flex-direction:column!important}.hamburger-nav-btn{display:flex!important;align-items:center;justify-content:center;min-width:44px;min-height:44px;z-index:2000;pointer-events:auto!important}.navigasi-soal-panel{position:fixed!important;top:0;left:-260px;width:250px!important;height:100vh;background-color:#fff!important;z-index:3000!important;margin-top:0!important;transition:left .3s ease-in-out!important;display:block!important;border-right:1px solid #ddd;border-radius:0!important;box-shadow:4px 0 15px #00000026!important}.navigasi-soal-panel.nav-open{left:0!important}.nav-overlay{position:fixed;inset:0;background-color:#00000080;z-index:2999;display:none}.nav-overlay.show{display:block}.main-soal-panel{width:100%!important;order:1}.img-responsive-soal{max-height:150px;max-width:100%}.soal-content-area{padding:0!important}}@media screen and (min-width:769px){.siswa-header{padding:14px 24px}.siswa-header-logo h1{font-size:1.2rem}.siswa-header-user span{display:inline}.siswa-main{padding:24px;gap:20px}.siswa-grid{grid-template-columns:repeat(2,180px);justify-content:center;gap:16px}.siswa-card{min-height:120px;padding:24px 16px;border-radius:14px}.siswa-card-title{font-size:.85rem}.siswa-info-grid,.siswa-ujian-card-info{grid-template-columns:repeat(4,1fr)}.img-responsive-soal{max-height:220px;max-width:450px}.siswa-logout-btn{padding:8px 18px;font-size:.85rem}}
