:root{--sh-bg-primary: #2d1b4e;--sh-bg-secondary: #1a1a2e;--sh-bg-surface: #3d2a5e;--sh-border: #6b4aa3;--sh-accent: #ffd700;--sh-accent-hover: #ffb300;--sh-text-primary: #ffffff;--sh-text-secondary: #c9a0dc;--sh-text-muted: #8a6fb0;--sh-success-bg: #1a472a;--sh-success-border: #4ade80;--sh-success-text: #4ade80;--sh-error-bg: #4a1a1a;--sh-error-border: #ff6b6b;--sh-error-text: #ff6b6b;--sh-warning-bg: #4a3a1a;--sh-warning-border: #ffd700;--sh-warning-text: #ffd700;--sh-font-display: "Bungee", Impact, sans-serif;--sh-font-heading: "Space Grotesk", sans-serif;--sh-font-body: "DM Sans", "Segoe UI", Arial, sans-serif;--sh-weight-display: 700;--sh-weight-heading: 600;--sh-weight-body: 400;--sh-transform-display: none;--sh-transform-heading: none;--sh-transform-body: none;--sh-radius-sm: 8px;--sh-radius-md: 12px;--sh-radius-lg: 16px;--sh-radius-xl: 20px;--sh-shadow-card: 0 4px 20px rgba(0, 0, 0, .3);--sh-shadow-glow: 0 0 40px rgba(107, 74, 163, .4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--sh-font-body);background:var(--sh-bg-secondary);color:var(--sh-text-primary);line-height:1.5;-webkit-font-smoothing:antialiased}.sh-card{background:linear-gradient(135deg,var(--sh-bg-primary) 0%,var(--sh-bg-secondary) 100%);border:2px solid var(--sh-border);border-radius:var(--sh-radius-lg);padding:24px;box-shadow:var(--sh-shadow-card)}.sh-title{font-family:var(--sh-font-display);font-weight:var(--sh-weight-display);text-transform:var(--sh-transform-display);color:var(--sh-accent);text-shadow:0 2px 4px rgba(0,0,0,.5)}.sh-subtitle{font-family:var(--sh-font-heading);font-weight:var(--sh-weight-heading);text-transform:var(--sh-transform-heading);color:var(--sh-text-secondary)}.sh-btn{padding:10px 24px;font-size:14px;font-weight:var(--sh-weight-heading);font-family:var(--sh-font-body);border:none;border-radius:var(--sh-radius-sm);cursor:pointer;transition:all .15s ease;text-decoration:none;display:inline-flex;align-items:center;gap:8px}.sh-btn-primary{background:linear-gradient(135deg,gold,#ffb300);color:#1a1a2e}.sh-btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ffd70066}.sh-btn-secondary{background:#ffffff14;color:var(--sh-text-secondary);border:1px solid rgba(107,74,163,.4)}.sh-btn-secondary:hover{background:#ffffff1f}.sh-btn-danger{background:linear-gradient(135deg,#f44,#c00);color:#fff}.sh-btn-danger:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f446}.sh-input{width:100%;padding:10px 14px;font-size:15px;font-family:var(--sh-font-body);border:2px solid var(--sh-border);border-radius:var(--sh-radius-sm);background:#ffffff0f;color:var(--sh-text-primary);outline:none;transition:border-color .15s}.sh-input:focus{border-color:var(--sh-accent);box-shadow:0 0 8px #ffd70033}.sh-label{display:block;font-size:13px;font-weight:var(--sh-weight-heading);color:var(--sh-text-secondary);margin-bottom:6px}.sh-badge{display:inline-block;padding:3px 10px;font-size:11px;font-weight:var(--sh-weight-display);border-radius:20px;text-transform:var(--sh-transform-display);letter-spacing:.5px}.sh-badge-gold{background:#ffd70026;color:var(--sh-accent)}.sh-badge-green{background:#4ade8026;color:var(--sh-success-text)}.sh-badge-red{background:#ff6b6b26;color:var(--sh-error-text)}:root{--csa-bg: #0f1424;--csa-surface: #1a2238;--csa-surface-2: #232c4a;--csa-border: #3a4670;--csa-accent: #7dd3fc;--csa-accent-2: #a78bfa;--csa-correct: #4ade80;--csa-wrong: #f87171;--csa-mono: "JetBrains Mono", ui-monospace, Menlo, Consolas, monospace}body{background:radial-gradient(circle at top,#1a2238,#0f1424 60%);min-height:100vh}.app-header{padding:24px 20px 20px;text-align:center;max-width:900px;margin:0 auto}.app-switcher{display:inline-flex;margin:0 auto 14px;padding:4px;background:var(--csa-surface);border:1px solid var(--csa-border);border-radius:999px;font-family:var(--csa-mono);font-size:12px;letter-spacing:1px}.app-switcher-link{padding:6px 16px;color:var(--sh-text-muted);text-decoration:none;border-radius:999px;transition:color .12s,background .12s}.app-switcher-link:hover{color:var(--csa-accent)}.app-switcher-link.active{background:linear-gradient(135deg,var(--csa-accent),var(--csa-accent-2));color:#0f1424;font-weight:600}.brand{font-family:var(--sh-font-heading);font-size:32px;letter-spacing:-.5px;color:var(--csa-accent);text-shadow:0 0 24px rgba(125,211,252,.25)}.tagline{margin-top:4px;color:var(--sh-text-muted);font-size:14px}.auth-pill{margin-top:14px;display:flex;justify-content:center}.auth-link{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;font-family:var(--csa-mono);font-size:12px;letter-spacing:.5px;color:var(--sh-text-muted);text-decoration:none;background:var(--csa-surface);border:1px solid var(--csa-border);border-radius:999px;transition:color .12s,border-color .12s}.auth-link:hover{color:var(--csa-accent);border-color:var(--csa-accent)}.auth-link-on{color:#e8ecf6}.auth-link-on strong{color:var(--csa-accent);font-weight:600}.auth-dot{width:7px;height:7px;border-radius:50%;background:var(--sh-text-muted)}.auth-dot-on{background:#4ade80;box-shadow:0 0 6px #4ade80b3}.auth-signout{margin-left:6px;padding:2px 10px;font:inherit;font-size:11px;background:transparent;border:1px solid var(--csa-border);border-radius:999px;color:var(--sh-text-muted);cursor:pointer}.auth-signout:hover{color:var(--csa-wrong);border-color:var(--csa-wrong)}.login-container{max-width:420px}.login-blurb{font-size:14px;color:var(--sh-text-muted);text-align:center;margin:0 0 24px;line-height:1.5}.login-form{display:flex;flex-direction:column;gap:14px;margin:18px 0 8px}.login-label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--sh-text-secondary)}.login-error{min-height:18px;font-size:13px;color:var(--csa-wrong);margin:0}.toggle-link{display:block;margin-top:14px;text-align:center;font-size:13px;color:var(--sh-text-muted);cursor:pointer;text-decoration:underline dashed;text-underline-offset:2px}.toggle-link:hover{color:var(--csa-accent)}.divider{text-align:center;margin:18px 0;font-family:var(--csa-mono);font-size:11px;letter-spacing:1px;color:var(--sh-text-muted)}.google-signin-container{display:flex;justify-content:center}.container{max-width:900px;margin:0 auto;padding:0 20px 80px}.overall-progress{margin:16px 0 24px;padding:16px 20px;background:var(--csa-surface);border:1px solid var(--csa-border);border-radius:var(--sh-radius-md);display:flex;flex-direction:column;gap:8px}.overall-progress .label{font-size:13px;color:var(--sh-text-muted);display:flex;justify-content:space-between}.progress-bar{height:8px;background:#ffffff0f;border-radius:999px;overflow:hidden}.progress-bar>span{display:block;height:100%;background:linear-gradient(90deg,var(--csa-accent),var(--csa-accent-2));transition:width .3s}.unit-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.unit-card{display:block;padding:18px;background:var(--csa-surface);border:1px solid var(--csa-border);border-radius:var(--sh-radius-md);color:inherit;text-decoration:none;transition:transform .15s,border-color .15s,box-shadow .15s}.unit-card:hover{transform:translateY(-2px);border-color:var(--csa-accent);box-shadow:0 6px 24px #7dd3fc1f}.unit-card .num{font-family:var(--csa-mono);font-size:12px;letter-spacing:1px;color:var(--csa-accent-2);text-transform:uppercase}.unit-card .name{margin:4px 0 6px;font-size:17px;font-weight:600;color:#fff}.unit-card .desc{font-size:13px;color:var(--sh-text-muted);line-height:1.45}.unit-card .meta{margin-top:12px;display:flex;justify-content:space-between;font-size:12px;color:var(--sh-text-muted)}.unit-card .meta strong{color:var(--csa-accent)}.reset-section{margin-top:32px;text-align:center}.back-link{display:inline-block;margin-bottom:12px;font-size:13px;color:var(--sh-text-muted);text-decoration:none}.back-link:hover{color:var(--csa-accent)}.mode-tabs{display:inline-flex;margin-top:16px;background:var(--csa-surface);border:1px solid var(--csa-border);border-radius:999px;padding:4px}.tab-btn{padding:8px 22px;font-size:14px;font-weight:600;background:transparent;border:none;color:var(--sh-text-muted);border-radius:999px;cursor:pointer;font-family:inherit}.tab-btn.active{background:linear-gradient(135deg,var(--csa-accent),var(--csa-accent-2));color:#0f1424}.mode-view.hidden{display:none}.flashcard-wrap{perspective:1400px;margin:28px auto 12px;max-width:640px;touch-action:none}.flashcard{position:relative;width:100%;display:grid;transform-style:preserve-3d;transition:transform .5s;cursor:pointer}.flashcard.flipped{transform:rotateY(180deg)}.flashcard.swiping-left .face{box-shadow:-10px 0 30px -8px #7dd3fc80}.flashcard.swiping-right .face{box-shadow:10px 0 30px -8px #7dd3fc80}.flashcard.swiping-up .face{box-shadow:0 -10px 30px -8px #ffc47d99;border-color:#ffc47de6}.flashcard.swiping-down .face{box-shadow:0 10px 30px -8px #4ade8099;border-color:#4ade80e6}.flashcard .face{grid-area:1 / 1;backface-visibility:hidden;-webkit-backface-visibility:hidden;background:var(--csa-surface);border:1px solid var(--csa-border);border-radius:var(--sh-radius-lg);padding:44px 26px 28px;display:flex;flex-direction:column;justify-content:center;min-height:280px}.flashcard .face.back{transform:rotateY(180deg);background:var(--csa-surface-2);justify-content:flex-start}.face .face-tag{position:absolute;top:14px;left:18px;font-family:var(--csa-mono);font-size:11px;letter-spacing:1.5px;color:var(--csa-accent-2);text-transform:uppercase}.face h2{font-family:var(--sh-font-heading);font-size:22px;font-weight:600;color:#fff;text-align:center}.face .body{font-size:15px;line-height:1.6;color:#e8ecf6}.face .body p+p{margin-top:10px}.swipe-hints{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:6px;max-width:640px;margin:14px auto 0;padding:0 4px;font-family:var(--csa-mono);font-size:11px;letter-spacing:.5px;color:var(--sh-text-muted);text-align:center}.swipe-hints .hint-up{color:#ffc47de6}.swipe-hints .hint-down{color:#4ade80e6}.card-box{position:absolute;top:14px;right:18px;font-family:var(--csa-mono);font-size:10px;letter-spacing:1.5px;color:var(--sh-text-muted);text-transform:uppercase;padding:2px 8px;border-radius:999px;border:1px solid var(--csa-border);background:#ffffff0a}.study-done{text-align:center;padding:60px 20px 40px;background:var(--csa-surface);border:1px solid var(--csa-border);border-radius:var(--sh-radius-lg)}.study-done .big{font-family:var(--sh-font-heading);font-size:26px;font-weight:600;color:var(--csa-accent);margin-bottom:8px}.study-done .sub{color:var(--sh-text-muted);margin-bottom:24px;font-size:14px;line-height:1.5}.flashcard-controls{display:flex;justify-content:space-between;align-items:center;margin:16px auto 0;max-width:640px}.flashcard-counter{font-family:var(--csa-mono);font-size:13px;color:var(--sh-text-muted)}.icon-btn{width:40px;height:40px;border-radius:50%;background:var(--csa-surface);border:1px solid var(--csa-border);color:var(--csa-accent);cursor:pointer;font-size:18px;display:inline-flex;align-items:center;justify-content:center}.icon-btn:hover{border-color:var(--csa-accent)}.icon-btn:disabled{opacity:.4;cursor:not-allowed}.quiz-card{background:var(--csa-surface);border:1px solid var(--csa-border);border-radius:var(--sh-radius-lg);padding:24px;margin:24px 0 12px}.quiz-progress{font-family:var(--csa-mono);font-size:12px;letter-spacing:1px;color:var(--csa-accent-2);text-transform:uppercase;margin-bottom:10px}.quiz-prompt{font-size:16px;line-height:1.6;color:#fff;margin-bottom:18px}.quiz-prompt code,.face .body code,.code-block{font-family:var(--csa-mono);font-size:13.5px;background:#0a0e1a;padding:2px 6px;border-radius:4px;color:#ffd866}.code-block{display:block;white-space:pre;padding:12px 14px;margin:10px 0;overflow-x:auto;border:1px solid var(--csa-border);font-size:13px;line-height:1.5}.choice-list{display:flex;flex-direction:column;gap:10px}.choice{text-align:left;padding:12px 14px;background:var(--csa-surface-2);border:1px solid var(--csa-border);border-radius:var(--sh-radius-sm);color:#e8ecf6;font:inherit;font-size:14.5px;cursor:pointer;display:flex;gap:10px;align-items:flex-start}.choice:hover{border-color:var(--csa-accent)}.choice .letter{font-family:var(--csa-mono);font-weight:600;color:var(--csa-accent-2);min-width:18px}.choice.correct{background:#4ade801a;border-color:var(--csa-correct)}.choice.correct .letter{color:var(--csa-correct)}.choice.wrong{background:#f871711a;border-color:var(--csa-wrong)}.choice.wrong .letter{color:var(--csa-wrong)}.choice:disabled{cursor:default}.feedback{margin-top:16px;padding:12px 14px;border-radius:var(--sh-radius-sm);font-size:14px;line-height:1.55;background:#a78bfa14;border-left:3px solid var(--csa-accent-2)}.feedback strong{color:var(--csa-accent)}.feedback code{font-family:var(--csa-mono);font-size:13px;color:#ffd866}.quiz-controls{display:flex;justify-content:flex-end;margin-top:14px}.quiz-result{text-align:center;padding:32px 20px}.quiz-result .score{font-size:48px;font-weight:700;color:var(--csa-accent);font-family:var(--sh-font-heading)}.quiz-result .total{color:var(--sh-text-muted);margin-top:4px}.quiz-result .actions{margin-top:24px;display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.empty-msg{text-align:center;padding:40px 20px;color:var(--sh-text-muted)}.hidden{display:none!important}.course-picker{padding:20px 0 40px}.picker-prompt{font-family:var(--sh-font-heading);font-size:18px;font-weight:600;color:var(--sh-text-secondary);text-align:center;margin:0 0 20px}.course-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.course-card{display:block;padding:22px;background:var(--csa-surface);border:1px solid var(--csa-border);border-radius:var(--sh-radius-md);color:inherit;text-decoration:none;transition:transform .15s,border-color .15s,box-shadow .15s}.course-card:hover{transform:translateY(-2px);border-color:var(--csa-accent);box-shadow:0 6px 24px #7dd3fc1f}.course-card .num{font-family:var(--csa-mono);font-size:12px;letter-spacing:1.5px;color:var(--csa-accent-2);text-transform:uppercase}.course-card .name{margin:6px 0 8px;font-size:19px;font-weight:600;color:#fff}.course-card .desc{font-size:13.5px;color:var(--sh-text-muted);line-height:1.5}.home-actions{display:flex;justify-content:center;margin:0 0 20px}.filter-pills{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0 20px;padding:10px;background:var(--csa-surface);border:1px solid var(--csa-border);border-radius:var(--sh-radius-md);position:sticky;top:0;z-index:5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.pill{padding:6px 12px;font-size:13px;font-family:var(--csa-mono);background:transparent;color:var(--sh-text-muted);border:1px solid var(--csa-border);border-radius:999px;cursor:pointer;transition:all .12s}.pill:hover{color:var(--csa-accent);border-color:var(--csa-accent)}.pill.active{background:linear-gradient(135deg,var(--csa-accent),var(--csa-accent-2));color:#0f1424;border-color:transparent;font-weight:600}.glossary-section+.glossary-section{margin-top:28px}.glossary-unit-heading{font-family:var(--sh-font-heading);font-size:16px;font-weight:600;color:var(--csa-accent);padding:8px 0;border-bottom:1px solid var(--csa-border);margin-bottom:10px}.glossary-unit-heading .num{display:inline-block;margin-right:8px;font-family:var(--csa-mono);font-size:11px;letter-spacing:1.5px;color:var(--csa-accent-2);text-transform:uppercase}.glossary-items{display:flex;flex-direction:column;gap:6px}.glossary-item{background:var(--csa-surface);border:1px solid var(--csa-border);border-radius:var(--sh-radius-sm);overflow:hidden}.glossary-item summary{padding:12px 14px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:10px;list-style:none;-webkit-user-select:none;user-select:none}.glossary-item summary::-webkit-details-marker{display:none}.glossary-item .term{font-weight:600;color:#fff;font-size:15px;flex:1}.glossary-item .caret{color:var(--csa-accent-2);font-size:14px;transition:transform .15s;flex:0 0 auto}.glossary-item[open] .caret{transform:rotate(90deg)}.glossary-item[open] summary{background:var(--csa-surface-2);border-bottom:1px solid var(--csa-border)}.glossary-body{padding:14px 16px 16px;font-size:14.5px;line-height:1.6;color:#e8ecf6}.glossary-body p+p{margin-top:8px}.tok-kw{color:#ff7ab2;font-weight:600}.tok-csp-kw{color:#c4a7ff;font-weight:600}.tok-string{color:#a3e635}.tok-num{color:#fb923c}.tok-comment{color:#8a93b3;font-style:italic}body.no-syntax-highlight .tok-kw,body.no-syntax-highlight .tok-csp-kw,body.no-syntax-highlight .tok-string,body.no-syntax-highlight .tok-num,body.no-syntax-highlight .tok-comment{color:inherit;font-weight:inherit;font-style:inherit}.syntax-toggle-wrap{margin-top:10px;display:flex;justify-content:center}.syntax-toggle{display:inline-flex;align-items:center;gap:8px;padding:5px 12px;font-family:var(--csa-mono);font-size:11px;letter-spacing:.5px;color:var(--sh-text-muted);background:var(--csa-surface);border:1px solid var(--csa-border);border-radius:999px;cursor:pointer;transition:color .12s,border-color .12s}.syntax-toggle:hover{color:var(--csa-accent);border-color:var(--csa-accent)}.syntax-toggle .toggle-dot{width:7px;height:7px;border-radius:50%;background:var(--sh-text-muted)}.syntax-toggle .toggle-dot.on{background:var(--csa-accent);box-shadow:0 0 6px var(--csa-accent)}.concept-link{display:inline;padding:0;margin:0;background:none;border:none;color:var(--csa-accent);border-bottom:1px dashed rgba(125,211,252,.5);font:inherit;cursor:pointer;line-height:inherit}.concept-link:hover{background:#7dd3fc1f;border-bottom-color:var(--csa-accent)}.concept-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#080b16b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9000;display:flex;align-items:flex-end;justify-content:center;padding:0;animation:concept-fade .15s ease-out}.concept-overlay.hidden{display:none}@keyframes concept-fade{0%{opacity:0}to{opacity:1}}.concept-modal{width:100%;max-width:600px;max-height:88vh;background:var(--csa-surface);border:1px solid var(--csa-border);border-radius:18px 18px 0 0;display:flex;flex-direction:column;overflow:hidden;animation:concept-rise .2s ease-out}@keyframes concept-rise{0%{transform:translateY(20px)}to{transform:translateY(0)}}@media (min-width: 720px){.concept-overlay{align-items:center;padding:24px}.concept-modal{border-radius:18px}}.concept-bar{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--csa-border);background:var(--csa-surface-2)}.concept-back,.concept-close{background:none;border:1px solid var(--csa-border);color:#e8ecf6;width:32px;height:32px;border-radius:50%;font-size:16px;cursor:pointer;flex:0 0 auto;display:flex;align-items:center;justify-content:center}.concept-back:hover,.concept-close:hover{border-color:var(--csa-accent);color:var(--csa-accent)}.concept-trail{flex:1;font-family:var(--csa-mono);font-size:11px;color:var(--sh-text-muted);letter-spacing:.4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.concept-term{font-family:var(--sh-font-heading);font-size:22px;color:var(--csa-accent);margin:0;padding:18px 20px 6px}.concept-body{padding:6px 20px 20px;font-size:14.5px;line-height:1.65;color:#e8ecf6;overflow-y:auto}.concept-body p+p{margin-top:8px}.concept-body code,.concept-body .code-block{font-family:var(--csa-mono);font-size:13.5px;background:#0a0e1a;padding:2px 6px;border-radius:4px;color:#ffd866}.concept-body .code-block{display:block;white-space:pre;padding:12px 14px;margin:10px 0;overflow-x:auto;border:1px solid var(--csa-border);font-size:13px;line-height:1.5}mark.hl{background:#f4d03f6b;color:inherit;padding:0;border-radius:2px;cursor:pointer;box-decoration-break:clone;-webkit-box-decoration-break:clone}mark.hl:hover{background:#f4d03fa6}.hl-toolbar{position:absolute;z-index:8000;background:var(--csa-surface);border:1px solid var(--csa-border);border-radius:999px;padding:4px;box-shadow:0 6px 20px #00000073}.hl-toolbar[hidden]{display:none}.hl-toolbar-btn{background:linear-gradient(135deg,#f4d03f,#f1c40f);border:none;color:#1a1a1a;padding:6px 16px;border-radius:999px;font-family:var(--csa-mono);font-size:12px;font-weight:700;letter-spacing:.5px;cursor:pointer}
