@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes pulseDot{0%,to{opacity:.5}50%{opacity:1}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;text-size-adjust:100%}body{min-height:100vh;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}img,picture,svg,video{display:block;max-width:100%}button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}input,textarea,select{font:inherit;color:inherit}a{color:inherit;text-decoration:none}ul,ol{list-style:none}:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:4px}html{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,sans-serif;font-size:16px;line-height:1.5}body{background:var(--bg-deep);color:var(--fg);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,sans-serif;font-feature-settings:"cv11","ss01","ss03";line-height:1.6}code,kbd,pre,samp{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Cascadia Code,Menlo,monospace}.h1{font-size:clamp(1.75rem,1.2rem + 2.4vw,2.75rem);font-weight:600;letter-spacing:-.02em;line-height:1.1;color:var(--fg)}.h2{font-size:clamp(1.25rem,1rem + 1vw,1.5rem);font-weight:600;letter-spacing:-.015em;line-height:1.2;color:var(--fg)}.h3{font-size:1rem;font-weight:600;letter-spacing:-.01em;color:var(--fg)}.h4{font-size:.8125rem;font-weight:600;color:var(--fg)}.eyebrow{font-size:.6875rem;text-transform:uppercase;letter-spacing:.1em;color:var(--fg-3);font-weight:600}.muted{color:var(--fg-3)}.muted-2{color:var(--fg-4)}.mono{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Cascadia Code,Menlo,monospace}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem .875rem;border-radius:9px;font-size:.8125rem;font-weight:500;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,sans-serif;border:1px solid var(--line-2);background:var(--bg-3);color:var(--fg);text-decoration:none;transition:background .15s ease,border-color .15s ease,transform .05s ease}.btn:hover{background:var(--bg-elev)}.btn:active{transform:translateY(1px)}.btn:disabled,.btn[aria-disabled=true]{opacity:.55;cursor:not-allowed}.btn>svg{flex-shrink:0}.btn--primary{background:linear-gradient(180deg,#8b8aff,#6968ee);border-color:#ffffff2e;color:#fff;box-shadow:0 6px 18px -6px #7c7bffb3,inset 0 1px #ffffff40}.btn--primary:hover{background:linear-gradient(180deg,#9897ff,#7574f0)}.btn--ghost{background:transparent;border-color:var(--line)}.btn--ghost:hover{background:var(--bg-2)}.btn--success{background:linear-gradient(180deg,#6ff0aa,#3dd87f);color:#04230f;border-color:#fff3;box-shadow:0 6px 18px -6px #5eeaa099,inset 0 1px #ffffff40}.btn--sm{padding:.3125rem .625rem;font-size:.75rem;border-radius:7px}.btn--block{width:100%}.badge{display:inline-flex;align-items:center;gap:.375rem;font-size:.6875rem;font-weight:500;padding:.1875rem .5rem;border-radius:999px;background:var(--bg-3);color:var(--fg-2);border:1px solid var(--line);letter-spacing:.01em;white-space:nowrap;line-height:1}.badge>svg{flex-shrink:0}.badge--sql{background:var(--sql-soft);color:var(--sql);border-color:var(--sql-line)}.badge--primary{background:var(--primary-soft);color:var(--primary-2);border-color:var(--primary-line)}.badge--warn{background:var(--warn-soft);color:var(--warn);border-color:var(--warn-line)}.badge--err{background:var(--err-soft);color:var(--err);border-color:var(--err-line)}.badge--info{background:var(--info-soft);color:var(--info);border-color:var(--info-line)}.badge--muted{background:var(--bg-2);color:var(--fg-3)}.badge__dot{width:6px;height:6px;border-radius:50%;background:currentColor}.chip{display:inline-flex;align-items:center;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Cascadia Code,Menlo,monospace;font-size:.6875rem;color:var(--fg-2);padding:.1875rem .4375rem;background:var(--bg-2);border-radius:5px;border:1px solid var(--line);white-space:nowrap}.kbd{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Cascadia Code,Menlo,monospace;font-size:.6875rem;background:var(--bg-3);color:var(--fg-2);padding:1px 6px;border-radius:5px;border:1px solid var(--line);border-bottom-width:2px}.card{background:linear-gradient(180deg,#ffffff06,#ffffff03);border:1px solid var(--line);border-radius:var(--radius);padding:1.125rem;position:relative;text-decoration:none;color:inherit;display:block}.card--glass{backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:linear-gradient(180deg,#161a25a6,#0d0f178c)}.card--interactive{transition:border-color .15s ease,transform .15s ease,background .15s ease;cursor:pointer}.card--interactive:hover{border-color:var(--line-2);transform:translateY(-1px)}.card--accent-sql{border-color:var(--sql-line);background:linear-gradient(180deg,var(--sql-soft),rgba(255,255,255,.01))}.card--accent-primary{border-color:var(--primary-line);background:linear-gradient(180deg,var(--primary-soft),rgba(255,255,255,.01))}.card--accent-warn{border-color:var(--warn-line);background:linear-gradient(180deg,var(--warn-soft),rgba(255,255,255,.01))}.callout{display:flex;gap:.75rem;padding:.875rem 1rem;border-radius:10px;border:1px solid var(--line);background:var(--bg-2);font-size:.84375rem;line-height:1.55;color:var(--fg-2)}.callout__ico{width:22px;height:22px;flex-shrink:0;border-radius:6px;display:grid;place-items:center;font-size:.75rem;font-weight:700;margin-top:1px;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Cascadia Code,Menlo,monospace;color:#0a0b12}.callout__body strong{color:var(--fg);display:block;margin-bottom:.25rem;font-weight:600;font-size:.8125rem}.callout--note{border-color:var(--info-line);background:var(--info-soft)}.callout--note .callout__ico{background:var(--info)}.callout--tip{border-color:var(--sql-line);background:var(--sql-soft)}.callout--tip .callout__ico{background:var(--sql)}.callout--warn{border-color:var(--warn-line);background:var(--warn-soft)}.callout--warn .callout__ico{background:var(--warn)}.callout--err{border-color:var(--err-line);background:var(--err-soft)}.callout--err .callout__ico{background:var(--err)}.code{background:#0b0d15;border:1px solid var(--line);border-radius:10px;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Cascadia Code,Menlo,monospace;font-size:.8125rem;line-height:1.65;overflow:hidden;box-shadow:0 8px 30px -12px #0009}.code__head{display:flex;align-items:center;padding:.5rem .75rem .5rem .875rem;border-bottom:1px solid var(--line);background:#ffffff05;font-size:.75rem;color:var(--fg-3);gap:.625rem;flex-wrap:wrap}.code__lang{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Cascadia Code,Menlo,monospace;font-size:.6875rem;color:var(--fg-2);display:inline-flex;align-items:center;gap:.375rem}.code__lang:before{content:"";width:8px;height:8px;border-radius:2px;background:var(--sql);box-shadow:0 0 8px var(--sql)}.code__file{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Cascadia Code,Menlo,monospace;font-size:.75rem;color:var(--fg-3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.code__actions{margin-left:auto;display:flex;gap:.375rem}.code__copy{font-size:.6875rem;color:var(--fg-3);display:inline-flex;align-items:center;gap:.3125rem;padding:.1875rem .4375rem;border-radius:6px;border:1px solid var(--line);background:var(--bg-2);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,sans-serif}.code__copy:hover{color:var(--fg);border-color:var(--line-2)}.code__copy:disabled{opacity:.6;cursor:not-allowed}.code__body{display:flex;font-size:.8125rem;overflow-x:auto}.code__gutter{flex-shrink:0;padding:.75rem 0;color:var(--fg-4);text-align:right;user-select:none;font-size:.75rem;border-right:1px solid var(--line);min-width:44px}.code__gutter span{display:block;padding:0 .75rem}.code__pre{margin:0;padding:.75rem 1rem;white-space:pre;overflow:visible;flex:1}.code__empty{padding:1.5rem 1rem;text-align:center;color:var(--fg-4);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,sans-serif;font-size:.8125rem}.empty{border:1px dashed var(--line-2);border-radius:12px;padding:1.5rem 1.25rem;background:repeating-linear-gradient(135deg,rgba(255,255,255,.012) 0,rgba(255,255,255,.012) 6px,transparent 6px,transparent 14px),var(--bg-1);display:flex;gap:1rem;align-items:flex-start;color:var(--fg-3)}.empty__ico{width:36px;height:36px;border-radius:10px;background:var(--bg-3);border:1px solid var(--line);display:grid;place-items:center;color:var(--fg-3);flex-shrink:0}.empty__body{flex:1;min-width:0}.empty__title{font-size:.875rem;font-weight:600;color:var(--fg-2);margin-bottom:.25rem}.empty__text{font-size:.8125rem;color:var(--fg-3);line-height:1.55;margin:0}.empty__hint{display:inline-flex;align-items:center;gap:.375rem;margin-top:.625rem;padding:.25rem .5rem;border-radius:6px;background:var(--bg-2);border:1px solid var(--line);font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Cascadia Code,Menlo,monospace;font-size:.6875rem;color:var(--fg-4)}.empty--compact{padding:1rem;gap:.75rem}.empty--compact .empty__ico{width:28px;height:28px;border-radius:8px}.empty--compact .empty__title{font-size:.8125rem}.empty--compact .empty__text{font-size:.78125rem}.progress{display:flex;flex-direction:column;gap:.5rem}.progress__bar{height:6px;background:var(--bg-3);border-radius:999px;overflow:hidden;border:1px solid var(--line)}.progress__fill{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--primary),#c089ff);transition:width .4s ease}.progress__meta{display:flex;justify-content:space-between;font-size:.75rem;color:var(--fg-3)}.breadcrumbs{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--fg-3);flex-wrap:wrap}.breadcrumbs a{color:inherit;text-decoration:none}.breadcrumbs a:hover,.breadcrumbs .breadcrumbs__current{color:var(--fg)}.breadcrumbs .breadcrumbs__sep{color:var(--fg-4);display:inline-flex}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--line);overflow-x:auto;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:.5625rem .875rem;font-size:.8125rem;color:var(--fg-3);background:transparent;border:0;border-bottom:2px solid transparent;margin-bottom:-1px;font-weight:500;white-space:nowrap;cursor:pointer}.tab:hover{color:var(--fg)}.tab.is-active{color:var(--fg);border-bottom-color:var(--primary)}.tab__count{font-family:JetBrains Mono,monospace;font-size:.625rem;background:var(--bg-3);padding:1px 5px;border-radius:4px;margin-left:.375rem;color:var(--fg-3)}.checklist{display:flex;flex-direction:column;gap:.375rem}.check-item{display:flex;align-items:flex-start;gap:.6875rem;padding:.625rem .75rem;border-radius:8px;background:var(--bg-2);border:1px solid var(--line);font-size:.84375rem;color:var(--fg-2);line-height:1.45}.check-item.is-done{color:var(--fg-3);text-decoration:line-through;text-decoration-color:var(--fg-4)}.check-item__box{width:16px;height:16px;border:1.5px solid var(--line-strong);border-radius:4px;flex-shrink:0;margin-top:1px;display:grid;place-items:center;background:var(--bg);color:transparent}.check-item.is-done .check-item__box{background:var(--sql);border-color:var(--sql);color:#0a0b12}.toc{width:220px;flex-shrink:0;padding:1.75rem 0 1.75rem 1.5rem;font-size:.8125rem;color:var(--fg-3);position:sticky;top:56px;align-self:flex-start;max-height:calc(100vh - 56px);overflow-y:auto;display:none}@media(min-width:75rem){.toc{display:block}}.toc__title{font-size:.6875rem;text-transform:uppercase;letter-spacing:.1em;color:var(--fg-4);font-weight:600;margin-bottom:.75rem;padding-left:.75rem}.toc__link{display:block;padding:.3125rem .75rem;color:var(--fg-3);border-left:2px solid var(--line);text-decoration:none;font-size:.78125rem;line-height:1.5}.toc__link:hover{color:var(--fg)}.toc__link.is-active{color:var(--fg);border-left-color:var(--primary);background:linear-gradient(90deg,var(--primary-soft),transparent)}.toc__link--indent{padding-left:1.5rem;font-size:.75rem}.toc__divider{height:1px;background:var(--line);margin:1.25rem 0}.topic-row{padding:0;overflow:hidden;transition:border-color .15s ease}.topic-row.is-doing{border-color:var(--primary-line);background:linear-gradient(180deg,var(--primary-soft),rgba(255,255,255,.01))}.topic-row>summary{list-style:none;cursor:pointer}.topic-row>summary::-webkit-details-marker{display:none}.topic-row>summary::marker{content:""}.topic-row__head{display:flex;align-items:center;gap:1.125rem;padding:1.125rem 1.25rem}@media(max-width:47.9375rem){.topic-row__head{gap:.75rem;padding:1rem;flex-wrap:wrap}}.topic-row__num{width:40px;height:40px;border-radius:10px;background:var(--bg-2);color:var(--fg-3);border:1px solid var(--line);display:grid;place-items:center;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Cascadia Code,Menlo,monospace;font-size:.875rem;font-weight:600;flex-shrink:0}.topic-row__num.is-done{background:var(--sql-soft);color:var(--sql);border-color:var(--sql-line)}.topic-row__num.is-doing{background:var(--primary-soft);color:var(--primary-2);border-color:var(--primary-line)}.topic-row__num.is-final{background:var(--warn-soft);color:var(--warn);border-color:var(--warn-line)}.topic-row__body{flex:1;min-width:0}.topic-row__title{display:flex;align-items:center;gap:.625rem;margin-bottom:.25rem;font-size:.90625rem;font-weight:600;color:var(--fg);flex-wrap:wrap}.topic-row__desc{font-size:.78125rem;color:var(--fg-3);line-height:1.5;max-width:35rem}.topic-row__meta{display:flex;align-items:center;gap:.875rem;color:var(--fg-3);font-size:.78125rem;flex-shrink:0;flex-wrap:wrap}.topic-row__meta>span,.topic-row__meta>.badge{display:inline-flex;align-items:center;gap:.3125rem}@media(max-width:47.9375rem){.topic-row__meta{width:100%;margin-top:.5rem;padding-left:52px}}.topic-row__chevron{width:14px;height:14px;color:var(--fg-4);transition:transform .15s ease}.topic-row[data-open=true] .topic-row__chevron{transform:rotate(0)}.topic-row[data-open=false] .topic-row__chevron{transform:rotate(-90deg)}.topic-row__children{border-top:1px solid var(--line);padding:.625rem 1.25rem .875rem;background:#0000002e}@media(min-width:48rem){.topic-row__children{padding-left:4.875rem}}.topic-row__children[hidden]{display:none}.lesson-row{display:flex;align-items:center;gap:.875rem;padding:.625rem .75rem;border-radius:8px;text-decoration:none;color:var(--fg);background:transparent;border:1px solid transparent;cursor:pointer;margin-top:2px;flex-wrap:wrap}.lesson-row:first-child{margin-top:.375rem}.lesson-row:hover{background:#ffffff06}.lesson-row.is-doing{background:var(--primary-soft);border-color:var(--primary-line)}.lesson-row.is-done .lesson-row__title{color:var(--fg-3)}.lesson-row__id{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Cascadia Code,Menlo,monospace;font-size:.6875rem;color:var(--fg-3);min-width:36px}.lesson-row__title{flex:1;font-size:.84375rem;color:var(--fg);min-width:0}.lesson-row__time{color:var(--fg-3);font-size:.75rem;display:inline-flex;align-items:center;gap:.25rem;min-width:56px;justify-content:flex-end}.lesson-row__arrow{color:var(--fg-4);flex-shrink:0}.difficulty{display:inline-flex;gap:2px;align-items:center}.difficulty__bar{width:10px;height:3px;border-radius:2px;background:var(--bg-3)}.difficulty__bar.is-on{background:var(--fg-2)}.difficulty__bar.is-on--final{background:var(--warn)}.lesson-nav{display:grid;grid-template-columns:1fr;gap:.75rem;margin-top:2.25rem}@media(min-width:48rem){.lesson-nav{grid-template-columns:1fr 1fr}}.lesson-nav__link{padding:1rem;text-decoration:none;display:block;color:inherit;transition:border-color .15s ease,transform .15s ease}.lesson-nav__link:hover{border-color:var(--line-2);transform:translateY(-1px)}.lesson-nav__link--prev{text-align:left}.lesson-nav__link--next{text-align:right;background:linear-gradient(180deg,var(--primary-soft),rgba(255,255,255,.01));border-color:var(--primary-line)}.lesson-nav__link--next .lesson-nav__title{color:var(--primary-2)}.lesson-nav__label{display:inline-flex;align-items:center;gap:.3125rem;font-size:.6875rem;color:var(--fg-3);margin-bottom:.25rem}.lesson-nav__title{font-weight:500;font-size:.875rem;color:var(--fg)}.lesson-nav__placeholder{padding:1rem;border:1px dashed var(--line);border-radius:var(--radius);font-size:.78125rem;color:var(--fg-4);text-align:center;background:#ffffff03}.section{margin-bottom:2.25rem;scroll-margin-top:5rem}.section__head{display:flex;align-items:baseline;gap:.75rem;margin-bottom:.875rem;flex-wrap:wrap}.section__eyebrow{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Cascadia Code,Menlo,monospace;font-size:.6875rem;color:var(--sql);letter-spacing:.06em;white-space:nowrap;opacity:.75}.section__title{margin:0}.section__rule{flex:1;height:1px;background:var(--line);min-width:1.25rem}.app{display:flex;flex-direction:column;min-height:100vh;background:radial-gradient(1200px 600px at 80% -10%,rgba(124,123,255,.08),transparent 60%),radial-gradient(900px 500px at -10% 110%,rgba(94,234,160,.05),transparent 60%),var(--bg);color:var(--fg);isolation:isolate;position:relative}.app__main{flex:1;display:flex;min-height:0}.docs{display:flex;flex:1;min-height:0}.docs__main{flex:1;min-width:0;overflow-y:auto}.docs__inner{max-width:1100px;margin:0 auto;padding:1.75rem 1.25rem 4rem}@media(min-width:48rem){.docs__inner{padding:2rem 2rem 5rem}}@media(min-width:75rem){.docs__inner{padding:1.75rem 3.5rem 5rem}}.docs__layout{display:flex;gap:2.5rem;align-items:flex-start}.docs__article{flex:1;min-width:0}.container{max-width:1080px;margin:0 auto;padding:0 1.25rem}@media(min-width:48rem){.container{padding:0 2.25rem}}@media(min-width:75rem){.container{padding:0 3.75rem}}.topbar{position:sticky;top:0;z-index:50;height:56px;display:flex;align-items:center;gap:.625rem;padding:0 .75rem;border-bottom:1px solid var(--line);background:#0d0f17c7;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}@media(min-width:48rem){.topbar{padding:0 1.5rem;gap:.875rem}}.brand{display:flex;align-items:center;gap:.625rem;font-weight:600;letter-spacing:-.01em;font-size:.875rem;text-decoration:none;color:var(--fg);flex-shrink:0;min-width:0}.brand-mark{width:26px;height:26px;border-radius:8px;border:1px solid var(--line-2);background:#ffffff09;display:grid;place-items:center;color:var(--sql);box-shadow:inset 0 1px #ffffff0a;flex-shrink:0}.brand-name{color:var(--fg);white-space:nowrap}.brand-sub{color:var(--fg-3);font-weight:400;padding-left:.625rem;border-left:1px solid var(--line-2);margin-left:.25rem}@media(max-width:47.9375rem){.brand-sub{display:none}}.topbar__menu-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:34px;border-radius:8px;border:1px solid var(--line);background:var(--bg-2);color:var(--fg-2);flex-shrink:0;margin-left:auto}.topbar__menu-btn:hover{color:var(--fg)}@media(min-width:64rem){.topbar__menu-btn{display:none}}.avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#5eeaa0,#7c7bff);display:grid;place-items:center;font-size:.75rem;font-weight:600;color:#0a0b12;border:1px solid var(--line-2);flex-shrink:0}.sidebar{width:280px;flex-shrink:0;padding:1.25rem .875rem 1.5rem 1.25rem;overflow-y:auto;background:#0b0d1466;border-right:1px solid var(--line);font-size:.8125rem}@media(max-width:63.9375rem){.sidebar{position:fixed;inset:56px 0 0;width:min(86vw,320px);z-index:40;background:var(--bg-1);transform:translate(-100%);transition:transform .22s ease;box-shadow:0 24px 60px -20px #000000b3}}.sidebar[data-open=true]{transform:translate(0)}.sidebar-overlay{position:fixed;inset:56px 0 0;background:#0000008c;backdrop-filter:blur(2px);z-index:35;display:none}.sidebar-overlay[data-open=true]{display:block}@media(min-width:64rem){.sidebar-overlay{display:none!important}}.side-section{margin-bottom:1.375rem}.side-title{font-size:.6875rem;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-4);font-weight:600;margin-bottom:.625rem;padding-left:.5rem}.side-tree{display:flex;flex-direction:column;gap:1px}.side-tree__group{width:100%;text-align:left;padding:.375rem .625rem;font-weight:500;color:var(--fg);display:flex;align-items:center;gap:.5rem;border-radius:7px;font-size:.8125rem}.side-tree__group:hover{background:var(--bg-2)}.side-tree__chevron{width:12px;height:12px;opacity:.5;transition:transform .15s ease;flex-shrink:0}.side-tree__group[aria-expanded=true] .side-tree__chevron{opacity:1;transform:rotate(0)}.side-tree__group[aria-expanded=false] .side-tree__chevron{transform:rotate(-90deg)}.side-tree__num{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Cascadia Code,Menlo,monospace;font-size:.6875rem;color:var(--fg-4);background:var(--bg-2);border:1px solid var(--line);border-radius:5px;padding:1px 5px;flex-shrink:0}.side-tree__title{flex:1;font-size:.8125rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.side-tree__children{display:flex;flex-direction:column;margin-left:.875rem;padding-left:.75rem;border-left:1px solid var(--line);gap:1px;margin-top:2px;margin-bottom:4px}.side-tree__children[hidden]{display:none}.side-tree__child{padding:.3125rem .625rem;font-size:.78125rem;color:var(--fg-3);border-radius:6px;display:flex;align-items:center;gap:.5rem}.side-tree__child:hover{color:var(--fg);background:var(--bg-2)}.side-tree__child.active{color:var(--fg);background:var(--primary-soft);box-shadow:inset 0 0 0 1px var(--primary-line)}.side-tree__child.is-done{color:var(--fg-4)}.side-tree__child .side-tree__child-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.side-check{width:12px;height:12px;border-radius:4px;background:var(--bg-3);border:1px solid var(--line-2);flex-shrink:0;display:grid;place-items:center;color:transparent}.side-check.is-done{background:var(--sql-soft);border-color:var(--sql-line);color:var(--sql)}.side-check.is-doing{background:var(--primary-soft);border-color:var(--primary-line)}.side-check.is-doing:after{content:"";width:6px;height:6px;border-radius:50%;background:var(--primary)}.field{display:flex;align-items:center;gap:.625rem;background:var(--bg-2);border:1px solid var(--line);border-radius:9px;padding:0 .75rem;height:38px;color:var(--fg-3);transition:border-color .15s ease}.field:focus-within{border-color:var(--primary-line);background:var(--bg-3)}.field input{flex:1;background:transparent;border:0;outline:0;color:var(--fg);font-size:.875rem;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,sans-serif;min-width:0}.field input::placeholder{color:var(--fg-3)}.site-footer{border-top:1px solid var(--line);padding:1.5rem 1.25rem;font-size:.8125rem;color:var(--fg-3);background:#0d0f1780}@media(min-width:48rem){.site-footer{padding:1.5rem 2.25rem}}.site-footer__inner{max-width:1100px;margin:0 auto;display:flex;flex-direction:column;gap:.625rem;align-items:flex-start}@media(min-width:48rem){.site-footer__inner{flex-direction:row;justify-content:space-between;align-items:center}}.sql-index{padding-top:1.5rem;padding-bottom:3rem}.sql-hero{border:1px solid var(--sql-line);border-radius:14px;padding:1.25rem 1.25rem 1.125rem;background:radial-gradient(circle at 100% -40%,rgba(94,234,160,.14),transparent 55%),linear-gradient(180deg,#5eeaa00d,#ffffff03);margin-bottom:1.25rem}@media(min-width:48rem){.sql-hero{padding:1.5rem 1.5rem 1.375rem}}.sql-hero__eyebrow{display:inline-flex;align-items:center;gap:.4375rem;color:var(--sql);font-size:.6875rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin:0 0 .5rem}.sql-hero__title{font-size:clamp(1.5rem,1.1rem + 1.6vw,1.875rem);font-weight:600;letter-spacing:-.02em;line-height:1.1;margin:0 0 .5rem;color:var(--fg)}.sql-hero__lead{margin:0;color:var(--fg-2);font-size:.9375rem;line-height:1.55;max-width:48rem}.sql-hero__stats{display:flex;flex-wrap:wrap;gap:.5rem 1.25rem;margin-top:1rem;font-size:.8125rem;color:var(--fg-3)}.sql-hero__stats>span{display:inline-flex;align-items:center;gap:.4375rem}.sql-hero__stats strong{color:var(--fg);font-weight:600}.sql-hero__pending{color:var(--fg-3);font-style:italic}.sql-toolbar{display:grid;grid-template-columns:1fr;gap:.75rem;margin-bottom:1.5rem}@media(min-width:64rem){.sql-toolbar{grid-template-columns:minmax(0,1.25fr) minmax(0,1fr);align-items:stretch}}.sql-search{display:flex;align-items:center;gap:.625rem;padding:.625rem .875rem;border:1px solid var(--line);border-radius:10px;background:var(--bg-2);transition:border-color .15s ease}.sql-search:focus-within{border-color:var(--sql-line)}.sql-search input{flex:1;background:transparent;border:0;outline:0;color:var(--fg);font-size:.9375rem;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,sans-serif;min-width:0}.sql-search input::placeholder{color:var(--fg-3)}.sql-search__count{font-size:.75rem;color:var(--fg-3);white-space:nowrap}.sql-progress{border:1px solid var(--line);border-radius:10px;background:var(--bg-2);padding:.75rem .875rem;display:flex;flex-direction:column;gap:.5rem;justify-content:center}.sql-progress__head{display:flex;justify-content:space-between;align-items:baseline;font-size:.8125rem;font-weight:500;color:var(--fg)}.sql-syllabus__head{display:flex;align-items:baseline;gap:.875rem;margin-bottom:.875rem}.sql-syllabus__head .h2{margin:0;font-size:1.0625rem;font-weight:600}.sql-syllabus__empty{margin:1.25rem 0 0;padding:1rem;border:1px dashed var(--line);border-radius:10px;text-align:center;color:var(--fg-3);font-size:.875rem}.lesson-row[hidden],.sql-syllabus [hidden]{display:none!important}.sql-final-access{display:flex;align-items:center;gap:1rem;margin-top:1.5rem;padding:1rem 1.125rem;border:1px solid var(--warn-line, var(--line));border-radius:12px;background:linear-gradient(180deg,#ffc0640f,#ffffff03);text-decoration:none;color:inherit;transition:border-color .15s ease,transform .15s ease}.sql-final-access:hover{border-color:var(--warn, var(--line-2));transform:translateY(-1px)}.sql-final-access__icon{width:42px;height:42px;border-radius:10px;background:#ffc0641f;border:1px solid var(--warn-line, var(--line));color:var(--warn, var(--fg));display:grid;place-items:center;flex-shrink:0}.sql-final-access__body{flex:1;display:flex;flex-direction:column;gap:.125rem;min-width:0}.sql-final-access__eyebrow{font-size:.6875rem;text-transform:uppercase;letter-spacing:.1em;color:var(--warn, var(--fg-3));font-weight:600}.sql-final-access__title{font-size:.9375rem;font-weight:600;color:var(--fg)}.sql-final-access__sub{font-size:.8125rem;color:var(--fg-3)}.module-hero{display:flex;flex-direction:column;gap:1.5rem;padding:1.75rem;margin-bottom:2.25rem;border-radius:16px;border:1px solid var(--sql-line);background:radial-gradient(circle at 110% -20%,rgba(94,234,160,.18),transparent 60%),linear-gradient(135deg,rgba(94,234,160,.08),var(--bg-2) 70%);position:relative;overflow:hidden}@media(min-width:48rem){.module-hero{flex-direction:row;align-items:flex-start;gap:1.5rem;padding:2rem}}.module-hero__icon{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,rgba(94,234,160,.3),var(--bg-3));border:1px solid var(--sql-line);display:grid;place-items:center;color:var(--sql);flex-shrink:0}.module-hero__body{flex:1;position:relative;min-width:0}.module-hero__title{margin:0 0 .5rem}.module-hero__lead{margin:0;color:var(--fg-2);font-size:.90625rem;max-width:38rem;line-height:1.55}.module-hero__stats{display:flex;gap:1.125rem;margin-top:1.125rem;font-size:.8125rem;color:var(--fg-3);flex-wrap:wrap}.module-hero__stats>span{display:inline-flex;align-items:center;gap:.375rem}.module-hero__cta{display:flex;flex-direction:column;gap:.625rem;flex-shrink:0;align-self:stretch}@media(min-width:48rem){.module-hero__cta{align-items:flex-end;align-self:flex-start}}.topic-list{display:flex;flex-direction:column;gap:.5rem}.module-section__head{display:flex;align-items:center;gap:.625rem;margin-bottom:1.125rem}.module-section__rule{flex:1;height:1px;background:var(--line)}.class-meta{display:flex;align-items:center;gap:.5rem;margin-bottom:.875rem;flex-wrap:wrap}.class-time{font-size:.75rem;color:var(--fg-3);display:inline-flex;align-items:center;gap:.3125rem;margin-left:.375rem}.class-title{margin:0 0 .875rem;font-size:clamp(1.625rem,1.2rem + 1.6vw,2.375rem);font-weight:600;letter-spacing:-.02em;line-height:1.1}.class-title__sub{color:var(--fg-3);font-weight:600}.class-lead{color:var(--fg-2);font-size:.9375rem;line-height:1.75;margin:0 0 1.375rem;max-width:48rem;padding:.875rem 1rem;border-left:3px solid var(--sql-line);background:var(--bg-2);border-radius:0 8px 8px 0}.class-lead.muted{border-left-color:var(--line-2);background:transparent;padding:0;font-style:italic}.class-tags{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:1.875rem}.class-complete{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.125rem;background:linear-gradient(180deg,var(--sql-soft),rgba(255,255,255,.01));border:1px solid var(--sql-line);border-radius:12px;flex-wrap:wrap}.class-complete__title{font-size:.875rem;font-weight:600;margin:0 0 2px;color:var(--fg)}.class-complete__sub{font-size:.8125rem;color:var(--fg-3);margin:0}.lesson-prose{display:flex;flex-direction:column;gap:0}.lesson-prose__section+.lesson-prose__section{margin-top:2.5rem;padding-top:2.5rem;border-top:1px solid var(--line)}.lesson-prose__h3{font-size:1.0625rem;font-weight:600;color:var(--fg);margin:0 0 1rem;letter-spacing:-.01em;line-height:1.3;padding-left:.875rem;border-left:2.5px solid var(--sql)}.lesson-prose__p{color:var(--fg-2);font-size:.9375rem;line-height:1.75;margin:0 0 .875rem}.lesson-prose__p:last-child{margin-bottom:0}.lesson-prose__list{color:var(--fg-2);font-size:.9375rem;line-height:1.65;margin:0 0 .875rem;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:.5rem}.lesson-prose__list:last-child{margin-bottom:0}.lesson-prose__list li{padding-left:1.25rem;position:relative}.lesson-prose__list li:before{content:"";position:absolute;left:.25rem;top:.625em;width:5px;height:5px;border-radius:50%;background:var(--sql);flex-shrink:0}.lesson-prose__list--ol{counter-reset:ol-counter;list-style:none;padding-left:0}.lesson-prose__list--ol li{counter-increment:ol-counter;padding-left:2rem}.lesson-prose__list--ol li:before{content:counter(ol-counter);position:absolute;left:0;top:.05em;width:1.375rem;height:1.375rem;background:var(--sql-soft);border:1px solid var(--sql-line);border-radius:5px;color:var(--sql);font-size:.6875rem;font-weight:700;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Cascadia Code,Menlo,monospace;display:flex;align-items:center;justify-content:center}.lesson-prose__table-wrap{overflow-x:auto;margin:0 0 .75rem;border-radius:10px;border:1px solid var(--line)}.lesson-prose__table-wrap:last-child{margin-bottom:0}.lesson-prose__table{width:100%;border-collapse:collapse;font-size:.875rem}.lesson-prose__table thead{background:var(--bg-3)}.lesson-prose__table thead th{padding:.625rem .875rem;text-align:left;font-weight:600;color:var(--fg);border-bottom:1px solid var(--line);white-space:nowrap}.lesson-prose__table tbody tr:not(:last-child) td{border-bottom:1px solid var(--line)}.lesson-prose__table tbody tr:hover td{background:#ffffff05}.lesson-prose__table tbody td{padding:.5625rem .875rem;color:var(--fg-2);vertical-align:top}.lesson-prose__table tbody td:first-child{font-weight:500;color:var(--fg);white-space:nowrap}.insight-cards{display:flex;flex-direction:column;gap:.625rem}.insight-card{display:flex;gap:.75rem;padding:.875rem 1rem;border-radius:10px;border:1px solid;font-size:.875rem;line-height:1.6;color:var(--fg-2);align-items:flex-start}.insight-card--err{border-color:var(--err-line);background:var(--err-soft)}.insight-card--err .insight-card__ico{background:var(--err)}.insight-card--tip{border-color:var(--sql-line);background:var(--sql-soft)}.insight-card--tip .insight-card__ico{background:var(--sql)}.insight-card__ico{flex-shrink:0;width:20px;height:20px;border-radius:6px;display:grid;place-items:center;font-size:.6875rem;font-weight:700;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Cascadia Code,Menlo,monospace;color:#0a0b12;margin-top:.125rem}.code-examples{display:flex;flex-direction:column;gap:1.5rem}.code-example__label{display:inline-flex;font-size:.75rem;font-weight:600;color:var(--fg-3);margin:0 0 .5rem;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Cascadia Code,Menlo,monospace;background:var(--bg-3);border:1px solid var(--line-2);padding:.1875rem .625rem;border-radius:6px;letter-spacing:.01em}.code-example__note{font-size:.8125rem;color:var(--fg-3);line-height:1.6;margin:.75rem 0 0;padding:.625rem .875rem;border-left:2px solid var(--sql-line);background:var(--sql-soft);border-radius:0 6px 6px 0}.lesson-checklist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.375rem}.lesson-checklist__item{display:flex;align-items:flex-start;gap:.75rem;font-size:.9375rem;color:var(--fg-2);line-height:1.6;padding:.5rem .625rem;border-radius:8px;transition:background .15s;cursor:default}.lesson-checklist__item:hover{background:var(--bg-2)}.lesson-checklist__box{flex-shrink:0;width:18px;height:18px;border-radius:5px;border:1.5px solid var(--sql-line);background:var(--sql-soft);margin-top:.15rem}.concepts-grid{display:grid;grid-template-columns:1fr;gap:.75rem}@media(min-width:48rem){.concepts-grid{grid-template-columns:repeat(2,1fr)}}.concept-card{padding:1rem 1.125rem;border-left:3px solid var(--sql-line);transition:border-color .15s}.concept-card:hover{border-color:var(--sql)}.concept-card__fn{color:var(--sql);font-size:.9375rem;margin-bottom:.4375rem;font-weight:600;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Cascadia Code,Menlo,monospace;display:flex;align-items:center;gap:.5rem}.concept-card__fn:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--sql);flex-shrink:0;opacity:.7}.concept-card__desc{font-size:.875rem;color:var(--fg-2);line-height:1.6;margin:0}.fp-hero{position:relative;padding:3rem 1.25rem 3.5rem;background:radial-gradient(800px 400px at 80% 20%,rgba(255,209,102,.18),transparent 60%),radial-gradient(800px 500px at 10% 90%,rgba(124,123,255,.18),transparent 60%),linear-gradient(180deg,#15131e,#0d0f17);border-bottom:1px solid var(--line);overflow:hidden}@media(min-width:48rem){.fp-hero{padding:3rem 2.25rem 3.5rem}}@media(min-width:75rem){.fp-hero{padding:3rem 3.75rem 3.5rem}}.fp-hero__grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:32px 32px;-webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 30%,black,transparent 70%);mask-image:radial-gradient(ellipse 80% 60% at 50% 30%,black,transparent 70%);pointer-events:none}.fp-hero__inner{position:relative;max-width:1100px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem}@media(min-width:48rem){.fp-hero__inner{flex-direction:row;align-items:flex-start;gap:1.75rem}}.fp-hero__badge{width:80px;height:80px;border-radius:20px;background:linear-gradient(135deg,#ffe082,#ffb74d 60%,#ff8a65);display:grid;place-items:center;color:#3d2200;flex-shrink:0;box-shadow:0 20px 60px -20px #ffa55099,inset 0 1px #fff6}.fp-hero__body{flex:1;min-width:0}.fp-hero__chips{display:flex;align-items:center;gap:.5rem;margin-bottom:.875rem;flex-wrap:wrap}.fp-hero__title{font-size:clamp(2rem,1.4rem + 4vw,3rem);margin:0 0 .875rem;line-height:1.1;font-weight:600;letter-spacing:-.02em}.fp-hero__title-accent{background:linear-gradient(90deg,#ffd166,#ff8c5e);-webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block}.fp-hero__lead{margin:0;color:var(--fg-2);font-size:1rem;line-height:1.6;max-width:40rem}.fp-hero__stats{display:flex;gap:1.5rem;margin-top:1.375rem;font-size:.84375rem;color:var(--fg-3);flex-wrap:wrap}.fp-hero__stats>span{display:inline-flex;align-items:center;gap:.375rem}.fp-hero__stats strong{color:var(--fg);font-weight:600}.fp-hero__cta{display:flex;flex-direction:column;gap:.5rem;min-width:11rem}@media(max-width:47.9375rem){.fp-hero__cta{width:100%}}.fp-body{max-width:1100px;margin:0 auto;padding:2.25rem 1.25rem 4rem}@media(min-width:48rem){.fp-body{padding:2.5rem 2.25rem 5rem}}@media(min-width:75rem){.fp-body{padding:2.5rem 3.75rem 5rem}}.fp-twocol{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-bottom:2.5rem}@media(min-width:48rem){.fp-twocol{grid-template-columns:1fr 1fr}}.fp-rf-grid{display:grid;grid-template-columns:1fr;gap:.625rem}@media(min-width:48rem){.fp-rf-grid{grid-template-columns:repeat(2,1fr)}}.fp-final-cta{margin-top:2.25rem;padding:1.75rem;border-radius:16px;background:linear-gradient(135deg,#7c7bff2e,#5eeaa01f);border:1px solid var(--primary-line);display:flex;align-items:center;gap:1.5rem;position:relative;overflow:hidden;flex-wrap:wrap}.fp-final-cta__title{margin:0 0 4px}.fp-final-cta__sub{font-size:.84375rem;color:var(--fg-2);margin:0}.fp-final-cta>svg{color:var(--warn);flex-shrink:0}.fp-final-cta__body{flex:1;position:relative;min-width:12rem}:root{--bg: #0a0b12;--bg-1: #0d0f17;--bg-2: #11141d;--bg-3: #161a25;--bg-elev: #1a1e2a;--bg-deep: #060710;--line: rgba(255, 255, 255, .07);--line-2: rgba(255, 255, 255, .12);--line-strong: rgba(255, 255, 255, .18);--fg: #e8eaf2;--fg-2: #b6bccd;--fg-3: #7a8295;--fg-4: #525a6e;--primary: #7c7bff;--primary-2: #9b8cff;--primary-soft: rgba(124, 123, 255, .14);--primary-line: rgba(124, 123, 255, .35);--sql: #5eeaa0;--sql-soft: rgba(94, 234, 160, .12);--sql-line: rgba(94, 234, 160, .32);--warn: #ffd166;--warn-soft: rgba(255, 209, 102, .12);--warn-line: rgba(255, 209, 102, .32);--err: #ff7a8a;--err-soft: rgba(255, 122, 138, .12);--err-line: rgba(255, 122, 138, .32);--info: #6cc5ff;--info-soft: rgba(108, 197, 255, .1);--info-line: rgba(108, 197, 255, .3);--mod-html: #ff8a5b;--mod-css: #6cc5ff;--mod-js: #ffd166;--mod-react: #61dafb;--mod-backend: #b48cff;--mod-api: #5eeaa0;--mod-git: #ff7a8a;--mod-sec: #ff5fa2;--radius-xs: 6px;--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--radius-xl: 22px;--shadow-1: 0 1px 0 rgba(255,255,255,.04) inset, 0 0 0 1px rgba(255,255,255,.04);--shadow-2: 0 12px 40px -12px rgba(0,0,0,.8), 0 0 0 1px var(--line);--shadow-glow: 0 6px 18px -6px rgba(124,123,255,.7)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.visually-hidden:focus-visible{position:fixed;top:.5rem;left:.5rem;width:auto;height:auto;clip:auto;padding:.5rem .75rem;margin:0;background:var(--bg-3);color:var(--fg);border-radius:8px;z-index:100}
