@charset "UTF-8";.triple-tables-container{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;gap:.75rem;align-items:start;margin-bottom:1.5rem}.table-section-small{min-width:0}.join-symbol-small{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:.5rem}.join-badge{background:#ffc10733;color:var(--warning-yellow);padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:700;text-transform:uppercase;border:1px solid var(--warning-yellow)}.join-emoji{font-size:1.5rem}.join-condition-small{font-size:.7rem;font-family:Courier New,Consolas,Monaco,monospace;color:var(--text-secondary);text-align:center;line-height:1.3;max-width:100px;word-wrap:break-word}.join-path-display{background:linear-gradient(135deg,#58a6ff1a,#2ebd8c1a);border:1px solid rgba(88,166,255,.3);border-radius:12px;padding:1rem;margin-bottom:1.25rem;box-shadow:0 4px 12px #0003}.join-path-label{font-weight:600;color:var(--accent-blue);margin-bottom:.5rem;font-size:.95rem;text-align:center}.join-path-flow{display:flex;align-items:center;justify-content:center;gap:.75rem;font-family:Courier New,Consolas,Monaco,monospace;font-size:1rem;font-weight:600;flex-wrap:wrap}.join-path-table{color:var(--accent-blue);background:#58a6ff33;padding:.35rem .75rem;border-radius:6px;border:1px solid rgba(88,166,255,.4)}.join-path-arrow{color:var(--accent-green);font-size:1.25rem;font-weight:700}.triple-tables-container .data-table th,.triple-tables-container .data-table td{padding:.5rem .6rem;font-size:.85rem;white-space:nowrap}.triple-tables-container .data-table td{color:var(--text-primary);font-weight:500}.triple-tables-container .table-label{font-size:.9rem;margin-bottom:.5rem}@media (max-width: 1200px){.triple-tables-container{grid-template-columns:1fr;gap:1.5rem}.join-symbol-small{transform:rotate(90deg);padding:1rem 0}.join-condition-small{transform:rotate(-90deg);max-width:none}}@media (max-width: 768px){.join-path-flow{font-size:.85rem;gap:.5rem}.join-path-table{padding:.25rem .5rem}.join-path-arrow{font-size:1rem}.triple-tables-container .data-table th,.triple-tables-container .data-table td{padding:.4rem .5rem;font-size:.75rem}.join-badge{font-size:.65rem;padding:.2rem .4rem}.join-emoji{font-size:1.25rem}.join-condition-small{font-size:.65rem}}.self-join-container{display:grid;gap:.75rem;align-items:start;margin-bottom:1.5rem}.self-join-container.no-connector{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.self-join-container.with-connector{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr)}.table-section-self{min-width:0;max-width:100%;overflow:hidden;display:flex;flex-direction:column}.table-section-self .table-container{flex:1;width:100%}.self-join-container .data-table{font-size:.8rem;width:100%;table-layout:auto}.self-join-container .data-table th,.self-join-container .data-table td{padding:.4rem .5rem;font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.self-join-container .data-table td{color:var(--text-primary);font-weight:500}.self-join-container .table-container{overflow-x:auto;max-width:100%}.self-join-container .table-label{font-size:.85rem;margin-bottom:.5rem}.self-join-container .key-indicator{font-size:.9rem;margin-left:.25rem}.employee-label{color:var(--accent-blue)!important;border-left:3px solid var(--accent-blue);padding-left:.5rem}.manager-label{color:var(--accent-green)!important;border-left:3px solid var(--accent-green);padding-left:.5rem}.alias-explanation{background:linear-gradient(135deg,#58a6ff1a,#2ebd8c1a);border:1px solid rgba(88,166,255,.3);border-radius:12px;padding:1rem;margin-bottom:1.25rem;box-shadow:0 4px 12px #0003}.alias-label{font-weight:600;color:var(--text-primary);margin-bottom:.75rem;font-size:.95rem;text-align:center}.alias-boxes{display:flex;gap:1rem;justify-content:center;align-items:center;flex-wrap:wrap}.alias-box{padding:.5rem 1rem;border-radius:8px;font-size:.9rem;font-family:Courier New,Consolas,Monaco,monospace;border:2px solid;text-align:center}.employee-alias{background:#58a6ff26;border-color:var(--accent-blue);color:var(--accent-blue)}.manager-alias{background:#2ebd8c26;border-color:var(--accent-green);color:var(--accent-green)}.alias-box strong{font-size:1.1rem;font-weight:700;margin-right:.5rem}.self-join-connector{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem .25rem;width:80px;flex-shrink:0}.connector-content{display:flex;flex-direction:column;align-items:center;gap:.5rem}.connector-arrow{font-size:1.5rem;color:var(--warning-yellow)}.connector-text{font-size:.65rem;font-family:Courier New,Consolas,Monaco,monospace;color:var(--text-primary);text-align:center;line-height:1.2;max-width:75px;word-wrap:break-word;background:#ffc10726;padding:.35rem .25rem;border-radius:6px;border:1px solid var(--warning-yellow)}@media (max-width: 1024px){.self-join-container.no-connector,.self-join-container.with-connector{grid-template-columns:1fr;gap:1.5rem}.self-join-connector{transform:rotate(90deg);padding:1.5rem 0}.connector-text{transform:rotate(-90deg);max-width:none}.connector-arrow{transform:rotate(90deg)}}@media (max-width: 768px){.alias-boxes{flex-direction:column;gap:.75rem}.alias-box{width:100%;max-width:300px}.connector-arrow{font-size:1.5rem}.connector-text{font-size:.7rem;padding:.4rem}.employee-label,.manager-label{font-size:.85rem}}.self-join-container .table-section-self:first-child tbody tr.selected{border-left:3px solid var(--accent-blue)}.self-join-container .table-section-self:last-child tbody tr.selected{border-left:3px solid var(--accent-green)}.subquery-box{background:linear-gradient(135deg,#8a2be226,#8a2be20d);border:2px solid rgba(138,43,226,.4);border-radius:12px;padding:1rem;margin-bottom:1.25rem;box-shadow:0 4px 12px #8a2be233}.subquery-label{font-weight:600;color:#a78bfa;margin-bottom:.75rem;font-size:.95rem}.subquery-content{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.subquery-content code{background:#0000004d;padding:.5rem .75rem;border-radius:6px;font-family:Courier New,Consolas,Monaco,monospace;font-size:.9rem;color:gold}.subquery-result{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#8a2be233;border-radius:8px;border:1px solid rgba(138,43,226,.4)}.subquery-result .arrow{font-size:1.2rem;color:#a78bfa}.subquery-result .value{font-weight:700;font-size:1.1rem;color:var(--accent-green);font-family:Courier New,Consolas,Monaco,monospace}.comparison-col{background:#ffc1071a;color:var(--warning-yellow);font-weight:600;font-size:.85rem;white-space:nowrap}.comparison-result{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-weight:700;font-size:.85rem}.comparison-result.yes{background:#2ebd8c33;color:var(--accent-green);border:1px solid var(--accent-green)}.comparison-result.no{background:#ff646433;color:#ff6464;border:1px solid #ff6464}.amount-cell{font-weight:600;font-family:Courier New,Consolas,Monaco,monospace}.subquery-animation .data-table tbody tr.selected{border-left:3px solid var(--warning-yellow)}@media (max-width: 768px){.subquery-content{flex-direction:column;align-items:flex-start}.subquery-result{width:100%;justify-content:center}.comparison-col{font-size:.75rem}.comparison-result{font-size:.75rem;padding:.2rem .4rem}}.exists-box{background:linear-gradient(135deg,#ff6b6b26,#ff6b6b0d);border:2px solid rgba(255,107,107,.4);border-radius:12px;padding:1rem;margin-bottom:1.25rem;box-shadow:0 4px 12px #ff6b6b33}.exists-label{font-weight:600;color:#ff6b6b;margin-bottom:.75rem;font-size:.95rem}.exists-content{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.exists-content code{background:#0000004d;padding:.5rem .75rem;border-radius:6px;font-family:Courier New,Consolas,Monaco,monospace;font-size:.9rem;color:gold}.exists-result{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;border:2px solid}.exists-result.found{background:#2ebd8c33;border-color:var(--accent-green)}.exists-result.not-found{background:#ff646433;border-color:#ff6464}.exists-result .arrow{font-size:1.2rem;color:var(--text-primary)}.exists-result .value{font-weight:700;font-size:.95rem;font-family:Courier New,Consolas,Monaco,monospace}.exists-result.found .value{color:var(--accent-green)}.exists-result.not-found .value{color:#ff6464}.exists-tables-container{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.table-section-exists{min-width:0}.exists-col{background:#ffc1071a;color:var(--warning-yellow);font-weight:600;font-size:.85rem;white-space:nowrap}.exists-badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-weight:700;font-size:.85rem}.exists-badge.yes{background:#2ebd8c33;color:var(--accent-green);border:1px solid var(--accent-green)}.exists-badge.no{background:#ff646433;color:#ff6464;border:1px solid #ff6464}.exists-animation .data-table tbody tr.selected{border-left:3px solid var(--warning-yellow)}@media (max-width: 1024px){.exists-tables-container{grid-template-columns:1fr;gap:1.5rem}}@media (max-width: 768px){.exists-content{flex-direction:column;align-items:flex-start}.exists-result{width:100%;justify-content:center}.exists-col{font-size:.75rem}.exists-badge{font-size:.75rem;padding:.2rem .4rem}}.case-box{background:linear-gradient(135deg,#8a2be226,#8a2be20d);border:2px solid rgba(138,43,226,.4);border-radius:12px;padding:1rem;margin-bottom:1.25rem;box-shadow:0 4px 12px #8a2be233}.case-label{font-weight:600;color:#a78bfa;margin-bottom:.75rem;font-size:.95rem}.case-conditions{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.case-condition{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:#0003;border-radius:6px;border:1px solid rgba(138,43,226,.3);transition:all .3s ease}.case-condition.active{background:#8a2be24d;border-color:#8a2be299;box-shadow:0 0 12px #8a2be266}.condition-text{font-family:Courier New,Consolas,Monaco,monospace;font-size:.9rem;color:var(--text-primary)}.condition-result{font-size:1.2rem;color:var(--accent-green);font-weight:700;min-width:24px;text-align:center}.case-result{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#8a2be233;border-radius:8px;border:1px solid rgba(138,43,226,.4)}.case-result .arrow{font-size:1rem;color:#a78bfa;font-weight:600}.case-result .value{font-weight:700;font-size:1rem;color:var(--accent-green);font-family:Courier New,Consolas,Monaco,monospace}.category-col{background:#8a2be21a;font-weight:600;font-size:.85rem}.category-badge{display:inline-block;padding:.3rem .6rem;border-radius:4px;font-weight:700;font-size:.8rem;white-space:nowrap}.category-badge.lightning-fast{background:#2ebd8c33;color:var(--accent-green);border:1px solid var(--accent-green)}.category-badge.quick{background:#58a6ff33;color:var(--accent-blue);border:1px solid var(--accent-blue)}.category-badge.normal{background:#ffc10733;color:var(--warning-yellow);border:1px solid var(--warning-yellow)}.category-badge.slow{background:#ff646433;color:#ff6464;border:1px solid #ff6464}.hours-cell{font-weight:600;font-family:Courier New,Consolas,Monaco,monospace}.case-animation .data-table tbody tr.selected{border-left:3px solid #a78bfa}@media (max-width: 768px){.case-conditions{gap:.4rem}.case-condition{padding:.4rem .6rem}.condition-text{font-size:.8rem}.case-result{flex-direction:column;align-items:flex-start;gap:.5rem}.category-badge{font-size:.75rem;padding:.25rem .5rem}}.union-animation .animation-header{padding:0 0 16px;border-bottom:1px solid var(--border-color);margin-bottom:24px}.union-animation .animation-header h3{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.union-animation .animation-scrollable-content{padding:0}.union-animation .animation-footer{margin-top:24px;padding:24px 0 0;border-top:1px solid var(--border-color);background:transparent}.union-visualization{min-height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center;margin:1rem 0;position:relative}.source-tables-container{display:grid;grid-template-columns:1fr auto 1fr;gap:1rem;width:100%;align-items:start}.source-table-wrapper{width:100%;min-width:0}.online-label{background:#2196f333;color:#2196f3;border:1px solid rgba(33,150,243,.3)}.retail-label{background:#9c27b033;color:#9c27b0;border:1px solid rgba(156,39,176,.3)}.result-label{background:#4caf5033;color:#4caf50;border:1px solid rgba(76,175,80,.3)}.duplicate-row{background:#f4433633!important;border-left:3px solid #F44336}.union-connector{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.5rem;min-width:60px}.union-arrow{font-size:1.5rem;color:var(--primary-color, #2196F3);font-weight:700;transform:rotate(90deg)}.union-text{font-size:.7rem;font-weight:700;color:var(--primary-color, #2196F3);background:#2196f326;padding:.25rem .5rem;border-radius:4px;border:1px solid rgba(33,150,243,.3);margin:.3rem 0;letter-spacing:.5px;writing-mode:horizontal-tb;white-space:nowrap}.result-table-wrapper{width:100%;max-width:600px;margin:0 auto;display:flex;flex-direction:column;align-items:center}.result-table-wrapper.standalone{margin-top:0}.result-table-wrapper.with-sources{margin-top:0;padding-top:0}.result-table-wrapper.with-sources:before{content:"↓";display:block;text-align:center;font-size:2rem;color:var(--primary-color, #2196F3);margin:.5rem 0;font-weight:700}.result-table-wrapper .table-container{width:100%;max-width:450px}@media (max-width: 900px){.source-tables-container{grid-template-columns:1fr;gap:1rem}.union-connector{padding:.5rem 0;min-width:auto}.union-arrow{transform:rotate(0);font-size:1.5rem}.union-text{font-size:.7rem;padding:.25rem .5rem}.result-table-wrapper,.result-table-wrapper .table-container{max-width:100%}.result-table-wrapper.with-sources:before{font-size:1.5rem;margin:.3rem 0}}.groupby-animation .animation-header{padding:0 0 16px;border-bottom:1px solid var(--border-color);margin-bottom:24px}.groupby-animation .animation-header h3{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.groupby-animation .animation-scrollable-content{padding:0}.groupby-animation .animation-footer{margin-top:24px;padding:24px 0 0;border-top:1px solid var(--border-color);background:transparent}.groupby-animation .data-table tbody tr,.groupby-animation table tbody tr{opacity:1}.groupby-animation .query-display{background:#0000004d;border:1px solid rgba(88,166,255,.3);border-radius:12px;padding:.75rem;margin-bottom:1rem;box-shadow:0 4px 12px #0003}.groupby-animation .query-label{font-weight:600;color:var(--accent-blue);margin-bottom:.5rem;font-size:.85rem}.groupby-animation .query-code{display:block;margin:0;background:#0006;padding:.5rem .75rem;border-radius:8px;border-left:4px solid var(--accent-blue);overflow-x:auto}.groupby-animation .query-code code{color:gold;font-family:Courier New,Consolas,Monaco,monospace;font-size:.85rem;line-height:1.6}.groupby-animation .animation-content{display:flex;flex-direction:column;gap:1.5rem;align-items:center;position:relative}.groupby-animation .table-container{background:#ffffff14;border:1px solid var(--border-color);border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000001a;padding:0}.groupby-animation .sales-table{padding:0}.groupby-animation .table-title{font-weight:600;font-size:.85rem;margin-bottom:.5rem;color:var(--text-primary);text-align:left;font-family:Courier New,monospace;padding:.75rem .75rem 0}.groupby-animation table{border-collapse:collapse;width:100%}.groupby-animation th{background:#58a6ff40;padding:.5rem .75rem;text-align:left;font-weight:600;border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:.85rem;transition:all .3s ease}.groupby-animation td{padding:.5rem .75rem;border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:.85rem;transition:all .3s ease}.groupby-animation tbody tr:last-child td{border-bottom:none}.groupby-animation tbody tr:hover{background:#ffffff0d}.groupby-animation .category-badge{padding:.25rem .5rem;border-radius:4px;font-weight:600;font-size:.85rem}.groupby-animation .category-badge.electronics{background:#58a6ff33;color:var(--accent-blue)}.groupby-animation .category-badge.furniture{background:#ff980033;color:var(--warning-orange)}.groupby-animation .grouped-buckets{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap;width:100%}.groupby-animation .bucket{background:#ffffff0d;border-radius:12px;padding:1.5rem;min-width:200px;box-shadow:0 8px 20px #00000026;border:3px solid}.groupby-animation .bucket.electronics{border-color:var(--accent-blue);background:#58a6ff1a}.groupby-animation .bucket.furniture{border-color:var(--warning-orange);background:#ff98001a}.groupby-animation .bucket-header{color:var(--text-primary);font-size:1.2rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--border-color);text-align:center}.groupby-animation .bucket-items{margin-bottom:1rem;min-height:80px}.groupby-animation .bucket-item{background:#ffffff14;padding:.5rem;margin-bottom:.5rem;border-radius:6px;font-size:.85rem;color:var(--text-secondary);text-align:center}.groupby-animation .bucket-sum{border-top:2px solid var(--border-color);padding-top:1rem;text-align:center}.groupby-animation .sum-label{font-size:.8rem;color:var(--text-secondary);font-weight:600;margin-bottom:.25rem}.groupby-animation .sum-value{font-size:1.5rem;font-weight:700;color:var(--accent-green)}.groupby-animation .result-container{background:#2ebd8c1a;border:2px solid var(--accent-green);border-radius:12px;overflow:hidden;box-shadow:0 6px 20px #58ffa633;padding:1.5rem;animation:pulse-glow 2s ease-in-out infinite}.groupby-animation .result-title{color:var(--accent-green);font-size:1.1rem;font-weight:700;text-align:center;margin-bottom:1rem}.groupby-animation .arrow-down{text-align:center;font-size:2.5rem;margin-bottom:1rem;line-height:1}.groupby-animation .result-container table{min-width:300px;background:#ffffff0d;border-radius:8px;overflow:hidden}.groupby-animation .result-container thead{background:#58ffa640}.groupby-animation .result-container td,.groupby-animation .result-container th{font-size:.85rem;color:var(--text-primary)}.groupby-animation .result-container td strong{color:var(--accent-green);font-weight:700}.groupby-animation .step-explanation{background:#58a6ff1a;padding:1rem 1.5rem;border-radius:8px;text-align:center;font-weight:500;font-size:1rem;margin-top:1rem;border:1px solid rgba(88,166,255,.3);color:var(--text-primary)}.groupby-animation .insight-box{background:linear-gradient(135deg,#58a6ff33,#58a6ff1a);border-left:4px solid var(--accent-blue);border-radius:12px;padding:1rem;margin-top:1.25rem;box-shadow:0 4px 12px #0000001a;line-height:1.6}.groupby-animation .insight-box strong{display:block;margin-bottom:.5rem;font-size:1rem;color:var(--accent-blue)}.groupby-animation .insight-box div{color:var(--text-secondary);margin-top:.5rem}.groupby-animation .insight-box code{background:#0000004d;padding:.2rem .5rem;border-radius:4px;font-family:Courier New,monospace;color:gold;font-size:.95rem}@media (max-width: 768px){.groupby-animation .query-display{padding:1rem}.groupby-animation .query-code{font-size:.9rem;padding:.75rem}.groupby-animation .grouped-buckets{flex-direction:column;gap:1.5rem}.groupby-animation .bucket{width:100%}.groupby-animation .table-container{overflow-x:auto}.groupby-animation th,.groupby-animation td{padding:.75rem 1rem;font-size:.9rem}}.data-table th.selected{background:#58a6ff33;color:var(--accent-blue);font-weight:700}.data-table td.selected{background:#58a6ff1a;font-weight:500;color:var(--text-primary)}.selection-indicator{display:inline-block;margin-left:.5rem;color:var(--accent-green);font-weight:700;font-size:1.1rem}.where-animation .filter-display{background:#ffc1071a;border:1px solid rgba(255,193,7,.3);border-radius:12px;padding:.75rem;margin-bottom:.75rem;box-shadow:0 4px 12px #0003}.where-animation .filter-label{font-weight:600;color:var(--warning-yellow);margin-bottom:.5rem;font-size:.8rem}.where-animation .filter-condition{display:flex;align-items:center;justify-content:center;gap:.5rem;font-family:Courier New,Consolas,Monaco,monospace;font-size:.9rem;font-weight:600}.where-animation .filter-column{color:var(--accent-blue);background:#58a6ff33;padding:.25rem .5rem;border-radius:4px}.where-animation .filter-operator{color:var(--text-primary)}.where-animation .filter-value{color:var(--accent-green);background:#2ebd8c33;padding:.25rem .5rem;border-radius:4px}.where-animation .data-table th.filter-highlighted{background:#ffc1074d;color:var(--warning-yellow);font-weight:700;animation:pulse-filter 1.5s ease-in-out infinite}@keyframes pulse-filter{0%,to{box-shadow:0 0 #ffc10766}50%{box-shadow:0 0 15px #ffc10766}}.where-animation .filter-indicator{display:inline-block;margin-left:.5rem;color:var(--warning-yellow);font-weight:700;font-size:1.1rem;animation:bounce-filter 2s ease-in-out infinite}@keyframes bounce-filter{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.where-animation .data-table td.selected{background:#2ebd8c26;font-weight:500;color:var(--text-primary)}.where-animation .data-table tbody tr{opacity:1;transition:all .5s ease}.where-animation .data-table tbody tr.selected{background:#2ebd8c1a;border-left:3px solid var(--accent-green)}.where-animation .data-table tbody tr:not(.selected){opacity:.3}.where-animation .result-section{animation:pulse-glow 2s ease-in-out infinite}@media (max-width: 768px){.where-animation .filter-condition{flex-direction:column;gap:.25rem;font-size:.8rem}}.and-or-animation .animation-header{padding:0 0 16px;border-bottom:1px solid var(--border-color);margin-bottom:24px}.and-or-animation .animation-header h3{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.and-or-animation .animation-scrollable-content{padding:0}.and-or-animation .animation-footer{margin-top:24px;padding:24px 0 0;border-top:1px solid var(--border-color);background:transparent}.and-or-animation .step-title{margin-bottom:1rem;text-align:center}.and-or-animation .step-title h4{margin:0 0 .4rem;font-size:1.2rem;font-weight:700;color:var(--accent-blue)}.and-or-animation .step-title p{margin:0;font-size:.9rem;color:var(--text-primary);opacity:.9;line-height:1.4}.and-or-animation .query-display{background:#0000004d;border:1px solid rgba(88,166,255,.3);border-radius:8px;padding:.75rem;margin-bottom:1rem;box-shadow:0 4px 12px #0003}.and-or-animation .query-label{font-weight:600;color:var(--accent-blue);margin-bottom:.4rem;font-size:.8rem}.and-or-animation .query-code{display:block;background:#0006;padding:.6rem .8rem;border-radius:6px;font-family:Courier New,Consolas,Monaco,monospace;font-size:.85rem;color:gold;border-left:3px solid var(--accent-blue);overflow-x:auto}.and-or-animation .logic-display{background:linear-gradient(135deg,#58a6ff26,#ffc10726);border:2px solid rgba(88,166,255,.3);border-radius:8px;padding:.75rem;margin-bottom:1rem;box-shadow:0 4px 12px #0003}.and-or-animation .logic-label{font-weight:600;color:var(--accent-blue);margin-bottom:.5rem;font-size:.8rem;text-align:center}.and-or-animation .logic-expression{display:flex;align-items:center;justify-content:center;gap:.75rem;font-family:Courier New,Consolas,Monaco,monospace;font-size:.95rem;font-weight:600;flex-wrap:wrap}.and-or-animation .logic-and{color:var(--accent-blue)}.and-or-animation .logic-or{color:var(--warning-yellow);font-size:1.1rem;font-weight:700}.and-or-animation .logic-group{background:#58a6ff33;padding:.4rem .75rem;border-radius:6px;border:1px solid rgba(88,166,255,.4)}.and-or-animation .logic-operator{color:var(--accent-blue);font-weight:800;margin:0 .25rem}.and-or-animation .table-section{margin-bottom:1rem}.and-or-animation .table-label{font-weight:600;color:var(--text-primary);margin-bottom:.4rem;font-size:.85rem}.and-or-animation .result-label{color:var(--accent-green);font-size:.95rem}.and-or-animation .table-container{background:#ffffff0d;border:1px solid var(--border-color);border-radius:8px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.and-or-animation .result-container{border:2px solid var(--accent-green);box-shadow:0 6px 20px #58ffa633}.and-or-animation .data-table{width:100%;border-collapse:collapse}.and-or-animation .data-table thead{background:#58a6ff26}.and-or-animation .result-table thead{background:#58ffa626}.and-or-animation .data-table th,.and-or-animation .data-table td{padding:.4rem .6rem;text-align:left;border-bottom:1px solid var(--border-color);font-size:.8rem;transition:all .3s ease;color:var(--text-primary);font-weight:500}.and-or-animation .data-table th{font-weight:600;color:var(--text-primary);position:relative}.and-or-animation .data-table th.logic-highlighted{animation:pulse-logic 1.5s ease-in-out infinite}@keyframes pulse-logic{0%,to{box-shadow:0 0 #58a6ff66}50%{box-shadow:0 0 15px #58a6ff66}}.and-or-animation .logic-indicator{display:inline-block;margin-left:.5rem;font-weight:700;font-size:.9rem;position:absolute;right:.5rem;top:50%;transform:translateY(-50%)}.and-or-animation .and-indicator{color:var(--accent-blue);animation:pulse-and 2s ease-in-out infinite}.and-or-animation .or-indicator{color:var(--warning-yellow);animation:pulse-or 2s ease-in-out infinite}@keyframes pulse-and{0%,to{opacity:.7;transform:translateY(-50%) scale(1)}50%{opacity:1;transform:translateY(-50%) scale(1.2)}}@keyframes pulse-or{0%,to{opacity:.7;transform:translateY(-50%) scale(1)}50%{opacity:1;transform:translateY(-50%) scale(1.3)}}.and-or-animation .data-table td.selected{background:#2ebd8c26;font-weight:500;color:var(--text-primary)}.and-or-animation .and-or-animation .data-table tbody tr.selected{background:#2ebd8c1a;border-left:3px solid var(--accent-green)}.and-or-animation .data-table tbody tr:not(.selected){opacity:.3}.and-or-animation .and-or-animation .and-or-animation .arrow-container{display:flex;flex-direction:column;align-items:center;margin:.75rem 0}.and-or-animation .arrow-down{font-size:2rem;line-height:1}.and-or-animation .arrow-label{margin-top:.4rem;font-size:.85rem;font-weight:600;color:var(--accent-green);text-transform:uppercase;letter-spacing:1.5px}.and-or-animation .result-section{animation:pulse-glow 2s ease-in-out infinite}.and-or-animation .insight-box{background:linear-gradient(135deg,#58a6ff33,#ffc10733);border-left:3px solid var(--accent-blue);border-radius:8px;padding:.75rem;margin-top:1rem;box-shadow:0 4px 12px #0000001a}.and-or-animation .insight-box strong{display:block;margin-bottom:.4rem;font-size:.85rem;color:var(--accent-blue)}.and-or-animation .insight-box p{margin:0;line-height:1.5;color:var(--text-primary);opacity:.95;font-size:.85rem}.and-or-animation .insight-box code{background:#0000004d;padding:.15rem .4rem;border-radius:3px;font-family:Courier New,monospace;color:gold;font-size:.8rem}@media (max-width: 768px){.and-or-animation .step-title h4{font-size:1.1rem}.and-or-animation .step-title p{font-size:.85rem}.and-or-animation .query-display{padding:.6rem}.and-or-animation .query-code{font-size:.8rem;padding:.5rem}.and-or-animation .logic-expression{flex-direction:column;gap:.5rem;font-size:.85rem}.and-or-animation .logic-group{padding:.35rem .6rem}.and-or-animation .data-table th,.and-or-animation .data-table td{padding:.35rem .5rem;font-size:.75rem}}.join-animation .animation-header{padding:0 0 16px;border-bottom:1px solid var(--border-color);margin-bottom:24px}.join-animation .animation-header h3{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.join-animation .animation-scrollable-content{padding:0}.join-animation .animation-footer{margin-top:24px;padding:24px 0 0;border-top:1px solid var(--border-color);background:transparent}.join-condition-display{background:#ffc1071a;border:1px solid rgba(255,193,7,.3);border-radius:8px;padding:.75rem;margin-bottom:1rem;box-shadow:0 4px 12px #0003}.join-label{font-weight:600;color:var(--warning-yellow);margin-bottom:.4rem;font-size:.8rem}.join-condition-text{display:flex;align-items:center;justify-content:center;gap:.5rem;font-family:Courier New,Consolas,Monaco,monospace;font-size:.95rem;font-weight:600}.join-left{color:var(--accent-blue);background:#58a6ff33;padding:.25rem .5rem;border-radius:4px}.join-operator{color:var(--text-primary)}.join-right{color:var(--accent-green);background:#2ebd8c33;padding:.25rem .5rem;border-radius:4px}.tables-wrapper{margin-bottom:1rem}.join-tables-container{display:grid;grid-template-columns:1fr auto 1fr;gap:.75rem;align-items:start}.join-table-section{min-width:0}.data-table th.join-key{background:#ffc10733;color:var(--warning-yellow);font-weight:700}.key-indicator{display:inline-block;margin-left:.5rem;font-size:1.1rem}.data-table td.selected{background:#ffc10726;font-weight:500;color:var(--text-primary)}.data-table tbody tr.selected{background:#ffc1071a;border-left:3px solid var(--warning-yellow)}.join-symbol{display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--text-primary)}.null-value{color:var(--text-secondary, #aaa);font-style:italic;opacity:.8;font-weight:500}.null-row{background:#8080800d}.null-row:hover{background:#8080801a}@media (max-width: 768px){.inline-animation-content .animation-container{padding:16px}.join-condition-text{flex-direction:column;gap:.25rem;font-size:1rem}.join-tables-container{grid-template-columns:1fr;gap:1.5rem}.join-symbol{transform:rotate(90deg);font-size:1.5rem}}.like-animation .animation-header{padding:0 0 16px;border-bottom:1px solid var(--border-color);margin-bottom:24px}.like-animation .animation-header h3{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.like-animation .animation-scrollable-content{padding:0}.like-animation .animation-footer{margin-top:24px;padding:24px 0 0;border-top:1px solid var(--border-color);background:transparent}.like-animation .step-title{margin-bottom:1rem;text-align:center}.like-animation .step-title h4{margin:0 0 .4rem;font-size:1.2rem;font-weight:700;color:var(--accent-blue)}.like-animation .step-title p{margin:0;font-size:.9rem;color:var(--text-primary);opacity:.9;line-height:1.4}.like-animation .query-display{background:#0000004d;border:1px solid rgba(88,166,255,.3);border-radius:8px;padding:.75rem;margin-bottom:1rem;box-shadow:0 4px 12px #0003}.like-animation .query-label{font-weight:600;color:var(--accent-blue);margin-bottom:.4rem;font-size:.8rem}.like-animation .query-code{display:block;background:#0006;padding:.6rem .8rem;border-radius:6px;font-family:Courier New,Consolas,Monaco,monospace;font-size:.85rem;color:gold;border-left:3px solid var(--accent-blue);overflow-x:auto}.like-animation .pattern-display{background:linear-gradient(135deg,#ffc10726,#ffc1070d);border:2px solid rgba(255,193,7,.3);border-radius:8px;padding:.75rem;margin-bottom:1rem;box-shadow:0 4px 12px #0003}.like-animation .pattern-label{font-weight:600;color:var(--warning-yellow);margin-bottom:.5rem;font-size:.8rem;text-align:center}.like-animation .pattern-breakdown{display:flex;align-items:center;justify-content:center;gap:.25rem;font-family:Courier New,Consolas,Monaco,monospace;font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.pattern-breakdown .wildcard{color:var(--warning-yellow);animation:pulse-wildcard 2s ease-in-out infinite}.pattern-breakdown .pattern-text{color:var(--accent-green);background:#2ebd8c33;padding:.25rem .75rem;border-radius:6px;font-weight:700}@keyframes pulse-wildcard{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.15)}}.like-animation .pattern-explanation{display:flex;align-items:center;justify-content:center;gap:.4rem;font-size:.75rem;color:var(--text-secondary);flex-wrap:wrap}.like-animation .wildcard-info{color:var(--warning-yellow);font-weight:600}.like-animation .text-info{color:var(--accent-green);font-weight:700;font-family:Courier New,monospace;background:#2ebd8c1a;padding:.1rem .3rem;border-radius:3px}.like-animation .separator{color:var(--text-secondary);font-weight:700}.like-animation .pattern-match{background:#ffc10766;color:var(--warning-yellow);font-weight:700;padding:.1rem .25rem;border-radius:3px;animation:highlight-match 1.5s ease-in-out infinite}@keyframes highlight-match{0%,to{background:#ffc1074d}50%{background:#ffc10780}}.like-animation .table-section{margin-bottom:1rem}.like-animation .table-label{font-weight:600;color:var(--text-primary);margin-bottom:.4rem;font-size:.85rem}.like-animation .result-label{color:var(--accent-green);font-size:.95rem}.like-animation .table-container{background:#ffffff0d;border:1px solid var(--border-color);border-radius:8px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.like-animation .result-container{border:2px solid var(--accent-green);box-shadow:0 6px 20px #58ffa633}.like-animation .data-table{width:100%;border-collapse:collapse}.like-animation .data-table thead{background:#58a6ff26}.like-animation .result-table thead{background:#58ffa626}.like-animation .data-table th,.like-animation .data-table td{padding:.4rem .6rem;text-align:left;border-bottom:1px solid var(--border-color);font-size:.8rem;transition:all .3s ease;color:var(--text-primary);font-weight:500}.like-animation .data-table th{font-weight:600;color:var(--text-primary);position:relative}.like-animation .data-table th.pattern-highlighted{background:#ffc1074d;color:var(--warning-yellow);font-weight:700;animation:pulse-pattern 1.5s ease-in-out infinite}@keyframes pulse-pattern{0%,to{box-shadow:0 0 #ffc10766}50%{box-shadow:0 0 15px #ffc10766}}.like-animation .pattern-indicator{display:inline-block;margin-left:.5rem;font-weight:700;font-size:.9rem}.like-animation .data-table td.selected{background:#2ebd8c26;font-weight:500;color:var(--text-primary)}.like-animation .like-animation .data-table tbody tr.selected{background:#2ebd8c1a;border-left:3px solid var(--accent-green)}.like-animation .data-table tbody tr:not(.selected){opacity:.3}.like-animation .like-animation .like-animation .arrow-container{display:flex;flex-direction:column;align-items:center;margin:.75rem 0}.like-animation .arrow-down{font-size:2rem;line-height:1}.like-animation .arrow-label{margin-top:.4rem;font-size:.85rem;font-weight:600;color:var(--accent-green);text-transform:uppercase;letter-spacing:1.5px}.like-animation .result-section{animation:pulse-glow 2s ease-in-out infinite}.like-animation .insight-box{background:linear-gradient(135deg,#ffc10733,#ffc1071a);border-left:3px solid var(--warning-yellow);border-radius:8px;padding:.75rem;margin-top:1rem;box-shadow:0 4px 12px #0000001a}.like-animation .insight-box strong{display:block;margin-bottom:.4rem;font-size:.85rem;color:var(--warning-yellow)}.like-animation .insight-box p{margin:0;line-height:1.5;color:var(--text-primary);opacity:.95;font-size:.85rem}.like-animation .insight-box code{background:#0000004d;padding:.15rem .4rem;border-radius:3px;font-family:Courier New,monospace;color:gold;font-size:.8rem}@media (max-width: 768px){.like-animation .step-title h4{font-size:1.1rem}.like-animation .step-title p{font-size:.85rem}.like-animation .query-display{padding:.6rem}.like-animation .query-code{font-size:.8rem;padding:.5rem}.like-animation .pattern-breakdown{font-size:1.2rem}.like-animation .pattern-explanation{flex-direction:column;gap:.25rem;font-size:.7rem}.like-animation .data-table th,.like-animation .data-table td{padding:.35rem .5rem;font-size:.75rem}}.in-animation .animation-header{padding:0 0 16px;border-bottom:1px solid var(--border-color);margin-bottom:24px}.in-animation .animation-header h3{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.in-animation .animation-scrollable-content{padding:0}.in-animation .animation-footer{margin-top:24px;padding:24px 0 0;border-top:1px solid var(--border-color);background:transparent}.in-list-display{background:linear-gradient(135deg,#ffc10726,#ffc1070d);border:2px solid rgba(255,193,7,.3);border-radius:12px;padding:1rem;margin-bottom:1.25rem;box-shadow:0 4px 12px #0003}.in-label{font-weight:600;color:var(--warning-yellow);margin-bottom:.75rem;font-size:.95rem;text-align:center}.in-values{display:flex;justify-content:center;gap:.75rem;margin-bottom:.5rem;flex-wrap:wrap}.in-value{background:#ffc10733;color:var(--warning-yellow);padding:.5rem 1rem;border-radius:8px;font-family:Courier New,Consolas,Monaco,monospace;font-weight:600;font-size:1.1rem;border:1px solid rgba(255,193,7,.4);animation:pulse-in-value 2s ease-in-out infinite}@keyframes pulse-in-value{0%,to{box-shadow:0 0 #ffc1074d;transform:scale(1)}50%{box-shadow:0 0 10px #ffc10766;transform:scale(1.05)}}.in-explanation{text-align:center}.in-info{color:var(--warning-yellow);font-weight:600;font-size:.85rem}.data-table th.in-highlighted{background:#ffc1074d;color:var(--warning-yellow);font-weight:700;animation:pulse-in 1.5s ease-in-out infinite}@keyframes pulse-in{0%,to{box-shadow:0 0 #ffc10766}50%{box-shadow:0 0 15px #ffc10766}}.in-indicator{display:inline-block;margin-left:.5rem;color:var(--warning-yellow);font-weight:700;font-size:1.1rem;animation:bounce-in 2s ease-in-out infinite}@keyframes bounce-in{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}@media (max-width: 768px){.in-values{gap:.5rem}.in-value{padding:.4rem .8rem;font-size:1rem}}.between-animation .animation-header{padding:0 0 16px;border-bottom:1px solid var(--border-color);margin-bottom:24px}.between-animation .animation-header h3{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.between-animation .animation-scrollable-content{padding:0}.between-animation .animation-footer{margin-top:24px;padding:24px 0 0;border-top:1px solid var(--border-color);background:transparent}.range-display{background:#0000004d;border:2px solid rgba(88,166,255,.4);border-radius:12px;padding:1.5rem;margin-bottom:1.25rem;box-shadow:0 4px 12px #0003}.range-label{font-weight:700;color:var(--accent-blue);margin-bottom:1.25rem;font-size:1.1rem;text-align:center}.range-visualization{display:flex;justify-content:center;align-items:center;margin-bottom:1rem;padding:.5rem 0}.age-spectrum{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;justify-content:center}.age-marker{padding:.5rem .75rem;border-radius:6px;font-size:.95rem;font-weight:600;transition:all .3s ease}.age-marker.in-range{background:var(--accent-green);color:#fff;box-shadow:0 2px 8px #2ebd8c66;animation:pulse-in-range 2s ease-in-out infinite}.age-marker.out-range{background:#ffffff0d;color:#ffffff4d;border:1px solid rgba(255,255,255,.1)}@keyframes pulse-in-range{0%,to{transform:scale(1);box-shadow:0 2px 8px #2ebd8c66}50%{transform:scale(1.05);box-shadow:0 4px 12px #2ebd8c99}}.range-explanation{text-align:center;margin-top:.75rem}.range-info{color:var(--text-secondary);font-weight:500;font-size:.9rem;background:#0003;padding:.5rem 1rem;border-radius:6px;display:inline-block}.data-table th.between-highlighted{background:#ffc1074d;color:var(--warning-yellow);font-weight:700;animation:pulse-between 1.5s ease-in-out infinite}@keyframes pulse-between{0%,to{box-shadow:0 0 #ffc10766}50%{box-shadow:0 0 15px #ffc10766}}.between-indicator{display:inline-block;margin-left:.5rem;color:var(--warning-yellow);font-weight:700;font-size:1.1rem;animation:bounce-between 2s ease-in-out infinite}@keyframes bounce-between{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}@media (max-width: 768px){.age-spectrum{gap:.4rem}.age-marker{padding:.4rem .6rem;font-size:.85rem}}.null-animation .animation-header{padding:0 0 16px;border-bottom:1px solid var(--border-color);margin-bottom:24px}.null-animation .animation-header h3{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.null-animation .animation-scrollable-content{padding:0}.null-animation .animation-footer{margin-top:24px;padding:24px 0 0;border-top:1px solid var(--border-color);background:transparent}.info-box{background:#0000004d;border:1px solid rgba(88,166,255,.3);border-radius:8px;padding:1rem;margin-bottom:1.25rem;box-shadow:0 4px 12px #0003}.info-content{text-align:center;line-height:1.6;color:var(--text-secondary);font-size:1rem}.info-content strong{color:var(--accent-blue)}.info-content code{background:#0000004d;padding:.2rem .4rem;border-radius:4px;font-family:Courier New,monospace;color:gold;font-weight:500}.data-table th.null-highlighted{background:#ffc1074d;color:var(--warning-yellow);font-weight:700;animation:pulse-null 1.5s ease-in-out infinite}@keyframes pulse-null{0%,to{box-shadow:0 0 #ffc10766}50%{box-shadow:0 0 15px #ffc10766}}.null-indicator{display:inline-block;margin-left:.5rem;color:var(--warning-yellow);font-weight:700;font-size:1.1rem;animation:bounce-null 2s ease-in-out infinite}@keyframes bounce-null{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.data-table td.selected{background:#2ebd8c26;font-weight:500;color:var(--text-primary)}.data-table tbody tr.selected{background:#2ebd8c1a;border-left:3px solid var(--accent-green)}.data-table tbody tr:not(.selected){opacity:.3}.null-value{color:var(--warning-yellow);font-weight:700;font-style:italic;background:#ffc1071a;padding:.2rem .5rem;border-radius:4px;border:1px solid rgba(255,193,7,.3);animation:null-glow 2s ease-in-out infinite}.zero-value{color:var(--accent-blue);font-weight:600;background:#58a6ff1a;padding:.2rem .4rem;border-radius:3px;border:1px solid rgba(88,166,255,.2)}.empty-value{color:var(--accent-green);font-weight:600;background:#2ebd8c1a;padding:.2rem .4rem;border-radius:3px;border:1px solid rgba(46,189,140,.2)}@keyframes null-glow{0%,to{box-shadow:0 0 2px #ffc1074d}50%{box-shadow:0 0 8px #ffc10780}}.normal-null{color:#ffc10799;font-weight:500;font-style:italic}.normal-value{color:var(--text-primary)}.result-section{animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 6px 20px #58ffa633}50%{box-shadow:0 8px 30px #58ffa666}}@media (max-width: 768px){.info-content{font-size:.9rem}.null-value{font-size:.8rem;padding:.15rem .4rem}}.distinct-animation .animation-header{padding:0 0 16px;border-bottom:1px solid var(--border-color);margin-bottom:24px}.distinct-animation .animation-header h3{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.distinct-animation .animation-scrollable-content{padding:0}.distinct-animation .animation-footer{margin-top:24px;padding:24px 0 0;border-top:1px solid var(--border-color);background:transparent}.duplicate-info{background:linear-gradient(135deg,#ffc10726,#ffc1070d);border:2px solid rgba(255,193,7,.3);border-radius:12px;padding:1rem;margin-bottom:1.25rem;box-shadow:0 4px 12px #0003}.duplicate-label{font-weight:600;color:var(--warning-yellow);margin-bottom:.75rem;font-size:.95rem;text-align:center}.category-counts{display:flex;flex-direction:column;gap:.75rem}.category-count-item{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.5rem;background:#0003;border-radius:8px;font-size:.95rem}.category-name{font-weight:600;color:var(--text-primary);min-width:100px}.count-badge{background:#ffc1074d;color:var(--warning-yellow);padding:.25rem .75rem;border-radius:6px;font-weight:700;font-size:.9rem;border:1px solid rgba(255,193,7,.4)}.arrow{color:var(--accent-green);font-weight:700;font-size:1.2rem}.unique-badge{background:#2ebd8c4d;color:var(--accent-green);padding:.25rem .75rem;border-radius:6px;font-weight:600;font-size:.9rem;border:1px solid rgba(46,189,140,.4)}.data-table th.distinct-highlighted{background:#ffc1074d;color:var(--warning-yellow);font-weight:700;animation:pulse-distinct 1.5s ease-in-out infinite}@keyframes pulse-distinct{0%,to{box-shadow:0 0 #ffc10766}50%{box-shadow:0 0 15px #ffc10766}}.distinct-indicator{display:inline-block;margin-left:.5rem;color:var(--warning-yellow);font-weight:700;font-size:1.1rem;animation:bounce-distinct 2s ease-in-out infinite}@keyframes bounce-distinct{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.distinct-animation .animation-scrollable-content .data-table tbody tr.duplicate-row{background:#7878820d!important;opacity:.6;border-left:initial}.distinct-animation .animation-scrollable-content .data-table tbody tr.duplicate-row td{color:#e0e0e0!important;border-left:none}.distinct-animation .animation-scrollable-content .data-table tbody tr td.duplicate-cell{background:#6e6e782e!important;border-left:none;font-weight:600;color:#f0f0f0!important;position:relative;font-style:italic}.distinct-animation .animation-scrollable-content .data-table tbody tr td.duplicate-cell:after{content:"⊘";position:absolute;right:4px;top:50%;transform:translateY(-50%);font-size:.9rem;opacity:.7;color:silver}.distinct-animation .animation-scrollable-content .data-table tbody tr:has(td.unique-cell){opacity:1}.distinct-animation .animation-scrollable-content .data-table tbody tr:has(td.unique-cell) td{opacity:1}.distinct-animation .animation-scrollable-content .data-table tbody tr td.unique-cell{background:#2ebd8c1f!important;border-left:3px solid var(--accent-green);font-weight:700;color:#fff!important;position:relative;animation:pulse-unique 2s ease-in-out infinite}.distinct-animation .animation-scrollable-content .data-table tbody tr td.unique-cell:after{content:"✓";position:absolute;right:4px;top:50%;transform:translateY(-50%);font-size:.9rem;color:#5ef5c8;font-weight:700}@keyframes pulse-unique{0%,to{box-shadow:0 0 #2ebd8c66}50%{box-shadow:0 0 10px #2ebd8c99}}@media (max-width: 768px){.category-counts{gap:.5rem}.category-count-item{flex-wrap:wrap;gap:.5rem;padding:.5rem}.category-name{min-width:80px;font-size:.85rem}.count-badge,.unique-badge{padding:.2rem .6rem;font-size:.8rem}}.orderby-animation .animation-header{padding:0 0 16px;border-bottom:1px solid var(--border-color);margin-bottom:24px}.orderby-animation .animation-header h3{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.orderby-animation .animation-scrollable-content{padding:0}.orderby-animation .animation-footer{margin-top:24px;padding:24px 0 0;border-top:1px solid var(--border-color);background:transparent}.sort-note{background:linear-gradient(135deg,#58a6ff26,#58a6ff0d);border:1px solid rgba(88,166,255,.3);border-radius:12px;padding:1rem;margin-bottom:1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 12px #0003}.data-table th.orderby-highlighted{background:#ffc1074d;color:var(--warning-yellow);font-weight:700;animation:pulse-orderby 1.5s ease-in-out infinite}@keyframes pulse-orderby{0%,to{box-shadow:0 0 #ffc10766}50%{box-shadow:0 0 15px #ffc10766}}.sort-indicator{display:inline-block;margin-left:.5rem;color:var(--warning-yellow);font-weight:700;font-size:1.1rem;animation:bounce-orderby 2s ease-in-out infinite}@keyframes bounce-orderby{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.orderby-animation .data-table tbody tr td.highlighted-cell{background:#ffc10726;font-weight:600;color:gold}@media (max-width: 768px){.sort-visualization{gap:.4rem}.sort-arrow,.sort-arrow-last{padding:.4rem .8rem;font-size:.9rem;min-width:150px}}.limit-animation .animation-header{padding:0 0 16px;border-bottom:1px solid var(--border-color);margin-bottom:24px}.limit-animation .animation-header h3{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.limit-animation .animation-scrollable-content{padding:0}.limit-animation .animation-footer{margin-top:24px;padding:24px 0 0;border-top:1px solid var(--border-color);background:transparent}.limit-note{background:linear-gradient(135deg,#58a6ff26,#58a6ff0d);border:1px solid rgba(88,166,255,.3);border-radius:12px;padding:1rem;margin-bottom:1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 12px #0003}.note-text strong{color:var(--accent-blue);font-weight:700}.limit-animation .animation-scrollable-content .data-table tbody tr:has(td.kept-cell){opacity:1}.limit-animation .animation-scrollable-content .data-table tbody tr:has(td.kept-cell) td{opacity:1}.limit-animation .animation-scrollable-content .data-table tbody tr td.kept-cell{background:#2ebd8c1f;border-left:3px solid var(--accent-green);font-weight:600;color:#fff;position:relative}.limit-animation .animation-scrollable-content .data-table tbody tr.removed-row{background:#7878820d;opacity:.3;border-left:initial}.limit-animation .animation-scrollable-content .data-table tbody tr.removed-row td{color:#e0e0e0;border-left:none;position:relative}.limit-animation .animation-scrollable-content .data-table tbody tr.removed-row td:after{content:"⊘";position:absolute;right:4px;top:50%;transform:translateY(-50%);font-size:.9rem;opacity:.5;color:#8c8c96cc}@media (max-width: 768px){.note-text{font-size:.85rem}}.offset-animation .animation-header{padding:0 0 16px;border-bottom:1px solid var(--border-color);margin-bottom:24px}.offset-animation .animation-header h3{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.offset-animation .animation-scrollable-content{padding:0}.offset-animation .animation-footer{margin-top:24px;padding:24px 0 0;border-top:1px solid var(--border-color);background:transparent}.offset-note{background:linear-gradient(135deg,#ff980026,#ff98000d);border:1px solid rgba(255,152,0,.3);border-radius:12px;padding:1rem;margin-bottom:1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 12px #0003}.note-icon{font-size:1.5rem;flex-shrink:0}.note-text{color:var(--text-secondary);font-size:.95rem;line-height:1.6}.note-text strong{color:#ffa726;font-weight:700}.row-number-header{width:60px;text-align:center;background:#58a6ff1a;font-weight:700;color:var(--accent-blue)}.row-number{width:60px;text-align:center;font-weight:600;color:var(--accent-blue);position:relative;background:#58a6ff0d}.skip-indicator{display:inline-block;margin-left:.5rem;color:#ff9800cc;font-weight:700;font-size:1.1rem}.kept-indicator{display:inline-block;margin-left:.5rem;color:var(--accent-green);font-weight:700;font-size:1.1rem}.offset-animation .animation-scrollable-content .data-table tbody tr.skipped-row{background:#ff980014;opacity:.3}.offset-animation .animation-scrollable-content .data-table tbody tr.skipped-row td{color:#e0e0e0;position:relative}.offset-animation .animation-scrollable-content .data-table tbody tr.skipped-row .row-number{background:#ff980026;color:#ff9800e6}.offset-animation .animation-scrollable-content .data-table tbody tr:has(td.kept-cell){opacity:1}.offset-animation .animation-scrollable-content .data-table tbody tr:has(td.kept-cell) td{opacity:1}.offset-animation .animation-scrollable-content .data-table tbody tr td.kept-cell{background:#2ebd8c1f;border-left:3px solid var(--accent-green);font-weight:600;color:#fff;position:relative}.offset-animation .animation-scrollable-content .data-table tbody tr.after-row{background:#7878820d;opacity:.3}.offset-animation .animation-scrollable-content .data-table tbody tr.after-row td{color:#e0e0e0;position:relative}.pagination-labels{display:flex;gap:1.5rem;justify-content:center;margin-top:1rem;padding:1rem;background:#58a6ff0d;border-radius:8px;border:1px solid rgba(88,166,255,.15)}.label-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-secondary)}.label-indicator{font-size:1.1rem;font-weight:700}.skipped-label .label-indicator{color:#ff9800e6}.kept-label .label-indicator{color:var(--accent-green)}.after-label .label-indicator{color:#8c8c96cc}@media (max-width: 768px){.note-text{font-size:.85rem}.pagination-labels{flex-direction:column;gap:.75rem;align-items:flex-start}.row-number-header,.row-number{width:40px;font-size:.85rem}}.coalesce-animation .animation-header{padding:0 0 16px;border-bottom:1px solid var(--border-color);margin-bottom:24px}.coalesce-animation .data-table tbody tr{opacity:1}.coalesce-animation .animation-header h3{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.coalesce-animation .animation-scrollable-content{padding:0}.coalesce-animation .animation-footer{margin-top:24px;padding:24px 0 0;border-top:1px solid var(--border-color);background:transparent}.highlight-col{background:#58a6ff26;color:var(--accent-blue);position:relative}.result-col{background:#2ebd8c26;color:var(--accent-green);position:relative;font-weight:700}.coalesce-badge{display:inline-block;margin-left:8px;padding:2px 8px;background:linear-gradient(135deg,var(--accent-blue),var(--accent-green));color:#fff;border-radius:4px;font-size:.7rem;font-weight:700;vertical-align:middle;box-shadow:0 2px 6px #2ebd8c4d}.null-cell{position:relative}.null-value{color:#ff6b6b;font-weight:600;font-style:italic;opacity:.8}.coalesced-cell{background:#2ebd8c26;font-weight:600;color:var(--accent-green)}.original-cell{background:#ffffff0d}.coalesce-result{display:inline-flex;align-items:center;gap:8px;padding:4px 8px;border-radius:6px;position:relative}.replaced-indicator{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--accent-green);color:#fff;border-radius:50%;font-size:.8rem;font-weight:700;box-shadow:0 2px 8px #2ebd8c66}.used-cell{background:#ffc10733;border:2px solid rgba(255,193,7,.4)}.fallback-indicator{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;font-size:.85rem;font-weight:700;box-shadow:0 2px 6px #0000004d}.fallback-1{background:linear-gradient(135deg,#4caf50,#66bb6a);color:#fff}.fallback-2{background:linear-gradient(135deg,#ffa726,#ffb74d);color:#fff}.fallback-3{background:linear-gradient(135deg,#ef5350,#e57373);color:#fff}.fallback-legend{margin-top:1.5rem;padding:1.5rem;background:#58a6ff1a;border:2px solid rgba(88,166,255,.3);border-radius:12px;box-shadow:0 4px 16px #0003}.legend-title{font-size:1.1rem;font-weight:700;color:var(--accent-blue);margin-bottom:1rem;text-align:center}.legend-items{display:flex;flex-direction:column;gap:.75rem}.legend-item{display:flex;align-items:center;gap:12px;padding:.75rem;background:#ffffff0d;border-radius:8px;transition:all .3s ease}.legend-item:hover{background:#ffffff14;transform:translate(4px)}.legend-badge{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:1rem;font-weight:700;box-shadow:0 3px 10px #0000004d}.legend-text{color:var(--text-secondary);font-size:.95rem;line-height:1.4}.legend-text strong{color:var(--text-primary);font-weight:700}@media (max-width: 768px){.coalesce-badge{font-size:.6rem;padding:2px 6px}.replaced-indicator{width:18px;height:18px;font-size:.7rem}.fallback-indicator{width:20px;height:20px;font-size:.75rem}.fallback-legend{padding:1rem}.legend-title{font-size:1rem}.legend-badge{width:28px;height:28px;font-size:.9rem}.legend-text{font-size:.85rem}}.open-animation-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,var(--accent-blue),var(--accent-green));color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #58a6ff4d;margin:1rem 0}.open-animation-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #58a6ff66}.toggle-animation-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,var(--accent-blue),var(--accent-green));color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #58a6ff4d}.toggle-animation-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #58a6ff66}.inline-animation-wrapper{margin:1rem 0}.inline-animation-content{overflow:hidden;margin-top:16px;border-radius:12px;background:var(--bg-secondary);border:1px solid var(--border-color)}.inline-animation-content .animation-container{padding:24px}.animation-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:9999;padding:2rem;overflow-y:auto}.animation-modal-content{max-width:900px;width:100%;max-height:90vh;height:90vh;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 20px 60px #00000080;display:flex;flex-direction:column}.animation-container{display:flex;flex-direction:column;height:100%;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;overflow:hidden}.animation-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,#58a6ff1a,#58a6ff0d);margin-bottom:16px}.animation-container .animation-header>h3{margin:0;font-size:20px;font-weight:700;color:var(--text-primary);padding:0}.close-btn{background:#ffffff1a;border:1px solid var(--border-color);color:var(--text-primary);font-size:1.5rem;width:40px;height:40px;border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;line-height:1}.close-btn:hover{background:#ff646433;border-color:#ff64644d;transform:scale(1.1)}.animation-scrollable-content{flex:1;overflow-y:auto;overflow-x:hidden;padding-bottom:2rem;min-height:0}.animation-scrollable-content::-webkit-scrollbar{width:8px}.animation-scrollable-content::-webkit-scrollbar-track{background:#ffffff1a;border-radius:4px}.animation-scrollable-content::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}.animation-scrollable-content::-webkit-scrollbar-thumb:hover{background:#ffffff80}.animation-footer{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-top:1px solid var(--border-color);background:#0003}.nav-btn{background:var(--accent-blue-gradient);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #58a6ff4d}.nav-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #58a6ff66}.nav-btn:active:not(:disabled){transform:translateY(0)}.nav-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.step-indicator{font-weight:500;color:var(--text-secondary);font-size:1rem}.step-title{margin-bottom:1.25rem;text-align:center}.step-title h4{margin:0 0 .5rem;font-size:1.5rem;font-weight:700;color:var(--accent-blue)}.step-title p{margin:0;font-size:1rem;color:var(--text-secondary);line-height:1.5}.query-display{background:#0000004d;border:1px solid rgba(88,166,255,.3);border-radius:12px;padding:.75rem;margin-bottom:1rem;box-shadow:0 4px 12px #0003}.query-label{font-weight:600;color:var(--accent-blue);margin-bottom:.5rem;font-size:.85rem}.query-code{display:block;background:#0006;padding:.5rem .75rem;border-radius:8px;font-family:Courier New,Consolas,Monaco,monospace;font-size:.85rem;color:gold;border-left:4px solid var(--accent-blue);overflow-x:auto}.table-section{margin-bottom:1rem}.table-label{font-weight:600;color:var(--text-primary);margin-bottom:.5rem;font-size:.85rem}.result-label{color:var(--accent-green);font-size:.95rem}.table-container{background:#ffffff14;border:1px solid var(--border-color);border-radius:12px;overflow-x:auto;overflow-y:hidden;box-shadow:0 4px 12px #0000001a}.result-container{border:2px solid var(--accent-green);box-shadow:0 6px 20px #58ffa633}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:#58a6ff40}.result-table thead{background:#58ffa626}.data-table th,.data-table td{padding:.35rem .5rem;text-align:left;border-bottom:1px solid var(--border-color);font-size:.75rem;transition:all .3s ease;white-space:nowrap}.data-table th{font-weight:600;color:var(--text-primary);position:relative}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:#ffffff0d}.arrow-container{display:flex;flex-direction:column;align-items:center;margin:1.25rem 0}.arrow-down{font-size:2.5rem;line-height:1}.arrow-label{margin-top:.5rem;font-size:1rem;font-weight:600;color:var(--accent-green);text-transform:uppercase;letter-spacing:2px}.insight-box{background:linear-gradient(135deg,#58a6ff33,#58a6ff1a);border-left:4px solid var(--accent-blue);border-radius:12px;padding:1rem;margin-top:1.25rem;box-shadow:0 4px 12px #0000001a}.insight-box strong{display:block;margin-bottom:.5rem;font-size:1rem;color:var(--accent-blue)}.insight-box p{margin:0;line-height:1.6;color:var(--text-secondary);font-size:.95rem}.insight-box code{background:#0000004d;padding:.2rem .5rem;border-radius:4px;font-family:Courier New,monospace;color:gold;font-size:.95rem}@media (max-width: 768px){.animation-modal-overlay,.animation-header{padding:1rem}.animation-header h3{font-size:1.2rem}.animation-scrollable-content{padding:1rem}.animation-footer{padding:1rem;flex-wrap:wrap;gap:.75rem}.nav-btn{padding:.6rem 1.2rem;font-size:.9rem}.step-indicator{width:100%;text-align:center;order:-1}.step-title h4{font-size:1.4rem}.step-title p{font-size:1rem}.query-display{padding:.6rem}.query-code{font-size:.75rem;padding:.5rem}.data-table th,.data-table td{padding:.3rem .4rem;font-size:.7rem}}.having-animation .animation-header{padding:0 0 16px;border-bottom:1px solid var(--border-color);margin-bottom:24px}.having-animation .animation-header h3{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.having-animation .animation-scrollable-content{padding:0}.having-animation .animation-footer{margin-top:24px;padding:24px 0 0;border-top:1px solid var(--border-color);background:transparent}.having-animation .data-table tbody tr{opacity:1}.having-animation .compact-table th,.having-animation .compact-table td{padding:.35rem .5rem;font-size:.75rem}.grouped-section{margin-top:1rem}.grouped-buckets{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.group-card{background:#ffffff0d;border:2px solid rgba(88,166,255,.3);border-radius:8px;padding:1rem;min-width:160px;max-width:200px;transition:all .5s ease;position:relative;overflow:hidden}.group-card.filtered-out{border-color:#ff646466;background:#ff646414}.group-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.group-header strong{font-size:.9rem;color:var(--text-primary);font-weight:700}.filter-badge{display:inline-flex;align-items:center;padding:2px 6px;border-radius:4px;font-size:.65rem;font-weight:700;text-transform:uppercase;box-shadow:0 2px 8px #0000004d}.filter-badge.pass{background:linear-gradient(135deg,#4caf50,#66bb6a);color:#fff}.filter-badge.fail{background:linear-gradient(135deg,#ef5350,#e57373);color:#fff}.group-items{margin-bottom:.5rem}.item-count{color:var(--text-secondary);font-size:.75rem;text-align:center;padding:.35rem;background:#ffffff0d;border-radius:4px}.group-aggregate{background:#58a6ff26;padding:.5rem;border-radius:6px;text-align:center;margin-bottom:.5rem}.agg-label{font-size:.65rem;color:var(--text-secondary);margin-bottom:.15rem;font-weight:600}.agg-value{font-size:1rem;font-weight:800;color:var(--accent-blue)}.having-check{background:#ffc10726;padding:.5rem;border-radius:6px;border:1px solid rgba(255,193,7,.3)}.check-label{font-size:.65rem;color:#ffc107;margin-bottom:.25rem;font-weight:600;text-transform:uppercase}.check-result{font-size:.85rem;font-weight:700;text-align:center}.check-result.pass{color:#4caf50}.check-result.fail{color:#ef5350}.filter-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#ff646426;display:flex;align-items:center;justify-content:center;border-radius:8px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.filter-text{font-size:.9rem;font-weight:800;color:#ef5350;text-transform:uppercase;text-shadow:0 2px 4px rgba(0,0,0,.5);letter-spacing:.5px}.result-box{margin-top:1rem;padding:1rem;background:#2ebd8c1a;border:2px solid var(--accent-green);border-radius:12px;box-shadow:0 8px 24px #0000004d}.result-label{font-size:1rem;font-weight:700;color:var(--accent-green);margin-bottom:.75rem;text-align:center}.result-table-container{display:flex;justify-content:center}.result-table{background:#ffffff0d;border-radius:8px;overflow:hidden;border:1px solid var(--border-color);min-width:280px}.result-table thead th{background:#2ebd8c40;color:var(--accent-green);padding:.5rem .75rem;font-weight:700;text-align:center;font-size:.8rem}.result-table tbody td{padding:.6rem .75rem;text-align:center;border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:.8rem}.result-table tbody tr:last-child td{border-bottom:none}.result-table tbody tr:hover{background:#ffffff0d}.result-table tbody td strong{color:var(--accent-green);font-weight:700}@media (max-width: 768px){.grouped-buckets{flex-direction:column;gap:.75rem}.group-card{min-width:100%;max-width:100%}.filter-text{font-size:.8rem}.group-header strong{font-size:.85rem}.agg-value{font-size:.9rem}.result-table{min-width:250px}.having-animation .compact-table th,.having-animation .compact-table td{padding:.3rem .4rem;font-size:.7rem}}.message-info,.message-success,.auth-success,.message-warning,.auth-warning,.message-error,.auth-error{padding:12px 16px;border-radius:8px;font-size:14px;line-height:1.5;margin:12px 0;border:1px solid;display:flex;align-items:flex-start;gap:8px}.message-error,.auth-error{background:#d665651a;border-color:var(--error-red);color:var(--error-red)}.message-warning,.auth-warning{background:#ff9f401a;border-color:#ff9f40;color:#ff9f40}.message-success,.auth-success{background:#2ebd8c1a;border-color:var(--success-green);color:var(--success-green)}.auth-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.auth-modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:32px;width:90%;max-width:440px;position:relative;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease-out}.auth-modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--text-secondary);font-size:32px;cursor:pointer;padding:4px 8px;line-height:1;transition:color .2s}.auth-modal-close:hover{color:var(--text-primary)}.auth-modal h2{margin:0 0 8px;color:var(--text-active);font-size:28px;font-weight:600}.auth-modal-context{margin:12px 0 8px;padding:12px 16px;background:#58a6ff1a;border:1px solid var(--accent-blue);border-radius:8px;color:var(--accent-blue);font-size:14px;font-weight:500;text-align:center}.auth-modal-subtitle{margin:0 0 24px;color:var(--text-secondary);font-size:15px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:var(--text-primary);font-size:14px;font-weight:500}.form-group input{width:100%;padding:12px 16px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:15px;transition:all .2s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:var(--accent-blue);background:var(--bg-primary)}.form-group input:disabled{opacity:.5;cursor:not-allowed}.form-hint{display:block;margin-top:6px;color:var(--text-secondary);font-size:13px}.auth-error,.auth-warning,.auth-success{margin-bottom:16px}.auth-verification-section{margin:12px 0 16px;display:flex;flex-direction:column;gap:8px;align-items:center}.auth-resend-message{font-size:13px;padding:8px 12px;border-radius:6px;background:#58a6ff1a;color:var(--accent-blue);text-align:center}.auth-toggle{margin-top:20px;text-align:center;color:var(--text-secondary);font-size:14px}.auth-toggle button{background:none;border:none;color:var(--accent-blue);font-size:14px;font-weight:600;cursor:pointer;text-decoration:underline;padding:0 4px;transition:color .2s}.auth-toggle button:hover:not(:disabled){color:var(--accent-blue-hover)}.auth-toggle button:disabled{opacity:.5;cursor:not-allowed}.auth-forgot-password{margin-top:12px;text-align:center}.auth-forgot-password a{background:none;border:none;color:var(--text-secondary);font-size:13px;cursor:pointer;text-decoration:none;padding:0;transition:color .2s}.auth-forgot-password a:hover{color:var(--accent-blue);text-decoration:underline}.auth-free-note{margin-top:20px;padding:12px;background:#c9a9611a;border:1px solid var(--gold);border-radius:8px;color:var(--gold);font-size:13px;text-align:center}.auth-confirmation{text-align:center;padding:1rem 0}.auth-confirmation-icon{font-size:4rem;margin-bottom:1rem;animation:slideDown .5s ease-out}.auth-confirmation h2{margin-bottom:1rem;color:var(--text-primary)}.auth-confirmation-message{font-size:1rem;color:var(--text-secondary);margin-bottom:1rem;line-height:1.6}.auth-confirmation-message strong{color:var(--accent-blue);font-weight:600}.auth-confirmation-note{font-size:.875rem;color:var(--text-muted);margin-bottom:1.5rem;line-height:1.5}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.message-info,.message-success,.message-warning,.purchase-warning,.message-error,.purchase-error{padding:12px 16px;border-radius:8px;font-size:14px;line-height:1.5;margin:12px 0;border:1px solid;display:flex;align-items:flex-start;gap:8px}.message-error,.purchase-error{background:#d665651a;border-color:var(--error-red);color:var(--error-red)}.message-warning,.purchase-warning{background:#ff9f401a;border-color:#ff9f40;color:#ff9f40}.purchase-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.purchase-modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;width:90%;max-width:560px;max-height:90vh;overflow-y:auto;position:relative;animation:slideUp .3s ease-out;box-shadow:0 25px 70px #0009}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.purchase-modal-close{position:absolute;top:16px;right:16px;background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:8px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.purchase-modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.purchase-modal-content{padding:48px 40px 40px;text-align:center}.purchase-modal-header{margin-bottom:32px}.premium-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:linear-gradient(135deg,#ffd70026,#ffc10726);border:1px solid rgba(255,215,0,.3);border-radius:20px;color:gold;font-size:11px;font-weight:700;letter-spacing:.5px;margin-bottom:20px}.premium-badge svg{width:14px;height:14px}.purchase-modal h2{font-size:32px;font-weight:700;margin:0 0 12px;color:var(--text-active);line-height:1.2}.purchase-modal-subtitle{font-size:16px;color:var(--text-secondary);line-height:1.5;max-width:420px;margin:0 auto}.purchase-modal-pricing{background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-hover) 100%);border:1px solid var(--border-color);border-radius:16px;padding:28px 32px;margin:32px 0}.pricing-header{display:flex;align-items:center;justify-content:center;gap:24px}.price-tag{display:flex;align-items:flex-start;line-height:1;color:var(--text-active)}.price-currency{font-size:28px;font-weight:700;margin-top:6px}.price-amount{font-size:56px;font-weight:800;letter-spacing:-2px}.price-details{display:flex;flex-direction:column;align-items:flex-start;gap:4px}.price-period{font-size:15px;font-weight:600;color:var(--text-primary)}.price-note{font-size:13px;color:var(--text-secondary)}.purchase-modal-benefits{margin:32px 0}.benefits-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:480px;margin:0 auto}.benefit-item{display:flex;align-items:flex-start;gap:12px;text-align:left;padding:16px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;transition:all .2s}.benefit-item:hover{background:var(--bg-hover);transform:translateY(-2px)}.benefit-icon{font-size:24px;line-height:1;flex-shrink:0}.benefit-text{display:flex;flex-direction:column;gap:4px}.benefit-text strong{font-size:14px;font-weight:600;color:var(--text-active);line-height:1.2}.benefit-text span{font-size:12px;color:var(--text-secondary);line-height:1.3}.purchase-cta{font-size:16px;font-weight:600;padding:16px 32px!important;margin-top:8px}.purchase-modal-footer{margin-top:24px;padding-top:24px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:12px;font-size:13px}.footer-guarantee,.footer-secure{display:flex;align-items:center;justify-content:center;gap:8px;color:var(--text-secondary)}.footer-guarantee svg,.footer-secure svg{opacity:.6}.purchase-error,.purchase-warning{margin-bottom:16px;text-align:center}.purchase-signin-prompt{padding:0;margin-top:24px}.purchase-signin-prompt p{font-size:15px;color:var(--text-secondary);line-height:1.5;margin-bottom:20px;max-width:400px;margin-left:auto;margin-right:auto}.purchase-auth-buttons{display:flex;gap:12px;margin-bottom:16px}.purchase-auth-buttons button{flex:1}@media (max-width: 480px){.purchase-auth-buttons{flex-direction:column}.purchase-auth-buttons button{width:100%}}.purchase-note{margin:0;color:var(--text-tertiary);font-size:14px}.purchase-signin-note{margin-top:8px;color:var(--text-secondary);font-size:14px}.purchase-verification-section{margin:16px 0;display:flex;flex-direction:column;gap:8px;align-items:center}.purchase-resend-message{font-size:13px;padding:8px 12px;border-radius:6px;background:#58a6ff1a;color:var(--accent-blue);text-align:center}@media (max-width: 640px){.purchase-modal{max-width:95%;border-radius:16px}.purchase-modal-content{padding:32px 24px 28px}.purchase-modal h2{font-size:26px}.pricing-header{flex-direction:column;gap:12px}.price-details{align-items:center;text-align:center}.price-amount{font-size:48px}.benefits-grid{grid-template-columns:1fr;gap:12px}.benefit-item{padding:12px}}.loading-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;min-height:200px;gap:16px}.loading-text{margin:0;color:var(--text-muted);font-size:14px;font-weight:500}.spinner{border:3px solid var(--bg-tertiary);border-top-color:var(--accent-blue);border-radius:50%;animation:spin .8s linear infinite}.spinner-small{width:24px;height:24px;border-width:2px}.spinner-medium{width:32px;height:32px;border-width:3px}.spinner-large{width:48px;height:48px;border-width:4px}.sidebar{width:280px;height:100vh;background-color:var(--sidebar-bg);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden;transition:width .3s cubic-bezier(.4,0,.2,1)}.sidebar.collapsed{width:48px}.sidebar.collapsed .sidebar-header{padding:16px 8px}.sidebar.collapsed .overall-progress,.sidebar.collapsed .lessons-list{opacity:0;pointer-events:none;overflow:hidden}.sidebar-header{padding:16px;border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);transition:padding .3s ease}.sidebar-header-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.sidebar-collapse-btn{width:32px;height:32px;flex-shrink:0}.sidebar.collapsed .sidebar-header-top{justify-content:center}.overall-progress{flex:1;min-width:0;transition:opacity .2s ease}.progress-bar{height:6px;background-color:var(--bg-tertiary);border-radius:3px;overflow:hidden;position:relative}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-blue) 0%,var(--accent-green) 100%);border-radius:3px;transition:width .5s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.progress-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-text{margin-top:8px;font-size:10px;color:var(--text-secondary);font-weight:600;text-align:center;text-transform:uppercase;letter-spacing:.5px}.lessons-list{flex:1;overflow-y:auto;padding:8px 0 60px;transition:opacity .2s ease;min-height:0}.lesson-group{margin-bottom:4px}.lesson-group:last-child{margin-bottom:0}.lesson-item{display:flex;align-items:center;padding:12px 8px;transition:all .2s cubic-bezier(.4,0,.2,1);border-left:3px solid transparent;position:relative}.lesson-chevron{display:flex;align-items:center;justify-content:center;width:24px;height:24px;margin-right:8px;background:none;border:none;color:var(--text-secondary);cursor:pointer;border-radius:4px;padding:0;flex-shrink:0;transition:all .2s ease}.lesson-chevron:hover{background-color:#ffffff0d;color:var(--text-primary)}.lesson-clickable{display:flex;align-items:center;flex:1;cursor:pointer;min-width:0}.lesson-item:before{content:"";position:absolute;left:0;top:0;width:100%;height:100%;background:linear-gradient(90deg,rgba(88,166,255,.15) 0%,transparent 100%);opacity:0;transition:opacity .2s ease;pointer-events:none}.lesson-item:hover:not(.locked){background-color:var(--bg-hover)}.lesson-item:hover:not(.locked):before{opacity:1}.lesson-item.active{background:linear-gradient(90deg,rgba(88,166,255,.2) 0%,transparent 100%);border-left-color:var(--accent-blue);box-shadow:inset 0 1px #ffffff0d}.lesson-item.locked{cursor:not-allowed;opacity:.5}.lesson-number{width:28px;height:28px;border-radius:4px;background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--text-primary);margin-right:12px;flex-shrink:0}.lesson-item.active .lesson-number{background:var(--accent-blue-gradient);color:#fff}.lesson-item.completed .lesson-number{background-color:var(--success-green);color:var(--bg-primary)}.lesson-info{flex:1;display:flex;align-items:center;justify-content:space-between;gap:8px}.lesson-title{font-size:14px;color:var(--text-primary);font-weight:500}.lesson-item.active .lesson-title{color:var(--text-active)}.lock-icon{color:var(--lock-icon);flex-shrink:0}.check-icon{color:var(--success-green);flex-shrink:0}.progress-badge{font-size:11px;color:var(--text-secondary);background-color:var(--bg-tertiary);padding:2px 6px;border-radius:8px;font-weight:600}.lesson-item.active .progress-badge{background-color:var(--bg-primary);color:var(--accent-blue)}.exercises-list{background-color:var(--bg-primary);padding:4px 0 8px;border-left:3px solid var(--accent-blue);margin-left:20px}.exercise-item{display:flex;align-items:center;padding:8px 20px 8px 24px;cursor:pointer;transition:background-color .15s ease;gap:10px}.exercise-item:hover{background-color:var(--bg-hover)}.exercise-item.active{background-color:var(--bg-tertiary)}.exercise-item.active .exercise-title{color:var(--text-active);font-weight:500}.exercise-indicator{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.exercise-number{width:20px;height:20px;border-radius:50%;background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--text-secondary);border:2px solid var(--border-color)}.exercise-item.active .exercise-number{background:var(--accent-blue-gradient);border-color:var(--accent-blue);color:#fff}.exercise-check{color:var(--success-green)}.exercise-item.completed{opacity:.8}.exercise-title{font-size:13px;color:var(--text-primary);flex:1}.exercise-item.completed .exercise-title{color:var(--text-secondary)}.locked-exercises-message{background-color:var(--bg-primary);padding:24px 20px;margin-left:20px;border-left:3px solid var(--lock-icon);display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.locked-exercises-message .lock-icon{color:var(--lock-icon);opacity:.7}.locked-exercises-message p{font-size:13px;color:var(--text-secondary);margin:0;font-weight:500}.locked-exercises-message .unlock-button{margin-top:4px}.lessons-list::-webkit-scrollbar{width:10px}.lessons-list::-webkit-scrollbar-track{background:var(--bg-secondary)}.lessons-list::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:5px}.lessons-list::-webkit-scrollbar-thumb:hover{background:var(--border-color)}.upgrade-button{margin:16px 16px 8px;padding:12px 16px;font-size:14px}.sidebar.collapsed .upgrade-button{opacity:0;pointer-events:none}.explanation-panel{height:100%;background-color:var(--bg-primary);overflow-y:auto;border-right:1px solid var(--border-color);position:relative}.playground-toggle-btn{position:fixed;top:100px;right:40px;z-index:1;font-size:13px;box-shadow:0 2px 8px #0000001a}.explanation-content{padding:24px;line-height:1.6;max-width:800px;margin:0 auto}.explanation-content h1{font-size:28px;font-weight:600;color:var(--text-active);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.explanation-content h2{font-size:20px;font-weight:600;color:var(--text-active);margin:20px 0 10px}.explanation-content h3{font-size:16px;font-weight:600;color:var(--text-active);margin:16px 0 8px}.explanation-content p{font-size:14px;color:var(--text-primary);margin:0}.explanation-content p.text-content{margin:6px 0}.explanation-content p.text-content:first-child{margin-top:0}.explanation-content strong{color:var(--text-active);font-weight:600}.explanation-content code{background-color:var(--bg-tertiary);color:var(--warning-orange);padding:2px 6px;border-radius:3px;font-size:13px;font-family:Consolas,Monaco,Courier New,monospace}.explanation-content .code-block{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;padding:12px 16px;margin:8px 0;overflow-x:auto;position:relative}.explanation-content .code-block code{background:none;color:var(--text-primary);padding:0;display:block;white-space:pre;font-size:13px;line-height:1.5}.copy-code-btn{position:absolute;top:8px;right:8px;padding:6px;opacity:.4;z-index:1}.copy-code-btn:hover{opacity:1;background-color:#0006}.explanation-content li{font-size:14px;color:var(--text-primary);margin:6px 0 6px 20px}.explanation-content blockquote{background:linear-gradient(135deg,#58a6ff1a,#58a6ff0d);border-left:4px solid var(--accent-blue);margin:16px 0;padding:12px 16px;border-radius:4px;font-style:italic;color:var(--text-secondary)}.explanation-content blockquote p{margin:0;color:var(--text-secondary)}.explanation-content blockquote strong{color:var(--accent-blue);font-weight:600}.explanation-content blockquote code{background-color:#58a6ff26;color:var(--accent-blue)}.markdown-table{width:100%;border-collapse:collapse;margin:16px 0;font-size:14px;background-color:var(--bg-secondary);border-radius:6px;overflow:hidden;border:1px solid var(--border-color)}.markdown-table thead{background-color:var(--bg-tertiary)}.markdown-table th{padding:12px 16px;text-align:left;font-weight:600;color:var(--text-active);border-bottom:2px solid var(--border-color)}.markdown-table td{padding:10px 16px;color:var(--text-primary);border-bottom:1px solid var(--border-color)}.markdown-table tbody tr:last-child td{border-bottom:none}.markdown-table tbody tr:hover{background-color:var(--bg-hover)}.markdown-table code{font-size:12px}.lesson-explanation-collapsed{border-bottom:2px solid var(--border-color);padding-bottom:24px;margin-bottom:24px}.current-exercise{margin-top:0}.current-exercise:not(:first-child){margin-top:32px;padding-top:24px;border-top:2px solid var(--border-color)}.exercise-header h2{font-size:18px;font-weight:600;color:var(--text-active);margin:0 0 16px;display:flex;align-items:center;gap:12px}.exercise-badge{display:inline-flex;align-items:center;justify-content:center;background-color:var(--accent-blue);color:#fff;font-size:12px;font-weight:600;padding:4px 10px;border-radius:12px;min-width:fit-content}.exercise-instructions{font-size:15px;line-height:1.6;margin-bottom:16px}.exercise-hint{display:flex;gap:12px;padding:12px 16px;background-color:#4ec9b01a;border-left:3px solid var(--success-green);border-radius:4px;font-size:13px;color:var(--text-primary);margin-top:16px}.hint-icon{font-size:18px;flex-shrink:0}.exercise-hint strong{color:var(--success-green)}button.toggle-instructions-btn{min-width:140px;justify-content:flex-start}.hint-section,.solution-section{margin-top:16px}.toggle-solution-btn{min-width:140px;justify-content:flex-start}.solution-code{margin-top:12px;animation:slideDown .2s ease-out}.solution-code pre{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;margin:0;overflow-x:auto;max-height:400px;overflow-y:auto;position:relative}.copy-solution-btn{position:absolute;top:8px;right:8px;padding:6px;opacity:.4;z-index:1}.copy-solution-btn:hover{opacity:1;background-color:#0006}.solution-code code{color:var(--text-primary);font-size:14px;font-family:Consolas,Monaco,Courier New,monospace;line-height:1.8;display:block;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word;padding:16px}.solution-code pre::-webkit-scrollbar{width:8px;height:8px}.solution-code pre::-webkit-scrollbar-track{background:var(--bg-primary);border-radius:4px}.solution-code pre::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}.solution-code pre::-webkit-scrollbar-thumb:hover{background:var(--border-color)}.explanation-panel::-webkit-scrollbar{width:10px}.explanation-panel::-webkit-scrollbar-track{background:var(--bg-primary)}.explanation-panel::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:5px}.explanation-panel::-webkit-scrollbar-thumb:hover{background:var(--border-color)}.syntax-notes{margin-top:32px;background:linear-gradient(135deg,#4ec9b014,#5c93bb14);border:1px solid rgba(92,147,187,.3);border-left:4px solid var(--accent-blue);border-radius:8px;overflow:hidden}.syntax-notes-toggle{width:100%;display:flex;align-items:center;gap:10px;padding:14px 16px;background:transparent;border:none;color:var(--accent-blue);font-size:15px;cursor:pointer;transition:all .2s ease;text-align:left}.syntax-notes-toggle:hover{background:#5c93bb1a}.syntax-notes-icon{font-size:20px;flex-shrink:0}.syntax-notes-content{font-size:14px;line-height:1.6;padding:0 16px 16px;animation:slideDown .2s ease-out}.syntax-notes-content p{margin:8px 0;color:var(--text-primary)}.syntax-notes-content strong{color:var(--text-active)}.syntax-notes-content code{background-color:#0003;color:var(--warning-orange);padding:2px 6px;border-radius:3px;font-size:13px}.navigation-buttons-container{margin-top:32px;padding-top:24px;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;gap:12px}.code-block-wrapper{position:relative;margin:8px 0}.code-block-wrapper .code-block{margin:0}.expand-query-btn{position:absolute;top:8px;right:8px;padding:6px 8px;font-size:12px;opacity:.7}.expand-query-btn:hover{opacity:1;background:#ffffff1a;border-color:#fff3}.explanation-panel .inline-query-results{margin-top:12px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);overflow:hidden;width:100%;box-sizing:border-box}.explanation-panel .inline-results-container{display:flex;flex-direction:column;width:100%;box-sizing:border-box}.explanation-panel .results-tabs{display:flex;gap:4px;background:var(--bg-secondary);padding:8px 8px 0}.explanation-panel .results-tab{flex:1;padding:8px 12px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.explanation-panel .results-tab.active{color:var(--accent-blue);border-bottom-color:var(--accent-blue)}.explanation-panel .results-tab:hover:not(.active){color:var(--text-primary);background:var(--bg-hover)}.explanation-panel .results-content{padding:12px;background:var(--bg-primary);max-height:300px;overflow-y:auto}.explanation-panel .results-table-wrapper{width:100%;overflow-x:auto}.explanation-panel .results-table{width:100%;border-collapse:collapse;font-size:13px}.explanation-panel .results-table th{background:var(--bg-secondary);color:var(--text-active);font-weight:600;padding:8px 12px;text-align:left;border-bottom:2px solid var(--border-color);position:sticky;top:0;z-index:1}.explanation-panel .results-table td{padding:6px 12px;border-bottom:1px solid var(--border-color);color:var(--text-primary)}.explanation-panel .results-table tbody tr:hover{background:var(--bg-hover)}.explanation-panel .results-table tbody tr:last-child td{border-bottom:none}.explanation-panel .results-content::-webkit-scrollbar{width:8px;height:8px}.explanation-panel .results-content::-webkit-scrollbar-track{background:var(--bg-primary)}.explanation-panel .results-content::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}.explanation-panel .results-content::-webkit-scrollbar-thumb:hover{background:var(--border-color)}.lesson-animation-overlay{position:relative;cursor:pointer;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:24px;margin:16px 0;transition:all .2s}.lesson-animation-overlay:hover{border-color:var(--accent-blue);box-shadow:0 4px 12px #58a6ff33}.animation-locked-content{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px}.animation-locked-icon{font-size:48px;opacity:.6}.animation-locked-text{text-align:center;color:var(--text-secondary)}.animation-locked-text h3{margin:0 0 8px;color:var(--text-active);font-size:18px}.animation-locked-text p{margin:0;font-size:14px}.animation-locked-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#000000e0,#000000d1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;border-radius:8px;cursor:pointer;transition:all .3s ease;padding:12px}.animation-locked-overlay:hover{background:linear-gradient(135deg,#000000eb,#000000db)}.animation-locked-overlay:hover .unlock-button{background:var(--accent-blue);box-shadow:0 6px 24px #58a6ff66}.locked-content{display:flex;flex-direction:row;align-items:center;gap:12px;padding:8px 12px;text-align:left;transition:transform .3s ease}.lock-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff1f;border-radius:50%;color:#fff;flex-shrink:0}.lock-icon svg{width:16px;height:16px;filter:drop-shadow(0 2px 8px rgba(0,0,0,.3))}.locked-title{color:#fff;font-size:14px;font-weight:600;letter-spacing:-.01em;text-shadow:0 2px 4px rgba(0,0,0,.3);margin:0;line-height:1;white-space:nowrap;flex-shrink:0}.locked-subtitle{display:none}.unlock-button{display:inline-flex;align-items:center;gap:6px;background:#58a6fff2;color:#fff;border:none;border-radius:6px;padding:8px 16px;font-size:12px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #58a6ff59;flex-shrink:0;white-space:nowrap}.unlock-button svg{width:11px;height:11px}.unlock-button:active{transform:scale(.98)}.sql-editor{height:100%;display:flex;flex-direction:column;background-color:var(--editor-bg);border-bottom:1px solid var(--border-color)}.editor-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);height:44px}.editor-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--text-primary)}.editor-title svg{opacity:.7}.editor-actions{display:flex;align-items:center;gap:12px}.run-button{margin:2px 4px 2px 8px;box-shadow:0 2px 8px #58a6ff4d}.run-button:hover:not(:disabled){box-shadow:0 4px 12px #58a6ff66}.close-playground-button svg,.template-button svg{opacity:.8}.run-button-text{min-width:78px}.keyboard-hint{font-size:11px;opacity:.8;margin-left:4px;padding-left:8px;border-left:1px solid rgba(255,255,255,.2)}.editor-container{flex:1;overflow:hidden}.results-table{height:100%;display:flex;flex-direction:column;background-color:var(--bg-primary)}.results-tabs{display:flex;gap:4px;padding:8px 8px 0;background-color:var(--bg-primary);border-bottom:1px solid var(--border-color)}.results-tabs .tab{display:flex;align-items:center;gap:6px;padding:8px 12px;background-color:transparent;color:var(--text-secondary);border:none;border-radius:6px 6px 0 0;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;border-bottom:2px solid transparent}.results-tabs .tab:hover{background-color:var(--bg-hover);color:var(--text-primary)}.results-tabs .tab.active{background-color:var(--bg-secondary);color:var(--text-primary);border-bottom-color:var(--accent-blue)}.results-tabs .tab svg{flex-shrink:0;opacity:.7}.results-tabs .tab.active svg{opacity:1}.results-tabs .tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:18px;padding:0 6px;background-color:var(--bg-hover);color:var(--text-secondary);border-radius:10px;font-size:11px;font-weight:600}.results-tabs .tab.active .tab-count{background-color:#58a6ff26;color:var(--accent-blue)}.database-sub-tabs{display:flex;gap:4px;padding:8px 16px;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);overflow-x:auto}.database-sub-tab{display:flex;align-items:center;padding:6px 12px;background-color:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.database-sub-tab:hover{background-color:var(--bg-hover);color:var(--text-primary);border-color:var(--accent-blue)}.database-sub-tab.active{background-color:#58a6ff1a;color:var(--accent-blue);border-color:var(--accent-blue);font-weight:600}.database-sub-tabs::-webkit-scrollbar{height:6px}.database-sub-tabs::-webkit-scrollbar-track{background:var(--bg-secondary)}.database-sub-tabs::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:3px}.database-sub-tabs::-webkit-scrollbar-thumb:hover{background:var(--border-color)}.results-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);height:44px}.results-header.error{background-color:#f487711a}.results-header.success{background-color:var(--bg-secondary)}.results-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--text-primary)}.results-header.error .results-title{color:var(--error-red)}.results-title svg{opacity:.7}.results-header-right{display:flex;align-items:center;gap:12px}.validation-badge{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:4px;animation:fadeInScale .3s ease-out}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.validation-badge.correct{background-color:#2ebd8c26;color:var(--success-green);border:1px solid rgba(46,189,140,.3)}.validation-badge.incorrect{background-color:#f4877126;color:var(--error-red);border:1px solid rgba(244,135,113,.3)}.validation-badge svg{flex-shrink:0}.row-count{font-size:12px;color:var(--text-secondary);background-color:var(--bg-tertiary);padding:4px 8px;border-radius:3px}.results-content{flex:1;overflow:auto}.results-content .empty{display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-secondary);gap:12px;min-height:100%;padding:40px 20px;text-align:center}.results-content .empty p{margin:0;font-size:14px}.results-content .empty .hint{font-size:12px;opacity:.7}.results-content .error{padding:16px}.results-content .error pre{color:var(--error-red);background-color:#f487711a;padding:12px;border-radius:4px;border:1px solid rgba(244,135,113,.3);margin:0;font-size:13px;line-height:1.5;overflow-x:auto}.table-wrapper{overflow:auto;height:100%}table{width:100%;border-collapse:collapse;font-size:13px}thead{position:sticky;top:0;background-color:var(--bg-secondary);z-index:1}th{text-align:left;padding:10px 16px;font-weight:600;color:var(--text-active);border-bottom:2px solid var(--border-color);white-space:nowrap}td{padding:10px 16px;color:var(--text-primary);border-bottom:1px solid var(--border-color)}tbody tr:hover{background-color:var(--bg-hover)}tbody tr:last-child td{border-bottom:none}.null-value{color:var(--text-secondary);font-style:italic;opacity:.6}.results-content::-webkit-scrollbar,.table-wrapper::-webkit-scrollbar{width:10px;height:10px}.results-content::-webkit-scrollbar-track,.table-wrapper::-webkit-scrollbar-track{background:var(--bg-primary)}.results-content::-webkit-scrollbar-thumb,.table-wrapper::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:5px}.results-content::-webkit-scrollbar-thumb:hover,.table-wrapper::-webkit-scrollbar-thumb:hover{background:var(--border-color)}.app-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:16px 24px;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px #0003}.header-content{max-width:1600px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.app-header-content{display:flex;align-items:center;justify-content:space-between}.header-logo{margin:0;font-size:20px;font-weight:800;color:var(--text-active);background:var(--accent-blue-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:flex;align-items:center;gap:8px}.header-logo-icon{color:var(--accent-blue);-webkit-text-fill-color:currentColor;flex-shrink:0}.header-actions{display:flex;align-items:center;gap:12px}.header-sign-in-btn{padding:8px 20px;background:var(--accent-green-gradient);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #2ebd8c4d}.header-sign-in-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #2ebd8c66}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:10px;padding:6px 12px 6px 6px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;transition:all .2s}.user-menu-trigger:hover{background:var(--bg-hover);border-color:var(--accent-blue)}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-blue-gradient);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px}.user-email{font-size:14px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;z-index:99}.user-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:240px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 8px 24px #0006;z-index:100;animation:dropdownSlide .2s ease-out}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.user-menu-item{padding:12px 16px;display:block;width:100%;text-align:left}.user-menu-info{cursor:default}.user-menu-label{font-size:11px;text-transform:uppercase;color:var(--text-secondary);font-weight:600;letter-spacing:.5px;margin-bottom:4px}.user-menu-email{font-size:14px;color:var(--text-primary);word-break:break-all}.user-menu-divider{height:1px;background:var(--border-color);margin:4px 0}.user-menu-button{background:none;border:none;color:var(--text-primary);font-size:14px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:10px}.user-menu-button:hover{background:var(--bg-hover);color:var(--accent-green)}@media (max-width: 768px){.header-logo{font-size:18px}.header-logo-icon{width:18px;height:18px}.user-email{display:none}.user-menu-trigger{padding:6px}}.verification-banner{background:linear-gradient(135deg,#c9a96126,#a0495e26);border:1px solid var(--gold);border-left:4px solid var(--gold);padding:16px 20px;margin-bottom:20px;border-radius:8px;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.verification-content{display:flex;align-items:center;gap:16px}.verification-icon{font-size:24px;flex-shrink:0}.verification-text{flex:1;display:flex;flex-direction:column;gap:4px}.verification-text strong{color:var(--text-active);font-size:15px}.verification-text span{color:var(--text-secondary);font-size:13px;line-height:1.4}.verification-resend-btn{padding:8px 16px;background:var(--accent-maroon);border:none;border-radius:6px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s}.verification-resend-btn:hover:not(:disabled){background:var(--accent-maroon-hover);transform:translateY(-1px)}.verification-resend-btn:disabled{opacity:.6;cursor:not-allowed}.verification-message{margin-top:12px;padding:8px 12px;background:#5fb8851a;border:1px solid var(--success-green);border-radius:6px;color:var(--success-green);font-size:13px}@media (max-width: 768px){.verification-content{flex-direction:column;align-items:flex-start}.verification-resend-btn{width:100%}}.success-toast{position:fixed;top:20px;right:20px;z-index:1000;transform:translate(400px);opacity:0;transition:all .3s cubic-bezier(.68,-.55,.265,1.55)}.success-toast.visible{transform:translate(0);opacity:1}.toast-content{background:linear-gradient(135deg,#2ebd8c,#1fa070);padding:16px 20px;border-radius:12px;box-shadow:0 10px 40px #2ebd8c66,0 0 0 1px #ffffff1a;display:flex;align-items:center;gap:12px;min-width:300px;animation:bounce .6s cubic-bezier(.68,-.55,.265,1.55)}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.toast-icon{flex-shrink:0;animation:checkmark .6s ease-in-out}@keyframes checkmark{0%{transform:scale(0) rotate(-45deg)}50%{transform:scale(1.2) rotate(10deg)}to{transform:scale(1) rotate(0)}}.toast-message{flex:1;color:#fff}.toast-title{font-size:16px;font-weight:700;margin-bottom:4px;text-shadow:0 1px 2px rgba(0,0,0,.1)}.toast-text{font-size:14px;opacity:.95}.confetti{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:999}.confetti-piece{position:absolute;width:8px;height:8px;top:-10px;opacity:0;animation:confetti-fall 2s ease-out forwards}@keyframes confetti-fall{0%{opacity:1;top:-10px;transform:translate(0) rotate(0)}to{opacity:0;top:100vh;transform:translate(calc(100vw * (var(--random, .5) - .5))) rotate(720deg)}}.app{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden}.app-body{display:flex;flex:1;overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:20px;gap:20px}.main-content>div:first-child{display:flex;gap:20px;flex:1;overflow:hidden}.left-panel{width:35%;min-width:300px;max-width:600px;overflow:hidden}.lesson-only-view .left-panel{width:100%;max-width:1200px;margin:0 auto}.right-panels{flex:1;display:flex;flex-direction:column;overflow:hidden;gap:20px}.editor-panel,.results-panel{flex:1;overflow:hidden;min-height:0}.loading-container{display:flex;align-items:center;justify-content:center;width:100%;height:100%;min-height:400px}@media (max-width: 1200px){.left-panel{width:40%}}@media (max-width: 900px){.main-content{flex-direction:column}.left-panel{width:100%;height:30vh;max-width:none}.right-panels{height:70vh}}.feature-icon-wrapper{display:inline-flex;align-items:center;justify-content:center;position:relative;width:100%;height:100%}.feature-icon-wrapper svg{display:block;width:100%;height:100%;position:relative;z-index:1}.feature-icon-wrapper:before{content:"";position:absolute;top:-10%;right:-10%;bottom:-10%;left:-10%;border-radius:50%;opacity:.3;filter:blur(6px);z-index:0}.gradient-blue{background:linear-gradient(135deg,#58a6ff,#1f6feb);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.gradient-blue svg{fill:url(#icon-gradient-blue);filter:drop-shadow(0 1px 4px rgba(88,166,255,.4))}.gradient-blue:before{background:linear-gradient(135deg,#58a6ff,#1f6feb)}.gradient-gold{background:linear-gradient(135deg,gold,#ff9f40);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.gradient-gold svg{fill:url(#icon-gradient-gold);filter:drop-shadow(0 1px 4px rgba(255,215,0,.4))}.gradient-gold:before{background:linear-gradient(135deg,gold,#ff9f40)}.gradient-green{background:linear-gradient(135deg,#2ebd8c,#1fa070);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.gradient-green svg{fill:url(#icon-gradient-green);filter:drop-shadow(0 1px 4px rgba(46,189,140,.4))}.gradient-green:before{background:linear-gradient(135deg,#2ebd8c,#1fa070)}.gradient-pink{background:linear-gradient(135deg,#ff6b9d,#c94b78);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.gradient-pink svg{fill:url(#icon-gradient-pink);filter:drop-shadow(0 1px 4px rgba(255,107,157,.4))}.gradient-pink:before{background:linear-gradient(135deg,#ff6b9d,#c94b78)}.gradient-purple{background:linear-gradient(135deg,#a78bfa,#7c3aed);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.gradient-purple svg{fill:url(#icon-gradient-purple);filter:drop-shadow(0 1px 4px rgba(167,139,250,.4))}.gradient-purple:before{background:linear-gradient(135deg,#a78bfa,#7c3aed)}.gradient-blue-green{background:linear-gradient(135deg,#58a6ff,#2ebd8c);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.gradient-blue-green svg{fill:url(#icon-gradient-blue-green);filter:drop-shadow(0 1px 4px rgba(88,166,255,.4))}.gradient-blue-green:before{background:linear-gradient(135deg,#58a6ff,#2ebd8c)}.btn-text,.btn-icon,.btn-outline-blue,.btn-outline,.btn-secondary,.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:background .3s ease,box-shadow .3s ease,transform .3s ease,color .3s ease,border-color .3s ease,opacity .3s ease;text-decoration:none;white-space:nowrap;-webkit-user-select:none;user-select:none}.btn-text:focus,.btn-icon:focus,.btn-outline-blue:focus,.btn-outline:focus,.btn-secondary:focus,.btn-primary:focus{outline:2px solid var(--accent-blue);outline-offset:2px}.btn-text:disabled,.btn-icon:disabled,.btn-outline-blue:disabled,.btn-outline:disabled,.btn-secondary:disabled,.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn-text svg,.btn-icon svg,.btn-outline-blue svg,.btn-outline svg,.btn-secondary svg,.btn-primary svg{flex-shrink:0}.btn-primary{background:var(--accent-blue-gradient);color:#fff;box-shadow:0 2px 8px #58a6ff4d}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#409eff,#1f6feb);box-shadow:0 4px 12px #58a6ff66}.btn-primary:active:not(:disabled){transform:scale(.98);box-shadow:0 2px 6px #58a6ff4d}.btn-secondary{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.btn-secondary:active:not(:disabled){transform:scale(.98)}.btn-outline{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);position:relative;overflow:hidden}.btn-outline:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(88,166,255,.1),transparent);transition:left .5s}.btn-outline:hover:not(:disabled){background:#58a6ff14;border-color:var(--accent-blue);color:var(--accent-blue)}.btn-outline:hover:not(:disabled):before{left:100%}.btn-outline:active:not(:disabled){transform:scale(.98)}.btn-outline-blue{background:#58a6ff1a;color:var(--accent-blue);border:1px solid var(--accent-blue)}.btn-outline-blue:hover:not(:disabled){background:#58a6ff33}.btn-outline-blue:active:not(:disabled){transform:scale(.98)}.btn-icon{background:#ffffff0d;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:8px;padding:8px;gap:0}.btn-icon:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent-blue)}.btn-text{background:none;color:var(--accent-blue);border:none;padding:8px 12px;font-weight:500}.btn-text:hover:not(:disabled){color:var(--accent-blue-hover);text-decoration:underline}.btn-text:active:not(:disabled){transform:scale(.98)}.btn-sm{padding:8px 12px;font-size:14px;border-radius:6px}.btn-md{padding:10px 20px;font-size:14px;border-radius:8px}.btn-lg{padding:16px 32px;font-size:18px;border-radius:12px}.btn-primary:not(.btn-sm):not(.btn-md):not(.btn-lg),.btn-secondary:not(.btn-sm):not(.btn-md):not(.btn-lg),.btn-outline:not(.btn-sm):not(.btn-md):not(.btn-lg),.btn-outline-blue:not(.btn-sm):not(.btn-md):not(.btn-lg){padding:12px 24px;font-size:16px}.btn-full{width:100%}.btn-loading{position:relative;pointer-events:none}.btn-loading:after{content:"";position:absolute;width:16px;height:16px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.message-info,.message-success,.message-warning,.message-error{padding:12px 16px;border-radius:8px;font-size:14px;line-height:1.5;margin:12px 0;border:1px solid;display:flex;align-items:flex-start;gap:8px}.message-error{background:#d665651a;border-color:var(--error-red);color:var(--error-red)}.message-warning{background:#ff9f401a;border-color:#ff9f40;color:#ff9f40}.message-success{background:#2ebd8c1a;border-color:var(--success-green);color:var(--success-green)}.message-info{background:#58a6ff1a;border-color:var(--accent-blue);color:var(--accent-blue)}.landing-page{min-height:100vh;width:100%;background:var(--bg-primary);color:var(--text-primary);overflow-x:hidden;overflow-y:auto;position:relative;height:auto!important}.landing-page:before{content:"";position:absolute;top:0;left:0;right:0;height:800px;background:radial-gradient(circle at 50% 0%,rgba(88,166,255,.08) 0%,transparent 50%);pointer-events:none;z-index:0}.landing-header{position:sticky;top:0;background:rgba(var(--bg-primary-rgb),.95);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);z-index:100;padding:20px 0;box-shadow:0 1px 3px #0000000d}.header-content{max-width:1200px;margin:0 auto;padding:0 32px;display:flex;align-items:center;justify-content:space-between}.logo{font-size:22px;font-weight:800;color:var(--text-active);background:var(--accent-blue-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:flex;align-items:center;gap:8px}.logo-icon{color:var(--accent-blue);-webkit-text-fill-color:currentColor;flex-shrink:0}.header-nav{display:flex;align-items:center;gap:16px}.hero{max-width:1200px;margin:0 auto;padding:100px 32px 80px;text-align:center;position:relative;z-index:1}.hero-content{max-width:780px;margin:0 auto}.hero h1{font-size:64px;font-weight:800;line-height:1.1;margin:0 0 24px;color:var(--text-active);letter-spacing:-2px;background:linear-gradient(135deg,var(--text-active) 0%,var(--accent-blue) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sparkle-title{position:relative;display:inline-block;background:linear-gradient(90deg,var(--text-active) 0%,var(--accent-blue) 25%,#9d4edd 50%,var(--accent-blue) 75%,var(--text-active) 100%);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:sparkle-gradient 4s ease-in-out infinite}.sparkle-title:before{content:"Learn SQL the Easy Way";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,transparent 40%,rgba(255,255,255,.8) 50%,transparent 60%,transparent 100%);background-size:200% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 3s ease-in-out infinite;z-index:1}@keyframes sparkle-gradient{0%,to{background-position:0% center}50%{background-position:100% center}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}.hero-subtitle{font-size:21px;line-height:1.6;color:var(--text-muted);max-width:620px;margin:0 auto 48px;font-weight:400}.hero-cta{display:flex;gap:20px;justify-content:center;align-items:center;margin-bottom:32px;flex-wrap:wrap}.landing-premium-btn{position:relative;padding:18px 40px;font-size:18px;font-weight:700;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;background:linear-gradient(135deg,#2ebd8c,#1fa070);color:#fff;box-shadow:0 2px 8px #2ebd8c4d;overflow:hidden}.landing-premium-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.landing-premium-btn:hover:not(:disabled){background:linear-gradient(135deg,#36d399,#22b378);box-shadow:0 4px 12px #2ebd8c66}.landing-premium-btn:hover:not(:disabled):before{left:100%}.landing-premium-btn:active:not(:disabled){transform:scale(.98);box-shadow:0 2px 6px #2ebd8c4d}.premium-btn-content{display:flex;align-items:center;gap:10px;position:relative;z-index:1;justify-content:center}.premium-btn-content svg{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.hero-note{font-size:15px;color:var(--text-secondary);opacity:.99;margin:0;display:flex;align-items:center;justify-content:center;gap:20px}.features{max-width:1200px;margin:0 auto;padding:60px 32px;position:relative;z-index:1}.features h2{text-align:center;font-size:42px;font-weight:800;margin:0 0 16px;color:var(--text-active);letter-spacing:-1px}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}.feature-card{text-align:left;padding:32px 28px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.feature-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent-blue-gradient);transform:scaleX(0);transform-origin:left;transition:transform .3s cubic-bezier(.4,0,.2,1)}.feature-card:hover{transform:translateY(-8px);box-shadow:0 20px 40px #0000001f;border-color:#58a6ff80;background:var(--bg-hover)}.feature-card:hover:before{transform:scaleX(1)}.feature-card:hover .feature-icon{transform:scale(1.1)}.feature-header{display:flex;align-items:center;gap:16px;margin-bottom:12px}.feature-icon{width:48px;height:48px;flex-shrink:0;display:inline-block;transition:transform .3s cubic-bezier(.4,0,.2,1)}.feature-icon svg{width:100%;height:100%}.feature-card h3{font-size:19px;font-weight:700;margin:0;color:var(--text-active)}.feature-card p{font-size:15px;line-height:1.6;color:var(--text-muted);margin:0}.faq{max-width:800px;margin:0 auto;padding:80px 32px;position:relative;z-index:1}.faq h2{text-align:center;font-size:42px;font-weight:800;margin:0 0 48px;color:var(--text-active);letter-spacing:-1px}.faq-list{display:flex;flex-direction:column;gap:12px}.faq-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.faq-item:hover{border-color:#58a6ff4d}.faq-item.open{border-color:#58a6ff80;background:var(--bg-hover)}.faq-item.open .faq-icon{transform:rotate(180deg)}.faq-item.open .faq-answer{max-height:500px;padding:0 24px 24px;opacity:1}.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:24px;background:transparent;border:none;text-align:left;cursor:pointer;font-size:17px;font-weight:600;color:var(--text-active);transition:color .2s ease}.faq-question:hover{color:var(--accent-blue)}.faq-question span{flex:1}.faq-icon{flex-shrink:0;color:var(--accent-blue);transition:transform .3s cubic-bezier(.4,0,.2,1)}.faq-answer{max-height:0;padding:0 24px;opacity:0;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.faq-answer p{margin:0;font-size:15px;line-height:1.7;color:var(--text-muted)}.pricing{max-width:650px;margin:80px auto 100px;padding:0 32px;text-align:center;position:relative;z-index:1}.pricing h2{font-size:42px;font-weight:800;margin:0 0 48px;color:var(--text-active);letter-spacing:-1px}.pricing-card{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:24px;padding:56px 48px 48px;position:relative;box-shadow:0 16px 48px #00000026;transition:all .3s cubic-bezier(.4,0,.2,1)}.pricing-card:hover{transform:translateY(-8px);box-shadow:0 24px 64px #0003;border-color:#58a6ff80}.pricing-badge{position:absolute;top:-16px;left:50%;transform:translate(-50%);background:var(--accent-blue-gradient);color:#fff;padding:8px 24px;border-radius:24px;font-size:13px;font-weight:700;letter-spacing:1px;box-shadow:0 6px 16px #58a6ff66;text-transform:uppercase}.pricing-price{display:flex;align-items:flex-start;justify-content:center;margin-bottom:16px}.price-currency{font-size:36px;font-weight:800;margin-top:12px;color:var(--accent-blue)}.price-amount{font-size:84px;font-weight:900;line-height:1;letter-spacing:-3px;background:var(--accent-blue-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.pricing-subtitle{font-size:17px;color:var(--text-secondary);margin:0 0 40px;font-weight:500}.pricing-features{list-style:none;margin:0 0 40px;text-align:left;background:var(--bg-tertiary);border-radius:12px;padding:24px 28px}.pricing-features li{padding:14px 0;font-size:16px;color:var(--text-primary);border-bottom:1px solid var(--border-color);display:flex;align-items:center;font-weight:500}.pricing-features li:before{content:"✓";color:var(--success-green);font-weight:700;font-size:18px;margin-right:12px}.pricing-features li:last-child{border-bottom:none;padding-bottom:0}.pricing-features li:first-child{padding-top:0}.pricing-note{font-size:14px;color:var(--text-secondary);margin:20px 0 0}.landing-footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:24px 32px;text-align:center}.footer-text{opacity:.5}.footer-content{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:12px}.footer-content p{margin:0;font-size:13px;color:var(--text-muted)}.footer-links{display:flex;align-items:center;gap:12px;font-size:12px}.footer-links a{color:var(--text-secondary);text-decoration:none;transition:color .2s ease;opacity:.7}.footer-links a:hover{opacity:1}.footer-separator{color:var(--border-color);-webkit-user-select:none;user-select:none}@media (max-width: 768px){.footer-links{flex-direction:column;gap:8px}.footer-separator{display:none}}@media (max-width: 1024px){.features-grid{grid-template-columns:repeat(2,1fr);gap:20px}}@media (max-width: 768px){.hero{padding:60px 24px}.hero h1{font-size:44px;letter-spacing:-1px}.sparkle-title:before{content:"Learn SQL the Easy Way"}.hero-subtitle{font-size:18px}.hero-cta{flex-direction:column;width:100%;gap:12px}.hero-cta button{width:100%}.landing-premium-btn{padding:16px 32px;font-size:17px}.hero-note{flex-direction:column;gap:8px}.features{padding:48px 24px}.features h2{font-size:32px;margin-bottom:32px}.features-grid{grid-template-columns:1fr;gap:16px}.feature-card{padding:28px 24px}.faq{padding:60px 24px}.faq h2{font-size:32px}.faq-question{font-size:16px;padding:20px}.pricing{margin:60px auto 80px}.pricing h2{font-size:32px}.pricing-card{padding:48px 32px 40px}.price-amount{font-size:68px}.pricing-features{padding:20px 24px}}@media (max-width: 480px){.landing-header{padding:16px 0}.header-content{padding:0 20px}.logo{font-size:18px}.hero{padding:48px 20px}.hero h1{font-size:36px}.sparkle-title:before{content:"Learn SQL the Easy Way"}.hero-subtitle{font-size:17px}.header-nav{gap:8px}.features{padding:40px 20px}.features h2{font-size:28px}.feature-icon{width:40px;height:40px}.feature-header{gap:12px}.faq{padding:48px 20px}.faq h2{font-size:28px}.faq-question{font-size:15px;padding:18px}.faq-answer p{font-size:14px}.pricing{padding:0 20px}.pricing-card{padding:40px 24px 32px}.price-amount{font-size:56px}}.password-reset-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:20px}.password-reset-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:40px;width:90%;max-width:440px;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease-out}.password-reset-card h1{margin:0 0 8px;color:var(--text-active);font-size:28px;font-weight:600}.password-reset-subtitle{margin:0 0 32px;color:var(--text-secondary);font-size:15px}.password-reset-back{margin-top:24px;text-align:center}.password-reset-back button{background:none;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;padding:8px 12px;transition:color .2s}.password-reset-back button:hover{color:var(--accent-blue)}.auth-callback-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg-primary)}.auth-callback-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:48px 32px;max-width:600px;width:100%;text-align:center;animation:slideUp .4s ease-out}.auth-icon{width:96px;height:96px;margin:0 auto 24px;display:flex;align-items:center;justify-content:center;border-radius:50%;animation:scaleIn .5s ease-out .2s both}.auth-icon.success{background:#22c55e1a;color:#22c55e}.auth-icon.error{background:#ef44441a;color:#ef4444}.auth-icon.loading{background:#58a6ff1a}.auth-callback-card h1{font-size:32px;font-weight:700;margin:0 0 16px;color:var(--text-active)}.auth-message{font-size:16px;color:var(--text-secondary);line-height:1.6;margin:0 0 32px}.auth-details{text-align:left;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:24px;margin:0 0 24px}.auth-details h3{font-size:18px;font-weight:600;margin:0 0 16px;color:var(--text-active)}.auth-details ul{list-style:none;padding:0;margin:0}.auth-details li{font-size:15px;color:var(--text-primary);padding:8px 0;line-height:1.5}.auth-actions{display:flex;gap:12px;justify-content:center;margin:24px 0 16px}@media (max-width: 640px){.auth-callback-card{padding:32px 24px}.auth-callback-card h1{font-size:24px}.auth-actions{flex-direction:column}.primary-button{width:100%}}.payment-result-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg-primary)}.payment-result-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:48px 32px;max-width:600px;width:100%;text-align:center;animation:slideUp .4s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.payment-icon{width:96px;height:96px;margin:0 auto 24px;display:flex;align-items:center;justify-content:center;border-radius:50%;animation:scaleIn .5s ease-out .2s both}@keyframes scaleIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.payment-icon.success{background:#22c55e1a;color:#22c55e}.payment-icon.cancel{background:#ef44441a;color:#ef4444}.payment-result-card h1{font-size:32px;font-weight:700;margin:0 0 16px;color:var(--text-active)}.payment-message{font-size:16px;color:var(--text-secondary);line-height:1.6;margin:0 0 32px}.payment-details{text-align:left;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:24px;margin:0 0 24px}.payment-details h3{font-size:18px;font-weight:600;margin:0 0 16px;color:var(--text-active)}.payment-details ul{list-style:none;padding:0;margin:0}.payment-details li{font-size:15px;color:var(--text-primary);padding:8px 0;line-height:1.5}.session-id{font-size:13px;color:var(--text-secondary);font-family:monospace;margin:16px 0;padding:8px 12px;background:var(--bg-primary);border-radius:6px;word-break:break-all}.payment-actions{display:flex;gap:12px;justify-content:center;margin:24px 0 16px}.primary-button{padding:14px 32px;font-size:16px;font-weight:600;color:#fff;background:var(--accent-blue-gradient);border:none;border-radius:10px;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #58a6ff66}.primary-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #58a6ff80}.primary-button:active{transform:translateY(0)}.secondary-button{padding:14px 32px;font-size:16px;font-weight:600;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;cursor:pointer;transition:all .3s}.secondary-button:hover{background:var(--bg-hover);border-color:var(--accent-blue)}.redirect-notice{font-size:14px;color:var(--text-secondary);margin-top:16px}.support-link{display:inline-block;margin-top:16px;color:var(--accent-blue);text-decoration:none;font-size:14px;transition:opacity .2s}.support-link:hover{opacity:.8;text-decoration:underline}@media (max-width: 640px){.payment-result-card{padding:32px 24px}.payment-result-card h1{font-size:24px}.payment-actions{flex-direction:column}.primary-button,.secondary-button{width:100%}}.legal-page{min-height:100vh;background:var(--bg-primary);color:var(--text-primary)}.legal-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:24px 32px}.legal-header-content{max-width:800px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.legal-logo{font-size:20px;font-weight:800;color:var(--text-active);text-decoration:none;background:var(--accent-blue-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transition:opacity .2s ease}.legal-logo:hover{opacity:.8}.legal-content{max-width:800px;margin:0 auto;padding:48px 32px 64px}.legal-content h1{font-size:36px;font-weight:800;margin:0 0 16px;color:var(--text-active)}.legal-last-updated{font-size:14px;color:var(--text-muted);margin-bottom:32px}.legal-content h2{font-size:24px;font-weight:700;margin:32px 0 16px;color:var(--text-active)}.legal-content h3{font-size:18px;font-weight:600;margin:24px 0 12px;color:var(--text-secondary)}.legal-content p{font-size:15px;line-height:1.7;color:var(--text-muted);margin:0 0 16px}.legal-content ul,.legal-content ol{font-size:15px;line-height:1.7;color:var(--text-muted);margin:0 0 16px;padding-left:24px}.legal-content li{margin-bottom:8px}.legal-content strong{color:var(--text-primary);font-weight:600}.legal-content a{color:var(--accent-blue);text-decoration:none}.legal-content a:hover{text-decoration:underline}@media (max-width: 768px){.legal-header{padding:20px 24px}.legal-content{padding:32px 24px 48px}.legal-content h1{font-size:28px}.legal-content h2{font-size:20px}.legal-content h3{font-size:16px}.legal-content p,.legal-content ul,.legal-content ol{font-size:14px}}:root{--bg-primary: #0d1117;--bg-secondary: #161b22;--bg-tertiary: #21262d;--bg-hover: #30363d;--border-color: #30363d;--text-primary: #e6edf3;--text-secondary: #7d8590;--text-active: #ffffff;--accent-blue: #58a6ff;--accent-blue-hover: #1f6feb;--accent-blue-gradient: linear-gradient(135deg, #58a6ff 0%, #1f6feb 100%);--accent-green: #2ebd8c;--accent-green-hover: #1fa070;--accent-green-gradient: linear-gradient(135deg, #2ebd8c 0%, #1fa070 100%);--success-green: #2ebd8c;--success-gradient: linear-gradient(135deg, #2ebd8c 0%, #1fa070 100%);--warning-orange: #d29922;--error-red: #f85149;--editor-bg: #0d1117;--sidebar-bg: #161b22;--panel-border: #30363d;--lock-icon: #7d8590;--gold: #d29922;--blue-soft: #388bfd}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary)}code{font-family:Consolas,Monaco,Courier New,monospace}#root{width:100%;min-height:100vh}.app{height:100vh;overflow:hidden}
