/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */@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-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}}}@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;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-2xl:1rem;--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);--color-surface:#101223;--color-surface-lowest:#0b0d1e;--color-surface-low:#181a2c;--color-surface-container:#1c1e30;--color-surface-high:#27293b;--color-surface-highest:#323346;--color-surface-bright:#36384b99;--color-primary:#bbc3ff;--color-primary-container:#3d5afe;--color-primary-dim:#4963ff;--color-on-surface:#e0e0f9;--color-on-surface-dim:#8e8fa2;--color-secondary:#c5c0ff;--color-tertiary:#ffade5;--color-success:#4caf50;--color-error:#ef5350;--color-error-soft:#ffb4ab;--color-warning:#ffa726;--sidebar-width:260px;--font-family-heading:"Manrope", sans-serif;--font-family-body:"Inter", sans-serif}}@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%;-moz-tab-size:4;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;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]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance: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{.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}}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.w-full{width:100%}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.rounded-2xl{border-radius:var(--radius-2xl)}.border{border-style:var(--tw-border-style);border-width:1px}.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,)}.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))}}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-family-body);background:var(--color-surface-lowest);color:var(--color-on-surface);-webkit-font-smoothing:antialiased;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-family-heading)}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}.gradient-primary{background:linear-gradient(135deg,#9ba8ff,#4963ff)}.gradient-text{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#bbc3ff,#9ba8ff);-webkit-background-clip:text;background-clip:text}.glass{background:var(--color-surface-bright);-webkit-backdrop-filter:blur(20px)}.glow{box-shadow:0 0 40px #3d5afe26}.glow-strong{box-shadow:0 0 60px #3d5afe4d}.hidden{display:none!important}.login-page{background:radial-gradient(ellipse at 30% 20%,#3d5afe1f 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,#9ba8ff14 0%,transparent 50%),var(--color-surface-lowest);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--color-surface-container);border-radius:var(--radius-xl);border:1px solid #ffffff0f;width:100%;max-width:400px;padding:36px 32px;box-shadow:0 16px 64px #0006}.login-logo{justify-content:center;align-items:center;gap:10px;margin-bottom:28px;display:flex}.login-logo .logo-icon{width:44px;height:44px;font-family:var(--font-family-heading);color:#fff;border-radius:12px;justify-content:center;align-items:center;font-size:20px;font-weight:800;display:flex}.login-logo .brand{font-family:var(--font-family-heading);color:var(--color-on-surface);font-size:22px;font-weight:800}.login-logo .brand em{color:var(--color-primary-dim);font-style:normal}.login-title{font-family:var(--font-family-heading);text-align:center;margin-bottom:4px;font-size:22px;font-weight:700}.login-sub{text-align:center;color:var(--color-on-surface-dim);margin-bottom:24px;font-size:14px}.password-wrap{position:relative}.password-wrap .input{padding-right:44px}.toggle-pw{border-radius:var(--radius-sm);width:36px;height:36px;color:var(--color-on-surface-dim);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:color .2s;display:flex;position:absolute;top:50%;right:4px;transform:translateY(-50%)}.toggle-pw:hover{color:var(--color-on-surface)}.forgot{text-align:right;margin:-8px 0 16px;font-size:13px}.forgot a{color:var(--color-primary)}.divider{color:var(--color-on-surface-dim);align-items:center;gap:12px;margin:20px 0;font-size:13px;display:flex}.divider:before,.divider:after{content:"";background:#ffffff0f;flex:1;height:1px}.social-btn{background:var(--color-surface-high);border-radius:var(--radius-xl);width:100%;color:var(--color-on-surface);cursor:pointer;border:1px solid #ffffff0f;justify-content:center;align-items:center;gap:10px;padding:12px;font-size:14px;font-weight:500;transition:background .2s;display:flex}.social-btn:hover{background:var(--color-surface-highest)}.register-link{text-align:center;color:var(--color-on-surface-dim);margin-top:20px;font-size:13px}.register-link a{color:var(--color-primary);font-weight:600}.demo-hint{border-radius:var(--radius-md);color:var(--color-on-surface-dim);text-align:center;background:#ffa7260f;border:1px solid #ffa72626;margin-top:16px;padding:12px 16px;font-size:12px;line-height:1.6}.demo-hint strong{color:var(--color-warning)}.onboarding-overlay{background:var(--color-surface-lowest);z-index:150;text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.onboarding-overlay.hidden{display:none}.ob-icon{margin-bottom:20px;font-size:56px}.ob-title{font-family:var(--font-family-heading);margin-bottom:10px;font-size:22px;font-weight:700}.ob-desc{color:var(--color-on-surface-dim);max-width:360px;margin-bottom:28px;font-size:15px;line-height:1.6}.ob-dots{justify-content:center;gap:8px;margin-bottom:28px;display:flex}.ob-dot{background:var(--color-surface-high);border-radius:50%;width:8px;height:8px;transition:background .3s}.ob-dot.active{background:var(--color-primary);border-radius:4px;width:24px}.ob-skip{color:var(--color-on-surface-dim);cursor:pointer;background:0 0;border:none;margin-top:12px;font-size:14px;transition:color .2s}.ob-skip:hover{color:var(--color-on-surface)}.sidebar{width:var(--sidebar-width);background:var(--color-surface-low);z-index:50;flex-direction:column;transition:transform .3s;display:flex;position:fixed;top:0;bottom:0}.sidebar-right{border-left:1px solid #ffffff0a;right:0}.sidebar-left{border-right:1px solid #ffffff0a;left:0}.sidebar-logo{border-bottom:1px solid #ffffff0a;align-items:center;gap:10px;padding:20px 24px;display:flex}.sidebar-logo .logo-icon{border-radius:var(--radius-md);color:#fff;width:36px;height:36px;font-family:var(--font-family-heading);justify-content:center;align-items:center;font-size:16px;font-weight:800;display:flex}.sidebar-logo span{font-family:var(--font-family-heading);font-size:16px;font-weight:700}.sidebar-logo em{color:var(--color-primary-dim);font-style:normal}.sidebar-label{color:var(--color-on-surface-dim);text-transform:uppercase;letter-spacing:1px;margin-top:24px;margin-bottom:8px;padding:0 24px;font-size:10px;font-weight:600}.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}.nav-section{color:var(--color-on-surface-dim);text-transform:uppercase;letter-spacing:1px;padding:16px 24px 8px;font-size:10px;font-weight:600}.nav-item{color:var(--color-on-surface-dim);cursor:pointer;align-items:center;gap:12px;padding:11px 24px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover{background:var(--color-surface-high);color:var(--color-on-surface);text-decoration:none}.nav-item.active{color:var(--color-primary);background:#4963ff1a}.sidebar-right .nav-item.active{border-left:3px solid var(--color-primary-dim)}.sidebar-left .nav-item.active{border-right:3px solid var(--color-primary-dim)}.nav-item .material-symbols-outlined{font-size:22px}.sidebar-footer{border-top:1px solid #ffffff0a;padding:16px 24px}.sidebar-user,.user-info{align-items:center;gap:10px;margin-bottom:12px;display:flex}.sidebar-user .avatar,.user-avatar{width:36px;height:36px;font-family:var(--font-family-heading);color:#fff;background:linear-gradient(135deg,#9ba8ff,#4963ff);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.user-name{font-size:13px;font-weight:600}.user-email,.user-role{color:var(--color-on-surface-dim);font-size:11px}.sidebar-toggle{border-radius:var(--radius-md);background:var(--color-surface-container);width:44px;height:44px;color:var(--color-on-surface);z-index:60;cursor:pointer;border:1px solid #ffffff0f;justify-content:center;align-items:center;font-size:22px;display:none;position:fixed;top:14px}.sidebar-right~.main-content .sidebar-toggle,.sidebar-toggle.right{right:14px}.sidebar-toggle.left{left:14px}.sidebar-overlay{z-index:49;background:#00000080;display:none;position:fixed;top:0;right:0;bottom:0;left:0}.sidebar-overlay.active{display:block}.main-content{flex-direction:column;min-height:100vh;display:flex}.main-content-right{margin-right:var(--sidebar-width)}.main-content-left{margin-left:var(--sidebar-width)}.page-header{background:var(--color-surface-low);border-bottom:1px solid #ffffff0a;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:24px 32px;display:flex}.page-header h1{font-family:var(--font-family-heading);font-size:24px;font-weight:700}.page-header .breadcrumb{color:var(--color-on-surface-dim);margin-top:2px;font-size:13px}.page-header-actions{align-items:center;gap:8px;display:flex}.page-body{flex:1;padding:24px 32px}.section-title{margin-bottom:12px;font-size:15px;font-weight:700}.card{background:var(--color-surface-container);border-radius:var(--radius-lg);margin-bottom:16px;padding:20px;transition:background .2s}.card:hover{background:var(--color-surface-high)}.grid-2{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--color-surface-container);border-radius:var(--radius-lg);flex-direction:column;gap:8px;padding:20px;display:flex}.stat-card .stat-value{font-family:var(--font-family-heading);font-size:28px;font-weight:800}.stat-card .stat-label{color:var(--color-on-surface-dim);font-size:12px;font-weight:500}.stat-card .stat-trend{align-items:center;gap:4px;font-size:11px;font-weight:600;display:flex}.stat-trend.up{color:var(--color-success)}.stat-trend.down{color:var(--color-error)}.progress-bar{background:var(--color-surface-high);border-radius:99px;height:6px;overflow:hidden}.progress-bar .fill{background:linear-gradient(135deg,#9ba8ff,#4963ff);border-radius:99px;height:100%;transition:width .6s}.btn{border-radius:var(--radius-xl);font-family:var(--font-family-body);cursor:pointer;color:#fff;border:none;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:14px;font-weight:600;text-decoration:none;transition:transform .15s,opacity .2s;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{color:#fff;background:linear-gradient(135deg,#9ba8ff,#4963ff)}.btn-primary:hover{opacity:.9}.btn-secondary{background:var(--color-surface-highest);color:var(--color-on-surface)}.btn-secondary:hover{background:var(--color-surface-high)}.btn-outline{color:var(--color-primary);background:0 0;border:1px solid #bbc3ff33}.btn-outline:hover{background:#bbc3ff0d}.btn-ghost{color:var(--color-primary);background:0 0;padding:8px 16px}.btn-success{background:var(--color-success);color:#fff}.btn-error{background:var(--color-error);color:#fff}.btn-block{width:100%}.btn-lg{padding:14px 28px;font-size:15px}.btn-sm{padding:8px 16px;font-size:13px}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.icon-btn{border-radius:var(--radius-md);width:40px;height:40px;color:var(--color-on-surface-dim);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:background .2s;display:flex}.icon-btn:hover{background:var(--color-surface-high)}.answer-grid{gap:12px;margin-top:16px;display:grid}.answer-grid.binary{grid-template-columns:1fr 1fr;max-width:400px}.answer-grid.multiple{grid-template-columns:1fr;max-width:600px}.answer-btn{border-radius:var(--radius-lg);background:var(--color-surface-container);color:var(--color-on-surface);cursor:pointer;text-align:left;border:2px solid #0000;align-items:center;gap:12px;padding:16px 20px;font-size:15px;font-weight:600;transition:all .2s;display:flex}.answer-btn:hover{background:var(--color-surface-high)}.answer-btn.selected{border-color:var(--color-primary-dim);background:#4963ff1a}.answer-btn.correct{border-color:var(--color-success);background:#4caf501a}.answer-btn.incorrect{border-color:var(--color-error);background:#ef53501a}.answer-letter{border-radius:var(--radius-md);background:var(--color-surface-high);width:36px;height:36px;font-family:var(--font-family-heading);flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.answer-btn.correct .answer-letter{background:var(--color-success);color:#fff}.answer-btn.incorrect .answer-letter{background:var(--color-error);color:#fff}.chip-row{flex-wrap:wrap;gap:8px;padding-bottom:8px;display:flex}.chip{border-radius:var(--radius-xl);background:var(--color-surface-high);color:var(--color-on-surface-dim);cursor:pointer;white-space:nowrap;border:none;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s}.chip.active{background:var(--color-primary-container);color:#fff}.chip:hover:not(.active){background:var(--color-surface-highest)}.badge{border-radius:var(--radius-xl);text-transform:uppercase;letter-spacing:.3px;align-items:center;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-primary{color:var(--color-primary);background:#4963ff26}.badge-success{color:var(--color-success);background:#4caf5026}.badge-error{color:var(--color-error-soft);background:#ef535026}.badge-warning{color:var(--color-warning);background:#ffa72626}.badge-danger{color:var(--color-error-soft);background:#ef535026}.badge-dot{background:var(--color-error);border-radius:50%;width:8px;height:8px;position:absolute;top:8px;right:8px}.input-group{margin-bottom:16px}.input-group label{color:var(--color-on-surface-dim);margin-bottom:6px;font-size:12px;font-weight:500;display:block}.input{border-radius:var(--radius-md);background:var(--color-surface-low);width:100%;color:var(--color-on-surface);font-size:14px;font-family:var(--font-family-body);border:1px solid #44465633;outline:none;padding:12px 16px;transition:all .2s}.input:focus{background:var(--color-surface-container);border-color:#bbc3ff4d}.input::placeholder{color:var(--color-on-surface-dim);opacity:.6}select.input{cursor:pointer}.search-bar{background:var(--color-surface-container);border-radius:var(--radius-lg);align-items:center;gap:8px;max-width:500px;margin-bottom:16px;padding:12px 16px;display:flex}.search-bar input{color:var(--color-on-surface);background:0 0;border:none;outline:none;flex:1;font-size:14px}.search-bar input::placeholder{color:var(--color-on-surface-dim)}.search-bar .material-symbols-outlined{color:var(--color-on-surface-dim);font-size:20px}.categories-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:24px;display:grid}.category-card{background:var(--color-surface-container);border-radius:var(--radius-lg);cursor:pointer;color:inherit;align-items:center;gap:14px;padding:18px 20px;text-decoration:none;transition:all .2s;display:flex}.category-card:hover{background:var(--color-surface-high);transform:translateY(-1px)}.category-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:24px;display:flex}.category-info{flex:1;min-width:0}.category-info .name{margin-bottom:2px;font-size:15px;font-weight:600}.category-info .desc{color:var(--color-on-surface-dim);margin-bottom:8px;font-size:12px}.category-meta{color:var(--color-on-surface-dim);justify-content:space-between;margin-top:4px;font-size:11px;display:flex}.media-container{aspect-ratio:16/9;background:var(--color-surface-low);border-radius:var(--radius-lg);width:100%;max-width:640px;margin-bottom:16px;position:relative;overflow:hidden}.media-container img,.media-container video{object-fit:cover;width:100%;height:100%}.media-placeholder{width:100%;height:100%;color:var(--color-on-surface-dim);flex-direction:column;justify-content:center;align-items:center;gap:8px;display:flex}.media-placeholder .material-symbols-outlined{font-size:48px}.question-item{cursor:pointer;border-bottom:1px solid #ffffff0a;gap:12px;padding:14px 0;transition:all .2s;display:flex}.question-item:hover{background:#ffffff05}.question-item:last-child{border-bottom:none}.question-thumb{border-radius:var(--radius-sm);background:var(--color-surface-high);flex-shrink:0;justify-content:center;align-items:center;width:64px;height:48px;display:flex;overflow:hidden}.question-thumb img{object-fit:cover;width:100%;height:100%}.question-thumb .material-symbols-outlined{color:var(--color-on-surface-dim);font-size:20px}.question-body{flex:1;min-width:0}.question-body .q-meta{align-items:center;gap:8px;margin-bottom:4px;display:flex}.question-body .q-text{color:var(--color-on-surface);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:13px;line-height:1.4;display:-webkit-box;overflow:hidden}.exam-history-item{border-bottom:1px solid #ffffff0a;align-items:center;gap:12px;padding:12px 0;display:flex}.exam-history-item:last-child{border-bottom:none}.exam-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.exam-dot.pass{background:var(--color-success)}.exam-dot.fail{background:var(--color-error)}.result-hero{text-align:center;flex-direction:column;align-items:center;padding:40px 20px 30px;display:flex}.result-icon{border-radius:50%;justify-content:center;align-items:center;width:96px;height:96px;margin-bottom:20px;display:flex}.result-icon.passed{color:var(--color-success);background:#4caf5026;box-shadow:0 0 60px #4caf5033}.result-icon.failed{color:var(--color-error);background:#ef535026;box-shadow:0 0 60px #ef535033}.result-icon .material-symbols-outlined{font-size:48px}.result-status{font-family:var(--font-family-heading);margin-bottom:8px;font-size:28px;font-weight:800}.result-status.passed{color:var(--color-success)}.result-status.failed{color:var(--color-error)}.result-score{font-family:var(--font-family-heading);margin-bottom:4px;font-size:36px;font-weight:700}.result-label{color:var(--color-on-surface-dim);font-size:13px}.profile-avatar{width:80px;height:80px;font-family:var(--font-family-heading);color:#fff;background:linear-gradient(135deg,#9ba8ff,#4963ff);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 12px;font-size:28px;font-weight:800;display:flex}.settings-item{background:var(--color-surface-container);cursor:pointer;color:inherit;align-items:center;gap:14px;padding:14px 16px;text-decoration:none;transition:background .2s;display:flex}.settings-item:hover{background:var(--color-surface-high)}.settings-item:first-child{border-radius:var(--radius-lg) var(--radius-lg) 0 0}.settings-item:last-child{border-radius:0 0 var(--radius-lg) var(--radius-lg)}.settings-item:only-child{border-radius:var(--radius-lg)}.settings-item+.settings-item{border-top:1px solid #ffffff0a}.settings-left{flex:1;align-items:center;gap:12px;display:flex}.toggle-switch{flex-shrink:0;width:44px;height:24px;display:inline-block;position:relative}.toggle-switch input{display:none}.toggle-slider{background:var(--color-surface-highest);cursor:pointer;border-radius:99px;transition:background .3s;position:absolute;top:0;right:0;bottom:0;left:0}.toggle-slider:before{content:"";background:var(--color-on-surface);border-radius:50%;width:18px;height:18px;transition:transform .3s;position:absolute;top:3px;left:3px}.toggle-switch input:checked+.toggle-slider{background:var(--color-primary-container)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.bookmark-card{background:var(--color-surface-container);border-radius:var(--radius-lg);cursor:pointer;flex-direction:column;margin-bottom:10px;padding:16px 18px;transition:all .2s;display:flex}.bookmark-card:hover{background:var(--color-surface-high)}.bm-top{align-items:flex-start;gap:12px;display:flex}.bm-thumb{border-radius:var(--radius-sm);background:var(--color-surface-high);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:36px;display:flex}.bm-thumb .material-symbols-outlined{color:var(--color-on-surface-dim);font-size:18px}.bm-info{flex:1;min-width:0}.bm-actions{border-top:1px solid #ffffff0a;justify-content:space-between;align-items:center;margin-top:10px;padding-top:10px;display:flex}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;color:var(--color-on-surface-dim);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #ffffff0f;padding:12px 16px;font-size:11px;font-weight:600}.data-table td{border-bottom:1px solid #ffffff0a;padding:14px 16px;font-size:14px}.data-table tr:hover td{background:#ffffff05}.pagination{justify-content:center;align-items:center;gap:8px;margin-top:20px;display:flex}.pagination button{border-radius:var(--radius-md);background:var(--color-surface-container);color:var(--color-on-surface-dim);cursor:pointer;border:none;padding:8px 14px;font-size:13px;transition:all .2s}.pagination button:hover{background:var(--color-surface-high)}.pagination button.active{background:var(--color-primary-container);color:#fff}.pagination button:disabled{opacity:.4;cursor:not-allowed}.modal-backdrop{z-index:100;opacity:0;pointer-events:none;background:#0009;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.modal-backdrop.active,.modal-backdrop.open{opacity:1;pointer-events:all}.modal-sheet{background:var(--color-surface-container);border-radius:var(--radius-xl);width:100%;max-width:520px;max-height:85vh;padding:24px;transition:transform .3s;overflow-y:auto;transform:scale(.95)}.modal-backdrop.active .modal-sheet,.modal-backdrop.open .modal-sheet{transform:scale(1)}.modal-handle{background:var(--color-surface-highest);border-radius:99px;width:40px;height:4px;margin:0 auto 16px}.modal-overlay{z-index:100;opacity:0;pointer-events:none;background:#0009;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.modal-overlay.active{opacity:1;pointer-events:all}.modal-overlay .modal{background:var(--color-surface-container);border-radius:var(--radius-xl);width:100%;max-width:520px;max-height:85vh;padding:24px;transition:transform .3s;overflow-y:auto;transform:scale(.95)}.modal-overlay.active .modal{transform:scale(1)}.modal-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.modal-header h3{font-size:18px;font-weight:700}:focus-visible,.btn:focus-visible,.chip:focus-visible,.nav-item:focus-visible{outline:2px solid var(--color-primary-dim);outline-offset:2px}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.toast{border-radius:var(--radius-lg);background:var(--color-surface-highest);width:max-content;max-width:400px;color:var(--color-on-surface);z-index:200;align-items:center;gap:8px;padding:12px 20px;font-size:14px;font-weight:500;transition:transform .3s;display:flex;position:fixed;top:20px;right:32px;transform:translateY(-120%);box-shadow:0 8px 32px #0000004d}.toast.show{transform:translateY(0)}.toast-success{border-left:3px solid var(--color-success)}.toast-error{border-left:3px solid var(--color-error)}.toast-info{border-left:3px solid var(--color-primary)}.exam-header-bar{border-bottom:1px solid #ffffff0a;justify-content:space-between;align-items:center;margin-bottom:16px;padding:16px 0;display:flex}.exam-header-bar .timer{font-family:var(--font-family-heading);color:var(--color-primary);font-size:24px;font-weight:700}.time-warning{color:var(--color-error)!important}.two-col{grid-template-columns:1fr 1fr;align-items:start;gap:32px;display:grid}.code-input{font-family:var(--font-family-heading),monospace;text-align:center;letter-spacing:4px;text-transform:uppercase;font-size:20px;font-weight:700}.empty-state{text-align:center;color:var(--color-on-surface-dim);flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;display:flex}.empty-state .material-symbols-outlined{margin-bottom:12px;font-size:48px}.fab{color:#fff;cursor:pointer;z-index:30;background:linear-gradient(135deg,#9ba8ff,#4963ff);border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:transform .2s;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 24px #4963ff66}.fab:hover{transform:scale(1.05)}.tab-bar{background:var(--color-surface-container);border-radius:var(--radius-lg);gap:4px;margin-bottom:20px;padding:4px;display:flex}.tab-bar button{border-radius:var(--radius-md);color:var(--color-on-surface-dim);cursor:pointer;background:0 0;border:none;flex:1;padding:10px 16px;font-size:13px;font-weight:500;transition:all .2s}.tab-bar button.active{background:var(--color-primary-container);color:#fff}.loading-spinner{border:3px solid var(--color-surface-highest);border-top-color:var(--color-primary-dim);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}.loading-spinner.sm{border-width:2px;width:20px;height:20px}.loading-spinner.lg{border-width:4px;width:48px;height:48px}.loading-center{justify-content:center;align-items:center;width:100%;padding:48px 24px;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:var(--color-surface-high);border-radius:var(--radius-sm);animation:1.5s ease-in-out infinite shimmer;position:relative;overflow:hidden}.skeleton:after{content:"";background:linear-gradient(90deg,#0000,#ffffff0a,#0000);animation:1.5s ease-in-out infinite shimmerSlide;position:absolute;top:0;right:0;bottom:0;left:0}@keyframes shimmer{0%,to{opacity:.6}50%{opacity:1}}@keyframes shimmerSlide{0%{transform:translate(-100%)}to{transform:translate(100%)}}.skeleton-text{height:14px;margin-bottom:8px}.skeleton-text.w-75{width:75%}.skeleton-text.w-50{width:50%}.skeleton-text.w-30{width:30%}.skeleton-circle{border-radius:50%}.skeleton-card{border-radius:var(--radius-lg);height:120px;margin-bottom:16px}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.4s ease-out fadeIn}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.scale-in{animation:.5s ease-out scaleIn}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:.5s ease-out slideUp}.stagger>*{opacity:0;animation:.4s ease-out forwards fadeIn}.stagger>:first-child{animation-delay:50ms}.stagger>:nth-child(2){animation-delay:.1s}.stagger>:nth-child(3){animation-delay:.15s}.stagger>:nth-child(4){animation-delay:.2s}.stagger>:nth-child(5){animation-delay:.25s}.stagger>:nth-child(6){animation-delay:.3s}.stagger>:nth-child(7){animation-delay:.35s}.stagger>:nth-child(8){animation-delay:.4s}.stagger>:nth-child(n+9){animation-delay:.45s}.offline-bar{text-align:center;background:var(--color-error);color:#fff;z-index:300;padding:10px 20px;font-size:13px;font-weight:600;transition:transform .3s;position:fixed;bottom:0;left:0;right:0;transform:translateY(100%)}.offline-bar.show{transform:translateY(0)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-surface-highest);border-radius:99px}@media(max-width:1024px){.sidebar-right{transform:translate(100%)}.sidebar-left{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-toggle{display:flex}.main-content-right,.main-content-left{margin-left:0;margin-right:0}.page-header{padding-right:72px}.stats-grid,.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}.two-col{grid-template-columns:1fr}}@media(max-width:640px){.stats-grid,.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.page-header h1{font-size:20px}.page-body{padding:16px}.categories-grid{grid-template-columns:1fr}}.landing-nav{z-index:100;-webkit-backdrop-filter:blur(16px);background:#0b0d1ed9;border-bottom:1px solid #ffffff0a;position:fixed;top:0;left:0;right:0}.landing-nav-inner{justify-content:space-between;align-items:center;max-width:1120px;height:64px;margin:0 auto;padding:0 24px;display:flex}.landing-brand{color:var(--color-on-surface);align-items:center;gap:10px;text-decoration:none;display:flex}.landing-brand:hover{text-decoration:none}.landing-nav-links{align-items:center;gap:24px;display:flex}.landing-nav-links a{color:var(--color-on-surface-dim);font-size:14px;font-weight:500;text-decoration:none;transition:color .15s}.landing-nav-links a:hover{color:var(--color-primary);text-decoration:none}.landing-hero{text-align:center;justify-content:center;align-items:center;min-height:100vh;padding:100px 24px 60px;display:flex}.landing-hero-inner{max-width:680px}.landing-hero-title{font-family:var(--font-family-heading);margin-bottom:20px;font-size:clamp(32px,5vw,52px);font-weight:800;line-height:1.15}.landing-hero-desc{color:var(--color-on-surface-dim);max-width:520px;margin:0 auto 36px;font-size:17px;line-height:1.7}.landing-hero-cta{flex-wrap:wrap;justify-content:center;gap:16px;display:flex}.landing-section{padding:80px 24px}.landing-section-alt{background:var(--color-surface-low)}.landing-container{max-width:1120px;margin:0 auto}.landing-section-title{font-family:var(--font-family-heading);text-align:center;margin-bottom:8px;font-size:32px;font-weight:800}.landing-section-sub{color:var(--color-on-surface-dim);text-align:center;margin-bottom:48px;font-size:16px}.landing-features-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.landing-feature-card{background:var(--color-surface-container);border-radius:var(--radius-lg);border:1px solid #ffffff0a;padding:28px 24px;transition:transform .2s,box-shadow .2s}.landing-feature-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px #0000004d}.landing-feature-icon{color:#fff;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:16px;display:flex}.landing-feature-icon .material-symbols-outlined{font-size:24px}.landing-feature-card h3{font-family:var(--font-family-heading);margin-bottom:8px;font-size:17px;font-weight:700}.landing-feature-card p{color:var(--color-on-surface-dim);font-size:14px;line-height:1.6}.landing-steps{flex-wrap:wrap;justify-content:center;align-items:center;gap:24px;display:flex}.landing-step{background:var(--color-surface-container);border-radius:var(--radius-lg);text-align:center;border:1px solid #ffffff0a;flex:1;min-width:220px;max-width:300px;padding:32px 28px}.landing-step-num{background:var(--color-primary-container);color:#fff;width:48px;height:48px;font-family:var(--font-family-heading);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 16px;font-size:20px;font-weight:800;display:flex}.landing-step h3{font-family:var(--font-family-heading);margin-bottom:8px;font-size:17px;font-weight:700}.landing-step p{color:var(--color-on-surface-dim);font-size:14px;line-height:1.6}.landing-step-arrow{color:var(--color-primary-dim);font-size:28px}.landing-step-arrow .material-symbols-outlined{font-size:32px}.landing-stats-grid{grid-template-columns:repeat(4,1fr);gap:24px;display:grid}.landing-stat{background:var(--color-surface-container);border-radius:var(--radius-lg);text-align:center;border:1px solid #ffffff0a;padding:32px 20px}.landing-stat-num{font-family:var(--font-family-heading);color:var(--color-primary);margin-bottom:4px;font-size:36px;font-weight:800}.landing-stat-label{color:var(--color-on-surface-dim);font-size:14px}.landing-cta{background:linear-gradient(135deg,#3d5afe14,#9ba8ff0f);padding:80px 24px}.landing-footer{background:var(--color-surface);border-top:1px solid #ffffff0a;padding:48px 24px 24px}.landing-footer-grid{grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:32px;display:grid}.landing-footer-bottom{color:var(--color-on-surface-dim);border-top:1px solid #ffffff0a;padding-top:20px;font-size:12px}@media(max-width:1024px){.landing-features-grid,.landing-stats-grid{grid-template-columns:repeat(2,1fr)}.landing-footer-grid{grid-template-columns:1fr;gap:24px}}@media(max-width:640px){.landing-features-grid{grid-template-columns:1fr}.landing-stats-grid{grid-template-columns:repeat(2,1fr)}.landing-steps{flex-direction:column}.landing-step-arrow{transform:rotate(90deg)}.landing-nav-links a:not(.btn){display:none}}@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-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}
