@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&family=Outfit:wght@300;400;500;600;700&display=swap";:root{--font-sans:"Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono:"JetBrains Mono", monospace;--bg-primary:#f3f4f6;--bg-secondary:#fffc;--bg-tertiary:#f1f5f9;--text-primary:#0f172a;--text-secondary:#334155;--text-muted:#64748b;--border-color:#e2e8f0cc;--accent-primary:#0f172a;--accent-teal:#0d9488;--accent-teal-soft:#0d948814;--accent-indigo:#6366f1;--accent-indigo-soft:#6366f114;--accent-amber:#d97706;--accent-red:#e11d48;--shadow-flat:0 4px 6px -1px #00000008, 0 2px 4px -2px #00000008;--shadow-hover:0 12px 20px -3px #6366f11a, 0 4px 6px -2px #6366f10d;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--transition-smooth:.2s cubic-bezier(.4, 0, .2, 1)}.dark-theme{--bg-primary:#0d1117;--bg-secondary:#161b22;--bg-tertiary:#21262d;--text-primary:#f0f6fc;--text-secondary:#c9d1d9;--text-muted:#8b949e;--border-color:#30363d;--accent-primary:#f0f6fc;--accent-teal:#2ea44f;--accent-teal-soft:#2ea44f1a;--accent-indigo:#58a6ff;--accent-indigo-soft:#58a6ff1a;--shadow-flat:0 1px 3px #0000001f, 0 1px 2px #0000003d;--shadow-hover:0 8px 24px #0003}*{box-sizing:border-box;margin:0;padding:0}html,body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);transition:background-color var(--transition-smooth), border-color var(--transition-smooth);-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.6}h1,h2,h3,h4{letter-spacing:-.02em;color:var(--text-primary);font-weight:700}a{color:var(--accent-indigo);transition:all var(--transition-smooth);text-decoration:none}a:hover{color:var(--accent-teal)}p{text-align:left}.text-center,.text-center p,.error-container p,.app-global-footer,.app-global-footer p,.exam-welcome-section p,.exam-landing-desc,.quiz-result-card p,.login-header p,.empty-state p{text-align:center}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border:2px solid var(--bg-primary);border-radius:9999px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}#app{flex-direction:column;min-height:100vh;display:flex}.main-content-area{flex-grow:1;width:100%;max-width:1400px;margin:0 auto;padding:40px 48px}.app-global-footer{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);text-align:center;color:var(--text-muted);-webkit-backdrop-filter:blur(12px);margin-top:48px;padding:24px;font-size:.85rem;font-weight:500}.navbar-container{z-index:100;border-radius:var(--radius-md);-webkit-backdrop-filter:blur(16px);transition:all var(--transition-smooth);background-color:#ffffffb3;border:1px solid #e2e8f0cc;justify-content:space-between;align-items:center;margin:16px 48px 0;padding:12px 32px;display:flex;position:sticky;top:16px;box-shadow:0 4px 30px #00000008}.dark-theme .navbar-container{background-color:#0d142699;border-color:#ffffff14;box-shadow:0 10px 30px #0006,inset 0 1px #ffffff0d}.nav-brand .brand-link{color:var(--text-primary);letter-spacing:-.04em;align-items:center;font-size:1.35rem;font-weight:800;display:flex}.brand-terminal{color:var(--accent-teal);font-family:var(--font-mono);margin-right:6px;font-weight:700;animation:1.2s step-end infinite cursorBlink}.brand-highlight{background:linear-gradient(135deg, var(--accent-teal) 0%, var(--accent-indigo) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.nav-menu{align-items:center;gap:8px;display:flex}.nav-item{color:var(--text-secondary);border-radius:var(--radius-sm);transition:all var(--transition-smooth);border:1px solid #0000;padding:8px 16px;font-size:.9rem;font-weight:600}.nav-item:hover{color:var(--text-primary);background-color:var(--bg-tertiary)}.nav-item.active{color:var(--text-primary);background-color:var(--bg-tertiary);border-color:var(--border-color);box-shadow:inset 0 1px #ffffff0d}.nav-item.logout-nav-item{opacity:.8}.nav-item.logout-nav-item:hover{opacity:1;background-color:#e11d4814}.nav-item.upcoming-nav-item:hover{color:var(--text-secondary)!important;background-color:#0000!important;border-color:#0000!important}.nav-actions{align-items:center;gap:16px;display:flex}.nav-stats{align-items:center;gap:8px;display:flex}.nav-level-badge{background-color:var(--accent-indigo-soft);color:var(--accent-indigo);border-radius:var(--radius-sm);letter-spacing:.05em;text-transform:uppercase;border:1px solid #6366f133;padding:4px 12px;font-size:.75rem;font-weight:700}.nav-xp-badge{background-color:var(--accent-teal-soft);color:var(--accent-teal);border-radius:var(--radius-sm);border:1px solid #10b98133;padding:4px 12px;font-size:.75rem;font-weight:700}.theme-toggle-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-primary);width:36px;height:36px;transition:all var(--transition-smooth);justify-content:center;align-items:center;padding:8px;display:flex}.theme-toggle-btn:hover{background-color:var(--border-color);transform:scale(1.05)}.mobile-menu-btn{display:none}.view-title{letter-spacing:-.03em;background:linear-gradient(135deg, var(--text-primary) 30%, var(--text-secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:2rem;font-weight:800}.view-subtitle{color:var(--text-secondary);margin-bottom:32px;font-size:1rem}.back-link{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);transition:all var(--transition-smooth);align-items:center;margin-bottom:24px;font-size:.8rem;font-weight:700;display:inline-flex}.back-link:hover{color:var(--accent-indigo);transform:translate(-4px)}.login-view{justify-content:center;align-items:center;min-height:70vh;display:flex}.login-wrapper{width:100%;max-width:440px;animation:.4s ease-out forwards fadeIn}.login-header-box{text-align:center;margin-bottom:32px}.login-logo-terminal{color:var(--accent-teal);font-family:var(--font-mono);margin-bottom:12px;font-size:2.75rem;font-weight:700;animation:1.2s step-end infinite cursorBlink;display:block}.login-main-title{letter-spacing:-.04em;margin-bottom:8px;font-size:2.25rem}.login-subtitle{color:var(--text-secondary);font-size:.95rem}.login-card-body{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(16px);box-shadow:var(--shadow-flat);transition:box-shadow var(--transition-smooth);padding:40px}.dark-theme .login-card-body{box-shadow:0 20px 40px #0006,inset 0 1px #ffffff0d}.login-card-title{margin-bottom:8px;font-size:1.35rem;font-weight:700}.login-card-desc{color:var(--text-secondary);margin-bottom:28px;font-size:.9rem}.login-buttons-stack{flex-direction:column;display:flex}.login-oauth-btn{font-family:var(--font-sans);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-smooth);color:#fff;border:none;justify-content:center;align-items:center;gap:12px;padding:14px 24px;font-size:.95rem;font-weight:700;display:flex;box-shadow:0 4px 12px #00000026}.login-oauth-btn:hover{opacity:.95;transform:translateY(-2px);box-shadow:0 6px 16px #0003}.login-oauth-btn:active{transform:translateY(0)}.login-oauth-btn.google{background-color:#4285f4}.login-oauth-btn.microsoft{background-color:#2f2f2f}.dark-theme .login-oauth-btn.microsoft{background-color:#1f2937;border:1px solid #ffffff14}.oauth-logo{font-family:var(--font-mono);border-radius:var(--radius-sm);background-color:#ffffff26;justify-content:center;align-items:center;width:26px;height:26px;font-size:.9rem;font-weight:700;display:flex}.login-footer-security{text-align:center;color:var(--text-muted);margin-top:32px;font-size:.75rem}.dash-welcome-row{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(16px);box-shadow:var(--shadow-flat);justify-content:space-between;align-items:center;margin-bottom:32px;padding:32px;display:flex;position:relative;overflow:hidden}.dark-theme .dash-welcome-row{background:linear-gradient(135deg,#0d1426b3 0%,#090d1680 100%);box-shadow:0 10px 30px #0000004d,inset 0 1px #ffffff0d}.dash-welcome-row:after{content:"";pointer-events:none;background:radial-gradient(circle,#6366f114 0%,#0000 70%);width:150px;height:150px;position:absolute;top:0;right:0}.welcome-title{margin-bottom:6px;font-size:1.85rem}.hacker-glow{color:var(--text-primary);font-weight:800}.user-rank-pill{font-family:var(--font-sans);color:var(--text-secondary);background:var(--bg-tertiary);border-radius:var(--radius-sm);border:1px solid var(--border-color);text-transform:uppercase;letter-spacing:.05em;transition:all var(--transition-smooth);align-items:center;padding:4px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.welcome-tip-container{background:var(--bg-tertiary);border:1px solid var(--border-color);border-left:3px solid var(--accent-teal);border-radius:var(--radius-md);max-width:800px;transition:all var(--transition-smooth);align-items:center;gap:14px;margin-top:8px;padding:12px 16px;display:flex;box-shadow:inset 0 2px 4px #00000005}.dark-theme .welcome-tip-container{background:#1e293b4d;box-shadow:inset 0 2px 4px #0003}.welcome-tip-container:hover{border-color:#10b9814d;border-left-color:var(--accent-teal);background-color:var(--bg-secondary);transform:translate(4px)}.tip-icon-wrapper{background:var(--accent-teal-soft);width:26px;height:26px;color:var(--accent-teal);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.9rem;animation:2s ease-in-out infinite pulse-tip;display:flex;box-shadow:0 0 10px #10b98126}@keyframes pulse-tip{0%,to{transform:scale(1);box-shadow:0 0 10px #10b98126}50%{transform:scale(1.1);box-shadow:0 0 16px #10b98159}}.welcome-badge a:hover .dash-avatar{transform:scale(1.08)rotate(5deg);border-color:var(--accent-indigo)!important;box-shadow:0 6px 20px #6366f180!important}.welcome-badge{background-color:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-color);width:64px;height:64px;font-family:var(--font-mono);color:var(--accent-teal);justify-content:center;align-items:center;font-weight:700;display:flex;box-shadow:inset 0 2px 4px #00000005}.dash-stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:36px;display:grid}.stat-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(16px);box-shadow:var(--shadow-flat);transition:all var(--transition-smooth);align-items:center;gap:20px;padding:24px;display:flex}.stat-card:hover{box-shadow:var(--shadow-hover);border-color:#818cf866;transform:translateY(-4px)}.stat-info{flex-direction:column;gap:4px;display:flex}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;font-weight:700}.stat-value{color:var(--text-primary);font-size:1.5rem;font-weight:800}.stat-unit{color:var(--text-muted);font-size:.85rem;font-weight:600}.dash-content-split{grid-template-columns:1fr 340px;gap:32px;display:grid}.pane-title{text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--border-color);color:var(--text-muted);align-items:center;gap:8px;margin-bottom:20px;padding-bottom:12px;font-size:1.1rem;font-weight:700;display:flex}.course-card-horizontal{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(16px);box-shadow:var(--shadow-flat);transition:all var(--transition-smooth);display:flex;overflow:hidden}.course-card-horizontal:hover{box-shadow:var(--shadow-hover);border-color:#10b9814d;transform:translateY(-4px)}.course-banner-lpic{border-right:1px solid var(--border-color);background:linear-gradient(135deg,#6366f114 0%,#10b98114 100%);justify-content:center;align-items:center;width:120px;min-width:120px;display:flex}.course-icon-lpic{letter-spacing:-.05em;background:linear-gradient(135deg, var(--accent-indigo) 0%, var(--accent-teal) 100%);-webkit-text-fill-color:transparent;white-space:nowrap;-webkit-background-clip:text;background-clip:text;font-size:1.8rem;font-weight:800}.course-details{flex-direction:column;flex-grow:1;padding:32px;display:flex}.course-header-row{align-items:center;gap:8px;margin-bottom:16px;display:flex}.course-badge{background-color:var(--accent-indigo-soft);color:var(--accent-indigo);border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.05em;padding:4px 8px;font-size:.7rem;font-weight:700}.course-difficulty.medium{background-color:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:3px 8px;font-size:.7rem;font-weight:700}.course-title{letter-spacing:-.02em;margin-bottom:12px;font-size:1.5rem}.course-description{color:var(--text-secondary);margin-bottom:24px;font-size:.95rem;line-height:1.6}.course-progress-row{align-items:center;gap:16px;margin-top:auto;margin-bottom:24px;display:flex}.progress-bar-container{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:9999px;flex-grow:1;height:8px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--accent-teal), #0d9488);border-radius:9999px;height:100%}.progress-label{color:var(--text-secondary);font-size:.85rem;font-weight:700}.btn-primary-action{background-color:var(--accent-indigo);color:#0f172a;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-smooth);text-align:center;border:1px solid #0000;padding:10px 20px;font-size:.9rem;font-weight:700;display:inline-block}.btn-primary-action:hover{background-color:var(--text-primary);color:var(--bg-primary)}.btn-primary-action:active{opacity:.9}.badges-grid-side{flex-direction:column;gap:12px;display:flex}.side-badge-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow-flat);transition:all var(--transition-smooth);align-items:center;gap:16px;padding:16px;display:flex}.side-badge-card:hover{border-color:#6366f133;transform:scale(1.02)}.side-badge-card.locked{opacity:.45;background-color:var(--bg-tertiary)}.badge-avatar{background-color:var(--bg-tertiary);border-radius:var(--radius-sm);width:44px;min-width:44px;height:44px;font-size:1.15rem;font-weight:800;font-family:var(--font-mono);border:1px solid var(--border-color);color:var(--text-muted);justify-content:center;align-items:center;display:flex}.side-badge-card.unlocked .badge-avatar{border-color:var(--accent-indigo);background:var(--accent-indigo-soft);color:var(--accent-indigo);box-shadow:0 0 10px #6366f11a}.badge-info{flex-direction:column;gap:2px;display:flex}.badge-name{color:var(--text-primary);font-size:.9rem;font-weight:700}.badge-desc{color:var(--text-secondary);font-size:.75rem;line-height:1.4}.course-detail-header{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-flat);transition:all var(--transition-smooth);text-align:center;flex-direction:column;align-items:center;margin-bottom:32px;padding:48px 40px;display:flex;position:relative;overflow:hidden}.dark-theme .course-detail-header{background:linear-gradient(135deg,#161b22b3 0%,#0d1117cc 100%);box-shadow:0 10px 30px #0000004d,inset 0 1px #ffffff0d}.course-detail-header:before{content:"";background:linear-gradient(to right, var(--accent-indigo), var(--accent-teal));width:100%;height:4px;position:absolute;top:0;left:0}.course-detail-header:after{content:"";pointer-events:none;background:radial-gradient(circle,#6366f108 0%,#0000 60%);width:200%;height:200%;position:absolute;top:-50%;left:-50%}.course-back-btn{text-transform:none;color:var(--text-secondary);background-color:var(--bg-tertiary);border:1px solid var(--border-color);transition:all var(--transition-smooth);box-shadow:var(--shadow-flat);border-radius:99px;align-items:center;gap:8px;padding:8px 16px;font-size:.8rem;font-weight:600;line-height:normal;text-decoration:none;display:inline-flex}.course-back-btn:hover{color:var(--text-primary);background-color:var(--border-color);transform:translateY(-1px);box-shadow:0 4px 12px #0000000d}.dark-theme .course-back-btn:hover{box-shadow:0 4px 12px #0003}.course-back-btn svg{vertical-align:middle;transition:transform var(--transition-smooth);display:inline-block;transform:translateY(-.5px)}.course-back-btn:hover svg{transform:translate(-3px)translateY(-.5px)}.course-detail-title{letter-spacing:-.03em;text-align:center;background:linear-gradient(135deg, var(--text-primary) 30%, var(--text-secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-top:0;margin-bottom:16px;font-size:2.25rem;font-weight:800;line-height:1.25}.course-detail-desc{color:var(--text-secondary);text-align:center;max-width:800px;margin-bottom:28px;margin-left:auto;margin-right:auto;font-size:1.05rem;line-height:1.65}.course-meta-tags{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.meta-tag{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);transition:all var(--transition-smooth);border-radius:99px;align-items:center;gap:8px;padding:6px 14px;font-size:.78rem;font-weight:600;line-height:normal;display:flex}.meta-tag:hover{border-color:var(--text-muted);background-color:var(--border-color);color:var(--text-primary);transform:translateY(-1px)}.meta-tag svg{color:var(--text-muted);vertical-align:middle;flex-shrink:0;display:inline-block;transform:translateY(-.5px)}.modules-syllabus-list{flex-direction:column;gap:20px;display:flex}.module-syll-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(16px);box-shadow:var(--shadow-flat);transition:all var(--transition-smooth);justify-content:space-between;gap:32px;padding:28px;display:flex;position:relative;overflow:hidden}.module-syll-card:hover{box-shadow:var(--shadow-hover);border-color:#6366f14d;transform:translateY(-4px)}.module-syll-card.dominant-glow{border-color:#10b98166;box-shadow:0 10px 25px -5px #10b9811a,inset 0 0 15px #10b98105}.module-syll-card.dominant-glow:after{content:"✓ HECHO";color:#fff;letter-spacing:.12em;text-align:center;pointer-events:none;background:linear-gradient(135deg,#059669,#10b981);width:100px;padding:5px 0;font-size:.65rem;font-weight:800;position:absolute;top:16px;right:-26px;transform:rotate(45deg);box-shadow:0 2px 10px #10b98173}.module-syll-card.locked-module-card{opacity:.55;filter:grayscale(35%);cursor:not-allowed!important}.module-syll-card.locked-module-card:hover{border-color:var(--border-color);box-shadow:var(--shadow-flat);transform:none}.module-syll-card.locked-module-card .module-id-badge{background-color:var(--bg-tertiary);color:var(--text-muted)}.module-card-left{flex-grow:1;gap:24px;display:flex}.module-id-badge{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:var(--radius-md);width:52px;min-width:52px;height:52px;font-size:1.25rem;font-weight:800;font-family:var(--font-mono);justify-content:center;align-items:center;display:flex;box-shadow:inset 0 1px 2px #00000005}.module-id-badge.exam-id-badge{width:auto;min-width:130px;font-size:.85rem;font-family:var(--font-sans);white-space:nowrap;letter-spacing:.02em;padding:0 14px}.dominant-glow .module-id-badge{border-color:var(--accent-teal);background-color:var(--accent-teal-soft);color:var(--accent-teal)}.module-main-info{flex-direction:column;flex-grow:1;min-width:0;display:flex}.module-card-title-row{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:6px;display:flex}.module-card-title{letter-spacing:-.02em;margin-bottom:0;font-size:1.35rem;font-weight:700}.syll-status-badge{letter-spacing:.02em;white-space:nowrap;border-radius:9999px;flex-shrink:0;padding:4px 10px;font-size:.7rem;font-weight:700}.syll-status-badge.not-started{background-color:var(--bg-tertiary);color:var(--text-muted);border:1px solid var(--border-color)}.syll-status-badge.in-progress{background-color:var(--accent-indigo-soft);color:var(--accent-indigo);border:1px solid #6366f133}.syll-status-badge.completed{background-color:var(--accent-teal-soft);color:var(--accent-teal);border:1px solid #10b98133}.syll-status-badge.locked{color:#f43f5e;background-color:#f43f5e14;border:1px solid #f43f5e33}.syll-progress-row{margin:12px 0 16px}.syll-progress-track{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:9999px;height:6px;overflow:hidden}.syll-progress-fill{background:linear-gradient(90deg, var(--accent-indigo), #4f46e5);border-radius:9999px;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.syll-progress-fill.completed{background:linear-gradient(90deg, var(--accent-teal), #0d9488)}.module-card-subtitle{color:var(--text-secondary);margin-bottom:6px;font-size:.95rem;font-weight:500}.module-card-summary{color:var(--text-muted);margin-bottom:16px;font-size:.85rem;line-height:1.5}.module-card-tags{flex-wrap:wrap;gap:12px;margin-top:auto;display:flex}.m-tag{color:var(--text-muted);background-color:var(--bg-tertiary);border-radius:var(--radius-sm);border:1px solid var(--border-color);padding:2px 8px;font-size:.75rem;font-weight:700}.module-card-right .m-card-arrow{transition:transform var(--transition-smooth)}.module-syll-card:hover .module-card-right .m-card-arrow{transform:translate(6px);color:var(--accent-indigo)!important}.module-reader-topbar{border-bottom:1px solid var(--border-color);align-items:center;gap:0;margin-bottom:32px;padding:20px 0;display:flex}.module-reader-topbar .back-link{white-space:nowrap;border-right:1px solid var(--border-color);flex-shrink:0;margin-bottom:0;margin-right:24px;padding-right:24px}.reader-topbar-title{flex-grow:1;align-items:center;gap:16px;min-width:0;display:flex}.module-number{background-color:var(--accent-indigo);color:#fff;border-radius:var(--radius-sm);min-width:44px;height:44px;font-size:1rem;font-weight:800;font-family:var(--font-mono);justify-content:center;align-items:center;padding:0 12px;display:flex;box-shadow:0 4px 10px #6366f133}.reader-topbar-title .module-detail-title{white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:1.25rem;font-weight:700;overflow:hidden}.reader-topbar-title .module-detail-subtitle{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;overflow:hidden}.module-reader-topbar>.module-header-badges{flex-shrink:0;gap:8px;margin-left:auto;display:flex}.reader-split-layout{grid-template-columns:310px 1fr;align-items:start;gap:36px;margin-top:0;display:grid}.reader-sidebar-navigation{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);max-height:calc(100vh - 140px);box-shadow:var(--shadow-flat);-webkit-backdrop-filter:blur(16px);padding:24px;position:sticky;top:96px;overflow-y:auto}.dark-theme .reader-sidebar-navigation{background-color:#0d14268c}.reader-progress-header{border-bottom:1px solid var(--border-color);margin-bottom:20px;padding-bottom:20px}.sidebar-progress-row{justify-content:space-between;align-items:center;display:flex}.progress-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;font-weight:700}.reader-progress-bar-bg{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:9999px;height:10px;margin:12px 0 0;overflow:hidden}.progress-percentage-text{color:var(--text-secondary);font-size:.8rem;font-weight:700}.reader-steps-list{flex-direction:column;gap:8px;display:flex}.reader-step-tab{border-radius:var(--radius-md);text-align:left;cursor:pointer;width:100%;transition:all var(--transition-smooth);color:var(--text-primary);font-family:var(--font-sans);background-color:#0000;border:1px solid #0000;align-items:flex-start;gap:12px;padding:12px 14px;display:flex}.reader-step-tab:hover{background-color:var(--bg-tertiary)}.reader-step-tab.active{background-color:var(--accent-indigo-soft);border-color:#6366f140;transform:translate(4px)}.reader-step-tab.read{opacity:.85}.step-badge{font-family:var(--font-mono);border:1px solid var(--border-color);background-color:var(--bg-tertiary);border-radius:var(--radius-sm);width:44px;min-width:44px;height:26px;color:var(--text-muted);transition:all var(--transition-smooth);justify-content:center;align-items:center;margin-top:2px;font-size:.7rem;font-weight:700;display:flex}.reader-step-tab.active .step-badge{background-color:var(--accent-indigo);color:#fff;border-color:var(--accent-indigo);box-shadow:0 4px 8px #6366f126}.reader-step-tab.read .step-badge{background-color:var(--accent-teal-soft);color:var(--accent-teal);border-color:#10b98133}.step-info{flex-direction:column;flex-grow:1;gap:3px;display:flex;overflow:visible}.step-title{color:var(--text-primary);white-space:normal;font-size:.875rem;font-weight:600;line-height:1.35}.step-status-indicator{color:var(--text-muted);font-size:.7rem}.reader-step-tab.active .step-status-indicator{color:var(--accent-indigo);font-weight:700}.reader-step-tab.read .step-status-indicator{color:var(--accent-teal);font-weight:700}.reader-content-pane{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-flat);-webkit-backdrop-filter:blur(16px);color:var(--text-primary);padding:48px;font-size:1.05rem;line-height:1.75}.dark-theme .reader-content-pane{background-color:#0d142666}.module-intro-box{background-color:var(--accent-teal-soft);border:1px solid #10b98133;border-left:4px solid var(--accent-teal);border-radius:var(--radius-md);color:var(--text-primary);margin-bottom:36px;padding:20px;font-size:1rem;line-height:1.6}.theory-section-title{border-left:4px solid var(--accent-indigo);color:var(--text-primary);letter-spacing:-.02em;margin-bottom:24px;padding-left:14px;font-size:1.65rem;font-weight:800}.theory-section-content p{color:var(--text-secondary);margin-bottom:18px}.theory-section-content ul{margin-bottom:20px;padding-left:8px!important;list-style:none!important}.theory-section-content ul li{color:var(--text-secondary);margin-bottom:8px;padding-left:20px;position:relative}.theory-section-content ul li:before{content:"—";color:var(--text-muted);opacity:.7;position:absolute;left:0}.theory-section-content ol{margin-bottom:20px;padding-left:24px!important}.theory-section-content ol li{color:var(--text-secondary);margin-bottom:8px}.theory-section-content ul ul,.theory-section-content ul ol,.theory-section-content ol ul,.theory-section-content ol ol{margin-top:6px;margin-bottom:6px;padding-left:24px!important}.content-subheader{color:var(--text-primary);align-items:center;gap:8px;margin-top:36px;margin-bottom:16px;font-size:1.25rem;font-weight:700;display:flex}.content-subheader:before{content:"";background-color:var(--accent-teal);border-radius:2px;width:4px;height:18px;display:inline-block}.reader-footer-nav{border-top:1px solid var(--border-color);grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;margin-top:48px;padding-top:28px;display:grid}.reader-footer-nav .prev-btn{justify-self:start}.reader-footer-nav .next-btn{justify-self:end}.reader-footer-nav .reader-section-badge-pill{justify-self:center}.reader-nav-btn{font-family:var(--font-sans);border-radius:var(--radius-sm);border:1px solid var(--border-color);background-color:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;transition:all var(--transition-smooth);align-items:center;gap:8px;padding:12px 24px;font-size:.9rem;font-weight:700;display:inline-flex}.reader-nav-btn:not(:disabled):hover{border-color:var(--text-primary);background-color:var(--bg-primary)}.reader-nav-btn.next-btn{background-color:var(--accent-indigo);color:#fff;border-color:#0000;box-shadow:0 4px 10px #6366f133}.reader-nav-btn.next-btn:not(:disabled):hover{background-color:#4f46e5;box-shadow:0 6px 14px #6366f14d}.reader-nav-btn.completion-pulse{animation:2s infinite alternate completionPulse;box-shadow:0 0 16px #10b9814d;background:linear-gradient(90deg, var(--accent-teal), #0d9488)!important;color:#fff!important;border-color:#0000!important}.code-block-container{border-radius:var(--radius-md);background-color:#0b0f19;border:1px solid #1e293b;margin:24px 0;position:relative;overflow:hidden;box-shadow:0 10px 30px #0006}.code-block-container:before{content:"";background-color:#0f172a;background-image:radial-gradient(circle,#ef4444 4px,#0000 5px),radial-gradient(circle,#fbbf24 4px,#0000 5px),radial-gradient(circle,#22c55e 4px,#0000 5px);background-position:12px 10px,30px 10px,48px 10px;background-repeat:no-repeat;background-size:14px 14px;border-bottom:1px solid #1e293b;height:34px;display:block}.code-bash-block{margin:0;padding:16px 20px;overflow-x:auto}.code-bash-block code{font-family:var(--font-mono);color:#38bdf8;font-size:.9rem;line-height:1.5}.inline-code{font-family:var(--font-mono);background-color:var(--bg-tertiary);color:var(--accent-indigo);border-radius:var(--radius-sm);border:1px solid var(--border-color);padding:2px 6px;font-size:.85rem;font-weight:600}.copy-code-btn{border-radius:var(--radius-sm);color:#94a3b8;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-smooth);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#1e293bb3;border:1px solid #ffffff14;align-items:center;gap:6px;padding:4px 8px;font-size:.7rem;font-weight:700;display:flex;position:absolute;top:6px;right:12px}.copy-code-btn:hover{color:#fff;background-color:#1e293be6;border-color:#38bdf8}.copy-code-btn.copied{background-color:var(--accent-teal)!important;color:#fff!important;border-color:var(--accent-teal)!important}.copy-icon{flex-shrink:0}.alert-box-card{border-radius:var(--radius-md);box-shadow:var(--shadow-flat);border-left:4px solid #0000;gap:16px;margin:24px 0;padding:20px;display:flex;max-width:100%!important}.alert-box-card.note{border-left-color:var(--accent-indigo);background-color:var(--accent-indigo-soft)}.alert-box-card.note .alert-icon{color:var(--accent-indigo)}.alert-box-card.warning{border-left-color:var(--accent-red);background-color:#e11d480d}.alert-box-card.warning .alert-icon{color:var(--accent-red)}.alert-box-card.tip{border-left-color:var(--accent-teal);background-color:var(--accent-teal-soft)}.alert-box-card.tip .alert-icon{color:var(--accent-teal)}.alert-icon{flex-shrink:0;justify-content:center;align-items:center;display:flex}.alert-content{color:var(--text-primary);font-size:.95rem;line-height:1.6}.alert-content strong{font-weight:700}.quiz-page{max-width:760px;margin:0 auto}.quiz-progress-text{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;font-size:.75rem;font-weight:700}.quiz-timer-badge{font-family:var(--font-mono);color:var(--text-primary);background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);transition:all var(--transition-smooth);align-items:center;gap:6px;padding:4px 12px;font-size:.8rem;font-weight:700;display:inline-flex}.quiz-timer-badge.low-time{color:var(--accent-red);background-color:#e11d480d;border-color:#e11d484d;animation:1.5s ease-in-out infinite pulseWarning}@keyframes pulseWarning{0%{opacity:1}50%{opacity:.6}to{opacity:1}}.quiz-progress-bar-bg{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:9999px;height:6px;overflow:hidden}.quiz-progress-bar-fill{background:linear-gradient(90deg, var(--accent-indigo), #4f46e5);border-radius:9999px;height:100%;transition:width .3s}.quiz-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(16px);box-shadow:var(--shadow-flat);margin-top:24px;padding:40px}.quiz-question-text{letter-spacing:-.01em;margin-bottom:28px;font-size:1.25rem;font-weight:700;line-height:1.5}.quiz-options-list{flex-direction:column;gap:12px;margin-bottom:28px;display:flex}.quiz-option-btn{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:all var(--transition-smooth);color:var(--text-primary);font-family:var(--font-sans);align-items:center;gap:16px;padding:16px 24px;display:flex}.quiz-option-btn:hover:not(:disabled){border-color:var(--accent-indigo);background-color:#6366f108;transform:translate(4px)}.quiz-option-btn.active-selection{box-shadow:0 0 10px #6366f126;border-color:var(--accent-indigo)!important;color:var(--accent-indigo)!important;background-color:#6366f114!important}.quiz-option-btn.active-selection .option-marker{background-color:var(--accent-indigo)!important;color:#fff!important;border-color:var(--accent-indigo)!important}.option-marker{border-radius:var(--radius-sm);background-color:var(--bg-secondary);border:1px solid var(--border-color);width:28px;height:28px;color:var(--text-muted);transition:all var(--transition-smooth);justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:flex}.quiz-option-btn:hover:not(:disabled) .option-marker{color:var(--accent-indigo);border-color:var(--accent-indigo)}.option-text{font-size:.95rem;font-weight:600}.quiz-option-btn.correct{box-shadow:0 0 15px #10b9811a;background-color:var(--accent-teal-soft)!important;border-color:var(--accent-teal)!important;color:var(--accent-teal)!important}.quiz-option-btn.correct .option-marker{background-color:var(--accent-teal)!important;color:#fff!important;border-color:var(--accent-teal)!important}.quiz-option-btn.incorrect{box-shadow:0 0 15px #e11d481a;border-color:var(--accent-red)!important;color:var(--accent-red)!important;background-color:#e11d480d!important}.quiz-option-btn.incorrect .option-marker{background-color:var(--accent-red)!important;color:#fff!important;border-color:var(--accent-red)!important}.quiz-feedback-box{background-color:var(--bg-tertiary);border-radius:var(--radius-md);border-left:4px solid var(--accent-indigo);margin-bottom:28px;padding:20px;font-size:.9rem;line-height:1.6;animation:.25s ease-out slideDown}.feedback-title{text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:.8rem;font-weight:700}.feedback-title.correct-title{color:var(--accent-teal)}.feedback-title.incorrect-title{color:var(--accent-red)}.feedback-content{color:var(--text-secondary)}.quiz-footer{justify-content:space-between;align-items:center;width:100%;margin-top:24px;display:flex}.quiz-prev-btn{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-smooth);align-items:center;gap:8px;padding:12px 24px;font-size:.9rem;font-weight:700;display:inline-flex}.quiz-prev-btn:hover{background-color:var(--border-color);border-color:var(--text-muted);transform:translateY(-2px)}.quiz-prev-btn.invisible{visibility:hidden;pointer-events:none}.quiz-next-btn{background-color:var(--text-primary);color:var(--bg-primary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-smooth);border:none;padding:12px 24px;font-size:.9rem;font-weight:700}.quiz-next-btn:hover{opacity:.9;transform:translateY(-2px)}.quiz-blank-input{background-color:var(--bg-tertiary);border:1px solid var(--border-color);width:100%;color:var(--text-primary);font-family:var(--font-mono);border-radius:var(--radius-md);transition:all var(--transition-smooth);outline:none;margin-bottom:24px;padding:16px 20px;font-size:1rem}.quiz-blank-input:focus{border-color:var(--accent-indigo);background-color:var(--bg-secondary);box-shadow:0 0 10px #6366f126}.quiz-blank-input:disabled{background-color:var(--bg-secondary);color:var(--text-muted);cursor:not-allowed}.quiz-blank-input.correct{border-color:var(--accent-teal)!important;background-color:var(--accent-teal-soft)!important;color:var(--accent-teal)!important}.quiz-blank-input.incorrect{border-color:var(--accent-red)!important;color:var(--accent-red)!important;background-color:#e11d480d!important}.quiz-blank-hint{color:var(--text-muted);margin-bottom:8px;font-size:.85rem;display:block}.quiz-result-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-flat);-webkit-backdrop-filter:blur(16px);padding:48px}.quiz-badge-success{background-color:var(--accent-teal-soft);color:var(--accent-teal);border:1px solid var(--accent-teal);letter-spacing:.05em;border-radius:9999px;margin-bottom:20px;padding:4px 14px;font-size:.75rem;font-weight:700;display:inline-block}.quiz-badge-failed{color:var(--accent-amber);border:1px solid var(--accent-amber);letter-spacing:.05em;background-color:#d977061a;border-radius:9999px;margin-bottom:20px;padding:4px 14px;font-size:.75rem;font-weight:700;display:inline-block}.result-title{margin-bottom:20px;font-size:1.75rem}.result-score-circle{border:3px solid var(--border-color);background-color:var(--bg-tertiary);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:110px;height:110px;margin:0 auto 28px;display:flex;box-shadow:inset 0 2px 4px #0000000d}.score-num{font-size:1.75rem;font-weight:800;line-height:1.1}.score-total{color:var(--text-muted);font-size:.85rem}.score-percentage{color:var(--accent-indigo);margin-top:2px;font-size:.8rem;font-weight:700}.result-description{color:var(--text-secondary);max-width:460px;margin:0 auto 36px;font-size:.95rem;line-height:1.6}.result-actions{justify-content:center;gap:16px;display:flex}.quiz-action-btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-smooth);padding:12px 24px;font-size:.9rem;font-weight:700}.quiz-action-btn.primary{background-color:var(--text-primary);color:var(--bg-primary);border:1px solid #0000}.quiz-action-btn.primary:hover{color:var(--text-primary);border-color:var(--text-primary);background-color:#0000}.quiz-action-btn.secondary{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.quiz-action-btn.secondary:hover{background-color:var(--border-color)}.terminal-page{max-width:900px;margin:0 auto}.terminal-wrapper{border-radius:var(--radius-lg);background-color:#070a13;border:1px solid #1e293b;margin-top:24px;overflow:hidden;box-shadow:0 20px 45px #00000080,inset 0 1px #ffffff0d}.terminal-header{background-color:#1a1e29;border-bottom:1px solid #2d313f;justify-content:space-between;align-items:center;height:38px;padding:0 16px;display:flex}.terminal-title-container{color:#a0aec0;font-family:var(--font-sans);align-items:center;gap:8px;font-size:.8rem;font-weight:600;display:flex}.terminal-icon{opacity:.8}.terminal-tabs{flex-grow:1;gap:4px;height:100%;margin-left:24px;display:flex}.terminal-tab{color:var(--text-primary);font-size:.75rem;font-family:var(--font-mono);background-color:#070a13;border:1px solid #2d313f;border-bottom:none;border-radius:4px 4px 0 0;align-self:flex-end;align-items:center;gap:8px;height:28px;padding:4px 14px;display:flex}.terminal-tab .tab-dot{background-color:var(--accent-teal);width:6px;height:6px;box-shadow:0 0 6px var(--accent-teal);border-radius:50%}.linux-window-buttons{gap:2px;display:flex}.linux-win-btn{color:#718096;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:28px;height:28px;font-size:.85rem;transition:all .2s;display:flex}.linux-win-btn:hover{color:var(--text-primary);background-color:#ffffff0f}.linux-win-btn.close:hover{color:#fff;background-color:#e53e3e}.terminal-badge{color:#34d399;border-radius:var(--radius-sm);letter-spacing:.05em;background-color:#10b9811a;border:1px solid #10b98140;padding:3px 8px;font-size:.65rem;font-weight:700}.terminal-body{height:380px;font-family:var(--font-mono);color:#e2e8f0;text-align:left;flex-direction:column;gap:6px;padding:20px;font-size:.9rem;line-height:1.55;display:flex;overflow-y:auto}.term-line{white-space:pre-wrap;word-break:break-all}.term-system{color:#475569;font-style:italic}.term-input{color:#38bdf8}.term-error{color:#f87171}.term-output{color:#cbd5e1}.term-dir{color:#38bdf8;font-weight:700}.term-suid{color:#facc15;font-weight:700;text-decoration:underline}.terminal-input-row{align-items:center;margin-top:6px;display:flex}.terminal-prompt{color:#34d399;white-space:nowrap;margin-right:8px;font-weight:700}.terminal-input-field{color:#f8fafc;font-family:var(--font-mono);caret-color:#34d399;background:0 0;border:none;outline:none;flex-grow:1;font-size:.9rem}.flag-submission-bar{text-align:left;background-color:#0f172a;border-top:1px solid #1e293b;padding:20px}.flag-prompt{color:#94a3b8;margin-bottom:10px;font-size:.85rem;font-weight:600}.flag-input-group{gap:12px;display:flex}.flag-input{color:#fff;font-family:var(--font-mono);border-radius:var(--radius-sm);transition:all var(--transition-smooth);background-color:#070a13;border:1px solid #1e293b;outline:none;flex-grow:1;padding:12px 16px;font-size:.9rem}.flag-input:focus{border-color:#10b981;box-shadow:0 0 10px #10b9811a}.flag-submit-btn{color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-smooth);background-color:#10b981;border:none;padding:0 24px;font-size:.85rem;font-weight:700;box-shadow:0 4px 12px #10b98133}.flag-submit-btn:hover{background-color:#059669;transform:translateY(-1px)}.flag-result{margin-top:12px;font-size:.85rem;font-weight:700}.flag-result.success{color:var(--accent-teal)}.flag-result.error{color:var(--accent-red)}.profile-view{max-width:900px;margin:0 auto}.profile-grid{grid-template-columns:1fr 1fr;gap:28px;margin-top:24px;display:grid}.profile-card-main,.profile-settings-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:border-color var(--transition-smooth), box-shadow var(--transition-smooth);padding:28px}.profile-avatar-row{align-items:center;gap:20px;display:flex}.avatar-large{background:linear-gradient(135deg, var(--accent-indigo) 0%, var(--accent-teal) 100%);border:1.5px solid var(--border-color);color:#fff;width:64px;height:64px;transition:border-color var(--transition-smooth), transform var(--transition-smooth);letter-spacing:-.02em;border-radius:50%;justify-content:center;align-items:center;font-size:1.45rem;font-weight:700;display:flex}.avatar-large:hover{border-color:var(--text-muted);transform:scale(1.03)}.avatar-details{flex-direction:column;gap:2px;display:flex}.profile-badge-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:600}.profile-rank{color:var(--text-primary);font-size:1.25rem;font-weight:700}.profile-divider{background-color:var(--border-color);border:0;height:1px;margin:24px 0}.profile-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;font-size:.8rem;font-weight:700;display:block}.profile-input-row{gap:12px;display:flex}.profile-input{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:var(--radius-sm);font-size:.9rem;font-family:var(--font-sans);transition:border-color var(--transition-smooth), box-shadow var(--transition-smooth);outline:none;flex-grow:1;padding:10px 14px}.profile-input:focus{border-color:var(--text-muted);box-shadow:0 0 0 2px #8b949e26}.profile-btn-primary{background-color:var(--accent-indigo-soft);color:var(--accent-indigo);border:1px solid var(--accent-indigo);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-smooth);padding:0 18px;font-size:.85rem;font-weight:600}.profile-btn-primary:hover{background-color:var(--accent-indigo);color:#fff}.profile-form-msg{margin-top:10px;font-size:.85rem;font-weight:700}.profile-form-msg.success{color:var(--accent-teal)}.profile-form-msg.error{color:var(--accent-red)}.linked-accounts-desc{color:var(--text-muted);margin-top:-6px;margin-bottom:16px;font-size:.82rem;line-height:1.4}.identity-connections-stack{flex-direction:column;gap:12px;display:flex}.connection-row-item{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:border-color var(--transition-smooth), background-color var(--transition-smooth);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.connection-row-item:hover{border-color:var(--border-color);background-color:#21262d4d}.provider-info-group{align-items:center;gap:12px;display:flex}.provider-icon-wrapper{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.connection-provider-info{text-align:left;flex-direction:column;gap:2px;display:flex}.provider-name-title{color:var(--text-primary);font-size:.9rem;font-weight:600}.provider-status-text{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:180px;font-size:.78rem;overflow:hidden}.connection-btn{font-family:var(--font-sans);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-smooth);outline:none;padding:6px 14px;font-size:.78rem;font-weight:600}.connection-btn.disconnected{background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.connection-btn.disconnected:hover{background-color:var(--border-color);border-color:var(--text-muted)}.connection-btn.connected{color:var(--accent-red);border:1px solid var(--border-color);background-color:#0000}.connection-btn.connected:hover{background-color:var(--accent-red);color:#fff;border-color:var(--accent-red)}.profile-section-title{color:var(--text-primary);margin-bottom:18px;font-weight:600;font-size:1.1rem!important}.setting-row{justify-content:space-between;align-items:center;gap:16px;display:flex}.setting-info{flex-direction:column;gap:4px;max-width:75%;display:flex}.setting-title{font-size:.95rem;font-weight:600}.setting-desc{color:var(--text-muted);font-size:.78rem;line-height:1.4}.switch-container{width:44px;height:22px;display:inline-block;position:relative}.switch-container input{opacity:0;width:0;height:0}.switch-slider{cursor:pointer;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:20px;transition:all .2s;position:absolute;inset:0}.switch-slider:before{content:"";background-color:var(--text-muted);border-radius:50%;width:14px;height:14px;transition:all .2s;position:absolute;bottom:3px;left:3px}.dark-theme .switch-slider:before{background-color:var(--text-muted)}input:checked+.switch-slider{background-color:var(--accent-teal-soft);border-color:var(--accent-teal)}input:checked+.switch-slider:before{background-color:var(--accent-teal);transform:translate(22px)}.profile-stats-list{flex-direction:column;gap:12px;display:flex}.p-stat-item{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding-bottom:10px;font-size:.9rem;display:flex}.p-stat-item:last-child{border-bottom:none;padding-bottom:0}.p-stat-left{align-items:center;gap:10px;display:flex}.p-stat-icon{color:var(--text-muted);flex-shrink:0}.p-stat-label{color:var(--text-secondary)}.p-stat-val{color:var(--text-primary);font-weight:600;font-family:var(--font-mono);font-size:.85rem}.profile-danger-zone{border-radius:var(--radius-md);background-color:#e11d4803;border:1px dashed #e11d484d;padding:16px}.danger-zone-title{color:var(--accent-red);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:.9rem;font-weight:600}.danger-zone-desc{color:var(--text-muted);margin-bottom:12px;font-size:.78rem;line-height:1.4}.profile-btn-danger{color:var(--accent-red);border-radius:var(--radius-sm);cursor:pointer;width:100%;transition:all var(--transition-smooth);background-color:#0000;border:1px solid #e11d4866;padding:10px;font-size:.85rem;font-weight:600}.profile-btn-danger:hover{background-color:var(--accent-red);color:#fff;border-color:var(--accent-red)}.oauth-modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:1000;background-color:#090d1699;justify-content:center;align-items:center;padding:20px;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.oauth-modal-container{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:520px;box-shadow:var(--shadow-hover);flex-direction:column;animation:.3s cubic-bezier(.34,1.56,.64,1) oauthScaleUp;display:flex;overflow:hidden}.oauth-modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.oauth-modal-title{color:var(--text-primary);align-items:center;gap:8px;font-size:1.2rem;font-weight:700;display:flex}.oauth-modal-close-btn{color:var(--text-muted);cursor:pointer;transition:color var(--transition-smooth);background:0 0;border:none;padding:4px;font-size:1.75rem;line-height:1}.oauth-modal-close-btn:hover{color:var(--text-primary)}.oauth-modal-body{max-height:65vh;padding:24px;overflow-y:auto}.oauth-modal-alert-box{border-left:4px solid var(--accent-red);border-radius:0 var(--radius-md) var(--radius-md) 0;background-color:#e11d480d;margin-bottom:24px;padding:16px}.oauth-modal-alert-box.success{border-left-color:var(--accent-teal);background-color:#10b9810d}.oauth-modal-alert-title{text-transform:uppercase;letter-spacing:.03em;margin-bottom:6px;font-size:.95rem;font-weight:700}.oauth-modal-alert-desc{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.oauth-modal-instruction-title{color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px;font-size:.9rem;font-weight:700}.oauth-modal-instructions{color:var(--text-secondary);margin-bottom:24px;padding-left:20px;font-size:.9rem;line-height:1.6}.oauth-modal-instructions li{margin-bottom:8px}.oauth-modal-tech-box{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-mono);color:var(--text-secondary);white-space:pre-wrap;word-break:break-all;max-height:150px;margin-top:12px;padding:16px;font-size:.8rem;overflow-y:auto}.oauth-modal-footer{border-top:1px solid var(--border-color);background-color:var(--bg-tertiary);justify-content:flex-end;padding:16px 24px;display:flex}.oauth-modal-btn{background-color:var(--text-primary);color:var(--bg-primary);font-family:var(--font-sans);border-radius:var(--radius-sm);cursor:pointer;transition:opacity var(--transition-smooth);border:none;padding:10px 20px;font-size:.85rem;font-weight:700}.oauth-modal-btn:hover{opacity:.9}.level-up-banner{z-index:1000;position:fixed;bottom:24px;right:24px}.lvl-banner-content{background:var(--text-primary);color:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border-color);align-items:center;gap:16px;padding:16px 24px;display:flex;box-shadow:0 10px 30px #0000004d}.lvl-banner-icon{font-size:1rem;font-weight:800;font-family:var(--font-mono);background-color:var(--accent-teal);color:#fff;border-radius:var(--radius-sm);padding:4px 8px;box-shadow:0 4px 8px #10b9814d}.lvl-banner-info h3{color:var(--bg-primary);text-transform:uppercase;letter-spacing:.08em;font-size:.85rem;font-weight:700}.lvl-banner-info p{opacity:.85;font-size:.8rem}.error-container{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);text-align:center;max-width:460px;box-shadow:var(--shadow-flat);-webkit-backdrop-filter:blur(16px);margin:48px auto;padding:48px}.error-container h2{margin-bottom:16px}.error-container p{color:var(--text-secondary);margin-bottom:24px}body.reader-mode-active{overflow:auto}body.reader-mode-active .main-content-area{padding:0}body.reader-mode-active .module-view{display:block}body.reader-mode-active .app-global-footer{display:none}.module-reader-topbar{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);-webkit-backdrop-filter:blur(20px);align-items:center;gap:20px;padding:14px 32px;display:flex}.module-reader-topbar .back-link{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-radius:var(--radius-sm);border:1px solid var(--border-color);transition:all var(--transition-smooth);white-space:nowrap;flex-shrink:0;align-items:center;gap:6px;padding:6px 12px;font-size:.8rem;font-weight:600;text-decoration:none;display:inline-flex}.module-reader-topbar .back-link:hover{color:var(--text-primary);border-color:var(--accent-indigo);background:var(--accent-indigo-soft)}.reader-topbar-title{flex:1;align-items:center;gap:14px;min-width:0;display:flex}.module-number-chip{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;border-radius:var(--radius-sm);background:var(--accent-indigo-soft);color:var(--accent-indigo);border:1px solid #6366f133;flex-shrink:0;padding:5px 10px;font-size:.7rem;font-weight:700}.reader-topbar-text{min-width:0}.module-detail-title{letter-spacing:-.01em;color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:700;overflow:hidden}.module-detail-subtitle{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;font-weight:400;overflow:hidden}.module-header-badges{flex-shrink:0;align-items:center;gap:8px;display:flex}.header-badge{letter-spacing:.02em;white-space:nowrap;border-radius:100px;padding:4px 10px;font-size:.72rem;font-weight:600}.difficulty-badge.fácil{color:#059669;background:#10b9811f;border:1px solid #10b98140}.difficulty-badge.medio{color:#d97706;background:#f59e0b1f;border:1px solid #f59e0b40}.difficulty-badge.difícil{color:#dc2626;background:#ef44441f;border:1px solid #ef444440}.xp-badge{background:var(--accent-indigo-soft);color:var(--accent-indigo);border:1px solid #6366f133}.sections-badge{background:var(--bg-tertiary);color:var(--text-muted);border:1px solid var(--border-color)}.reader-split-layout{grid-template-columns:1fr 280px;align-items:start;min-height:100vh;display:grid}.reader-sidebar-navigation{border-left:1px solid var(--border-color);background:var(--bg-secondary);flex-direction:column;order:2;height:calc(100vh - 61px);display:flex;position:sticky;top:61px;overflow:hidden auto}.reader-progress-header{border-bottom:1px solid var(--border-color);flex-shrink:0;padding:20px 20px 16px}.sidebar-progress-row{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.progress-title{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);font-size:.78rem;font-weight:700}.progress-percentage-text{font-size:.78rem;font-weight:700;font-family:var(--font-mono);color:var(--accent-teal)}.reader-progress-bar-bg{background:var(--bg-tertiary);border-radius:100px;height:4px;margin-bottom:10px;overflow:hidden}.reader-progress-bar-fill{background:linear-gradient(90deg, var(--accent-teal), var(--accent-indigo));border-radius:100px;width:0%;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1);box-shadow:0 0 8px #10b98166}.progress-hint-text{color:var(--text-muted);font-size:.72rem;line-height:1.4}.reader-sidebar-index-header{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);flex-shrink:0;align-items:center;gap:8px;padding:14px 20px 10px;font-size:.72rem;font-weight:700;display:flex}.reader-steps-list{flex-direction:column;flex:1;gap:2px;padding:4px 12px 20px;display:flex}.reader-step-tab{border-radius:var(--radius-md);cursor:pointer;text-align:left;width:100%;transition:all var(--transition-smooth);background:0 0;border:1px solid #0000;align-items:flex-start;gap:12px;padding:10px 12px;display:flex;position:relative}.reader-step-tab:hover{background:var(--bg-tertiary);border-color:var(--border-color)}.reader-step-tab.active{background:var(--accent-indigo-soft);border-color:#6366f14d}.reader-step-tab.read .step-badge{background:var(--accent-teal-soft);color:var(--accent-teal);border-color:#10b9814d}.step-badge{font-family:var(--font-mono);background:var(--bg-tertiary);color:var(--text-muted);border:1px solid var(--border-color);white-space:nowrap;transition:all var(--transition-smooth);border-radius:5px;flex-shrink:0;margin-top:1px;padding:3px 6px;font-size:.65rem;font-weight:700}.reader-step-tab.active .step-badge{background:var(--accent-indigo);color:#fff;border-color:#0000}.step-info{flex-direction:column;gap:2px;min-width:0;display:flex}.step-title{color:var(--text-secondary);transition:color var(--transition-smooth);font-size:.82rem;font-weight:500;line-height:1.4}.reader-step-tab.active .step-title{color:var(--accent-indigo);font-weight:600}.reader-step-tab.read .step-title{color:var(--text-primary)}.step-status-indicator{color:var(--text-muted);transition:color var(--transition-smooth);font-size:.7rem}.reader-step-tab.active .step-status-indicator{color:var(--accent-indigo)}.reader-step-tab.read .step-status-indicator{color:var(--accent-teal)}.reader-content-pane{flex-direction:column;order:1;display:flex}.reader-content-scroll-container{flex:1}.reader-pages-container{width:100%;max-width:860px;margin:0 auto;padding:40px 56px}.module-intro-box{background:linear-gradient(135deg, var(--accent-indigo-soft), var(--accent-teal-soft));border-radius:var(--radius-lg);border:1px solid #6366f133;gap:16px;margin-bottom:32px;padding:20px 24px;display:flex}.intro-box-icon{color:var(--accent-indigo);flex-shrink:0;align-items:flex-start;margin-top:2px;display:flex}.module-intro-box p{color:var(--text-secondary);font-size:.95rem;font-style:italic;line-height:1.7}.theory-section-title{letter-spacing:-.025em;color:var(--text-primary);border-bottom:2px solid var(--border-color);margin-bottom:24px;padding-bottom:16px;font-size:1.5rem;font-weight:700;position:relative}.theory-section-title:after{content:"";background:linear-gradient(90deg, var(--accent-indigo), var(--accent-teal));border-radius:2px;width:48px;height:2px;position:absolute;bottom:-2px;left:0}.theory-section-content{color:var(--text-secondary);font-size:.95rem;line-height:1.8}.theory-section-content p{margin-bottom:16px}.theory-section-content ul,.theory-section-content ol{margin-bottom:16px;padding-left:22px}.theory-section-content li{margin-bottom:8px;line-height:1.7}.theory-section-content ul>li::marker{color:var(--accent-indigo)}.theory-section-content ol>li::marker{color:var(--accent-teal);font-weight:700;font-family:var(--font-mono);font-size:.85em}.content-subheader{color:var(--text-primary);letter-spacing:-.01em;align-items:center;gap:8px;margin:28px 0 12px;font-size:1.05rem;font-weight:700;display:flex}.content-subheader:before{content:"";background:linear-gradient(180deg, var(--accent-indigo), var(--accent-teal));border-radius:2px;flex-shrink:0;width:3px;height:1em;display:inline-block}.reader-footer-nav{border-top:1px solid var(--border-color);background:var(--bg-secondary);-webkit-backdrop-filter:blur(12px);z-index:40;justify-content:space-between;align-items:center;gap:16px;padding:16px 56px;display:flex;position:sticky;bottom:0}.reader-footer-center{flex-direction:column;align-items:center;gap:4px;display:flex}.reader-section-badge-pill{font-size:.8rem;font-weight:600;font-family:var(--font-mono);color:var(--text-muted);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:100px;padding:4px 14px}.reader-kbd-hint{color:var(--text-muted);opacity:.6;font-size:.68rem;font-family:var(--font-mono)}.reader-nav-btn{border-radius:var(--radius-md);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-smooth);border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-secondary);align-items:center;gap:8px;padding:10px 22px;font-size:.85rem;font-weight:600;display:inline-flex}.reader-nav-btn:hover:not(:disabled){background:var(--text-primary);color:var(--bg-primary);border-color:var(--text-primary);box-shadow:var(--shadow-hover);transform:translateY(-1px)}.reader-nav-btn:disabled{opacity:.35;cursor:not-allowed}.next-btn{background:var(--accent-indigo);color:#fff;border-color:var(--accent-indigo)}.next-btn:hover:not(:disabled){background:var(--text-primary);border-color:var(--text-primary)}.reader-nav-btn.completion-pulse{background:var(--accent-teal);color:#fff;border-color:var(--accent-teal);animation:1.2s ease-in-out infinite alternate completionPulse}.reader-section-page{animation:.2s ease-out forwards fadeIn}.module-challenges-panel{width:100%;max-width:860px;margin:0 auto;padding:40px 56px 60px;animation:.35s ease-out forwards fadeIn}.challenges-panel-header{background:linear-gradient(135deg, var(--accent-teal-soft), var(--accent-indigo-soft));border-radius:var(--radius-lg);border:1px solid #10b98133;align-items:center;gap:20px;margin-bottom:28px;padding:24px 28px;display:flex}.challenges-panel-icon{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--accent-teal), var(--accent-indigo));color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex;box-shadow:0 8px 16px #10b98140}.challenges-panel-title{color:var(--text-primary);letter-spacing:-.02em;margin-bottom:4px;font-size:1.3rem;font-weight:700}.challenges-panel-subtitle{color:var(--text-muted);font-size:.9rem;line-height:1.5}.challenges-cards-grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;display:grid}.challenge-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:inherit;transition:all var(--transition-smooth);align-items:flex-start;gap:18px;padding:24px;text-decoration:none;display:flex;position:relative;overflow:hidden}.challenge-card:before{content:"";opacity:0;transition:opacity var(--transition-smooth);position:absolute;inset:0}.quiz-card-challenge:before{background:linear-gradient(135deg,#6366f10a,#0000)}.terminal-card-challenge:before{background:linear-gradient(135deg,#10b9810a,#0000)}.challenge-card:hover{border-color:var(--accent-indigo);box-shadow:var(--shadow-hover);transform:translateY(-2px)}.challenge-card:hover:before{opacity:1}.terminal-card-challenge:hover{border-color:var(--accent-teal)}.challenge-card-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.quiz-icon{background:var(--accent-indigo-soft);color:var(--accent-indigo);border:1px solid #6366f133}.terminal-icon{background:var(--accent-teal-soft);color:var(--accent-teal);border:1px solid #10b98133}.challenge-card-body{flex:1;min-width:0}.challenge-card-title{color:var(--text-primary);letter-spacing:-.01em;margin-bottom:6px;font-size:.95rem;font-weight:700}.challenge-card-desc{color:var(--text-muted);margin-bottom:14px;font-size:.82rem;line-height:1.5}.challenge-card-meta{align-items:center;gap:8px;display:flex}.challenge-xp-badge{font-size:.72rem;font-weight:700;font-family:var(--font-mono);background:var(--accent-indigo-soft);color:var(--accent-indigo);border:1px solid #6366f133;border-radius:100px;padding:3px 10px}.challenge-xp-badge.terminal{background:var(--accent-teal-soft);color:var(--accent-teal);border-color:#10b98133}.challenge-status-badge{border-radius:100px;padding:3px 10px;font-size:.72rem;font-weight:600}.challenge-status-badge.pending{background:var(--bg-tertiary);color:var(--text-muted);border:1px solid var(--border-color)}.challenge-status-badge.done{color:var(--accent-teal);background:#10b9811a;border:1px solid #10b98140}.challenges-panel-footer{justify-content:flex-end;display:flex}.btn-complete-module{background:var(--text-primary);color:var(--bg-primary);border-radius:var(--radius-md);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-smooth);border:none;align-items:center;gap:10px;padding:14px 28px;font-size:.9rem;font-weight:700;display:inline-flex;box-shadow:0 4px 12px #00000026}.btn-complete-module:hover{opacity:.88;transform:translateY(-1px);box-shadow:0 8px 20px #0003}@media (width<=768px){.challenges-cards-grid{grid-template-columns:1fr}.module-challenges-panel{padding:24px 20px 48px}}.animate-fade-in{animation:.25s ease-out forwards fadeIn}.animate-slide-down{animation:.3s cubic-bezier(.16,1,.3,1) forwards slideDown}.animate-slide-up{animation:.3s cubic-bezier(.16,1,.3,1) forwards slideUp}.hidden{display:none!important}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(30px)}}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-6px)}40%,80%{transform:translate(6px)}}@keyframes cursorBlink{0%,to{color:var(--accent-teal)}50%{color:#0000}}@keyframes completionPulse{0%{transform:scale(1);box-shadow:0 0 12px #10b9814d}to{transform:scale(1.03);box-shadow:0 0 24px #10b98199}}@keyframes oauthScaleUp{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media (width<=1100px){.dash-content-split{grid-template-columns:1fr}.reader-split-layout{grid-template-columns:1fr 240px}}@media (width<=960px){.profile-grid{grid-template-columns:1fr}.module-syll-card{flex-direction:column}.module-card-right{border-left:none;border-top:1px solid var(--border-color);width:100%;padding-top:16px;padding-left:0;justify-content:flex-start!important}.reader-split-layout{grid-template-rows:auto auto;grid-template-columns:1fr}.reader-sidebar-navigation{border-left:none;border-top:1px solid var(--border-color);order:2;max-height:220px}.reader-content-pane{order:1}.module-reader-topbar .back-link{display:inline-flex}.module-header-badges .sections-badge{display:none}}@media (width<=768px){.main-content-area{padding:24px 20px}.navbar-container{border-top:none;border-left:none;border-right:none;border-radius:0;margin:0;padding:12px 20px;top:0}.nav-menu{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);opacity:0;pointer-events:none;flex-direction:column;gap:0;width:100%;padding:8px 0;transition:all .3s;position:fixed;top:61px;left:0;transform:translateY(-150%)}.nav-menu.open{opacity:1;pointer-events:all;transform:translateY(0)}.nav-item{text-align:center;border-radius:0;width:100%;padding:12px 20px}.mobile-menu-btn{cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:space-between;width:22px;height:16px;display:flex}.mobile-menu-btn span{background-color:var(--text-primary);border-radius:1px;width:100%;height:2px;transition:all .2s;display:block}.mobile-menu-btn.open span:first-child{transform:rotate(45deg)translate(5px,5px)}.mobile-menu-btn.open span:nth-child(2){opacity:0}.mobile-menu-btn.open span:nth-child(3){transform:rotate(-45deg)translate(5px,-5px)}.nav-stats{display:none}.course-card-horizontal{flex-direction:column}.course-banner-lpic{border-right:none;border-bottom:1px solid var(--border-color);width:100%;height:80px}.module-card-left{flex-direction:column;gap:16px}.quiz-card,.profile-card-main,.profile-settings-card{padding:24px}.module-reader-topbar{gap:10px;padding:10px 16px}.module-header-badges{display:none}.reader-pages-container{padding:24px 20px}.reader-footer-nav{gap:10px;padding:16px 20px}.reader-nav-btn{padding:8px 16px;font-size:.8rem}}.sidebar-challenges-divider{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;border-bottom:1px dashed var(--border-color);opacity:.8;margin-top:24px;margin-bottom:12px;padding-bottom:8px;font-size:.7rem;font-weight:700}.reader-step-tab.challenge-tab{border:1px solid #0000;margin-top:4px}.reader-step-tab.challenge-tab.locked{opacity:.5;cursor:not-allowed}.reader-step-tab.challenge-tab.locked .step-title{color:var(--text-muted)}.reader-step-tab.challenge-tab.locked:hover{box-shadow:none!important;background-color:#0000!important;border-color:#0000!important;transform:none!important}.reader-step-tab.challenge-tab .step-badge.challenge-badge{background-color:var(--bg-tertiary);border-color:var(--border-color);font-size:.95rem}.reader-step-tab.challenge-tab.active .step-badge.challenge-badge{background-color:var(--accent-indigo);color:#fff;border-color:var(--accent-indigo)}.reader-step-tab.challenge-tab.read .step-badge.challenge-badge{background-color:var(--accent-teal-soft);color:var(--accent-teal);border-color:#10b98133}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:12px;width:calc(100% - 48px);max-width:380px;display:flex;position:fixed;top:24px;right:24px}.toast-card{-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:var(--radius-md);pointer-events:all;background-color:#0f172af2;align-items:flex-start;gap:14px;padding:16px 20px;transition:all .3s;animation:.35s cubic-bezier(.16,1,.3,1) forwards toastSlideIn;display:flex;box-shadow:0 10px 25px -5px #0000004d,0 8px 10px -6px #0000004d}.toast-card.success{border-left:4px solid var(--accent-teal);box-shadow:0 4px 20px #10b98126}.toast-card.warning{border-left:4px solid var(--accent-yellow);box-shadow:0 4px 20px #f59e0b26}.toast-card.error{border-left:4px solid var(--accent-red);box-shadow:0 4px 20px #ef444426}.toast-card.info{border-left:4px solid var(--accent-indigo);box-shadow:0 4px 20px #6366f126}.toast-icon{flex-shrink:0;margin-top:2px;font-size:1.25rem;line-height:1}.toast-content{font-family:var(--font-sans);color:var(--text-primary);flex-grow:1;font-size:.9rem;font-weight:500;line-height:1.5}.toast-close-btn{color:var(--text-muted);cursor:pointer;transition:color var(--transition-smooth);background:0 0;border:none;padding:0 0 0 8px;font-size:1.25rem;line-height:1}.toast-close-btn:hover{color:var(--text-primary)}.toast-card.slide-out{animation:.3s forwards toastSlideOut}@keyframes toastSlideIn{0%{opacity:0;transform:translate(120%)translateY(-10px)}to{opacity:1;transform:translate(0)translateY(0)}}@keyframes toastSlideOut{0%{opacity:1;transform:translate(0)scale(1)}to{opacity:0;transform:translate(120%)scale(.9)}}.course-part-title{color:var(--text-primary);border-bottom:1px dashed var(--border-color);letter-spacing:-.01em;align-items:center;gap:10px;margin:32px 0 16px;padding-bottom:10px;font-size:1.2rem;font-weight:700;display:flex}.course-part-title:before{content:"";background:linear-gradient(180deg, var(--accent-indigo), var(--accent-teal));border-radius:2px;flex-shrink:0;width:4px;height:1.1em;display:inline-block}.collapsible-section-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--transition-smooth)}.collapsible-section-header:hover,.collapsible-section-header:hover .section-chevron{color:var(--accent-indigo)}.section-toggle-meta{flex-shrink:0;align-items:center;gap:10px;margin-left:auto;display:flex}.section-module-count{color:var(--text-muted);background:var(--bg-tertiary);border:1px solid var(--border-color);font-size:.72rem;font-weight:600;font-family:var(--font-mono);border-radius:99px;padding:2px 10px}.section-chevron{color:var(--text-muted);flex-shrink:0;transition:transform .25s}.collapsible-list{opacity:1;max-height:9999px;transition:max-height .38s,opacity .28s;overflow:hidden}.collapsible-list.collapsed{opacity:0;max-height:0!important}.side-badge-card.locked-obj{opacity:.52;background-color:var(--bg-tertiary);border-style:dashed}.side-badge-card.locked-obj:hover{opacity:.72;transform:none}.nav-avatar:hover,.dash-avatar:hover{transform:scale(1.08);box-shadow:0 6px 20px #6366f173}.exam-landing-container{max-width:860px;margin:48px auto;padding:0 24px 60px}.exam-hero-header{text-align:center;margin-bottom:48px}.exam-landing-badge{color:var(--accent-indigo);letter-spacing:.1em;text-transform:uppercase;background:#6366f11a;border:1px solid #6366f14d;border-radius:999px;align-items:center;gap:6px;margin-bottom:20px;padding:5px 14px;font-size:.72rem;font-weight:700;display:inline-flex}.exam-landing-title{letter-spacing:-.04em;color:var(--text-primary);margin:0 0 16px;font-size:2.6rem;font-weight:900;line-height:1.1}.exam-title-accent{background:linear-gradient(135deg, var(--accent-indigo) 0%, #a78bfa 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.exam-landing-desc{color:var(--text-secondary);text-align:center;max-width:600px;margin:0 auto 28px;font-size:1rem;line-height:1.7}.exam-stats-row{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.exam-stat-pill{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-muted);border-radius:999px;align-items:center;gap:6px;padding:7px 16px;font-size:.8rem;font-weight:600;display:inline-flex}.exam-stat-pill svg{opacity:.7}.exam-modes-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}.exam-mode-card{cursor:pointer;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--bg-secondary);transition:all var(--transition-smooth);-webkit-backdrop-filter:blur(12px);position:relative;overflow:hidden}.exam-mode-card:hover{background:#6366f105;border-color:#6366f180;transform:translateY(-6px);box-shadow:0 20px 40px #6366f114}.dark-theme .exam-mode-card:hover{background:#6366f10a}.exam-mode-card.real-exam-card:hover{background:#f59e0b05;border-color:#f59e0b80;box-shadow:0 20px 40px #f59e0b14}.dark-theme .exam-mode-card.real-exam-card:hover{background:#f59e0b0a}.card-header-badge{text-transform:uppercase;letter-spacing:.05em;border:1px solid #0000;border-radius:99px;padding:4px 10px;font-size:.68rem;font-weight:700;line-height:1;position:absolute;top:24px;right:24px}.study-badge{background:var(--accent-indigo-soft);color:var(--accent-indigo);border-color:#6366f133}.real-badge{color:#f59e0b;background:#f59e0b14;border-color:#f59e0b33}.exam-mode-card-inner{flex-direction:column;height:100%;padding:32px 28px 28px;display:flex}.exam-mode-icon{width:54px;height:54px;transition:all var(--transition-smooth);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;margin-bottom:20px;display:flex}.study-icon{color:var(--accent-indigo);background:#6366f114;border:1px solid #6366f133}.real-icon{color:#f59e0b;background:#f59e0b14;border:1px solid #f59e0b33}.exam-mode-card:hover .exam-mode-icon{transform:scale(1.08)}.exam-mode-card:hover .study-icon{background:var(--accent-indigo);border-color:var(--accent-indigo);color:#fff;box-shadow:0 0 18px #6366f173}.exam-mode-card.real-exam-card:hover .real-icon{color:#fff;background:#f59e0b;border-color:#f59e0b;box-shadow:0 0 18px #f59e0b66}.exam-mode-body{flex:1}.exam-mode-title{color:var(--text-primary);letter-spacing:-.02em;margin:0 0 10px;font-size:1.3rem;font-weight:800}.exam-mode-desc{color:var(--text-muted);text-align:left;margin:0 0 18px;font-size:.875rem;line-height:1.65}.exam-mode-features{flex-direction:column;gap:7px;margin:0 0 28px;padding:0;list-style:none;display:flex}.exam-mode-features li{color:var(--text-muted);text-align:left;align-items:center;gap:8px;font-size:.8rem;display:flex}.exam-mode-features li:before{content:"";background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236366f1' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:contain;flex-shrink:0;width:14px;height:14px;display:inline-block}.dark-theme .exam-mode-features li:before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2358a6ff' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E")}.exam-mode-card.real-exam-card .exam-mode-features li:before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f59e0b' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E")}.exam-mode-btn{border-radius:var(--radius-md);cursor:pointer;width:100%;transition:all var(--transition-smooth);letter-spacing:.01em;border:none;justify-content:center;align-items:center;gap:8px;margin-top:auto;padding:13px 20px;font-family:inherit;font-size:.9rem;font-weight:700;display:flex}.exam-mode-btn.study-btn{background:linear-gradient(135deg, var(--accent-indigo) 0%, #7c3aed 100%);color:#fff;box-shadow:0 4px 14px #6366f14d}.exam-mode-btn.study-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #6366f180}.exam-mode-btn.real-btn{color:#fff;background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);box-shadow:0 4px 14px #f59e0b4d}.exam-mode-btn.real-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #f59e0b80}.exam-mode-btn svg{transition:transform .2s}.exam-mode-btn:hover svg{transform:translate(3px)}@media (width<=680px){.exam-modes-grid{grid-template-columns:1fr}.exam-landing-title{font-size:1.9rem}}.profile-ranks-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-flat);-webkit-backdrop-filter:blur(16px);margin-top:32px;padding:32px}.profile-ranks-card h3{margin-bottom:20px;font-size:1.25rem;font-weight:700}.profile-ranks-card .card-subtitle{color:var(--text-muted);margin-top:-12px;margin-bottom:24px;font-size:.85rem;line-height:1.5}.table-responsive-wrapper{border-radius:var(--radius-md);border:1px solid var(--border-color);overflow-x:auto}.ranks-table{border-collapse:collapse;text-align:left;width:100%;font-size:.9rem}.ranks-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background-color:var(--bg-tertiary);border-bottom:1px solid var(--border-color);padding:14px 20px;font-size:.8rem;font-weight:700}.ranks-table td{color:var(--text-secondary);border-bottom:1px solid var(--border-color);transition:all var(--transition-smooth);padding:14px 20px}.ranks-table tr.current-rank-row td{color:var(--text-primary);border-bottom:1px solid var(--accent-indigo);border-top:1px solid var(--accent-indigo);background-color:#6366f114;font-weight:700}.ranks-table tr.current-rank-row{box-shadow:inset 4px 0 0 var(--accent-indigo)}.status-pill{border-radius:99px;padding:4px 10px;font-size:.72rem;font-weight:600;display:inline-block}.status-pill.current{background-color:var(--accent-indigo-soft);color:var(--accent-indigo);border:1px solid #6366f14d;font-weight:700}.status-pill.completed{background-color:var(--accent-teal-soft);color:var(--accent-teal);border:1px solid #10b98133}.status-pill.pending{color:var(--text-muted);background-color:#0000;border:none}.welcome-header-line{flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:16px;display:flex}.tip-content{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.tip-label{font-family:var(--font-mono);color:var(--accent-teal);text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;font-weight:700;display:block}#dynamic-tip{opacity:1;color:var(--text-secondary);font-size:.85rem;line-height:1.5;transition:opacity .35s}.welcome-badge{flex-shrink:0;position:relative}.dash-avatar{background:linear-gradient(135deg, var(--accent-indigo) 0%, var(--accent-teal) 100%);color:#fff;width:64px;height:64px;font-family:var(--font-sans);border:2.5px solid var(--border-color);transition:all var(--transition-smooth);border-radius:50%;justify-content:center;align-items:center;font-size:1.4rem;font-weight:800;display:flex;box-shadow:0 4px 14px #6366f14d}.status-indicator-dot{background-color:var(--accent-teal);border:2.5px solid var(--bg-primary);width:14px;height:14px;transition:background-color var(--transition-smooth);border-radius:50%;position:absolute;bottom:2px;right:2px;box-shadow:0 0 10px #10b98166}.stat-icon-wrapper{border-radius:var(--radius-md);width:48px;height:48px;box-shadow:var(--shadow-flat);transition:all var(--transition-smooth);flex-shrink:0;justify-content:center;align-items:center;font-size:1.3rem;display:flex}.stat-icon-wrapper.xp-icon{background-color:var(--accent-teal-soft);color:var(--accent-teal);border:1px solid #10b98133}.stat-icon-wrapper.level-icon{background-color:var(--accent-indigo-soft);color:var(--accent-indigo);border:1px solid #6366f133}.stat-icon-wrapper.modules-icon{color:var(--accent-amber);background-color:#d9770614;border:1px solid #d9770633}.stat-card:hover .stat-icon-wrapper{transform:scale(1.1)}.daily-objectives-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-flat);-webkit-backdrop-filter:blur(16px);text-align:left;transition:all var(--transition-smooth);margin-bottom:24px;padding:24px}.daily-objectives-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.daily-objectives-header h3{color:var(--text-primary);align-items:center;gap:8px;margin:0;font-size:.95rem;font-weight:700;display:flex}.daily-count-badge{font-family:var(--font-mono);color:var(--accent-indigo);background:var(--accent-indigo-soft);border:1px solid #6366f133;border-radius:99px;padding:2px 8px;font-size:.72rem;font-weight:700}.daily-progress-track{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:100px;height:6px;margin-bottom:20px;overflow:hidden}.daily-progress-fill{background:linear-gradient(90deg, var(--accent-indigo), var(--accent-teal));border-radius:100px;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.daily-tasks-list{flex-direction:column;gap:10px;display:flex}.daily-task-item{border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--border-color);align-items:center;gap:14px;padding:12px 14px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.daily-task-item.done{background:var(--accent-teal-soft);border-color:#10b98126}.daily-task-item:hover{border-color:var(--text-muted);transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.daily-task-item.done:hover{border-color:var(--accent-teal)}.task-emoji{transition:transform var(--transition-smooth);font-size:1.15rem}.daily-task-item:hover .task-emoji{transform:scale(1.15)}.task-info{flex-grow:1;min-width:0}.task-name{color:var(--text-primary);transition:color var(--transition-smooth);margin:0;font-size:.82rem;font-weight:700}.daily-task-item.done .task-name{color:var(--accent-teal);opacity:.85;text-decoration:line-through}.task-desc{color:var(--text-muted);margin:2px 0 0;font-size:.72rem;line-height:1.4}.task-check-circle{border:2px solid var(--border-color);color:#fff;width:20px;height:20px;transition:all var(--transition-smooth);background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.daily-task-item.done .task-check-circle{background-color:var(--accent-teal);border-color:var(--accent-teal);box-shadow:0 0 8px #10b98166}.daily-footer-notice{color:var(--text-muted);text-align:center;margin:14px 0 0;font-size:.68rem;line-height:1.4}.nav-avatar-btn{align-items:center;text-decoration:none;display:flex}.nav-avatar-circle{background:linear-gradient(135deg, var(--accent-indigo) 0%, var(--accent-teal) 100%);color:#fff;border:1.5px solid var(--border-color);width:32px;height:32px;transition:all var(--transition-smooth);border-radius:50%;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:flex}.nav-avatar-btn:hover .nav-avatar-circle{border-color:var(--accent-indigo);transform:scale(1.05)}.nav-avatar-circle.active-avatar{border-color:var(--accent-indigo);box-shadow:0 0 0 2px #58a6ff4d}.nav-logout-btn{width:32px;height:32px;color:var(--text-secondary);border:1px solid var(--border-color);background-color:var(--bg-tertiary);transition:all var(--transition-smooth);border-radius:50%;justify-content:center;align-items:center;display:flex}.nav-logout-btn:hover{color:var(--accent-red);background-color:#e11d4814;border-color:#e11d4866;transform:scale(1.05)}
