:root{--bg-primary:#0d1117;--bg-secondary:#161b22;--bg-tertiary:#1c2128;--bg-card:#161b22;--bg-card-hover:#1c2128;--bg-surface:#ffffff0a;--bg-glass:#ffffff0a;--navbar-bg:#0d1423d9;--navbar-border:#2f81f740;--text-primary:#e6edf3;--text-secondary:#8b949e;--text-tertiary:#6e7681;--text-muted:#484f58;--accent-primary:#2f81f7;--accent-primary-glow:#2f81f733;--accent-secondary:#3dc9b0;--accent-secondary-glow:#3dc9b033;--accent-tertiary:#bc8cff;--accent-warning:#d29922;--accent-error:#f85149;--accent-success:#3fb950;--gradient-primary:#2f81f7;--gradient-secondary:#3dc9b0;--gradient-accent:#bc8cff;--gradient-dark:#0d1117;--gradient-card:#2f81f70d;--border-color:#30363d;--border-active:#388bfd;--viz-default:#388bfd;--viz-comparing:#d29922;--viz-swapping:#f85149;--viz-sorted:#3fb950;--viz-pivot:#bc8cff;--viz-current:#3dc9b0;--viz-visited:#8957e5;--viz-found:#3fb950;--viz-searching:#2f81f7;--viz-path:#d29922;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--text-xs:.7rem;--text-sm:.8rem;--text-base:.9rem;--text-lg:1.05rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:2rem;--text-4xl:2.5rem;--text-5xl:3rem;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--radius-sm:4px;--radius-md:6px;--radius-lg:10px;--radius-xl:16px;--radius-full:9999px;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 3px 10px #0006;--shadow-lg:0 8px 24px #0006;--shadow-glow:0 0 12px var(--accent-primary-glow);--shadow-glow-secondary:0 0 12px var(--accent-secondary-glow);--transition-fast:.15s ease;--transition-base:.22s ease;--transition-slow:.35s ease;--z-base:1;--z-overlay:1000;--z-modal:2000;--z-tooltip:3000}[data-theme=light]{--bg-primary:#fff;--bg-secondary:#f6f8fa;--bg-tertiary:#eaeef2;--bg-card:#fff;--bg-card-hover:#f6f8fa;--bg-surface:#00000008;--bg-glass:#00000008;--navbar-bg:#f6f8fad9;--navbar-border:#0969da40;--text-primary:#1f2328;--text-secondary:#656d76;--text-tertiary:#8c959f;--text-muted:#afb8c1;--border-color:#d0d7de;--border-active:#0969da;--accent-primary:#0969da;--accent-primary-glow:#0969da26;--accent-secondary:#1a7f64;--accent-secondary-glow:#1a7f6426;--accent-success:#1a7f64;--accent-error:#cf222e;--accent-warning:#9a6700;--accent-tertiary:#8250df;--gradient-primary:#0969da;--gradient-dark:#fff;--gradient-card:#0969da0a;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 3px 10px #0000001a;--shadow-lg:0 8px 24px #0000001f;--viz-default:#0969da;--viz-comparing:#9a6700;--viz-swapping:#cf222e;--viz-sorted:#1a7f64;--viz-pivot:#8250df;--viz-current:#1a7f64;--viz-visited:#8250df;--viz-found:#1a7f64;--viz-searching:#0969da;--viz-path:#9a6700}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none}ul,ol{list-style:none}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none;outline:none}img{max-width:100%;display:block}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}::selection{background:var(--accent-primary);color:#fff}#root,.app{flex-direction:column;min-height:100vh;display:flex}.glass{background:var(--bg-card);border:1px solid var(--border-color)}.glow{box-shadow:var(--shadow-glow)}code,pre,.mono{font-family:var(--font-mono)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%{opacity:.6}50%{opacity:.3}to{opacity:.6}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes glow-pulse{0%,to{box-shadow:0 0 8px var(--accent-primary-glow)}50%{box-shadow:0 0 16px var(--accent-primary-glow)}}.animate-fade-in{animation:.4s forwards fadeIn}.animate-slide-up{animation:.5s forwards slideUp}@keyframes spin{to{transform:rotate(360deg)}}.navbar{z-index:var(--z-overlay);padding:0 var(--space-xl);background:var(--navbar-bg);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--navbar-border);justify-content:space-between;align-items:center;height:56px;display:flex;position:sticky;top:0;box-shadow:0 4px 30px #0000001a}.navbar-brand{align-items:center;gap:var(--space-sm);letter-spacing:-.3px;color:var(--text-primary);font-size:1.25rem;font-weight:700;display:flex}.brand-logo{object-fit:contain;width:auto;height:36px}.brand-text{color:var(--text-primary)}.navbar-links{align-items:center;height:100%;display:flex}.nav-link{padding:0 var(--space-md);height:100%;font-size:var(--text-sm);color:var(--text-secondary);transition:color var(--transition-fast);align-items:center;gap:6px;font-weight:500;display:flex;position:relative}.nav-link:hover,.nav-link.active{color:var(--text-primary)}.nav-icon{font-size:.85rem}.nav-indicator{bottom:0;left:var(--space-md);right:var(--space-md);background:var(--accent-primary);border-radius:var(--radius-full) var(--radius-full) 0 0;height:2px;position:absolute}.navbar-actions{align-items:center;gap:var(--space-sm);display:flex}.theme-toggle{border-radius:var(--radius-md);border:1px solid var(--border-color);width:34px;height:34px;color:var(--text-secondary);transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.theme-toggle:hover{background:var(--bg-secondary);border-color:var(--text-tertiary);color:var(--text-primary)}.theme-icon{justify-content:center;align-items:center;font-size:1rem;line-height:1;display:flex}.nav-btn{border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--text-secondary);border:1px solid var(--border-color);transition:all var(--transition-fast);align-items:center;gap:6px;padding:6px 12px;font-weight:500;display:flex}.nav-btn:hover{color:var(--text-primary);border-color:var(--text-tertiary);background:var(--bg-secondary)}.github-btn{color:var(--text-secondary)}.mobile-menu-toggle{cursor:pointer;z-index:1002;background:0 0;border:none;flex-direction:column;gap:5px;margin-right:-10px;padding:10px;display:none}.hamburger-bar{background:var(--text-primary);border-radius:2px;width:20px;height:2px;transition:all .3s cubic-bezier(.4,0,.2,1);display:block}.mobile-menu-toggle.active .hamburger-bar:first-child{transform:translateY(7px)rotate(45deg)}.mobile-menu-toggle.active .hamburger-bar:nth-child(2){opacity:0;transform:translate(-10px)}.mobile-menu-toggle.active .hamburger-bar:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.mobile-navbar-actions{display:none}@media (width<=850px){.mobile-menu-toggle{display:flex}.navbar-actions{display:none!important}.navbar-links{background:var(--navbar-bg);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--navbar-border);opacity:0;pointer-events:none;z-index:1001;flex-direction:column;justify-content:flex-start;gap:10px;height:calc(100dvh - 56px);padding:20px;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:56px;left:0;right:0;overflow-y:auto;transform:translateY(-100%);box-shadow:0 10px 30px #0003}.navbar-links.mobile-open{opacity:1;pointer-events:auto;transform:translateY(0)}.nav-link{border-radius:8px;flex-shrink:0;width:100%;height:48px;padding:0 15px;font-size:1rem}.nav-link.active{background:var(--bg-surface)}.nav-indicator{border-radius:0 4px 4px 0;width:3px;height:20px;top:50%;left:0;right:auto;transform:translateY(-50%)}.nav-label{display:inline}.mobile-navbar-actions{justify-content:space-between;align-items:center;gap:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--navbar-border);flex-direction:row;flex-shrink:0;width:100%;margin-top:auto;display:flex}.mobile-navbar-actions .theme-toggle{border-radius:var(--radius-md);border:1px solid var(--border-color);width:38px;height:38px;color:var(--text-secondary);background:0 0;justify-content:center;align-items:center;display:flex}.mobile-user-actions{align-items:center;gap:var(--space-sm);flex-direction:row;display:flex}.mobile-user-info{align-items:center;display:flex}.mobile-navbar-actions .login-btn,.mobile-navbar-actions .signout-btn{width:auto;height:38px;font-size:var(--text-xs);justify-content:center;align-items:center;padding:0 16px;display:inline-flex}}@media (width<=480px){.brand-text{display:none}}.navbar-user{align-items:center;gap:var(--space-sm);margin-left:var(--space-xs);padding-left:var(--space-sm);border-left:1px solid var(--border-color);display:flex}.navbar-avatar{object-fit:cover;border:2px solid var(--border-color);background:var(--bg-tertiary);border-radius:50%;width:30px;height:30px}.signout-btn{font-size:var(--text-xs);color:var(--text-secondary);border-radius:var(--radius-sm);border:1px solid var(--border-color);transition:all var(--transition-fast);background:0 0;padding:5px 10px;font-weight:500}.signout-btn:hover{color:var(--accent-error);border-color:var(--accent-error);background:#f8514914}.login-btn{font-size:var(--text-xs);color:var(--bg-primary);border-radius:var(--radius-sm);background:var(--accent-primary,#2f81f7);border:1px solid var(--accent-primary,#2f81f7);transition:all var(--transition-fast);justify-content:center;align-items:center;padding:5px 12px;font-weight:500;text-decoration:none;display:inline-flex}.login-btn:hover{filter:brightness(1.1);color:var(--bg-primary)}.footer{background:var(--bg-secondary,#0d1117);border-top:1px solid var(--border-color,#ffffff1a);color:var(--text-secondary,#8b949e);margin-top:auto;padding:4rem 2rem 2rem}.footer-content{grid-template-columns:1.5fr 3fr;gap:4rem;max-width:1200px;margin:0 auto 4rem;display:grid}.footer-brand{color:var(--text-primary,#fff);letter-spacing:-.02em;margin-bottom:1rem;font-size:1.8rem;font-weight:800}.footer-description{max-width:320px;margin-bottom:2rem;line-height:1.6}.social-links{gap:1rem;display:flex}.social-icon{background:var(--bg-surface);width:42px;height:42px;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:12px;justify-content:center;align-items:center;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.social-icon:hover{color:var(--text-primary);border-color:var(--accent-primary);box-shadow:var(--shadow-md);transform:translateY(-4px)}.social-icon.linkedin:hover{background:#0077b5}.social-icon.instagram:hover{background:#dc2743}.social-icon.twitter:hover{background:#1da1f2}.social-icon.github:hover{background:#24292e}.footer-links-container{grid-template-columns:repeat(3,1fr);gap:2rem;display:grid}.footer-section h4{color:var(--text-primary,#fff);margin-bottom:1.5rem;font-size:1.1rem;font-weight:600}.footer-section ul{margin:0;padding:0;list-style:none}.footer-section ul li{margin-bottom:.8rem}.footer-section ul li a{color:inherit;font-size:.95rem;text-decoration:none;transition:color .2s}.footer-section ul li a:hover{color:var(--primary-color,#2f81f7)}.contact-item{align-items:center;gap:.8rem;font-size:.95rem;display:flex}.footer-email{color:inherit;text-decoration:none;transition:color .2s}.footer-email:hover{color:var(--primary-color,#2f81f7)}.btn-newsletter{align-items:center;gap:.5rem;margin-top:.5rem;font-weight:500;display:inline-flex;color:var(--primary-color,#2f81f7)!important}.footer-bottom{border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding-top:2rem;font-size:.85rem;display:flex}.footer-bottom-links{align-items:center;gap:1rem;display:flex}.footer-bottom-links a{color:inherit;text-decoration:none}.footer-bottom-links a:hover{color:var(--text-primary)}.dot{color:var(--text-muted)}.gradient-text{color:var(--accent-primary)}@media (width<=768px){.footer{padding:3rem 1.5rem 2rem}.footer-content{grid-template-columns:1fr;gap:2.5rem}.footer-links-container{grid-template-columns:repeat(2,1fr);gap:1.5rem}.footer-bottom{text-align:center;flex-direction:column;gap:1.2rem;padding-top:1.5rem}}@media (width<=480px){.footer-links-container{grid-template-columns:1fr;gap:2rem}.footer-brand{font-size:1.5rem}.footer-bottom-links{flex-wrap:wrap;justify-content:center}}.home{position:relative}.hero{text-align:center;padding:var(--space-md) var(--space-xl) var(--space-2xl);border-bottom:1px solid var(--border-color);flex-direction:column;align-items:center;max-width:860px;margin:0 auto;display:flex;position:relative}.hero-logo{width:auto;height:150px;margin-bottom:var(--space-md);object-fit:contain}.hero-badge{border-radius:var(--radius-full);border:1px solid var(--border-color);font-size:var(--text-xs);color:var(--text-secondary);margin-bottom:var(--space-lg);letter-spacing:.2px;background:0 0;align-items:center;gap:7px;padding:4px 12px;display:inline-flex}.badge-dot{background:var(--accent-success);border-radius:50%;width:6px;height:6px;animation:2.5s ease-in-out infinite pulse}.hero-title{letter-spacing:-1px;margin-bottom:var(--space-md);color:var(--text-primary);font-size:clamp(2rem,5vw,2.8rem);font-weight:700;line-height:1.15}.hero-subtitle{font-size:var(--text-base);color:var(--text-secondary);max-width:580px;margin-bottom:var(--space-xl);line-height:1.75}.hero-actions{gap:var(--space-sm);margin-bottom:var(--space-2xl);display:flex}.btn{border-radius:var(--radius-md);font-weight:600;font-size:var(--text-sm);transition:all var(--transition-fast);cursor:pointer;align-items:center;gap:7px;padding:10px 20px;display:inline-flex}.btn-primary{background:var(--accent-primary);color:#fff;border:1px solid #0000}.btn-primary:hover{box-shadow:var(--shadow-sm);background:#388bfd;transform:translateY(-1px)}.btn-secondary{color:var(--text-primary);border:1px solid var(--border-color);background:0 0}.btn-secondary:hover{background:var(--bg-secondary);border-color:var(--text-tertiary);transform:translateY(-1px)}.hero-stats{align-items:center;gap:40px;display:flex}.stat{flex-direction:column;align-items:center;gap:4px;display:flex}.stat-value{color:var(--text-primary);font-size:1.85rem;font-weight:700}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.6px;font-size:.78rem}.stat-divider{background:var(--border-color);width:1px;height:42px}.section-title{font-size:var(--text-2xl);text-align:center;margin-bottom:var(--space-sm);letter-spacing:-.5px;color:var(--text-primary);font-weight:700}.section-subtitle{text-align:center;color:var(--text-secondary);max-width:560px;margin:0 auto var(--space-2xl);font-size:var(--text-sm);line-height:1.7}.features{padding:var(--space-3xl) var(--space-xl);border-bottom:1px solid var(--border-color);max-width:1100px;margin:0 auto}.features-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));display:grid}.feature-card{padding:var(--space-lg);border-radius:var(--radius-lg);background:var(--bg-secondary);border:1px solid var(--border-color);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);cursor:default}.feature-card:hover{border-color:var(--text-tertiary);box-shadow:var(--shadow-md)}.feature-icon{border-radius:var(--radius-md);width:40px;height:40px;margin-bottom:var(--space-md);opacity:.9;justify-content:center;align-items:center;font-size:1.3rem;display:flex}.feature-title{font-size:var(--text-base);margin-bottom:var(--space-xs);color:var(--text-primary);font-weight:600}.feature-description{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.65}.categories-section{padding:var(--space-3xl) var(--space-xl);border-bottom:1px solid var(--border-color);max-width:1100px;margin:0 auto}.categories-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));display:grid}.category-card{padding:var(--space-lg);border-radius:var(--radius-lg);background:var(--bg-secondary);border:1px solid var(--border-color);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);display:block;position:relative}.category-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-md)}.category-card:hover .category-arrow{opacity:1;transform:translate(0)}.category-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.category-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;display:flex}.category-count{font-size:var(--text-xs);color:var(--text-secondary);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-full);padding:2px 8px}.category-name{font-size:var(--text-base);margin-bottom:var(--space-sm);color:var(--text-primary);font-weight:600}.category-algos{flex-wrap:wrap;gap:5px;display:flex}.category-algo-tag{border-radius:var(--radius-full);background:var(--bg-tertiary);border:1px solid var(--border-color);font-size:var(--text-xs);color:var(--text-secondary);padding:2px 8px}.category-algo-tag.more{color:var(--accent-primary);border-color:var(--border-color)}.category-arrow{right:var(--space-lg);top:var(--space-lg);font-size:var(--text-sm);color:var(--accent-primary);opacity:0;transition:all var(--transition-fast);position:absolute;transform:translate(-6px)}.cta-section{padding:var(--space-3xl) var(--space-xl);max-width:800px;margin:0 auto}.cta-card{text-align:center;padding:var(--space-2xl) var(--space-xl);border-radius:var(--radius-lg);background:var(--bg-secondary);border:1px solid var(--border-color)}.cta-card h2{font-size:var(--text-2xl);margin-bottom:var(--space-sm);color:var(--text-primary);font-weight:700}.cta-card p{color:var(--text-secondary);margin-bottom:var(--space-lg);font-size:var(--text-sm)}.cta-actions{justify-content:center;gap:var(--space-md);display:flex}.sql-section{padding:var(--space-3xl) var(--space-xl);border-bottom:1px solid var(--border-color);max-width:1100px;margin:0 auto}.sql-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));display:grid}.sql-card{height:100%;padding:var(--space-lg);border-radius:var(--radius-lg);background:var(--bg-secondary);border:1px solid var(--border-color);transition:border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);cursor:pointer;flex-direction:column;display:flex;position:relative;overflow:hidden}.sql-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.sql-card-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.sql-card-icon{border-radius:var(--radius-md);border:1px solid #ffffff0d;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.25rem;display:flex}.sql-card-badge{text-transform:uppercase;letter-spacing:.8px;border-radius:var(--radius-full);background:#ffffff05;border:1px solid;padding:2px 8px;font-size:10px;font-weight:700}.sql-card-title{font-size:var(--text-base);margin-bottom:var(--space-xs);color:var(--text-primary);font-weight:600}.sql-card-description{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-lg);flex-grow:1;line-height:1.6}.sql-card-action{font-size:var(--text-xs);color:var(--accent-primary);transition:gap var(--transition-fast);align-items:center;gap:5px;margin-top:auto;font-weight:600;display:flex}.sql-card:hover .sql-card-action{gap:8px}@media (width<=850px){.hero-stats{justify-content:center;gap:var(--space-md) var(--space-lg);flex-wrap:wrap}.stat-divider{display:none}.stat{flex:120px;min-width:120px}}@media (width<=768px){.hero{padding:var(--space-2xl) var(--space-md)}.hero-title{letter-spacing:-.5px;font-size:1.8rem}.hero-actions{gap:var(--space-sm);flex-direction:column;width:100%;max-width:320px;margin-left:auto;margin-right:auto}.btn{justify-content:center}.features,.categories-section,.sql-section{padding-left:var(--space-md);padding-right:var(--space-md)}.cta-card{padding:var(--space-xl) var(--space-md)}}@media (width<=600px){.cta-actions{align-items:stretch;gap:var(--space-sm);flex-direction:column;width:100%;max-width:320px;margin:0 auto}.cta-actions .btn{justify-content:center}}@media (width<=480px){.hero-logo{height:100px;margin-bottom:var(--space-sm)}.hero-title{font-size:1.6rem}}.algorithms-page{max-width:1200px;padding:var(--space-2xl) var(--space-xl);margin:0 auto}.algorithms-header{text-align:center;margin-bottom:var(--space-2xl);padding-bottom:var(--space-xl);border-bottom:1px solid var(--border-color)}.page-title{font-size:var(--text-3xl);letter-spacing:-.5px;margin-bottom:var(--space-sm);color:var(--text-primary);font-weight:700}.page-subtitle{color:var(--text-secondary);max-width:560px;font-size:var(--text-sm);margin:0 auto;line-height:1.7}.filters-bar{gap:var(--space-sm);margin-bottom:var(--space-xl);flex-direction:column;display:flex}.search-box{align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border-color);transition:border-color var(--transition-fast);padding:9px 14px;display:flex}.search-box:focus-within{border-color:var(--accent-primary)}.search-icon{opacity:.5;font-size:.9rem}.search-input{font-size:var(--text-base);color:var(--text-primary);background:0 0;flex:1}.search-input::placeholder{color:var(--text-muted)}.category-filters{gap:var(--space-xs);flex-wrap:wrap;display:flex}.filter-btn{border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--text-secondary);border:1px solid var(--border-color);transition:all var(--transition-fast);background:0 0;padding:5px 14px;font-weight:500}.filter-btn:hover{border-color:var(--text-tertiary);color:var(--text-primary);background:var(--bg-secondary)}.filter-btn.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.algorithms-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.algo-card{padding:var(--space-lg);border-radius:var(--radius-lg);background:var(--bg-secondary);border:1px solid var(--border-color);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);flex-direction:column;height:100%;display:flex;position:relative;overflow:hidden}.algo-card:before{content:"";background:var(--accent-primary);opacity:0;height:2px;transition:opacity var(--transition-fast);position:absolute;top:0;left:0;right:0}.algo-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-md)}.algo-card:hover:before{opacity:1}.algo-card-top{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.algo-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:38px;height:38px;font-size:1.1rem;display:flex}.algo-difficulty{border-radius:var(--radius-full);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.4px;padding:2px 8px;font-weight:600}.algo-difficulty[data-difficulty=easy]{color:var(--accent-success);background:#3fb9501f}.algo-difficulty[data-difficulty=medium]{color:var(--accent-warning);background:#d299221f}.algo-difficulty[data-difficulty=hard]{color:var(--accent-error);background:#f851491f}.algo-name{font-size:var(--text-base);margin-bottom:var(--space-xs);color:var(--text-primary);font-weight:600}.algo-desc{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-md);flex:1;line-height:1.55}.algo-complexity{gap:var(--space-lg);padding:var(--space-sm) 0;margin-bottom:var(--space-md);border-top:1px solid var(--border-color);display:flex}.complexity-item{flex-direction:column;gap:2px;display:flex}.complexity-label{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.4px}.complexity-value{font-size:var(--text-sm);color:var(--accent-secondary);font-weight:600}.algo-card-footer{justify-content:flex-end;display:flex}.visualize-btn{font-size:var(--text-sm);color:var(--accent-primary);opacity:0;transition:all var(--transition-fast);font-weight:600;transform:translate(-6px)}.algo-card:hover .visualize-btn{opacity:1;transform:translate(0)}.no-results{text-align:center;padding:var(--space-3xl);color:var(--text-secondary)}.no-results span{margin-bottom:var(--space-md);font-size:2.5rem;display:block}@media (width<=768px){.algorithms-page{padding:var(--space-xl) var(--space-md)}.algorithms-grid{grid-template-columns:1fr}}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;background:#000000b3;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.login-modal{background:var(--bg-secondary);border:1px solid var(--border-color);z-index:2001;text-align:center;border-radius:24px;width:100%;max-width:420px;padding:40px 32px;position:relative;overflow:hidden;box-shadow:0 25px 50px -12px #00000080}@media (width<=480px){.login-modal{border-radius:20px;padding:32px 20px}.modal-icon{margin-bottom:16px;font-size:40px}.login-modal h2{font-size:20px}.login-modal p{margin-bottom:24px;font-size:14px}}.modal-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:24px;transition:all .2s;display:flex;position:absolute;top:15px;right:15px}.modal-close:hover{color:var(--text-primary);background:#ffffff1a}.modal-icon{margin-bottom:20px;font-size:48px}.login-modal h2{color:var(--text-primary);margin-bottom:12px;font-size:24px;font-weight:700}.login-modal p{color:var(--text-secondary);margin-bottom:30px;font-size:15px;line-height:1.6}.modal-actions{flex-direction:column;gap:12px;display:flex}.btn-google{color:#1f1f1f;cursor:pointer;background:#fff;border:none;border-radius:12px;justify-content:center;align-items:center;gap:12px;padding:12px;font-size:16px;font-weight:600;transition:transform .2s,background .2s;display:flex}.btn-google:hover{background:#f1f1f1;transform:translateY(-2px)}.btn-google img{width:20px;height:20px}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;background:0 0;border-radius:12px;padding:12px;font-size:15px;font-weight:500;transition:all .2s}.btn-ghost:hover{border-color:var(--text-secondary);color:var(--text-primary);background:#ffffff0d}.spinner-small{border:2px solid #0000001a;border-top-color:#4285f4;border-radius:50%;width:18px;height:18px;animation:.6s linear infinite spin}.array-visualizer{gap:var(--space-md);flex-direction:column;height:100%;display:flex}.bars-container{padding:var(--space-md);flex:1;align-items:flex-end;gap:2px;min-height:300px;display:flex}.bar-wrapper{flex-direction:column;justify-content:flex-end;align-items:center;height:100%;display:flex}.bar{border-radius:4px 4px 0 0;justify-content:center;align-items:flex-start;width:100%;min-width:4px;transition:background-color .15s,box-shadow .15s;display:flex;position:relative}.bar-value{color:var(--text-secondary);white-space:nowrap;font-size:10px;font-weight:600;font-family:var(--font-mono);position:absolute;top:-22px}.bar-index{color:var(--text-tertiary);font-size:9px;font-family:var(--font-mono);margin-top:4px}.bar-comparing{animation:.5s ease-in-out infinite alternate bar-pulse}.bar-swapping{animation:.3s ease-in-out bar-shake}.bar-found{animation:.6s ease-in-out infinite alternate bar-glow}@keyframes bar-pulse{0%{opacity:.8}to{opacity:1}}@keyframes bar-shake{0%,to{transform:translate(0)}25%{transform:translate(-3px)}75%{transform:translate(3px)}}@keyframes bar-glow{0%{filter:brightness()}to{filter:brightness(1.4)}}.viz-legend{gap:var(--space-md);padding:var(--space-sm) var(--space-md);flex-wrap:wrap;justify-content:center;display:flex}.legend-item{align-items:center;gap:6px;display:flex}.legend-dot{border-radius:3px;width:10px;height:10px}.legend-label{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:capitalize}.bubble-visualizer{align-items:center;gap:var(--space-lg);height:100%;padding:var(--space-lg) var(--space-md);flex-direction:column;display:flex}.bubbles-area{padding:var(--space-xl) var(--space-md);flex-wrap:wrap;flex:1;justify-content:center;align-items:center;gap:24px;min-height:200px;display:flex}.bubble{cursor:default;border:2.5px solid;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:border-color .2s;display:flex;position:relative}.bubble-value{font-family:var(--font-mono);color:#fff;text-shadow:0 1px 3px #0000004d;z-index:2;pointer-events:none;font-size:15px;font-weight:700}.bubble-shine{pointer-events:none;z-index:3;background:radial-gradient(#ffffff73 0%,#ffffff1a 60%,#0000 100%);border-radius:50%;width:35%;height:28%;position:absolute;top:12%;left:18%}.bubble-index{font-family:var(--font-mono);color:var(--text-tertiary);font-size:10px;font-weight:500;position:absolute;bottom:-22px}.compare-arrows{z-index:4;position:absolute;top:50%;right:-12px;transform:translate(50%,-50%)}.compare-icon{color:var(--accent-warning);font-size:16px;animation:.5s ease-in-out infinite alternate arrow-bounce}@keyframes arrow-bounce{0%{transform:translate(-2px)}to{transform:translate(2px)}}.bubble-comparing{animation:.6s ease-in-out infinite bubble-wobble}@keyframes bubble-wobble{0%,to{transform:rotate(0)scale(1.02)}25%{transform:rotate(-3deg)scale(1.05)}75%{transform:rotate(3deg)scale(1.05)}}.bubble-swapping{z-index:10;animation:.35s ease-in-out bubble-swap}@keyframes bubble-swap{0%{transform:scale(1)}30%{transform:scale(1.2)translateY(-8px)}60%{transform:scale(.95)translateY(4px)}to{transform:scale(1)translateY(0)}}.bubble-sorted{animation:2s ease-in-out infinite bubble-settled}@keyframes bubble-settled{0%,to{transform:scale(1)}50%{transform:scale(1.03)}}.bubble-default{animation:3s ease-in-out infinite bubble-float}@keyframes bubble-float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.bubble-track{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;display:flex}.track-dot{background:var(--border-color);border-radius:50%;width:6px;height:6px}.bubble-legend{gap:var(--space-md);padding-top:var(--space-sm);flex-wrap:wrap;justify-content:center;display:flex}.legend-bubble{border:2px solid;border-radius:50%;width:18px;height:18px;position:relative;overflow:hidden}.legend-bubble:after{content:"";background:#ffffff59;border-radius:50%;width:35%;height:25%;position:absolute;top:15%;left:20%}@media (width<=768px){.bubbles-area{gap:16px}.compare-arrows{right:-8px}.bubble-value{font-size:12px}}.selection-visualizer{gap:var(--space-xl);padding:var(--space-lg);flex-direction:column;width:100%;height:100%;display:flex}.region-labels{background:var(--bg-tertiary);border-radius:var(--radius-full);border:1px solid var(--border-color);width:100%;height:32px;display:flex;overflow:hidden}.region-label{font-size:var(--text-xs);transition:all var(--transition-base);justify-content:center;align-items:center;font-weight:600;display:flex}.sorted-region{color:#00b894;background:#00b89426;border-right:1px solid #00b8944d}.unsorted-region{color:var(--text-tertiary)}.selection-cards{padding:var(--space-xl) var(--space-md);flex:1;justify-content:center;align-items:flex-end;gap:12px;min-height:280px;display:flex}.sel-card{padding:var(--space-md) var(--space-sm);border-radius:var(--radius-md);width:64px;min-height:220px;transition:border-color var(--transition-fast);border:2px solid;flex-direction:column;justify-content:flex-end;align-items:center;display:flex;position:relative}.sel-badge{background:var(--bg-card);border:1px solid var(--border-color);border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex;position:absolute;top:-12px;box-shadow:0 4px 12px #0003}.sel-bar-container{width:100%;margin-bottom:var(--space-sm);flex:1;align-items:flex-end;padding:0 4px;display:flex}.sel-bar{border-radius:var(--radius-sm);background:var(--accent-primary);opacity:.6;width:100%;transition:background var(--transition-base)}.sel-card-comparing .sel-bar{opacity:.9;background:#fdcb6e}.sel-card-pivot .sel-bar{opacity:1;background:#e17055}.sel-card-sorted .sel-bar{opacity:.7;background:#00b894}.sel-card-swapping .sel-bar{opacity:1;background:#ff4757}.sel-value{font-family:var(--font-mono);color:var(--text-primary);margin-bottom:4px;font-size:16px;font-weight:700}.sel-index{color:var(--text-muted);text-transform:uppercase;font-size:10px;font-weight:500}.min-indicator{color:#e17055;white-space:nowrap;font-size:10px;font-weight:800;position:absolute;top:-35px}.swap-connector{color:#ff4757;z-index:5;font-size:20px;position:absolute;top:50%;right:-24px;transform:translateY(-50%)}.min-callout{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);background:#e170551a;border:1px solid #e1705533;align-self:center;display:flex}.min-callout-text{font-size:var(--text-sm);color:var(--text-secondary)}.min-callout-text strong{color:#e17055}.sel-legend{gap:var(--space-lg);padding-top:var(--space-md);flex-wrap:wrap;justify-content:center;display:flex}.sel-legend-entry{align-items:center;gap:8px;display:flex}.sel-legend-swatch{border:1px solid;border-radius:4px;width:16px;height:16px}.sel-legend-text{font-size:var(--text-xs);color:var(--text-tertiary)}@media (width<=768px){.sel-card{width:48px;padding:var(--space-sm) 4px}.sel-value{font-size:14px}.region-labels{height:24px}}.insertion-visualizer{box-sizing:border-box;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:2rem;display:flex;position:relative}.insertion-cards{flex-wrap:wrap;justify-content:center;align-items:flex-end;gap:12px;width:100%;min-height:250px;margin-top:40px;margin-bottom:2rem;display:flex}.ins-card{-webkit-backdrop-filter:blur(8px);will-change:transform, opacity;border:1px solid #ffffff1a;border-radius:12px;flex-direction:column;justify-content:flex-end;align-items:center;width:60px;height:180px;padding:10px;transition:border-color .3s;display:flex;position:relative}.ins-card-holding{border-width:2px}.ins-badge{background:var(--surface-2);z-index:2;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:18px;display:flex;position:absolute;top:-12px;box-shadow:0 4px 12px #0000004d}.ins-bar-container{background:#0003;border-radius:6px;justify-content:center;align-items:flex-end;width:100%;height:120px;margin-bottom:12px;display:flex;overflow:hidden}.ins-bar{border-radius:4px;width:100%;transition:background-color .3s;bottom:0}.ins-bar-default{background:var(--viz-default)}.ins-bar-comparing{background:#fdcb6e}.ins-bar-holding{background:#0984e3}.ins-bar-swapping{background:#ff4757}.ins-bar-sorted{background:#00b894}.ins-value{font-family:var(--font-mono);color:var(--text-primary);margin-bottom:4px;font-size:1.1rem;font-weight:600}.ins-index{font-family:var(--font-mono);color:var(--text-tertiary);font-size:.75rem}.ins-drop-shadow{pointer-events:none;background:radial-gradient(#0006 0%,#0000 70%);border-radius:50%;width:50%;height:10px;position:absolute;bottom:-40px}.ins-callout{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0984e326;border:1px solid #0984e34d;border-radius:20px;align-items:center;gap:10px;padding:8px 16px;display:flex;position:absolute;top:1rem;box-shadow:0 8px 24px #0003}.ins-callout-icon{font-size:1.2rem}.ins-callout-text{color:var(--text-primary);font-size:.95rem}.ins-callout-text strong{color:#0984e3;font-size:1.1rem}.ins-legend{background:var(--surface-1);border:1px solid var(--border-color);border-radius:30px;flex-wrap:wrap;justify-content:center;align-items:center;gap:16px;margin-top:auto;padding:12px 24px;display:flex;box-shadow:0 4px 20px #00000026}.ins-legend-entry{align-items:center;gap:8px;display:flex}.ins-legend-swatch{border:1px solid;border-radius:4px;width:14px;height:14px}.ins-legend-text{color:var(--text-secondary);font-size:.85rem;font-weight:500}@media (width<=768px){.ins-card{width:40px;height:140px;padding:6px}.ins-bar-container{height:90px}.ins-value{font-size:.9rem}.ins-index{display:none}.ins-legend{padding:10px 16px}}.merge-visualizer{box-sizing:border-box;flex-direction:column;justify-content:flex-start;align-items:center;width:100%;padding:2rem 2rem 80px;transition:min-height .3s;display:flex}.merge-tree-container{flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:8px;width:100%;margin-top:20px;margin-bottom:40px;display:flex}.merge-node{-webkit-backdrop-filter:blur(8px);will-change:transform, opacity;z-index:2;border:1px solid #ffffff1a;border-radius:8px;flex-direction:column;justify-content:flex-end;align-items:center;width:45px;height:140px;padding:6px;display:flex;position:relative}.merge-bar-wrapper{background:#0003;border-radius:4px;justify-content:center;align-items:flex-end;width:100%;height:100px;margin-bottom:8px;display:flex;overflow:hidden}.merge-bar{opacity:.8;border-radius:3px;width:100%;bottom:0}.merge-value{font-family:var(--font-mono);color:var(--text-primary);margin-bottom:2px;font-size:1rem;font-weight:600}.merge-legend{background:var(--surface-1);border:1px solid var(--border-color);border-radius:30px;flex-wrap:wrap;justify-content:center;align-items:center;gap:16px;margin-top:auto;padding:12px 24px;display:flex;box-shadow:0 4px 20px #00000026}.merge-legend-entry{align-items:center;gap:8px;display:flex}.merge-legend-swatch{border:1px solid;border-radius:4px;width:14px;height:14px}.merge-legend-text{color:var(--text-secondary);font-size:.85rem;font-weight:500}@media (width<=768px){.merge-node{width:32px;height:110px;padding:4px}.merge-bar-wrapper{height:80px}.merge-value{font-size:.85rem}.merge-tree-container{gap:4px}}.quick-visualizer{box-sizing:border-box;flex-direction:column;justify-content:flex-start;align-items:center;width:100%;min-height:350px;padding:2rem;display:flex}.quick-orbs-container{width:100%;min-height:150px;transform-style:preserve-3d;flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;margin-top:40px;margin-bottom:60px;display:flex}.quick-orb{-webkit-backdrop-filter:blur(8px);will-change:transform, width, height;border:2px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;transition:border-color .3s,background-color .3s;display:flex;position:relative}.quick-orb-value{font-family:var(--font-mono);color:var(--text-primary);text-shadow:0 2px 4px #00000080;font-weight:700}.quick-orb-tooltip{background:var(--surface-2);z-index:20;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:18px;display:flex;position:absolute;top:-24px;box-shadow:0 4px 12px #0000004d}.quick-legend{background:var(--surface-1);border:1px solid var(--border-color);border-radius:30px;flex-wrap:wrap;justify-content:center;align-items:center;gap:16px;margin-top:auto;padding:12px 24px;display:flex;box-shadow:0 4px 20px #00000026}.quick-legend-entry{align-items:center;gap:8px;display:flex}.quick-legend-swatch{border:1px solid;border-radius:50%;width:16px;height:16px}.quick-legend-text{color:var(--text-secondary);font-size:.85rem;font-weight:500}@media (width<=768px){.quick-orbs-container{gap:6px}}.heap-visualizer{box-sizing:border-box;flex-direction:column;justify-content:flex-start;align-items:center;width:100%;min-height:400px;padding:2rem;display:flex}.heap-tree-container{width:100%;transform-style:preserve-3d;flex-direction:column;justify-content:center;align-items:center;gap:20px;margin-top:20px;margin-bottom:40px;display:flex}.heap-tree-row{justify-content:center;align-items:center;gap:24px;width:100%;display:flex}.heap-orb{-webkit-backdrop-filter:blur(8px);will-change:transform, width, height;border:2px solid #ffffff1a;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;transition:border-color .3s,background-color .3s;display:flex;position:relative}.heap-orb-value{font-family:var(--font-mono);color:var(--text-primary);text-shadow:0 2px 4px #00000080;font-weight:700}.heap-orb-idx{font-family:var(--font-mono);color:var(--text-tertiary);font-size:10px;position:absolute;bottom:-20px}.heap-legend{background:var(--surface-1);border:1px solid var(--border-color);border-radius:30px;flex-wrap:wrap;justify-content:center;align-items:center;gap:16px;margin-top:auto;padding:12px 24px;display:flex;box-shadow:0 4px 20px #00000026}.heap-legend-entry{align-items:center;gap:8px;display:flex}.heap-legend-swatch{border:1px solid;border-radius:50%;width:16px;height:16px}.heap-legend-text{color:var(--text-secondary);font-size:.85rem;font-weight:500}@media (width<=768px){.heap-tree-container{gap:12px}.heap-tree-row{gap:8px}}.radix-visualizer{width:100%;height:100%;padding:var(--space-md);gap:var(--space-xl);flex-direction:column;display:flex}.radix-main-array{gap:var(--space-sm);flex-wrap:wrap;justify-content:center;align-items:center;min-height:80px;display:flex}.radix-card{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-family:var(--font-mono);border:2px solid;justify-content:center;align-items:center;min-width:50px;font-weight:600;display:flex}.highlight-digit{color:var(--highlight-color,var(--accent-warning));text-shadow:0 1px 2px #0003;font-size:1.1em;font-weight:900;text-decoration:underline}.dimmed-padding{opacity:.5}.radix-buckets-container{gap:var(--space-md);transition:opacity var(--transition-base);flex-direction:column;flex:1;display:flex}.radix-buckets-title{text-align:center;color:var(--text-secondary);font-weight:600}.radix-buckets{gap:var(--space-sm);flex:1;grid-template-columns:repeat(10,1fr);align-items:stretch;min-height:200px;display:grid}.radix-bucket{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:var(--transition-fast);flex-direction:column;display:flex;overflow:hidden}.radix-bucket.active-bucket{border-color:var(--viz-comparing);box-shadow:0 0 12px #d2992233}.bucket-label{background:var(--bg-tertiary);text-align:center;border-bottom:1px solid var(--border-color);font-weight:700;font-family:var(--font-mono);padding:4px 0}.bucket-items{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:6px;padding:8px;display:flex}.bucket-card{border-radius:var(--radius-sm);font-family:var(--font-mono);border:1px solid;padding:4px 8px;font-size:.9em;font-weight:600}.radix-legend{justify-content:center;gap:var(--space-md);flex-wrap:wrap;margin-top:auto;display:flex}.legend-entry{align-items:center;gap:8px;display:flex}.legend-swatch{border:2px solid;border-radius:4px;width:16px;height:16px}.legend-text{font-size:var(--text-sm);color:var(--text-secondary)}@media (width<=768px){.radix-buckets{grid-template-columns:repeat(5,1fr)}}.search-visualizer{box-sizing:border-box;flex-direction:column;justify-content:flex-start;align-items:center;width:100%;min-height:350px;padding:2rem;display:flex}.search-orbs-container{width:100%;min-height:150px;transform-style:preserve-3d;flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;margin-top:40px;margin-bottom:60px;display:flex}.search-orb{-webkit-backdrop-filter:blur(8px);will-change:transform, width, height, opacity;border:2px solid #ffffff1a;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;transition:border-color .3s,background-color .3s;display:flex;position:relative}.search-orb.dimmed{filter:grayscale(80%)!important}.search-orb-value{font-family:var(--font-mono);color:var(--text-primary);text-shadow:0 2px 4px #00000080;font-weight:700}.search-orb-idx{font-family:var(--font-mono);color:var(--text-tertiary);opacity:.6;font-size:11px;position:absolute;bottom:-22px}.search-orb-tooltip{background:var(--surface-2);z-index:20;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:16px;display:flex;position:absolute;top:-24px;box-shadow:0 4px 12px #0000004d}.search-legend{background:var(--surface-1);border:1px solid var(--border-color);border-radius:30px;flex-wrap:wrap;justify-content:center;align-items:center;gap:16px;margin-top:auto;padding:12px 24px;display:flex;box-shadow:0 4px 20px #00000026}.search-legend-entry{align-items:center;gap:8px;display:flex}.search-legend-swatch{border:1px solid;border-radius:50%;width:16px;height:16px}.search-legend-text{color:var(--text-secondary);font-size:.85rem;font-weight:500}@media (width<=768px){.search-orbs-container{gap:8px}}.graph-visualizer{gap:var(--space-sm);flex-direction:column;height:100%;display:flex}.graph-svg-wrapper{border-radius:var(--radius-md);flex:1;min-height:260px;position:relative;overflow:hidden}.graph-svg{width:100%;height:100%;min-height:260px}.graph-edge{transition:stroke .3s,stroke-width .3s,opacity .3s}.edge-current{animation:.7s ease-in-out infinite alternate edge-pulse}@keyframes edge-pulse{0%{opacity:.5}to{opacity:1}}.edge-path-animated{stroke-dasharray:10 4;animation:1.2s linear infinite dash-flow}@keyframes dash-flow{0%{stroke-dashoffset:0}to{stroke-dashoffset:-20px}}.node-circle{cursor:pointer;transition:fill .3s,stroke .3s}.node-ring{animation:1.2s ease-in-out infinite ring-pulse}@keyframes ring-pulse{0%,to{opacity:.2}50%{opacity:.45}}.node-path-ring{animation:1s ease-in-out infinite path-ring-pulse}@keyframes path-ring-pulse{0%,to{opacity:.25;r:27}50%{opacity:.55;r:31}}.node-badge-ring{transform-origin:50%;animation:8s linear infinite badge-spin}@keyframes badge-spin{to{stroke-dashoffset:-100px}}.node-active-current .node-circle{animation:.8s ease-in-out infinite alternate node-glow-pulse}@keyframes node-glow-pulse{0%{filter:brightness()}to{filter:brightness(1.4)}}.dijkstra-info-row{gap:var(--space-sm);grid-template-columns:auto 1fr;min-height:0;display:grid}.dist-table-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);flex-shrink:0;min-width:130px;max-width:160px;overflow:hidden}.dist-table-header{border-bottom:1px solid var(--border-color);background:linear-gradient(90deg,#2f81f726,#3dc9b01a);padding:6px 10px}.dist-table-title{font-size:var(--text-xs);color:var(--accent-primary);text-transform:uppercase;letter-spacing:.6px;font-weight:700}.dist-table-body{flex-direction:column;max-height:160px;display:flex;overflow-y:auto}.dist-row{border-bottom:1px solid #ffffff0a;align-items:center;gap:4px;padding:4px 10px;transition:background .2s;display:flex}.dist-row:last-child{border-bottom:none}.dist-row-current{background:#fdcb6e1f}.dist-row-path{background:#f59e0b1f}.dist-row-source{background:#38bdf81a}.dist-row-target{background:#f59e0b1a}.dist-node-id{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-secondary);min-width:14px;font-weight:700}.dist-badge{border-radius:var(--radius-full);letter-spacing:.3px;text-transform:uppercase;padding:1px 4px;font-size:8px;font-weight:800}.dist-badge-src{color:#38bdf8;background:#38bdf833;border:1px solid #38bdf866}.dist-badge-tgt{color:#f59e0b;background:#f59e0b33;border:1px solid #f59e0b66}.dist-value{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--accent-secondary);margin-left:auto;font-weight:600}.dist-row-path .dist-value{color:#f59e0b}.dist-row-current .dist-value{color:#fdcb6e}.path-explanation-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);flex-direction:column;gap:6px;display:flex;position:relative;overflow:hidden}.path-explanation-card:before{content:"";background:linear-gradient(90deg, var(--accent-primary), var(--accent-secondary));height:2px;position:absolute;top:0;left:0;right:0}.explanation-header{align-items:center;gap:6px;display:flex}.explanation-icon{font-size:14px}.explanation-title{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.6px;font-weight:700}.explanation-text{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.55;font-family:var(--font-sans)}.final-path-banner{border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);gap:var(--space-xs);background:linear-gradient(135deg,#f59e0b1f 0%,#fdcb6e14 50%,#f59e0b1f 100%);border:1.5px solid #f59e0b73;flex-direction:column;animation:2s ease-in-out infinite alternate banner-glow;display:flex;box-shadow:0 0 20px #f59e0b26,inset 0 0 20px #f59e0b0a}@keyframes banner-glow{0%{box-shadow:0 0 16px #f59e0b26}to{box-shadow:0 0 28px #f59e0b59}}.final-path-header{align-items:center;gap:var(--space-sm);display:flex}.final-path-icon{font-size:16px}.final-path-title{font-size:var(--text-sm);color:#f59e0b;letter-spacing:.3px;font-weight:700}.final-path-cost{font-family:var(--font-mono);font-size:var(--text-sm);color:#fdcb6e;border-radius:var(--radius-full);background:#f59e0b26;border:1px solid #f59e0b4d;margin-left:auto;padding:2px 10px;font-weight:700}.final-path-nodes{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.final-path-node-group{align-items:center;gap:4px;display:flex}.final-path-node{width:28px;height:28px;font-family:var(--font-mono);font-size:var(--text-sm);color:#f59e0b;background:#f59e0b2e;border:1.5px solid #f59e0b80;border-radius:50%;justify-content:center;align-items:center;font-weight:700;transition:transform .2s;display:inline-flex}.final-path-node-src{color:#38bdf8;background:#38bdf82e;border-color:#38bdf88c}.final-path-node-tgt{background:#f59e0b47;border-color:#f59e0b;box-shadow:0 0 8px #f59e0b66}.final-path-arrow{font-size:var(--text-sm);color:#f59e0bb3;font-weight:600}.graph-data-display{gap:var(--space-lg);padding:var(--space-xs) var(--space-sm);flex-wrap:wrap;display:flex}.data-panel{align-items:center;gap:var(--space-sm);display:flex}.data-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:600;font-family:var(--font-mono)}.data-items{flex-wrap:wrap;gap:4px;display:flex}.data-item{border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:600;font-family:var(--font-mono);padding:3px 10px}.data-queued{color:#38bdf8;background:#38bdf826;border:1px solid #38bdf84d}.data-stack{color:#6c5ce7;background:#6c5ce726;border:1px solid #6c5ce74d}.data-visited{color:#00b894;background:#00b89426;border:1px solid #00b8944d}[data-theme=light] .dist-row{border-bottom-color:#0000000d}[data-theme=light] .dist-row-path{background:#f59e0b14}[data-theme=light] .dist-row-current{background:#fdcb6e1a}[data-theme=light] .explanation-text{color:var(--text-secondary)}[data-theme=light] .final-path-banner{background:linear-gradient(135deg,#f59e0b14 0%,#fdcb6e0d 50%,#f59e0b14 100%)}.n-queen-container{justify-content:center;align-items:center;width:100%;height:100%;padding:20px;display:flex}.chessboard{aspect-ratio:1;border:4px solid #34495e;border-radius:8px;width:100%;max-width:500px;display:grid;overflow:hidden;box-shadow:0 10px 30px #0000004d}.board-cell{justify-content:center;align-items:center;font-size:2.5rem;transition:all .3s;display:flex;position:relative}.board-cell.white{background-color:#ecf0f1}.board-cell.black{background-color:#95a5a6}.board-cell.current{z-index:10;box-shadow:inset 0 0 0 4px #f1c40f}.board-cell.safe{box-shadow:inset 0 0 0 4px #2ecc71;background-color:#2ecc7166!important}.board-cell.unsafe{box-shadow:inset 0 0 0 4px #e74c3c;background-color:#e74c3c66!important}.queen-icon{filter:drop-shadow(0 2px 4px #0000004d);-webkit-user-select:none;user-select:none;z-index:5;display:block}.scanning-indicator{z-index:1;background:#f1c40f;position:absolute;inset:0}@media (width<=600px){.board-cell{font-size:1.5rem}}.tree-visualizer{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;height:500px;transition:background-color var(--transition-base), border-color var(--transition-base);background-size:20px 20px;justify-content:center;padding:40px;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 0 20px #0003}[data-theme=light] .tree-visualizer{box-shadow:inset 0 0 10px #0000000d}.tree-svg{pointer-events:none;z-index:1;width:100%;height:100%;position:absolute;top:0;left:0}.connection-path.highlight{stroke:var(--accent-primary);stroke-width:3px;stroke-dasharray:6 4;filter:drop-shadow(0 0 6px var(--accent-primary));animation:1s linear infinite dash-flow}.tree-node{color:#fff;width:100%;height:100%;font-weight:700;font-family:var(--font-mono);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(4px);border:2px solid #ffffff26;border-radius:50%;justify-content:center;align-items:center;transition:all .4s cubic-bezier(.34,1.56,.64,1);display:flex}.tree-node.red{background:#ff4757;border-color:#ffffff4d;box-shadow:0 0 15px #ff475766}.tree-node.black{background:#2f3542;border-color:#ffffff26;box-shadow:0 4px 10px #0000004d}.tree-node.highlight{outline:4px solid var(--accent-primary);outline-offset:4px;animation:1.5s infinite pulse-node;transform:scale(1.1)}@keyframes pulse-node{0%{outline-color:#2f81f7cc}50%{outline-color:#2f81f733}to{outline-color:#2f81f7cc}}.node-value{text-shadow:0 1px 3px #00000080;font-size:1rem}.tree-empty{height:100%;color:var(--text-tertiary);justify-content:center;align-items:center;font-style:italic;display:flex}.recursion-visualizer{background-color:var(--bg-secondary);border:1px solid var(--border-color);width:100%;height:500px;transition:background-color var(--transition-base), border-color var(--transition-base);background-image:radial-gradient(#ffffff0a 1px,#0000 1px);background-size:20px 20px;border-radius:16px;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 0 20px #0003}[data-theme=light] .recursion-visualizer{background-image:radial-gradient(#0000000d 1px,#0000 1px);box-shadow:inset 0 0 10px #0000000d}.recursion-empty{height:100%;color:var(--text-secondary);justify-content:center;align-items:center;font-size:1.1rem;display:flex}.recursion-svg{width:100%;height:100%}.connection-path-base{fill:none;stroke:var(--border-color);stroke-width:1.5px;opacity:.25;transition:stroke var(--transition-base)}.connection-path{fill:none;transition:stroke var(--transition-base), stroke-width var(--transition-base), filter var(--transition-base)}.connection-path.computing{stroke:var(--accent-warning);stroke-width:2px;stroke-dasharray:6 4;filter:drop-shadow(0 0 4px var(--accent-warning));animation:1.5s linear infinite dash-flow}.connection-path.current{stroke:var(--accent-primary);stroke-width:3px;stroke-dasharray:6 4;filter:drop-shadow(0 0 6px var(--accent-primary));animation:1s linear infinite dash-flow}.connection-path.done{stroke:var(--accent-success);stroke-width:2px;opacity:.8}.recursion-node{background:var(--bg-card);border:2px solid var(--border-color);color:var(--text-primary);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(8px);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;font-size:11px;font-weight:600;transition:all .4s cubic-bezier(.34,1.56,.64,1);display:flex;position:relative}.recursion-node.computing{border-color:var(--accent-warning);background:#d299221a;box-shadow:0 0 12px #d299224d}.recursion-node.current{border-color:var(--accent-primary);background:var(--accent-primary-glow);box-shadow:0 0 18px var(--accent-primary-glow);transform:scale(1.12)}.recursion-node.done{border-color:var(--accent-success);background:#3fb95014}.node-name{margin-bottom:2px;font-size:11px}.node-value{color:var(--accent-success);font-size:13px;font-weight:700}.ds-visualizer{padding:var(--space-xl);flex-direction:column;align-items:center;height:100%;display:flex}.ds-label{font-size:var(--text-sm);color:var(--text-tertiary);letter-spacing:2px;margin-bottom:var(--space-xl);font-weight:700;font-family:var(--font-mono)}.stack-container{flex-direction:column;align-items:center;display:flex}.stack-elements{padding:var(--space-md);border:2px dashed var(--border-color);border-radius:var(--radius-md);border-top:none;flex-direction:column-reverse;align-items:center;gap:6px;min-width:120px;min-height:200px;display:flex}.queue-container{align-items:center;gap:var(--space-sm);display:flex}.queue-elements{padding:var(--space-md);border:2px dashed var(--border-color);border-radius:var(--radius-md);align-items:center;gap:6px;min-width:200px;min-height:60px;display:flex}.ds-element{border-radius:var(--radius-sm);font-family:var(--font-mono);font-weight:600;font-size:var(--text-base);align-items:center;gap:var(--space-sm);border:2px solid;justify-content:center;min-width:60px;padding:10px 20px;transition:all .2s;display:flex}.ds-top-label{font-size:var(--text-xs);color:var(--accent-primary);white-space:nowrap;font-weight:500}.ds-pointer{font-size:var(--text-sm);color:var(--text-tertiary);font-family:var(--font-mono);font-weight:600}.ds-empty{padding:var(--space-xl);color:var(--text-tertiary);font-family:var(--font-mono)}.ll-container{align-items:center;gap:var(--space-sm);padding:var(--space-md);max-width:100%;display:flex;overflow-x:auto}.ll-head-label{font-size:var(--text-sm);color:var(--accent-primary);font-weight:600;font-family:var(--font-mono)}.ll-nodes,.ll-node-wrapper{align-items:center;gap:4px;display:flex}.ll-node{border-radius:var(--radius-sm);border:2px solid;transition:all .2s;display:flex;overflow:hidden}.ll-data{font-family:var(--font-mono);font-weight:600;font-size:var(--text-base);padding:10px 16px}.ll-next{font-size:var(--text-sm);color:var(--text-tertiary);border-left:2px solid;align-items:center;padding:10px 12px;display:flex}.ll-arrow{color:var(--text-tertiary);font-size:var(--text-lg)}.ll-pointer{transform:scale(1.05)}.controls-panel{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);gap:var(--space-md);flex-direction:column;display:flex}.step-description{align-items:center;gap:var(--space-md);min-height:32px;display:flex}.step-badge{border-radius:var(--radius-full);background:var(--accent-primary);color:#fff;font-size:var(--text-xs);font-weight:600;font-family:var(--font-mono);flex-shrink:0;padding:3px 10px}.step-text{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.4}.progress-container{width:100%}.progress-slider{border-radius:var(--radius-full);cursor:pointer;appearance:none;background:var(--border-color);outline:none;width:100%;height:6px}.progress-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent-primary);cursor:pointer;width:16px;height:16px;box-shadow:0 0 8px var(--accent-primary-glow);border:2px solid #fff;border-radius:50%}.progress-slider::-moz-range-thumb{background:var(--accent-primary);cursor:pointer;width:16px;height:16px;box-shadow:0 0 8px var(--accent-primary-glow);border:2px solid #fff;border-radius:50%}.controls-row{justify-content:space-between;align-items:center;gap:var(--space-lg);display:flex}.control-group{align-items:center;gap:var(--space-sm);display:flex}.control-btn{border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--border-color);width:40px;height:40px;transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:1.2rem;display:flex}.control-btn:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--border-active);transform:scale(1.05)}.control-btn:disabled{opacity:.3;cursor:not-allowed}.play-btn{background:var(--accent-primary);width:48px;height:48px;box-shadow:0 4px 12px var(--accent-primary-glow);border:none;border-radius:50%;font-size:1.4rem}.play-btn:hover:not(:disabled){box-shadow:0 6px 20px var(--accent-primary-glow);transform:scale(1.1)}.speed-control{align-items:center;gap:var(--space-sm);display:flex}.speed-label{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.speed-buttons{background:var(--bg-tertiary);border-radius:var(--radius-sm);gap:2px;padding:2px;display:flex}.speed-btn{font-size:var(--text-xs);color:var(--text-tertiary);transition:all var(--transition-fast);font-weight:600;font-family:var(--font-mono);border-radius:4px;padding:4px 10px}.speed-btn:hover{color:var(--text-primary)}.speed-btn.active{background:var(--accent-primary);color:#fff}.shortcuts-hint{gap:var(--space-lg);justify-content:center;display:flex}.shortcuts-hint span{font-size:var(--text-xs);color:var(--text-muted);font-family:var(--font-mono)}@media (width<=768px){.controls-row{flex-direction:column}.shortcuts-hint{display:none}}.code-panel{border-radius:var(--radius-lg);transition:all var(--transition-base);overflow:hidden}.code-panel-header{padding:var(--space-md) var(--space-lg);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast);justify-content:space-between;align-items:center;display:flex}.code-panel-header:hover{background:var(--bg-glass)}.code-panel-title{align-items:center;gap:var(--space-sm);display:flex}.code-panel-title h3{font-size:var(--text-base);font-weight:600}.code-icon{font-size:1.1rem}.expand-hint{font-size:var(--text-sm);color:var(--text-tertiary);margin-left:var(--space-xs)}.code-actions{gap:var(--space-sm);display:flex}.copy-btn{border-radius:var(--radius-sm);font-size:var(--text-xs);color:var(--text-secondary);background:var(--bg-tertiary);border:1px solid var(--border-color);transition:all var(--transition-fast);padding:5px 12px;font-weight:600}.copy-btn:hover{color:var(--text-primary);border-color:var(--border-active)}.lang-tabs{padding:0 var(--space-lg);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-color);gap:2px;display:flex}.lang-tab{border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--text-tertiary);transition:all var(--transition-fast);border:1px solid #0000;align-items:center;gap:5px;padding:7px 14px;font-weight:500;display:flex}.lang-tab:hover{color:var(--text-secondary);background:var(--bg-glass)}.lang-tab.active{color:var(--text-primary);background:var(--bg-card);border-color:var(--accent-primary)}.lang-tab-icon{font-size:.95rem}.lang-tab-label{font-size:var(--text-xs)}.code-block-wrapper{background:var(--bg-card);border-top:1px solid var(--border-color);max-height:480px;display:flex;position:relative;overflow-y:auto}.code-block-lines{padding:var(--space-md) 0;flex-direction:column;flex:1;display:flex}.code-line-row{font-family:var(--font-mono);white-space:pre;border-left:3px solid #0000;font-size:13px;line-height:1.65;transition:background .15s,border-left-color .15s;display:flex}.code-line-row.highlight{border-left-color:var(--accent-warning);background:#fdcb6e1f}.code-line-row .line-number{text-align:right;min-width:45px;padding-right:var(--space-md);color:var(--text-muted);-webkit-user-select:none;user-select:none;border-right:1px solid var(--border-color);margin-right:var(--space-md)}.code-line-row .line-number.highlight{color:var(--accent-warning);font-weight:700}.code-line-row .line-content{color:var(--text-secondary);tab-size:2;flex:1;overflow-x:auto}.code-line-row.highlight .line-content{color:var(--text-primary)}.code-panel.collapsed{max-height:52px}@media (width<=768px){.lang-tab-label{display:none}}.custom-input{border-radius:var(--radius-lg);transition:all var(--transition-base);overflow:hidden}.custom-input-header{padding:var(--space-md) var(--space-lg);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast);justify-content:space-between;align-items:center;display:flex}.custom-input-header:hover{background:var(--bg-glass)}.custom-input-title{align-items:center;gap:var(--space-sm);display:flex}.custom-input-title h3{font-size:var(--text-base);font-weight:600}.input-icon{font-size:1.1rem}.custom-input-body{padding:0 var(--space-lg) var(--space-lg);gap:var(--space-md);flex-direction:column;display:flex}.preset-row{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.preset-label{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;font-weight:600}.preset-buttons{flex-wrap:wrap;gap:4px;display:flex}.preset-btn{border-radius:var(--radius-sm);font-size:var(--text-xs);color:var(--text-secondary);background:var(--bg-tertiary);border:1px solid var(--border-color);transition:all var(--transition-fast);padding:4px 10px;font-weight:500}.random-btn{border-color:var(--accent-warning);color:var(--accent-warning)}.random-btn:hover{background:#fdcb6e1a}.input-group{flex-direction:column;gap:4px;display:flex}.input-label{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:500}.input-row{gap:var(--space-sm);width:100%;display:flex}.input-field{border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);font-family:var(--font-mono);font-size:var(--text-base);transition:all var(--transition-fast);outline:none;flex:1;padding:12px 16px}.input-field:focus{border-color:var(--accent-primary);background:var(--bg-card);box-shadow:0 0 0 3px #6c5ce726}.target-field{max-width:200px}.visualize-btn-inline{background:var(--accent-primary);color:#fff;border-radius:var(--radius-md);height:48px;font-weight:700;font-size:var(--text-sm);transition:all var(--transition-fast);box-shadow:0 4px 12px var(--accent-primary-glow);white-space:nowrap;justify-content:center;align-items:center;gap:8px;padding:0 24px;animation:3s infinite pulse-glow;display:flex}.visualize-btn-inline:hover{box-shadow:0 6px 20px var(--accent-primary-glow);filter:brightness(1.1);transform:translateY(-2px)}.visualize-btn-inline:active{transform:translateY(0)}@keyframes pulse-glow{0%,to{box-shadow:0 4px 12px var(--accent-primary-glow)}50%{box-shadow:0 4px 24px #6c5ce780}}.custom-input.closed{max-height:52px}@media (width<=600px){.custom-input-header{padding:var(--space-md)}.custom-input-body{padding:0 var(--space-md) var(--space-md)}.input-row{flex-direction:column}.target-field{max-width:none}.visualize-btn-inline{width:100%;height:48px;padding:0}}.visualizer-page{max-width:1600px;padding:var(--space-lg) var(--space-xl);gap:var(--space-lg);flex-direction:column;margin:0 auto;display:flex}.viz-header{justify-content:space-between;align-items:center;gap:var(--space-md);padding-bottom:var(--space-md);border-bottom:1px solid var(--border-color);display:flex}.viz-header-left{gap:var(--space-xs);flex-direction:column;display:flex}.back-link{font-size:var(--text-sm);color:var(--text-secondary);transition:color var(--transition-fast);align-items:center;gap:4px;display:inline-flex}.back-link:hover{color:var(--accent-primary)}.viz-title-group{align-items:center;gap:var(--space-sm);display:flex}.viz-icon{font-size:1.3rem}.viz-title{font-size:var(--text-2xl);letter-spacing:-.3px;color:var(--text-primary);font-weight:700}.viz-difficulty{border-radius:var(--radius-full);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.4px;padding:2px 8px;font-weight:600}.viz-difficulty[data-difficulty=easy]{color:var(--accent-success);background:#3fb9501f}.viz-difficulty[data-difficulty=medium]{color:var(--accent-warning);background:#d299221f}.viz-difficulty[data-difficulty=hard]{color:var(--accent-error);background:#f851491f}.generate-btn{flex-shrink:0}.viz-content{gap:var(--space-md);flex-direction:column;display:flex}.viz-main-layout{grid-template-columns:var(--left-width,65%) 16px calc(100% - var(--left-width,65%) - 16px);align-items:start;gap:0;display:grid}.viz-resizer{cursor:col-resize;-webkit-user-select:none;user-select:none;z-index:10;justify-content:center;align-self:stretch;align-items:center;width:16px;height:100%;display:flex;position:relative}.viz-resizer-line{background:var(--border-color);border-radius:var(--radius-full);width:2px;height:calc(100% - 20px);min-height:460px;transition:background var(--transition-fast), width var(--transition-fast)}.viz-resizer:hover .viz-resizer-line,.viz-resizer.active .viz-resizer-line{background:var(--accent-warning);width:4px}.viz-main-layout.resizing{-webkit-user-select:none;user-select:none;cursor:col-resize}.viz-main-layout.resizing *{-webkit-user-select:none!important;user-select:none!important;pointer-events:none!important}.viz-main-layout.resizing .viz-resizer{pointer-events:auto!important}.viz-left-col{gap:var(--space-md);flex-direction:column;min-width:0;display:flex}.viz-right-col{flex-direction:column;min-width:0;display:flex}.viz-canvas{border-radius:var(--radius-lg);padding:var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);flex-direction:column;min-height:480px;display:flex}.viz-empty{color:var(--text-tertiary);font-size:var(--text-base);flex:1;justify-content:center;align-items:center;display:flex}.input-label-bar{justify-content:space-between;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border-color);display:flex}.input-label-info{align-items:center;gap:var(--space-sm);min-width:0;display:flex}.input-label-icon{flex-shrink:0;font-size:.9rem}.input-label-text{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.solution-badge{border-radius:var(--radius-full);border:1px solid var(--border-color);background:#ffffff0d;flex-shrink:0;align-items:center;gap:8px;padding:6px 12px;display:flex}.solution-badge.highlight{border-color:var(--accent-warning);background:#fdcb6e26;animation:.8s ease-in-out badge-pulse}@keyframes badge-pulse{0%{transform:scale(1)}50%{box-shadow:0 0 10px var(--accent-warning);transform:scale(1.05)}to{transform:scale(1)}}.badge-icon{font-size:.9rem}.badge-label{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:500}.badge-value{font-size:var(--text-sm);color:var(--accent-warning);font-weight:700;font-family:var(--font-mono)}.viz-info-panel{gap:var(--space-md);grid-template-columns:2fr 1fr 1fr;display:grid}.info-card{padding:var(--space-md);border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border-color)}.info-card h3{font-size:var(--text-xs);margin-bottom:var(--space-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.info-card p{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.55}.complexity-grid{gap:var(--space-lg);display:flex}.complexity-grid>div{flex-direction:column;gap:2px;display:flex}.complexity-case{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.4px}.complexity-val{font-size:var(--text-base);color:var(--accent-secondary);font-weight:600}.visualizer-not-found{justify-content:center;align-items:center;gap:var(--space-lg);height:50vh;color:var(--text-secondary);flex-direction:column;display:flex}@media (width<=1024px){.viz-main-layout{gap:var(--space-md);grid-template-columns:1fr}.viz-resizer{display:none}}@media (width<=768px){.visualizer-page{padding:var(--space-md);gap:var(--space-md)}.viz-header{align-items:stretch;gap:var(--space-sm);flex-direction:column}.viz-title{font-size:var(--text-xl)}.generate-btn{justify-content:center;width:100%}.viz-info-panel{gap:var(--space-sm);grid-template-columns:1fr}.viz-canvas{min-height:350px;padding:var(--space-sm)}.complexity-grid{gap:var(--space-md)}}@media (width<=480px){.viz-title-group{flex-wrap:wrap}.input-label-bar{flex-direction:column;align-items:stretch;gap:10px}.solution-badge{justify-content:center}}.dijkstra-node-picker{align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border-color);flex-wrap:wrap;display:flex}.picker-group{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.picker-label{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.6px;white-space:nowrap;align-items:center;gap:6px;font-weight:700;display:flex}.picker-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.picker-dot-src{background:#38bdf8;box-shadow:0 0 6px #38bdf899}.picker-dot-tgt{background:#f59e0b;box-shadow:0 0 6px #f59e0b99}.picker-nodes{flex-wrap:wrap;gap:4px;display:flex}.picker-btn{border:1.5px solid var(--border-color);background:var(--bg-tertiary);width:30px;height:30px;color:var(--text-secondary);font-family:var(--font-mono);font-size:var(--text-xs);cursor:pointer;transition:all var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;font-weight:700;display:flex}.picker-btn:hover:not(:disabled){border-color:var(--text-tertiary);color:var(--text-primary);background:var(--bg-secondary);transform:scale(1.1)}.picker-btn:disabled{opacity:.3;cursor:not-allowed}.picker-btn-active-src{box-shadow:0 0 8px #38bdf84d;color:#38bdf8!important;background:#38bdf833!important;border-color:#38bdf8!important}.picker-btn-active-tgt{box-shadow:0 0 8px #f59e0b4d;color:#f59e0b!important;background:#f59e0b33!important;border-color:#f59e0b!important}.picker-separator{color:var(--text-muted);align-items:center;padding:0 4px;display:flex}.source-label{color:#38bdf8}.target-label{color:#f59e0b}.visual-stage{background:var(--bg-primary);flex-direction:column;height:100%;display:flex;position:relative;overflow:hidden}.stage-header{border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.stage-badge{letter-spacing:.12em;color:var(--accent-primary);background:var(--accent-primary-glow);border-radius:var(--radius-sm);border:1px solid #2f81f740;padding:4px 10px;font-size:10px;font-weight:800}.header-right{align-items:center;gap:10px;display:flex}.step-counter{color:var(--text-tertiary);font-size:12px;font-family:var(--font-mono)}.step-counter strong{color:var(--text-primary)}.guide-toggle-btn{width:26px;height:26px;color:var(--accent-primary);cursor:pointer;background:#2f81f71f;border:1px solid #2f81f74d;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:800;transition:all .15s;display:flex}.guide-toggle-btn:hover{background:#2f81f738;transform:scale(1.1)}.guide-open-btn{background:var(--accent-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;align-items:center;gap:6px;margin:12px auto 0;padding:9px 20px;font-size:13px;font-weight:700;transition:all .15s;display:inline-flex;box-shadow:0 2px 12px #2f81f759}.guide-open-btn:hover{transform:translateY(-1px);box-shadow:0 4px 18px #2f81f773}.naming-guide-panel{background:var(--bg-secondary);border-left:1px solid var(--border-color);border-bottom:1px solid var(--border-color);border-bottom-left-radius:var(--radius-lg);z-index:200;flex-direction:column;width:320px;max-height:calc(100% - 110px);display:flex;position:absolute;top:48px;right:0;overflow-y:auto;box-shadow:-4px 4px 24px #00000059}.ng-panel{flex-direction:column;gap:14px;padding:16px;display:flex}.ng-header{justify-content:space-between;align-items:center;display:flex}.ng-title{color:var(--text-primary);letter-spacing:.02em;font-size:14px;font-weight:800}.ng-close{width:24px;height:24px;color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:14px;transition:all .15s;display:flex}.ng-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.ng-subtitle{color:var(--text-secondary);border-bottom:1px solid var(--border-color);margin:0;padding-bottom:10px;font-size:11px;line-height:1.5}.ng-entries{flex-direction:column;gap:14px;display:flex}.ng-entry{background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-color);flex-direction:column;gap:6px;padding:10px 12px;display:flex}.ng-entry-header{border-left:3px solid;align-items:center;gap:7px;margin-left:-2px;padding-left:8px;display:flex}.ng-entry-emoji{font-size:15px}.ng-entry-type{letter-spacing:.02em;font-size:13px;font-weight:800}.ng-rule{color:var(--text-secondary);margin:0;font-size:11px;line-height:1.5}.ng-names{flex-wrap:wrap;gap:5px;display:flex}.ng-name-tag{font-family:var(--font-mono);color:var(--accent-primary);background:var(--accent-primary-glow);border-radius:var(--radius-sm);border:1px solid #2f81f740;padding:2px 7px;font-size:11px;font-weight:700}.ng-pointers{flex-direction:column;gap:4px;margin-top:2px;display:flex}.ng-ptr-label{color:var(--text-tertiary);font-size:10px;font-weight:600}.ng-ptr-tags{flex-wrap:wrap;gap:4px;display:flex}.ng-ptr-tag{font-family:var(--font-mono);color:var(--accent-warning);border-radius:var(--radius-sm);background:#d299221a;border:1px solid #d2992240;padding:2px 6px;font-size:10px;font-weight:700}.ng-examples{flex-direction:column;gap:3px;margin-top:2px;display:flex}.ng-example{font-family:var(--font-mono);color:var(--text-secondary);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);white-space:nowrap;text-overflow:ellipsis;padding:3px 8px;font-size:10px;display:block;overflow:hidden}.stage-main{scroll-behavior:smooth;background-image:radial-gradient(circle at 1px 1px,#ffffff0a 1px,#0000 0);background-size:28px 28px;flex-direction:column;flex:1;align-items:center;padding:28px 20px 80px;display:flex;overflow:auto}.visual-grid{flex-direction:column;align-items:center;gap:28px;width:100%;max-width:900px;display:flex}.visual-section{background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color);width:100%;box-shadow:var(--shadow-md);flex-direction:column;align-items:center;gap:20px;padding:20px 24px 24px;display:flex}.section-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1.2px;background:var(--bg-tertiary);border-radius:var(--radius-sm);border:1px solid var(--border-color);align-self:flex-start;padding:3px 10px;font-size:10px;font-weight:700}.section-label-name{color:var(--accent-secondary);font-weight:900}.visual-array{flex-wrap:wrap;justify-content:center;align-items:flex-end;gap:14px;padding-top:32px;display:flex}.orb-column{flex-direction:column;align-items:center;gap:6px;min-width:50px;display:flex;position:relative}.pointer-container{justify-content:center;align-items:flex-end;height:32px;display:flex}.pointer-arrow{flex-direction:column;align-items:center;font-size:10px;font-weight:800;line-height:1.2;display:flex}.pointer-label{font-family:var(--font-mono);font-size:10px}.visual-orb{border:2px solid var(--border-color);background:var(--accent-primary);box-shadow:var(--shadow-md), 0 0 12px var(--accent-primary-glow);border-radius:50%;justify-content:center;align-items:center;transition:border-color .2s;display:flex}.orb-value{color:#fff;font-weight:700;font-family:var(--font-mono);text-shadow:0 1px 2px #00000080;font-size:12px}.orb-index{color:var(--text-tertiary);font-size:11px;font-family:var(--font-mono)}.visual-stack{flex-direction:column;gap:4px;width:100%;min-width:160px;max-width:320px;display:flex}.stack-item{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);height:44px;font-family:var(--font-mono);color:var(--text-primary);box-shadow:var(--shadow-sm);justify-content:center;align-items:center;font-size:15px;font-weight:600;transition:background .2s;display:flex;position:relative}.stack-item:first-child{background:var(--bg-card);border-color:var(--accent-primary);box-shadow:0 0 8px var(--accent-primary-glow)}.stack-value{color:var(--text-primary);font-size:15px;font-weight:700;font-family:var(--font-mono)}.stack-top-badge{letter-spacing:.08em;color:var(--accent-warning);border-radius:var(--radius-sm);background:#d299221f;border:1px solid #d299224d;padding:2px 6px;font-size:9px;font-weight:800;position:absolute;right:-52px}.stack-base-label{letter-spacing:.1em;color:var(--text-tertiary);text-align:center;border-top:2px dashed var(--border-color);width:100%;padding-top:6px;font-size:9px;font-weight:700}.visual-queue{flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;padding:24px 12px 12px;display:flex}.queue-item{flex-direction:column;align-items:center;gap:6px;display:flex;position:relative}.queue-box{background:var(--bg-tertiary);border:2px solid var(--accent-secondary);border-radius:var(--radius-md);width:56px;height:56px;font-weight:700;font-family:var(--font-mono);color:var(--text-primary);box-shadow:0 0 8px var(--accent-secondary-glow);justify-content:center;align-items:center;font-size:15px;display:flex}.queue-badge{letter-spacing:.08em;border-radius:var(--radius-sm);padding:2px 6px;font-size:9px;font-weight:800;position:absolute}.queue-badge.front{color:var(--accent-warning);background:#d299221f;border:1px solid #d299224d;top:-22px}.queue-badge.rear{color:var(--accent-secondary);background:var(--accent-secondary-glow);border:1px solid #3dc9b04d;bottom:-22px}.visual-list{flex-wrap:nowrap;align-items:center;gap:6px;width:100%;padding:12px 8px 16px;display:flex;overflow-x:auto}.visual-list-horizontal{flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px 8px 16px;display:flex;overflow-x:auto}.list-head-label{letter-spacing:.1em;color:var(--accent-primary);background:var(--accent-primary-glow);border-radius:var(--radius-sm);border:1px solid #2f81f74d;flex-shrink:0;padding:3px 8px;font-size:9px;font-weight:800}.list-node-container{flex-shrink:0;align-items:center;gap:6px;display:flex}.list-node{background:var(--bg-card);border:2px solid var(--accent-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-md);display:flex;overflow:hidden}.list-node-val{color:var(--text-primary);border-right:1px solid var(--border-color);text-align:center;min-width:36px;font-size:14px;font-weight:700;font-family:var(--font-mono);padding:8px 14px}.list-node-next{color:var(--accent-primary);font-family:var(--font-mono);background:var(--bg-tertiary);padding:8px 10px;font-size:14px;font-weight:700}.list-arrow{color:var(--text-secondary);flex-shrink:0;font-size:16px}.list-tail{color:var(--text-tertiary);background:var(--bg-tertiary);border-radius:var(--radius-sm);border:1px solid var(--border-color);flex-shrink:0;padding:5px 10px;font-size:10px;font-weight:700}.visual-tree{justify-content:center;width:100%;padding:8px 12px 24px;display:flex;overflow-x:auto}.tree-node-container{flex-direction:column;align-items:center;display:flex;position:relative}.tree-node-circle{background:var(--bg-tertiary);border:2px solid var(--accent-secondary);width:46px;height:46px;font-weight:700;font-family:var(--font-mono);color:var(--text-primary);z-index:2;box-shadow:var(--shadow-md), 0 0 8px var(--accent-secondary-glow);border-radius:50%;justify-content:center;align-items:center;font-size:14px;display:flex}.tree-leaf{color:var(--text-tertiary);background:var(--bg-tertiary);border-radius:var(--radius-sm);border:1px solid var(--border-color);padding:4px 8px;font-size:10px}.tree-branches{gap:24px;padding-top:20px;display:flex;position:relative}.tree-branches:before{content:"";background:var(--border-color);width:2px;height:20px;position:absolute;top:0;left:50%;transform:translate(-50%)}.tree-branch{flex-direction:column;align-items:center;display:flex;position:relative}.tree-branch:before{content:"";background:var(--border-color);width:2px;height:20px;position:absolute;top:0;left:50%;transform:translate(-50%)}.vs-graph-container{background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border-color);width:100%;overflow:hidden}.vs-graph-svg{width:100%;min-height:280px;display:block}.vs-graph-edge{transition:stroke .3s,stroke-width .3s}.vs-node-circle{transition:fill .3s,stroke .3s}.vs-node-ring{animation:2s ease-in-out infinite vs-ring-pulse}@keyframes vs-ring-pulse{0%,to{opacity:.15}50%{opacity:.35}}.visual-string{flex-wrap:wrap;justify-content:center;align-items:flex-end;gap:4px;width:100%;padding-top:32px;display:flex;overflow-x:auto}.string-col{flex-direction:column;align-items:center;gap:5px;min-width:34px;display:flex;position:relative}.string-cell{background:var(--bg-tertiary);border:1.5px solid var(--border-color);border-radius:var(--radius-sm);width:34px;height:34px;font-family:var(--font-mono);color:var(--text-primary);cursor:default;letter-spacing:0;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;transition:all .18s;display:flex}.string-cell:hover{background:#e06c7514;border-color:#e06c754d}.string-cell.string-cell-active{z-index:2;transform:scale(1.1);box-shadow:0 0 12px #e06c7580;color:#fff!important;background:#e06c75!important;font-weight:800!important}.string-idx{color:var(--text-tertiary);font-size:10px;font-family:var(--font-mono)}.string-truncated{color:var(--text-tertiary);background:var(--bg-tertiary);border:1px dashed var(--border-color);border-radius:var(--radius-sm);white-space:nowrap;justify-content:center;align-self:center;align-items:center;height:34px;padding:0 8px;font-size:10px;font-weight:700;display:flex}.visual-matrix-wrap{flex-direction:column;gap:3px;padding:4px 2px 8px;display:flex;overflow-x:auto}.matrix-col-header{gap:3px;margin-bottom:2px;display:flex}.matrix-corner{flex-shrink:0;width:32px}.matrix-col-idx{text-align:center;width:44px;font-size:10px;font-family:var(--font-mono);color:var(--text-tertiary);border-bottom:1px solid var(--border-color);flex-shrink:0;padding-bottom:4px;font-weight:700;transition:color .2s,border-color .2s}.matrix-col-idx.matrix-ptr-col{color:var(--accent-warning);border-bottom-color:var(--accent-warning)}.matrix-row{align-items:center;gap:3px;display:flex}.matrix-row-idx{text-align:center;width:32px;font-size:10px;font-family:var(--font-mono);color:var(--text-tertiary);border-right:1px solid var(--border-color);flex-shrink:0;margin-right:3px;padding-right:6px;font-weight:700;transition:color .2s}.matrix-row-idx.matrix-ptr-row{color:var(--accent-warning);border-right-color:var(--accent-warning)}.matrix-cell{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:44px;height:44px;font-family:var(--font-mono);color:var(--text-primary);cursor:default;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:600;transition:all .2s;display:flex}.matrix-cell:hover{background:#ffffff0d;border-color:#ffffff26}.matrix-cell-active{z-index:2;transform:scale(1.08);box-shadow:0 0 14px #d2992280,0 0 4px #d299224d;color:#000!important;background:#d29922!important;border-color:#d29922!important;font-weight:800!important}.matrix-cell-row-hl{color:var(--accent-warning)!important;background:#d299221a!important;border-color:#d299224d!important}.matrix-cell-col-hl{color:var(--accent-primary)!important;background:#2f81f71a!important;border-color:#2f81f74d!important}.visual-map{background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-color);width:100%;max-width:480px;box-shadow:var(--shadow-md);overflow:hidden}.map-table{flex-direction:column;display:flex}.map-header{border-bottom:2px solid var(--border-color);background:#ffffff08;padding:8px 16px;display:flex}.map-col{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.1em;flex:1;font-size:10px;font-weight:800}.map-col:last-child{text-align:right}.map-row{border-bottom:1px solid var(--border-color);align-items:center;padding:10px 16px;transition:background .2s;display:flex}.map-row:last-child{border-bottom:none}.map-row:hover{background:#ffffff05}.map-key{font-family:var(--font-mono);color:var(--accent-secondary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;font-weight:700;overflow:hidden}.map-sep{color:var(--text-tertiary);padding:0 12px;font-weight:800}.map-val{font-family:var(--font-mono);color:var(--text-primary);text-align:right;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;font-weight:600;overflow:hidden}.visual-primitives-panel{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:var(--radius-md);min-width:140px;box-shadow:var(--shadow-lg);z-index:50;opacity:.95;flex-direction:column;gap:8px;padding:12px 16px;display:flex;position:absolute;top:60px;right:20px}.primitives-header{color:var(--accent-secondary);letter-spacing:.12em;border-bottom:1px dashed var(--border-color);margin-bottom:4px;padding-bottom:6px;font-size:10px;font-weight:800}.primitives-list{flex-direction:column;gap:6px;display:flex}.primitive-item{font-family:var(--font-mono);align-items:center;font-size:12px;display:flex}.primitive-key{color:var(--text-secondary);font-weight:600}.primitive-sep{color:var(--text-tertiary);margin:0 6px}.primitive-val{color:var(--text-primary);font-weight:700}.visual-output-panel{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);width:100%;max-width:900px;box-shadow:var(--shadow-md);flex-direction:column;gap:12px;margin-top:28px;padding:20px 24px;display:flex}.output-content{color:var(--text-primary);white-space:pre-wrap;word-break:break-all;margin:0;font-size:13px;line-height:1.5}.visual-stage-empty{background:var(--bg-primary);justify-content:center;align-items:center;height:100%;padding:24px;display:flex}.empty-content{text-align:center;max-width:480px}.empty-icon{opacity:.6;margin-bottom:16px;font-size:36px}.empty-content h3{color:var(--text-primary);margin:0 0 8px;font-size:18px;font-weight:700}.empty-content p{color:var(--text-secondary);margin:0 0 24px;font-size:13px;line-height:1.6}.hint-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;width:100%;display:grid}.hint-item{background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color);text-align:left;flex-direction:column;gap:4px;padding:10px 12px;display:flex}.hint-item code{color:var(--accent-primary);font-size:12px;font-weight:700;font-family:var(--font-mono)}.hint-item span{color:var(--text-tertiary);font-size:10px}.hint-tip{color:var(--text-tertiary)!important;margin-top:16px!important;font-size:11px!important}.ds-empty-msg{color:var(--text-tertiary);padding:16px;font-size:12px;font-style:italic}.stage-controls-container{pointer-events:none;z-index:100;justify-content:center;display:flex;position:absolute;bottom:20px;left:0;right:0}.stage-controls{pointer-events:auto;border-radius:var(--radius-full);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);background:#0d1117e6;gap:8px;padding:6px 8px;display:flex}.stage-ctrl-btn{width:34px;height:34px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:14px;transition:all .15s;display:flex}.stage-ctrl-btn:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary);transform:scale(1.08)}.stage-ctrl-btn:disabled{opacity:.3;cursor:not-allowed}.play-btn{box-shadow:0 2px 8px var(--accent-primary-glow);background:var(--accent-primary)!important;color:#fff!important}.play-btn:hover:not(:disabled){transform:scale(1.1);background:#388bfd!important}.play-btn.playing{box-shadow:0 2px 8px #d2992266;background:var(--accent-warning)!important}@media (width<=1024px){.visual-grid{padding:0 10px}}@media (width<=768px){.stage-main{padding:20px 12px 100px}.visual-section{padding:16px 14px 20px}.visual-array{gap:8px}.orb-column{min-width:40px}.visual-orb{width:36px!important;height:36px!important}.orb-value{font-size:11px}.visual-stack{max-width:100%}.queue-box{width:44px;height:44px;font-size:13px}.list-node-val{padding:6px 10px;font-size:12px}.list-node-next{padding:6px 8px;font-size:12px}.naming-guide-panel{border-left:none;border-top:1px solid var(--border-color);border-bottom-left-radius:0;width:100%;max-height:80%}}@media (width<=480px){.stage-header{padding:8px 12px}.stage-badge{padding:3px 8px;font-size:9px}.step-counter{font-size:10px}.visual-primitives-panel{width:auto;max-width:none;top:50px;left:12px;right:12px}.primitives-list{flex-flow:wrap;gap:12px}.primitive-item{font-size:11px}.visual-orb{width:32px!important;height:32px!important}.orb-value{font-size:10px}.stack-item{height:36px;font-size:13px}.queue-box{width:38px;height:38px;font-size:12px}.string-cell{width:28px;height:28px;font-size:12px}.matrix-cell{width:28px;height:28px;font-size:11px}.tree-node-circle{width:36px;height:36px;font-size:12px}.tree-branches{gap:12px}}.rec-tree-wrapper{flex-direction:column;align-items:center;gap:12px;width:100%;display:flex}.rec-tree-legend{letter-spacing:.06em;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);align-items:center;gap:16px;padding:4px 12px;font-size:10px;font-weight:700;display:flex}.rec-legend-item{align-items:center;gap:5px;display:flex}.rec-legend-item.active{color:var(--accent-primary)}.rec-legend-item.waiting{color:var(--text-secondary)}.rec-legend-item.done{color:var(--accent-secondary)}.rec-tree-scroll{scrollbar-width:thin;scrollbar-color:var(--border-color) transparent;justify-content:center;width:100%;padding-bottom:8px;display:flex;overflow:auto visible}.rec-tree-scroll::-webkit-scrollbar{height:4px}.rec-tree-scroll::-webkit-scrollbar-track{background:0 0}.rec-tree-scroll::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.rec-tree-svg{min-width:200px;display:block;overflow:visible}.ai-hint-panel{z-index:100;background:#141419d9;border:1px solid #2f81f759;border-radius:12px;flex-direction:column;max-height:40%;animation:.3s ease-out forwards slideUp;display:flex;position:absolute;bottom:20px;left:20px;right:20px;overflow:hidden;box-shadow:0 8px 32px #0000004d}.ai-hint-header{background:#2f81f71a;border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.ai-hint-title{color:#cce0ff;align-items:center;gap:8px;font-size:.95rem;font-weight:600;display:flex}.ai-icon{color:var(--accent-primary)}.close-btn{color:#888;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;transition:all .2s;display:flex}.close-btn:hover{color:#fff;background:#ffffff1a}.ai-hint-content{padding:16px;font-size:.9rem;line-height:1.5;overflow-y:auto}.ai-hint-loading{flex-direction:column;gap:12px;display:flex}.skeleton-line{background:#ffffff1a;border-radius:4px;height:12px;animation:1.5s infinite pulse}.ai-hint-error{color:#ff6b6b;text-align:center;flex-direction:column;align-items:center;gap:12px;padding:20px 0;display:flex}.retry-btn{color:#ff6b6b;cursor:pointer;background:#ff6b6b1a;border:1px solid #ff6b6b4d;border-radius:6px;padding:6px 12px;transition:all .2s}.retry-btn:hover{background:#ff6b6b33}.ai-hint-result{flex-direction:column;gap:16px;display:flex}.hint-section h4{color:#aaa;text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:6px;margin:0 0 8px;font-size:.85rem;display:flex}.hint-section p{color:#eee;margin:0}.problem-section h4{color:#ff9e64}.lines-section h4{color:#f1fa8c}.tip-section h4{color:#8be9fd}.suspect-lines{flex-wrap:wrap;gap:8px;display:flex}.line-badge{color:#f1fa8c;background:#f1fa8c26;border:1px solid #f1fa8c4d;border-radius:12px;padding:2px 8px;font-family:JetBrains Mono,monospace;font-size:.8rem}.ai-hint-line-decoration{background-color:#f1fa8c26}.ai-hint-line-margin{background-color:#f1fa8ccc;margin-left:4px;width:4px!important}@media (width<=768px){.ai-hint-panel{max-height:85%;bottom:10px;left:10px;right:10px}}.playground{flex-direction:column;height:calc(100dvh - 56px);display:flex;overflow:hidden}.playground-toolbar{padding:0 var(--space-lg);border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0;justify-content:space-between;align-items:center;height:44px;display:flex}.playground-title{font-size:var(--text-base);color:var(--text-primary);font-weight:600}.toolbar-left,.toolbar-right{align-items:center;gap:var(--space-sm);display:flex}.language-selector{background:var(--bg-tertiary);border-radius:var(--radius-sm);border:1px solid var(--border-color);gap:2px;padding:2px;display:flex}.lang-btn{font-size:var(--text-xs);color:var(--text-tertiary);transition:all var(--transition-fast);border-radius:3px;align-items:center;gap:4px;padding:4px 10px;font-weight:500;display:flex}.lang-btn:hover{color:var(--text-primary);background:var(--bg-card-hover)}.lang-btn.active{color:var(--text-primary);background:var(--bg-card)}.lang-icon{font-size:.85rem}.lang-label{display:none}@media (width>=900px){.lang-label{display:inline}}.btn-run{background:var(--accent-success);color:#fff;border-radius:var(--radius-sm);font-weight:600;font-size:var(--text-xs);transition:all var(--transition-fast);border:1px solid #0000;padding:6px 16px}.btn-run:hover:not(:disabled){background:#3fb950cc;transform:translateY(-1px)}.btn-run:disabled{opacity:.45;cursor:not-allowed}.btn-trace{border:1px solid var(--border-color);color:var(--text-secondary);border-radius:var(--radius-sm);font-weight:600;font-size:var(--text-xs);transition:all var(--transition-fast);background:0 0;padding:6px 12px}.btn-trace:hover:not(:disabled){border-color:var(--accent-warning);color:var(--accent-warning);background:#d2992214}.btn-trace:disabled{opacity:.4;cursor:not-allowed}.playground-main{grid-template-columns:var(--left-width,1fr) 6px 1fr;flex:1;display:grid;position:relative;overflow:hidden}.playground-main.is-resizing{cursor:col-resize;-webkit-user-select:none;user-select:none}.playground-main.is-resizing .editor-panel,.playground-main.is-resizing .output-panel{pointer-events:none}.playground-resizer{background:var(--border-color);cursor:col-resize;z-index:100;justify-content:center;align-items:center;width:6px;transition:background .2s,width .2s;display:flex;position:relative}.playground-resizer:hover,.playground-resizer.active{background:var(--primary-color);width:8px}.playground-resizer:hover .resizer-knob,.playground-resizer.active .resizer-knob{background:#fff}.is-resizing *{pointer-events:none!important}.is-resizing .playground-resizer{pointer-events:auto!important}.editor-panel{border-right:1px solid var(--border-color);flex-direction:column;display:flex;overflow:hidden}.editor-header{padding:0 var(--space-md);border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0;align-items:center;height:36px;display:flex}.editor-tab{height:100%;font-size:var(--text-xs);color:var(--text-secondary);align-items:center;gap:6px;padding:0 10px;display:flex}.editor-tab.active{color:var(--text-primary);border-bottom:1px solid var(--accent-primary)}.tab-dot{border-radius:50%;width:7px;height:7px}.editor-body{flex:1;position:relative;overflow:hidden}.output-panel{background:var(--bg-secondary);flex-direction:column;display:flex;position:relative;overflow:hidden}.output-tabs{border-bottom:1px solid var(--border-color);flex-shrink:0;display:flex}.output-tab{font-size:var(--text-xs);color:var(--text-tertiary);transition:all var(--transition-fast);border-bottom:2px solid #0000;flex:1;justify-content:center;align-items:center;gap:5px;padding:9px;font-weight:500;display:flex}.output-tab:hover{color:var(--text-secondary)}.output-tab.active{color:var(--text-primary);border-bottom-color:var(--accent-primary)}.trace-count{border-radius:var(--radius-full);background:var(--accent-primary);color:#fff;padding:1px 5px;font-size:10px;font-weight:700}.output-body{padding:var(--space-md);flex:1;overflow-y:auto}.output-text{font-size:var(--text-sm);color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;line-height:1.6}.trace-body{gap:var(--space-md);padding:var(--space-md);flex-direction:column;flex:1;display:flex;overflow-y:auto}.trace-empty{text-align:center;height:100%;color:var(--text-tertiary);justify-content:center;align-items:center;gap:var(--space-sm);flex-direction:column;display:flex}.trace-hint{font-size:var(--text-sm);color:var(--text-muted)}.trace-controls{align-items:center;gap:var(--space-sm);display:flex}.trace-step-info{font-size:var(--text-xs);color:var(--text-tertiary);margin-left:auto}.trace-event{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);display:flex}.trace-event.error{background:#f8514912;border:1px solid #f8514940}.trace-event-badge{border-radius:var(--radius-sm);background:var(--accent-secondary);color:#fff;padding:2px 7px;font-size:10px;font-weight:700}.trace-event.error .trace-event-badge{background:var(--accent-error)}.trace-error-msg{font-size:var(--text-sm);color:var(--accent-error);flex:1}.trace-line-num{font-size:var(--text-xs);color:var(--text-tertiary)}.trace-variables h4,.trace-callstack h4,.trace-output h4{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.8px;margin-bottom:var(--space-sm)}.var-list{flex-direction:column;gap:3px;display:flex}.var-item{align-items:center;gap:var(--space-sm);border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);font-size:var(--text-sm);padding:4px 8px;display:flex}.var-name{color:var(--accent-secondary);font-weight:600}.var-equals{color:var(--text-tertiary)}.var-value{color:var(--accent-warning);word-break:break-all}.stack-frames{flex-direction:column;gap:2px;display:flex}.stack-frame{border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);font-size:var(--text-sm);color:var(--text-secondary);padding:4px 8px}.stack-frame:first-child{color:var(--accent-primary);border-color:#2f81f740;font-weight:600}.trace-output pre{padding:var(--space-sm);border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);font-size:var(--text-sm);color:var(--text-secondary);white-space:pre-wrap}@media (width<=900px){.playground-main{grid-template-rows:1fr 1fr;grid-template-columns:1fr}.playground-resizer{display:none}.editor-panel{border-right:none;border-bottom:1px solid var(--border-color)}.playground-toolbar{height:auto;padding:var(--space-sm) var(--space-md);gap:var(--space-sm);flex-wrap:wrap;justify-content:center}.toolbar-left{justify-content:center;width:100%}}@media (width<=600px){.playground-main{grid-template-rows:1.2fr .8fr}.playground-toolbar{padding:var(--space-xs)}.btn-run,.btn-trace{padding:6px 12px;font-size:11px}.playground-title{display:none}}.visual-variable-highlight{border-bottom:2px solid var(--primary-color);cursor:help;background-color:#6c5ce726;border-radius:2px;transition:background-color .2s}.visual-variable-highlight:hover{background-color:#6c5ce740}.trace-line-decoration{background-color:#fdcb6e1f!important;border-left:3px solid #fdcb6e!important}.trace-line-error-decoration{background-color:#ff475726!important;border-left:3px solid #ff4757!important}.trace-line-margin{background-color:#fdcb6e0f}.trace-line-error-margin{background-color:#ff47570f}.python-loading-overlay{justify-content:center;align-items:center;gap:var(--space-md);height:100%;padding:var(--space-xl);text-align:center;flex-direction:column;display:flex}.python-loading-spinner{border:3px solid var(--border-color);border-top-color:#3572a5;border-radius:50%;width:44px;height:44px;animation:.9s linear infinite py-spin}@keyframes py-spin{to{transform:rotate(360deg)}}.python-loading-title{font-size:var(--text-base);color:var(--text-primary);font-weight:600;animation:2s ease-in-out infinite py-pulse}.python-loading-sub{font-size:var(--text-sm);color:var(--text-tertiary);max-width:280px;line-height:1.6}@keyframes py-pulse{0%,to{opacity:1}50%{opacity:.55}}.devai-hint-btn{color:#fff;cursor:pointer;background:var(--accent-primary);box-shadow:0 4px 12px var(--accent-primary-glow);z-index:1;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:8px 16px;font-size:.9rem;font-weight:600;transition:all .3s;display:inline-flex;position:relative;overflow:hidden}.devai-hint-btn:before{content:"";background:conic-gradient(from 0deg, transparent 20%, var(--accent-primary) 40%, var(--accent-secondary) 60%, var(--accent-tertiary) 80%, transparent 100%);opacity:0;z-index:-2;width:200%;height:200%;transition:opacity .3s;animation:2.5s linear infinite rotateBorder;position:absolute;top:-50%;left:-50%}.devai-hint-btn:after{content:"";z-index:-1;background:#0d1324;border-radius:7px;transition:background .3s;position:absolute;inset:1.5px}[data-theme=light] .devai-hint-btn:after{background:#f0f6fc}[data-theme=light] .devai-hint-btn{color:var(--text-primary)}.devai-hint-btn:hover:before{opacity:1}.devai-hint-btn:hover{box-shadow:0 0 16px var(--accent-primary-glow);background:0 0;transform:translateY(-1px)}.devai-hint-btn:active{transform:translateY(0)}.devai-hint-btn-sm{color:#fff;cursor:pointer;background:var(--accent-primary);z-index:1;border:none;border-radius:6px;justify-content:center;align-self:flex-start;align-items:center;gap:6px;padding:4px 10px;font-size:.85rem;font-weight:600;transition:all .3s;display:inline-flex;position:relative;overflow:hidden}.devai-hint-btn-sm:before{content:"";background:conic-gradient(from 0deg, transparent 20%, var(--accent-primary) 40%, var(--accent-secondary) 60%, var(--accent-tertiary) 80%, transparent 100%);opacity:0;z-index:-2;width:200%;height:200%;transition:opacity .3s;animation:2.5s linear infinite rotateBorder;position:absolute;top:-50%;left:-50%}.devai-hint-btn-sm:after{content:"";z-index:-1;background:#0d1324;border-radius:5px;transition:background .3s;position:absolute;inset:1.5px}[data-theme=light] .devai-hint-btn-sm:after{background:#f0f6fc}[data-theme=light] .devai-hint-btn-sm{color:var(--text-primary)}.devai-hint-btn-sm:hover:before{opacity:1}.devai-hint-btn-sm:hover{background:0 0;transform:translateY(-1px)}.devai-hint-btn-sm:active{transform:translateY(0)}@keyframes rotateBorder{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-page{background:var(--bg-primary);width:100vw;min-height:100vh;display:flex;position:relative;overflow:hidden auto}.login-bg-grid{background-color:var(--border-color);opacity:.35;pointer-events:none;background-size:28px 28px;width:60%;position:absolute;inset:0}.login-orb{filter:blur(100px);pointer-events:none;z-index:0;border-radius:50%;position:absolute}.login-orb--blue{background:#2f81f71f;width:500px;height:500px;top:-100px;left:-100px}.login-orb--teal{background:#3dc9b01a;width:400px;height:400px;bottom:-50px;right:20%}.login-left{z-index:1;flex:0 0 60%;align-items:center;padding:8% 10%;display:flex;position:relative}.login-left-content{gap:var(--space-lg);flex-direction:column;max-width:600px;display:flex}.login-logo-large{align-items:center;gap:24px;display:flex}.login-logo-large .login-logo{border-radius:var(--radius-md);object-fit:contain;width:160px;height:160px}.login-logo-large .login-brand{letter-spacing:-3px;font-size:4rem;font-weight:800}.login-hero-title{color:var(--text-primary);letter-spacing:-1.5px;font-size:4rem;font-weight:800;line-height:1.1}.gradient-text-alt{color:var(--accent-secondary)}.login-hero-subtitle{font-size:var(--text-lg);color:var(--text-secondary);max-width:90%;line-height:1.6}.login-right{background:var(--bg-secondary);border-left:1px solid var(--border-color);padding:var(--space-2xl);z-index:2;flex:0 0 40%;justify-content:center;align-items:center;display:flex;box-shadow:-10px 0 30px #00000026}.login-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;max-width:400px;padding:var(--space-2xl) var(--space-xl);box-shadow:var(--shadow-sm);align-items:center;gap:var(--space-lg);flex-direction:column;display:flex}.login-logo-wrap{align-items:center;gap:12px;display:flex}.login-title{font-size:var(--text-2xl);color:var(--text-primary);text-align:center;font-weight:700}.login-subtitle{font-size:var(--text-sm);color:var(--text-secondary);text-align:center;margin-top:-12px;line-height:1.6}.login-divider{align-items:center;gap:var(--space-md);width:100%;color:var(--text-tertiary);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:1px;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--border-color);flex:1;height:1px}.login-oauth-btn{justify-content:center;align-items:center;gap:var(--space-md);width:100%;padding:13px var(--space-lg);border-radius:var(--radius-lg);font-size:var(--text-base);border:1px solid var(--border-color);transition:background var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);cursor:pointer;font-weight:500;font-family:var(--font-sans);display:flex}.login-oauth-btn:disabled{opacity:.6;cursor:not-allowed}.login-oauth-btn--google{background:var(--bg-tertiary);color:var(--text-primary)}.login-oauth-btn--google:hover:not(:disabled){background:var(--bg-card-hover);border-color:#4285f4;box-shadow:0 0 0 3px #4285f41f}.oauth-icon{flex-shrink:0;width:20px;height:20px}.login-spinner{border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.7s linear infinite spin}.login-error{width:100%;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:var(--accent-error);font-size:var(--text-sm);text-align:center;background:#f851491a;border:1px solid #f851494d}.login-terms{font-size:var(--text-xs);color:var(--text-tertiary);text-align:center;line-height:1.6}.login-link{color:var(--accent-primary);text-underline-offset:2px;text-decoration:underline}.login-link:hover{color:var(--text-primary)}@media (width<=1024px){.login-page{flex-direction:column;overflow-y:auto}.login-bg-grid{width:100%}.login-left{width:100%;padding:var(--space-2xl) var(--space-xl);text-align:center;flex:none;align-items:center}.login-left-content{align-items:center;max-width:100%}.login-logo-large{gap:var(--space-md);flex-direction:column}.login-logo-large .login-logo{width:120px;height:120px}.login-logo-large .login-brand{letter-spacing:-2px;font-size:3rem}.login-hero-title{font-size:3rem}.login-hero-subtitle{max-width:100%;margin:0 auto}.login-right{border-left:none;border-top:1px solid var(--border-color);width:100%;padding:var(--space-2xl) var(--space-xl);flex:none}}@media (width<=768px){.login-left{padding:var(--space-2xl) var(--space-lg)}.login-logo-large .login-logo{width:100px;height:100px}.login-logo-large .login-brand,.login-hero-title{font-size:2.5rem}.login-card{padding:var(--space-xl) var(--space-lg)}}@media (width<=480px){.login-left{padding:var(--space-xl) var(--space-md)}.login-logo-large .login-logo{width:80px;height:80px}.login-logo-large .login-brand{letter-spacing:-1px;font-size:2rem}.login-hero-title{font-size:1.8rem;line-height:1.2}.login-hero-subtitle{font-size:var(--text-base)}.login-right{padding:var(--space-xl) var(--space-md)}.login-card{box-shadow:none;background:0 0;border:none;padding:0}.login-title{font-size:var(--text-xl)}}.sql-page{background:var(--bg-primary);flex-direction:column;height:calc(100dvh - 56px);display:flex;overflow:hidden}.sql-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:0 var(--space-lg);flex-shrink:0}.sql-header-inner{justify-content:space-between;align-items:center;gap:var(--space-md);height:52px;display:flex}.sql-title-group{align-items:center;gap:var(--space-sm);flex-shrink:0;display:flex}.sql-title-icon{border-radius:var(--radius-md);width:34px;height:34px;color:var(--accent-primary);background:#2f81f726;border:1px solid #2f81f74d;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sql-title{font-size:var(--text-base);color:var(--text-primary);font-weight:700;line-height:1.2}.sql-subtitle{font-size:var(--text-xs);color:var(--text-tertiary);line-height:1}.dataset-tabs{background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-color);scrollbar-width:none;gap:4px;padding:3px;display:flex;overflow-x:auto}.dataset-tabs::-webkit-scrollbar{display:none}.dataset-tab{border-radius:calc(var(--radius-md) - 2px);font-size:var(--text-xs);color:var(--text-tertiary);white-space:nowrap;transition:all var(--transition-fast);align-items:center;gap:5px;padding:5px 12px;font-weight:500;display:flex}.dataset-tab:hover{color:var(--text-primary);background:var(--bg-card-hover)}.dataset-tab.active{background:var(--bg-card);color:var(--text-primary);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.dataset-tab-name{display:none}@media (width>=640px){.dataset-tab-name{display:inline}}.sql-body{grid-template-columns:var(--left-width,320px) 6px 1fr;flex:1;min-height:0;display:grid;position:relative;overflow:hidden}.sql-body.is-resizing{cursor:col-resize;-webkit-user-select:none;user-select:none}.sql-body.is-resizing .sql-left-panel,.sql-body.is-resizing .sql-right-panel{pointer-events:none}.sql-resizer{background:var(--border-color);cursor:col-resize;z-index:100;justify-content:center;align-items:center;width:6px;transition:background .2s,width .2s;display:flex;position:relative}.sql-resizer:hover,.sql-resizer.active{background:var(--accent-primary);width:8px}.resizer-knob{background:#fff3;border-radius:1px;width:2px;height:20px}.sql-resizer:hover .resizer-knob,.sql-resizer.active .resizer-knob{background:#fff}.sql-left-panel{border-right:1px solid var(--border-color);background:var(--bg-secondary);flex-direction:column;min-height:0;display:flex;overflow:hidden}.preset-queries{padding:var(--space-sm) var(--space-sm) var(--space-xs);border-bottom:1px solid var(--border-color);flex-shrink:0}.panel-label{text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);padding:var(--space-xs) var(--space-xs) var(--space-sm);align-items:center;gap:5px;font-size:10px;font-weight:600;display:flex}.panel-label-btn{cursor:pointer;width:100%;padding:var(--space-xs);transition:color var(--transition-fast);background:0 0;border:none;outline:none;justify-content:space-between;font-family:inherit}.panel-label-btn:hover{color:var(--text-primary)}.panel-label-left{align-items:center;gap:5px;display:flex}.presets-chevron{transition:transform var(--transition-fast);color:var(--text-muted)}.presets-chevron.open{transform:rotate(90deg)}.preset-list{padding-bottom:var(--space-xs);flex-wrap:wrap;gap:4px;display:flex}.preset-btn{border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--text-secondary);background:var(--bg-tertiary);border:1px solid var(--border-color);transition:all var(--transition-fast);white-space:nowrap;padding:4px 10px;font-weight:500}.preset-btn:hover{color:var(--text-primary);border-color:var(--accent-primary);background:var(--accent-primary-glow)}.preset-btn.active{color:var(--accent-primary);border-color:var(--accent-primary);background:var(--accent-primary-glow);font-weight:600}.sql-editor-panel{border-bottom:1px solid var(--border-color);flex-direction:column;flex:1;min-height:0;display:flex}.sql-editor-header{padding:0 var(--space-sm);background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:center;height:32px;display:flex}.editor-header-left{align-items:center;gap:5px;display:flex}.editor-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.editor-dot.red{background:#ff5f57}.editor-dot.yellow{background:#febc2e}.editor-dot.green{background:#28c840}.editor-file-name{font-size:var(--text-xs);color:var(--text-tertiary);font-family:var(--font-mono);margin-left:6px}.editor-hint{color:var(--text-muted);font-size:10px;font-family:var(--font-mono)}.sql-editor-body{flex:1;min-height:0;display:flex;position:relative;overflow:hidden}.line-numbers{padding:var(--space-sm) 0;text-align:right;-webkit-user-select:none;user-select:none;background:var(--bg-tertiary);border-right:1px solid var(--border-color);flex-shrink:0;min-width:36px;padding-right:8px;overflow:hidden}.line-num{font-family:var(--font-mono);color:var(--text-muted);height:19.2px;font-size:12px;line-height:1.6}.sql-textarea{padding:var(--space-sm);font-family:var(--font-mono);color:var(--text-primary);background:var(--bg-secondary);resize:none;word-break:break-word;min-height:120px;max-height:260px;caret-color:var(--accent-primary);border:none;outline:none;flex:1;font-size:13px;line-height:1.6;overflow-y:auto}.sql-textarea::placeholder{color:var(--text-muted)}.sql-textarea:focus{background:var(--bg-secondary)}.sql-left-panel.presets-collapsed .sql-textarea{max-height:none}.sql-active-clause-banner{background:#2f81f70f;border-top:1px solid #2f81f726;border-bottom:1px solid #2f81f726;flex-shrink:0;align-items:center;gap:7px;padding:6px 12px;animation:.3s bannerFadeIn;display:flex}@keyframes bannerFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.active-clause-text{color:var(--text-tertiary);flex:1;font-size:11px}.active-clause-text strong{font-family:var(--font-mono);font-size:12px}.active-clause-target{color:var(--text-muted);animation:2s infinite pulse}.sql-editor-footer{align-items:center;gap:var(--space-sm);padding:var(--space-sm);border-top:1px solid var(--border-color);background:var(--bg-tertiary);flex-shrink:0;display:flex}.sql-run-btn{border-radius:var(--radius-sm);background:var(--gradient-primary);color:#fff;font-weight:600;font-size:var(--text-xs);cursor:pointer;transition:all var(--transition-fast);border:none;align-items:center;gap:6px;padding:6px 16px;display:flex;box-shadow:0 2px 8px #2f81f759}.sql-run-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #2f81f773}.sql-run-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.sql-run-btn.running{background:var(--bg-card);color:var(--text-secondary);box-shadow:none;border:1px solid var(--border-color)}.run-spinner{border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;width:12px;height:12px;animation:.7s linear infinite spin}.run-status{font-size:var(--text-xs);align-items:center;gap:4px;display:flex}.status-ok{color:var(--accent-success);align-items:center;gap:4px;display:flex}.status-error{color:var(--accent-error);align-items:center;gap:4px;display:flex}.schema-sidebar{flex-shrink:0;max-height:220px;overflow-y:auto}.schema-header{padding:var(--space-sm);text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);border-top:1px solid var(--border-color);background:var(--bg-tertiary);align-items:center;gap:5px;font-size:10px;font-weight:600;display:flex;position:sticky;top:0}.schema-guide-btn{border-radius:var(--radius-full);color:#58a6ff;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all var(--transition-fast);background:#58a6ff14;border:1px solid #58a6ff33;flex-shrink:0;align-items:center;gap:4px;margin-left:auto;padding:3px 8px;font-family:inherit;font-size:10px;font-weight:700;display:flex}.schema-guide-btn:hover{color:#79c0ff;background:#58a6ff29;border-color:#58a6ff66;box-shadow:0 0 10px #58a6ff33}.schema-table{border-bottom:1px solid var(--border-color)}.schema-table-name{width:100%;padding:7px var(--space-sm);font-size:var(--text-xs);color:var(--text-secondary);transition:all var(--transition-fast);text-align:left;align-items:center;gap:6px;font-weight:600;display:flex}.schema-table-name:hover{color:var(--text-primary);background:var(--bg-card-hover)}.schema-table-name.open{color:var(--accent-primary)}.schema-table-rows{color:var(--text-muted);font-size:10px;font-weight:400;font-family:var(--font-mono);margin-left:auto}.schema-chevron{transition:transform var(--transition-fast);margin-left:4px}.schema-table-name.open .schema-chevron{transform:rotate(90deg)}.schema-columns{padding:0 var(--space-sm) var(--space-sm) 28px;overflow:hidden}.schema-col{color:var(--text-tertiary);font-size:11px;font-family:var(--font-mono);align-items:center;gap:6px;padding:2px 0;display:flex}.schema-col-dot{background:var(--border-color);border-radius:50%;flex-shrink:0;width:5px;height:5px}.schema-col-name{flex:1}.schema-col-type{color:var(--text-muted);background:var(--bg-tertiary);border-radius:3px;padding:1px 5px;font-size:10px;font-style:italic}.sql-right-panel{background:var(--bg-primary);flex-direction:column;min-height:0;display:flex;overflow:hidden}.sql-empty-state{justify-content:center;align-items:center;gap:var(--space-md);text-align:center;height:100%;padding:var(--space-2xl);flex-direction:column;display:flex}.empty-icon-wrap{border-radius:var(--radius-xl);width:72px;height:72px;color:var(--accent-primary);background:#2f81f71a;border:1px solid #2f81f733;justify-content:center;align-items:center;animation:3s ease-in-out infinite float;display:flex}.sql-empty-state h2{font-size:var(--text-xl);color:var(--text-primary);font-weight:700}.sql-empty-state p{font-size:var(--text-sm);color:var(--text-secondary);max-width:400px;line-height:1.7}.empty-tip{border-radius:var(--radius-full);background:var(--bg-tertiary);border:1px solid var(--border-color);font-size:var(--text-xs);color:var(--text-tertiary);align-items:center;gap:6px;padding:8px 14px;display:flex}.empty-phases-preview{margin-top:var(--space-sm);flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.empty-phase-chip{border-radius:var(--radius-full);background:var(--bg-tertiary);border:1px solid var(--border-color);font-size:var(--text-xs);color:var(--text-muted);font-weight:500;font-family:var(--font-mono);padding:5px 14px}.sql-error-state{justify-content:center;align-items:center;gap:var(--space-sm);height:100%;color:var(--accent-error);text-align:center;padding:var(--space-2xl);flex-direction:column;display:flex}.sql-error-state h3{font-size:var(--text-lg);color:var(--text-primary)}.error-msg{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--accent-error);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);background:#f8514914;border:1px solid #f8514933;max-width:500px}.error-hint{font-size:var(--text-sm);color:var(--text-tertiary)}.sql-viz{flex-direction:column;height:100%;min-height:0;display:flex;overflow:hidden}.pipeline-bar{padding:8px var(--space-md);border-bottom:1px solid var(--border-color);background:var(--bg-secondary);scrollbar-width:none;flex-shrink:0;align-items:center;gap:2px;display:flex;overflow-x:auto}.pipeline-bar::-webkit-scrollbar{display:none}.pipeline-step-wrapper{flex-shrink:0;align-items:center;gap:2px;display:flex}.pipeline-step{border-radius:var(--radius-full);color:var(--text-muted);transition:all var(--transition-fast);cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #0000;align-items:center;gap:5px;padding:5px 10px;font-size:11px;font-weight:600;display:flex;position:relative}.pipeline-step:hover{color:var(--text-secondary);background:var(--bg-tertiary)}.pipeline-step.done{color:var(--step-color,var(--accent-secondary));opacity:.7}.pipeline-step.active{color:var(--step-color,var(--accent-primary));background:color-mix(in srgb, var(--step-color,var(--accent-primary)) 12%, transparent);border-color:color-mix(in srgb, var(--step-color,var(--accent-primary)) 35%, transparent);box-shadow:0 0 12px color-mix(in srgb, var(--step-color,var(--accent-primary)) 25%, transparent)}.pipeline-step-icon{align-items:center;display:flex}.pipeline-step-label{font-family:var(--font-mono)}.pipeline-step-pulse{background:var(--step-color,var(--accent-primary));border-radius:50%;width:7px;height:7px;animation:1.5s infinite pulse;position:absolute;top:-2px;right:-2px}.pipeline-arrow{color:var(--text-muted);flex-shrink:0}.pipeline-arrow.arrow-done{color:var(--accent-secondary);opacity:.5}.sql-controls{padding:var(--space-xs) var(--space-md);align-items:center;gap:var(--space-md);border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0;display:flex}.controls-left{align-items:center;gap:4px;display:flex}.ctrl-btn{border-radius:var(--radius-md);width:30px;height:30px;color:var(--text-secondary);background:var(--bg-tertiary);border:1px solid var(--border-color);transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:15px;display:flex}.ctrl-btn:hover:not(:disabled){color:var(--text-primary);border-color:var(--accent-primary);background:var(--accent-primary-glow)}.ctrl-btn:disabled{opacity:.3;cursor:not-allowed}.ctrl-btn.ctrl-play{background:var(--gradient-primary);color:#fff;border:none;width:34px;height:34px;box-shadow:0 2px 8px #2f81f74d}.ctrl-btn.ctrl-play:hover:not(:disabled){background:var(--gradient-primary);color:#fff;border:none;transform:scale(1.05);box-shadow:0 4px 14px #2f81f773}.ctrl-btn.ctrl-play.active{background:#d29922d9;box-shadow:0 2px 8px #d299224d}.controls-center{align-items:center;gap:var(--space-sm);flex:1;display:flex}.phase-counter{font-size:var(--text-xs);color:var(--text-tertiary);white-space:nowrap;font-family:var(--font-mono)}.phase-progress-bar{background:var(--bg-tertiary);border-radius:2px;flex:1;max-width:180px;height:4px;overflow:hidden}.phase-progress-fill{border-radius:2px;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1),background .3s}.controls-right{align-items:center;gap:6px;display:flex}.ctrl-btn-sm{border-radius:var(--radius-sm);color:var(--text-tertiary);background:var(--bg-tertiary);border:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;align-items:center;gap:4px;padding:4px 8px;font-size:11px;font-weight:500;display:flex}.ctrl-btn-sm:hover{color:var(--text-primary);border-color:var(--accent-primary)}.ctrl-btn-sm.active-sm{color:var(--accent-primary);background:var(--accent-primary-glow);border-color:var(--accent-primary)}.view-tabs{background:var(--bg-tertiary);border-radius:var(--radius-sm);border:1px solid var(--border-color);gap:2px;padding:2px;display:flex}.view-tab{font-size:var(--text-xs);color:var(--text-tertiary);transition:all var(--transition-fast);border-radius:3px;align-items:center;gap:4px;padding:4px 10px;font-weight:500;display:flex}.view-tab:hover{color:var(--text-primary)}.view-tab.active{background:var(--bg-card);color:var(--text-primary);box-shadow:var(--shadow-sm)}.phase-narration{margin:var(--space-sm) var(--space-md) 0;border-radius:var(--radius-lg);background:color-mix(in srgb, var(--phase-color,var(--accent-primary)) 5%, var(--bg-secondary));border:1px solid color-mix(in srgb, var(--phase-color,var(--accent-primary)) 22%, transparent);box-shadow:0 2px 12px color-mix(in srgb, var(--phase-color,var(--accent-primary)) 8%, transparent);flex-shrink:0;align-items:flex-start;gap:0;display:flex;overflow:hidden}.narration-identity{border-right:1px solid color-mix(in srgb, var(--phase-color,var(--accent-primary)) 18%, transparent);background:color-mix(in srgb, var(--phase-color,var(--accent-primary)) 8%, transparent);flex-shrink:0;align-items:flex-start;gap:10px;min-width:170px;padding:10px 14px;display:flex}.narration-emoji{filter:drop-shadow(0 2px 4px #0000004d);margin-top:1px;font-size:22px;line-height:1}.narration-meta{flex-direction:column;gap:2px;display:flex}.narration-step-label{color:var(--text-muted);font-size:10px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.6px}.narration-phase-name{font-size:var(--text-md);font-weight:800;font-family:var(--font-mono);letter-spacing:.5px}.narration-short-desc{color:var(--text-tertiary);font-size:11px;font-style:italic}.narration-divider{display:none}.narration-body{border-right:1px solid color-mix(in srgb, var(--phase-color,var(--accent-primary)) 12%, transparent);flex-direction:column;flex:1;gap:5px;min-width:0;padding:10px 14px;display:flex}.narration-what-label{text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted);align-items:center;gap:5px;font-size:10px;font-weight:700;display:flex}.narration-desc{color:var(--text-primary);font-size:12px;font-weight:500;line-height:1.5}.narration-desc strong{color:var(--text-primary);font-weight:700}.narration-desc code{font-family:var(--font-mono);background:var(--bg-tertiary);color:var(--accent-tertiary);border-radius:3px;padding:1px 5px;font-size:11px}.narration-how{color:var(--text-tertiary);font-size:11px;line-height:1.5}.narration-stats{flex-direction:column;flex-shrink:0;justify-content:center;gap:6px;min-width:120px;padding:10px 14px;display:flex}.narration-stat{align-items:center;gap:6px;display:flex}.narration-stat.stat-filtered .stat-value{color:var(--accent-error)}.stat-icon{color:var(--text-muted);flex-shrink:0;align-items:center;display:flex}.stat-value{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-primary);align-items:center;gap:4px;font-weight:700;display:flex}.stat-label{color:var(--text-muted);font-size:10px}.row-delta{border-radius:var(--radius-full);align-items:center;gap:2px;padding:1px 5px;font-size:10px;font-weight:700;display:inline-flex}.delta-pos{color:var(--accent-success);background:#3fb9501f}.delta-neg{color:var(--accent-error);background:#f851491f}.sql-content-area{flex:1;min-height:0;display:flex;overflow:hidden}.timeline-sidebar{border-right:1px solid var(--border-color);flex-shrink:0;overflow:hidden}.exec-timeline{background:var(--bg-secondary);flex-direction:column;width:160px;height:100%;display:flex;overflow:hidden}.exec-timeline-header{text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);border-bottom:1px solid var(--border-color);background:var(--bg-tertiary);flex-shrink:0;align-items:center;gap:5px;padding:8px 12px;font-size:10px;font-weight:700;display:flex}.exec-timeline-body{scrollbar-width:thin;flex:1;padding:8px 0;overflow-y:auto}.exec-timeline-item-wrapper{position:relative}.exec-timeline-item{text-align:left;cursor:pointer;width:100%;transition:all var(--transition-fast);background:0 0;border:none;align-items:center;gap:8px;padding:5px 12px 5px 10px;display:flex;position:relative}.exec-timeline-item:hover{background:var(--bg-card-hover)}.exec-timeline-item.done{opacity:.65}.exec-timeline-item.active{background:color-mix(in srgb, var(--step-color,var(--accent-primary)) 10%, transparent)}.exec-connector{background:var(--border-color);z-index:0;width:2px;height:100%;position:absolute;top:100%;left:18px}.exec-connector.connector-done{background:color-mix(in srgb, var(--step-color,var(--accent-primary)) 50%, transparent)}.exec-node{border:1.5px solid var(--border-color);background:var(--bg-tertiary);width:22px;height:22px;color:var(--text-muted);z-index:1;transition:all var(--transition-fast);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex;position:relative}.exec-timeline-item.done .exec-node{border-color:color-mix(in srgb, var(--step-color,var(--accent-primary)) 60%, transparent);color:var(--step-color,var(--accent-primary));background:color-mix(in srgb, var(--step-color,var(--accent-primary)) 10%, var(--bg-tertiary))}.exec-timeline-item.active .exec-node{border-color:var(--step-color,var(--accent-primary));color:var(--step-color,var(--accent-primary));background:color-mix(in srgb, var(--step-color,var(--accent-primary)) 15%, var(--bg-secondary));box-shadow:0 0 10px color-mix(in srgb, var(--step-color,var(--accent-primary)) 35%, transparent);animation:1.8s infinite pulse}.exec-node-num{font-size:10px}.exec-item-info{flex-direction:column;gap:1px;min-width:0;display:flex}.exec-item-label{font-size:11px;font-weight:600;font-family:var(--font-mono);color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.exec-timeline-item.active .exec-item-label{color:var(--step-color,var(--accent-primary))}.exec-timeline-item.done .exec-item-label{color:var(--text-tertiary)}.exec-item-stats{font-size:10px;font-family:var(--font-mono);align-items:center;gap:4px;display:flex}.exec-stat-active{color:var(--accent-success)}.exec-stat-filtered{color:var(--accent-error)}.sql-data-view{flex-direction:column;flex:1;min-width:0;min-height:0;display:flex;overflow:hidden}.sql-viz-content{min-height:0;padding:var(--space-sm) var(--space-md) 0;gap:var(--space-sm);flex-direction:column;flex:1;display:flex;overflow:hidden}.sql-table-wrapper{border-radius:var(--radius-lg);border:1px solid var(--border-color);background:var(--bg-secondary);flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.sql-table-scroll{flex:1;overflow:auto}.sql-table{border-collapse:collapse;width:100%;font-size:var(--text-sm);font-family:var(--font-mono)}.sql-table thead{z-index:2;position:sticky;top:0}.sql-table thead tr{background:var(--bg-tertiary)}.sql-table th{text-align:left;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.6px;border-bottom:1px solid var(--border-color);white-space:nowrap;padding:7px 12px;font-size:11px;font-weight:700;position:relative}.sql-table th.col-active{color:var(--accent-primary);background:color-mix(in srgb, var(--accent-primary) 8%, var(--bg-tertiary))}.col-active-dot{background:var(--accent-primary);vertical-align:middle;border-radius:50%;width:6px;height:6px;margin-right:5px;animation:1.5s infinite pulse;display:inline-block}.row-num-col{width:32px;color:var(--text-muted)!important}.row-status-col{text-align:right;width:80px;color:var(--text-muted)!important;padding-right:14px!important}.sql-table td{border-bottom:1px solid var(--border-color);vertical-align:middle;white-space:nowrap;transition:background var(--transition-fast);padding:6px 12px}.sql-table td.cell-active{background:color-mix(in srgb, var(--accent-primary) 5%, transparent)}.sql-table tbody tr:last-child td{border-bottom:none}.sql-table tbody tr:hover td{background:var(--bg-card-hover)}.row-num{color:var(--text-muted);text-align:center;min-width:32px;font-size:11px}.sql-row{transition:background var(--transition-base)}.sql-row.row-highlighted td{background:color-mix(in srgb, var(--accent-primary) 6%, transparent)}.sql-row.row-highlighted:hover td{background:color-mix(in srgb, var(--accent-primary) 11%, transparent)}.sql-row.row-filtered{opacity:.42}.sql-row.row-filtered td{background:color-mix(in srgb, var(--accent-error) 6%, transparent);text-decoration:line-through;-webkit-text-decoration-color:var(--accent-error);text-decoration-color:var(--accent-error);text-decoration-thickness:1px}.sql-row.row-grouped td{background:color-mix(in srgb, var(--accent-secondary) 7%, transparent)}.sql-row.row-selected td{background:color-mix(in srgb, var(--accent-success) 6%, transparent)}.sql-row.row-sorted td{background:color-mix(in srgb, var(--accent-warning) 6%, transparent)}.sql-row.row-changed td{animation:.5s rowChangePulse}@keyframes rowChangePulse{0%{background:#ffffff0f}to{background:0 0}}.cell-null{color:#ff7b72;background:#ff7b721f;border:1px solid #ff7b7233;border-radius:4px;padding:1px 5px;font-size:11px;font-style:italic;font-weight:600;display:inline-block}.cell-number{color:#79c0ff}.cell-string{color:var(--text-secondary)}.cell-bool{font-weight:600}.cell-true{color:var(--accent-success)}.cell-false{color:var(--accent-error)}.row-status-td{text-align:right;padding-right:10px!important}.row-status-badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.4px;font-size:10px;font-weight:600;font-family:var(--font-mono);padding:1px 7px;display:inline-block}.badge-normal{color:var(--text-muted);background:#ffffff0d}.badge-highlighted{color:#79c0ff;background:#2f81f726}.badge-filtered{color:#ff7b72;background:#f8514926;text-decoration:line-through}.badge-grouped{color:#3dc9b0;background:#3dc9b026}.badge-selected{color:#3fb950;background:#3fb95026}.badge-sorted{color:#58a6ff;background:#58a6ff26}.sql-table-footer{background:var(--bg-tertiary);border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;flex-shrink:0;padding:6px 14px;display:flex}.table-footer-stats{align-items:center;gap:var(--space-md);display:flex}.table-footer-legend{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.table-stat{color:var(--text-tertiary);font-size:11px}.table-stat strong{color:var(--text-primary)}.text-filtered{color:var(--accent-error)!important}.leg{color:var(--text-muted);align-items:center;gap:4px;font-size:10px;display:flex}.leg-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.dot-highlighted{background:var(--accent-primary)}.dot-filtered{background:var(--accent-error)}.dot-selected{background:var(--accent-success)}.dot-grouped{background:var(--accent-secondary)}.dot-sorted{background:var(--accent-warning)}.sql-table-empty{justify-content:center;align-items:center;gap:var(--space-sm);height:200px;color:var(--text-muted);font-size:var(--text-sm);flex-direction:column;display:flex}.sql-highlighted-view{padding:var(--space-sm);font-family:var(--font-mono);white-space:pre-wrap;word-break:break-word;background:0 0;flex:1;margin:0;font-size:13px;line-height:1.6;overflow-x:auto}.sql-tok-plain{color:var(--text-primary)}.sql-tok-kw{color:#cc99cd;font-weight:700;transition:all .25s}.sql-tok-active{color:#fff;background:color-mix(in srgb, var(--accent-primary) 25%, transparent);box-shadow:0 0 8px color-mix(in srgb, var(--accent-primary) 40%, transparent);border-radius:3px;padding:0 2px;animation:1.5s infinite kwPulse}@keyframes kwPulse{0%,to{box-shadow:0 0 6px #2f81f766}50%{box-shadow:0 0 14px #2f81f7b3}}.schema-full-view{min-width:0;min-height:0;padding:var(--space-md);gap:var(--space-md);flex-direction:column;flex:1;display:flex;overflow-y:auto}.schema-full-table{border-radius:var(--radius-lg);border:1px solid var(--border-color);background:var(--bg-secondary);min-width:0;overflow:hidden}.schema-full-table-header{background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);font-size:var(--text-sm);color:var(--text-primary);align-items:center;gap:7px;padding:9px 14px;font-weight:600;display:flex}.schema-row-count{font-size:var(--text-xs);color:var(--text-muted);margin-left:auto;font-weight:400}.schema-full-table-scroll{width:100%;overflow-x:auto}.schema-more-rows{color:var(--text-muted);background:var(--bg-tertiary);border-top:1px solid var(--border-color);text-align:center;padding:6px 14px;font-size:11px}.sql-guide-view{min-width:0;min-height:0;padding:var(--space-lg);gap:var(--space-xl);scrollbar-width:thin;flex-direction:column;flex:1;display:flex;overflow-y:auto}.guide-header h2{font-size:var(--text-lg);color:var(--text-primary);margin-bottom:4px;font-weight:700}.guide-header p{font-size:var(--text-sm);color:var(--text-secondary)}.guide-body{gap:var(--space-xl);grid-template-columns:1fr;display:grid}@media (width>=960px){.guide-body{grid-template-columns:1.2fr 1fr}}.execution-flow{gap:var(--space-md);padding-left:var(--space-md);flex-direction:column;display:flex;position:relative}.execution-flow:before{content:"";background:var(--accent-primary);opacity:.3;z-index:0;width:2px;position:absolute;top:15px;bottom:15px;left:25px}.flow-node{gap:var(--space-md);z-index:1;display:flex;position:relative}.node-badge{color:#fff;z-index:2;border:1px solid #fff3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;font-weight:700;display:flex;box-shadow:0 0 10px #ffffff1a}.node-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);transition:all var(--transition-fast);flex-direction:column;flex:1;gap:6px;display:flex}.node-content:hover{border-color:var(--accent-primary);background:var(--bg-card-hover);transform:translate(4px)}.node-clause{font-family:var(--font-mono);font-size:var(--text-sm);letter-spacing:.5px;font-weight:700}.node-desc{font-size:var(--text-xs);color:var(--text-secondary);line-height:1.5}.node-code{font-family:var(--font-mono);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);word-break:break-all;padding:4px 8px;font-size:11px}.guide-gotchas{gap:var(--space-md);flex-direction:column;display:flex}.guide-gotchas h3{font-size:var(--text-md);color:var(--text-primary);margin-bottom:var(--space-xs);font-weight:700}.gotcha-card{border:1px solid var(--border-color);border-left:3px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-md);transition:all var(--transition-fast);background:#ffffff05}.gotcha-card:hover{background:#ffffff0a;border-color:#2f81f74d #2f81f74d #2f81f74d currentColor;transform:translate(2px)}.gotcha-card.accent-blue{border-left-color:#2f81f7}.gotcha-card.accent-blue:hover{border-color:#2f81f759 #2f81f759 #2f81f759 #2f81f7}.gotcha-card.accent-yellow{border-left-color:#d29922}.gotcha-card.accent-yellow:hover{border-color:#d2992259 #d2992259 #d2992259 #d29922}.gotcha-card.accent-green{border-left-color:#3fb950}.gotcha-card.accent-green:hover{border-color:#3fb95059 #3fb95059 #3fb95059 #3fb950}.gotcha-card.accent-purple{border-left-color:#a371f7}.gotcha-card.accent-purple:hover{border-color:#a371f759 #a371f759 #a371f759 #a371f7}.gotcha-card.accent-orange{border-left-color:#f0883e}.gotcha-card.accent-orange:hover{border-color:#f0883e59 #f0883e59 #f0883e59 #f0883e}.gotcha-card-header{justify-content:space-between;align-items:flex-start;gap:var(--space-sm);margin-bottom:6px;display:flex}.gotcha-card h4{font-size:var(--text-sm);color:var(--accent-primary);flex:1;margin-bottom:0;font-weight:600}.gotcha-card p{font-size:var(--text-xs);color:var(--text-tertiary);line-height:1.6}.gotcha-card code{font-family:var(--font-mono);background:var(--bg-tertiary);color:var(--text-primary);border-radius:3px;padding:2px 5px;font-size:11px}.gotcha-tag{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.4px;flex-shrink:0;align-items:center;padding:2px 7px;font-size:10px;font-weight:700;display:inline-flex}.tag-gotcha{color:#ff7b72;background:#f851491f;border:1px solid #f8514933}.tag-best-practice{color:#3fb950;background:#3fb9501f;border:1px solid #3fb95033}.tag-performance{color:#a371f7;background:#a371f71f;border:1px solid #a371f733}.execution-step-tip{border-radius:var(--radius-sm);color:var(--text-tertiary);background:#ffffff06;border:1px solid #ffffff0f;align-items:flex-start;gap:6px;margin-top:2px;padding:6px 8px;font-size:11px;line-height:1.5;display:flex}.tip-icon{flex-shrink:0;margin-top:1px;font-size:12px}.keyboard-hint{padding:var(--space-xs);color:var(--text-muted);border-top:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0;justify-content:center;align-items:center;gap:8px;font-size:11px;display:flex}@media (width<=1024px){.sql-body{grid-template-columns:var(--left-width,280px) 6px 1fr}.exec-timeline{width:140px}.narration-identity{min-width:140px}.narration-stats{min-width:100px}}@media (width<=768px){.sql-page{height:auto;overflow:auto}.sql-header-inner{height:auto;padding:var(--space-sm) 0;gap:var(--space-sm);flex-direction:column;align-items:flex-start}.sql-header{padding:var(--space-sm) var(--space-md)}.sql-body{flex:unset;grid-template-rows:auto auto;grid-template-columns:1fr;overflow:visible}.sql-resizer{display:none}.sql-left-panel{border-right:none;border-bottom:1px solid var(--border-color);max-height:none;overflow:visible}.sql-right-panel{min-height:500px;overflow:visible}.sql-viz{height:auto;overflow:visible}.sql-viz-content{flex:unset;padding-bottom:var(--space-md);overflow:visible}.schema-full-view,.sql-guide-view{flex:unset;min-height:unset;min-width:unset;overflow:visible}.sql-table-wrapper{min-height:300px}.controls-center,.timeline-sidebar{display:none}.sql-content-area{flex-direction:column}.sql-empty-state{height:400px}.phase-narration{flex-direction:column}.narration-identity{min-width:unset;border-bottom:1px solid #ffffff14;border-right:none}.narration-body{border-right:none}.narration-stats{gap:var(--space-md);flex-flow:wrap}.ctrl-btn-sm{display:none}.sql-controls{justify-content:space-between;gap:var(--space-sm);flex-wrap:wrap}.controls-right{margin-left:auto}}@media (width<=480px){.sql-title-group{gap:6px}.sql-title{font-size:var(--text-sm)}.sql-subtitle{display:none}.preset-list{flex-wrap:nowrap;padding-bottom:4px;overflow-x:auto}.pipeline-step-label{display:none}.pipeline-step{padding:5px 7px}.keyboard-hint,.view-tab svg{display:none}.narration-identity{flex-direction:row;align-items:center}.sql-active-clause-banner{display:none}}.editor-mode-tabs{background:var(--bg-tertiary);border-radius:var(--radius-md);border-bottom:1px solid var(--border-color);margin:var(--space-xs) var(--space-sm) 0;flex-shrink:0;gap:4px;padding:4px;display:flex}.mode-tab-btn{color:var(--text-muted);cursor:pointer;border-radius:calc(var(--radius-md) - 2px);transition:all var(--transition-fast);background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:6px;padding:8px 12px;font-size:12px;font-weight:600;display:flex}.mode-tab-btn:hover{color:var(--text-primary);background:#ffffff08}.mode-tab-btn.active{background:var(--bg-card);color:var(--accent-primary);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.challenge-arena-panel{padding:var(--space-md);gap:var(--space-md);flex-direction:column;flex:1;min-height:0;display:flex;overflow-y:auto}.challenge-selector-wrapper{gap:var(--space-xs);flex-direction:column;display:flex}.challenge-select-label{text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);font-size:11px;font-weight:700}.challenge-select-dropdown-container{position:relative}.challenge-select-dropdown{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-primary);cursor:pointer;transition:border-color var(--transition-fast);outline:none;padding:10px 14px;font-size:13px;font-weight:500}.challenge-select-dropdown:focus{border-color:var(--accent-primary)}.active-challenge-card{border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);gap:var(--space-sm);background:#ffffff05;flex-direction:column;display:flex}.challenge-card-header{align-items:center;gap:var(--space-sm);display:flex}.challenge-card-title{color:var(--text-primary);font-size:14px;font-weight:700}.difficulty-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:700}.difficulty-badge.easy{color:#3fb950;background:#3fb95026;border:1px solid #3fb9504d}.difficulty-badge.medium{color:#d29922;background:#d2992226;border:1px solid #d299224d}.difficulty-badge.hard{color:#ff7b72;background:#ff7b7226;border:1px solid #ff7b724d}.challenge-card-desc{color:var(--text-secondary);font-size:13px;line-height:1.5}.challenge-card-desc strong{color:var(--text-primary)}.challenge-card-desc code{font-family:var(--font-mono);background:#ffffff0f;border-radius:4px;padding:1px 4px;font-size:11px}.challenge-hints-section{margin-top:var(--space-xs);border-top:1px dashed var(--border-color);padding-top:var(--space-sm);gap:var(--space-sm);flex-direction:column;display:flex}.btn-show-hint{border:1px solid var(--border-color);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background:0 0;align-self:flex-start;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;display:flex}.btn-show-hint:hover:not(:disabled){color:var(--text-primary);border-color:var(--text-muted);background:#ffffff08}.btn-show-hint:disabled{opacity:.5;cursor:not-allowed}.hints-container{flex-direction:column;gap:8px;display:flex}.hint-bubble{border-radius:var(--radius-md);color:var(--text-secondary);background:#2f81f70d;border:1px solid #2f81f726;padding:8px 12px;font-size:12px;line-height:1.4}.hint-bubble strong{color:var(--accent-primary)}.editor-footer-buttons{align-items:center;gap:8px;display:flex}.sql-submit-btn{border-radius:var(--radius-md);color:#fff;cursor:pointer;height:32px;transition:all var(--transition-fast);background:linear-gradient(135deg,#a371f7 0%,#7a52b3 100%);border:none;align-items:center;gap:6px;padding:0 16px;font-size:12px;font-weight:600;display:flex}.sql-submit-btn:hover{transform:translateY(-1px);box-shadow:0 0 12px #a371f766}.sql-submit-btn:active{transform:translateY(0)}.challenge-validation-banner{margin:var(--space-md) var(--space-md) 0;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);align-items:center;gap:var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);display:flex}.challenge-validation-banner.success{background:#3fb95014;border-color:#3fb95040}.challenge-validation-banner.failed{background:#ff7b7214;border-color:#ff7b7240}.banner-icon{flex-shrink:0;justify-content:center;align-items:center;display:flex}.challenge-validation-banner.success .banner-icon{color:#3fb950}.challenge-validation-banner.failed .banner-icon{color:#ff7b72}.banner-content{flex-direction:column;flex:1;gap:2px;display:flex}.banner-title{font-size:13px;font-weight:700}.challenge-validation-banner.success .banner-title{color:#3fb950}.challenge-validation-banner.failed .banner-title{color:#ff7b72}.banner-desc{color:var(--text-secondary);font-size:12px;line-height:1.4}.banner-next-btn{color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:#3fb950;border:none;align-items:center;gap:4px;padding:6px 12px;font-size:12px;font-weight:600;display:flex}.banner-next-btn:hover{background:#4cd964;box-shadow:0 0 10px #3fb95066}.challenge-success-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.challenge-success-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center;align-items:center;gap:var(--space-md);flex-direction:column;width:90%;max-width:480px;display:flex;position:relative;overflow:hidden;box-shadow:0 20px 50px #00000080,0 0 40px #a371f726}.challenge-success-card:before{content:"";background:linear-gradient(90deg,#2f81f7,#bc8cff,#3dc9b0);width:100%;height:4px;position:absolute;top:0;left:0}.success-icon-wrap{border-radius:var(--radius-full);width:80px;height:80px;margin-bottom:var(--space-sm);background:#a371f71a;border:2px dashed #a371f74d;justify-content:center;align-items:center;animation:20s linear infinite rotateDashed;display:flex}@keyframes rotateDashed{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sparkle-icon{color:#a371f7;filter:drop-shadow(0 0 8px #a371f799);animation:2s ease-in-out infinite pulseSparkle}@keyframes pulseSparkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.15)}}.challenge-success-card h2{color:var(--text-primary);margin:0;font-size:24px;font-weight:800}.challenge-success-title{color:var(--accent-primary);background:var(--accent-primary-glow);border-radius:var(--radius-full);margin-top:-4px;padding:4px 12px;font-size:15px;font-weight:600}.challenge-success-desc{color:var(--text-secondary);margin:0 0 var(--space-sm);font-size:14px;line-height:1.5}.success-actions{gap:var(--space-md);width:100%;display:flex}.success-actions button{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);flex:1;padding:12px;font-size:13px;font-weight:600}.success-actions .btn-secondary{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary)}.success-actions .btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--text-muted)}.success-actions .btn-primary{color:#fff;background:linear-gradient(135deg,#3fb950 0%,#2ea44f 100%);border:none;justify-content:center;align-items:center;gap:6px;display:flex}.success-actions .btn-primary:hover{transform:translateY(-1px);box-shadow:0 0 16px #3fb95066}.join-venn-diagram-container{border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:var(--space-md);padding:var(--space-md);gap:var(--space-md);transition:padding var(--transition-fast), margin var(--transition-fast);background:#ffffff03;flex-direction:column;display:flex}.join-venn-diagram-container.collapsed{margin-bottom:var(--space-sm);padding:var(--space-sm) var(--space-md);gap:0}.join-venn-diagram-container.collapsed .venn-header{border-bottom:none;padding-bottom:0}.venn-header{color:var(--text-primary);border-bottom:1px solid var(--border-color);padding-bottom:var(--space-xs);align-items:center;gap:8px;font-size:13px;font-weight:700;display:flex}.venn-body{gap:var(--space-md);grid-template-columns:1.2fr 1fr;align-items:center;display:grid}@media (width<=768px){.venn-body{grid-template-columns:1fr}}.venn-svg-wrapper{justify-content:center;display:flex}.venn-svg{width:100%;max-width:320px;overflow:visible}.venn-part{cursor:pointer;transition:all .3s}.venn-part:hover{fill-opacity:.95;stroke-width:3px}.venn-table-title{fill:var(--text-primary);letter-spacing:.5px;font-family:inherit;font-size:10px;font-weight:800}.venn-table-subtitle{fill:var(--text-muted);font-family:inherit;font-size:9px;font-weight:600}.venn-count{font-family:var(--font-mono);fill:var(--text-primary);font-size:18px;font-weight:800;transition:all .3s}.venn-count.inactive{fill:var(--text-muted);opacity:.5}.venn-label{fill:var(--text-secondary);letter-spacing:.2px;font-family:inherit;font-size:8px;font-weight:700}.venn-info-panel{gap:var(--space-md);flex-direction:column;display:flex}.venn-explanation{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);padding:12px;font-size:12px;line-height:1.5}.explanation-title{color:var(--text-primary);margin:0 0 var(--space-xs);font-weight:700}.venn-explanation strong{color:var(--text-primary)}.venn-summary-stats{flex-direction:column;gap:6px;display:flex}.venn-summary-stats .stat-row{color:var(--text-secondary);align-items:center;font-size:12px;display:flex}.venn-summary-stats .bullet{border-radius:var(--radius-full);width:8px;height:8px;margin-right:8px}.venn-summary-stats .bullet.left{background:#2f81f7}.venn-summary-stats .bullet.overlap{background:#3dc9b0}.venn-summary-stats .bullet.right{background:#bc8cff}.venn-summary-stats .lbl{flex:1}.venn-summary-stats .val{color:var(--text-primary);font-weight:700;font-family:var(--font-mono)}.venn-summary-stats .total{border-top:1px solid var(--border-color);margin-top:4px;padding-top:6px}.venn-summary-stats .total .lbl{color:var(--text-primary);font-weight:700}.venn-summary-stats .total .val{color:var(--accent-primary)}
