@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#1e293b;background-color:#f0f4f8;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden;width:100%;max-width:100vw}html{overflow-x:hidden;width:100%;max-width:100vw}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}body.login-page-active{overflow:hidden;height:100vh}.login-container{height:100vh;max-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 24px;background:#001f3f;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;position:relative;overflow:hidden}.login-container:before{content:"";position:fixed;inset:0;width:100%;height:100%;background:#ffffff14;backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);z-index:0;pointer-events:none}.login-container:after{content:"";position:absolute;top:-50%;right:-20%;width:800px;height:800px;background:radial-gradient(circle,rgba(255,255,255,.05) 0%,transparent 70%);border-radius:50%;z-index:0;animation:float 20s ease-in-out infinite}.login-card-large{width:100%;max-width:1000px;max-height:90vh;background:#ffffff14;border-radius:40px;border:1px solid rgba(255,255,255,.3);box-shadow:0 30px 80px #001f3f80,0 0 0 1px #ffffff26 inset,inset 0 1px #fff6,inset 0 -1px #ffffff1a;animation:fadeInUp .6s cubic-bezier(.16,1,.3,1);position:relative;z-index:1;overflow:hidden;display:flex;min-height:500px;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%)}.login-card-large:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.25) 0%,rgba(255,255,255,.1) 50%,transparent 100%);border-radius:40px 40px 0 0;pointer-events:none;z-index:1}.login-card-large:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.1) 50%,transparent 70%);animation:shine 3s infinite;pointer-events:none;z-index:2}.login-card-large:hover{border-color:#fff6;box-shadow:0 35px 90px #001f3f99,0 0 0 1px #fff3 inset,inset 0 1px #ffffff80,inset 0 -1px #ffffff26}.login-card-large:hover:before{background:linear-gradient(180deg,rgba(255,255,255,.35) 0%,rgba(255,255,255,.15) 50%,transparent 100%)}.login-left-section{flex:1;position:relative;display:none}.login-image-wrapper{width:100%;height:100%;position:relative;overflow:hidden}.login-school-image{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .6s cubic-bezier(.4,0,.2,1);filter:brightness(.95) blur(3px)}.login-card-large:hover .login-school-image{transform:scale(1.08);filter:brightness(1) blur(2px)}.login-image-overlay{position:absolute;inset:0;background:linear-gradient(180deg,#3b82f640,#1e40af59,#3b82f666);display:flex;align-items:center;justify-content:center;padding:40px;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.login-logo-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10;display:flex;align-items:center;justify-content:center;padding:0;background:transparent;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%;max-width:500px}.login-card-large:hover .login-logo-overlay{transform:translate(-50%,-50%) scale(1.02)}.login-logo-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;text-align:center;animation:fadeInUp .8s ease-out}.login-school-logo{max-width:280px;max-height:280px;width:auto;height:auto;object-fit:contain;filter:drop-shadow(0 8px 24px rgba(0,0,0,.3));transition:transform .3s ease;mix-blend-mode:multiply;background:transparent}.login-card-large:hover .login-school-logo{transform:scale(1.05)}.login-school-name{font-size:28px;font-weight:800;color:#fff;margin:0;text-shadow:0 2px 8px rgba(0,0,0,.3),0 4px 16px rgba(0,0,0,.2);letter-spacing:.5px;line-height:1.3;padding:0 20px;text-align:center;transition:all .3s ease}.login-card-large:hover .login-school-name{transform:translateY(-4px);text-shadow:0 4px 12px rgba(0,0,0,.4),0 6px 20px rgba(0,0,0,.3)}.login-right-section{flex:1;display:flex;align-items:center;justify-content:center;padding:48px 40px;min-height:500px;max-height:90vh;background:transparent;position:relative;z-index:3;overflow:hidden}.login-right-section:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:linear-gradient(180deg,#fff6,#fff3);opacity:.8;border-radius:0 2px 2px 0}.login-form-wrapper{width:100%;max-width:420px}.login-header{margin-bottom:36px;text-align:center}.login-logo-container{display:flex;align-items:center;justify-content:center;gap:18px;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,.2);position:relative}.login-logo-container:after{content:"";position:absolute;bottom:-1px;left:50%;transform:translate(-50%);width:60px;height:2px;background:linear-gradient(90deg,#fff9,#ffffff4d);border-radius:2px}.login-icon-wrapper{width:64px;height:64px;background:linear-gradient(135deg,#3b82f6,#1e40af);border-radius:18px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px #3b82f659,0 0 0 1px #3b82f626,inset 0 1px #fff3;flex-shrink:0;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.login-icon-wrapper:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 12px 32px #3b82f666,0 0 0 1px #3b82f633,inset 0 1px #ffffff4d}.login-icon-wrapper:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent,rgba(255,255,255,.3),transparent);animation:shine 3s infinite}.login-icon{font-size:32px;color:#fff;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));position:relative;z-index:1}.login-logo-text{text-align:center}.login-logo-text .login-title{font-size:26px;font-weight:800;background:linear-gradient(135deg,#fff,#ffffffe6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 4px;letter-spacing:-.6px;line-height:1.2;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.login-logo-text .login-subtitle{font-size:13px;color:#ffffffd9;margin:0;line-height:1.4;font-weight:400;text-shadow:0 1px 3px rgba(0,0,0,.2)}.login-welcome-text{text-align:center}.login-welcome-title{font-size:32px;font-weight:800;color:#fff;margin:0 0 12px;letter-spacing:-.8px;line-height:1.2;text-shadow:0 2px 8px rgba(0,0,0,.3)}.login-welcome-subtitle{font-size:15px;color:#ffffffe6;margin:0;line-height:1.5;font-weight:400;text-shadow:0 1px 4px rgba(0,0,0,.2)}.badge-dot{width:6px;height:6px;background:#3b82f6;border-radius:50%;display:inline-block;animation:pulse 2s ease-in-out infinite}.login-content{width:100%}.login-divider{display:flex;align-items:center;text-align:center;margin:24px 0 20px;position:relative}.login-divider:before,.login-divider:after{content:"";flex:1;border-bottom:1px solid rgba(255,255,255,.2)}.divider-text{padding:0 20px;font-size:13px;color:#ffffffb3;font-weight:600;text-transform:uppercase;letter-spacing:1px;background:transparent;position:relative;z-index:1}.google-login-button{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 24px;background:#ffffff26;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);border-radius:14px;font-size:15px;font-weight:600;color:#fff;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;box-shadow:0 4px 12px #0003,0 2px 4px #0000001a,inset 0 1px #fff3;outline:none;position:relative;overflow:hidden;letter-spacing:.2px}.google-login-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transition:left .5s}.google-login-button:hover:before{left:100%}.google-login-button:hover{box-shadow:0 8px 24px #0000004d,0 4px 8px #0003,inset 0 1px #ffffff4d;border-color:#ffffff80;transform:translateY(-2px);background:#ffffff40}.google-login-button:active{transform:translateY(0);box-shadow:0 4px 12px #0003,0 2px 4px #0000001a,inset 0 1px #fff3;background:#fff3}.google-login-button:disabled{opacity:.5;cursor:not-allowed;box-shadow:0 1px 2px #0000000d;transform:none}.google-login-button:disabled:before{display:none}.google-login-button:focus-visible{outline:2px solid rgba(255,255,255,.6);outline-offset:2px;border-color:#ffffff80}.google-logo-icon{flex-shrink:0;width:20px;height:20px;filter:drop-shadow(0 1px 1px rgba(0,0,0,.1))}.loading-spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.2);border-top-color:#fffc;border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.login-footer-info{display:flex;align-items:flex-start;gap:12px;margin-top:20px;padding:14px;background:#ffffff14;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:14px;border:1px solid rgba(255,255,255,.2);transition:all .3s ease;box-shadow:0 2px 8px #00000026,inset 0 1px #ffffff1a}.login-footer-info:hover{background:#ffffff1f;border-color:#ffffff4d;transform:translateY(-2px);box-shadow:0 4px 12px #0003,inset 0 1px #ffffff26}.info-icon{flex-shrink:0;opacity:.8;filter:brightness(0) invert(1)}.login-footer-info span{font-size:13px;color:#ffffffd9;line-height:1.5;font-weight:400;text-shadow:0 1px 2px rgba(0,0,0,.2)}.info-icon{flex-shrink:0;margin-top:2px;opacity:.6}.account-picker-overlay{position:fixed;inset:0;background:#001f3fb3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .3s ease}.account-picker-popup{width:100%;max-width:440px;background:#fff;border-radius:24px;box-shadow:0 20px 60px #00000026,0 0 0 1px #0000000a inset;overflow:hidden;animation:slideUp .35s cubic-bezier(.16,1,.3,1);max-height:90vh;display:flex;flex-direction:column;border:1px solid rgba(0,0,0,.06);position:relative}.account-picker-header{padding:48px 40px 32px;text-align:center;background:#fff;position:relative;z-index:2;border-bottom:1px solid rgba(0,0,0,.08);display:flex;flex-direction:column;align-items:center;justify-content:flex-start}.account-picker-close{position:absolute;top:20px;right:20px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#f8f9fa;border:1px solid rgba(0,0,0,.06);border-radius:50%;cursor:pointer;color:#5f6368;font-size:18px;transition:all .2s cubic-bezier(.4,0,.2,1);outline:none;z-index:10;box-shadow:0 1px 3px #0000000f}.account-picker-close:hover{background:#e8e8e8;border-color:#0000001f;color:#202124;transform:rotate(90deg) scale(1.1);box-shadow:0 4px 8px #0000001f}.account-picker-close:active{transform:rotate(90deg) scale(.95)}.account-picker-close:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.account-picker-google-logo-container{display:flex;align-items:center;justify-content:center;width:100%;margin:0 auto 24px}.account-picker-google-logo{height:36px;width:auto;display:block;margin:0;padding:0;object-fit:contain;filter:drop-shadow(0 1px 2px rgba(0,0,0,.05))}.account-picker-title{font-size:24px;font-weight:500;color:#202124;margin:0 0 8px;line-height:1.4;letter-spacing:-.2px}.account-picker-subtitle{font-size:14px;color:#5f6368;margin:0;line-height:1.5;font-weight:400;letter-spacing:.1px}.account-picker-list{padding:8px 0;border-top:1px solid rgba(0,0,0,.08);overflow-y:auto;flex:1;background:#fff;position:relative;z-index:2;max-height:420px}.account-picker-item{width:100%;display:flex;align-items:center;padding:14px 40px;background:transparent;border:none;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);text-align:left;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;outline:none;position:relative;border-bottom:1px solid rgba(0,0,0,.06)}.account-picker-item:last-child{border-bottom:none}.account-picker-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(90deg,#3b82f6,#1e40af);transition:width .3s ease}.account-picker-item:hover{background:#f8f9fa;transform:translate(2px);border-bottom-color:transparent}.account-picker-item:hover:before{width:3px;background:linear-gradient(180deg,#3b82f6,#1e40af)}.account-picker-item:active{background:#f1f3f4;transform:translate(2px)}.account-picker-item:disabled{opacity:.5;cursor:not-allowed;transform:none}.account-picker-item:focus-visible{background:#f8f9fa;outline:2px solid #3b82f6;outline-offset:-2px}.account-picker-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:600;flex-shrink:0;margin-right:14px;line-height:1;box-shadow:0 2px 6px #0000001f,0 0 0 1px #ffffffe6;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.account-picker-item:hover .account-picker-avatar{transform:scale(1.03);box-shadow:0 3px 10px #0000002e,0 0 0 1px #fffffff2}.account-picker-info{flex:1;min-width:0}.account-picker-name{font-size:15px;font-weight:500;color:#202124;line-height:1.4;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.1px}.account-picker-email{font-size:13px;color:#5f6368;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:.1px}.account-picker-loading{margin-left:auto;display:flex;align-items:center;justify-content:center}.loading-spinner-small{width:16px;height:16px;border:2px solid rgba(255,255,255,.2);border-top-color:#fffc;border-radius:50%;animation:spin .8s linear infinite}.account-picker-footer{padding:18px 40px 22px;border-top:1px solid rgba(0,0,0,.08);background:#f8f9fa;position:relative;z-index:2}.account-picker-footer-text{font-size:12px;color:#5f6368;line-height:1.5;text-align:center;font-weight:400;letter-spacing:.1px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes iconFloat{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-10px) rotate(2deg)}}@keyframes shine{0%{transform:translate(-100%) translateY(-100%) rotate(45deg);opacity:0}50%{opacity:1}to{transform:translate(100%) translateY(100%) rotate(45deg);opacity:0}}@keyframes float{0%,to{transform:translate(0) scale(1)}50%{transform:translate(20px,-20px) scale(1.1)}}@keyframes floatCloud{0%,to{transform:translate(0) translateY(0)}25%{transform:translate(30px) translateY(-20px)}50%{transform:translate(60px) translateY(-10px)}75%{transform:translate(30px) translateY(-30px)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}@media(min-width:768px){.login-left-section{display:block}}@media(max-width:767px){.login-card-large{flex-direction:column;min-height:auto;max-width:440px}.login-right-section{padding:40px 32px;min-height:auto}.login-left-section{display:none}.login-logo-overlay{padding:0;max-width:100%}.login-school-logo{max-width:200px;max-height:200px}.login-school-name{font-size:20px;padding:0 16px}}@media(max-width:480px){.login-container{padding:24px 16px}.login-card-large{border-radius:20px}.login-right-section{padding:40px 24px}.login-icon-wrapper{width:48px;height:48px}.login-icon{font-size:24px}.login-logo-text .login-title{font-size:20px}.login-logo-text .login-subtitle{font-size:12px}.login-welcome-title{font-size:24px}.login-welcome-subtitle{font-size:14px}.login-school-name{font-size:18px;padding:0 12px}.login-school-logo{max-width:180px;max-height:180px}.google-login-button{padding:13px 20px;font-size:14px}.account-picker-overlay{padding:16px}.account-picker-popup{max-width:100%;border-radius:16px}.account-picker-header{padding:24px 24px 16px}.account-picker-item{padding:14px 24px}.account-picker-footer{padding:16px 24px 20px}}@media(max-width:360px){.login-right-section{padding:32px 20px}.login-header{margin-bottom:32px}.login-logo-container{flex-direction:column;text-align:center;gap:12px}.login-icon-wrapper{width:48px;height:48px;margin:0 auto}.login-icon{font-size:24px}.login-logo-text .login-title{font-size:18px}.login-logo-text .login-subtitle{font-size:11px}.login-welcome-title{font-size:22px;text-align:center}.login-welcome-subtitle{font-size:13px;text-align:center}}:root{--sidebar-text: rgba(255, 255, 255, .9);--sidebar-text-muted: rgba(255, 255, 255, .7);--sidebar-hover: rgba(255, 255, 255, .1);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--border-radius: 8px;--transition-base: .2s ease;--z-fixed: 1000}.sidebar{width:240px;height:100vh;display:flex;flex-direction:column;position:fixed;left:0;top:0;z-index:var(--z-fixed);border-right:1px solid rgba(255,255,255,.05);transition:all .3s ease;overflow:hidden}.sidebar-admin,.sidebar-guru{background:#0f1f3d;box-shadow:4px 0 20px #00000026}.sidebar-header{padding:1.5rem 1.5rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.07);display:flex;background-color:#071121;flex-direction:column;align-items:center;text-align:center;gap:.5rem;flex-shrink:0}.sidebar-logo-wrapper{width:52px;height:52px;border-radius:14px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;box-shadow:0 4px 12px #00000040}.sidebar-logo-wrapper img{width:100%;height:100%;object-fit:cover}.sidebar-logo-icon{font-size:1.5rem;color:#ffffffe6}.sidebar-logo-text{font-size:1.1rem;font-weight:800;color:#fff;margin:0;letter-spacing:1px}.sidebar-logo-sub{font-size:.6rem;font-weight:600;color:#fff;margin:0;letter-spacing:1.5px;text-transform:uppercase}.sidebar-role-badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:6px;font-size:.6rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-top:.25rem}.role-badge-admin{background:#3b82f64d;color:#93c5fd;border:1px solid rgba(59,130,246,.4)}.role-badge-guru{background:#10b98140;color:#6ee7b7;border:1px solid rgba(16,185,129,.35)}.sidebar-profile{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0}.profile-avatar{width:40px;height:40px;border-radius:10px;background:#ffffff1f;display:flex;align-items:center;justify-content:center;color:var(--sidebar-text);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);flex-shrink:0;overflow:hidden;border:1px solid rgba(255,255,255,.15)}.profile-avatar-img{width:100%;height:100%;object-fit:cover}.profile-avatar-initial{font-size:var(--font-size-sm);color:var(--sidebar-text)}.profile-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.profile-name{font-size:var(--font-size-sm);font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-role{font-size:var(--font-size-xs);color:#8a9bbe;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-notifications{padding:var(--spacing-sm) var(--spacing-lg);border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-notification-btn{width:100%;display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius);color:var(--sidebar-text-muted);text-decoration:none;transition:all var(--transition-base);cursor:pointer;background:transparent;border:none;font-size:var(--font-size-sm);font-family:inherit;position:relative}.sidebar-notification-btn:hover{color:var(--sidebar-text);background:var(--sidebar-hover)}.sidebar-admin .sidebar-notification-btn:hover,.sidebar-guru .sidebar-notification-btn:hover{background:#3b82f626;color:#93c5fd}.sidebar-admin .sidebar-notification-btn.active,.sidebar-guru .sidebar-notification-btn.active{background:linear-gradient(135deg,#3b82f633,#1e40af33);color:#60a5fa;font-weight:var(--font-weight-medium);border-left:3px solid #3b82f6;box-shadow:0 2px 8px #3b82f633}.notification-icon{font-size:1rem;width:16px;height:16px;flex-shrink:0}.notification-label{flex:1;font-weight:var(--font-weight-normal);text-align:left}.notification-badge{background:#ef4444;color:#fff;border-radius:10px;padding:2px 6px;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);min-width:18px;text-align:center;line-height:1.2}.sidebar-nav{flex:1;padding:var(--spacing-md);overflow-y:auto;overflow-x:hidden;min-height:0}.sidebar-category{margin-top:var(--spacing-sm);margin-bottom:var(--spacing-xs);padding:0}.sidebar-category-header{font-size:.65rem;font-weight:700;color:#8a9bbe;text-transform:uppercase;letter-spacing:.1em;display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg) var(--spacing-sm);cursor:pointer;transition:all var(--transition-base);-webkit-user-select:none;user-select:none}.sidebar-category-header:hover{opacity:1;color:var(--sidebar-text);background:#ffffff0d}.sidebar-category-items{max-height:500px;opacity:1;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);padding-left:1.25rem}.sidebar-category.collapsed .sidebar-category-items{max-height:0;opacity:0;margin-top:0}.chevron-icon{font-size:.75rem;transition:transform .3s ease}.sidebar-category.collapsed .chevron-icon{transform:rotate(-90deg)}.sidebar-category:first-of-type{margin-top:0}.sidebar-item{display:flex;align-items:center;gap:var(--spacing-md);padding:.75rem var(--spacing-md);margin:2px 0;border-radius:10px;color:#8a9bbe;text-decoration:none;transition:all .2s ease;cursor:pointer;background:transparent;border:none;width:100%;font-size:.9rem;font-family:inherit;font-weight:500;text-align:left}.sidebar-item:hover{color:var(--sidebar-text);background:var(--sidebar-hover)}.sidebar-admin .sidebar-item:hover,.sidebar-guru .sidebar-item:hover{background:#3b82f626;color:#93c5fd}.sidebar-item.active{background:#1b3a6b!important;color:#fff!important;font-weight:600;box-shadow:0 4px 12px #0000001a}.sidebar-icon{font-size:1.125rem;width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-label{flex:1}.sidebar-item.disabled{opacity:.5;cursor:not-allowed;pointer-events:none;position:relative}.sidebar-item.disabled:after{content:"";position:absolute;inset:0;background:#0000001a;border-radius:var(--border-radius)}.sidebar-item.disabled:hover{color:var(--sidebar-text-muted);background:transparent}.sidebar-admin .sidebar-item.disabled:hover,.sidebar-guru .sidebar-item.disabled:hover{background:transparent;color:var(--sidebar-text-muted)}.sidebar-footer{padding:var(--spacing-md);border-top:1px solid rgba(255,255,255,.1);flex-shrink:0;background:#0f1f3d;position:sticky;bottom:0;z-index:10}.logout-btn{color:var(--sidebar-text-muted)}.logout-btn:hover{color:#ef4444;background:#ef44441a}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.sidebar-modal-overlay{position:fixed;inset:0;background:#0f172ab3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:sidebarFadeIn .2s ease-out}.sidebar-modal-container{background:#fff;border-radius:16px;width:100%;max-width:400px;padding:2rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;text-align:center;animation:sidebarSlideUp .3s ease-out}.sidebar-modal-title{font-size:1.25rem;font-weight:700;color:#0f172a;margin-bottom:.5rem}.sidebar-modal-message{font-size:.95rem;color:#64748b;margin-bottom:2rem;line-height:1.5}.sidebar-modal-actions{display:flex;gap:1rem;justify-content:center}.sidebar-modal-btn{padding:.75rem 1.5rem;border-radius:10px;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .2s ease;border:1px solid transparent}.sidebar-modal-btn-cancel{background:#f1f5f9;color:#475569}.sidebar-modal-btn-cancel:hover{background:#e2e8f0;color:#1e293b}.sidebar-modal-btn-confirm{background:#ef4444;color:#fff}.sidebar-modal-btn-confirm:hover{background:#dc2626;box-shadow:0 4px 12px #ef444433}@keyframes sidebarFadeIn{0%{opacity:0}to{opacity:1}}@keyframes sidebarSlideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dashboard-layout{display:flex;min-height:100vh;width:100%;max-width:100vw;background:#fff;position:relative;overflow-x:hidden;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.main-content{flex:1;margin-left:240px;display:flex;flex-direction:column;min-height:100vh;padding:2rem;max-width:calc(100vw - 240px);width:calc(100vw - 240px);box-sizing:border-box;position:relative;z-index:1;background:#f0f4f8;overflow-x:hidden}.content-area{flex:1;overflow-y:auto;overflow-x:hidden;width:100%;max-width:100%;position:relative;z-index:1;box-sizing:border-box}@media(max-width:768px){.main-content{margin-left:0;max-width:100vw;width:100vw;padding:1rem;box-sizing:border-box}}select.admin-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}.admin-dashboard{width:100%;max-width:100%;padding:0;animation:guruFadeIn .35s ease-out;box-sizing:border-box}.admin-dashboard .page-header{background:var(--guru-bg-card);border:1px solid var(--guru-border-soft);border-radius:14px;padding:1rem 1.25rem;display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.25rem}.admin-dashboard .page-title{font-size:2rem;font-weight:800;margin:0 0 .45rem;letter-spacing:0;display:flex;align-items:center;gap:.85rem;flex-wrap:wrap}.admin-dashboard .admin-title .title-text{color:var(--guru-text-title);background:none;-webkit-text-fill-color:unset}.admin-dashboard .admin-title .title-badge{background:#1b3a6b;color:#fff;border-radius:999px;padding:.34rem .86rem;font-size:.78rem;line-height:1;text-transform:uppercase;letter-spacing:.04em;border:1px solid rgba(27,58,107,.3);box-shadow:none}.page-subtitle{font-size:.94rem;color:var(--guru-text-muted);margin:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:1.5rem}.admin-dashboard .stat-card{background:#fff;border:1px solid var(--guru-border-soft);border-radius:12px;padding:1.25rem;text-decoration:none;color:inherit;transition:all .2s ease;display:flex;align-items:center;gap:1rem;animation:slideUp .5s ease-out backwards}.admin-dashboard .stat-card:hover{transform:translateY(-3px);box-shadow:0 10px 20px #3b82f61f;border-color:var(--guru-primary)}.admin-dashboard .stat-icon{font-size:1.25rem;color:var(--guru-primary)}.action-card{background:#fff;border:1px solid var(--guru-border-soft);border-left:3px solid var(--guru-primary);border-radius:12px;padding:1.25rem 1rem;text-decoration:none;color:inherit;transition:all .2s ease;display:flex;align-items:center;gap:.75rem;animation:slideUp .5s ease-out backwards}.action-card:hover{transform:translateY(-2px);background:var(--guru-primary-soft);border-color:var(--guru-primary);box-shadow:0 4px 12px #3b82f61a}.admin-dashboard .action-icon{font-size:1.05rem;color:var(--guru-primary)}.periode-info{display:flex;flex-direction:column;gap:.5rem}.periode-nama{font-size:1rem;font-weight:700;color:#0f1f3d}.periode-detail{display:flex;gap:.4rem;flex-wrap:wrap}.periode-badge{background:var(--guru-primary-soft);color:var(--guru-primary);font-size:.72rem;font-weight:600;padding:.2rem .6rem;border-radius:999px;text-transform:uppercase}.periode-dates{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:#64748b}.stats-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.stats-detail-item{background:#f8fafc;border-radius:8px;padding:.75rem;text-align:center;border:1px solid var(--guru-border-soft)}.stats-detail-label{font-size:.72rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em;font-weight:600;margin-bottom:.3rem}.stats-detail-value{font-size:1.5rem;font-weight:800;color:#0f1f3d;line-height:1}.stats-detail-value.primary{color:#3b82f6}.stats-detail-value.success{color:#10b981}.stats-detail-value.danger{color:#ef4444}@media(max-width:768px){.page-title{font-size:1.75rem}.stats-grid{grid-template-columns:1fr;gap:1rem}.actions-grid{grid-template-columns:1fr}}@media(max-width:480px){.stat-value{font-size:1.4rem}}.paket-ujian-page{width:100%;max-width:100%;padding:0;animation:fadeIn .6s ease-out;box-sizing:border-box}.paket-ujian-page .guru-card{margin-top:0}.paket-ujian-error{padding:.75rem 1rem;background:#fef2f2;color:#b91c1c;border-radius:8px;margin-bottom:1rem}.paket-ujian-loading{padding:2rem;text-align:center;color:#64748b}.paket-ujian-table-wrap{overflow-x:auto;border:1px solid var(--guru-border-soft);border-radius:12px;overflow:hidden;background:#fff}.paket-ujian-table{width:100%;border-collapse:collapse}.paket-ujian-table th,.paket-ujian-table td{padding:.75rem 1rem;text-align:left!important;border:none;border-bottom:1px solid var(--guru-bg-row-separator);font-size:.9375rem;color:#0f172a}.paket-ujian-table tr:last-child td{border-bottom:none}.paket-ujian-table tr:hover td{background:var(--guru-bg-table-head)}.paket-ujian-table th{background:#1b3a6bd9;font-weight:700;font-size:.75rem;color:#fff;text-transform:uppercase;letter-spacing:.04em;padding:.9rem 1rem}.paket-ujian-table tbody tr:hover{background:var(--guru-bg-table-head)}.paket-ujian-table .empty-row{text-align:center;color:#64748b;padding:2rem}.token-code{font-family:ui-monospace,monospace;font-size:.9rem;background:#f1f5f9;padding:.2rem .5rem;border-radius:6px;letter-spacing:.05em}.btn-icon{display:inline-flex;align-items:center;justify-content:center;background:var(--btn-secondary-bg);border:1px solid var(--btn-secondary-border);padding:.4rem;cursor:pointer;border-radius:8px;margin-right:.25rem;color:var(--btn-secondary-text);text-decoration:none;transition:all .15s ease}.btn-icon.view,.btn-icon.edit{background:var(--btn-edit-bg);border-color:var(--btn-edit-border);color:var(--btn-edit-text)}.btn-icon.view:hover,.btn-icon.edit:hover{background:var(--btn-edit-hover-bg);border-color:var(--btn-edit-hover-border);color:var(--btn-edit-hover-text);transform:translateY(-1px)}.paket-ujian-form-page .paket-ujian-form-header{margin-bottom:1.5rem}.paket-ujian-form-header .page-title{font-size:1.75rem;margin:.5rem 0 .25rem}.paket-ujian-form-header .page-subtitle{font-size:.95rem;color:#64748b;margin:0}.paket-ujian-form-full{width:100%;max-width:100%;padding:1.5rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-sizing:border-box}.form-section{margin-bottom:2rem;padding:1.25rem;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.form-section-title{margin:0 0 1rem;font-size:1.1rem;font-weight:700;color:#0f172a;padding-bottom:.5rem;border-bottom:2px solid #e2e8f0}.form-section-desc{margin:0 0 1rem;font-size:.9rem;color:#64748b}.form-row.two-cols{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.25rem}.form-group{margin-bottom:0}.form-group>label{display:block;font-size:.8125rem;font-weight:600;color:#1e293b;letter-spacing:.02em;margin-bottom:.5rem;padding-left:.5rem;border-left:3px solid #3b82f6;line-height:1.4}.form-group input[type=text]::placeholder,.form-group textarea::placeholder{color:#94a3b8}.token-input{background:#f1f5f9!important;font-family:ui-monospace,monospace;letter-spacing:.15em;border-color:#94a3b8!important}.token-row .form-group{margin-bottom:0}.form-section-full{width:100%}.soal-picker-filters{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;padding:1rem;background:#f8fafc;border-radius:10px}.soal-picker-filters .filter-group{flex:1;min-width:140px}.soal-picker-filters .filter-group label{display:block;font-size:.8125rem;font-weight:600;color:#1e293b;margin-bottom:.45rem;padding-left:.4rem;border-left:3px solid #64748b}.soal-picker-filters .filter-group select{padding:.6rem .75rem;border:2px solid #cbd5e1;border-radius:8px;background:#fff}.soal-picker-filters .filter-group select:focus{outline:none;border-color:#3b82f6}.soal-picker-actions{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;padding:.75rem 1rem;background:#f8fafc;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:2}.soal-picker-count{font-size:.9375rem;color:#475569}.soal-picker-count strong{color:#0f172a}.soal-picker-buttons{display:flex;gap:.75rem}.btn-secondary{padding:.5rem 1rem;background:var(--btn-secondary-bg);border:1px solid var(--btn-secondary-border);color:var(--btn-secondary-text);border-radius:8px;cursor:pointer;font-weight:500;font-size:.9rem;transition:all .15s ease}.soal-picker-table-wrap{border:1px solid var(--guru-border-soft);border-radius:12px;overflow:auto;max-height:70vh;background:#fff;display:flex;flex-direction:column}.soal-picker-loading,.soal-picker-empty{padding:2rem;text-align:center;color:#64748b}.soal-picker-table{width:100%;border-collapse:collapse}.soal-picker-table th,.soal-picker-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #e2e8f0}.soal-picker-table th{background:#1b3a6bd9;font-weight:700;font-size:.75rem;color:#fff;text-transform:uppercase;letter-spacing:.04em;position:sticky;top:0;z-index:1}.soal-picker-table .col-check{width:44px;text-align:center;vertical-align:middle}.cell-check-label{display:inline-flex;align-items:center;justify-content:center;cursor:pointer;margin:0}.cell-check-label input[type=checkbox]{width:1.1rem;height:1.1rem;cursor:pointer}.soal-picker-table .cell-soal-preview{max-width:280px;overflow:hidden;text-overflow:ellipsis}.soal-picker-table tbody tr{cursor:pointer}.soal-picker-table tbody tr:hover{background:#f8fafc}.soal-picker-table tbody tr.row-selected{background:#eff6ff}.badge-pilgan{background:#dbeafe;color:#1e40af}.badge-pilgan_kompleks{background:#d1fae5;color:#065f46}.badge-pilgan_kategori{background:#fef3c7;color:#92400e}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.form-actions-full{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--btn-secondary-border)}.modal-content.modal-soal{background:#fff;border-radius:16px;max-width:900px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 50px #0003}.modal-content .modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0;flex-shrink:0}.modal-content .modal-title{margin:0;font-size:1.25rem;font-weight:700;color:#0f172a}.modal-content .modal-close{background:none;border:none;padding:.5rem;cursor:pointer;color:#64748b;font-size:1.25rem}.modal-content .modal-close:hover{color:#0f172a}.modal-content .modal-body{padding:1rem 1.5rem;overflow-y:auto;flex:1;min-height:0}.modal-soal-table-wrap{overflow:auto;border:1px solid #e2e8f0;border-radius:12px;max-height:60vh}.modal-soal-table{margin:0}.modal-soal-table .cell-soal-preview{max-width:280px;overflow:hidden;text-overflow:ellipsis}select.admin-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}.admin-jurusan-page{width:100%;max-width:100%;padding:0;animation:guruFadeIn .35s ease-out;box-sizing:border-box;overflow-x:hidden}.jurusan-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;margin-bottom:1.5rem}.jurusan-title{font-size:2rem;font-weight:800;margin:0 0 .45rem;letter-spacing:0;display:flex;align-items:center;gap:.85rem;flex-wrap:wrap}.jurusan-title .title-text{color:var(--guru-text-title);background:none;-webkit-text-fill-color:unset}.jurusan-title .title-badge{background:#1b3a6b;color:#fff;border-radius:999px;padding:.34rem .86rem;font-size:.78rem;line-height:1;text-transform:uppercase;letter-spacing:.04em;border:1px solid rgba(27,58,107,.3);box-shadow:none}.jurusan-subtitle{font-size:1rem;color:#64748b;margin:0}.jurusan-meta{display:flex;gap:.75rem}.jurusan-alert{background:#ef444414;border:1px solid rgba(239,68,68,.25);color:#991b1b;padding:.75rem 1rem;border-radius:12px;margin:1rem 0}.jurusan-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:1.25rem;box-shadow:0 1px 3px #0000000a;margin-top:1rem}.jurusan-form-card{background:var(--guru-bg-card);border:1px solid var(--guru-border-soft);border-radius:14px;padding:2rem;margin-top:1.5rem;position:relative;overflow:hidden}.jurusan-form-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--guru-primary);opacity:.6}.jurusan-card-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.btn-add-jurusan{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:10px;border:1px solid var(--btn-primary-border);background:var(--btn-primary-bg);color:var(--btn-primary-text);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:140px;-webkit-user-select:none;user-select:none}.btn-add-jurusan:hover:not(:disabled){background:var(--btn-primary-hover-bg);border-color:var(--btn-primary-hover-border);transform:translateY(-2px);box-shadow:0 8px 20px #3b82f633}.btn-add-jurusan:disabled{opacity:.6;cursor:not-allowed;transform:none}.jurusan-card-title{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0 0 .375rem;letter-spacing:-.01em}.jurusan-card-subtitle{font-size:.9375rem;color:#64748b;margin:0;line-height:1.5}.jurusan-table-wrap{overflow-x:auto;border-radius:10px;border:1px solid #e2e8f0;background:#fff}.jurusan-table{width:100%;border-collapse:collapse}.jurusan-table th,.jurusan-table td{padding:.75rem 1rem;text-align:left!important;border-bottom:1px solid #e2e8f0;font-size:.9375rem;color:#0f172a;vertical-align:middle}.jurusan-table th{background:#1b3a6bd9;font-weight:700;font-size:.75rem;color:#fff;text-transform:uppercase;letter-spacing:.04em;padding:.9rem 1rem;white-space:nowrap}.jurusan-table tbody tr:hover{background:#f8fafc}.jurusan-form{width:100%}.form-row{display:grid;grid-template-columns:1fr 2fr;gap:1.5rem}.input{width:100%;padding:1rem 1.25rem;border-radius:12px;border:2px solid #e2e8f0;outline:none;transition:all .3s cubic-bezier(.4,0,.2,1);background:#fff;color:#0f172a;font-size:1rem;font-weight:500}.input.small{padding:.6rem .75rem;border-radius:10px}.jurusan-empty{padding:2rem 1rem;text-align:center;color:#64748b}.name-text{font-weight:600;color:#0f172a}.paket-ujian-table th,.paket-ujian-table td{text-align:left;vertical-align:middle}.paket-ujian-table th:first-child,.paket-ujian-table td:first-child,.paket-ujian-table th:nth-child(2),.paket-ujian-table td:nth-child(2){text-align:left}@media(max-width:768px){.admin-jurusan-page{padding:0}.jurusan-header{flex-direction:column;align-items:stretch}.jurusan-title{font-size:2rem}.jurusan-form-card{padding:1.5rem}.header-content{flex-direction:column;gap:1rem}.header-icon-wrapper{width:48px;height:48px}.header-icon,.jurusan-card-title{font-size:1.25rem}.jurusan-card-subtitle{font-size:.875rem}.input{padding:.875rem 1rem;font-size:.9375rem}.btn-submit{width:100%;padding:.875rem 1.5rem;min-width:auto}.form-row{grid-template-columns:1fr;gap:1.25rem}.jurusan-row{grid-template-columns:1fr;gap:.75rem}.col-id,.col-name{width:100%}.col-actions{justify-content:flex-start}.modal-container{max-width:100%;margin:1rem}.modal-header{padding:1.5rem 1.5rem 1rem}.modal-icon-wrapper{width:64px;height:64px;margin-bottom:1rem}.modal-icon{font-size:1.75rem}.modal-title{font-size:1.25rem}.modal-body{padding:1.25rem 1.5rem}.modal-message{font-size:.9375rem}.modal-footer{padding:1.25rem 1.5rem 1.5rem;flex-direction:column}.modal-btn{width:100%;min-width:auto}}.jurusan-header{align-items:center;gap:1rem;flex-wrap:wrap}.jurusan-title{font-size:2rem;letter-spacing:0}.jurusan-title .title-badge{box-shadow:none}.jurusan-card{border-radius:12px;box-shadow:none}.jurusan-row{border-radius:10px;background:#fff}.btn-add-jurusan{border-radius:10px;transition:all .2s ease}.btn-add-jurusan .btn-icon{width:26px;height:26px;font-size:1.4rem}select.admin-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}.admin-kelas-page{width:100%;max-width:100%;padding:0;animation:guruFadeIn .35s ease-out;box-sizing:border-box;overflow-x:hidden}.kelas-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;margin-bottom:1.5rem}.kelas-title{font-size:2rem;font-weight:800;margin:0 0 .45rem;letter-spacing:0;display:flex;align-items:center;gap:.85rem;flex-wrap:wrap}.kelas-title .title-text{color:var(--guru-text-title);background:none;-webkit-text-fill-color:unset}.kelas-title .title-badge{background:#1b3a6b;color:#fff;border-radius:999px;padding:.34rem .86rem;font-size:.78rem;line-height:1;text-transform:uppercase;letter-spacing:.04em;border:1px solid rgba(27,58,107,.3);box-shadow:none}.kelas-subtitle{font-size:1rem;color:#64748b;margin:0}.kelas-meta{display:flex;gap:.75rem}.kelas-alert{background:#ef444414;border:1px solid rgba(239,68,68,.25);color:#991b1b;padding:.75rem 1rem;border-radius:12px;margin:1rem 0}.kelas-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:1.25rem;box-shadow:0 1px 3px #0000000a;margin-top:1rem}.kelas-form-card{background:var(--guru-bg-card);border:1px solid var(--guru-border-soft);border-radius:14px;padding:2rem;margin-top:1.5rem;position:relative;overflow:hidden}.kelas-form-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--guru-primary);opacity:.6}.kelas-card-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.btn-add-kelas{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:10px;border:1px solid var(--btn-primary-border);background:var(--btn-primary-bg);color:var(--btn-primary-text);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:140px;-webkit-user-select:none;user-select:none}.btn-add-kelas:hover:not(:disabled){background:var(--btn-primary-hover-bg);border-color:var(--btn-primary-hover-border);transform:translateY(-2px);box-shadow:0 8px 20px #3b82f633}.btn-add-kelas:disabled{opacity:.6;cursor:not-allowed;transform:none}.kelas-card-title{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0 0 .375rem;letter-spacing:-.01em}.kelas-card-subtitle{font-size:.9375rem;color:#64748b;margin:0;line-height:1.5}.kelas-form{width:100%}.form-row{display:grid;grid-template-columns:1fr 2fr 1fr;gap:1.5rem}.input:focus{border-color:var(--guru-primary);box-shadow:0 0 0 4px #3b82f61a;background:var(--guru-bg-card)}select.input{cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:12px 12px;background-clip:padding-box;padding-right:2.5rem}select.input:focus{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%233b82f6' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-size:12px 12px;background-repeat:no-repeat;background-position:right 1rem center;background-clip:padding-box}.btn-submit{display:inline-flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 2rem;border-radius:12px;border:none;background:linear-gradient(135deg,#3b82f6,#1e40af);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none;box-shadow:0 4px 14px #3b82f640,0 0 #3b82f666;align-self:flex-start;min-width:180px}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #3b82f659,0 0 0 4px #3b82f61a}.btn-submit:active:not(:disabled){transform:translateY(0);box-shadow:0 4px 14px #3b82f640,0 0 0 2px #3b82f633}.btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:0 2px 8px #3b82f626}select.input.small{padding-right:2rem;background-size:10px 10px;background-position:right .75rem center}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem .9rem;border-radius:12px;border:1px solid #e2e8f0;background:#fff;color:#0f172a;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.btn.danger{border-color:var(--btn-danger-border);color:var(--btn-danger-text)}.btn.danger:hover{background:var(--btn-danger-hover-bg);border-color:var(--btn-danger-hover-border);color:var(--btn-danger-hover-text);box-shadow:0 8px 20px #ef444433}.kelas-empty{padding:2rem 1rem;text-align:center;color:#64748b}.kelas-table-wrap{overflow-x:auto;border-radius:10px;border:1px solid #e2e8f0;background:#fff}.kelas-table{width:100%;border-collapse:collapse}.kelas-table th,.kelas-table td{padding:.75rem 1rem;text-align:left!important;border-bottom:1px solid #e2e8f0;font-size:.9375rem;color:#0f172a;vertical-align:middle}.kelas-table th{background:#1b3a6bd9;font-weight:700;font-size:.75rem;color:#fff;text-transform:uppercase;letter-spacing:.04em;padding:.9rem 1rem;white-space:nowrap}.kelas-table tbody tr:hover{background:#f8fafc}.modal-container.modal-form{max-width:520px}.modal-btn-primary{background:var(--btn-primary-bg);border-color:var(--btn-primary-border);color:var(--btn-primary-text)}.modal-btn-danger{background:var(--btn-danger-bg);border-color:var(--btn-danger-border);color:var(--btn-danger-text)}@media(max-width:1024px){.form-row{grid-template-columns:1fr;gap:1.25rem}.kelas-row{grid-template-columns:1fr;gap:.75rem}.col-nama,.col-tingkat,.col-jurusan,.col-inisial{width:100%}}@media(max-width:768px){.admin-kelas-page{padding:0}.kelas-header{flex-direction:column;align-items:stretch}.kelas-title{font-size:2rem}.kelas-form-card{padding:1.5rem}.header-content{flex-direction:column;gap:1rem}.header-icon-wrapper{width:48px;height:48px}.header-icon,.kelas-card-title{font-size:1.25rem}.kelas-card-subtitle{font-size:.875rem}.input{padding:.875rem 1rem;font-size:.9375rem}.btn-submit{width:100%;padding:.875rem 1.5rem;min-width:auto}.kelas-row{grid-template-columns:1fr}.col-actions{justify-content:flex-start}.modal-container{max-width:100%;margin:1rem}.modal-header{padding:1.5rem 1.5rem 1rem}.modal-icon-wrapper{width:64px;height:64px;margin-bottom:1rem}.modal-icon{font-size:1.75rem}.modal-title{font-size:1.25rem}.modal-body{padding:1.25rem 1.5rem}.modal-message{font-size:.9375rem}.modal-footer{padding:1.25rem 1.5rem 1.5rem;flex-direction:column}.modal-btn{width:100%;min-width:auto}}.kelas-header{align-items:center;gap:1rem;flex-wrap:wrap}.kelas-title{font-size:2rem;letter-spacing:0}.kelas-title .title-badge{box-shadow:none}.kelas-card{border-radius:12px;box-shadow:none}.btn-add-kelas{border-radius:10px;transition:all .2s ease}.btn-add-kelas .btn-icon{width:26px;height:26px;font-size:1.4rem}select.admin-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}select.input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}select.input:focus{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%233b82f6' d='M6 9L1 4h10z'/%3E%3C/svg%3E")}select.admin-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}select.input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}select.input:focus{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%233b82f6' d='M6 9L1 4h10z'/%3E%3C/svg%3E")}.siswa-table-wrap{overflow-x:auto;border-radius:10px;border:1px solid #e2e8f0;background:#fff}.siswa-table{width:100%;border-collapse:collapse}.siswa-table th,.siswa-table td{padding:.75rem 1rem;text-align:left!important;border-bottom:1px solid #e2e8f0;font-size:.9375rem;color:#0f172a;vertical-align:middle}.siswa-table th{background:#1b3a6bd9;font-weight:700;font-size:.75rem;color:#fff;text-transform:uppercase;letter-spacing:.04em;padding:.9rem 1rem;white-space:nowrap}.siswa-table tbody tr:hover{background:#f8fafc}.modal-warning{color:#ef4444;background:#fef2f2;border:1px solid #fee2e2;padding:.5rem;margin-top:1rem;border-radius:8px;font-size:.875rem}.kelas-badge{white-space:nowrap;min-width:160px;text-align:center;padding:6px 12px!important;display:inline-block;line-height:1.2}@media(max-width:1024px){.siswa-table-grid .user-row{grid-template-columns:1fr 1fr;gap:1rem;padding:1.5rem}.col-actions{grid-column:span 2;justify-content:flex-start}}.siswa-table th:last-child,.siswa-table td:last-child{position:sticky;right:0;background:#fff;z-index:1;box-shadow:-2px 0 5px #0000000d}.siswa-table th:last-child{background:#1b3a6bd9;z-index:2}.siswa-table tbody tr:hover td:last-child{background:#f8fafc}select.admin-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}select.input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}select.input:focus{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%233b82f6' d='M6 9L1 4h10z'/%3E%3C/svg%3E")}.identitas-wrapper{display:flex;flex-direction:column;gap:2px}.guru-table-wrap{overflow-x:auto;border-radius:10px;border:1px solid #e2e8f0;background:#fff}.guru-table{width:100%;border-collapse:collapse}.guru-table th,.guru-table td{padding:.75rem 1rem;text-align:left!important;border-bottom:1px solid #e2e8f0;font-size:.9375rem;color:#0f172a;vertical-align:middle}.guru-table th{background:#1b3a6bd9;font-weight:700;font-size:.75rem;color:#fff;text-transform:uppercase;letter-spacing:.04em;padding:.9rem 1rem;white-space:nowrap}.guru-table tbody tr:hover{background:#f8fafc}.btn-action.primary{background:#3b82f6;color:#fff;border-color:#2563eb}.btn-action.primary:hover:not(:disabled){background:#2563eb}.btn-action.btn-delete{background:#ef4444;color:#fff;border-color:#dc2626}.nip-text{font-family:monospace;font-size:.9375rem;color:#475569}.edit-cell-group{display:flex;flex-direction:column;gap:.5rem;width:100%}.modal-btn-primary{background:linear-gradient(135deg,#3b82f6,#1e40af);color:#fff;border:none}.modal-btn-danger{background:#ef4444;color:#fff;border:none}.modal-btn-primary:hover{filter:brightness(1.1)}.text-center{text-align:center}@media(max-width:1024px){.guru-table-grid .user-row{grid-template-columns:1fr 1fr;gap:1rem;padding:1.5rem}.col-actions{grid-column:span 2;justify-content:flex-start}}.guru-table th:last-child,.guru-table td:last-child{position:sticky;right:0;background:#fff;z-index:1;box-shadow:-2px 0 5px #0000000d}.guru-table th:last-child{background:#1b3a6bd9;z-index:2}.guru-table tbody tr:hover td:last-child{background:#f8fafc}select.admin-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}.mapel-page{width:100%;max-width:100%;padding:0;animation:guruFadeIn .35s ease-out;box-sizing:border-box;overflow-x:hidden}.mapel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;margin-bottom:1.5rem}.mapel-title{font-size:2rem;font-weight:800;margin:0 0 .45rem;letter-spacing:0;display:flex;align-items:center;gap:.85rem;flex-wrap:wrap}.mapel-title .title-text{color:var(--guru-text-title);background:none;-webkit-text-fill-color:unset}.mapel-title .title-badge{background:#1b3a6b;color:#fff;border-radius:999px;padding:.34rem .86rem;font-size:.78rem;line-height:1;text-transform:uppercase;letter-spacing:.04em;border:1px solid rgba(27,58,107,.3);box-shadow:none}.mapel-subtitle{font-size:1rem;color:#64748b;margin:0}.mapel-meta{display:flex;gap:.75rem}.mapel-meta .meta-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:.875rem 1rem;min-width:92px;box-shadow:0 1px 3px #0000000a}.mapel-meta .meta-label{font-size:.75rem;color:#64748b}.mapel-meta .meta-value{font-size:1.25rem;font-weight:700;color:#0f172a}.mapel-alert{background:#ef444414;border:1px solid rgba(239,68,68,.25);color:#991b1b;padding:.75rem 1rem;border-radius:12px;margin:1rem 0}.mapel-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:1.25rem;box-shadow:0 1px 3px #0000000a;margin-top:1rem}.mapel-card-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.mapel-card-title{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0}.btn-add-mapel{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:10px;border:1px solid var(--btn-primary-border);background:var(--btn-primary-bg);color:var(--btn-primary-text);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:140px}.btn-add-mapel:hover:not(:disabled){background:var(--btn-primary-hover-bg);border-color:var(--btn-primary-hover-border);transform:translateY(-2px);box-shadow:0 8px 20px #3b82f633}.btn-add-mapel:disabled{opacity:.6;cursor:not-allowed}.btn-add-mapel .btn-icon{font-size:1.125rem}.mapel-empty{padding:2rem 1rem;text-align:center;color:#64748b}.mapel-table-wrap{overflow-x:auto;border-radius:10px;border:1px solid #e2e8f0;background:#fff}.mapel-table{width:100%;border-collapse:collapse}.mapel-table th,.mapel-table td{padding:.75rem 1rem;text-align:left!important;border-bottom:1px solid #e2e8f0;font-size:.9375rem;color:#0f172a;vertical-align:middle}.mapel-table th{background:#1b3a6bd9;font-weight:700;font-size:.75rem;color:#fff;text-transform:uppercase;letter-spacing:.04em;padding:.9rem 1rem;white-space:nowrap}.mapel-table tbody tr:hover{background:#f8fafc}.mapel-form .form-group{margin-bottom:1.25rem}.mapel-form .form-group:last-child{margin-bottom:0}.mapel-form .label{display:block;font-size:.9375rem;font-weight:600;color:#0f172a;margin-bottom:.4rem}.mapel-form .label-required{color:#ef4444}.mapel-form .input{width:100%;padding:.75rem 1rem;border-radius:10px;border:1px solid #e2e8f0;font-size:1rem}.mapel-form .input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.mapel-form .textarea{resize:vertical;min-height:80px}.mapel-form .field-hint{font-size:.8125rem;color:#64748b;margin:.35rem 0 0;font-weight:400}.kategori-options{display:flex;gap:1.5rem;flex-wrap:wrap}.radio-label{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9375rem;font-weight:500;color:#0f172a}.radio-label input{width:1.1rem;height:1.1rem;accent-color:#3b82f6}.mapel-page .modal-overlay{position:fixed;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.mapel-page .modal-container{background:#fff;border-radius:16px;box-shadow:0 20px 60px #00000040;max-width:520px;width:100%;overflow:hidden}.mapel-page .modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0}.mapel-page .modal-title{margin:0;font-size:1.25rem}.mapel-page .modal-close{background:none;border:none;padding:.5rem;cursor:pointer;color:#64748b;font-size:1.25rem}.mapel-page .modal-close:hover:not(:disabled){color:#0f172a}.mapel-page .modal-body{padding:1.5rem}.mapel-page .modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #e2e8f0}.mapel-page .modal-btn{padding:.6rem 1.25rem;border-radius:10px;font-weight:600;cursor:pointer;border:1px solid #e2e8f0;background:#fff;display:inline-flex;align-items:center;gap:.5rem}.mapel-page .modal-btn-cancel:hover{background:#f1f5f9}.mapel-page .modal-btn-primary{background:var(--btn-primary-bg);border-color:var(--btn-primary-border);color:var(--btn-primary-text)}.mapel-page .modal-btn-primary:hover:not(:disabled){background:var(--btn-primary-hover-bg);border-color:var(--btn-primary-hover-border);transform:translateY(-2px)}.mapel-page .modal-btn-danger{background:var(--btn-danger-bg);border-color:var(--btn-danger-border);color:var(--btn-danger-text)}.mapel-page .modal-btn-danger:hover:not(:disabled){background:var(--btn-danger-hover-bg);border-color:var(--btn-danger-hover-border);color:var(--btn-danger-hover-text);transform:translateY(-2px)}@media(max-width:900px){.mapel-header{align-items:center;gap:1rem;flex-wrap:wrap}.mapel-title{font-size:2rem;letter-spacing:0}.mapel-title .title-badge{box-shadow:none}.mapel-meta .meta-card{border-radius:10px;box-shadow:none}.mapel-card{border-radius:12px;box-shadow:none}.btn-add-mapel{border-radius:10px}.btn-add-mapel .btn-icon{width:26px;height:26px;font-size:1.4rem}}select.admin-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}.admin-angkatan-page{width:100%;max-width:100%;padding:0;animation:guruFadeIn .35s ease-out;box-sizing:border-box;overflow-x:hidden}.angkatan-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;margin-bottom:1.5rem}.angkatan-title{font-size:2rem;font-weight:800;margin:0 0 .45rem;letter-spacing:0;display:flex;align-items:center;gap:.85rem;flex-wrap:wrap}.angkatan-title .title-text{color:var(--guru-text-title);background:none;-webkit-text-fill-color:unset}.angkatan-subtitle{font-size:1rem;color:#64748b;margin:0}.angkatan-table-wrap{overflow-x:auto;border-radius:10px;border:1px solid #e2e8f0;background:#fff}.angkatan-table{width:100%;border-collapse:collapse}.angkatan-table th,.angkatan-table td{padding:.75rem 1rem;text-align:left!important;border-bottom:1px solid #e2e8f0;font-size:.9375rem;color:#0f172a;vertical-align:middle}.angkatan-table th{background:#1b3a6bd9;font-weight:700;font-size:.75rem;color:#fff;text-transform:uppercase;letter-spacing:.04em;padding:.9rem 1rem;white-space:nowrap}.angkatan-table tbody tr:hover{background:#f8fafc}.angkatan-table th.text-center,.angkatan-table td.text-center{text-align:center!important}.admin-page{width:100%;max-width:100%;box-sizing:border-box;animation:guruFadeIn .35s ease-out}.admin-header-card{background:var(--guru-bg-card);border:1px solid var(--guru-border-soft);border-radius:14px;padding:1rem 1.25rem;display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.25rem}.admin-title{margin:0 0 .45rem;color:var(--guru-text-title);font-size:2rem;font-weight:800;display:flex;align-items:center;gap:.85rem;flex-wrap:wrap}.admin-title-text{color:var(--guru-text-title)}.admin-badge{background:#1b3a6b;color:#fff;border-radius:999px;padding:.34rem .86rem;font-size:.78rem;line-height:1;text-transform:uppercase;letter-spacing:.04em;border:1px solid rgba(27,58,107,.3)}.admin-subtitle{margin:0;color:var(--guru-text-muted);font-size:.94rem}.admin-meta{display:flex;gap:.7rem;flex-wrap:wrap}.admin-meta-card{background:#fff;border:1px solid var(--guru-border-soft);border-radius:12px;padding:.85rem 1.25rem;min-width:110px;text-align:center;transition:all .3s ease;box-shadow:0 2px 4px #00000005}.admin-meta-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #3b82f626;border-color:var(--guru-primary)}.admin-meta-card.blue-accent{background:var(--guru-primary-soft);border:1px solid #BFDBFE}.admin-meta-label{color:var(--guru-primary);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.admin-meta-value{color:var(--guru-text-title);font-size:1.4rem;font-weight:800;line-height:1}.admin-card{background:var(--guru-bg-card);border:1px solid var(--guru-border-soft);border-radius:14px;padding:1.1rem}.admin-card+.admin-card{margin-top:1rem}.admin-card-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1rem}.admin-card-title{margin:0;color:var(--guru-text-title);font-size:1.1rem;font-weight:800}.admin-alert{background:#fef2f2;border:1px solid #FEE2E2;color:#991b1b;padding:.75rem 1rem;border-radius:12px;margin:1rem 0}.admin-success{background:var(--guru-success-soft);border:1px solid #86EFAC;color:#15803d;padding:.75rem 1rem;border-radius:12px;margin:1rem 0}.admin-stat-card{background:var(--guru-bg-card);border:1px solid var(--guru-border-soft);border-radius:12px;padding:1.25rem;transition:all .2s ease;display:flex;align-items:center;gap:1rem;animation:slideUp .5s ease-out backwards;text-decoration:none;color:inherit}.admin-stat-card:hover{transform:translateY(-3px);box-shadow:0 10px 20px #3b82f61f;border-color:var(--guru-primary)}.admin-stat-icon-wrapper{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--guru-primary-soft);flex-shrink:0}.admin-stat-icon{font-size:1.25rem;color:var(--guru-primary)}.admin-stat-content{flex:1;min-width:0}.admin-stat-value{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0 0 .25rem;line-height:1.2}.admin-stat-title{font-size:.84rem;color:#64748b;margin:0}.admin-action-card{background:var(--guru-bg-card);border:1px solid var(--guru-border-soft);border-left:3px solid var(--guru-primary);border-radius:12px;padding:1.25rem 1rem;text-decoration:none;color:inherit;transition:all .2s ease;display:flex;align-items:center;gap:.75rem;animation:slideUp .5s ease-out backwards}.admin-action-card:hover{transform:translateY(-2px);background:var(--guru-primary-soft);border-color:var(--guru-primary);box-shadow:0 4px 12px #3b82f61a}.admin-action-icon-wrapper{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--guru-primary-soft)}.admin-action-icon{font-size:1.05rem;color:var(--guru-primary)}.admin-action-label{font-size:.9rem;font-weight:700;color:#0f1f3d}.btn-primary-admin{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:10px;border:1px solid var(--btn-primary-border);background:var(--btn-primary-bg);color:var(--btn-primary-text);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.btn-primary-admin:hover:not(:disabled){background:var(--btn-primary-hover-bg);border-color:var(--btn-primary-hover-border);transform:translateY(-2px);box-shadow:0 8px 20px #3b82f633}.btn-primary-admin:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary-admin{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:10px;border:1px solid var(--btn-secondary-border);background:var(--btn-secondary-bg);color:var(--btn-secondary-text);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-secondary-admin:hover:not(:disabled){background:var(--btn-secondary-hover-bg);border-color:var(--btn-secondary-hover-border);transform:translateY(-1px)}.btn-secondary-admin:disabled{opacity:.6;cursor:not-allowed}.btn-danger-admin{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:10px;border:1px solid var(--btn-danger-border);background:var(--btn-danger-bg);color:var(--btn-danger-text);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-danger-admin:hover:not(:disabled){background:var(--btn-danger-hover-bg);border-color:var(--btn-danger-hover-border);color:var(--btn-danger-hover-text);transform:translateY(-2px)}.btn-danger-admin:disabled{opacity:.6;cursor:not-allowed}.btn-ghost-admin{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem .9rem;border-radius:10px;border:1px solid transparent;background:transparent;color:var(--guru-text-body);font-weight:600;cursor:pointer;transition:all .2s ease}.btn-success-admin{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:10px;border:1px solid var(--btn-success-border);background:var(--btn-success-bg);color:var(--btn-success-text);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-success-admin:hover:not(:disabled){background:var(--btn-success-hover-bg);border-color:var(--btn-success-hover-border);color:var(--btn-success-hover-text);transform:translateY(-1px)}.admin-table-wrap{overflow-x:auto;border-radius:12px;border:1px solid var(--guru-border-soft);background:var(--guru-bg-card)}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{padding:.8rem 1rem;text-align:left!important;border-bottom:1px solid var(--guru-border-soft);font-size:.9375rem;color:var(--guru-text-body);vertical-align:middle}.admin-table th{background:var(--guru-bg-table-head);font-weight:700;font-size:.9rem;color:var(--guru-text-title)}.admin-table tbody tr:hover{background:var(--guru-surface-hover)}.btn-action-admin{width:34px;height:34px;padding:0;border-radius:8px;border:1px solid var(--guru-border-soft);background:var(--guru-bg-card);color:var(--guru-text-muted);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn-action-admin:hover:not(:disabled){background:var(--guru-surface-hover);border-color:var(--guru-border-medium);color:var(--guru-text-body);transform:translateY(-1px)}.btn-action-admin.primary{background:var(--guru-primary);color:#fff;border-color:var(--guru-primary-hover)}.btn-action-admin.primary:hover:not(:disabled){background:var(--guru-primary-hover)}.btn-action-admin.danger{background:var(--guru-danger);color:#fff;border-color:#dc2626}.btn-action-admin.danger:hover:not(:disabled){background:#dc2626}.admin-status-badge{display:inline-flex;align-items:center;justify-content:flex-start;padding:.35rem .75rem;border-radius:6px;font-size:.8125rem;font-weight:600}.admin-status-badge.aktif{background:var(--guru-success-soft);color:#16a34a}.admin-status-badge.nonaktif{background:var(--guru-danger-soft);color:#ef4444}.admin-field-wrapper{display:flex;flex-direction:column;gap:.75rem}.admin-label{display:flex;align-items:center;gap:.25rem;font-size:.9375rem;font-weight:600;color:var(--guru-text-body)}.admin-label-required{color:var(--guru-danger);font-weight:700}.admin-label-optional{color:var(--guru-text-muted);font-weight:400;font-size:.8125rem;font-style:italic}.admin-input{width:100%;padding:.8rem 1rem;border:2px solid var(--guru-border-soft);border-radius:10px;outline:none;transition:all .3s ease;background:var(--guru-bg-card);color:var(--guru-text-body);font-size:1rem;font-weight:500;font-family:inherit}.admin-input::placeholder{color:var(--guru-text-soft);font-weight:400}.admin-input:focus{border-color:var(--guru-primary);box-shadow:0 0 0 4px #3b82f61a}.admin-input:disabled{background:var(--guru-bg-row-separator);color:var(--guru-text-soft);cursor:not-allowed}.admin-input.small{padding:.6rem .75rem;border-radius:10px;font-size:.9375rem}select.admin-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}.admin-field-hint{font-size:.8125rem;color:var(--guru-text-muted);margin:0;font-weight:400}.admin-empty{padding:2rem 1rem;text-align:center;color:var(--guru-text-muted);font-size:.9375rem}.pagination-container{display:flex;justify-content:space-between;align-items:center;margin-top:1.5rem;padding:1rem 1.5rem;background:var(--guru-bg-card);border-radius:14px;border:1px solid var(--guru-border-soft)}.pagination-info{font-size:.875rem;color:var(--guru-text-muted);font-weight:500}.pagination-info strong{color:var(--guru-text-title);font-weight:700}.btn-pagination{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid var(--guru-border-soft);background:var(--guru-bg-card);color:var(--guru-text-muted);cursor:pointer;transition:all .2s ease;font-size:.875rem;font-weight:600}.btn-pagination:hover:not(:disabled){border-color:var(--guru-primary);color:var(--guru-primary);background:var(--guru-primary-soft);transform:translateY(-1px)}.btn-pagination.active{background:var(--btn-primary-bg);border-color:var(--btn-primary-border);color:var(--btn-primary-text)}.btn-pagination:disabled{opacity:.5;cursor:not-allowed}.search-input{width:100%;padding:.625rem 1rem .625rem 2.5rem;border-radius:12px;border:1px solid var(--guru-border-soft);background:var(--guru-bg-page);font-size:.875rem;font-weight:500;color:var(--guru-text-body);transition:all .2s ease}.search-input:focus{outline:none;border-color:var(--guru-primary);background:var(--guru-bg-card);box-shadow:0 0 0 4px #3b82f61a}.search-input::placeholder{color:var(--guru-text-soft)}.modal-overlay-admin{position:fixed;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem;animation:guruFadeIn .2s ease-out}.modal-container-admin{background:var(--guru-bg-card);border-radius:16px;box-shadow:0 20px 60px #0003;max-width:480px;width:100%;overflow:hidden;animation:slideUpModal .3s cubic-bezier(.16,1,.3,1);position:relative}.modal-container-admin.modal-form{max-width:680px}.modal-header-admin{padding:1.5rem 2rem 1rem;border-bottom:1px solid var(--guru-border-soft);display:flex;align-items:center;justify-content:space-between}.modal-title-admin{font-size:1.25rem;font-weight:700;color:var(--guru-text-title);margin:0}.modal-close-admin{background:none;border:none;color:var(--guru-text-muted);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s;font-size:1.25rem}.modal-close-admin:hover{background:var(--guru-surface-hover);color:var(--guru-text-title)}.modal-body-admin{padding:1.5rem 2rem}.modal-container-admin.modal-form .modal-body-admin{padding:0 2rem 1rem;max-height:60vh;overflow-y:auto}.modal-footer-admin{padding:1.25rem 2rem 1.5rem;display:flex;gap:.75rem;justify-content:flex-end}.spinner-admin{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@media(max-width:768px){.admin-title{font-size:1.75rem}.admin-header-card{padding:.9rem 1rem}.modal-container-admin{max-width:100%;margin:1rem}.pagination-container{flex-direction:column;gap:1rem;text-align:center}}.admin-user-page{width:100%;max-width:100%;padding:0;animation:guruFadeIn .35s ease-out;box-sizing:border-box;overflow-x:hidden}.user-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;margin-bottom:1.5rem}.user-title{font-size:2rem;font-weight:800;margin:0 0 .45rem;letter-spacing:0;display:flex;align-items:center;gap:.85rem;flex-wrap:wrap}.user-title .title-text{color:var(--guru-text-title);background:none;-webkit-text-fill-color:unset}.user-title .title-badge{background:#1b3a6b;color:#fff;border-radius:999px;padding:.34rem .86rem;font-size:.78rem;line-height:1;text-transform:uppercase;letter-spacing:.04em;border:1px solid rgba(27,58,107,.3);box-shadow:none}.user-subtitle{font-size:1rem;color:#64748b;margin:0}.user-meta{display:flex;gap:.75rem}.meta-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:.875rem 1rem;min-width:92px;box-shadow:0 1px 3px #0000000a}.meta-label{font-size:.75rem;color:#64748b}.meta-value{font-size:1.25rem;font-weight:700;color:#0f172a}.user-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:1.25rem;box-shadow:0 1px 3px #0000000a;margin-top:1rem}.user-form-card{background:var(--guru-bg-card);border:1px solid var(--guru-border-soft);border-radius:14px;padding:2rem;margin-top:1.5rem;position:relative;overflow:hidden}.user-form-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--guru-primary);opacity:.6}.btn-add-user{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:10px;border:1px solid var(--btn-primary-border);background:var(--btn-primary-bg);color:var(--btn-primary-text);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.btn-add-user:hover:not(:disabled){background:var(--btn-primary-hover-bg);border-color:var(--btn-primary-hover-border);transform:translateY(-2px);box-shadow:0 8px 20px #3b82f633}.btn-add-user:disabled{opacity:.6;cursor:not-allowed;transform:none}.header-content{display:flex;align-items:flex-start;gap:1.25rem;flex:1}.header-icon-wrapper{width:56px;height:56px;border-radius:14px;background:var(--guru-primary-soft);display:flex;align-items:center;justify-content:center;flex-shrink:0}.header-icon{font-size:1.5rem;color:#3b82f6}.user-card-title{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0 0 .375rem;letter-spacing:-.01em}.user-card-subtitle{font-size:.9375rem;color:#64748b;margin:0;line-height:1.5}.user-alert,.user-success{padding:1rem 1.25rem;border-radius:12px;margin-bottom:1.5rem;font-size:.9375rem;font-weight:500;display:flex;align-items:center;gap:.75rem;animation:fadeIn .3s ease}.user-alert{background:#fef2f2;border:1px solid #fee2e2;color:#b91c1c}.user-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d}.user-form{width:100%}.form-group{display:flex;flex-direction:column;gap:1.5rem}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.field-wrapper{display:flex;flex-direction:column;gap:.75rem}.label{display:flex;align-items:center;gap:.25rem;font-size:.9375rem;font-weight:600;color:#0f172a}.label-text{display:inline-block}.label-required{color:#ef4444;font-weight:700}.label-optional{color:#64748b;font-weight:400;font-size:.8125rem;font-style:italic}.input-wrapper{position:relative;width:100%}.password-wrapper{display:flex;align-items:center}.password-wrapper .input{padding-right:3rem}.password-toggle{position:absolute;right:1rem;background:none;border:none;color:#64748b;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;transition:color .2s}.password-toggle:hover{color:#3b82f6}.password-toggle:disabled{opacity:.5;cursor:not-allowed}.input{width:100%;padding:1rem 1.25rem;border-radius:12px;border:2px solid #e2e8f0;outline:none;transition:all .3s cubic-bezier(.4,0,.2,1);background:#fff;color:#0f172a;font-size:1rem;font-weight:500;font-family:inherit}.input::placeholder{color:#94a3b8;font-weight:400}.input:focus{border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f61a,0 4px 12px #3b82f614;background:#fff}.input:disabled{background:#f1f5f9;color:#94a3b8;cursor:not-allowed}select.input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}select.input:focus{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%233b82f6' d='M6 9L1 4h10z'/%3E%3C/svg%3E")}.input-underline{position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#3b82f6,#1e40af);transform:scaleX(0);transform-origin:left;transition:transform .3s cubic-bezier(.4,0,.2,1);border-radius:2px}.input:focus~.input-underline{transform:scaleX(1)}.field-hint{font-size:.8125rem;color:#64748b;margin:0;font-weight:400}.btn-submit{display:inline-flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 2rem;border-radius:10px;border:1px solid var(--btn-primary-border);background:var(--btn-primary-bg);color:var(--btn-primary-text);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;align-self:flex-start;min-width:180px}.btn-submit:hover:not(:disabled){background:var(--btn-primary-hover-bg);border-color:var(--btn-primary-hover-border);transform:translateY(-2px);box-shadow:0 8px 20px #3b82f633}.btn-submit:active:not(:disabled){transform:translateY(0)}.btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-icon{font-size:1.125rem;width:20px;height:20px}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.input.small{padding:.6rem .75rem;border-radius:10px;font-size:.9375rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:12px;border:1px solid #e2e8f0;background:#fff;color:#0f172a;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.btn:hover{transform:translateY(-1px);box-shadow:0 10px 25px #0f172a14}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.btn.primary{border-color:var(--btn-primary-border);background:var(--btn-primary-bg);color:var(--btn-primary-text)}.btn.primary:hover{background:var(--btn-primary-hover-bg);border-color:var(--btn-primary-hover-border);transform:translateY(-2px);box-shadow:0 8px 20px #3b82f633}.btn.ghost{background:transparent}.btn.danger{border-color:#ef444459;color:#b91c1c}.btn.danger:hover{box-shadow:0 12px 30px #ef44441f}.user-empty{padding:2rem 1rem;text-align:center;color:#64748b}.user-table-wrap{overflow-x:auto;border-radius:10px;border:1px solid #e2e8f0;background:#fff}.user-table{width:100%;border-collapse:collapse}.user-table th,.user-table td{padding:.75rem 1rem;text-align:left!important;border-bottom:1px solid #e2e8f0;font-size:.9375rem;color:#0f172a;vertical-align:middle}.user-table th{background:#1b3a6bd9;font-weight:700;font-size:.75rem;color:#fff;text-transform:uppercase;letter-spacing:.04em;padding:.9rem 1rem;white-space:nowrap}.user-table tbody tr:hover{background:#f8fafc}.user-table th.text-center,.siswa-table th.text-center,.guru-table th.text-center{text-align:center!important}.status-badge{display:inline-flex;align-items:center;justify-content:flex-start;padding:.35rem .75rem;border-radius:6px;font-size:.8125rem;font-weight:600;margin:0;text-align:left}.status-aktif{background-color:#f0fdf4;color:#16a34a}.status-nonaktif{background-color:#fef2f2;color:#ef4444}.btn-action{width:34px;height:34px;padding:0;border-radius:8px;border:1px solid #e2e8f0;background:#fff;color:#475569;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}.btn-action:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1;color:#0f172a;transform:translateY(-1px)}.btn-action.primary{background:var(--guru-primary);color:#fff;border-color:var(--guru-primary-hover)}.btn-action.primary:hover:not(:disabled){background:var(--guru-primary-hover)}.btn-action.btn-delete{background:var(--guru-danger);color:#fff;border-color:#dc2626}.btn-action.btn-delete:hover:not(:disabled){background:#dc2626}.google-linked-hint{font-size:.75rem;color:#64748b;font-style:italic;margin-bottom:.5rem}.password-edit-wrapper{width:100%;margin-bottom:.5rem}.password-edit-wrapper .input-wrapper{position:relative}.password-edit-wrapper .password-toggle{position:absolute;right:.5rem;top:50%;transform:translateY(-50%)}.modal-overlay{position:fixed;inset:0;background:#0f172a99;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem;animation:fadeInOverlay .2s ease-out}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.modal-container{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d,0 0 0 1px #ffffff1a inset;max-width:480px;width:100%;overflow:hidden;animation:slideUpModal .3s cubic-bezier(.16,1,.3,1);position:relative}.modal-container.modal-form{max-width:680px}@keyframes slideUpModal{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{padding:2rem 2rem 1.5rem;text-align:center;border-bottom:1px solid #e2e8f0;position:relative}.modal-header:has(.modal-close){text-align:left;display:flex;align-items:center;justify-content:space-between}.modal-close{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;color:#64748b;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s;font-size:1.25rem}.modal-close:hover:not(:disabled){background:#f1f5f9;color:#0f172a}.modal-close:disabled{opacity:.5;cursor:not-allowed}.modal-icon-wrapper{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;position:relative}.modal-icon-wrapper:before{content:"";position:absolute;inset:-4px;border-radius:50%;opacity:.2;animation:pulse 2s ease-in-out infinite}.modal-icon-wrapper.modal-icon-success{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.modal-icon-wrapper.modal-icon-success:before{background:linear-gradient(135deg,#3b82f6,#1e40af)}.modal-icon-wrapper.modal-icon-danger{background:linear-gradient(135deg,#fee2e2,#fecaca)}.modal-icon-wrapper.modal-icon-danger:before{background:linear-gradient(135deg,#ef4444,#dc2626)}.modal-icon{font-size:2rem;z-index:1;position:relative}.modal-icon-wrapper.modal-icon-success .modal-icon{color:#3b82f6}.modal-icon-wrapper.modal-icon-danger .modal-icon{color:#ef4444}.modal-title{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0;letter-spacing:-.01em}.modal-body{padding:1.5rem 2rem}.modal-container.modal-form .modal-body{padding:0 2rem 1rem;max-height:60vh;overflow-y:auto}.modal-container.modal-form .modal-header{padding-bottom:1.5rem;margin-bottom:0}.modal-container.modal-form .modal-footer{padding-top:1.5rem;border-top:1px solid #e2e8f0;margin-top:0}.modal-container.modal-form .form-group{display:flex;flex-direction:column;gap:1.5rem}.modal-container.modal-form .field-wrapper{display:flex;flex-direction:column;gap:.75rem}.field-info{background:#eff6ff;border:1px solid #bfdbfe;border-radius:12px;padding:1rem;margin-top:.5rem}.info-text{font-size:.875rem;color:#1e40af;margin:0;line-height:1.5}.info-text strong{font-weight:600;color:#1e3a8a}.modal-message{font-size:1rem;color:#475569;line-height:1.6;margin:0;text-align:center}.modal-message strong{color:#0f172a;font-weight:600}.modal-warning{display:block;margin-top:.75rem;font-size:.875rem;color:#ef4444;font-weight:500}.modal-footer{padding:1.5rem 2rem 2rem;display:flex;gap:.75rem;justify-content:flex-end}.modal-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:12px;border:2px solid;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none;min-width:120px}.modal-btn-icon{font-size:1.125rem;width:18px;height:18px}.modal-btn-cancel{background:#fff;border-color:#e2e8f0;color:#64748b}.modal-btn-cancel:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1;color:#475569;transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.modal-btn-primary{background:var(--btn-primary-bg);border-color:var(--btn-primary-border);color:var(--btn-primary-text);box-shadow:none}.modal-btn-primary:hover:not(:disabled){background:var(--btn-primary-hover-bg);border-color:var(--btn-primary-hover-border);transform:translateY(-2px);box-shadow:0 8px 20px #3b82f633}.modal-btn-danger{background:var(--btn-danger-bg);border-color:var(--btn-danger-border);color:var(--btn-danger-text);box-shadow:none}.modal-btn-danger:hover:not(:disabled){background:var(--btn-danger-hover-bg);border-color:var(--btn-danger-hover-border);color:var(--btn-danger-hover-text);transform:translateY(-2px);box-shadow:0 8px 20px #ef444433}.modal-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.spinner-small{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:.2}50%{transform:scale(1.1);opacity:.3}}@media(max-width:1024px){.form-row{grid-template-columns:1fr;gap:1.25rem}.user-row{grid-template-columns:1fr;gap:.75rem}.col-email,.col-nama,.col-role,.col-status{width:100%}}@media(max-width:768px){.admin-user-page{padding:0}.user-header{flex-direction:column;align-items:stretch}.user-title{font-size:2rem}.user-form-card{padding:1.5rem}.header-content{flex-direction:column;gap:1rem}.header-icon-wrapper{width:48px;height:48px}.header-icon,.user-card-title{font-size:1.25rem}.user-card-subtitle{font-size:.875rem}.input{padding:.875rem 1rem;font-size:.9375rem}.btn-submit{width:100%;padding:.875rem 1.5rem;min-width:auto}.user-row{grid-template-columns:1fr}.col-actions{justify-content:flex-start}.modal-container{max-width:100%;margin:1rem}.modal-header{padding:1.5rem 1.5rem 1rem}.modal-icon-wrapper{width:64px;height:64px;margin-bottom:1rem}.modal-icon{font-size:1.75rem}.modal-title{font-size:1.25rem}.modal-body{padding:1.25rem 1.5rem}.modal-message{font-size:.9375rem}.modal-footer{padding:1.25rem 1.5rem 1.5rem;flex-direction:column}.modal-btn{width:100%;min-width:auto}}.toggle-switch{position:relative;display:inline-block;width:52px;height:28px}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#e2e8f0;transition:.4s;border-radius:34px;border:1px solid #cbd5e1}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:#fff;transition:.4s;border-radius:50%;box-shadow:0 2px 4px #0000001a}input:checked+.toggle-slider{background-color:#22c55e;border-color:#16a34a}input:focus+.toggle-slider{box-shadow:0 0 1px #22c55e}input:checked+.toggle-slider:before{transform:translate(24px)}.toggle-wrapper{display:flex;align-items:center;gap:1rem}.toggle-label-text{font-size:.9375rem;font-weight:600;color:#0f172a}.modal-overlay{cursor:default}.import-instruction{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:1rem;margin-bottom:1.5rem}.import-instruction h4{margin:0 0 .5rem;color:#0f172a;font-size:1rem}.import-instruction ol{margin:0;padding-left:1.25rem;color:#64748b;font-size:.875rem;line-height:1.6}.btn-download-template{display:inline-flex;align-items:center;gap:.5rem;color:#3b82f6;font-weight:600;text-decoration:none;font-size:.875rem;margin-top:.75rem;transition:color .2s}.btn-download-template:hover{color:#1e40af;text-decoration:underline}.file-upload-area{border:2px dashed #e2e8f0;border-radius:16px;padding:2.5rem 2rem;text-align:center;cursor:pointer;transition:all .2s;background:#fff}.file-upload-area:hover{border-color:#3b82f6;background:#3b82f605}.file-upload-area.dragging{border-color:#3b82f6;background:#3b82f614;box-shadow:0 0 0 4px #3b82f61a}.file-upload-icon{font-size:2.5rem;color:#94a3b8;margin-bottom:1rem}.file-upload-text{display:block;font-size:1rem;color:#0f172a;font-weight:600;margin-bottom:.25rem}.file-upload-subtext{font-size:.875rem;color:#64748b}.selected-file-info{margin-top:1rem;padding:1rem 1.25rem;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;display:flex;align-items:center;gap:1rem;animation:fadeIn .3s ease}.file-info-icon{font-size:1.5rem;color:#16a34a;flex-shrink:0}.file-details{flex:1;min-width:0;display:flex;flex-direction:column}.file-name{font-weight:600;color:#15803d;font-size:.9375rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-remove-file{background:transparent;border:none;color:#64748b;cursor:pointer;padding:.25rem;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s}.modal-confirm{text-align:center;padding:2.5rem}.modal-confirm-header{margin-bottom:1.5rem;display:flex;flex-direction:column;align-items:center}.modal-confirm-icon-box{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;position:relative}.modal-confirm-icon-box.danger{background:#fef2f2;color:#ef4444;border:4px solid #fee2e2}.modal-confirm-icon-box.danger:after{content:"";position:absolute;inset:-8px;border-radius:50%;border:2px solid #ef4444;opacity:.15;animation:modalIconPulse 2s infinite}@keyframes modalIconPulse{0%{transform:scale(1);opacity:.15}50%{transform:scale(1.15);opacity:.05}to{transform:scale(1);opacity:.15}}.modal-confirm-title{font-size:1.75rem;font-weight:800;color:#0f172a;margin:0;letter-spacing:-.02em}.modal-confirm-body{margin-bottom:2rem}.modal-confirm-text{font-size:1rem;color:#64748b;line-height:1.6;margin-bottom:1.25rem}.modal-confirm-item{font-weight:700;color:#0f172a;background:#f8fafc;padding:.25rem .5rem;border-radius:4px}.modal-confirm-warning{background:#fff1f2;color:#be123c;padding:.75rem 1rem;border-radius:10px;font-size:.875rem;font-weight:600;display:inline-flex;align-items:center;gap:.5rem;border:1px solid #fecaca}.modal-confirm-footer{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.modal-confirm-footer .btn{justify-content:center;height:48px;font-size:1rem}.modal-confirm-footer .btn-danger{background:var(--btn-danger-bg);color:var(--btn-danger-text);border:1px solid var(--btn-danger-border)}.modal-confirm-footer .btn-danger:hover{background:var(--btn-danger-hover-bg);border-color:var(--btn-danger-hover-border);color:var(--btn-danger-hover-text);transform:translateY(-2px);box-shadow:0 8px 20px #ef444433}.modal-confirm-footer .btn-secondary{background:var(--btn-secondary-bg);border:1px solid var(--btn-secondary-border);color:var(--btn-secondary-text)}.modal-confirm-footer .btn-secondary:hover{background:var(--btn-secondary-hover-bg);border-color:var(--btn-secondary-hover-border);color:var(--guru-text-body);transform:translateY(-2px)}.btn-remove-file:hover{background:#fee2e2;color:#ef4444}.import-results{margin-top:1.5rem;padding:1rem;border-radius:12px;background:#f8fafc;border:1px solid #e2e8f0}.result-item{display:flex;justify-content:space-between;padding:.5rem 0;font-size:.875rem}.result-item:not(:last-child){border-bottom:1px dashed #e2e8f0}.result-label{color:#64748b}.result-val{font-weight:700;color:#0f172a}.user-header{align-items:center;gap:1rem;flex-wrap:wrap}.user-title{font-size:2rem;letter-spacing:0}.user-title .title-badge{box-shadow:none}.meta-card{border-radius:10px;box-shadow:none}.user-card{border-radius:12px;box-shadow:none}.user-row{background:#fff;border-radius:10px}.user-row:hover{background:#f8fafc}.btn-add-user{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:12px;border:1px solid transparent;background:linear-gradient(135deg,#3b82f6,#1e40af);color:#fff;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:140px}.btn-add-user:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #3b82f659}.btn-add-user .btn-icon{width:24px;height:24px;font-size:1.25rem}.action-buttons{display:flex;align-items:center;gap:12px}.action-buttons .btn{min-width:140px;justify-content:center}.user-row>div{text-align:left}.user-row-head>div{text-align:left}.pagination-container{display:flex;justify-content:space-between;align-items:center;margin-top:2rem;padding:1rem 1.5rem;background:#fff;border-radius:16px;border:1px solid #e2e8f0;box-shadow:0 4px 6px -1px #0000000d}.pagination-info{font-size:.875rem;color:#64748b;font-weight:500}.pagination-info strong{color:#0f172a;font-weight:700}.pagination-controls{display:flex;align-items:center;gap:.5rem}.btn-pagination{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;color:#64748b;cursor:pointer;transition:all .2s ease;font-size:.875rem;font-weight:600}.btn-pagination:hover:not(:disabled){border-color:#3b82f6;color:#3b82f6;background:#eff6ff;transform:translateY(-1px)}.btn-pagination.active{background:var(--btn-primary-bg);border-color:var(--btn-primary-border);color:var(--btn-primary-text);box-shadow:none}.btn-pagination:disabled{opacity:.5;cursor:not-allowed;background:#f8fafc}.pagination-show-all{margin-left:1rem;padding:.5rem 1rem;font-size:.8125rem;font-weight:600;color:#3b82f6;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;cursor:pointer;transition:all .2s ease}.pagination-show-all:hover{background:#dbeafe;border-color:#3b82f6}.pagination-show-all.active{background:#3b82f6;color:#fff;border-color:#1e40af}@media(max-width:640px){.pagination-container{flex-direction:column;gap:1rem;text-align:center}}.search-box{position:relative;width:250px}.search-input{width:100%;padding:.625rem 1rem;border-radius:12px;border:1px solid #e2e8f0;background:#f8fafc;font-size:.875rem;font-weight:500;color:#1e293b;transition:all .2s ease}.search-input:focus{outline:none;border-color:#3b82f6;background:#fff;box-shadow:0 0 0 4px #3b82f61a}.search-input::placeholder{color:#94a3b8}.admin-sync-page{width:100%;max-width:100%;padding:0;animation:fadeIn .6s ease-out}.sync-layout{display:flex;gap:2rem;margin-top:1rem}.sync-sidebar{width:300px;flex-shrink:0}.sync-content{flex-grow:1}.module-selector{display:flex;flex-direction:column;gap:.5rem}.module-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-radius:12px;cursor:pointer;transition:all .2s;border:1px solid #e2e8f0;background:#fff}.module-item:hover{background:#f8fafc;transform:translate(4px)}.module-item.selected{background:#eff6ff;border-color:#3b82f6;box-shadow:0 4px 12px #3b82f61a}.module-check{display:flex;align-items:center;justify-content:center;color:#3b82f6;font-size:1.25rem}.module-check .dot{width:12px;height:12px;border-radius:50%;background:#e2e8f0}.report-card{margin-bottom:1.5rem;border-left:4px solid #3b82f6}.report-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.report-stats{display:flex;gap:.5rem}.stat-pill{padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:600}.stat-pill.new{background:#ecfdf5;color:#10b981}.stat-pill.update{background:#fffbeb;color:#f59e0b}.stat-pill.synced{background:#f1f5f9;color:#64748b}.report-actions{display:flex;gap:.75rem;padding-bottom:1rem;border-bottom:1px solid #f1f5f9;margin-bottom:1rem}.btn-small{padding:6px 12px;font-size:.8rem;border-radius:8px}.report-details{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.detail-section h4{font-size:.875rem;color:#64748b;margin-bottom:.75rem}.sync-badge{display:inline-block;padding:2px 8px;background:#f1f5f9;border-radius:4px;font-size:.75rem;margin-right:4px;margin-bottom:4px}.sync-badge.new{background:#d1fae5;color:#065f46}.diff-list{display:flex;flex-direction:column;gap:6px}.diff-item{display:flex;align-items:center;gap:10px;font-size:.8rem;padding:4px 8px;background:#fffbeb;border-radius:6px}.diff-anchor{font-weight:700;color:#b45309;min-width:80px}.diff-arrow{color:#d97706}.sync-overlay{position:fixed;inset:0;background:#0f172a66;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999}.loader-circles{display:flex;justify-content:center;gap:8px;margin-bottom:1.5rem}.loader-circles div{width:14px;height:14px;background:#3b82f6;border-radius:50%;animation:loader-bounce .6s infinite alternate}.loader-circles div:nth-child(2){animation-delay:.2s}.loader-circles div:nth-child(3){animation-delay:.4s}@keyframes loader-bounce{0%{transform:translateY(0)}to{transform:translateY(-12px)}}.spin{animation:spin 1s linear infinite}.user-success{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d;border-radius:12px;font-size:.875rem;font-weight:500;margin-top:1rem}.user-success svg{color:#16a34a;flex-shrink:0}:root{--guru-sidebar-bg: #0f1f3d;--guru-sidebar-active: #1b3a6b;--guru-sidebar-text: #ffffff;--guru-sidebar-muted: #8a9bbe;--guru-online-dot: #22c55e;--guru-bg-page: #f0f4f8;--guru-bg-card: #ffffff;--guru-bg-table-head: #f8fafc;--guru-bg-row-separator: #f1f5f9;--guru-text-title: #0f1f3d;--guru-text-body: #1e293b;--guru-text-muted: #64748b;--guru-text-soft: #94a3b8;--guru-primary: #3B82F6;--guru-primary-soft: #EFF6FF;--guru-primary-hover: #2563EB;--guru-success: #22C55E;--guru-success-soft: #F0FDF4;--guru-warning: #F97316;--guru-warning-soft: #FFF7ED;--guru-danger: #EF4444;--guru-danger-soft: #FEE2E2;--guru-border-soft: #E2E8F0;--guru-border-medium: #CBD5E1;--guru-border-subtle: #F1F5F9;--guru-surface-bg: #FFFFFF;--guru-surface-hover: #F8FAFC;--btn-primary-bg: #1B3A6B;--btn-primary-border: #1B3A6B;--btn-primary-text: #FFFFFF;--btn-primary-hover-bg: #163160;--btn-primary-hover-border: #163160;--btn-primary-hover-text: #FFFFFF;--btn-success-bg: #ECFDF5;--btn-success-border: #86EFAC;--btn-success-text: #15803D;--btn-success-hover-bg: #BBF7D0;--btn-success-hover-border: #22C55E;--btn-success-hover-text: #166534;--btn-edit-bg: #EEF2FF;--btn-edit-border: #C7D2FE;--btn-edit-text: #4338CA;--btn-edit-hover-bg: #C7D2FE;--btn-edit-hover-border: #6366F1;--btn-edit-hover-text: #3730A3;--btn-danger-bg: #FEF2F2;--btn-danger-border: #FECACA;--btn-danger-text: #B91C1C;--btn-danger-hover-bg: #FEE2E2;--btn-danger-hover-border: #EF4444;--btn-danger-hover-text: #991B1B;--btn-secondary-bg: #F8FAFC;--btn-secondary-border: #E2E8F0;--btn-secondary-text: #475569;--btn-secondary-hover-bg: #F1F5F9;--btn-secondary-hover-border: #CBD5E1;--btn-outline-bg: #FFFFFF;--btn-outline-border: #93C5FD;--btn-outline-text: #3B82F6;--btn-outline-hover-bg: #EEF4FF}.guru-page{width:100%;max-width:100%;box-sizing:border-box;animation:guruFadeIn .35s ease-out}.guru-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.25rem}.guru-header-card{background:var(--guru-bg-card);border:1px solid var(--guru-border-soft);border-radius:14px;padding:1rem 1.25rem}.guru-title{margin:0 0 .45rem;color:var(--guru-text-title);font-size:2rem;font-weight:800;display:flex;align-items:center;gap:.85rem;flex-wrap:wrap}.guru-title-text{color:var(--guru-text-title)}.guru-title-badge{background:#1b3a6b;color:#fff;border-radius:999px;padding:.34rem .86rem;font-size:.78rem;line-height:1;text-transform:uppercase;letter-spacing:.04em;border:1px solid rgba(27,58,107,.3)}.guru-subtitle{margin:0;color:var(--guru-text-muted);font-size:.94rem}.guru-meta{display:flex;gap:.7rem;flex-wrap:wrap}.guru-meta-card{background:#fff;border:1px solid var(--guru-border-soft);border-radius:12px;padding:.85rem 1.25rem;min-width:110px;text-align:center;transition:all .3s ease;box-shadow:0 2px 4px #00000005}.guru-meta-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #3b82f626;border-color:var(--guru-primary)}.guru-header-card .guru-meta-card{background:var(--guru-primary-soft);border:1px solid #BFDBFE}.guru-meta-label{color:var(--guru-primary);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.guru-meta-value{color:var(--guru-text-title);font-size:1.4rem;font-weight:800;line-height:1}.guru-card{background:var(--guru-bg-card);border:1px solid var(--guru-border-soft);border-radius:14px;padding:1.1rem}.guru-card+.guru-card{margin-top:1rem}.guru-card-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1rem}.guru-card-title{margin:0;color:var(--guru-text-title);font-size:1.1rem;font-weight:800}.guru-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.guru-form-label{color:var(--guru-text-body);font-size:.84rem;font-weight:700;margin-bottom:.45rem;display:inline-flex;align-items:center;gap:.42rem}.guru-select{width:100%;border:1px solid var(--guru-border-soft);border-radius:10px;padding:.72rem .92rem;color:var(--guru-text-body);background:var(--guru-bg-card)}.guru-select:focus{outline:0;border-color:var(--guru-primary);box-shadow:0 0 0 3px #3b82f626}.guru-count-text{color:var(--guru-primary);font-size:.82rem;font-weight:700}@keyframes guruFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.guru-header-card{padding:.9rem 1rem}}.dashboard-page{padding:0}.dashboard-error{padding:.75rem 1rem;background:#fef2f2;color:#b91c1c;border-radius:8px;margin-bottom:1rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem;color:inherit;transition:all .2s ease;display:flex;align-items:center;gap:1rem;animation:slideUp .5s ease-out backwards}.guru-stat-card{border:1px solid var(--guru-border-soft);background:var(--guru-bg-card)}.guru-stat-card:hover{transform:translateY(-3px);box-shadow:0 10px 20px #3b82f61f;border-color:var(--guru-primary)}.stat-icon-wrapper{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--guru-primary-soft);flex-shrink:0}.stat-icon-wrapper.total{background:#eff6ff}.stat-icon-wrapper.rata{background:#fff7ed}.stat-icon-wrapper.tinggi{background:#f0fdf4}.guru-stat-card .stat-icon{font-size:1.25rem}.guru-stat-card .stat-icon.total-icon{color:#3b82f6}.guru-stat-card .stat-icon.rata-icon{color:#f97316}.guru-stat-card .stat-icon.tinggi-icon{color:#22c55e}.stat-content{flex:1;min-width:0}.stat-value{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0 0 .25rem;line-height:1.2}.stat-title{font-size:.84rem;color:#64748b;margin:0}.section-header{margin-bottom:1rem}.section-title{font-size:1.5rem;font-weight:700;color:#0f1f3d;margin:0 0 .5rem;letter-spacing:-.01em}.section-subtitle{font-size:.875rem;color:#64748b;margin:0}.quick-actions{margin-top:.25rem}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.action-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem 1rem;text-decoration:none;color:inherit;transition:all .2s ease;display:flex;align-items:center;gap:.75rem;animation:slideUp .5s ease-out backwards}.guru-action-card{border:1px solid var(--guru-border-soft);border-left:3px solid var(--guru-primary)}.guru-action-card:hover{transform:translateY(-2px);background:var(--guru-primary-soft);border-color:var(--guru-primary);box-shadow:0 4px 12px #3b82f61a}.action-icon-wrapper{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--guru-primary-soft)}.guru-action-card .action-icon{font-size:1.05rem;color:var(--guru-primary)}.action-label{font-size:.9rem;font-weight:700;color:#0f1f3d}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.widgets-section{margin-bottom:1.5rem}.widgets-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem}.widget-card{background:#fff;border:1px solid var(--guru-border-soft);border-radius:12px;overflow:hidden;animation:slideUp .5s ease-out backwards}.widget-header{display:flex;align-items:center;gap:.6rem;padding:.85rem 1rem;border-bottom:1px solid var(--guru-border-soft);background:#f8fafc}.widget-icon-wrapper{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--guru-primary-soft)}.widget-icon{font-size:.9rem;color:var(--guru-primary)}.widget-title{font-size:.85rem;font-weight:700;color:#0f1f3d;margin:0;flex:1}.widget-see-all{font-size:.78rem;color:var(--guru-primary);text-decoration:none;font-weight:600;transition:color .2s}.widget-see-all:hover{color:#1b3a6b}.widget-body{padding:1rem;min-height:120px}.widget-loading{font-size:.85rem;color:#94a3b8;text-align:center;padding:1.5rem 0}.widget-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;padding:1rem 0;text-align:center}.widget-empty .empty-icon{color:#cbd5e1}.widget-empty p{font-size:.83rem;color:#94a3b8;margin:0}.widget-link{font-size:.8rem;color:var(--guru-primary);text-decoration:none;font-weight:600;margin-top:.25rem;transition:color .2s}.widget-link:hover{color:#1b3a6b}.widget-list{display:flex;flex-direction:column;gap:.5rem}.widget-list-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.5rem .65rem;border-radius:8px;background:#f8fafc;transition:background .2s}.widget-list-item:hover{background:var(--guru-primary-soft)}.item-info{flex:1;min-width:0}.item-primary{font-size:.85rem;font-weight:600;color:#0f1f3d;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-secondary{font-size:.75rem;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-date{font-size:.75rem;color:#94a3b8;font-weight:600;flex-shrink:0}.charts-section{margin-bottom:1.5rem}.charts-section .section-header{margin-bottom:1rem}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.chart-card{background:#fff;border:1px solid var(--guru-border-soft);border-radius:12px;overflow:hidden;animation:slideUp .5s ease-out backwards}.chart-card.chart-wide{grid-column:span 2}.chart-header{padding:.85rem 1rem;border-bottom:1px solid var(--guru-border-soft);background:#f8fafc}.chart-title{font-size:.88rem;font-weight:700;color:#0f1f3d;margin:0;display:flex;align-items:center}.chart-body{padding:1rem}.chart-empty{height:150px;display:flex;align-items:center;justify-content:center;font-size:.83rem;color:#94a3b8}.pie-chart-wrapper{display:flex;align-items:center;gap:.5rem}.pie-legend{flex:1;display:flex;flex-direction:column;gap:.4rem;min-width:0}.legend-item{display:flex;align-items:center;gap:.45rem}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-label{font-size:.78rem;color:#64748b;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.legend-value{font-size:.8rem;font-weight:700;color:#0f1f3d;flex-shrink:0}@media(max-width:1024px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media(max-width:900px){.charts-grid{grid-template-columns:1fr}.chart-card.chart-wide{grid-column:span 1}}@media(max-width:768px){.page-title{font-size:2rem}.stats-grid{grid-template-columns:1fr;gap:1rem}.actions-grid{grid-template-columns:1fr}}@media(max-width:480px){.page-title{font-size:1.75rem}.stat-value{font-size:1.4rem}}.jadwal-page .guru-card{margin-top:0}.user-alert{background:#ef444414;border:1px solid rgba(239,68,68,.25);color:#991b1b;padding:.75rem 1rem;border-radius:12px;margin:1rem 0}.user-alert.success{background:#05966914;color:#059669;border-color:#05966940}.user-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem;margin-top:1rem}.user-card-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.user-card-title{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0;letter-spacing:-.01em}.btn-add-user{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:10px;background:var(--btn-primary-bg);color:var(--btn-primary-text);border:1px solid var(--btn-primary-border);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.btn-add-user:hover:not(:disabled){background:var(--btn-primary-hover-bg);border-color:var(--btn-primary-hover-border);color:var(--btn-primary-hover-text);transform:translateY(-1px)}.btn-plus{width:18px;height:18px}.btn-add-user:disabled{opacity:.5;cursor:not-allowed;transform:none}.tabs-container{display:flex;gap:1rem;margin-bottom:1.5rem;border:1px solid var(--guru-border-soft);background:var(--guru-bg-table-head);border-radius:12px;padding:.5rem}.tab-button{padding:.6rem .9rem;background:var(--btn-secondary-bg);border:1px solid var(--btn-secondary-border);border-radius:8px;font-size:.92rem;font-weight:600;color:var(--btn-secondary-text);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.tab-button.active{background:var(--btn-primary-bg);color:var(--btn-primary-text);border-color:var(--btn-primary-border)}.jadwal-table{display:flex;flex-direction:column;background:#fff;border:1px solid var(--guru-border-soft);border-radius:12px;overflow:hidden}.jadwal-row{display:grid;grid-template-columns:1.5fr 180px 1.2fr 1.2fr 130px 96px;gap:1rem;align-items:center;padding:.9rem 1rem;border-bottom:1px solid var(--guru-bg-row-separator);background:var(--guru-bg-card);transition:all .2s ease}.jadwal-row:last-child{border-bottom:none}.jadwal-row:hover{transform:none;box-shadow:none;background:var(--guru-bg-table-head)}.jadwal-row-head{border:none;background:#1b3a6bd9;padding:.65rem 1rem;margin-bottom:.25rem}.jadwal-row-head>div{font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#fff;text-align:center}.jadwal-row-head>div:first-child{text-align:left}.col-actions{display:flex;gap:.35rem;justify-content:center;align-items:center;width:100%;min-width:0}.col-main{display:flex;flex-direction:column;gap:.5rem;text-align:left}.jadwal-nama{font-weight:700;color:var(--guru-text-title);font-size:1rem;display:flex;align-items:center;gap:.5rem}.kiosk-badge{display:inline-flex;align-items:center;padding:.2rem .5rem;border-radius:4px;font-size:.7rem;font-weight:800;background:#d1fae5;color:#059669}.jadwal-meta-info{font-size:.82rem;color:var(--guru-text-muted);display:flex;align-items:center;gap:.5rem}.col-tokens{display:flex;flex-direction:column;gap:.4rem}.token-box{font-family:JetBrains Mono,Fira Code,monospace;font-size:.85rem;padding:.35rem .6rem;border-radius:6px;border:1px solid transparent;text-align:center;display:flex;justify-content:space-between;align-items:center}.token-box.in{background:var(--guru-bg-table-head);border-color:#cbd5e1;color:#1e293b}.token-box.out{background:#fee2e2;border-color:#fecaca;color:#991b1b}.token-value{font-weight:700;font-size:1rem}.col-mapel-paket{display:flex;flex-direction:column;gap:.45rem;align-items:center}.mapel-badge{display:inline-flex;align-items:center;padding:.4rem .75rem;border-radius:8px;font-size:.85rem;font-weight:600;background:var(--guru-primary-soft);color:var(--guru-primary);border:1px solid #dbeafe;justify-content:center;width:100%}.paket-badge{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem;font-weight:500;color:#475569;justify-content:center}.paket-owner{font-size:.75rem}.paket-owner.own{color:#059669}.paket-owner.other{color:#64748b}.paket-owner.empty{color:#d97706}.col-kelas-waktu{display:flex;flex-direction:column;gap:.4rem;align-items:center;text-align:center}.kelas-count{font-weight:700;color:#334155;font-size:.95rem}.waktu-info{font-size:.8rem;line-height:1.4;color:#64748b;display:flex;align-items:center;gap:.35rem}.waktu-stack{display:flex;flex-direction:column}.status-badge{padding:.4rem .75rem;border-radius:8px;font-size:.85rem;font-weight:600;display:inline-flex;align-items:center;gap:.35rem;justify-content:center;width:100%}.status-badge.aktif{background:var(--guru-success-soft);color:var(--guru-success)}.status-badge.warning{background:#f59e0b1a;color:#d97706}.status-badge.danger{background:#ef44441a;color:#dc2626}.btn-action{width:30px;height:30px;padding:0;border-radius:8px;border:1px solid var(--btn-secondary-border);background:var(--btn-secondary-bg);color:var(--btn-secondary-text);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}.official-table .jadwal-row .btn-action{width:34px;height:34px}.official-table .jadwal-row .btn-action.with-label{width:auto;min-width:88px;height:34px;padding:0 10px;gap:6px}.official-table .jadwal-row .btn-action.with-label span{font-size:.78rem;line-height:1}.btn-action:hover:not(:disabled){background:var(--btn-secondary-hover-bg);border-color:var(--btn-secondary-hover-border);color:var(--btn-secondary-hover-border);transform:translateY(-1px)}.btn-action.primary{background:var(--btn-primary-bg);color:var(--btn-primary-text);border-color:var(--btn-primary-border)}.btn-action.primary:hover:not(:disabled){background:var(--btn-primary-hover-bg);border-color:var(--btn-primary-hover-border);color:var(--btn-primary-hover-text)}.btn-action.success{background:var(--btn-success-bg);color:var(--btn-success-text);border-color:var(--btn-success-border)}.btn-action.success:hover:not(:disabled){background:var(--btn-success-hover-bg);border-color:var(--btn-success-hover-border);color:var(--btn-success-hover-text)}.btn-action.danger{background:var(--btn-danger-bg);color:var(--btn-danger-text);border-color:var(--btn-danger-border)}.btn-action.danger:hover:not(:disabled){background:var(--btn-danger-hover-bg);border-color:var(--btn-danger-hover-border);color:var(--btn-danger-hover-text)}.empty-state{padding:3rem 1rem;text-align:center;color:#94a3b8;font-style:italic;background:#f8fafc;border-radius:12px;border:2px dashed #e2e8f0}.loading-state{padding:2rem;text-align:center;color:#64748b;font-weight:600}.modal-overlay{position:fixed;inset:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.modal-container{background:#fff;border-radius:12px;border:1px solid #e2e8f0;box-shadow:0 12px 30px #0000002e;max-width:520px;width:100%;overflow:hidden;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:1200px){.jadwal-row{grid-template-columns:1.35fr 165px 1.1fr 1.15fr 115px 90px;gap:.85rem}}.bank-soal-page{width:100%;max-width:100%;padding:0;box-sizing:border-box}.btn-back{background:none;border:none;color:#3b82f6;display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:600;padding:0;font-size:.9rem;margin-bottom:.5rem;transition:all .2s ease}.btn-back:hover{color:#1d4ed8;transform:translate(-3px)}.btn-tambah{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--btn-primary-bg);color:var(--btn-primary-text);border:1px solid var(--btn-primary-border);border-radius:10px;font-weight:600;cursor:pointer;white-space:nowrap;text-decoration:none}.btn-tambah:hover{background:var(--btn-primary-hover-bg);border-color:var(--btn-primary-hover-border);color:var(--btn-primary-hover-text);transform:translateY(-1px)}.header-actions,.bank-soal-page .user-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.btn-import-excel{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--btn-outline-bg);color:var(--btn-outline-text);border:1px solid var(--btn-outline-border);border-radius:10px;font-weight:600;cursor:pointer;white-space:nowrap}.btn-import-excel:hover{background:var(--btn-outline-hover-bg)}.import-section-title{margin:0 0 .75rem;font-size:1.1rem;font-weight:700;color:#0f172a;padding-bottom:.5rem;border-bottom:2px solid #e2e8f0}.import-section-desc{margin:0 0 1rem;font-size:.9rem;color:#64748b}.import-actions-row{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.btn-download-template,.btn-guide{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-weight:500;cursor:pointer;background:var(--btn-secondary-bg);border:1px solid var(--btn-secondary-border);color:var(--btn-secondary-text);transition:all .15s ease}.btn-download-template:hover,.btn-guide:hover{background:var(--btn-secondary-hover-bg);border-color:var(--btn-secondary-hover-border)}.import-form{margin-top:.5rem}.import-form-row{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.import-form-row.import-file-row{align-items:flex-end}.import-form-row .filter-group input[type=file]{padding:.4rem 0;font-size:.9rem}.import-form-row .file-name{display:block;margin-top:.25rem;font-size:.85rem;color:#475569}.btn-submit-import{padding:.85rem 1.5rem;background:var(--btn-primary-bg);color:var(--btn-primary-text);border:1px solid var(--btn-primary-border);border-radius:10px;font-weight:700;font-size:1rem;cursor:pointer;width:100%;display:flex;justify-content:center;align-items:center;gap:.5rem;transition:all .2s ease}.upload-zone-wrapper{border:2px dashed #cbd5e1;border-radius:12px;background:#f8fafc;padding:2rem 1.5rem;text-align:center;transition:all .2s ease;position:relative;cursor:pointer;margin-bottom:1.5rem;display:flex;flex-direction:column;align-items:center;justify-content:center}.upload-zone-wrapper:hover{border-color:#3b82f6;background:#eff6ff}.upload-zone-wrapper .upload-icon{font-size:3rem;color:#3b82f6;margin-bottom:.75rem}.upload-zone-wrapper .upload-text{font-size:1rem;font-weight:600;color:#1e293b;margin:0 0 .25rem}.upload-zone-wrapper .upload-sub{font-size:.85rem;color:#64748b;margin:0}.upload-zone-wrapper input[type=file]{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer}.file-name-chip{display:inline-flex;align-items:center;gap:.5rem;background:#dbeafe;color:#1e40af;padding:.5rem 1rem;border-radius:50px;font-weight:600;font-size:.9rem;margin-top:1rem}.btn-submit-import:hover:not(:disabled){background:var(--btn-primary-hover-bg);border-color:var(--btn-primary-hover-border);color:var(--btn-primary-hover-text)}.btn-submit-import:disabled{opacity:.5;cursor:not-allowed}.import-result{margin-top:1rem;padding:.75rem 1rem;background:#ecfdf5;border:1px solid #a7f3d0;border-radius:8px;font-size:.9rem}.import-result.has-errors{background:#fefce8;border-color:#fde047}.bank-soal-notice{margin-bottom:1rem;padding:.75rem 1rem;border-radius:10px;font-size:.9rem;border:1px solid transparent}.bank-soal-notice.success{background:#ecfdf5;color:#065f46;border-color:#a7f3d0}.bank-soal-notice.error{background:#fef2f2;color:#991b1b;border-color:#fecaca}.import-errors-list{margin:.5rem 0 0;padding-left:1.25rem;font-size:.85rem;color:#713f12}.guide-modal{max-width:560px}.guide-content{padding:1.25rem 1.5rem}.guide-content p{margin:0 0 .75rem;font-size:.95rem}.guide-table{width:100%;border-collapse:collapse;margin:.75rem 0 1rem;font-size:.9rem}.guide-table th,.guide-table td{padding:.5rem .75rem;text-align:left;border:1px solid #e2e8f0}.guide-table th{background:#f8fafc;font-weight:600}.guide-table code{background:#f1f5f9;padding:.15rem .4rem;border-radius:4px;font-size:.85em}.bank-soal-filters{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;padding:1.25rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px}.bank-soal-filters-title{width:100%;margin:0 0 1rem;font-size:1rem;font-weight:700;color:#0f172a;padding-bottom:.5rem;border-bottom:2px solid #e2e8f0}.filter-group{flex:1;min-width:160px}.filter-group label{display:block;font-size:.8125rem;font-weight:600;color:#1e293b;margin-bottom:.45rem;padding-left:.4rem;border-left:3px solid #3B82F6;letter-spacing:.02em}.filter-group select,.filter-group input[type=text]{width:100%;padding:.65rem .85rem;border:2px solid #cbd5e1;border-radius:8px;font-size:.9375rem;background:#fff;color:#0f172a}.filter-group select:focus,.filter-group input[type=text]:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.bank-soal-error{padding:.75rem 1rem;background:#fef2f2;color:#b91c1c;border-radius:8px;margin-bottom:1rem}.bank-soal-loading{padding:2rem;text-align:center;color:#64748b}.bank-soal-table-wrap{overflow-x:auto;background:#fff;border:1px solid var(--guru-border-soft);border-radius:12px;overflow:hidden}.bank-soal-table{width:100%;border-collapse:collapse}.bank-soal-table th,.bank-soal-table td{padding:.75rem 1rem;text-align:left;border:none;border-bottom:1px solid var(--guru-bg-row-separator)}.bank-soal-table tr:last-child td{border-bottom:none}.bank-soal-table tr:hover td{background:var(--guru-bg-table-head)}.bank-soal-table thead tr th{background:#1b3a6bd9;font-weight:700;font-size:.75rem;color:#fff;text-transform:uppercase;letter-spacing:.05em;padding:.75rem 1rem;border-bottom:none}.bank-soal-table td.soal-preview{max-width:280px;overflow:hidden;text-overflow:ellipsis}.bank-soal-table .empty-row{text-align:center;color:#64748b;padding:3rem}.folder-name-cell{display:flex;align-items:center;gap:.75rem;color:#0f1f3d;font-weight:600}.folder-icon{font-size:1.25rem;color:#3b82f6}.soal-count-badge{display:inline-flex;align-items:center;justify-content:center;background:#eff6ff;color:#3b82f6;font-weight:700;padding:.35rem .85rem;border-radius:20px;font-size:.8rem}.action-buttons-cell{display:flex;gap:.5rem;align-items:center}.bank-soal-pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-top:.85rem;padding:1rem 1.25rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px}.pagination-info{font-size:.9rem;color:#64748b}.pagination-controls{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.pagination-btn{padding:.5rem .75rem;font-size:.9rem;border:1px solid #e2e8f0;background:#fff;border-radius:8px;cursor:pointer;color:#475569}.pagination-btn:hover:not(:disabled){background:#f1f5f9;border-color:#cbd5e1}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-pages{display:flex;align-items:center;gap:.25rem}.pagination-ellipsis{padding:0 .35rem;color:#64748b;font-size:.9rem;-webkit-user-select:none;user-select:none}.pagination-page{min-width:2.25rem;padding:.5rem;font-size:.9rem;border:1px solid #e2e8f0;background:#fff;border-radius:8px;cursor:pointer;color:#475569}.pagination-page:hover{background:#f1f5f9}.pagination-page.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.badge{display:inline-block;padding:.25rem .6rem;border-radius:6px;font-size:.75rem;font-weight:600}.badge-pilgan{background:#eff6ff;color:#3b82f6}.badge-pilgan_kompleks{background:#f0fdf4;color:#22c55e}.badge-pilgan_kategori{background:#fff7ed;color:#f97316}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid;cursor:pointer;border-radius:8px;margin-right:.35rem;transition:all .2s ease}.btn-icon.view{background:var(--btn-success-bg);border-color:var(--btn-success-border);color:var(--btn-success-text)}.btn-icon.view:hover{background:var(--btn-success-hover-bg);border-color:var(--btn-success-hover-border);color:var(--btn-success-hover-text);transform:translateY(-1px)}.btn-icon.edit{background:var(--btn-edit-bg);border-color:var(--btn-edit-border);color:var(--btn-edit-text)}.btn-icon.edit:hover{background:var(--btn-edit-hover-bg);border-color:var(--btn-edit-hover-border);color:var(--btn-edit-hover-text);transform:translateY(-1px)}.btn-icon.delete{background:var(--btn-danger-bg);border-color:var(--btn-danger-border);color:var(--btn-danger-text)}.btn-icon.delete:hover{background:var(--btn-danger-hover-bg);border-color:var(--btn-danger-hover-border);color:var(--btn-danger-hover-text);transform:translateY(-1px)}.btn-icon svg{font-size:1.15rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.bank-soal-modal{background:#fff;border-radius:16px;max-width:640px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 50px #0003}.import-modal{max-width:860px}.import-modal-body{padding:1.2rem 1.5rem 1.4rem}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0}.modal-header h2{margin:0;font-size:1.25rem}.modal-close{background:none;border:1px solid #e2e8f0;width:34px;height:34px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;padding:0;cursor:pointer;color:#64748b}.modal-close:hover{color:#0f172a;background:#f8fafc}.bank-soal-form{padding:1.5rem}.form-error{padding:.75rem;background:#fef2f2;color:#b91c1c;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.form-row.two-cols{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.8125rem;font-weight:600;color:#1e293b;letter-spacing:.02em;margin-bottom:.5rem;padding-left:.5rem;border-left:3px solid #3B82F6;line-height:1.4}.form-group input[type=text],.form-group select,.form-group textarea{width:100%;padding:.7rem .9rem;border:2px solid #cbd5e1;border-radius:8px;font-size:.9375rem;background:#fff;color:#0f172a;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.form-group input[type=text]:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.form-group textarea{resize:vertical;min-height:80px}.kolom-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.kolom-letter{flex-shrink:0;width:1.5rem;font-weight:600;color:#475569}.kolom-row input{flex:1;padding:.6rem .85rem;border:2px solid #cbd5e1;border-radius:8px;background:#fff}.kolom-row input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.btn-check{flex-shrink:0;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border:2px solid var(--btn-secondary-border);background:var(--btn-secondary-bg);border-radius:8px;cursor:pointer;color:var(--btn-secondary-text);transition:all .15s ease}.btn-check.active{background:var(--btn-primary-bg);border-color:var(--btn-primary-border);color:var(--btn-primary-text)}.benar-salah-btns{display:flex;gap:.35rem}.benar-salah-btns button{padding:.4rem .75rem;font-size:.8rem;border:1px solid var(--btn-secondary-border);background:var(--btn-secondary-bg);color:var(--btn-secondary-text);border-radius:6px;cursor:pointer;transition:all .15s ease}.benar-salah-btns button.active{background:var(--btn-primary-bg);border-color:var(--btn-primary-border);color:var(--btn-primary-text)}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--btn-secondary-border)}.btn-secondary{padding:.6rem 1.25rem;background:var(--btn-secondary-bg);border:1px solid var(--btn-secondary-border);color:var(--btn-secondary-text);border-radius:8px;cursor:pointer;font-weight:500;transition:all .15s ease}.btn-secondary:hover{background:var(--btn-secondary-hover-bg);border-color:var(--btn-secondary-hover-border)}.btn-primary{padding:.6rem 1.25rem;background:var(--btn-primary-bg);color:var(--btn-primary-text);border:1px solid var(--btn-primary-border);border-radius:8px;cursor:pointer;font-weight:600;transition:all .15s ease}.btn-primary:hover:not(:disabled){background:var(--btn-primary-hover-bg);border-color:var(--btn-primary-hover-border);color:var(--btn-primary-hover-text)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-primary:hover:not(:disabled){background:#2563eb;box-shadow:0 4px 10px #3b82f659}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.bank-soal-form-page .bank-soal-form-header{margin-bottom:1.5rem}.bank-soal-form-header .page-title{font-size:1.75rem;margin:.5rem 0 .25rem}.bank-soal-form-header .page-subtitle{font-size:.95rem;color:#64748b;margin:0}.btn-back{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 0;margin-bottom:.5rem;background:none;border:none;color:#3b82f6;font-size:.9rem;font-weight:500;cursor:pointer;text-decoration:none}.btn-back:hover{text-decoration:underline}.bank-soal-form-full{width:100%;max-width:100%;padding:1.5rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-sizing:border-box}.bank-soal-form-page .form-section{margin-bottom:2rem;padding:1.25rem;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.bank-soal-form-page .form-section-title{margin:0 0 1rem;font-size:1.1rem;font-weight:700;color:#0f172a;padding-bottom:.5rem;border-bottom:2px solid #e2e8f0}.bank-soal-form-page .form-section-desc{margin:0 0 1rem;font-size:.9rem;color:#64748b}.bank-soal-form-page .form-section .form-group,.bank-soal-form-page .form-section .form-row.two-cols{margin-bottom:1.25rem}.bank-soal-form-page .form-section .form-row.two-cols:last-child{margin-bottom:0}.bank-soal-form-page .form-section .field-hint{margin:.35rem 0 0;font-size:.8125rem;color:#64748b}.form-actions-full{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e2e8f0}@media(max-width:640px){.form-row.two-cols{grid-template-columns:1fr}}.btn-plus{width:22px;height:22px;font-size:1.2rem}.admin-success-alert{background:#05966914!important;color:#059669!important;border-color:#05966940!important}.paket-ujian-table th,.paket-ujian-table td{text-align:left!important;vertical-align:middle}.clickable-row{transition:background-color .2s ease}.clickable-row:hover{background-color:#f1f5f9!important}.wizard-page{padding:2rem;max-width:1200px;margin:0 auto;font-family:Inter,sans-serif;color:#1e293b}.wizard-header{margin-bottom:2rem}.back-link{background:none;border:none;color:#3b82f6;font-weight:600;cursor:pointer;padding:0;margin-bottom:1rem;font-size:.9rem;transition:opacity .2s}.back-link:hover{opacity:.8}.wizard-header h2{font-size:1.8rem;font-weight:700;color:#0f172a;margin-bottom:.5rem}.wizard-header p{color:#64748b;font-size:1rem}.stepper{display:flex;justify-content:space-between;margin-bottom:3rem;position:relative;background:#fff;padding:1.5rem;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d}.step-item{display:flex;flex-direction:column;align-items:center;z-index:1;width:100px;position:relative}.step-item:after{content:"";position:absolute;top:20px;left:50%;width:100%;height:2px;background:#e2e8f0;z-index:-1}.step-item:last-child:after{display:none}.step-circle{width:40px;height:40px;border-radius:50%;background:#f1f5f9;color:#64748b;display:flex;align-items:center;justify-content:center;font-weight:700;margin-bottom:.5rem;transition:all .3s;border:2px solid white}.step-item.active .step-circle{background:#3b82f6;color:#fff;box-shadow:0 0 0 4px #bfdbfe}.step-item.completed .step-circle{background:#10b981;color:#fff}.step-item.completed:after{background:#10b981}.step-label{font-size:.8rem;font-weight:600;text-align:center;color:#64748b}.step-item.active .step-label{color:#3b82f6}.step-item.completed .step-label{color:#10b981}.wizard-content{background:#fff;border-radius:16px;padding:2.5rem;box-shadow:0 10px 15px -3px #0000000d;min-height:400px;margin-bottom:2rem}.step-panel h3{font-size:1.4rem;font-weight:700;margin-bottom:.5rem;color:#0f172a}.step-panel .hint{color:#64748b;margin-bottom:1.5rem}.slide-in{animation:slideIn .3s ease-out forwards}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.period-toggle{display:flex;gap:1.5rem;margin-bottom:2rem;padding:1rem;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.radio-label{display:flex;align-items:center;gap:8px;font-weight:600;cursor:pointer}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.span-full{grid-column:1 / -1}.safety-option-card{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:#f0f9ff;border:1px solid #bae6fd;border-radius:12px;margin-bottom:2rem}.option-header{display:flex;gap:1rem;align-items:center}.option-header strong{display:block;font-size:1.1rem;color:#0369a1}.toggle-switch{position:relative;width:60px;height:30px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-switch label{position:absolute;cursor:pointer;inset:0;background-color:#cbd5e1;transition:.4s;border-radius:34px}.toggle-switch label:before{position:absolute;content:"";height:22px;width:22px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%}.toggle-switch input:checked+label{background-color:#3b82f6}.toggle-switch input:checked+label:before{transform:translate(30px)}.form-group label{display:block;font-size:.9rem;font-weight:600;margin-bottom:.5rem;color:#334155}.wizard-input{width:100%;padding:.75rem 1rem;border-radius:10px;border:1px solid #cbd5e1;font-family:inherit;font-size:.95rem;transition:all .2s}.wizard-input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #bfdbfe}.grid-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.action-row{margin-bottom:1rem;display:flex;gap:.5rem}.btn-small{padding:.4rem .8rem;border-radius:6px;border:none;background:#3b82f6;color:#fff;font-size:.8rem;font-weight:600;cursor:pointer}.btn-small.btn-ghost{background:#f1f5f9;color:#64748b}.selection-card{display:flex;align-items:flex-start;gap:10px;padding:1rem;border-radius:12px;border:2px solid #e2e8f0;background:#fff;cursor:pointer;transition:all .2s}.selection-card:hover{border-color:#cbd5e1;background:#f8fafc}.selection-card.selected{border-color:#3b82f6;background:#eff6ff}.selection-card input{margin-top:4px;transform:scale(1.2)}.selection-card .details strong{display:block;color:#0f172a}.selection-card .details span{font-size:.8rem;color:#64748b}.step4-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:1.5rem}.sessions-container{display:flex;flex-direction:column;gap:1.75rem}.session-card{background:#fff;border:1px solid #e2e8f0;border-radius:20px;overflow:hidden;box-shadow:0 4px 16px #0000000f;transition:box-shadow .2s}.session-card:hover{box-shadow:0 8px 24px #00000017}.session-card-header{background:linear-gradient(135deg,#f8faff,#f0f4ff);border-bottom:1px solid #e0e8ff;padding:1.25rem 1.75rem;display:flex;align-items:center;flex-wrap:wrap;gap:1.5rem}.session-badge{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.session-number{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#6366f1);color:#fff;font-size:1.25rem;font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #3b82f659;flex-shrink:0}.session-label{font-size:1rem;font-weight:700;color:#1e293b;white-space:nowrap}.session-time-inputs{display:flex;gap:1.25rem;flex-grow:1;flex-wrap:wrap}.time-group{display:flex;flex-direction:column;gap:6px}.time-label{font-size:.75rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:4px}.time-label-icon{font-size:.85rem}.time-input{padding:.6rem .9rem;font-size:.9rem;border-radius:10px}.durasi-input{width:100px!important;text-align:center;font-weight:700;font-size:1rem}.selesai-display{height:42px;display:flex;align-items:center;padding:0 1rem;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;color:#059669;font-weight:700;font-size:.95rem;min-width:140px;white-space:nowrap}.btn-remove-session{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;width:38px;height:38px;border-radius:10px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;flex-shrink:0;display:flex;align-items:center;justify-content:center}.btn-remove-session:hover{background:#dc2626;border-color:#dc2626;color:#fff;transform:scale(1.05)}.session-bulk-actions{background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:.875rem 1.75rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.bulk-group{display:flex;align-items:center;gap:.875rem;flex:1}.bulk-label{font-size:.85rem;font-weight:600;color:#475569;white-space:nowrap}.bulk-select{max-width:260px;padding:.5rem .875rem;font-size:.875rem;border-radius:8px}.session-meta{flex-shrink:0}.kelas-count-badge{background:#dbeafe;color:#1d4ed8;font-size:.8rem;font-weight:700;padding:.3rem .75rem;border-radius:999px;border:1px solid #bfdbfe;white-space:nowrap}.session-class-grid{padding:1.5rem 1.75rem}.class-grid-header{display:grid;grid-template-columns:28% 44% 28%;padding:0 0 .75rem;border-bottom:2px solid #e2e8f0;margin-bottom:.5rem;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#64748b}.col-required{color:#ef4444;margin-left:2px}.col-optional{color:#94a3b8;font-weight:400;text-transform:none;letter-spacing:0}.class-rows{display:flex;flex-direction:column}.class-row{display:grid;grid-template-columns:28% 44% 28%;align-items:center;gap:0;padding:.625rem 0;border-bottom:1px solid #f1f5f9;transition:background .15s;border-radius:8px}.class-row:last-child{border-bottom:none}.class-row:hover{background:#f8fafc}.class-row.row-done .kelas-badge{border-color:#bbf7d0;background:#f0fdf4}.class-row.row-done .kelas-tingkat{background:#10b981}.kelas-badge{display:inline-flex;align-items:center;gap:.5rem;border:1px solid #e2e8f0;border-radius:8px;padding:.35rem .65rem;background:#f8fafc;transition:all .2s}.kelas-tingkat{background:#64748b;color:#fff;font-size:.7rem;font-weight:800;padding:.15rem .45rem;border-radius:4px;text-transform:uppercase;transition:background .2s}.kelas-name{font-size:.85rem;font-weight:600;color:#1e293b}.row-input{padding:.55rem .75rem;font-size:.875rem;border-radius:8px;margin-right:.75rem}.row-input.input-empty{border-color:#fca5a5;background:#fff7f7}.row-input.input-empty:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef444426}.btn-add-slot{display:flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#3b82f6,#6366f1);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:12px;font-weight:700;font-size:.95rem;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #3b82f64d;white-space:nowrap;flex-shrink:0}.btn-add-slot:hover{transform:translateY(-2px);box-shadow:0 8px 20px #3b82f666}.empty-state{text-align:center;padding:4rem 2rem;background:#f8fafc;border:2px dashed #cbd5e1;border-radius:20px;color:#94a3b8}.empty-icon{font-size:3rem;margin-bottom:1rem}.empty-state h4{font-size:1.1rem;font-weight:700;color:#475569;margin:0 0 .5rem}.empty-state p{font-size:.9rem;margin:0;color:#94a3b8}.summary-box{background:#f8fafc;padding:1.5rem;border-radius:12px;border:1px solid #e2e8f0;margin-bottom:1.5rem}.sum-item{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid #e2e8f0}.sum-item:last-child{border-bottom:none}.summary-alert{display:flex;gap:1rem;padding:1.5rem;background:#fffbeb;border:1px solid #fde68a;color:#92400e;border-radius:12px}.wizard-footer{display:flex;justify-content:space-between}.btn-wizard-nav{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.btn-wizard-nav.back{background:#fff;color:#64748b;border:1px solid #cbd5e1}.btn-wizard-nav.back:hover{background:#f8fafc}.btn-wizard-nav.next{background:#0f172a;color:#fff}.btn-wizard-nav.next:hover{background:#1e293b}.btn-wizard-nav.finish{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-wizard-nav.finish:hover{opacity:.9}.rekap-page .guru-card{margin-top:0}.rekap-filter-card{margin-bottom:1rem}.filter-item{display:flex;flex-direction:column}.rekap-state{text-align:center;color:var(--guru-text-muted);padding:3.5rem 1rem}.student-info{display:flex;align-items:center;min-width:0}.student-avatar{width:36px;height:36px;border-radius:999px;background:var(--guru-primary-soft);color:var(--guru-primary);font-weight:800;margin-right:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.student-names{min-width:0;display:flex;flex-direction:column}.student-name,.student-email{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.student-name{color:var(--guru-text-title);font-weight:700}.student-email{color:var(--guru-text-soft);font-size:.8rem}.kelas-pill{font-size:.84rem;line-height:1.3;font-weight:700;color:var(--guru-primary);background:var(--guru-primary-soft);border-radius:999px;padding:.3rem .62rem;display:inline-block}.status-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.34rem .72rem;border-radius:999px;font-size:.8rem;font-weight:700}.status-badge.aktif{color:var(--guru-success);background:var(--guru-success-soft)}.status-badge.progress{color:var(--guru-primary);background:var(--guru-primary-soft)}.nilai-col{text-align:center}.score-display{font-size:1.08rem;font-weight:800}.score-display.high{color:var(--guru-success)}.score-display.med{color:var(--guru-warning)}.aksi-col{display:flex;gap:.5rem;justify-content:center}.btn-action{width:auto;display:inline-flex;align-items:center;justify-content:center;gap:.35rem;border-radius:10px;font-size:.83rem;font-weight:700;padding:.52rem .88rem;border:1px solid;transition:all .18s ease}.btn-action.primary{background:var(--btn-success-bg);border-color:var(--btn-success-border);color:var(--btn-success-text)}.btn-action.primary:hover{background:var(--btn-success-hover-bg);border-color:var(--btn-success-hover-border);color:var(--btn-success-hover-text)}.btn-action.danger{background:var(--btn-danger-bg);border-color:var(--btn-danger-border);color:var(--btn-danger-text)}.btn-action.danger:hover{background:var(--btn-danger-hover-bg);border-color:var(--btn-danger-hover-border);color:var(--btn-danger-hover-text)}.rekap-table{width:100%;border-radius:12px;overflow:hidden;border:1px solid var(--guru-border-soft)}.rekap-row{display:grid;grid-template-columns:2fr 2fr 160px 130px 230px;align-items:center;padding:.86rem 1.12rem;gap:1rem;border-bottom:1px solid var(--guru-bg-row-separator);background:var(--guru-bg-card);transition:background .15s}.rekap-row:last-child{border-bottom:none}.rekap-row:hover:not(.rekap-head){background:var(--guru-bg-table-head)}.rekap-head>div{text-align:center}.rekap-head>div:first-child,.rekap-head>div:nth-child(2){text-align:left}.rekap-head{background:#1b3a6bd9!important;font-size:.73rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.05em;padding:.74rem 1.12rem;border-bottom:1px solid rgba(27,58,107,.4)}@media(max-width:1024px){.rekap-row{grid-template-columns:minmax(220px,1.6fr) minmax(170px,1.2fr) 150px 120px 190px;gap:.7rem;padding:.76rem .84rem}.btn-action{font-size:.78rem;padding:.45rem .65rem}}@media(max-width:768px){.guru-form-grid{grid-template-columns:1fr}.rekap-table{overflow-x:auto}.rekap-row{min-width:820px}}.analisis-page .guru-card{margin-top:0}.table-pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;margin-top:.75rem;padding:.85rem 1rem;background:#f8fafc;border:1px solid var(--guru-border-soft);border-radius:12px}.table-pagination-info{font-size:.875rem;color:#64748b}.table-pagination-controls{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.table-pagination-btn{padding:.45rem .8rem;font-size:.85rem;border:1px solid var(--btn-secondary-border);background:var(--btn-secondary-bg);color:var(--btn-secondary-text);border-radius:8px;cursor:pointer;transition:all .15s ease}.table-pagination-btn:hover:not(:disabled){background:var(--btn-secondary-hover-bg);border-color:var(--btn-secondary-hover-border)}.table-pagination-btn:disabled{opacity:.45;cursor:not-allowed}.table-pagination-btn.show-all{border-color:var(--btn-outline-border);color:var(--btn-outline-text);background:var(--btn-outline-bg)}.table-pagination-btn.show-all:hover{background:var(--btn-outline-hover-bg)}.table-pagination-pages{display:flex;align-items:center;gap:.25rem}.table-pagination-ellipsis{padding:0 .3rem;color:#94a3b8;font-size:.9rem;-webkit-user-select:none;user-select:none}.table-pagination-page{min-width:2rem;padding:.4rem;font-size:.85rem;border:1px solid var(--btn-secondary-border);background:var(--btn-secondary-bg);color:var(--btn-secondary-text);border-radius:8px;cursor:pointer;transition:all .15s ease}.table-pagination-page:hover{background:var(--btn-secondary-hover-bg);border-color:var(--btn-secondary-hover-border)}.table-pagination-page.active{background:var(--btn-primary-bg);border-color:var(--btn-primary-border);color:var(--btn-primary-text);font-weight:700}.analisis-filter-card{margin-bottom:1.5rem}.analisis-state{padding:4rem;text-align:center;color:var(--guru-text-muted)}.analisis-empty{padding:5rem;text-align:center;color:var(--guru-text-soft)}.analisis-empty-icon{margin-bottom:1rem;opacity:.4}.analisis-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.summary-box{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:1.25rem 1rem;border-radius:14px;text-align:center;border:1px solid transparent}.summary-box .s-val{font-size:2rem;font-weight:800;line-height:1}.summary-box .s-lbl{font-size:.8rem;font-weight:600}.summary-box .s-lbl small{display:block;font-size:.7rem;font-weight:500;opacity:.75;margin-top:2px}.summary-box.mudah{background:var(--guru-success-soft);border-color:#bbf7d0;color:#15803d}.summary-box.sedang{background:var(--guru-primary-soft);border-color:#bfdbfe;color:#1d4ed8}.summary-box.sulit{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.summary-box.info{background:var(--guru-bg-table-head);border-color:var(--guru-border-soft);color:#334155}.analisis-table{width:100%;border:1px solid var(--guru-border-soft);border-radius:12px;overflow:hidden}.analisis-row{display:grid;grid-template-columns:48px 1fr 100px 90px 130px 120px;align-items:center;padding:.875rem 1.25rem;gap:1rem;border-bottom:1px solid var(--guru-bg-row-separator);background:var(--guru-bg-card);transition:background .15s}.analisis-row:last-child{border-bottom:none}.analisis-row:hover:not(.analisis-head){background:var(--guru-bg-table-head)}.analisis-head{background:#1b3a6bd9;font-size:.72rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.05em;padding:.7rem 1.25rem;border-bottom:1px solid rgba(27,58,107,.4)}.analisis-head>div{text-align:center}.analisis-head>div:nth-child(1),.analisis-head>div:nth-child(2){text-align:left}.soal-num{font-weight:800;color:#94a3b8;font-size:.8rem}.soal-text-cell{font-size:.9rem;color:var(--guru-text-body);font-weight:500;line-height:1.5}.stat-cell{text-align:center;display:flex;flex-direction:column;align-items:center;gap:2px}.stat-val{font-weight:800;font-size:1rem;color:#334155}.stat-val.green{color:#16a34a}.stat-lbl{font-size:.68rem;color:#94a3b8}.eval-cell{text-align:center}.ratio-bar{width:70px;height:5px;background:var(--guru-border-soft);border-radius:3px;overflow:hidden;margin-top:4px}.ratio-fill{height:100%;border-radius:3px;transition:width .4s ease}.stat-val.ratio-high{color:var(--guru-success)}.stat-val.ratio-mid{color:#1d4ed8}.stat-val.ratio-low{color:var(--guru-danger)}.ratio-fill.ratio-high{background:var(--guru-success)}.ratio-fill.ratio-mid{background:#1d4ed8}.ratio-fill.ratio-low{background:var(--guru-danger)}.diff-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:9999px;font-size:.75rem;font-weight:700;white-space:nowrap}.diff-badge.mudah{background:#dcfce7;color:#15803d}.diff-badge.sedang{background:#dbeafe;color:#1d4ed8}.diff-badge.sulit{background:#fee2e2;color:#b91c1c}@media(max-width:1024px){.analisis-summary-grid{grid-template-columns:repeat(2,1fr)}}.review-hasil-page{padding:1.5rem;background-color:var(--guru-bg-page);min-height:100vh;animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.review-container{max-width:1100px;margin:0 auto}.review-header-compact{background:#fff;padding:1rem 1.5rem;border-radius:16px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 3px #0000000a;border:1px solid #e2e8f0;margin-bottom:1rem}.header-left{display:flex;align-items:center;gap:1.5rem}.btn-back-minimal{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:8px;border:1px solid var(--btn-secondary-border);background:var(--btn-secondary-bg);color:var(--btn-secondary-text);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s}.btn-back-minimal:hover{background:var(--btn-secondary-hover-bg);border-color:var(--btn-secondary-hover-border)}.student-info-main{display:flex;align-items:center;gap:1rem}.avatar-small{width:40px;height:40px;background:#eff6ff;border:1px solid #BFDBFE;color:#1d4ed8;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.1rem}.student-name-small{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0}.student-meta-small{font-size:.8rem;color:#64748b;margin:0}.header-right-stats{display:flex;align-items:center;gap:1.5rem}.score-badge-compact{display:flex;flex-direction:column;align-items:center;padding:.25rem 1rem;background:#f1f5f9;border-radius:10px;border:1px solid #e2e8f0}.score-badge-compact .label{font-size:.65rem;font-weight:800;color:#94a3b8}.score-badge-compact .value{font-size:1.5rem;font-weight:900;color:var(--guru-primary)}.stats-row-compact{display:flex;gap:.5rem}.stat-item-mini{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:8px;font-size:.875rem;font-weight:700}.stat-item-mini.green{background:var(--btn-success-bg);color:var(--btn-success-text);border:1px solid var(--btn-success-border)}.stat-item-mini.red{background:var(--btn-danger-bg);color:var(--btn-danger-text);border:1px solid var(--btn-danger-border)}.stat-item-mini.gray{background:var(--btn-secondary-bg);color:var(--btn-secondary-text);border:1px solid var(--btn-secondary-border)}.exam-info-strip{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;background:var(--guru-primary-soft);color:var(--guru-primary);border-radius:12px;font-size:.875rem;border:1px solid #dbeafe;margin-bottom:1.5rem}.exam-info-strip strong{font-weight:700}.answers-container-compact{width:100%}.answers-grid-compact{display:grid;grid-template-columns:1fr;gap:.75rem}.q-card-compact{background:#fff;border-radius:12px;border:1px solid #e2e8f0;overflow:hidden;display:flex;flex-direction:column}.q-card-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background:#f8fafc;border-bottom:1px solid #f1f5f9}.q-number-badge{font-size:.75rem;font-weight:800;color:#94a3b8}.q-result-text{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.025em}.q-result-text.correct{color:#16a34a}.q-result-text.wrong{color:#dc2626}.q-body-compact{padding:1rem 1.25rem}.q-text-small{font-size:.95rem;color:#1e293b;font-weight:500;line-height:1.5;margin-bottom:1rem}.q-image-small{margin-bottom:1rem}.q-image-small img{max-width:300px;border-radius:8px;border:1px solid #f1f5f9}.q-comparison-compact{display:flex;gap:2rem;padding-top:.75rem;border-top:1px dashed #e2e8f0}.comp-item{display:flex;align-items:center;gap:.75rem}.comp-item .l{font-size:.75rem;font-weight:700;color:#94a3b8;text-transform:uppercase}.comp-item .v{font-size:.9rem;font-weight:700;color:#334155}.comp-item .v.highlight{color:#2563eb;background:#eff6ff;padding:.125rem .5rem;border-radius:4px}.comp-item .v.empty{font-style:italic;color:#cbd5e1;font-weight:400}.is-correct{border-left:4px solid #22c55e}.is-wrong{border-left:4px solid #ef4444}.review-page-loading,.review-page-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem;min-height:80vh}.loader{width:32px;height:32px;border:3px solid #e2e8f0;border-top:3px solid #93C5FD;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.review-header-compact{flex-direction:column;align-items:flex-start;gap:1rem}.header-right-stats{width:100%;justify-content:space-between}.q-comparison-compact{flex-direction:column;gap:.5rem}}
