@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap);@import url(https://fonts.googleapis.com/css2?family=Caveat:wght@600&display=swap);:root{--primary:#009a3e;--primary-dark:#007a31;--primary-light:#dff5e7;--primary-50:#f0faf3;--green:#16a34a;--green-light:#dff5e7;--red:#dc2626;--red-light:#fdecec;--orange:#f59e0b;--orange-light:#fff4db;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--white:#fff;--shadow-sm:0 1px 2px #0000000d;--shadow:0 2px 6px #009a3e14;--shadow-md:0 4px 12px #009a3e1a;--shadow-lg:0 8px 24px #009a3e1f;--radius:12px;--radius-sm:8px;--radius-xs:6px;--sidebar-w:260px;--topbar-h:56px;--transition:all 0.2s cubic-bezier(0.2,0,0,1)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background:#f8fafc;background:var(--gray-50);color:#0f172a;color:var(--gray-900);font-family:Inter,-apple-system,sans-serif}a{color:#009a3e;color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}code{background:#f1f5f9;background:var(--gray-100);border-radius:3px;font-size:.85em;padding:1px 5px}img{max-width:100%}.app-loading,.loading{align-items:center;color:#64748b;color:var(--gray-500);display:flex;font-size:.9rem;justify-content:center;min-height:60vh}.app-layout,.app-loading{min-height:100vh}.app-layout,.sidebar{display:flex}.sidebar{background:#fff;background:var(--white);border-right:1px solid #e2e8f0;border-right:1px solid var(--gray-200);bottom:0;flex-direction:column;left:0;overflow-y:auto;position:fixed;top:0;width:260px;width:var(--sidebar-w);z-index:100}.sidebar-overlay{display:none}.sidebar-header{align-items:center;border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--gray-100);display:flex;gap:10px;padding:14px 16px}.sidebar-logo-img{border-radius:8px;flex-shrink:0;height:32px;object-fit:cover;width:32px}.sidebar-logo-text{flex:1 1;min-width:0}.sidebar-logo-title{color:#0f172a;color:var(--gray-900);display:block;font-size:.9rem;font-weight:700;line-height:1.3}.sidebar-logo-sub{display:block;font-size:.65rem}.sidebar-close,.sidebar-logo-sub{color:#64748b;color:var(--gray-500)}.sidebar-close{background:none;border:none;border-radius:6px;cursor:pointer;display:none;padding:4px}.sidebar-close:hover{background:#f1f5f9;background:var(--gray-100);color:#334155;color:var(--gray-700)}.sidebar-badge{align-items:center;background:#dff5e7;background:var(--primary-light);border-radius:20px;color:#009a3e;color:var(--primary);display:inline-flex;font-size:.65rem;font-weight:600;gap:4px;padding:2px 10px}.sidebar-pokja-info{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--gray-100);color:#475569;color:var(--gray-600);font-size:.78rem;padding:10px 16px}.sidebar-pokja-info strong{color:#0f172a;color:var(--gray-900);display:block;margin-bottom:2px}.sidebar-nav{flex:1 1;padding:6px 10px}.sidebar-section-label{color:#64748b;color:var(--gray-500);font-size:.65rem;font-weight:600;letter-spacing:.04em;padding:10px 12px 4px;text-transform:uppercase}.sidebar-item{align-items:center;background:none;border:none;border-radius:6px;border-radius:var(--radius-xs);color:#334155;color:var(--gray-700);cursor:pointer;display:flex;font-family:inherit;font-size:.82rem;font-weight:500;gap:8px;margin-bottom:1px;padding:8px 10px;text-align:left;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition);width:100%}.sidebar-item:hover{background:#f1f5f9;background:var(--gray-100);color:#0f172a;color:var(--gray-900)}.sidebar-item.active{background:#dff5e7;background:var(--primary-light);color:#009a3e;color:var(--primary);font-weight:600}.sidebar-item-icon{align-items:center;display:flex;flex-shrink:0;justify-content:center;width:20px}.sidebar-item-count{background:#f1f5f9;background:var(--gray-100);border-radius:10px;color:#475569;color:var(--gray-600);font-size:.65rem;font-weight:600;margin-left:auto;padding:1px 7px}.sidebar-item.active .sidebar-item-count{background:#009a3e;background:var(--primary);color:#fff}.sidebar-footer{align-items:center;border-top:1px solid #f1f5f9;border-top:1px solid var(--gray-100);color:#94a3b8;color:var(--gray-400);display:flex;font-size:.7rem;gap:4px;justify-content:center;padding:12px 16px;text-align:center}.footer-heart{color:#009a3e;color:var(--primary)}.app-main{flex:1 1;margin-left:260px;margin-left:var(--sidebar-w);min-height:100vh}.topbar{align-items:center;background:#fff;background:var(--white);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--gray-200);display:flex;gap:12px;height:56px;height:var(--topbar-h);padding:0 20px;position:-webkit-sticky;position:sticky;top:0;z-index:50}.hamburger{background:none;border:none;border-radius:6px;color:#475569;color:var(--gray-600);cursor:pointer;display:none;padding:6px}.hamburger:hover{background:#f1f5f9;background:var(--gray-100)}.topbar-title{color:#0f172a;color:var(--gray-900);flex:1 1;font-size:1rem;font-weight:700}.topbar-user-dropdown{display:inline-block;position:relative}.topbar-user-dropdown summary{align-items:center;cursor:pointer;display:flex;gap:8px;list-style:none}.topbar-user-dropdown summary::-webkit-details-marker{display:none}.topbar-user-avatar{align-items:center;background:#dff5e7;background:var(--primary-light);border-radius:50%;color:#009a3e;color:var(--primary);display:flex;flex-shrink:0;font-size:.8rem;font-weight:700;height:30px;justify-content:center;width:30px}.topbar-dropdown-menu{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--radius-sm);box-shadow:0 4px 12px #009a3e1a;box-shadow:var(--shadow-md);margin-top:6px;min-width:150px;padding:6px 0;position:absolute;right:0;top:100%;z-index:100}.topbar-dropdown-item{background:#0000;border:none;color:#334155;color:var(--gray-700);cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:500;padding:8px 14px;text-align:left;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition);width:100%}.topbar-dropdown-item:hover{background:#f8fafc;background:var(--gray-50);color:#009a3e;color:var(--primary)}.content-area{max-width:1200px;padding:20px}.card{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);padding:16px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.card:hover{box-shadow:0 2px 6px #009a3e14;box-shadow:var(--shadow)}.card-hover:hover{box-shadow:0 4px 12px #009a3e1a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-stat{border-bottom:3px solid #009a3e;border-bottom:3px solid var(--primary)}.card-glass{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(135deg,#fff,#f0faf3);background:linear-gradient(135deg,#fff,var(--primary-50));border:1px solid #fffc}.btn{align-items:center;border:none;border-radius:6px;border-radius:var(--radius-xs);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.85rem;font-weight:600;gap:6px;line-height:1.4;padding:9px 18px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.btn:hover{filter:brightness(.95)}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:#009a3e;background:var(--primary);color:#fff}.btn-primary:hover{background:#007a31;background:var(--primary-dark)}.btn-secondary{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);color:#334155;color:var(--gray-700)}.btn-secondary:hover{background:#f8fafc;background:var(--gray-50);border-color:#cbd5e1;border-color:var(--gray-300)}.btn-ghost{background:#0000;color:#475569;color:var(--gray-600)}.btn-ghost:hover{background:#f1f5f9;background:var(--gray-100)}.btn-danger{background:#dc2626;background:var(--red);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-sm{font-size:.78rem;padding:6px 12px}.btn-full{justify-content:center;width:100%}.badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.68rem;font-weight:600;gap:4px;line-height:1;padding:3px 10px}.badge-success{background:#e3f6ea;color:#1f7a3a}.badge-warning{background:#fef9c3;color:#854d0e}.badge-danger{background:#fde8e8;color:#b91c1c}.badge-info{background:#dff5e7;background:var(--primary-light);color:#007a31;color:var(--primary-dark)}.badge-muted{background:#eef2f7;color:#64748b}.form-group{margin-bottom:14px}.form-label{color:#475569;color:var(--gray-600);display:block;font-size:.78rem;font-weight:600;margin-bottom:4px}.form-input,.form-select,.form-textarea{background:#fff;background:var(--white);border:1.5px solid #e2e8f0;border:1.5px solid var(--gray-200);border-radius:6px;border-radius:var(--radius-xs);font-family:inherit;font-size:.85rem;padding:9px 12px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition);width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#009a3e;border-color:var(--primary);box-shadow:0 0 0 2px #dff5e7;box-shadow:0 0 0 2px var(--primary-light);outline:none}.form-textarea{min-height:60px;resize:vertical}.form-hint{color:#64748b;color:var(--gray-500);font-size:.72rem;margin-top:3px}.form-error{background:#fdecec;background:var(--red-light);border-left:3px solid #dc2626;border-left:3px solid var(--red);border-radius:6px;border-radius:var(--radius-xs);color:#dc2626;color:var(--red);font-size:.8rem;margin-bottom:12px;padding:8px 12px}.table-wrap{max-width:100%;overflow-x:auto}.table{border-collapse:collapse;font-size:.82rem;width:100%}.table thead{background:#f8fafc;background:var(--gray-50)}.table th{color:#475569;color:var(--gray-600);font-size:.72rem;font-weight:600;letter-spacing:.02em;padding:9px 14px;text-align:left;text-transform:uppercase;white-space:nowrap}.table td,.table th{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--gray-200)}.table td{color:#1e293b;color:var(--gray-800);padding:10px 14px}.table tbody tr{transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.table tbody tr:hover{background:#f0faf3;background:var(--primary-50)}.table tbody tr:last-child td{border-bottom:none}.modal-overlay{align-items:center;animation:fadeIn .15s ease-out;background:#00000073;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:999}.modal-card{animation:slideUp .2s ease-out;background:#fff;background:var(--white);border-radius:16px;box-shadow:0 8px 24px #009a3e1f;box-shadow:var(--shadow-lg);max-height:85vh;max-width:420px;overflow-y:auto;padding:24px;width:100%}.modal-card h3{font-size:1rem;font-weight:700;margin-bottom:4px}.modal-card p{color:#64748b;color:var(--gray-500);font-size:.82rem;margin-bottom:16px}.modal-actions{display:flex;gap:8px;margin-top:12px}.modal-actions .btn{flex:1 1;justify-content:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.toast-container{display:flex;flex-direction:column;gap:6px;pointer-events:none;position:fixed;right:12px;top:12px;z-index:10000}.toast{align-items:center;animation:toastIn .25s ease-out;background:#fff;background:var(--white);border-left:4px solid #94a3b8;border-left:4px solid var(--gray-400);border-radius:10px;box-shadow:0 4px 16px #0000001a;color:#1e293b;color:var(--gray-800);display:flex;font-size:.85rem;font-weight:500;gap:8px;max-width:380px;padding:10px 16px;pointer-events:auto}.toast--success{border-left-color:#16a34a;border-left-color:var(--green)}.toast--error{border-left-color:#dc2626;border-left-color:var(--red)}.toast--warning{border-left-color:#f59e0b;border-left-color:var(--orange)}.toast--info{border-left-color:#009a3e;border-left-color:var(--primary)}.toast-message{flex:1 1}@keyframes toastIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.progress-bar{background:#f1f5f9;background:var(--gray-100);border-radius:4px;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#009a3e,#34d399);background:linear-gradient(90deg,var(--primary),#34d399);border-radius:4px;height:100%;transition:width .5s ease}.timeline{padding-left:44px;position:relative}.timeline:before{background:#e2e8f0;background:var(--gray-200);bottom:20px;content:"";left:16px;position:absolute;top:20px;width:2px}.timeline-step{margin-bottom:16px;position:relative}.timeline-step:last-child{margin-bottom:0}.timeline-dot{align-items:center;background:#fff;background:var(--white);border:2px solid #cbd5e1;border:2px solid var(--gray-300);border-radius:50%;box-shadow:0 0 0 3px #f8fafc;box-shadow:0 0 0 3px var(--gray-50);color:#64748b;color:var(--gray-500);display:flex;font-size:.75rem;height:34px;justify-content:center;left:-44px;position:absolute;top:2px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition);width:34px;z-index:2}.timeline-step.completed .timeline-dot{background:#16a34a;background:var(--green);border-color:#16a34a;border-color:var(--green);box-shadow:0 0 0 3px #dff5e7;box-shadow:0 0 0 3px var(--green-light);color:#fff}.timeline-step.current .timeline-dot{background:#009a3e;background:var(--primary);border-color:#009a3e;border-color:var(--primary);box-shadow:0 0 0 3px #dff5e7;box-shadow:0 0 0 3px var(--primary-light);color:#fff}.timeline-step.locked .timeline-dot{background:#f1f5f9;background:var(--gray-100);border-color:#cbd5e1;border-color:var(--gray-300);color:#94a3b8;color:var(--gray-400)}.timeline-body{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);padding:14px 16px}.timeline-step.current .timeline-body{border-color:#dff5e7;border-color:var(--primary-light);box-shadow:0 0 0 2px #dff5e7;box-shadow:0 0 0 2px var(--primary-light)}.timeline-step.locked .timeline-body{opacity:.6}.timeline-body h4{font-size:.9rem;font-weight:700;margin-bottom:6px}.timeline-body p{color:#334155;color:var(--gray-700);font-size:.82rem;line-height:1.5;margin-bottom:6px}.step-btn-group{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.step-btn-group-vertical{align-items:flex-start;flex-direction:column;gap:8px}.level-badge{align-items:center;border:1px solid;border-radius:20px;display:inline-flex;font-size:.78rem;font-weight:700;gap:4px;margin-left:4px;padding:3px 10px}.login-page{align-items:center;background:linear-gradient(135deg,#f0f9ff,#f8fafc);display:flex;justify-content:center;min-height:100vh;padding:20px;position:relative}.login-bg-shapes{inset:0;overflow:hidden;pointer-events:none;position:absolute;z-index:0}.login-bg-shapes span{border-radius:50%;opacity:.08;position:absolute}.login-bg-shapes .s1{background:radial-gradient(circle,#0ea5e9,#0000 70%);height:500px;right:-100px;top:-200px;width:500px}.login-bg-shapes .s2{background:radial-gradient(circle,#10b981,#0000 70%);bottom:-120px;height:350px;left:-80px;width:350px}.login-card{animation:slideUp .3s ease-out;background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:20px;box-shadow:0 8px 30px #0000000f;max-width:380px;padding:28px 28px 24px;position:relative;width:100%;z-index:1}.login-logo{margin-bottom:22px;text-align:center}.login-logo-img{border-radius:14px;box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);height:56px;margin-bottom:10px;object-fit:cover;width:56px}.login-logo h1{font-size:1.3rem;font-weight:700;margin-bottom:2px}.login-logo p{color:#64748b;color:var(--gray-500);font-size:.8rem}.login-field{margin-bottom:14px}.login-field label{color:#334155;color:var(--gray-700);display:block;font-size:.8rem;font-weight:600;margin-bottom:5px}.login-field input{background:#f8fafc;background:var(--gray-50);border:1.5px solid #e2e8f0;border:1.5px solid var(--gray-200);border-radius:6px;border-radius:var(--radius-xs);font-family:inherit;font-size:.9rem;padding:10px 12px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition);width:100%}.login-field input:focus{background:#fff;background:var(--white);border-color:#009a3e;border-color:var(--primary);box-shadow:0 0 0 3px #dff5e7;box-shadow:0 0 0 3px var(--primary-light);outline:none}.login-btn{background:#009a3e;background:var(--primary);border:none;border-radius:6px;border-radius:var(--radius-xs);color:#fff;cursor:pointer;font-family:inherit;font-size:.9rem;font-weight:600;padding:11px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition);width:100%}.login-btn:hover{background:#007a31;background:var(--primary-dark)}.login-btn:disabled{cursor:not-allowed;opacity:.6}.login-error{background:#fdecec;background:var(--red-light);border-left:3px solid #dc2626;border-left:3px solid var(--red);border-radius:6px;border-radius:var(--radius-xs);color:#dc2626;color:var(--red);font-size:.8rem;margin-bottom:12px;padding:8px 12px}.login-quick{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--gray-200);margin-bottom:18px;padding-bottom:16px}.login-quick-label{color:#64748b;color:var(--gray-500);font-size:.7rem;font-weight:600;letter-spacing:.04em;margin-bottom:8px;text-align:center;text-transform:uppercase}.login-quick-grid{display:flex;gap:6px}.login-quick-btn{align-items:center;background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:6px;border-radius:var(--radius-xs);color:#334155;color:var(--gray-700);cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-family:inherit;font-size:.65rem;font-weight:600;gap:3px;padding:8px 4px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.login-quick-btn:hover{background:#f8fafc;background:var(--btn-bg,var(--gray-50));border-color:#cbd5e1;border-color:var(--btn-color,var(--gray-300));color:#0f172a;color:var(--btn-color,var(--gray-900))}.login-quick-btn:disabled{cursor:not-allowed;opacity:.5}.dashboard-welcome{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:20px}.dashboard-greeting{font-size:1.2rem;font-weight:700}.dashboard-subtitle{color:#64748b;color:var(--gray-500);font-size:.82rem}.dashboard-badge{align-items:center;background:#dff5e7;background:var(--primary-light);border-radius:12px;display:flex;flex-direction:column;flex-shrink:0;padding:6px 14px}.badge-progress{font-size:1.1rem;font-weight:700;line-height:1}.badge-label,.badge-progress{color:#009a3e;color:var(--primary)}.badge-label{font-size:.65rem;letter-spacing:1px;margin-top:2px;opacity:.7;text-transform:uppercase}.stats-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-bottom:20px}.stat-card{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);padding:16px}.stat-card:hover{box-shadow:0 2px 6px #009a3e14;box-shadow:var(--shadow)}.stat-icon{align-items:center;background:#dff5e7;background:var(--primary-light);border-radius:10px;color:#007a31;color:var(--primary-dark);display:flex;height:36px;justify-content:center;margin-bottom:10px;width:36px}.stat-icon-green{background:#dff5e7!important;background:var(--green-light)!important;color:var(--green-dark)!important}.stat-icon-orange{background:#fff4db!important;background:var(--orange-light)!important;color:#f59e0b!important;color:var(--orange)!important}.stat-number{color:#0f172a;color:var(--gray-900);display:block;font-size:1.5rem;font-weight:800;line-height:1.2}.stat-label{color:#64748b;color:var(--gray-500);display:block;font-size:.75rem;font-weight:500;margin-top:3px}.page-header{margin-bottom:16px}.page-title{font-size:1.2rem;font-weight:700}.page-subtitle{color:#64748b;color:var(--gray-500);font-size:.82rem;margin-top:2px}.kelas-tabs{display:flex;gap:8px;margin-bottom:20px;overflow-x:auto;padding-bottom:4px}.kelas-tab-btn{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:20px;color:#475569;color:var(--gray-600);cursor:pointer;font-family:inherit;font-size:.82rem;font-weight:500;padding:7px 14px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition);white-space:nowrap}.kelas-tab-btn:hover{background:#f8fafc;background:var(--gray-50);color:#009a3e;color:var(--primary)}.kelas-tab-btn.active{background:#009a3e;background:var(--primary);border-color:#009a3e;border-color:var(--primary);color:#fff}.kelas-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.kelas-card{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);cursor:pointer;padding:16px;position:relative;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.kelas-card:hover{border-color:#dff5e7;border-color:var(--primary-light);box-shadow:0 4px 12px #009a3e1a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.kelas-card-done{filter:grayscale(20%);opacity:.7}.kelas-card-header{align-items:flex-start;display:flex;gap:8px;justify-content:space-between;margin-bottom:10px}.kelas-card-header h4{flex:1 1;font-size:.92rem;font-weight:700;margin:0}.kelas-mini-progress{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.mini-step{background:#f1f5f9;background:var(--gray-100);border-radius:20px;color:#64748b;color:var(--gray-500);font-size:.65rem;font-weight:500;padding:3px 8px}.mini-step[data-done=true]{background:#e3f6ea;color:#1f7a3a}.kelas-empty{background:#fff;background:var(--white);border:1px dashed #cbd5e1;border:1px dashed var(--gray-300);border-radius:12px;border-radius:var(--radius);color:#64748b;color:var(--gray-500);font-size:.85rem;padding:24px;text-align:center}.kelas-sections{display:flex;flex-direction:column;gap:28px}.kelas-section-title{color:#1e293b;color:var(--gray-800);font-size:.95rem;font-weight:700;margin-bottom:12px}.detail-header{align-items:center;display:flex;gap:12px;padding:12px 0}.detail-header h2{font-size:1.05rem;font-weight:700}.back-btn{align-items:center;background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:6px;border-radius:var(--radius-xs);color:#334155;color:var(--gray-700);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.82rem;font-weight:500;gap:4px;padding:6px 10px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.back-btn:hover{background:#f0faf3;background:var(--primary-50);border-color:#dff5e7;border-color:var(--primary-light)}.pokja-status-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr);margin-bottom:16px}.pokja-status-label{color:#64748b;color:var(--gray-500);display:block;font-size:.72rem;margin-bottom:4px}.pokja-header{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:14px}.pokja-title{font-size:.92rem;font-weight:700;margin:0}.pokja-actions{display:flex;flex-wrap:wrap;gap:8px}.pokja-body{color:#1e293b;color:var(--gray-800);font-size:.88rem;line-height:1.6}.pokja-body iframe,.pokja-body img,.pokja-body video{border-radius:8px;border-radius:var(--radius-sm);max-width:100%}.pokja-download-btn{align-items:center;background:#009a3e;background:var(--primary);border-radius:6px;border-radius:var(--radius-xs);color:#fff;display:inline-flex;font-size:.82rem;font-weight:600;gap:6px;margin-top:14px;padding:8px 14px;text-decoration:none}.pokja-download-btn:hover{filter:brightness(.95);text-decoration:none}.step-link-btn{align-items:center;background:#dff5e7;background:var(--primary-light);border-radius:6px;border-radius:var(--radius-xs);color:#009a3e;color:var(--primary);display:inline-flex;font-size:.8rem;font-weight:600;gap:6px;padding:7px 14px;text-decoration:none}.step-confirm-btn,.step-link-btn:hover{background:#009a3e;background:var(--primary);color:#fff}.step-confirm-btn{border:none;border-radius:6px;border-radius:var(--radius-xs);cursor:pointer;display:inline-block;font-family:inherit;font-size:.8rem;font-weight:600;padding:7px 16px}.step-confirm-btn:hover{background:#007a31;background:var(--primary-dark)}.step-visit-btn{align-items:center;background:#f1f5f9;background:var(--gray-100);border:none;border-radius:6px;border-radius:var(--radius-xs);color:#334155;color:var(--gray-700);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.8rem;font-weight:500;gap:6px;padding:7px 14px}.step-visit-btn:hover{background:#f0faf3;background:var(--primary-50)}.step-start-btn{background:#009a3e;background:var(--primary);border:none;border-radius:6px;border-radius:var(--radius-xs);color:#fff;cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:600;padding:9px 20px}.step-start-btn:hover{background:#007a31;background:var(--primary-dark)}.test-passed{color:#237341}.test-failed,.test-passed{font-size:1rem;font-weight:700}.test-failed{color:#dc2626;color:var(--red)}.test-page{margin:0 auto;max-width:720px;padding-bottom:80px}.test-header{background:#fff;background:var(--white);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--gray-200);margin-bottom:16px;padding:14px 0}.test-title{flex-wrap:wrap;font-size:1rem;font-weight:700;gap:8px}.test-timer-row,.test-title{align-items:center;display:flex}.test-timer-row{gap:16px;margin-top:8px}.test-timer{font-feature-settings:"tnum";align-items:center;background:#f8fafc;background:var(--gray-50);border-radius:8px;color:#1e293b;color:var(--gray-800);display:flex;font-size:.85rem;font-variant-numeric:tabular-nums;font-weight:700;gap:5px;padding:3px 10px}.test-timer.urgent{animation:pulse 1s infinite;background:#fdecec;background:var(--red-light);color:#dc2626;color:var(--red)}.test-progress-text{color:#64748b;color:var(--gray-500);font-size:.78rem;font-weight:500}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.question-card{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);display:flex;gap:12px;margin-bottom:12px;padding:16px}.question-number{color:#009a3e;color:var(--primary);flex-shrink:0;font-size:.82rem;font-weight:700;text-align:center;width:24px}.question-text{color:#1e293b;color:var(--gray-800);font-size:.88rem;line-height:1.5;margin-bottom:10px}.question-options{display:flex;flex-direction:column;gap:6px}.option-label{align-items:center;border:1.5px solid #e2e8f0;border:1.5px solid var(--gray-200);border-radius:6px;border-radius:var(--radius-xs);color:#334155;color:var(--gray-700);cursor:pointer;display:flex;font-size:.85rem;gap:8px;padding:8px 12px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.option-label:hover{background:#f0faf3;background:var(--primary-50)}.option-label.selected,.option-label:hover{border-color:#009a3e;border-color:var(--primary)}.option-label.selected{background:#dff5e7;background:var(--primary-light);color:#0f172a;color:var(--gray-900)}.option-label input{display:none}.option-letter{align-items:center;background:#f1f5f9;background:var(--gray-100);border-radius:50%;color:#475569;color:var(--gray-600);display:flex;flex-shrink:0;font-size:.7rem;font-weight:700;height:24px;justify-content:center;width:24px}.option-label.selected .option-letter{background:#009a3e;background:var(--primary);color:#fff}.test-footer{background:#fff;background:var(--white);border-top:1px solid #e2e8f0;border-top:1px solid var(--gray-200);bottom:0;gap:10px;left:260px;left:var(--sidebar-w);padding:12px 20px;position:fixed;right:0;z-index:20}.test-footer,.test-result{display:flex;justify-content:center}.test-result{align-items:center;min-height:70vh;padding:20px}.result-card{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:20px;box-shadow:0 8px 24px #009a3e1f;box-shadow:var(--shadow-lg);max-width:340px;padding:40px 32px;text-align:center;width:100%}.result-card.passed{border-top:4px solid #16a34a;border-top:4px solid var(--green)}.result-card.failed{border-top:4px solid #dc2626;border-top:4px solid var(--red)}.result-icon{font-size:3rem}.result-card h2{font-size:1.2rem;font-weight:700;margin:10px 0 6px}.result-card.passed h2{color:var(--green-dark)}.result-card.failed h2{color:#dc2626;color:var(--red)}.result-score{font-size:4rem;font-weight:800;line-height:1}.result-card.passed .result-score{color:#16a34a;color:var(--green)}.result-card.failed .result-score{color:#dc2626;color:var(--red)}.result-detail{color:#64748b;color:var(--gray-500);font-size:.82rem;margin-top:6px}.result-btn{background:#009a3e;background:var(--primary);border:none;border-radius:6px;border-radius:var(--radius-xs);color:#fff;cursor:pointer;font-family:inherit;font-size:.9rem;font-weight:600;margin-top:20px;padding:10px 32px}.result-btn:hover{background:#007a31;background:var(--primary-dark)}.attempt-badge{background:#dff5e7;background:var(--primary-light);color:#007a31;color:var(--primary-dark)}.attempt-badge,.passing-badge{border-radius:20px;font-size:.68rem;font-weight:600;padding:2px 8px}.passing-badge{background:#e8f2ec;color:#2d6f45}.test-score-badge{align-items:center;border-radius:50%;display:inline-flex;font-size:.8rem;font-weight:800;height:32px;justify-content:center;width:32px}.test-score-badge.pass{background:#dff5e7;background:var(--primary-light);color:#007a31;color:var(--primary-dark)}.test-score-badge.fail{background:#fdecec;background:var(--red-light);color:#dc2626;color:var(--red)}.warning-overlay{align-items:center;animation:fadeIn .15s ease-out;background:#0006;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1000}.warning-card{animation:slideUp .2s ease-out;background:#fff;background:var(--white);border-radius:16px;box-shadow:0 20px 60px #0000001f;max-width:400px;padding:24px 22px 20px;text-align:center;width:100%}.warning-icon{align-items:center;background:#fff4db;background:var(--orange-light);border-radius:50%;color:#f59e0b;color:var(--orange);display:flex;font-size:1.2rem;font-weight:800;height:40px;justify-content:center;margin:0 auto 12px;width:40px}.warning-card h3{font-size:.95rem;font-weight:800;margin-bottom:4px}.warning-card p{color:#475569;color:var(--gray-600);font-size:.84rem;line-height:1.4}.warning-sub{color:#64748b;color:var(--gray-500);font-size:.78rem;margin-top:4px}.warning-actions{display:flex;flex-direction:column;gap:8px;margin-top:16px}.warning-btn-primary{background:#dc2626;background:var(--red);border:none;border-radius:10px;color:#fff;cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:700;padding:10px 20px}.warning-btn-primary:hover{background:#b91c1c}.warning-btn-secondary{background:#0000;border:none;border-radius:10px;color:#475569;color:var(--gray-600);cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:600;padding:10px 20px}.warning-btn-secondary:hover{background:#f1f5f9;background:var(--gray-100)}.id-card-wrapper{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:24px;box-shadow:0 10px 30px #00000014;margin:0 auto 20px;max-width:360px;overflow:hidden;position:relative}.id-card-header{align-items:flex-start;background:linear-gradient(135deg,#009a3e,#007a31);background:linear-gradient(135deg,var(--primary),var(--primary-dark));display:flex;height:130px;justify-content:center;padding-top:20px;position:relative}.id-card-watermark{left:50%;opacity:.04;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:200px}.id-card-body{margin-top:-60px;padding:0 20px 24px;text-align:center}.id-card-avatar-wrap{background:#fff;background:var(--white);border-radius:50%;box-shadow:0 8px 20px #0000001f;cursor:pointer;height:120px;margin:0 auto 10px;padding:5px;position:relative;width:120px;z-index:2}.id-card-avatar{background:#dff5e7;background:var(--primary-light);color:#009a3e;color:var(--primary);font-size:2.5rem;font-weight:800;height:100%;overflow:hidden;width:100%}.avatar-check-badge,.id-card-avatar{align-items:center;border-radius:50%;display:flex;justify-content:center}.avatar-check-badge{background:#16a34a;background:var(--green);border:3px solid #fff;bottom:2px;height:28px;position:absolute;right:8px;width:28px}.id-card-name{font-size:1.4rem;font-weight:900;margin-bottom:6px}.id-card-nip{background:#dff5e7;background:var(--primary-light);border-radius:20px;color:#009a3e;color:var(--primary);display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:1px;margin-bottom:10px;padding:3px 12px}.id-card-subtitle{color:#64748b;color:var(--gray-500);font-size:.7rem;font-weight:700;letter-spacing:2px;margin-bottom:12px;text-transform:uppercase}.id-card-details{background:#f8fafc;background:var(--gray-50);border-radius:16px;padding:14px 16px}.id-card-row{align-items:center;border-bottom:1px dashed #e2e8f0;border-bottom:1px dashed var(--gray-200);display:flex;gap:12px;padding:7px 0}.id-card-row:last-child{border-bottom:none}.id-card-icon{align-items:center;background:#009a3e;background:var(--primary);border-radius:50%;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.id-card-text{align-items:flex-start;display:flex;flex-direction:column;text-align:left}.id-card-text .label{color:#94a3b8;color:var(--gray-400);font-size:.6rem;font-weight:700;letter-spacing:.5px}.id-card-text .value{color:#1e293b;color:var(--gray-800);font-size:.85rem;font-weight:700}.id-card-signature{color:#009a3e;color:var(--primary);font-family:Caveat,cursive;font-size:1.2rem}.btn-download-id{align-items:center;background:#009a3e;background:var(--primary);border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:8px;justify-content:center;margin:0 auto;max-width:360px;padding:11px 20px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition);width:100%}.btn-download-id:hover{background:#007a31;background:var(--primary-dark)}.certificate-wrapper{align-items:center;display:flex;flex-direction:column;overflow-x:auto;padding-bottom:16px;width:100%}.certificate-preview{background:#fff;height:1123px;margin:0 auto;min-width:794px;position:relative;width:794px}.cert-border-outer{height:100%;padding:24px;width:100%}.cert-border-inner{align-items:center;border:10px solid #007a31;border:10px solid var(--primary-dark);display:flex;flex-direction:column;height:100%;outline:3px solid #dff5e7;outline:3px solid var(--primary-light);outline-offset:-14px;overflow:hidden;padding:48px 40px;position:relative}.cert-watermark-img{left:50%;opacity:.05;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:350px}.cert-header{align-items:center;display:flex;flex-direction:column;gap:12px;margin-bottom:16px;text-align:center;width:100%;z-index:2}.cert-logo{height:80px;object-fit:contain;width:80px}.cert-institution{color:#334155;color:var(--gray-700);font-size:.85rem;font-weight:700;letter-spacing:2px;text-transform:uppercase}.cert-title{color:#007a31;color:var(--primary-dark);font-size:1.8rem;font-weight:800;letter-spacing:4px;text-transform:uppercase}.cert-divider{background:#009a3e;background:var(--primary);height:3px;margin:20px auto;width:100px;z-index:2}.cert-body{flex:1 1;margin:16px 0;text-align:center;z-index:2}.cert-name{color:#0f172a;color:var(--gray-900);font-family:Georgia,serif;font-size:2.4rem;font-weight:700;text-decoration:underline;-webkit-text-decoration-color:#dff5e7;text-decoration-color:#dff5e7;-webkit-text-decoration-color:var(--primary-light);text-decoration-color:var(--primary-light);text-underline-offset:6px}.cert-description{color:#334155;color:var(--gray-700);font-size:1rem;line-height:1.6;margin:0 auto;max-width:500px}.cert-footer{align-items:flex-end;display:flex;justify-content:space-between;margin-top:auto;padding-top:30px;width:100%;z-index:2}.cert-serial-number{color:#475569;color:var(--gray-600);font-size:.85rem;font-weight:600}.cert-signature-line{background:#0f172a;background:var(--gray-900);height:1px;margin-bottom:6px;width:180px}.cert-signature-label{color:#1e293b;color:var(--gray-800);font-size:.85rem;font-weight:700}.test-score-table-wrap{max-width:100%;overflow-x:auto}.test-score-table{min-width:700px}.test-score-table td,.test-score-table th{text-align:center;vertical-align:middle}.test-score-table td:first-child,.test-score-table th:first-child{min-width:200px;text-align:left;width:200px}.superadmin-layout{display:flex;min-height:100vh}.sa-sidebar{composes:sidebar}.sa-sidebar.open{transform:translateX(0)}.sa-sidebar-overlay{background:#0000004d;display:none;inset:0;position:fixed;z-index:99}.sa-main{flex:1 1;margin-left:260px;margin-left:var(--sidebar-w);min-height:100vh;min-width:0}.sa-topbar{composes:topbar}.sa-topbar h1{flex:1 1;font-size:1rem;font-weight:700}.sa-topbar-user{align-items:center;color:#475569;color:var(--gray-600);display:flex;font-size:.82rem;gap:10px}.sa-content{padding:20px}.sa-stats-grid{grid-gap:14px;gap:14px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.sa-charts-grid,.sa-stats-grid{display:grid;margin-bottom:20px}.sa-charts-grid{grid-gap:16px;gap:16px;grid-template-columns:1fr 1fr}.sa-section-card{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);margin-bottom:20px;padding:20px}.sa-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:14px}.sa-section-header h3{align-items:center;display:flex;font-size:.95rem;font-weight:700;gap:6px}.sa-count{background:#f1f5f9;background:var(--gray-100);border-radius:20px;color:#64748b;color:var(--gray-500);font-size:.75rem;font-weight:500;padding:2px 10px}.sa-table-header{align-items:center;display:flex;justify-content:space-between;padding:14px 20px 0}.sa-table-header h3{font-size:.95rem;font-weight:700}.sa-table-wrap{max-width:100%;overflow-x:auto;padding:0}.sa-table{border-collapse:collapse;font-size:.8rem;width:100%}.sa-table th{background:#f8fafc;background:var(--gray-50);color:#475569;color:var(--gray-600);font-size:.72rem;font-weight:600;letter-spacing:.02em;padding:8px 14px;text-align:left;text-transform:uppercase;white-space:nowrap}.sa-table td,.sa-table th{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--gray-200)}.sa-table td{color:#1e293b;color:var(--gray-800);padding:10px 14px}.sa-table tbody tr:hover{background:#f0faf3;background:var(--primary-50)}.sa-table tbody tr:last-child td{border-bottom:none}.sa-overview-header{margin-bottom:20px}.sa-overview-header h2{font-size:1.1rem;font-weight:700}.sa-overview-header p{color:#64748b;color:var(--gray-500);font-size:.82rem;margin-top:2px}.sa-analytics-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.sa-analytic-card{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);padding:16px}.sa-analytic-card h4{font-size:.85rem;font-weight:600;margin-bottom:8px}.sa-analytic-row{align-items:center;border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--gray-100);color:#334155;color:var(--gray-700);display:flex;font-size:.8rem;justify-content:space-between;padding:5px 0}.sa-analytic-row:last-child{border-bottom:none}.role-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.65rem;font-weight:600;gap:4px;padding:3px 8px}.role-superadmin{background:#dff5e7;background:var(--primary-light);color:#007a31;color:var(--primary-dark)}.role-admin_pokja{background:#fff4db;background:var(--orange-light);color:#f59e0b;color:var(--orange)}.role-karyawan{background:#f1f5f9;background:var(--gray-100)}.role-karyawan,.sa-page-btn{color:#475569;color:var(--gray-600)}.sa-page-btn{align-items:center;background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:8px;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.78rem;font-weight:500;height:30px;justify-content:center;min-width:30px;padding:0 8px}.sa-page-btn:hover:not(:disabled):not(.active){background:#dff5e7;background:var(--primary-light);border-color:#009a3e;border-color:var(--primary);color:#009a3e;color:var(--primary)}.sa-page-btn.active{background:#009a3e;background:var(--primary);border-color:#009a3e;border-color:var(--primary);color:#fff}.sa-page-btn:disabled{cursor:not-allowed;opacity:.35}.sa-pagination{align-items:center;border-top:1px solid #f1f5f9;border-top:1px solid var(--gray-100);display:flex;flex-wrap:wrap;gap:4px;justify-content:center;padding:12px 20px}.soal-form{background:#f8fafc;background:var(--gray-50);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--gray-200);padding:16px}.soal-form h4{font-size:.88rem;font-weight:700;margin-bottom:10px}.soal-form-msg{background:#f1f5f9;background:var(--gray-100);border-radius:6px;color:#334155;color:var(--gray-700);font-size:.8rem;margin-bottom:10px;padding:6px 10px}.soal-form-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;margin-bottom:10px}.soal-form-row{display:flex;flex-direction:column;gap:3px}.soal-form-row label{color:#475569;color:var(--gray-600);font-size:.72rem;font-weight:600}.soal-form-row input,.soal-form-row select,.soal-form-row textarea{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:6px;font-family:inherit;font-size:.8rem;padding:7px 10px}.soal-form-row input:focus,.soal-form-row select:focus,.soal-form-row textarea:focus{border-color:#009a3e;border-color:var(--primary);box-shadow:0 0 0 2px #dff5e7;box-shadow:0 0 0 2px var(--primary-light);outline:none}.soal-form-actions{border-top:1px solid #e2e8f0;border-top:1px solid var(--gray-200);display:flex;gap:8px;margin-top:12px;padding-top:10px}.crud-modal-overlay{composes:modal-overlay}.crud-modal{composes:modal-card;max-width:560px}.crud-modal h4{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--gray-100);font-size:.95rem;font-weight:700;margin-bottom:14px;padding-bottom:10px}.search-input{background:#f8fafc;background:var(--gray-50);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:6px;border-radius:var(--radius-xs);font-family:inherit;font-size:.82rem;padding:7px 12px;width:180px}.search-input:focus{background:#fff;background:var(--white);border-color:#009a3e;border-color:var(--primary);box-shadow:0 0 0 2px #dff5e7;box-shadow:0 0 0 2px var(--primary-light);outline:none}.sa-import{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.sa-import-section{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);padding:20px}.sa-import-section h3{font-size:.95rem;font-weight:700;margin-bottom:6px}.sa-import-section p{color:#64748b;color:var(--gray-500);font-size:.8rem;margin-bottom:6px}.sa-import-section code{background:#f1f5f9;background:var(--gray-100);border-radius:4px;font-size:.78rem;padding:2px 6px}.sa-import-section input[type=file]{color:#334155;color:var(--gray-700);font-family:inherit;font-size:.8rem}.sa-import-section input[type=file]::-webkit-file-upload-button{background:#009a3e;background:var(--primary);border:none;border-radius:6px;border-radius:var(--radius-xs);color:#fff;cursor:pointer;font-family:inherit;font-size:.78rem;font-weight:600;margin-right:10px;padding:7px 14px}.sa-import-section input[type=file]::file-selector-button{background:#009a3e;background:var(--primary);border:none;border-radius:6px;border-radius:var(--radius-xs);color:#fff;cursor:pointer;font-family:inherit;font-size:.78rem;font-weight:600;margin-right:10px;padding:7px 14px}.sa-import-msg{background:#dff5e7;background:var(--green-light);border-left:3px solid #16a34a;border-left:3px solid var(--green);color:var(--green-dark)}.sa-import-loading,.sa-import-msg{border-radius:6px;border-radius:var(--radius-xs);font-size:.8rem;padding:10px 16px}.sa-import-loading{background:#dff5e7;background:var(--primary-light);color:#009a3e;color:var(--primary)}.sa-settings{max-width:480px}.sa-setting-item{margin-bottom:14px}.sa-setting-item label{color:#334155;color:var(--gray-700);display:block;font-size:.8rem;font-weight:600;margin-bottom:4px}.sa-setting-item input{border:1.5px solid #e2e8f0;border:1.5px solid var(--gray-200);border-radius:6px;border-radius:var(--radius-xs);font-family:inherit;font-size:.85rem;padding:8px 12px;width:120px}.sa-setting-item input:focus{border-color:#009a3e;border-color:var(--primary);box-shadow:0 0 0 2px #dff5e7;box-shadow:0 0 0 2px var(--primary-light);outline:none}.sa-delete-btn,.sa-edit-btn{align-items:center;background:none;border:1px solid #0000;border-radius:6px;color:#475569;color:var(--gray-600);cursor:pointer;display:inline-flex;height:28px;justify-content:center;width:28px}.sa-edit-btn:hover{background:#dff5e7;background:var(--primary-light);border-color:#009a3e;border-color:var(--primary);color:#009a3e;color:var(--primary)}.sa-delete-btn:hover{background:#fdecec;background:var(--red-light);border-color:#dc2626;border-color:var(--red);color:#dc2626;color:var(--red)}.mobile-bottom-nav{display:none}.timeline-container{display:flex;flex-direction:column;padding-left:8px}.timeline-item{padding-bottom:20px;padding-left:24px;position:relative}.timeline-item:before{background:#e2e8f0;background:var(--gray-200);bottom:-2px;content:"";left:5px;position:absolute;top:20px;width:2px}.timeline-item:last-child:before{display:none}.timeline-marker{border:2px solid #fff;border:2px solid var(--white);border-radius:50%;box-shadow:0 0 0 1px #cbd5e1;box-shadow:0 0 0 1px var(--gray-300);height:12px;left:0;position:absolute;top:4px;width:12px;z-index:1}.timeline-marker.bg-gray{background:#94a3b8;background:var(--gray-400)}.timeline-marker.bg-primary{background:#009a3e;background:var(--primary);box-shadow:0 0 0 1px #009a3e,0 0 0 4px #009a3e26;box-shadow:0 0 0 1px var(--primary),0 0 0 4px #009a3e26}.timeline-marker.bg-orange{background:#f59e0b;background:var(--orange)}.timeline-body-jd{background:#fff;background:var(--white);border:1px solid #f1f5f9;border:1px solid var(--gray-100);border-radius:8px;border-radius:var(--radius-sm);padding:14px}.timeline-date{color:#64748b;color:var(--gray-500);font-size:.72rem;font-weight:700;letter-spacing:.3px;margin-bottom:4px;text-transform:uppercase}.timeline-title-jd{color:#1e293b;color:var(--gray-800);font-size:.9rem;font-weight:700;margin-bottom:4px}.timeline-desc{color:#475569;color:var(--gray-600);font-size:.8rem;line-height:1.5}.twibbon-modal-overlay{align-items:center;background:#000000d9;display:flex;inset:0;justify-content:center;overflow-y:auto;padding:16px;position:fixed;z-index:9999}.status-badge{align-items:center;border-radius:999px;display:inline-flex;font-size:.78rem;font-weight:600;gap:4px;line-height:1;padding:6px 10px}.status-badge--completed{background:#e3f6ea;color:#1f7a3a}.status-badge--inprogress{background:#f3f4e8;color:#6b7a2a}.status-badge--notstarted{background:#eef2f7;color:#64748b}.flex{display:flex}.flex-center{align-items:center;display:flex}.flex-col{flex-direction:column}.gap-4{gap:4px}.gap-6{gap:6px}.gap-8{gap:8px}.gap-10{gap:10px}.gap-12{gap:12px}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.text-sm{font-size:.82rem}.text-xs{font-size:.72rem}.text-muted{color:#64748b;color:var(--gray-500)}.text-green{color:#16a34a!important;color:var(--green)!important}.text-orange{color:#f59e0b!important;color:var(--orange)!important}.text-red{color:#dc2626!important;color:var(--red)!important}.text-center{text-align:center}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.w-full{width:100%}.hover-lift{transition:transform .2s,box-shadow .2s}.hover-lift:hover{box-shadow:0 8px 20px #009a3e14;transform:translateY(-2px)}.glass-welcome{background:linear-gradient(135deg,#fff,#f0faf3)!important;background:linear-gradient(135deg,#fff,var(--primary-50))!important}.error-msg{composes:form-error}@media (max-width:900px){.pokja-status-grid,.sa-charts-grid{grid-template-columns:1fr}.soal-form-grid{grid-template-columns:1fr!important}}@media (max-width:768px){:root{--sidebar-w:0px;--topbar-h:56px}.sidebar{transform:translateX(-100%);transition:transform .25s ease;width:280px}.sidebar.open{transform:translateX(0)}.sidebar-overlay{background:#0000004d;display:block;inset:0;position:fixed;z-index:99}.sidebar-close{display:flex}.app-main{margin-left:0;padding-bottom:70px}.hamburger{display:flex}.content-area,.sa-content{padding:14px}.sa-content{padding-bottom:20px!important}.sa-main{margin-left:0}.sa-sidebar,.sa-sidebar-overlay{display:none!important}.stats-grid{grid-template-columns:repeat(2,1fr)}.kelas-grid{grid-template-columns:1fr}.sa-stats-grid{grid-template-columns:repeat(2,1fr)}.sa-analytics-grid,.sa-import{grid-template-columns:1fr}.test-score-table td:first-child,.test-score-table th:first-child{max-width:120px;min-width:120px;width:120px}.test-footer{bottom:65px;margin-left:0}.sa-section-header,.sa-table-header{align-items:flex-start;flex-direction:column;gap:8px}.search-input{width:100%}.topbar-user-dropdown summary span:first-child{display:none}.sticky-col-name-td,.sticky-col-name-th,.sticky-col-nip-td,.sticky-col-nip-th,.sticky-col-no-td,.sticky-col-no-th,.sticky-col-no2-td,.sticky-col-no2-th,.sticky-col-std-td,.sticky-col-std-th{position:static!important}.mobile-bottom-nav{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-top:1px solid #e2e8f0;border-top:1px solid var(--gray-200);bottom:0;box-shadow:0 -4px 12px #0000000d;display:flex;height:60px;justify-content:space-around;left:0;padding-bottom:env(safe-area-inset-bottom);position:fixed;right:0;z-index:999}.mobile-bottom-nav-item{align-items:center;background:none;border:none;color:#64748b;color:var(--gray-500);display:flex;flex:1 1;flex-direction:column;font-family:inherit;height:100%;justify-content:center;transition:all .2s ease}.mobile-bottom-nav-item.active{color:#009a3e;color:var(--primary)}.mobile-bottom-nav-icon{margin-bottom:3px}.mobile-bottom-nav-item.active .mobile-bottom-nav-icon{transform:translateY(-2px)}.mobile-bottom-nav-label{font-size:.62rem;font-weight:600}.test-questions{padding-bottom:80px}.sa-content{padding-bottom:80px!important}.content-area{padding-bottom:20px}.certificate-preview{margin:0}.cert-border-outer{padding:8px}.cert-border-inner{padding:24px 16px}.cert-name{font-size:1.6rem}.cert-title{font-size:1.2rem}}@media (max-width:480px){.stats-grid{gap:8px}.stat-card{padding:12px}.stat-number{font-size:1.3rem}.detail-header{flex-wrap:wrap}.pokja-header{align-items:flex-start;flex-direction:column}.step-btn-group .btn,.step-btn-group .step-confirm-btn,.step-btn-group .step-link-btn,.step-btn-group .step-start-btn,.step-btn-group .step-visit-btn{justify-content:center!important;width:100%!important}.test-score-table td,.test-score-table th{font-size:.7rem;padding:6px}.test-score-table td:first-child,.test-score-table th:first-child{min-width:100px;width:100px}}
/*# sourceMappingURL=main.22a15b8a.css.map*/