@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.2a48534a.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:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.18a48cbc.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.7a40eb73.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.c995e352.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.76dcb0b2.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:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.7cd81963.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:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.3a6ba036.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:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_fe8b9d92-module__LINzvG__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_fe8b9d92-module__LINzvG__variable{--font-inter:"Inter","Inter Fallback"}
@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/13bf9871fe164e7f-s.f2220059.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:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/cc545e633e20c56d-s.f6f1950f.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/71b036adf157cdcf-s.bd5f4d11.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/89b21bb081cb7469-s.51c18f09.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:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/3fe682a82f50d426-s.23358719.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:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/70bc3e132a0a741e-s.p.15008bfb.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:JetBrains Mono Fallback;src:local(Arial);ascent-override:75.79%;descent-override:22.29%;line-gap-override:0.0%;size-adjust:134.59%}.jetbrains_mono_8dec50e9-module__V6cRDq__className{font-family:JetBrains Mono,JetBrains Mono Fallback;font-style:normal}.jetbrains_mono_8dec50e9-module__V6cRDq__variable{--font-mono:"JetBrains Mono","JetBrains Mono Fallback"}
@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:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--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{.collapse{visibility:collapse}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.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}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.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}.items-center{align-items:center}.justify-between{justify-content:space-between}.border{border-style:var(--tw-border-style);border-width:1px}.break-all{word-break:break-all}.capitalize{text-transform:capitalize}.uppercase{text-transform:uppercase}.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))}}:root{--bg-darkest:#080b12;--bg-darker:#0a0e17;--bg-dark:#0d1321;--bg-base:#111827;--bg-elevated:#1a2332;--bg-surface:#1f2937;--bg-overlay:#111827f2;--border-subtle:#ffffff0a;--border-default:#ffffff14;--border-strong:#ffffff1f;--border-accent:#9fef004d;--text-primary:#f9fafb;--text-secondary:#9ca3af;--text-muted:#6b7280;--text-dim:#4b5563;--htb-green:#9fef00;--htb-green-dim:#9fef0026;--htb-green-glow:#9fef0066;--htb-cyan:#00d4ff;--htb-cyan-dim:#00d4ff26;--htb-purple:#b44aff;--htb-purple-dim:#b44aff26;--htb-red:#ff3e3e;--htb-red-dim:#ff3e3e26;--htb-yellow:#ffaf00;--htb-yellow-dim:#ffaf0026;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080;--glow-green:0 0 20px #9fef004d;--glow-cyan:0 0 20px #00d4ff4d;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background:var(--bg-darker);color:var(--text-primary);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}body:before{content:"";pointer-events:none;z-index:0;background-image:linear-gradient(#9fef0005 1px,#0000 1px),linear-gradient(90deg,#9fef0005 1px,#0000 1px);background-size:50px 50px;position:fixed;inset:0}h1,h2,h3,h4,h5,h6{letter-spacing:-.02em;font-weight:700;line-height:1.2}.text-display{background:linear-gradient(135deg,var(--text-primary)0%,var(--htb-green)100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:3rem;font-weight:800}.text-headline{font-size:2rem;font-weight:700}.text-title{font-size:1.25rem;font-weight:600}.text-body{color:var(--text-secondary);font-size:1rem}.text-caption{color:var(--text-muted);font-size:.875rem}.text-overline{letter-spacing:.1em;text-transform:uppercase;color:var(--htb-green);font-size:.75rem;font-weight:600}.page-container{z-index:1;min-height:100vh;position:relative}.content-wrapper{max-width:1400px;padding:var(--space-lg)var(--space-xl);margin:0 auto}.section-header{margin-bottom:var(--space-xl)}.section-header h1{margin-bottom:var(--space-sm)}.navbar{z-index:100;padding:var(--space-md)var(--space-xl);background:var(--bg-overlay);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-default);justify-content:space-between;align-items:center;gap:var(--space-md);min-height:60px;display:flex;position:sticky;top:0}.navbar-brand{align-items:center;gap:var(--space-md);flex-shrink:0;display:flex}.navbar-logo{background:linear-gradient(135deg,var(--htb-green)0%,#6fe000 100%);border-radius:var(--radius-sm);width:32px;height:32px;color:var(--bg-darkest);justify-content:center;align-items:center;font-size:1.25rem;font-weight:800;display:flex}.navbar-title{letter-spacing:.05em;text-transform:uppercase;color:var(--text-primary);font-size:.875rem;font-weight:700}.navbar-nav{align-items:center;gap:var(--space-sm);scrollbar-width:none;-ms-overflow-style:none;flex:1;min-width:0;display:flex;overflow-x:auto}.navbar-nav::-webkit-scrollbar{display:none}.nav-link{padding:var(--space-sm)var(--space-md);color:var(--text-secondary);border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .2s}.nav-link.active{color:var(--text-primary);background:var(--bg-surface)}.nav-user{align-items:center;gap:var(--space-md);padding-left:var(--space-md);border-left:1px solid var(--border-default);flex-shrink:0;display:flex}.nav-avatar{background:var(--bg-surface);border:2px solid var(--border-strong);border-radius:var(--radius-full);width:32px;height:32px;color:var(--text-secondary);justify-content:center;align-items:center;font-size:.75rem;font-weight:600;display:flex}.navbar-user{align-items:center;gap:var(--space-md);padding-left:var(--space-md);border-left:1px solid var(--border-default);display:flex}.navbar-stats{align-items:center;gap:var(--space-sm);margin-right:var(--space-sm);display:flex}.xp-badge{border-radius:var(--radius-full);color:var(--htb-green);background:#9fef0026;border:1px solid #9fef0066;padding:4px 10px;font-size:.75rem;font-weight:600}.streak-badge{border-radius:var(--radius-full);color:var(--htb-yellow);background:#ffc10726;border:1px solid #ffc10766;padding:4px 10px;font-size:.75rem;font-weight:600}.avatar{background:linear-gradient(135deg,var(--htb-green)0%,var(--htb-cyan)100%);border-radius:var(--radius-full);width:32px;height:32px;color:var(--bg-darkest);justify-content:center;align-items:center;font-size:.875rem;font-weight:700;display:flex}.username{color:var(--text-primary);font-size:.875rem;font-weight:500}.card{background:var(--bg-base);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-lg);position:relative;overflow:hidden}.card:before{content:"";background:linear-gradient(90deg,transparent,var(--border-strong),transparent);height:1px;position:absolute;top:0;left:0;right:0}.card-elevated{background:var(--bg-elevated);box-shadow:var(--shadow-md)}.card-glow{box-shadow:var(--glow-green);border-color:var(--border-accent)}.stats-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.stat-card{background:linear-gradient(135deg,var(--bg-base)0%,var(--bg-elevated)100%);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-lg);position:relative;overflow:hidden}.stat-card:after{content:"";background:radial-gradient(circle at top right,var(--htb-green-dim),transparent 70%);pointer-events:none;width:100px;height:100px;position:absolute;top:0;right:0}.stat-card.cyan:after{background:radial-gradient(circle at top right,var(--htb-cyan-dim),transparent 70%)}.stat-card.purple:after{background:radial-gradient(circle at top right,var(--htb-purple-dim),transparent 70%)}.stat-card.yellow:after{background:radial-gradient(circle at top right,var(--htb-yellow-dim),transparent 70%)}.stat-icon{background:var(--htb-green-dim);border-radius:var(--radius-md);width:40px;height:40px;margin-bottom:var(--space-md);justify-content:center;align-items:center;font-size:1.25rem;display:flex}.stat-icon.cyan{background:var(--htb-cyan-dim);color:var(--htb-cyan)}.stat-icon.purple{background:var(--htb-purple-dim);color:var(--htb-purple)}.stat-icon.yellow{background:var(--htb-yellow-dim);color:var(--htb-yellow)}.stat-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:var(--space-xs);font-size:.75rem;font-weight:500}.stat-value.accent{color:var(--htb-green);text-shadow:0 0 20px var(--htb-green-glow)}.form-group{margin-bottom:var(--space-lg)}.form-label{color:var(--text-secondary);margin-bottom:var(--space-sm);font-size:.875rem;font-weight:500;display:block}.form-input{width:100%;color:var(--text-primary);background:var(--bg-dark);border:1px solid var(--border-default);border-radius:var(--radius-md);outline:none;padding:14px 16px;font-size:.9375rem;transition:all .2s}.form-input::placeholder{color:var(--text-dim)}.form-input:focus{border-color:var(--htb-green);box-shadow:0 0 0 3px var(--htb-green-dim)}.form-checkbox{align-items:center;gap:var(--space-sm);padding:var(--space-sm)0;display:flex}.form-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--htb-green);cursor:pointer}.form-checkbox label{color:var(--text-secondary);cursor:pointer;font-size:.875rem}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);cursor:pointer;border:none;padding:12px 24px;font-size:.875rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.btn-primary{background:linear-gradient(135deg,var(--htb-green)0%,#7cd000 100%);color:var(--bg-darkest);box-shadow:0 4px 12px #9fef004d}.btn-secondary{background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-strong)}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border-default);background:0 0}.btn-danger{background:var(--htb-red-dim);color:var(--htb-red);border:1px solid #ff3e3e4d}.btn-sm{padding:8px 16px;font-size:.8125rem}.btn-lg{padding:16px 32px;font-size:1rem}.btn-block{width:100%}.user-list{gap:var(--space-md);flex-direction:column;display:flex}.user-card{align-items:center;gap:var(--space-lg);padding:var(--space-lg);background:var(--bg-base);border:1px solid var(--border-default);border-radius:var(--radius-lg);display:flex}.user-avatar{background:linear-gradient(135deg,var(--htb-green-dim)0%,var(--htb-cyan-dim)100%);border-radius:var(--radius-full);width:48px;height:48px;color:var(--htb-green);flex-shrink:0;justify-content:center;align-items:center;font-size:1.25rem;font-weight:700;display:flex}.user-info{flex:1;min-width:0}.user-name{color:var(--text-primary);margin-bottom:2px;font-size:1rem;font-weight:600}.user-meta{color:var(--text-muted);align-items:center;gap:var(--space-sm);font-size:.8125rem;display:flex}.user-actions{gap:var(--space-sm);display:flex}.badge{text-transform:uppercase;letter-spacing:.03em;border-radius:var(--radius-full);background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border-default);align-items:center;gap:4px;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-green{background:var(--htb-green-dim);color:var(--htb-green);border-color:#9fef004d}.badge-cyan{background:var(--htb-cyan-dim);color:var(--htb-cyan);border-color:#00d4ff4d}.badge-purple{background:var(--htb-purple-dim);color:var(--htb-purple);border-color:#b44aff4d}.badge-yellow{background:var(--htb-yellow-dim);color:var(--htb-yellow);border-color:#ffaf004d}.badge-red{background:var(--htb-red-dim);color:var(--htb-red);border-color:#ff3e3e4d}.role-admin{background:var(--htb-purple-dim);color:var(--htb-purple);border-color:#b44aff4d}.role-student{background:var(--htb-cyan-dim);color:var(--htb-cyan);border-color:#00d4ff4d}.module-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}.module-card{background:var(--bg-base);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-lg);color:inherit;text-decoration:none;display:block;position:relative;overflow:hidden}.module-card:before{content:"";background:linear-gradient(90deg,var(--htb-green),var(--htb-cyan));height:3px;position:absolute;top:0;left:0;right:0}.module-title{color:var(--text-primary);margin-bottom:var(--space-sm);font-size:1.125rem;font-weight:600}.module-description{color:var(--text-muted);margin-bottom:var(--space-lg);font-size:.875rem;line-height:1.5}.module-meta{gap:var(--space-sm);flex-wrap:wrap;display:flex}.module-progress{margin-top:var(--space-lg)}.progress-bar{background:var(--bg-surface);border-radius:var(--radius-full);height:4px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,var(--htb-green),var(--htb-cyan));border-radius:var(--radius-full);height:100%;transition:width .3s}.progress-text{margin-top:var(--space-sm);color:var(--text-muted);justify-content:space-between;font-size:.75rem;display:flex}.course-layout{height:calc(100vh - 65px);display:flex}.course-sidebar{background:var(--bg-dark);border-right:1px solid var(--border-default);width:300px;min-width:300px;overflow-y:auto}.sidebar-header{padding:var(--space-lg);border-bottom:1px solid var(--border-default)}.sidebar-title{margin-bottom:4px;font-size:1rem;font-weight:600}.sidebar-subtitle{color:var(--text-muted);font-size:.75rem}.sidebar-nav{padding:var(--space-sm)0}.sidebar-item{align-items:center;gap:var(--space-md);padding:var(--space-md)var(--space-lg);color:var(--text-secondary);text-align:left;cursor:pointer;background:0 0;border:none;border-left:3px solid #0000;width:100%;font-size:.875rem;text-decoration:none;display:flex}.sidebar-item.active{background:var(--bg-base);color:var(--text-primary);border-left-color:var(--htb-green)}.sidebar-item.complete{color:var(--htb-green)}.sidebar-status{background:var(--border-strong);border-radius:50%;flex-shrink:0;width:8px;height:8px}.sidebar-status.complete{background:var(--htb-green)}.course-content{padding:var(--space-xl);background:var(--bg-darker);flex:1;overflow-y:auto}.terminal-container{background:var(--bg-darkest);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden}.terminal-header{align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--bg-dark);border-bottom:1px solid var(--border-default);display:flex}.terminal-dot{border-radius:50%;width:12px;height:12px}.terminal-dot.red{background:#ff5f56}.terminal-dot.yellow{background:#ffbd2e}.terminal-dot.green{background:#27c93f}.terminal-title{text-align:center;color:var(--text-muted);flex:1;font-size:.75rem}.terminal-body{padding:var(--space-md);min-height:400px}.auth-page{min-height:100vh;padding:var(--space-xl);z-index:1;justify-content:center;align-items:center;display:flex;position:relative}.auth-card{background:var(--bg-base);border:1px solid var(--border-default);border-radius:var(--radius-xl);width:100%;max-width:420px;padding:var(--space-2xl);box-shadow:var(--shadow-lg);position:relative}.auth-card:before{content:"";background:linear-gradient(90deg,var(--htb-green),var(--htb-cyan));border-radius:var(--radius-full);width:100px;height:3px;position:absolute;top:-1px;left:50%;transform:translate(-50%)}.auth-header{align-items:center;gap:var(--space-md);margin-bottom:var(--space-xl);display:flex}.auth-logo{background:linear-gradient(135deg,var(--htb-green)0%,#6fe000 100%);border-radius:var(--radius-md);width:48px;height:48px;color:var(--bg-darkest);justify-content:center;align-items:center;font-size:1.5rem;font-weight:800;display:flex}.auth-titles h1{margin-bottom:2px;font-size:1.25rem;font-weight:700}.auth-divider{margin:var(--space-xl)0;border:none;border-top:1px solid var(--border-default)}.auth-footer{text-align:center;color:var(--text-muted);font-size:.875rem}.auth-footer a,.auth-footer button{color:var(--htb-cyan);cursor:pointer;font-size:inherit;background:0 0;border:none;text-decoration:none}.empty-state{text-align:center;padding:var(--space-2xl);color:var(--text-muted)}.empty-state-icon{width:64px;height:64px;margin:0 auto var(--space-lg);background:var(--bg-surface);border-radius:var(--radius-lg);color:var(--text-dim);justify-content:center;align-items:center;font-size:1.5rem;display:flex}.empty-state-title{color:var(--text-secondary);margin-bottom:var(--space-sm);font-size:1rem;font-weight:600}.empty-state-text{font-size:.875rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.flex-1{flex:1}.text-center{text-align:center}.w-full{width:100%}.mt-lg{margin-top:var(--space-lg)}.mb-lg{margin-bottom:var(--space-lg)}.dashboard-banner{background:linear-gradient(135deg,var(--bg-base)0%,var(--bg-elevated)100%);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--space-xl);margin-bottom:var(--space-xl);justify-content:space-between;align-items:center;display:flex;position:relative;overflow:hidden}.dashboard-banner:before{content:"";background:linear-gradient(90deg,var(--htb-green),var(--htb-cyan),var(--htb-purple));height:3px;position:absolute;top:0;left:0;right:0}.dashboard-banner:after{content:"";background:radial-gradient(circle,var(--htb-green-dim),transparent 70%);pointer-events:none;width:300px;height:300px;position:absolute;top:-50%;right:-10%}.banner-content{flex:1}.banner-progress{align-items:center;gap:var(--space-sm);flex-direction:column;display:flex}.banner-progress-circle{width:80px;height:80px;position:relative}.banner-progress-circle svg{width:100%;height:100%;transform:rotate(-90deg)}.progress-percent{color:var(--htb-green);font-size:1.25rem;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.stats-grid{gap:var(--space-md);margin-bottom:var(--space-xl);grid-template-columns:repeat(4,1fr);display:grid}@media (max-width:1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.stats-grid{grid-template-columns:1fr}}.stat-card{align-items:center;gap:var(--space-md);background:var(--bg-base);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex}.stat-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.25rem;display:flex}.stat-content{flex-direction:column;display:flex}.stat-value{color:var(--text-primary);font-size:1.5rem;font-weight:700;line-height:1.2}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.module-card.complete{border-color:#9fef004d}.module-card.complete:before{background:var(--htb-green)}.module-complete-badge{top:var(--space-md);right:var(--space-md);background:var(--htb-green-dim);color:var(--htb-green);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;padding:4px 8px;font-size:.625rem;font-weight:600;position:absolute}.hint-panel{background:var(--bg-base);border:1px solid var(--border-accent);border-radius:var(--radius-lg);margin-bottom:var(--space-lg);overflow:hidden}.hint-panel-header{padding:var(--space-md)var(--space-lg);background:var(--htb-green-dim);border-bottom:1px solid var(--border-accent);cursor:pointer;justify-content:space-between;align-items:center;display:flex}.hint-panel-header:hover{background:#9fef0033}.hint-panel-title{align-items:center;gap:var(--space-sm);color:var(--htb-green);font-size:.875rem;font-weight:600;display:flex}.hint-panel-toggle{color:var(--htb-green);cursor:pointer;background:0 0;border:none;font-size:.75rem}.hint-panel-content{padding:var(--space-lg)}.hint-step{align-items:flex-start;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-sm);background:var(--bg-surface);border:1px solid var(--border-default);display:flex}.hint-step.active{background:var(--htb-cyan-dim);border-color:#00d4ff4d}.hint-step.completed{background:var(--htb-green-dim);border-color:#9fef004d}.hint-step-number{background:var(--bg-elevated);border:2px solid var(--border-strong);width:24px;height:24px;color:var(--text-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:600;display:flex}.hint-step.active .hint-step-number{background:var(--htb-cyan);border-color:var(--htb-cyan);color:var(--bg-darkest)}.hint-step.completed .hint-step-number{background:var(--htb-green);border-color:var(--htb-green);color:var(--bg-darkest)}.hint-step-content{flex:1;min-width:0}.hint-step-command{color:var(--htb-cyan);background:var(--bg-dark);border-radius:var(--radius-sm);margin-bottom:var(--space-xs);padding:6px 10px;font-family:JetBrains Mono,monospace;font-size:.875rem;display:inline-block}.hint-step.completed .hint-step-command{color:var(--htb-green)}.hint-step-hint{color:var(--text-secondary);font-size:.8125rem;line-height:1.4}.hint-copy-btn{background:var(--bg-elevated);border:1px solid var(--border-default);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;padding:6px 12px;font-size:.75rem;transition:all .2s}.hint-copy-btn:hover{background:var(--htb-cyan-dim);color:var(--htb-cyan);border-color:#00d4ff4d}@media (max-width:1024px){.content-wrapper{padding:var(--space-lg)}.stats-grid{grid-template-columns:repeat(2,1fr)}.module-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.course-sidebar{width:260px;min-width:260px}}@media (max-width:768px){.navbar{padding:var(--space-sm)var(--space-md);gap:var(--space-sm);flex-wrap:nowrap}.navbar-brand{gap:var(--space-sm);flex-shrink:0}.navbar-logo{width:28px;height:28px;font-size:1rem}.navbar-title{font-size:.75rem;display:none}.navbar-nav{-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;flex-wrap:nowrap;gap:4px;overflow-x:auto}.navbar-nav::-webkit-scrollbar{display:none}.nav-link{white-space:nowrap;flex-shrink:0;padding:6px 10px;font-size:.75rem}.nav-user{padding-left:var(--space-sm);gap:var(--space-sm);border-left:none;flex-shrink:0}.nav-avatar{width:28px;height:28px;font-size:.6875rem}.text-caption{display:none}.btn-ghost.btn-sm{padding:6px 10px;font-size:.6875rem}.navbar-user{padding-left:var(--space-sm);border-left:none;gap:8px}.navbar-stats{display:none}.avatar{width:28px;height:28px;font-size:.75rem}.username,.xp-badge,.streak-badge{display:none}.content-wrapper{padding:var(--space-md)}.stats-grid{gap:var(--space-md);grid-template-columns:1fr 1fr}.stat-card{padding:var(--space-md)}.stat-value{font-size:1.75rem}.stat-icon{width:32px;height:32px;margin-bottom:var(--space-sm);font-size:1rem}.module-grid{gap:var(--space-md);grid-template-columns:1fr}.module-card{padding:var(--space-md)}.module-title{font-size:1rem}.module-description{margin-bottom:var(--space-md);font-size:.8125rem}.course-layout{flex-direction:column;height:auto;min-height:calc(100vh - 65px)}.course-sidebar{border-right:none;border-bottom:1px solid var(--border-default);width:100%;min-width:100%;max-height:none;overflow-y:visible}.sidebar-header{padding:var(--space-md)}.sidebar-nav{-webkit-overflow-scrolling:touch;padding:var(--space-sm)var(--space-md);gap:var(--space-sm);scrollbar-width:none;-ms-overflow-style:none;display:flex;overflow-x:auto}.sidebar-nav::-webkit-scrollbar{display:none}.sidebar-item{padding:var(--space-sm)var(--space-md);border-radius:var(--radius-md);background:var(--bg-surface);white-space:nowrap;border-left:none;flex-shrink:0}.sidebar-item.active{background:var(--htb-green-dim);border:1px solid #9fef004d}.course-content{padding:var(--space-md)}.terminal-container{border-radius:var(--radius-md)}.terminal-header{padding:var(--space-sm)}.user-card{align-items:flex-start;gap:var(--space-md);flex-direction:column}.user-actions{justify-content:flex-end;width:100%}.text-display{font-size:2rem}.text-headline{font-size:1.5rem}.text-title{font-size:1.125rem}.form-input{padding:12px 14px;font-size:16px}.btn{padding:10px 20px;font-size:.8125rem}.btn-lg{padding:12px 24px;font-size:.875rem}.card{padding:var(--space-md);border-radius:var(--radius-md)}.hint-panel{border-radius:var(--radius-lg)var(--radius-lg)0 0;border-top:1px solid var(--border-default);width:100%;max-height:50vh;position:fixed;inset:auto 0 0}}@media (max-width:480px){.navbar{padding:8px 12px}.stats-grid{grid-template-columns:1fr}.stat-card{padding:var(--space-sm)}.stat-value{font-size:1.5rem}.user-card{padding:var(--space-md)}.content-wrapper,.module-card{padding:var(--space-sm)}.btn-block{padding:12px 16px}.auth-page{padding:var(--space-md)}.auth-card{padding:var(--space-lg);border-radius:var(--radius-lg)}.auth-logo{width:40px;height:40px;font-size:1.25rem}.auth-titles h1{font-size:1.125rem}}@media (min-width:1400px){.content-wrapper{max-width:1600px}.module-grid{grid-template-columns:repeat(auto-fill,minmax(380px,1fr))}}@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}
