@import url("https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap");:root{--bg-primary:#0b0f19;--bg-secondary:#131a2c;--bg-tertiary:#1b253f;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--accent-cyan:#06b6d4;--accent-blue:#3b82f6;--accent-emerald:#10b981;--accent-orange:#f97316;--accent-red:#ef4444;--border-color:#1e293b;--border-hover:#334155;--glass-bg:rgba(19,26,44,.7);--glass-border:hsla(0,0%,100%,.05);--sidebar-width:320px;--header-height:70px;--font-sans:"Outfit",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace;--transition-smooth:all 0.3s cubic-bezier(0.4,0,0.2,1);--shadow-sm:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.3),0 4px 6px -2px rgba(0,0,0,.15)}*{box-sizing:border-box;margin:0;padding:0}body,html{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);font-size:16px;line-height:1.6;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--border-color) var(--bg-primary)}a{color:var(--accent-cyan);text-decoration:none;transition:var(--transition-smooth)}a:hover{color:var(--text-primary)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}.app-container{min-height:100vh;position:relative}.sidebar{background-color:var(--bg-secondary);border-right:1px solid var(--border-color);height:100vh;position:fixed;top:0;left:0;width:var(--sidebar-width);overflow-y:auto;padding:2rem 1.5rem;gap:2rem;z-index:100}.logo-section,.sidebar{display:flex;flex-direction:column}.logo-section{gap:.5rem}.logo-section h1{font-size:1.5rem;font-weight:700;letter-spacing:-.025em;background:linear-gradient(135deg,var(--text-primary) 30%,var(--accent-cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.logo-section span{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;font-weight:600}.nav-menu{gap:1.5rem}.nav-menu,.week-group{display:flex;flex-direction:column}.week-group{gap:.25rem}.week-header{font-size:.95rem;font-weight:600;color:var(--text-primary);padding:.5rem;border-radius:6px;cursor:default;display:flex;align-items:center}.topic-list{list-style:none;padding-left:.75rem;border-left:1px solid var(--border-color);margin-left:.5rem;display:flex;flex-direction:column;gap:.125rem}.topic-item a{display:block;font-size:.875rem;color:var(--text-secondary);padding:.375rem .5rem;border-radius:6px;transition:var(--transition-smooth)}.topic-item a:hover{background-color:var(--bg-tertiary);color:var(--accent-cyan)}.topic-item.active a{background-color:rgba(6,182,212,.1);color:var(--accent-cyan);font-weight:500;border-left:2px solid var(--accent-cyan);border-top-left-radius:0;border-bottom-left-radius:0}.main-viewport{margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column}.top-header{background-color:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--glass-border);height:var(--header-height);position:-webkit-sticky;position:sticky;top:0;width:100%;display:flex;align-items:center;justify-content:space-between;padding:0 3rem;z-index:90}.top-header h2{font-size:1.1rem}.home-btn,.top-header h2{font-weight:500;color:var(--text-primary)}.home-btn{background:var(--bg-tertiary);padding:.5rem 1rem;border-radius:8px;font-size:.9rem;border:1px solid var(--border-color);transition:var(--transition-smooth)}.home-btn:hover{background:var(--border-hover);border-color:var(--text-muted)}.content-pane{padding:3rem;max-width:1200px;width:100%;margin:0 auto;flex:1 1}.dashboard-container{display:flex;flex-direction:column;gap:2rem}.dashboard-hero{margin-bottom:1.5rem;display:flex;flex-direction:column;gap:1rem}.badge{background:linear-gradient(135deg,rgba(6,182,212,.15),rgba(59,130,246,.15));color:#22d3ee;padding:.35rem 1rem;border-radius:100px;font-size:.75rem;font-weight:600;align-self:flex-start;letter-spacing:.08em;text-transform:uppercase;border:1px solid rgba(6,182,212,.3);box-shadow:0 0 15px rgba(6,182,212,.1)}.dashboard-hero h2{font-size:2.75rem;font-weight:800;letter-spacing:-.03em;line-height:1.25;background:linear-gradient(135deg,var(--text-primary) 30%,#a5b4fc 70%,var(--accent-cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.dashboard-hero p{color:var(--text-secondary);font-size:1.1rem;max-width:850px;line-height:1.7}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:1.25rem;gap:1.25rem;margin-bottom:1rem}.stat-item{background:linear-gradient(135deg,rgba(19,26,44,.6),rgba(27,37,63,.3));border:1px solid var(--border-color);border-radius:16px;padding:1.5rem 1.25rem;text-align:center;display:flex;flex-direction:column;gap:.35rem;transition:var(--transition-smooth)}.stat-item:hover{border-color:var(--border-hover);transform:translateY(-2px)}.stat-val{font-size:2rem;font-weight:800;background:linear-gradient(135deg,var(--text-primary),var(--accent-cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.stat-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:600}.outcomes-section{margin:1rem 0}.outcomes-section h3{font-size:1.4rem;font-weight:700;margin-bottom:1.5rem;letter-spacing:-.02em;background:linear-gradient(135deg,var(--text-primary),var(--accent-cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;display:inline-block}.outcomes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:1.25rem;gap:1.25rem}.outcome-card{background:rgba(19,26,44,.4);border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;display:flex;gap:1.25rem;align-items:flex-start;transition:var(--transition-smooth)}.outcome-card:hover{border-color:var(--border-hover);background:rgba(27,37,63,.5);transform:translateY(-3px);box-shadow:var(--shadow-sm)}.outcome-icon{font-size:1.5rem;background:rgba(6,182,212,.1);padding:.5rem;border-radius:12px;line-height:1;display:flex;align-items:center;justify-content:center;color:var(--accent-cyan);border:1px solid rgba(6,182,212,.15)}.outcome-content h4{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.35rem}.outcome-content p{font-size:.875rem;color:var(--text-secondary);line-height:1.5}.section-divider{margin-top:1.5rem;border-bottom:1px solid var(--border-color);padding-bottom:.75rem}.section-divider h3{font-size:1.4rem;font-weight:700;letter-spacing:-.02em;background:linear-gradient(135deg,var(--text-primary),var(--accent-cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;display:inline-block}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));grid-gap:1.75rem;gap:1.75rem;margin-top:1rem}.card{background:linear-gradient(135deg,var(--bg-secondary) 0,rgba(27,37,63,.4) 100%);border:1px solid var(--border-color);border-radius:20px;padding:1.75rem;display:flex;flex-direction:column;gap:1.25rem;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative;overflow:hidden}.card:hover{transform:translateY(-6px);border-color:hsla(0,0%,100%,.1);box-shadow:0 20px 25px -5px rgba(0,0,0,.3),0 10px 10px -5px rgba(0,0,0,.2)}.card-header{display:flex;justify-content:space-between;align-items:center}.module-badge{font-size:.75rem;color:var(--accent-blue);letter-spacing:.08em}.difficulty-badge,.module-badge{font-weight:700;text-transform:uppercase}.difficulty-badge{font-size:.65rem;padding:.2rem .6rem;border-radius:6px;letter-spacing:.05em}.difficulty-badge.introductory{background:rgba(16,185,129,.1);color:#34d399;border:1px solid rgba(16,185,129,.2)}.difficulty-badge.intermediate{background:rgba(59,130,246,.1);color:#60a5fa;border:1px solid rgba(59,130,246,.2)}.difficulty-badge.advanced{background:rgba(168,85,247,.1);color:#c084fc;border:1px solid rgba(168,85,247,.2)}.difficulty-badge.expert{background:rgba(239,68,68,.1);color:#f87171;border:1px solid rgba(239,68,68,.2)}.card-main{display:flex;flex-direction:column;gap:.75rem}.card-title-row{display:flex;align-items:center;gap:.75rem}.card-icon{font-size:1.5rem;line-height:1}.card h3{font-size:1.25rem;font-weight:700;color:var(--text-primary);line-height:1.3}.theme-tag{font-size:.75rem;color:var(--text-secondary);font-weight:600;background:hsla(0,0%,100%,.03);padding:.25rem .6rem;border-radius:8px;border:1px solid var(--border-color);align-self:flex-start;letter-spacing:.02em}.topics-preview{font-size:.8rem;color:var(--text-muted);line-height:1.5;background:rgba(0,0,0,.15);padding:.75rem;border-radius:10px;border:1px solid hsla(0,0%,100%,.02)}.card-meta-info,.topics-preview strong{color:var(--text-secondary)}.card-meta-info{display:flex;gap:1.25rem;font-size:.75rem;margin-top:auto;border-top:1px solid hsla(0,0%,100%,.04);padding-top:1rem}.card-footer,.meta-item{display:flex;align-items:center;gap:.35rem}.card-footer{font-size:.85rem;font-weight:700;color:var(--accent-cyan);transition:gap .2s ease}.card:hover .card-footer{gap:.6rem;color:var(--text-primary)}.markdown-body{font-size:1.05rem;color:#e2e8f0;max-width:800px;margin:0 auto}.markdown-body h1{font-size:2.2rem;font-weight:700;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color);letter-spacing:-.03em}.markdown-body h2{font-size:1.5rem;margin-top:2rem;margin-bottom:1rem;padding-bottom:.25rem;border-bottom:1px solid var(--border-color)}.markdown-body h2,.markdown-body h3{font-weight:600;color:var(--text-primary)}.markdown-body h3{font-size:1.2rem;margin-top:1.5rem;margin-bottom:.75rem}.markdown-body p{margin-bottom:1.2rem;line-height:1.7}.markdown-body ol,.markdown-body ul{margin-bottom:1.2rem;padding-left:1.5rem}.markdown-body li{margin-bottom:.4rem}.markdown-body pre{background-color:var(--bg-secondary)!important;border:1px solid var(--border-color);border-radius:8px;padding:1.2rem;overflow-x:auto;margin-bottom:1.5rem;font-family:var(--font-mono);font-size:.9rem;line-height:1.5}.markdown-body code{font-family:var(--font-mono);background-color:hsla(0,0%,100%,.06);padding:.15rem .35rem;border-radius:4px;font-size:.9em;color:#ec4899}.markdown-body pre code{background-color:transparent;padding:0;border-radius:0;font-size:inherit;color:#cbd5e1}.markdown-body table{width:100%;border-collapse:collapse;margin-bottom:1.5rem;font-size:.95rem}.markdown-body td,.markdown-body th{padding:.75rem 1rem;border:1px solid var(--border-color);text-align:left}.markdown-body th{background-color:var(--bg-secondary);font-weight:600;color:var(--text-primary)}.markdown-body tr:nth-child(2n){background-color:hsla(0,0%,100%,.02)}.markdown-body blockquote{padding:1rem 1.5rem;border-left:4px solid var(--border-hover);background-color:var(--bg-secondary);border-radius:0 8px 8px 0;margin-bottom:1.5rem;color:var(--text-secondary)}.markdown-body blockquote p:last-child{margin-bottom:0}.markdown-body blockquote:has(p:first-child:contains("[!NOTE]")),.markdown-body blockquote:has(strong:first-child:contains("[!NOTE]")){border-left-color:var(--accent-blue);background-color:rgba(59,130,246,.05)}.markdown-body blockquote:has(p:first-child:contains("[!TIP]")),.markdown-body blockquote:has(strong:first-child:contains("[!TIP]")){border-left-color:var(--accent-emerald);background-color:rgba(16,185,129,.05)}.markdown-body blockquote:has(p:first-child:contains("[!IMPORTANT]")),.markdown-body blockquote:has(strong:first-child:contains("[!IMPORTANT]")){border-left-color:var(--accent-cyan);background-color:rgba(6,182,212,.05)}.markdown-body blockquote:has(p:first-child:contains("[!WARNING]")),.markdown-body blockquote:has(strong:first-child:contains("[!WARNING]")){border-left-color:var(--accent-orange);background-color:rgba(249,115,22,.05)}.markdown-body blockquote:has(p:first-child:contains("[!CAUTION]")),.markdown-body blockquote:has(strong:first-child:contains("[!CAUTION]")){border-left-color:var(--accent-red);background-color:rgba(239,68,68,.05)}@media (max-width:900px){.app-container{grid-template-columns:1fr}.sidebar{display:none}.main-viewport{margin-left:0}.top-header{padding:0 1.5rem}.content-pane{padding:1.5rem}.dashboard-hero h2{font-size:2rem}}.login-page-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg-primary);background-image:radial-gradient(at 0 0,rgba(6,182,212,.05) 0,transparent 50%),radial-gradient(at 100% 100%,rgba(59,130,246,.05) 0,transparent 50%);position:relative;overflow:hidden;padding:2rem}.ambient-glow{position:absolute;border-radius:50%;filter:blur(120px);z-index:1;opacity:.15}.glow-blue{width:400px;height:400px;background:var(--accent-blue);top:-100px;right:-100px}.glow-cyan{width:500px;height:500px;background:var(--accent-cyan);bottom:-150px;left:-150px}.login-wrapper{display:grid;grid-template-columns:1.1fr 1fr;grid-gap:4rem;gap:4rem;max-width:1000px;width:100%;align-items:center;z-index:10}.login-branding{display:flex;flex-direction:column;gap:1rem}.branding-badge{background:rgba(6,182,212,.1);color:var(--accent-cyan);padding:.35rem 1rem;border-radius:100px;font-size:.75rem;font-weight:600;letter-spacing:.1em;align-self:flex-start;border:1px solid rgba(6,182,212,.2)}.login-branding h1{font-size:4.5rem;font-weight:800;line-height:1;background:linear-gradient(135deg,var(--text-primary) 20%,#a5b4fc 60%,var(--accent-cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.04em}.branding-desc{font-size:1.35rem;color:var(--text-secondary);line-height:1.5;font-weight:400}.branding-meta{display:flex;gap:.75rem;margin-top:1rem}.meta-badge{background:hsla(0,0%,100%,.03);border:1px solid var(--border-color);padding:.4rem .8rem;border-radius:10px;font-size:.8rem;color:var(--text-secondary);font-weight:500}.login-card{background:rgba(19,26,44,.55);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid hsla(0,0%,100%,.06);border-radius:24px;padding:2.5rem;box-shadow:var(--shadow-lg),0 0 40px rgba(0,0,0,.3)}.login-form{display:flex;flex-direction:column;gap:1.5rem}.login-form h2{font-size:1.6rem;font-weight:700;letter-spacing:-.02em;background:linear-gradient(135deg,var(--text-primary),#cbd5e1);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.login-subtitle{font-size:.9rem;color:var(--text-secondary);line-height:1.5;margin-top:-.75rem}.login-error-alert{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);padding:.75rem 1rem;border-radius:12px;display:flex;align-items:center;gap:.75rem;animation:shake .3s ease-in-out}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}.error-icon{font-size:1.1rem}.error-text{font-size:.85rem;color:#fca5a5;font-weight:500}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-group label{font-size:.85rem;font-weight:600;color:var(--text-secondary);letter-spacing:.02em}.input-group input{background:rgba(11,15,25,.6);border:1px solid var(--border-color);border-radius:12px;padding:.85rem 1rem;font-family:var(--font-sans);font-size:.95rem;color:var(--text-primary);transition:var(--transition-smooth)}.input-group input:focus{outline:none;border-color:var(--accent-cyan);box-shadow:0 0 0 2px rgba(6,182,212,.15);background:rgba(11,15,25,.8)}.login-submit-btn{background:linear-gradient(135deg,var(--accent-cyan) 0,var(--accent-blue) 100%);color:#fff;border:none;border-radius:12px;padding:1rem;font-size:.95rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:var(--transition-smooth);box-shadow:0 4px 12px rgba(6,182,212,.2)}.login-submit-btn:hover:not(:disabled){opacity:.95;transform:translateY(-1px);box-shadow:0 6px 16px rgba(6,182,212,.35)}.login-submit-btn:active:not(:disabled){transform:translateY(0)}.login-submit-btn:disabled{opacity:.6;cursor:not-allowed}.spinner-loader{display:flex;align-items:center;gap:.5rem}.credentials-callout{background:hsla(0,0%,100%,.02);border:1px solid var(--border-color);border-radius:14px;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.callout-header{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-primary)}.callout-body{font-size:.8rem;color:var(--text-secondary);display:flex;flex-direction:column;gap:.25rem}.credential-code{font-family:var(--font-mono);background:hsla(0,0%,100%,.05)!important;color:var(--accent-cyan)!important;padding:.1rem .3rem!important;border-radius:4px}.loading-fallback{color:var(--text-secondary);text-align:center;padding:2rem 0;font-size:.95rem}.sidebar-footer{margin-top:auto;border-top:1px solid var(--border-color);padding-top:1.5rem}.user-profile{gap:.75rem;padding:.25rem}.avatar,.user-profile{display:flex;align-items:center}.avatar{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));color:#fff;justify-content:center;font-weight:700;font-size:1.1rem;box-shadow:0 4px 10px rgba(6,182,212,.25)}.user-info{display:flex;flex-direction:column}.username{font-size:.9rem;font-weight:600;color:var(--text-primary)}.role{font-size:.75rem;color:var(--text-muted)}.header-actions{display:flex;align-items:center;gap:.75rem}.logout-btn{background:transparent;color:var(--text-secondary);padding:.5rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500;border:1px solid var(--border-color);transition:var(--transition-smooth)}.logout-btn:hover{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.3);color:#fca5a5}@media (max-width:900px){.login-wrapper{grid-template-columns:1fr;gap:2rem;max-width:450px}.login-branding{text-align:center;align-items:center}.login-branding h1{font-size:3.5rem}}.card-actions-wrapper{position:absolute;top:1rem;right:1rem;z-index:20;display:flex;gap:.5rem}.visibility-toggle-btn{background:rgba(19,26,44,.6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border-color);color:var(--text-secondary);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition-smooth);outline:none}.visibility-toggle-btn:hover{transform:scale(1.1);color:var(--text-primary)}.visibility-toggle-btn.visible-state:hover{border-color:var(--accent-emerald);box-shadow:0 0 10px rgba(16,185,129,.3);color:var(--accent-emerald)}.visibility-toggle-btn.hidden-state{border-color:rgba(239,68,68,.4);color:var(--accent-red);background:rgba(239,68,68,.05)}.visibility-toggle-btn.hidden-state:hover{border-color:var(--accent-red);box-shadow:0 0 10px rgba(239,68,68,.3)}.toggle-icon{width:18px;height:18px;pointer-events:none}.card.hidden-card{opacity:.55;border-style:dashed!important;background:linear-gradient(135deg,rgba(19,26,44,.3),rgba(27,37,63,.15))}.card.hidden-card:hover{opacity:.85}.module-hidden-badge{background:rgba(239,68,68,.1);padding:.15rem .4rem;font-size:.65rem;font-weight:700;letter-spacing:.05em}.module-hidden-badge,.sidebar-hidden-badge{color:#f87171;border:1px solid rgba(239,68,68,.2);border-radius:4px;text-transform:uppercase;margin-left:.5rem;display:inline-block;vertical-align:middle}.sidebar-hidden-badge{background:rgba(239,68,68,.12);padding:.1rem .3rem;font-size:.6rem;font-weight:600;letter-spacing:.02em}.week-group.module-hidden{opacity:.6;transition:opacity .2s ease}.week-group.module-hidden:hover{opacity:.95}.mini-spinner{width:14px;height:14px;border:2px solid hsla(0,0%,100%,.2);border-top-color:currentcolor;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.solutions-toggle-btn{background:rgba(19,26,44,.6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border-color);color:var(--text-secondary);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition-smooth);outline:none}.solutions-toggle-btn:hover{transform:scale(1.1);color:var(--text-primary)}.solutions-toggle-btn.visible-state:hover{border-color:var(--accent-cyan);box-shadow:0 0 10px rgba(6,182,212,.3);color:var(--accent-cyan)}.solutions-toggle-btn.hidden-state{border-color:rgba(249,115,22,.4);color:var(--accent-orange);background:rgba(249,115,22,.05)}.solutions-toggle-btn.hidden-state:hover{border-color:var(--accent-orange);box-shadow:0 0 10px rgba(249,115,22,.3)}.solutions-hidden-badge{background:rgba(249,115,22,.1);padding:.15rem .4rem;font-size:.65rem;font-weight:700;margin-left:.5rem;letter-spacing:.05em}.solutions-hidden-badge,.topic-hidden-indicator{color:var(--accent-orange);border:1px solid rgba(249,115,22,.2);border-radius:4px;text-transform:uppercase;display:inline-block;vertical-align:middle}.topic-hidden-indicator{font-size:.6rem;background:rgba(249,115,22,.12);padding:.1rem .3rem;font-weight:600;letter-spacing:.02em}.solutions-hidden-topic{opacity:.7}.solutions-hidden-topic:hover{opacity:1}