:root{--py-blue: #3776ab;--py-blue-600: #2f6692;--py-blue-700: #275577;--py-yellow: #ffd43b;--py-yellow-600: #f4c20d;--accent: #6c63ff;--accent-600: #574fe0;--accent-700: #463fc4;--accent-soft: #eceaff;--success: #18a558;--success-soft: #e3f7ec;--danger: #e0455e;--danger-soft: #fce8eb;--warning: #e8930c;--warning-soft: #fdf2dd;--info: #2f86c5;--info-soft: #e4f1fb;--bg: #f6f7fb;--bg-warm: #fbfaf5;--surface: #ffffff;--surface-2: #f1f3f9;--border: #e4e7ef;--border-strong: #d2d7e3;--ink: #1f2533;--ink-2: #4a5163;--ink-3: #828aa0;--ink-on-dark: #f4f6fb;--code-bg: #282c34;--code-ink: #abb2bf;--font-display: "Nunito", system-ui, sans-serif;--font-body: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", ui-monospace, "SF Mono", Menlo, monospace;--r-sm: 8px;--r-md: 12px;--r-lg: 18px;--r-xl: 26px;--r-pill: 999px;--shadow-sm: 0 1px 2px rgba(31, 37, 51, .06), 0 1px 3px rgba(31, 37, 51, .04);--shadow-md: 0 4px 14px rgba(31, 37, 51, .08), 0 2px 6px rgba(31, 37, 51, .05);--shadow-lg: 0 12px 34px rgba(31, 37, 51, .12), 0 4px 12px rgba(31, 37, 51, .06);--shadow-accent: 0 8px 22px rgba(108, 99, 255, .28);--ring: 0 0 0 3px var(--accent-soft);--maxw: 1140px;--gap: 16px;--transition: .16s cubic-bezier(.2, .8, .3, 1)}*{box-sizing:border-box}html,body{margin:0;padding:0;min-height:100%}body{font-family:var(--font-body);background:radial-gradient(1200px 600px at 100% -10%,#eef1ff 0%,transparent 55%),radial-gradient(900px 500px at -10% 0%,#fff7df 0%,transparent 45%),var(--bg);background-attachment:fixed;color:var(--ink);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);line-height:1.2;margin:0 0 .5em;font-weight:800;letter-spacing:-.01em}h1{font-size:clamp(1.8rem,4vw,2.6rem)}h2{font-size:clamp(1.4rem,3vw,1.9rem)}h3{font-size:1.25rem}p{margin:0 0 1em}a{color:var(--accent-600);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--accent-700);text-decoration:underline}code,kbd,samp{font-family:var(--font-mono);font-size:.92em}:not(pre)>code{background:var(--accent-soft);color:var(--accent-700);padding:.1em .4em;border-radius:6px;font-weight:500;white-space:nowrap}ul,ol{padding-left:1.4em}li{margin:.3em 0}hr{border:none;border-top:1px solid var(--border);margin:1.5rem 0}::selection{background:var(--py-yellow);color:var(--ink)}*{scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}.stack{display:flex;flex-direction:column}.row{display:flex;align-items:center}.gap-sm{gap:8px}.gap{gap:16px}.gap-lg{gap:24px}.wrap{flex-wrap:wrap}.between{justify-content:space-between}.center{justify-content:center;align-items:center}.grow{flex:1}.muted{color:var(--ink-2)}.dim{color:var(--ink-3)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:22px;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition)}.card.hoverable:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--border-strong)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-body);font-weight:600;font-size:.97rem;line-height:1;padding:12px 20px;border-radius:var(--r-pill);border:1px solid transparent;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),background var(--transition),border-color var(--transition);white-space:nowrap;text-decoration:none}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn:focus-visible{outline:none;box-shadow:var(--ring)}.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-accent)}.btn-primary:hover:not(:disabled){background:var(--accent-600);color:#fff;text-decoration:none}.btn-run{background:var(--success);color:#fff;box-shadow:0 8px 20px #18a55847}.btn-run:hover:not(:disabled){background:#149049;color:#fff;text-decoration:none}.btn-ghost{background:var(--surface);color:var(--ink);border-color:var(--border-strong)}.btn-ghost:hover:not(:disabled){background:var(--surface-2);color:var(--ink);text-decoration:none}.btn-yellow{background:var(--py-yellow);color:#4a3c00;box-shadow:0 8px 20px #ffd43b59}.btn-yellow:hover:not(:disabled){background:var(--py-yellow-600);text-decoration:none}.btn-sm{padding:8px 14px;font-size:.88rem}.btn-lg{padding:15px 28px;font-size:1.05rem}.badge{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;font-weight:700;padding:4px 11px;border-radius:var(--r-pill);letter-spacing:.01em;white-space:nowrap}.badge-beginner{background:var(--success-soft);color:#0f7a3f}.badge-intermediate{background:var(--warning-soft);color:#a5650a}.badge-python{background:var(--info-soft);color:var(--py-blue-700)}.badge-sql{background:#efe7fb;color:#6a37b8}.badge-soft{background:var(--surface-2);color:var(--ink-2)}.progress{height:10px;background:var(--surface-2);border-radius:var(--r-pill);overflow:hidden}.progress>span{display:block;height:100%;border-radius:var(--r-pill);background:linear-gradient(90deg,var(--accent),var(--py-blue));transition:width .5s cubic-bezier(.2,.8,.3,1)}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.field label{font-weight:600;font-size:.9rem;color:var(--ink-2)}.input{font-family:var(--font-body);font-size:1rem;padding:12px 14px;border:1px solid var(--border-strong);border-radius:var(--r-md);background:var(--surface);color:var(--ink);transition:border-color var(--transition),box-shadow var(--transition);width:100%}.input:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}.callout{border-radius:var(--r-md);padding:14px 16px 14px 18px;margin:16px 0;border-left:4px solid var(--info);background:var(--info-soft);color:var(--ink)}.callout .callout-title{font-weight:700;font-family:var(--font-display);margin-bottom:4px;display:flex;align-items:center;gap:8px}.callout :last-child{margin-bottom:0}.callout-tip{border-left-color:var(--success);background:var(--success-soft)}.callout-warning{border-left-color:var(--warning);background:var(--warning-soft)}.callout-info{border-left-color:var(--info);background:var(--info-soft)}@keyframes pop{0%{transform:scale(.8);opacity:0}70%{transform:scale(1.05)}to{transform:scale(1);opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fade-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:fade-up .32s ease both}.spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.spinner.dark{border-color:#1f253326;border-top-color:var(--accent)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;transition-duration:.001ms!important}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.prose{font-size:1.02rem;line-height:1.7;color:var(--ink)}.prose p:last-child{margin-bottom:0}.prose strong{font-weight:700}.prose .md-code{background:var(--code-bg);color:#c8d3e0;padding:13px 15px;border-radius:10px;font-family:var(--font-mono);font-size:.85rem;line-height:1.5;overflow-x:auto;margin:12px 0;white-space:pre}.gl-term{font-family:var(--font-mono);font-size:.9em;font-weight:600;color:var(--py-blue-700);background:#eaf2fb;border:none;border-bottom:2px dotted var(--py-blue);border-radius:5px;padding:.05em .4em;cursor:help;transition:background var(--transition),color var(--transition);white-space:nowrap}.gl-term:hover,.gl-term:focus-visible{background:var(--py-blue);color:#fff;outline:none}.gl-pop.svelte-1pqf3ur{position:fixed;z-index:1000;transform:translate(-50%,10px);width:min(340px,calc(100vw - 28px));background:#1f2430;color:#e7ecf4;border:1px solid #323a4d;border-radius:14px;box-shadow:0 16px 40px #0006;padding:13px 15px;font-family:var(--font-body);animation:svelte-1pqf3ur-pop .14s ease both}.gl-pop.above.svelte-1pqf3ur{transform:translate(-50%,calc(-100% - 10px))}.head.svelte-1pqf3ur{display:flex;align-items:center;gap:9px;margin-bottom:7px}.name.svelte-1pqf3ur{font-family:var(--font-mono);font-weight:700;color:#ffd43b;background:#ffd43b1f;padding:2px 8px;border-radius:7px}.pron.svelte-1pqf3ur{font-size:.82rem;color:#9aa6bd}.x.svelte-1pqf3ur{margin-left:auto;background:none;border:none;color:#8b94a8;cursor:pointer;font-size:.9rem;padding:2px 4px}.en.svelte-1pqf3ur{font-size:.82rem;color:#9aa6bd;margin-bottom:6px}.explain.svelte-1pqf3ur{font-size:.9rem;line-height:1.5;color:#dfe5f0}.ex.svelte-1pqf3ur{margin:9px 0 0;padding:9px 11px;background:#161b24;border-radius:9px;font-family:var(--font-mono);font-size:.8rem;color:#c8d3e0;white-space:pre-wrap;overflow-x:auto}@keyframes svelte-1pqf3ur-pop{0%{opacity:0;transform:translate(-50%,4px) scale(.97)}to{opacity:1}}.shell.svelte-12qhfyh{min-height:100vh;display:flex;flex-direction:column}.topbar.svelte-12qhfyh{position:sticky;top:0;z-index:50;background:#ffffffd1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}.bar.svelte-12qhfyh{display:flex;align-items:center;gap:18px;height:64px}.brand.svelte-12qhfyh{display:flex;align-items:center;gap:9px;text-decoration:none;color:var(--ink);font-family:var(--font-display);font-weight:800;font-size:1.2rem}.brand.svelte-12qhfyh:hover{text-decoration:none}.logo.svelte-12qhfyh{font-size:1.5rem}.nav.svelte-12qhfyh{display:flex;gap:6px;margin-left:14px}.navlink.svelte-12qhfyh{padding:8px 14px;border-radius:var(--r-pill);color:var(--ink-2);font-weight:600;font-size:.94rem;text-decoration:none}.navlink.svelte-12qhfyh:hover{background:var(--surface-2);text-decoration:none}.navlink.on.svelte-12qhfyh{background:var(--accent-soft);color:var(--accent-700)}.user.svelte-12qhfyh{margin-left:auto;display:flex;align-items:center;gap:14px}.who.svelte-12qhfyh{display:flex;align-items:center;gap:7px;font-weight:600;font-size:.92rem;color:var(--ink-2)}.role-dot.svelte-12qhfyh{width:9px;height:9px;border-radius:50%;background:var(--py-blue)}.role-dot.teacher.svelte-12qhfyh{background:var(--py-yellow-600)}form.svelte-12qhfyh{margin:0}.content.svelte-12qhfyh{flex:1;padding:30px 0 60px}.foot.svelte-12qhfyh{border-top:1px solid var(--border);padding:22px 0;color:var(--ink-3);font-size:.88rem;text-align:center}@media(max-width:560px){.brand-name.svelte-12qhfyh,.who.svelte-12qhfyh{display:none}}
