@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:200 800;font-display:swap;src:url(../media/0b1dc8ddaa74ba49-s.8624a701.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:200 800;font-display:swap;src:url(../media/e629b5bc06499d58-s.8e66b869.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:200 800;font-display:swap;src:url(../media/1a099d89ee94ee96-s.f6ed4c33.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:200 800;font-display:swap;src:url(../media/fba5a26ea33df6a3-s.p.1bbdebe6.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Plus Jakarta Sans Fallback;src:local(Arial);ascent-override:98.88%;descent-override:21.15%;line-gap-override:0.0%;size-adjust:104.98%}.plus_jakarta_sans_8bc347b7-module__2ann4W__className{font-family:Plus Jakarta Sans,Plus Jakarta Sans Fallback;font-style:normal}
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-white:#fff;--spacing:.25rem;--radius-lg:.5rem;--ease-in-out:cubic-bezier(.4,0,.2,1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.sticky{position:sticky}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.right-\[320px\]{right:320px}.bottom-\[20px\]{bottom:20px}.z-10{z-index:10}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mt-10{margin-top:calc(var(--spacing)*10)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.w-\[120px\]{width:120px}.w-full{width:100%}.flex-1{flex:1}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.justify-between{justify-content:space-between}.gap-\[8px\]{gap:8px}.gap-\[12px\]{gap:12px}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.rounded-lg{border-radius:var(--radius-lg)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-white\/10{border-color:#ffffff1a}@supports (color:color-mix(in lab, red, red)){.border-white\/10{border-color:color-mix(in oklab,var(--color-white)10%,transparent)}}.bg-white\/5{background-color:#ffffff0d}@supports (color:color-mix(in lab, red, red)){.bg-white\/5{background-color:color-mix(in oklab,var(--color-white)5%,transparent)}}.p-5{padding:calc(var(--spacing)*5)}.p-6{padding:calc(var(--spacing)*6)}.capitalize{text-transform:capitalize}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,)var(--tw-slashed-zero,)var(--tw-numeric-figure,)var(--tw-numeric-spacing,)var(--tw-numeric-fraction,)}.underline{text-decoration-line:underline}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.select-none{-webkit-user-select:none;user-select:none}@media (min-width:48rem){.md\:block{display:block}.md\:h-full{height:100%}.md\:w-\[280px\]{width:280px}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:flex-row{flex-direction:row}.md\:overflow-hidden{overflow:hidden}.md\:overflow-y-auto{overflow-y:auto}.md\:border-t-0{border-top-style:var(--tw-border-style);border-top-width:0}.md\:border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.md\:p-10{padding:calc(var(--spacing)*10)}}@media (min-width:64rem){.lg\:px-\[60px\]{padding-inline:60px}.lg\:py-\[40px\]{padding-block:40px}}}:root{--gradient-1:#6366f1;--gradient-2:#8b5cf6;--gradient-3:#a855f7;--gradient-4:#06b6d4;--gradient-5:#3b82f6;--emerald:#10b981;--teal:#14b8a6;--gold:#f59e0b;--bg-dark:#0a0e1a;--bg-card:#ffffff0a;--bg-card-hover:#ffffff14;--border-glass:#ffffff14;--text-primary:#f0f4ff;--text-secondary:#8b95b0;--success:#10b981;--warning:#f59e0b;--danger:#ef4444}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg-dark);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Plus Jakarta Sans,Inter,system-ui,-apple-system,sans-serif;overflow-x:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#6366f14d;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#6366f180}.gradient-bg{background:linear-gradient(135deg,#0a0e1a 0%,#1a1040 25%,#0d1f3c 50%,#0a2035 75%,#0a0e1a 100%) 0 0/400% 400%;animation:15s infinite gradientShift}@keyframes gradientShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}.gradient-orb{filter:blur(80px);opacity:.15;pointer-events:none;border-radius:50%;position:absolute}.gradient-orb-1{background:linear-gradient(135deg,var(--gradient-1),var(--gradient-2));width:600px;height:600px;top:-200px;right:-100px}.gradient-orb-2{background:linear-gradient(135deg,var(--gradient-4),var(--gradient-5));width:500px;height:500px;bottom:-150px;left:-100px}.gradient-orb-3{background:linear-gradient(135deg,var(--gradient-3),#ec4899);width:400px;height:400px;top:40%;left:30%}.glass-card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-glass);border-radius:16px;transition:all .3s cubic-bezier(.4,0,.2,1)}.glass-card:hover{background:var(--bg-card-hover);border-color:#6366f14d;transform:translateY(-2px);box-shadow:0 8px 32px #6366f11a}.gradient-text{background:linear-gradient(135deg,var(--gradient-1),var(--gradient-4));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.shimmer-btn{background:linear-gradient(135deg,var(--gradient-1),var(--gradient-2));color:#fff;cursor:pointer;border:none;border-radius:12px;font-weight:600;transition:all .3s;position:relative;overflow:hidden}.shimmer-btn:before{content:"";background:linear-gradient(90deg,#0000,#fff3,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.shimmer-btn:hover:before{left:100%}.shimmer-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #6366f166}.progress-bar-bg{background:#ffffff0f;border-radius:999px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg,var(--gradient-1),var(--gradient-4));border-radius:999px;height:100%;transition:width 1s cubic-bezier(.4,0,.2,1)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in-up{animation:.6s forwards fadeInUp}@keyframes pulseGlow{0%,to{box-shadow:0 0 20px #6366f11a}50%{box-shadow:0 0 40px #6366f133}}.pulse-glow{animation:3s infinite pulseGlow}@keyframes float{0%,to{transform:translateY(0)rotate(0)}33%{transform:translateY(-10px)rotate(1deg)}66%{transform:translateY(5px)rotate(-1deg)}}.animate-float{animation:6s ease-in-out infinite float}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}.stagger-5{animation-delay:.5s}.stagger-6{animation-delay:.6s}.stagger-7{animation-delay:.7s}.stagger-8{animation-delay:.8s}.sidebar{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid var(--border-glass);background:#0a0e1af2}.sidebar-link{color:var(--text-secondary);border-radius:12px;align-items:center;gap:12px;padding:12px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:all .3s;display:flex}.sidebar-link:hover{color:var(--text-primary);background:#6366f11a}.sidebar-link.active{color:var(--text-primary);background:linear-gradient(135deg,#6366f126,#8b5cf626);border:1px solid #6366f133}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{border:1px solid var(--border-glass);background:#131829;border-radius:20px;width:90%;max-width:900px;max-height:80vh;padding:32px;position:relative;overflow-y:auto}.input-field{border:1px solid var(--border-glass);width:100%;color:var(--text-primary);background:#ffffff0a;border-radius:12px;outline:none;padding:12px 16px;font-size:14px;transition:all .3s}.input-field:focus{border-color:var(--gradient-1);box-shadow:0 0 0 3px #6366f11a}.input-field::placeholder{color:var(--text-secondary);opacity:.6}select option{color:#000;background-color:#fff}.drop-zone{text-align:center;cursor:pointer;border:2px dashed #6366f14d;border-radius:16px;padding:48px;transition:all .3s}.drop-zone:hover,.drop-zone.active{border-color:var(--gradient-1);background:#6366f10d}.data-table{border-collapse:separate;border-spacing:0;width:100%}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:1px solid var(--border-glass);padding:12px 16px;font-size:12px;font-weight:600}.data-table td{border-bottom:1px solid #ffffff08;padding:12px 16px;font-size:14px}.data-table tr:hover td{background:#6366f108}.badge{border-radius:999px;align-items:center;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge-success{color:#34d399;background:#10b98126}.badge-warning{color:#fbbf24;background:#f59e0b26}.badge-danger{color:#f87171;background:#ef444426}.badge-info{color:#818cf8;background:#6366f126}.role-card{cursor:pointer;text-align:center;background:#ffffff08;border:1px solid #ffffff0f;border-radius:20px;padding:32px 28px;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.role-card:before{content:"";opacity:0;border-radius:20px;transition:opacity .4s;position:absolute;inset:0}.role-card:hover{border-color:#ffffff26;transform:translateY(-8px)scale(1.02);box-shadow:0 20px 60px #0000004d}.role-card:hover:before{opacity:1}.role-card.pengajar:before{background:linear-gradient(135deg,#f59e0b14,#fbbf2408)}.role-card.pengajar:hover{border-color:#f59e0b4d;box-shadow:0 20px 60px #f59e0b1a}.role-card.pegawai:before{background:linear-gradient(135deg,#6366f114,#06b6d408)}.role-card.pegawai:hover{border-color:#6366f14d;box-shadow:0 20px 60px #6366f11a}.role-card.umum:before{background:linear-gradient(135deg,#10b98114,#14b8a608)}.role-card.umum:hover{border-color:#10b9814d;box-shadow:0 20px 60px #10b9811a}.course-card{cursor:pointer;background:#ffffff08;border:1px solid #ffffff0f;border-radius:16px;padding:24px;transition:all .3s cubic-bezier(.4,0,.2,1)}.course-card:hover{background:#ffffff0f;border-color:#6366f133;transform:translateY(-4px);box-shadow:0 12px 40px #0003}.course-card.selected{background:#6366f11a;border-color:#6366f166;box-shadow:0 0 20px #6366f126}.quiz-option{cursor:pointer;background:#ffffff08;border:1px solid #ffffff14;border-radius:12px;align-items:center;gap:12px;padding:16px 20px;transition:all .2s;display:flex}.quiz-option:hover{background:#6366f114;border-color:#6366f14d}.quiz-option.selected{background:#6366f11f;border-color:#6366f180}.quiz-option.correct{background:#10b9811f;border-color:#10b98180}.quiz-option.wrong{background:#ef44441f;border-color:#ef444480}@keyframes floatParticle{0%,to{opacity:.3;transform:translateY(0)translate(0)}25%{opacity:.6;transform:translateY(-20px)translate(10px)}50%{opacity:.4;transform:translateY(-10px)translate(-5px)}75%{opacity:.5;transform:translateY(-30px)translate(15px)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes shimmerGlow{0%,to{opacity:.5}50%{opacity:1}}.animate-fade-in-scale{animation:.8s cubic-bezier(.16,1,.3,1) forwards fadeInScale}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-bounce-in{animation:.6s cubic-bezier(.68,-.55,.265,1.55) forwards bounceIn}@keyframes glowPulse{0%,to{filter:drop-shadow(0 0 6px);transform:scale(1)}50%{filter:drop-shadow(0 0 16px);transform:scale(1.08)}}.icon-glow-pulse{animation:2.5s ease-in-out infinite glowPulse}@keyframes iconFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.icon-float{animation:3s ease-in-out infinite iconFloat}.role-card:hover .role-icon-box{animation:.4s forwards bounceIn}@keyframes particleDrift{0%{opacity:0;transform:translateY(0)translate(0)scale(0)}10%{opacity:.6;transform:scale(1)}90%{opacity:.3}to{opacity:0;transform:translateY(-100vh)translate(80px)scale(.5)}}.landing-particles{pointer-events:none;z-index:0;position:absolute;inset:0;overflow:hidden}.landing-particles span{background:#ffd70066;border-radius:50%;width:6px;height:6px;animation:linear infinite particleDrift;position:absolute;bottom:-10px}.landing-particles span:first-child{width:4px;height:4px;animation-duration:12s;animation-delay:0s;left:10%}.landing-particles span:nth-child(2){background:#6366f14d;width:6px;height:6px;animation-duration:14s;animation-delay:2s;left:25%}.landing-particles span:nth-child(3){width:3px;height:3px;animation-duration:10s;animation-delay:4s;left:40%}.landing-particles span:nth-child(4){background:#10b9814d;width:5px;height:5px;animation-duration:16s;animation-delay:1s;left:55%}.landing-particles span:nth-child(5){background:#f59e0b66;width:4px;height:4px;animation-duration:11s;animation-delay:3s;left:70%}.landing-particles span:nth-child(6){background:#6366f140;width:7px;height:7px;animation-duration:13s;animation-delay:5s;left:85%}.landing-particles span:nth-child(7){width:3px;height:3px;animation-duration:15s;animation-delay:6s;left:50%}.landing-particles span:nth-child(8){background:#06b6d44d;width:5px;height:5px;animation-duration:9s;animation-delay:7s;left:15%}.jp-progress-ring{width:140px;height:140px;position:relative}.jp-progress-ring svg{transform:rotate(-90deg)}.jp-progress-ring .ring-bg{fill:none;stroke:#ffffff0f;stroke-width:10px}.jp-progress-ring .ring-fill{fill:none;stroke-width:10px;stroke-linecap:round;transition:stroke-dashoffset 1.5s cubic-bezier(.4,0,.2,1)}.jp-progress-ring .ring-value{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.achievement-badge{text-align:center;background:#ffffff05;border:1px solid #ffffff0f;border-radius:16px;flex-direction:column;align-items:center;gap:8px;min-width:100px;padding:16px 12px;transition:all .3s;display:flex}.achievement-badge.earned{background:#ffd7000d;border-color:#ffd7004d}.achievement-badge.earned:hover{transform:translateY(-4px);box-shadow:0 8px 24px #ffd70026}.achievement-badge:not(.earned){opacity:.4;filter:grayscale()}.achievement-badge .badge-icon{font-size:32px;line-height:1}.achievement-badge .badge-label{color:var(--text-primary);font-size:11px;font-weight:700}.achievement-badge .badge-desc{color:var(--text-secondary);font-size:10px;line-height:1.3}.drop-zone-enhanced{text-align:center;cursor:pointer;background:#6366f105;border:2px dashed #6366f140;border-radius:16px;padding:40px 24px;transition:all .3s}.drop-zone-enhanced:hover,.drop-zone-enhanced.dragging{background:#6366f114;border-color:#6366f199;transform:scale(1.01);box-shadow:0 0 30px #6366f11a}.drop-zone-enhanced.dragging{animation:1s infinite pulseGlow}.stagger-entrance>*{opacity:0;animation:.5s forwards fadeInUp}.stagger-entrance>:first-child{animation-delay:50ms}.stagger-entrance>:nth-child(2){animation-delay:.1s}.stagger-entrance>:nth-child(3){animation-delay:.15s}.stagger-entrance>:nth-child(4){animation-delay:.2s}.stagger-entrance>:nth-child(5){animation-delay:.25s}.stagger-entrance>:nth-child(6){animation-delay:.3s}.tab-btn{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:8px;padding:10px 20px;font-family:inherit;font-size:13px;font-weight:600;transition:all .2s;display:flex}.tab-btn.active{color:#818cf8;background:linear-gradient(135deg,#6366f140,#06b6d426);border-bottom:2px solid #818cf8}.tab-btn:not(.active){color:var(--text-secondary);background:#ffffff08;border-bottom:2px solid #0000}@media (max-width:768px){.sidebar{z-index:40;width:280px;transition:left .3s;position:fixed;top:0;bottom:0;left:-280px}.sidebar.open{left:0}.role-card{padding:24px 20px}}.mobile-nav-toggle{color:#fff;cursor:pointer;z-index:50;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:20px;transition:all .3s;display:none;position:fixed;bottom:20px;right:20px;box-shadow:0 4px 20px #6366f166}.mobile-nav-toggle:hover{transform:scale(1.1);box-shadow:0 6px 25px #6366f180}@media (max-width:768px){.mobile-nav-toggle{display:flex}}@media (max-width:1200px){.stats-grid{grid-template-columns:repeat(2,1fr)!important}}@media (max-width:768px){.stats-grid,.unit-cards-grid,.course-grid{grid-template-columns:1fr!important}.achievements-flex{flex-direction:column!important;align-items:center!important}}@media (max-width:640px){.mobile-padding{padding:16px!important}.mobile-full-width{width:100%!important;max-width:100%!important}.modal-mobile{width:95%!important;max-width:95%!important;margin:10px!important;padding:20px!important}.header-mobile{flex-direction:column!important;align-items:flex-start!important;gap:12px!important}.header-buttons{flex-wrap:wrap!important;width:100%!important}.header-buttons button{flex:1!important;min-width:120px!important;padding:8px 12px!important;font-size:12px!important}.hero-mobile{flex-direction:column!important;padding:16px!important}.progress-ring-mobile{margin:0 auto!important}.jp-info-mobile{text-align:center!important}.badges-mobile{justify-content:center!important}}@media (max-width:768px){.quiz-option,.sidebar-link{min-height:48px!important;padding:14px 16px!important}.course-card{padding:20px!important}.role-card{padding:20px 16px!important}.glass-card{padding:16px!important}.btn-mobile{touch-action:manipulation!important;min-height:48px!important}}@media (max-width:640px){html{font-size:14px}h1{font-size:1.75rem!important}h2{font-size:1.5rem!important}h3{font-size:1.25rem!important}h4{font-size:1.1rem!important}}@media (max-width:768px){body{overflow-x:hidden}.prevent-overflow{-webkit-overflow-scrolling:touch;overflow-x:auto}}@supports (padding-bottom:env(safe-area-inset-bottom)){.mobile-nav-toggle{bottom:calc(20px + env(safe-area-inset-bottom));right:calc(20px + env(safe-area-inset-right))}}.table-responsive-wrapper{-webkit-overflow-scrolling:touch;border-radius:12px;overflow-x:auto}@media (max-width:768px){.table-responsive-wrapper table{font-size:12px}.table-responsive-wrapper th,.table-responsive-wrapper td{white-space:nowrap;padding:8px 10px!important}}@media (max-width:640px){.hide-mobile{display:none!important}}@media (min-width:641px){.show-mobile-only{display:none!important}}@media (max-width:480px){.jp-progress-ring,.jp-progress-ring svg{width:100px!important;height:100px!important}.jp-progress-ring .ring-bg,.jp-progress-ring .ring-fill{stroke-width:8px!important}}@media (max-width:768px){.stack-cards-mobile>*{margin-bottom:12px}.stack-cards-mobile>:last-child{margin-bottom:0}}@media (max-width:640px){.input-field{padding:12px 14px!important;font-size:16px!important}.input-field::placeholder{font-size:14px}.modal-overlay{justify-content:center!important;align-items:flex-end!important;padding:10px!important}.modal-content{border-radius:20px 20px 0 0!important;width:100%!important;max-width:100%!important;max-height:85vh!important;padding:24px 16px!important}}@media (max-width:900px){.landing-grid{grid-template-columns:repeat(2,1fr)!important}}@media (max-width:640px){.landing-grid{margin:0 auto;grid-template-columns:1fr!important;max-width:400px!important}.landing-logo{height:80px!important}.landing-title{letter-spacing:2px!important;font-size:2.5rem!important}.landing-subtitle{font-size:1rem!important}}.table-responsive-wrapper{-webkit-overflow-scrolling:touch;width:100%;margin-bottom:1rem;overflow-x:auto}.no-select{-webkit-user-select:none;user-select:none}@media (hover:none){html{scroll-behavior:auto}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
