@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap);@import url(https://fonts.googleapis.com/css2?family=Caveat:wght@600&display=swap);:root{--sa-sidebar-w:268px;--sa-topbar-h:68px;--sa-bg:#f3f7fb;--sa-bg-soft:#eef5ff;--sa-sidebar-bg:#0f172a;--sa-sidebar-bg-2:#16213a;--sa-card-bg:#fff;--sa-card-border:#e6edf5;--sa-accent:#2563eb;--sa-accent-2:#0ea5e9;--sa-success:#16a34a;--sa-warning:#f59e0b;--sa-danger:#dc2626;--sa-text:#0f172a;--sa-muted:#64748b;--sa-muted-2:#94a3b8;--sa-ring:#2563eb29;--sa-shadow-sm:0 1px 2px #0f172a0f;--sa-shadow-md:0 12px 30px #0f172a14;--sa-shadow-lg:0 24px 60px #0f172a24;--sa-radius-sm:10px;--sa-radius-md:16px;--sa-radius-lg:22px}.superadmin-layout{background:radial-gradient(circle at top left,#0ea5e91f,#0000 34rem),linear-gradient(135deg,#f3f7fb,#f8fafc 55%,#eef6ff);background:radial-gradient(circle at top left,#0ea5e91f,#0000 34rem),linear-gradient(135deg,var(--sa-bg),#f8fafc 55%,#eef6ff);overflow-x:hidden;width:100%}.sa-main{display:flex;flex-direction:column;margin-left:268px;margin-left:var(--sa-sidebar-w)}.sa-content{box-sizing:border-box;flex:1 1;padding:28px;width:100%}.sa-sidebar{background:linear-gradient(180deg,#0f172a,#16213a);background:linear-gradient(180deg,var(--sa-sidebar-bg),var(--sa-sidebar-bg-2));box-shadow:18px 0 45px #0f172a29;color:#fff;transition:transform .25s ease,box-shadow .25s ease;width:268px;width:var(--sa-sidebar-w)}.sa-sidebar-overlay{display:none}.sa-sidebar-header{border-bottom:1px solid #ffffff14;padding:22px 18px 20px}.sa-logo-img{background:#fff;border-radius:14px;box-shadow:0 12px 24px #0000002e;height:44px;padding:3px;width:44px}.sa-sidebar-brand-block{min-width:0}.sa-brand-title{align-items:center;color:#fff;display:flex;font-size:1rem;font-weight:750;gap:8px;line-height:1.2}.sa-brand-text{color:#e2e8f0ad;font-size:.76rem;margin-top:3px}.sa-sidebar-nav{flex:1 1;overflow-y:auto;padding:14px 10px}.sa-nav-item{background:#0000;border:1px solid #0000;border-radius:14px;color:#e2e8f0b8;font-size:.9rem;font-weight:600;gap:11px;margin-bottom:4px;padding:12px 14px;position:relative;transition:transform .15s ease,background .15s ease,color .15s ease,border-color .15s ease}.sa-nav-item:hover{background:#ffffff14;border-color:#ffffff14;color:#fff;transform:translateX(2px)}.sa-nav-item.active{background:linear-gradient(135deg,#2563eb,#0ea5e9);background:linear-gradient(135deg,var(--sa-accent),var(--sa-accent-2));border-color:#ffffff2e;box-shadow:0 12px 24px #2563eb47;color:#fff}.sa-nav-item.active:before{background:#fff;border-radius:999px;bottom:12px;content:"";left:-10px;position:absolute;top:12px;width:4px}.sa-nav-icon{height:24px;width:24px}.sa-nav-label{flex:1 1;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}.sa-sidebar-footer{border-top:1px solid #ffffff14;padding:12px 10px 16px}.sa-nav-item-danger{color:#fca5a5}.sa-nav-item-danger:hover{background:#dc26262e;border-color:#f8717133;color:#fff}.sa-badge{background:#ffffff1f;border-radius:10px;color:#fff;font-size:.7rem;height:20px;justify-content:center;margin-left:auto;min-width:20px;padding:0 6px}.sa-badge-super{background:#fbbf2433;color:#fbbf24}.admin-badge{background:#3b82f633;color:#60a5fa}.sa-badge-offset{margin-left:8px}.sa-badge-process{background:#fef3c7;color:#92400e}.sa-topbar{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffdb;border-bottom:1px solid #e2e8f0cc;gap:16px;height:68px;height:var(--sa-topbar-h)}.sa-topbar h1{color:#0f172a;color:var(--sa-text);font-size:1.1rem;font-weight:750;letter-spacing:-.02em;margin:0}.sa-topbar-user{background:#fff;border:1px solid #e6edf5;border:1px solid var(--sa-card-border);border-radius:999px;box-shadow:0 1px 2px #0f172a0f;box-shadow:var(--sa-shadow-sm);padding:6px}.sa-topbar-user-avatar{background:linear-gradient(135deg,#2563eb,#0ea5e9);background:linear-gradient(135deg,var(--sa-accent),var(--sa-accent-2));color:#fff;font-size:.86rem;font-weight:750;height:36px;width:36px}.sa-user-meta{min-width:0;padding-right:2px}.sa-user-name{color:#0f172a;color:var(--sa-text);font-size:.86rem;font-weight:700;line-height:1.2;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sa-user-role{color:#94a3b8;color:var(--sa-muted-2);font-size:.72rem;margin-top:1px}.sa-logout-btn-sm{background:none;border:1px solid #e6edf5;border:1px solid var(--sa-card-border);border-radius:8px;color:#64748b;color:var(--sa-muted);font-size:.8rem;padding:6px 12px;transition:all .15s}.sa-logout-btn-sm:hover{background:#fef2f2;border-color:#fecaca}.hamburger{color:#0f172a;color:var(--sa-sidebar-bg);padding:8px}.hamburger:hover{background:#f1f5f9}.sa-overview-header h1{color:#0f172a;color:var(--sa-sidebar-bg);font-size:1.5rem;font-weight:700;margin:0}.sa-overview-header p{font-size:.88rem;margin:4px 0 0}.sa-overview-hero{background:radial-gradient(circle at 82% 20%,#ffffff47,#0000 16rem),linear-gradient(135deg,#1d4ed8,#0ea5e9 58%,#14b8a6);border-radius:22px;border-radius:var(--sa-radius-lg);box-shadow:0 12px 30px #0f172a14;box-shadow:var(--sa-shadow-md);color:#fff;margin-bottom:22px;overflow:hidden;padding:26px;position:relative}.sa-overview-hero:after{background:#ffffff2e;border-radius:999px;bottom:-110px;content:"";height:220px;position:absolute;right:-80px;width:220px}.sa-overview-hero h2{font-size:clamp(1.35rem,2vw,2rem);font-weight:800;letter-spacing:-.03em;margin:0;position:relative;z-index:1}.sa-overview-hero p{color:#ffffffd1;font-size:.95rem;margin:8px 0 0;position:relative;z-index:1}.sa-stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-bottom:24px}.sa-stat-card{align-items:center;background:#fffffff2;border:1px solid #e6edf5;border:1px solid var(--sa-card-border);border-radius:16px;border-radius:var(--sa-radius-md);box-shadow:0 1px 2px #0f172a0f;box-shadow:var(--sa-shadow-sm);display:flex;gap:16px;overflow:hidden;position:relative;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.sa-stat-card:hover{border-color:#cfe0f5;box-shadow:0 12px 30px #0f172a14;box-shadow:var(--sa-shadow-md);transform:translateY(-2px)}.sa-stat-card:after{background:#2563eb0f;border-radius:999px;content:"";height:120px;inset:auto -40px -50px auto;position:absolute;width:120px}.sa-stat-content{min-width:0}.sa-stat-icon{align-items:center;background:#f1f5f9;border-radius:10px;color:#64748b;display:flex;flex-shrink:0;height:44px;justify-content:center;width:44px}.sa-stat-icon--blue{background:#eff6ff;color:#3b82f6}.sa-stat-icon--green{background:#f0fdf4;color:#22c55e}.sa-stat-icon--orange{background:#fff7ed;color:#f97316}.sa-stat-icon--purple{background:#faf5ff;color:#a855f7}.sa-stat-number{font-size:1.5rem;font-weight:700}.sa-stat-label{font-size:.8rem}.sa-section-card{background:var(--sa-card-bg);border:1px solid #e6edf5;border:1px solid var(--sa-card-border);border-radius:16px;border-radius:var(--sa-radius-md);box-shadow:0 1px 2px #0f172a0f;box-shadow:var(--sa-shadow-sm);margin-bottom:20px;padding:20px}.sa-section-header{flex-wrap:wrap;gap:10px}.sa-section-header h2{color:#0f172a;color:var(--sa-sidebar-bg);font-size:1.1rem;font-weight:600;margin:0}.sa-card-flush{overflow:hidden;padding:0}.sa-table-header{flex-wrap:wrap;gap:14px;margin-bottom:0;padding:18px 20px}.sa-table-title{color:#0f172a;color:var(--sa-text);font-size:1rem;font-weight:800;letter-spacing:-.015em;margin:0}.sa-table-title,.sa-toolbar{align-items:center;display:flex;gap:8px}.sa-toolbar{flex-wrap:wrap}.sa-actions{align-items:center;display:flex;gap:6px}.sa-muted-cell{color:#94a3b8;color:var(--sa-muted-2)}.sa-cell-strong{color:#0f172a;color:var(--sa-text);font-weight:700}.sa-full-row{grid-column:1/-1}.sa-form-narrow{max-width:120px}.sa-form-actions{display:flex;gap:8px;margin-top:16px}.sa-import-gap{margin-top:20px}.sa-form-msg-spaced{margin-top:10px}.sa-table-container{-webkit-overflow-scrolling:touch;border-top:1px solid #e6edf5;border-top:1px solid var(--sa-card-border);overflow-x:auto}.sa-table-wrap{min-width:680px}.sa-table th{background:#f8fafc;border-bottom:1px solid #e6edf5;border-bottom:1px solid var(--sa-card-border);color:#64748b;color:var(--sa-muted);font-size:.74rem;font-weight:800;letter-spacing:.055em;padding:13px 14px}.sa-table td{border-bottom:1px solid #edf2f7;color:#334155;font-size:.86rem;padding:13px 14px;vertical-align:middle}.sa-table tr:hover td{background:#fbfdff}.sa-empty-state{color:#64748b;color:var(--sa-muted);flex-direction:column;gap:8px;padding:52px 20px;text-align:center}.sa-empty-icon,.sa-empty-state{align-items:center;display:flex;justify-content:center}.sa-empty-icon{background:#f1f5f9;border-radius:16px;color:#94a3b8;color:var(--sa-muted-2);height:44px;width:44px}.sa-delete-btn,.sa-edit-btn{border:none;font-size:.78rem;font-weight:500;padding:5px 10px;transition:all .15s}.sa-edit-btn{background:#eff6ff;color:#2563eb;margin-right:4px}.sa-edit-btn:hover{background:#dbeafe}.sa-delete-btn{background:#fef2f2;color:#dc2626}.sa-delete-btn:hover{background:#fee2e2}.sa-pagination{align-items:center;display:flex;gap:4px;justify-content:center;padding:16px 0 4px}.sa-page-btn{background:var(--sa-card-bg);border:1px solid #e6edf5;border:1px solid var(--sa-card-border);display:flex;font-size:.82rem;height:34px;min-width:34px;transition:all .15s}.sa-page-btn:hover{color:#2563eb;color:var(--sa-accent)}.sa-page-btn.active,.sa-page-btn:hover{border-color:#2563eb;border-color:var(--sa-accent)}.sa-page-btn.active{background:#2563eb;background:var(--sa-accent)}.sa-page-dots{color:#94a3b8;padding:0 4px}.btn-primary,.btn-secondary{border-radius:11px;cursor:pointer;font-size:.84rem;font-weight:750;min-height:38px;padding:9px 16px;transition:transform .15s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease}.btn-primary{background:linear-gradient(135deg,#2563eb,#0ea5e9);background:linear-gradient(135deg,var(--sa-accent),var(--sa-accent-2));border:1px solid #ffffff1f;box-shadow:0 10px 20px #2563eb2e}.btn-primary:hover{box-shadow:0 14px 26px #2563eb3d;transform:translateY(-1px)}.btn-primary:disabled{box-shadow:none;transform:none}.btn-secondary{border:1px solid #e6edf5;border:1px solid var(--sa-card-border);color:#475569}.btn-secondary:hover{background:#f8fafc;border-color:#cbd5e1;transform:translateY(-1px)}.soal-form-grid{grid-gap:16px;gap:16px}.soal-form-row label{font-size:.8rem;font-weight:500}.sa-table-header input[type=text],.sa-table-header select,.soal-form-row input,.soal-form-row select,.soal-form-row textarea{background:#fff;border:1px solid #e6edf5;border:1px solid var(--sa-card-border);border-radius:11px;color:#0f172a;color:var(--sa-text);font-size:.86rem;min-height:38px;outline:none;padding:9px 12px;transition:border .15s ease,box-shadow .15s ease}.sa-table-header input[type=text]:focus,.sa-table-header select:focus,.soal-form-row input:focus,.soal-form-row select:focus,.soal-form-row textarea:focus{border-color:#2563eb;border-color:var(--sa-accent);box-shadow:0 0 0 4px #2563eb29;box-shadow:0 0 0 4px var(--sa-ring)}.soal-form-row textarea{font-family:inherit;min-height:80px;resize:vertical}.crud-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172a85}.crud-modal{background:var(--sa-card-bg);border:1px solid #ffffffb3;border-radius:22px;border-radius:var(--sa-radius-lg);box-shadow:0 24px 60px #0f172a24;box-shadow:var(--sa-shadow-lg);max-height:86vh;padding:24px}.crud-modal h3{color:#0f172a;color:var(--sa-text);font-size:1.15rem;font-weight:800;letter-spacing:-.02em;margin:0 0 18px}.crud-modal .btn-primary{margin-top:8px;width:100%}.sa-import-section{background:var(--sa-card-bg);border:1px solid #e6edf5;border:1px solid var(--sa-card-border);border-radius:16px;border-radius:var(--sa-radius-md);box-shadow:0 1px 2px #0f172a0f;box-shadow:var(--sa-shadow-sm);margin-bottom:20px}.sa-import-section h3{font-weight:600;margin:0 0 8px}.sa-import-section p{font-size:.85rem;margin:0 0 16px}.sa-settings-tab{width:100%}.sa-settings-card{background:var(--sa-card-bg);border:1px solid #e6edf5;border:1px solid var(--sa-card-border);border-radius:16px;border-radius:var(--sa-radius-md);box-shadow:0 1px 2px #0f172a0f;box-shadow:var(--sa-shadow-sm);margin-bottom:16px;padding:20px}.sa-settings-card-label{font-size:.9rem;font-weight:600;margin-bottom:8px}.sa-settings-card-value{color:#2563eb;color:var(--sa-accent);font-size:1.5rem}.role-badge{background:#f1f5f9;color:#475569;font-size:.72rem;text-transform:uppercase}.kunci-badge,.role-badge{border-radius:4px;display:inline-block;padding:2px 8px}.kunci-badge{background:#fef3c7;color:#92400e;font-weight:600}.mono{background:#f8fafc;border-radius:4px;font-family:Courier New,monospace;font-size:.78rem;padding:1px 6px}.text-blue{color:#3b82f6}.text-green{color:#22c55e}.text-orange{color:#f97316}.text-red{color:#dc2626}.loading{align-items:center;color:#94a3b8;display:flex;font-size:.9rem;justify-content:center;padding:60px 20px}.fade-in{animation:fadeIn .3s ease}@media (max-width:768px){.sa-sidebar{box-shadow:none;transform:translateX(-100%)}.sa-sidebar.open{box-shadow:18px 0 45px #0f172a38;transform:translateX(0)}.sa-sidebar-overlay{background:#0006;display:block;inset:0;position:fixed;z-index:99}.sa-main{margin-left:0}.sa-topbar{padding:0 14px}.hamburger{display:flex}.sa-content{padding:18px 14px}.sa-topbar-user{padding:4px}.sa-logout-btn-sm,.sa-user-meta{display:none}.sa-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.sa-stats-grid{grid-template-columns:1fr}.sa-section-header{align-items:stretch;flex-direction:column}}.sa-settings-tab{display:flex;flex-direction:column;gap:30px}.sa-section-desc{color:#475569;margin-bottom:15px}.sa-form-grid-padded{margin-bottom:20px}.sa-file-upload-group{align-items:center;display:flex;gap:10px}.sa-signature-preview{background:#fff;border:1px dashed #e6edf5;border:1px dashed var(--sa-card-border);border-radius:8px;display:inline-block;margin-top:10px;padding:10px}.sa-signature-img{max-height:60px}.sa-settings-danger-zone{background:var(--white);border:1px solid #dc2626;border:1px solid var(--sa-danger);border-radius:16px;border-radius:var(--sa-radius-md);margin-top:40px;overflow:hidden}.danger-header{padding:24px 24px 16px}.danger-header h3{color:#dc2626;color:var(--sa-danger);font-size:1.1rem;font-weight:700;margin:0 0 8px}.danger-header p{color:#64748b;color:var(--sa-muted);font-size:.85rem;line-height:1.5;margin:0}.danger-confirm-box{background:#fef2f2;border-bottom:1px solid #fee2e2;border-top:1px solid #fee2e2;padding:16px 24px}.danger-confirm-box label{color:#991b1b;display:block;font-size:.85rem;margin-bottom:8px}.danger-input{background:#fff;border:1px solid #fca5a5;border-radius:6px;color:#7f1d1d;font-family:inherit;font-size:.9rem;max-width:320px;padding:8px 12px;transition:var(--sa-transition);width:100%}.danger-input:focus{border-color:#ef4444;box-shadow:0 0 0 3px #fee2e2;outline:none}.danger-items{display:flex;flex-direction:column}.danger-item{align-items:center;border-bottom:1px solid #e6edf5;border-bottom:1px solid var(--sa-card-border);display:flex;gap:20px;justify-content:space-between;padding:20px 24px}.danger-item:last-child{border-bottom:none}.danger-item-text h4{color:#0f172a;color:var(--sa-text);font-size:.9rem;font-weight:600;margin:0 0 4px}.danger-item-text h4.text-red{color:#dc2626;color:var(--sa-danger)}.danger-item-text p{color:#64748b;color:var(--sa-muted);font-size:.8rem;line-height:1.4;margin:0}.btn-danger-action{border-radius:6px;cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:600;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.btn-danger-action:disabled{cursor:not-allowed;filter:grayscale(100%);opacity:.5}.btn-danger-outline-soft{background:#fff;border:1px solid #2563eb;border:1px solid var(--sa-accent);color:#2563eb;color:var(--sa-accent)}.btn-danger-outline-soft:not(:disabled):hover{background:#eff6ff}.btn-danger-outline{background:#fff;border:1px solid #dc2626;border:1px solid var(--sa-danger);color:#dc2626;color:var(--sa-danger)}.btn-danger-outline:not(:disabled):hover{background:#fef2f2}.btn-danger-solid{background:#dc2626;background:var(--sa-danger);border:1px solid #dc2626;border:1px solid var(--sa-danger);color:#fff}.btn-danger-solid:not(:disabled):hover{background:#b91c1c}.sa-modal-wide{max-height:90vh;max-width:900px;overflow-y:auto;width:95%}.sa-modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.sa-modal-header h3{margin:0}.sa-modal-body-gray{background:#f1f5f9;border-radius:8px;display:flex;justify-content:center;padding:20px}.sa-kpi-section{background:var(--white);border:1px solid #e6edf5;border:1px solid var(--sa-card-border);border-radius:16px;border-radius:var(--sa-radius-md);box-shadow:0 1px 2px #0f172a0f;box-shadow:var(--sa-shadow-sm);margin-top:24px;padding:24px}.sa-kpi-section h3{color:#0f172a;color:var(--sa-text);font-size:1.1rem;font-weight:700;margin:0 0 4px}.sa-kpi-desc{color:#64748b;color:var(--sa-muted);font-size:.85rem;margin:0 0 20px}.sa-kpi-list{gap:16px}.sa-kpi-item,.sa-kpi-list{display:flex;flex-direction:column}.sa-kpi-item{gap:8px}.sa-kpi-item-header{color:#0f172a;color:var(--sa-text);display:flex;font-size:.9rem;font-weight:600;justify-content:space-between}.sa-kpi-item-value{color:#2563eb;color:var(--sa-accent)}.sa-kpi-bar-bg{background:#e2e8f0;border-radius:4px;height:8px;overflow:hidden;width:100%}.sa-kpi-bar-fill{background:#16a34a;background:var(--sa-success);border-radius:4px;height:100%;transition:width 1s cubic-bezier(.4,0,.2,1)}.sa-stat-icon--green{background:#dcfce7}.sa-stat-icon--green,.text-green{color:#16a34a;color:var(--sa-success)}.sa-stat-icon--purple{background:#f3e8ff;color:#9333ea}.sa-kpi-card-v2{background:var(--white);border:1px solid #e6edf5;border:1px solid var(--sa-card-border);border-radius:16px;border-radius:var(--sa-radius-md);box-shadow:0 1px 2px #0f172a0f;box-shadow:var(--sa-shadow-sm);display:flex;flex-direction:column;gap:8px;padding:16px 20px;transition:transform .2s ease,box-shadow .2s ease}.sa-kpi-card-v2:hover{box-shadow:0 12px 30px #0f172a14;box-shadow:var(--sa-shadow-md);transform:translateY(-2px)}.sa-kpi-header{align-items:center;display:flex;justify-content:space-between}.sa-kpi-label{color:#64748b;color:var(--sa-muted);font-size:.75rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.sa-kpi-icon-mini{align-items:center;border-radius:8px;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.sa-kpi-value{color:#0f172a;color:var(--sa-text);font-size:1.75rem;font-weight:800;line-height:1.2}.sa-kpi-bar-mini{background:#f1f5f9;border-radius:2px;height:4px;margin-top:4px;overflow:hidden;width:100%}.sa-kpi-fill{border-radius:2px;height:100%;transition:width 1s ease-out}.sa-kpi-target{color:#64748b;font-size:.7rem;font-weight:500}.sa-bg-blue{background:#eff6ff;color:#3b82f6}.sa-bg-orange{background:#fffbeb;color:#f59e0b}.sa-bg-green{background:#ecfdf5;color:#10b981}.page-header{margin-bottom:24px}.page-header h1{color:var(--gray-900);font-size:1.4rem;font-weight:700;margin-bottom:4px}.page-header p{color:var(--gray-500);font-size:.82rem}.kpi-banner{background:var(--white);border:1px solid #e6edf5;border:1px solid var(--sa-card-border);border-radius:16px;border-radius:var(--sa-radius-md);box-shadow:0 1px 2px #0f172a0f;box-shadow:var(--sa-shadow-sm);display:flex;gap:0;margin-bottom:20px;padding:20px 24px}.kpi-banner-item{align-items:center;display:flex;flex:1 1;gap:16px;padding:0 16px}.kpi-banner-item:first-child{padding-left:0}.kpi-banner-item:last-child{padding-right:0}.kpi-banner-icon{align-items:center;border-radius:var(--radius-sm);display:flex;flex-shrink:0;height:52px;justify-content:center;width:52px}.kpi-banner-icon.green{background:#dcfce7;color:#16a34a}.kpi-banner-icon.orange{background:#fef3c7;color:#d97706}.kpi-banner-icon.blue{background:#dbeafe;color:#2563eb}.kpi-banner-icon.purple{background:#f3e8ff;color:#9333ea}.kpi-banner-icon.red{background:#fee2e2;color:#dc2626}.kpi-banner-info{flex:1 1;min-width:0}.kpi-banner-label{color:#64748b;display:block;font-size:.72rem;font-weight:600;letter-spacing:.04em;margin-bottom:2px;text-transform:uppercase}.kpi-banner-value{color:#1e293b;display:block;font-size:1.6rem;font-weight:800;line-height:1.2}.kpi-banner-bar{background:#f1f5f9;border-radius:2px;height:4px;margin:6px 0 3px;overflow:hidden}.kpi-banner-bar-fill{background:var(--sa-primary);border-radius:2px;height:100%;transition:width 1s cubic-bezier(.2,0,0,1)}.kpi-banner-target{color:#94a3b8;font-size:.68rem;font-weight:500}.kpi-banner-divider{background:#e6edf5;background:var(--sa-card-border);flex-shrink:0;width:1px}.kpi-period-badge{align-items:center;background:#f0fdf4;border-radius:20px;color:#16a34a;display:inline-flex;font-size:.72rem;font-weight:600;padding:4px 12px;white-space:nowrap}.stats-grid{grid-gap:16px;gap:16px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));margin-bottom:24px}.kpi-card{background:var(--white);border:1px solid #e6edf5;border:1px solid var(--sa-card-border);border-radius:16px;border-radius:var(--sa-radius-md);overflow:hidden;padding:18px 20px 14px;position:relative;transition:all .2s cubic-bezier(.2,0,0,1)}.kpi-card:hover{box-shadow:0 12px 30px #0f172a14;box-shadow:var(--sa-shadow-md);transform:translateY(-2px)}.kpi-card:before{background:var(--sa-primary);content:"";height:3px;left:0;position:absolute;right:0;top:0}.kpi-card-top{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:10px}.kpi-icon-wrap{align-items:center;border-radius:var(--radius-sm);display:flex;flex-shrink:0;height:38px;justify-content:center;width:38px}.kpi-icon-wrap.green{background:#dcfce7;color:#16a34a}.kpi-icon-wrap.orange{background:#fef3c7;color:#d97706}.kpi-icon-wrap.purple{background:#f3e8ff;color:#9333ea}.kpi-icon-wrap.blue{background:#dbeafe;color:#2563eb}.kpi-icon-wrap.red{background:#fee2e2;color:#dc2626}.kpi-meta{align-items:flex-end;display:flex;flex-direction:column;gap:1px}.kpi-trend{align-items:center;border-radius:20px;display:inline-flex;font-size:.7rem;font-weight:600;gap:2px;padding:2px 8px}.kpi-trend.up{background:#f0fdf4;color:#16a34a}.kpi-trend.down{background:#fef2f2;color:#ef4444}.kpi-period{color:#94a3b8;font-size:.65rem}.kpi-value{color:#1e293b;font-size:1.5rem;font-weight:800;line-height:1.2;margin-bottom:2px}.kpi-label{color:#64748b;font-size:.8rem;font-weight:500;margin-bottom:10px}.kpi-footer{align-items:center;border-top:1px solid #f1f5f9;display:flex;justify-content:space-between;padding-top:10px}.kpi-footer-label{color:#94a3b8;font-size:.7rem;font-weight:500}.kpi-footer-pct{color:#475569;font-size:.7rem;font-weight:700}.kpi-score-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-bottom:24px}.kpi-score-item{background:var(--white);border:1px solid #e6edf5;border:1px solid var(--sa-card-border);border-radius:var(--radius-sm);padding:14px 16px;transition:all .2s cubic-bezier(.2,0,0,1)}.kpi-score-item:hover{box-shadow:0 1px 2px #0f172a0f;box-shadow:var(--sa-shadow-sm)}.kpi-score-header{font-size:.72rem;font-weight:600;gap:6px;letter-spacing:.03em;margin-bottom:6px;text-transform:uppercase}.kpi-score-header,.kpi-score-icon{align-items:center;color:#64748b;display:flex}.kpi-score-icon{background:#f8fafc;border-radius:6px;flex-shrink:0;height:24px;justify-content:center;width:24px}.kpi-score-value{color:#1e293b;font-size:1.4rem;font-weight:800;line-height:1.2;margin-bottom:8px}.kpi-score-detail{align-items:center;border-top:1px solid #f8fafc;color:#64748b;display:flex;font-size:.75rem;justify-content:space-between;padding:3px 0}.kpi-score-detail:first-of-type{border-top:none}.grid-2col{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1.6fr 1fr;margin-bottom:24px}.card{background:var(--white);border:1px solid #e6edf5;border:1px solid var(--sa-card-border);border-radius:var(--radius-md);overflow:hidden;transition:all .2s cubic-bezier(.2,0,0,1)}.card:hover{box-shadow:0 12px 30px #0f172a14;box-shadow:var(--sa-shadow-md)}.card-header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;padding:16px 20px}.card-header h3{color:#1e293b;font-size:.9rem;font-weight:700}.card-body{padding:20px}.progress-bar-track{background:#f1f5f9;border-radius:4px;height:8px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg,#10b981,#16a34a);border-radius:4px;height:100%;transition:width 1s cubic-bezier(.2,0,0,1)}.progress-label{display:flex;font-size:.8rem;justify-content:space-between;margin-bottom:6px}.progress-label .label{color:#475569;font-weight:500}.progress-label .value{color:#1e293b;font-weight:700}.chart-bars{align-items:flex-end;display:flex;gap:8px;height:160px;padding:0 4px}.chart-bar{background:#dcfce7;border-radius:4px 4px 0 0;flex:1 1;min-height:4px;position:relative;transition:all .2s cubic-bezier(.2,0,0,1)}.chart-bar:hover{background:#16a34a}.chart-labels{display:flex;gap:8px;margin-top:8px}.chart-labels span{color:#64748b;flex:1 1;font-size:.68rem;text-align:center}.donut-container{align-items:center;display:flex;gap:24px;justify-content:center}.donut{border-radius:50%;flex-shrink:0;height:120px;position:relative;width:120px}.donut-center{align-items:center;background:var(--white);border-radius:50%;display:flex;flex-direction:column;inset:20px;justify-content:center;position:absolute}.donut-center .big{color:#1e293b;font-size:1.2rem;font-weight:800;line-height:1}.donut-center .small{color:#64748b;font-size:.68rem}.donut-legend{display:flex;flex-direction:column;gap:8px}.donut-legend-item{align-items:center;color:#475569;display:flex;font-size:.82rem;gap:8px}.donut-legend-item .dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.donut-legend-item .val{color:#1e293b;font-weight:600;margin-left:auto}.activity-list{display:flex;flex-direction:column;gap:0}.activity-item{align-items:flex-start;border-bottom:1px solid #f1f5f9;display:flex;gap:12px;padding:12px 0}.activity-item:last-child{border-bottom:none}.activity-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:.8rem;height:34px;justify-content:center;width:34px}.activity-icon.green{background:#dcfce7;color:#16a34a}.activity-icon.orange{background:#fef3c7;color:#d97706}.activity-icon.blue{background:#dbeafe;color:#2563eb}.activity-icon.red{background:#fee2e2;color:#dc2626}.activity-text{flex:1 1}.activity-title{color:#1e293b;font-size:.85rem;font-weight:600;margin-bottom:2px}.activity-desc{color:#64748b;font-size:.78rem}.activity-time{color:#94a3b8;flex-shrink:0;font-size:.72rem;white-space:nowrap}@media (max-width:768px){.grid-2col,.grid-4col{grid-template-columns:1fr!important}.kpi-banner{flex-direction:column;gap:16px}.kpi-banner-divider{height:1px;margin:8px 0;width:100%}.donut-legend{align-items:center;flex-direction:column;gap:8px}}.sa-quick-actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px}@media (max-width:768px){.sa-quick-actions{flex-direction:column}.sa-quick-actions button{width:100%}}.ud-dashboard-premium{font-family:Inter,system-ui,sans-serif;margin:0 auto;max-width:1200px;padding:24px}.ud-hero-banner-mesh{align-items:center;background:#022c22;border-radius:24px;box-shadow:0 20px 40px #05966933;color:#fff;display:flex;justify-content:space-between;margin-bottom:40px;overflow:hidden;padding:40px;position:relative}.ud-hero-bg-anim{animation:meshRotate 20s linear infinite;background:radial-gradient(circle at 50% 50%,#10b98166 0,#0000 40%),radial-gradient(circle at 80% 20%,#34d39966 0,#0000 40%),radial-gradient(circle at 20% 80%,#04785780 0,#0000 50%);height:200%;left:-50%;pointer-events:none;position:absolute;top:-50%;width:200%;z-index:0}@keyframes meshRotate{0%{transform:rotate(0deg) scale(1)}50%{transform:rotate(180deg) scale(1.1)}to{transform:rotate(1turn) scale(1)}}.ud-hero-content,.ud-hero-progress{position:relative;z-index:1}.ud-hero-greeting{align-items:center;display:flex;font-size:2.2rem;font-weight:800;gap:16px;margin:0 0 16px;text-shadow:0 2px 10px #0003}.ud-glass-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:1px solid #ffffff4d;border-radius:30px;box-shadow:0 4px 15px #0000001a,inset 0 0 10px #ffffff1a;font-size:.9rem;font-weight:800;letter-spacing:1px;padding:8px 16px;text-transform:uppercase}.ud-hero-xp{font-size:1.2rem;font-weight:500;margin:0;opacity:.9}.ud-progress-circle-neon{background:conic-gradient(#34d399 var(--progress),#ffffff1a 0deg);box-shadow:0 0 20px #34d3994d,inset 0 0 20px #0003;height:120px;margin:0 auto 12px;width:120px}.ud-progress-circle-neon,.ud-progress-inner{align-items:center;border-radius:50%;display:flex;justify-content:center}.ud-progress-inner{background:#022c22;box-shadow:inset 0 4px 10px #0000004d;color:#fff;font-size:1.8rem;font-weight:800;height:100px;width:100px}.ud-progress-label{font-size:.9rem;font-weight:700;letter-spacing:1px;opacity:.9;text-align:center;text-transform:uppercase}.ud-stats-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(4,1fr);margin-bottom:40px}.ud-stat-card{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffc;border:1px solid #fff;border-radius:20px;box-shadow:0 10px 30px #00000008;display:flex;gap:20px;padding:24px;transform-style:preserve-3d;transition:all .4s cubic-bezier(.34,1.56,.64,1)}.ud-stat-card:hover{border-color:#10b9814d;box-shadow:0 20px 40px #10b9811a;transform:translateY(-8px) scale(1.02)}.ud-stat-icon{align-items:center;border-radius:16px;box-shadow:0 8px 16px #0000000d;display:flex;font-size:1.8rem;height:56px;justify-content:center;width:56px}.ud-stat-info{display:flex;flex-direction:column}.ud-stat-num{color:#0f172a;font-size:1.8rem;font-weight:900;line-height:1.2}.ud-stat-lbl{color:#64748b;font-size:.9rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.ud-progress-card{background:#fff;border:1px solid #f1f5f9;border-radius:24px;box-shadow:0 10px 30px #00000008;margin-bottom:40px;padding:32px}.ud-section-title{align-items:center;color:#0f172a;display:flex;font-size:1.4rem;font-weight:800;gap:12px;margin:0 0 24px}.ud-progress-bar-bg{background:#f1f5f9;border-radius:8px;box-shadow:inset 0 2px 4px #0000000d;height:16px;margin-bottom:16px;overflow:hidden}.ud-progress-bar-fill{background:linear-gradient(90deg,var(--primary),#34d399);border-radius:8px;box-shadow:0 0 10px #10b98166;height:100%;transition:width 1.5s cubic-bezier(.34,1.56,.64,1)}.ud-start-btn{background:linear-gradient(135deg,var(--primary),#047857);border:none;border-radius:30px;box-shadow:0 8px 20px #10b9814d;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;padding:12px 28px;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.ud-start-btn:hover{box-shadow:0 12px 25px #10b98166;transform:translateY(-3px) scale(1.05)}.ud-chip-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}.ud-chip{background:#fff;border:1px solid #e2e8f0;border-radius:20px;box-shadow:0 2px 5px #00000005;color:#334155;font-size:.85rem;font-weight:600;padding:8px 16px;transition:all .2s}.ud-chip:hover{background:#f8fafc;border-color:var(--primary-light);transform:translateY(-2px)}.ud-timeline-modern{padding-left:40px;position:relative}.ud-timeline-modern:before{background:linear-gradient(180deg,#e2e8f0,#f1f5f9);border-radius:3px;bottom:0;content:"";left:19px;position:absolute;top:0;width:3px}.ud-timeline-item-modern{margin-bottom:32px;position:relative}.ud-timeline-item-modern:last-child{margin-bottom:0}.ud-timeline-dot{background:var(--primary);border:4px solid #fff;border-radius:50%;box-shadow:0 0 0 4px #10b9811a;height:24px;left:-33px;position:absolute;transition:transform .3s;width:24px;z-index:1}.ud-timeline-item-modern:hover .ud-timeline-dot{transform:scale(1.2)}.ud-timeline-content-modern{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 15px #00000005;padding:24px;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.ud-timeline-content-modern:hover{border-color:var(--primary-light);box-shadow:0 10px 25px #10b9811a;transform:translateX(8px)}.ud-timeline-date{color:var(--primary);font-size:.85rem;font-weight:700;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.ud-timeline-title{color:#0f172a;font-size:1.15rem;font-weight:800;margin-bottom:12px}.ud-timeline-desc{color:#475569;font-size:.95rem;line-height:1.6}.ud-timeline-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}.ud-btn-feedback,.ud-btn-zoom{align-items:center;border-radius:12px;color:#fff;display:inline-flex;font-size:.9rem;font-weight:700;gap:8px;padding:10px 20px;text-decoration:none;transition:all .2s}.ud-btn-zoom{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 4px 12px #3b82f64d}.ud-btn-zoom:hover{box-shadow:0 8px 16px #3b82f666;transform:translateY(-2px)}.ud-btn-feedback{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px #10b9814d}.ud-btn-feedback:hover{box-shadow:0 8px 16px #10b98166;transform:translateY(-2px)}.ud-achievement-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.ud-achievement-card{background:#fff;border:1px solid #e2e8f0;border-radius:20px;box-shadow:0 4px 15px #00000008;display:flex;flex-direction:column;overflow:hidden;transition:all .4s cubic-bezier(.34,1.56,.64,1)}.ud-achievement-card:hover{box-shadow:0 15px 30px #00000014;transform:translateY(-8px)}.ud-achievement-card.passed{border-color:#a7f3d0}.ud-achievement-card.inprogress{border-color:#fed7aa}.ud-achieve-header{align-items:flex-start;border-bottom:1px solid #f1f5f9;display:flex;gap:12px;justify-content:space-between;padding:20px}.ud-achievement-card.passed .ud-achieve-header{background:linear-gradient(90deg,#ecfdf5,#fff)}.ud-achievement-card.inprogress .ud-achieve-header{background:linear-gradient(90deg,#fff7ed,#fff)}.ud-achieve-title{color:#0f172a;font-size:1.1rem;font-weight:700;line-height:1.4;margin:0}.ud-achieve-badge{border-radius:20px;font-size:.75rem;font-weight:800;padding:6px 12px;text-transform:uppercase;white-space:nowrap}.ud-achievement-card.passed .ud-achieve-badge{background:#10b981;color:#fff}.ud-achievement-card.inprogress .ud-achieve-badge{background:#f97316;color:#fff}.ud-achieve-scores{grid-gap:16px;display:grid;flex:1 1;gap:16px;grid-template-columns:repeat(2,1fr);padding:20px}.ud-score-item{background:#f8fafc;border:1px solid #f1f5f9;border-radius:12px;display:flex;flex-direction:column;padding:12px}.ud-score-lbl{color:#64748b;font-size:.75rem;font-weight:600;margin-bottom:4px;text-transform:uppercase}.ud-score-val{color:#1e293b;font-size:1.2rem;font-weight:800}.ud-achieve-footer{align-items:center;background:#f8fafc;border-top:1px dashed #e2e8f0;display:flex;justify-content:space-between;padding:16px 20px}.ud-highest-lbl{color:#475569;font-size:.9rem;font-weight:700}.ud-highest-val{color:var(--primary);font-size:1.4rem;font-weight:900}@media (max-width:1024px){.ud-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.ud-dashboard-premium{padding:16px}.ud-hero-banner-mesh{flex-direction:column;gap:24px;padding:32px 20px;text-align:center}.ud-hero-greeting{flex-wrap:wrap;justify-content:center}.ud-progress-card{padding:20px}.ud-achievement-grid{grid-template-columns:1fr}}@media (max-width:480px){.ud-stats-grid{grid-template-columns:1fr}}.uk-hero{background:linear-gradient(135deg,#064e3b,var(--primary),#10b981);border-radius:20px;box-shadow:0 10px 25px #0596694d;color:#fff;display:flex;flex-direction:column;justify-content:center;margin-bottom:32px;overflow:hidden;padding:32px 40px;position:relative}.uk-hero:before{background:radial-gradient(circle,#ffffff26 0,#0000 70%);border-radius:50%;content:"";height:250px;pointer-events:none;position:absolute;right:-50px;top:-50px;width:250px}.uk-hero-title{font-size:2rem;font-weight:800;letter-spacing:-.5px;margin:0 0 8px;text-shadow:0 2px 4px #0003}.uk-hero-subtitle{font-size:1.05rem;font-weight:500;margin:0;opacity:.9}.uk-tabs-container{display:flex;gap:12px;margin-bottom:24px;overflow-x:auto;padding-bottom:8px}.uk-tab-pill{background:#fff;border:1px solid var(--gray-200);border-radius:30px;box-shadow:0 2px 8px #00000005;color:var(--gray-600);cursor:pointer;font-size:.95rem;font-weight:600;padding:10px 24px;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap}.uk-tab-pill:hover{background:var(--gray-50);transform:translateY(-1px)}.uk-tab-pill.active{background:var(--primary);border-color:var(--primary);box-shadow:0 4px 12px #0596694d;color:#fff}.uk-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.uk-card{background:#fff;border:1px solid var(--gray-100);border-radius:16px;box-shadow:0 4px 15px #00000008;cursor:pointer;display:flex;flex-direction:column;overflow:hidden;padding:24px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.uk-card:hover{border-color:var(--primary-light);box-shadow:0 15px 30px #0596691a;transform:translateY(-6px)}.uk-card-watermark{bottom:-20px;color:var(--primary);opacity:.03;pointer-events:none;position:absolute;right:-20px;transition:transform .4s ease,opacity .4s ease}.uk-card:hover .uk-card-watermark{opacity:.06;transform:scale(1.1) rotate(-10deg)}.uk-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px;z-index:1}.uk-card-title{color:var(--gray-800);flex:1 1;font-size:1.15rem;font-weight:700;line-height:1.4;margin:0;padding-right:12px}.uk-card-score{align-items:center;color:var(--gray-500);display:flex;font-size:.85rem;gap:6px;margin-bottom:20px;z-index:1}.uk-card-score strong{background:var(--gray-100);border-radius:12px;color:var(--gray-800);padding:2px 8px}.uk-stepper{display:flex;justify-content:space-between;margin-top:auto;position:relative;z-index:1}.uk-stepper:before{background:var(--gray-200);content:"";height:2px;left:10%;position:absolute;right:10%;top:10px;z-index:-1}.uk-step{flex-direction:column;gap:6px}.uk-step,.uk-step-circle{align-items:center;background:#fff;display:flex}.uk-step-circle{border:2px solid var(--gray-300);border-radius:50%;color:#0000;font-size:.6rem;height:22px;justify-content:center;transition:all .2s;width:22px}.uk-step[data-done=true] .uk-step-circle{background:var(--primary);border-color:var(--primary);color:#fff}.uk-step[data-current=true] .uk-step-circle{border-color:var(--primary);box-shadow:0 0 0 3px #05966933}.uk-step-label{color:var(--gray-400);font-size:.7rem;font-weight:600}.uk-step[data-current=true] .uk-step-label,.uk-step[data-done=true] .uk-step-label{color:var(--gray-700)}.uk-badge{border-radius:20px;font-size:.75rem;font-weight:700;padding:4px 10px;white-space:nowrap}.uk-badge-selesai{background:#dcfce7;color:#16a34a}.uk-badge-progress{background:#ffedd5;color:#ea580c}.uk-badge-belum{background:#f1f5f9;color:#64748b}@media (max-width:768px){.uk-hero{padding:24px}.uk-grid{grid-template-columns:1fr}.uk-tabs-container{margin-right:-16px;padding-right:16px}}.ut-page{animation:fadeIn .3s ease-out;margin:0 auto;max-width:800px;padding-bottom:80px}.ut-header-wrapper{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;border:1px solid var(--gray-100);border-radius:0 0 20px 20px;border-top:none;box-shadow:0 4px 20px #0000000d;margin-bottom:32px;overflow:hidden;position:-webkit-sticky;position:sticky;top:0;z-index:100}.ut-progress-track{background:var(--gray-100);height:6px;left:0;position:absolute;right:0;top:0;width:100%}.ut-progress-fill{background:linear-gradient(90deg,#10b981,#34d399);box-shadow:0 0 10px #10b98180;height:100%;transition:width .4s cubic-bezier(.34,1.56,.64,1)}.ut-header{align-items:center;display:flex;justify-content:space-between;padding:16px 24px}.ut-title-group{display:flex;flex-direction:column;gap:4px}.ut-title{color:var(--gray-800);font-size:1.25rem;font-weight:800;margin:0}.ut-badge{background:var(--primary-100);border-radius:12px;color:var(--primary-dark);display:inline-block;font-size:.75rem;font-weight:700;padding:2px 8px;width:-webkit-fit-content;width:fit-content}.ut-status-group{align-items:center;display:flex;gap:16px}.ut-progress-text{color:var(--gray-600);font-size:.9rem;font-weight:600}.ut-progress-text .answered-count{color:var(--primary);font-size:1.1rem;font-weight:800}.ut-timer{align-items:center;background:var(--primary);border-radius:20px;box-shadow:0 4px 12px #0596694d;color:#fff;display:flex;font-size:1.1rem;font-weight:700;gap:6px;letter-spacing:1px;padding:8px 16px;transition:all .3s ease}.ut-timer.urgent{animation:pulse-danger 1s infinite alternate;background:#ef4444;box-shadow:0 4px 12px #ef44444d}.timer-icon{animation:tick-tock 1s linear infinite}@keyframes pulse-danger{0%{box-shadow:0 0 0 #ef444466;transform:scale(1)}to{box-shadow:0 0 15px #ef4444cc;transform:scale(1.05)}}@keyframes tick-tock{0%{transform:rotate(0deg)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}to{transform:rotate(0deg)}}.ut-question-card{background:#fff;border:1px solid var(--gray-200);border-radius:16px;box-shadow:0 4px 15px #00000005;display:flex;gap:16px;margin-bottom:24px;padding:24px;transition:all .2s}.ut-question-card:hover{border-color:var(--primary-light);box-shadow:0 8px 25px #0596690d}.ut-question-number{color:var(--gray-400);font-size:1.25rem;font-weight:800;width:32px}.ut-question-text{color:var(--gray-800);font-size:1.1rem;font-weight:500;line-height:1.6;margin-bottom:20px}.ut-options{display:flex;flex-direction:column;gap:12px}.ut-option-label{align-items:center;background:var(--gray-50);border:2px solid var(--gray-100);border-radius:12px;cursor:pointer;display:flex;gap:16px;overflow:hidden;padding:12px 16px;position:relative;transform:scale(1);transition:all .3s cubic-bezier(.34,1.56,.64,1)}.ut-option-label:hover{background:#fff;border-color:var(--primary-light);box-shadow:0 6px 16px #0000000d;transform:translateY(-2px) scale(1.01)}.ut-option-label input[type=radio]{display:none}.ut-option-letter{align-items:center;background:#fff;border:2px solid var(--gray-200);border-radius:8px;color:var(--gray-500);display:flex;font-weight:700;height:30px;justify-content:center;transition:all .2s;width:30px}.ut-option-text{color:var(--gray-700);flex:1 1;font-size:1rem}.ut-option-label.selected{background:#ecfdf5;border-color:var(--primary);box-shadow:0 4px 12px #05966926,inset 0 0 0 2px var(--primary);transform:scale(1.02)}.ut-option-label.selected .ut-option-letter{background:var(--primary);border-color:var(--primary);box-shadow:0 2px 8px #05966966;color:#fff;transform:rotate(-5deg) scale(1.1)}.ut-option-label.selected .ut-option-text{color:var(--gray-900);font-weight:700}.ut-footer{background:#fff;bottom:0;box-shadow:0 -4px 20px #0000000d;gap:16px;left:0;padding:16px 24px;position:fixed;right:0;z-index:99}.ut-btn,.ut-footer{display:flex;justify-content:center}.ut-btn{align-items:center;border:none;border-radius:12px;cursor:pointer;font-size:1rem;font-weight:700;gap:8px;padding:12px 24px;transition:all .2s}.ut-btn-cancel{background:var(--gray-100);color:var(--gray-600)}.ut-btn-cancel:hover{background:var(--gray-200)}.ut-btn-submit{background:linear-gradient(135deg,var(--primary),#059669);box-shadow:0 4px 12px #0596694d;color:#fff;min-width:250px}.ut-btn-submit:hover:not(:disabled){box-shadow:0 6px 16px #05966966;transform:translateY(-2px)}.ut-btn-submit:disabled{background:var(--gray-300);box-shadow:none;cursor:not-allowed;opacity:.7}.ut-result-container{align-items:center;display:flex;justify-content:center;min-height:80vh;padding:24px}.ut-result-card{background:#fff;border:1px solid var(--gray-100);border-radius:24px;box-shadow:0 20px 40px #00000014;max-width:480px;overflow:hidden;padding:40px;position:relative;text-align:center;width:100%}.ut-confetti-bg{animation:confettiRotate 10s linear infinite;background-image:radial-gradient(circle at 20% 30%,#10b98126 0,#0000 50%),radial-gradient(circle at 80% 40%,#34d39926 0,#0000 50%),radial-gradient(circle at 50% 80%,#f59e0b1a 0,#0000 50%);bottom:0;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:-1}@keyframes confettiRotate{0%{transform:scale(1) rotate(0deg)}50%{transform:scale(1.1) rotate(2deg)}to{transform:scale(1) rotate(0deg)}}.ut-result-card.passed:before{background:linear-gradient(135deg,#10b981,#34d399,#059669)}.ut-result-card.failed:before,.ut-result-card.passed:before{border-radius:50%;content:"";filter:blur(10px);height:200px;left:-60px;opacity:.9;position:absolute;right:-60px;top:-60px;z-index:0}.ut-result-card.failed:before{background:linear-gradient(135deg,#f59e0b,#fbbf24,#d97706)}.ut-result-icon{align-items:center;background:#fff;border:4px solid #fff;border-radius:50%;box-shadow:0 10px 25px #0000001a;display:flex;height:90px;justify-content:center;margin:0 auto 24px;position:relative;width:90px;z-index:1}.ut-result-title{color:var(--gray-800);font-size:1.8rem;font-weight:800;margin:0 0 8px}.ut-result-score{color:var(--primary);font-size:4rem;font-weight:900;line-height:1;margin:16px 0;text-shadow:2px 2px 0 #0596691a}.ut-result-card.failed .ut-result-score{color:#f59e0b}.ut-result-detail{color:var(--gray-500);font-size:1rem;margin-bottom:24px}.ut-result-btn{background:linear-gradient(135deg,var(--primary),#047857);border:none;border-radius:30px;box-shadow:0 4px 12px #10b9814d;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:700;padding:14px 32px;transition:all .3s cubic-bezier(.34,1.56,.64,1);width:100%}.ut-result-btn:hover{background:linear-gradient(135deg,#059669,#065f46);box-shadow:0 8px 20px #10b98166;transform:translateY(-2px)}.ut-warning-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;display:flex;inset:0;justify-content:center;position:fixed;z-index:999}.ut-warning-card{animation:fadeIn .2s ease-out;background:#fff;border-radius:20px;max-width:400px;padding:32px;text-align:center}.ud-detail-page{animation:fadeIn .3s ease-out;padding-bottom:40px}.ud-detail-header{justify-content:space-between;margin-bottom:24px}.ud-back-btn,.ud-detail-header{align-items:center;display:flex}.ud-back-btn{background:#fff;border:1px solid var(--gray-200);border-radius:20px;box-shadow:0 2px 4px #00000005;color:var(--gray-700);cursor:pointer;font-weight:600;gap:8px;padding:8px 16px;transition:all .2s}.ud-back-btn:hover{background:var(--gray-50);border-color:var(--gray-300);transform:translateX(-4px)}.ud-passing-badge{background:#fef9c3;border:1px solid #fde047;border-radius:20px;color:#a16207;font-size:.85rem;font-weight:700;padding:6px 14px}.ud-detail-progress-card{background:#fff;border:1px solid var(--gray-100);border-radius:16px;box-shadow:0 4px 15px #00000008;margin-bottom:32px;padding:24px}.ud-detail-progress-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.ud-detail-progress-title{color:var(--gray-800);font-size:1.1rem;font-weight:700;margin:0}.ud-detail-progress-count{background:var(--primary-50);border-radius:20px;color:var(--primary);font-size:.85rem;font-weight:700;padding:4px 12px}.ud-detail-progress-bar-bg{background:var(--gray-100);border-radius:6px;height:12px;overflow:hidden;width:100%}.ud-detail-progress-fill{background:linear-gradient(90deg,var(--primary),#34d399);border-radius:6px;height:100%;transition:width 1s ease-in-out}.ud-timeline-vertical{display:flex;flex-direction:column;gap:0;padding-left:12px}.ud-time-step{display:flex;padding-bottom:32px;position:relative}.ud-time-step:last-child{padding-bottom:0}.ud-time-step:before{background:var(--gray-200);bottom:-4px;content:"";left:18px;position:absolute;top:36px;width:2px;z-index:0}.ud-time-step:last-child:before{display:none}.ud-time-step.completed:before{background:var(--primary)}.ud-step-icon-wrapper{align-items:center;background:#fff;border:2px solid var(--gray-300);border-radius:50%;color:var(--gray-400);display:flex;flex-shrink:0;height:40px;justify-content:center;margin-right:20px;transition:all .3s;width:40px;z-index:1}.ud-time-step.completed .ud-step-icon-wrapper{background:var(--primary);border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-50);color:#fff}.ud-time-step.current .ud-step-icon-wrapper{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-50);color:var(--primary)}.ud-step-content{background:#fff;border:1px solid var(--gray-200);border-radius:16px;box-shadow:0 2px 8px #00000005;flex:1 1;padding:24px;position:relative;transition:all .3s}.ud-time-step.current .ud-step-content{border-color:var(--primary-light);box-shadow:0 8px 20px #05966914}.ud-time-step.locked .ud-step-content{background:var(--gray-50);opacity:.7}.ud-step-title{color:var(--gray-800);font-size:1.1rem;margin:0 0 8px}.ud-step-desc{color:var(--gray-500);font-size:.9rem;line-height:1.5;margin:0 0 16px}.ud-step-actions{display:flex;flex-wrap:wrap;gap:12px}.ud-btn-action{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:600;gap:8px;padding:10px 20px;text-decoration:none;transition:all .2s}.ud-btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));box-shadow:0 4px 12px #0596694d;color:#fff}.ud-btn-primary:hover{box-shadow:0 6px 16px #05966966;transform:translateY(-2px)}.ud-btn-outline{background:#fff;border:1px solid var(--primary);color:var(--primary)}.ud-btn-outline:hover{background:var(--primary-50)}.ud-locked-msg{background:var(--gray-200);border-radius:8px;color:var(--gray-600);display:inline-block;font-size:.85rem;font-weight:600;padding:8px 16px}.ud-passed-msg{background:#dcfce7;color:#16a34a}.ud-failed-msg,.ud-passed-msg{border-radius:8px;display:inline-block;font-size:.85rem;font-weight:700;padding:8px 16px}.ud-failed-msg{background:#fee2e2;color:#dc2626}.ud-test-info{background:var(--gray-50);border:1px dashed var(--gray-300);border-radius:8px;color:var(--gray-600);display:flex;font-size:.85rem;gap:16px;margin-bottom:16px;padding:10px}.ud-viewer-container{animation:fadeIn .3s ease-out;background:#f1f5f9;border:1px solid var(--gray-300);border-radius:12px;box-shadow:0 4px 12px #0000000d;margin-top:16px;overflow:hidden}.ud-viewer-header{align-items:center;background:var(--gray-800);color:#fff;display:flex;font-size:.9rem;font-weight:600;justify-content:space-between;padding:8px 16px}.ud-viewer-close{background:#0000;border:none;color:#fff;cursor:pointer;opacity:.8;padding:4px;transition:opacity .2s}.ud-viewer-close:hover{opacity:1}.ud-viewer-iframe{border:none;display:block;height:500px;width:100%}:root{--primary:#009a3e;--primary-dark:#007a31;--primary-light:#dff5e7;--primary-50:#f8faf9;--green:#16a34a;--green-light:#dff5e7;--green-dark:#007a31;--red:#dc2626;--red-light:#fdecec;--orange:#f59e0b;--orange-light:#fff4db;--purple:#00b85c;--purple-light:#e8faf1;--gray-50:#f8faf9;--gray-100:#f8faf9;--gray-200:#dce8e0;--gray-300:#c9d8cf;--gray-400:#aabbb1;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#1e293b;--white:#fff;--shadow-sm:0 1px 2px #009a3e0f,0 1px 3px #007a310d;--shadow:0 2px 6px #009a3e14,0 1px 3px #007a310d;--shadow-md:0 4px 12px #009a3e1a,0 2px 6px #007a3112;--shadow-lg:0 8px 24px #009a3e1f;--radius:12px;--radius-sm:8px;--radius-xs:6px;--sidebar-w:260px;--topbar-h:64px;--transition:all 0.2s cubic-bezier(0.2,0,0,1)}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8faf9;background:var(--gray-50);color:#1e293b;color:var(--gray-900);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}a{color:#009a3e;color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}code{font-family:SF Mono,Fira Code,monospace;font-size:.8em}.app-loading,.loading{align-items:center;color:#475569;color:var(--gray-600);display:flex;font-size:.95rem;justify-content:center;min-height:60vh}.app-loading,.login-page{min-height:100vh}.login-page{align-items:center;background:#f8fafc;display:flex;justify-content:center;overflow:hidden;padding:20px;position:relative}.login-bg-shapes{inset:0;overflow:hidden;pointer-events:none;position:absolute;z-index:0}.login-bg-shapes span{animation:loginFloat linear infinite;border-radius:50%;display:block;opacity:.12;position:absolute}.login-bg-shapes .shape-1{animation-duration:18s;background:radial-gradient(circle,#0ea5e9 0,#0000 70%);height:600px;right:-100px;top:-250px;width:600px}.login-bg-shapes .shape-2{animation-delay:-4s;animation-duration:22s;background:radial-gradient(circle,#10b981 0,#0000 70%);bottom:-150px;height:400px;left:-80px;width:400px}.login-bg-shapes .shape-3{animation-delay:-8s;animation-duration:25s;background:radial-gradient(circle,#14b8a6 0,#0000 70%);height:300px;left:10%;top:30%;width:300px}.login-bg-shapes .shape-4{animation-delay:-2s;animation-duration:20s;background:radial-gradient(circle,#f59e0b 0,#0000 70%);bottom:20%;height:180px;right:15%;width:180px}.login-bg-shapes .cross{animation:loginDrift linear infinite;border-radius:0;height:40px;opacity:.06;width:40px}.login-bg-shapes .cross:before{background:currentColor;-webkit-clip-path:path("M14 0h12v14h14v12H26v14H14V26H0V14h14z");clip-path:path("M14 0h12v14h14v12H26v14H14V26H0V14h14z");content:"";inset:0;position:absolute}.login-bg-shapes .cross-1{animation-duration:30s;color:#0ea5e9;height:48px;left:5%;top:15%;width:48px}.login-bg-shapes .cross-2{animation-delay:-6s;animation-duration:35s;bottom:25%;color:#10b981;height:32px;right:8%;width:32px}.login-bg-shapes .cross-3{animation-delay:-12s;animation-duration:28s;color:#14b8a6;height:24px;left:50%;top:60%;width:24px}@keyframes loginFloat{0%{transform:translate(0) scale(1) rotate(0deg)}25%{transform:translate(40px,-30px) scale(1.05) rotate(5deg)}50%{transform:translate(-20px,20px) scale(.95) rotate(-3deg)}75%{transform:translate(30px,10px) scale(1.02) rotate(4deg)}to{transform:translate(0) scale(1) rotate(0deg)}}@keyframes loginDrift{0%{opacity:.06;transform:translateY(0) rotate(0deg)}50%{opacity:.1;transform:translateY(-120px) rotate(180deg)}to{opacity:.06;transform:translateY(0) rotate(1turn)}}.login-bg-wave{bottom:0;height:200px;left:0;pointer-events:none;position:absolute;right:0;z-index:0}.login-bg-wave svg{height:100%;width:100%}.login-card{animation:loginFadeIn .4s ease-out;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#ffffffd9;border:1px solid #fff9;border-radius:24px;box-shadow:0 8px 40px #0000000f,0 1px 4px #0000000a;max-width:400px;padding:36px 36px 32px;position:relative;width:100%;z-index:1}@keyframes loginFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-logo{margin-bottom:28px;text-align:center}.login-logo-img{border-radius:16px;box-shadow:0 2px 8px #00000014;height:68px;margin-bottom:12px;object-fit:cover;width:68px}.login-logo h1{color:#1e293b;color:var(--gray-900);font-size:1.4rem;font-weight:700;margin-bottom:2px}.login-logo p{color:#475569;color:var(--gray-600);font-size:.82rem}.login-field{margin-bottom:18px}.login-field label{color:#334155;color:var(--gray-700);display:block;font-size:.82rem;font-weight:600;margin-bottom:6px}.login-field input{background:#f8faf9;background:var(--gray-50);border:1.5px solid #c9d8cf;border:1.5px solid var(--gray-300);border-radius:6px;border-radius:var(--radius-xs);font-family:inherit;font-size:.92rem;padding:11px 14px;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-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:.82rem;margin-bottom:16px;padding:10px 14px}.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:.92rem;font-weight:600;margin-top:4px;padding:12px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition);width:100%}.login-btn:hover{background:#007a31;background:var(--primary-dark);box-shadow:0 1px 2px #009a3e0f,0 1px 3px #007a310d;box-shadow:var(--shadow-sm)}.login-btn:disabled{cursor:not-allowed;opacity:.6}.login-btn:active{transform:scale(.985)}.login-quick{border-bottom:1px solid #dce8e0;border-bottom:1px solid var(--gray-200);margin-bottom:24px;padding-bottom:20px}.login-quick-label{color:#64748b;color:var(--gray-500);font-size:.72rem;font-weight:600;letter-spacing:.04em;margin-bottom:10px;text-align:center;text-transform:uppercase}.login-quick-grid{display:flex;gap:8px}.login-quick-btn{align-items:center;background:#fff;background:var(--white);border:1px solid #dce8e0;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:.68rem;font-weight:600;gap:4px;padding:10px 6px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.login-quick-btn:hover{background:#f8faf9;background:var(--btn-bg,var(--gray-50));border-color:#c9d8cf;border-color:var(--btn-color,var(--gray-300));color:#1e293b;color:var(--btn-color,var(--gray-900))}.login-quick-btn:disabled{cursor:not-allowed;opacity:.5}.login-quick-btn svg{flex-shrink:0}.app-layout{display:flex;min-height:100vh}.sidebar{background:#fff;background:var(--white);border-right:1px solid #dce8e0;border-right:1px solid var(--gray-200);bottom:0;display:flex;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 #f8faf9;border-bottom:1px solid var(--gray-100);display:flex;gap:12px;padding:18px 20px 14px}.sidebar-logo-img{border-radius:10px;flex-shrink:0;height:38px;object-fit:cover;width:38px}.sidebar-logo-text{flex:1 1}.sidebar-logo-title{color:#1e293b;color:var(--gray-900);display:block;font-size:1rem;font-weight:700;line-height:1.3}.sidebar-logo-sub{display:block;font-size:.7rem;font-weight:500}.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:#f8faf9;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:.68rem;font-weight:600;gap:4px;margin-top:3px;padding:2px 10px}.sidebar-badge.admin-badge{background:#fff4db;background:var(--orange-light);color:#f59e0b;color:var(--orange)}.sidebar-pokja-info{border-bottom:1px solid #f8faf9;border-bottom:1px solid var(--gray-100);color:#334155;color:var(--gray-700);font-size:.8rem;padding:12px 20px}.sidebar-pokja-info strong{color:#1e293b;color:var(--gray-900);display:block}.sidebar-nav{flex:1 1;padding:8px 12px}.sidebar-section-label{color:#64748b;color:var(--gray-500);font-size:.68rem;font-weight:600;letter-spacing:.05em;padding:12px 12px 6px;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:.85rem;font-weight:500;gap:10px;margin-bottom:1px;padding:10px 12px;text-align:left;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition);width:100%}.sidebar-item:hover{background:#f8faf9;background:var(--gray-100);color:#1e293b;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:22px}.sidebar-item-count{background:#f8faf9;background:var(--gray-100);border-radius:10px;color:#475569;color:var(--gray-600);font-size:.7rem;font-weight:600;margin-left:auto;padding:1px 8px}.sidebar-item.active .sidebar-item-count{background:#009a3e;background:var(--primary);color:#fff}.sidebar-user{align-items:center;border-top:1px solid #f8faf9;border-top:1px solid var(--gray-100);display:flex;gap:10px;padding:14px 20px}.sidebar-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:.85rem;font-weight:700;height:34px;justify-content:center;width:34px}.sidebar-user-info{flex:1 1;min-width:0}.sidebar-user-name{color:#1e293b;color:var(--gray-800);display:block;font-size:.85rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-role{color:#64748b;color:var(--gray-500);display:block;font-size:.7rem;margin-top:1px}.sidebar-logout{background:none;border:none;border-radius:6px;color:#aabbb1;color:var(--gray-400);cursor:pointer;display:flex;padding:6px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.sidebar-logout:hover{background:#fdecec;background:var(--red-light);color:#dc2626;color:var(--red)}.sidebar-user-settings{background:none;border:none;border-radius:6px;color:#aabbb1;color:var(--gray-400);cursor:pointer;display:flex;padding:6px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.sidebar-user-settings:hover{background:var(--blue-light);color:var(--blue)}.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 #dce8e0;border-bottom:1px solid var(--gray-200);display:flex;gap:16px;height:64px;height:var(--topbar-h);padding:0 28px;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:#f8faf9;background:var(--gray-100)}.topbar-title{color:#1e293b;color:var(--gray-900);flex:1 1;font-size:1.05rem;font-weight:700}.topbar-user{align-items:center;border-radius:100px;color:#475569;color:var(--gray-600);cursor:pointer;display:flex;font-size:.82rem;gap:10px;padding:6px 12px 6px 6px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.topbar-user:hover{background:#f8faf9;background:var(--gray-50)}.topbar-user-avatar{align-items:center;background:#dff5e7;background:var(--primary-light);border-radius:50%;color:#009a3e;color:var(--primary);display:flex;font-size:.8rem;font-weight:700;height:30px;justify-content:center;width:30px}.topbar-user span{font-weight:500}.topbar-logout-btn{background:#f8faf9;background:var(--gray-100);border:none;border-radius:100px;color:#334155;color:var(--gray-700);cursor:pointer;font-family:inherit;font-size:.78rem;padding:6px 14px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.topbar-logout-btn:hover{background:#fdecec;background:var(--red-light);color:#dc2626;color:var(--red)}.content-area{padding:24px 28px}.dashboard-page{max-width:1200px}.dashboard-welcome{gap:16px;margin-bottom:24px}.dashboard-greeting{font-size:1.35rem;font-weight:700;margin-bottom:2px}.dashboard-subtitle{color:#64748b;color:var(--gray-500);font-size:.85rem;margin:0}.dashboard-badge{background:#dff5e7;background:var(--primary-light);border-radius:12px;flex-shrink:0;padding:8px 16px}.badge-progress{font-size:1.2rem;font-weight:700;line-height:1}.badge-label,.badge-progress{color:#009a3e;color:var(--primary)}.badge-label{font-size:.7rem;letter-spacing:1px;margin-top:2px;opacity:.7;text-transform:uppercase}.stats-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:28px}.stat-card{background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #009a3e0f,0 1px 3px #007a310d;box-shadow:var(--shadow-sm);padding:20px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.stat-card:hover{box-shadow:0 2px 6px #009a3e14,0 1px 3px #007a310d;box-shadow:var(--shadow);transform:translateY(-1px)}.stat-number{color:#1e293b;color:var(--gray-900);display:block;font-size:1.7rem;font-weight:800;line-height:1.2}.stat-label{color:#64748b;color:var(--gray-500);display:block;font-size:.78rem;font-weight:500;margin-top:4px}.overall-progress-bar{background:#f8faf9;background:var(--gray-100);border-radius:4px;height:8px;overflow:hidden}.overall-progress-fill{background:linear-gradient(90deg,#009a3e,#00b85c);background:linear-gradient(90deg,var(--primary),var(--purple));border-radius:4px;height:100%;transition:width .6s cubic-bezier(.2,0,0,1)}.progress-bar-section{background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #009a3e0f,0 1px 3px #007a310d;box-shadow:var(--shadow-sm);margin-bottom:20px;padding:16px 20px}.progress-bar-section h3{color:#1e293b;color:var(--gray-800);font-size:.88rem;font-weight:600;margin:0 0 4px}.chart-legend{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin-top:14px}.legend-item{align-items:center;color:#64748b;color:var(--gray-500);display:flex;font-size:.78rem;gap:6px}.legend-dot{border-radius:3px;flex-shrink:0;height:10px;width:10px}.page-header{margin-bottom:20px}.page-title{color:#1e293b;color:var(--gray-900);font-size:1.3rem;font-weight:700}.page-subtitle{color:#64748b;color:var(--gray-500);font-size:.85rem;margin-top:2px}.kelas-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.kelas-card{background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #009a3e0f,0 1px 3px #007a310d;box-shadow:var(--shadow-sm);cursor:pointer;padding:20px;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,0 2px 6px #007a3112;box-shadow:var(--shadow-md);transform:translateY(-2px)}.kelas-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.kelas-card-header h4{color:#1e293b;color:var(--gray-900);font-size:1rem;font-weight:700}.kelas-badge{border-radius:20px;font-size:.68rem;font-weight:600;padding:3px 10px;white-space:nowrap}.badge-belum{background:#eef2f7;color:#64748b}.badge-progress{background:#f3f4e8;color:#6b7a2a}.badge-selesai{background:#e3f6ea;color:#1f7a3a}.kelas-mini-progress{display:flex;gap:8px;margin-top:12px}.mini-step{background:#f8faf9;background:var(--gray-100);border-radius:20px;color:#64748b;color:var(--gray-500);font-size:.68rem;font-weight:500;padding:3px 10px}.mini-step[data-done=true]{background:#e8f8ee;color:#1f7a3a}.mini-step[data-current=true]{background:#edf7ee;color:#3d7a4e}.card-completed-badge{font-size:1.3rem;position:absolute;right:-6px;top:-6px}.kelas-card-footer{border-top:1px solid #f8faf9;border-top:1px solid var(--gray-100);color:#64748b;color:var(--gray-500);font-size:.75rem;margin-top:14px;padding-top:12px}.detail-page{padding:0}.detail-header{align-items:center;background:#fff;background:var(--white);border-bottom:1px solid #dce8e0;border-bottom:1px solid var(--gray-200);display:flex;gap:14px;padding:16px 28px}.detail-header h1,.detail-header h2{color:#1e293b;color:var(--gray-900);font-size:1.15rem;font-weight:700;margin:0}.back-button{align-items:center;background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:6px;border-radius:var(--radius-xs);color:#1e293b;color:var(--gray-800);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.85rem;font-weight:500;gap:6px;padding:8px 12px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.back-button:hover{background:#f8faf9;background:var(--primary-50);border-color:#dff5e7;border-color:var(--primary-light)}.pokja-status-card{grid-gap:14px;background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #009a3e0f,0 1px 3px #007a310d;box-shadow:var(--shadow-sm);display:grid;gap:14px;grid-template-columns:repeat(3,minmax(0,1fr));margin:24px 28px 0;padding:18px 20px}.pokja-status-item{min-width:0}.pokja-status-label{color:#64748b;color:var(--gray-500);display:block;font-size:.75rem;margin-bottom:6px}.pokja-status-value{align-items:center;display:flex}.status-badge{align-items:center;border-radius:999px;display:inline-flex;font-size:.8rem;font-weight:600;gap:6px;line-height:1;padding:7px 10px}.status-badge--completed{background:#e3f6ea;color:#1f7a3a}.status-badge--inprogress{background:#f3f4e8;color:#6b7a2a}.status-badge--notstarted{background:#eef2f7;color:#64748b}.pokja-content{background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #009a3e0f,0 1px 3px #007a310d;box-shadow:var(--shadow-sm);margin:18px 28px 24px;padding:20px}.pokja-header{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-bottom:16px}.pokja-title{color:#1e293b;color:var(--gray-900);font-size:.95rem;font-weight:700;margin:0}.pokja-actions{display:flex;flex-wrap:wrap;gap:10px}.pokja-btn{align-items:center;background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:10px;color:#1e293b;color:var(--gray-800);display:inline-flex;font:inherit;font-size:.85rem;font-weight:600;gap:6px;padding:8px 12px}.pokja-btn:hover{background:#f8faf9;background:var(--gray-50)}.pokja-btn.status-badge{border:0}.pokja-body{color:#1e293b;color:var(--gray-800);font-size:.92rem;line-height:1.7}.pokja-body iframe,.pokja-body img,.pokja-body video{border-radius:12px;max-width:100%}.pokja-download-btn{align-items:center;background:#009a3e;background:var(--primary);border-radius:10px;color:#fff;display:inline-flex;font-size:.85rem;font-weight:600;gap:8px;margin-top:18px;padding:10px 14px;text-decoration:none}.pokja-download-btn:hover{filter:brightness(.95)}@media (max-width:900px){.pokja-status-card{grid-template-columns:1fr;margin:18px 16px 0}.pokja-content{margin:16px 16px 20px}.detail-header{flex-wrap:wrap;padding:12px 16px}.pokja-header{align-items:flex-start;flex-direction:column}}.detail-content{max-width:780px;padding:24px 28px}.steps-timeline{padding-left:52px;position:relative}.steps-timeline:before{background:#dce8e0;background:var(--gray-200);bottom:22px;content:"";left:20px;position:absolute;top:22px;width:2px}.timeline-step{margin-bottom:18px;position:relative}.timeline-step:last-child{margin-bottom:0}.timeline-dot{align-items:center;background:#fff;background:var(--white);border:2px solid #c9d8cf;border:2px solid var(--gray-300);border-radius:50%;box-shadow:0 0 0 4px #f8faf9;box-shadow:0 0 0 4px var(--gray-50);color:#64748b;color:var(--gray-500);display:flex;height:42px;justify-content:center;left:-52px;position:absolute;top:2px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition);width:42px;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 4px #dff5e7;box-shadow:0 0 0 4px 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 4px #dff5e7;box-shadow:0 0 0 4px var(--primary-light);color:#fff}.timeline-step.locked .timeline-dot{background:#f8faf9;background:var(--gray-100);border-color:#c9d8cf;border-color:var(--gray-300);color:#aabbb1;color:var(--gray-400)}.timeline-content{background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:var(--radius);box-shadow:0 1px 2px #009a3e0f,0 1px 3px #007a310d;box-shadow:var(--shadow-sm);padding:18px 20px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.timeline-step.current .timeline-content{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-content h3{color:#1e293b;color:var(--gray-900);font-size:.95rem;font-weight:700;margin-bottom:8px}.timeline-step.locked .timeline-content{opacity:.6}.step-locked{color:#64748b;color:var(--gray-500);font-size:.82rem}.step-detail p{color:#334155;color:var(--gray-700);font-size:.85rem;line-height:1.5;margin-bottom:8px}.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:.82rem;font-weight:600;gap:6px;margin-bottom:8px;padding:8px 16px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.step-link-btn,.step-link-btn:hover{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:.82rem;font-weight:600;padding:8px 18px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.step-confirm-btn:hover{background:#007a31;background:var(--primary-dark)}.step-visit-btn{align-items:center;background:#f8faf9;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:.82rem;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.step-visit-btn:hover{background:#f8faf9;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:.88rem;font-weight:600;padding:10px 24px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.step-start-btn:hover{background:#007a31;background:var(--primary-dark)}.step-btn-group{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.test-passed{color:#237341}.test-failed,.test-passed{font-size:1.1rem;font-weight:700}.test-failed{color:#dc2626;color:var(--red)}.test-info{color:#64748b;color:var(--gray-500);font-size:.78rem}.test-score-badge{align-items:center;border-radius:50%;display:inline-flex;font-size:.85rem;font-weight:800;height:36px;justify-content:center;width:36px}.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)}.test-page{margin:0 auto;max-width:800px;padding:0 16px 100px}.test-header{background:#fff;background:var(--white);border-bottom:1px solid #dce8e0;border-bottom:1px solid var(--gray-200);margin:0 -28px;padding:16px 20px;position:-webkit-sticky;position:sticky;top:64px;top:var(--topbar-h);z-index:20}.test-title{align-items:center;color:#1e293b;color:var(--gray-900);display:flex;flex-wrap:wrap;font-size:1.05rem;font-weight:700;gap:10px}.attempt-badge{background:#edf7ee;color:#3d7a4e;font-weight:600}.attempt-badge,.passing-badge{border-radius:20px;font-size:.7rem;padding:2px 10px}.passing-badge{background:#e8f2ec;color:#2d6f45;font-weight:700}.test-timer-row{gap:20px;margin-top:10px}.test-timer,.test-timer-row{align-items:center;display:flex}.test-timer{font-feature-settings:"tnum";background:#f8faf9;background:var(--gray-50);border-radius:8px;color:#1e293b;color:var(--gray-800);font-size:.9rem;font-variant-numeric:tabular-nums;font-weight:700;gap:6px;padding:4px 12px}.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:.8rem;font-weight:500}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.test-questions{padding-top:20px}.question-card{background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #009a3e0f,0 1px 3px #007a310d;box-shadow:var(--shadow-sm);display:flex;gap:16px;margin-bottom:14px;padding:20px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.question-card:hover{border-color:#c9d8cf;border-color:var(--gray-300)}.question-number{color:#009a3e;color:var(--primary);flex-shrink:0;font-size:.85rem;font-weight:700;padding-top:2px;text-align:center;width:28px}.question-text{color:#1e293b;color:var(--gray-800);font-size:.9rem;line-height:1.5;margin-bottom:12px}.question-options{display:flex;flex-direction:column;gap:8px}.option-label{align-items:center;border:1.5px solid #dce8e0;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:10px;padding:10px 14px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.option-label:hover{background:#f8faf9;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:#1e293b;color:var(--gray-900)}.option-label input{display:none}.option-letter{align-items:center;background:#f8faf9;background:var(--gray-100);border-radius:50%;color:#475569;color:var(--gray-600);display:flex;flex-shrink:0;font-size:.72rem;font-weight:700;height:26px;justify-content:center;width:26px}.option-label.selected .option-letter{background:#009a3e;background:var(--primary);color:#fff}.option-text{flex:1 1}.test-footer{background:#fff;background:var(--white);border-top:1px solid #dce8e0;border-top:1px solid var(--gray-200);bottom:0;display:flex;gap:12px;justify-content:center;left:0;margin-left:260px;margin-left:var(--sidebar-w);padding:14px 28px;position:fixed;right:0}.test-cancel-btn{background:#f8faf9;background:var(--gray-100);border:none;border-radius:6px;border-radius:var(--radius-xs);color:#475569;color:var(--gray-600);cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:500;padding:10px 22px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.test-cancel-btn:hover{background:#dce8e0;background:var(--gray-200)}.test-submit-btn{background:#16a34a;background:var(--green);border:none;border-radius:6px;border-radius:var(--radius-xs);color:#fff;cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:600;padding:10px 24px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.test-submit-btn:disabled{cursor:not-allowed;opacity:.5}.test-submit-btn:not(:disabled):hover{background:#007a31;background:var(--green-dark)}.test-result{align-items:center;display:flex;justify-content:center;min-height:70vh;padding:20px}.result-card{background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:20px;box-shadow:0 8px 24px #009a3e1f;box-shadow:var(--shadow-lg);max-width:380px;padding:48px 40px;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:3.5rem}.result-card h2{font-size:1.3rem;font-weight:700;margin:12px 0 8px}.result-card.passed h2{color:#007a31;color:var(--green-dark)}.result-card.failed h2{color:#dc2626;color:var(--red)}.result-score{font-size:4.5rem;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:.85rem;margin-top:8px}.result-attempts{color:#f59e0b;color:var(--orange);font-size:.82rem;font-weight:500;margin-top:8px}.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:.95rem;font-weight:600;margin-top:24px;padding:12px 36px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.result-btn:hover{background:#007a31;background:var(--primary-dark)}.error-msg{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:.82rem;margin:16px 28px;padding:10px 16px}.superadmin-layout{display:flex;min-height:100vh}.sa-sidebar{background:#fff;background:var(--white);border-right:1px solid #dce8e0;border-right:1px solid var(--gray-200);bottom:0;display:flex;flex-direction:column;left:0;overflow-y:auto;position:fixed;top:0;width:260px;width:var(--sidebar-w);z-index:100}.sa-sidebar-header{align-items:center;border-bottom:1px solid #f8faf9;border-bottom:1px solid var(--gray-100);display:flex;gap:12px;padding:18px 20px 14px}.sa-logo-img{border-radius:10px;flex-shrink:0;height:38px;object-fit:cover;width:38px}.sa-nav-icon{align-items:center;display:flex;flex-shrink:0;justify-content:center;width:22px}.sa-brand-text{flex:1 1}.sa-brand-title{color:#1e293b;color:var(--gray-900);display:block;font-size:.95rem;font-weight:700}.sa-brand-sub{color:#64748b;color:var(--gray-500);display:block;font-size:.68rem;margin-top:1px}.sa-badge{align-items:center;background:#dff5e7;background:var(--primary-light);border-radius:20px;color:#009a3e;color:var(--primary);display:inline-flex;font-size:.68rem;font-weight:600;gap:4px;margin-top:3px;padding:2px 10px}.sa-badge.admin-badge{background:#fff4db;background:var(--orange-light);color:#f59e0b;color:var(--orange)}.sa-pokja-info{border-bottom:1px solid #f8faf9;border-bottom:1px solid var(--gray-100);color:#475569;color:var(--gray-600);font-size:.78rem;padding:12px 20px}.sa-pokja-info strong{color:#1e293b;color:var(--gray-900);display:block;font-size:.85rem;margin-bottom:2px}.sa-nav{flex:1 1;padding:8px 12px}.sa-nav-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:.85rem;font-weight:500;gap:10px;margin-bottom:1px;padding:10px 12px;text-align:left;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition);width:100%}.sa-nav-item:hover{background:#f8faf9;background:var(--gray-100);color:#1e293b;color:var(--gray-900)}.sa-nav-item.active{background:#dff5e7;background:var(--primary-light);color:#009a3e;color:var(--primary);font-weight:600}.sa-sidebar-footer{border-top:1px solid #f8faf9;border-top:1px solid var(--gray-100);padding:14px 20px}.sa-logout-btn{align-items:center;background:#f8faf9;background:var(--gray-50);border:1px solid #dce8e0;border:1px solid var(--gray-200);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;padding:10px 14px;text-align:left;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition);width:100%}.sa-logout-btn:hover{background:#fdecec;background:var(--red-light);border-color:#fdecec;border-color:var(--red-light);color:#dc2626;color:var(--red)}.sa-main{flex:1 1;margin-left:260px;margin-left:var(--sidebar-w);min-height:100vh;min-width:0}.sa-topbar{align-items:center;background:#fff;background:var(--white);border-bottom:1px solid #dce8e0;border-bottom:1px solid var(--gray-200);display:flex;height:64px;height:var(--topbar-h);justify-content:space-between;padding:0 28px;position:-webkit-sticky;position:sticky;top:0;z-index:50}.sa-topbar h1{color:#1e293b;color:var(--gray-900);font-size:1.05rem;font-weight:700}.sa-topbar-user{align-items:center;color:#475569;color:var(--gray-600);display:flex;font-size:.82rem;gap:10px}.sa-topbar-user-avatar{align-items:center;background:#dff5e7;background:var(--primary-light);border-radius:50%;color:#009a3e;color:var(--primary);display:flex;font-size:.8rem;font-weight:700;height:30px;justify-content:center;width:30px}.sa-topbar-user span{font-weight:500}.sa-logout-btn-sm{background:#f8faf9;background:var(--gray-100);border:none;border-radius:100px;color:#334155;color:var(--gray-700);cursor:pointer;font-family:inherit;font-size:.78rem;padding:6px 14px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.sa-logout-btn-sm:hover{background:#fdecec;background:var(--red-light);color:#dc2626;color:var(--red)}.sa-content{padding:24px 28px}.sa-stats-grid{grid-gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.sa-charts-grid,.sa-stats-grid{grid-gap:20px;display:grid;gap:20px;margin-bottom:24px}.sa-charts-grid{grid-gap:20px;grid-template-columns:1fr 1fr}@media (max-width:900px){.sa-charts-grid{grid-template-columns:1fr}}.sa-stat-card{background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #009a3e0f,0 1px 3px #007a310d;box-shadow:var(--shadow-sm);padding:20px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.sa-stat-card:hover{border-color:#c9d8cf;border-color:var(--gray-300);box-shadow:0 2px 6px #009a3e14,0 1px 3px #007a310d;box-shadow:var(--shadow);transform:translateY(-1px)}.sa-stat-card .sa-stat-icon{align-items:center;background:#dff5e7;background:var(--primary-light);border-radius:12px;color:#007a31;color:var(--primary-dark);display:flex;height:40px;justify-content:center;margin-bottom:12px;width:40px}.sa-stat-icon--blue{background:#dff5e7!important;background:var(--primary-light)!important;color:#007a31!important;color:var(--primary-dark)!important}.sa-stat-icon--green{background:#dff5e7!important;background:var(--green-light)!important;color:#007a31!important;color:var(--green-dark)!important}.sa-stat-icon--orange{background:#fff4db!important;background:var(--orange-light)!important;color:#f59e0b!important;color:var(--orange)!important}.sa-stat-icon--purple{background:#f8faf9!important;background:var(--primary-50)!important;color:#009a3e!important;color:var(--primary)!important}.sa-stat-number{color:#1e293b;color:var(--gray-900);font-size:1.7rem;font-weight:800;line-height:1.2}.sa-stat-label{color:#64748b;color:var(--gray-500);font-size:.78rem;font-weight:500;margin-top:4px}.sa-settings-card{background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #009a3e0f,0 1px 3px #007a310d;box-shadow:var(--shadow-sm);padding:20px 24px}.sa-settings-card-label{color:#64748b;color:var(--gray-500);font-size:.72rem;font-weight:500;letter-spacing:.03em;margin-bottom:2px;text-transform:uppercase}.sa-settings-card-value{color:#1e293b;color:var(--gray-900);font-size:1.3rem;font-weight:700}.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-blue{color:#009a3e!important;color:var(--primary)!important}.sa-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.sa-section-header h3{align-items:center;color:#1e293b;color:var(--gray-900);display:flex;font-size:1rem;font-weight:700;gap:8px}.sa-section-header .sa-count{background:#f8faf9;background:var(--gray-100);border-radius:20px;color:#64748b;color:var(--gray-500);font-size:.78rem;font-weight:500;padding:2px 10px}.sa-section-card{background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #009a3e0f,0 1px 3px #007a310d;box-shadow:var(--shadow-sm);margin-bottom:24px;padding:24px}.badge-preview-card{background:linear-gradient(180deg,#fff,#fbfdfb)}.badge-preview-grid{grid-gap:14px;display:grid;gap:14px}.badge-preview-label{color:#64748b;color:var(--gray-500);font-size:.78rem;font-weight:500;margin-bottom:8px}.badge-preview-row{display:flex;flex-wrap:wrap;gap:8px}.sa-section-card h3{color:#1e293b;color:var(--gray-900);font-size:1rem;font-weight:700;margin-bottom:16px}.sa-table-container{background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #009a3e0f,0 1px 3px #007a310d;box-shadow:var(--shadow-sm);margin-bottom:24px;overflow:hidden}.sa-table-header{align-items:center;display:flex;justify-content:space-between;padding:16px 20px 0}.sa-table-header h3{color:#1e293b;color:var(--gray-900);font-size:1rem;font-weight:700}.sa-table-wrap{border-radius:0 0 12px 12px;border-radius:0 0 var(--radius) var(--radius);max-width:100%;overflow-x:auto;padding:0 4px}.sa-table{border-collapse:collapse;font-size:.82rem;width:100%}.sa-table thead{background:#f8faf9;background:var(--gray-50)}.sa-table th{color:#475569;color:var(--gray-600);font-size:.75rem;font-weight:600;letter-spacing:.02em;padding:10px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.sa-table td,.sa-table th{border-bottom:1px solid #dce8e0;border-bottom:1px solid var(--gray-200)}.sa-table td{color:#1e293b;color:var(--gray-800);font-size:.82rem;padding:12px 16px}.sa-table tbody tr{transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.sa-table tbody tr:hover{background:#f8faf9;background:var(--primary-50)}.sa-table tbody tr:last-child td{border-bottom:none}.sa-table .mono{color:#334155;color:var(--gray-700);font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.78rem}.role-badge{font-size:.68rem;padding:3px 10px}.kunci-badge{align-items:center;background:#dff5e7;background:var(--green-light);border-radius:50%;color:#007a31;color:var(--green-dark);display:inline-flex;font-size:.72rem;font-weight:800;height:26px;justify-content:center;width:26px}.status-pass{color:#16a34a;color:var(--green)}.status-fail,.status-pass{font-size:.78rem;font-weight:600}.status-fail{color:#dc2626;color:var(--red)}.status-pending{color:#f59e0b;color:var(--orange);font-size:.78rem;font-weight:600}.sa-settings{max-width:500px}.sa-settings-grid{display:flex;flex-direction:column;gap:20px}.sa-setting-item label{color:#334155;color:var(--gray-700);display:block;font-size:.82rem;font-weight:600;margin-bottom:6px}.sa-setting-item input{border:1.5px solid #c9d8cf;border:1.5px solid var(--gray-300);border-radius:6px;border-radius:var(--radius-xs);font-family:inherit;font-size:.92rem;padding:10px 14px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition);width:120px}.sa-setting-item input:focus{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}.sa-setting-item .setting-hint{color:#64748b;color:var(--gray-500);font-size:.72rem;margin-top:4px}.sa-import{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(340px,1fr))}.sa-import-section{background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #009a3e0f,0 1px 3px #007a310d;box-shadow:var(--shadow-sm);padding:24px}.sa-import-section h3{color:#1e293b;color:var(--gray-900);font-size:1rem;font-weight:700;margin-bottom:8px}.sa-import-section p{color:#64748b;color:var(--gray-500);font-size:.82rem;line-height:1.5;margin-bottom:6px}.sa-import-section code{background:#f8faf9;background:var(--gray-100);border-radius:4px;color:#334155;color:var(--gray-700);font-size:.78rem;padding:2px 8px}.sa-import-section .file-input-wrap{margin-top:14px}.sa-import-section input[type=file]{color:#334155;color:var(--gray-700);font-family:inherit;font-size:.82rem}.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:12px;padding:8px 16px;-webkit-transition:all .2s cubic-bezier(.2,0,0,1);transition:all .2s cubic-bezier(.2,0,0,1);-webkit-transition:var(--transition);transition:var(--transition)}.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:12px;padding:8px 16px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.sa-import-section input[type=file]::-webkit-file-upload-button:hover{background:#007a31;background:var(--primary-dark)}.sa-import-section input[type=file]::file-selector-button:hover{background:#007a31;background:var(--primary-dark)}.sa-import-msg{background:#dff5e7;background:var(--green-light);border-left:3px solid #16a34a;border-left:3px solid var(--green);color:#007a31;color:var(--green-dark)}.sa-import-loading,.sa-import-msg{border-radius:6px;border-radius:var(--radius-xs);font-size:.82rem;grid-column:1/-1;padding:12px 18px}.sa-import-loading{background:#dff5e7;background:var(--primary-light);color:#009a3e;color:var(--primary)}.soal-text{max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sa-overview-header{margin-bottom:24px}.sa-overview-header h2{color:#1e293b;color:var(--gray-900);font-size:1.25rem;font-weight:700}.sa-overview-header p{color:#64748b;color:var(--gray-500);font-size:.85rem;margin-top:2px}.sa-analytics-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-top:8px}.sa-analytic-card{background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #009a3e0f,0 1px 3px #007a310d;box-shadow:var(--shadow-sm);padding:18px 20px}.sa-analytic-card h4{color:#1e293b;color:var(--gray-800);font-size:.88rem;font-weight:600;margin-bottom:8px}.sa-analytic-row{align-items:center;border-bottom:1px solid #f8faf9;border-bottom:1px solid var(--gray-100);color:#334155;color:var(--gray-700);display:flex;font-size:.82rem;justify-content:space-between;padding:6px 0}.sa-analytic-row:last-child{border-bottom:none}@media (max-width:768px){:root{--sidebar-w:0px;--topbar-h:56px}.sidebar{transform:translateX(-100%);transition:transform .25s cubic-bezier(.2,0,0,1);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}.hamburger{display:flex}.topbar-user span{display:none}.sa-sidebar{transform:translateX(-100%);transition:transform .25s cubic-bezier(.2,0,0,1);width:280px}.sa-sidebar.open{transform:translateX(0)}.sa-sidebar-overlay{background:#0000004d;display:block;inset:0;position:fixed;z-index:99}.sa-main{margin-left:0}.stats-grid{grid-template-columns:repeat(2,1fr)}.kelas-grid{grid-template-columns:1fr}.sa-stats-grid{grid-template-columns:repeat(2,1fr)}.sa-import{grid-template-columns:1fr}.content-area,.detail-content,.sa-content{padding:16px}.detail-header{flex-wrap:wrap;padding:12px 16px}.test-footer{margin-left:0}.test-header{margin:0 -16px}.sa-analytics-grid{grid-template-columns:1fr}.sa-table-header{align-items:flex-start;flex-direction:column;gap:12px}.sa-table-header>div{justify-content:flex-start;width:100%}}.search-wrap{position:relative}.search-input{background:#f8faf9;background:var(--gray-50);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:8px;font-family:inherit;font-size:.82rem;padding:8px 12px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition);width:200px}.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}.search-input::placeholder{color:#aabbb1;color:var(--gray-400)}.soal-form{background:#f8faf9;background:var(--gray-50);border-bottom:1px solid #dce8e0;border-bottom:1px solid var(--gray-200);padding:20px}.soal-form h4{color:#1e293b;color:var(--gray-900);font-size:.9rem;font-weight:700;margin-bottom:12px}.soal-form-msg{background:#f8faf9;background:var(--gray-100);border-radius:6px;color:#334155;color:var(--gray-700);font-size:.82rem;margin-bottom:12px;padding:8px 12px}.soal-form-grid{grid-gap:12px;display:grid;gap:12px;margin-bottom:12px}.soal-form-choices,.soal-form-grid{grid-template-columns:1fr 1fr}.soal-form-row{display:flex;flex-direction:column;gap:4px}.soal-form-row label{color:#475569;color:var(--gray-600);font-size:.75rem;font-weight:600}.soal-form-row input,.soal-form-row select,.soal-form-row textarea{background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:6px;font-family:inherit;font-size:.82rem;padding:8px 10px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.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 #dce8e0;border-top:1px solid var(--gray-200);display:flex;gap:8px;margin-top:16px;padding-top:12px}.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;font-size:.85rem;height:30px;justify-content:center;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition);width:30px}.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)}.btn-primary{align-items:center;background:#009a3e;background:var(--primary);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.85rem;font-weight:600;gap:6px;padding:10px 20px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.btn-primary:hover{background:#007a31;background:var(--primary-dark)}.btn-primary:disabled{cursor:not-allowed;opacity:.5}.btn-secondary{align-items:center;background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:8px;color:#334155;color:var(--gray-700);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.85rem;font-weight:500;gap:6px;padding:10px 20px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.btn-secondary:hover{background:#f8faf9;background:var(--gray-50);border-color:#c9d8cf;border-color:var(--gray-300)}.warning-overlay{align-items:center;animation:fadeIn .15s ease-out;background:#0006;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.warning-card{animation:slideUp .2s ease-out;background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:18px;box-shadow:0 20px 60px #0000001f;max-width:420px;padding:28px 24px 22px;text-align:center;width:100%}.delete-confirm-card{max-width:440px}.delete-confirm-card .warning-icon{background:#fdecec;background:var(--red-light);color:#dc2626;color:var(--red)}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.warning-icon{align-items:center;background:#fff4db;background:var(--orange-light);border-radius:50%;color:#f59e0b;color:var(--orange);display:flex;font-size:1.35rem;font-weight:800;height:44px;justify-content:center;margin:0 auto 14px;width:44px}.warning-card h3{color:#1e293b;color:var(--gray-900);font-size:1rem;font-weight:800;letter-spacing:-.01em;margin-bottom:6px}.warning-card p{color:#475569;color:var(--gray-600);font-size:.86rem;line-height:1.45}.warning-card .warning-sub{color:#64748b;color:var(--gray-500);font-size:.8rem;margin-top:4px}.warning-actions{display:flex;flex-direction:column;gap:10px;margin-top:18px}.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:12px 20px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.warning-btn-primary:hover{background:#b91c1c}.warning-btn-secondary{background:#0000;border:1px solid #0000;border-radius:10px;color:#475569;color:var(--gray-600);cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:600;padding:12px 20px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.warning-btn-secondary:hover{background:#fdecec;background:var(--red-light);color:#dc2626;color:var(--red)}.crud-modal-overlay{align-items:center;animation:fadeIn .15s ease-out;background:#00000073;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.crud-modal{animation:slideUp .2s ease-out;background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:16px;box-shadow:0 20px 60px #00000024;max-height:85vh;max-width:560px;overflow-y:auto;padding:28px 28px 24px;width:100%}.crud-modal h4{border-bottom:1px solid #f8faf9;border-bottom:1px solid var(--gray-100);color:#1e293b;color:var(--gray-900);font-size:1rem;font-weight:700;margin-bottom:16px;padding-bottom:12px}.crud-modal .soal-form-msg{background:#f8faf9;background:var(--gray-100);border-radius:6px;color:#334155;color:var(--gray-700);font-size:.82rem;margin-bottom:12px;padding:8px 12px}.crud-modal .soal-form-grid{grid-gap:12px;display:grid;gap:12px;margin-bottom:8px}.crud-modal .soal-form-choices,.crud-modal .soal-form-grid{grid-template-columns:1fr 1fr}.crud-modal .soal-form-row{display:flex;flex-direction:column;gap:4px}.crud-modal .soal-form-row label{color:#475569;color:var(--gray-600);font-size:.75rem;font-weight:600}.crud-modal .soal-form-row input,.crud-modal .soal-form-row select,.crud-modal .soal-form-row textarea{background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:6px;font-family:inherit;font-size:.82rem;padding:8px 10px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.crud-modal .soal-form-row input:focus,.crud-modal .soal-form-row select:focus,.crud-modal .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}.crud-modal .soal-form-actions{border-top:1px solid #dce8e0;border-top:1px solid var(--gray-200);display:flex;gap:8px;margin-top:16px;padding-top:12px}.sa-table-wrap .sa-pagination{align-items:center;border-top:1px solid #f8faf9;border-top:1px solid var(--gray-100);display:flex;flex-wrap:wrap;gap:4px;justify-content:center;padding:14px 20px}.sa-page-btn{font-size:.8rem;height:32px;line-height:1;min-width:32px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.sa-page-btn.active{background:#009a3e;background:var(--primary);border-color:#009a3e;border-color:var(--primary);box-shadow:0 2px 6px #1a73e84d;color:#fff;color:var(--white);font-weight:600}.sa-page-btn:disabled{cursor:not-allowed;opacity:.35}.sa-page-btn:first-child,.sa-page-btn:last-child{font-weight:500;padding:0 12px}.sa-page-dots{align-items:center;color:#aabbb1;color:var(--gray-400);display:inline-flex;font-size:.85rem;height:32px;justify-content:center;letter-spacing:1px;min-width:32px;-webkit-user-select:none;user-select:none}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mb-16{margin-bottom:16px}.text-sm{font-size:.82rem}.text-xs{font-size:.72rem}.text-muted{color:#64748b;color:var(--gray-500)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.flex{display:flex}.flex-center{align-items:center;display:flex}.gap-8{gap:8px}.gap-12{gap:12px}.toast-container{display:flex;flex-direction:column;gap:8px;pointer-events:none;position:fixed;right:16px;top:16px;z-index:10000}.toast{align-items:center;animation:toast-slide-in .3s ease-out;background:#fff;border-left:4px solid #64748b;border-radius:10px;box-shadow:0 4px 20px #0000001f,0 1px 3px #0000000f;color:#1e293b;display:flex;font-size:.88rem;font-weight:500;gap:10px;max-width:400px;padding:12px 20px;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-icon{font-size:1.1rem}.toast-message{flex:1 1}.modal-overlay{align-items:center;animation:fadeIn .15s ease-out;background:#00000073;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:999}.modal-card{animation:modalPop .2s ease-out;background:#fff;background:var(--white);border-radius:16px;box-shadow:0 8px 24px #009a3e1f;box-shadow:var(--shadow-lg);max-width:420px;padding:24px;width:90%}@keyframes modalPop{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.form-input{background:#fff;background:var(--white);border:1.5px solid #dce8e0;border:1.5px solid var(--gray-200);border-radius:8px;box-sizing:border-box;color:#1e293b;color:var(--gray-800);font-size:.85rem;outline:none;padding:9px 12px;transition:border-color .15s;width:100%}.form-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #3b82f61a}.form-label{color:#475569;color:var(--gray-600);display:block;font-size:.78rem;font-weight:600;margin-bottom:4px}.topbar-settings-btn{background:none;border:none;border-radius:6px;color:#64748b;color:var(--gray-500);cursor:pointer;display:inline-flex;padding:6px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.topbar-settings-btn:hover{background:var(--blue-light);color:var(--blue)}@keyframes toast-slide-in{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.certificate-wrapper{-webkit-overflow-scrolling:touch;align-items:center;display:flex;flex-direction:column;overflow-x:auto;padding-bottom:20px;width:100%}.certificate-preview{background:#fff;height:1123px;margin:0 auto;min-width:794px;position:relative;width:794px}.cert-border-outer{background:#fff;padding:30px;width:100%}.cert-border-inner,.cert-border-outer{box-sizing:border-box;height:100%;position:relative}.cert-border-inner{border:12px solid #007a31;border:12px solid var(--primary-dark);border-radius:2px;outline:4px solid #dff5e7;outline:4px solid var(--primary-light);outline-offset:-18px;overflow:hidden;padding:60px 50px}.cert-border-inner,.cert-header{align-items:center;display:flex;flex-direction:column}.cert-header{gap:16px;margin-bottom:20px;position:relative;text-align:center;width:100%;z-index:2}.cert-logo{height:90px;object-fit:contain;width:90px}.cert-header-text{text-align:center;width:100%}.cert-institution{color:#334155;color:var(--gray-700);font-size:.95rem;font-weight:700;letter-spacing:3px;margin-bottom:8px;text-transform:uppercase}.cert-title{color:#007a31;color:var(--primary-dark);font-size:2.2rem;font-weight:800;letter-spacing:5px;margin-bottom:4px;text-transform:uppercase}.cert-subtitle{color:#64748b;color:var(--gray-500);font-size:1rem;letter-spacing:1px}.cert-divider{background:#009a3e;background:var(--primary);height:3px;margin:24px auto;position:relative;width:120px;z-index:2}.cert-divider-sm{background:#dff5e7;background:var(--primary-light);height:2px;margin:20px auto;width:60px}.cert-body{flex:1 1;margin:20px 0;position:relative;text-align:center;z-index:2}.cert-greeting{color:#475569;color:var(--gray-600);font-size:1.1rem;font-style:italic;margin:0 0 20px}.cert-name{color:#1e293b;color:var(--gray-900);font-family:Georgia,Times New Roman,serif;font-size:3rem;font-weight:700;margin:0 0 10px;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:8px}.cert-nip{color:#64748b;color:var(--gray-500);font-size:1.1rem;margin:0 0 40px}.cert-description{color:#334155;color:var(--gray-700);font-size:1.15rem;line-height:1.8;margin:0 auto;max-width:550px}.cert-footer{align-items:flex-end;display:flex;justify-content:space-between;margin-top:auto;padding-top:40px;position:relative;width:100%;z-index:2}.cert-footer-left{text-align:left}.cert-serial-title{color:#64748b;color:var(--gray-500);font-size:.8rem;letter-spacing:1px;text-transform:uppercase}.cert-serial-number{color:#1e293b;color:var(--gray-900);font-family:Courier New,monospace;font-size:1rem;font-weight:600;margin-top:4px}.cert-footer-right{text-align:center}.cert-signature-line{background:#1e293b;background:var(--gray-900);height:1px;margin-bottom:8px;width:220px}.cert-signature-label{color:#1e293b;color:var(--gray-800);font-size:.95rem;font-weight:700;line-height:1.4}.cert-date{color:#475569;color:var(--gray-600);font-size:.95rem;margin-top:6px}.cert-watermark-img{left:50%;opacity:.05;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:400px;z-index:0}@media (max-width:800px){.certificate-wrapper{align-items:flex-start}.certificate-preview{margin:0}}@media (max-width:600px){.cert-border-outer{padding:10px}.cert-border-inner{padding:30px 20px}.cert-name{font-size:1.8rem}.cert-title{font-size:1.4rem}.cert-logo{height:60px;width:60px}.cert-institution{font-size:.7rem}.cert-watermark-img{width:300px}}.test-score-table-wrap{-webkit-overflow-scrolling:touch;max-width:100%;scrollbar-width:thin}.test-score-table-wrap:after{background:linear-gradient(180deg,#fff0,#fff);background:linear-gradient(180deg,#fff0,var(--white));color:#64748b;color:var(--gray-500);content:"Geser tabel ke samping untuk melihat semua kolom";display:none;font-size:.72rem;padding:8px 14px 12px}.test-score-table{min-width:760px}.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{background:#fff;background:var(--white);box-shadow:1px 0 0 #dce8e0;box-shadow:1px 0 0 var(--gray-200);left:0;max-width:220px;min-width:220px;position:-webkit-sticky;position:sticky;text-align:left;width:220px;z-index:1}.test-score-table th:first-child{background:#f8faf9;background:var(--gray-50);z-index:2}.test-score-table td:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.test-score-table tbody tr:hover td:first-child{background:#f8faf9;background:var(--primary-50)}.test-score-table .status-badge{white-space:nowrap}@media (max-width:768px){.test-score-table-wrap:after{display:block}.test-score-table{font-size:.72rem;min-width:680px;width:-webkit-max-content;width:max-content}.test-score-table td,.test-score-table th{font-size:.7rem;padding:7px 8px}.test-score-table td:first-child,.test-score-table th:first-child{max-width:130px;min-width:130px;width:130px}.test-score-table .status-badge{font-size:.7rem;padding:6px 8px}}@media (max-width:480px){.test-score-table{min-width:620px}.test-score-table td,.test-score-table th{padding:6px}.test-score-table td:first-child,.test-score-table th:first-child{max-width:118px;min-width:118px;width:118px}}.app-main,.content-area,.dashboard-page,.sa-section-card,.sa-table-wrap,.test-score-table-wrap{box-sizing:border-box;max-width:100%;min-width:0}.dashboard-page{overflow-x:hidden;width:100%}.test-score-table-wrap{contain:inline-size;display:block;overflow-x:auto;overflow-y:hidden;overscroll-behavior-x:contain;width:100%}.test-score-table{max-width:100%;table-layout:fixed;width:100%}@media (max-width:768px){#root,body,html{max-width:100%;overflow-x:hidden}.content-area{max-width:100vw;width:100%}.stats-grid{max-width:100%;width:100%}.test-score-table-wrap{border-radius:0 0 12px 12px;border-radius:0 0 var(--radius) var(--radius);margin-left:0;margin-right:0}}.test-score-table td:nth-child(8){text-align:left}.topbar-user-dropdown{display:inline-block;position:relative}.topbar-user-dropdown summary{cursor:pointer;list-style:none}.topbar-dropdown-menu{background:#fff;background:var(--white);border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 4px 12px #009a3e1a,0 2px 6px #007a3112;box-shadow:var(--shadow-md);margin-top:8px;min-width:160px;padding:8px 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:.88rem;font-weight:500;padding:10px 16px;text-align:left;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition);width:100%}.topbar-dropdown-item:hover{background:#f8faf9;background:var(--gray-50);color:#009a3e;color:var(--primary)}.kelas-tabs{gap:12px;margin-bottom:24px}.kelas-tab-btn{box-shadow:0 1px 2px #00000005;font-weight:500;transition:all .2s ease}.kelas-tab-btn:hover{background:var(--gray-50)}.kelas-tab-btn.active{border-color:#009a3e;border-color:var(--primary);box-shadow:0 4px 10px #0d948833}.kelas-sections{gap:36px}.kelas-section-title{align-items:center;color:#1e293b;color:var(--gray-800);display:flex;font-size:1rem;font-weight:700;gap:8px}.kelas-card-done{filter:grayscale(20%);opacity:.7}.kelas-empty{background:#fff;border:1px dashed #c9d8cf;border:1px dashed var(--gray-300);border-radius:12px;color:#64748b;color:var(--gray-500);font-size:.9rem;padding:30px;text-align:center}.mobile-bottom-nav{display:none}@media (max-width:768px){.mobile-bottom-nav{align-items:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#fffffff2;border-top:1px solid #dce8e0;border-top:1px solid var(--gray-200);bottom:0;box-shadow:0 -4px 12px #0000000d;display:flex;height:65px;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;text-decoration:none;transition:all .2s ease}.mobile-bottom-nav-item.active{color:#009a3e;color:var(--primary)}.mobile-bottom-nav-icon{margin-bottom:4px;transition:transform .2s ease}.mobile-bottom-nav-item.active .mobile-bottom-nav-icon{transform:translateY(-2px)}.mobile-bottom-nav-label{font-size:.65rem;font-weight:600}.app-main{padding-bottom:80px}.hamburger:not(.sa-topbar .hamburger),.sidebar,.sidebar-overlay{display:none!important}.sa-topbar .hamburger{display:flex!important}.test-footer{bottom:65px;z-index:998}.test-questions{padding-bottom:120px}}.id-card-wrapper{background:#fff;border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:16px;box-shadow:0 10px 30px #00000014;max-width:340px}.id-card-header{background:linear-gradient(135deg,#009a3e,#007a31);background:linear-gradient(135deg,var(--primary),var(--primary-dark));height:120px;padding-top:16px}.id-card-watermark{opacity:.05;transform:translate(-50%,-40%);width:200px}.id-card-body{padding:0 24px 32px}.twibbon-modal-overlay{align-items:center;background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:20px;position:fixed;right:0;top:0;z-index:9999}.twibbon-modal-content{background:#0000;border-radius:20px;display:flex;flex-direction:column;gap:16px;margin:auto;max-width:420px;padding:0;position:relative;width:100%}.twibbon-close{background:#fff;border:none;border-radius:50%;color:#1e293b;color:var(--gray-900);cursor:pointer;font-size:1.5rem;height:32px;justify-content:center;position:absolute;right:0;top:-40px;width:32px;z-index:10}.twibbon-card,.twibbon-close{align-items:center;display:flex}.twibbon-card{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-radius:24px;box-shadow:0 20px 50px #0003;flex-direction:column;min-height:-webkit-max-content;min-height:max-content;overflow:hidden;padding:30px 20px;position:relative;width:100%}.twibbon-bg{background-image:radial-gradient(#22c55e 1.5px,#0000 0);background-size:24px 24px;bottom:0;left:0;opacity:.15;position:absolute;right:0;top:0;z-index:0}.twibbon-bg:before{background:#bbf7d0;border-radius:40% 60% 70% 30%/40% 50% 60% 50%;content:"";filter:blur(30px);height:250px;left:-10%;opacity:.6;position:absolute;top:-10%;width:250px}.twibbon-bg:after{background:#86efac;border-radius:60% 40% 30% 70%/60% 30% 70% 40%;bottom:-10%;content:"";filter:blur(35px);height:300px;opacity:.5;position:absolute;right:-10%;width:300px}.twibbon-logo{background:#fff;border-radius:50%;box-shadow:0 4px 10px #0000000d;height:48px;margin-bottom:20px;object-fit:contain;padding:6px;position:relative;z-index:1}.twibbon-hero-text{align-items:center;display:flex;flex-direction:column;margin-bottom:24px;position:relative;text-align:center;z-index:1}.twibbon-hero-text .saya-siap{color:#1e293b;font-size:2.2rem;font-weight:900;letter-spacing:-1px;line-height:1;margin-bottom:-2px;text-transform:uppercase;transform:rotate(-2deg)}.twibbon-hero-text .akreditasi{color:#16a34a;font-size:3rem;font-weight:900;letter-spacing:-2px;line-height:1;position:relative;text-shadow:3px 3px 0 #fff,-3px -3px 0 #fff,3px -3px 0 #fff,-3px 3px 0 #fff,0 8px 15px #00000026;text-transform:uppercase;transform:rotate(-1deg) scale(1.05)}.twibbon-avatar-wrapper{background:#fff;border:8px solid #fff;border-radius:50%;box-shadow:0 10px 30px #00000026;height:220px;margin-bottom:24px;position:relative;width:220px;z-index:1}.twibbon-avatar-img{border-radius:50%;height:100%;object-fit:cover;width:100%}.twibbon-avatar-placeholder{background:#dff5e7;background:var(--primary-light);color:#009a3e;color:var(--primary);font-size:5rem;font-weight:800;height:100%;width:100%}.twibbon-avatar-badge,.twibbon-avatar-placeholder{align-items:center;border-radius:50%;display:flex;justify-content:center}.twibbon-avatar-badge{background:#16a34a;border:5px solid #fff;bottom:5px;box-shadow:0 4px 12px #0003;color:#fff;height:56px;position:absolute;right:5px;width:56px}.twibbon-info{align-items:center;background:#fffffff2;border-radius:20px;box-shadow:0 10px 30px #0000000d;display:flex;flex-direction:column;padding:16px;position:relative;width:90%;z-index:1}.twibbon-name{color:#0f172a;font-size:1.6rem;font-weight:900;margin-bottom:12px}.twibbon-badge{background:#15803d;border-radius:20px;color:#fff;font-size:.65rem;font-weight:700;gap:8px;margin-bottom:12px;padding:6px 12px;text-align:center}.twibbon-badge,.twibbon-title{align-items:center;display:flex;text-transform:uppercase}.twibbon-title{color:#16a34a;font-size:1.4rem;font-weight:900;gap:12px;line-height:1.2;position:relative}.twibbon-footer{align-items:center;display:flex;flex-direction:column;gap:12px;margin-top:auto;position:relative;width:100%;z-index:1}.twibbon-cursive{color:#15803d;font-family:Caveat,cursive,Comic Sans MS,sans-serif;font-size:1.3rem;transform:rotate(-2deg)}.twibbon-pill{align-items:center;background:#fff9;border-radius:30px;display:flex;gap:12px;padding:8px 16px;width:90%}.twibbon-pill-icon{align-items:center;background:#bbf7d0;border-radius:50%;color:#16a34a;display:flex;height:36px;justify-content:center;width:36px}.twibbon-pill-text{color:#1e293b;font-size:.6rem;font-weight:800;line-height:1.3;text-align:left}.id-card-wrapper{aspect-ratio:9/16;background:#f8fafc;border:1px solid #00000005;border-radius:32px;box-shadow:0 20px 40px #0000001a;flex-direction:column;margin:0 auto 24px;max-width:380px}.id-card-header,.id-card-wrapper{display:flex;overflow:hidden;position:relative}.id-card-header{align-items:flex-start;background:linear-gradient(135deg,#15803d,#16a34a);border-bottom-left-radius:50% 20px;border-bottom-right-radius:50% 20px;flex-shrink:0;height:200px;justify-content:center;padding-top:24px}.id-card-header:before{background:radial-gradient(circle,#ffffff26 0,#fff0 70%);height:150px;right:-40px;top:-40px;width:150px}.id-card-header:after,.id-card-header:before{border-radius:50%;content:"";position:absolute}.id-card-header:after{background:radial-gradient(circle,#ffffff1a 0,#fff0 70%);bottom:-50px;height:200px;left:-20px;width:200px}.id-card-logo-box{align-items:center;display:flex;flex-direction:column;gap:8px;z-index:1}.id-card-logo-icon{align-items:center;background:#0000;display:flex;justify-content:center}.id-card-logo-text{align-items:center;color:#fff;display:flex;flex-direction:column;text-align:center}.id-card-logo-text strong{font-size:.9rem;font-weight:800;letter-spacing:.5px}.id-card-logo-text span{font-size:.65rem;opacity:.9}.id-card-watermark{left:50%;opacity:.03;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:240px;z-index:0}.id-card-body{display:flex;flex:1 1;flex-direction:column;margin-top:-75px;padding:0 24px 24px;position:relative;text-align:center}.id-card-avatar-wrap{background:#fff;background:var(--white);border-radius:50%;box-shadow:0 10px 25px #00000026;flex-shrink:0;height:150px;margin:0 auto 12px;padding:6px;position:relative;transition:transform .2s;width:150px;z-index:2}.id-card-avatar-wrap:hover .avatar-edit-overlay{opacity:1}.id-card-avatar{background:#dff5e7;background:var(--primary-light);color:#009a3e;color:var(--primary);font-size:3rem;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;border:4px solid #fff;bottom:0;box-shadow:0 4px 10px #0000001a;height:32px;position:absolute;right:10px;width:32px;z-index:3}.avatar-edit-icon{display:none}.avatar-edit-overlay{align-items:center;background:#00000080;border-radius:50%;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .2s;z-index:4}.id-card-name{color:#1e293b;font-size:1.8rem;font-weight:900;line-height:1.2;margin-bottom:8px}.id-card-nip{background:#fff;border-radius:20px;box-shadow:0 2px 10px #0000000d;color:#16a34a;display:inline-block;font-size:.85rem;font-weight:800;letter-spacing:1.5px;margin-bottom:12px;padding:4px 14px}.id-card-subtitle{align-items:center;color:#64748b;display:flex;font-size:.75rem;font-weight:800;gap:8px;justify-content:center;letter-spacing:2px;margin-bottom:16px;text-transform:uppercase}.id-card-details{background:#fff;border-radius:24px;box-shadow:0 5px 20px #00000008;display:flex;flex-direction:column;padding:20px;position:relative;z-index:1}.id-card-row{align-items:center;border-bottom:1px dashed #e2e8f0;display:flex;gap:16px;padding:8px 0}.id-card-row:last-child{border-bottom:none;padding-bottom:0}.id-card-row:first-child{padding-top:0}.id-card-icon{align-items:center;background:#16a34a;border-radius:50%;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.id-card-text{align-items:flex-start;display:flex;flex-direction:column;text-align:left}.id-card-text .label{color:#94a3b8;font-size:.65rem;font-weight:800;letter-spacing:.5px;margin-bottom:2px}.id-card-text .value{color:#0f172a;font-size:.95rem;font-weight:800}.id-card-badge-shift{align-items:center;background:#dcfce7;border-radius:12px;color:#16a34a;display:flex;font-size:.7rem;font-weight:800;gap:4px;padding:6px 10px}.id-card-bottom-section{align-items:flex-end;display:flex;justify-content:space-between;margin-top:auto;position:relative;text-align:left;z-index:1}.id-card-bottom-left{display:flex;flex-direction:column;gap:12px}.status-badge-active{align-items:center;background:#dcfce7;border-radius:20px;display:flex;gap:12px;padding:8px 16px;width:-webkit-fit-content;width:fit-content}.status-icon{align-items:center;background:#fff;border-radius:50%;display:flex;height:24px;justify-content:center;width:24px}.status-text-box{display:flex;flex-direction:column}.status-text-box .status-label{color:#16a34a;font-size:.55rem;font-weight:800;letter-spacing:.5px}.status-text-box .status-value{color:#15803d;font-size:.85rem;font-weight:900}.id-card-signature{color:#16a34a;font-family:Caveat,cursive,sans-serif;font-size:1.3rem;margin-top:4px;transform:rotate(-2deg)}.id-card-qr-box{align-items:center;background:#fff;border-radius:16px;box-shadow:0 4px 15px #0000000d;display:flex;flex-direction:column;padding:8px;width:100px}.qr-placeholder{border-radius:8px;height:84px;margin-bottom:8px;overflow:hidden;width:84px}.qr-badge{background:#16a34a;border-radius:8px;font-size:.55rem;font-weight:800;padding:4px 0;text-align:center}.btn-download-id,.qr-badge{align-items:center;color:#fff;display:flex;justify-content:center;width:100%}.btn-download-id{background:#009a3e;background:var(--primary);border:none;border-radius:12px;box-shadow:0 4px 12px #0d94884d;cursor:pointer;font-size:.95rem;font-weight:600;gap:8px;margin:0 auto;max-width:340px;padding:12px 24px;transition:all .2s}.btn-download-id:hover{background:#007a31;background:var(--primary-dark);transform:translateY(-2px)}.timeline-container{display:flex;flex-direction:column;gap:0;padding-left:12px;position:relative}.timeline-item{padding-bottom:24px;padding-left:28px;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-item:before{background-color:#e2e8f0;bottom:-4px;content:"";left:6px;position:absolute;top:24px;width:2px;z-index:0}.timeline-item:last-child:before{display:none}.timeline-marker{border:3px solid #fff;border-radius:50%;box-shadow:0 0 0 1px #cbd5e1;height:14px;left:0;position:absolute;top:4px;width:14px;z-index:1}.timeline-marker.bg-gray{background-color:#94a3b8}.timeline-marker.bg-primary{animation:pulsePrimary 2s infinite;background-color:#009a3e;background-color:var(--primary);box-shadow:0 0 0 1px #009a3e;box-shadow:0 0 0 1px var(--primary)}.timeline-marker.bg-orange{background-color:#f97316;box-shadow:0 0 0 1px #f97316}@keyframes pulsePrimary{0%{box-shadow:0 0 0 0 #0d948866}70%{box-shadow:0 0 0 6px #0d948800}to{box-shadow:0 0 0 0 #0d948800}}.timeline-content{background:#fff;border:1px solid #f1f5f9;border-radius:12px;box-shadow:0 2px 8px #00000005;padding:16px;transition:transform .2s ease,box-shadow .2s ease}.timeline-content:hover{box-shadow:0 6px 16px #0000000d;transform:translateY(-2px)}.timeline-date{color:#64748b;font-size:.75rem;letter-spacing:.5px;text-transform:uppercase}.timeline-date,.timeline-title{font-weight:700;margin-bottom:6px}.timeline-title{color:#1e293b;font-size:.95rem}.timeline-desc{color:#475569;font-size:.85rem;line-height:1.5}.zoom-btn{transition:background .2s,transform .2s}.zoom-btn:hover{background:#1e70d6!important;transform:translateY(-1px)}.hover-lift{transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s cubic-bezier(.4,0,.2,1)}.hover-lift:hover{box-shadow:0 12px 24px #0d948814;transform:translateY(-4px)}.glass-welcome{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(135deg,#fff,#f8faf9)!important;background:linear-gradient(135deg,#fff 0,var(--primary-50) 100%)!important;border:1px solid #fffc!important;box-shadow:0 8px 32px #0d94880d!important;overflow:hidden;position:relative}.glass-welcome:before{background:radial-gradient(circle,var(--primary-100) 0,#0000 70%);border-radius:50%;content:"";height:300px;opacity:.6;position:absolute;right:-10%;top:-50%;width:300px;z-index:0}.glass-welcome>*{position:relative;z-index:1}.pulse-badge{animation:float 3s ease-in-out infinite}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-5px)}to{transform:translateY(0)}}.pulse-btn{animation:pulse-shadow 2s infinite}@keyframes pulse-shadow{0%{box-shadow:0 0 0 0 #0d948866}70%{box-shadow:0 0 0 6px #0d948800}to{box-shadow:0 0 0 0 #0d948800}}@media (max-width:768px){.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}.soal-form-grid{grid-template-columns:1fr!important}.sa-settings-tab .btn-primary,.sa-settings-tab .btn-secondary,.step-btn-group .btn-primary,.step-btn-group .btn-secondary,.step-btn-group .step-confirm-btn,.step-btn-group .step-link-btn,.step-btn-group .step-start-btn,.step-btn-group .step-visit-btn{flex:none!important;justify-content:center!important;margin-bottom:8px;width:100%!important}.file-upload-group{align-items:stretch!important;flex-direction:column!important}.sa-content{padding-bottom:80px!important}.hamburger,.sa-sidebar,.sa-sidebar-overlay{display:none!important}.app-header,.sa-topbar,.topbar{position:-webkit-sticky!important;position:sticky!important;top:0!important;z-index:100!important}}.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:#f8faf9;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 #dce8e0;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)}.hover-row{transition:background-color .2s ease}.hover-row:hover,.hover-row:hover td{background-color:#f8faf9!important;background-color:var(--primary-50)!important}@media (min-width:769px){.sticky-col-nip-td,.sticky-col-nip-th{left:0;position:-webkit-sticky;position:sticky;z-index:2}.sticky-col-nip-td{border-right:1px solid #f8faf9;border-right:1px solid var(--gray-100);z-index:1}.sticky-col-no-td,.sticky-col-no-th{left:0;position:-webkit-sticky;position:sticky;z-index:2}.sticky-col-no-td{z-index:1}.sticky-col-name-td,.sticky-col-name-th{left:40px;position:-webkit-sticky;position:sticky;z-index:2}.sticky-col-name-td{border-right:1px solid #f8faf9;border-right:1px solid var(--gray-100);z-index:1}.sticky-col-std-td,.sticky-col-std-th{left:0;position:-webkit-sticky;position:sticky;z-index:2}.sticky-col-std-td{z-index:1}.sticky-col-no2-td,.sticky-col-no2-th{left:100px;position:-webkit-sticky;position:sticky;z-index:2}.sticky-col-no2-td{border-right:1px solid #f8faf9;border-right:1px solid var(--gray-100);z-index:1}}@media (max-width:768px){.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}.soal-form-grid{grid-template-columns:1fr!important}.sa-settings-tab .btn-primary,.sa-settings-tab .btn-secondary,.step-btn-group .btn-primary,.step-btn-group .btn-secondary,.step-btn-group .step-confirm-btn,.step-btn-group .step-link-btn,.step-btn-group .step-start-btn,.step-btn-group .step-visit-btn{flex:none!important;justify-content:center!important;margin-bottom:8px;width:100%!important}.file-upload-group{align-items:stretch!important;flex-direction:column!important}.sa-content{padding-bottom:80px!important}.hamburger,.sa-sidebar,.sa-sidebar-overlay{display:none!important}.app-header,.sa-topbar,.topbar{position:-webkit-sticky!important;position:sticky!important;top:0!important;z-index:100!important}}.soal-form-row input,.soal-form-row select,.soal-form-row textarea{max-width:100%;min-width:0;width:100%}.dashboard-welcome{align-items:center;border-radius:20px;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:32px;padding:24px 32px}.dashboard-greeting{font-size:1.8rem;font-weight:800;line-height:1.2;margin:0}.dashboard-subtitle{color:#475569;color:var(--gray-600);font-size:1.05rem;margin:6px 0 0}.dashboard-badge{align-items:center;background:#f8faf9;background:var(--primary-50);border:1px solid #dff5e7;border:1px solid var(--primary-light);border-radius:16px;display:flex;flex-direction:column;justify-content:center;padding:16px 24px}.dashboard-badge .badge-progress{color:#007a31;color:var(--primary-dark);font-size:1.8rem;font-weight:900;line-height:1}.dashboard-badge .badge-label{color:#009a3e;color:var(--primary);font-size:.75rem;font-weight:700;letter-spacing:1px;margin-top:4px}.kelas-filters::-webkit-scrollbar{display:none}.kelas-filters{-ms-overflow-style:none;scrollbar-width:none}.kelas-tab-btn{background:#fff;border:1px solid #dce8e0;border:1px solid var(--gray-200);border-radius:20px;color:#475569;color:var(--gray-600);cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:600;padding:8px 16px;transition:all .2s;white-space:nowrap}.kelas-tab-btn:hover{background:#f8faf9;background:var(--primary-50);border-color:#dff5e7;border-color:var(--primary-light);color:#009a3e;color:var(--primary)}.kelas-tab-btn.active{background:#009a3e;background:var(--primary);border:none;box-shadow:0 4px 12px #0d948833;color:#fff}.kelas-page-wrap{display:flex;flex-direction:column;gap:24px}.kelas-tabs{-ms-overflow-style:none;display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}.kelas-tabs::-webkit-scrollbar{display:none}.kelas-sections{display:flex;flex-direction:column;gap:32px}.kelas-section-title{border-bottom:2px solid #f8faf9;border-bottom:2px solid var(--gray-100);color:var(--slate-800);font-size:1.1rem;font-weight:800;margin-bottom:16px;padding-bottom:8px}.activity-icon.golden{background-color:#fef08a;color:#ca8a04}.btn-outline{align-items:center;background-color:initial;border:1px solid #16a34a;border-radius:8px;color:#16a34a;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.95rem;font-weight:600;gap:8px;justify-content:center;padding:8px 16px;transition:all .2s}.btn-outline:hover{background-color:#f0fdf4;transform:translateY(-1px)}
/*# sourceMappingURL=main.a53175a8.css.map*/