:root{--font: "Space Grotesk", system-ui, sans-serif;--surface: #F9F9F8;--red: #8B0000;--black: #000000;--white: #FFFFFF;--muted: #555555;--border: 2px solid var(--black);--radius: 4px;--shadow: 4px 4px 0px 0px rgba(0,0,0,1);--shadow-sm: 2px 2px 0px 0px rgba(0,0,0,1)}*,*:before,*:after{box-sizing:border-box}body{margin:0;background:var(--surface);color:var(--black);font-family:var(--font);font-size:1rem;line-height:1.6}a{color:var(--red);font-weight:500;text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3{font-weight:700;letter-spacing:-.02em;margin:0 0 .75rem;text-transform:uppercase}h1{font-size:2rem}h2{font-size:1.35rem}h3{font-size:1.1rem}p{margin:0 0 .75rem}pre{background:#eee;border:var(--border);border-radius:var(--radius);padding:.75rem 1rem;overflow-x:auto;white-space:pre-wrap;font-size:.875rem}code{font-size:.9em}.page-shell{display:flex;flex-direction:column;min-height:100vh}main{max-width:52rem;width:100%;margin:0 auto;padding:2rem 1.5rem 4rem}.top-nav{display:flex;align-items:center;gap:0;padding:0 1.5rem;border-bottom:var(--border);background:var(--surface);position:sticky;top:0;z-index:10}.top-nav a{display:inline-flex;align-items:center;height:3rem;padding:0 .875rem;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--black);border-right:1px solid rgba(0,0,0,.12);text-decoration:none;transition:background .1s,color .1s}.top-nav a:first-child{border-left:1px solid rgba(0,0,0,.12)}.top-nav a:hover,.top-nav a.active{background:var(--red);color:var(--white)}.top-nav .spacer{flex:1}.top-nav .nav-meta{display:flex;align-items:center;gap:.75rem;font-size:.8rem}.top-nav .muted{color:var(--muted);font-size:.8rem}button,.btn{font-family:var(--font);font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:.45rem 1rem;background:var(--black);color:var(--white);border:var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .08s,box-shadow .08s}button:hover:not(:disabled),.btn:hover{transform:translate(-1px,-1px);box-shadow:3px 3px #000}button:active:not(:disabled){transform:translate(1px,1px);box-shadow:1px 1px #000}button:disabled{opacity:.35;cursor:not-allowed;box-shadow:none}button.btn-danger{background:var(--red)}button.btn-text{background:none;border:none;box-shadow:none;color:var(--red);text-transform:none;letter-spacing:normal;padding:0;font-weight:500}button.btn-text:hover{text-decoration:underline;transform:none}form{display:flex;flex-direction:column;gap:.625rem;max-width:34rem;padding:1.25rem;border:var(--border);border-radius:var(--radius);box-shadow:var(--shadow);background:var(--white);margin-bottom:1.25rem}form label{display:flex;flex-direction:column;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;gap:.25rem}form label.inline{flex-direction:row;align-items:center;gap:.5rem;text-transform:none;letter-spacing:normal;font-weight:500}form input,form textarea,form select{font-family:var(--font);font-size:.95rem;padding:.45rem .6rem;border:var(--border);border-radius:var(--radius);background:var(--surface);outline:none}form input:focus,form textarea:focus,form select:focus{box-shadow:2px 2px 0 0 var(--red)}form button{align-self:flex-start}.unit-card{border:var(--border);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1.5rem;overflow:hidden;background:var(--white)}.unit-card-header{background:var(--red);color:var(--white);padding:.75rem 1.25rem}.unit-card-header h2{margin:0;color:var(--white);font-size:1rem}.unit-card-header p{margin:.2rem 0 0;font-size:.85rem;opacity:.85}.unit-card-body{padding:.5rem 0}.topic-row{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1.25rem;border-bottom:1px solid rgba(0,0,0,.08);gap:1rem}.topic-row:last-child{border-bottom:none}.topic-row a,.topic-row>span:not(.badge):not(.topic-meta):not(.exercise-count){font-weight:600;font-size:.95rem;color:var(--black);text-decoration:none;flex:1}.topic-row a:hover{color:var(--red)}.topic-row.topic-locked a,.topic-row.topic-locked span{color:#aaa;font-weight:500}.topic-meta{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.badge{display:inline-flex;align-items:center;white-space:nowrap;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;padding:.2rem .55rem;border-radius:var(--radius);border:1px solid currentColor;line-height:1}.badge-mastered{color:var(--white);background:var(--red);border-color:var(--red)}.badge-unlocked{color:var(--black);background:transparent;border-color:var(--black)}.badge-locked{color:#aaa;background:transparent;border-color:#aaa}.exercise-count{font-size:.78rem;color:var(--muted)}.back-link{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--black);margin-bottom:1.5rem}.mastered-banner{display:inline-flex;align-items:center;gap:.5rem;background:var(--red);color:var(--white);font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:.4rem .85rem;border-radius:var(--radius);margin-bottom:1.25rem}.lesson{border:var(--border);border-radius:var(--radius);padding:1.25rem;background:var(--white);box-shadow:var(--shadow-sm);margin-bottom:1.5rem}.exercises-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.exercise{border:var(--border);border-radius:var(--radius);padding:1.25rem;background:var(--white);box-shadow:var(--shadow)}.prompt{font-weight:600;font-size:1rem;margin-bottom:1rem}.choice{display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem;border:1px solid rgba(0,0,0,.2);border-radius:var(--radius);margin-bottom:.5rem;cursor:pointer;font-size:.95rem;transition:border-color .1s,background .1s}.choice:hover{border-color:var(--black);background:#00000008}.choice input[type=radio]{accent-color:var(--red)}.short-answer-row{display:flex;gap:.75rem;align-items:center}.short-answer-row input{font-family:var(--font);font-size:.95rem;padding:.45rem .6rem;border:var(--border);border-radius:var(--radius);background:var(--surface);flex:1;max-width:28rem}.short-answer-row input:focus{outline:none;box-shadow:2px 2px 0 0 var(--red)}.result-msg{margin-top:.75rem;font-weight:600;font-size:.9rem;padding:.5rem .75rem;border-radius:var(--radius);border-left:4px solid}.result-msg.correct{border-color:var(--red);color:var(--red);background:#8b00000f}.result-msg.incorrect{border-color:#555;color:#333;background:#0000000a}.admin-card-body{padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.75rem}.admin-topic-card{border:var(--border);border-radius:var(--radius);background:var(--surface);overflow:hidden}.admin-topic-card-header{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;padding:.6rem 1rem;background:#0000000a;border-bottom:1px solid rgba(0,0,0,.12);flex-wrap:wrap}.admin-topic-card-body{padding:.75rem 1rem;display:flex;flex-direction:column;gap:.5rem}.clamp-text{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.exercise-row{padding:.4rem 0;border-top:1px dotted rgba(0,0,0,.2)}.row{display:flex;gap:.5rem;margin-top:.25rem}.tabs{display:flex;gap:.5rem;margin-bottom:.5rem}.field-label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.choice-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.choice-row input[type=text],.choice-row input:not([type]){flex:1}.btn-text{background:none;border:none;cursor:pointer;padding:0;color:var(--red);font-weight:500;font-family:var(--font);box-shadow:none;text-transform:none;letter-spacing:normal}.add-child{margin-top:.5rem}.add-grandchild{margin-top:.25rem}.prereq-row{display:flex;align-items:center;justify-content:space-between;padding:.25rem 0;border-top:1px dotted rgba(0,0,0,.2)}button.danger{background:var(--red)}.shiki-wrap pre,.code-block-plain{background:#fff;border:2px solid #000;border-radius:4px;box-shadow:4px 4px #000;padding:1rem 1.25rem;overflow-x:auto;margin:.75rem 0;font-family:Fira Code,Cascadia Code,Consolas,monospace;font-size:.85rem;line-height:1.65}.shiki-wrap pre.shiki{background:#fff!important}:not(pre)>code{background:#0000000f;border-radius:3px;padding:.1em .35em;font-family:Fira Code,Cascadia Code,Consolas,monospace;font-size:.85em}.code-editor-wrap{margin-bottom:.75rem}.code-editor-wrap .cm-editor{width:100%}.code-exercise{display:flex;flex-direction:column;gap:0}.code-lang-badge{display:inline-flex;align-items:center;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:.2rem .6rem;background:var(--black);color:var(--white);border-radius:var(--radius) var(--radius) 0 0;margin-bottom:0;align-self:flex-start}.code-tests{margin-top:.75rem}.code-tests-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:0 0 .35rem}.code-test-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.3rem}.code-test-item{display:flex;align-items:baseline;gap:.5rem;font-size:.875rem;padding:.3rem .6rem;border-radius:var(--radius);border:1px solid rgba(0,0,0,.1);background:#00000005}.code-test-item.pass{border-color:var(--red);background:#8b00000d}.code-test-item.fail{border-color:#555;background:#0000000a}.code-test-icon{font-size:.85rem;font-weight:700;width:1rem;text-align:center;flex-shrink:0}.code-test-item.pass .code-test-icon{color:var(--red)}.code-test-item.fail .code-test-icon{color:#555}.code-test-error{font-size:.78rem;color:#555;font-family:Fira Code,Cascadia Code,Consolas,monospace;margin-left:auto;max-width:50%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.code-runtime-error{margin-top:.5rem;font-size:.8rem;font-family:Fira Code,Cascadia Code,Consolas,monospace;color:#555;background:#0000000a;border:1px solid rgba(0,0,0,.12);border-radius:var(--radius);padding:.4rem .6rem;white-space:pre-wrap}.correct{color:var(--red);font-weight:600}.incorrect{color:#444;font-weight:600}.muted{color:var(--muted);font-size:.875rem}.error{color:var(--red);white-space:pre-wrap;font-weight:600}
