.navbar-notifications{position:relative;display:inline-flex;align-items:center}.navbar-notif-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;background:transparent;border:1px solid transparent;border-radius:8px;color:var(--text-secondary, #9ca3af);cursor:pointer;padding:0;transition:all .15s}.navbar-notif-btn:hover{color:var(--text-primary, #fff);background:#ffffff0d;border-color:var(--border-color, #2a2f3a)}.navbar-notif-icon{width:18px;height:18px}.navbar-notif-badge{position:absolute;top:-2px;right:-2px;min-width:18px;height:18px;padding:0 5px;background:#ef4444;color:#fff;border-radius:9px;font-size:.7rem;font-weight:700;line-height:18px;text-align:center;box-shadow:0 0 0 2px var(--bg-color, #0f1117)}.navbar-notif-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:340px;max-height:480px;overflow-y:auto;background:var(--card-bg, #161922);border:1px solid var(--border-color, #2a2f3a);border-radius:10px;box-shadow:0 10px 30px #0006;z-index:1000}.navbar-notif-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border-color, #2a2f3a);font-size:.85rem;font-weight:700;color:var(--text-primary, #fff)}.navbar-notif-section{padding:.5rem 0;border-bottom:1px solid var(--border-color, #2a2f3a)}.navbar-notif-section:last-child{border-bottom:none}.navbar-notif-section-title{padding:.4rem 1rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary, #9ca3af)}.navbar-notif-item{display:block;padding:.6rem 1rem;text-decoration:none;color:var(--text-primary, #fff);border-left:3px solid transparent;transition:background .15s,border-color .15s}.navbar-notif-item:hover{background:#ffffff0a;border-left-color:var(--primary-color, #38bdf8);text-decoration:none;color:var(--text-primary, #fff)}.navbar-notif-item-title{font-size:.875rem;font-weight:600;color:var(--text-primary, #fff);margin-bottom:.2rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar-notif-item-meta{display:flex;align-items:center;justify-content:space-between;gap:.5rem;font-size:.75rem;color:var(--text-secondary, #9ca3af)}.navbar-notif-item-class{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.navbar-notif-item-progress{font-weight:600;color:var(--text-secondary, #9ca3af);flex-shrink:0}.navbar-notif-item-due{margin-top:.25rem;font-size:.72rem;color:var(--text-secondary, #9ca3af)}.navbar-notif-item-due.late{color:#f59e0b;font-weight:600}@media (max-width: 600px){.navbar-notif-dropdown{width:290px;right:-40px}}.navbar-notif-dismiss{background:none;border:none;color:var(--text-secondary);font-size:1.1rem;line-height:1;cursor:pointer;padding:0 .2rem;margin-left:auto;flex-shrink:0;opacity:.5;transition:opacity .15s,color .15s}.navbar-notif-dismiss:hover{opacity:1;color:var(--text-primary)}.navbar-notif-item-title{display:flex;align-items:center;gap:.35rem}.navbar-notif-mark-read{background:none;border:none;color:var(--primary-color, #00b509);font-size:.7rem;font-weight:600;cursor:pointer;padding:0;margin-left:auto;transition:opacity .15s}.navbar-notif-mark-read:hover{opacity:.7}.cspp-setpw-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000c7;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.cspp-setpw-modal{background:var(--bg-secondary, #1e1e2e);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:1.75rem 2rem;max-width:440px;width:100%;animation:cspp-setpw-fade-in .22s ease;box-shadow:0 12px 40px #00000080;box-sizing:border-box}@keyframes cspp-setpw-fade-in{0%{opacity:0;transform:translateY(-12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.cspp-setpw-title{font-size:1.35rem;font-weight:700;color:var(--text-primary, #e0e0e0);margin:0 0 .4rem}.cspp-setpw-subtitle{font-size:.9rem;color:var(--text-secondary, #aaa);line-height:1.5;margin:0 0 1.25rem}.cspp-setpw-subtitle strong{color:var(--text-primary, #e0e0e0);font-weight:600}.cspp-setpw-form{display:flex;flex-direction:column;gap:.9rem}.cspp-setpw-field label{display:block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary, #aaa);margin-bottom:.35rem}.cspp-setpw-input-row{position:relative;display:flex;align-items:stretch}.cspp-setpw-field input{width:100%;padding:.65rem .85rem;font-size:.95rem;border:1px solid var(--border-color, rgba(255, 255, 255, .14));border-radius:8px;background:var(--bg-color, #121212);color:var(--text-primary, #e0e0e0);outline:none;transition:border-color .15s,box-shadow .15s;box-sizing:border-box;font-family:inherit}.cspp-setpw-field input:focus{border-color:var(--primary-color, #00b509);box-shadow:0 0 0 3px #00b5092e}.cspp-setpw-field input[aria-invalid=true]{border-color:#e74c3c}.cspp-setpw-input-row input{padding-right:3.75rem}.cspp-setpw-toggle{position:absolute;right:.4rem;top:50%;transform:translateY(-50%);background:transparent;border:0;color:var(--text-secondary, #aaa);font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;line-height:1;padding:.35rem .5rem;cursor:pointer;border-radius:5px}.cspp-setpw-toggle:hover{background:#ffffff14}.cspp-setpw-hint{font-size:.75rem;color:var(--text-secondary, #aaa);margin:.3rem 0 0;line-height:1.4}.cspp-setpw-hint.error{color:#e74c3c}.cspp-setpw-error{font-size:.85rem;color:#e74c3c;margin:0;padding:.55rem .75rem;background:#e74c3c14;border:1px solid rgba(231,76,60,.25);border-radius:6px}.cspp-setpw-actions{display:flex;gap:.75rem;margin-top:.25rem}.cspp-setpw-submit{flex:1;padding:.7rem 1rem;font-size:.95rem;font-weight:600;border-radius:8px;border:0;background:var(--primary-color, #00b509);color:#fff;cursor:pointer;transition:background .15s,transform .1s}.cspp-setpw-submit:hover:not(:disabled){background:var(--primary-hover, #009808)}.cspp-setpw-submit:active:not(:disabled){transform:translateY(1px)}.cspp-setpw-submit:disabled{opacity:.5;cursor:not-allowed}.cspp-setpw-footnote{font-size:.75rem;color:var(--text-secondary, #aaa);opacity:.75;text-align:center;margin:.5rem 0 0}@media (max-width: 480px){.cspp-setpw-modal{padding:1.4rem 1.25rem}.cspp-setpw-title{font-size:1.2rem}}.navbar{background-color:#000;border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:1000}.navbar-container{max-width:1600px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;height:56px;gap:.75rem;min-width:0}.navbar-brand{font-size:1.125rem;font-weight:700;color:var(--primary-color)!important;text-decoration:none!important;letter-spacing:-.3px;flex-shrink:0;white-space:nowrap}.navbar-brand:hover{color:var(--primary-hover)!important;text-decoration:none!important}.brand-cs{color:var(--primary-color)}.navbar-brand-short{display:none}.navbar-brand-full{display:inline}.navbar-spacer{flex:1;min-width:0}.navbar-links{display:flex;align-items:center;gap:.125rem;flex-shrink:0}.navbar-link{display:flex;align-items:center;gap:.375rem;color:var(--text-secondary);text-decoration:none;padding:.4rem .75rem;border-radius:6px;font-size:.9rem;font-weight:500;transition:all .15s;white-space:nowrap}.navbar-link:hover{color:var(--text-primary);background-color:#ffffff1f;text-decoration:none}.navbar-link.active{color:var(--primary-color);background-color:#00b5091a}.nav-icon{font-size:1rem;line-height:1;flex-shrink:0}.nav-icon-exit{font-size:1.1rem;font-style:normal;font-weight:600;transform:rotate(-45deg);display:inline-block;line-height:1}.navbar-user{display:flex;align-items:center;gap:.625rem;flex-shrink:0;margin-left:.25rem;padding-left:.75rem;border-left:1px solid var(--border-color)}.navbar-username{font-size:.875rem;color:var(--text-secondary);white-space:nowrap}.navbar-logout{display:flex;align-items:center;gap:.375rem;background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);padding:.35rem .75rem;border-radius:6px;font-size:.875rem;cursor:pointer;transition:all .15s;white-space:nowrap}.navbar-logout:hover{border-color:var(--text-secondary);color:var(--text-primary)}.navbar-game-btn{display:flex;align-items:center;justify-content:center;font-size:1.05rem;line-height:1;color:var(--text-secondary);text-decoration:none!important;padding:.3rem .4rem;border-radius:6px;transition:all .15s;flex-shrink:0;position:relative}.navbar-game-btn:hover{background-color:#ffffff1f;color:var(--text-primary);text-decoration:none!important}.navbar-settings-btn{display:flex;align-items:center;justify-content:center;font-size:1.05rem;line-height:1;color:var(--text-secondary);text-decoration:none;padding:.3rem .4rem;border-radius:6px;transition:all .15s;flex-shrink:0;position:relative}.navbar-settings-btn:hover{background-color:#ffffff1f;color:var(--text-primary);text-decoration:none}.navbar-settings-btn.active{color:var(--primary-color);background-color:#00b5091a}.navbar-email-badge{position:absolute;top:2px;right:2px;min-width:14px;height:14px;padding:0 3px;background:#ef4444;color:#fff;font-size:.6rem;font-weight:700;line-height:14px;border-radius:7px;text-align:center;pointer-events:none}.navbar-game-btn:hover:after,.navbar-settings-btn:hover:after{content:attr(title);position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:4px;padding:.3rem .6rem;background:#222;color:#fff;font-size:.75rem;font-weight:500;border-radius:4px;white-space:nowrap;pointer-events:none;z-index:1001;box-shadow:0 2px 8px #0006}.navbar-guest{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.navbar-btn-login{display:inline-flex;align-items:center;background:var(--primary-color);color:#000!important;text-decoration:none!important;font-size:.875rem;font-weight:600;padding:.4rem 1rem;border-radius:6px;transition:background .15s;white-space:nowrap}.navbar-btn-login:hover{background:var(--primary-hover);text-decoration:none!important}.navbar-hci{border-bottom-color:#6c3fc766}.navbar-course-switcher{position:relative;border-left:1px solid var(--border-color);margin-left:.25rem;padding-left:.25rem}.navbar-course-toggle{display:flex;align-items:center;gap:.375rem;background:transparent;border:1px solid transparent;color:var(--text-secondary);padding:.35rem .6rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.navbar-course-toggle:hover{color:var(--text-primary);background:#ffffff1f;border-color:var(--border-color)}.navbar-course-chevron{font-size:.5rem;opacity:.6;margin-left:-.1rem}.navbar-course-dropdown{position:absolute;top:calc(100% + 6px);right:0;background:#1a1a1a;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:.35rem;min-width:210px;z-index:1002;box-shadow:0 8px 30px #00000080,0 2px 8px #0000004d}.navbar-course-option{display:flex;align-items:center;gap:.65rem;padding:.6rem .75rem;border-radius:7px;text-decoration:none!important;color:var(--text-secondary);transition:all .12s}.navbar-course-option:hover{background:#ffffff1f;color:var(--text-primary);text-decoration:none!important}.navbar-course-option.active{background:#00b50914;color:var(--text-primary)}.navbar-course-option-icon{font-size:1.15rem;line-height:1;flex-shrink:0}.navbar-course-option-text{display:flex;flex-direction:column;gap:.05rem;flex:1;min-width:0}.navbar-course-option-label{font-size:.85rem;font-weight:600;color:inherit}.navbar-course-option-desc{font-size:.7rem;color:var(--text-secondary);opacity:.7}.navbar-course-check{font-size:.75rem;color:#00b509;font-weight:700;flex-shrink:0}.navbar-course-divider{height:1px;background:#ffffff14;margin:.25rem .5rem}.navbar-tools-hr{border:0;border-top:1px solid rgba(255,255,255,.08);margin:.35rem .5rem}.navbar-tools-dropdown{display:none;position:relative}.navbar-tools-toggle{display:flex;align-items:center;gap:.375rem;background:transparent;border:1px solid transparent;color:var(--text-secondary);padding:.35rem .6rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.navbar-tools-label-text{display:inline}.navbar-tools-toggle:hover{color:var(--text-primary);background:#ffffff1f;border-color:var(--border-color)}.navbar-tools-toggle.has-active{color:var(--primary-color);background-color:#00b5091a}.navbar-tools-chevron{font-size:.5rem;opacity:.6;margin-left:-.1rem}.navbar-tools-panel{position:absolute;top:calc(100% + 6px);left:0;background:#1a1a1a;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:.35rem;min-width:200px;z-index:1002;box-shadow:0 8px 30px #00000080,0 2px 8px #0000004d}.navbar-tools-option{display:flex;align-items:center;gap:.65rem;padding:.55rem .75rem;border-radius:7px;text-decoration:none!important;color:var(--text-secondary);transition:all .12s;white-space:nowrap}.navbar-tools-option:hover{background:#ffffff1f;color:var(--text-primary);text-decoration:none!important}.navbar-tools-option.active{background:#00b50914;color:var(--primary-color)}.navbar-tools-option-icon{font-size:1rem;line-height:1;flex-shrink:0}.navbar-tools-option-label{font-size:.85rem;font-weight:500}.navbar-teachers-dropdown{position:relative}.navbar-teachers-toggle{display:flex;align-items:center;gap:.375rem;background:transparent;border:1px solid transparent;color:var(--text-secondary);padding:.35rem .6rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.navbar-teachers-toggle:hover{color:var(--text-primary);background:#ffffff1f;border-color:var(--border-color)}.navbar-teachers-toggle.has-active{color:var(--primary-color);background-color:#00b5091a}.navbar-compact .navbar-brand-full{display:none}.navbar-compact .navbar-brand-short{display:inline}.navbar-tools-collapsed .navbar-tool-link{display:none}.navbar-tools-collapsed .navbar-tools-dropdown{display:flex}.navbar-all-collapsed .navbar-keepvisible-link,.navbar-all-collapsed .navbar-guest-course-link,.navbar-all-collapsed .navbar-teachers-dropdown .nav-label,.navbar-all-collapsed .navbar-tools-label-text,.navbar-minimal .navbar-course-toggle .nav-label{display:none}@media (max-width: 900px){.navbar-tool-link{display:none}.navbar-tools-dropdown{display:flex}}@media (max-width: 700px){.navbar-brand-full{display:none}.navbar-brand-short{display:inline}}@media (max-width: 640px){.navbar-keepvisible-link,.navbar-guest-course-link,.navbar-teachers-dropdown .nav-label,.navbar-tools-label-text{display:none}}@media (max-width: 640px){.navbar-container{padding:0 .75rem;gap:.25rem}.navbar-username{display:none}.navbar-link{padding:.4rem .5rem}.navbar-link .nav-icon{display:none}.navbar-user{padding-left:.5rem;gap:0}.navbar-notifications~.navbar-game-btn{display:none}}@media (max-width: 360px){.navbar-container{padding:0 .5rem;gap:.125rem}.navbar-link{padding:.35rem}.navbar-user{padding-left:.35rem}}.site-footer{padding:2.5rem 2rem 1.5rem;border-top:1px solid var(--border-color);color:var(--text-secondary);font-size:.85rem;margin-top:auto}.footer-ap-disclaimer{text-align:center;font-size:.75rem;color:var(--text-secondary);opacity:.75;margin-top:.75rem;padding:0 1rem;line-height:1.4;max-width:720px;margin-left:auto;margin-right:auto}.footer-brand{text-align:center;font-size:.9rem;font-weight:600;color:#fff;margin-bottom:1.75rem}.footer-columns{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem 2rem;max-width:800px;margin:0 auto 1.75rem}.footer-col{display:flex;flex-direction:column;gap:.4rem}.footer-col-heading{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#00b509;margin:0 0 .5rem;padding-bottom:.4rem;border-bottom:1px solid rgba(0,181,9,.2)}.footer-col a{color:var(--text-secondary);text-decoration:none;font-size:.82rem;transition:color .2s;line-height:1.6}.footer-col a:hover{color:var(--primary-color)}.footer-bottom{text-align:center;font-size:.75rem;color:var(--text-secondary);opacity:.6;padding-top:1.25rem;border-top:1px solid var(--border-color);display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:.5rem 1.25rem}.footer-legal-links{display:inline-flex;align-items:center;flex-wrap:wrap;gap:.25rem}.footer-legal-links a{color:inherit;text-decoration:none}.footer-legal-links a:hover{text-decoration:underline}@media (max-width: 640px){.site-footer{padding:2rem 1.25rem 1.25rem}.footer-columns{grid-template-columns:repeat(2,1fr);gap:1.25rem 1.5rem}}@media (max-width: 380px){.footer-columns{grid-template-columns:1fr;gap:1.25rem}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #00b509;--primary-hover: #009a07;--secondary-color: #94a3b8;--success-color: #10b981;--error-color: #ef4444;--warning-color: #f59e0b;--bg-color: #111111;--bg-secondary: #000000;--text-primary: #e4e4e7;--text-secondary: #a1a1aa;--border-color: #2e2e2e;--shadow: 0 1px 3px 0 rgba(0, 0, 0, .4), 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -2px rgba(0, 0, 0, .3)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-secondary);color:var(--text-primary);line-height:1.6}.App{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1}.skip-to-content{position:absolute;top:-100px;left:0;padding:.75rem 1.25rem;background:var(--primary-color);color:#000;font-weight:700;text-decoration:none;border-radius:0 0 6px;z-index:10000;transition:top .15s ease-in-out}.skip-to-content:focus{top:0;outline:3px solid #fff;outline-offset:-3px}.main-content:focus{outline:none}:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px;border-radius:2px}code{font-family:Courier New,Courier,monospace;background-color:#2a2a2a;padding:2px 6px;border-radius:4px;font-size:.9em}select{color-scheme:dark}select option{background-color:#1a1a1a;color:#e4e4e7}pre{background-color:#1e293b;color:#e2e8f0;padding:1rem;border-radius:8px;overflow-x:auto;margin:1rem 0}pre code{background-color:transparent;color:inherit;padding:0}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block;text-align:center}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.btn-secondary{background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background-color:#2e2e2e}.btn-outline{background-color:transparent;color:var(--primary-color);border:1px solid var(--primary-color)}.btn-outline:hover:not(:disabled){background-color:var(--primary-color);color:#fff}.btn-large{padding:1rem 2rem;font-size:1.125rem}.loading{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:1.125rem;color:var(--text-secondary)}.error-message{background-color:#3b1111;color:#fca5a5;padding:1rem;border-radius:8px;margin-bottom:1rem;border:1px solid #5c1a1a}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.guest-gate-wrapper{position:relative;min-height:60vh}.guest-gate-blur{filter:blur(1px);opacity:1;pointer-events:none;-webkit-user-select:none;user-select:none;max-height:80vh;overflow:hidden}.guest-gate-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(to bottom,#0000,#0000004d 40%,#000000b8);padding:2rem 1rem;z-index:10}.guest-gate-card{background:var(--bg-color);border:1px solid var(--border-color);border-radius:16px;padding:3rem 2.5rem;text-align:center;max-width:480px;width:100%;box-shadow:0 24px 60px #0009}.guest-gate-icon{font-size:3rem;margin-bottom:1rem}.guest-gate-card h2{font-size:1.75rem;font-weight:700;margin-bottom:.75rem;color:var(--text-primary)}.guest-gate-card p{color:var(--text-secondary);margin-bottom:2rem;font-size:1.05rem}.guest-gate-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}@media (max-width: 480px){.guest-gate-card{padding:2rem 1.5rem}.guest-gate-card h2{font-size:1.5rem}}.guest-gate-preview{padding:2rem;max-width:860px;margin:0 auto}.ggp-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.75rem}.ggp-title-block{display:flex;flex-direction:column;gap:.5rem}.ggp-bar{height:14px;border-radius:6px;background:var(--border-color)}.ggp-bar.wide{width:240px;background:var(--text-secondary);opacity:.5}.ggp-bar.medium{width:160px;opacity:.3}.ggp-badge{background:var(--primary-color);color:#fff;font-size:.75rem;font-weight:700;padding:.25rem .75rem;border-radius:999px;opacity:.85}.ggp-grid{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}.ggp-card{display:flex;align-items:center;gap:1rem;background:var(--bg-color);border:1px solid var(--border-color);border-radius:10px;padding:.9rem 1.1rem}.ggp-card-icon{font-size:1.4rem;flex-shrink:0}.ggp-card-body{flex:1;min-width:0}.ggp-card-label{font-weight:600;font-size:.95rem;color:var(--text-primary);margin-bottom:.15rem}.ggp-card-sub{font-size:.8rem;color:var(--text-secondary);margin-bottom:.4rem}.ggp-progress-track{height:5px;background:var(--border-color);border-radius:3px;overflow:hidden}.ggp-progress-fill{height:100%;background:var(--primary-color);border-radius:3px}.ggp-card-check{font-size:1.1rem;flex-shrink:0}.ggp-stats{display:flex;gap:1.5rem;justify-content:center;background:var(--bg-color);border:1px solid var(--border-color);border-radius:10px;padding:1rem}.ggp-stat{display:flex;flex-direction:column;align-items:center;gap:.2rem}.ggp-stat-num{font-size:1.5rem;font-weight:700;color:var(--primary-color)}.ggp-stat-lbl{font-size:.75rem;color:var(--text-secondary)}a{color:var(--primary-color);text-decoration:none}a:hover{text-decoration:underline}a[class*=-pill]:hover,a[class*=-chip]:hover,a[class*=-tag]:hover,a[class*=-badge]:hover,a.pill:hover,a.chip:hover{text-decoration:none}@media (max-width: 768px){.btn{padding:.625rem 1.25rem;font-size:.9375rem}.btn-large{padding:.875rem 1.75rem;font-size:1rem}}.qp-hero-label{display:inline-block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#a855f7;background:#a855f71f;border:1px solid rgba(168,85,247,.3);padding:.4rem 1.25rem;border-radius:999px;margin-bottom:1.25rem}.blocks-resource-pill{position:relative;color:var(--primary-color);font-weight:600;font-size:.85rem;text-decoration:none;padding:.35rem .9rem;border-radius:999px;background:#00b50914;border:1px solid rgba(0,181,9,.2);transition:background .2s,border-color .2s}.blocks-resource-pill:hover{background:#00b5092e;border-color:var(--primary-color);text-decoration:none}.blocks-resource-pill:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 10px);left:0;width:300px;font-size:.8rem;font-weight:400;color:#e2e8f0;background:linear-gradient(135deg,#0d2e0e,#0a1a0a);border:1px solid rgba(0,181,9,.3);border-radius:10px;padding:.55rem .85rem;box-shadow:0 8px 24px #0009;pointer-events:none;opacity:0;transform:translateY(4px);transition:opacity .2s,transform .2s;z-index:50;line-height:1.5}.blocks-resource-pill[data-tooltip]:hover:after{opacity:1;transform:translateY(0)}@media (max-width: 768px){.blocks-resource-pill:after{display:none}}.blocks-upsell-banner{display:flex;align-items:center;justify-content:space-between;gap:1.25rem;flex-wrap:wrap;padding:1rem 1.5rem;border-radius:10px;margin-bottom:1.5rem;background:linear-gradient(135deg,#0d2e0e,#0a1a0a);border:1px solid rgba(0,181,9,.25)}.blocks-upsell-text{flex:1 1 100%;font-size:.95rem;color:var(--text-secondary);line-height:1.5}.blocks-upsell-text strong{color:var(--text-primary)}.blocks-upsell-actions{display:flex;gap:.75rem;flex-wrap:wrap}@media (max-width: 600px){.blocks-upsell-actions{flex-direction:column}.blocks-upsell-actions .btn{text-align:center}}.blocks-course-upsell{margin-top:2rem;display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:1.25rem;background:linear-gradient(135deg,#0d0d1a,#050510);border:1px solid rgba(168,85,247,.2);border-radius:12px;padding:1.5rem}@media (max-width: 768px){.blocks-course-upsell{grid-template-columns:1fr}}.blocks-course-upsell-main h2{margin:.4rem 0 .6rem;font-size:1.4rem;color:var(--text-primary);line-height:1.3}.blocks-course-upsell-main p{margin:0 0 1rem;color:var(--text-secondary);line-height:1.6;font-size:.92rem}.blocks-course-upsell-badge{display:inline-block;background:#a855f72e;color:#a855f7;padding:.25rem .7rem;border-radius:999px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.blocks-course-upsell-actions{display:flex;gap:.6rem;flex-wrap:wrap}.blocks-course-upsell-teacher{background:#a855f70f;border:1px solid rgba(168,85,247,.2);border-radius:8px;padding:1rem 1.1rem;align-self:start}.blocks-course-upsell-teacher h3{margin:0 0 .5rem;font-size:1rem;color:var(--text-primary)}.blocks-course-upsell-teacher p{margin:0 0 .85rem;color:var(--text-secondary);line-height:1.55;font-size:.85rem}.back-to-top{position:fixed;bottom:2rem;right:2rem;width:44px;height:44px;border-radius:50%;border:1px solid rgba(0,181,9,.4);background:var(--bg-secondary);color:var(--primary-color);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #0006;transition:background .2s,border-color .2s;z-index:100}.back-to-top:hover{background:#00b5091a;border-color:var(--primary-color)}.csa-cross-links{max-width:960px;margin:3rem auto 2rem;padding:2rem 1.5rem;background:linear-gradient(135deg,#00b50914,#a855f714);border:1px solid rgba(0,181,9,.25);border-radius:14px;text-align:center}.csa-cross-links h3{margin:0 0 .5rem;font-size:1.35rem;color:var(--text-primary, #e6e6f0)}.csa-cross-links p{margin:0 0 1.25rem;font-size:.95rem;color:var(--text-secondary, #a8a8b8);max-width:640px;margin-left:auto;margin-right:auto;margin-bottom:1.25rem}.csa-cross-links-grid{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}
