*,:before,:after{box-sizing:border-box}:root{--font-sans:"IBM Plex Sans", system-ui, sans-serif;--font-mono:"IBM Plex Mono", "Fira Code", monospace;--bg-base:#161616;--bg-layer:#262626;--bg-layer-2:#393939;--bg-hover:#2c2c2c;--bg-selected:#393939;--border-subtle:#393939;--border-strong:#525252;--text-primary:#f4f4f4;--text-secondary:#c6c6c6;--text-placeholder:#6f6f6f;--text-disabled:#525252;--color-blue:#4589ff;--color-blue-hover:#5596ff;--color-blue-dark:#0353e9;--color-teal:#08bdba;--color-green:#42be65;--color-green-bg:#1c3a27;--color-red:#fa4d56;--color-red-bg:#3a1a1d;--color-yellow:#f1c21b;--color-orange:#ff832b;--color-purple:#be95ff;--easy-color:#42be65;--easy-bg:#1c3a27;--medium-color:#f1c21b;--medium-bg:#3a2e0a;--hard-color:#ff832b;--hard-bg:#3a1f0a;--header-height:48px;--schema-height:180px;--panel-gap:1px}html,body{background:var(--bg-base);height:100%;color:var(--text-primary);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;margin:0;padding:0;font-size:14px;line-height:1.5}#root{flex-direction:column;height:100vh;display:flex;overflow:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#6f6f6f}.app-header{height:var(--header-height);background:var(--bg-layer);border-bottom:1px solid var(--border-subtle);flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;padding:0 1rem;display:flex}.app-logo{color:var(--text-primary);align-items:center;gap:.5rem;text-decoration:none;display:flex}.app-logo-icon{background:var(--color-blue);color:#fff;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:13px;font-weight:700;display:flex}.app-logo-name{letter-spacing:.02em;color:var(--text-primary);font-size:14px;font-weight:600}.header-center{flex:1;justify-content:center;align-items:center;gap:.5rem;display:flex}.progress-dots{align-items:center;gap:4px;max-width:400px;display:flex;overflow:hidden}.progress-dot{aspect-ratio:1;background:var(--bg-layer-2);border:1px solid var(--border-strong);cursor:pointer;border-radius:50%;flex-shrink:0;width:8px;height:8px;padding:0;transition:all .15s}.progress-dot.solved,.progress-dot.completed{background:var(--color-green);border-color:var(--color-green)}.progress-dot.attempted{background:var(--color-yellow);border-color:var(--color-yellow)}.progress-dot.current{background:var(--color-blue);border-color:var(--color-blue);width:10px;height:10px}.progress-text{color:var(--text-secondary);white-space:nowrap;font-variant-numeric:tabular-nums;font-size:12px}.header-right{align-items:center;gap:.5rem;display:flex}.app-main{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.panels-row{flex:1;min-height:0;display:flex;overflow:hidden}.challenge-panel{border-right:1px solid var(--border-subtle);background:var(--bg-base);flex-direction:column;width:45%;min-width:340px;display:flex;overflow:hidden}.challenge-meta{border-bottom:1px solid var(--border-subtle);flex-wrap:wrap;flex-shrink:0;align-items:flex-start;gap:.5rem;padding:.875rem 1rem .75rem;display:flex}.dataset-badge{background:var(--bg-layer-2);color:var(--text-secondary);border:1px solid var(--border-subtle);letter-spacing:.03em;text-transform:uppercase;border-radius:2px;padding:2px 8px;font-size:11px;font-weight:500}.difficulty-badge{letter-spacing:.03em;text-transform:uppercase;border-radius:2px;padding:2px 8px;font-size:11px;font-weight:600}.difficulty-badge.easy{color:var(--easy-color);background:var(--easy-bg)}.difficulty-badge.medium{color:var(--medium-color);background:var(--medium-bg)}.difficulty-badge.hard{color:var(--hard-color);background:var(--hard-bg)}.challenge-body{border-bottom:1px solid var(--border-subtle);flex-shrink:0;padding:1rem;overflow-y:auto}.challenge-title{color:var(--text-primary);margin:0 0 .75rem;font-size:16px;font-weight:600;line-height:1.3}.challenge-prompt{color:var(--text-secondary);margin:0 0 .75rem;font-size:14px;line-height:1.6}.hint-toggle{color:var(--color-blue);cursor:pointer;background:0 0;border:none;align-items:center;gap:.375rem;padding:0;font-family:inherit;font-size:12px;font-weight:500;transition:color .1s;display:inline-flex}.hint-toggle:hover{color:var(--color-blue-hover)}.hint-box{background:var(--bg-layer);border-left:3px solid var(--color-blue);color:var(--text-secondary);border-radius:0 2px 2px 0;margin-top:.75rem;padding:.75rem;font-size:13px;line-height:1.6;animation:.15s slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.editor-section{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.editor-toolbar{border-bottom:1px solid var(--border-subtle);background:var(--bg-layer);flex-shrink:0;justify-content:space-between;align-items:center;padding:.5rem 1rem;display:flex}.editor-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:500}.editor-hint{color:var(--text-placeholder);font-size:11px}.sql-editor-wrap{background:#161616;flex-direction:column;flex:1;height:100%;min-height:0;display:flex;overflow:hidden}.sql-editor-textarea{display:none}.sql-editor-wrap.disabled{opacity:.6}.cm-editor{height:100%;outline:none!important}.cm-focused{outline:none!important}.editor-actions{border-top:1px solid var(--border-subtle);background:var(--bg-layer);flex-shrink:0;align-items:center;gap:.5rem;padding:.5rem 1rem;display:flex}.challenges-list{border-right:1px solid var(--border-subtle);background:var(--bg-layer);flex-direction:column;flex-shrink:0;width:240px;min-width:200px;max-width:280px;height:100%;display:flex;overflow:hidden}.cl-header{border-bottom:1px solid var(--border-subtle);background:var(--bg-layer);flex-direction:column;flex-shrink:0;gap:.5rem;padding:.75rem;display:flex}.cl-title-row{justify-content:space-between;align-items:center;display:flex}.cl-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);font-size:11px;font-weight:600}.cl-count{color:var(--color-green);font-variant-numeric:tabular-nums;font-size:11px;font-weight:600}.cl-search-wrap{align-items:center;display:flex;position:relative}.cl-search-icon{color:var(--text-placeholder);pointer-events:none;font-size:14px;line-height:1;position:absolute;left:7px}.cl-search{background:var(--bg-base);border:1px solid var(--border-subtle);width:100%;color:var(--text-primary);border-radius:3px;outline:none;padding:5px 26px;font-family:inherit;font-size:12px;transition:border-color .15s}.cl-search:focus{border-color:var(--color-blue)}.cl-search-clear{color:var(--text-placeholder);cursor:pointer;background:0 0;border:none;border-radius:2px;padding:2px 4px;font-size:14px;line-height:1;position:absolute;right:5px}.cl-search-clear:hover{color:var(--text-primary);background:var(--bg-layer-2)}.cl-filters{gap:4px;display:flex}.cl-filter-btn{border:1px solid var(--border-subtle);background:var(--bg-base);color:var(--text-secondary);cursor:pointer;text-transform:uppercase;letter-spacing:.04em;border-radius:2px;flex:1;padding:3px 0;font-family:inherit;font-size:10px;font-weight:600;transition:all .12s}.cl-filter-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.cl-filter-btn.active{background:var(--bg-layer-2);border-color:var(--border-strong);color:var(--text-primary)}.cl-filter-btn.active.easy{border-color:var(--easy-color);color:var(--easy-color)}.cl-filter-btn.active.medium{border-color:var(--medium-color);color:var(--medium-color)}.cl-filter-btn.active.hard{border-color:var(--hard-color);color:var(--hard-color)}.cl-body{flex:1;min-height:0;overflow:hidden auto}.cl-group{border-bottom:1px solid var(--border-subtle)}.cl-group-header{text-transform:uppercase;letter-spacing:.08em;color:var(--color-teal);z-index:1;background:#08bdba0f;padding:6px 12px 4px;font-size:10px;font-weight:700;position:sticky;top:0}.cl-item{cursor:pointer;text-align:left;width:100%;color:var(--text-secondary);background:0 0;border:none;border-bottom:1px solid #39393966;align-items:center;gap:7px;padding:7px 12px;font-family:inherit;font-size:12px;transition:background .1s,color .1s;display:flex}.cl-item:last-child{border-bottom:none}.cl-item:hover{background:var(--bg-hover);color:var(--text-primary)}.cl-item.active{color:var(--color-blue);border-left:2px solid var(--color-blue);background:#4589ff1f;padding-left:10px}.cl-item.done{color:var(--color-green)}.cl-item.attempted{color:var(--color-yellow)}.cl-item.done.active{color:var(--color-green);border-left-color:var(--color-green);background:#42be651a}.cl-item.attempted.active{color:var(--color-yellow);border-left-color:var(--color-yellow);background:#f1c21b1a}.cl-item-status{text-align:center;flex-shrink:0;width:12px;font-size:11px}.cl-item-title{text-overflow:ellipsis;white-space:nowrap;flex:1;line-height:1.4;overflow:hidden}.cl-item-badge{text-transform:uppercase;border-radius:2px;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;font-size:9px;font-weight:700;display:flex}.cl-item-badge.easy{background:var(--easy-bg);color:var(--easy-color)}.cl-item-badge.medium{background:var(--medium-bg);color:var(--medium-color)}.cl-item-badge.hard{background:var(--hard-bg);color:var(--hard-color)}.cl-empty{text-align:center;color:var(--text-placeholder);padding:2rem 1rem;font-size:12px}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:0;align-items:center;gap:.375rem;padding:.5rem 1rem;font-family:inherit;font-size:14px;font-weight:500;text-decoration:none;transition:background .1s,color .1s;display:inline-flex}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--color-blue);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-blue-hover)}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border-strong);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.btn-success{background:var(--color-green);color:#0a1f12;font-weight:600;animation:.5s cubic-bezier(.175,.885,.32,1.275) success-bounce}@keyframes success-bounce{0%{transform:scale(.8)}50%{transform:scale(1.1)}to{transform:scale(1)}}.btn-success:hover:not(:disabled){background:#4ecd6e}.btn-sm{padding:.25rem .625rem;font-size:12px}.results-panel{background:var(--bg-base);flex-direction:column;flex:1;display:flex;overflow:hidden}.results-header{border-bottom:1px solid var(--border-subtle);background:var(--bg-layer);flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;padding:.5rem 1rem;display:flex}.results-header-left{align-items:center;gap:.75rem;display:flex}.result-status{align-items:center;gap:.5rem;font-size:13px;font-weight:500;display:flex}.status-correct{color:var(--color-green);animation:.4s cubic-bezier(.175,.885,.32,1.275) success-pop}@keyframes success-pop{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.status-wrong{color:var(--color-red)}.results-body{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.result-pane{border-bottom:1px solid var(--border-subtle);flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.result-pane:last-child{border-bottom:none}.result-pane-header{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;background:var(--bg-layer);border-bottom:1px solid var(--border-subtle);flex-shrink:0;padding:.375rem 1rem;font-size:11px;font-weight:500}.result-pane-body{flex:1;min-height:0;overflow:auto}.result-table-wrap{height:100%;overflow:auto}.result-table{border-collapse:collapse;width:100%;font-size:12px;font-family:var(--font-mono)}.result-table th{background:var(--bg-layer-2);color:var(--text-secondary);text-align:left;border-bottom:1px solid var(--border-subtle);white-space:nowrap;text-transform:uppercase;letter-spacing:.04em;padding:6px 12px;font-size:11px;font-weight:500;position:sticky;top:0}.result-table td{border-bottom:1px solid var(--border-subtle);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:300px;padding:5px 12px;overflow:hidden}.result-table tr:hover td{background:var(--bg-hover)}.result-table tr:nth-child(2n) td{background:#ffffff05}.result-empty{text-align:center;color:var(--text-placeholder);padding:2rem 1rem;font-size:13px}.result-error{background:var(--color-red-bg);border-left:3px solid var(--color-red);border-radius:0 2px 2px 0;margin:.75rem 1rem;padding:1rem}.result-error-label{color:var(--color-red);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.375rem;font-size:11px;font-weight:600}.result-error-msg{font-family:var(--font-mono);color:#ffb3b8;word-break:break-all;font-size:12px;line-height:1.5}.result-truncated{color:var(--color-yellow);border-top:1px solid var(--border-subtle);background:#3a2e0a;flex-shrink:0;padding:4px 12px;font-size:11px}.result-placeholder{height:100%;color:var(--text-placeholder);flex-direction:column;justify-content:center;align-items:center;gap:.5rem;display:flex}.result-placeholder-icon{opacity:.4;font-size:28px}.result-placeholder-text{font-size:13px}.schema-panel{border-top:1px solid var(--border-subtle);background:var(--bg-layer);max-height:var(--schema-height);flex-shrink:0}.schema-toggle-btn{cursor:pointer;width:100%;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;background:0 0;border:none;border-bottom:1px solid #0000;justify-content:space-between;align-items:center;padding:.5rem 1rem;font-family:inherit;font-size:11px;font-weight:500;transition:color .1s;display:flex}.schema-toggle-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.schema-toggle-btn.open{border-bottom-color:var(--border-subtle)}.schema-body{max-height:calc(var(--schema-height) - 36px);flex-wrap:nowrap;gap:1.5rem;padding:.75rem 1rem;display:flex;overflow:auto}.schema-table{flex-shrink:0}.schema-table-name{color:var(--color-teal);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.375rem;font-size:11px;font-weight:600}.schema-columns{margin:0;padding:0;list-style:none}.schema-column{font-family:var(--font-mono);color:var(--text-secondary);align-items:center;gap:.5rem;padding:1px 0;font-size:11px;display:flex}.schema-column-name{color:var(--text-primary)}.schema-column-type{color:var(--color-purple);font-size:10px}.schema-column-pk{color:var(--color-yellow);border:1px solid var(--color-yellow);opacity:.7;border-radius:2px;padding:0 3px;font-size:9px}.dev-panel{border:1px solid var(--color-purple);z-index:1000;background:#1a0a1e;border-bottom:none;border-right:none;flex-direction:column;width:480px;max-height:60vh;display:flex;position:fixed;bottom:0;right:0}.dev-panel-header{color:var(--color-purple);text-transform:uppercase;letter-spacing:.06em;background:#be95ff1a;border-bottom:1px solid #be95ff33;justify-content:space-between;align-items:center;padding:.5rem .75rem;font-size:11px;font-weight:600;display:flex}.dev-panel-body{flex-direction:column;flex:1;gap:.75rem;padding:.75rem;display:flex;overflow-y:auto}.dev-section-label{color:var(--color-purple);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.25rem;font-size:10px;font-weight:600}.dev-code{font-family:var(--font-mono);color:#e2b8ff;white-space:pre-wrap;word-break:break-all;background:#0000004d;border-radius:2px;padding:.5rem;font-size:11px;overflow-x:auto}.dev-test-result{margin-top:.25rem;padding:.5rem;font-size:12px}.dev-test-pass{color:var(--color-green)}.dev-test-fail{color:var(--color-red)}.home-container{background:var(--bg-base);flex-direction:column;justify-content:center;align-items:center;height:100vh;padding:2rem;display:flex}.home-content{text-align:center;width:100%;max-width:900px}.home-title{color:var(--text-primary);margin-bottom:.5rem;font-size:2.5rem;font-weight:700}.home-subtitle{color:var(--text-secondary);margin-bottom:3rem;font-size:1.1rem}.module-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;display:grid}.module-card{background:var(--bg-layer);border:1px solid var(--border-subtle);cursor:pointer;border-radius:8px;flex-direction:column;align-items:center;padding:2.5rem 2rem;transition:all .2s;display:flex;position:relative;overflow:hidden}.module-card:hover{border-color:var(--color-blue);background:var(--bg-hover);transform:translateY(-4px)}.module-icon{color:#fff;border-radius:12px;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:1.5rem;font-size:24px;font-weight:700;display:flex}.sql-icon{background:var(--color-blue)}.python-icon{background:var(--color-teal);opacity:.7}.module-name{color:var(--text-primary);margin-bottom:.75rem;font-size:1.5rem;font-weight:600}.module-desc{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.95rem;line-height:1.6}.module-content-preview{text-align:left;border-top:1px solid var(--border-subtle);width:100%;padding-top:1.5rem}.preview-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-placeholder);margin-bottom:1rem;font-size:11px;font-weight:600;display:block}.preview-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.preview-item{color:var(--text-secondary);align-items:center;gap:.75rem;font-size:13px;display:flex}.preview-dot{background:var(--color-blue);border-radius:50%;flex-shrink:0;width:6px;height:6px}.skeleton-list{flex-direction:column;gap:.75rem;display:flex}.skeleton-item{background:var(--bg-layer-2);border-radius:4px;height:14px;position:relative;overflow:hidden}.skeleton-item:after{content:"";background:linear-gradient(90deg,#0000,#ffffff08,#0000);width:100%;height:100%;animation:1.5s infinite skeleton-shimmer;position:absolute;top:0;left:0}@keyframes skeleton-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.coming-soon-badge{background:var(--bg-layer-2);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border:1px solid var(--border-subtle);border-radius:4px;padding:4px 10px;font-size:10px;font-weight:700;position:absolute;top:12px;right:12px}.coming-soon-container{background:var(--bg-base);text-align:center;justify-content:center;align-items:center;height:100vh;display:flex}.coming-soon-content{max-width:500px;padding:2rem}.coming-soon-icon{margin-bottom:1.5rem;font-size:4rem}.coming-soon-content h1{margin-bottom:1rem;font-size:2rem}.coming-soon-content p{color:var(--text-secondary);margin-bottom:2rem;line-height:1.6}.loading-overlay{background:var(--bg-base);z-index:10;flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex;position:absolute;inset:0}.loading-spinner{border:2px solid var(--border-subtle);border-top-color:var(--color-blue);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--text-secondary);font-size:13px}.challenge-nav{align-items:center;gap:.375rem;display:flex}@media (width<=768px){.panels-row{flex-direction:column}.challenge-panel{border-right:none;border-bottom:1px solid var(--border-subtle);width:100%;height:55vh}.progress-dots{display:none}}
