@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap);:root{--primary:#1a73e8;--primary-dark:#1557b0;--primary-light:#e8f0fe;--primary-50:#f0f5ff;--green:#0f9d58;--green-light:#e6f4ea;--green-dark:#0b8043;--red:#d93025;--red-light:#fce8e6;--orange:#f09300;--orange-light:#fef7e0;--purple:#7c3aed;--purple-light:#f0e6ff;--gray-50:#f8f9fa;--gray-100:#f1f3f4;--gray-200:#e8eaed;--gray-300:#dadce0;--gray-400:#bdc1c6;--gray-500:#9aa0a6;--gray-600:#80868b;--gray-700:#5f6368;--gray-800:#3c4043;--gray-900:#202124;--white:#fff;--shadow-sm:0 1px 2px #3c404314,0 1px 3px #3c40430f;--shadow:0 2px 6px #3c40431a,0 1px 3px #3c40430f;--shadow-md:0 4px 12px #3c40431f,0 2px 6px #3c404314;--shadow-lg:0 8px 24px #3c404326;--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:#f8f9fa;background:var(--gray-50);color:#202124;color:var(--gray-900);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}a{color:#1a73e8;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:#80868b;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:#202124;color:var(--gray-900);font-size:1.4rem;font-weight:700;margin-bottom:2px}.login-logo p{color:#80868b;color:var(--gray-600);font-size:.82rem}.login-field{margin-bottom:18px}.login-field label{color:#5f6368;color:var(--gray-700);display:block;font-size:.82rem;font-weight:600;margin-bottom:6px}.login-field input{background:#f8f9fa;background:var(--gray-50);border:1.5px solid #dadce0;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:#1a73e8;border-color:var(--primary);box-shadow:0 0 0 3px #e8f0fe;box-shadow:0 0 0 3px var(--primary-light);outline:none}.login-error{background:#fce8e6;background:var(--red-light);border-left:3px solid #d93025;border-left:3px solid var(--red);border-radius:6px;border-radius:var(--radius-xs);color:#d93025;color:var(--red);font-size:.82rem;margin-bottom:16px;padding:10px 14px}.login-btn{background:#1a73e8;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:#1557b0;background:var(--primary-dark);box-shadow:0 1px 2px #3c404314,0 1px 3px #3c40430f;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 #e8eaed;border-bottom:1px solid var(--gray-200);margin-bottom:24px;padding-bottom:20px}.login-quick-label{color:#9aa0a6;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 #e8eaed;border:1px solid var(--gray-200);border-radius:6px;border-radius:var(--radius-xs);color:#5f6368;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:#f8f9fa;background:var(--btn-bg,var(--gray-50));border-color:#dadce0;border-color:var(--btn-color,var(--gray-300));color:#202124;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 #e8eaed;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 #f1f3f4;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:#202124;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:#9aa0a6;color:var(--gray-500)}.sidebar-close{background:none;border:none;border-radius:6px;cursor:pointer;display:none;padding:4px}.sidebar-close:hover{background:#f1f3f4;background:var(--gray-100);color:#5f6368;color:var(--gray-700)}.sidebar-badge{align-items:center;background:#e8f0fe;background:var(--primary-light);border-radius:20px;color:#1a73e8;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:#fef7e0;background:var(--orange-light);color:#f09300;color:var(--orange)}.sidebar-pokja-info{border-bottom:1px solid #f1f3f4;border-bottom:1px solid var(--gray-100);color:#5f6368;color:var(--gray-700);font-size:.8rem;padding:12px 20px}.sidebar-pokja-info strong{color:#202124;color:var(--gray-900);display:block}.sidebar-nav{flex:1 1;padding:8px 12px}.sidebar-section-label{color:#9aa0a6;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:#5f6368;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:#f1f3f4;background:var(--gray-100);color:#202124;color:var(--gray-900)}.sidebar-item.active{background:#e8f0fe;background:var(--primary-light);color:#1a73e8;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:#f1f3f4;background:var(--gray-100);border-radius:10px;color:#80868b;color:var(--gray-600);font-size:.7rem;font-weight:600;margin-left:auto;padding:1px 8px}.sidebar-item.active .sidebar-item-count{background:#1a73e8;background:var(--primary);color:#fff}.sidebar-user{align-items:center;border-top:1px solid #f1f3f4;border-top:1px solid var(--gray-100);display:flex;gap:10px;padding:14px 20px}.sidebar-user-avatar{align-items:center;background:#e8f0fe;background:var(--primary-light);border-radius:50%;color:#1a73e8;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:#3c4043;color:var(--gray-800);display:block;font-size:.85rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-role{color:#9aa0a6;color:var(--gray-500);display:block;font-size:.7rem;margin-top:1px}.sidebar-logout{background:none;border:none;border-radius:6px;color:#bdc1c6;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:#fce8e6;background:var(--red-light);color:#d93025;color:var(--red)}.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 #e8eaed;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:#80868b;color:var(--gray-600);cursor:pointer;display:none;padding:6px}.hamburger:hover{background:#f1f3f4;background:var(--gray-100)}.topbar-title{color:#202124;color:var(--gray-900);flex:1 1;font-size:1.05rem;font-weight:700}.topbar-user{align-items:center;border-radius:100px;color:#80868b;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:#f8f9fa;background:var(--gray-50)}.topbar-user-avatar{align-items:center;background:#e8f0fe;background:var(--primary-light);border-radius:50%;color:#1a73e8;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:#f1f3f4;background:var(--gray-100);border:none;border-radius:100px;color:#5f6368;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:#fce8e6;background:var(--red-light);color:#d93025;color:var(--red)}.content-area{padding:24px 28px}.dashboard-page{max-width:1200px}.dashboard-greeting{font-size:1.35rem;font-weight:700;margin-bottom:4px}.dashboard-subtitle{color:#9aa0a6;color:var(--gray-500);font-size:.85rem;margin-bottom:24px}.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 #e8eaed;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #3c404314,0 1px 3px #3c40430f;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 #3c40431a,0 1px 3px #3c40430f;box-shadow:var(--shadow);transform:translateY(-1px)}.stat-number{color:#202124;color:var(--gray-900);display:block;font-size:1.7rem;font-weight:800;line-height:1.2}.stat-label{color:#9aa0a6;color:var(--gray-500);display:block;font-size:.78rem;font-weight:500;margin-top:4px}.progress-bar-section{background:#fff;background:var(--white);border:1px solid #e8eaed;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #3c404314,0 1px 3px #3c40430f;box-shadow:var(--shadow-sm);margin-bottom:28px;padding:24px}.progress-bar-section h3{color:#3c4043;color:var(--gray-800);font-size:.88rem;font-weight:600;margin-bottom:4px}.progress-bar-section .progress-sub{color:#9aa0a6;color:var(--gray-500);font-size:.75rem;margin-bottom:14px}.overall-progress-bar{background:#f1f3f4;background:var(--gray-100);border-radius:4px;height:8px;overflow:hidden}.overall-progress-fill{background:linear-gradient(90deg,#1a73e8,#4285f4);background:linear-gradient(90deg,var(--primary),#4285f4);border-radius:4px;height:100%;transition:width .6s cubic-bezier(.2,0,0,1)}.step-progress-row{display:flex;flex-wrap:wrap;gap:20px;margin-top:16px}.step-item{align-items:center;color:#9aa0a6;color:var(--gray-500);display:flex;font-size:.8rem;font-weight:500;gap:8px}.step-item[data-done=true]{color:#0f9d58;color:var(--green)}.step-dot{background:#dadce0;background:var(--gray-300);border-radius:50%;flex-shrink:0;height:10px;width:10px}.step-dot[data-done=true]{background:#0f9d58;background:var(--green)}.step-dot[data-current=true]{background:#1a73e8;background:var(--primary);box-shadow:0 0 0 3px #e8f0fe;box-shadow:0 0 0 3px var(--primary-light)}.page-header{margin-bottom:20px}.page-title{color:#202124;color:var(--gray-900);font-size:1.3rem;font-weight:700}.page-subtitle{color:#9aa0a6;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 #e8eaed;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #3c404314,0 1px 3px #3c40430f;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:#e8f0fe;border-color:var(--primary-light);box-shadow:0 4px 12px #3c40431f,0 2px 6px #3c404314;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:#202124;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:#f1f3f4;background:var(--gray-100);color:#80868b;color:var(--gray-600)}.badge-progress{background:#fef7e0;background:var(--orange-light);color:#f09300;color:var(--orange)}.badge-selesai{background:#e6f4ea;background:var(--green-light);color:#0b8043;color:var(--green-dark)}.kelas-mini-progress{display:flex;gap:8px;margin-top:12px}.mini-step{background:#f1f3f4;background:var(--gray-100);border-radius:20px;color:#9aa0a6;color:var(--gray-500);font-size:.68rem;font-weight:500;padding:3px 10px}.mini-step[data-done=true]{background:#e6f4ea;background:var(--green-light);color:#0b8043;color:var(--green-dark)}.mini-step[data-current=true]{background:#e8f0fe;background:var(--primary-light);color:#1a73e8;color:var(--primary)}.card-completed-badge{font-size:1.3rem;position:absolute;right:-6px;top:-6px}.kelas-card-footer{border-top:1px solid #f1f3f4;border-top:1px solid var(--gray-100);color:#9aa0a6;color:var(--gray-500);font-size:.75rem;margin-top:14px;padding-top:12px}.detail-page{padding:0}.detail-header{background:#fff;background:var(--white);border-bottom:1px solid #e8eaed;border-bottom:1px solid var(--gray-200);gap:16px;padding:16px 28px}.back-btn,.detail-header{align-items:center;display:flex}.back-btn{background:none;border:none;border-radius:6px;border-radius:var(--radius-xs);color:#1a73e8;color:var(--primary);cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:500;gap:6px;padding:6px 10px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.back-btn:hover{background:#e8f0fe;background:var(--primary-light)}.detail-header h1{color:#202124;color:var(--gray-900);font-size:1.15rem;font-weight:700}.detail-passing{background:#f1f3f4;background:var(--gray-100);border-radius:20px;color:#9aa0a6;color:var(--gray-500);font-size:.75rem;font-weight:500;padding:3px 10px}.detail-content{max-width:720px;padding:24px 28px}.steps-timeline{padding-left:48px;position:relative}.steps-timeline:before{background:#e8eaed;background:var(--gray-200);bottom:24px;content:"";left:20px;position:absolute;top:24px;width:2px}.timeline-step{margin-bottom:20px;position:relative}.timeline-dot{align-items:center;background:#fff;background:var(--white);border:2px solid #dadce0;border:2px solid var(--gray-300);border-radius:50%;color:#9aa0a6;color:var(--gray-500);display:flex;font-size:1rem;height:40px;justify-content:center;left:-48px;position:absolute;top:0;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition);width:40px;z-index:1}.timeline-step.completed .timeline-dot{background:#e6f4ea;background:var(--green-light);border-color:#0f9d58;border-color:var(--green);color:#0f9d58;color:var(--green)}.timeline-step.current .timeline-dot{background:#e8f0fe;background:var(--primary-light);border-color:#1a73e8;border-color:var(--primary);box-shadow:0 0 0 4px #e8f0fe;box-shadow:0 0 0 4px var(--primary-light);color:#1a73e8;color:var(--primary)}.timeline-content{background:#fff;background:var(--white);border:1px solid #e8eaed;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #3c404314,0 1px 3px #3c40430f;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:#e8f0fe;border-color:var(--primary-light);box-shadow:0 0 0 2px #e8f0fe;box-shadow:0 0 0 2px var(--primary-light)}.timeline-content h3{color:#202124;color:var(--gray-900);font-size:.95rem;font-weight:700;margin-bottom:8px}.timeline-step.locked .timeline-content{opacity:.6}.step-locked{color:#9aa0a6;color:var(--gray-500);font-size:.82rem}.step-detail p{color:#5f6368;color:var(--gray-700);font-size:.85rem;line-height:1.5;margin-bottom:8px}.step-link-btn{align-items:center;background:#e8f0fe;background:var(--primary-light);border-radius:6px;border-radius:var(--radius-xs);color:#1a73e8;color:var(--primary);display:inline-flex;font-size:.82rem;font-weight:600;gap:6px;margin-bottom:8px;padding:8px 16px;text-decoration:none;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.step-link-btn:hover{background:#1a73e8;background:var(--primary);color:#fff;text-decoration:none}.step-confirm-btn{background:#0f9d58;background:var(--green);border:none;border-radius:6px;border-radius:var(--radius-xs);color:#fff;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:#0b8043;background:var(--green-dark)}.step-visit-btn{align-items:center;background:#f1f3f4;background:var(--gray-100);border:none;border-radius:6px;border-radius:var(--radius-xs);color:#5f6368;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:#e8eaed;background:var(--gray-200)}.step-start-btn{background:#1a73e8;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:#1557b0;background:var(--primary-dark)}.step-btn-group{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.test-passed{color:#0f9d58;color:var(--green)}.test-failed,.test-passed{font-size:1.1rem;font-weight:700}.test-failed{color:#d93025;color:var(--red)}.test-info{color:#9aa0a6;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:#e6f4ea;background:var(--green-light);color:#0b8043;color:var(--green-dark)}.test-score-badge.fail{background:#fce8e6;background:var(--red-light);color:#d93025;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 #e8eaed;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:#202124;color:var(--gray-900);display:flex;font-size:1.05rem;font-weight:700;gap:10px}.attempt-badge{background:#fef7e0;background:var(--orange-light);border-radius:20px;color:#f09300;color:var(--orange);font-size:.7rem;font-weight:600;padding:2px 10px}.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:#f8f9fa;background:var(--gray-50);border-radius:8px;color:#3c4043;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:#fce8e6;background:var(--red-light);color:#d93025;color:var(--red)}.test-progress-text{color:#9aa0a6;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 #e8eaed;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #3c404314,0 1px 3px #3c40430f;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:#dadce0;border-color:var(--gray-300)}.question-number{color:#1a73e8;color:var(--primary);flex-shrink:0;font-size:.85rem;font-weight:700;padding-top:2px;text-align:center;width:28px}.question-text{color:#3c4043;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 #e8eaed;border:1.5px solid var(--gray-200);border-radius:6px;border-radius:var(--radius-xs);color:#5f6368;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:#f0f5ff;background:var(--primary-50)}.option-label.selected,.option-label:hover{border-color:#1a73e8;border-color:var(--primary)}.option-label.selected{background:#e8f0fe;background:var(--primary-light);color:#202124;color:var(--gray-900)}.option-label input{display:none}.option-letter{align-items:center;background:#f1f3f4;background:var(--gray-100);border-radius:50%;color:#80868b;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:#1a73e8;background:var(--primary);color:#fff}.option-text{flex:1 1}.test-footer{background:#fff;background:var(--white);border-top:1px solid #e8eaed;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:#f1f3f4;background:var(--gray-100);border:none;border-radius:6px;border-radius:var(--radius-xs);color:#80868b;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:#e8eaed;background:var(--gray-200)}.test-submit-btn{background:#0f9d58;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:#0b8043;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 #e8eaed;border:1px solid var(--gray-200);border-radius:20px;box-shadow:0 8px 24px #3c404326;box-shadow:var(--shadow-lg);max-width:380px;padding:48px 40px;text-align:center;width:100%}.result-card.passed{border-top:4px solid #0f9d58;border-top:4px solid var(--green)}.result-card.failed{border-top:4px solid #d93025;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:#0b8043;color:var(--green-dark)}.result-card.failed h2{color:#d93025;color:var(--red)}.result-score{font-size:4.5rem;font-weight:800;line-height:1}.result-card.passed .result-score{color:#0f9d58;color:var(--green)}.result-card.failed .result-score{color:#d93025;color:var(--red)}.result-detail{color:#9aa0a6;color:var(--gray-500);font-size:.85rem;margin-top:8px}.result-attempts{color:#f09300;color:var(--orange);font-size:.82rem;font-weight:500;margin-top:8px}.result-btn{background:#1a73e8;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:#1557b0;background:var(--primary-dark)}.error-msg{background:#fce8e6;background:var(--red-light);border-left:3px solid #d93025;border-left:3px solid var(--red);border-radius:6px;border-radius:var(--radius-xs);color:#d93025;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 #e8eaed;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 #f1f3f4;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:#202124;color:var(--gray-900);display:block;font-size:.95rem;font-weight:700}.sa-brand-sub{color:#9aa0a6;color:var(--gray-500);display:block;font-size:.68rem;margin-top:1px}.sa-badge{align-items:center;background:#e8f0fe;background:var(--primary-light);border-radius:20px;color:#1a73e8;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:#fef7e0;background:var(--orange-light);color:#f09300;color:var(--orange)}.sa-pokja-info{border-bottom:1px solid #f1f3f4;border-bottom:1px solid var(--gray-100);color:#80868b;color:var(--gray-600);font-size:.78rem;padding:12px 20px}.sa-pokja-info strong{color:#202124;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:#5f6368;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:#f1f3f4;background:var(--gray-100);color:#202124;color:var(--gray-900)}.sa-nav-item.active{background:#e8f0fe;background:var(--primary-light);color:#1a73e8;color:var(--primary);font-weight:600}.sa-sidebar-footer{border-top:1px solid #f1f3f4;border-top:1px solid var(--gray-100);padding:14px 20px}.sa-logout-btn{align-items:center;background:#f8f9fa;background:var(--gray-50);border:1px solid #e8eaed;border:1px solid var(--gray-200);border-radius:6px;border-radius:var(--radius-xs);color:#5f6368;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:#fce8e6;background:var(--red-light);border-color:#fce8e6;border-color:var(--red-light);color:#d93025;color:var(--red)}.sa-main{flex:1 1;margin-left:260px;margin-left:var(--sidebar-w);min-height:100vh}.sa-topbar{align-items:center;background:#fff;background:var(--white);border-bottom:1px solid #e8eaed;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:#202124;color:var(--gray-900);font-size:1.05rem;font-weight:700}.sa-topbar-user{align-items:center;color:#80868b;color:var(--gray-600);display:flex;font-size:.82rem;gap:10px}.sa-topbar-user-avatar{align-items:center;background:#e8f0fe;background:var(--primary-light);border-radius:50%;color:#1a73e8;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:#f1f3f4;background:var(--gray-100);border:none;border-radius:100px;color:#5f6368;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:#fce8e6;background:var(--red-light);color:#d93025;color:var(--red)}.sa-content{padding:24px 28px}.sa-stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));margin-bottom:28px}.sa-stat-card{background:#fff;background:var(--white);border:1px solid #e8eaed;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #3c404314,0 1px 3px #3c40430f;box-shadow:var(--shadow-sm);padding:20px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.sa-stat-card:hover{box-shadow:0 2px 6px #3c40431a,0 1px 3px #3c40430f;box-shadow:var(--shadow);transform:translateY(-1px)}.sa-stat-card .sa-stat-icon{align-items:center;background:#f1f3f4;background:var(--gray-100);border-radius:10px;color:#80868b;color:var(--gray-600);display:flex;height:40px;justify-content:center;margin-bottom:12px;width:40px}.sa-stat-icon--blue{background:#e8f0fe!important;background:var(--primary-light)!important;color:#1a73e8!important;color:var(--primary)!important}.sa-stat-icon--green{background:#e6f4ea!important;background:var(--green-light)!important;color:#0f9d58!important;color:var(--green)!important}.sa-stat-icon--orange{background:#fef7e0!important;background:var(--orange-light)!important;color:#f09300!important;color:var(--orange)!important}.sa-stat-icon--purple{background:#f0e6ff!important;background:var(--purple-light)!important;color:#7c3aed!important;color:var(--purple)!important}.sa-stat-number{color:#202124;color:var(--gray-900);font-size:1.7rem;font-weight:800;line-height:1.2}.sa-stat-label{color:#9aa0a6;color:var(--gray-500);font-size:.78rem;font-weight:500;margin-top:4px}.sa-settings-card{background:#fff;background:var(--white);border:1px solid #e8eaed;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #3c404314,0 1px 3px #3c40430f;box-shadow:var(--shadow-sm);padding:20px 24px}.sa-settings-card-label{color:#9aa0a6;color:var(--gray-500);font-size:.72rem;font-weight:500;letter-spacing:.03em;margin-bottom:2px;text-transform:uppercase}.sa-settings-card-value{color:#202124;color:var(--gray-900);font-size:1.3rem;font-weight:700}.text-green{color:#0f9d58!important;color:var(--green)!important}.text-orange{color:#f09300!important;color:var(--orange)!important}.text-red{color:#d93025!important;color:var(--red)!important}.text-blue{color:#1a73e8!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:#202124;color:var(--gray-900);display:flex;font-size:1rem;font-weight:700;gap:8px}.sa-section-header .sa-count{background:#f1f3f4;background:var(--gray-100);border-radius:20px;color:#9aa0a6;color:var(--gray-500);font-size:.78rem;font-weight:500;padding:2px 10px}.sa-section-card{background:#fff;background:var(--white);border:1px solid #e8eaed;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #3c404314,0 1px 3px #3c40430f;box-shadow:var(--shadow-sm);margin-bottom:24px;padding:24px}.sa-section-card h3{color:#202124;color:var(--gray-900);font-size:1rem;font-weight:700;margin-bottom:16px}.sa-table-container{background:#fff;background:var(--white);border:1px solid #e8eaed;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #3c404314,0 1px 3px #3c40430f;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:#202124;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);overflow-x:auto;padding:0 4px}.sa-table{border-collapse:collapse;font-size:.82rem;width:100%}.sa-table thead{background:#f8f9fa;background:var(--gray-50)}.sa-table th{border-bottom:1px solid #e8eaed;border-bottom:1px solid var(--gray-200);color:#80868b;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{border-bottom:1px solid #f1f3f4;border-bottom:1px solid var(--gray-100);color:#3c4043;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:#f8f9fa;background:var(--gray-50)}.sa-table tbody tr:last-child td{border-bottom:none}.sa-table .mono{color:#5f6368;color:var(--gray-700);font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.78rem}.role-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.68rem;font-weight:600;gap:4px;padding:3px 10px}.role-superadmin{background:#ede9fe;color:#7c3aed}.role-admin_pokja{background:#fef7e0;background:var(--orange-light);color:#f09300;color:var(--orange)}.role-karyawan{background:#f1f3f4;background:var(--gray-100);color:#80868b;color:var(--gray-600)}.kunci-badge{align-items:center;background:#e6f4ea;background:var(--green-light);border-radius:50%;color:#0b8043;color:var(--green-dark);display:inline-flex;font-size:.72rem;font-weight:800;height:26px;justify-content:center;width:26px}.status-pass{color:#0f9d58;color:var(--green)}.status-fail,.status-pass{font-size:.78rem;font-weight:600}.status-fail{color:#d93025;color:var(--red)}.status-pending{color:#f09300;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:#5f6368;color:var(--gray-700);display:block;font-size:.82rem;font-weight:600;margin-bottom:6px}.sa-setting-item input{border:1.5px solid #dadce0;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:#1a73e8;border-color:var(--primary);box-shadow:0 0 0 3px #e8f0fe;box-shadow:0 0 0 3px var(--primary-light);outline:none}.sa-setting-item .setting-hint{color:#9aa0a6;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 #e8eaed;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #3c404314,0 1px 3px #3c40430f;box-shadow:var(--shadow-sm);padding:24px}.sa-import-section h3{color:#202124;color:var(--gray-900);font-size:1rem;font-weight:700;margin-bottom:8px}.sa-import-section p{color:#9aa0a6;color:var(--gray-500);font-size:.82rem;line-height:1.5;margin-bottom:6px}.sa-import-section code{background:#f1f3f4;background:var(--gray-100);border-radius:4px;color:#5f6368;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:#5f6368;color:var(--gray-700);font-family:inherit;font-size:.82rem}.sa-import-section input[type=file]::-webkit-file-upload-button{background:#1a73e8;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:#1a73e8;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:#1557b0;background:var(--primary-dark)}.sa-import-section input[type=file]::file-selector-button:hover{background:#1557b0;background:var(--primary-dark)}.sa-import-msg{background:#e6f4ea;background:var(--green-light);border-left:3px solid #0f9d58;border-left:3px solid var(--green);color:#0b8043;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:#e8f0fe;background:var(--primary-light);color:#1a73e8;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:#202124;color:var(--gray-900);font-size:1.25rem;font-weight:700}.sa-overview-header p{color:#9aa0a6;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 #e8eaed;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #3c404314,0 1px 3px #3c40430f;box-shadow:var(--shadow-sm);padding:18px 20px}.sa-analytic-card h4{color:#3c4043;color:var(--gray-800);font-size:.88rem;font-weight:600;margin-bottom:8px}.sa-analytic-row{align-items:center;border-bottom:1px solid #f1f3f4;border-bottom:1px solid var(--gray-100);color:#5f6368;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}}.search-wrap{position:relative}.search-input{background:#f8f9fa;background:var(--gray-50);border:1px solid #e8eaed;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:#1a73e8;border-color:var(--primary);box-shadow:0 0 0 2px #e8f0fe;box-shadow:0 0 0 2px var(--primary-light);outline:none}.search-input::placeholder{color:#bdc1c6;color:var(--gray-400)}.soal-form{background:#f8f9fa;background:var(--gray-50);border-bottom:1px solid #e8eaed;border-bottom:1px solid var(--gray-200);padding:20px}.soal-form h4{color:#202124;color:var(--gray-900);font-size:.9rem;font-weight:700;margin-bottom:12px}.soal-form-msg{background:#f1f3f4;background:var(--gray-100);border-radius:6px;color:#5f6368;color:var(--gray-700);font-size:.82rem;margin-bottom:12px;padding:8px 12px}.soal-form-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr;margin-bottom:12px}.soal-form-choices{grid-template-columns:1fr 1fr}.soal-form-row{display:flex;flex-direction:column;gap:4px}.soal-form-row label{color:#80868b;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 #e8eaed;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:#1a73e8;border-color:var(--primary);box-shadow:0 0 0 2px #e8f0fe;box-shadow:0 0 0 2px var(--primary-light);outline:none}.soal-form-actions{border-top:1px solid #e8eaed;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:#80868b;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:#e8f0fe;background:var(--primary-light);border-color:#1a73e8;border-color:var(--primary);color:#1a73e8;color:var(--primary)}.sa-delete-btn:hover{background:#fce8e6;background:var(--red-light);border-color:#d93025;border-color:var(--red);color:#d93025;color:var(--red)}.btn-primary{align-items:center;background:#1a73e8;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:#1557b0;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 #e8eaed;border:1px solid var(--gray-200);border-radius:8px;color:#5f6368;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:#f8f9fa;background:var(--gray-50);border-color:#dadce0;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-radius:16px;box-shadow:0 20px 60px #0003;max-width:400px;padding:32px 28px 24px;text-align:center;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.warning-icon{align-items:center;background:#fef7e0;background:var(--orange-light);border-radius:50%;color:#f09300;color:var(--orange);display:flex;font-size:1.5rem;font-weight:800;height:48px;justify-content:center;margin:0 auto 16px;width:48px}.warning-card h3{color:#202124;color:var(--gray-900);font-size:1.05rem;font-weight:700;margin-bottom:8px}.warning-card p{color:#80868b;color:var(--gray-600);font-size:.88rem;line-height:1.5}.warning-card .warning-sub{color:#9aa0a6;color:var(--gray-500);font-size:.82rem;margin-top:4px}.warning-actions{display:flex;flex-direction:column;gap:8px;margin-top:20px}.warning-btn-primary{background:#f09300;background:var(--orange);border:none;border-radius:10px;color:#fff;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-primary:hover{background:#d68200}.warning-btn-secondary{background:#fff;background:var(--white);border:1px solid #e8eaed;border:1px solid var(--gray-200);border-radius:10px;color:#5f6368;color:var(--gray-700);cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:500;padding:12px 20px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.warning-btn-secondary:hover{background:#f8f9fa;background:var(--gray-50)}.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-radius:16px;box-shadow:0 20px 60px #00000040;max-height:85vh;max-width:560px;overflow-y:auto;padding:28px 28px 24px;width:100%}.crud-modal h4{border-bottom:1px solid #f1f3f4;border-bottom:1px solid var(--gray-100);color:#202124;color:var(--gray-900);font-size:1rem;font-weight:700;margin-bottom:16px;padding-bottom:12px}.crud-modal .soal-form-msg{background:#f1f3f4;background:var(--gray-100);border-radius:6px;color:#5f6368;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;grid-template-columns:1fr 1fr;margin-bottom:8px}.crud-modal .soal-form-choices{grid-template-columns:1fr 1fr}.crud-modal .soal-form-row{display:flex;flex-direction:column;gap:4px}.crud-modal .soal-form-row label{color:#80868b;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 #e8eaed;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:#1a73e8;border-color:var(--primary);box-shadow:0 0 0 2px #e8f0fe;box-shadow:0 0 0 2px var(--primary-light);outline:none}.crud-modal .soal-form-actions{border-top:1px solid #e8eaed;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 #f1f3f4;border-top:1px solid var(--gray-100);display:flex;flex-wrap:wrap;gap:4px;justify-content:center;padding:14px 20px}.sa-page-btn{align-items:center;background:#fff;background:var(--white);border:1px solid #e8eaed;border:1px solid var(--gray-200);border-radius:8px;color:#80868b;color:var(--gray-600);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.8rem;font-weight:500;height:32px;justify-content:center;line-height:1;min-width:32px;padding:0 8px;transition:all .2s cubic-bezier(.2,0,0,1);transition:var(--transition)}.sa-page-btn:hover:not(:disabled):not(.active){background:#e8f0fe;background:var(--primary-light);border-color:#1a73e8;border-color:var(--primary);color:#1a73e8;color:var(--primary)}.sa-page-btn.active{background:#1a73e8;background:var(--primary);border-color:#1a73e8;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:#bdc1c6;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:#9aa0a6;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}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/*# sourceMappingURL=main.db61b078.css.map*/