:root{--bg: #0d1117;--panel: #161b22;--panel-2: #1c2230;--border: #2d333b;--text: #e6edf3;--muted: #8b949e;--accent: #1f6feb;--accent-2: #2ea043;--danger: #f85149;--chip: #30363d;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{background:var(--bg);color:var(--text)}*{scrollbar-width:thin;scrollbar-color:var(--chip) transparent}::-webkit-scrollbar{width:11px;height:11px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--chip);border-radius:8px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:#475061;background-clip:padding-box;border:2px solid transparent}::-webkit-scrollbar-corner{background:transparent}.app{display:grid;grid-template-columns:280px 1fr;height:100vh;overflow:hidden}.sidebar{background:var(--panel);border-right:1px solid var(--border);padding:18px 14px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.brand{display:flex;align-items:center;gap:10px}.brand__logo{font-size:28px}.brand__name{font-weight:700;font-size:18px}.brand__sub{color:var(--muted);font-size:12px}.sidebar__progress{font-size:12px;color:var(--muted)}.sidebar__progress-row{display:flex;justify-content:space-between;align-items:center}.streak{color:#f0883e;font-weight:600}.bar{margin-top:6px;height:6px;background:var(--chip);border-radius:99px;overflow:hidden}.bar__fill{height:100%;background:var(--accent-2);transition:width .3s ease}.nav-label{text-transform:uppercase;font-size:11px;letter-spacing:.08em;color:var(--muted);margin-bottom:6px}.nav-section{display:flex;justify-content:space-between;align-items:center;text-transform:uppercase;font-size:10px;letter-spacing:.08em;color:var(--muted);margin:14px 0 4px;padding:12px 8px 0;border-top:1px solid var(--border)}.nav-section:first-child{border-top:none;padding-top:0;margin-top:2px}.nav-section.is-complete{color:var(--accent-2)}.nav-section__count{font-weight:600}.lesson-link{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:transparent;border:none;color:var(--text);padding:8px;border-radius:8px;cursor:pointer;font-size:13px}.lesson-link:hover{background:var(--panel-2)}.lesson-link.is-active{background:var(--panel-2);outline:1px solid var(--border)}.lesson-link__title{flex:1}.tick{width:22px;height:22px;flex:0 0 22px;border-radius:50%;background:var(--chip);color:var(--muted);display:grid;place-items:center;font-size:12px}.tick.is-done{background:var(--accent-2);color:#fff}.db-picker{display:flex;flex-direction:column;gap:4px;padding:6px 8px 0 36px}.db-option{font-size:13px;color:var(--muted);display:flex;gap:8px;align-items:center;cursor:pointer}.sidebar__footer{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:8px;font-size:12px}.sidebar__footer a{color:var(--muted);text-decoration:none}.sidebar__footer a:hover{color:var(--text)}.reset-progress{background:none;border:1px solid var(--border);color:var(--muted);border-radius:6px;padding:4px 9px;font-size:12px;cursor:pointer}.reset-progress:hover{color:var(--danger);border-color:var(--danger)}.main{display:grid;grid-template-columns:minmax(320px,460px) 1fr;overflow:hidden}.panel{overflow-y:auto;padding:22px}.panel--left{border-right:1px solid var(--border);background:var(--panel)}.panel--right{display:flex;flex-direction:column;gap:12px}.chip{display:inline-block;background:var(--accent);color:#fff;font-size:11px;font-weight:600;padding:3px 9px;border-radius:99px}.lesson__head{display:flex;align-items:center;gap:10px}.lesson__count{color:var(--muted);font-size:12px}.lesson__done{color:var(--accent-2);font-size:12px;font-weight:600}.lesson h2{margin:12px 0 8px;font-size:21px}.lesson__prompt{line-height:1.6;color:#cdd9e5}.lesson__prompt code,.lesson code{background:var(--panel-2);padding:1px 6px;border-radius:5px;font-size:.9em;color:#79c0ff}.lesson__hint{background:var(--panel-2);border:1px solid var(--border);padding:10px 12px;border-radius:8px;white-space:pre-wrap;font-size:13px;color:#cdd9e5}.muted{color:var(--muted);font-size:13px;line-height:1.5}.link{background:none;border:none;color:var(--accent);cursor:pointer;padding:6px 0;font-size:13px}.feedback{margin-top:14px;padding:12px 14px;border-radius:8px;font-size:14px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}.feedback--pass{background:#2ea04326;border:1px solid var(--accent-2)}.feedback--fail{background:#f851491f;border:1px solid var(--danger)}.schema-wrap{margin-top:26px;border-top:1px solid var(--border);padding-top:16px}.schema details{margin-bottom:8px}.schema summary{cursor:pointer;list-style:none}.schema summary::-webkit-details-marker{display:none}.schema__table{background:var(--panel-2);border:1px solid var(--border);color:#79c0ff;font-weight:600;padding:4px 10px;border-radius:6px;cursor:pointer;font-size:13px}.schema ul{list-style:none;margin:6px 0 0;padding:0 0 0 12px}.schema li{display:flex;justify-content:space-between;align-items:center;padding:2px 0}.schema__col{background:none;border:none;color:var(--text);cursor:pointer;font-size:13px;padding:2px 4px}.schema__col:hover{color:#79c0ff}.schema__type{color:var(--muted);font-size:11px}.schema--empty{color:var(--muted);font-size:13px}.editor{border:1px solid var(--border);border-radius:10px;overflow:hidden}.cm-snippetField{background:#d2992229;outline:1px dashed rgba(227,179,65,.55);border-radius:3px}.cm-editor .cm-snippetFieldPosition{border-left:2px solid #e3b341}.toolbar{display:flex;gap:10px;flex-wrap:wrap}.btn{border:1px solid var(--border);background:var(--panel-2);color:var(--text);padding:9px 16px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--accent);border-color:var(--accent)}.btn--check{background:var(--accent-2);border-color:var(--accent-2)}.btn--ghost{background:transparent}.btn--danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn--small{padding:5px 12px;font-size:13px}.btn kbd{background:#0000004d;border-radius:4px;padding:1px 5px;font-size:11px;margin-left:4px}.results{flex:1;overflow:auto;border:1px solid var(--border);border-radius:10px;background:var(--panel)}.result{padding:14px}.result--empty,.result--ok{color:var(--muted);font-size:14px}.result--error{color:var(--danger);font-size:14px;font-family:ui-monospace,monospace}.result--table{padding:0}.result table{border-collapse:collapse;width:100%;font-size:13px}.result th,.result td{border-bottom:1px solid var(--border);padding:8px 12px;text-align:left;white-space:nowrap}.result th{position:sticky;top:0;background:var(--panel-2);color:#79c0ff;font-weight:600}.result tbody tr:hover{background:var(--panel-2)}.result__meta{padding:8px 12px;color:var(--muted);font-size:12px}.lesson__remain{color:var(--muted);font-size:12px}.task{background:#58a6ff1a;border:1px solid var(--accent);border-left-width:4px;border-radius:10px;padding:14px 16px;margin:6px 0 18px}.task__label{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}.task__body p{margin:0;font-size:15.5px;line-height:1.55;color:#f0f6fc}.task__body code{background:#0d111799;padding:1px 6px;border-radius:5px;color:#79c0ff;font-size:.92em}.learn-toggle{background:none;border:none;color:var(--muted);cursor:pointer;font-size:12px;text-transform:uppercase;letter-spacing:.06em;padding:4px 0;margin-bottom:6px}.learn-toggle:hover{color:var(--text)}.learn{margin-bottom:6px}.syntax__hint{text-transform:none;letter-spacing:0;color:#6e7681;font-weight:400}.key-idea{display:flex;gap:10px;align-items:flex-start;background:var(--panel-2);border-left:3px solid var(--accent);border-radius:8px;padding:12px 14px;margin-bottom:16px}.key-idea__bulb{font-size:18px;line-height:1.4}.key-idea__text p{margin:0;line-height:1.5;font-size:14px}.concept-art{margin:0 0 16px;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:10px 12px 6px}.concept-art svg{width:100%;height:auto;display:block}.concept-art figcaption{color:var(--muted);font-size:12px;text-align:center;margin-top:4px}.syntax{margin:16px 0;border:1px solid var(--border);border-radius:10px;padding:12px 14px;background:var(--panel-2)}.syntax__label{text-transform:uppercase;font-size:10px;letter-spacing:.08em;color:var(--muted);margin-bottom:8px}.syntax__line{display:flex;flex-wrap:wrap;gap:6px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px}.tok{padding:3px 8px;border-radius:6px;border:1px solid transparent;white-space:nowrap}.tok--keyword{background:#a371f72e;color:#d2a8ff;font-weight:700}.tok--table{background:#58a6ff29;color:#79c0ff}.tok--column{background:#39b65024;color:#7ee787}.tok--literal{background:var(--chip);color:#cdd9e5}.tok--slot{background:#d2992224;color:#e3b341;border:1px dashed #e3b341}.tok--mini{padding:1px 6px;font-size:12px}.syntax__notes{list-style:none;margin:12px 0 0;padding:0;display:flex;flex-direction:column;gap:7px}.syntax__notes li{display:flex;align-items:center;gap:8px;font-size:12.5px}.syntax__note{color:var(--muted)}.diff{padding:12px}.diff__note{background:#f851491f;border:1px solid var(--danger);border-radius:8px;padding:8px 12px;font-size:13px;margin-bottom:12px}.diff__note code{background:#0000004d;padding:1px 5px;border-radius:4px}.diff__grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.diff__side{border:1px solid var(--border);border-radius:8px;overflow:hidden}.diff__h{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;font-size:12px;font-weight:600;background:var(--panel-2);border-bottom:1px solid var(--border)}.diff__tag{font-weight:600;font-size:11px;padding:1px 7px;border-radius:99px}.diff__tag--missing{background:#2ea04333;color:#7ee787}.diff__tag--extra{background:#f851492e;color:#ff7b72}.diff__tablewrap{overflow:auto;max-height:320px}.diff table{border-collapse:collapse;width:100%;font-size:12.5px}.diff th,.diff td{border-bottom:1px solid var(--border);padding:6px 10px;text-align:left;white-space:nowrap}.diff th{position:sticky;top:0;background:var(--panel-2);color:#79c0ff}.diff tr.row--missing{background:#2ea04326}.diff tr.row--extra{background:#f8514924}.diff__empty{padding:14px;color:var(--muted);font-size:13px}.diff__legend{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:10px;font-size:11px;color:var(--muted)}.swatch{width:12px;height:12px;border-radius:3px;display:inline-block;margin-left:8px}.swatch--missing{background:#2ea04380}.swatch--extra{background:#f8514980}@media(max-width:900px){.app{grid-template-columns:1fr;height:auto}.main{grid-template-columns:1fr}.sidebar{height:auto}.diff__grid{grid-template-columns:1fr}}.cert-btn{margin-top:10px;width:100%;background:linear-gradient(90deg,#e3b341,#f0883e);color:#0d1117;border:none;border-radius:8px;padding:9px;font-weight:700;font-size:13px;cursor:pointer}.cert-btn:hover{filter:brightness(1.06)}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;padding:20px;z-index:100}.modal__card{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:20px;width:min(960px,100%);max-height:92vh;overflow:auto}.modal__card--narrow{width:min(460px,100%)}.modal__head{display:flex;justify-content:space-between;align-items:center}.modal__head h2{margin:0;font-size:20px}.modal__close{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer}.modal__close:hover{color:var(--text)}.modal__name{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted);margin:12px 0}.modal__name input{background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:8px 10px;font-size:15px}.modal__confirm{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px}.modal__locked{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:10px 14px;font-size:14px;margin:12px 0}.cert-wrap{border:1px solid var(--border);border-radius:10px;overflow:hidden}.cert-wrap svg{width:100%;height:auto;display:block}.modal__actions{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}@media print{body *{visibility:hidden}.cert,.cert *{visibility:visible}.cert{position:absolute;left:0;top:0;width:100%;height:auto}}.main--single{display:block;overflow-y:auto;padding:28px}.cert-view{max-width:760px;margin:0 auto}.cert-view h2{margin:0 0 6px;font-size:24px}.cert-progress{display:flex;align-items:center;gap:12px;margin:16px 0 18px;font-size:13px;color:var(--muted)}.cert-progress .bar{flex:1;height:8px}.cert-stage{position:relative;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:#fff}.cert-stage .cert{width:100%;height:auto;display:block}.cert-stage.is-locked .cert{filter:blur(3px) grayscale(.7);opacity:.5}.cert-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#e6edf3;font-weight:700;background:#0d111759}.cert-overlay__lock{font-size:44px}.cert-view__actions{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap;align-items:center}.badge-ready{background:var(--accent-2);color:#fff;font-size:10px;font-weight:700;padding:1px 7px;border-radius:99px}.confirm-box{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:16px;font-size:14px;line-height:1.5;margin:12px 0;text-align:center}.confirm-box__name{font-size:22px;font-weight:800;color:#58a6ff;margin:8px 0}.track-toggle{display:flex;gap:6px;background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:4px}.track-btn{flex:1;background:none;border:none;color:var(--muted);padding:7px;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer}.track-btn:hover{color:var(--text)}.track-btn.is-active{background:var(--accent);color:#fff}.docview{padding:12px}.docview__doc{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;margin:0 0 8px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px;color:#cdd9e5;overflow-x:auto;white-space:pre}
